加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

确保一个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实现了内存设备的全局监视器.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读