123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- /*
- * Copyright (C) 2012 ARM Ltd.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- #ifndef __ASM_FP_H
- #define __ASM_FP_H
- #include <asm/ptrace.h>
- #ifndef __ASSEMBLY__
- /*
- * FP/SIMD storage area has:
- * - FPSR and FPCR
- * - 32 128-bit data registers
- *
- * Note that user_fpsimd forms a prefix of this structure, which is
- * relied upon in the ptrace FP/SIMD accessors.
- */
- struct fpsimd_state {
- union {
- struct user_fpsimd_state user_fpsimd;
- struct {
- __uint128_t vregs[32];
- u32 fpsr;
- u32 fpcr;
- };
- };
- /* the id of the last cpu to have restored this state */
- unsigned int cpu;
- };
- /*
- * Struct for stacking the bottom 'n' FP/SIMD registers.
- */
- struct fpsimd_partial_state {
- u32 fpsr;
- u32 fpcr;
- u32 num_regs;
- __uint128_t vregs[32];
- };
- #if defined(__KERNEL__) && defined(CONFIG_COMPAT)
- /* Masks for extracting the FPSR and FPCR from the FPSCR */
- #define VFP_FPSCR_STAT_MASK 0xf800009f
- #define VFP_FPSCR_CTRL_MASK 0x07f79f00
- /*
- * The VFP state has 32x64-bit registers and a single 32-bit
- * control/status register.
- */
- #define VFP_STATE_SIZE ((32 * 8) + 4)
- #endif
- struct task_struct;
- extern void fpsimd_save_state(struct fpsimd_state *state);
- extern void fpsimd_load_state(struct fpsimd_state *state);
- extern void fpsimd_thread_switch(struct task_struct *next);
- extern void fpsimd_flush_thread(void);
- extern void fpsimd_preserve_current_state(void);
- extern void fpsimd_restore_current_state(void);
- extern void fpsimd_update_current_state(struct fpsimd_state *state);
- extern void fpsimd_flush_task_state(struct task_struct *target);
- extern void fpsimd_save_partial_state(struct fpsimd_partial_state *state,
- u32 num_regs);
- extern void fpsimd_load_partial_state(struct fpsimd_partial_state *state);
- #endif
- #endif
|