cpu_gcc.S 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Copyright (c) 2006-2020, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Date Author Notes
  7. * 2018-10-06 ZhaoXiaowei the first version
  8. */
  9. .text
  10. .globl rt_hw_get_current_el
  11. rt_hw_get_current_el:
  12. MRS X0, CurrentEL
  13. CMP X0, 0xc
  14. B.EQ 3f
  15. CMP X0, 0x8
  16. B.EQ 2f
  17. CMP X0, 0x4
  18. B.EQ 1f
  19. LDR X0, =0
  20. B 0f
  21. 3:
  22. LDR X0, =3
  23. B 0f
  24. 2:
  25. LDR X0, =2
  26. B 0f
  27. 1:
  28. LDR X0, =1
  29. B 0f
  30. 0:
  31. RET
  32. .globl rt_hw_set_current_vbar
  33. rt_hw_set_current_vbar:
  34. MRS X1, CurrentEL
  35. CMP X1, 0xc
  36. B.EQ 3f
  37. CMP X1, 0x8
  38. B.EQ 2f
  39. CMP X1, 0x4
  40. B.EQ 1f
  41. B 0f
  42. 3:
  43. MSR VBAR_EL3,X0
  44. B 0f
  45. 2:
  46. MSR VBAR_EL2,X0
  47. B 0f
  48. 1:
  49. MSR VBAR_EL1,X0
  50. B 0f
  51. 0:
  52. RET
  53. .globl rt_hw_set_elx_env
  54. rt_hw_set_elx_env:
  55. MRS X1, CurrentEL
  56. CMP X1, 0xc
  57. B.EQ 3f
  58. CMP X1, 0x8
  59. B.EQ 2f
  60. CMP X1, 0x4
  61. B.EQ 1f
  62. B 0f
  63. 3:
  64. MRS X0, SCR_EL3
  65. ORR X0, X0, #0xF /* SCR_EL3.NS|IRQ|FIQ|EA */
  66. MSR SCR_EL3, X0
  67. B 0f
  68. 2:
  69. MRS X0, HCR_EL2
  70. ORR X0, X0, #0x38
  71. MSR HCR_EL2, X0
  72. B 0f
  73. 1:
  74. B 0f
  75. 0:
  76. RET
  77. .global rt_cpu_vector_set_base
  78. rt_cpu_vector_set_base:
  79. MSR VBAR_EL1,X0
  80. RET
  81. /**
  82. * unsigned long rt_hw_ffz(unsigned long x)
  83. */
  84. .global rt_hw_ffz
  85. rt_hw_ffz:
  86. mvn x1, x0
  87. clz x0, x1
  88. mov x1, #0x3f
  89. sub x0, x1, x0
  90. ret
  91. .global rt_hw_clz
  92. rt_hw_clz:
  93. clz x0, x0
  94. ret