繁体   English   中英

OpenMP原子内存顺序

[英]OpenMP atomic memory order

我开始学习OpenMP并发现了#pragma omp atomic指令。

我对C ++ 11的原子有基本的了解,并且知道你可以将memory_order参数传递给atomics的方法。 如果我错了,请纠正我,但我认为如果使用memory_order_seq_cst ,这允许使用atomics作为同步点。

一些限制较少的内存顺序,如memory_order_relaxed只需确保原子上的操作同步并对其他人可见。 它对其他内存更新没有任何帮助。

我想知道OpenMP的原子指令使用了什么内存顺序。 它只会同步对原子的访问,还是会充当内存同步的重点?

我的猜测是它更像是memory_order_relaxed ,因为critical是提供完全同步。

我欢迎任何好的解释/信息。 谢谢。

OpenMP内存模型一直在发展。 直到并包括OpenMP 3.1,该模型基于“刷新”操作。 这些与C ++内存模型中的任何内容都不具有可比性。 松散地说,刷新大致对应于atomic_thread_fence(x),其中x是memory_order_seq_cst。 但是,如果“两次冲洗的两个冲洗套件的交叉点是空的”那就存在了问题。

OpenMP 4.0添加了seq_cst子句,并直接回答了问题:

注 - 与其他隐式刷新区域一样,第20页的1.4.4节减少了必须强制执行的顺序。 目的是,当C ++ 11或C11中存在类似操作时,顺序一致的原子构造与C ++ 11 / C11中的memory_order_seq_cst原子操作具有相同的语义。 类似地,非顺序一致的原子结构与C ++ 11 / C11中的memory_order_relaxed原子操作具有相同的语义。

有关更多详细信息,请下载最新版本的规范 (此时为4.0),并阅读1.4.4“OpenMP内存一致性”和2.12.6“原子构造”部分。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM