driver_init.c 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /*
  2. * Code generated from Atmel Start.
  3. *
  4. * This file will be overwritten when reconfiguring your Atmel Start project.
  5. * Please copy examples or other code you want to keep to a separate file
  6. * to avoid losing it when reconfiguring.
  7. */
  8. #include "driver_init.h"
  9. #include <peripheral_clk_config.h>
  10. #include <utils.h>
  11. #include <hal_init.h>
  12. #include <hpl_adc_base.h>
  13. /*! The buffer size for USART */
  14. #define TARGET_IO_BUFFER_SIZE 16
  15. struct aes_sync_descriptor CRYPTOGRAPHY_0;
  16. struct usart_async_descriptor TARGET_IO;
  17. struct can_async_descriptor CAN_0;
  18. static uint8_t TARGET_IO_buffer[TARGET_IO_BUFFER_SIZE];
  19. struct adc_sync_descriptor ADC_0;
  20. struct i2c_m_sync_desc I2C_0;
  21. struct mac_async_descriptor MACIF;
  22. void ADC_0_PORT_init(void)
  23. {
  24. // Disable digital pin circuitry
  25. gpio_set_pin_direction(PA02, GPIO_DIRECTION_OFF);
  26. gpio_set_pin_function(PA02, PINMUX_PA02B_ADC0_AIN0);
  27. }
  28. void ADC_0_CLOCK_init(void)
  29. {
  30. hri_mclk_set_APBDMASK_ADC0_bit(MCLK);
  31. hri_gclk_write_PCHCTRL_reg(GCLK, ADC0_GCLK_ID, CONF_GCLK_ADC0_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  32. }
  33. void ADC_0_init(void)
  34. {
  35. ADC_0_CLOCK_init();
  36. ADC_0_PORT_init();
  37. adc_sync_init(&ADC_0, ADC0, (void *)NULL);
  38. }
  39. /**
  40. * \brief AES initialization function
  41. *
  42. * Enables AES peripheral, clocks and initializes AES driver
  43. */
  44. void CRYPTOGRAPHY_0_init(void)
  45. {
  46. hri_mclk_set_APBCMASK_AES_bit(MCLK);
  47. aes_sync_init(&CRYPTOGRAPHY_0, AES);
  48. }
  49. /**
  50. * \brief USART Clock initialization function
  51. *
  52. * Enables register interface and peripheral clock
  53. */
  54. void TARGET_IO_CLOCK_init()
  55. {
  56. hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM2_GCLK_ID_CORE, CONF_GCLK_SERCOM2_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  57. hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM2_GCLK_ID_SLOW, CONF_GCLK_SERCOM2_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  58. hri_mclk_set_APBBMASK_SERCOM2_bit(MCLK);
  59. }
  60. /**
  61. * \brief USART pinmux initialization function
  62. *
  63. * Set each required pin to USART functionality
  64. */
  65. void TARGET_IO_PORT_init()
  66. {
  67. gpio_set_pin_function(PB25, PINMUX_PB25D_SERCOM2_PAD0);
  68. gpio_set_pin_function(PB24, PINMUX_PB24D_SERCOM2_PAD1);
  69. }
  70. /**
  71. * \brief USART initialization function
  72. *
  73. * Enables USART peripheral, clocks and initializes USART driver
  74. */
  75. void TARGET_IO_init(void)
  76. {
  77. TARGET_IO_CLOCK_init();
  78. usart_async_init(&TARGET_IO, SERCOM2, TARGET_IO_buffer, TARGET_IO_BUFFER_SIZE, (void *)NULL);
  79. TARGET_IO_PORT_init();
  80. }
  81. void I2C_0_PORT_init(void)
  82. {
  83. gpio_set_pin_pull_mode(PD08,
  84. // <y> Pull configuration
  85. // <id> pad_pull_config
  86. // <GPIO_PULL_OFF"> Off
  87. // <GPIO_PULL_UP"> Pull-up
  88. // <GPIO_PULL_DOWN"> Pull-down
  89. GPIO_PULL_OFF);
  90. gpio_set_pin_function(PD08, PINMUX_PD08C_SERCOM7_PAD0);
  91. gpio_set_pin_pull_mode(PD09,
  92. // <y> Pull configuration
  93. // <id> pad_pull_config
  94. // <GPIO_PULL_OFF"> Off
  95. // <GPIO_PULL_UP"> Pull-up
  96. // <GPIO_PULL_DOWN"> Pull-down
  97. GPIO_PULL_OFF);
  98. gpio_set_pin_function(PD09, PINMUX_PD09C_SERCOM7_PAD1);
  99. }
  100. void I2C_0_CLOCK_init(void)
  101. {
  102. hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM7_GCLK_ID_CORE, CONF_GCLK_SERCOM7_CORE_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  103. hri_gclk_write_PCHCTRL_reg(GCLK, SERCOM7_GCLK_ID_SLOW, CONF_GCLK_SERCOM7_SLOW_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  104. hri_mclk_set_APBDMASK_SERCOM7_bit(MCLK);
  105. }
  106. void I2C_0_init(void)
  107. {
  108. I2C_0_CLOCK_init();
  109. i2c_m_sync_init(&I2C_0, SERCOM7);
  110. I2C_0_PORT_init();
  111. }
  112. void CAN_0_PORT_init(void)
  113. {
  114. gpio_set_pin_function(PB13, PINMUX_PB13H_CAN1_RX);
  115. gpio_set_pin_function(PB12, PINMUX_PB12H_CAN1_TX);
  116. }
  117. /**
  118. * \brief CAN initialization function
  119. *
  120. * Enables CAN peripheral, clocks and initializes CAN driver
  121. */
  122. void CAN_0_init(void)
  123. {
  124. hri_mclk_set_AHBMASK_CAN1_bit(MCLK);
  125. hri_gclk_write_PCHCTRL_reg(GCLK, CAN1_GCLK_ID, CONF_GCLK_CAN1_SRC | (1 << GCLK_PCHCTRL_CHEN_Pos));
  126. can_async_init(&CAN_0, CAN1);
  127. CAN_0_PORT_init();
  128. }
  129. void MACIF_PORT_init(void)
  130. {
  131. gpio_set_pin_function(PC11, PINMUX_PC11L_GMAC_GMDC);
  132. gpio_set_pin_function(PC12, PINMUX_PC12L_GMAC_GMDIO);
  133. gpio_set_pin_function(PA13, PINMUX_PA13L_GMAC_GRX0);
  134. gpio_set_pin_function(PA12, PINMUX_PA12L_GMAC_GRX1);
  135. gpio_set_pin_function(PC20, PINMUX_PC20L_GMAC_GRXDV);
  136. gpio_set_pin_function(PA15, PINMUX_PA15L_GMAC_GRXER);
  137. gpio_set_pin_function(PA18, PINMUX_PA18L_GMAC_GTX0);
  138. gpio_set_pin_function(PA19, PINMUX_PA19L_GMAC_GTX1);
  139. gpio_set_pin_function(PA14, PINMUX_PA14L_GMAC_GTXCK);
  140. gpio_set_pin_function(PA17, PINMUX_PA17L_GMAC_GTXEN);
  141. }
  142. void MACIF_CLOCK_init(void)
  143. {
  144. hri_mclk_set_AHBMASK_GMAC_bit(MCLK);
  145. hri_mclk_set_APBCMASK_GMAC_bit(MCLK);
  146. }
  147. void MACIF_init(void)
  148. {
  149. MACIF_CLOCK_init();
  150. mac_async_init(&MACIF, GMAC);
  151. MACIF_PORT_init();
  152. }
  153. void MACIF_example(void)
  154. {
  155. mac_async_enable(&MACIF);
  156. mac_async_write(&MACIF, (uint8_t *)"Hello World!", 12);
  157. }
  158. void system_init(void)
  159. {
  160. init_mcu();
  161. // GPIO on PC18
  162. gpio_set_pin_level(LED0,
  163. // <y> Initial level
  164. // <id> pad_initial_level
  165. // <false"> Low
  166. // <true"> High
  167. false);
  168. // Set pin direction to output
  169. gpio_set_pin_direction(LED0, GPIO_DIRECTION_OUT);
  170. gpio_set_pin_function(LED0, GPIO_PIN_FUNCTION_OFF);
  171. ADC_0_init();
  172. CRYPTOGRAPHY_0_init();
  173. TARGET_IO_init();
  174. I2C_0_init();
  175. CAN_0_init();
  176. MACIF_init();
  177. }