hal_config.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. // SPDX-License-Identifier: BSD-3-Clause
  2. // Copyright (c) 2017-2022, Alex Taradov <alex@taradov.com>. All rights reserved.
  3. #ifndef _HAL_CONFIG_H_
  4. #define _HAL_CONFIG_H_
  5. /*- Includes ----------------------------------------------------------------*/
  6. #include "samd11.h"
  7. #include "hal_gpio.h"
  8. /*- Definitions -------------------------------------------------------------*/
  9. #define HAL_BOARD_STD
  10. //#define HAL_BOARD_VCP_V1
  11. //#define HAL_BOARD_VCP_V3
  12. //#define HAL_BOARD_OBD
  13. #if defined(HAL_BOARD_CUSTOM)
  14. // Externally supplied board configuration takes precedence
  15. #include HAL_BOARD_CUSTOM
  16. #elif defined(HAL_BOARD_STD)
  17. #define DAP_CONFIG_ENABLE_JTAG
  18. HAL_GPIO_PIN(SWCLK_TCK, A, 14)
  19. HAL_GPIO_PIN(SWDIO_TMS, A, 15)
  20. HAL_GPIO_PIN(TDO, A, 9)
  21. HAL_GPIO_PIN(TDI, A, 8)
  22. HAL_GPIO_PIN(nRESET, A, 5)
  23. HAL_GPIO_PIN(DAP_STATUS, A, 4);
  24. HAL_GPIO_PIN(BOOT_ENTER, A, 31);
  25. #elif defined(HAL_BOARD_VCP_V1)
  26. #define HAL_CONFIG_ENABLE_VCP
  27. HAL_GPIO_PIN(SWCLK_TCK, A, 14)
  28. HAL_GPIO_PIN(SWDIO_TMS, A, 15)
  29. HAL_GPIO_PIN(nRESET, A, 9)
  30. HAL_GPIO_PIN(VCP_STATUS, A, 2);
  31. HAL_GPIO_PIN(DAP_STATUS, A, 4);
  32. HAL_GPIO_PIN(BOOT_ENTER, A, 31);
  33. HAL_GPIO_PIN(UART_TX, A, 8);
  34. HAL_GPIO_PIN(UART_RX, A, 5);
  35. #define UART_SERCOM SERCOM0
  36. #define UART_SERCOM_PMUX PORT_PMUX_PMUXE_D_Val
  37. #define UART_SERCOM_GCLK_ID SERCOM0_GCLK_ID_CORE
  38. #define UART_SERCOM_APBCMASK PM_APBCMASK_SERCOM0
  39. #define UART_SERCOM_IRQ_INDEX SERCOM0_IRQn
  40. #define UART_SERCOM_IRQ_HANDLER irq_handler_sercom0
  41. #define UART_SERCOM_TXPO 1
  42. #define UART_SERCOM_RXPO 1
  43. #elif defined(HAL_BOARD_VCP_V3)
  44. #define HAL_CONFIG_ENABLE_VCP
  45. #define DAP_CONFIG_ENABLE_JTAG
  46. HAL_GPIO_PIN(SWCLK_TCK, A, 9)
  47. HAL_GPIO_PIN(SWDIO_TMS, A, 8)
  48. HAL_GPIO_PIN(TDI, A, 14)
  49. HAL_GPIO_PIN(TDO, A, 10)
  50. HAL_GPIO_PIN(nRESET, A, 15)
  51. HAL_GPIO_PIN(VCP_STATUS, A, 3);
  52. HAL_GPIO_PIN(DAP_STATUS, A, 6);
  53. HAL_GPIO_PIN(BOOT_ENTER, A, 31);
  54. HAL_GPIO_PIN(UART_TX, A, 16);
  55. HAL_GPIO_PIN(UART_RX, A, 17);
  56. #define UART_SERCOM SERCOM1
  57. #define UART_SERCOM_PMUX PORT_PMUX_PMUXE_C_Val
  58. #define UART_SERCOM_GCLK_ID SERCOM1_GCLK_ID_CORE
  59. #define UART_SERCOM_APBCMASK PM_APBCMASK_SERCOM1
  60. #define UART_SERCOM_IRQ_INDEX SERCOM1_IRQn
  61. #define UART_SERCOM_IRQ_HANDLER irq_handler_sercom1
  62. #define UART_SERCOM_TXPO 1
  63. #define UART_SERCOM_RXPO 3
  64. #elif defined(HAL_BOARD_OBD)
  65. #define HAL_CONFIG_ENABLE_VCP
  66. HAL_GPIO_PIN(SWCLK_TCK, A, 9)
  67. HAL_GPIO_PIN(SWDIO_TMS, A, 14)
  68. HAL_GPIO_PIN(nRESET, A, 15)
  69. HAL_GPIO_PIN(VCP_STATUS, A, 2);
  70. HAL_GPIO_PIN(DAP_STATUS, A, 4);
  71. HAL_GPIO_PIN(BOOT_ENTER, A, 31);
  72. HAL_GPIO_PIN(UART_TX, A, 8);
  73. HAL_GPIO_PIN(UART_RX, A, 5);
  74. #define UART_SERCOM SERCOM0
  75. #define UART_SERCOM_PMUX PORT_PMUX_PMUXE_D_Val
  76. #define UART_SERCOM_GCLK_ID SERCOM0_GCLK_ID_CORE
  77. #define UART_SERCOM_APBCMASK PM_APBCMASK_SERCOM0
  78. #define UART_SERCOM_IRQ_INDEX SERCOM0_IRQn
  79. #define UART_SERCOM_IRQ_HANDLER irq_handler_sercom0
  80. #define UART_SERCOM_TXPO 1
  81. #define UART_SERCOM_RXPO 1
  82. #else
  83. #error No board defined
  84. #endif
  85. #endif // _HAL_CONFIG_H_