gpt4 book ai didi

c++ - 如何对齐堆栈上的缓冲区?

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:25:40 26 4
gpt4 key购买 nike

我正在尝试实现一个按大小对齐的内存缓冲区,以便我可以使用 DMA Controller 的模数功能来实现环形缓冲区。我知道我可以用 memalign 做到这一点,但我想知道是否可以在堆栈上这样做,因为到目前为止我已经能够避免动态内存。我正在使用 GCC 4.4.1,我不关心可移植性(嵌入式系统)。

我想做这样的事情:

template<uint16_t num_channels, uint16_t buffer_size>
class sampler {
__attribute__((aligned(buffer_size * num_channels * 2)))
uint16_t buffer[buffer_size][num_channels];
};

但是 GCC 当然不会接受非常量对齐(并且似乎表明对齐 > 8 可能无论如何都不会被接受)。

我想我可以使用 C++0x alignas() 来实现这一点,但它似乎直到 4.8 版才出现在 GCC 中。

我想一个选择可能是将缓冲区的大小加倍,但这似乎浪费了很多空间(我正计划尝试为该缓冲区使用设备内存的很大一部分)。也许我应该放弃并使用动态内存。 memalign 在空间浪费方面是否相对有效?

有什么想法吗?

最佳答案

你不需要将存储的大小加倍,你只需要添加 (alignment - 1) 到它——基本上和 memalign 后面做的一样场景。对于二次方对齐:

char buf[size + (alignment -1)];
char *aligned = (char*)((intptr_t)buf + (alignment - 1) & ~intptr_t(alignment - 1));

关于c++ - 如何对齐堆栈上的缓冲区?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13663911/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com