mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

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>
34 lines
521 B
C
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
|