OpenOCD
jtag/drivers/driver.c
Go to the documentation of this file.
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 
3 /***************************************************************************
4  * Copyright (C) 2005 by Dominic Rath *
5  * Dominic.Rath@gmx.de *
6  * *
7  * Copyright (C) 2007-2010 Øyvind Harboe *
8  * oyvind.harboe@zylin.com *
9  * *
10  * Copyright (C) 2009 SoftPLC Corporation *
11  * http://softplc.com *
12  * dick@softplc.com *
13  * *
14  * Copyright (C) 2009 Zachary T Welch *
15  * zw@superlucidity.net *
16  ***************************************************************************/
17 
18 #ifdef HAVE_CONFIG_H
19 #include "config.h"
20 #endif
21 
22 #include <jtag/jtag.h>
23 #include <jtag/interface.h>
24 #include <jtag/commands.h>
25 #include <jtag/minidriver.h>
26 #include <helper/command.h>
27 
30 
36 };
37 
40 
41 static void jtag_callback_queue_reset(void)
42 {
45 }
46 
52  const struct scan_field *in_fields, tap_state_t state)
53 {
54  size_t num_taps = jtag_tap_count_enabled();
55 
56  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
57  struct scan_command *scan = cmd_queue_alloc(sizeof(struct scan_command));
58  struct scan_field *out_fields = cmd_queue_alloc(num_taps * sizeof(struct scan_field));
59 
61 
62  cmd->type = JTAG_SCAN;
63  cmd->cmd.scan = scan;
64 
65  scan->ir_scan = true;
66  scan->num_fields = num_taps; /* one field per device */
67  scan->fields = out_fields;
68  scan->end_state = state;
69 
70  struct scan_field *field = out_fields; /* keep track where we insert data */
71 
72  /* loop over all enabled TAPs */
73 
74  for (struct jtag_tap *tap = jtag_tap_next_enabled(NULL); tap; tap = jtag_tap_next_enabled(tap)) {
75  /* search the input field list for fields for the current TAP */
76 
77  if (tap == active) {
78  /* if TAP is listed in input fields, copy the value */
79  tap->bypass = false;
80 
81  jtag_scan_field_clone(field, in_fields);
82  } else {
83  /* if a TAP isn't listed in input fields, set it to BYPASS */
84 
85  tap->bypass = true;
86 
87  field->num_bits = tap->ir_length;
88  if (tap->ir_bypass_value) {
89  uint8_t *v = cmd_queue_alloc(DIV_ROUND_UP(tap->ir_length, 8));
90  buf_set_u64(v, 0, tap->ir_length, tap->ir_bypass_value);
91  field->out_value = v;
92  } else {
93  field->out_value = buf_set_ones(cmd_queue_alloc(DIV_ROUND_UP(tap->ir_length, 8)), tap->ir_length);
94  }
95  field->in_value = NULL; /* do not collect input for tap's in bypass */
96  }
97 
98  /* update device information */
99  buf_cpy(field->out_value, tap->cur_instr, tap->ir_length);
100 
101  field++;
102  }
103  /* paranoia: jtag_tap_count_enabled() and jtag_tap_next_enabled() not in sync */
104  assert(field == out_fields + num_taps);
105 
106  return ERROR_OK;
107 }
108 
113 int interface_jtag_add_dr_scan(struct jtag_tap *active, int in_num_fields,
114  const struct scan_field *in_fields, tap_state_t state)
115 {
116  /* count devices in bypass */
117 
118  size_t bypass_devices = 0;
119  size_t all_devices = 0;
120 
121  for (struct jtag_tap *tap = jtag_tap_next_enabled(NULL); tap; tap = jtag_tap_next_enabled(tap)) {
122  all_devices++;
123 
124  if (tap->bypass)
125  bypass_devices++;
126  }
127 
128  if (all_devices == bypass_devices) {
129  LOG_ERROR("At least one TAP shouldn't be in BYPASS mode");
130 
131  return ERROR_FAIL;
132  }
133 
134  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
135  struct scan_command *scan = cmd_queue_alloc(sizeof(struct scan_command));
136  struct scan_field *out_fields = cmd_queue_alloc((in_num_fields + bypass_devices) * sizeof(struct scan_field));
137 
139 
140  cmd->type = JTAG_SCAN;
141  cmd->cmd.scan = scan;
142 
143  scan->ir_scan = false;
144  scan->num_fields = in_num_fields + bypass_devices;
145  scan->fields = out_fields;
146  scan->end_state = state;
147 
148  struct scan_field *field = out_fields; /* keep track where we insert data */
149 
150  /* loop over all enabled TAPs */
151 
152  for (struct jtag_tap *tap = jtag_tap_next_enabled(NULL); tap; tap = jtag_tap_next_enabled(tap)) {
153  /* if TAP is not bypassed insert matching input fields */
154 
155  if (!tap->bypass) {
156  assert(active == tap);
157 #ifndef NDEBUG
158  /* remember initial position for assert() */
159  struct scan_field *start_field = field;
160 #endif /* NDEBUG */
161 
162  for (int j = 0; j < in_num_fields; j++) {
163  jtag_scan_field_clone(field, in_fields + j);
164 
165  field++;
166  }
167 
168  assert(field > start_field); /* must have at least one input field per not bypassed TAP */
169  }
170 
171  /* if a TAP is bypassed, generated a dummy bit*/
172  else {
173  field->num_bits = 1;
174  field->out_value = NULL;
175  field->in_value = NULL;
176 
177  field++;
178  }
179  }
180 
181  assert(field == out_fields + scan->num_fields); /* no superfluous input fields permitted */
182 
183  return ERROR_OK;
184 }
185 
186 static int jtag_add_plain_scan(int num_bits, const uint8_t *out_bits,
187  uint8_t *in_bits, tap_state_t state, bool ir_scan)
188 {
189  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
190  struct scan_command *scan = cmd_queue_alloc(sizeof(struct scan_command));
191  struct scan_field *out_fields = cmd_queue_alloc(sizeof(struct scan_field));
192 
194 
195  cmd->type = JTAG_SCAN;
196  cmd->cmd.scan = scan;
197 
198  scan->ir_scan = ir_scan;
199  scan->num_fields = 1;
200  scan->fields = out_fields;
201  scan->end_state = state;
202 
203  out_fields->num_bits = num_bits;
204  out_fields->out_value = buf_cpy(out_bits, cmd_queue_alloc(DIV_ROUND_UP(num_bits, 8)), num_bits);
205  out_fields->in_value = in_bits;
206 
207  return ERROR_OK;
208 }
209 
210 int interface_jtag_add_plain_dr_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, tap_state_t state)
211 {
212  return jtag_add_plain_scan(num_bits, out_bits, in_bits, state, false);
213 }
214 
215 int interface_jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, tap_state_t state)
216 {
217  return jtag_add_plain_scan(num_bits, out_bits, in_bits, state, true);
218 }
219 
221 {
223 
224  /* allocate memory for a new list member */
225  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
226 
228 
229  cmd->type = JTAG_TLR_RESET;
230 
231  cmd->cmd.statemove = cmd_queue_alloc(sizeof(struct statemove_command));
232  cmd->cmd.statemove->end_state = state;
233 
234  return ERROR_OK;
235 }
236 
237 int interface_add_tms_seq(unsigned int num_bits, const uint8_t *seq, enum tap_state state)
238 {
239  struct jtag_command *cmd;
240 
241  cmd = cmd_queue_alloc(sizeof(struct jtag_command));
242  if (!cmd)
243  return ERROR_FAIL;
244 
245  cmd->type = JTAG_TMS;
246  cmd->cmd.tms = cmd_queue_alloc(sizeof(*cmd->cmd.tms));
247  if (!cmd->cmd.tms)
248  return ERROR_FAIL;
249 
250  /* copy the bits; our caller doesn't guarantee they'll persist */
251  cmd->cmd.tms->num_bits = num_bits;
252  cmd->cmd.tms->bits = buf_cpy(seq,
253  cmd_queue_alloc(DIV_ROUND_UP(num_bits, 8)), num_bits);
254  if (!cmd->cmd.tms->bits)
255  return ERROR_FAIL;
256 
258 
259  return ERROR_OK;
260 }
261 
262 int interface_jtag_add_pathmove(unsigned int num_states, const tap_state_t *path)
263 {
264  /* allocate memory for a new list member */
265  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
266 
268 
269  cmd->type = JTAG_PATHMOVE;
270 
271  cmd->cmd.pathmove = cmd_queue_alloc(sizeof(struct pathmove_command));
272  cmd->cmd.pathmove->num_states = num_states;
273  cmd->cmd.pathmove->path = cmd_queue_alloc(sizeof(tap_state_t) * num_states);
274 
275  for (unsigned int i = 0; i < num_states; i++)
276  cmd->cmd.pathmove->path[i] = path[i];
277 
278  return ERROR_OK;
279 }
280 
281 int interface_jtag_add_runtest(unsigned int num_cycles, tap_state_t state)
282 {
283  /* allocate memory for a new list member */
284  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
285 
287 
288  cmd->type = JTAG_RUNTEST;
289 
290  cmd->cmd.runtest = cmd_queue_alloc(sizeof(struct runtest_command));
291  cmd->cmd.runtest->num_cycles = num_cycles;
292  cmd->cmd.runtest->end_state = state;
293 
294  return ERROR_OK;
295 }
296 
297 int interface_jtag_add_clocks(unsigned int num_cycles)
298 {
299  /* allocate memory for a new list member */
300  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
301 
303 
304  cmd->type = JTAG_STABLECLOCKS;
305 
306  cmd->cmd.stableclocks = cmd_queue_alloc(sizeof(struct stableclocks_command));
307  cmd->cmd.stableclocks->num_cycles = num_cycles;
308 
309  return ERROR_OK;
310 }
311 
312 int interface_jtag_add_reset(int req_trst, int req_srst)
313 {
314  /* allocate memory for a new list member */
315  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
316 
318 
319  cmd->type = JTAG_RESET;
320 
321  cmd->cmd.reset = cmd_queue_alloc(sizeof(struct reset_command));
322  cmd->cmd.reset->trst = req_trst;
323  cmd->cmd.reset->srst = req_srst;
324 
325  return ERROR_OK;
326 }
327 
328 int interface_jtag_add_sleep(uint32_t us)
329 {
330  /* allocate memory for a new list member */
331  struct jtag_command *cmd = cmd_queue_alloc(sizeof(struct jtag_command));
332 
334 
335  cmd->type = JTAG_SLEEP;
336 
337  cmd->cmd.sleep = cmd_queue_alloc(sizeof(struct sleep_command));
338  cmd->cmd.sleep->us = us;
339 
340  return ERROR_OK;
341 }
342 
343 /* add callback to end of queue */
347 {
348  struct jtag_callback_entry *entry = cmd_queue_alloc(sizeof(struct jtag_callback_entry));
349 
350  entry->next = NULL;
351  entry->callback = callback;
352  entry->data0 = data0;
353  entry->data1 = data1;
354  entry->data2 = data2;
355  entry->data3 = data3;
356 
358  jtag_callback_queue_head = entry;
359  jtag_callback_queue_tail = entry;
360  } else {
362  jtag_callback_queue_tail = entry;
363  }
364 }
365 
367 {
368  static int reentry;
369 
370  assert(reentry == 0);
371  reentry++;
372 
374  if (retval == ERROR_OK) {
375  struct jtag_callback_entry *entry;
376  for (entry = jtag_callback_queue_head; entry; entry = entry->next) {
377  retval = entry->callback(entry->data0, entry->data1, entry->data2, entry->data3);
378  if (retval != ERROR_OK)
379  break;
380  }
381  }
382 
385 
386  reentry--;
387 
388  return retval;
389 }
390 
393 {
395  return ERROR_OK;
396 }
397 
399 {
401 }
402 
404 {
406 }
407 
411 {
413 }
void * buf_set_ones(void *_buf, unsigned int size)
Set the contents of buf with count bits, all set to 1.
Definition: binarybuffer.c:105
void * buf_cpy(const void *from, void *_to, unsigned int size)
Copies size bits out of from and into to.
Definition: binarybuffer.c:43
static void buf_set_u64(uint8_t *_buffer, unsigned int first, unsigned int num, uint64_t value)
Sets num bits in _buffer, starting at the first bit, using the bits in value.
Definition: binarybuffer.h:65
void jtag_queue_command(struct jtag_command *cmd)
Definition: commands.c:39
void jtag_scan_field_clone(struct scan_field *dst, const struct scan_field *src)
Copy a struct scan_field for insertion into the queue.
Definition: commands.c:160
void jtag_command_queue_reset(void)
Definition: commands.c:142
void * cmd_queue_alloc(size_t size)
Definition: commands.c:66
@ JTAG_TLR_RESET
Definition: commands.h:137
@ JTAG_SCAN
Definition: commands.h:129
@ JTAG_PATHMOVE
Definition: commands.h:140
@ JTAG_STABLECLOCKS
Definition: commands.h:142
@ JTAG_RUNTEST
Definition: commands.h:138
@ JTAG_SLEEP
Definition: commands.h:141
@ JTAG_RESET
Definition: commands.h:139
@ JTAG_TMS
Definition: commands.h:143
unsigned int jtag_tap_count_enabled(void)
Definition: jtag/core.c:206
struct jtag_tap * jtag_tap_next_enabled(struct jtag_tap *p)
Definition: jtag/core.c:271
int default_interface_jtag_execute_queue(void)
Calls the interface callback to execute the queue.
Definition: jtag/core.c:938
int interface_jtag_add_plain_dr_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, tap_state_t state)
int interface_jtag_execute_queue(void)
int interface_jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, tap_state_t state)
static void interface_jtag_add_callback4(jtag_callback_t callback, jtag_callback_data_t data0, jtag_callback_data_t data1, jtag_callback_data_t data2, jtag_callback_data_t data3)
int interface_jtag_add_pathmove(unsigned int num_states, const tap_state_t *path)
void jtag_add_callback4(jtag_callback_t f, jtag_callback_data_t data0, jtag_callback_data_t data1, jtag_callback_data_t data2, jtag_callback_data_t data3)
void jtag_add_callback(jtag_callback1_t f, jtag_callback_data_t data0)
A simpler version of jtag_add_callback4().
static struct jtag_callback_entry * jtag_callback_queue_head
int interface_jtag_add_dr_scan(struct jtag_tap *active, int in_num_fields, const struct scan_field *in_fields, tap_state_t state)
see jtag_add_dr_scan()
static void jtag_callback_queue_reset(void)
int interface_add_tms_seq(unsigned int num_bits, const uint8_t *seq, enum tap_state state)
int interface_jtag_add_reset(int req_trst, int req_srst)
This drives the actual srst and trst pins.
int interface_jtag_add_ir_scan(struct jtag_tap *active, const struct scan_field *in_fields, tap_state_t state)
see jtag_add_ir_scan()
static void interface_jtag_add_callback(jtag_callback1_t callback, jtag_callback_data_t data0)
static int jtag_add_plain_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, tap_state_t state, bool ir_scan)
static struct jtag_callback_entry * jtag_callback_queue_tail
int interface_jtag_add_sleep(uint32_t us)
int interface_jtag_add_clocks(unsigned int num_cycles)
static int jtag_convert_to_callback4(jtag_callback_data_t data0, jtag_callback_data_t data1, jtag_callback_data_t data2, jtag_callback_data_t data3)
int interface_jtag_add_runtest(unsigned int num_cycles, tap_state_t state)
int interface_jtag_add_tlr(void)
The JTAG interface can be implemented with a software or hardware fifo.
int(* jtag_callback_t)(jtag_callback_data_t data0, jtag_callback_data_t data1, jtag_callback_data_t data2, jtag_callback_data_t data3)
Defines the interface of the JTAG callback mechanism.
Definition: jtag.h:379
tap_state
Defines JTAG Test Access Port states.
Definition: jtag.h:37
@ TAP_RESET
Definition: jtag.h:56
enum tap_state tap_state_t
Defines JTAG Test Access Port states.
intptr_t jtag_callback_data_t
Defines the type of data passed to the jtag_callback_t interface.
Definition: jtag.h:336
void(* jtag_callback1_t)(jtag_callback_data_t data0)
Defines a simple JTAG callback that can allow conversions on data scanned in from an interface.
Definition: jtag.h:346
static struct scan_blk scan
Definition: lakemont.c:60
#define ERROR_FAIL
Definition: log.h:173
#define LOG_ERROR(expr ...)
Definition: log.h:132
#define ERROR_OK
Definition: log.h:167
struct jtag_callback_entry * next
jtag_callback_data_t data1
jtag_callback_t callback
jtag_callback_data_t data0
jtag_callback_data_t data2
jtag_callback_data_t data3
Definition: jtag.h:101
The scan_command provide a means of encapsulating a set of scan_field structures that should be scann...
Definition: commands.h:35
This structure defines a single scan field in the scan.
Definition: jtag.h:87
uint8_t * in_value
A pointer to a 32-bit memory location for data scanned out.
Definition: jtag.h:93
const uint8_t * out_value
A pointer to value to be scanned into the device.
Definition: jtag.h:91
unsigned int num_bits
The number of bits this field specifies.
Definition: jtag.h:89
#define DIV_ROUND_UP(m, n)
Rounds m up to the nearest multiple of n using division.
Definition: types.h:79
#define NULL
Definition: usb.h:16
uint8_t cmd
Definition: vdebug.c:1
uint8_t state[4]
Definition: vdebug.c:21