svd_SVDConv_pg.html 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639
  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>SVDConv utility</title>
  7. <title>CMSIS-SVD: SVDConv utility</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-SVD
  35. &#160;<span id="projectnumber">Version 1.3.6</span>
  36. </div>
  37. <div id="projectbrief">CMSIS System View Description</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>
  62. <div id="MSearchBox" class="MSearchBoxInactive">
  63. <span class="left">
  64. <img id="MSearchSelect" src="search/mag_sel.png"
  65. onmouseover="return searchBox.OnSearchSelectShow()"
  66. onmouseout="return searchBox.OnSearchSelectHide()"
  67. alt=""/>
  68. <input type="text" id="MSearchField" value="Search" accesskey="S"
  69. onfocus="searchBox.OnSearchFieldFocus(true)"
  70. onblur="searchBox.OnSearchFieldFocus(false)"
  71. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  72. </span><span class="right">
  73. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  74. </span>
  75. </div>
  76. </li>
  77. </ul>
  78. </div>
  79. </div><!-- top -->
  80. <div id="side-nav" class="ui-resizable side-nav-resizable">
  81. <div id="nav-tree">
  82. <div id="nav-tree-contents">
  83. <div id="nav-sync" class="sync"></div>
  84. </div>
  85. </div>
  86. <div id="splitbar" style="-moz-user-select:none;"
  87. class="ui-resizable-handle">
  88. </div>
  89. </div>
  90. <script type="text/javascript">
  91. $(document).ready(function(){initNavTree('svd_SVDConv_pg.html','');});
  92. </script>
  93. <div id="doc-content">
  94. <!-- window showing the filter options -->
  95. <div id="MSearchSelectWindow"
  96. onmouseover="return searchBox.OnSearchSelectShow()"
  97. onmouseout="return searchBox.OnSearchSelectHide()"
  98. onkeydown="return searchBox.OnSearchSelectKey(event)">
  99. <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>Pages</a></div>
  100. <!-- iframe showing the search results (closed by default) -->
  101. <div id="MSearchResultsWindow">
  102. <iframe src="javascript:void(0)" frameborder="0"
  103. name="MSearchResults" id="MSearchResults">
  104. </iframe>
  105. </div>
  106. <div class="header">
  107. <div class="headertitle">
  108. <div class="title">SVDConv utility </div> </div>
  109. </div><!--header-->
  110. <div class="contents">
  111. <div class="textblock"><p><b>SVDConv</b> is a command-line utility to validate CMSIS-SVD files and to generate CMSIS-compliant device header files. <b>SVDConv</b> is distributed with the <b>ARM::CMSIS</b> Pack (in the CMSIS\Utilities directory) together with the <b>CMSIS-SVD.xsd</b> schema file. <b>SVDConv</b> is available for Windows and Linux operating systems.</p>
  112. <p><b>SVDConv</b> performs the following operations:</p>
  113. <ul>
  114. <li>Checks the syntactical and structural compliance with the specified CMSIS-SVD format.</li>
  115. <li>Checks the consistency, correctness, and completeness of the CMSIS-SVD file against the CMSIS-SVD schema file.</li>
  116. <li>Generates CMSIS-compliant device header files, which can be used for software development.</li>
  117. </ul>
  118. <dl class="section note"><dt>Note</dt><dd>Consider using --strict option to receive all pedantic warnings. Some rules are skipped by default due to backward compatibility reasons. All newly developed/updated SVD files should rather respect all rules.</dd></dl>
  119. <h2>Operation </h2>
  120. <p><b>SVDConv</b> is invoked form the command line. The general command format is: </p>
  121. <div class="fragment"><div class="line">SVDConv.exe &lt;SVD_file&gt; &lt;options&gt;</div>
  122. </div><!-- fragment --><p>&#160;</p>
  123. <table class="cmtable" summary="SVDConv Args">
  124. <tr>
  125. <th>&lt;options&gt; </th><th>Short Name </th><th>Description </th></tr>
  126. <tr>
  127. <td><em>none</em> </td><td>Validation </td><td>Perform a validation check of the SVD file. Errors and warnings are printed on screen. </td></tr>
  128. <tr>
  129. <td>-b </td><td>Log File </td><td>Specify the log file name for writing messages. Default: screen. </td></tr>
  130. <tr>
  131. <td>-o </td><td>Output Path </td><td>Specify an output path for the generated device header file or log file. Default: current directory. </td></tr>
  132. <tr>
  133. <td>--generate=header </td><td>Generate Device Header File </td><td>Generates the device header file. The name of the generated file is derived from the value of the tag &lt;devicename&gt; in the CMSIS-SVD file. Refer to <a class="el" href="elem_device.html">device</a>. </td></tr>
  134. <tr>
  135. <td>--generate=partition </td><td>Generate Partition file for Cortex-M Security Extensions (Armv8-M) </td><td>Generates the device partition file. The name of the generated file is composed of <em>partition_</em> and the value of the device <em>&lt;name&gt;</em> (for example, <em>partition_CMSDK_ARMv8MBL.h</em>). Refer to <a class="el" href="elem_device.html">/device element</a>. The content of the file uses Configuration Wizard annotations and is derived from the SAU-specific information of the <a class="el" href="elem_cpu.html#elem_sauRegionsConfig">/device/cpu/sauRegionsConfig element</a> and the interrupts specified in the <a class="el" href="elem_peripherals.html">/device/peripherals element</a>. </td></tr>
  136. <tr>
  137. <td>--fields=enum </td><td>Bit-field Enums </td><td>Generates enum lists for each field value description contained in the CMSIS-SVD input file. Must be used in combination with <em>--generate=header</em>. </td></tr>
  138. <tr>
  139. <td>--fields=macro </td><td>Bit-field Macros </td><td>Generates position and mask C-Macros for each field description contained in the CMSIS-SVD input file. Must be used in combination with <em>--generate=header</em>. </td></tr>
  140. <tr>
  141. <td>--fields=struct </td><td>Bit-field Structs </td><td>Generates bit fields for each field description contained in the CMSIS-SVD input file. Must be used in combination with <em>--generate=header</em>. </td></tr>
  142. <tr>
  143. <td>--fields=struct-ansic </td><td>ANSI Bit-field Structs </td><td>Generates MISRA-compliant structures for each bitfield. The generated code <b>is not CMSIS-compliant</b>! Must be used in combination with <em>--generate=header</em>. </td></tr>
  144. <tr>
  145. <td>--strict </td><td>Strict error checking </td><td><b>RECOMMENDED!</b> Applies strict error checking and generates a lot more messages. </td></tr>
  146. </table>
  147. <h2>Return Codes </h2>
  148. <p><b>SVDConv</b> returns the following codes: <br/>
  149. </p>
  150. <table class="doxtable">
  151. <tr>
  152. <th align="center">Code </th><th align="left">Description </th><th align="left">Action </th></tr>
  153. <tr>
  154. <td align="center">0 </td><td align="left">OK </td><td align="left">No action required. Validation and conversion performed without errors. </td></tr>
  155. <tr>
  156. <td align="center">1 </td><td align="left">WARNINGS </td><td align="left">Warnings should be checked an possibly removed. The header file is created and could be used. </td></tr>
  157. <tr>
  158. <td align="center">2 </td><td align="left">ERRORS </td><td align="left">Errors in the SVD description file. Important elements are missing and must be corrected. </td></tr>
  159. <tr>
  160. <td align="center">3 </td><td align="left">Error in command line </td><td align="left">Check and correct the command line arguments. </td></tr>
  161. </table>
  162. <p><b>Examples</b> <br/>
  163. </p>
  164. <ol type="1">
  165. <li>Retrieve help information on screen. <div class="fragment"><div class="line">SVDConv </div>
  166. </div><!-- fragment --> <br/>
  167. </li>
  168. <li>Perform a consistency check by passing only the SVD file name. Errors and warnings are printed on screen. <div class="fragment"><div class="line">SVDConv ARM_Example.svd </div>
  169. </div><!-- fragment --> <br/>
  170. The result is printed on screen: <pre class="fragment"> MVCM3110.svd(1688) : info
  171. &lt;description&gt; missing for value '2 : MODE2'
  172. MVCM3110.svd(1692) : info
  173. &lt;description&gt; missing for value '3 : MODE3'
  174. MVCM3110.svd(1696) : info
  175. &lt;description&gt; missing for value '4 : MODE4'
  176. Area of improvements:
  177. * Description contains 267 &lt;fields&gt; defined without associated &lt;enumeratedValues&gt;
  178. Found 0 Errors and 1 Warnings
  179. Return Code: 1 (WARNINGS)</pre> <br/>
  180. </li>
  181. <li>Generate the header file. Performs a consistency check. Errors and warnings are printed on screen. <div class="fragment"><div class="line">SVDConv ARM_Example.svd --generate=header</div>
  182. </div><!-- fragment --> <br/>
  183. Code snippet from the generated header file showing the structure for <b>TIMER0</b>. <br/>
  184. <div class="fragment"><div class="line"><span class="comment">/* ================ TIMER0 ================ */</span></div>
  185. <div class="line"><span class="keyword">typedef</span> <span class="keyword">struct </span>{ </div>
  186. <div class="line"> __IO uint32_t CR; </div>
  187. <div class="line"> __IO uint16_t SR; </div>
  188. <div class="line"> __I uint16_t RESERVED0[5];</div>
  189. <div class="line"> __IO uint16_t INT; </div>
  190. <div class="line"> __I uint16_t RESERVED1[7];</div>
  191. <div class="line"> __IO uint32_t COUNT; </div>
  192. <div class="line"> __IO uint32_t MATCH; </div>
  193. <div class="line"> <span class="keyword">union </span>{</div>
  194. <div class="line"> __O uint32_t PRESCALE_WR; </div>
  195. <div class="line"> __I uint32_t PRESCALE_RD; </div>
  196. <div class="line"> };</div>
  197. <div class="line"> __I uint32_t RESERVED2[9];</div>
  198. <div class="line"> __IO uint32_t RELOAD[4]; </div>
  199. <div class="line">} TIMER0_Type;</div>
  200. </div><!-- fragment --> <br/>
  201. </li>
  202. <li>Generate the header file containing bit fields. Performs a consistency check. Errors and warnings are printed on screen. <div class="fragment"><div class="line">SVDConv ARM_Example.svd --generate=header --fields=<span class="keyword">struct</span></div>
  203. </div><!-- fragment --> <br/>
  204. Code snippet from the generated header file showing the structure for <b>TIMER0</b>. <br/>
  205. Compare to the code snippet above. <div class="fragment"><div class="line"><span class="comment">/* ================ TIMER0 ================ */</span></div>
  206. <div class="line"><span class="keyword">typedef</span> <span class="keyword">struct </span>{ </div>
  207. <div class="line"> <span class="keyword">union </span>{</div>
  208. <div class="line"> __IO uint32_t CR; </div>
  209. <div class="line"> <span class="keyword">struct </span>{</div>
  210. <div class="line"> __IO uint32_t EN : 1; </div>
  211. <div class="line"> __O uint32_t RST : 1; </div>
  212. <div class="line"> __IO uint32_t CNT : 2; </div>
  213. <div class="line"> __IO uint32_t MODE : 3; </div>
  214. <div class="line"> __IO uint32_t PSC : 1; </div>
  215. <div class="line"> __IO uint32_t CNTSRC : 4; </div>
  216. <div class="line"> __IO uint32_t CAPSRC : 4; </div>
  217. <div class="line"> __IO uint32_t CAPEDGE : 2; </div>
  218. <div class="line"> uint32_t : 2;</div>
  219. <div class="line"> __IO uint32_t TRGEXT : 2; </div>
  220. <div class="line"> uint32_t : 2;</div>
  221. <div class="line"> __IO uint32_t RELOAD : 2; </div>
  222. <div class="line"> __IO uint32_t IDR : 2; </div>
  223. <div class="line"> uint32_t : 3;</div>
  224. <div class="line"> __IO uint32_t S : 1; </div>
  225. <div class="line"> } CR_b; </div>
  226. <div class="line"> };</div>
  227. <div class="line"> </div>
  228. <div class="line"> <span class="keyword">union </span>{</div>
  229. <div class="line"> __IO uint16_t SR; </div>
  230. <div class="line"> <span class="keyword">struct </span>{</div>
  231. <div class="line"> __I uint16_t RUN : 1; </div>
  232. <div class="line"> uint16_t : 7;</div>
  233. <div class="line"> __IO uint16_t MATCH : 1; </div>
  234. <div class="line"> __IO uint16_t UN : 1; </div>
  235. <div class="line"> __IO uint16_t OV : 1; </div>
  236. <div class="line"> uint16_t : 1;</div>
  237. <div class="line"> __I uint16_t RST : 1; </div>
  238. <div class="line"> uint16_t : 1;</div>
  239. <div class="line"> __I uint16_t RELOAD : 2; </div>
  240. <div class="line"> } SR_b; </div>
  241. <div class="line"> };</div>
  242. <div class="line"> __I uint16_t RESERVED0[5];</div>
  243. <div class="line"> </div>
  244. <div class="line"> <span class="keyword">union </span>{</div>
  245. <div class="line"> __IO uint16_t INT; </div>
  246. <div class="line"> <span class="keyword">struct </span>{</div>
  247. <div class="line"> __IO uint16_t EN : 1; </div>
  248. <div class="line"> uint16_t : 3;</div>
  249. <div class="line"> __IO uint16_t MODE : 3; </div>
  250. <div class="line"> } INT_b; </div>
  251. <div class="line"> };</div>
  252. <div class="line"> __I uint16_t RESERVED1[7];</div>
  253. <div class="line"> __IO uint32_t COUNT; </div>
  254. <div class="line"> __IO uint32_t MATCH; </div>
  255. <div class="line"> <span class="keyword">union </span>{</div>
  256. <div class="line"> __O uint32_t PRESCALE_WR; </div>
  257. <div class="line"> __I uint32_t PRESCALE_RD; </div>
  258. <div class="line"> };</div>
  259. <div class="line"> __I uint32_t RESERVED2[9];</div>
  260. <div class="line"> __IO uint32_t RELOAD[4]; </div>
  261. <div class="line">} TIMER0_Type;</div>
  262. </div><!-- fragment --></li>
  263. </ol>
  264. <h1><a class="anchor" id="svdconvMessages"></a>
  265. Error and Warning Messages</h1>
  266. <p>The following table shows the errors and warnings issued by svdconv.</p>
  267. <h2>Help messages </h2>
  268. <table class="cmtable" summary="svdconv Invocation Msgs">
  269. <tr>
  270. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Details/Action </th></tr>
  271. <tr>
  272. <td>M020 </td><td>TEXT</td><td><em>SVD_STRING_OPTIONS</em> </td><td>Displays programm help. </td></tr>
  273. <tr>
  274. <td>M021 </td><td>TEXT</td><td><em>'DESCR'</em> <em>'VER'</em> <br/>
  275. <em>'COPYRIGHT'</em> </td><td>Displays module name 'DESCR', version 'VER' and copyright information 'COPYRIGHT'. </td></tr>
  276. <tr>
  277. <td>M022 </td><td>TEXT</td><td>Found <em>'ERR'</em> Error(s) and <em>'WARN'</em> Warning(s).</td><td>Displays the number of errors/warnings. </td></tr>
  278. <tr>
  279. <td>M023 </td><td>TEXT</td><td>Phase <em>'CHECK'</em> </td><td>Information about the check phase. </td></tr>
  280. <tr>
  281. <td>M024 </td><td>TEXT</td><td>Arguments: <em>'OPTS'</em> </td><td>Specify arguments. </td></tr>
  282. </table>
  283. <h2>Informative messages </h2>
  284. <table class="cmtable" summary="Info Messages">
  285. <tr>
  286. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Details/Action </th></tr>
  287. <tr>
  288. <td>M040 </td><td>Info</td><td><em>'NAME'</em>: <em>'TIME'</em> ms. Passed</td><td></td></tr>
  289. <tr>
  290. <td>M041 </td><td>Info</td><td>Overall time: <em>'TIME'</em> ms.</td><td></td></tr>
  291. <tr>
  292. <td>M050 </td><td>Info</td><td>Current Working Directory: <em>'PATH'</em> </td><td></td></tr>
  293. <tr>
  294. <td>M051 </td><td>Info</td><td>Reading SVD File: <em>'PATH'</em> </td><td></td></tr>
  295. <tr>
  296. <td>M061 </td><td>Info</td><td>Checking SVD Description</td><td></td></tr>
  297. </table>
  298. <h2>Invocation errors </h2>
  299. <table class="cmtable" summary="Internal and Invocation Errors">
  300. <tr>
  301. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Action </th></tr>
  302. <tr>
  303. <td>M101 </td><td>ERROR</td><td>Unknown error!</td><td>Please contact support. </td></tr>
  304. <tr>
  305. <td>M102 </td><td>ERROR</td><td>MFC initialization failed</td><td>Please contact support. </td></tr>
  306. <tr>
  307. <td>M103 </td><td>ERROR</td><td>Internal Error: <em>'REF'</em> </td><td>Please contact support. </td></tr>
  308. <tr>
  309. <td>M104 </td><td>CRITICAL</td><td><em>'MSG'</em> </td><td>Please contact support. </td></tr>
  310. <tr>
  311. <td>M105 </td><td>ERROR</td><td>Cannot add Register to group sorter: <em>'NAME'</em> </td><td></td></tr>
  312. <tr>
  313. <td>M106 </td><td>ERROR</td><td>Command <em>'NAME'</em> failed: <em>'NUM'</em>: <em>'MSG'</em> </td><td></td></tr>
  314. <tr>
  315. <td>M107 </td><td>ERROR</td><td>Lost xml file stream.</td><td>Check SVD file. </td></tr>
  316. <tr>
  317. <td>M108 </td><td>ERROR</td><td>SfrDis not supported.Disassembly not supported.</td><td></td></tr>
  318. <tr>
  319. <td>M109 </td><td>ERROR</td><td>Cannot find <em>'NAME'</em> </td><td>Check specified file. </td></tr>
  320. <tr>
  321. <td>M111 </td><td>PROGRESS</td><td><em>'NAME'</em> failed</td><td>Check specified file. </td></tr>
  322. <tr>
  323. <td>M120 </td><td>ERROR</td><td>Invalid arguments!</td><td>Provide a list of valid arguments. </td></tr>
  324. <tr>
  325. <td>M121 </td><td>ERROR</td><td>File not found <em>'NAME'</em> Check specified file.</td><td></td></tr>
  326. <tr>
  327. <td>M122 </td><td>ERROR</td><td>Name of command file should follow <em>'@'</em> </td><td>Check specified command. </td></tr>
  328. <tr>
  329. <td>M123 </td><td>ERROR</td><td>File not found: <em>'PATH'!</em> </td><td>Check speficied path. </td></tr>
  330. <tr>
  331. <td>M124 </td><td>ERROR</td><td>Cannot execute SfrCC2: <em>'PATH'!"</em> </td><td>Check path to SfrCC2. </td></tr>
  332. <tr>
  333. <td>M125 </td><td>WARNING</td><td>SfrCC2 report: <br/>
  334. <em>'MSG'</em> <br/>
  335. SfrCC2 report end.</td><td></td></tr>
  336. <tr>
  337. <td>M126 </td><td>WARNING</td><td>SfrDis: <em>'MSG'</em> </td><td></td></tr>
  338. <tr>
  339. <td>M127 </td><td>ERROR</td><td>SfrCC2 reports errors!</td><td>Check SVD file. </td></tr>
  340. <tr>
  341. <td>M128 </td><td>WARNING</td><td>SfrCC2 reports warnings!</td><td>Check SVD file. </td></tr>
  342. <tr>
  343. <td>M129 </td><td>ERROR</td><td>Option unknown: <em>'OPT'</em> </td><td>Check given option <em>'OPT'</em>. </td></tr>
  344. <tr>
  345. <td>M130 </td><td>ERROR</td><td>Cannot create file <em>'NAME'</em> </td><td>Check user rights. </td></tr>
  346. <tr>
  347. <td>M132 </td><td>ERROR</td><td>SfrCC2 report: <br/>
  348. <em>'MSG'</em> <br/>
  349. SfrCC2 report end."</td><td></td></tr>
  350. </table>
  351. <h2>Validation errors </h2>
  352. <table class="cmtable" summary="Validation Errors">
  353. <tr>
  354. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Action </th></tr>
  355. <tr>
  356. <td>M201 </td><td>ERROR</td><td>Tag &lt;<em>'TAG'&gt;</em> unknown or not allowed on this level."</td><td>Check tag </td></tr>
  357. <tr>
  358. <td>M202 </td><td>ERROR</td><td>Parse error: &lt;<em>'TAG'&gt;</em> = <em>'VALUE'</em> </td><td>Check tag/value. </td></tr>
  359. <tr>
  360. <td>M203 </td><td>ERROR</td><td>Value already set: &lt;<em>'TAG'&gt;</em> = <em>'VALUE'</em> </td><td>Check tag/value. </td></tr>
  361. <tr>
  362. <td>M204 </td><td>ERROR</td><td>Parse Error: <em>'VALUE'</em> </td><td>Check value. </td></tr>
  363. <tr>
  364. <td>M205 </td><td>WARNING</td><td>Tag &lt;<em>'TAG'&gt;</em> empty</td><td>Assign value to tag. </td></tr>
  365. <tr>
  366. <td>M206 </td><td>ERROR</td><td>DerivedFrom not found: <em>'NAME'</em> </td><td>Check derivate. </td></tr>
  367. <tr>
  368. <td>M207 </td><td>ERROR</td><td>Expression marker found but no &lt;dim&gt; specified: <em>'NAME'</em> </td><td>Specify dimension. </td></tr>
  369. <tr>
  370. <td>M208 </td><td>ERROR</td><td>Ignoring &lt;dimIndex&gt; because specified &lt;name&gt; requires Array generation.</td><td>Generate an array. </td></tr>
  371. <tr>
  372. <td>M209 </td><td>WARNING</td><td>CPU section not set. This is required for CMSIS Headerfile generation and debug support.</td><td>Add CPU section. </td></tr>
  373. <tr>
  374. <td>M210 </td><td>WARNING</td><td>Use new Format CMSIS-SVD &gt;= V1.1 and add &lt;CPU&gt; Section.</td><td>Update schema and add CPU section. </td></tr>
  375. <tr>
  376. <td>M211 </td><td>ERROR</td><td>Ignoring <em>'LEVEL'</em> <em>'NAME'</em> (see previous message)</td><td></td></tr>
  377. <tr>
  378. <td>M212 </td><td>ERROR</td><td>Address Block &lt;usage&gt; parse error: <em>'NAME'</em> </td><td>Correct address block. </td></tr>
  379. <tr>
  380. <td>M213 </td><td>ERROR</td><td>Expression for <em>'NAME'</em> incomplete, &lt;<em>'TAG'&gt;</em> missing.</td><td>Add tag. </td></tr>
  381. <tr>
  382. <td>M214 </td><td>ERROR</td><td>Peripheral <em>'NAME'</em> &lt;dim&gt; single-instantiation is not supported (use Array instead).</td><td>Correct Regs to Reg[s]. </td></tr>
  383. <tr>
  384. <td>M215 </td><td>WARNING</td><td>Size of &lt;dim&gt; is only one element for <em>'NAME'</em>, is this intended?</td><td>Check single element. </td></tr>
  385. <tr>
  386. <td>M216 </td><td>WARNING</td><td>Unsupported character found in <em>'NAME'</em> : <em>'HEX'</em>.</td><td>Correct name. </td></tr>
  387. <tr>
  388. <td>M217 </td><td>WARNING</td><td>Forbidden Trigraph '??CHAR' found in <em>'NAME'</em>.</td><td></td></tr>
  389. <tr>
  390. <td>M218 </td><td>WARNING</td><td>Unsupported ESC sequence found in <em>'NAME'</em> : <em>'CHAR'</em>.</td><td>Correct escape sequence. </td></tr>
  391. <tr>
  392. <td>M219 </td><td>ERROR</td><td>C Code generation error: <em>'MSG'</em> </td><td></td></tr>
  393. <tr>
  394. <td>M220 </td><td>WARNING</td><td>C Code generation warning: <em>'MSG'</em> </td><td></td></tr>
  395. <tr>
  396. <td>M221 </td><td>WARNING</td><td>Input filename must end with .svd: <em>'NAME'</em> </td><td>Correct input filename extension. </td></tr>
  397. <tr>
  398. <td>M222 </td><td>WARNING</td><td>Input filename has no extension: <em>'NAME'</em> </td><td>Correct input filename extension. </td></tr>
  399. <tr>
  400. <td>M223 </td><td>ERROR</td><td>Input File Name <em>'INFILE'</em> does not match the tag &lt;name&gt; in the &lt;device&gt; section: <em>'NAME'</em> </td><td>Correct the MCU name. </td></tr>
  401. <tr>
  402. <td>M224 </td><td>WARNING</td><td>Deprecated: <em>'NAME'</em> Use <em>'NAME2'</em> instead</td><td>Update SVD file. </td></tr>
  403. <tr>
  404. <td>M225 </td><td>ERROR</td><td>Upper/lower case error: <em>'NAME'</em>, should be <em>'NAME2'"</em> </td><td>Update SVD file. </td></tr>
  405. <tr>
  406. <td>M226 </td><td>ERROR</td><td>SFD Code generation error: <em>'MSG'</em> </td><td></td></tr>
  407. <tr>
  408. <td>M227 </td><td>WARNING</td><td>SFD Code generation warning: <em>'MSG'</em> </td><td></td></tr>
  409. <tr>
  410. <td>M228 </td><td>ERROR</td><td>Enumerated Value Container: Only one Item allowed on this Level!</td><td>Remove additional items. </td></tr>
  411. <tr>
  412. <td>M229 </td><td>ERROR</td><td>Register <em>'NAME'</em> is not an array, &lt;dimArrayIndex&gt; is not applicable</td><td>Correct SVD. </td></tr>
  413. <tr>
  414. <td>M230 </td><td>ERROR</td><td>Value <em>'NAME'</em>:<em>'NUM'</em> out of Range for <em>'LEVEL'</em> <em>'NAME2'</em>[<em>'NUM2'</em>].</td><td>Correct SVD. </td></tr>
  415. <tr>
  416. <td>M231 </td><td>ERROR</td><td>Value &lt;isDefault&gt; not allowed for <em>'LEVEL'</em>.</td><td>Correct SVD. </td></tr>
  417. <tr>
  418. <td>M232 </td><td>ERROR</td><td>Tag &lt;<em>'TAG'&gt;</em> name <em>'NAME'</em> must not have specifier <em>'CHAR'</em>. Ignoring entry."</td><td>Correct SVD. </td></tr>
  419. <tr>
  420. <td>M233 </td><td>ERROR</td><td>Parse error: &lt;<em>'TAG'&gt;</em> = <em>'VALUE'</em> </td><td>Correct SVD. </td></tr>
  421. <tr>
  422. <td>M234 </td><td>ERROR</td><td>No valid items found for <em>'LEVEL'</em> <em>'NAME'</em> </td><td>Correct SVD. </td></tr>
  423. <tr>
  424. <td>M235 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> cannot be an array.</td><td>Correct SVD. </td></tr>
  425. <tr>
  426. <td>M236 </td><td>ERROR</td><td>Expression for &lt;<em>'TAG'&gt;</em> <em>'NAME'</em> not allowed.</td><td>Correct SVD. </td></tr>
  427. <tr>
  428. <td>M237 </td><td>ERROR</td><td>Nameless <em>'LEVEL'</em> must have &lt;<em>'TAG'&gt;</em>.</td><td>Correct SVD. </td></tr>
  429. <tr>
  430. <td>M238 </td><td>ERROR</td><td><em>'LEVEL'</em> must not have &lt;<em>'TAG'&gt;</em>."</td><td>Correct SVD. </td></tr>
  431. <tr>
  432. <td>M239 </td><td>ERROR</td><td>Dimed <em>'LEVEL'</em> <em>'NAME'</em> must have an expression.</td><td>Correct SVD. </td></tr>
  433. <tr>
  434. <td>M240 </td><td>ERROR</td><td>Tag &lt;<em>'TAG'&gt;</em> unknown or not allowed on <em>'LEVEL2'</em>:<em>'LEVEL'</em>.</td><td>Correct SVD. </td></tr>
  435. <tr>
  436. <td>M241 </td><td>ERROR</td><td>Parse Error: <em>'VALUE'</em> invalid for Array generation</td><td>Correct SVD. </td></tr>
  437. <tr>
  438. <td>M242 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> &lt;dimArrayIndex&gt; found, but no &lt;dim&gt;</td><td>Correct SVD. </td></tr>
  439. <tr>
  440. <td>M243 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> &lt;dimArrayIndex&gt; found, but &lt;dim&gt; does not describe an array</td><td>Correct SVD. </td></tr>
  441. </table>
  442. <h2>Data Check Errors </h2>
  443. <table class="cmtable" summary="Data Check Errors">
  444. <tr>
  445. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Action </th></tr>
  446. <tr>
  447. <td>M301 </td><td>ERROR</td><td>Interrupt number <em>'NUM'</em> : <em>'NAME'</em> already defined: <em>'NAME2'</em> <em>'LINE'</em> </td><td></td></tr>
  448. <tr>
  449. <td>M302 </td><td>ERROR</td><td>Size of Register <em>'NAME'</em>:<em>'NUM'</em> must be 8, 16 or 32 Bits</td><td></td></tr>
  450. <tr>
  451. <td>M303 </td><td>WARNING</td><td>Register name <em>'NAME'</em> is prefixed with Peripheral name <em>'NAME2'</em> </td><td>RegName = USART_CR ==&gt; USART-&gt;USART_CR </td></tr>
  452. <tr>
  453. <td>M304 </td><td>WARNING</td><td>Interrupt number overwrite: <em>'NUM'</em> : <em>'NAME'</em> <em>'LINE'</em> </td><td></td></tr>
  454. <tr>
  455. <td>M305 </td><td>ERROR</td><td>Name not C compliant: <em>'NAME'</em> : <em>'HEX'</em>, replaced by '_'</td><td></td></tr>
  456. <tr>
  457. <td>M306 </td><td>ERROR</td><td>Schema Version not set for &lt;device&gt;.</td><td></td></tr>
  458. <tr>
  459. <td>M307 </td><td>ERROR</td><td>Name is equal to Value: <em>'NAME'</em> </td><td></td></tr>
  460. <tr>
  461. <td>M308 </td><td>ERROR</td><td>Number of &lt;dimIndex&gt; Elements <em>'NUM'</em> is different to number of &lt;dim&gt; instances <em>'NUM2'</em> </td><td></td></tr>
  462. <tr>
  463. <td>M309 </td><td>ERROR</td><td>Field <em>'NAME'</em>: Offset error: <em>'NUM'</em> </td><td></td></tr>
  464. <tr>
  465. <td>M310 </td><td>ERROR</td><td>Field <em>'NAME'</em>: BitWidth error: <em>'NUM'</em> </td><td></td></tr>
  466. <tr>
  467. <td>M311 </td><td>ERROR</td><td>Field <em>'NAME'</em>: Calculation: MSB or LSB == -1</td><td></td></tr>
  468. <tr>
  469. <td>M312 </td><td>ERROR</td><td>Address Block missing for Peripheral <em>'NAME'</em> </td><td></td></tr>
  470. <tr>
  471. <td>M313 </td><td>ERROR</td><td>Field <em>'NAME'</em>: LSB &gt; MSB: BitWith calculates to <em>'NUM'</em> </td><td></td></tr>
  472. <tr>
  473. <td>M314 </td><td>ERROR</td><td>Address Block: &lt;offset&gt; or &lt;size&gt; not set.</td><td></td></tr>
  474. <tr>
  475. <td>M315 </td><td>ERROR</td><td>Address Block: &lt;size&gt; is zero.</td><td></td></tr>
  476. <tr>
  477. <td>M316 </td><td>ERROR</td><td><em>'LEVEL'</em> &lt;name&gt; not set.</td><td></td></tr>
  478. <tr>
  479. <td>M317 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;description&gt; not set.</td><td></td></tr>
  480. <tr>
  481. <td>M318 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> &lt;<em>'TAG'&gt;</em> is equal to &lt;name&gt;</td><td></td></tr>
  482. <tr>
  483. <td>M319 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;<em>'TAG'&gt;</em> <em>'NAME'</em> ends with newline, is this intended?</td><td></td></tr>
  484. <tr>
  485. <td>M320 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;description&gt; <em>'NAME'</em> is not very descriptive</td><td></td></tr>
  486. <tr>
  487. <td>M321 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;<em>'ITEM'&gt;</em> <em>'NAME'</em> starts with '_', is this intended?</td><td></td></tr>
  488. <tr>
  489. <td>M322 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'ITEM'</em> <em>'NAME'</em> is meaningless text. Deleted.</td><td></td></tr>
  490. <tr>
  491. <td>M323 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;<em>'ITEM'&gt;</em> <em>'NAME'</em> contains text <em>'TEXT'</em> </td><td></td></tr>
  492. <tr>
  493. <td>M324 </td><td>ERROR</td><td>Field <em>'NAME'</em> <em>'BITRANGE'</em> does not fit into Register <em>'NAME2'</em>:<em>'NUM'</em> <em>'LINE'</em> </td><td></td></tr>
  494. <tr>
  495. <td>M325 </td><td>ERROR</td><td>CPU Revision is not set"</td><td></td></tr>
  496. <tr>
  497. <td>M326 </td><td>ERROR</td><td>Endianess is not set, using default (little)</td><td></td></tr>
  498. <tr>
  499. <td>M327 </td><td>ERROR</td><td>NVIC Prio Bits not set or wrong value, must be 2..8. Using default (4)</td><td></td></tr>
  500. <tr>
  501. <td>M328 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> has no Registers, ignoring <em>'LEVEL'</em>.</td><td></td></tr>
  502. <tr>
  503. <td>M329 </td><td>ERROR</td><td>CPU Type is not set, using default (Cortex-M3)</td><td></td></tr>
  504. <tr>
  505. <td>M330 </td><td>ERROR</td><td>Interrupt <em>'NAME'</em> Number not set.</td><td></td></tr>
  506. <tr>
  507. <td>M331 </td><td>ERROR</td><td>Interrupt <em>'NAME'</em> Number <em>'NUM'</em> greater 239.</td><td></td></tr>
  508. <tr>
  509. <td>M332 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> has only one Register.</td><td></td></tr>
  510. <tr>
  511. <td>M333 </td><td>ERROR</td><td>Duplicate &lt;enumeratedValue&gt; <em>'NUM'</em>: <em>'NAME'</em> (<em>'USAGE'</em>), already used by <em>'NAME2'</em> (<em>'USAGE2'</em>) <em>'LINE'</em> </td><td></td></tr>
  512. <tr>
  513. <td>M334 </td><td>WARNING</td><td><em>'LEVEL'</em> &lt;<em>'ITEM'&gt;</em> <em>'NAME'</em> is very long, use &lt;description&gt; and a shorter &lt;name&gt;</td><td></td></tr>
  514. <tr>
  515. <td>M335 </td><td>ERROR</td><td>Value <em>'NAME'</em>:<em>'NUM'</em> does not fit into field <em>'NAME2'</em> <em>'BITRANGE'</em>.</td><td></td></tr>
  516. <tr>
  517. <td>M336 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> already defined <em>'LINE'</em> </td><td></td></tr>
  518. <tr>
  519. <td>M337 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> already defined <em>'LINE'</em> </td><td></td></tr>
  520. <tr>
  521. <td>M338 </td><td>ERROR</td><td>Field <em>'NAME'</em> <em>'BITRANGE'</em> (<em>'ACCESS'</em>) overlaps <em>'NAME2'</em> <em>'BITRANGE2'</em> (<em>'ACCESS2'</em>) <em>'LINE'</em> </td><td></td></tr>
  522. <tr>
  523. <td>M339 </td><td>ERROR</td><td>Register <em>'NAME'</em> (<em>'ACCESS'</em>) (@<em>'ADDRSIZE'</em>) has same address or overlaps <em>'NAME2'</em> (<em>'ACCESS2'</em>) (@<em>'ADDRSIZE2'</em>) <em>'LINE'</em> </td><td></td></tr>
  524. <tr>
  525. <td>M340 </td><td>ERROR</td><td>No Devices found.</td><td></td></tr>
  526. <tr>
  527. <td>M341 </td><td>ERROR</td><td>More than one devices found, only one is allowed per SVD File.</td><td></td></tr>
  528. <tr>
  529. <td>M342 </td><td>ERROR</td><td>Dim-extended <em>'LEVEL'</em> <em>'NAME'</em> must not have &lt;headerStructName&gt;</td><td></td></tr>
  530. <tr>
  531. <td>M343 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> (@<em>'ADDR'</em>) has same address as <em>'NAME2'</em> <em>'LINE'</em> </td><td></td></tr>
  532. <tr>
  533. <td>M344 </td><td>ERROR</td><td>Register <em>'NAME'</em> (@<em>'ADDRSIZE'</em>) is outside or does not fit any &lt;addressBlock&gt; specified for Peripheral <em>'NAME2'</em> <br/>
  534. <em>'TEXT'</em> </td><td></td></tr>
  535. <tr>
  536. <td>M345 </td><td>ERROR</td><td>Field <em>'NAME'</em> <em>'BITRANGE'</em> does not fit into Register <em>'NAME2'</em>:<em>'NUM'</em> </td><td></td></tr>
  537. <tr>
  538. <td>M346 </td><td>WARNING</td><td>Register <em>'NAME'</em> (@<em>'ADDR'</em>) offset is equal or is greater than it's Peripheral base address <em>'NAME2'</em> (@<em>'ADDR2'</em>), is this intended?</td><td></td></tr>
  539. <tr>
  540. <td>M347 </td><td>WARNING</td><td>Field <em>'NAME'</em> (width &lt; 6Bit) without any &lt;enumeratedValue&gt; found.</td><td></td></tr>
  541. <tr>
  542. <td>M348 </td><td>ERROR</td><td>Alternate <em>'LEVEL'</em> <em>'NAME'</em> does not exist at <em>'LEVEL'</em> address (@<em>'ADDR'</em>)</td><td></td></tr>
  543. <tr>
  544. <td>M349 </td><td>ERROR</td><td>Alternate <em>'LEVEL'</em> <em>'NAME'</em> is equal to <em>'LEVEL'</em> name <em>'NAME2'</em> </td><td></td></tr>
  545. <tr>
  546. <td>M350 </td><td>WARNING</td><td>Peripheral <em>'NAME'</em> (@<em>'ADDR'</em>) is not 4Byte-aligned.</td><td></td></tr>
  547. <tr>
  548. <td>M351 </td><td>WARNING</td><td>Peripheral <em>'TYPE'</em> <em>'NAME'</em> is equal to Peripheral name.</td><td></td></tr>
  549. <tr>
  550. <td>M352 </td><td>WARNING</td><td>AddressBlock of Peripheral <em>'NAME'</em> (@<em>'ADDR'</em>) <em>'TEXT'</em> overlaps <em>'NAME2'</em> (@<em>'ADDR2'</em>) <em>'TEXT2'</em> <em>'LINE'</em> </td><td></td></tr>
  551. <tr>
  552. <td>M353 </td><td>WARNING</td><td>Peripheral group name <em>'NAME'</em> should not end with '_'</td><td></td></tr>
  553. <tr>
  554. <td>M354 </td><td>ERROR</td><td>Interrupt '<em>'NUM'</em>:<em>'NAME'</em> specifies a Core Interrupt. Core Interrupts must not be defined, they are set through &lt;cpu&gt;&lt;name&gt;.</td><td></td></tr>
  555. <tr>
  556. <td>M355 </td><td>ERROR</td><td>No Interrupts found on pos. 0..15. External (Vendor-)Interrupts possibly defined on position 16+. External Interrupts must start on position 0</td><td></td></tr>
  557. <tr>
  558. <td>M356 </td><td>WARNING</td><td>No Interrupt definitions found.</td><td></td></tr>
  559. <tr>
  560. <td>M357 </td><td>ERROR</td><td>Core Interrupts found. Interrupt Numbers are wrong. Internal Interrupts must not be described, External Interrupts must start at 0.</td><td></td></tr>
  561. <tr>
  562. <td>M358 </td><td>ERROR</td><td>AddressBlock of Peripheral <em>'NAME'</em> <em>'TEXT'</em> overlaps AddressBlock <em>'TEXT2'</em> in same peripheral <em>'LINE'</em> </td><td></td></tr>
  563. <tr>
  564. <td>M359 </td><td>ERROR</td><td>Address Block: &lt;usage&gt; not set.</td><td></td></tr>
  565. <tr>
  566. <td>M360 </td><td>ERROR</td><td>Address Block: found &lt;<em>'TAG'&gt;</em> (<em>'HEXNUM'</em>) &gt; <em>'HEXNUM2'</em>.</td><td></td></tr>
  567. <tr>
  568. <td>M361 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'ITEM'</em> <em>'NAME'</em>: 'RESERVED' items must not be defined.</td><td></td></tr>
  569. <tr>
  570. <td>M362 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'ITEM'</em> <em>'NAME'</em>: 'RESERVED' items must not be defined.</td><td></td></tr>
  571. <tr>
  572. <td>M363 </td><td>ERROR</td><td>CPU: &lt;sauNumRegions&gt; not set.</td><td></td></tr>
  573. <tr>
  574. <td>M364 </td><td>ERROR</td><td>CPU: &lt;sauNumRegions&gt; value <em>'NUM'</em> greater than SAU max num (<em>'NUM2'</em>)</td><td></td></tr>
  575. <tr>
  576. <td>M365 </td><td>WARNING</td><td>Register <em>'NAME'</em> (<em>'ACCESS'</em>) (@<em>'ADDRSIZE'</em>) has same address or overlaps <em>'NAME2'</em> (<em>'ACCESS2'</em>) (@<em>'ADDRSIZE2'</em>) <em>'LINE'</em> </td><td></td></tr>
  577. <tr>
  578. <td>M366 </td><td>ERROR</td><td>Register <em>'NAME'</em> size (<em>'NUM'Bit</em>) is greater than &lt;dimIncrement&gt; * &lt;addressBitsUnits&gt; (<em>'NUM2'Bit</em>).</td><td></td></tr>
  579. <tr>
  580. <td>M367 </td><td>WARNING</td><td>Access Type: Field <em>'NAME'</em> (<em>'ACCESS'</em>) does not match Register <em>'NAME2'</em> (<em>'ACCESS2'</em>)</td><td></td></tr>
  581. <tr>
  582. <td>M368 </td><td>WARNING</td><td><em>'LEVEL'</em> <em>'NAME'</em> (@<em>'ADDR'</em>) has same address as <em>'NAME2'</em> <em>'LINE'</em> </td><td></td></tr>
  583. <tr>
  584. <td>M369 </td><td>ERROR</td><td>Enumerated Value <em>'NAME'</em>: &lt;value&gt; not set.</td><td></td></tr>
  585. <tr>
  586. <td>M370 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em>: &lt;offset&gt; not set.</td><td></td></tr>
  587. <tr>
  588. <td>M371 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> &lt;headerStructName&gt; is equal to hirachical name</td><td></td></tr>
  589. <tr>
  590. <td>M372 </td><td>ERROR</td><td><em>'LEVEL'</em> &lt;<em>'TAG'&gt;</em> <em>'NAME'</em> already defined <em>'LINE'</em> </td><td></td></tr>
  591. <tr>
  592. <td>M373 </td><td>ERROR</td><td><em>'LEVEL'</em> &lt;<em>'TAG'&gt;</em> <em>'NAME'</em> already defined <em>'LINE'</em> </td><td></td></tr>
  593. <tr>
  594. <td>M374 </td><td>WARNING</td><td>&lt;enumeratedValues&gt; can be one &lt;enumeratedValues&gt; container for all &lt;enumeratedValue&gt;s, where &lt;usage&gt; can be read, write, or read-write or two &lt;enumeratedValues&gt; containers, where one is set to &lt;usage&gt; read and the other is set to &lt;usage&gt; write</td><td></td></tr>
  595. <tr>
  596. <td>M375 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> (&lt;enumeratedValues&gt; <em>'NAME2'</em>): Too many &lt;enumeratedValues&gt; container specified.</td><td></td></tr>
  597. <tr>
  598. <td>M376 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> (&lt;enumeratedValues&gt; <em>'NAME2'</em>): <em>'USAGE'</em> container already defined in <em>'LINE'</em>.</td><td></td></tr>
  599. <tr>
  600. <td>M377 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em> (&lt;enumeratedValues&gt; <em>'NAME2'</em>): <em>'USAGE'</em> container conflicts with <em>'NAME3'</em> <em>'LINE'</em>.</td><td></td></tr>
  601. <tr>
  602. <td>M378 </td><td>ERROR</td><td>Register Array: Register <em>'NAME'</em> size (<em>'NUM'Bit</em>) does not match &lt;dimIncrement&gt; (<em>'NUM2'Bit</em>).</td><td></td></tr>
  603. <tr>
  604. <td>M379 </td><td>ERROR</td><td>XBin Number <em>'NAME'</em> too large, skipping evaluation.</td><td></td></tr>
  605. <tr>
  606. <td>M380 </td><td>ERROR</td><td>AddressBlock of Peripheral <em>'NAME'</em> (@<em>'ADDR'</em>) <em>'TEXT'</em> does not fit into 32Bit Address Space.</td><td></td></tr>
  607. <tr>
  608. <td>M381 </td><td>ERROR</td><td>Interrupt <em>'NAME'</em> Number <em>'NUM'</em> greater or equal deviceNumInterrupts (<em>'NUM2'</em>).</td><td></td></tr>
  609. <tr>
  610. <td>M382 </td><td>ERROR</td><td><em>'LEVEL'</em> <em>'NAME'</em>: <em>'NAME2'</em> <em>'HEXNUM'</em> does not fit into <em>'LEVEL'</em> width: <em>'NUM'</em> Bit.</td><td></td></tr>
  611. </table>
  612. <h2>Data modification errors </h2>
  613. <table class="cmtable" summary="SfrCC2 related Data modification Errors">
  614. <tr>
  615. <th>Message Number </th><th>Type </th><th>Message Text </th><th>Action </th></tr>
  616. <tr>
  617. <td>M517 </td><td>WARNING</td><td>SFD Code generation: Forbidden Trigraph '??CHAR' found in <em>'NAME'</em>.</td><td></td></tr>
  618. <tr>
  619. <td>M516 </td><td>WARNING</td><td>SFD Code generation: Unsupported character found in <em>'NAME'</em> : <em>'HEX'</em>.</td><td></td></tr>
  620. <tr>
  621. <td>M518 </td><td>WARNING</td><td>SFD Code generation: Unsupported ESC sequence found in <em>'NAME'</em> : <em>'CHAR'</em>.</td><td></td></tr>
  622. </table>
  623. </div></div><!-- contents -->
  624. </div><!-- doc-content -->
  625. <!-- start footer part -->
  626. <div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
  627. <ul>
  628. <li class="footer">Generated on Thu Apr 9 2020 15:50:02 for CMSIS-SVD Version 1.3.6 by Arm Ltd. All rights reserved.
  629. <!--
  630. <a href="http://www.doxygen.org/index.html">
  631. <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.6
  632. -->
  633. </li>
  634. </ul>
  635. </div>
  636. </body>
  637. </html>