samd21e18a.h 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644
  1. /**
  2. * \file
  3. *
  4. * \brief Peripheral I/O description for SAMD21E18A
  5. *
  6. * Copyright (c) 2014-2015 Atmel Corporation. All rights reserved.
  7. *
  8. * \asf_license_start
  9. *
  10. * \page License
  11. *
  12. * Redistribution and use in source and binary forms, with or without
  13. * modification, are permitted provided that the following conditions are met:
  14. *
  15. * 1. Redistributions of source code must retain the above copyright notice,
  16. * this list of conditions and the following disclaimer.
  17. *
  18. * 2. Redistributions in binary form must reproduce the above copyright notice,
  19. * this list of conditions and the following disclaimer in the documentation
  20. * and/or other materials provided with the distribution.
  21. *
  22. * 3. The name of Atmel may not be used to endorse or promote products derived
  23. * from this software without specific prior written permission.
  24. *
  25. * 4. This software may only be redistributed and used in connection with an
  26. * Atmel microcontroller product.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
  29. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  30. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
  31. * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR
  32. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  33. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  34. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  35. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  36. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  37. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  38. * POSSIBILITY OF SUCH DAMAGE.
  39. *
  40. * \asf_license_stop
  41. *
  42. */
  43. /*
  44. * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
  45. */
  46. #ifndef _SAMD21E18A_PIO_
  47. #define _SAMD21E18A_PIO_
  48. #define PIN_PA00 0 /**< \brief Pin Number for PA00 */
  49. #define PORT_PA00 (1ul << 0) /**< \brief PORT Mask for PA00 */
  50. #define PIN_PA01 1 /**< \brief Pin Number for PA01 */
  51. #define PORT_PA01 (1ul << 1) /**< \brief PORT Mask for PA01 */
  52. #define PIN_PA02 2 /**< \brief Pin Number for PA02 */
  53. #define PORT_PA02 (1ul << 2) /**< \brief PORT Mask for PA02 */
  54. #define PIN_PA03 3 /**< \brief Pin Number for PA03 */
  55. #define PORT_PA03 (1ul << 3) /**< \brief PORT Mask for PA03 */
  56. #define PIN_PA04 4 /**< \brief Pin Number for PA04 */
  57. #define PORT_PA04 (1ul << 4) /**< \brief PORT Mask for PA04 */
  58. #define PIN_PA05 5 /**< \brief Pin Number for PA05 */
  59. #define PORT_PA05 (1ul << 5) /**< \brief PORT Mask for PA05 */
  60. #define PIN_PA06 6 /**< \brief Pin Number for PA06 */
  61. #define PORT_PA06 (1ul << 6) /**< \brief PORT Mask for PA06 */
  62. #define PIN_PA07 7 /**< \brief Pin Number for PA07 */
  63. #define PORT_PA07 (1ul << 7) /**< \brief PORT Mask for PA07 */
  64. #define PIN_PA08 8 /**< \brief Pin Number for PA08 */
  65. #define PORT_PA08 (1ul << 8) /**< \brief PORT Mask for PA08 */
  66. #define PIN_PA09 9 /**< \brief Pin Number for PA09 */
  67. #define PORT_PA09 (1ul << 9) /**< \brief PORT Mask for PA09 */
  68. #define PIN_PA10 10 /**< \brief Pin Number for PA10 */
  69. #define PORT_PA10 (1ul << 10) /**< \brief PORT Mask for PA10 */
  70. #define PIN_PA11 11 /**< \brief Pin Number for PA11 */
  71. #define PORT_PA11 (1ul << 11) /**< \brief PORT Mask for PA11 */
  72. #define PIN_PA14 14 /**< \brief Pin Number for PA14 */
  73. #define PORT_PA14 (1ul << 14) /**< \brief PORT Mask for PA14 */
  74. #define PIN_PA15 15 /**< \brief Pin Number for PA15 */
  75. #define PORT_PA15 (1ul << 15) /**< \brief PORT Mask for PA15 */
  76. #define PIN_PA16 16 /**< \brief Pin Number for PA16 */
  77. #define PORT_PA16 (1ul << 16) /**< \brief PORT Mask for PA16 */
  78. #define PIN_PA17 17 /**< \brief Pin Number for PA17 */
  79. #define PORT_PA17 (1ul << 17) /**< \brief PORT Mask for PA17 */
  80. #define PIN_PA18 18 /**< \brief Pin Number for PA18 */
  81. #define PORT_PA18 (1ul << 18) /**< \brief PORT Mask for PA18 */
  82. #define PIN_PA19 19 /**< \brief Pin Number for PA19 */
  83. #define PORT_PA19 (1ul << 19) /**< \brief PORT Mask for PA19 */
  84. #define PIN_PA22 22 /**< \brief Pin Number for PA22 */
  85. #define PORT_PA22 (1ul << 22) /**< \brief PORT Mask for PA22 */
  86. #define PIN_PA23 23 /**< \brief Pin Number for PA23 */
  87. #define PORT_PA23 (1ul << 23) /**< \brief PORT Mask for PA23 */
  88. #define PIN_PA24 24 /**< \brief Pin Number for PA24 */
  89. #define PORT_PA24 (1ul << 24) /**< \brief PORT Mask for PA24 */
  90. #define PIN_PA25 25 /**< \brief Pin Number for PA25 */
  91. #define PORT_PA25 (1ul << 25) /**< \brief PORT Mask for PA25 */
  92. #define PIN_PA27 27 /**< \brief Pin Number for PA27 */
  93. #define PORT_PA27 (1ul << 27) /**< \brief PORT Mask for PA27 */
  94. #define PIN_PA28 28 /**< \brief Pin Number for PA28 */
  95. #define PORT_PA28 (1ul << 28) /**< \brief PORT Mask for PA28 */
  96. #define PIN_PA30 30 /**< \brief Pin Number for PA30 */
  97. #define PORT_PA30 (1ul << 30) /**< \brief PORT Mask for PA30 */
  98. #define PIN_PA31 31 /**< \brief Pin Number for PA31 */
  99. #define PORT_PA31 (1ul << 31) /**< \brief PORT Mask for PA31 */
  100. /* ========== PORT definition for GCLK peripheral ========== */
  101. #define PIN_PA14H_GCLK_IO0 14L /**< \brief GCLK signal: IO0 on PA14 mux H */
  102. #define MUX_PA14H_GCLK_IO0 7L
  103. #define PINMUX_PA14H_GCLK_IO0 ((PIN_PA14H_GCLK_IO0 << 16) | MUX_PA14H_GCLK_IO0)
  104. #define PORT_PA14H_GCLK_IO0 (1ul << 14)
  105. #define PIN_PA27H_GCLK_IO0 27L /**< \brief GCLK signal: IO0 on PA27 mux H */
  106. #define MUX_PA27H_GCLK_IO0 7L
  107. #define PINMUX_PA27H_GCLK_IO0 ((PIN_PA27H_GCLK_IO0 << 16) | MUX_PA27H_GCLK_IO0)
  108. #define PORT_PA27H_GCLK_IO0 (1ul << 27)
  109. #define PIN_PA28H_GCLK_IO0 28L /**< \brief GCLK signal: IO0 on PA28 mux H */
  110. #define MUX_PA28H_GCLK_IO0 7L
  111. #define PINMUX_PA28H_GCLK_IO0 ((PIN_PA28H_GCLK_IO0 << 16) | MUX_PA28H_GCLK_IO0)
  112. #define PORT_PA28H_GCLK_IO0 (1ul << 28)
  113. #define PIN_PA30H_GCLK_IO0 30L /**< \brief GCLK signal: IO0 on PA30 mux H */
  114. #define MUX_PA30H_GCLK_IO0 7L
  115. #define PINMUX_PA30H_GCLK_IO0 ((PIN_PA30H_GCLK_IO0 << 16) | MUX_PA30H_GCLK_IO0)
  116. #define PORT_PA30H_GCLK_IO0 (1ul << 30)
  117. #define PIN_PA15H_GCLK_IO1 15L /**< \brief GCLK signal: IO1 on PA15 mux H */
  118. #define MUX_PA15H_GCLK_IO1 7L
  119. #define PINMUX_PA15H_GCLK_IO1 ((PIN_PA15H_GCLK_IO1 << 16) | MUX_PA15H_GCLK_IO1)
  120. #define PORT_PA15H_GCLK_IO1 (1ul << 15)
  121. #define PIN_PA16H_GCLK_IO2 16L /**< \brief GCLK signal: IO2 on PA16 mux H */
  122. #define MUX_PA16H_GCLK_IO2 7L
  123. #define PINMUX_PA16H_GCLK_IO2 ((PIN_PA16H_GCLK_IO2 << 16) | MUX_PA16H_GCLK_IO2)
  124. #define PORT_PA16H_GCLK_IO2 (1ul << 16)
  125. #define PIN_PA17H_GCLK_IO3 17L /**< \brief GCLK signal: IO3 on PA17 mux H */
  126. #define MUX_PA17H_GCLK_IO3 7L
  127. #define PINMUX_PA17H_GCLK_IO3 ((PIN_PA17H_GCLK_IO3 << 16) | MUX_PA17H_GCLK_IO3)
  128. #define PORT_PA17H_GCLK_IO3 (1ul << 17)
  129. #define PIN_PA10H_GCLK_IO4 10L /**< \brief GCLK signal: IO4 on PA10 mux H */
  130. #define MUX_PA10H_GCLK_IO4 7L
  131. #define PINMUX_PA10H_GCLK_IO4 ((PIN_PA10H_GCLK_IO4 << 16) | MUX_PA10H_GCLK_IO4)
  132. #define PORT_PA10H_GCLK_IO4 (1ul << 10)
  133. #define PIN_PA11H_GCLK_IO5 11L /**< \brief GCLK signal: IO5 on PA11 mux H */
  134. #define MUX_PA11H_GCLK_IO5 7L
  135. #define PINMUX_PA11H_GCLK_IO5 ((PIN_PA11H_GCLK_IO5 << 16) | MUX_PA11H_GCLK_IO5)
  136. #define PORT_PA11H_GCLK_IO5 (1ul << 11)
  137. #define PIN_PA22H_GCLK_IO6 22L /**< \brief GCLK signal: IO6 on PA22 mux H */
  138. #define MUX_PA22H_GCLK_IO6 7L
  139. #define PINMUX_PA22H_GCLK_IO6 ((PIN_PA22H_GCLK_IO6 << 16) | MUX_PA22H_GCLK_IO6)
  140. #define PORT_PA22H_GCLK_IO6 (1ul << 22)
  141. #define PIN_PA23H_GCLK_IO7 23L /**< \brief GCLK signal: IO7 on PA23 mux H */
  142. #define MUX_PA23H_GCLK_IO7 7L
  143. #define PINMUX_PA23H_GCLK_IO7 ((PIN_PA23H_GCLK_IO7 << 16) | MUX_PA23H_GCLK_IO7)
  144. #define PORT_PA23H_GCLK_IO7 (1ul << 23)
  145. /* ========== PORT definition for EIC peripheral ========== */
  146. #define PIN_PA16A_EIC_EXTINT0 16L /**< \brief EIC signal: EXTINT0 on PA16 mux A */
  147. #define MUX_PA16A_EIC_EXTINT0 0L
  148. #define PINMUX_PA16A_EIC_EXTINT0 ((PIN_PA16A_EIC_EXTINT0 << 16) | MUX_PA16A_EIC_EXTINT0)
  149. #define PORT_PA16A_EIC_EXTINT0 (1ul << 16)
  150. #define PIN_PA00A_EIC_EXTINT0 0L /**< \brief EIC signal: EXTINT0 on PA00 mux A */
  151. #define MUX_PA00A_EIC_EXTINT0 0L
  152. #define PINMUX_PA00A_EIC_EXTINT0 ((PIN_PA00A_EIC_EXTINT0 << 16) | MUX_PA00A_EIC_EXTINT0)
  153. #define PORT_PA00A_EIC_EXTINT0 (1ul << 0)
  154. #define PIN_PA17A_EIC_EXTINT1 17L /**< \brief EIC signal: EXTINT1 on PA17 mux A */
  155. #define MUX_PA17A_EIC_EXTINT1 0L
  156. #define PINMUX_PA17A_EIC_EXTINT1 ((PIN_PA17A_EIC_EXTINT1 << 16) | MUX_PA17A_EIC_EXTINT1)
  157. #define PORT_PA17A_EIC_EXTINT1 (1ul << 17)
  158. #define PIN_PA01A_EIC_EXTINT1 1L /**< \brief EIC signal: EXTINT1 on PA01 mux A */
  159. #define MUX_PA01A_EIC_EXTINT1 0L
  160. #define PINMUX_PA01A_EIC_EXTINT1 ((PIN_PA01A_EIC_EXTINT1 << 16) | MUX_PA01A_EIC_EXTINT1)
  161. #define PORT_PA01A_EIC_EXTINT1 (1ul << 1)
  162. #define PIN_PA18A_EIC_EXTINT2 18L /**< \brief EIC signal: EXTINT2 on PA18 mux A */
  163. #define MUX_PA18A_EIC_EXTINT2 0L
  164. #define PINMUX_PA18A_EIC_EXTINT2 ((PIN_PA18A_EIC_EXTINT2 << 16) | MUX_PA18A_EIC_EXTINT2)
  165. #define PORT_PA18A_EIC_EXTINT2 (1ul << 18)
  166. #define PIN_PA02A_EIC_EXTINT2 2L /**< \brief EIC signal: EXTINT2 on PA02 mux A */
  167. #define MUX_PA02A_EIC_EXTINT2 0L
  168. #define PINMUX_PA02A_EIC_EXTINT2 ((PIN_PA02A_EIC_EXTINT2 << 16) | MUX_PA02A_EIC_EXTINT2)
  169. #define PORT_PA02A_EIC_EXTINT2 (1ul << 2)
  170. #define PIN_PA03A_EIC_EXTINT3 3L /**< \brief EIC signal: EXTINT3 on PA03 mux A */
  171. #define MUX_PA03A_EIC_EXTINT3 0L
  172. #define PINMUX_PA03A_EIC_EXTINT3 ((PIN_PA03A_EIC_EXTINT3 << 16) | MUX_PA03A_EIC_EXTINT3)
  173. #define PORT_PA03A_EIC_EXTINT3 (1ul << 3)
  174. #define PIN_PA19A_EIC_EXTINT3 19L /**< \brief EIC signal: EXTINT3 on PA19 mux A */
  175. #define MUX_PA19A_EIC_EXTINT3 0L
  176. #define PINMUX_PA19A_EIC_EXTINT3 ((PIN_PA19A_EIC_EXTINT3 << 16) | MUX_PA19A_EIC_EXTINT3)
  177. #define PORT_PA19A_EIC_EXTINT3 (1ul << 19)
  178. #define PIN_PA04A_EIC_EXTINT4 4L /**< \brief EIC signal: EXTINT4 on PA04 mux A */
  179. #define MUX_PA04A_EIC_EXTINT4 0L
  180. #define PINMUX_PA04A_EIC_EXTINT4 ((PIN_PA04A_EIC_EXTINT4 << 16) | MUX_PA04A_EIC_EXTINT4)
  181. #define PORT_PA04A_EIC_EXTINT4 (1ul << 4)
  182. #define PIN_PA05A_EIC_EXTINT5 5L /**< \brief EIC signal: EXTINT5 on PA05 mux A */
  183. #define MUX_PA05A_EIC_EXTINT5 0L
  184. #define PINMUX_PA05A_EIC_EXTINT5 ((PIN_PA05A_EIC_EXTINT5 << 16) | MUX_PA05A_EIC_EXTINT5)
  185. #define PORT_PA05A_EIC_EXTINT5 (1ul << 5)
  186. #define PIN_PA06A_EIC_EXTINT6 6L /**< \brief EIC signal: EXTINT6 on PA06 mux A */
  187. #define MUX_PA06A_EIC_EXTINT6 0L
  188. #define PINMUX_PA06A_EIC_EXTINT6 ((PIN_PA06A_EIC_EXTINT6 << 16) | MUX_PA06A_EIC_EXTINT6)
  189. #define PORT_PA06A_EIC_EXTINT6 (1ul << 6)
  190. #define PIN_PA22A_EIC_EXTINT6 22L /**< \brief EIC signal: EXTINT6 on PA22 mux A */
  191. #define MUX_PA22A_EIC_EXTINT6 0L
  192. #define PINMUX_PA22A_EIC_EXTINT6 ((PIN_PA22A_EIC_EXTINT6 << 16) | MUX_PA22A_EIC_EXTINT6)
  193. #define PORT_PA22A_EIC_EXTINT6 (1ul << 22)
  194. #define PIN_PA07A_EIC_EXTINT7 7L /**< \brief EIC signal: EXTINT7 on PA07 mux A */
  195. #define MUX_PA07A_EIC_EXTINT7 0L
  196. #define PINMUX_PA07A_EIC_EXTINT7 ((PIN_PA07A_EIC_EXTINT7 << 16) | MUX_PA07A_EIC_EXTINT7)
  197. #define PORT_PA07A_EIC_EXTINT7 (1ul << 7)
  198. #define PIN_PA23A_EIC_EXTINT7 23L /**< \brief EIC signal: EXTINT7 on PA23 mux A */
  199. #define MUX_PA23A_EIC_EXTINT7 0L
  200. #define PINMUX_PA23A_EIC_EXTINT7 ((PIN_PA23A_EIC_EXTINT7 << 16) | MUX_PA23A_EIC_EXTINT7)
  201. #define PORT_PA23A_EIC_EXTINT7 (1ul << 23)
  202. #define PIN_PA28A_EIC_EXTINT8 28L /**< \brief EIC signal: EXTINT8 on PA28 mux A */
  203. #define MUX_PA28A_EIC_EXTINT8 0L
  204. #define PINMUX_PA28A_EIC_EXTINT8 ((PIN_PA28A_EIC_EXTINT8 << 16) | MUX_PA28A_EIC_EXTINT8)
  205. #define PORT_PA28A_EIC_EXTINT8 (1ul << 28)
  206. #define PIN_PA09A_EIC_EXTINT9 9L /**< \brief EIC signal: EXTINT9 on PA09 mux A */
  207. #define MUX_PA09A_EIC_EXTINT9 0L
  208. #define PINMUX_PA09A_EIC_EXTINT9 ((PIN_PA09A_EIC_EXTINT9 << 16) | MUX_PA09A_EIC_EXTINT9)
  209. #define PORT_PA09A_EIC_EXTINT9 (1ul << 9)
  210. #define PIN_PA10A_EIC_EXTINT10 10L /**< \brief EIC signal: EXTINT10 on PA10 mux A */
  211. #define MUX_PA10A_EIC_EXTINT10 0L
  212. #define PINMUX_PA10A_EIC_EXTINT10 ((PIN_PA10A_EIC_EXTINT10 << 16) | MUX_PA10A_EIC_EXTINT10)
  213. #define PORT_PA10A_EIC_EXTINT10 (1ul << 10)
  214. #define PIN_PA30A_EIC_EXTINT10 30L /**< \brief EIC signal: EXTINT10 on PA30 mux A */
  215. #define MUX_PA30A_EIC_EXTINT10 0L
  216. #define PINMUX_PA30A_EIC_EXTINT10 ((PIN_PA30A_EIC_EXTINT10 << 16) | MUX_PA30A_EIC_EXTINT10)
  217. #define PORT_PA30A_EIC_EXTINT10 (1ul << 30)
  218. #define PIN_PA11A_EIC_EXTINT11 11L /**< \brief EIC signal: EXTINT11 on PA11 mux A */
  219. #define MUX_PA11A_EIC_EXTINT11 0L
  220. #define PINMUX_PA11A_EIC_EXTINT11 ((PIN_PA11A_EIC_EXTINT11 << 16) | MUX_PA11A_EIC_EXTINT11)
  221. #define PORT_PA11A_EIC_EXTINT11 (1ul << 11)
  222. #define PIN_PA31A_EIC_EXTINT11 31L /**< \brief EIC signal: EXTINT11 on PA31 mux A */
  223. #define MUX_PA31A_EIC_EXTINT11 0L
  224. #define PINMUX_PA31A_EIC_EXTINT11 ((PIN_PA31A_EIC_EXTINT11 << 16) | MUX_PA31A_EIC_EXTINT11)
  225. #define PORT_PA31A_EIC_EXTINT11 (1ul << 31)
  226. #define PIN_PA24A_EIC_EXTINT12 24L /**< \brief EIC signal: EXTINT12 on PA24 mux A */
  227. #define MUX_PA24A_EIC_EXTINT12 0L
  228. #define PINMUX_PA24A_EIC_EXTINT12 ((PIN_PA24A_EIC_EXTINT12 << 16) | MUX_PA24A_EIC_EXTINT12)
  229. #define PORT_PA24A_EIC_EXTINT12 (1ul << 24)
  230. #define PIN_PA25A_EIC_EXTINT13 25L /**< \brief EIC signal: EXTINT13 on PA25 mux A */
  231. #define MUX_PA25A_EIC_EXTINT13 0L
  232. #define PINMUX_PA25A_EIC_EXTINT13 ((PIN_PA25A_EIC_EXTINT13 << 16) | MUX_PA25A_EIC_EXTINT13)
  233. #define PORT_PA25A_EIC_EXTINT13 (1ul << 25)
  234. #define PIN_PA14A_EIC_EXTINT14 14L /**< \brief EIC signal: EXTINT14 on PA14 mux A */
  235. #define MUX_PA14A_EIC_EXTINT14 0L
  236. #define PINMUX_PA14A_EIC_EXTINT14 ((PIN_PA14A_EIC_EXTINT14 << 16) | MUX_PA14A_EIC_EXTINT14)
  237. #define PORT_PA14A_EIC_EXTINT14 (1ul << 14)
  238. #define PIN_PA15A_EIC_EXTINT15 15L /**< \brief EIC signal: EXTINT15 on PA15 mux A */
  239. #define MUX_PA15A_EIC_EXTINT15 0L
  240. #define PINMUX_PA15A_EIC_EXTINT15 ((PIN_PA15A_EIC_EXTINT15 << 16) | MUX_PA15A_EIC_EXTINT15)
  241. #define PORT_PA15A_EIC_EXTINT15 (1ul << 15)
  242. #define PIN_PA27A_EIC_EXTINT15 27L /**< \brief EIC signal: EXTINT15 on PA27 mux A */
  243. #define MUX_PA27A_EIC_EXTINT15 0L
  244. #define PINMUX_PA27A_EIC_EXTINT15 ((PIN_PA27A_EIC_EXTINT15 << 16) | MUX_PA27A_EIC_EXTINT15)
  245. #define PORT_PA27A_EIC_EXTINT15 (1ul << 27)
  246. #define PIN_PA08A_EIC_NMI 8L /**< \brief EIC signal: NMI on PA08 mux A */
  247. #define MUX_PA08A_EIC_NMI 0L
  248. #define PINMUX_PA08A_EIC_NMI ((PIN_PA08A_EIC_NMI << 16) | MUX_PA08A_EIC_NMI)
  249. #define PORT_PA08A_EIC_NMI (1ul << 8)
  250. /* ========== PORT definition for USB peripheral ========== */
  251. #define PIN_PA24G_USB_DM 24L /**< \brief USB signal: DM on PA24 mux G */
  252. #define MUX_PA24G_USB_DM 6L
  253. #define PINMUX_PA24G_USB_DM ((PIN_PA24G_USB_DM << 16) | MUX_PA24G_USB_DM)
  254. #define PORT_PA24G_USB_DM (1ul << 24)
  255. #define PIN_PA25G_USB_DP 25L /**< \brief USB signal: DP on PA25 mux G */
  256. #define MUX_PA25G_USB_DP 6L
  257. #define PINMUX_PA25G_USB_DP ((PIN_PA25G_USB_DP << 16) | MUX_PA25G_USB_DP)
  258. #define PORT_PA25G_USB_DP (1ul << 25)
  259. #define PIN_PA23G_USB_SOF_1KHZ 23L /**< \brief USB signal: SOF_1KHZ on PA23 mux G */
  260. #define MUX_PA23G_USB_SOF_1KHZ 6L
  261. #define PINMUX_PA23G_USB_SOF_1KHZ ((PIN_PA23G_USB_SOF_1KHZ << 16) | MUX_PA23G_USB_SOF_1KHZ)
  262. #define PORT_PA23G_USB_SOF_1KHZ (1ul << 23)
  263. /* ========== PORT definition for SERCOM0 peripheral ========== */
  264. #define PIN_PA04D_SERCOM0_PAD0 4L /**< \brief SERCOM0 signal: PAD0 on PA04 mux D */
  265. #define MUX_PA04D_SERCOM0_PAD0 3L
  266. #define PINMUX_PA04D_SERCOM0_PAD0 ((PIN_PA04D_SERCOM0_PAD0 << 16) | MUX_PA04D_SERCOM0_PAD0)
  267. #define PORT_PA04D_SERCOM0_PAD0 (1ul << 4)
  268. #define PIN_PA08C_SERCOM0_PAD0 8L /**< \brief SERCOM0 signal: PAD0 on PA08 mux C */
  269. #define MUX_PA08C_SERCOM0_PAD0 2L
  270. #define PINMUX_PA08C_SERCOM0_PAD0 ((PIN_PA08C_SERCOM0_PAD0 << 16) | MUX_PA08C_SERCOM0_PAD0)
  271. #define PORT_PA08C_SERCOM0_PAD0 (1ul << 8)
  272. #define PIN_PA05D_SERCOM0_PAD1 5L /**< \brief SERCOM0 signal: PAD1 on PA05 mux D */
  273. #define MUX_PA05D_SERCOM0_PAD1 3L
  274. #define PINMUX_PA05D_SERCOM0_PAD1 ((PIN_PA05D_SERCOM0_PAD1 << 16) | MUX_PA05D_SERCOM0_PAD1)
  275. #define PORT_PA05D_SERCOM0_PAD1 (1ul << 5)
  276. #define PIN_PA09C_SERCOM0_PAD1 9L /**< \brief SERCOM0 signal: PAD1 on PA09 mux C */
  277. #define MUX_PA09C_SERCOM0_PAD1 2L
  278. #define PINMUX_PA09C_SERCOM0_PAD1 ((PIN_PA09C_SERCOM0_PAD1 << 16) | MUX_PA09C_SERCOM0_PAD1)
  279. #define PORT_PA09C_SERCOM0_PAD1 (1ul << 9)
  280. #define PIN_PA06D_SERCOM0_PAD2 6L /**< \brief SERCOM0 signal: PAD2 on PA06 mux D */
  281. #define MUX_PA06D_SERCOM0_PAD2 3L
  282. #define PINMUX_PA06D_SERCOM0_PAD2 ((PIN_PA06D_SERCOM0_PAD2 << 16) | MUX_PA06D_SERCOM0_PAD2)
  283. #define PORT_PA06D_SERCOM0_PAD2 (1ul << 6)
  284. #define PIN_PA10C_SERCOM0_PAD2 10L /**< \brief SERCOM0 signal: PAD2 on PA10 mux C */
  285. #define MUX_PA10C_SERCOM0_PAD2 2L
  286. #define PINMUX_PA10C_SERCOM0_PAD2 ((PIN_PA10C_SERCOM0_PAD2 << 16) | MUX_PA10C_SERCOM0_PAD2)
  287. #define PORT_PA10C_SERCOM0_PAD2 (1ul << 10)
  288. #define PIN_PA07D_SERCOM0_PAD3 7L /**< \brief SERCOM0 signal: PAD3 on PA07 mux D */
  289. #define MUX_PA07D_SERCOM0_PAD3 3L
  290. #define PINMUX_PA07D_SERCOM0_PAD3 ((PIN_PA07D_SERCOM0_PAD3 << 16) | MUX_PA07D_SERCOM0_PAD3)
  291. #define PORT_PA07D_SERCOM0_PAD3 (1ul << 7)
  292. #define PIN_PA11C_SERCOM0_PAD3 11L /**< \brief SERCOM0 signal: PAD3 on PA11 mux C */
  293. #define MUX_PA11C_SERCOM0_PAD3 2L
  294. #define PINMUX_PA11C_SERCOM0_PAD3 ((PIN_PA11C_SERCOM0_PAD3 << 16) | MUX_PA11C_SERCOM0_PAD3)
  295. #define PORT_PA11C_SERCOM0_PAD3 (1ul << 11)
  296. /* ========== PORT definition for SERCOM1 peripheral ========== */
  297. #define PIN_PA16C_SERCOM1_PAD0 16L /**< \brief SERCOM1 signal: PAD0 on PA16 mux C */
  298. #define MUX_PA16C_SERCOM1_PAD0 2L
  299. #define PINMUX_PA16C_SERCOM1_PAD0 ((PIN_PA16C_SERCOM1_PAD0 << 16) | MUX_PA16C_SERCOM1_PAD0)
  300. #define PORT_PA16C_SERCOM1_PAD0 (1ul << 16)
  301. #define PIN_PA00D_SERCOM1_PAD0 0L /**< \brief SERCOM1 signal: PAD0 on PA00 mux D */
  302. #define MUX_PA00D_SERCOM1_PAD0 3L
  303. #define PINMUX_PA00D_SERCOM1_PAD0 ((PIN_PA00D_SERCOM1_PAD0 << 16) | MUX_PA00D_SERCOM1_PAD0)
  304. #define PORT_PA00D_SERCOM1_PAD0 (1ul << 0)
  305. #define PIN_PA17C_SERCOM1_PAD1 17L /**< \brief SERCOM1 signal: PAD1 on PA17 mux C */
  306. #define MUX_PA17C_SERCOM1_PAD1 2L
  307. #define PINMUX_PA17C_SERCOM1_PAD1 ((PIN_PA17C_SERCOM1_PAD1 << 16) | MUX_PA17C_SERCOM1_PAD1)
  308. #define PORT_PA17C_SERCOM1_PAD1 (1ul << 17)
  309. #define PIN_PA01D_SERCOM1_PAD1 1L /**< \brief SERCOM1 signal: PAD1 on PA01 mux D */
  310. #define MUX_PA01D_SERCOM1_PAD1 3L
  311. #define PINMUX_PA01D_SERCOM1_PAD1 ((PIN_PA01D_SERCOM1_PAD1 << 16) | MUX_PA01D_SERCOM1_PAD1)
  312. #define PORT_PA01D_SERCOM1_PAD1 (1ul << 1)
  313. #define PIN_PA30D_SERCOM1_PAD2 30L /**< \brief SERCOM1 signal: PAD2 on PA30 mux D */
  314. #define MUX_PA30D_SERCOM1_PAD2 3L
  315. #define PINMUX_PA30D_SERCOM1_PAD2 ((PIN_PA30D_SERCOM1_PAD2 << 16) | MUX_PA30D_SERCOM1_PAD2)
  316. #define PORT_PA30D_SERCOM1_PAD2 (1ul << 30)
  317. #define PIN_PA18C_SERCOM1_PAD2 18L /**< \brief SERCOM1 signal: PAD2 on PA18 mux C */
  318. #define MUX_PA18C_SERCOM1_PAD2 2L
  319. #define PINMUX_PA18C_SERCOM1_PAD2 ((PIN_PA18C_SERCOM1_PAD2 << 16) | MUX_PA18C_SERCOM1_PAD2)
  320. #define PORT_PA18C_SERCOM1_PAD2 (1ul << 18)
  321. #define PIN_PA31D_SERCOM1_PAD3 31L /**< \brief SERCOM1 signal: PAD3 on PA31 mux D */
  322. #define MUX_PA31D_SERCOM1_PAD3 3L
  323. #define PINMUX_PA31D_SERCOM1_PAD3 ((PIN_PA31D_SERCOM1_PAD3 << 16) | MUX_PA31D_SERCOM1_PAD3)
  324. #define PORT_PA31D_SERCOM1_PAD3 (1ul << 31)
  325. #define PIN_PA19C_SERCOM1_PAD3 19L /**< \brief SERCOM1 signal: PAD3 on PA19 mux C */
  326. #define MUX_PA19C_SERCOM1_PAD3 2L
  327. #define PINMUX_PA19C_SERCOM1_PAD3 ((PIN_PA19C_SERCOM1_PAD3 << 16) | MUX_PA19C_SERCOM1_PAD3)
  328. #define PORT_PA19C_SERCOM1_PAD3 (1ul << 19)
  329. /* ========== PORT definition for SERCOM2 peripheral ========== */
  330. #define PIN_PA08D_SERCOM2_PAD0 8L /**< \brief SERCOM2 signal: PAD0 on PA08 mux D */
  331. #define MUX_PA08D_SERCOM2_PAD0 3L
  332. #define PINMUX_PA08D_SERCOM2_PAD0 ((PIN_PA08D_SERCOM2_PAD0 << 16) | MUX_PA08D_SERCOM2_PAD0)
  333. #define PORT_PA08D_SERCOM2_PAD0 (1ul << 8)
  334. #define PIN_PA09D_SERCOM2_PAD1 9L /**< \brief SERCOM2 signal: PAD1 on PA09 mux D */
  335. #define MUX_PA09D_SERCOM2_PAD1 3L
  336. #define PINMUX_PA09D_SERCOM2_PAD1 ((PIN_PA09D_SERCOM2_PAD1 << 16) | MUX_PA09D_SERCOM2_PAD1)
  337. #define PORT_PA09D_SERCOM2_PAD1 (1ul << 9)
  338. #define PIN_PA10D_SERCOM2_PAD2 10L /**< \brief SERCOM2 signal: PAD2 on PA10 mux D */
  339. #define MUX_PA10D_SERCOM2_PAD2 3L
  340. #define PINMUX_PA10D_SERCOM2_PAD2 ((PIN_PA10D_SERCOM2_PAD2 << 16) | MUX_PA10D_SERCOM2_PAD2)
  341. #define PORT_PA10D_SERCOM2_PAD2 (1ul << 10)
  342. #define PIN_PA14C_SERCOM2_PAD2 14L /**< \brief SERCOM2 signal: PAD2 on PA14 mux C */
  343. #define MUX_PA14C_SERCOM2_PAD2 2L
  344. #define PINMUX_PA14C_SERCOM2_PAD2 ((PIN_PA14C_SERCOM2_PAD2 << 16) | MUX_PA14C_SERCOM2_PAD2)
  345. #define PORT_PA14C_SERCOM2_PAD2 (1ul << 14)
  346. #define PIN_PA11D_SERCOM2_PAD3 11L /**< \brief SERCOM2 signal: PAD3 on PA11 mux D */
  347. #define MUX_PA11D_SERCOM2_PAD3 3L
  348. #define PINMUX_PA11D_SERCOM2_PAD3 ((PIN_PA11D_SERCOM2_PAD3 << 16) | MUX_PA11D_SERCOM2_PAD3)
  349. #define PORT_PA11D_SERCOM2_PAD3 (1ul << 11)
  350. #define PIN_PA15C_SERCOM2_PAD3 15L /**< \brief SERCOM2 signal: PAD3 on PA15 mux C */
  351. #define MUX_PA15C_SERCOM2_PAD3 2L
  352. #define PINMUX_PA15C_SERCOM2_PAD3 ((PIN_PA15C_SERCOM2_PAD3 << 16) | MUX_PA15C_SERCOM2_PAD3)
  353. #define PORT_PA15C_SERCOM2_PAD3 (1ul << 15)
  354. /* ========== PORT definition for SERCOM3 peripheral ========== */
  355. #define PIN_PA16D_SERCOM3_PAD0 16L /**< \brief SERCOM3 signal: PAD0 on PA16 mux D */
  356. #define MUX_PA16D_SERCOM3_PAD0 3L
  357. #define PINMUX_PA16D_SERCOM3_PAD0 ((PIN_PA16D_SERCOM3_PAD0 << 16) | MUX_PA16D_SERCOM3_PAD0)
  358. #define PORT_PA16D_SERCOM3_PAD0 (1ul << 16)
  359. #define PIN_PA22C_SERCOM3_PAD0 22L /**< \brief SERCOM3 signal: PAD0 on PA22 mux C */
  360. #define MUX_PA22C_SERCOM3_PAD0 2L
  361. #define PINMUX_PA22C_SERCOM3_PAD0 ((PIN_PA22C_SERCOM3_PAD0 << 16) | MUX_PA22C_SERCOM3_PAD0)
  362. #define PORT_PA22C_SERCOM3_PAD0 (1ul << 22)
  363. #define PIN_PA17D_SERCOM3_PAD1 17L /**< \brief SERCOM3 signal: PAD1 on PA17 mux D */
  364. #define MUX_PA17D_SERCOM3_PAD1 3L
  365. #define PINMUX_PA17D_SERCOM3_PAD1 ((PIN_PA17D_SERCOM3_PAD1 << 16) | MUX_PA17D_SERCOM3_PAD1)
  366. #define PORT_PA17D_SERCOM3_PAD1 (1ul << 17)
  367. #define PIN_PA23C_SERCOM3_PAD1 23L /**< \brief SERCOM3 signal: PAD1 on PA23 mux C */
  368. #define MUX_PA23C_SERCOM3_PAD1 2L
  369. #define PINMUX_PA23C_SERCOM3_PAD1 ((PIN_PA23C_SERCOM3_PAD1 << 16) | MUX_PA23C_SERCOM3_PAD1)
  370. #define PORT_PA23C_SERCOM3_PAD1 (1ul << 23)
  371. #define PIN_PA18D_SERCOM3_PAD2 18L /**< \brief SERCOM3 signal: PAD2 on PA18 mux D */
  372. #define MUX_PA18D_SERCOM3_PAD2 3L
  373. #define PINMUX_PA18D_SERCOM3_PAD2 ((PIN_PA18D_SERCOM3_PAD2 << 16) | MUX_PA18D_SERCOM3_PAD2)
  374. #define PORT_PA18D_SERCOM3_PAD2 (1ul << 18)
  375. #define PIN_PA24C_SERCOM3_PAD2 24L /**< \brief SERCOM3 signal: PAD2 on PA24 mux C */
  376. #define MUX_PA24C_SERCOM3_PAD2 2L
  377. #define PINMUX_PA24C_SERCOM3_PAD2 ((PIN_PA24C_SERCOM3_PAD2 << 16) | MUX_PA24C_SERCOM3_PAD2)
  378. #define PORT_PA24C_SERCOM3_PAD2 (1ul << 24)
  379. #define PIN_PA19D_SERCOM3_PAD3 19L /**< \brief SERCOM3 signal: PAD3 on PA19 mux D */
  380. #define MUX_PA19D_SERCOM3_PAD3 3L
  381. #define PINMUX_PA19D_SERCOM3_PAD3 ((PIN_PA19D_SERCOM3_PAD3 << 16) | MUX_PA19D_SERCOM3_PAD3)
  382. #define PORT_PA19D_SERCOM3_PAD3 (1ul << 19)
  383. #define PIN_PA25C_SERCOM3_PAD3 25L /**< \brief SERCOM3 signal: PAD3 on PA25 mux C */
  384. #define MUX_PA25C_SERCOM3_PAD3 2L
  385. #define PINMUX_PA25C_SERCOM3_PAD3 ((PIN_PA25C_SERCOM3_PAD3 << 16) | MUX_PA25C_SERCOM3_PAD3)
  386. #define PORT_PA25C_SERCOM3_PAD3 (1ul << 25)
  387. /* ========== PORT definition for TCC0 peripheral ========== */
  388. #define PIN_PA04E_TCC0_WO0 4L /**< \brief TCC0 signal: WO0 on PA04 mux E */
  389. #define MUX_PA04E_TCC0_WO0 4L
  390. #define PINMUX_PA04E_TCC0_WO0 ((PIN_PA04E_TCC0_WO0 << 16) | MUX_PA04E_TCC0_WO0)
  391. #define PORT_PA04E_TCC0_WO0 (1ul << 4)
  392. #define PIN_PA08E_TCC0_WO0 8L /**< \brief TCC0 signal: WO0 on PA08 mux E */
  393. #define MUX_PA08E_TCC0_WO0 4L
  394. #define PINMUX_PA08E_TCC0_WO0 ((PIN_PA08E_TCC0_WO0 << 16) | MUX_PA08E_TCC0_WO0)
  395. #define PORT_PA08E_TCC0_WO0 (1ul << 8)
  396. #define PIN_PA05E_TCC0_WO1 5L /**< \brief TCC0 signal: WO1 on PA05 mux E */
  397. #define MUX_PA05E_TCC0_WO1 4L
  398. #define PINMUX_PA05E_TCC0_WO1 ((PIN_PA05E_TCC0_WO1 << 16) | MUX_PA05E_TCC0_WO1)
  399. #define PORT_PA05E_TCC0_WO1 (1ul << 5)
  400. #define PIN_PA09E_TCC0_WO1 9L /**< \brief TCC0 signal: WO1 on PA09 mux E */
  401. #define MUX_PA09E_TCC0_WO1 4L
  402. #define PINMUX_PA09E_TCC0_WO1 ((PIN_PA09E_TCC0_WO1 << 16) | MUX_PA09E_TCC0_WO1)
  403. #define PORT_PA09E_TCC0_WO1 (1ul << 9)
  404. #define PIN_PA10F_TCC0_WO2 10L /**< \brief TCC0 signal: WO2 on PA10 mux F */
  405. #define MUX_PA10F_TCC0_WO2 5L
  406. #define PINMUX_PA10F_TCC0_WO2 ((PIN_PA10F_TCC0_WO2 << 16) | MUX_PA10F_TCC0_WO2)
  407. #define PORT_PA10F_TCC0_WO2 (1ul << 10)
  408. #define PIN_PA18F_TCC0_WO2 18L /**< \brief TCC0 signal: WO2 on PA18 mux F */
  409. #define MUX_PA18F_TCC0_WO2 5L
  410. #define PINMUX_PA18F_TCC0_WO2 ((PIN_PA18F_TCC0_WO2 << 16) | MUX_PA18F_TCC0_WO2)
  411. #define PORT_PA18F_TCC0_WO2 (1ul << 18)
  412. #define PIN_PA11F_TCC0_WO3 11L /**< \brief TCC0 signal: WO3 on PA11 mux F */
  413. #define MUX_PA11F_TCC0_WO3 5L
  414. #define PINMUX_PA11F_TCC0_WO3 ((PIN_PA11F_TCC0_WO3 << 16) | MUX_PA11F_TCC0_WO3)
  415. #define PORT_PA11F_TCC0_WO3 (1ul << 11)
  416. #define PIN_PA19F_TCC0_WO3 19L /**< \brief TCC0 signal: WO3 on PA19 mux F */
  417. #define MUX_PA19F_TCC0_WO3 5L
  418. #define PINMUX_PA19F_TCC0_WO3 ((PIN_PA19F_TCC0_WO3 << 16) | MUX_PA19F_TCC0_WO3)
  419. #define PORT_PA19F_TCC0_WO3 (1ul << 19)
  420. #define PIN_PA14F_TCC0_WO4 14L /**< \brief TCC0 signal: WO4 on PA14 mux F */
  421. #define MUX_PA14F_TCC0_WO4 5L
  422. #define PINMUX_PA14F_TCC0_WO4 ((PIN_PA14F_TCC0_WO4 << 16) | MUX_PA14F_TCC0_WO4)
  423. #define PORT_PA14F_TCC0_WO4 (1ul << 14)
  424. #define PIN_PA22F_TCC0_WO4 22L /**< \brief TCC0 signal: WO4 on PA22 mux F */
  425. #define MUX_PA22F_TCC0_WO4 5L
  426. #define PINMUX_PA22F_TCC0_WO4 ((PIN_PA22F_TCC0_WO4 << 16) | MUX_PA22F_TCC0_WO4)
  427. #define PORT_PA22F_TCC0_WO4 (1ul << 22)
  428. #define PIN_PA15F_TCC0_WO5 15L /**< \brief TCC0 signal: WO5 on PA15 mux F */
  429. #define MUX_PA15F_TCC0_WO5 5L
  430. #define PINMUX_PA15F_TCC0_WO5 ((PIN_PA15F_TCC0_WO5 << 16) | MUX_PA15F_TCC0_WO5)
  431. #define PORT_PA15F_TCC0_WO5 (1ul << 15)
  432. #define PIN_PA23F_TCC0_WO5 23L /**< \brief TCC0 signal: WO5 on PA23 mux F */
  433. #define MUX_PA23F_TCC0_WO5 5L
  434. #define PINMUX_PA23F_TCC0_WO5 ((PIN_PA23F_TCC0_WO5 << 16) | MUX_PA23F_TCC0_WO5)
  435. #define PORT_PA23F_TCC0_WO5 (1ul << 23)
  436. #define PIN_PA16F_TCC0_WO6 16L /**< \brief TCC0 signal: WO6 on PA16 mux F */
  437. #define MUX_PA16F_TCC0_WO6 5L
  438. #define PINMUX_PA16F_TCC0_WO6 ((PIN_PA16F_TCC0_WO6 << 16) | MUX_PA16F_TCC0_WO6)
  439. #define PORT_PA16F_TCC0_WO6 (1ul << 16)
  440. #define PIN_PA17F_TCC0_WO7 17L /**< \brief TCC0 signal: WO7 on PA17 mux F */
  441. #define MUX_PA17F_TCC0_WO7 5L
  442. #define PINMUX_PA17F_TCC0_WO7 ((PIN_PA17F_TCC0_WO7 << 16) | MUX_PA17F_TCC0_WO7)
  443. #define PORT_PA17F_TCC0_WO7 (1ul << 17)
  444. /* ========== PORT definition for TCC1 peripheral ========== */
  445. #define PIN_PA06E_TCC1_WO0 6L /**< \brief TCC1 signal: WO0 on PA06 mux E */
  446. #define MUX_PA06E_TCC1_WO0 4L
  447. #define PINMUX_PA06E_TCC1_WO0 ((PIN_PA06E_TCC1_WO0 << 16) | MUX_PA06E_TCC1_WO0)
  448. #define PORT_PA06E_TCC1_WO0 (1ul << 6)
  449. #define PIN_PA10E_TCC1_WO0 10L /**< \brief TCC1 signal: WO0 on PA10 mux E */
  450. #define MUX_PA10E_TCC1_WO0 4L
  451. #define PINMUX_PA10E_TCC1_WO0 ((PIN_PA10E_TCC1_WO0 << 16) | MUX_PA10E_TCC1_WO0)
  452. #define PORT_PA10E_TCC1_WO0 (1ul << 10)
  453. #define PIN_PA30E_TCC1_WO0 30L /**< \brief TCC1 signal: WO0 on PA30 mux E */
  454. #define MUX_PA30E_TCC1_WO0 4L
  455. #define PINMUX_PA30E_TCC1_WO0 ((PIN_PA30E_TCC1_WO0 << 16) | MUX_PA30E_TCC1_WO0)
  456. #define PORT_PA30E_TCC1_WO0 (1ul << 30)
  457. #define PIN_PA07E_TCC1_WO1 7L /**< \brief TCC1 signal: WO1 on PA07 mux E */
  458. #define MUX_PA07E_TCC1_WO1 4L
  459. #define PINMUX_PA07E_TCC1_WO1 ((PIN_PA07E_TCC1_WO1 << 16) | MUX_PA07E_TCC1_WO1)
  460. #define PORT_PA07E_TCC1_WO1 (1ul << 7)
  461. #define PIN_PA11E_TCC1_WO1 11L /**< \brief TCC1 signal: WO1 on PA11 mux E */
  462. #define MUX_PA11E_TCC1_WO1 4L
  463. #define PINMUX_PA11E_TCC1_WO1 ((PIN_PA11E_TCC1_WO1 << 16) | MUX_PA11E_TCC1_WO1)
  464. #define PORT_PA11E_TCC1_WO1 (1ul << 11)
  465. #define PIN_PA31E_TCC1_WO1 31L /**< \brief TCC1 signal: WO1 on PA31 mux E */
  466. #define MUX_PA31E_TCC1_WO1 4L
  467. #define PINMUX_PA31E_TCC1_WO1 ((PIN_PA31E_TCC1_WO1 << 16) | MUX_PA31E_TCC1_WO1)
  468. #define PORT_PA31E_TCC1_WO1 (1ul << 31)
  469. #define PIN_PA08F_TCC1_WO2 8L /**< \brief TCC1 signal: WO2 on PA08 mux F */
  470. #define MUX_PA08F_TCC1_WO2 5L
  471. #define PINMUX_PA08F_TCC1_WO2 ((PIN_PA08F_TCC1_WO2 << 16) | MUX_PA08F_TCC1_WO2)
  472. #define PORT_PA08F_TCC1_WO2 (1ul << 8)
  473. #define PIN_PA24F_TCC1_WO2 24L /**< \brief TCC1 signal: WO2 on PA24 mux F */
  474. #define MUX_PA24F_TCC1_WO2 5L
  475. #define PINMUX_PA24F_TCC1_WO2 ((PIN_PA24F_TCC1_WO2 << 16) | MUX_PA24F_TCC1_WO2)
  476. #define PORT_PA24F_TCC1_WO2 (1ul << 24)
  477. #define PIN_PA09F_TCC1_WO3 9L /**< \brief TCC1 signal: WO3 on PA09 mux F */
  478. #define MUX_PA09F_TCC1_WO3 5L
  479. #define PINMUX_PA09F_TCC1_WO3 ((PIN_PA09F_TCC1_WO3 << 16) | MUX_PA09F_TCC1_WO3)
  480. #define PORT_PA09F_TCC1_WO3 (1ul << 9)
  481. #define PIN_PA25F_TCC1_WO3 25L /**< \brief TCC1 signal: WO3 on PA25 mux F */
  482. #define MUX_PA25F_TCC1_WO3 5L
  483. #define PINMUX_PA25F_TCC1_WO3 ((PIN_PA25F_TCC1_WO3 << 16) | MUX_PA25F_TCC1_WO3)
  484. #define PORT_PA25F_TCC1_WO3 (1ul << 25)
  485. /* ========== PORT definition for TCC2 peripheral ========== */
  486. #define PIN_PA16E_TCC2_WO0 16L /**< \brief TCC2 signal: WO0 on PA16 mux E */
  487. #define MUX_PA16E_TCC2_WO0 4L
  488. #define PINMUX_PA16E_TCC2_WO0 ((PIN_PA16E_TCC2_WO0 << 16) | MUX_PA16E_TCC2_WO0)
  489. #define PORT_PA16E_TCC2_WO0 (1ul << 16)
  490. #define PIN_PA00E_TCC2_WO0 0L /**< \brief TCC2 signal: WO0 on PA00 mux E */
  491. #define MUX_PA00E_TCC2_WO0 4L
  492. #define PINMUX_PA00E_TCC2_WO0 ((PIN_PA00E_TCC2_WO0 << 16) | MUX_PA00E_TCC2_WO0)
  493. #define PORT_PA00E_TCC2_WO0 (1ul << 0)
  494. #define PIN_PA17E_TCC2_WO1 17L /**< \brief TCC2 signal: WO1 on PA17 mux E */
  495. #define MUX_PA17E_TCC2_WO1 4L
  496. #define PINMUX_PA17E_TCC2_WO1 ((PIN_PA17E_TCC2_WO1 << 16) | MUX_PA17E_TCC2_WO1)
  497. #define PORT_PA17E_TCC2_WO1 (1ul << 17)
  498. #define PIN_PA01E_TCC2_WO1 1L /**< \brief TCC2 signal: WO1 on PA01 mux E */
  499. #define MUX_PA01E_TCC2_WO1 4L
  500. #define PINMUX_PA01E_TCC2_WO1 ((PIN_PA01E_TCC2_WO1 << 16) | MUX_PA01E_TCC2_WO1)
  501. #define PORT_PA01E_TCC2_WO1 (1ul << 1)
  502. /* ========== PORT definition for TC3 peripheral ========== */
  503. #define PIN_PA18E_TC3_WO0 18L /**< \brief TC3 signal: WO0 on PA18 mux E */
  504. #define MUX_PA18E_TC3_WO0 4L
  505. #define PINMUX_PA18E_TC3_WO0 ((PIN_PA18E_TC3_WO0 << 16) | MUX_PA18E_TC3_WO0)
  506. #define PORT_PA18E_TC3_WO0 (1ul << 18)
  507. #define PIN_PA14E_TC3_WO0 14L /**< \brief TC3 signal: WO0 on PA14 mux E */
  508. #define MUX_PA14E_TC3_WO0 4L
  509. #define PINMUX_PA14E_TC3_WO0 ((PIN_PA14E_TC3_WO0 << 16) | MUX_PA14E_TC3_WO0)
  510. #define PORT_PA14E_TC3_WO0 (1ul << 14)
  511. #define PIN_PA19E_TC3_WO1 19L /**< \brief TC3 signal: WO1 on PA19 mux E */
  512. #define MUX_PA19E_TC3_WO1 4L
  513. #define PINMUX_PA19E_TC3_WO1 ((PIN_PA19E_TC3_WO1 << 16) | MUX_PA19E_TC3_WO1)
  514. #define PORT_PA19E_TC3_WO1 (1ul << 19)
  515. #define PIN_PA15E_TC3_WO1 15L /**< \brief TC3 signal: WO1 on PA15 mux E */
  516. #define MUX_PA15E_TC3_WO1 4L
  517. #define PINMUX_PA15E_TC3_WO1 ((PIN_PA15E_TC3_WO1 << 16) | MUX_PA15E_TC3_WO1)
  518. #define PORT_PA15E_TC3_WO1 (1ul << 15)
  519. /* ========== PORT definition for TC4 peripheral ========== */
  520. #define PIN_PA22E_TC4_WO0 22L /**< \brief TC4 signal: WO0 on PA22 mux E */
  521. #define MUX_PA22E_TC4_WO0 4L
  522. #define PINMUX_PA22E_TC4_WO0 ((PIN_PA22E_TC4_WO0 << 16) | MUX_PA22E_TC4_WO0)
  523. #define PORT_PA22E_TC4_WO0 (1ul << 22)
  524. #define PIN_PA23E_TC4_WO1 23L /**< \brief TC4 signal: WO1 on PA23 mux E */
  525. #define MUX_PA23E_TC4_WO1 4L
  526. #define PINMUX_PA23E_TC4_WO1 ((PIN_PA23E_TC4_WO1 << 16) | MUX_PA23E_TC4_WO1)
  527. #define PORT_PA23E_TC4_WO1 (1ul << 23)
  528. /* ========== PORT definition for TC5 peripheral ========== */
  529. #define PIN_PA24E_TC5_WO0 24L /**< \brief TC5 signal: WO0 on PA24 mux E */
  530. #define MUX_PA24E_TC5_WO0 4L
  531. #define PINMUX_PA24E_TC5_WO0 ((PIN_PA24E_TC5_WO0 << 16) | MUX_PA24E_TC5_WO0)
  532. #define PORT_PA24E_TC5_WO0 (1ul << 24)
  533. #define PIN_PA25E_TC5_WO1 25L /**< \brief TC5 signal: WO1 on PA25 mux E */
  534. #define MUX_PA25E_TC5_WO1 4L
  535. #define PINMUX_PA25E_TC5_WO1 ((PIN_PA25E_TC5_WO1 << 16) | MUX_PA25E_TC5_WO1)
  536. #define PORT_PA25E_TC5_WO1 (1ul << 25)
  537. /* ========== PORT definition for ADC peripheral ========== */
  538. #define PIN_PA02B_ADC_AIN0 2L /**< \brief ADC signal: AIN0 on PA02 mux B */
  539. #define MUX_PA02B_ADC_AIN0 1L
  540. #define PINMUX_PA02B_ADC_AIN0 ((PIN_PA02B_ADC_AIN0 << 16) | MUX_PA02B_ADC_AIN0)
  541. #define PORT_PA02B_ADC_AIN0 (1ul << 2)
  542. #define PIN_PA03B_ADC_AIN1 3L /**< \brief ADC signal: AIN1 on PA03 mux B */
  543. #define MUX_PA03B_ADC_AIN1 1L
  544. #define PINMUX_PA03B_ADC_AIN1 ((PIN_PA03B_ADC_AIN1 << 16) | MUX_PA03B_ADC_AIN1)
  545. #define PORT_PA03B_ADC_AIN1 (1ul << 3)
  546. #define PIN_PA04B_ADC_AIN4 4L /**< \brief ADC signal: AIN4 on PA04 mux B */
  547. #define MUX_PA04B_ADC_AIN4 1L
  548. #define PINMUX_PA04B_ADC_AIN4 ((PIN_PA04B_ADC_AIN4 << 16) | MUX_PA04B_ADC_AIN4)
  549. #define PORT_PA04B_ADC_AIN4 (1ul << 4)
  550. #define PIN_PA05B_ADC_AIN5 5L /**< \brief ADC signal: AIN5 on PA05 mux B */
  551. #define MUX_PA05B_ADC_AIN5 1L
  552. #define PINMUX_PA05B_ADC_AIN5 ((PIN_PA05B_ADC_AIN5 << 16) | MUX_PA05B_ADC_AIN5)
  553. #define PORT_PA05B_ADC_AIN5 (1ul << 5)
  554. #define PIN_PA06B_ADC_AIN6 6L /**< \brief ADC signal: AIN6 on PA06 mux B */
  555. #define MUX_PA06B_ADC_AIN6 1L
  556. #define PINMUX_PA06B_ADC_AIN6 ((PIN_PA06B_ADC_AIN6 << 16) | MUX_PA06B_ADC_AIN6)
  557. #define PORT_PA06B_ADC_AIN6 (1ul << 6)
  558. #define PIN_PA07B_ADC_AIN7 7L /**< \brief ADC signal: AIN7 on PA07 mux B */
  559. #define MUX_PA07B_ADC_AIN7 1L
  560. #define PINMUX_PA07B_ADC_AIN7 ((PIN_PA07B_ADC_AIN7 << 16) | MUX_PA07B_ADC_AIN7)
  561. #define PORT_PA07B_ADC_AIN7 (1ul << 7)
  562. #define PIN_PA08B_ADC_AIN16 8L /**< \brief ADC signal: AIN16 on PA08 mux B */
  563. #define MUX_PA08B_ADC_AIN16 1L
  564. #define PINMUX_PA08B_ADC_AIN16 ((PIN_PA08B_ADC_AIN16 << 16) | MUX_PA08B_ADC_AIN16)
  565. #define PORT_PA08B_ADC_AIN16 (1ul << 8)
  566. #define PIN_PA09B_ADC_AIN17 9L /**< \brief ADC signal: AIN17 on PA09 mux B */
  567. #define MUX_PA09B_ADC_AIN17 1L
  568. #define PINMUX_PA09B_ADC_AIN17 ((PIN_PA09B_ADC_AIN17 << 16) | MUX_PA09B_ADC_AIN17)
  569. #define PORT_PA09B_ADC_AIN17 (1ul << 9)
  570. #define PIN_PA10B_ADC_AIN18 10L /**< \brief ADC signal: AIN18 on PA10 mux B */
  571. #define MUX_PA10B_ADC_AIN18 1L
  572. #define PINMUX_PA10B_ADC_AIN18 ((PIN_PA10B_ADC_AIN18 << 16) | MUX_PA10B_ADC_AIN18)
  573. #define PORT_PA10B_ADC_AIN18 (1ul << 10)
  574. #define PIN_PA11B_ADC_AIN19 11L /**< \brief ADC signal: AIN19 on PA11 mux B */
  575. #define MUX_PA11B_ADC_AIN19 1L
  576. #define PINMUX_PA11B_ADC_AIN19 ((PIN_PA11B_ADC_AIN19 << 16) | MUX_PA11B_ADC_AIN19)
  577. #define PORT_PA11B_ADC_AIN19 (1ul << 11)
  578. #define PIN_PA04B_ADC_VREFP 4L /**< \brief ADC signal: VREFP on PA04 mux B */
  579. #define MUX_PA04B_ADC_VREFP 1L
  580. #define PINMUX_PA04B_ADC_VREFP ((PIN_PA04B_ADC_VREFP << 16) | MUX_PA04B_ADC_VREFP)
  581. #define PORT_PA04B_ADC_VREFP (1ul << 4)
  582. /* ========== PORT definition for AC peripheral ========== */
  583. #define PIN_PA04B_AC_AIN0 4L /**< \brief AC signal: AIN0 on PA04 mux B */
  584. #define MUX_PA04B_AC_AIN0 1L
  585. #define PINMUX_PA04B_AC_AIN0 ((PIN_PA04B_AC_AIN0 << 16) | MUX_PA04B_AC_AIN0)
  586. #define PORT_PA04B_AC_AIN0 (1ul << 4)
  587. #define PIN_PA05B_AC_AIN1 5L /**< \brief AC signal: AIN1 on PA05 mux B */
  588. #define MUX_PA05B_AC_AIN1 1L
  589. #define PINMUX_PA05B_AC_AIN1 ((PIN_PA05B_AC_AIN1 << 16) | MUX_PA05B_AC_AIN1)
  590. #define PORT_PA05B_AC_AIN1 (1ul << 5)
  591. #define PIN_PA06B_AC_AIN2 6L /**< \brief AC signal: AIN2 on PA06 mux B */
  592. #define MUX_PA06B_AC_AIN2 1L
  593. #define PINMUX_PA06B_AC_AIN2 ((PIN_PA06B_AC_AIN2 << 16) | MUX_PA06B_AC_AIN2)
  594. #define PORT_PA06B_AC_AIN2 (1ul << 6)
  595. #define PIN_PA07B_AC_AIN3 7L /**< \brief AC signal: AIN3 on PA07 mux B */
  596. #define MUX_PA07B_AC_AIN3 1L
  597. #define PINMUX_PA07B_AC_AIN3 ((PIN_PA07B_AC_AIN3 << 16) | MUX_PA07B_AC_AIN3)
  598. #define PORT_PA07B_AC_AIN3 (1ul << 7)
  599. #define PIN_PA18H_AC_CMP0 18L /**< \brief AC signal: CMP0 on PA18 mux H */
  600. #define MUX_PA18H_AC_CMP0 7L
  601. #define PINMUX_PA18H_AC_CMP0 ((PIN_PA18H_AC_CMP0 << 16) | MUX_PA18H_AC_CMP0)
  602. #define PORT_PA18H_AC_CMP0 (1ul << 18)
  603. #define PIN_PA19H_AC_CMP1 19L /**< \brief AC signal: CMP1 on PA19 mux H */
  604. #define MUX_PA19H_AC_CMP1 7L
  605. #define PINMUX_PA19H_AC_CMP1 ((PIN_PA19H_AC_CMP1 << 16) | MUX_PA19H_AC_CMP1)
  606. #define PORT_PA19H_AC_CMP1 (1ul << 19)
  607. /* ========== PORT definition for DAC peripheral ========== */
  608. #define PIN_PA02B_DAC_VOUT 2L /**< \brief DAC signal: VOUT on PA02 mux B */
  609. #define MUX_PA02B_DAC_VOUT 1L
  610. #define PINMUX_PA02B_DAC_VOUT ((PIN_PA02B_DAC_VOUT << 16) | MUX_PA02B_DAC_VOUT)
  611. #define PORT_PA02B_DAC_VOUT (1ul << 2)
  612. #define PIN_PA03B_DAC_VREFP 3L /**< \brief DAC signal: VREFP on PA03 mux B */
  613. #define MUX_PA03B_DAC_VREFP 1L
  614. #define PINMUX_PA03B_DAC_VREFP ((PIN_PA03B_DAC_VREFP << 16) | MUX_PA03B_DAC_VREFP)
  615. #define PORT_PA03B_DAC_VREFP (1ul << 3)
  616. /* ========== PORT definition for I2S peripheral ========== */
  617. #define PIN_PA11G_I2S_FS0 11L /**< \brief I2S signal: FS0 on PA11 mux G */
  618. #define MUX_PA11G_I2S_FS0 6L
  619. #define PINMUX_PA11G_I2S_FS0 ((PIN_PA11G_I2S_FS0 << 16) | MUX_PA11G_I2S_FS0)
  620. #define PORT_PA11G_I2S_FS0 (1ul << 11)
  621. #define PIN_PA09G_I2S_MCK0 9L /**< \brief I2S signal: MCK0 on PA09 mux G */
  622. #define MUX_PA09G_I2S_MCK0 6L
  623. #define PINMUX_PA09G_I2S_MCK0 ((PIN_PA09G_I2S_MCK0 << 16) | MUX_PA09G_I2S_MCK0)
  624. #define PORT_PA09G_I2S_MCK0 (1ul << 9)
  625. #define PIN_PA10G_I2S_SCK0 10L /**< \brief I2S signal: SCK0 on PA10 mux G */
  626. #define MUX_PA10G_I2S_SCK0 6L
  627. #define PINMUX_PA10G_I2S_SCK0 ((PIN_PA10G_I2S_SCK0 << 16) | MUX_PA10G_I2S_SCK0)
  628. #define PORT_PA10G_I2S_SCK0 (1ul << 10)
  629. #define PIN_PA07G_I2S_SD0 7L /**< \brief I2S signal: SD0 on PA07 mux G */
  630. #define MUX_PA07G_I2S_SD0 6L
  631. #define PINMUX_PA07G_I2S_SD0 ((PIN_PA07G_I2S_SD0 << 16) | MUX_PA07G_I2S_SD0)
  632. #define PORT_PA07G_I2S_SD0 (1ul << 7)
  633. #define PIN_PA19G_I2S_SD0 19L /**< \brief I2S signal: SD0 on PA19 mux G */
  634. #define MUX_PA19G_I2S_SD0 6L
  635. #define PINMUX_PA19G_I2S_SD0 ((PIN_PA19G_I2S_SD0 << 16) | MUX_PA19G_I2S_SD0)
  636. #define PORT_PA19G_I2S_SD0 (1ul << 19)
  637. #define PIN_PA08G_I2S_SD1 8L /**< \brief I2S signal: SD1 on PA08 mux G */
  638. #define MUX_PA08G_I2S_SD1 6L
  639. #define PINMUX_PA08G_I2S_SD1 ((PIN_PA08G_I2S_SD1 << 16) | MUX_PA08G_I2S_SD1)
  640. #define PORT_PA08G_I2S_SD1 (1ul << 8)
  641. #endif /* _SAMD21E18A_PIO_ */