保姆级避坑指南:在Ubuntu 22.04上搞定Hi3516CV610 SDK环境(附完整依赖包清单)
保姆级避坑指南在Ubuntu 22.04上搞定Hi3516CV610 SDK环境附完整依赖包清单第一次接触海思Hi3516CV610开发板的开发者往往会在搭建SDK环境时踩不少坑。Ubuntu 22.04作为较新的LTS版本与海思官方推荐的开发环境存在一些兼容性问题。本文将带你一步步避开这些雷区从系统配置到最终编译手把手完成整个环境搭建。1. 系统环境准备那些官方文档没告诉你的细节在开始安装SDK之前Ubuntu 22.04需要做一些特殊的配置调整。这些步骤看似简单却直接影响后续的编译能否成功。1.1 Shell环境配置海思的编译脚本对bash的特性依赖较强而Ubuntu默认使用dash作为/bin/sh的链接。切换方法sudo dpkg-reconfigure dash在弹出的对话框中选择No将默认shell改为bash。这一步至关重要否则后续执行SDK中的脚本时会遇到语法错误。1.2 基础依赖安装官方提供的依赖包安装命令可能需要针对Ubuntu 22.04进行调整。以下是经过验证可用的完整命令sudo apt-get install -y make libc6-i386 lib32z1 lib32stdc6 \ libncurses5-dev ncurses-term libncursesw5-dev g u-boot-tools \ texinfo gawk libssl-dev openssl bc p7zip-full gperf bison flex \ diffutils git unzip libffi-dev libtool libfreetype6 fakeroot \ autopoint po4a python3-pip wget libmpc-dev zlib1g-dev \ liblzo2-dev uuid-dev pkg-config automake特别注意在Ubuntu 22.04上部分软件包名称已变更libssl-dev替代了旧版的openssl-dev需要显式安装python3-pip而非python-pip1.3 解决64位系统兼容性问题创建空白的/etc/ld.so.preload文件可以避免某些32位库的加载冲突echo | sudo tee /etc/ld.so.preload sudo ldconfig这个步骤解决了找不到共享库的常见报错特别是在交叉编译工具链工作时。2. 交叉编译工具链配置中的那些坑海思官方提供的交叉编译工具链在较新系统上需要额外配置才能正常工作。2.1 工具链安装假设工具链压缩包为gcc-arm-v01c02-linux-musleabi.tgz安装步骤如下tar xf gcc-arm-v01c02-linux-musleabi.tgz cd gcc-arm-v01c02-linux-musleabi/ sudo ./install_gcc_toolchain.sh source /etc/profile验证安装是否成功arm-v01c02-linux-musleabi-gcc -v2.2 解决sudo环境变量问题Ubuntu 22.04的sudo默认会重置PATH环境变量导致sudo下找不到交叉编译工具。解决方法sudo visudo在文件中添加以下内容替换username为你的实际用户名Defaults env_keep PATH Defaults secure_path /usr/sbin:/usr/bin:/sbin:/bin:/home/username/gcc-arm-v01c02-linux-musleabi/arm-v01c02-linux-musleabi-gcc/bin这个配置保留了PATH变量并添加了工具链路径到sudo的安全路径中。3. SDK安装与配置避开那些隐藏的依赖海思SDK的安装过程看似简单实则暗藏多个依赖项需要手动处理。3.1 解压与展开SDKtar -zxf Hi3516CV610_SDK_V1.0.1.0.tgz cd Hi3516CV610_SDK_V1.0.1.0/ sudo ./sdk.unpack常见问题如果遇到权限问题建议使用sudo执行解压和展开操作但要注意后续操作的文件权限。3.2 内核源码准备SDK需要特定版本的Linux内核源码下载linux-5.10.221.tar.gz放置到正确位置sudo mv linux-5.10.221.tar.gz Hi3516CV610_SDK_V1.0.1.0/open_source/linux/3.3 额外工具安装mtd-utils是必须的依赖sudo apt-get install zlib1g-dev liblzo2-dev uuid-dev wget https://infraroot.at/pub/mtd/mtd-utils-2.1.4.tar.bz2 sudo mv mtd-utils-2.1.4.tar.bz2 Hi3516CV610_SDK_V1.0.1.0/open_source/mtd-utils/4. Python环境配置那些容易忽略的细节海思的编译系统依赖多个Python包Ubuntu 22.04的Python3环境需要特别注意。4.1 必要Python包安装sudo pip3 install wheel pycryptodome pyelftools cryptography版本冲突解决如果遇到版本冲突可以尝试添加--ignore-installed参数。4.2 创建Python软链接海思脚本通常直接调用python而非python3sudo ln -s /usr/bin/python3 /usr/bin/python5. 编译实战从失败到成功的经验分享进入编译阶段仍有几个关键点需要注意。5.1 开始编译cd Hi3516CV610_SDK_V1.0.1.0/smp/a7_linux/source/bsp/ sudo make LIB_TYPEmusl CHIPhi3516cv610 DEBUG1 all5.2 常见编译错误解决找不到交叉编译工具链确认source /etc/profile已执行检查sudo的PATH配置是否正确内核头文件缺失确保linux内核源码包已正确放置检查open_source/linux目录权限Python模块导入失败确认所有required Python包已安装检查python软链接是否正确5.3 编译优化建议首次编译建议添加DEBUG1参数便于发现问题如果编译中途失败可以先执行make clean再重新开始多核编译可以加快速度make -j$(nproc) ...6. 完整依赖包清单与验证方法为确保环境完整以下是所有必要组件的检查清单类别组件验证命令系统工具makemake --version库文件libc6-i386ls /usr/lib/i386-linux-gnuPython环境pycryptodomepython3 -c import Crypto工具链arm-gccarm-v01c02-linux-musleabi-gcc -v内核源码linux-5.10ls Hi3516CV610_SDK_V1.0.1.0/open_source/linux/对于时间有限的开发者可以先将这些依赖准备齐全再开始SDK安装能节省大量排错时间。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2498156.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!