精彩BUG人生[2] -- 不对齐的精彩
2011-01-06 22:09
197 查看
说到对齐,不少学习C语言的同学自然会想到数据结构中成员的对齐,比如,常有面试题目是会问:
struct {
char a;
short b;
int c;
};
占用几个字节?这个不恰当的例子确实是和对齐有些相关,但有几个人遇到不对齐的麻烦了呢?
昨天发现一个奇怪的现象:点灯测试代码正常,加入了一个函数块就不正常了,代码块如下:
uint8_t pid = 0;
uint8_t tid = 0;
void foo1(void)
{
xxx;
}
void foo2(void)
{
yyy;
}
通过尝试,注释掉 foo1()就正常,反之就不正常,不知缘由!
无奈之下,就又拿起来openocd+jtag,发现CPU出现了 hard fault 异常,原因是 UNALIGNED 发生,最后查得原因是:当启动代码在做 拷贝数据段数据时,指令发现数据未对齐,发生了CPU异常,注释掉的代码,正好造成数据段数据对齐了,所以有那个怪现象。
以后知道了,要靠按照块来注释代码时,数据也要注释掉,因为它也有可能造成错误。
这是一块 cortex-m3的板子,以后接触新CPU最好把它与其他CPU差异弄弄清楚,再开始。
这应该是我在现在公司最后一个比较有意思的BUG了,希望我的BUG人生继续精彩。
struct {
char a;
short b;
int c;
};
占用几个字节?这个不恰当的例子确实是和对齐有些相关,但有几个人遇到不对齐的麻烦了呢?
昨天发现一个奇怪的现象:点灯测试代码正常,加入了一个函数块就不正常了,代码块如下:
uint8_t pid = 0;
uint8_t tid = 0;
void foo1(void)
{
xxx;
}
void foo2(void)
{
yyy;
}
通过尝试,注释掉 foo1()就正常,反之就不正常,不知缘由!
无奈之下,就又拿起来openocd+jtag,发现CPU出现了 hard fault 异常,原因是 UNALIGNED 发生,最后查得原因是:当启动代码在做 拷贝数据段数据时,指令发现数据未对齐,发生了CPU异常,注释掉的代码,正好造成数据段数据对齐了,所以有那个怪现象。
以后知道了,要靠按照块来注释代码时,数据也要注释掉,因为它也有可能造成错误。
这是一块 cortex-m3的板子,以后接触新CPU最好把它与其他CPU差异弄弄清楚,再开始。
这应该是我在现在公司最后一个比较有意思的BUG了,希望我的BUG人生继续精彩。
相关文章推荐
- 精彩BUG人生[3] -- 潜伏期很长
- 精彩BUG人生[1] -- 开篇:费力的2周
- 精彩BUG人生[4] -- bug free or not
- 我的人生因CSDN而精彩
- 人生三分之一的睡眠决定着另外三分之二的精彩
- 精彩的人生早已开始,看你怎么看待你的人生了
- 十个哲理故事 一场精彩的人生课[转贴]
- 人生的精彩
- 人生,挺得住才精彩
- 恋上自由精彩的人生旅途
- 精彩的人生感悟
- 你二,所以你“生命是如此的精彩,人生是如此的辉煌”
- 精彩三级跳的职业人生
- 懂了这10句话,人生一定很精彩!
- 我的IT人生:修复别人的BUG
- 我的IT人生:修复别人的BUG
- 人生这样才精彩
- 非等宽字体的编号对齐问题--这应该算是Office 2007的BUG吧?
- 人生这样才精彩
- 人生最精彩的不是实现梦想的瞬间