移植需要注意字节对齐问题

来源:互联网 发布:出库软件 编辑:程序博客网 时间:2024/05/23 11:53

    今天YD在移植告警模块时遇到一个很稀罕的warning,google+baidu也没有找到结果。

    warning描述如下: Warning[Pa039]: use of address of unaligned structure member ......

    对应的程序为: lstInit(&(gCurAlarmList.currentAlarmTable));

    gCurAlarmList的定义为:

typedef struct  curAlarmList
{    
    ALARM_ELEMENT *pstCurAlarmList;                            /*记录的起始地址 */
    LIST currentAlarmTable;                                    /*  当前告警表的入口 */
    LIST freeAlarmEntresQueue;                                /*空闲结点表 */
    ALARM_ELEMENT *pstFirstEntryInAlarmList;                    /*第一个条目的地址 */
    int curAlarmItems;                                        /*当前告警的条目数*/
}CUR_ALARM_LIST;    

   

    YD先采用强制类型转换的方式告警并未消除。在正文中加入#pragma pack(1)也无效。怀疑为数据结构声明环境的问题。

    与YD确认,系统使用的是ARM的体系结构和指令集,ARM有下面限制:

在ARM中,有ARM和Thumb两种指令。

ARM指令:每执行一条指令,PC的值加4个字节(32bits).一次访问4字节内容,该字节的起始地址必须是4字节对齐的位置上,即地址的低两位为bits[0b00],也就是说地址必须是4的倍数。

Thumb指令:每执行一条指令,PC的值加2个字节(16bits).).一次访问2字节内容,该字节的起始地址必须是2字节对齐的位置上,即地址的低两位为bits[0b0],也就是说地址必须是2的倍数。

    检查数据结构声明文件中发现头文件中有#pragma pack(1),遂改为#pragma pack(4),再编译warning消失。

    但是,一定要注意:这绝不是结束,还需要代码允许的正确性,例如结构中的小于4B的char 成员是否还可正常访问。