pthreads v. SSE weak memory ordering

后端 未结 1 734
滥情空心
滥情空心 2021-02-15 09:33

Do the Linux glibc pthread functions on x86_64 act as fences for weakly-ordered memory accesses? (pthread_mutex_lock/unlock are the exact functions I\'m interested in).

1条回答
  •  暖寄归人
    2021-02-15 09:50

    Non-temporal stores need sfence instruction to be ordered properly.

    However, the efficient user-level implementation of a simple mutex supposes that it is released by a simple write which does not imply write-buffers flush, in contrast to atomic read-modify-write operations like lock cmpxchg which imply full memory fence.

    So you have a situation when the unlock has no effect of store-with-release semantic applied for non-temporal stores. Thus, these SSE stores can be reordered after the unlock and after another thread acquires the mutex.

    0 讨论(0)
提交回复
热议问题