鸿蒙OpenHarmony:【常见编译问题和解决方法】
人阅读 2024-05-11 17:44:43
常见问题
常见编译问题和解决方法
鸿蒙开发指导文档:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
提示“usr/sbin/ninja: invalid option -- w”
- 现象描述: 编译失败,提示“usr/sbin/ninja: invalid option -- w”。
- 可能原因: 编译环境中ninja版本太低,不支持--w选项。
- 解决办法: 卸载环境中ninja和gn,按照[获取工具]。
提示“/usr/bin/ld: cannot find -lncurses”
- 现象描述: 编译失败,提示“/usr/bin/ld: cannot find -lncurses”。
- 可能原因: 编译环境ncurses库缺失。
- 解决办法:
sudo apt-get install lib32ncurses5-dev
提示“line 77: mcopy: command not found”
- 现象描述: 编译失败,提示“line 77: mcopy: command not found”。
- 可能原因: 编译环境未安装mcopy。
- 解决办法:
sudo apt-get install dosfstools mtools
提示“riscv32-unknown-elf-gcc: error trying to exec 'cc1': execvp: No such file or directory”
现象描述: 编译失败,提示“riscv32-unknown-elf-gcc: error trying to exec 'cc1': execvp: No such file or directory”。
可能原因: 当前用户对riscv编译器路径下的文件访问权限不够。
解决办法: 查询gcc_riscv32所在目录。
which riscv32-unknown-elf-gcc
使用chmod命令修改目录权限为755。
提示“No module named 'Crypto'”
- 现象描述: 编译失败,提示“No module named 'Crypto'”。
- 可能原因: python3未安装Crypto。
- 解决办法:
- 查询Python版本号。
python3 --version
- 需使用python3.9.2以上版本,然后安装pycryptodome。
sudo pip3 install pycryptodome
- 查询Python版本号。
提示“xx.sh : xx unexpected operator”
- 现象描述: 编译失败:“xx.sh [: xx unexpected operator”。
- 可能原因: 编译环境shell不是bash。
- 解决办法:
sudo rm -rf /bin/sh sudo ln -s /bin/bash /bin/sh
提示“some services are not authenticated. Listed as follow”
- 现象描述: 编译失败:“some services are not authenticated. Listed as follow”。
- 可能原因: 报错中列举出来的进程.cfg配置文件中,定义了uid为root或system,而该进程并不在产品定义的高权限进程允许范围内。
- 解决办法:
- 降低进程的权限等级。修改.cfg配置文件中的uid定义,非必需的场景下,不要定义uid为root或system。
如果由于实现业务功能需要,进程必须要有root或system权限,只有在联系安全专家评审,通过安全审视后,方可修改产品的高权限进程管控列表,配置文件路径为"vendor/{公司名称}/{产品名称}/security_config/high_privilege_process_list.json
"。
示例:rk3586的高权限进程配置文件位于//vendor/hihope/rk3568/security_config/high_privilege_process_list.json
- 降低进程的权限等级。修改.cfg配置文件中的uid定义,非必需的场景下,不要定义uid为root或system。
提示“Error: some services do not match with critical whitelist”
- 现象描述: 编译失败:“Error: some services do not match with critical whitelist”。
- 可能原因: 报错中列举出来的进程.cfg配置文件中,定义并使能了critical字段,而该进程未被允许添加critical字段,或该字段配置与白名单中不符。
- 解决办法:
移除进程的critical字段或把critical字段第一位置0。修改原服务.cfg配置文件中的critical字段,非必需的场景下,不要使能critical字段。
关于critical字段的详细使用方法,请参考[服务配置]。如果由于实现业务功能需要,进程必须要使能critical字段,只有在联系安全专家评审,通过安全审视后,方可修改产品的critical_reboot进程管控白名单//vendor/{公司名称}/{产品名称}/security_config/critical_reboot_process_list.json
。
示例:rk3586的critical_reboot进程管控白名单为//vendor/hihope/rk3568/security_config/critical_reboot_process_list.json
审核编辑 黄宇