blob: 2979efb1db780fe71f9247af139c1d52931dd1b0 [file] [log] [blame]
David Cunadoce88eee2017-10-20 11:30:57 +01001/*
Madhukar Pappireddy78728cd2024-06-17 15:22:36 -05002 * Copyright (c) 2017-2024, Arm Limited and Contributors. All rights reserved.
David Cunadoce88eee2017-10-20 11:30:57 +01003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Antonio Nino Diaz033b4bb2018-10-25 16:52:26 +01007#ifndef SVE_H
8#define SVE_H
David Cunadoce88eee2017-10-20 11:30:57 +01009
Max Shvetsovc4502772021-03-22 11:59:37 +000010#include <context.h>
Antonio Nino Diaz033b4bb2018-10-25 16:52:26 +010011
Jayanth Dodderi Chidanandd62c6812023-03-07 10:43:19 +000012#if (ENABLE_SME_FOR_NS || ENABLE_SVE_FOR_NS)
Madhukar Pappireddy78728cd2024-06-17 15:22:36 -050013
Boyan Karatotev6468d4a2023-02-16 15:12:45 +000014void sve_init_el2_unused(void);
Elizabeth Ho4fc00d22023-07-18 14:10:25 +010015void sve_enable_per_world(per_world_context_t *per_world_ctx);
16void sve_disable_per_world(per_world_context_t *per_world_ctx);
Jayanth Dodderi Chidanandd62c6812023-03-07 10:43:19 +000017#else
Elizabeth Ho4fc00d22023-07-18 14:10:25 +010018static inline void sve_init_el2_unused(void)
Jayanth Dodderi Chidanandd62c6812023-03-07 10:43:19 +000019{
20}
Elizabeth Ho4fc00d22023-07-18 14:10:25 +010021static inline void sve_enable_per_world(per_world_context_t *per_world_ctx)
Boyan Karatotev6468d4a2023-02-16 15:12:45 +000022{
23}
Elizabeth Ho4fc00d22023-07-18 14:10:25 +010024static inline void sve_disable_per_world(per_world_context_t *per_world_ctx)
Jayanth Dodderi Chidanandd62c6812023-03-07 10:43:19 +000025{
26}
27#endif /* ( ENABLE_SME_FOR_NS | ENABLE_SVE_FOR_NS ) */
David Cunadoce88eee2017-10-20 11:30:57 +010028
Madhukar Pappireddy78728cd2024-06-17 15:22:36 -050029#if CTX_INCLUDE_SVE_REGS
30void sve_context_save(simd_regs_t *regs);
31void sve_context_restore(simd_regs_t *regs);
32#endif
33
Antonio Nino Diaz033b4bb2018-10-25 16:52:26 +010034#endif /* SVE_H */