“Alignment trap”:遇到字节对齐的问题,直译意思为“对齐陷阱”。
Linux下对Alignment trap的处理有下面几种方式:(cat /proc/cpu/alignment)
0 (ignored)
1 (warn)
2 (fixup)
3 (fixup+warn)
4 (signal)
5 (signal+warn)
我的嵌入式linux系统下的默认处理方式是第3级处理方式:修复+警告。
于是修改为:echo 5 > /proc/cpu/alignment,这样修改为会给内核一个信号。
问题: arm中Alignment trap错误处理:
案例:
- int main()
- {
- char tmp = 0;
- scanf("%x",&tmp);
- printf("tmp is 0x%x",tmp);
- }
Alignment trap:test_ (2094) PC=0x4008177c Instr=0xe5820000 Address=0xbeb93c89 FSR 0x813
这个问题是由于使用scanf将一个十六进制(创建应为int *)赋给了一个char *,导致对齐问题出现,将char tmp改为int tmp即可。
在代码编写中,需要注意一下以下的事:
1、结构体尽量使用4字节对齐,比如设置一个传输长度len的类型时,用short表示的范围已经足够,当然也可以用int。像制定一些网络协议,最好考虑一下4字节对齐。
2、分配内存时也尽量4字节对齐,无论是申请的内存还是定义数组大小。
3、对指针进行访问的时候也要十分注意4字节对齐,特别是一些为了避免编译警告的强制类型转换。
http://blog.chinaunix.net/uid-24567872-id-201530.html
- int main()
- {
- char tmp = 0;
- scanf("%x",&tmp);
- printf("tmp is 0x%x",tmp);
- }
Alignment trap:test_ (2094) PC=0x4008177c Instr=0xe5820000 Address=0xbeb93c89 FSR 0x813
这个问题是由于使用scanf将一个十六进制(创建应为int *)赋给了一个char *,导致对齐问题出现,将char tmp改为int tmp即可。
在代码编写中,需要注意一下以下的事:
1、结构体尽量使用4字节对齐,比如设置一个传输长度len的类型时,用short表示的范围已经足够,当然也可以用int。像制定一些网络协议,最好考虑一下4字节对齐。
2、分配内存时也尽量4字节对齐,无论是申请的内存还是定义数组大小。
3、对指针进行访问的时候也要十分注意4字节对齐,特别是一些为了避免编译警告的强制类型转换。
http://blog.chinaunix.net/uid-24567872-id-201530.html