鸿蒙OpenHarmony:【常见编译问题和解决方法】

电子说

1.3w人已加入

描述

常见问题

常见编译问题和解决方法

鸿蒙开发指导文档:[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。
  • 解决办法:
    1. 查询Python版本号。
      python3 --version
      
    2. 需使用python3.9.2以上版本,然后安装pycryptodome。
      sudo pip3 install pycryptodome
      

提示“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,而该进程并不在产品定义的高权限进程允许范围内。
  • 解决办法:
    1. 降低进程的权限等级。修改.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

提示“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

审核编辑 黄宇

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分