Add RISC-V spinlock support in s_lock.h.
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 13 Aug 2021 17:58:47 +0000 (13:58 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 13 Aug 2021 17:59:06 +0000 (13:59 -0400)
commit48695decc27159275a10cf9e1f31bae51f311305
tree4cdba192d195aea5de8de75faaaa373472a5dd74
parent4873da79da4bbd54f580ca6e5b2f5c46ae6e4bc6
Add RISC-V spinlock support in s_lock.h.

Like the ARM case, just use gcc's __sync_lock_test_and_set();
that will compile into AMOSWAP.W.AQ which does what we need.

At some point it might be worth doing some work on atomic ops
for RISC-V, but this should be enough for a creditable port.

Back-patch to all supported branches, just in case somebody
wants to try them on RISC-V.

Marek Szuba

Discussion: https://postgr.es/m/dea97b6d-f55f-1f6d-9109-504aa7dfa421@gentoo.org
src/include/storage/s_lock.h