当前位置: 首页 > news >正文

嵌入式Linux(RV1126)系统定制中的编译与引导问题调试报告

一、 项目背景与目标

本次工作的目标是基于瑞芯微RV1126官方SDK(基于Buildroot 2018.02)进行二次开发,构建一个集成了特定网络服务(telnet,SSH, Samba, NTP)与系统调试/监控工具(vmstat,GDB, iostat, perf,pidstat....)的定制化Linux系统。

开发环境为现代Ubuntu主机,而目标SDK版本较老。在编译与部署过程中,遇到了一系列典型的兼容性与配置问题,其中遇到了很多的问题,本文选了几个比较典型的问题,旨在对整个调试过程进行技术性复盘。


第二部分:编译阶段的兼容性问题与解决方案

在通过Buildroot的menuconfig添加所需软件包后,编译阶段出现大量由环境不兼容导致的错误。

2.1 问题:opensshlibgpg-error 的编译失败
  • 问题现象: 编译在 openssh-7.6p1 及作为其依赖的 libgpg-error-1.27 等软件包处中断。日志显示,错误主要集中在:

    1. 对新版Glibc/OpenSSL库的API不兼容(如explicit_bzero函数未声明、RSA等加密结构体不透明导致解引用失败)。

    2. 构建脚本与新版Gawk工具的语法冲突(namespace被识别为关键字)。

  • 原因分析与思路: 根本原因为SDK内的软件包版本过低,其源码编写时所依赖的工具链(GCC, Glibc, OpenSSL, Gawk)的API和语法,与当前宿主机的现代化版本存在显著差异。

    解决思路从最初的“直接修复源码(打补丁)”,逐步演进到“更换组件”和“升级软件包版本”。在实践中发现,由于SDK内的源码可能已被厂商修改,通用补丁无法直接应用(Hunk FAILED),且手动修复过程繁琐、易错。

  • 最终解决方案:

    1. 更换组件:鉴于修复旧版openssh的补丁复杂且不稳定,决定将其替换为更轻量、依赖更少、更适合嵌入式环境的 dropbear,从根本上规避了与openssl的兼容性问题。

    2. 升级软件包:对于作为核心依赖的libgpg-error,在尝试补丁修复失败后,最终通过修改其在Buildroot中的.mk定义文件,将版本从 1.27 升级至兼容性更好的 1.42,并同步更新了其下载源与哈希值(后因哈希功能被禁用而省略),解决了与Gawk的兼容性问题。


第三部分:系统引导阶段的配置与同步问题

在解决所有编译问题、成功生成系统镜像后,烧录至开发板却遇到了启动失败的问题。

3.1 问题:内核无法挂载根文件系统 (bad geometry)
  • 问题现象: 系统启动至加载内核后阶段中止,日志抛出 EXT4-fs: bad geometry: block count xxx exceeds size of device... 错误,最终导致 Kernel panic

  • 原因分析与思路: 此错误直接原因为根文件系统镜像(rootfs.ext4)的实际体积(约1.2G)因新增功能而增大,超过了 parameter.txt 文件中为rootfs分区分配的原始大小(1G)。必须对分区表进行扩容。

  • 最终解决方案: 在不删除其他必要分区(oem, userdata)的前提下,通过重新计算rootfs之后所有分区的起始地址(offset),修改了parameter.txt文件,将rootfs分区成功扩容至1.5G以上,解决了镜像空间不足的问题。

3.2 问题:U-Boot无法找到分区,引导失败
  • 问题现象: 使用瑞芯微烧录工具,按照修改后的分区规则,单独烧录每一个固件。然后重启,启动时uart打印有报错信息:U-Boot抛出 *** Warning - bad CRC, using default environmentCould not find baseparameter partition 错误,无法继续引导内核。

  • 原因分析与思路: 此问题暴露了嵌入式系统引导流程中的两个关键点:

    1. 构建配置与烧录配置的脱节:经排查,SDK中存在两份参数文件,一份用于构建脚本在打包时进行尺寸检查(位于device/rockchip/...),另一份用于烧录工具(位于rockdev/)。必须确保两份配置源头一致。

    2. 核心引导组件未同步更新:更重要的是,之前的编译都只针对rootfs。当分区表这种底层配置大改后,引导程序(U-Boot)和内核(Kernel)必须同步重新编译才能识别新的硬件布局。旧的uboot.img无法解析新的分区表,是引导失败的直接原因。

  • 最终解决方案:

    1. 统一修改SDK源码中所有相关的parameter.txt文件,从源头保证分区定义的一致性。

    2. 在Buildroot中执行 make savedefconfig 固化对rootfs的修改。

    3. 执行一次完整的顶层SDK编译脚本(./build.sh,确保U-Boot、Kernel、Rootfs三大组件基于一致的配置重新生成,然后用瑞芯微烧录工具直接烧录统一固件(rockdev/update.img),而不是一个个去烧录各分区固件,从而解决了组件间的配置同步问题。

四、 总结

本次调试过程清晰地揭示了在处理老旧嵌入式SDK时常见的两类问题:

  1. 编译期兼容性问题:由于工具链版本差异引发,其最优解决策略是优先考虑组件替换软件包版本升级,而非投入巨大成本进行源码修复。

  2. 系统引导配置同步问题:任何涉及分区、内存布局等底层配置的变更,都必须确保引导程序、内核、根文件系统等所有相关组件进行全局性的重新编译,以保证信息的一致性。

系统性的排查思路和对底层工作原理的理解,是高效解决此类复杂问题的基础。

http://www.dtcms.com/a/281881.html

相关文章:

  • 【RTSP从零实践】12、TCP传输H264格式RTP包(RTP_over_TCP)的RTSP服务器(附带源码)
  • 基于WebRTC技术实现一个在线课堂系统
  • el-input 回显怎么用符号¥和变量拼接展示?
  • Spring Boot 解决跨域问题
  • Spring Boot - Spring Boot 集成 MyBatis 分页实现 手写 SQL 分页
  • 日语学习-日语知识点小记-构建基础-JLPT-N3阶段(5):语法+单词
  • Buffer Pool
  • css 如何实现大屏4个占位 中屏2个 小屏幕1个
  • Samba服务器
  • Git版本控制完全指南:从入门到精通
  • 网络编程/Java面试/TCPUDP区别
  • 基于spring boot养老院老人健康监护平台设计与实现
  • SFT:大型语言模型专业化定制的核心技术体系——原理、创新与应用全景
  • docker run elasticsearch 报错
  • JAVA面试宝典 -《分布式ID生成器:Snowflake优化变种》
  • 详解SPFA算法-单源最短路径求解
  • C++ - 仿 RabbitMQ 实现消息队列--sqlite与gtest快速上手
  • 基于springboot+vue的酒店管理系统设计与实现
  • 一叶障目不见森林
  • 身份证号码姓名认证解决方案-身份证三要素API接口
  • Apache IoTDB(1):时序数据库介绍与单机版安装部署指南
  • 更灵活方便的初始化、清除方法——fixture【pytest】
  • QT跨平台应用程序开发框架(9)—— 容器类控件
  • 城市守护者的蓝色印记
  • Qt小组件 - 5 图片懒加载样例
  • 【MAC】nacos 2.5.1容器docker安装
  • Python面向对象编程(OOP)详解:通俗易懂的全面指南
  • 高性能架构模式——高性能缓存架构
  • python的慈善捐赠平台管理信息系统
  • 【前端】在Vue3中绘制多系列柱状图与曲线图