All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
@ 2021-03-19 12:01 ` Andre Przywara
  0 siblings, 0 replies; 6+ messages in thread
From: Andre Przywara @ 2021-03-19 12:01 UTC (permalink / raw)
  To: Catalin Marinas, Will Deacon, Shuah Khan
  Cc: Mark Brown, Dave Martin, linux-arm-kernel, linux-kselftest

The "First Fault Register" (FFR) is an SVE register that mimics a
predicate register, but clears bits when a load or store fails to handle
an element of a vector. The supposed usage scenario is to initialise
this register (using SETFFR), then *read* it later on to learn about
elements that failed to load or store. Explicit writes to this register
using the WRFFR instruction are only supposed to *restore* values
previously read from the register (for context-switching only).
As the manual describes, this register holds only certain values, it:
"... contains a monotonic predicate value, in which starting from bit 0
there are zero or more 1 bits, followed only by 0 bits in any remaining
bit positions."
Any other value is UNPREDICTABLE and is not supposed to be "restored"
into the register.

The SVE test currently tries to write a signature pattern into the
register, which is *not* a canonical FFR value. Apparently the existing
setups treat UNPREDICTABLE as "read-as-written", but a new
implementation actually only stores canonical values. As a consequence,
the sve-test fails immediately when comparing the FFR value:
-----------
 # ./sve-test
Vector length:  128 bits
PID:    207
Mismatch: PID=207, iteration=0, reg=48
        Expected [cf00]
        Got      [0f00]
Aborted
-----------

Fix this by only populating the FFR with proper canonical values.
Effectively the requirement described above limits us to 17 unique
values over 16 bits worth of FFR, so we condense our signature down to 4
bits (2 bits from the PID, 2 bits from the generation) and generate the
canonical pattern from it. Any bits describing elements above the
minimum 128 bit are set to 0.

This aligns the FFR usage to the architecture and fixes the test on
microarchitectures implementing FFR in a more restricted way.

Signed-off-by: Andre Przywara <andre.przywara@arm.com>
---
 tools/testing/selftests/arm64/fp/sve-test.S | 22 ++++++++++++++++-----
 1 file changed, 17 insertions(+), 5 deletions(-)

diff --git a/tools/testing/selftests/arm64/fp/sve-test.S b/tools/testing/selftests/arm64/fp/sve-test.S
index 9210691aa998..e3e08d9c7020 100644
--- a/tools/testing/selftests/arm64/fp/sve-test.S
+++ b/tools/testing/selftests/arm64/fp/sve-test.S
@@ -284,16 +284,28 @@ endfunction
 // Set up test pattern in the FFR
 // x0: pid
 // x2: generation
+//
+// We need to generate a canonical FFR value, which consists of a number of
+// low "1" bits, followed by a number of zeros. This gives us 17 unique values
+// per 16 bits of FFR, so we create a 4 bit signature out of the PID and
+// generation, and use that as the initial number of ones in the pattern.
+// We fill the upper lanes of FFR with zeros.
 // Beware: corrupts P0.
 function setup_ffr
 	mov	x4, x30
 
-	bl	pattern
+	and	w0, w0, #0x3
+	bfi	w0, w2, #2, #2
+	mov	w1, #1
+	lsl	w1, w1, w0
+	sub	w1, w1, #1
+
 	ldr	x0, =ffrref
-	ldr	x1, =scratch
-	rdvl	x2, #1
-	lsr	x2, x2, #3
-	bl	memcpy
+	strh	w1, [x0], 2
+	rdvl	x1, #1
+	lsr	x1, x1, #3
+	sub	x1, x1, #2
+	bl	memclr
 
 	mov	x0, #0
 	ldr	x1, =ffrref
-- 
2.25.1


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

* [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
@ 2021-03-19 12:01 ` Andre Przywara
  0 siblings, 0 replies; 6+ messages in thread
From: Andre Przywara @ 2021-03-19 12:01 UTC (permalink / raw)
  To: Catalin Marinas, Will Deacon, Shuah Khan
  Cc: Mark Brown, Dave Martin, linux-arm-kernel, linux-kselftest

