xref: /qemu/target/arm/tcg/helper-sme.h (revision e9ad3ef19ee4af62152fdc7f1150bf59a7f997d0)
1f84734b8SRichard Henderson /*
2f84734b8SRichard Henderson  *  AArch64 SME specific helper definitions
3f84734b8SRichard Henderson  *
4f84734b8SRichard Henderson  *  Copyright (c) 2022 Linaro, Ltd
5f84734b8SRichard Henderson  *
6f84734b8SRichard Henderson  * This library is free software; you can redistribute it and/or
7f84734b8SRichard Henderson  * modify it under the terms of the GNU Lesser General Public
8f84734b8SRichard Henderson  * License as published by the Free Software Foundation; either
9f84734b8SRichard Henderson  * version 2.1 of the License, or (at your option) any later version.
10f84734b8SRichard Henderson  *
11f84734b8SRichard Henderson  * This library is distributed in the hope that it will be useful,
12f84734b8SRichard Henderson  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13f84734b8SRichard Henderson  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14f84734b8SRichard Henderson  * Lesser General Public License for more details.
15f84734b8SRichard Henderson  *
16f84734b8SRichard Henderson  * You should have received a copy of the GNU Lesser General Public
17f84734b8SRichard Henderson  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
18f84734b8SRichard Henderson  */
19f84734b8SRichard Henderson 
20f84734b8SRichard Henderson DEF_HELPER_FLAGS_2(set_pstate_sm, TCG_CALL_NO_RWG, void, env, i32)
21f84734b8SRichard Henderson DEF_HELPER_FLAGS_2(set_pstate_za, TCG_CALL_NO_RWG, void, env, i32)
22ad939afbSRichard Henderson 
23ad939afbSRichard Henderson DEF_HELPER_FLAGS_3(sme_zero, TCG_CALL_NO_RWG, void, env, i32, i32)
24e9ad3ef1SRichard Henderson 
25e9ad3ef1SRichard Henderson /* Move to/from vertical array slices, i.e. columns, so 'c'.  */
26e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_cz_b, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
27e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_zc_b, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
28e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_cz_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
29e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_zc_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
30e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_cz_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
31e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_zc_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
32e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_cz_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
33e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_zc_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
34e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_cz_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
35e9ad3ef1SRichard Henderson DEF_HELPER_FLAGS_4(sme_mova_zc_q, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
36