cpu.h 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * Copyright (c) 2006-2023, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. */
  9. #ifndef __RT_HW_CPU_H__
  10. #define __RT_HW_CPU_H__
  11. #include <rtdef.h>
  12. #include <cpuport.h>
  13. #include <mm_aspace.h>
  14. #ifdef RT_USING_OFW
  15. #include <drivers/ofw.h>
  16. #endif
  17. #define ID_ERROR __INT64_MAX__
  18. #define MPIDR_AFFINITY_MASK 0x000000ff00ffffffUL
  19. struct cpu_ops_t
  20. {
  21. const char *method;
  22. int (*cpu_init)(rt_uint32_t id, void *param);
  23. int (*cpu_boot)(rt_uint32_t id, rt_uint64_t entry);
  24. void (*cpu_shutdown)(void);
  25. };
  26. #define sysreg_32(op1, crn, crm, op2) s3_##op1 ##_##crn ##_##crm ##_##op2
  27. #define sysreg_64(op1, crn, crm, op2) sysreg_32(op1, crn, crm, op2)
  28. #define MPIDR_AFFINITY_MASK 0x000000ff00ffffffUL
  29. #define MPIDR_LEVEL_BITS_SHIFT 3
  30. #define MPIDR_LEVEL_BITS (1 << MPIDR_LEVEL_BITS_SHIFT)
  31. #define MPIDR_LEVEL_MASK ((1 << MPIDR_LEVEL_BITS) - 1)
  32. #define MPIDR_LEVEL_SHIFT(level) (((1 << (level)) >> 1) << MPIDR_LEVEL_BITS_SHIFT)
  33. #define MPIDR_AFFINITY_LEVEL(mpidr, level) (((mpidr) >> MPIDR_LEVEL_SHIFT(level)) & MPIDR_LEVEL_MASK)
  34. /* GIC registers */
  35. #define ICC_IAR0_SYS sysreg_64(0, c12, c8, 0)
  36. #define ICC_IAR1_SYS sysreg_64(0, c12, c12, 0)
  37. #define ICC_EOIR0_SYS sysreg_64(0, c12, c8, 1)
  38. #define ICC_EOIR1_SYS sysreg_64(0, c12, c12, 1)
  39. #define ICC_HPPIR0_SYS sysreg_64(0, c12, c8, 2)
  40. #define ICC_HPPIR1_SYS sysreg_64(0, c12, c12, 2)
  41. #define ICC_BPR0_SYS sysreg_64(0, c12, c8, 3)
  42. #define ICC_BPR1_SYS sysreg_64(0, c12, c12, 3)
  43. #define ICC_DIR_SYS sysreg_64(0, c12, c11, 1)
  44. #define ICC_PMR_SYS sysreg_64(0, c4, c6, 0)
  45. #define ICC_RPR_SYS sysreg_64(0, c12, c11, 3)
  46. #define ICC_CTLR_SYS sysreg_64(0, c12, c12, 4)
  47. #define ICC_SRE_SYS sysreg_64(0, c12, c12, 5)
  48. #define ICC_IGRPEN0_SYS sysreg_64(0, c12, c12, 6)
  49. #define ICC_IGRPEN1_SYS sysreg_64(0, c12, c12, 7)
  50. #define ICC_SGI0R_SYS sysreg_64(0, c12, c11, 7)
  51. #define ICC_SGI1R_SYS sysreg_64(0, c12, c11, 5)
  52. #define ICC_ASGI1R_SYS sysreg_64(0, c12, c11, 6)
  53. /* Arch timer registers */
  54. #define CNTP_CTL CNTP_CTL_EL0 /* EL1 Physical Timer */
  55. #define CNTHP_CTL CNTHP_CTL_EL2 /* EL2 Non-secure Physical Timer */
  56. #define CNTHPS_CTL CNTHPS_CTL_EL2 /* EL2 Secure Physical Timer */
  57. #define CNTPS_CTL CNTPS_CTL_EL1 /* EL3 Physical Timer */
  58. #define CNTV_CTL CNTV_CTL_EL0 /* EL1 Virtual Timer */
  59. #define CNTHV_CTL CNTHV_CTL_EL2 /* EL2 Non-secure Virtual Timer */
  60. #define CNTHVS_CTL CNTHVS_CTL_EL2 /* EL2 Secure Virtual Timer */
  61. #define CNTP_CVAL CNTP_CVAL_EL0
  62. #define CNTHP_CVAL CNTHP_CVAL_EL2
  63. #define CNTHPS_CVAL CNTHPS_CVAL_EL2
  64. #define CNTPS_CVAL CNTPS_CVAL_EL1
  65. #define CNTV_CVAL CNTV_CVAL_EL0
  66. #define CNTHV_CVAL CNTHV_CVAL_EL2
  67. #define CNTHVS_CVAL CNTHVS_CVAL_EL2
  68. #define CNTP_TVAL CNTP_TVAL_EL0
  69. #define CNTHP_TVAL CNTHP_TVAL_EL2
  70. #define CNTHPS_TVAL CNTHPS_TVAL_EL2
  71. #define CNTPS_TVAL CNTPS_TVAL_EL1
  72. #define CNTV_TVAL CNTV_TVAL_EL0
  73. #define CNTHV_TVAL CNTHV_TVAL_EL2
  74. #define CNTHVS_TVAL CNTHVS_TVAL_EL2
  75. #define CNTPCT CNTPCT_EL0
  76. #define CNTVCT CNTVCT_EL0
  77. #define CNTFRQ CNTFRQ_EL0
  78. extern rt_uint64_t rt_cpu_mpidr_table[];
  79. #endif /* __RT_HW_CPU_H__ */