4. 镜像升级
下面以Android系统为例介绍如何升级镜像。
在Android主机端,通过HMDML C++接口升级固件镜像。
4.1. 升级前操作
在主机端,需要创建一个目录用于存放固件升级程序相关文件,并完成文件准备工作。以下示例以 upgrade_firmware 为目录名。该目录需包含以下内容:
镜像升级源码文件:参考
hm_fw_upgrade_example.c示例代码,完成镜像升级源码文件,并命名为firmware_upgrade.cpp。示例位于驱动安装包中
/path/to/houmo-drv-xh2/hal/export/samples目录下,示例详情参看 示例参数说明。构建脚本:参见 创建构建脚本。
编译脚本:参见 创建编译脚本。
头文件:从系统软件包
/path/to/houmo-drv-xh2/hal/export/include目录复制hm_sys.h和hm_api.h到该目录。
4.1.1. 创建构建脚本
镜像升级前,用户需创建一个 CMake 构建脚本,用于在主机端编译生成可执行文件。示例文件名为 CMakeLists.txt,主要操作如下:
设置 CMake 工程信息与 C++ 标准。
指定 CMake 最低版本和工具链文件。
设置 C++ 标准为 C++17,并开启调试信息。
配置 Android 平台信息。
ANDROID_NDK:替换为主机端实际 NDK 安装路径。ANDROID_PLATFORM:指定 Android API 版本,例如 android-24。ANDROID_ABI:指定目标架构,例如 arm64-v8a。设置 Android STL 为共享库
c++_shared。
设置 HAL 库及头文件路径:
HAL_LIBRARY:替换为主机端驱动动态库libhal_xh2a.so的路径。该库位于驱动安装包中houmo-drv-xh2_<release>_android_$arch/houmo-drv-xh2/hal/lib下。通过
include_directories指定头文件路径,例如工程通用头文件${CMAKE_BINARY_DIR}/../../common和 Android 系统头文件${ANDROID_NDK}/sysroot/usr/include。
添加可执行文件并链接库。
通过
add_executable设置输出可执行文件名。通过
target_link_libraries链接 HAL 动态库,实现驱动接口调用。
完整示例如下,示例展示关键步骤代码,仅供参考,不可以直接拷贝运行。
cmake_minimum_required(VERSION 3.16)
set(CMAKE_TOOLCHAIN_FILE ${ANDROID_NDK}/build/cmake/android.toolchain.cmake)
project(IpuTest)
# 设置C++标准
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g")
# Android特定配置 - 需通过命令行传入ANDROID_NDK路径
if(NOT ANDROID_NDK)
message(FATAL_ERROR "请通过-DANDROID_NDK=指定NDK路径")
endif()
# 设置Android平台和架构
if(NOT ANDROID_PLATFORM)
set(ANDROID_PLATFORM android-24) # 最低支持Android 7.0
endif()
if(NOT ANDROID_ABI)
set(ANDROID_ABI arm64-v8a) # 默认编译ARM64架构
endif()
# Android平台配置
set(ANDROID_STL c++_shared) # 使用共享STL
set(ANDROID_USE_LEGACY_TOOLCHAIN_FILE FALSE)
# 设置库文件名称和搜索路径(Android平台)
set(HAL_LIBRARY_NAMES hal_xh2a)
set(LIB_SEARCH_PATHS
${CMAKE_CURRENT_SOURCE_DIR}/../lib/android/${ANDROID_ABI}/ # 按架构区分的库路径
${CMAKE_CURRENT_SOURCE_DIR}/../lib/android/ # 通用Android库路径
)
set(CMAKE_FIND_LIBRARY_SUFFIXES .so .a) # Android常用库后缀
# 直接指定库文件绝对路径,替换所有 find_library 相关代码
set(HAL_LIBRARY /path/to/houmo-drv-xh2/hal/lib/libhal_xh2a.so)
if(NOT EXISTS ${HAL_LIBRARY})
message(FATAL_ERROR "HAL库不存在:${HAL_LIBRARY}")
endif()
message(STATUS "找到HAL库: ${HAL_LIBRARY}")
# 包含头文件目录
include_directories(
${CMAKE_BINARY_DIR}/../../common
${ANDROID_NDK}/sysroot/usr/include # Android系统头文件
)
# 添加可执行文件
add_executable(firmware_upgrade firmware_upgrade.cpp)
# 链接库文件
target_link_libraries(firmware_upgrade PRIVATE ${HAL_LIBRARY})
4.1.2. 创建编译脚本
在主机端,需要创建一个用于编译固件升级示例程序的 shell 脚本,并保存为 .sh 文件,例如 compile.sh。主要内容如下:
设置编译目录。在示例中,将编译产物输出到
build_android目录。示例中用户需根据实际环境修改变量值:
NDK_PATH:主机端 Android NDK 的实际安装路径。HOUMO_SDK_PATH:主机端后摩驱动路径,通常位于驱动安装包中houmo-drv-xh2_<release>_android_$arch/houmo-drv-xh2目录下。ANDROID_ABI:目标架构,如arm64-v8a。ANDROID_PLATFORM:Android平台版本,如android-27。
执行 CMake 生成 Makefile,并通过 Make 编译生成可执行文件。
完整示例如下,示例展示关键步骤代码,仅供参考,不可以直接拷贝运行。
#!/bin/bash
# 配置编译目录
BUILD_DIR=build_android
rm -rf $BUILD_DIR
mkdir -p $BUILD_DIR
cd $BUILD_DIR
# 关键:指定 NDK 路径(替换为你的实际 NDK 路径)
NDK_PATH="/path/to/android-ndk-r27c" # 例如:~/Android/Sdk/ndk/r27d
HOUMO_SDK_PATH="/home/useradmin/wsy/houmo-drv-xh2/houmo-drv-xh2/"
ANDROID_ABI="arm64-v8a"
ANDROID_PLATFORM="android-27"
# 执行 cmake 生成 Makefile(参数必须写在同一行,用空格分隔)
cmake --fresh .. \
-DANDROID_NDK=$NDK_PATH \
-DANDROID_PLATFORM=android-27 \
-DANDROID_ABI=arm64-v8a
# 编译(-j4 表示使用 4 线程加速)
make -j4
# 回到原目录
cd ..
4.2. 升级操作
镜像升级主要步骤如下:
完成镜像升级前准备。
完成 升级前操作。
编译生成可执行文件。在主机端执行以下命令,生成可执行文件:
cd upgrade_firmware chmod +x compile.sh ./compile.sh
编译成功后,会在编译脚本中指定的输出目录中生成可执行文件。示例中,该目录为
build_android,可执行文件名称为firmware_upgrade。传输文件至 Android 端。
启动Android开发板并进入 shell 模式:
adb shell su
将主机端的
upgrade_firmware文件夹推送至 Android 端的/data/houmo目录:adb push upgrade_firmware /data/houmo
传输下载的镜像文件到 Android 端指定目录:
adb push M50_<product_name>-<target_hw>_<release>/images /data/houmo/upgrade_firmware
配置环境变量。在 Android 端设置驱动库路径:
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/data/houmo/houmo-drv-xh2/hal/lib
升级镜像。在 Android 端,进入
upgrade_firmware目录,执行以下命令升级。仅需升级firmware.img镜像。脚本运行还需提供升级镜像等参数,详情参看 示例参数说明。示例如下:cd /data/houmo/upgrade_firmware ./firmware_upgrade -m sync -d all -f ../../images/firmware.img
固件升级以逻辑设备(即单颗 M50 芯片)为基本单元。对于多颗芯片的产品(如 LQ50 Duo M.2卡),须确保完成卡内所有逻辑设备的升级,建议一次完成所有逻辑设备升级。
重启Android端。升级完成后,在 Android 端执行以下命令重启系统,使新固件生效:
reboot