use hard-coded sh4a atomic opcodes to avoid linker errors on sh
authorRich Felker <dalias@aerifal.cx>
Thu, 8 Jun 2017 23:44:27 +0000 (19:44 -0400)
committerRich Felker <dalias@aerifal.cx>
Thu, 8 Jun 2017 23:44:27 +0000 (19:44 -0400)
when using the sh4a opcodes, the assembler tags the resulting object
file as requiring sh4a. the linker then refuses to (static) link it
with object files marked as requiring j2, since there is no isa level
that includes both sh4a and j2 instructions.

src/thread/sh/atomics.s

index 3b58ccccb2cbb454e99878bec6a1eda033f47d1c..9d9fcb6eda587f5d0d4e18063eb2409bfa7e4936 100644 (file)
@@ -28,15 +28,15 @@ __sh_cas_gusa:
 .hidden __sh_cas_llsc
 __sh_cas_llsc:
        mov r0,r1
-       synco
-0:     movli.l @r1,r0
+       .word 0x00ab /* synco */
+0:     .word 0x0163 /* movli.l @r1,r0 */
        cmp/eq r0,r2
        bf 1f
        mov r3,r0
-       movco.l r0,@r1
+       .word 0x0173 /* movco.l r0,@r1 */
        bf 0b
        mov r2,r0
-1:     synco
+1:     .word 0x00ab /* synco */
        mov r0,r3
        rts
         mov r1,r0