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