pac_armv81.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. /******************************************************************************
  2. * @file pac_armv81.h
  3. * @brief CMSIS PAC key functions for Armv8.1-M PAC extension
  4. * @version V1.0.0
  5. * @date 23. March 2022
  6. ******************************************************************************/
  7. /*
  8. * Copyright (c) 2022 Arm Limited. All rights reserved.
  9. *
  10. * SPDX-License-Identifier: Apache-2.0
  11. *
  12. * Licensed under the Apache License, Version 2.0 (the License); you may
  13. * not use this file except in compliance with the License.
  14. * You may obtain a copy of the License at
  15. *
  16. * www.apache.org/licenses/LICENSE-2.0
  17. *
  18. * Unless required by applicable law or agreed to in writing, software
  19. * distributed under the License is distributed on an AS IS BASIS, WITHOUT
  20. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  21. * See the License for the specific language governing permissions and
  22. * limitations under the License.
  23. */
  24. #if defined ( __ICCARM__ )
  25. #pragma system_include /* treat file as system include file for MISRA check */
  26. #elif defined (__clang__)
  27. #pragma clang system_header /* treat file as system include file */
  28. #endif
  29. #ifndef PAC_ARMV81_H
  30. #define PAC_ARMV81_H
  31. /* ################### PAC Key functions ########################### */
  32. /**
  33. \ingroup CMSIS_Core_FunctionInterface
  34. \defgroup CMSIS_Core_PacKeyFunctions PAC Key functions
  35. \brief Functions that access the PAC keys.
  36. @{
  37. */
  38. #if (defined (__ARM_FEATURE_PAUTH) && (__ARM_FEATURE_PAUTH == 1))
  39. /**
  40. \brief read the PAC key used for privileged mode
  41. \details Reads the PAC key stored in the PAC_KEY_P registers.
  42. \param [out] pPacKey 128bit PAC key
  43. */
  44. __STATIC_FORCEINLINE void __get_PAC_KEY_P (uint32_t* pPacKey) {
  45. __ASM volatile (
  46. "mrs r1, pac_key_p_0\n"
  47. "str r1,[%0,#0]\n"
  48. "mrs r1, pac_key_p_1\n"
  49. "str r1,[%0,#4]\n"
  50. "mrs r1, pac_key_p_2\n"
  51. "str r1,[%0,#8]\n"
  52. "mrs r1, pac_key_p_3\n"
  53. "str r1,[%0,#12]\n"
  54. : : "r" (pPacKey) : "memory", "r1"
  55. );
  56. }
  57. /**
  58. \brief write the PAC key used for privileged mode
  59. \details writes the given PAC key to the PAC_KEY_P registers.
  60. \param [in] pPacKey 128bit PAC key
  61. */
  62. __STATIC_FORCEINLINE void __set_PAC_KEY_P (uint32_t* pPacKey) {
  63. __ASM volatile (
  64. "ldr r1,[%0,#0]\n"
  65. "msr pac_key_p_0, r1\n"
  66. "ldr r1,[%0,#4]\n"
  67. "msr pac_key_p_1, r1\n"
  68. "ldr r1,[%0,#8]\n"
  69. "msr pac_key_p_2, r1\n"
  70. "ldr r1,[%0,#12]\n"
  71. "msr pac_key_p_3, r1\n"
  72. : : "r" (pPacKey) : "memory", "r1"
  73. );
  74. }
  75. /**
  76. \brief read the PAC key used for unprivileged mode
  77. \details Reads the PAC key stored in the PAC_KEY_U registers.
  78. \param [out] pPacKey 128bit PAC key
  79. */
  80. __STATIC_FORCEINLINE void __get_PAC_KEY_U (uint32_t* pPacKey) {
  81. __ASM volatile (
  82. "mrs r1, pac_key_u_0\n"
  83. "str r1,[%0,#0]\n"
  84. "mrs r1, pac_key_u_1\n"
  85. "str r1,[%0,#4]\n"
  86. "mrs r1, pac_key_u_2\n"
  87. "str r1,[%0,#8]\n"
  88. "mrs r1, pac_key_u_3\n"
  89. "str r1,[%0,#12]\n"
  90. : : "r" (pPacKey) : "memory", "r1"
  91. );
  92. }
  93. /**
  94. \brief write the PAC key used for unprivileged mode
  95. \details writes the given PAC key to the PAC_KEY_U registers.
  96. \param [in] pPacKey 128bit PAC key
  97. */
  98. __STATIC_FORCEINLINE void __set_PAC_KEY_U (uint32_t* pPacKey) {
  99. __ASM volatile (
  100. "ldr r1,[%0,#0]\n"
  101. "msr pac_key_u_0, r1\n"
  102. "ldr r1,[%0,#4]\n"
  103. "msr pac_key_u_1, r1\n"
  104. "ldr r1,[%0,#8]\n"
  105. "msr pac_key_u_2, r1\n"
  106. "ldr r1,[%0,#12]\n"
  107. "msr pac_key_u_3, r1\n"
  108. : : "r" (pPacKey) : "memory", "r1"
  109. );
  110. }
  111. #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3))
  112. /**
  113. \brief read the PAC key used for privileged mode (non-secure)
  114. \details Reads the PAC key stored in the non-secure PAC_KEY_P registers when in secure mode.
  115. \param [out] pPacKey 128bit PAC key
  116. */
  117. __STATIC_FORCEINLINE void __TZ_get_PAC_KEY_P_NS (uint32_t* pPacKey) {
  118. __ASM volatile (
  119. "mrs r1, pac_key_p_0_ns\n"
  120. "str r1,[%0,#0]\n"
  121. "mrs r1, pac_key_p_1_ns\n"
  122. "str r1,[%0,#4]\n"
  123. "mrs r1, pac_key_p_2_ns\n"
  124. "str r1,[%0,#8]\n"
  125. "mrs r1, pac_key_p_3_ns\n"
  126. "str r1,[%0,#12]\n"
  127. : : "r" (pPacKey) : "memory", "r1"
  128. );
  129. }
  130. /**
  131. \brief write the PAC key used for privileged mode (non-secure)
  132. \details writes the given PAC key to the non-secure PAC_KEY_P registers when in secure mode.
  133. \param [in] pPacKey 128bit PAC key
  134. */
  135. __STATIC_FORCEINLINE void __TZ_set_PAC_KEY_P_NS (uint32_t* pPacKey) {
  136. __ASM volatile (
  137. "ldr r1,[%0,#0]\n"
  138. "msr pac_key_p_0_ns, r1\n"
  139. "ldr r1,[%0,#4]\n"
  140. "msr pac_key_p_1_ns, r1\n"
  141. "ldr r1,[%0,#8]\n"
  142. "msr pac_key_p_2_ns, r1\n"
  143. "ldr r1,[%0,#12]\n"
  144. "msr pac_key_p_3_ns, r1\n"
  145. : : "r" (pPacKey) : "memory", "r1"
  146. );
  147. }
  148. /**
  149. \brief read the PAC key used for unprivileged mode (non-secure)
  150. \details Reads the PAC key stored in the non-secure PAC_KEY_U registers when in secure mode.
  151. \param [out] pPacKey 128bit PAC key
  152. */
  153. __STATIC_FORCEINLINE void __TZ_get_PAC_KEY_U_NS (uint32_t* pPacKey) {
  154. __ASM volatile (
  155. "mrs r1, pac_key_u_0_ns\n"
  156. "str r1,[%0,#0]\n"
  157. "mrs r1, pac_key_u_1_ns\n"
  158. "str r1,[%0,#4]\n"
  159. "mrs r1, pac_key_u_2_ns\n"
  160. "str r1,[%0,#8]\n"
  161. "mrs r1, pac_key_u_3_ns\n"
  162. "str r1,[%0,#12]\n"
  163. : : "r" (pPacKey) : "memory", "r1"
  164. );
  165. }
  166. /**
  167. \brief write the PAC key used for unprivileged mode (non-secure)
  168. \details writes the given PAC key to the non-secure PAC_KEY_U registers when in secure mode.
  169. \param [in] pPacKey 128bit PAC key
  170. */
  171. __STATIC_FORCEINLINE void __TZ_set_PAC_KEY_U_NS (uint32_t* pPacKey) {
  172. __ASM volatile (
  173. "ldr r1,[%0,#0]\n"
  174. "msr pac_key_u_0_ns, r1\n"
  175. "ldr r1,[%0,#4]\n"
  176. "msr pac_key_u_1_ns, r1\n"
  177. "ldr r1,[%0,#8]\n"
  178. "msr pac_key_u_2_ns, r1\n"
  179. "ldr r1,[%0,#12]\n"
  180. "msr pac_key_u_3_ns, r1\n"
  181. : : "r" (pPacKey) : "memory", "r1"
  182. );
  183. }
  184. #endif /* (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) */
  185. #endif /* (defined (__ARM_FEATURE_PAUTH) && (__ARM_FEATURE_PAUTH == 1)) */
  186. /*@} end of CMSIS_Core_PacKeyFunctions */
  187. #endif /* PAC_ARMV81_H */