2019-10-20 14:43:14 +00:00
|
|
|
#
|
|
|
|
# Loongson Processors' Support
|
|
|
|
#
|
|
|
|
|
|
|
|
cflags-$(CONFIG_CPU_LOONGSON2EF) += -Wa,--trap
|
MIPS: Loongson2ef: Remove unnecessary {as,cc}-option calls
When building with LLVM's integrated assembler, the build errors because
it does not implement -mfix-loongson2f-{jump,nop}:
arch/mips/loongson2ef/Platform:36: *** only binutils >= 2.20.2 have needed option -mfix-loongson2f-nop. Stop.
The error is a little misleading because binutils are not being used in
this case.
To clear this up, remove the as-option calls because binutils 2.23 is
the minimum supported version for building the kernel. At the same time,
remove the cc-option calls for the '-march=' flags, as GCC 5.1.0 is the
minimum supported version.
This change will not fix the LLVM build for CONFIG_CPU_LOONGSON2{E,F},
as it does not implement the loongson2{e,f} march arguments (nor r4600,
so it will error prior to this change) nor the assembler flags mentioned
above but it will make the errors more obvious.
Link: https://github.com/ClangBuiltLinux/linux/issues/1529
Reported-by: Ryutaroh Matsumoto <ryutaroh@ict.e.titech.ac.jp>
Signed-off-by: Nathan Chancellor <nathan@kernel.org>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
2021-12-07 17:59:51 +00:00
|
|
|
cflags-$(CONFIG_CPU_LOONGSON2E) += -march=loongson2e
|
|
|
|
cflags-$(CONFIG_CPU_LOONGSON2F) += -march=loongson2f
|
MIPS: Loongson-2EF: disable fix-loongson3-llsc in compiler
Firstly, Loongson-2EF support ll/sc instructions, but
doesn't need fix-loongson3-llsc compile option.
Secondly, fix-loongson3-llsc will cause kernel startup
fail at futex_init, because compiler will add 'sync' before
'll', which will affect __ex_table.
futex_init will pass NULL uaddr parameter to
futex_atomic_cmpxchg_inatomic.
futex_atomic_cmpxchg_inatomic will access uaddr directly,
which will cause page fault exception, the exception should be
handled by __ex_table's nextinsn if the exception insn exsit in
__ex_table. Because __ex_table is affected by compiler,
the exception can not be handled, and
futex_atomic_cmpxchg_inatomic will crash.
Error code as below:
__ex_table.insn = 1b, which is 'sync' compiled with
fix-loongson3-llsc, but the actual exception instrction is ll.
So, do_page_fault will not find the correct inst in __ex_table, and
can not handle this exception.
"1: "user_ll("%1", "%3")" \n"
" bne %1, %z4, 3f \n"
" .set pop \n"
" move $1, %z5 \n"
" .set "MIPS_ISA_ARCH_LEVEL" \n"
"2: "user_sc("$1", "%2")" \n"
" beqz $1, 1b \n"
"3: " __SYNC_ELSE(full, loongson3_war, __WEAK_LLSC_MB) "\n"
" .insn \n"
" .set pop \n"
" .section .fixup,\"ax\" \n"
"4: li %0, %6 \n"
" j 3b \n"
" .previous \n"
" .section __ex_table,\"a\" \n"
" "__UA_ADDR "\t1b, 4b \n"
" "__UA_ADDR "\t2b, 4b \n"
" .previous
Signed-off-by: Lichao Liu <liulichao@loongson.cn>
Reviewed-by: Jiaxun Yang <jiaxun.yang@flygoat.com>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
2020-06-11 09:59:24 +00:00
|
|
|
#
|
|
|
|
# Some versions of binutils, not currently mainline as of 2019/02/04, support
|
|
|
|
# an -mfix-loongson3-llsc flag which emits a sync prior to each ll instruction
|
|
|
|
# to work around a CPU bug (see __SYNC_loongson3_war in asm/sync.h for a
|
|
|
|
# description).
|
|
|
|
#
|
|
|
|
# We disable this in order to prevent the assembler meddling with the
|
|
|
|
# instruction that labels refer to, ie. if we label an ll instruction:
|
|
|
|
#
|
|
|
|
# 1: ll v0, 0(a0)
|
|
|
|
#
|
|
|
|
# ...then with the assembler fix applied the label may actually point at a sync
|
|
|
|
# instruction inserted by the assembler, and if we were using the label in an
|
|
|
|
# exception table the table would no longer contain the address of the ll
|
|
|
|
# instruction.
|
|
|
|
#
|
|
|
|
# Avoid this by explicitly disabling that assembler behaviour. If upstream
|
|
|
|
# binutils does not merge support for the flag then we can revisit & remove
|
|
|
|
# this later - for now it ensures vendor toolchains don't cause problems.
|
|
|
|
#
|
|
|
|
cflags-$(CONFIG_CPU_LOONGSON2EF) += $(call as-option,-Wa$(comma)-mno-fix-loongson3-llsc,)
|
|
|
|
|
2019-10-20 14:43:14 +00:00
|
|
|
# Enable the workarounds for Loongson2f
|
|
|
|
ifdef CONFIG_CPU_LOONGSON2F_WORKAROUNDS
|
MIPS: Loongson2ef: Remove unnecessary {as,cc}-option calls
When building with LLVM's integrated assembler, the build errors because
it does not implement -mfix-loongson2f-{jump,nop}:
arch/mips/loongson2ef/Platform:36: *** only binutils >= 2.20.2 have needed option -mfix-loongson2f-nop. Stop.
The error is a little misleading because binutils are not being used in
this case.
To clear this up, remove the as-option calls because binutils 2.23 is
the minimum supported version for building the kernel. At the same time,
remove the cc-option calls for the '-march=' flags, as GCC 5.1.0 is the
minimum supported version.
This change will not fix the LLVM build for CONFIG_CPU_LOONGSON2{E,F},
as it does not implement the loongson2{e,f} march arguments (nor r4600,
so it will error prior to this change) nor the assembler flags mentioned
above but it will make the errors more obvious.
Link: https://github.com/ClangBuiltLinux/linux/issues/1529
Reported-by: Ryutaroh Matsumoto <ryutaroh@ict.e.titech.ac.jp>
Signed-off-by: Nathan Chancellor <nathan@kernel.org>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
2021-12-07 17:59:51 +00:00
|
|
|
cflags-$(CONFIG_CPU_NOP_WORKAROUNDS) += -Wa,-mfix-loongson2f-nop
|
|
|
|
cflags-$(CONFIG_CPU_JUMP_WORKAROUNDS) += -Wa,-mfix-loongson2f-jump
|
2019-10-20 14:43:14 +00:00
|
|
|
endif
|
|
|
|
|
2020-09-23 10:33:12 +00:00
|
|
|
# Some -march= flags enable MMI instructions, and GCC complains about that
|
|
|
|
# support being enabled alongside -msoft-float. Thus explicitly disable MMI.
|
|
|
|
cflags-y += $(call cc-option,-mno-loongson-mmi)
|
|
|
|
|
2019-10-20 14:43:14 +00:00
|
|
|
#
|
|
|
|
# Loongson Machines' Support
|
|
|
|
#
|
|
|
|
|
|
|
|
cflags-$(CONFIG_MACH_LOONGSON2EF) += -I$(srctree)/arch/mips/include/asm/mach-loongson2ef -mno-branch-likely
|
|
|
|
load-$(CONFIG_LEMOTE_FULOONG2E) += 0xffffffff80100000
|
|
|
|
load-$(CONFIG_LEMOTE_MACH2F) += 0xffffffff80200000
|