Home Backend Development C++ How Do Internal Reorderings in C Atomic Read-Modify-Write Operations Affect Memory Ordering?

How Do Internal Reorderings in C Atomic Read-Modify-Write Operations Affect Memory Ordering?

Dec 09, 2024 pm 07:59 PM

How Do Internal Reorderings in C   Atomic Read-Modify-Write Operations Affect Memory Ordering?

Treatment of Atomic Read-Modify-Write (RMW) Operations in Memory Ordering

In response to the question regarding the nature of atomic read-modify-write (RMW) operations, the C standard classifies them as single operations with semantics that combine both acquire and release properties.

Implications for Ordering

This designation implies that no memory reads or writes occurring in the same thread can be reordered before or after an RMW operation. However, it does not preclude the possibility of reordering between the internal read and write components of the RMW.

Concrete Example

Consider the code example provided:

std::atomic<int> x, y;

void thread_A() {
    x.exchange(1, std::memory_order_acq_rel);
    y.store(1, std::memory_order_relaxed);
}

void thread_B() {
    int yy = y.load(std::memory_order_acquire);
    int xx = x.load(std::memory_order_acquire);
    std::cout << xx << ", " << yy << std::endl;
}
Copy after login

In this scenario, Thread B can indeed output 0, 1. This is because the load and store operations performed within Thread A's RMW operation can be internallyreordered, allowing Thread B to observe the state after the load (0) but before the store (1).

ARM64 Implementation

The ARM64 implementation of the RMW operation, as described by the ldaxr, stlxr, and str instructions, aligns with the standard's expectations. The str instruction can be visible before the stlxr instruction, potentially leading to the observation of 0, 1 by Thread B.

Memory Order Implications

Replacing memory_order_acq_rel with seq_cst would not affect this behavior, as it only introduces additional semantics relative to other seq_cst operations, which are not present in the code example.

Conclusion

Atomic RMW operations in C are singular operations with acquire-release semantics. While they prevent reordering of external operations before and after, the potential for reordering between their internal components allows for scenarios like the one in the code example, where Thread B can output 0, 1.

The above is the detailed content of How Do Internal Reorderings in C Atomic Read-Modify-Write Operations Affect Memory Ordering?. For more information, please follow other related articles on the PHP Chinese website!

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

Hot Article

Hot tools Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

C language function format letter case conversion steps C language function format letter case conversion steps Mar 03, 2025 pm 05:53 PM

C language function format letter case conversion steps

Gulc: C library built from scratch Gulc: C library built from scratch Mar 03, 2025 pm 05:46 PM

Gulc: C library built from scratch

What are the types of values ​​returned by c language functions? What determines the return value? What are the types of values ​​returned by c language functions? What determines the return value? Mar 03, 2025 pm 05:52 PM

What are the types of values ​​returned by c language functions? What determines the return value?

What are the definitions and calling rules of c language functions and what are the What are the definitions and calling rules of c language functions and what are the Mar 03, 2025 pm 05:53 PM

What are the definitions and calling rules of c language functions and what are the

How does the C   Standard Template Library (STL) work? How does the C Standard Template Library (STL) work? Mar 12, 2025 pm 04:50 PM

How does the C Standard Template Library (STL) work?

Where is the return value of the c language function stored in memory? Where is the return value of the c language function stored in memory? Mar 03, 2025 pm 05:51 PM

Where is the return value of the c language function stored in memory?

distinct usage and phrase sharing distinct usage and phrase sharing Mar 03, 2025 pm 05:51 PM

distinct usage and phrase sharing

What is the minimum common multiple of the maximum common divisor of a c language function? What is the minimum common multiple of the maximum common divisor of a c language function? Mar 03, 2025 pm 05:55 PM

What is the minimum common multiple of the maximum common divisor of a c language function?

See all articles