常见问题

常见编译问题和解决方法

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