MIPS: Apply `.insn' to fixup labels throughout
authorMaciej W. Rozycki <macro@codesourcery.com>
Sat, 15 Nov 2014 22:09:31 +0000 (22:09 +0000)
committerRalf Baechle <ralf@linux-mips.org>
Mon, 24 Nov 2014 06:45:36 +0000 (07:45 +0100)
commit0e525e48f73cc8a4df8da0be77e4146bea85e1a5
tree44d3ac8b6859b5b45ea9d58a71f7ac9f7a70336b
parentb0984c43702f0fe2dbb0c344843e36c8b2cd13f1
MIPS: Apply `.insn' to fixup labels throughout

Fix the issue with the ISA bit being lost in fixups that jump to labels
placed just before a section switch.  Such a switch leads to the ISA bit
being lost, because GAS concludes there is no code that follows and
therefore the label refers to data.  Use the `.insn' pseudo-op to
convince the tool this is not the case.

This lack of label annotation leads to microMIPS compilation errors
like:

mips-linux-gnu-ld: arch/mips/built-in.o: .fixup+0x3b8: Unsupported jump between ISA modes; consider recompiling with interlinking enabled.
mips-linux-gnu-ld: final link failed: Bad value

Signed-off-by: Maciej W. Rozycki <macro@codesourcery.com>
Signed-off-by: Steven J. Hill <Steven.Hill@imgtec.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/8483/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/include/asm/futex.h
arch/mips/include/asm/paccess.h
arch/mips/kernel/syscall.c