gpt4 book ai didi

c - 如何为 TMS320F2812 DSP 编写内存屏障?

转载 作者:行者123 更新时间:2023-12-03 20:22:12 24 4
gpt4 key购买 nike

我浏览了 TI C/C++ 编译器 v6.1 用户指南 ( spru514e ),但没有找到任何内容。
asm声明似乎没有在这方面提供任何内容,手册甚至警告不要更改变量的值(p132)。用于声明对变量的影响的 GNU 扩展未实现 (p115)。

我也没有找到任何内在的内存屏障(比如 Keil 的 armcc 中的 __memory_changed() )。

搜索网络或 TI 论坛也没有任何结果。

任何其他提示如何继续?

最佳答案

内存屏障与内存访问的顺序有关,但您还必须确保值不会留在寄存器中,而是完全写入内存。

使用 TI 编译器强制执行此操作的唯一方法是使用 volatile .

请注意 volatile ,虽然是一个变量的修饰符,但在它的实现中不是关于变量本身(即它的内存),而是关于对这个变量的所有访问。
因此,如果您想避免优化太少的影响,请编写您的程序,以便只有某些变量访问是 volatile 的。

为此,请正常声明变量,并添加 volatile仅当您想强制读取或写入变量时。
您可以像这样使用辅助函数:

inline void force_write(int *ptr, int value)
{
*(volatile int *)ptr = value;
}

或者使用这个从 Linux 窃取的漂亮宏,可用于读/写和所有类型:
#define ACCESS_ONCE(x) (*(volatile typeof(x) *)&(x))
...
if (ACCESS_ONCE(ready) != 0)
ACCESS_ONCE(new_data) = 42;

(这个名字有历史原因;最好叫它 FORCE_ACCESS 。)

关于c - 如何为 TMS320F2812 DSP 编写内存屏障?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12797181/

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