Commit 72e30195 authored by Joey Gouly's avatar Joey Gouly Committed by Catalin Marinas

kselftest/arm64: add FEAT_LSE128 to hwcap test

Add test of a 128-bit atomic instruction for FEAT_LSE128.
Signed-off-by: default avatarJoey Gouly <joey.gouly@arm.com>
Cc: Will Deacon <will@kernel.org>
Link: https://lore.kernel.org/r/20231003124544.858804-3-joey.gouly@arm.com
[catalin.marinas@arm.com: reordered lse128_sigill() alphabetically]
Signed-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
parent 94d0657f
...@@ -81,6 +81,20 @@ static void lrcpc_sigill(void) ...@@ -81,6 +81,20 @@ static void lrcpc_sigill(void)
asm volatile(".inst 0xb8bfc3e0" : : : ); asm volatile(".inst 0xb8bfc3e0" : : : );
} }
static void lse128_sigill(void)
{
u64 __attribute__ ((aligned (16))) mem[2] = { 10, 20 };
register u64 *memp asm ("x0") = mem;
register u64 val0 asm ("x1") = 5;
register u64 val1 asm ("x2") = 4;
/* SWPP X1, X2, [X0] */
asm volatile(".inst 0x19228001"
: "+r" (memp), "+r" (val0), "+r" (val1)
:
: "cc", "memory");
}
static void mops_sigill(void) static void mops_sigill(void)
{ {
char dst[1], src[1]; char dst[1], src[1];
...@@ -390,6 +404,13 @@ static const struct hwcap_data { ...@@ -390,6 +404,13 @@ static const struct hwcap_data {
.sigbus_fn = uscat_sigbus, .sigbus_fn = uscat_sigbus,
.sigbus_reliable = true, .sigbus_reliable = true,
}, },
{
.name = "LSE128",
.at_hwcap = AT_HWCAP2,
.hwcap_bit = HWCAP2_LSE128,
.cpuinfo = "lse128",
.sigill_fn = lse128_sigill,
},
{ {
.name = "MOPS", .name = "MOPS",
.at_hwcap = AT_HWCAP2, .at_hwcap = AT_HWCAP2,
......
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