You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

292 lines
8.0 KiB

  1. /***************************************************************************
  2. * Copyright (C) 2006 by Anders Larsen *
  3. * al@alarsen.net *
  4. * *
  5. * This program is free software; you can redistribute it and/or modify *
  6. * it under the terms of the GNU General Public License as published by *
  7. * the Free Software Foundation; either version 2 of the License, or *
  8. * (at your option) any later version. *
  9. * *
  10. * This program is distributed in the hope that it will be useful, *
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of *
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
  13. * GNU General Public License for more details. *
  14. * *
  15. * You should have received a copy of the GNU General Public License *
  16. * along with this program; if not, write to the *
  17. * Free Software Foundation, Inc., *
  18. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
  19. ***************************************************************************/
  20. #ifdef HAVE_CONFIG_H
  21. #include "config.h"
  22. #endif
  23. #include "log.h"
  24. #include "jtag.h"
  25. #include "bitbang.h"
  26. /* system includes */
  27. #include <string.h>
  28. #include <stdlib.h>
  29. #include <stdio.h>
  30. #include <sys/mman.h>
  31. #include <unistd.h>
  32. #include <fcntl.h>
  33. /* AT91RM9200 */
  34. #define AT91C_BASE_SYS (0xfffff000)
  35. /* GPIO assignment */
  36. #define PIOA (0 << 7)
  37. #define PIOB (1 << 7)
  38. #define PIOC (2 << 7)
  39. #define PIOD (3 << 7)
  40. #define PIO_PER (0) /* PIO enable */
  41. #define PIO_OER (4) /* output enable */
  42. #define PIO_ODR (5) /* output disable */
  43. #define PIO_SODR (12) /* set output data */
  44. #define PIO_CODR (13) /* clear output data */
  45. #define PIO_PDSR (15) /* pin data status */
  46. #define PIO_PPUER (25) /* pull-up enable */
  47. #define NC (0) /* not connected */
  48. #define P0 (1 << 0)
  49. #define P1 (1 << 1)
  50. #define P2 (1 << 2)
  51. #define P3 (1 << 3)
  52. #define P4 (1 << 4)
  53. #define P5 (1 << 5)
  54. #define P6 (1 << 6)
  55. #define P7 (1 << 7)
  56. #define P8 (1 << 8)
  57. #define P9 (1 << 9)
  58. #define P10 (1 << 10)
  59. #define P11 (1 << 11)
  60. #define P12 (1 << 12)
  61. #define P13 (1 << 13)
  62. #define P14 (1 << 14)
  63. #define P15 (1 << 15)
  64. #define P16 (1 << 16)
  65. #define P17 (1 << 17)
  66. #define P18 (1 << 18)
  67. #define P19 (1 << 19)
  68. #define P20 (1 << 20)
  69. #define P21 (1 << 21)
  70. #define P22 (1 << 22)
  71. #define P23 (1 << 23)
  72. #define P24 (1 << 24)
  73. #define P25 (1 << 25)
  74. #define P26 (1 << 26)
  75. #define P27 (1 << 27)
  76. #define P28 (1 << 28)
  77. #define P29 (1 << 29)
  78. #define P30 (1 << 30)
  79. #define P31 (1 << 31)
  80. struct device_t
  81. {
  82. char* name;
  83. int TDO_PIO; /* PIO holding TDO */
  84. u32 TDO_MASK; /* TDO bitmask */
  85. int TRST_PIO; /* PIO holding TRST */
  86. u32 TRST_MASK; /* TRST bitmask */
  87. int TMS_PIO; /* PIO holding TMS */
  88. u32 TMS_MASK; /* TMS bitmask */
  89. int TCK_PIO; /* PIO holding TCK */
  90. u32 TCK_MASK; /* TCK bitmask */
  91. int TDI_PIO; /* PIO holding TDI */
  92. u32 TDI_MASK; /* TDI bitmask */
  93. int SRST_PIO; /* PIO holding SRST */
  94. u32 SRST_MASK; /* SRST bitmask */
  95. };
  96. struct device_t devices[] =
  97. {
  98. { "rea_ecr", PIOD, P27, PIOA, NC, PIOD, P23, PIOD, P24, PIOD, P26, PIOC, P5 },
  99. { NULL, 0 }
  100. };
  101. /* configuration */
  102. char* at91rm9200_device;
  103. /* interface variables
  104. */
  105. static struct device_t* device;
  106. static int dev_mem_fd;
  107. static void *sys_controller;
  108. static u32* pio_base;
  109. /* low level command set
  110. */
  111. int at91rm9200_read(void);
  112. void at91rm9200_write(int tck, int tms, int tdi);
  113. void at91rm9200_reset(int trst, int srst);
  114. int at91rm9200_speed(int speed);
  115. int at91rm9200_register_commands(struct command_context_s *cmd_ctx);
  116. int at91rm9200_init(void);
  117. int at91rm9200_quit(void);
  118. jtag_interface_t at91rm9200_interface =
  119. {
  120. .name = "at91rm9200",
  121. .execute_queue = bitbang_execute_queue,
  122. .speed = at91rm9200_speed,
  123. .register_commands = at91rm9200_register_commands,
  124. .init = at91rm9200_init,
  125. .quit = at91rm9200_quit,
  126. };
  127. bitbang_interface_t at91rm9200_bitbang =
  128. {
  129. .read = at91rm9200_read,
  130. .write = at91rm9200_write,
  131. .reset = at91rm9200_reset,
  132. .blink = 0
  133. };
  134. int at91rm9200_read(void)
  135. {
  136. return (pio_base[device->TDO_PIO + PIO_PDSR] & device->TDO_MASK) != 0;
  137. }
  138. void at91rm9200_write(int tck, int tms, int tdi)
  139. {
  140. if (tck)
  141. pio_base[device->TCK_PIO + PIO_SODR] = device->TCK_MASK;
  142. else
  143. pio_base[device->TCK_PIO + PIO_CODR] = device->TCK_MASK;
  144. if (tms)
  145. pio_base[device->TMS_PIO + PIO_SODR] = device->TMS_MASK;
  146. else
  147. pio_base[device->TMS_PIO + PIO_CODR] = device->TMS_MASK;
  148. if (tdi)
  149. pio_base[device->TDI_PIO + PIO_SODR] = device->TDI_MASK;
  150. else
  151. pio_base[device->TDI_PIO + PIO_CODR] = device->TDI_MASK;
  152. }
  153. /* (1) assert or (0) deassert reset lines */
  154. void at91rm9200_reset(int trst, int srst)
  155. {
  156. if (trst == 0)
  157. pio_base[device->TRST_PIO + PIO_SODR] = device->TRST_MASK;
  158. else if (trst == 1)
  159. pio_base[device->TRST_PIO + PIO_CODR] = device->TRST_MASK;
  160. if (srst == 0)
  161. pio_base[device->SRST_PIO + PIO_SODR] = device->SRST_MASK;
  162. else if (srst == 1)
  163. pio_base[device->SRST_PIO + PIO_CODR] = device->SRST_MASK;
  164. }
  165. int at91rm9200_speed(int speed)
  166. {
  167. return ERROR_OK;
  168. }
  169. int at91rm9200_handle_device_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc)
  170. {
  171. if (argc == 0)
  172. return ERROR_OK;
  173. /* only if the device name wasn't overwritten by cmdline */
  174. if (at91rm9200_device == 0)
  175. {
  176. at91rm9200_device = malloc(strlen(args[0]) + sizeof(char));
  177. strcpy(at91rm9200_device, args[0]);
  178. }
  179. return ERROR_OK;
  180. }
  181. int at91rm9200_register_commands(struct command_context_s *cmd_ctx)
  182. {
  183. register_command(cmd_ctx, NULL, "at91rm9200_device", at91rm9200_handle_device_command,
  184. COMMAND_CONFIG, NULL);
  185. return ERROR_OK;
  186. }
  187. int at91rm9200_init(void)
  188. {
  189. struct device_t *cur_device;
  190. cur_device = devices;
  191. if (at91rm9200_device == NULL || at91rm9200_device[0] == 0)
  192. {
  193. at91rm9200_device = "rea_ecr";
  194. LOG_WARNING("No at91rm9200 device specified, using default 'rea_ecr'");
  195. }
  196. while (cur_device->name)
  197. {
  198. if (strcmp(cur_device->name, at91rm9200_device) == 0)
  199. {
  200. device = cur_device;
  201. break;
  202. }
  203. cur_device++;
  204. }
  205. if (!device)
  206. {
  207. LOG_ERROR("No matching device found for %s", at91rm9200_device);
  208. return ERROR_JTAG_INIT_FAILED;
  209. }
  210. bitbang_interface = &at91rm9200_bitbang;
  211. dev_mem_fd = open("/dev/mem", O_RDWR | O_SYNC);
  212. if (dev_mem_fd < 0) {
  213. perror("open");
  214. return ERROR_JTAG_INIT_FAILED;
  215. }
  216. sys_controller = mmap(NULL, 4096, PROT_READ | PROT_WRITE,
  217. MAP_SHARED, dev_mem_fd, AT91C_BASE_SYS);
  218. if (sys_controller == MAP_FAILED) {
  219. perror("mmap");
  220. close(dev_mem_fd);
  221. return ERROR_JTAG_INIT_FAILED;
  222. }
  223. pio_base = (u32*)sys_controller + 0x100;
  224. /*
  225. * Configure TDO as an input, and TDI, TCK, TMS, TRST, SRST
  226. * as outputs. Drive TDI and TCK low, and TMS/TRST/SRST high.
  227. */
  228. pio_base[device->TDI_PIO + PIO_CODR] = device->TDI_MASK;
  229. pio_base[device->TDI_PIO + PIO_OER] = device->TDI_MASK;
  230. pio_base[device->TDI_PIO + PIO_PER] = device->TDI_MASK;
  231. pio_base[device->TCK_PIO + PIO_CODR] = device->TCK_MASK;
  232. pio_base[device->TCK_PIO + PIO_OER] = device->TCK_MASK;
  233. pio_base[device->TCK_PIO + PIO_PER] = device->TCK_MASK;
  234. pio_base[device->TMS_PIO + PIO_SODR] = device->TMS_MASK;
  235. pio_base[device->TMS_PIO + PIO_OER] = device->TMS_MASK;
  236. pio_base[device->TMS_PIO + PIO_PER] = device->TMS_MASK;
  237. pio_base[device->TRST_PIO + PIO_SODR] = device->TRST_MASK;
  238. pio_base[device->TRST_PIO + PIO_OER] = device->TRST_MASK;
  239. pio_base[device->TRST_PIO + PIO_PER] = device->TRST_MASK;
  240. pio_base[device->SRST_PIO + PIO_SODR] = device->SRST_MASK;
  241. pio_base[device->SRST_PIO + PIO_OER] = device->SRST_MASK;
  242. pio_base[device->SRST_PIO + PIO_PER] = device->SRST_MASK;
  243. pio_base[device->TDO_PIO + PIO_ODR] = device->TDO_MASK;
  244. pio_base[device->TDO_PIO + PIO_PPUER] = device->TDO_MASK;
  245. pio_base[device->TDO_PIO + PIO_PER] = device->TDO_MASK;
  246. return ERROR_OK;
  247. }
  248. int at91rm9200_quit(void)
  249. {
  250. return ERROR_OK;
  251. }