x86_64 中雙精度數和向量的原子操作
而C 11 std::atomic在大多數實現上提供無鎖操作,原子AVX 或SSE 向量操作仍然依賴CPU,並且缺乏彙編級支援。
雙精度上的原子操作
- 對於 8 個位元組,包括雙精度數,加載和儲存操作自然是原子的。
- 讀取-修改-寫入操作需要一個使用 cmpxchg(或 TSX)重試循環,因為沒有直接記憶體目標指令。
- Cmpxchg16b 可用於 16 位元組原子 RMW 操作。
- IEEE 浮點操作的一些特殊情況可以是使用整數運算實現(例如絕對值,
向量上的原子操作
- 跨快取一致性系統的原子向量載入/儲存操作沒有硬體支援。 🎜>
雙精確度對齊陣列上的向量載入/儲存可能可以安全使用,而不會帶來快取行的風險- 對於16 位元組原子載入/儲存/RMW,可以使用cmpxchg16b。
- 原子更新16 位元組物件是可能的,但不能保證單獨讀取 8位元組一半是原子的。載入/儲存(例如,直接使用mov 指令傳入/傳出xmm暫存器)。
以上是x86_64 上的雙精度運算和向量運算的原子性如何?的詳細內容。更多資訊請關注PHP中文網其他相關文章!