From: Rich Felker Date: Thu, 8 Jun 2017 23:44:27 +0000 (-0400) Subject: use hard-coded sh4a atomic opcodes to avoid linker errors on sh X-Git-Tag: v1.1.17~61 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=bc313e880c6cde2e512d2f43e84968d1b12bd19d;p=oweals%2Fmusl.git use hard-coded sh4a atomic opcodes to avoid linker errors on sh 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. --- diff --git a/src/thread/sh/atomics.s b/src/thread/sh/atomics.s index 3b58cccc..9d9fcb6e 100644 --- a/src/thread/sh/atomics.s +++ b/src/thread/sh/atomics.s @@ -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