Commit 4126bde0 authored by Mark Brown's avatar Mark Brown Committed by Catalin Marinas

kselftest/arm64: sme: Provide streaming mode SVE stress test

One of the features of SME is the addition of streaming mode, in which we
have access to a set of streaming mode SVE registers at the SME vector
length. Since these are accessed using the SVE instructions let's reuse
the existing SVE stress test for testing with a compile time option for
controlling the few small differences needed:

 - Enter streaming mode immediately on starting the program.
 - In streaming mode FFR is removed so skip reading and writing FFR.
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
Reviewed-by: default avatarShuah Khan <skhan@linuxfoundation.org>
Acked-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
Link: https://lore.kernel.org/r/20220419112247.711548-33-broonie@kernel.orgSigned-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
parent a0f2eb64
...@@ -5,5 +5,6 @@ rdvl-sve ...@@ -5,5 +5,6 @@ rdvl-sve
sve-probe-vls sve-probe-vls
sve-ptrace sve-ptrace
sve-test sve-test
ssve-test
vec-syscfg vec-syscfg
vlset vlset
...@@ -5,6 +5,7 @@ TEST_GEN_PROGS := sve-ptrace sve-probe-vls vec-syscfg ...@@ -5,6 +5,7 @@ TEST_GEN_PROGS := sve-ptrace sve-probe-vls vec-syscfg
TEST_PROGS_EXTENDED := fp-pidbench fpsimd-test fpsimd-stress \ TEST_PROGS_EXTENDED := fp-pidbench fpsimd-test fpsimd-stress \
rdvl-sme rdvl-sve \ rdvl-sme rdvl-sve \
sve-test sve-stress \ sve-test sve-stress \
ssve-test ssve-stress \
vlset vlset
all: $(TEST_GEN_PROGS) $(TEST_PROGS_EXTENDED) all: $(TEST_GEN_PROGS) $(TEST_PROGS_EXTENDED)
...@@ -19,6 +20,8 @@ sve-ptrace: sve-ptrace.o ...@@ -19,6 +20,8 @@ sve-ptrace: sve-ptrace.o
sve-probe-vls: sve-probe-vls.o rdvl.o sve-probe-vls: sve-probe-vls.o rdvl.o
sve-test: sve-test.o asm-utils.o sve-test: sve-test.o asm-utils.o
$(CC) -nostdlib $^ -o $@ $(CC) -nostdlib $^ -o $@
ssve-test: sve-test.S asm-utils.o
$(CC) -DSSVE -nostdlib $^ -o $@
vec-syscfg: vec-syscfg.o rdvl.o vec-syscfg: vec-syscfg.o rdvl.o
vlset: vlset.o vlset: vlset.o
......
#!/bin/bash
# SPDX-License-Identifier: GPL-2.0-only
# Copyright (C) 2015-2019 ARM Limited.
# Original author: Dave Martin <Dave.Martin@arm.com>
set -ue
NR_CPUS=`nproc`
pids=
logs=
cleanup () {
trap - INT TERM CHLD
set +e
if [ -n "$pids" ]; then
kill $pids
wait $pids
pids=
fi
if [ -n "$logs" ]; then
cat $logs
rm $logs
logs=
fi
}
interrupt () {
cleanup
exit 0
}
child_died () {
cleanup
exit 1
}
trap interrupt INT TERM EXIT
for x in `seq 0 $((NR_CPUS * 4))`; do
log=`mktemp`
logs=$logs\ $log
./ssve-test >$log &
pids=$pids\ $!
done
# Wait for all child processes to be created:
sleep 10
while :; do
kill -USR1 $pids
done &
pids=$pids\ $!
wait
exit 1
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#include <asm/unistd.h> #include <asm/unistd.h>
#include "assembler.h" #include "assembler.h"
#include "asm-offsets.h" #include "asm-offsets.h"
#include "sme-inst.h"
#define NZR 32 #define NZR 32
#define NPR 16 #define NPR 16
...@@ -156,6 +157,7 @@ endfunction ...@@ -156,6 +157,7 @@ endfunction
// We fill the upper lanes of FFR with zeros. // We fill the upper lanes of FFR with zeros.
// Beware: corrupts P0. // Beware: corrupts P0.
function setup_ffr function setup_ffr
#ifndef SSVE
mov x4, x30 mov x4, x30
and w0, w0, #0x3 and w0, w0, #0x3
...@@ -178,6 +180,9 @@ function setup_ffr ...@@ -178,6 +180,9 @@ function setup_ffr
wrffr p0.b wrffr p0.b
ret x4 ret x4
#else
ret
#endif
endfunction endfunction
// Trivial memory compare: compare x2 bytes starting at address x0 with // Trivial memory compare: compare x2 bytes starting at address x0 with
...@@ -260,6 +265,7 @@ endfunction ...@@ -260,6 +265,7 @@ endfunction
// Beware -- corrupts P0. // Beware -- corrupts P0.
// Clobbers x0-x5. // Clobbers x0-x5.
function check_ffr function check_ffr
#ifndef SSVE
mov x3, x30 mov x3, x30
ldr x4, =scratch ldr x4, =scratch
...@@ -280,6 +286,9 @@ function check_ffr ...@@ -280,6 +286,9 @@ function check_ffr
mov x2, x5 mov x2, x5
mov x30, x3 mov x30, x3
b memcmp b memcmp
#else
ret
#endif
endfunction endfunction
// Any SVE register modified here can cause corruption in the main // Any SVE register modified here can cause corruption in the main
...@@ -295,10 +304,12 @@ function irritator_handler ...@@ -295,10 +304,12 @@ function irritator_handler
movi v0.8b, #1 movi v0.8b, #1
movi v9.16b, #2 movi v9.16b, #2
movi v31.8b, #3 movi v31.8b, #3
#ifndef SSVE
// And P0 // And P0
rdffr p0.b rdffr p0.b
// And FFR // And FFR
wrffr p15.b wrffr p15.b
#endif
ret ret
endfunction endfunction
...@@ -359,6 +370,11 @@ endfunction ...@@ -359,6 +370,11 @@ endfunction
.globl _start .globl _start
function _start function _start
_start: _start:
#ifdef SSVE
puts "Streaming mode "
smstart_sm
#endif
// Sanity-check and report the vector length // Sanity-check and report the vector length
rdvl x19, #8 rdvl x19, #8
...@@ -407,6 +423,10 @@ _start: ...@@ -407,6 +423,10 @@ _start:
orr w2, w2, #SA_NODEFER orr w2, w2, #SA_NODEFER
bl setsignal bl setsignal
#ifdef SSVE
smstart_sm // syscalls will have exited streaming mode
#endif
mov x22, #0 // generation number, increments per iteration mov x22, #0 // generation number, increments per iteration
.Ltest_loop: .Ltest_loop:
rdvl x0, #8 rdvl x0, #8
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment