给嵌入式设备移植软件,交叉编译时一切正常,交叉编译后在设备上运行时前面部分运行正常,在某个阶段就会报错/mnt/release/bin/demoui: can't resolve symbol 'wcslen'
。
之前设备厂家给的原厂系统中 libstdc++居然好像真没有这些宽字符的支持(用 nm -D
看的),但是交叉编译器里面的 libstdc++有,以为找到了突破点,用编译器里面的替换了 rootfs 里面那些 lib,结果报错依旧。
目标设备是 uclibc 的。找不到思路了,来请教各位大神现在该如何定位错误。
源码应该没有问题,移植的是嵌入式的一个 GUI 库 awtk,github.com/zlgopen/awtk-linux-fb,我觉得可能还是与交叉编译器有关。
1
May725 2020-07-20 12:40:43 +08:00 via iPhone
交叉编译工具链不保证同一套吗?
|
2
jworg 2020-07-20 13:13:53 +08:00
这个就是厂家做文件系统时的交叉编译工具链和你现在用的不一致,你的 “用编译器里面的替换了 rootfs 里面那些 lib” 思路可能对,某些情况确实会好,但还是最好还是用原厂的做文件系统时的交叉编译工具链。要么找原厂要,要么自己用现在的工具链编一个文件系统丢进去。
|
4
ysc3839 2020-07-20 18:03:30 +08:00 via Android
尝试自己实现一套 wchar.h 的函数?可以从 musl 、uclibc 之类的抄一份来。
|