]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
Fixes for 4.4
authorSasha Levin <sashal@kernel.org>
Sun, 22 Nov 2020 19:20:10 +0000 (14:20 -0500)
committerSasha Levin <sashal@kernel.org>
Sun, 22 Nov 2020 19:20:10 +0000 (14:20 -0500)
Signed-off-by: Sasha Levin <sashal@kernel.org>
queue-4.4/mips-fix-build_rollback_prologue-for-micromips.patch [new file with mode: 0644]
queue-4.4/series

diff --git a/queue-4.4/mips-fix-build_rollback_prologue-for-micromips.patch b/queue-4.4/mips-fix-build_rollback_prologue-for-micromips.patch
new file mode 100644 (file)
index 0000000..c34a12b
--- /dev/null
@@ -0,0 +1,50 @@
+From df536f17f3083c55d06cde985eae4a4f05dee89b Mon Sep 17 00:00:00 2001
+From: Sasha Levin <sashal@kernel.org>
+Date: Fri, 19 Aug 2016 18:15:40 +0100
+Subject: MIPS: Fix BUILD_ROLLBACK_PROLOGUE for microMIPS
+
+From: Paul Burton <paul.burton@imgtec.com>
+
+[ Upstream commit 1eefcbc89cf3a8e252e5aeb25825594699b47360 ]
+
+When the kernel is built for microMIPS, branches targets need to be
+known to be microMIPS code in order to result in bit 0 of the PC being
+set. The branch target in the BUILD_ROLLBACK_PROLOGUE macro was simply
+the end of the macro, which may be pointing at padding rather than at
+code. This results in recent enough GNU linkers complaining like so:
+
+    mips-img-linux-gnu-ld: arch/mips/built-in.o: .text+0x3e3c: Unsupported branch between ISA modes.
+    mips-img-linux-gnu-ld: final link failed: Bad value
+    Makefile:936: recipe for target 'vmlinux' failed
+    make: *** [vmlinux] Error 1
+
+Fix this by changing the branch target to be the start of the
+appropriate handler, skipping over any padding.
+
+Signed-off-by: Paul Burton <paul.burton@imgtec.com>
+Cc: linux-mips@linux-mips.org
+Patchwork: https://patchwork.linux-mips.org/patch/14019/
+Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
+Signed-off-by: Sasha Levin <sashal@kernel.org>
+---
+ arch/mips/kernel/genex.S | 3 +--
+ 1 file changed, 1 insertion(+), 2 deletions(-)
+
+diff --git a/arch/mips/kernel/genex.S b/arch/mips/kernel/genex.S
+index 7ffd158de76e5..1b837d6f73deb 100644
+--- a/arch/mips/kernel/genex.S
++++ b/arch/mips/kernel/genex.S
+@@ -142,9 +142,8 @@ LEAF(__r4k_wait)
+       PTR_LA  k1, __r4k_wait
+       ori     k0, 0x1f        /* 32 byte rollback region */
+       xori    k0, 0x1f
+-      bne     k0, k1, 9f
++      bne     k0, k1, \handler
+       MTC0    k0, CP0_EPC
+-9:
+       .set pop
+       .endm
+-- 
+2.27.0
+
index cc40d40ba8c27e2418c730abd88dd4f19deb8c3f..e321c5bfc3df09c9623bbc21d95c1cb032f3da03 100644 (file)
@@ -12,3 +12,4 @@ net-usb-qmi_wwan-set-dtr-quirk-for-mr400.patch
 net-have-netpoll-bring-up-dsa-management-interface.patch
 pinctrl-rockchip-enable-gpio-pclk-for-rockchip_gpio_.patch
 arm64-psci-avoid-printing-in-cpu_psci_cpu_die.patch
+mips-fix-build_rollback_prologue-for-micromips.patch