linux/tools/testing/selftests/arm64/signal/sve_helpers.h
Mark Brown 116e50d647 kselftest/arm64: Check that SVCR is 0 in signal handlers
We don't currently validate that we exit streaming mode and clear ZA when
we enter a signal handler. Add simple checks for this in the SSVE and ZA
tests.

Signed-off-by: Mark Brown <broonie@kernel.org>
Link: https://lore.kernel.org/r/20241106-arm64-fpmr-signal-test-v1-1-31fa34ce58fe@kernel.org
[catalin.marinas@arm.com: Use %lx in fprintf() as uint64_t seems to be unsigned long in glibc]
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
2024-11-12 13:18:13 +00:00

34 lines
521 B
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (C) 2024 ARM Limited
*
* Common helper functions for SVE and SME functionality.
*/
#ifndef __SVE_HELPERS_H__
#define __SVE_HELPERS_H__
#include <stdbool.h>
#define VLS_USE_SVE false
#define VLS_USE_SME true
extern unsigned int vls[];
extern unsigned int nvls;
int sve_fill_vls(bool use_sme, int min_vls);
static inline uint64_t get_svcr(void)
{
uint64_t val;
asm volatile (
"mrs %0, S3_3_C4_C2_2\n"
: "=r"(val)
:
: "cc");
return val;
}
#endif