从EFS读取的打包结构给出了奇怪的结果

时间:2013-08-24 03:54:11

标签: c packed

我创建了一个具有以下结构的EFS项目

struct 
{
    uint8 version;   // uint8 - 1 byte data type, uint16 - 2 byte
    uint16 y1;
    uint16 y2;
    uint16 y3;
    uint8 reserved[9];
}

现在EFS文件大小为16字节,所以我认为它是打包的。

现在我有相同的结构,在上电时我从EFS读取值,但我的编译器返回的结构的大小为18字节(编译器不支持打包,因此EFS读取失败) )。

我只读了16个字节并且它通过了。

问题:

(1)。如果我只读取16个字节,则不存在数据丢失的风险,因为在第一个成员之后,我的结构中将有一个字节填充空间(因为我的编译器不支持Packed结构而我不能使用它)  我将以下值写入EFS,

version -0
y1      -6
y2      -10
y3      -60

我只读了16个字节,并且我的结构的每个成员都分配了正确的值。是否存在我的结构将具有错误值的任何情况。

(2)。由于第一步的混淆,我创建了一个临时结构,如下面

struct
{ 
    uint8 version;
    uint8 y1_a;
    uint8 y1_b;
    uint8 y2_a;
    uint8 y2_b;
    uint8 y3_a;
    uint8 y3_b;
    uint8 reserved[9];
}

现在EFS和结构大小都是16字节, 现在,当我将输入提供给EFS时     version = 0,y1 = 6,y2 = 10,y3 = 60,

为成员分配如下值:version = 0,y1_a = 6,y1_b = 0,y2_a = 10,y2_b = 0, y3_a = 60,y3_b = 0;

有人可以帮助理解这个吗? 我的想法是读取临时结构(以便EF和我的结构的大小都相同),然后从temp struture为我的原始结构赋值

1 个答案:

答案 0 :(得分:0)

我假设您只是通过将EFS中的字节复制到结构来读取数据。

(如果你填写这样的结构:

read(&(s.version)...);
read(&(s.y1)...);
当然,你对打包或解压缩的结构没有任何问题......但是你必须确保以相同的方式完成写作。)

根据编译器的不同,EFS读取的数据肯定无法正确分配。

为了检查编译器如何完成打包,我会做两个测试:

int a = ((int)&(s.y1)) - ((int)&(s.version));

如果编译器打包,则为1,否则为2。

union {
    struct {
        uint8 version;
        uint16 y1;
        ...
    } unsure;
    struct {
        uint8 version;
        uint8 y1_a;
        uint8 y1_b;
        ...
    } definitely_unpacked;
}

这个联合应该让你更详细地了解正在发生的事情:当你将数据读入联合时,你可以看到第二个结构中的哪个uint8将映射到第一个结构中的哪个uint16。