本文主要是介绍交叉编译后的动态库太大,在嵌入式平台上放不下,如何处理。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在arm交叉编译工具链下,存在一个strip的工具,使用strip aa.so,就可以将.so文件减少。
在linux下有个工具叫做strip,这是一个可以将linux下的可执行文件的符号表去除,减少每个可执行文件的大小,这对于嵌入式方面很有必要。
但是没有了符号表也就意味着没有办法采用gdb进行调试,因为gdb调试是读取ELF文件头来获取符号表,进而调试,
但strip之后,可执行文件的ELF文件头就没有.symtab这个符号表,有的仅是动态符号表。在strip之后nm libxxx.so是看不到符号表的,
nm -D libxxx.so可以看到动态符号表,但用处不大,但strip有个参数选项叫做--only-keep-debug,这个选项可以在strip的时候保留debug调试信息,
但是strip有个弊端,就是什么样的strip就处理什么样的可执行文件,x86的strip处理不了ARM平台的库。当然x86平台上肯定也有ARM的strip工具链。
首先,分离调试信息可以用来下面方法进行分离。
/home/share/arm-hisiv300-linux/arm-hisiv300-linux-uclibcgnueabi/bin/objcopy --only-keep-debug ../../../libCameraClient-hisiv300/protobuf-2.6.0/lib/libprotobuf.so.9.0.0 ../../../libCameraClient-hisiv300/protobuf-2.6.0/lib/libprotobuf.so.9.0.0.debug
其次,分离后进行so的剥离
/home/share/arm-hisiv300-linux/arm-hisiv300-linux-uclibcgnueabi/bin/strip ../../../libCameraClient-hisiv300/protobuf-2.6.0/lib/libprotobuf.so.9.0.0
最后,一步需要将a.so.debug的路径添加到strip之后的a.so,采用下面方法。
/home/share/arm-hisiv300-linux/arm-hisiv300-linux-uclibcgnueabi/bin/objcopy --add-gnu-debuglink ../../../libCameraClient-hisiv300/protobuf-2.6.0/lib/libprotobuf.so.9.0.0.debug ../../../libCameraClient-hisiv300/protobuf-2.6.0/lib/libprotobuf.so.9.0.0
这样做会在a.so中添加一个gnu_debuglink这样一个段来保存debug文件的信息。
这篇关于交叉编译后的动态库太大,在嵌入式平台上放不下,如何处理。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!