PowerPC: RTS SMP functions lack memory barriers
@hvr reported on POWER7 big endian (powerpc64) and on AIX (powerpc):
internal error: END_TSO_QUEUE object entered!
(GHC version 8.0.0.20160421 for powerpc64_unknown_linux)
Also concprog001 segfaults, which I falsely attributed to #11259 (closed) (no runtime linker support) when I marked the test broken on powerpc64.
I propose to use gcc and clang _sync_* built-ins that are already used in libraries/ghc-prim/cbits/atomic.c instead of CPP ifdefs and inline assembly.
Trac metadata
| Trac field | Value |
|---|---|
| Version | 8.0.1 |
| Type | Bug |
| TypeOfFailure | OtherFailure |
| Priority | normal |
| Resolution | Unresolved |
| Component | Runtime System |
| Test case | |
| Differential revisions | |
| BlockedBy | |
| Related | |
| Blocking | |
| CC | simonmar |
| Operating system | |
| Architecture |