linux应用移植问题
创始人
2024-03-04 22:02:03
0

背景

公司设备降成本,设备运行平台从armv7架构mpu换成了armv5架构的mpu,应用移植过程都挺顺利的,只是牵涉到一个引用外部库的应用时,运行该应用到引用库中的函数时,应用抛出illegal instrution异常。

问题分析

  1. 初步排查发现库的编译工具链用错了,更改了对应固件的编译链测试发现还是不行;
  2. 禁用库相关代码逻辑测试,发现应用可正常运作,问题确定出在引用库文件上;
  3. 因为glibc和musl libc存在部分差异,更换系统的libc库,重新编译测试应用,发现还是存在异常;
  4. 使用gdb调试应用发现设备崩溃在 push_all函数内,核查相关函数代码未发现异常;
  5. gdb调试查看对应的汇编代码layout asm;
    assemle code
    发现程序挂在了vpush指令,向上排查未发现其它地方使用该指令;
  6. 搜索核查vpush指令,发现其是NEON指令集指令,其他人文章传统ARM架构寄存器与指令集中也有谈及到;
    vpush
  7. 目标明确,编译库文件时使其不使用NEON指令;
    我这面是将编译选项中参数改为-march=armv5te -mfpu=vfp,再次测试应用即可正常运行;降成本的mpu支持的指令集减少一部分,这一点一开始没意识到走了很多弯路记录一下;

参考文章

  1. ARM Compiler toolchain Assembler Reference Version 5.03;
  2. [ARM926EJ-S Technical Reference Manual r0p5];(https://developer.arm.com/documentation/ddi0198/e/introduction/about-the-arm926ej-s-processor)
  3. gdb 调试利器;
  4. illegal instruction非法指令的解决思路;
  5. Dev 日志 | 一次 Segmentation Fault 和 GCC Illegal Instruction 编译问题排查, 写完文章发现了也有人遇到类似问题,之前搜索指向的是错误执行也会导致类似的问题,因此一开始方向有问题;

相关内容

热门资讯

美国2年期国债收益率上涨15个... 原标题:美国2年期国债收益率上涨15个基点 美国2年期国债收益率上涨15个基...
汽车油箱结构是什么(汽车油箱结... 本篇文章极速百科给大家谈谈汽车油箱结构是什么,以及汽车油箱结构原理图解对应的知识点,希望对各位有所帮...
嵌入式 ADC使用手册完整版 ... 嵌入式 ADC使用手册完整版 (188977万字)💜&#...
重大消息战皇大厅开挂是真的吗... 您好:战皇大厅这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...
盘点十款牵手跑胡子为什么一直... 您好:牵手跑胡子这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游...
senator香烟多少一盒(s... 今天给各位分享senator香烟多少一盒的知识,其中也会对sevebstars香烟进行解释,如果能碰...
终于懂了新荣耀斗牛真的有挂吗... 您好:新荣耀斗牛这款游戏可以开挂,确实是有挂的,需要了解加客服微信8435338】很多玩家在这款游戏...
盘点十款明星麻将到底有没有挂... 您好:明星麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【5848499】很多玩家在这款游戏...
总结文章“新道游棋牌有透视挂吗... 您好:新道游棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【7682267】很多玩家在这款游...
终于懂了手机麻将到底有没有挂... 您好:手机麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【8435338】很多玩家在这款游戏...