如何正确读取内存中的数据(memcpy)

时间:2016-07-19 20:04:21

标签: c++ c memory bit-shift

我有一些表,例如一个声明为uint8_t keyLock[16];的表,我已将这些表的内容保存在MCU的闪存中。在这个记忆中,它看起来如下:

Address    Data
00190008 - BA98B694
0019000C - E854B6E7
00190010 - 9200B2C9
00190014 - 42F8B048

当我通过memcpy函数(memcpy(keyLock, 0x00190008, 32);)将flash数据复制到我的表格中时,表格的内容最终就像这样初始化:

keyLock = {
    0xBA, 0x98, 0xB6, 0x94, 0xE8, 0x54, 0xB6, 0xE7,
    0x92, 0x00, 0xB2, 0xC9, 0x42, 0xF8, 0xB0, 0x48
}

我希望内容就像表格初始化一样:

keyLock = {
    0x94, 0xB6, 0x98, 0xBA, 0xE7, 0xB6, 0x54, 0xE8,
    0xC9, 0xB2, 0x00, 0x92, 0x48, 0xB0, 0xF8, 0x42
}

我的memcpy()电话有什么问题,如何编写表格以填写所需内容,如上所述?

1 个答案:

答案 0 :(得分:4)

当你将4个字节的内存存储为32但是整数的值为BA98B694时,哪个字节先行?

在您的问题中,您隐含地假设BA字节首先出现,但在您的系统上,94首先出现。

您的memcpy正在做的一切正确。您的问题是您对字节序的期望,或闪存中表格的布局。

您可以通过简单地交换每个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中,假设您可以控制它。