memory-model Questions

1

Solved

#include <memory> #include <atomic> #include <iostream> #include <thread> #include <cassert> int main() { std::atomic<bool> flag = {false}; std::atomic<int&...
Calan asked 19/9, 2024 at 14:22

1

Solved

Consider the following code, with adjacent mutex sections containing shared memory accesses: std::mutex mutex; int x; void func() { { std::lock_guard lock{mutex}; x++; } { std::lock_guard lo...
Captor asked 22/6, 2024 at 13:0

0

After a release operation A is performed on an atomic object M, the longest continuous subsequence of the modification order of M that consists of: Writes performed by the same thread that perfor...
Vastha asked 10/9, 2023 at 11:57

2

Solved

(Assume: int x{ 6 } and 2 evaluations write x = 6 at the same time) -- CPP reference says on Multi-threaded executions and data races | Data races: When an evaluation of an expression writes to a ...
Adagio asked 3/9, 2023 at 10:8

2

Solved

TL:DR: if a mutex implementation uses acquire and release operations, could an implementation do compile-time reordering like would normally be allowed and overlap two critical sections that should...
Tumulus asked 19/4, 2020 at 4:51

1

Solved

Just when I thought I got some grip around atomics, I see another article. This is an excerpt from GCC wiki, under Overall Summary: -Thread 1- -Thread 2- -Thread 3- y.store (20); if (x.load() == ...
Reeducate asked 11/2, 2023 at 18:16

4

While reading the source codes of Go, I have a question about the code in src/sync/once.go: func (o *Once) Do(f func()) { // Note: Here is an incorrect implementation of Do: // // if atomic.Comp...
Yvor asked 28/1, 2021 at 10:18

6

Solved

I don't understand, why will be problems without release sequence, if we have 2 threads in the example below. We have only 2 operations on the atomic variable count. count is decremented sequently ...
Editor asked 25/7, 2016 at 10:43

0

In the following code int a = A.load(std::memory_order_acquire); T b = load_non_atomic(data); // ---- barrier ---- int c = A.load(std::memory_order_acquire); What kind of barrier should I use ...
Scarberry asked 14/10, 2022 at 12:43

2

Solved

Consider the following situation // Global int x = 0; // not atomic // Thread 1 x = 1; // Thread 2 if (false) x = 2; Does this constitute a data race according to the standard? [intro.races] sa...
Keramic asked 9/6, 2022 at 14:2

1

Solved

I've read this Q&A: What is the significance of 'strongly happens before' compared to '(simply) happens before'? The author gives an outline of an interesting evaluation that wa...
Zamia asked 24/5, 2022 at 22:57

4

Solved

I am currently reading C++ Concurrency in Action by Anthony Williams. One of his listing shows this code, and he states that the assertion that z != 0 can fire. #include <atomic> #include &...
Fishman asked 22/1, 2018 at 14:31

2

Solved

When it comes to implementing CAS Loop using std::atomic, cppreference in this link gives the following example for push: template<typename T> class stack { std::atomic<node<T>*&gt...
Majormajordomo asked 31/10, 2019 at 0:8

3

Solved

I read a chapter and I didn't like it much. I'm still unclear what the differences is between each memory order. This is my current speculation which I understood after reading the much more simple...
Scarbrough asked 10/9, 2012 at 6:39

1

Solved

I read about Herb's atomic<> Weapons talk and had a question about page 42: He mentioned that (50:00 in the video): (x86) stores are much stronger than they need to be... What I don't unde...
Frambesia asked 6/12, 2021 at 17:43

1

Solved

Consider the store buffer litmus test with SC atomics: // Initial std::atomic<int> x(0), y(0); // Thread 1 // Thread 2 x.store(1); y.store(1); auto r1 = y.load(); auto r2 = x.load(); Can th...

3

Solved

My understanding of std::memory_order_acquire and std::memory_order_release is as follows: Acquire means that no memory accesses which appear after the acquire fence can be reordered to before the...
Sequestered asked 24/4, 2016 at 15:1

2

Solved

it make me confused, i reading golang memory model, https://golang.org/ref/mem var l sync.Mutex var a string func f() { a = "hello, world" l.Unlock() } func main() { l.Lock() go f()...
Outrank asked 23/3, 2021 at 8:51

4

Solved

Many programming languages today have happens-before relation and release+acquire synchronization operations. Some of these programming languages: C/C++11: happens-before, release+acquire Rust and...
Haughay asked 1/11, 2021 at 1:38

1

Solved

Consider this code: std::atomic<int> x{ 0 }; std::atomic<int> y{ 0 }; int a; int b; void thread1() { //atomic op A x.store(1, std::memory_order_relaxed); //fence X std::atomic_thr...
Sturdy asked 29/10, 2021 at 18:53

4

Solved

I was recently answering a question on the undefined behaviour of doing p < q in C when p and q are pointers into different objects/arrays. That got me thinking: C++ has the same (undefined) beh...

1

Solved

I've been studying the memory model and saw this (quote from https://research.swtch.com/hwmm): Litmus Test: Write Queue (also called Store Buffer) Can this program see r1 = 0, r2 = 0? // Thread 1 /...
Galactometer asked 9/9, 2021 at 3:51

1

With ARMv8.3 a new instruction has been introduced: LDAPR. When there is a STLR followed by a LDAR to a different address, then these 2 can't be reordered and hence it is called RCsc (release consi...

3

Solved

Learning golang on the way, I got a little confused when trying to understand the channel communications described in the memory model spec as below: A send on a channel happens before the cor...
Saiga asked 19/10, 2017 at 4:5

3

I'm trying to compile and link a simple program to a DOS .com file using Turbo C compiler and linker. By that I try the simplest C-program I can think of. void main() {} Are there command line a...
Sour asked 1/5, 2019 at 14:50

© 2022 - 2025 — McMap. All rights reserved.