linux-mips.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/4] MIPS I/II FP signal context handling fixes
@ 2016-10-31 16:24 Maciej W. Rozycki
  2016-10-31 16:24 ` Maciej W. Rozycki
                   ` (4 more replies)
  0 siblings, 5 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:24 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Hi,

 These fix a bunch of MIPS I/II FP signal context handling issues I have 
discovered while working on the recent FCSR updates.  See individual patch 
descriptions for details.

 Please queue for the upstream merge.

  Maciej

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 0/4] MIPS I/II FP signal context handling fixes
  2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
@ 2016-10-31 16:24 ` Maciej W. Rozycki
  2016-10-31 16:25 ` [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling Maciej W. Rozycki
                   ` (3 subsequent siblings)
  4 siblings, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:24 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Hi,

 These fix a bunch of MIPS I/II FP signal context handling issues I have 
discovered while working on the recent FCSR updates.  See individual patch 
descriptions for details.

 Please queue for the upstream merge.

  Maciej

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling
  2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
  2016-10-31 16:24 ` Maciej W. Rozycki
@ 2016-10-31 16:25 ` Maciej W. Rozycki
  2016-10-31 16:25   ` Maciej W. Rozycki
  2016-11-01  9:27   ` Paul Burton
  2016-10-31 16:26 ` [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context Maciej W. Rozycki
                   ` (2 subsequent siblings)
  4 siblings, 2 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:25 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit 0ae8dceaebe3 ("Merge with 2.3.10.") and use the local 
`fault' handler to recover from FP sigcontext access violation faults, 
like corresponding code does in r4k_fpu.S.  The `bad_stack' handler is 
in syscall.c and is not suitable here as we want to propagate the error 
condition up through the caller rather than killing the thread outright.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
 I guess it hardly ever triggers and code still builds, so it has aged so
well...

  Maciej

linux-mips-isa1-sig-fp-context-fault.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:36:46.000000000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:37:20.891186000 +0100
@@ -21,7 +21,7 @@
 #define EX(a,b)							\
 9:	a,##b;							\
 	.section __ex_table,"a";				\
-	PTR	9b,bad_stack;					\
+	PTR	9b,fault;					\
 	.previous
 
 	.set	noreorder

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling
  2016-10-31 16:25 ` [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling Maciej W. Rozycki
@ 2016-10-31 16:25   ` Maciej W. Rozycki
  2016-11-01  9:27   ` Paul Burton
  1 sibling, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:25 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit 0ae8dceaebe3 ("Merge with 2.3.10.") and use the local 
`fault' handler to recover from FP sigcontext access violation faults, 
like corresponding code does in r4k_fpu.S.  The `bad_stack' handler is 
in syscall.c and is not suitable here as we want to propagate the error 
condition up through the caller rather than killing the thread outright.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
 I guess it hardly ever triggers and code still builds, so it has aged so
well...

  Maciej

linux-mips-isa1-sig-fp-context-fault.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:36:46.000000000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:37:20.891186000 +0100
@@ -21,7 +21,7 @@
 #define EX(a,b)							\
 9:	a,##b;							\
 	.section __ex_table,"a";				\
-	PTR	9b,bad_stack;					\
+	PTR	9b,fault;					\
 	.previous
 
 	.set	noreorder

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context
  2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
  2016-10-31 16:24 ` Maciej W. Rozycki
  2016-10-31 16:25 ` [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling Maciej W. Rozycki
@ 2016-10-31 16:26 ` Maciej W. Rozycki
  2016-10-31 16:26   ` Maciej W. Rozycki
  2016-10-31 16:27 ` [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets Maciej W. Rozycki
  2016-10-31 16:27 ` [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout Maciej W. Rozycki
  4 siblings, 1 reply; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:26 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit e50c0a8fa60d ("Support the MIPS32 / MIPS64 DSP ASE.") 
and remove the Floating Point Implementation Register (FIR) from the FP 
register set recorded in a signal context with MIPS I processors too, in 
line with the change applied to r4k_fpu.S.

The `sc_fpc_eir' slot is unused according to our current ABI and the FIR 
register is read-only and always directly accessible from user software.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa1-sig-fp-context-dsp.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:17:38.000000000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:19:40.565112000 +0100
@@ -64,13 +64,9 @@ LEAF(_save_fp_context)
 	EX(swc1 $f29,(SC_FPREGS+232)(a0))
 	EX(swc1 $f30,(SC_FPREGS+240)(a0))
 	EX(swc1 $f31,(SC_FPREGS+248)(a0))
-	EX(sw	t1,(SC_FPC_CSR)(a0))
-	cfc1	t0,$0				# implementation/version
 	jr	ra
+	 EX(sw	t1,(SC_FPC_CSR)(a0))
 	.set	pop
-	.set	nomacro
-	 EX(sw	t0,(SC_FPC_EIR)(a0))
-	.set	macro
 	END(_save_fp_context)
 
 /*

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context
  2016-10-31 16:26 ` [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context Maciej W. Rozycki
@ 2016-10-31 16:26   ` Maciej W. Rozycki
  0 siblings, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:26 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit e50c0a8fa60d ("Support the MIPS32 / MIPS64 DSP ASE.") 
and remove the Floating Point Implementation Register (FIR) from the FP 
register set recorded in a signal context with MIPS I processors too, in 
line with the change applied to r4k_fpu.S.

The `sc_fpc_eir' slot is unused according to our current ABI and the FIR 
register is read-only and always directly accessible from user software.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa1-sig-fp-context-dsp.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:17:38.000000000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:19:40.565112000 +0100
@@ -64,13 +64,9 @@ LEAF(_save_fp_context)
 	EX(swc1 $f29,(SC_FPREGS+232)(a0))
 	EX(swc1 $f30,(SC_FPREGS+240)(a0))
 	EX(swc1 $f31,(SC_FPREGS+248)(a0))
-	EX(sw	t1,(SC_FPC_CSR)(a0))
-	cfc1	t0,$0				# implementation/version
 	jr	ra
+	 EX(sw	t1,(SC_FPC_CSR)(a0))
 	.set	pop
-	.set	nomacro
-	 EX(sw	t0,(SC_FPC_EIR)(a0))
-	.set	macro
 	END(_save_fp_context)
 
 /*

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
                   ` (2 preceding siblings ...)
  2016-10-31 16:26 ` [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context Maciej W. Rozycki
@ 2016-10-31 16:27 ` Maciej W. Rozycki
  2016-10-31 16:27   ` Maciej W. Rozycki
  2016-11-01  9:31   ` Paul Burton
  2016-10-31 16:27 ` [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout Maciej W. Rozycki
  4 siblings, 2 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:27 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: Paul Burton, linux-mips, linux-kernel

Fix a regression introduced with commit 2db9ca0a3551 ("MIPS: Use struct 
mips_abi offsets to save FP context") for MIPS I/I FP signal contexts, 
by converting save/restore code to the updated internal API.  Start FGR
offsets from 0 rather than SC_FPREGS from $a0 and use $a1 rather than
the offset of SC_FPC_CSR from $a0 for the Floating Point Control/Status
Register (FCSR).

Document the new internal API and adjust assembly code formatting for 
consistency.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa12-sig-fp-context-offsets.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:28:09.266462000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:29:01.523906000 +0100
@@ -26,97 +26,104 @@
 
 	.set	noreorder
 	.set	mips1
-	/* Save floating point context */
+
+/**
+ * _save_fp_context() - save FP context from the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
+ *
+ * Save FP context, including the 32 FP data registers and the FP
+ * control & status register, from the FPU to signal context.
+ */
 LEAF(_save_fp_context)
 	.set	push
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
-	cfc1	t1,fcr31
-	EX(swc1 $f0,(SC_FPREGS+0)(a0))
-	EX(swc1 $f1,(SC_FPREGS+8)(a0))
-	EX(swc1 $f2,(SC_FPREGS+16)(a0))
-	EX(swc1 $f3,(SC_FPREGS+24)(a0))
-	EX(swc1 $f4,(SC_FPREGS+32)(a0))
-	EX(swc1 $f5,(SC_FPREGS+40)(a0))
-	EX(swc1 $f6,(SC_FPREGS+48)(a0))
-	EX(swc1 $f7,(SC_FPREGS+56)(a0))
-	EX(swc1 $f8,(SC_FPREGS+64)(a0))
-	EX(swc1 $f9,(SC_FPREGS+72)(a0))
-	EX(swc1 $f10,(SC_FPREGS+80)(a0))
-	EX(swc1 $f11,(SC_FPREGS+88)(a0))
-	EX(swc1 $f12,(SC_FPREGS+96)(a0))
-	EX(swc1 $f13,(SC_FPREGS+104)(a0))
-	EX(swc1 $f14,(SC_FPREGS+112)(a0))
-	EX(swc1 $f15,(SC_FPREGS+120)(a0))
-	EX(swc1 $f16,(SC_FPREGS+128)(a0))
-	EX(swc1 $f17,(SC_FPREGS+136)(a0))
-	EX(swc1 $f18,(SC_FPREGS+144)(a0))
-	EX(swc1 $f19,(SC_FPREGS+152)(a0))
-	EX(swc1 $f20,(SC_FPREGS+160)(a0))
-	EX(swc1 $f21,(SC_FPREGS+168)(a0))
-	EX(swc1 $f22,(SC_FPREGS+176)(a0))
-	EX(swc1 $f23,(SC_FPREGS+184)(a0))
-	EX(swc1 $f24,(SC_FPREGS+192)(a0))
-	EX(swc1 $f25,(SC_FPREGS+200)(a0))
-	EX(swc1 $f26,(SC_FPREGS+208)(a0))
-	EX(swc1 $f27,(SC_FPREGS+216)(a0))
-	EX(swc1 $f28,(SC_FPREGS+224)(a0))
-	EX(swc1 $f29,(SC_FPREGS+232)(a0))
-	EX(swc1 $f30,(SC_FPREGS+240)(a0))
-	EX(swc1 $f31,(SC_FPREGS+248)(a0))
+	cfc1	t1, fcr31
+	EX(swc1 $f0, 0(a0))
+	EX(swc1 $f1, 8(a0))
+	EX(swc1 $f2, 16(a0))
+	EX(swc1 $f3, 24(a0))
+	EX(swc1 $f4, 32(a0))
+	EX(swc1 $f5, 40(a0))
+	EX(swc1 $f6, 48(a0))
+	EX(swc1 $f7, 56(a0))
+	EX(swc1 $f8, 64(a0))
+	EX(swc1 $f9, 72(a0))
+	EX(swc1 $f10, 80(a0))
+	EX(swc1 $f11, 88(a0))
+	EX(swc1 $f12, 96(a0))
+	EX(swc1 $f13, 104(a0))
+	EX(swc1 $f14, 112(a0))
+	EX(swc1 $f15, 120(a0))
+	EX(swc1 $f16, 128(a0))
+	EX(swc1 $f17, 136(a0))
+	EX(swc1 $f18, 144(a0))
+	EX(swc1 $f19, 152(a0))
+	EX(swc1 $f20, 160(a0))
+	EX(swc1 $f21, 168(a0))
+	EX(swc1 $f22, 176(a0))
+	EX(swc1 $f23, 184(a0))
+	EX(swc1 $f24, 192(a0))
+	EX(swc1 $f25, 200(a0))
+	EX(swc1 $f26, 208(a0))
+	EX(swc1 $f27, 216(a0))
+	EX(swc1 $f28, 224(a0))
+	EX(swc1 $f29, 232(a0))
+	EX(swc1 $f30, 240(a0))
+	EX(swc1 $f31, 248(a0))
 	jr	ra
-	 EX(sw	t1,(SC_FPC_CSR)(a0))
+	 EX(sw	t1, (a1))
 	.set	pop
 	END(_save_fp_context)
 
-/*
- * Restore FPU state:
- *  - fp gp registers
- *  - cp1 status/control register
+/**
+ * _restore_fp_context() - restore FP context to the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
  *
- * We base the decision which registers to restore from the signal stack
- * frame on the current content of c0_status, not on the content of the
- * stack frame which might have been changed by the user.
+ * Restore FP context, including the 32 FP data registers and the FP
+ * control & status register, from signal context to the FPU.
  */
 LEAF(_restore_fp_context)
 	.set	push
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
-	EX(lw t0,(SC_FPC_CSR)(a0))
-	EX(lwc1 $f0,(SC_FPREGS+0)(a0))
-	EX(lwc1 $f1,(SC_FPREGS+8)(a0))
-	EX(lwc1 $f2,(SC_FPREGS+16)(a0))
-	EX(lwc1 $f3,(SC_FPREGS+24)(a0))
-	EX(lwc1 $f4,(SC_FPREGS+32)(a0))
-	EX(lwc1 $f5,(SC_FPREGS+40)(a0))
-	EX(lwc1 $f6,(SC_FPREGS+48)(a0))
-	EX(lwc1 $f7,(SC_FPREGS+56)(a0))
-	EX(lwc1 $f8,(SC_FPREGS+64)(a0))
-	EX(lwc1 $f9,(SC_FPREGS+72)(a0))
-	EX(lwc1 $f10,(SC_FPREGS+80)(a0))
-	EX(lwc1 $f11,(SC_FPREGS+88)(a0))
-	EX(lwc1 $f12,(SC_FPREGS+96)(a0))
-	EX(lwc1 $f13,(SC_FPREGS+104)(a0))
-	EX(lwc1 $f14,(SC_FPREGS+112)(a0))
-	EX(lwc1 $f15,(SC_FPREGS+120)(a0))
-	EX(lwc1 $f16,(SC_FPREGS+128)(a0))
-	EX(lwc1 $f17,(SC_FPREGS+136)(a0))
-	EX(lwc1 $f18,(SC_FPREGS+144)(a0))
-	EX(lwc1 $f19,(SC_FPREGS+152)(a0))
-	EX(lwc1 $f20,(SC_FPREGS+160)(a0))
-	EX(lwc1 $f21,(SC_FPREGS+168)(a0))
-	EX(lwc1 $f22,(SC_FPREGS+176)(a0))
-	EX(lwc1 $f23,(SC_FPREGS+184)(a0))
-	EX(lwc1 $f24,(SC_FPREGS+192)(a0))
-	EX(lwc1 $f25,(SC_FPREGS+200)(a0))
-	EX(lwc1 $f26,(SC_FPREGS+208)(a0))
-	EX(lwc1 $f27,(SC_FPREGS+216)(a0))
-	EX(lwc1 $f28,(SC_FPREGS+224)(a0))
-	EX(lwc1 $f29,(SC_FPREGS+232)(a0))
-	EX(lwc1 $f30,(SC_FPREGS+240)(a0))
-	EX(lwc1 $f31,(SC_FPREGS+248)(a0))
+	EX(lw t0, (a1))
+	EX(lwc1 $f0, 0(a0))
+	EX(lwc1 $f1, 8(a0))
+	EX(lwc1 $f2, 16(a0))
+	EX(lwc1 $f3, 24(a0))
+	EX(lwc1 $f4, 32(a0))
+	EX(lwc1 $f5, 40(a0))
+	EX(lwc1 $f6, 48(a0))
+	EX(lwc1 $f7, 56(a0))
+	EX(lwc1 $f8, 64(a0))
+	EX(lwc1 $f9, 72(a0))
+	EX(lwc1 $f10, 80(a0))
+	EX(lwc1 $f11, 88(a0))
+	EX(lwc1 $f12, 96(a0))
+	EX(lwc1 $f13, 104(a0))
+	EX(lwc1 $f14, 112(a0))
+	EX(lwc1 $f15, 120(a0))
+	EX(lwc1 $f16, 128(a0))
+	EX(lwc1 $f17, 136(a0))
+	EX(lwc1 $f18, 144(a0))
+	EX(lwc1 $f19, 152(a0))
+	EX(lwc1 $f20, 160(a0))
+	EX(lwc1 $f21, 168(a0))
+	EX(lwc1 $f22, 176(a0))
+	EX(lwc1 $f23, 184(a0))
+	EX(lwc1 $f24, 192(a0))
+	EX(lwc1 $f25, 200(a0))
+	EX(lwc1 $f26, 208(a0))
+	EX(lwc1 $f27, 216(a0))
+	EX(lwc1 $f28, 224(a0))
+	EX(lwc1 $f29, 232(a0))
+	EX(lwc1 $f30, 240(a0))
+	EX(lwc1 $f31, 248(a0))
 	jr	ra
-	 ctc1	t0,fcr31
+	 ctc1	t0, fcr31
 	.set	pop
 	END(_restore_fp_context)
 	.set	reorder
Index: linux-sfr-test/arch/mips/kernel/r6000_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:28:57.927876000 +0100
+++ linux-sfr-test/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:29:12.415002000 +0100
@@ -21,7 +21,14 @@
 	.set	push
 	SET_HARDFLOAT
 
-	/* Save floating point context */
+/**
+ * _save_fp_context() - save FP context from the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
+ *
+ * Save FP context, including the 32 FP data registers and the FP
+ * control & status register, from the FPU to signal context.
+ */
 	LEAF(_save_fp_context)
 	mfc0	t0,CP0_STATUS
 	sll	t0,t0,2
@@ -30,59 +37,59 @@
 
 	cfc1	t1,fcr31
 	/* Store the 16 double precision registers */
-	sdc1	$f0,(SC_FPREGS+0)(a0)
-	sdc1	$f2,(SC_FPREGS+16)(a0)
-	sdc1	$f4,(SC_FPREGS+32)(a0)
-	sdc1	$f6,(SC_FPREGS+48)(a0)
-	sdc1	$f8,(SC_FPREGS+64)(a0)
-	sdc1	$f10,(SC_FPREGS+80)(a0)
-	sdc1	$f12,(SC_FPREGS+96)(a0)
-	sdc1	$f14,(SC_FPREGS+112)(a0)
-	sdc1	$f16,(SC_FPREGS+128)(a0)
-	sdc1	$f18,(SC_FPREGS+144)(a0)
-	sdc1	$f20,(SC_FPREGS+160)(a0)
-	sdc1	$f22,(SC_FPREGS+176)(a0)
-	sdc1	$f24,(SC_FPREGS+192)(a0)
-	sdc1	$f26,(SC_FPREGS+208)(a0)
-	sdc1	$f28,(SC_FPREGS+224)(a0)
-	sdc1	$f30,(SC_FPREGS+240)(a0)
+	sdc1	$f0,0(a0)
+	sdc1	$f2,16(a0)
+	sdc1	$f4,32(a0)
+	sdc1	$f6,48(a0)
+	sdc1	$f8,64(a0)
+	sdc1	$f10,80(a0)
+	sdc1	$f12,96(a0)
+	sdc1	$f14,112(a0)
+	sdc1	$f16,128(a0)
+	sdc1	$f18,144(a0)
+	sdc1	$f20,160(a0)
+	sdc1	$f22,176(a0)
+	sdc1	$f24,192(a0)
+	sdc1	$f26,208(a0)
+	sdc1	$f28,224(a0)
+	sdc1	$f30,240(a0)
 	jr	ra
-	 sw	t0,SC_FPC_CSR(a0)
+	 sw	t0,(a1)
 1:	jr	ra
 	 nop
 	END(_save_fp_context)
 
-/* Restore FPU state:
- *  - fp gp registers
- *  - cp1 status/control register
+/**
+ * _restore_fp_context() - restore FP context to the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
  *
- * We base the decision which registers to restore from the signal stack
- * frame on the current content of c0_status, not on the content of the
- * stack frame which might have been changed by the user.
+ * Restore FP context, including the 32 FP data registers and the FP
+ * control & status register, from signal context to the FPU.
  */
 	LEAF(_restore_fp_context)
 	mfc0	t0,CP0_STATUS
 	sll	t0,t0,2
 
 	bgez	t0,1f
-	 lw	t0,SC_FPC_CSR(a0)
+	 lw	t0,(a1)
 	/* Restore the 16 double precision registers */
-	ldc1	$f0,(SC_FPREGS+0)(a0)
-	ldc1	$f2,(SC_FPREGS+16)(a0)
-	ldc1	$f4,(SC_FPREGS+32)(a0)
-	ldc1	$f6,(SC_FPREGS+48)(a0)
-	ldc1	$f8,(SC_FPREGS+64)(a0)
-	ldc1	$f10,(SC_FPREGS+80)(a0)
-	ldc1	$f12,(SC_FPREGS+96)(a0)
-	ldc1	$f14,(SC_FPREGS+112)(a0)
-	ldc1	$f16,(SC_FPREGS+128)(a0)
-	ldc1	$f18,(SC_FPREGS+144)(a0)
-	ldc1	$f20,(SC_FPREGS+160)(a0)
-	ldc1	$f22,(SC_FPREGS+176)(a0)
-	ldc1	$f24,(SC_FPREGS+192)(a0)
-	ldc1	$f26,(SC_FPREGS+208)(a0)
-	ldc1	$f28,(SC_FPREGS+224)(a0)
-	ldc1	$f30,(SC_FPREGS+240)(a0)
+	ldc1	$f0,0(a0)
+	ldc1	$f2,16(a0)
+	ldc1	$f4,32(a0)
+	ldc1	$f6,48(a0)
+	ldc1	$f8,64(a0)
+	ldc1	$f10,80(a0)
+	ldc1	$f12,96(a0)
+	ldc1	$f14,112(a0)
+	ldc1	$f16,128(a0)
+	ldc1	$f18,144(a0)
+	ldc1	$f20,160(a0)
+	ldc1	$f22,176(a0)
+	ldc1	$f24,192(a0)
+	ldc1	$f26,208(a0)
+	ldc1	$f28,224(a0)
+	ldc1	$f30,240(a0)
 	jr	ra
 	 ctc1	t0,fcr31
 1:	jr	ra

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-10-31 16:27 ` [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets Maciej W. Rozycki
@ 2016-10-31 16:27   ` Maciej W. Rozycki
  2016-11-01  9:31   ` Paul Burton
  1 sibling, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:27 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: Paul Burton, linux-mips, linux-kernel

Fix a regression introduced with commit 2db9ca0a3551 ("MIPS: Use struct 
mips_abi offsets to save FP context") for MIPS I/I FP signal contexts, 
by converting save/restore code to the updated internal API.  Start FGR
offsets from 0 rather than SC_FPREGS from $a0 and use $a1 rather than
the offset of SC_FPC_CSR from $a0 for the Floating Point Control/Status
Register (FCSR).

Document the new internal API and adjust assembly code formatting for 
consistency.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa12-sig-fp-context-offsets.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:28:09.266462000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:29:01.523906000 +0100
@@ -26,97 +26,104 @@
 
 	.set	noreorder
 	.set	mips1
-	/* Save floating point context */
+
+/**
+ * _save_fp_context() - save FP context from the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
+ *
+ * Save FP context, including the 32 FP data registers and the FP
+ * control & status register, from the FPU to signal context.
+ */
 LEAF(_save_fp_context)
 	.set	push
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
-	cfc1	t1,fcr31
-	EX(swc1 $f0,(SC_FPREGS+0)(a0))
-	EX(swc1 $f1,(SC_FPREGS+8)(a0))
-	EX(swc1 $f2,(SC_FPREGS+16)(a0))
-	EX(swc1 $f3,(SC_FPREGS+24)(a0))
-	EX(swc1 $f4,(SC_FPREGS+32)(a0))
-	EX(swc1 $f5,(SC_FPREGS+40)(a0))
-	EX(swc1 $f6,(SC_FPREGS+48)(a0))
-	EX(swc1 $f7,(SC_FPREGS+56)(a0))
-	EX(swc1 $f8,(SC_FPREGS+64)(a0))
-	EX(swc1 $f9,(SC_FPREGS+72)(a0))
-	EX(swc1 $f10,(SC_FPREGS+80)(a0))
-	EX(swc1 $f11,(SC_FPREGS+88)(a0))
-	EX(swc1 $f12,(SC_FPREGS+96)(a0))
-	EX(swc1 $f13,(SC_FPREGS+104)(a0))
-	EX(swc1 $f14,(SC_FPREGS+112)(a0))
-	EX(swc1 $f15,(SC_FPREGS+120)(a0))
-	EX(swc1 $f16,(SC_FPREGS+128)(a0))
-	EX(swc1 $f17,(SC_FPREGS+136)(a0))
-	EX(swc1 $f18,(SC_FPREGS+144)(a0))
-	EX(swc1 $f19,(SC_FPREGS+152)(a0))
-	EX(swc1 $f20,(SC_FPREGS+160)(a0))
-	EX(swc1 $f21,(SC_FPREGS+168)(a0))
-	EX(swc1 $f22,(SC_FPREGS+176)(a0))
-	EX(swc1 $f23,(SC_FPREGS+184)(a0))
-	EX(swc1 $f24,(SC_FPREGS+192)(a0))
-	EX(swc1 $f25,(SC_FPREGS+200)(a0))
-	EX(swc1 $f26,(SC_FPREGS+208)(a0))
-	EX(swc1 $f27,(SC_FPREGS+216)(a0))
-	EX(swc1 $f28,(SC_FPREGS+224)(a0))
-	EX(swc1 $f29,(SC_FPREGS+232)(a0))
-	EX(swc1 $f30,(SC_FPREGS+240)(a0))
-	EX(swc1 $f31,(SC_FPREGS+248)(a0))
+	cfc1	t1, fcr31
+	EX(swc1 $f0, 0(a0))
+	EX(swc1 $f1, 8(a0))
+	EX(swc1 $f2, 16(a0))
+	EX(swc1 $f3, 24(a0))
+	EX(swc1 $f4, 32(a0))
+	EX(swc1 $f5, 40(a0))
+	EX(swc1 $f6, 48(a0))
+	EX(swc1 $f7, 56(a0))
+	EX(swc1 $f8, 64(a0))
+	EX(swc1 $f9, 72(a0))
+	EX(swc1 $f10, 80(a0))
+	EX(swc1 $f11, 88(a0))
+	EX(swc1 $f12, 96(a0))
+	EX(swc1 $f13, 104(a0))
+	EX(swc1 $f14, 112(a0))
+	EX(swc1 $f15, 120(a0))
+	EX(swc1 $f16, 128(a0))
+	EX(swc1 $f17, 136(a0))
+	EX(swc1 $f18, 144(a0))
+	EX(swc1 $f19, 152(a0))
+	EX(swc1 $f20, 160(a0))
+	EX(swc1 $f21, 168(a0))
+	EX(swc1 $f22, 176(a0))
+	EX(swc1 $f23, 184(a0))
+	EX(swc1 $f24, 192(a0))
+	EX(swc1 $f25, 200(a0))
+	EX(swc1 $f26, 208(a0))
+	EX(swc1 $f27, 216(a0))
+	EX(swc1 $f28, 224(a0))
+	EX(swc1 $f29, 232(a0))
+	EX(swc1 $f30, 240(a0))
+	EX(swc1 $f31, 248(a0))
 	jr	ra
-	 EX(sw	t1,(SC_FPC_CSR)(a0))
+	 EX(sw	t1, (a1))
 	.set	pop
 	END(_save_fp_context)
 
-/*
- * Restore FPU state:
- *  - fp gp registers
- *  - cp1 status/control register
+/**
+ * _restore_fp_context() - restore FP context to the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
  *
- * We base the decision which registers to restore from the signal stack
- * frame on the current content of c0_status, not on the content of the
- * stack frame which might have been changed by the user.
+ * Restore FP context, including the 32 FP data registers and the FP
+ * control & status register, from signal context to the FPU.
  */
 LEAF(_restore_fp_context)
 	.set	push
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
-	EX(lw t0,(SC_FPC_CSR)(a0))
-	EX(lwc1 $f0,(SC_FPREGS+0)(a0))
-	EX(lwc1 $f1,(SC_FPREGS+8)(a0))
-	EX(lwc1 $f2,(SC_FPREGS+16)(a0))
-	EX(lwc1 $f3,(SC_FPREGS+24)(a0))
-	EX(lwc1 $f4,(SC_FPREGS+32)(a0))
-	EX(lwc1 $f5,(SC_FPREGS+40)(a0))
-	EX(lwc1 $f6,(SC_FPREGS+48)(a0))
-	EX(lwc1 $f7,(SC_FPREGS+56)(a0))
-	EX(lwc1 $f8,(SC_FPREGS+64)(a0))
-	EX(lwc1 $f9,(SC_FPREGS+72)(a0))
-	EX(lwc1 $f10,(SC_FPREGS+80)(a0))
-	EX(lwc1 $f11,(SC_FPREGS+88)(a0))
-	EX(lwc1 $f12,(SC_FPREGS+96)(a0))
-	EX(lwc1 $f13,(SC_FPREGS+104)(a0))
-	EX(lwc1 $f14,(SC_FPREGS+112)(a0))
-	EX(lwc1 $f15,(SC_FPREGS+120)(a0))
-	EX(lwc1 $f16,(SC_FPREGS+128)(a0))
-	EX(lwc1 $f17,(SC_FPREGS+136)(a0))
-	EX(lwc1 $f18,(SC_FPREGS+144)(a0))
-	EX(lwc1 $f19,(SC_FPREGS+152)(a0))
-	EX(lwc1 $f20,(SC_FPREGS+160)(a0))
-	EX(lwc1 $f21,(SC_FPREGS+168)(a0))
-	EX(lwc1 $f22,(SC_FPREGS+176)(a0))
-	EX(lwc1 $f23,(SC_FPREGS+184)(a0))
-	EX(lwc1 $f24,(SC_FPREGS+192)(a0))
-	EX(lwc1 $f25,(SC_FPREGS+200)(a0))
-	EX(lwc1 $f26,(SC_FPREGS+208)(a0))
-	EX(lwc1 $f27,(SC_FPREGS+216)(a0))
-	EX(lwc1 $f28,(SC_FPREGS+224)(a0))
-	EX(lwc1 $f29,(SC_FPREGS+232)(a0))
-	EX(lwc1 $f30,(SC_FPREGS+240)(a0))
-	EX(lwc1 $f31,(SC_FPREGS+248)(a0))
+	EX(lw t0, (a1))
+	EX(lwc1 $f0, 0(a0))
+	EX(lwc1 $f1, 8(a0))
+	EX(lwc1 $f2, 16(a0))
+	EX(lwc1 $f3, 24(a0))
+	EX(lwc1 $f4, 32(a0))
+	EX(lwc1 $f5, 40(a0))
+	EX(lwc1 $f6, 48(a0))
+	EX(lwc1 $f7, 56(a0))
+	EX(lwc1 $f8, 64(a0))
+	EX(lwc1 $f9, 72(a0))
+	EX(lwc1 $f10, 80(a0))
+	EX(lwc1 $f11, 88(a0))
+	EX(lwc1 $f12, 96(a0))
+	EX(lwc1 $f13, 104(a0))
+	EX(lwc1 $f14, 112(a0))
+	EX(lwc1 $f15, 120(a0))
+	EX(lwc1 $f16, 128(a0))
+	EX(lwc1 $f17, 136(a0))
+	EX(lwc1 $f18, 144(a0))
+	EX(lwc1 $f19, 152(a0))
+	EX(lwc1 $f20, 160(a0))
+	EX(lwc1 $f21, 168(a0))
+	EX(lwc1 $f22, 176(a0))
+	EX(lwc1 $f23, 184(a0))
+	EX(lwc1 $f24, 192(a0))
+	EX(lwc1 $f25, 200(a0))
+	EX(lwc1 $f26, 208(a0))
+	EX(lwc1 $f27, 216(a0))
+	EX(lwc1 $f28, 224(a0))
+	EX(lwc1 $f29, 232(a0))
+	EX(lwc1 $f30, 240(a0))
+	EX(lwc1 $f31, 248(a0))
 	jr	ra
-	 ctc1	t0,fcr31
+	 ctc1	t0, fcr31
 	.set	pop
 	END(_restore_fp_context)
 	.set	reorder
Index: linux-sfr-test/arch/mips/kernel/r6000_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:28:57.927876000 +0100
+++ linux-sfr-test/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:29:12.415002000 +0100
@@ -21,7 +21,14 @@
 	.set	push
 	SET_HARDFLOAT
 
-	/* Save floating point context */
+/**
+ * _save_fp_context() - save FP context from the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
+ *
+ * Save FP context, including the 32 FP data registers and the FP
+ * control & status register, from the FPU to signal context.
+ */
 	LEAF(_save_fp_context)
 	mfc0	t0,CP0_STATUS
 	sll	t0,t0,2
@@ -30,59 +37,59 @@
 
 	cfc1	t1,fcr31
 	/* Store the 16 double precision registers */
-	sdc1	$f0,(SC_FPREGS+0)(a0)
-	sdc1	$f2,(SC_FPREGS+16)(a0)
-	sdc1	$f4,(SC_FPREGS+32)(a0)
-	sdc1	$f6,(SC_FPREGS+48)(a0)
-	sdc1	$f8,(SC_FPREGS+64)(a0)
-	sdc1	$f10,(SC_FPREGS+80)(a0)
-	sdc1	$f12,(SC_FPREGS+96)(a0)
-	sdc1	$f14,(SC_FPREGS+112)(a0)
-	sdc1	$f16,(SC_FPREGS+128)(a0)
-	sdc1	$f18,(SC_FPREGS+144)(a0)
-	sdc1	$f20,(SC_FPREGS+160)(a0)
-	sdc1	$f22,(SC_FPREGS+176)(a0)
-	sdc1	$f24,(SC_FPREGS+192)(a0)
-	sdc1	$f26,(SC_FPREGS+208)(a0)
-	sdc1	$f28,(SC_FPREGS+224)(a0)
-	sdc1	$f30,(SC_FPREGS+240)(a0)
+	sdc1	$f0,0(a0)
+	sdc1	$f2,16(a0)
+	sdc1	$f4,32(a0)
+	sdc1	$f6,48(a0)
+	sdc1	$f8,64(a0)
+	sdc1	$f10,80(a0)
+	sdc1	$f12,96(a0)
+	sdc1	$f14,112(a0)
+	sdc1	$f16,128(a0)
+	sdc1	$f18,144(a0)
+	sdc1	$f20,160(a0)
+	sdc1	$f22,176(a0)
+	sdc1	$f24,192(a0)
+	sdc1	$f26,208(a0)
+	sdc1	$f28,224(a0)
+	sdc1	$f30,240(a0)
 	jr	ra
-	 sw	t0,SC_FPC_CSR(a0)
+	 sw	t0,(a1)
 1:	jr	ra
 	 nop
 	END(_save_fp_context)
 
-/* Restore FPU state:
- *  - fp gp registers
- *  - cp1 status/control register
+/**
+ * _restore_fp_context() - restore FP context to the FPU
+ * @a0 - pointer to fpregs field of sigcontext
+ * @a1 - pointer to fpc_csr field of sigcontext
  *
- * We base the decision which registers to restore from the signal stack
- * frame on the current content of c0_status, not on the content of the
- * stack frame which might have been changed by the user.
+ * Restore FP context, including the 32 FP data registers and the FP
+ * control & status register, from signal context to the FPU.
  */
 	LEAF(_restore_fp_context)
 	mfc0	t0,CP0_STATUS
 	sll	t0,t0,2
 
 	bgez	t0,1f
-	 lw	t0,SC_FPC_CSR(a0)
+	 lw	t0,(a1)
 	/* Restore the 16 double precision registers */
-	ldc1	$f0,(SC_FPREGS+0)(a0)
-	ldc1	$f2,(SC_FPREGS+16)(a0)
-	ldc1	$f4,(SC_FPREGS+32)(a0)
-	ldc1	$f6,(SC_FPREGS+48)(a0)
-	ldc1	$f8,(SC_FPREGS+64)(a0)
-	ldc1	$f10,(SC_FPREGS+80)(a0)
-	ldc1	$f12,(SC_FPREGS+96)(a0)
-	ldc1	$f14,(SC_FPREGS+112)(a0)
-	ldc1	$f16,(SC_FPREGS+128)(a0)
-	ldc1	$f18,(SC_FPREGS+144)(a0)
-	ldc1	$f20,(SC_FPREGS+160)(a0)
-	ldc1	$f22,(SC_FPREGS+176)(a0)
-	ldc1	$f24,(SC_FPREGS+192)(a0)
-	ldc1	$f26,(SC_FPREGS+208)(a0)
-	ldc1	$f28,(SC_FPREGS+224)(a0)
-	ldc1	$f30,(SC_FPREGS+240)(a0)
+	ldc1	$f0,0(a0)
+	ldc1	$f2,16(a0)
+	ldc1	$f4,32(a0)
+	ldc1	$f6,48(a0)
+	ldc1	$f8,64(a0)
+	ldc1	$f10,80(a0)
+	ldc1	$f12,96(a0)
+	ldc1	$f14,112(a0)
+	ldc1	$f16,128(a0)
+	ldc1	$f18,144(a0)
+	ldc1	$f20,160(a0)
+	ldc1	$f22,176(a0)
+	ldc1	$f24,192(a0)
+	ldc1	$f26,208(a0)
+	ldc1	$f28,224(a0)
+	ldc1	$f30,240(a0)
 	jr	ra
 	 ctc1	t0,fcr31
 1:	jr	ra

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout
  2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
                   ` (3 preceding siblings ...)
  2016-10-31 16:27 ` [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets Maciej W. Rozycki
@ 2016-10-31 16:27 ` Maciej W. Rozycki
  2016-10-31 16:27   ` Maciej W. Rozycki
  4 siblings, 1 reply; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:27 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit 80cbfad79096 ("MIPS: Correct MIPS I FP context 
layout") and correct the way Floating Point General registers are stored
in a signal context with MIPS I hardware.

Use the S.D and L.D assembly macros to have pairs of SWC1 instructions 
and pairs of LWC1 instructions produced, respectively, in an arrangement 
which makes the memory representation of floating-point data passed 
compatible with that used by hardware SDC1 and LDC1 instructions, where 
available, regardless of the hardware endianness used.  This matches the 
layout used by r4k_fpu.S, ensuring run-time compatibility for MIPS I 
software across all o32 hardware platforms.

Define an EX2 macro to handle exceptions from both hardware instructions 
implicitly produced from S.D and L.D assembly macros.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa1-sig-fp-context.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:38:03.979547000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:41:53.059507000 +0100
@@ -24,6 +24,13 @@
 	PTR	9b,fault;					\
 	.previous
 
+#define EX2(a,b)						\
+9:	a,##b;							\
+	.section __ex_table,"a";				\
+	PTR	9b,bad_stack;					\
+	PTR	9b+4,bad_stack;					\
+	.previous
+
 	.set	noreorder
 	.set	mips1
 
@@ -40,38 +47,22 @@ LEAF(_save_fp_context)
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
 	cfc1	t1, fcr31
-	EX(swc1 $f0, 0(a0))
-	EX(swc1 $f1, 8(a0))
-	EX(swc1 $f2, 16(a0))
-	EX(swc1 $f3, 24(a0))
-	EX(swc1 $f4, 32(a0))
-	EX(swc1 $f5, 40(a0))
-	EX(swc1 $f6, 48(a0))
-	EX(swc1 $f7, 56(a0))
-	EX(swc1 $f8, 64(a0))
-	EX(swc1 $f9, 72(a0))
-	EX(swc1 $f10, 80(a0))
-	EX(swc1 $f11, 88(a0))
-	EX(swc1 $f12, 96(a0))
-	EX(swc1 $f13, 104(a0))
-	EX(swc1 $f14, 112(a0))
-	EX(swc1 $f15, 120(a0))
-	EX(swc1 $f16, 128(a0))
-	EX(swc1 $f17, 136(a0))
-	EX(swc1 $f18, 144(a0))
-	EX(swc1 $f19, 152(a0))
-	EX(swc1 $f20, 160(a0))
-	EX(swc1 $f21, 168(a0))
-	EX(swc1 $f22, 176(a0))
-	EX(swc1 $f23, 184(a0))
-	EX(swc1 $f24, 192(a0))
-	EX(swc1 $f25, 200(a0))
-	EX(swc1 $f26, 208(a0))
-	EX(swc1 $f27, 216(a0))
-	EX(swc1 $f28, 224(a0))
-	EX(swc1 $f29, 232(a0))
-	EX(swc1 $f30, 240(a0))
-	EX(swc1 $f31, 248(a0))
+	EX2(s.d $f0, 0(a0))
+	EX2(s.d $f2, 16(a0))
+	EX2(s.d $f4, 32(a0))
+	EX2(s.d $f6, 48(a0))
+	EX2(s.d $f8, 64(a0))
+	EX2(s.d $f10, 80(a0))
+	EX2(s.d $f12, 96(a0))
+	EX2(s.d $f14, 112(a0))
+	EX2(s.d $f16, 128(a0))
+	EX2(s.d $f18, 144(a0))
+	EX2(s.d $f20, 160(a0))
+	EX2(s.d $f22, 176(a0))
+	EX2(s.d $f24, 192(a0))
+	EX2(s.d $f26, 208(a0))
+	EX2(s.d $f28, 224(a0))
+	EX2(s.d $f30, 240(a0))
 	jr	ra
 	 EX(sw	t1, (a1))
 	.set	pop
@@ -90,38 +81,22 @@ LEAF(_restore_fp_context)
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
 	EX(lw t0, (a1))
-	EX(lwc1 $f0, 0(a0))
-	EX(lwc1 $f1, 8(a0))
-	EX(lwc1 $f2, 16(a0))
-	EX(lwc1 $f3, 24(a0))
-	EX(lwc1 $f4, 32(a0))
-	EX(lwc1 $f5, 40(a0))
-	EX(lwc1 $f6, 48(a0))
-	EX(lwc1 $f7, 56(a0))
-	EX(lwc1 $f8, 64(a0))
-	EX(lwc1 $f9, 72(a0))
-	EX(lwc1 $f10, 80(a0))
-	EX(lwc1 $f11, 88(a0))
-	EX(lwc1 $f12, 96(a0))
-	EX(lwc1 $f13, 104(a0))
-	EX(lwc1 $f14, 112(a0))
-	EX(lwc1 $f15, 120(a0))
-	EX(lwc1 $f16, 128(a0))
-	EX(lwc1 $f17, 136(a0))
-	EX(lwc1 $f18, 144(a0))
-	EX(lwc1 $f19, 152(a0))
-	EX(lwc1 $f20, 160(a0))
-	EX(lwc1 $f21, 168(a0))
-	EX(lwc1 $f22, 176(a0))
-	EX(lwc1 $f23, 184(a0))
-	EX(lwc1 $f24, 192(a0))
-	EX(lwc1 $f25, 200(a0))
-	EX(lwc1 $f26, 208(a0))
-	EX(lwc1 $f27, 216(a0))
-	EX(lwc1 $f28, 224(a0))
-	EX(lwc1 $f29, 232(a0))
-	EX(lwc1 $f30, 240(a0))
-	EX(lwc1 $f31, 248(a0))
+	EX2(l.d $f0, 0(a0))
+	EX2(l.d $f2, 16(a0))
+	EX2(l.d $f4, 32(a0))
+	EX2(l.d $f6, 48(a0))
+	EX2(l.d $f8, 64(a0))
+	EX2(l.d $f10, 80(a0))
+	EX2(l.d $f12, 96(a0))
+	EX2(l.d $f14, 112(a0))
+	EX2(l.d $f16, 128(a0))
+	EX2(l.d $f18, 144(a0))
+	EX2(l.d $f20, 160(a0))
+	EX2(l.d $f22, 176(a0))
+	EX2(l.d $f24, 192(a0))
+	EX2(l.d $f26, 208(a0))
+	EX2(l.d $f28, 224(a0))
+	EX2(l.d $f30, 240(a0))
 	jr	ra
 	 ctc1	t0, fcr31
 	.set	pop

^ permalink raw reply	[flat|nested] 16+ messages in thread

* [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout
  2016-10-31 16:27 ` [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout Maciej W. Rozycki
@ 2016-10-31 16:27   ` Maciej W. Rozycki
  0 siblings, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-10-31 16:27 UTC (permalink / raw)
  To: Ralf Baechle; +Cc: linux-mips, linux-kernel

Complement commit 80cbfad79096 ("MIPS: Correct MIPS I FP context 
layout") and correct the way Floating Point General registers are stored
in a signal context with MIPS I hardware.

Use the S.D and L.D assembly macros to have pairs of SWC1 instructions 
and pairs of LWC1 instructions produced, respectively, in an arrangement 
which makes the memory representation of floating-point data passed 
compatible with that used by hardware SDC1 and LDC1 instructions, where 
available, regardless of the hardware endianness used.  This matches the 
layout used by r4k_fpu.S, ensuring run-time compatibility for MIPS I 
software across all o32 hardware platforms.

Define an EX2 macro to handle exceptions from both hardware instructions 
implicitly produced from S.D and L.D assembly macros.

Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
---
linux-mips-isa1-sig-fp-context.patch
Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
===================================================================
--- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:38:03.979547000 +0100
+++ linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:41:53.059507000 +0100
@@ -24,6 +24,13 @@
 	PTR	9b,fault;					\
 	.previous
 
+#define EX2(a,b)						\
+9:	a,##b;							\
+	.section __ex_table,"a";				\
+	PTR	9b,bad_stack;					\
+	PTR	9b+4,bad_stack;					\
+	.previous
+
 	.set	noreorder
 	.set	mips1
 
@@ -40,38 +47,22 @@ LEAF(_save_fp_context)
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
 	cfc1	t1, fcr31
-	EX(swc1 $f0, 0(a0))
-	EX(swc1 $f1, 8(a0))
-	EX(swc1 $f2, 16(a0))
-	EX(swc1 $f3, 24(a0))
-	EX(swc1 $f4, 32(a0))
-	EX(swc1 $f5, 40(a0))
-	EX(swc1 $f6, 48(a0))
-	EX(swc1 $f7, 56(a0))
-	EX(swc1 $f8, 64(a0))
-	EX(swc1 $f9, 72(a0))
-	EX(swc1 $f10, 80(a0))
-	EX(swc1 $f11, 88(a0))
-	EX(swc1 $f12, 96(a0))
-	EX(swc1 $f13, 104(a0))
-	EX(swc1 $f14, 112(a0))
-	EX(swc1 $f15, 120(a0))
-	EX(swc1 $f16, 128(a0))
-	EX(swc1 $f17, 136(a0))
-	EX(swc1 $f18, 144(a0))
-	EX(swc1 $f19, 152(a0))
-	EX(swc1 $f20, 160(a0))
-	EX(swc1 $f21, 168(a0))
-	EX(swc1 $f22, 176(a0))
-	EX(swc1 $f23, 184(a0))
-	EX(swc1 $f24, 192(a0))
-	EX(swc1 $f25, 200(a0))
-	EX(swc1 $f26, 208(a0))
-	EX(swc1 $f27, 216(a0))
-	EX(swc1 $f28, 224(a0))
-	EX(swc1 $f29, 232(a0))
-	EX(swc1 $f30, 240(a0))
-	EX(swc1 $f31, 248(a0))
+	EX2(s.d $f0, 0(a0))
+	EX2(s.d $f2, 16(a0))
+	EX2(s.d $f4, 32(a0))
+	EX2(s.d $f6, 48(a0))
+	EX2(s.d $f8, 64(a0))
+	EX2(s.d $f10, 80(a0))
+	EX2(s.d $f12, 96(a0))
+	EX2(s.d $f14, 112(a0))
+	EX2(s.d $f16, 128(a0))
+	EX2(s.d $f18, 144(a0))
+	EX2(s.d $f20, 160(a0))
+	EX2(s.d $f22, 176(a0))
+	EX2(s.d $f24, 192(a0))
+	EX2(s.d $f26, 208(a0))
+	EX2(s.d $f28, 224(a0))
+	EX2(s.d $f30, 240(a0))
 	jr	ra
 	 EX(sw	t1, (a1))
 	.set	pop
@@ -90,38 +81,22 @@ LEAF(_restore_fp_context)
 	SET_HARDFLOAT
 	li	v0, 0					# assume success
 	EX(lw t0, (a1))
-	EX(lwc1 $f0, 0(a0))
-	EX(lwc1 $f1, 8(a0))
-	EX(lwc1 $f2, 16(a0))
-	EX(lwc1 $f3, 24(a0))
-	EX(lwc1 $f4, 32(a0))
-	EX(lwc1 $f5, 40(a0))
-	EX(lwc1 $f6, 48(a0))
-	EX(lwc1 $f7, 56(a0))
-	EX(lwc1 $f8, 64(a0))
-	EX(lwc1 $f9, 72(a0))
-	EX(lwc1 $f10, 80(a0))
-	EX(lwc1 $f11, 88(a0))
-	EX(lwc1 $f12, 96(a0))
-	EX(lwc1 $f13, 104(a0))
-	EX(lwc1 $f14, 112(a0))
-	EX(lwc1 $f15, 120(a0))
-	EX(lwc1 $f16, 128(a0))
-	EX(lwc1 $f17, 136(a0))
-	EX(lwc1 $f18, 144(a0))
-	EX(lwc1 $f19, 152(a0))
-	EX(lwc1 $f20, 160(a0))
-	EX(lwc1 $f21, 168(a0))
-	EX(lwc1 $f22, 176(a0))
-	EX(lwc1 $f23, 184(a0))
-	EX(lwc1 $f24, 192(a0))
-	EX(lwc1 $f25, 200(a0))
-	EX(lwc1 $f26, 208(a0))
-	EX(lwc1 $f27, 216(a0))
-	EX(lwc1 $f28, 224(a0))
-	EX(lwc1 $f29, 232(a0))
-	EX(lwc1 $f30, 240(a0))
-	EX(lwc1 $f31, 248(a0))
+	EX2(l.d $f0, 0(a0))
+	EX2(l.d $f2, 16(a0))
+	EX2(l.d $f4, 32(a0))
+	EX2(l.d $f6, 48(a0))
+	EX2(l.d $f8, 64(a0))
+	EX2(l.d $f10, 80(a0))
+	EX2(l.d $f12, 96(a0))
+	EX2(l.d $f14, 112(a0))
+	EX2(l.d $f16, 128(a0))
+	EX2(l.d $f18, 144(a0))
+	EX2(l.d $f20, 160(a0))
+	EX2(l.d $f22, 176(a0))
+	EX2(l.d $f24, 192(a0))
+	EX2(l.d $f26, 208(a0))
+	EX2(l.d $f28, 224(a0))
+	EX2(l.d $f30, 240(a0))
 	jr	ra
 	 ctc1	t0, fcr31
 	.set	pop

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling
  2016-10-31 16:25 ` [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling Maciej W. Rozycki
  2016-10-31 16:25   ` Maciej W. Rozycki
@ 2016-11-01  9:27   ` Paul Burton
  2016-11-01  9:27     ` Paul Burton
  1 sibling, 1 reply; 16+ messages in thread
From: Paul Burton @ 2016-11-01  9:27 UTC (permalink / raw)
  To: Maciej W. Rozycki; +Cc: linux-mips, Ralf Baechle, linux-kernel

[-- Attachment #1: Type: text/plain, Size: 1240 bytes --]

On Monday, 31 October 2016 16:25:44 GMT Maciej W. Rozycki wrote:
> Complement commit 0ae8dceaebe3 ("Merge with 2.3.10.") and use the local
> `fault' handler to recover from FP sigcontext access violation faults,
> like corresponding code does in r4k_fpu.S.  The `bad_stack' handler is
> in syscall.c and is not suitable here as we want to propagate the error
> condition up through the caller rather than killing the thread outright.
> 
> Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
> ---
>  I guess it hardly ever triggers and code still builds, so it has aged so
> well...
> 
>   Maciej
> 
> linux-mips-isa1-sig-fp-context-fault.patch
> Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22
> 02:36:46.000000000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:37:20.891186000
> +0100 @@ -21,7 +21,7 @@
>  #define EX(a,b)							\
>  9:	a,##b;							\
>  	.section __ex_table,"a";				\
> -	PTR	9b,bad_stack;					\
> +	PTR	9b,fault;					\
>  	.previous
> 
>  	.set	noreorder

Hi Maciej,

Looks good to me:

    Reviewed-by: Paul Burton <paul.burton@imgtec.com>

Thanks,
    Paul

[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 801 bytes --]

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling
  2016-11-01  9:27   ` Paul Burton
@ 2016-11-01  9:27     ` Paul Burton
  0 siblings, 0 replies; 16+ messages in thread
From: Paul Burton @ 2016-11-01  9:27 UTC (permalink / raw)
  To: Maciej W. Rozycki; +Cc: linux-mips, Ralf Baechle, linux-kernel

[-- Attachment #1: Type: text/plain, Size: 1240 bytes --]

On Monday, 31 October 2016 16:25:44 GMT Maciej W. Rozycki wrote:
> Complement commit 0ae8dceaebe3 ("Merge with 2.3.10.") and use the local
> `fault' handler to recover from FP sigcontext access violation faults,
> like corresponding code does in r4k_fpu.S.  The `bad_stack' handler is
> in syscall.c and is not suitable here as we want to propagate the error
> condition up through the caller rather than killing the thread outright.
> 
> Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
> ---
>  I guess it hardly ever triggers and code still builds, so it has aged so
> well...
> 
>   Maciej
> 
> linux-mips-isa1-sig-fp-context-fault.patch
> Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22
> 02:36:46.000000000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:37:20.891186000
> +0100 @@ -21,7 +21,7 @@
>  #define EX(a,b)							\
>  9:	a,##b;							\
>  	.section __ex_table,"a";				\
> -	PTR	9b,bad_stack;					\
> +	PTR	9b,fault;					\
>  	.previous
> 
>  	.set	noreorder

Hi Maciej,

Looks good to me:

    Reviewed-by: Paul Burton <paul.burton@imgtec.com>

Thanks,
    Paul

[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 801 bytes --]

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-10-31 16:27 ` [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets Maciej W. Rozycki
  2016-10-31 16:27   ` Maciej W. Rozycki
@ 2016-11-01  9:31   ` Paul Burton
  2016-11-01  9:31     ` Paul Burton
  2016-11-01 11:49     ` Maciej W. Rozycki
  1 sibling, 2 replies; 16+ messages in thread
From: Paul Burton @ 2016-11-01  9:31 UTC (permalink / raw)
  To: Maciej W. Rozycki; +Cc: Ralf Baechle, linux-mips, linux-kernel

[-- Attachment #1: Type: text/plain, Size: 10482 bytes --]

On Monday, 31 October 2016 16:27:01 GMT Maciej W. Rozycki wrote:
> Fix a regression introduced with commit 2db9ca0a3551 ("MIPS: Use struct
> mips_abi offsets to save FP context") for MIPS I/I FP signal contexts,
> by converting save/restore code to the updated internal API.  Start FGR
> offsets from 0 rather than SC_FPREGS from $a0 and use $a1 rather than
> the offset of SC_FPC_CSR from $a0 for the Floating Point Control/Status
> Register (FCSR).
> 
> Document the new internal API and adjust assembly code formatting for
> consistency.
> 
> Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
> ---
> linux-mips-isa12-sig-fp-context-offsets.patch
> Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22
> 02:28:09.266462000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:29:01.523906000
> +0100 @@ -26,97 +26,104 @@
> 
>  	.set	noreorder
>  	.set	mips1
> -	/* Save floating point context */
> +
> +/**
> + * _save_fp_context() - save FP context from the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
> + *
> + * Save FP context, including the 32 FP data registers and the FP
> + * control & status register, from the FPU to signal context.
> + */
>  LEAF(_save_fp_context)
>  	.set	push
>  	SET_HARDFLOAT
>  	li	v0, 0					# assume success
> -	cfc1	t1,fcr31
> -	EX(swc1 $f0,(SC_FPREGS+0)(a0))
> -	EX(swc1 $f1,(SC_FPREGS+8)(a0))
> -	EX(swc1 $f2,(SC_FPREGS+16)(a0))
> -	EX(swc1 $f3,(SC_FPREGS+24)(a0))
> -	EX(swc1 $f4,(SC_FPREGS+32)(a0))
> -	EX(swc1 $f5,(SC_FPREGS+40)(a0))
> -	EX(swc1 $f6,(SC_FPREGS+48)(a0))
> -	EX(swc1 $f7,(SC_FPREGS+56)(a0))
> -	EX(swc1 $f8,(SC_FPREGS+64)(a0))
> -	EX(swc1 $f9,(SC_FPREGS+72)(a0))
> -	EX(swc1 $f10,(SC_FPREGS+80)(a0))
> -	EX(swc1 $f11,(SC_FPREGS+88)(a0))
> -	EX(swc1 $f12,(SC_FPREGS+96)(a0))
> -	EX(swc1 $f13,(SC_FPREGS+104)(a0))
> -	EX(swc1 $f14,(SC_FPREGS+112)(a0))
> -	EX(swc1 $f15,(SC_FPREGS+120)(a0))
> -	EX(swc1 $f16,(SC_FPREGS+128)(a0))
> -	EX(swc1 $f17,(SC_FPREGS+136)(a0))
> -	EX(swc1 $f18,(SC_FPREGS+144)(a0))
> -	EX(swc1 $f19,(SC_FPREGS+152)(a0))
> -	EX(swc1 $f20,(SC_FPREGS+160)(a0))
> -	EX(swc1 $f21,(SC_FPREGS+168)(a0))
> -	EX(swc1 $f22,(SC_FPREGS+176)(a0))
> -	EX(swc1 $f23,(SC_FPREGS+184)(a0))
> -	EX(swc1 $f24,(SC_FPREGS+192)(a0))
> -	EX(swc1 $f25,(SC_FPREGS+200)(a0))
> -	EX(swc1 $f26,(SC_FPREGS+208)(a0))
> -	EX(swc1 $f27,(SC_FPREGS+216)(a0))
> -	EX(swc1 $f28,(SC_FPREGS+224)(a0))
> -	EX(swc1 $f29,(SC_FPREGS+232)(a0))
> -	EX(swc1 $f30,(SC_FPREGS+240)(a0))
> -	EX(swc1 $f31,(SC_FPREGS+248)(a0))
> +	cfc1	t1, fcr31
> +	EX(swc1 $f0, 0(a0))
> +	EX(swc1 $f1, 8(a0))
> +	EX(swc1 $f2, 16(a0))
> +	EX(swc1 $f3, 24(a0))
> +	EX(swc1 $f4, 32(a0))
> +	EX(swc1 $f5, 40(a0))
> +	EX(swc1 $f6, 48(a0))
> +	EX(swc1 $f7, 56(a0))
> +	EX(swc1 $f8, 64(a0))
> +	EX(swc1 $f9, 72(a0))
> +	EX(swc1 $f10, 80(a0))
> +	EX(swc1 $f11, 88(a0))
> +	EX(swc1 $f12, 96(a0))
> +	EX(swc1 $f13, 104(a0))
> +	EX(swc1 $f14, 112(a0))
> +	EX(swc1 $f15, 120(a0))
> +	EX(swc1 $f16, 128(a0))
> +	EX(swc1 $f17, 136(a0))
> +	EX(swc1 $f18, 144(a0))
> +	EX(swc1 $f19, 152(a0))
> +	EX(swc1 $f20, 160(a0))
> +	EX(swc1 $f21, 168(a0))
> +	EX(swc1 $f22, 176(a0))
> +	EX(swc1 $f23, 184(a0))
> +	EX(swc1 $f24, 192(a0))
> +	EX(swc1 $f25, 200(a0))
> +	EX(swc1 $f26, 208(a0))
> +	EX(swc1 $f27, 216(a0))
> +	EX(swc1 $f28, 224(a0))
> +	EX(swc1 $f29, 232(a0))
> +	EX(swc1 $f30, 240(a0))
> +	EX(swc1 $f31, 248(a0))
>  	jr	ra
> -	 EX(sw	t1,(SC_FPC_CSR)(a0))
> +	 EX(sw	t1, (a1))
>  	.set	pop
>  	END(_save_fp_context)
> 
> -/*
> - * Restore FPU state:
> - *  - fp gp registers
> - *  - cp1 status/control register
> +/**
> + * _restore_fp_context() - restore FP context to the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
>   *
> - * We base the decision which registers to restore from the signal stack
> - * frame on the current content of c0_status, not on the content of the
> - * stack frame which might have been changed by the user.
> + * Restore FP context, including the 32 FP data registers and the FP
> + * control & status register, from signal context to the FPU.
>   */
>  LEAF(_restore_fp_context)
>  	.set	push
>  	SET_HARDFLOAT
>  	li	v0, 0					# assume success
> -	EX(lw t0,(SC_FPC_CSR)(a0))
> -	EX(lwc1 $f0,(SC_FPREGS+0)(a0))
> -	EX(lwc1 $f1,(SC_FPREGS+8)(a0))
> -	EX(lwc1 $f2,(SC_FPREGS+16)(a0))
> -	EX(lwc1 $f3,(SC_FPREGS+24)(a0))
> -	EX(lwc1 $f4,(SC_FPREGS+32)(a0))
> -	EX(lwc1 $f5,(SC_FPREGS+40)(a0))
> -	EX(lwc1 $f6,(SC_FPREGS+48)(a0))
> -	EX(lwc1 $f7,(SC_FPREGS+56)(a0))
> -	EX(lwc1 $f8,(SC_FPREGS+64)(a0))
> -	EX(lwc1 $f9,(SC_FPREGS+72)(a0))
> -	EX(lwc1 $f10,(SC_FPREGS+80)(a0))
> -	EX(lwc1 $f11,(SC_FPREGS+88)(a0))
> -	EX(lwc1 $f12,(SC_FPREGS+96)(a0))
> -	EX(lwc1 $f13,(SC_FPREGS+104)(a0))
> -	EX(lwc1 $f14,(SC_FPREGS+112)(a0))
> -	EX(lwc1 $f15,(SC_FPREGS+120)(a0))
> -	EX(lwc1 $f16,(SC_FPREGS+128)(a0))
> -	EX(lwc1 $f17,(SC_FPREGS+136)(a0))
> -	EX(lwc1 $f18,(SC_FPREGS+144)(a0))
> -	EX(lwc1 $f19,(SC_FPREGS+152)(a0))
> -	EX(lwc1 $f20,(SC_FPREGS+160)(a0))
> -	EX(lwc1 $f21,(SC_FPREGS+168)(a0))
> -	EX(lwc1 $f22,(SC_FPREGS+176)(a0))
> -	EX(lwc1 $f23,(SC_FPREGS+184)(a0))
> -	EX(lwc1 $f24,(SC_FPREGS+192)(a0))
> -	EX(lwc1 $f25,(SC_FPREGS+200)(a0))
> -	EX(lwc1 $f26,(SC_FPREGS+208)(a0))
> -	EX(lwc1 $f27,(SC_FPREGS+216)(a0))
> -	EX(lwc1 $f28,(SC_FPREGS+224)(a0))
> -	EX(lwc1 $f29,(SC_FPREGS+232)(a0))
> -	EX(lwc1 $f30,(SC_FPREGS+240)(a0))
> -	EX(lwc1 $f31,(SC_FPREGS+248)(a0))
> +	EX(lw t0, (a1))
> +	EX(lwc1 $f0, 0(a0))
> +	EX(lwc1 $f1, 8(a0))
> +	EX(lwc1 $f2, 16(a0))
> +	EX(lwc1 $f3, 24(a0))
> +	EX(lwc1 $f4, 32(a0))
> +	EX(lwc1 $f5, 40(a0))
> +	EX(lwc1 $f6, 48(a0))
> +	EX(lwc1 $f7, 56(a0))
> +	EX(lwc1 $f8, 64(a0))
> +	EX(lwc1 $f9, 72(a0))
> +	EX(lwc1 $f10, 80(a0))
> +	EX(lwc1 $f11, 88(a0))
> +	EX(lwc1 $f12, 96(a0))
> +	EX(lwc1 $f13, 104(a0))
> +	EX(lwc1 $f14, 112(a0))
> +	EX(lwc1 $f15, 120(a0))
> +	EX(lwc1 $f16, 128(a0))
> +	EX(lwc1 $f17, 136(a0))
> +	EX(lwc1 $f18, 144(a0))
> +	EX(lwc1 $f19, 152(a0))
> +	EX(lwc1 $f20, 160(a0))
> +	EX(lwc1 $f21, 168(a0))
> +	EX(lwc1 $f22, 176(a0))
> +	EX(lwc1 $f23, 184(a0))
> +	EX(lwc1 $f24, 192(a0))
> +	EX(lwc1 $f25, 200(a0))
> +	EX(lwc1 $f26, 208(a0))
> +	EX(lwc1 $f27, 216(a0))
> +	EX(lwc1 $f28, 224(a0))
> +	EX(lwc1 $f29, 232(a0))
> +	EX(lwc1 $f30, 240(a0))
> +	EX(lwc1 $f31, 248(a0))
>  	jr	ra
> -	 ctc1	t0,fcr31
> +	 ctc1	t0, fcr31
>  	.set	pop
>  	END(_restore_fp_context)
>  	.set	reorder
> Index: linux-sfr-test/arch/mips/kernel/r6000_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r6000_fpu.S	2016-10-22
> 02:28:57.927876000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:29:12.415002000
> +0100 @@ -21,7 +21,14 @@
>  	.set	push
>  	SET_HARDFLOAT
> 
> -	/* Save floating point context */
> +/**
> + * _save_fp_context() - save FP context from the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
> + *
> + * Save FP context, including the 32 FP data registers and the FP
> + * control & status register, from the FPU to signal context.
> + */
>  	LEAF(_save_fp_context)
>  	mfc0	t0,CP0_STATUS
>  	sll	t0,t0,2
> @@ -30,59 +37,59 @@
> 
>  	cfc1	t1,fcr31
>  	/* Store the 16 double precision registers */
> -	sdc1	$f0,(SC_FPREGS+0)(a0)
> -	sdc1	$f2,(SC_FPREGS+16)(a0)
> -	sdc1	$f4,(SC_FPREGS+32)(a0)
> -	sdc1	$f6,(SC_FPREGS+48)(a0)
> -	sdc1	$f8,(SC_FPREGS+64)(a0)
> -	sdc1	$f10,(SC_FPREGS+80)(a0)
> -	sdc1	$f12,(SC_FPREGS+96)(a0)
> -	sdc1	$f14,(SC_FPREGS+112)(a0)
> -	sdc1	$f16,(SC_FPREGS+128)(a0)
> -	sdc1	$f18,(SC_FPREGS+144)(a0)
> -	sdc1	$f20,(SC_FPREGS+160)(a0)
> -	sdc1	$f22,(SC_FPREGS+176)(a0)
> -	sdc1	$f24,(SC_FPREGS+192)(a0)
> -	sdc1	$f26,(SC_FPREGS+208)(a0)
> -	sdc1	$f28,(SC_FPREGS+224)(a0)
> -	sdc1	$f30,(SC_FPREGS+240)(a0)
> +	sdc1	$f0,0(a0)
> +	sdc1	$f2,16(a0)
> +	sdc1	$f4,32(a0)
> +	sdc1	$f6,48(a0)
> +	sdc1	$f8,64(a0)
> +	sdc1	$f10,80(a0)
> +	sdc1	$f12,96(a0)
> +	sdc1	$f14,112(a0)
> +	sdc1	$f16,128(a0)
> +	sdc1	$f18,144(a0)
> +	sdc1	$f20,160(a0)
> +	sdc1	$f22,176(a0)
> +	sdc1	$f24,192(a0)
> +	sdc1	$f26,208(a0)
> +	sdc1	$f28,224(a0)
> +	sdc1	$f30,240(a0)
>  	jr	ra
> -	 sw	t0,SC_FPC_CSR(a0)
> +	 sw	t0,(a1)
>  1:	jr	ra
>  	 nop
>  	END(_save_fp_context)
> 
> -/* Restore FPU state:
> - *  - fp gp registers
> - *  - cp1 status/control register
> +/**
> + * _restore_fp_context() - restore FP context to the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
>   *
> - * We base the decision which registers to restore from the signal stack
> - * frame on the current content of c0_status, not on the content of the
> - * stack frame which might have been changed by the user.
> + * Restore FP context, including the 32 FP data registers and the FP
> + * control & status register, from signal context to the FPU.
>   */
>  	LEAF(_restore_fp_context)
>  	mfc0	t0,CP0_STATUS
>  	sll	t0,t0,2
> 
>  	bgez	t0,1f
> -	 lw	t0,SC_FPC_CSR(a0)
> +	 lw	t0,(a1)
>  	/* Restore the 16 double precision registers */
> -	ldc1	$f0,(SC_FPREGS+0)(a0)
> -	ldc1	$f2,(SC_FPREGS+16)(a0)
> -	ldc1	$f4,(SC_FPREGS+32)(a0)
> -	ldc1	$f6,(SC_FPREGS+48)(a0)
> -	ldc1	$f8,(SC_FPREGS+64)(a0)
> -	ldc1	$f10,(SC_FPREGS+80)(a0)
> -	ldc1	$f12,(SC_FPREGS+96)(a0)
> -	ldc1	$f14,(SC_FPREGS+112)(a0)
> -	ldc1	$f16,(SC_FPREGS+128)(a0)
> -	ldc1	$f18,(SC_FPREGS+144)(a0)
> -	ldc1	$f20,(SC_FPREGS+160)(a0)
> -	ldc1	$f22,(SC_FPREGS+176)(a0)
> -	ldc1	$f24,(SC_FPREGS+192)(a0)
> -	ldc1	$f26,(SC_FPREGS+208)(a0)
> -	ldc1	$f28,(SC_FPREGS+224)(a0)
> -	ldc1	$f30,(SC_FPREGS+240)(a0)
> +	ldc1	$f0,0(a0)
> +	ldc1	$f2,16(a0)
> +	ldc1	$f4,32(a0)
> +	ldc1	$f6,48(a0)
> +	ldc1	$f8,64(a0)
> +	ldc1	$f10,80(a0)
> +	ldc1	$f12,96(a0)
> +	ldc1	$f14,112(a0)
> +	ldc1	$f16,128(a0)
> +	ldc1	$f18,144(a0)
> +	ldc1	$f20,160(a0)
> +	ldc1	$f22,176(a0)
> +	ldc1	$f24,192(a0)
> +	ldc1	$f26,208(a0)
> +	ldc1	$f28,224(a0)
> +	ldc1	$f30,240(a0)
>  	jr	ra
>  	 ctc1	t0,fcr31
>  1:	jr	ra

Hi Maciej,

Thanks for fixing that up:

    Reviewed-by: Paul Burton <paul.burton@imgtec.com>

BTW, do you have a feel for whether there's a good r2k/r3k platform (ideal 
would be some software emulator if any are good enough) that we could hook up 
to our continuous integration system? That would help us to catch any 
regressions like this in future before they hit mainline.

Thanks,
    Paul

[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 801 bytes --]

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-11-01  9:31   ` Paul Burton
@ 2016-11-01  9:31     ` Paul Burton
  2016-11-01 11:49     ` Maciej W. Rozycki
  1 sibling, 0 replies; 16+ messages in thread
From: Paul Burton @ 2016-11-01  9:31 UTC (permalink / raw)
  To: Maciej W. Rozycki; +Cc: Ralf Baechle, linux-mips, linux-kernel

[-- Attachment #1: Type: text/plain, Size: 10482 bytes --]

On Monday, 31 October 2016 16:27:01 GMT Maciej W. Rozycki wrote:
> Fix a regression introduced with commit 2db9ca0a3551 ("MIPS: Use struct
> mips_abi offsets to save FP context") for MIPS I/I FP signal contexts,
> by converting save/restore code to the updated internal API.  Start FGR
> offsets from 0 rather than SC_FPREGS from $a0 and use $a1 rather than
> the offset of SC_FPC_CSR from $a0 for the Floating Point Control/Status
> Register (FCSR).
> 
> Document the new internal API and adjust assembly code formatting for
> consistency.
> 
> Signed-off-by: Maciej W. Rozycki <macro@imgtec.com>
> ---
> linux-mips-isa12-sig-fp-context-offsets.patch
> Index: linux-sfr-test/arch/mips/kernel/r2300_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r2300_fpu.S	2016-10-22
> 02:28:09.266462000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r2300_fpu.S	2016-10-22 02:29:01.523906000
> +0100 @@ -26,97 +26,104 @@
> 
>  	.set	noreorder
>  	.set	mips1
> -	/* Save floating point context */
> +
> +/**
> + * _save_fp_context() - save FP context from the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
> + *
> + * Save FP context, including the 32 FP data registers and the FP
> + * control & status register, from the FPU to signal context.
> + */
>  LEAF(_save_fp_context)
>  	.set	push
>  	SET_HARDFLOAT
>  	li	v0, 0					# assume success
> -	cfc1	t1,fcr31
> -	EX(swc1 $f0,(SC_FPREGS+0)(a0))
> -	EX(swc1 $f1,(SC_FPREGS+8)(a0))
> -	EX(swc1 $f2,(SC_FPREGS+16)(a0))
> -	EX(swc1 $f3,(SC_FPREGS+24)(a0))
> -	EX(swc1 $f4,(SC_FPREGS+32)(a0))
> -	EX(swc1 $f5,(SC_FPREGS+40)(a0))
> -	EX(swc1 $f6,(SC_FPREGS+48)(a0))
> -	EX(swc1 $f7,(SC_FPREGS+56)(a0))
> -	EX(swc1 $f8,(SC_FPREGS+64)(a0))
> -	EX(swc1 $f9,(SC_FPREGS+72)(a0))
> -	EX(swc1 $f10,(SC_FPREGS+80)(a0))
> -	EX(swc1 $f11,(SC_FPREGS+88)(a0))
> -	EX(swc1 $f12,(SC_FPREGS+96)(a0))
> -	EX(swc1 $f13,(SC_FPREGS+104)(a0))
> -	EX(swc1 $f14,(SC_FPREGS+112)(a0))
> -	EX(swc1 $f15,(SC_FPREGS+120)(a0))
> -	EX(swc1 $f16,(SC_FPREGS+128)(a0))
> -	EX(swc1 $f17,(SC_FPREGS+136)(a0))
> -	EX(swc1 $f18,(SC_FPREGS+144)(a0))
> -	EX(swc1 $f19,(SC_FPREGS+152)(a0))
> -	EX(swc1 $f20,(SC_FPREGS+160)(a0))
> -	EX(swc1 $f21,(SC_FPREGS+168)(a0))
> -	EX(swc1 $f22,(SC_FPREGS+176)(a0))
> -	EX(swc1 $f23,(SC_FPREGS+184)(a0))
> -	EX(swc1 $f24,(SC_FPREGS+192)(a0))
> -	EX(swc1 $f25,(SC_FPREGS+200)(a0))
> -	EX(swc1 $f26,(SC_FPREGS+208)(a0))
> -	EX(swc1 $f27,(SC_FPREGS+216)(a0))
> -	EX(swc1 $f28,(SC_FPREGS+224)(a0))
> -	EX(swc1 $f29,(SC_FPREGS+232)(a0))
> -	EX(swc1 $f30,(SC_FPREGS+240)(a0))
> -	EX(swc1 $f31,(SC_FPREGS+248)(a0))
> +	cfc1	t1, fcr31
> +	EX(swc1 $f0, 0(a0))
> +	EX(swc1 $f1, 8(a0))
> +	EX(swc1 $f2, 16(a0))
> +	EX(swc1 $f3, 24(a0))
> +	EX(swc1 $f4, 32(a0))
> +	EX(swc1 $f5, 40(a0))
> +	EX(swc1 $f6, 48(a0))
> +	EX(swc1 $f7, 56(a0))
> +	EX(swc1 $f8, 64(a0))
> +	EX(swc1 $f9, 72(a0))
> +	EX(swc1 $f10, 80(a0))
> +	EX(swc1 $f11, 88(a0))
> +	EX(swc1 $f12, 96(a0))
> +	EX(swc1 $f13, 104(a0))
> +	EX(swc1 $f14, 112(a0))
> +	EX(swc1 $f15, 120(a0))
> +	EX(swc1 $f16, 128(a0))
> +	EX(swc1 $f17, 136(a0))
> +	EX(swc1 $f18, 144(a0))
> +	EX(swc1 $f19, 152(a0))
> +	EX(swc1 $f20, 160(a0))
> +	EX(swc1 $f21, 168(a0))
> +	EX(swc1 $f22, 176(a0))
> +	EX(swc1 $f23, 184(a0))
> +	EX(swc1 $f24, 192(a0))
> +	EX(swc1 $f25, 200(a0))
> +	EX(swc1 $f26, 208(a0))
> +	EX(swc1 $f27, 216(a0))
> +	EX(swc1 $f28, 224(a0))
> +	EX(swc1 $f29, 232(a0))
> +	EX(swc1 $f30, 240(a0))
> +	EX(swc1 $f31, 248(a0))
>  	jr	ra
> -	 EX(sw	t1,(SC_FPC_CSR)(a0))
> +	 EX(sw	t1, (a1))
>  	.set	pop
>  	END(_save_fp_context)
> 
> -/*
> - * Restore FPU state:
> - *  - fp gp registers
> - *  - cp1 status/control register
> +/**
> + * _restore_fp_context() - restore FP context to the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
>   *
> - * We base the decision which registers to restore from the signal stack
> - * frame on the current content of c0_status, not on the content of the
> - * stack frame which might have been changed by the user.
> + * Restore FP context, including the 32 FP data registers and the FP
> + * control & status register, from signal context to the FPU.
>   */
>  LEAF(_restore_fp_context)
>  	.set	push
>  	SET_HARDFLOAT
>  	li	v0, 0					# assume success
> -	EX(lw t0,(SC_FPC_CSR)(a0))
> -	EX(lwc1 $f0,(SC_FPREGS+0)(a0))
> -	EX(lwc1 $f1,(SC_FPREGS+8)(a0))
> -	EX(lwc1 $f2,(SC_FPREGS+16)(a0))
> -	EX(lwc1 $f3,(SC_FPREGS+24)(a0))
> -	EX(lwc1 $f4,(SC_FPREGS+32)(a0))
> -	EX(lwc1 $f5,(SC_FPREGS+40)(a0))
> -	EX(lwc1 $f6,(SC_FPREGS+48)(a0))
> -	EX(lwc1 $f7,(SC_FPREGS+56)(a0))
> -	EX(lwc1 $f8,(SC_FPREGS+64)(a0))
> -	EX(lwc1 $f9,(SC_FPREGS+72)(a0))
> -	EX(lwc1 $f10,(SC_FPREGS+80)(a0))
> -	EX(lwc1 $f11,(SC_FPREGS+88)(a0))
> -	EX(lwc1 $f12,(SC_FPREGS+96)(a0))
> -	EX(lwc1 $f13,(SC_FPREGS+104)(a0))
> -	EX(lwc1 $f14,(SC_FPREGS+112)(a0))
> -	EX(lwc1 $f15,(SC_FPREGS+120)(a0))
> -	EX(lwc1 $f16,(SC_FPREGS+128)(a0))
> -	EX(lwc1 $f17,(SC_FPREGS+136)(a0))
> -	EX(lwc1 $f18,(SC_FPREGS+144)(a0))
> -	EX(lwc1 $f19,(SC_FPREGS+152)(a0))
> -	EX(lwc1 $f20,(SC_FPREGS+160)(a0))
> -	EX(lwc1 $f21,(SC_FPREGS+168)(a0))
> -	EX(lwc1 $f22,(SC_FPREGS+176)(a0))
> -	EX(lwc1 $f23,(SC_FPREGS+184)(a0))
> -	EX(lwc1 $f24,(SC_FPREGS+192)(a0))
> -	EX(lwc1 $f25,(SC_FPREGS+200)(a0))
> -	EX(lwc1 $f26,(SC_FPREGS+208)(a0))
> -	EX(lwc1 $f27,(SC_FPREGS+216)(a0))
> -	EX(lwc1 $f28,(SC_FPREGS+224)(a0))
> -	EX(lwc1 $f29,(SC_FPREGS+232)(a0))
> -	EX(lwc1 $f30,(SC_FPREGS+240)(a0))
> -	EX(lwc1 $f31,(SC_FPREGS+248)(a0))
> +	EX(lw t0, (a1))
> +	EX(lwc1 $f0, 0(a0))
> +	EX(lwc1 $f1, 8(a0))
> +	EX(lwc1 $f2, 16(a0))
> +	EX(lwc1 $f3, 24(a0))
> +	EX(lwc1 $f4, 32(a0))
> +	EX(lwc1 $f5, 40(a0))
> +	EX(lwc1 $f6, 48(a0))
> +	EX(lwc1 $f7, 56(a0))
> +	EX(lwc1 $f8, 64(a0))
> +	EX(lwc1 $f9, 72(a0))
> +	EX(lwc1 $f10, 80(a0))
> +	EX(lwc1 $f11, 88(a0))
> +	EX(lwc1 $f12, 96(a0))
> +	EX(lwc1 $f13, 104(a0))
> +	EX(lwc1 $f14, 112(a0))
> +	EX(lwc1 $f15, 120(a0))
> +	EX(lwc1 $f16, 128(a0))
> +	EX(lwc1 $f17, 136(a0))
> +	EX(lwc1 $f18, 144(a0))
> +	EX(lwc1 $f19, 152(a0))
> +	EX(lwc1 $f20, 160(a0))
> +	EX(lwc1 $f21, 168(a0))
> +	EX(lwc1 $f22, 176(a0))
> +	EX(lwc1 $f23, 184(a0))
> +	EX(lwc1 $f24, 192(a0))
> +	EX(lwc1 $f25, 200(a0))
> +	EX(lwc1 $f26, 208(a0))
> +	EX(lwc1 $f27, 216(a0))
> +	EX(lwc1 $f28, 224(a0))
> +	EX(lwc1 $f29, 232(a0))
> +	EX(lwc1 $f30, 240(a0))
> +	EX(lwc1 $f31, 248(a0))
>  	jr	ra
> -	 ctc1	t0,fcr31
> +	 ctc1	t0, fcr31
>  	.set	pop
>  	END(_restore_fp_context)
>  	.set	reorder
> Index: linux-sfr-test/arch/mips/kernel/r6000_fpu.S
> ===================================================================
> --- linux-sfr-test.orig/arch/mips/kernel/r6000_fpu.S	2016-10-22
> 02:28:57.927876000 +0100 +++
> linux-sfr-test/arch/mips/kernel/r6000_fpu.S	2016-10-22 02:29:12.415002000
> +0100 @@ -21,7 +21,14 @@
>  	.set	push
>  	SET_HARDFLOAT
> 
> -	/* Save floating point context */
> +/**
> + * _save_fp_context() - save FP context from the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
> + *
> + * Save FP context, including the 32 FP data registers and the FP
> + * control & status register, from the FPU to signal context.
> + */
>  	LEAF(_save_fp_context)
>  	mfc0	t0,CP0_STATUS
>  	sll	t0,t0,2
> @@ -30,59 +37,59 @@
> 
>  	cfc1	t1,fcr31
>  	/* Store the 16 double precision registers */
> -	sdc1	$f0,(SC_FPREGS+0)(a0)
> -	sdc1	$f2,(SC_FPREGS+16)(a0)
> -	sdc1	$f4,(SC_FPREGS+32)(a0)
> -	sdc1	$f6,(SC_FPREGS+48)(a0)
> -	sdc1	$f8,(SC_FPREGS+64)(a0)
> -	sdc1	$f10,(SC_FPREGS+80)(a0)
> -	sdc1	$f12,(SC_FPREGS+96)(a0)
> -	sdc1	$f14,(SC_FPREGS+112)(a0)
> -	sdc1	$f16,(SC_FPREGS+128)(a0)
> -	sdc1	$f18,(SC_FPREGS+144)(a0)
> -	sdc1	$f20,(SC_FPREGS+160)(a0)
> -	sdc1	$f22,(SC_FPREGS+176)(a0)
> -	sdc1	$f24,(SC_FPREGS+192)(a0)
> -	sdc1	$f26,(SC_FPREGS+208)(a0)
> -	sdc1	$f28,(SC_FPREGS+224)(a0)
> -	sdc1	$f30,(SC_FPREGS+240)(a0)
> +	sdc1	$f0,0(a0)
> +	sdc1	$f2,16(a0)
> +	sdc1	$f4,32(a0)
> +	sdc1	$f6,48(a0)
> +	sdc1	$f8,64(a0)
> +	sdc1	$f10,80(a0)
> +	sdc1	$f12,96(a0)
> +	sdc1	$f14,112(a0)
> +	sdc1	$f16,128(a0)
> +	sdc1	$f18,144(a0)
> +	sdc1	$f20,160(a0)
> +	sdc1	$f22,176(a0)
> +	sdc1	$f24,192(a0)
> +	sdc1	$f26,208(a0)
> +	sdc1	$f28,224(a0)
> +	sdc1	$f30,240(a0)
>  	jr	ra
> -	 sw	t0,SC_FPC_CSR(a0)
> +	 sw	t0,(a1)
>  1:	jr	ra
>  	 nop
>  	END(_save_fp_context)
> 
> -/* Restore FPU state:
> - *  - fp gp registers
> - *  - cp1 status/control register
> +/**
> + * _restore_fp_context() - restore FP context to the FPU
> + * @a0 - pointer to fpregs field of sigcontext
> + * @a1 - pointer to fpc_csr field of sigcontext
>   *
> - * We base the decision which registers to restore from the signal stack
> - * frame on the current content of c0_status, not on the content of the
> - * stack frame which might have been changed by the user.
> + * Restore FP context, including the 32 FP data registers and the FP
> + * control & status register, from signal context to the FPU.
>   */
>  	LEAF(_restore_fp_context)
>  	mfc0	t0,CP0_STATUS
>  	sll	t0,t0,2
> 
>  	bgez	t0,1f
> -	 lw	t0,SC_FPC_CSR(a0)
> +	 lw	t0,(a1)
>  	/* Restore the 16 double precision registers */
> -	ldc1	$f0,(SC_FPREGS+0)(a0)
> -	ldc1	$f2,(SC_FPREGS+16)(a0)
> -	ldc1	$f4,(SC_FPREGS+32)(a0)
> -	ldc1	$f6,(SC_FPREGS+48)(a0)
> -	ldc1	$f8,(SC_FPREGS+64)(a0)
> -	ldc1	$f10,(SC_FPREGS+80)(a0)
> -	ldc1	$f12,(SC_FPREGS+96)(a0)
> -	ldc1	$f14,(SC_FPREGS+112)(a0)
> -	ldc1	$f16,(SC_FPREGS+128)(a0)
> -	ldc1	$f18,(SC_FPREGS+144)(a0)
> -	ldc1	$f20,(SC_FPREGS+160)(a0)
> -	ldc1	$f22,(SC_FPREGS+176)(a0)
> -	ldc1	$f24,(SC_FPREGS+192)(a0)
> -	ldc1	$f26,(SC_FPREGS+208)(a0)
> -	ldc1	$f28,(SC_FPREGS+224)(a0)
> -	ldc1	$f30,(SC_FPREGS+240)(a0)
> +	ldc1	$f0,0(a0)
> +	ldc1	$f2,16(a0)
> +	ldc1	$f4,32(a0)
> +	ldc1	$f6,48(a0)
> +	ldc1	$f8,64(a0)
> +	ldc1	$f10,80(a0)
> +	ldc1	$f12,96(a0)
> +	ldc1	$f14,112(a0)
> +	ldc1	$f16,128(a0)
> +	ldc1	$f18,144(a0)
> +	ldc1	$f20,160(a0)
> +	ldc1	$f22,176(a0)
> +	ldc1	$f24,192(a0)
> +	ldc1	$f26,208(a0)
> +	ldc1	$f28,224(a0)
> +	ldc1	$f30,240(a0)
>  	jr	ra
>  	 ctc1	t0,fcr31
>  1:	jr	ra

Hi Maciej,

Thanks for fixing that up:

    Reviewed-by: Paul Burton <paul.burton@imgtec.com>

BTW, do you have a feel for whether there's a good r2k/r3k platform (ideal 
would be some software emulator if any are good enough) that we could hook up 
to our continuous integration system? That would help us to catch any 
regressions like this in future before they hit mainline.

Thanks,
    Paul

[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 801 bytes --]

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-11-01  9:31   ` Paul Burton
  2016-11-01  9:31     ` Paul Burton
@ 2016-11-01 11:49     ` Maciej W. Rozycki
  2016-11-01 11:49       ` Maciej W. Rozycki
  1 sibling, 1 reply; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-11-01 11:49 UTC (permalink / raw)
  To: Paul Burton; +Cc: Ralf Baechle, linux-mips, linux-kernel

On Tue, 1 Nov 2016, Paul Burton wrote:

> BTW, do you have a feel for whether there's a good r2k/r3k platform (ideal 
> would be some software emulator if any are good enough) that we could hook up 
> to our continuous integration system? That would help us to catch any 
> regressions like this in future before they hit mainline.

 I know about no such platform I'm afraid.

 QEMU does not have the R2k/R3k exception/MMU/cache model and implementing 
that would be a considerable effort I see no volunteers for.  I haven't 
heard of any other simulator which might be closer to implementing that 
model.

 As to using real hardware -- I might be the closest myself to be capable 
of doing some automated testing as I have an R3k machine in my home lab 
wired for remote control.  It could track Ralf's `mips-for-linux-next' 
branch and watch out for regressions, by trying to build and boot kernels 
automatically on a regular basis; maybe doing some further validation 
even, such as running GCC or glibc regression testing.  But while the 
target is ready I'm still missing the host-side setup, which I haven't 
completed.  I don't think there's any other hardware readily available 
which could be hooked somewhere.

 So for the time being I think we need to continue relying on people 
spotting issues by hand.  I think we've been doing pretty good overall.

 Thanks for your review.

  Maciej

^ permalink raw reply	[flat|nested] 16+ messages in thread

* Re: [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets
  2016-11-01 11:49     ` Maciej W. Rozycki
@ 2016-11-01 11:49       ` Maciej W. Rozycki
  0 siblings, 0 replies; 16+ messages in thread
From: Maciej W. Rozycki @ 2016-11-01 11:49 UTC (permalink / raw)
  To: Paul Burton; +Cc: Ralf Baechle, linux-mips, linux-kernel

On Tue, 1 Nov 2016, Paul Burton wrote:

> BTW, do you have a feel for whether there's a good r2k/r3k platform (ideal 
> would be some software emulator if any are good enough) that we could hook up 
> to our continuous integration system? That would help us to catch any 
> regressions like this in future before they hit mainline.

 I know about no such platform I'm afraid.

 QEMU does not have the R2k/R3k exception/MMU/cache model and implementing 
that would be a considerable effort I see no volunteers for.  I haven't 
heard of any other simulator which might be closer to implementing that 
model.

 As to using real hardware -- I might be the closest myself to be capable 
of doing some automated testing as I have an R3k machine in my home lab 
wired for remote control.  It could track Ralf's `mips-for-linux-next' 
branch and watch out for regressions, by trying to build and boot kernels 
automatically on a regular basis; maybe doing some further validation 
even, such as running GCC or glibc regression testing.  But while the 
target is ready I'm still missing the host-side setup, which I haven't 
completed.  I don't think there's any other hardware readily available 
which could be hooked somewhere.

 So for the time being I think we need to continue relying on people 
spotting issues by hand.  I think we've been doing pretty good overall.

 Thanks for your review.

  Maciej

^ permalink raw reply	[flat|nested] 16+ messages in thread

end of thread, other threads:[~2016-11-01 11:50 UTC | newest]

Thread overview: 16+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-10-31 16:24 [PATCH 0/4] MIPS I/II FP signal context handling fixes Maciej W. Rozycki
2016-10-31 16:24 ` Maciej W. Rozycki
2016-10-31 16:25 ` [PATCH 1/4] MIPS: Fix ISA I FP sigcontext access violation handling Maciej W. Rozycki
2016-10-31 16:25   ` Maciej W. Rozycki
2016-11-01  9:27   ` Paul Burton
2016-11-01  9:27     ` Paul Burton
2016-10-31 16:26 ` [PATCH 2/4] MIPS: Remove FIR from ISA I FP signal context Maciej W. Rozycki
2016-10-31 16:26   ` Maciej W. Rozycki
2016-10-31 16:27 ` [PATCH 3/4] MIPS: Fix ISA I/II FP signal context offsets Maciej W. Rozycki
2016-10-31 16:27   ` Maciej W. Rozycki
2016-11-01  9:31   ` Paul Burton
2016-11-01  9:31     ` Paul Burton
2016-11-01 11:49     ` Maciej W. Rozycki
2016-11-01 11:49       ` Maciej W. Rozycki
2016-10-31 16:27 ` [PATCH 4/4] MIPS: Correct MIPS I FP sigcontext layout Maciej W. Rozycki
2016-10-31 16:27   ` Maciej W. Rozycki

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).