ARM9上使用C的未对齐内存访问异常的解决方法是什么?

dub*_*nde 4 c c++ embedded arm

架构ARM9.编程语言C.

我们有一个第三方堆栈,其中一个调用将一个指针(pBuffer)带到一个内存位置.在堆栈中,它们可以自由地移动指针传递并按照自己的意愿访问它.不幸的是,它们偏移了传入的指针并将其传递给另一个试图从奇数/未计数内存位置执行此操作的函数

         ((uint16 *)pBuffer)[index] = value;
Run Code Online (Sandbox Code Playgroud)

where value是类型,uint16index检查边界和索引pBuffer.这会导致未对齐的内存访问异常.pBuffer指向char *堆上.

如上所述,即使我们可以查看第三方堆栈,我们也无法正式更新代码.因此,我们通知提供商,他们在下一版本中提供更新.

我想知道是否有解决方法.如何在不违反未对齐访问的情况下执行上述分配?解决此类问题的最佳方法是什么?

jal*_*alf 7

逐字节复制值.将其转换为(无符号)char指针,然后一次复制一个字节.

它不漂亮,但听起来并不像你有很多选择.