dap_config.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. // SPDX-License-Identifier: BSD-3-Clause
  2. // Copyright (c) 2020-2022, Alex Taradov <alex@taradov.com>. All rights reserved.
  3. #ifndef _DAP_CONFIG_H_
  4. #define _DAP_CONFIG_H_
  5. /*- Includes ----------------------------------------------------------------*/
  6. #include "same70.h"
  7. #include "hal_gpio.h"
  8. /*- Definitions -------------------------------------------------------------*/
  9. HAL_GPIO_PIN(SWCLK_TCK, D, 20)
  10. HAL_GPIO_PIN(SWDIO_TMS, D, 21)
  11. HAL_GPIO_PIN(nRESET, D, 22)
  12. //#define DAP_CONFIG_ENABLE_JTAG
  13. #define DAP_CONFIG_DEFAULT_PORT DAP_PORT_SWD
  14. #define DAP_CONFIG_DEFAULT_CLOCK 1000000 // Hz
  15. #define DAP_CONFIG_PACKET_SIZE 1024
  16. #define DAP_CONFIG_PACKET_COUNT 16
  17. #define DAP_CONFIG_JTAG_DEV_COUNT 8
  18. // DAP_CONFIG_PRODUCT_STR must contain "CMSIS-DAP" to be compatible with the standard
  19. #define DAP_CONFIG_VENDOR_STR "Alex Taradov"
  20. #define DAP_CONFIG_PRODUCT_STR "Generic CMSIS-DAP Adapter"
  21. #define DAP_CONFIG_SER_NUM_STR usb_serial_number
  22. #define DAP_CONFIG_CMSIS_DAP_VER_STR "1.3.0"
  23. //#define DAP_CONFIG_RESET_TARGET_FN target_specific_reset_function
  24. //#define DAP_CONFIG_VENDOR_FN vendor_command_handler_function
  25. // Attribute to use for performance-critical functions
  26. #define DAP_CONFIG_PERFORMANCE_ATTR __attribute__((section(".ramfunc")))
  27. // A value at which dap_clock_test() produces 1 kHz output on the SWCLK pin
  28. #define DAP_CONFIG_DELAY_CONSTANT 75000
  29. // A threshold for switching to fast clock (no added delays)
  30. // This is the frequency produced by dap_clock_test(1) on the SWCLK pin
  31. #define DAP_CONFIG_FAST_CLOCK 16000000 // Hz
  32. /*- Prototypes --------------------------------------------------------------*/
  33. extern char usb_serial_number[16];
  34. /*- Implementations ---------------------------------------------------------*/
  35. //-----------------------------------------------------------------------------
  36. static inline void DAP_CONFIG_SWCLK_TCK_write(int value)
  37. {
  38. HAL_GPIO_SWCLK_TCK_write(value);
  39. }
  40. //-----------------------------------------------------------------------------
  41. static inline void DAP_CONFIG_SWDIO_TMS_write(int value)
  42. {
  43. HAL_GPIO_SWDIO_TMS_write(value);
  44. }
  45. //-----------------------------------------------------------------------------
  46. static inline void DAP_CONFIG_TDI_write(int value)
  47. {
  48. (void)value;
  49. }
  50. //-----------------------------------------------------------------------------
  51. static inline void DAP_CONFIG_TDO_write(int value)
  52. {
  53. (void)value;
  54. }
  55. //-----------------------------------------------------------------------------
  56. static inline void DAP_CONFIG_nTRST_write(int value)
  57. {
  58. (void)value;
  59. }
  60. //-----------------------------------------------------------------------------
  61. static inline void DAP_CONFIG_nRESET_write(int value)
  62. {
  63. HAL_GPIO_nRESET_write(value);
  64. }
  65. //-----------------------------------------------------------------------------
  66. static inline int DAP_CONFIG_SWCLK_TCK_read(void)
  67. {
  68. return HAL_GPIO_SWCLK_TCK_read();
  69. }
  70. //-----------------------------------------------------------------------------
  71. static inline int DAP_CONFIG_SWDIO_TMS_read(void)
  72. {
  73. return HAL_GPIO_SWDIO_TMS_read();
  74. }
  75. //-----------------------------------------------------------------------------
  76. static inline int DAP_CONFIG_TDI_read(void)
  77. {
  78. return 0;
  79. }
  80. //-----------------------------------------------------------------------------
  81. static inline int DAP_CONFIG_TDO_read(void)
  82. {
  83. return 0;
  84. }
  85. //-----------------------------------------------------------------------------
  86. static inline int DAP_CONFIG_nTRST_read(void)
  87. {
  88. return 0;
  89. }
  90. //-----------------------------------------------------------------------------
  91. static inline int DAP_CONFIG_nRESET_read(void)
  92. {
  93. return HAL_GPIO_nRESET_read();
  94. }
  95. //-----------------------------------------------------------------------------
  96. static inline void DAP_CONFIG_SWCLK_TCK_set(void)
  97. {
  98. HAL_GPIO_SWCLK_TCK_set();
  99. }
  100. //-----------------------------------------------------------------------------
  101. static inline void DAP_CONFIG_SWCLK_TCK_clr(void)
  102. {
  103. HAL_GPIO_SWCLK_TCK_clr();
  104. }
  105. //-----------------------------------------------------------------------------
  106. static inline void DAP_CONFIG_SWDIO_TMS_in(void)
  107. {
  108. HAL_GPIO_SWDIO_TMS_in();
  109. }
  110. //-----------------------------------------------------------------------------
  111. static inline void DAP_CONFIG_SWDIO_TMS_out(void)
  112. {
  113. HAL_GPIO_SWDIO_TMS_out();
  114. }
  115. //-----------------------------------------------------------------------------
  116. static inline void DAP_CONFIG_SETUP(void)
  117. {
  118. HAL_GPIO_SWCLK_TCK_in();
  119. HAL_GPIO_SWDIO_TMS_in();
  120. HAL_GPIO_nRESET_in();
  121. HAL_GPIO_SWDIO_TMS_pullup();
  122. }
  123. //-----------------------------------------------------------------------------
  124. static inline void DAP_CONFIG_DISCONNECT(void)
  125. {
  126. HAL_GPIO_SWCLK_TCK_in();
  127. HAL_GPIO_SWDIO_TMS_in();
  128. HAL_GPIO_nRESET_in();
  129. }
  130. //-----------------------------------------------------------------------------
  131. static inline void DAP_CONFIG_CONNECT_SWD(void)
  132. {
  133. HAL_GPIO_SWDIO_TMS_out();
  134. HAL_GPIO_SWDIO_TMS_set();
  135. HAL_GPIO_SWCLK_TCK_out();
  136. HAL_GPIO_SWCLK_TCK_set();
  137. HAL_GPIO_nRESET_out();
  138. HAL_GPIO_nRESET_set();
  139. }
  140. //-----------------------------------------------------------------------------
  141. static inline void DAP_CONFIG_CONNECT_JTAG(void)
  142. {
  143. HAL_GPIO_SWDIO_TMS_out();
  144. HAL_GPIO_SWDIO_TMS_set();
  145. HAL_GPIO_SWCLK_TCK_out();
  146. HAL_GPIO_SWCLK_TCK_set();
  147. HAL_GPIO_nRESET_out();
  148. HAL_GPIO_nRESET_set();
  149. }
  150. //-----------------------------------------------------------------------------
  151. static inline void DAP_CONFIG_LED(int index, int state)
  152. {
  153. (void)index;
  154. (void)state;
  155. }
  156. //-----------------------------------------------------------------------------
  157. __attribute__((always_inline))
  158. static inline void DAP_CONFIG_DELAY(uint32_t cycles)
  159. {
  160. asm volatile (
  161. "1: subs %[cycles], %[cycles], #1 \n"
  162. " bne 1b \n"
  163. : [cycles] "+l"(cycles)
  164. );
  165. }
  166. #endif // _DAP_CONFIG_H_