The "First Fault Register" (FFR) is an SVE register that mimics a
predicate register, but clears bits when a load or store fails to handle
an element of a vector. The supposed usage scenario is to initialise
this register (using SETFFR), then *read* it later on to learn about
elements that failed to load or store. Explicit writes to this register
using the WRFFR instruction are only supposed to *restore* values
previously read from the register (for context-switching only).
As the manual describes, this register holds only certain values, it:
"... contains a monotonic predicate value, in which starting from bit 0
there are zero or more 1 bits, followed only by 0 bits in any remaining
bit positions."
Any other value is UNPREDICTABLE and is not supposed to be "restored"
into the register.

The SVE test currently tries to write a signature pattern into the
register, which is *not* a canonical FFR value. Apparently the existing
setups treat UNPREDICTABLE as "read-as-written", but a new
implementation actually only stores canonical values. As a consequence,
the sve-test fails immediately when comparing the FFR value:
-----------
 # ./sve-test
Vector length:  128 bits
PID:    207
Mismatch: PID=207, iteration=0, reg=48
        Expected [cf00]
        Got      [0f00]
Aborted
-----------

Fix this by only populating the FFR with proper canonical values.
Effectively the requirement described above limits us to 17 unique
values over 16 bits worth of FFR, so we condense our signature down to 4
bits (2 bits from the PID, 2 bits from the generation) and generate the
canonical pattern from it. Any bits describing elements above the
minimum 128 bit are set to 0.

This aligns the FFR usage to the architecture and fixes the test on
microarchitectures implementing FFR in a more restricted way.

Signed-off-by: Andre Przywara <andre.przywara@arm.com>
---
 tools/testing/selftests/arm64/fp/sve-test.S | 22 ++++++++++++++++-----
 1 file changed, 17 insertions(+), 5 deletions(-)

diff --git a/tools/testing/selftests/arm64/fp/sve-test.S b/tools/testing/selftests/arm64/fp/sve-test.S
index 9210691aa998..e3e08d9c7020 100644
--- a/tools/testing/selftests/arm64/fp/sve-test.S
+++ b/tools/testing/selftests/arm64/fp/sve-test.S
@@ -284,16 +284,28 @@ endfunction
 // Set up test pattern in the FFR
 // x0: pid
 // x2: generation
+//
+// We need to generate a canonical FFR value, which consists of a number of
+// low "1" bits, followed by a number of zeros. This gives us 17 unique values
+// per 16 bits of FFR, so we create a 4 bit signature out of the PID and
+// generation, and use that as the initial number of ones in the pattern.
+// We fill the upper lanes of FFR with zeros.
 // Beware: corrupts P0.
 function setup_ffr
 	mov	x4, x30
 
-	bl	pattern
+	and	w0, w0, #0x3
+	bfi	w0, w2, #2, #2
+	mov	w1, #1
+	lsl	w1, w1, w0
+	sub	w1, w1, #1
+
 	ldr	x0, =ffrref
-	ldr	x1, =scratch
-	rdvl	x2, #1
-	lsr	x2, x2, #3
-	bl	memcpy
+	strh	w1, [x0], 2
+	rdvl	x1, #1
+	lsr	x1, x1, #3
+	sub	x1, x1, #2
+	bl	memclr
 
 	mov	x0, #0
 	ldr	x1, =ffrref
-- 
2.25.1


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

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

