一.问题背景
我在am335x上移植Minigui的时候,在移动光标的时候,系统会死机,100%能复现,系统没有任何出错日志,ping不通开发板,外部中断也没有响应。经过定位是移植光标的时候,是调用memcpy进行内存拷贝导致的。每次调用两次memcpy,第一次的源地址是mmap映射framebuffer的内存到用户空间的地址,拷贝到普通内存中。经过排查定位,是linaro编译器对memcpy采用neon优化导致的。
本人采用的运行环境是am335x,系统linux4.14,编译器是TI提供的linaro-4.9。
二.定位过程
定位过程中做的工作:
1.采用linaro官方的最新的linaro8.x编译器也会死机.
2.采用arm9的编译器和arago编译器没有过死机现象。
3.在天嵌的开发板TQ335x上也出现同样的死机现象,linux版本是linux3.2,也是linaro编译器, tq提供的另一个A8编译器没有死机。
4.检查内存,不存在内存溢出的问题,无论内存是否对齐都会死机。
5.自己用c实现简单的memcpy,单个字节赋值不会死机
6.在cortex-a9上不死机
在stackflow上也遇到过类似的问题:
https://stackoverflow.com/questions/56006842/memcpy-hangs-in-memcpy-neon-when-copying-into-dma-buffer