如何从内存中正确读取数据(memcpy)
How to properly read data from memory (memcpy)
我有一些tables,例如一个声明为uint8_t keyLock[16];
,我已经将这些tables的内容保存在我的MCU的闪存中。在此内存中,它如下所示:
Address Data
00190008 - BA98B694
0019000C - E854B6E7
00190010 - 9200B2C9
00190014 - 42F8B048
当我通过 memcpy
函数 (memcpy(keyLock, 0x00190008, 32);
) 将闪存数据复制到我的 table 时,table 的内容最终会像这样初始化一样:
keyLock = {
0xBA, 0x98, 0xB6, 0x94, 0xE8, 0x54, 0xB6, 0xE7,
0x92, 0x00, 0xB2, 0xC9, 0x42, 0xF8, 0xB0, 0x48
}
我希望内容就像 table 是这样初始化的:
keyLock = {
0x94, 0xB6, 0x98, 0xBA, 0xE7, 0xB6, 0x54, 0xE8,
0xC9, 0xB2, 0x00, 0x92, 0x48, 0xB0, 0xF8, 0x42
}
我的 memcpy()
调用有什么问题,我应该如何编写它来填充 table 所需的内容,如上所示?
当你将 4 个字节的内存存储为一个 32 但整数,其值为 BA98B694
,哪个字节在前?
在您的问题中,您隐含地假定 BA
字节在前,但在您的系统上似乎 94
在前。
您的 memcpy
一切正常。你的问题是你对字节顺序的期望,或者你的 table 在 flash 中的布局。
您可以通过简单地交换每个 4 字节双字的顺序来修复它。
void endian_4byte_swap( uint32_t* bytes ){
std::swap(bytes[0],bytes[3]);
std::swap(bytes[1],bytes[2]);
}
void endian_fix_table( uint32_t (&table)[16] ){
for(int i=0;i<4;++i)
endian_4byte_swap(&table[4*i]);
}
但这治标不治本。真正的解决方法是修复 Flash 中的 table,前提是您可以控制它。
我有一些tables,例如一个声明为uint8_t keyLock[16];
,我已经将这些tables的内容保存在我的MCU的闪存中。在此内存中,它如下所示:
Address Data
00190008 - BA98B694
0019000C - E854B6E7
00190010 - 9200B2C9
00190014 - 42F8B048
当我通过 memcpy
函数 (memcpy(keyLock, 0x00190008, 32);
) 将闪存数据复制到我的 table 时,table 的内容最终会像这样初始化一样:
keyLock = {
0xBA, 0x98, 0xB6, 0x94, 0xE8, 0x54, 0xB6, 0xE7,
0x92, 0x00, 0xB2, 0xC9, 0x42, 0xF8, 0xB0, 0x48
}
我希望内容就像 table 是这样初始化的:
keyLock = {
0x94, 0xB6, 0x98, 0xBA, 0xE7, 0xB6, 0x54, 0xE8,
0xC9, 0xB2, 0x00, 0x92, 0x48, 0xB0, 0xF8, 0x42
}
我的 memcpy()
调用有什么问题,我应该如何编写它来填充 table 所需的内容,如上所示?
当你将 4 个字节的内存存储为一个 32 但整数,其值为 BA98B694
,哪个字节在前?
在您的问题中,您隐含地假定 BA
字节在前,但在您的系统上似乎 94
在前。
您的 memcpy
一切正常。你的问题是你对字节顺序的期望,或者你的 table 在 flash 中的布局。
您可以通过简单地交换每个 4 字节双字的顺序来修复它。
void endian_4byte_swap( uint32_t* bytes ){
std::swap(bytes[0],bytes[3]);
std::swap(bytes[1],bytes[2]);
}
void endian_fix_table( uint32_t (&table)[16] ){
for(int i=0;i<4;++i)
endian_4byte_swap(&table[4*i]);
}
但这治标不治本。真正的解决方法是修复 Flash 中的 table,前提是您可以控制它。