* Re: [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
  2021-03-19 12:01 ` Andre Przywara
@ 2021-03-19 12:20   ` Mark Brown
  -1 siblings, 0 replies; 6+ messages in thread
From: Mark Brown @ 2021-03-19 12:20 UTC (permalink / raw)
  To: Andre Przywara
  Cc: Catalin Marinas, Will Deacon, Shuah Khan, Dave Martin,
	linux-arm-kernel, linux-kselftest

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

On Fri, Mar 19, 2021 at 12:01:28PM +0000, Andre Przywara wrote:
> The "First Fault Register" (FFR) is an SVE register that mimics a
> predicate register, but clears bits when a load or store fails to handle
> an element of a vector. The supposed usage scenario is to initialise

Reviwed-by: Mark Brown <broonie@kernel.org>

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

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

* Re: [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
@ 2021-03-19 12:20   ` Mark Brown
  0 siblings, 0 replies; 6+ messages in thread
From: Mark Brown @ 2021-03-19 12:20 UTC (permalink / raw)
  To: Andre Przywara
  Cc: Catalin Marinas, Will Deacon, Shuah Khan, Dave Martin,
	linux-arm-kernel, linux-kselftest


[-- Attachment #1.1: Type: text/plain, Size: 323 bytes --]

On Fri, Mar 19, 2021 at 12:01:28PM +0000, Andre Przywara wrote:
> The "First Fault Register" (FFR) is an SVE register that mimics a
> predicate register, but clears bits when a load or store fails to handle
> an element of a vector. The supposed usage scenario is to initialise

Reviwed-by: Mark Brown <broonie@kernel.org>

[-- Attachment #1.2: signature.asc --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

[-- Attachment #2: Type: text/plain, Size: 176 bytes --]

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

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

* Re: [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
  2021-03-19 12:01 ` Andre Przywara
@ 2021-03-22 13:19   ` Will Deacon
  -1 siblings, 0 replies; 6+ messages in thread
From: Will Deacon @ 2021-03-22 13:19 UTC (permalink / raw)
  To: Shuah Khan, Catalin Marinas, Andre Przywara
  Cc: kernel-team, Will Deacon, linux-arm-kernel, Mark Brown,
	linux-kselftest, Dave Martin

On Fri, 19 Mar 2021 12:01:28 +0000, Andre Przywara wrote:
> The "First Fault Register" (FFR) is an SVE register that mimics a
> predicate register, but clears bits when a load or store fails to handle
> an element of a vector. The supposed usage scenario is to initialise
> this register (using SETFFR), then *read* it later on to learn about
> elements that failed to load or store. Explicit writes to this register
> using the WRFFR instruction are only supposed to *restore* values
> previously read from the register (for context-switching only).
> As the manual describes, this register holds only certain values, it:
> "... contains a monotonic predicate value, in which starting from bit 0
> there are zero or more 1 bits, followed only by 0 bits in any remaining
> bit positions."
> Any other value is UNPREDICTABLE and is not supposed to be "restored"
> into the register.
> 
> [...]

Applied to arm64 (for-next/fixes), thanks!

[1/1] kselftest/arm64: sve: Do not use non-canonical FFR register value
      https://git.kernel.org/arm64/c/7011d72588d1

Cheers,
-- 
Will

https://fixes.arm64.dev
https://next.arm64.dev
https://will.arm64.dev

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

* Re: [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value
@ 2021-03-22 13:19   ` Will Deacon
  0 siblings, 0 replies; 6+ messages in thread
From: Will Deacon @ 2021-03-22 13:19 UTC (permalink / raw)
  To: Shuah Khan, Catalin Marinas, Andre Przywara
  Cc: kernel-team, Will Deacon, linux-arm-kernel, Mark Brown,
	linux-kselftest, Dave Martin

On Fri, 19 Mar 2021 12:01:28 +0000, Andre Przywara wrote:
> The "First Fault Register" (FFR) is an SVE register that mimics a
> predicate register, but clears bits when a load or store fails to handle
> an element of a vector. The supposed usage scenario is to initialise
> this register (using SETFFR), then *read* it later on to learn about
> elements that failed to load or store. Explicit writes to this register
> using the WRFFR instruction are only supposed to *restore* values
> previously read from the register (for context-switching only).
> As the manual describes, this register holds only certain values, it:
> "... contains a monotonic predicate value, in which starting from bit 0
> there are zero or more 1 bits, followed only by 0 bits in any remaining
> bit positions."
> Any other value is UNPREDICTABLE and is not supposed to be "restored"
> into the register.
> 
> [...]

Applied to arm64 (for-next/fixes), thanks!

[1/1] kselftest/arm64: sve: Do not use non-canonical FFR register value
      https://git.kernel.org/arm64/c/7011d72588d1

Cheers,
-- 
Will

https://fixes.arm64.dev
https://next.arm64.dev
https://will.arm64.dev

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

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

end of thread, other threads:[~2021-03-22 13:23 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-03-19 12:01 [PATCH] kselftest/arm64: sve: Do not use non-canonical FFR register value Andre Przywara
2021-03-19 12:01 ` Andre Przywara
2021-03-19 12:20 ` Mark Brown
2021-03-19 12:20   ` Mark Brown
2021-03-22 13:19 ` Will Deacon
2021-03-22 13:19   ` Will Deacon

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.