fpsimd.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * Copyright (C) 2012 ARM Ltd.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #ifndef __ASM_FP_H
  17. #define __ASM_FP_H
  18. #include <asm/ptrace.h>
  19. #ifndef __ASSEMBLY__
  20. /*
  21. * FP/SIMD storage area has:
  22. * - FPSR and FPCR
  23. * - 32 128-bit data registers
  24. *
  25. * Note that user_fp forms a prefix of this structure, which is relied
  26. * upon in the ptrace FP/SIMD accessors. struct user_fpsimd_state must
  27. * form a prefix of struct fpsimd_state.
  28. */
  29. struct fpsimd_state {
  30. union {
  31. struct user_fpsimd_state user_fpsimd;
  32. struct {
  33. __uint128_t vregs[32];
  34. u32 fpsr;
  35. u32 fpcr;
  36. };
  37. };
  38. };
  39. #if defined(__KERNEL__) && defined(CONFIG_COMPAT)
  40. /* Masks for extracting the FPSR and FPCR from the FPSCR */
  41. #define VFP_FPSCR_STAT_MASK 0xf800009f
  42. #define VFP_FPSCR_CTRL_MASK 0x07f79f00
  43. /*
  44. * The VFP state has 32x64-bit registers and a single 32-bit
  45. * control/status register.
  46. */
  47. #define VFP_STATE_SIZE ((32 * 8) + 4)
  48. #endif
  49. struct task_struct;
  50. extern void fpsimd_save_state(struct fpsimd_state *state);
  51. extern void fpsimd_load_state(struct fpsimd_state *state);
  52. extern void fpsimd_thread_switch(struct task_struct *next);
  53. extern void fpsimd_flush_thread(void);
  54. #endif
  55. #endif