cpuport.h 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-08-20 zx.chen The first version
  9. */
  10. #ifndef CPUPORT_H__
  11. #define CPUPORT_H__
  12. #include <rtconfig.h>
  13. #include <theadconfig.h>
  14. /* bytes of register width */
  15. #ifdef ARCH_RISCV_64
  16. #define DFSTORE fsd
  17. #define DFLOAD fld
  18. #define SFSTORE fsw
  19. #define SFLOAD flw
  20. #define STORE sd
  21. #define LOAD ld
  22. #define REGBYTES 8
  23. #define SFREGBYTES 4
  24. #define DFREGBYTES 8
  25. #else
  26. #define DFSTORE fsd
  27. #define DFLOAD fld
  28. #define SFSTORE fsw
  29. #define SFLOAD flw
  30. #define STORE sw
  31. #define LOAD lw
  32. #define REGBYTES 4
  33. #define SFREGBYTES 4
  34. #define DFREGBYTES 8
  35. #endif
  36. #ifdef ARCH_RISCV_FPU
  37. #ifdef ARCH_RISCV_FPU_D
  38. #define FSTORE fsd
  39. #define FLOAD fld
  40. #define FREGBYTES 8
  41. #define rv_floatreg_t rt_int64_t
  42. #endif
  43. #ifdef ARCH_RISCV_FPU_S
  44. #define FSTORE fsw
  45. #define FLOAD flw
  46. #define FREGBYTES 4
  47. #define rv_floatreg_t rt_int32_t
  48. #endif
  49. #endif
  50. #endif