Linux下编译海思WS63 SDK全攻略

目录

引言

准备工作

编译方法

UTF-8问题的解决

结束语


引言

一般使用海思的WS63 SDK都是在Windows进行编译,以前在我博客也介绍过。不过以我多年的经验,总会有学生的电脑因为各种原因无法编译成功,所以还需要试试Linux下编译的方法作为备份推荐给学生。我基本上是按照官方文档做的(docs/zh-CN/software/SDK开发环境搭建用户指南/WS63V100 SDK开发环境搭建 用户指南.md · HiSpark/fbb_ws63 - Gitee.com),记录了几个自己遇到的问题。

准备工作

Linux系统推荐使用Ubuntu 20.04及以上版本,Shell使用bash ,SDK使用Cmake编译(3.14.1以上),编译工具还包括Python(3.8.0以上)等。这里我使用的是华为云免费提供的开发者云电脑。海思的WS63 SDK体积较小,所以使用这个云电脑也是可以的,而且默认的云电脑的环境也是符合要求的。

安装Kconfiglib 14.1.0+,使用命令"sudo pip install kconfiglib"(需root/sudo权限安装)。

安装pycparser,使用pip install pycparser进行安装。

编译方法

使用下面的命令下载代码:

复制代码
git clone https://gitee.com/HiSpark/fbb_ws63.git

在src目录下执行"python3 build.py"指令运行脚本编译,即可编译出对应的SDK程序。编译命令列表如表1所示。

表 1 build.sh参数列表

参数 示例 说明
python3 build.py ws63-liteos-app 启动ws63-liteos-app目标的增量编译。
-c python3 build.py -c ws63-liteos-app 启动ws63-liteos-app目标的全量编译。
menuconfig python3 build.py ws63-liteos-app menuconfig 启动ws63-liteos-app目标的menuconfig图形配置界面。

表 2 编译目标介绍

编译目标 说明
python3 build.py -c ws63-liteos-app app版本编译目标(自动包含flashboot编译)
python3 build.py -c ws63-flashboot flashboot镜像编译目标
python3 build.py -c ws63-liteos-xts openharmony xts认证版本编译目标(详情请参考"鸿蒙XTS认证指导书")
python3 build.py -c ws63-liteos-app-iot Harmony connect版本编译目标(详情请参考"HiLink编译使用指南")
python3 build.py -c ws63-liteos-hilink Harmony connect独立升级版本编译目标(详情请参考"HiLink编译使用指南")

编译得到的烧录镜像在"output/ws63/fwpkg/ws63-liteos-app"目录下(如表3所示)。

表 3 烧录镜像

文件名 说明
ws63-liteos-app_all.fwpkg 空片烧录时,需要烧录此文件。包含了所有的需要升级的内容。包含:root_loaderboot_sign.bin、root_params.bin、flashboot_sign.bin、ws63_all_nv.bin、ws63-liteos-app-sign.bin。 各文件介绍如下: root_loaderboot_sign.bin:loaderboot的镜像文件。升级开始时,芯片中固化的romboot会接收此镜像文件,加载到内存并运行,loadboot负责接收后续的镜像文件。注:此镜像只在升级阶段放在RAM中运行,并不存放在flash中。 root_params.bin:flash分区信息的镜像文件。分区信息供romboot、loaderboot和flashboot使用。 flashboot_sign.bin:flashboot的镜像文件。 ws63_all_nv.bin:参数区的镜像文件。 ws63-liteos-app-sign.bin:版本镜像文件。
ws63-liteos-app_load_only.fwpkg 版本升级打包文件,包含:root_loaderboot_sign.bin、ws63-liteos-app-sign.bin。不包含flashboot相关内容。 当芯片烧录过"ws63-liteos-app_all.fwpkg"镜像后,如果后续修改不涉及root_params、flash_boot、nv的修改,则可以用此文件升级。

注:编译得到的中间文件在"output/ws63/acore/ws63-liteos-app"目录下。

UTF-8问题的解决

按照上述步骤编译的时候,程序快要编译结束时遇到一个问题:

bash 复制代码
../../../../../output/ws63/acore/boot_bin/ws63-liteos-mfg.bin  generated successfully!!!

[100%] Built target WS63_GENERAT_SIGNBIN

[100%] Built target GENERAT_ASM

[100%] Built target GENERAT_LST

[100%] MEM_LIMIT

[100%] Built target GENERAT_MEM_LIMIT

Traceback (most recent call last):

 File "/home/developer/fbb_ws63/src/build/script/utils/mem_stats.py", line 716, in <module>

   main(sys.argv[1], sys.argv[2], sys.argv[3], sys.argv[4])

 File "/home/developer/fbb_ws63/src/build/script/utils/mem_stats.py", line 704, in main

   lst_file.process()

 File "/home/developer/fbb_ws63/src/build/script/utils/mem_stats.py", line 394, in process

   section = self.get_first_section()

 File "/home/developer/fbb_ws63/src/build/script/utils/mem_stats.py", line 337, in get_first_section

   if(self.find_file_sections()):

 File "/home/developer/fbb_ws63/src/build/script/utils/mem_stats.py", line 346, in find_file_sections

   file_line = self.file.readline()

 File "/usr/lib/python3.10/codecs.py", line 322, in decode

   (result, consumed) = self._buffer_decode(data, self.errors, final)

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xb3 in position 4093: invalid start byte

make[2]: *** [CMakeFiles/GENERAT_MEM.dir/build.make:71:CMakeFiles/GENERAT_MEM] 错误 1

make[1]: *** [CMakeFiles/Makefile2:5080:CMakeFiles/GENERAT_MEM.dir/all] 错误 2

make: *** [Makefile:91:all] 错误 2

######### Build target:ws63_liteos_app failed

这个问题是因为Python脚本在处理ws63-liteos-app.lst文件时遇到非标准的Unicode字符,所以报错了。要解决这个问题,可以修改一下 /home/developer/fbb_ws63/src/build/script/utils/mem_stats.py脚本,在696行, 在"with open(lst_file_name, "r") as fp_lst_file_name, open("加上", errors='ignore'",意思是遇到非法字符就忽略,从而避免了报错的发生。

这样就可以最终完成编译了。

经过实际烧写测试,程序可以正常运行。

结束语

至此,完成了Linux下的编译操作,作为一个备选项,可以在下学期的课程中推荐给学生。

相关推荐
L_autinue_Star24 分钟前
从0到1实现Shell!Linux进程程序替换详解
linux·运维·服务器·c++·chrome
Ftrans34 分钟前
【分享】文件摆渡系统适配医疗场景:安全与效率兼得
大数据·运维·安全
程序员JerrySUN2 小时前
Linux 文件系统实现层详解:原理、结构与驱动衔接
android·linux·运维·数据库·redis·嵌入式硬件
SAP龙哥2 小时前
日常运维问题汇总-58
运维
J_Xiong01172 小时前
【工程篇】07:如何打包conda环境并拷贝到另一台服务器上
运维·服务器·conda
LUCIAZZZ3 小时前
高性能网络模式-Reactor和Preactor
java·服务器·开发语言·网络·操作系统·计算机系统
k *3 小时前
网络编程-tcp连接:服务器与客户端
服务器·网络·tcp/ip
Wezzer3 小时前
haproxy负载均衡
运维·服务器·haproxy·keepalvied
HainesFreeman3 小时前
Linux、Ubuntu和CentOS的关系与区别
linux·ubuntu·centos
yuanManGan4 小时前
Linux基本指令(一)
linux·运维·服务器