Home > Backend Development > C++ > Can Modern x86 CPUs Really Not Atomically Store a Single Byte to Memory?

Can Modern x86 CPUs Really Not Atomically Store a Single Byte to Memory?

Linda Hamilton
Release: 2024-12-29 08:49:10
Original
634 people have browsed it

Can Modern x86 CPUs Really Not Atomically Store a Single Byte to Memory?

Can Modern x86 Hardware Not Store a Single Byte to Memory?

Stroustrup's statement in his book refers to the potential behavior of hypothetical hardware without a well-defined memory model. He suggests that such hardware might implement byte stores with non-atomic updates, potentially affecting neighboring bytes.

Actual Modern Hardware Behavior

However, modern hardware, including x86, does not behave in the way Stroustrup describes:

  • Single-byte stores on x86 hardware are atomic and do not disturb surrounding bytes.
  • Implementing byte stores with atomic RMW cycles (read-modify-write) is unnecessary and inefficient on high-performance CPUs.
  • Some non-x86 CPUs may use atomic RMW cycles internally to implement byte stores, but this is not visible to external software.

Historical Context

Stroustrup's statement may have been based on the behavior of early Alpha AXP processors, which initially did not support byte load/store instructions. However, later versions of Alpha and all modern CPUs support safe and efficient byte stores.

Hardware Implementation

Modern CPUs typically use caches that store segments of memory. In a cached system:

  • All byte stores within a cache line are atomic.
  • The CPU fetches the entire cache line, modifies the byte, and writes the line back to memory.
  • The cache controller remains in control of the line while the byte update is performed, preventing unintended changes by other cores.

Exceptions

While modern CPUs provide atomic byte stores, there may be exceptions in certain situations:

  • Uncacheable memory regions may not have the same safeguards, potentially allowing non-atomic byte writes.
  • I/O operations to devices may not be atomic at the byte level.

Conclusion

In practice, modern hardware supports atomic byte stores, making Stroustrup's description of potential hardware behavior less relevant to actual systems. The memory model guarantees provided by C compilers rely on the reliable behavior of modern hardware to ensure thread safety.

The above is the detailed content of Can Modern x86 CPUs Really Not Atomically Store a Single Byte to Memory?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template