startup_ARMCM35P.c 7.4 KB

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