aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGreentime Hu <[email protected]>2023-06-05 11:07:04 +0000
committerPalmer Dabbelt <[email protected]>2023-06-08 07:16:40 -0700
commit0a3381a01dcc3d0537732794c007f32e4dfd1efc (patch)
treebaf4b78fcb5537bf12177d8da0407ac901a2f022
parent74abe5a39d3a110f4c87c8ff34b80705009a96e0 (diff)
riscv: Introduce Vector enable/disable helpers
These are small and likely to be frequently called so implement as inline routines (vs. function call). Co-developed-by: Guo Ren <[email protected]> Signed-off-by: Guo Ren <[email protected]> Co-developed-by: Vincent Chen <[email protected]> Signed-off-by: Vincent Chen <[email protected]> Signed-off-by: Greentime Hu <[email protected]> Signed-off-by: Vineet Gupta <[email protected]> Signed-off-by: Andy Chiu <[email protected]> Reviewed-by: Conor Dooley <[email protected]> Reviewed-by: Heiko Stuebner <[email protected]> Tested-by: Heiko Stuebner <[email protected]> Reviewed-by: Palmer Dabbelt <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Palmer Dabbelt <[email protected]>
-rw-r--r--arch/riscv/include/asm/vector.h11
1 files changed, 11 insertions, 0 deletions
diff --git a/arch/riscv/include/asm/vector.h b/arch/riscv/include/asm/vector.h
index bdbb05b70151..51bb37232943 100644
--- a/arch/riscv/include/asm/vector.h
+++ b/arch/riscv/include/asm/vector.h
@@ -11,12 +11,23 @@
#ifdef CONFIG_RISCV_ISA_V
#include <asm/hwcap.h>
+#include <asm/csr.h>
static __always_inline bool has_vector(void)
{
return riscv_has_extension_unlikely(RISCV_ISA_EXT_v);
}
+static __always_inline void riscv_v_enable(void)
+{
+ csr_set(CSR_SSTATUS, SR_VS);
+}
+
+static __always_inline void riscv_v_disable(void)
+{
+ csr_clear(CSR_SSTATUS, SR_VS);
+}
+
#else /* ! CONFIG_RISCV_ISA_V */
static __always_inline bool has_vector(void) { return false; }