确保一个cpu在另一个cpu读取“double”之前写了一个“double”?
发布时间:2020-12-16 09:45:05 所属栏目:百科 来源:网络整理
导读:我要在双核ARM Cortex-A9 CPU上运行一个操作系统(一个核心运行 Linux,另一个运行没有操作系统). 在无操作系统方面,我们将64位双写入DDR内存,然后Linux端读取它. 由于CPU具有到DDR的32位总线,因此该值在两个总线周期内传输,这意味着如果写入和读取在总线上混
我要在双核ARM Cortex-A9 CPU上运行一个操作系统(一个核心运行
Linux,另一个运行没有操作系统).
在无操作系统方面,我们将64位双写入DDR内存,然后Linux端读取它. 由于CPU具有到DDR的32位总线,因此该值在两个总线周期内传输,这意味着如果写入和读取在总线上混合,则该值可能会被破坏. 我该怎么做才能让它以安全的方式运作? 解决方法
您没有明确说明您的订购要求是什么或者您打算如何发出变化 – 所以我只是简单回答所述的问题:
如果在64位对齐位置执行LDREXD / STREXD指令,则保证它们是单拷贝原子(如果位置不是,则它们将中止).如果你正在做一些无锁的事情,这可能对你有益.如果没有,只需使用互斥锁实现它. 当然,只有满足以下任一条件,LDREXD / STREXD才能正常工作: > Linux和您的其他软件都启用了缓存,两个cpus都设置了“SMP”位,并且都将共享区域映射为可写回写的cacehable.> Linux和您的其他软件都将共享区域视为未缓存,并且您的SoC实现了内存设备的全局监视器. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |