DSP

code技巧之四字节对齐

2019-07-13 19:02发布

在DSP项目开发中,往往会遇到申请的空间要按N字节对齐或者申请的空间的起始地址为N字节的倍数,这主要是处理器的对齐规则决定,以保证最少读周期。下面以四字节对齐为例,介绍技巧:          这里,使用宏定义来实现:          #define   MEM_ALIGNMENT    4          #define   MEM_ALIGNMENT_SIZE(size)    (((size) +  MEM_ALIGNMENT - 1) & ~( MEM_ALIGNMENT - 1 ))   // 申请的空间大小为不小于size的以4为倍数的大小          #define   MEM_ALIGNMENT_ADDR(addr)   ((void *)((Uint32)(addr) +  MEM_ALIGNMENT - 1) &~ (Uint32)( MEM_ALIGNMENT -1)) // 申请的起始地址为不小于addr的以4为倍数的地址