<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/64521>64521</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Missing documentation on how nontemporal stores interact with concurrency primitives
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
RalfJung
</td>
</tr>
</table>
<pre>
The LLVM LangRef doesn't document how `!nontemporal` stores are intended to interact with concurrency primitives. The current interactions are extremely surprising, basically making `!nontemporal` stores even less ordered than "non-atomic" stores:
```
Thread A:
store i32 %v, ptr %p, !nontemporal !13
fence release
// set some global flag (relaxed write)
Thread B:
// wait till global flag is set (relaxed read)
fence acquire
%_0 = load i32, ptr %p, !noundef !11
```
According to all the usual concurrency rules, that last load must see the store. However, the way LLVM compiles this program on x86, it has a data race: the fences become NOPs and the relaxed accesses become regular MOV, so we end up with `MOVNT; MOV` in thread A, which the CPU is allowed to reorder -- meaning that thread B might see the flag write but then fail to see the data store!
In other words, `!nontemporal` violates TSO, but the compilation scheme LLVM (and everyone else) uses for release/acquire synchronization relies on TSO. Together this leads to rather unpredictable semantics.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyMVF1v6zYM_TXKC9HAlpvUffBDPxBsQ3t7cW_W14GWaVubLHmiHDf79YNk9wsohgFBYkfk0eEheZBZd5aoErtbsbvf4BR656sfaNrfJtttatecq2NP8PDw_AgPaLsf1ELjiK2QVwEap6aBbIDezSD2mZC5dTbQMDqPRuwz4OA8MaAn0DaQbaiB4NKzRxVg1qEH5ayavCerzjB6PeigT8RbiDcvB-EtQzu7wNFL8DSQOQNPfvSate2EvIMaWSs05gwD_qVt95-86EQWDDGD8w35SK5HC0JK6-wFBjdoJaRcw0VxI7J7kd1EyOWTXo-9J2zg5u0clgTQhQQhd6fIaww-Po_x-TOf-JoXa2ZLVhF4MoRMr2hCHoQ8AFMAdgNBZ1yNBlqDHQhZejL4Qg3MXgcS8nol-ZHb7QduK9qMOkDQxnyC05yu-YAa899AYSWI6u9J-1eCQu7-yEAU92AcNrHsLyuebENtqjb_Usfl-0Yp55vYueAAjYHQE0w8ofk0KH4yxBE69BjAIIfl8mHiAEyU0lIbtvCLm-lEfokmmPG8TLRyw6gNMYReM4zedR4HcBZeyn0M1gF6ZEBoMCB4VCSKmwSRVGCoScV-fHv6zoC2SUevuqFSxPwe5KmbDHp4fHqO2OxgJiDbwDQuayD22ePT87ejKG5T0D4DbSG8Dpe8g7nXqk-X3H3_PbYKjXHzslKe0gjDxQUMhDbpF5VZ829h0F3_rkxqdhoYqKcYRRZa1CZCvcakqpOEQuYfW_SrBRd68jA736QmfLlkJ-0MBmI4_nxKq7lctMqOcZeBVU_DajBCllHE2KqzswRkOI4zTFHF1vm3tZCHdf6Az1b13ln9zwLnyWji2MLjz6ctHF1HiWhqsCFsOGmF6c_Jjp4arQLWhoBpQBu04u2mqYrmurjGDVX5_jq_LPNdvt_0VZury0yVObaFpDq_bkspdyWWzVXb7vaZ3OhKZrLIyqzMrnZlsd8WtcwkqZp2qszzPBOXGQ2ozdaY07B1vtto5omq_eVO5huDNRlObiylpRnSoZAymrOvYs5FPXUsLjOjOfA7StDBUPWoOdrgmy8vmjib_Pmj46z2939seDN5U_UhjMn-knV0OvRTvVVuEPIQKaw_F6N3f5IKQh4ScRbykAr7NwAA__9JPB3X">