startup_s_pg.html 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <title>Startup File startup_&lt;device&gt;.s</title>
  7. <title>CMSIS-Core (Cortex-M): Startup File startup_&lt;device&gt;.s</title>
  8. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  9. <link href="cmsis.css" rel="stylesheet" type="text/css" />
  10. <script type="text/javascript" src="jquery.js"></script>
  11. <script type="text/javascript" src="dynsections.js"></script>
  12. <script type="text/javascript" src="printComponentTabs.js"></script>
  13. <link href="navtree.css" rel="stylesheet" type="text/css"/>
  14. <script type="text/javascript" src="resize.js"></script>
  15. <script type="text/javascript" src="navtree.js"></script>
  16. <script type="text/javascript">
  17. $(document).ready(initResizable);
  18. $(window).load(resizeHeight);
  19. </script>
  20. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  21. <script type="text/javascript" src="search/search.js"></script>
  22. <script type="text/javascript">
  23. $(document).ready(function() { searchBox.OnSelectItem(0); });
  24. </script>
  25. </head>
  26. <body>
  27. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  28. <div id="titlearea">
  29. <table cellspacing="0" cellpadding="0">
  30. <tbody>
  31. <tr style="height: 46px;">
  32. <td id="projectlogo"><img alt="Logo" src="CMSIS_Logo_Final.png"/></td>
  33. <td style="padding-left: 0.5em;">
  34. <div id="projectname">CMSIS-Core (Cortex-M)
  35. &#160;<span id="projectnumber">Version 5.2.1</span>
  36. </div>
  37. <div id="projectbrief">CMSIS-Core support for Cortex-M processor-based devices</div>
  38. </td>
  39. </tr>
  40. </tbody>
  41. </table>
  42. </div>
  43. <!-- end header part -->
  44. <div id="CMSISnav" class="tabs1">
  45. <ul class="tablist">
  46. <script type="text/javascript">
  47. <!--
  48. writeComponentTabs.call(this);
  49. //-->
  50. </script>
  51. </ul>
  52. </div>
  53. <!-- Generated by Doxygen 1.8.6 -->
  54. <script type="text/javascript">
  55. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  56. </script>
  57. <div id="navrow1" class="tabs">
  58. <ul class="tablist">
  59. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  60. <li class="current"><a href="pages.html"><span>Usage&#160;and&#160;Description</span></a></li>
  61. <li><a href="modules.html"><span>Reference</span></a></li>
  62. <li>
  63. <div id="MSearchBox" class="MSearchBoxInactive">
  64. <span class="left">
  65. <img id="MSearchSelect" src="search/mag_sel.png"
  66. onmouseover="return searchBox.OnSearchSelectShow()"
  67. onmouseout="return searchBox.OnSearchSelectHide()"
  68. alt=""/>
  69. <input type="text" id="MSearchField" value="Search" accesskey="S"
  70. onfocus="searchBox.OnSearchFieldFocus(true)"
  71. onblur="searchBox.OnSearchFieldFocus(false)"
  72. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  73. </span><span class="right">
  74. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  75. </span>
  76. </div>
  77. </li>
  78. </ul>
  79. </div>
  80. </div><!-- top -->
  81. <div id="side-nav" class="ui-resizable side-nav-resizable">
  82. <div id="nav-tree">
  83. <div id="nav-tree-contents">
  84. <div id="nav-sync" class="sync"></div>
  85. </div>
  86. </div>
  87. <div id="splitbar" style="-moz-user-select:none;"
  88. class="ui-resizable-handle">
  89. </div>
  90. </div>
  91. <script type="text/javascript">
  92. $(document).ready(function(){initNavTree('startup_s_pg.html','');});
  93. </script>
  94. <div id="doc-content">
  95. <!-- window showing the filter options -->
  96. <div id="MSearchSelectWindow"
  97. onmouseover="return searchBox.OnSearchSelectShow()"
  98. onmouseout="return searchBox.OnSearchSelectHide()"
  99. onkeydown="return searchBox.OnSearchSelectKey(event)">
  100. <a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Data Structures</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Groups</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Pages</a></div>
  101. <!-- iframe showing the search results (closed by default) -->
  102. <div id="MSearchResultsWindow">
  103. <iframe src="javascript:void(0)" frameborder="0"
  104. name="MSearchResults" id="MSearchResults">
  105. </iframe>
  106. </div>
  107. <div class="header">
  108. <div class="headertitle">
  109. <div class="title">Startup File startup_&lt;device&gt;.s </div> </div>
  110. </div><!--header-->
  111. <div class="contents">
  112. <div class="textblock"><p>The <a class="el" href="startup_s_pg.html">Startup File startup_&lt;device&gt;.s</a> contains:</p>
  113. <ul>
  114. <li>The reset handler which is executed after CPU reset and typically calls the <a class="el" href="group__system__init__gr.html#ga93f514700ccf00d08dbdcff7f1224eb2">SystemInit</a> function.</li>
  115. <li>The setup values for the Main Stack Pointer (MSP).</li>
  116. <li>Exception vectors of the Cortex-M Processor with weak functions that implement default routines.</li>
  117. <li>Interrupt vectors that are device specific with weak functions that implement default routines.</li>
  118. </ul>
  119. <p>The file exists for each supported toolchain and is the only tool-chain specific CMSIS file.</p>
  120. <p>To adapt the file to a new device only the interrupt vector table needs to be extended with the device-specific interrupt handlers. The naming convention for the interrupt handler names are &lt;interrupt_name&gt;_IRQHandler. This table needs to be consistent with <a class="el" href="group__NVIC__gr.html#ga7e1129cd8a196f4284d41db3e82ad5c8">IRQn_Type</a> that defines all the IRQ numbers for each interrupt.</p>
  121. <p><b>Example:</b> </p>
  122. <p>The following example shows the extension of the interrupt vector table for the LPC1100 device family.</p>
  123. <div class="fragment"><div class="line"> ; External Interrupts</div>
  124. <div class="line"> DCD WAKEUP0_IRQHandler ; 16+ 0: Wakeup PIO0.0</div>
  125. <div class="line"> DCD WAKEUP1_IRQHandler ; 16+ 1: Wakeup PIO0.1</div>
  126. <div class="line"> DCD WAKEUP2_IRQHandler ; 16+ 2: Wakeup PIO0.2</div>
  127. <div class="line"> : :</div>
  128. <div class="line"> : :</div>
  129. <div class="line"> DCD EINT1_IRQHandler ; 16+30: PIO INT1</div>
  130. <div class="line"> DCD EINT0_IRQHandler ; 16+31: PIO INT0</div>
  131. <div class="line"> :</div>
  132. <div class="line"> :</div>
  133. <div class="line"> EXPORT WAKEUP0_IRQHandler [WEAK]</div>
  134. <div class="line"> EXPORT WAKEUP1_IRQHandler [WEAK]</div>
  135. <div class="line"> EXPORT WAKEUP2_IRQHandler [WEAK]</div>
  136. <div class="line"> : :</div>
  137. <div class="line"> : :</div>
  138. <div class="line"> EXPORT EINT1_IRQHandler [WEAK]</div>
  139. <div class="line"> EXPORT EINT0_IRQHandler [WEAK]</div>
  140. <div class="line"></div>
  141. <div class="line">WAKEUP0_IRQHandler</div>
  142. <div class="line">WAKEUP1_IRQHandler</div>
  143. <div class="line">WAKEUP1_IRQHandler</div>
  144. <div class="line"> :</div>
  145. <div class="line"> :</div>
  146. <div class="line">EINT1_IRQHandler</div>
  147. <div class="line">EINT0_IRQHandler</div>
  148. <div class="line"> B .</div>
  149. </div><!-- fragment --><h1><a class="anchor" id="startup_s_sec"></a>
  150. startup_Device.s Template File</h1>
  151. <p>An Arm Compiler <a class="el" href="startup_s_pg.html#startup_s_sec">startup_Device.s Template File</a> for an Armv7-M processor like Cortex-M3 is shown below. The files for other compiler vendors differ slightly in the syntax, but not in the overall structure.</p>
  152. <pre class="fragment">;/**************************************************************************//**
  153. ; * @file startup_&lt;Device&gt;.s
  154. ; * @brief CMSIS Cortex-M ARMv7-M based Core Device Startup File for
  155. ; * Device &lt;Device&gt;
  156. ; * @version V5.4.0
  157. ; * @date 12. December 2018
  158. ; ******************************************************************************/
  159. ;/*
  160. ; * Copyright (c) 2009-2018 Arm Limited. All rights reserved.
  161. ; *
  162. ; * SPDX-License-Identifier: Apache-2.0
  163. ; *
  164. ; * Licensed under the Apache License, Version 2.0 (the License); you may
  165. ; * not use this file except in compliance with the License.
  166. ; * You may obtain a copy of the License at
  167. ; *
  168. ; * www.apache.org/licenses/LICENSE-2.0
  169. ; *
  170. ; * Unless required by applicable law or agreed to in writing, software
  171. ; * distributed under the License is distributed on an AS IS BASIS, WITHOUT
  172. ; * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  173. ; * See the License for the specific language governing permissions and
  174. ; * limitations under the License.
  175. ; */
  176. ;//-------- &lt;&lt;&lt; Use Configuration Wizard in Context Menu &gt;&gt;&gt; ------------------
  177. ;&lt;h&gt; Stack Configuration
  178. ; &lt;o&gt; Stack Size (in Bytes) &lt;0x0-0xFFFFFFFF:8&gt;
  179. ;&lt;/h&gt;
  180. Stack_Size EQU 0x00000400
  181. AREA STACK, NOINIT, READWRITE, ALIGN=3
  182. __stack_limit
  183. Stack_Mem SPACE Stack_Size
  184. __initial_sp
  185. ;&lt;h&gt; Heap Configuration
  186. ; &lt;o&gt; Heap Size (in Bytes) &lt;0x0-0xFFFFFFFF:8&gt;
  187. ;&lt;/h&gt;
  188. Heap_Size EQU 0x00000C00
  189. IF Heap_Size != 0 ; Heap is provided
  190. AREA HEAP, NOINIT, READWRITE, ALIGN=3
  191. __heap_base
  192. Heap_Mem SPACE Heap_Size
  193. __heap_limit
  194. ENDIF
  195. PRESERVE8
  196. THUMB
  197. ; Vector Table Mapped to Address 0 at Reset
  198. AREA RESET, DATA, READONLY
  199. EXPORT __Vectors
  200. EXPORT __Vectors_End
  201. EXPORT __Vectors_Size
  202. __Vectors DCD __initial_sp ; Top of Stack
  203. DCD Reset_Handler ; Reset Handler
  204. DCD NMI_Handler ; -14 NMI Handler
  205. DCD HardFault_Handler ; -13 Hard Fault Handler
  206. DCD MemManage_Handler ; -12 MPU Fault Handler
  207. DCD BusFault_Handler ; -11 Bus Fault Handler
  208. DCD UsageFault_Handler ; -10 Usage Fault Handler
  209. DCD 0 ; Reserved
  210. DCD 0 ; Reserved
  211. DCD 0 ; Reserved
  212. DCD 0 ; Reserved
  213. DCD SVC_Handler ; -5 SVCall Handler
  214. DCD DebugMon_Handler ; -4 Debug Monitor Handler
  215. DCD 0 ; Reserved
  216. DCD PendSV_Handler ; -2 PendSV Handler
  217. DCD SysTick_Handler ; -1 SysTick Handler
  218. ; Interrupts
  219. ; ToDo: Add here the vectors for the device specific external interrupts handler
  220. DCD Interrupt0_Handler ; 0 Interrupt 0
  221. DCD Interrupt1_Handler ; 1 Interrupt 1
  222. DCD Interrupt2_Handler ; 2 Interrupt 2
  223. DCD Interrupt3_Handler ; 3 Interrupt 3
  224. DCD Interrupt4_Handler ; 4 Interrupt 4
  225. DCD Interrupt5_Handler ; 5 Interrupt 5
  226. DCD Interrupt6_Handler ; 6 Interrupt 6
  227. DCD Interrupt7_Handler ; 7 Interrupt 7
  228. DCD Interrupt8_Handler ; 8 Interrupt 8
  229. DCD Interrupt9_Handler ; 9 Interrupt 9
  230. SPACE (214 * 4) ; Interrupts 10 .. 224 are left out
  231. __Vectors_End
  232. __Vectors_Size EQU __Vectors_End - __Vectors
  233. AREA |.text|, CODE, READONLY
  234. ; Reset Handler
  235. Reset_Handler PROC
  236. EXPORT Reset_Handler [WEAK]
  237. IMPORT SystemInit
  238. IMPORT __main
  239. LDR R0, =SystemInit
  240. BLX R0
  241. LDR R0, =__main
  242. BX R0
  243. ENDP
  244. ; Macro to define default exception/interrupt handlers.
  245. ; Default handler are weak symbols with an endless loop.
  246. ; They can be overwritten by real handlers.
  247. MACRO
  248. Set_Default_Handler $Handler_Name
  249. $Handler_Name PROC
  250. EXPORT $Handler_Name [WEAK]
  251. B .
  252. ENDP
  253. MEND
  254. ; Default exception/interrupt handler
  255. Set_Default_Handler NMI_Handler
  256. Set_Default_Handler HardFault_Handler
  257. Set_Default_Handler MemManage_Handler
  258. Set_Default_Handler BusFault_Handler
  259. Set_Default_Handler UsageFault_Handler
  260. Set_Default_Handler SVC_Handler
  261. Set_Default_Handler DebugMon_Handler
  262. Set_Default_Handler PendSV_Handler
  263. Set_Default_Handler SysTick_Handler
  264. Set_Default_Handler Interrupt0_Handler
  265. Set_Default_Handler Interrupt1_Handler
  266. Set_Default_Handler Interrupt2_Handler
  267. Set_Default_Handler Interrupt3_Handler
  268. Set_Default_Handler Interrupt4_Handler
  269. Set_Default_Handler Interrupt5_Handler
  270. Set_Default_Handler Interrupt6_Handler
  271. Set_Default_Handler Interrupt7_Handler
  272. Set_Default_Handler Interrupt8_Handler
  273. Set_Default_Handler Interrupt9_Handler
  274. ALIGN
  275. ; User setup Stack &amp; Heap
  276. IF :LNOT::DEF:__MICROLIB
  277. IMPORT __use_two_region_memory
  278. ENDIF
  279. EXPORT __stack_limit
  280. EXPORT __initial_sp
  281. IF Heap_Size != 0 ; Heap is provided
  282. EXPORT __heap_base
  283. EXPORT __heap_limit
  284. ENDIF
  285. END
  286. </pre> </div></div><!-- contents -->
  287. </div><!-- doc-content -->
  288. <!-- start footer part -->
  289. <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  290. <ul>
  291. <li class="navelem"><a class="el" href="templates_pg.html">CMSIS-Core Device Templates</a></li>
  292. <li class="footer">Generated on Wed Mar 20 2019 14:10:33 for CMSIS-Core (Cortex-M) by Arm Ltd. All rights reserved.
  293. <!--
  294. <a href="http://www.doxygen.org/index.html">
  295. <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.6
  296. -->
  297. </li>
  298. </ul>
  299. </div>
  300. </body>
  301. </html>