在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为倍数的地址