startup_ARMv8MBL.c 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. /******************************************************************************
  2. * @file startup_ARMv8MBL.c
  3. * @brief CMSIS-Core Device Startup File for a ARMv8MBL Device
  4. * @version V2.1.0
  5. * @date 16. December 2020
  6. ******************************************************************************/
  7. /*
  8. * Copyright (c) 2009-2020 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 (ARMv8MBL)
  25. #include "ARMv8MBL.h"
  26. #else
  27. #error device not specified!
  28. #endif
  29. /*----------------------------------------------------------------------------
  30. External References
  31. *----------------------------------------------------------------------------*/
  32. extern uint32_t __INITIAL_SP;
  33. extern uint32_t __STACK_LIMIT;
  34. #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U)
  35. extern uint32_t __STACK_SEAL;
  36. #endif
  37. extern __NO_RETURN void __PROGRAM_START(void);
  38. /*----------------------------------------------------------------------------
  39. Internal References
  40. *----------------------------------------------------------------------------*/
  41. __NO_RETURN void Reset_Handler (void);
  42. void Default_Handler(void);
  43. /*----------------------------------------------------------------------------
  44. Exception / Interrupt Handler
  45. *----------------------------------------------------------------------------*/
  46. /* Exceptions */
  47. void NMI_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  48. void HardFault_Handler (void) __attribute__ ((weak));
  49. void SVC_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  50. void PendSV_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  51. void SysTick_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  52. void Interrupt0_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  53. void Interrupt1_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  54. void Interrupt2_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  55. void Interrupt3_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  56. void Interrupt4_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  57. void Interrupt5_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  58. void Interrupt6_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  59. void Interrupt7_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  60. void Interrupt8_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  61. void Interrupt9_Handler (void) __attribute__ ((weak, alias("Default_Handler")));
  62. /*----------------------------------------------------------------------------
  63. Exception / Interrupt Vector table
  64. *----------------------------------------------------------------------------*/
  65. #if defined ( __GNUC__ )
  66. #pragma GCC diagnostic push
  67. #pragma GCC diagnostic ignored "-Wpedantic"
  68. #endif
  69. extern const VECTOR_TABLE_Type __VECTOR_TABLE[240];
  70. const VECTOR_TABLE_Type __VECTOR_TABLE[240] __VECTOR_TABLE_ATTRIBUTE = {
  71. (VECTOR_TABLE_Type)(&__INITIAL_SP), /* Initial Stack Pointer */
  72. Reset_Handler, /* Reset Handler */
  73. NMI_Handler, /* -14 NMI Handler */
  74. HardFault_Handler, /* -13 Hard Fault Handler */
  75. 0, /* Reserved */
  76. 0, /* Reserved */
  77. 0, /* Reserved */
  78. 0, /* Reserved */
  79. 0, /* Reserved */
  80. 0, /* Reserved */
  81. 0, /* Reserved */
  82. SVC_Handler, /* -5 SVC Handler */
  83. 0, /* Reserved */
  84. 0, /* Reserved */
  85. PendSV_Handler, /* -2 PendSV Handler */
  86. SysTick_Handler, /* -1 SysTick Handler */
  87. /* Interrupts */
  88. Interrupt0_Handler, /* 0 Interrupt 0 */
  89. Interrupt1_Handler, /* 1 Interrupt 1 */
  90. Interrupt2_Handler, /* 2 Interrupt 2 */
  91. Interrupt3_Handler, /* 3 Interrupt 3 */
  92. Interrupt4_Handler, /* 4 Interrupt 4 */
  93. Interrupt5_Handler, /* 5 Interrupt 5 */
  94. Interrupt6_Handler, /* 6 Interrupt 6 */
  95. Interrupt7_Handler, /* 7 Interrupt 7 */
  96. Interrupt8_Handler, /* 8 Interrupt 8 */
  97. Interrupt9_Handler /* 9 Interrupt 9 */
  98. /* Interrupts 10 .. 223 are left out */
  99. };
  100. #if defined ( __GNUC__ )
  101. #pragma GCC diagnostic pop
  102. #endif
  103. /*----------------------------------------------------------------------------
  104. Reset Handler called on controller reset
  105. *----------------------------------------------------------------------------*/
  106. __NO_RETURN void Reset_Handler(void)
  107. {
  108. __set_PSP((uint32_t)(&__INITIAL_SP));
  109. #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U)
  110. __set_MSPLIM((uint32_t)(&__STACK_LIMIT));
  111. __set_PSPLIM((uint32_t)(&__STACK_LIMIT));
  112. __TZ_set_STACKSEAL_S((uint32_t *)(&__STACK_SEAL));
  113. #endif
  114. SystemInit(); /* CMSIS System Initialization */
  115. __PROGRAM_START(); /* Enter PreMain (C library entry point) */
  116. }
  117. #if defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
  118. #pragma clang diagnostic push
  119. #pragma clang diagnostic ignored "-Wmissing-noreturn"
  120. #endif
  121. /*----------------------------------------------------------------------------
  122. Hard Fault Handler
  123. *----------------------------------------------------------------------------*/
  124. void HardFault_Handler(void)
  125. {
  126. while(1);
  127. }
  128. /*----------------------------------------------------------------------------
  129. Default Handler for Exceptions / Interrupts
  130. *----------------------------------------------------------------------------*/
  131. void Default_Handler(void)
  132. {
  133. while(1);
  134. }
  135. #if defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
  136. #pragma clang diagnostic pop
  137. #endif