CMSIS-SVD_Schema_1_0.xsd 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!--
  3. @date: 29.07.2011
  4. @note Copyright (C) 2011 ARM Limited. All rights reserved.
  5. @par
  6. ARM Limited (ARM) is supplying this software for use with Cortex-M
  7. processor based microcontroller, but can be equally used for other
  8. suitable processor architectures. This file can be freely distributed.
  9. Modifications to this file shall be clearly marked.
  10. @par
  11. THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED
  12. OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
  13. MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
  14. ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
  15. CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
  16. -->
  17. <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified" attributeFormDefault="qualified" version="1.0">
  18. <xs:simpleType name="registerNameType">
  19. <xs:restriction base="xs:string">
  20. <xs:pattern value="([_A-Za-z]{1}[_A-Za-z0-9]*(\[%s\])?)|([_A-Za-z]{1}[_A-Za-z0-9]*(%s)?[_A-Za-z0-9]*)"/>
  21. </xs:restriction>
  22. </xs:simpleType>
  23. <xs:simpleType name="dimIndexType">
  24. <xs:restriction base="xs:string">
  25. <xs:pattern value="[0-9]+\-[0-9]+|[A-Z]-[A-Z]|[_0-9a-zA-Z]+(,\s*[_0-9a-zA-Z]+)+"/>
  26. </xs:restriction>
  27. </xs:simpleType>
  28. <xs:simpleType name="scaledNonNegativeInteger">
  29. <xs:restriction base="xs:string">
  30. <xs:pattern value="[+]?(0x|0X|#)?[0-9a-fA-F]+[kmgtKMGT]?"/>
  31. </xs:restriction>
  32. </xs:simpleType>
  33. <xs:simpleType name="enumeratedValueDataType">
  34. <xs:restriction base="xs:string">
  35. <xs:pattern value="[+]?(0x|0X|#)?[0-9a-fxA-FX]+"/>
  36. </xs:restriction>
  37. </xs:simpleType>
  38. <xs:simpleType name="accessType">
  39. <xs:restriction base="xs:token">
  40. <xs:enumeration value="read-only"/>
  41. <xs:enumeration value="write-only"/>
  42. <xs:enumeration value="read-write"/>
  43. <xs:enumeration value="writeOnce"/>
  44. <xs:enumeration value="read-writeOnce"/>
  45. </xs:restriction>
  46. </xs:simpleType>
  47. <xs:simpleType name="modifiedWriteValuesType">
  48. <xs:restriction base="xs:token">
  49. <xs:enumeration value="oneToClear"/>
  50. <xs:enumeration value="oneToSet"/>
  51. <xs:enumeration value="oneToToggle"/>
  52. <xs:enumeration value="zeroToClear"/>
  53. <xs:enumeration value="zeroToSet"/>
  54. <xs:enumeration value="zeroToToggle"/>
  55. <xs:enumeration value="clear"/>
  56. <xs:enumeration value="set"/>
  57. <xs:enumeration value="modify"/>
  58. </xs:restriction>
  59. </xs:simpleType>
  60. <xs:simpleType name="readActionType">
  61. <xs:restriction base="xs:token">
  62. <xs:enumeration value="clear"/>
  63. <xs:enumeration value="set"/>
  64. <xs:enumeration value="modify"/>
  65. <xs:enumeration value="modifyExternal"/>
  66. </xs:restriction>
  67. </xs:simpleType>
  68. <xs:simpleType name="enumUsageType">
  69. <xs:restriction base="xs:token">
  70. <xs:enumeration value="read"/>
  71. <xs:enumeration value="write"/>
  72. <xs:enumeration value="read-write"/>
  73. </xs:restriction>
  74. </xs:simpleType>
  75. <xs:simpleType name="bitRangeType">
  76. <xs:restriction base="xs:token">
  77. <xs:pattern value="\[([0-3])?[0-9]:([0-3])?[0-9]\]"/>
  78. </xs:restriction>
  79. </xs:simpleType>
  80. <xs:complexType name="writeConstraintType">
  81. <xs:choice>
  82. <xs:element name="writeAsRead" type="xs:boolean"/>
  83. <xs:element name="useEnumeratedValues" type="xs:boolean"/>
  84. <xs:element name="range">
  85. <xs:complexType>
  86. <xs:sequence>
  87. <xs:element name="minimum" type="scaledNonNegativeInteger"/>
  88. <xs:element name="maximum" type="scaledNonNegativeInteger"/>
  89. </xs:sequence>
  90. </xs:complexType>
  91. </xs:element>
  92. </xs:choice>
  93. </xs:complexType>
  94. <xs:complexType name="addressBlockType">
  95. <xs:sequence>
  96. <xs:element name="offset" type="scaledNonNegativeInteger"/>
  97. <xs:element name="size" type="scaledNonNegativeInteger"/>
  98. <xs:element name="usage">
  99. <xs:simpleType>
  100. <xs:restriction base="xs:token">
  101. <xs:enumeration value="registers"/>
  102. <xs:enumeration value="buffer"/>
  103. <xs:enumeration value="reserved"/>
  104. </xs:restriction>
  105. </xs:simpleType>
  106. </xs:element>
  107. </xs:sequence>
  108. </xs:complexType>
  109. <xs:complexType name="interruptType">
  110. <xs:sequence>
  111. <xs:element name="name" type="xs:string"/>
  112. <xs:element name="value" type="xs:integer"/>
  113. </xs:sequence>
  114. </xs:complexType>
  115. <xs:group name="registerPropertiesGroup">
  116. <xs:sequence>
  117. <xs:element name="size" type="scaledNonNegativeInteger" minOccurs="0"/>
  118. <xs:element name="access" type="accessType" minOccurs="0"/>
  119. <xs:element name="resetValue" type="scaledNonNegativeInteger" minOccurs="0"/>
  120. <xs:element name="resetMask" type="scaledNonNegativeInteger" minOccurs="0"/>
  121. </xs:sequence>
  122. </xs:group>
  123. <xs:group name="bitRangeLsbMsbStyle">
  124. <xs:sequence>
  125. <xs:element name="lsb" type="scaledNonNegativeInteger"/>
  126. <xs:element name="msb" type="scaledNonNegativeInteger"/>
  127. </xs:sequence>
  128. </xs:group>
  129. <xs:group name="bitRangeOffsetWidthStyle">
  130. <xs:sequence>
  131. <xs:element name="bitOffset" type="scaledNonNegativeInteger"/>
  132. <xs:element name="bitWidth" type="scaledNonNegativeInteger" minOccurs="0"/>
  133. </xs:sequence>
  134. </xs:group>
  135. <xs:group name="dimElementGroup">
  136. <xs:sequence>
  137. <xs:element name="dim" type="scaledNonNegativeInteger"/>
  138. <xs:element name="dimIncrement" type="scaledNonNegativeInteger"/>
  139. <xs:element name="dimIndex" type="dimIndexType" minOccurs="0"/>
  140. </xs:sequence>
  141. </xs:group>
  142. <xs:element name="device" nillable="true">
  143. <xs:complexType>
  144. <xs:sequence>
  145. <xs:element name="name" type="xs:string"/>
  146. <xs:element name="version" type="xs:string"/>
  147. <xs:element name="description" type="xs:string"/>
  148. <xs:element name="addressUnitBits" type="scaledNonNegativeInteger"/>
  149. <xs:element name="width" type="scaledNonNegativeInteger"/>
  150. <xs:group ref="registerPropertiesGroup" minOccurs="0"/>
  151. <xs:element name="peripherals">
  152. <xs:complexType>
  153. <xs:sequence>
  154. <xs:element name="peripheral" minOccurs="1" maxOccurs="unbounded">
  155. <xs:complexType>
  156. <xs:sequence>
  157. <xs:element name="name" type="xs:Name"/>
  158. <xs:element name="version" type="xs:string" minOccurs="0"/>
  159. <xs:element name="description" type="xs:string" minOccurs="0"/>
  160. <xs:element name="groupName" type="xs:string" minOccurs="0"/>
  161. <xs:element name="prependToName" type="xs:string" minOccurs="0"/>
  162. <xs:element name="appendToName" type="xs:string" minOccurs="0"/>
  163. <xs:element name="disableCondition" type="xs:string" minOccurs="0"/>
  164. <xs:element name="baseAddress" type="scaledNonNegativeInteger"/>
  165. <xs:group ref="registerPropertiesGroup" minOccurs="0"/>
  166. <xs:element name="addressBlock" type="addressBlockType" minOccurs="0" maxOccurs="unbounded"/>
  167. <xs:element name="interrupt" type="interruptType" minOccurs="0" maxOccurs="unbounded"/>
  168. <xs:element name="registers" minOccurs="0" maxOccurs="1">
  169. <xs:complexType>
  170. <xs:sequence>
  171. <xs:element name="register" minOccurs="1" maxOccurs="unbounded">
  172. <xs:complexType>
  173. <xs:sequence>
  174. <xs:group ref="dimElementGroup" minOccurs="0"/>
  175. <xs:element name="name" type="registerNameType"/> <!-- was xs:Name -->
  176. <xs:element name="displayName" type="xs:string" minOccurs="0"/>
  177. <xs:element name="description" type="xs:string" minOccurs="0"/>
  178. <xs:element name="alternateGroup" type="xs:Name" minOccurs="0"/>
  179. <xs:element name="addressOffset" type="scaledNonNegativeInteger"/>
  180. <xs:group ref="registerPropertiesGroup" minOccurs="0"/>
  181. <xs:element name="modifiedWriteValues" type="modifiedWriteValuesType" minOccurs="0"/>
  182. <xs:element name="writeConstraint" type="writeConstraintType" minOccurs="0"/>
  183. <xs:element name="readAction" type="readActionType" minOccurs="0"/>
  184. <xs:element name="fields" minOccurs="0" maxOccurs="1">
  185. <xs:complexType>
  186. <xs:sequence>
  187. <xs:element name="field" minOccurs="1" maxOccurs="unbounded">
  188. <xs:complexType>
  189. <xs:sequence>
  190. <xs:element name="name" type="xs:string"/>
  191. <xs:element name="description" type="xs:string" minOccurs="0"/>
  192. <xs:choice>
  193. <xs:group ref="bitRangeLsbMsbStyle" minOccurs="0"/>
  194. <xs:group ref="bitRangeOffsetWidthStyle" minOccurs="0"/>
  195. <xs:element name="bitRange" type="bitRangeType" minOccurs="0"/>
  196. </xs:choice>
  197. <xs:element name="access" type="accessType" minOccurs="0"/>
  198. <xs:element name="modifiedWriteValues" type="modifiedWriteValuesType" minOccurs="0"/>
  199. <xs:element name="writeConstraint" type="writeConstraintType" minOccurs="0"/>
  200. <xs:element name="readAction" type="readActionType" minOccurs="0"/>
  201. <xs:element name="enumeratedValues" minOccurs="0" maxOccurs="2">
  202. <xs:complexType>
  203. <xs:sequence>
  204. <xs:element name="name" type="xs:Name" minOccurs="0"/>
  205. <xs:element name="usage" type="enumUsageType" minOccurs="0"/>
  206. <xs:element name="enumeratedValue" minOccurs="1" maxOccurs="unbounded">
  207. <xs:complexType>
  208. <xs:sequence>
  209. <xs:element name="name" type="xs:string"/>
  210. <xs:element name="description" type="xs:string" minOccurs="0"/>
  211. <xs:choice>
  212. <xs:element name="value" type="enumeratedValueDataType"/>
  213. <xs:element name="isDefault" type="xs:boolean"/>
  214. </xs:choice>
  215. </xs:sequence>
  216. </xs:complexType>
  217. </xs:element>
  218. </xs:sequence>
  219. <xs:attribute name="derivedFrom" type="xs:Name" use="optional"/>
  220. </xs:complexType>
  221. </xs:element>
  222. </xs:sequence>
  223. <xs:attribute name="derivedFrom" type="xs:Name" use="optional"/>
  224. </xs:complexType>
  225. </xs:element>
  226. </xs:sequence>
  227. </xs:complexType>
  228. </xs:element>
  229. </xs:sequence>
  230. <xs:attribute name="derivedFrom" type="xs:Name" use="optional"/>
  231. </xs:complexType>
  232. </xs:element>
  233. </xs:sequence>
  234. </xs:complexType>
  235. </xs:element>
  236. </xs:sequence>
  237. <xs:attribute name="derivedFrom" type="xs:Name" use="optional"/>
  238. </xs:complexType>
  239. </xs:element>
  240. </xs:sequence>
  241. </xs:complexType>
  242. </xs:element>
  243. <xs:element name="vendorExtensions" minOccurs="0" maxOccurs="1">
  244. <xs:complexType>
  245. <xs:sequence>
  246. <xs:any namespace="##any" processContents="lax" minOccurs="0" maxOccurs="unbounded">
  247. </xs:any>
  248. </xs:sequence>
  249. </xs:complexType>
  250. </xs:element>
  251. </xs:sequence>
  252. <xs:attribute name="schemaVersion" type="xs:decimal" use="required" fixed="1.0"/>
  253. </xs:complexType>
  254. </xs:element>
  255. </xs:schema>