build: cleanup src/jtag directory

Change-Id: I7caf57ca3d9dfbe152504472a6bb26c2a28b92e8
Signed-off-by: Spencer Oliver <spen@spen-soft.co.uk>
Reviewed-on: http://openocd.zylin.com/423
Tested-by: jenkins
This commit is contained in:
Spencer Oliver 2012-02-02 15:13:13 +00:00
parent 3da783f628
commit 38f8e5eefa
14 changed files with 903 additions and 971 deletions

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -49,8 +50,7 @@
extern struct jtag_interface *jtag_interface; extern struct jtag_interface *jtag_interface;
const char *jtag_only[] = { "jtag", NULL }; const char *jtag_only[] = { "jtag", NULL };
static int static int jim_adapter_name(Jim_Interp *interp, int argc, Jim_Obj * const *argv)
jim_adapter_name(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
{ {
Jim_GetOptInfo goi; Jim_GetOptInfo goi;
Jim_GetOpt_Setup(&goi, interp, argc-1, argv + 1); Jim_GetOpt_Setup(&goi, interp, argc-1, argv + 1);
@ -67,7 +67,6 @@ jim_adapter_name(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
return JIM_OK; return JIM_OK;
} }
static int default_khz(int khz, int *jtag_speed) static int default_khz(int khz, int *jtag_speed)
{ {
LOG_ERROR("Translation from khz to jtag_speed not implemented"); LOG_ERROR("Translation from khz to jtag_speed not implemented");
@ -98,9 +97,8 @@ COMMAND_HANDLER(interface_transport_command)
int retval; int retval;
retval = CALL_COMMAND_HANDLER(transport_list_parse, &transports); retval = CALL_COMMAND_HANDLER(transport_list_parse, &transports);
if (retval != ERROR_OK) { if (retval != ERROR_OK)
return retval; return retval;
}
retval = allow_transports(CMD_CTX, (const char **)transports); retval = allow_transports(CMD_CTX, (const char **)transports);
@ -118,8 +116,7 @@ COMMAND_HANDLER(handle_interface_list_command)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
command_print(CMD_CTX, "The following debug interfaces are available:"); command_print(CMD_CTX, "The following debug interfaces are available:");
for (unsigned i = 0; NULL != jtag_interfaces[i]; i++) for (unsigned i = 0; NULL != jtag_interfaces[i]; i++) {
{
const char *name = jtag_interfaces[i]->name; const char *name = jtag_interfaces[i]->name;
command_print(CMD_CTX, "%u: %s", i + 1, name); command_print(CMD_CTX, "%u: %s", i + 1, name);
} }
@ -132,8 +129,7 @@ COMMAND_HANDLER(handle_interface_command)
int retval; int retval;
/* check whether the interface is already configured */ /* check whether the interface is already configured */
if (jtag_interface) if (jtag_interface) {
{
LOG_WARNING("Interface already configured, ignoring"); LOG_WARNING("Interface already configured, ignoring");
return ERROR_OK; return ERROR_OK;
} }
@ -142,13 +138,11 @@ COMMAND_HANDLER(handle_interface_command)
if (CMD_ARGC != 1 || CMD_ARGV[0][0] == '\0') if (CMD_ARGC != 1 || CMD_ARGV[0][0] == '\0')
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
for (unsigned i = 0; NULL != jtag_interfaces[i]; i++) for (unsigned i = 0; NULL != jtag_interfaces[i]; i++) {
{
if (strcmp(CMD_ARGV[0], jtag_interfaces[i]->name) != 0) if (strcmp(CMD_ARGV[0], jtag_interfaces[i]->name) != 0)
continue; continue;
if (NULL != jtag_interfaces[i]->commands) if (NULL != jtag_interfaces[i]->commands) {
{
retval = register_commands(CMD_CTX, NULL, retval = register_commands(CMD_CTX, NULL,
jtag_interfaces[i]->commands); jtag_interfaces[i]->commands);
if (ERROR_OK != retval) if (ERROR_OK != retval)
@ -391,8 +385,7 @@ COMMAND_HANDLER(handle_adapter_nsrst_delay_command)
{ {
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned delay; unsigned delay;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay);
@ -406,8 +399,7 @@ COMMAND_HANDLER(handle_adapter_nsrst_assert_width_command)
{ {
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned width; unsigned width;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], width); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], width);
@ -425,8 +417,7 @@ COMMAND_HANDLER(handle_adapter_khz_command)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
int retval = ERROR_OK; int retval = ERROR_OK;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned khz = 0; unsigned khz = 0;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], khz); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], khz);

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -41,14 +42,14 @@ struct cmd_queue_page {
}; };
#define CMD_QUEUE_PAGE_SIZE (1024 * 1024) #define CMD_QUEUE_PAGE_SIZE (1024 * 1024)
static struct cmd_queue_page *cmd_queue_pages = NULL; static struct cmd_queue_page *cmd_queue_pages;
struct jtag_command *jtag_command_queue = NULL; struct jtag_command *jtag_command_queue;
static struct jtag_command **next_command_pointer = &jtag_command_queue; static struct jtag_command **next_command_pointer = &jtag_command_queue;
void jtag_queue_command(struct jtag_command * cmd) void jtag_queue_command(struct jtag_command *cmd)
{ {
// this command goes on the end, so ensure the queue terminates /* this command goes on the end, so ensure the queue terminates */
cmd->next = NULL; cmd->next = NULL;
struct jtag_command **last_cmd = next_command_pointer; struct jtag_command **last_cmd = next_command_pointer;
@ -56,11 +57,11 @@ void jtag_queue_command(struct jtag_command * cmd)
assert(NULL == *last_cmd); assert(NULL == *last_cmd);
*last_cmd = cmd; *last_cmd = cmd;
// store location where the next command pointer will be stored /* store location where the next command pointer will be stored */
next_command_pointer = &cmd->next; next_command_pointer = &cmd->next;
} }
void* cmd_queue_alloc(size_t size) void *cmd_queue_alloc(size_t size)
{ {
struct cmd_queue_page **p_page = &cmd_queue_pages; struct cmd_queue_page **p_page = &cmd_queue_pages;
int offset; int offset;
@ -95,19 +96,17 @@ void* cmd_queue_alloc(size_t size)
#define ALIGN_SIZE (sizeof(union worse_case_align)) #define ALIGN_SIZE (sizeof(union worse_case_align))
/* The alignment process. */ /* The alignment process. */
size = (size + ALIGN_SIZE -1) & (~(ALIGN_SIZE-1)); size = (size + ALIGN_SIZE - 1) & (~(ALIGN_SIZE - 1));
/* Done... */ /* Done... */
if (*p_page) if (*p_page) {
{
while ((*p_page)->next) while ((*p_page)->next)
p_page = &((*p_page)->next); p_page = &((*p_page)->next);
if (CMD_QUEUE_PAGE_SIZE - (*p_page)->used < size) if (CMD_QUEUE_PAGE_SIZE - (*p_page)->used < size)
p_page = &((*p_page)->next); p_page = &((*p_page)->next);
} }
if (!*p_page) if (!*p_page) {
{
*p_page = malloc(sizeof(struct cmd_queue_page)); *p_page = malloc(sizeof(struct cmd_queue_page));
(*p_page)->used = 0; (*p_page)->used = 0;
(*p_page)->address = malloc(CMD_QUEUE_PAGE_SIZE); (*p_page)->address = malloc(CMD_QUEUE_PAGE_SIZE);
@ -125,8 +124,7 @@ static void cmd_queue_free(void)
{ {
struct cmd_queue_page *page = cmd_queue_pages; struct cmd_queue_page *page = cmd_queue_pages;
while (page) while (page) {
{
struct cmd_queue_page *last = page; struct cmd_queue_page *last = page;
free(page->address); free(page->address);
page = page->next; page = page->next;
@ -149,8 +147,7 @@ enum scan_type jtag_scan_type(const struct scan_command *cmd)
int i; int i;
int type = 0; int type = 0;
for (i = 0; i < cmd->num_fields; i++) for (i = 0; i < cmd->num_fields; i++) {
{
if (cmd->fields[i].in_value) if (cmd->fields[i].in_value)
type |= SCAN_IN; type |= SCAN_IN;
if (cmd->fields[i].out_value) if (cmd->fields[i].out_value)
@ -167,9 +164,7 @@ int jtag_scan_size(const struct scan_command *cmd)
/* count bits in scan command */ /* count bits in scan command */
for (i = 0; i < cmd->num_fields; i++) for (i = 0; i < cmd->num_fields; i++)
{
bit_count += cmd->fields[i].num_bits; bit_count += cmd->fields[i].num_bits;
}
return bit_count; return bit_count;
} }
@ -180,7 +175,7 @@ int jtag_build_buffer(const struct scan_command *cmd, uint8_t **buffer)
int i; int i;
bit_count = jtag_scan_size(cmd); bit_count = jtag_scan_size(cmd);
*buffer = calloc(1,DIV_ROUND_UP(bit_count, 8)); *buffer = calloc(1, DIV_ROUND_UP(bit_count, 8));
bit_count = 0; bit_count = 0;
@ -188,10 +183,8 @@ int jtag_build_buffer(const struct scan_command *cmd, uint8_t **buffer)
cmd->ir_scan ? "IRSCAN" : "DRSCAN", cmd->ir_scan ? "IRSCAN" : "DRSCAN",
cmd->num_fields); cmd->num_fields);
for (i = 0; i < cmd->num_fields; i++) for (i = 0; i < cmd->num_fields; i++) {
{ if (cmd->fields[i].out_value) {
if (cmd->fields[i].out_value)
{
#ifdef _DEBUG_JTAG_IO_ #ifdef _DEBUG_JTAG_IO_
char *char_buf = buf_to_str(cmd->fields[i].out_value, char *char_buf = buf_to_str(cmd->fields[i].out_value,
(cmd->fields[i].num_bits > DEBUG_JTAG_IOZ) (cmd->fields[i].num_bits > DEBUG_JTAG_IOZ)
@ -204,9 +197,7 @@ int jtag_build_buffer(const struct scan_command *cmd, uint8_t **buffer)
#endif #endif
buf_set_buf(cmd->fields[i].out_value, 0, *buffer, buf_set_buf(cmd->fields[i].out_value, 0, *buffer,
bit_count, cmd->fields[i].num_bits); bit_count, cmd->fields[i].num_bits);
} } else {
else
{
DEBUG_JTAG_IO("fields[%i].out_value[%i]: NULL", DEBUG_JTAG_IO("fields[%i].out_value[%i]: NULL",
i, cmd->fields[i].num_bits); i, cmd->fields[i].num_bits);
} }
@ -214,7 +205,7 @@ int jtag_build_buffer(const struct scan_command *cmd, uint8_t **buffer)
bit_count += cmd->fields[i].num_bits; bit_count += cmd->fields[i].num_bits;
} }
//DEBUG_JTAG_IO("bit_count totalling: %i", bit_count); /*DEBUG_JTAG_IO("bit_count totalling: %i", bit_count); */
return bit_count; return bit_count;
} }
@ -228,15 +219,14 @@ int jtag_read_buffer(uint8_t *buffer, const struct scan_command *cmd)
/* we return ERROR_OK, unless a check fails, or a handler reports a problem */ /* we return ERROR_OK, unless a check fails, or a handler reports a problem */
retval = ERROR_OK; retval = ERROR_OK;
for (i = 0; i < cmd->num_fields; i++) for (i = 0; i < cmd->num_fields; i++) {
{
/* if neither in_value nor in_handler /* if neither in_value nor in_handler
* are specified we don't have to examine this field * are specified we don't have to examine this field
*/ */
if (cmd->fields[i].in_value) if (cmd->fields[i].in_value) {
{
int num_bits = cmd->fields[i].num_bits; int num_bits = cmd->fields[i].num_bits;
uint8_t *captured = buf_set_buf(buffer, bit_count, malloc(DIV_ROUND_UP(num_bits, 8)), 0, num_bits); uint8_t *captured = buf_set_buf(buffer, bit_count,
malloc(DIV_ROUND_UP(num_bits, 8)), 0, num_bits);
#ifdef _DEBUG_JTAG_IO_ #ifdef _DEBUG_JTAG_IO_
char *char_buf = buf_to_str(captured, char *char_buf = buf_to_str(captured,
@ -250,9 +240,7 @@ int jtag_read_buffer(uint8_t *buffer, const struct scan_command *cmd)
#endif #endif
if (cmd->fields[i].in_value) if (cmd->fields[i].in_value)
{
buf_cpy(captured, cmd->fields[i].in_value, num_bits); buf_cpy(captured, cmd->fields[i].in_value, num_bits);
}
free(captured); free(captured);
} }
@ -261,5 +249,3 @@ int jtag_read_buffer(uint8_t *buffer, const struct scan_command *cmd)
return retval; return retval;
} }

View File

@ -23,6 +23,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifndef JTAG_COMMANDS_H #ifndef JTAG_COMMANDS_H
#define JTAG_COMMANDS_H #define JTAG_COMMANDS_H
@ -32,11 +33,11 @@
* to the device, or both. * to the device, or both.
*/ */
enum scan_type { enum scan_type {
/// From device to host, /** From device to host, */
SCAN_IN = 1, SCAN_IN = 1,
/// From host to device, /** From host to device, */
SCAN_OUT = 2, SCAN_OUT = 2,
/// Full-duplex scan. /** Full-duplex scan. */
SCAN_IO = 3 SCAN_IO = 3
}; };
@ -45,56 +46,56 @@ enum scan_type {
* structures that should be scanned in/out to the device. * structures that should be scanned in/out to the device.
*/ */
struct scan_command { struct scan_command {
/// instruction/not data scan /** instruction/not data scan */
bool ir_scan; bool ir_scan;
/// number of fields in *fields array /** number of fields in *fields array */
int num_fields; int num_fields;
/// pointer to an array of data scan fields /** pointer to an array of data scan fields */
struct scan_field* fields; struct scan_field *fields;
/// state in which JTAG commands should finish /** state in which JTAG commands should finish */
tap_state_t end_state; tap_state_t end_state;
}; };
struct statemove_command { struct statemove_command {
/// state in which JTAG commands should finish /** state in which JTAG commands should finish */
tap_state_t end_state; tap_state_t end_state;
}; };
struct pathmove_command { struct pathmove_command {
/// number of states in *path /** number of states in *path */
int num_states; int num_states;
/// states that have to be passed /** states that have to be passed */
tap_state_t* path; tap_state_t *path;
}; };
struct runtest_command { struct runtest_command {
/// number of cycles to spend in Run-Test/Idle state /** number of cycles to spend in Run-Test/Idle state */
int num_cycles; int num_cycles;
/// state in which JTAG commands should finish /** state in which JTAG commands should finish */
tap_state_t end_state; tap_state_t end_state;
}; };
struct stableclocks_command { struct stableclocks_command {
/// number of clock cycles that should be sent /** number of clock cycles that should be sent */
int num_cycles; int num_cycles;
}; };
struct reset_command { struct reset_command {
/// Set TRST output: 0 = deassert, 1 = assert, -1 = no change /** Set TRST output: 0 = deassert, 1 = assert, -1 = no change */
int trst; int trst;
/// Set SRST output: 0 = deassert, 1 = assert, -1 = no change /** Set SRST output: 0 = deassert, 1 = assert, -1 = no change */
int srst; int srst;
}; };
struct end_state_command { struct end_state_command {
/// state in which JTAG commands should finish /** state in which JTAG commands should finish */
tap_state_t end_state; tap_state_t end_state;
}; };
struct sleep_command { struct sleep_command {
/// number of microseconds to sleep /** number of microseconds to sleep */
uint32_t us; uint32_t us;
}; };
@ -161,17 +162,17 @@ struct jtag_command {
struct jtag_command *next; struct jtag_command *next;
}; };
/// The current queue of jtag_command_s structures. /** The current queue of jtag_command_s structures. */
extern struct jtag_command* jtag_command_queue; extern struct jtag_command *jtag_command_queue;
void* cmd_queue_alloc(size_t size); void *cmd_queue_alloc(size_t size);
void jtag_queue_command(struct jtag_command *cmd); void jtag_queue_command(struct jtag_command *cmd);
void jtag_command_queue_reset(void); void jtag_command_queue_reset(void);
enum scan_type jtag_scan_type(const struct scan_command* cmd); enum scan_type jtag_scan_type(const struct scan_command *cmd);
int jtag_scan_size(const struct scan_command* cmd); int jtag_scan_size(const struct scan_command *cmd);
int jtag_read_buffer(uint8_t* buffer, const struct scan_command* cmd); int jtag_read_buffer(uint8_t *buffer, const struct scan_command *cmd);
int jtag_build_buffer(const struct scan_command* cmd, uint8_t** buffer); int jtag_build_buffer(const struct scan_command *cmd, uint8_t **buffer);
#endif // JTAG_COMMANDS_H #endif /* JTAG_COMMANDS_H */

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -43,14 +44,17 @@
#include "svf/svf.h" #include "svf/svf.h"
#include "xsvf/xsvf.h" #include "xsvf/xsvf.h"
/// The number of JTAG queue flushes (for profiling and debugging purposes). /** The number of JTAG queue flushes (for profiling and debugging purposes). */
static int jtag_flush_queue_count; static int jtag_flush_queue_count;
// Sleep this # of ms after flushing the queue /* Sleep this # of ms after flushing the queue */
static int jtag_flush_queue_sleep = 0; static int jtag_flush_queue_sleep;
static void jtag_add_scan_check(struct jtag_tap *active, static void jtag_add_scan_check(struct jtag_tap *active,
void (*jtag_add_scan)(struct jtag_tap *active, int in_num_fields, const struct scan_field *in_fields, tap_state_t state), void (*jtag_add_scan)(struct jtag_tap *active,
int in_num_fields,
const struct scan_field *in_fields,
tap_state_t state),
int in_num_fields, struct scan_field *in_fields, tap_state_t state); int in_num_fields, struct scan_field *in_fields, tap_state_t state);
/** /**
@ -65,8 +69,7 @@ static void jtag_add_scan_check(struct jtag_tap *active,
*/ */
static int jtag_error = ERROR_OK; static int jtag_error = ERROR_OK;
static const char *jtag_event_strings[] = static const char *jtag_event_strings[] = {
{
[JTAG_TRST_ASSERTED] = "TAP reset", [JTAG_TRST_ASSERTED] = "TAP reset",
[JTAG_TAP_EVENT_SETUP] = "TAP setup", [JTAG_TAP_EVENT_SETUP] = "TAP setup",
[JTAG_TAP_EVENT_ENABLE] = "TAP enabled", [JTAG_TAP_EVENT_ENABLE] = "TAP enabled",
@ -85,12 +88,12 @@ static int jtag_srst = -1;
/** /**
* List all TAPs that have been created. * List all TAPs that have been created.
*/ */
static struct jtag_tap *__jtag_all_taps = NULL; static struct jtag_tap *__jtag_all_taps;
/** /**
* The number of TAPs in the __jtag_all_taps list, used to track the * The number of TAPs in the __jtag_all_taps list, used to track the
* assigned chain position to new TAPs * assigned chain position to new TAPs
*/ */
static unsigned jtag_num_taps = 0; static unsigned jtag_num_taps;
static enum reset_types jtag_reset_config = RESET_NONE; static enum reset_types jtag_reset_config = RESET_NONE;
tap_state_t cmd_queue_cur_state = TAP_RESET; tap_state_t cmd_queue_cur_state = TAP_RESET;
@ -98,42 +101,42 @@ tap_state_t cmd_queue_cur_state = TAP_RESET;
static bool jtag_verify_capture_ir = true; static bool jtag_verify_capture_ir = true;
static int jtag_verify = 1; static int jtag_verify = 1;
/* how long the OpenOCD should wait before attempting JTAG communication after reset lines deasserted (in ms) */ /* how long the OpenOCD should wait before attempting JTAG communication after reset lines
static int adapter_nsrst_delay = 0; /* default to no nSRST delay */ *deasserted (in ms) */
static int jtag_ntrst_delay = 0; /* default to no nTRST delay */ static int adapter_nsrst_delay; /* default to no nSRST delay */
static int adapter_nsrst_assert_width = 0; /* width of assertion */ static int jtag_ntrst_delay;/* default to no nTRST delay */
static int jtag_ntrst_assert_width = 0; /* width of assertion */ static int adapter_nsrst_assert_width; /* width of assertion */
static int jtag_ntrst_assert_width; /* width of assertion */
/** /**
* Contains a single callback along with a pointer that will be passed * Contains a single callback along with a pointer that will be passed
* when an event occurs. * when an event occurs.
*/ */
struct jtag_event_callback { struct jtag_event_callback {
/// a event callback /* / a event callback */
jtag_event_handler_t callback; jtag_event_handler_t callback;
/// the private data to pass to the callback /* / the private data to pass to the callback */
void* priv; void *priv;
/// the next callback /* / the next callback */
struct jtag_event_callback* next; struct jtag_event_callback *next;
}; };
/* callbacks to inform high-level handlers about JTAG state changes */ /* callbacks to inform high-level handlers about JTAG state changes */
static struct jtag_event_callback *jtag_event_callbacks; static struct jtag_event_callback *jtag_event_callbacks;
/* speed in kHz*/ /* speed in kHz*/
static int speed_khz = 0; static int speed_khz;
/* speed to fallback to when RCLK is requested but not supported */ /* speed to fallback to when RCLK is requested but not supported */
static int rclk_fallback_speed_khz = 0; static int rclk_fallback_speed_khz;
static enum {CLOCK_MODE_UNSELECTED, CLOCK_MODE_KHZ, CLOCK_MODE_RCLK} clock_mode; static enum {CLOCK_MODE_UNSELECTED, CLOCK_MODE_KHZ, CLOCK_MODE_RCLK} clock_mode;
static int jtag_speed = 0; static int jtag_speed;
static struct jtag_interface *jtag = NULL; static struct jtag_interface *jtag;
const struct swd_driver *swd;
const struct swd_driver *swd = NULL;
/* configuration */ /* configuration */
struct jtag_interface *jtag_interface = NULL; struct jtag_interface *jtag_interface;
void jtag_set_flush_queue_sleep(int ms) void jtag_set_flush_queue_sleep(int ms)
{ {
@ -195,8 +198,7 @@ unsigned jtag_tap_count_enabled(void)
{ {
struct jtag_tap *t = jtag_all_taps(); struct jtag_tap *t = jtag_all_taps();
unsigned n = 0; unsigned n = 0;
while (t) while (t) {
{
if (t->enabled) if (t->enabled)
n++; n++;
t = t->next_tap; t = t->next_tap;
@ -204,7 +206,7 @@ unsigned jtag_tap_count_enabled(void)
return n; return n;
} }
/// Append a new TAP to the chain of all taps. /* / Append a new TAP to the chain of all taps. */
void jtag_tap_add(struct jtag_tap *t) void jtag_tap_add(struct jtag_tap *t)
{ {
t->abs_chain_position = jtag_num_taps++; t->abs_chain_position = jtag_num_taps++;
@ -231,8 +233,7 @@ struct jtag_tap *jtag_tap_by_string(const char *s)
/* try by name first */ /* try by name first */
struct jtag_tap *t = jtag_all_taps(); struct jtag_tap *t = jtag_all_taps();
while (t) while (t) {
{
if (0 == strcmp(t->dotted_name, s)) if (0 == strcmp(t->dotted_name, s))
return t; return t;
t = t->next_tap; t = t->next_tap;
@ -255,11 +256,10 @@ struct jtag_tap *jtag_tap_by_string(const char *s)
return t; return t;
} }
struct jtag_tap* jtag_tap_next_enabled(struct jtag_tap* p) struct jtag_tap *jtag_tap_next_enabled(struct jtag_tap *p)
{ {
p = p ? p->next_tap : jtag_all_taps(); p = p ? p->next_tap : jtag_all_taps();
while (p) while (p) {
{
if (p->enabled) if (p->enabled)
return p; return p;
p = p->next_tap; p = p->next_tap;
@ -278,12 +278,9 @@ int jtag_register_event_callback(jtag_event_handler_t callback, void *priv)
struct jtag_event_callback **callbacks_p = &jtag_event_callbacks; struct jtag_event_callback **callbacks_p = &jtag_event_callbacks;
if (callback == NULL) if (callback == NULL)
{
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
}
if (*callbacks_p) if (*callbacks_p) {
{
while ((*callbacks_p)->next) while ((*callbacks_p)->next)
callbacks_p = &((*callbacks_p)->next); callbacks_p = &((*callbacks_p)->next);
callbacks_p = &((*callbacks_p)->next); callbacks_p = &((*callbacks_p)->next);
@ -302,14 +299,10 @@ int jtag_unregister_event_callback(jtag_event_handler_t callback, void *priv)
struct jtag_event_callback **p = &jtag_event_callbacks, *temp; struct jtag_event_callback **p = &jtag_event_callbacks, *temp;
if (callback == NULL) if (callback == NULL)
{
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
}
while (*p) while (*p) {
{ if (((*p)->priv != priv) || ((*p)->callback != callback)) {
if (((*p)->priv != priv) || ((*p)->callback != callback))
{
p = &(*p)->next; p = &(*p)->next;
continue; continue;
} }
@ -328,8 +321,7 @@ int jtag_call_event_callbacks(enum jtag_event event)
LOG_DEBUG("jtag event: %s", jtag_event_strings[event]); LOG_DEBUG("jtag event: %s", jtag_event_strings[event]);
while (callback) while (callback) {
{
struct jtag_event_callback *next; struct jtag_event_callback *next;
/* callback may remove itself */ /* callback may remove itself */
@ -364,7 +356,9 @@ void jtag_add_ir_scan_noverify(struct jtag_tap *active, const struct scan_field
jtag_set_error(retval); jtag_set_error(retval);
} }
static void jtag_add_ir_scan_noverify_callback(struct jtag_tap *active, int dummy, const struct scan_field *in_fields, static void jtag_add_ir_scan_noverify_callback(struct jtag_tap *active,
int dummy,
const struct scan_field *in_fields,
tap_state_t state) tap_state_t state)
{ {
jtag_add_ir_scan_noverify(active, in_fields, state); jtag_add_ir_scan_noverify(active, in_fields, state);
@ -375,8 +369,7 @@ void jtag_add_ir_scan(struct jtag_tap *active, struct scan_field *in_fields, tap
{ {
assert(state != TAP_RESET); assert(state != TAP_RESET);
if (jtag_verify && jtag_verify_capture_ir) if (jtag_verify && jtag_verify_capture_ir) {
{
/* 8 x 32 bit id's is enough for all invocations */ /* 8 x 32 bit id's is enough for all invocations */
/* if we are to run a verification of the ir scan, we need to get the input back. /* if we are to run a verification of the ir scan, we need to get the input back.
@ -384,11 +377,10 @@ void jtag_add_ir_scan(struct jtag_tap *active, struct scan_field *in_fields, tap
*/ */
in_fields->check_value = active->expected; in_fields->check_value = active->expected;
in_fields->check_mask = active->expected_mask; in_fields->check_mask = active->expected_mask;
jtag_add_scan_check(active, jtag_add_ir_scan_noverify_callback, 1, in_fields, state); jtag_add_scan_check(active, jtag_add_ir_scan_noverify_callback, 1, in_fields,
state);
} else } else
{
jtag_add_ir_scan_noverify(active, in_fields, state); jtag_add_ir_scan_noverify(active, in_fields, state);
}
} }
void jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, void jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits,
@ -407,22 +399,31 @@ void jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_b
static int jtag_check_value_inner(uint8_t *captured, uint8_t *in_check_value, static int jtag_check_value_inner(uint8_t *captured, uint8_t *in_check_value,
uint8_t *in_check_mask, int num_bits); uint8_t *in_check_mask, int num_bits);
static int jtag_check_value_mask_callback(jtag_callback_data_t data0, jtag_callback_data_t data1, jtag_callback_data_t data2, jtag_callback_data_t data3) static int jtag_check_value_mask_callback(jtag_callback_data_t data0,
jtag_callback_data_t data1,
jtag_callback_data_t data2,
jtag_callback_data_t data3)
{ {
return jtag_check_value_inner((uint8_t *)data0, (uint8_t *)data1, (uint8_t *)data2, (int)data3); return jtag_check_value_inner((uint8_t *)data0,
(uint8_t *)data1,
(uint8_t *)data2,
(int)data3);
} }
static void jtag_add_scan_check(struct jtag_tap *active, void (*jtag_add_scan)(struct jtag_tap *active, int in_num_fields, const struct scan_field *in_fields, tap_state_t state), static void jtag_add_scan_check(struct jtag_tap *active, void (*jtag_add_scan)(
struct jtag_tap *active,
int in_num_fields,
const struct scan_field *in_fields,
tap_state_t state),
int in_num_fields, struct scan_field *in_fields, tap_state_t state) int in_num_fields, struct scan_field *in_fields, tap_state_t state)
{ {
jtag_add_scan(active, in_num_fields, in_fields, state); jtag_add_scan(active, in_num_fields, in_fields, state);
for (int i = 0; i < in_num_fields; i++) for (int i = 0; i < in_num_fields; i++) {
{ if ((in_fields[i].check_value != NULL) && (in_fields[i].in_value != NULL)) {
if ((in_fields[i].check_value != NULL) && (in_fields[i].in_value != NULL))
{
/* this is synchronous for a minidriver */ /* this is synchronous for a minidriver */
jtag_add_callback4(jtag_check_value_mask_callback, (jtag_callback_data_t)in_fields[i].in_value, jtag_add_callback4(jtag_check_value_mask_callback,
(jtag_callback_data_t)in_fields[i].in_value,
(jtag_callback_data_t)in_fields[i].check_value, (jtag_callback_data_t)in_fields[i].check_value,
(jtag_callback_data_t)in_fields[i].check_mask, (jtag_callback_data_t)in_fields[i].check_mask,
(jtag_callback_data_t)in_fields[i].num_bits); (jtag_callback_data_t)in_fields[i].num_bits);
@ -430,19 +431,21 @@ static void jtag_add_scan_check(struct jtag_tap *active, void (*jtag_add_scan)(s
} }
} }
void jtag_add_dr_scan_check(struct jtag_tap *active, int in_num_fields, struct scan_field *in_fields, tap_state_t state) void jtag_add_dr_scan_check(struct jtag_tap *active,
int in_num_fields,
struct scan_field *in_fields,
tap_state_t state)
{ {
if (jtag_verify) if (jtag_verify)
{
jtag_add_scan_check(active, jtag_add_dr_scan, in_num_fields, in_fields, state); jtag_add_scan_check(active, jtag_add_dr_scan, in_num_fields, in_fields, state);
} else else
{
jtag_add_dr_scan(active, in_num_fields, in_fields, state); jtag_add_dr_scan(active, in_num_fields, in_fields, state);
}
} }
void jtag_add_dr_scan(struct jtag_tap *active, int in_num_fields, const struct scan_field *in_fields, void jtag_add_dr_scan(struct jtag_tap *active,
int in_num_fields,
const struct scan_field *in_fields,
tap_state_t state) tap_state_t state)
{ {
assert(state != TAP_RESET); assert(state != TAP_RESET);
@ -511,25 +514,21 @@ void jtag_add_pathmove(int num_states, const tap_state_t *path)
tap_state_t cur_state = cmd_queue_cur_state; tap_state_t cur_state = cmd_queue_cur_state;
/* the last state has to be a stable state */ /* the last state has to be a stable state */
if (!tap_is_state_stable(path[num_states - 1])) if (!tap_is_state_stable(path[num_states - 1])) {
{
LOG_ERROR("BUG: TAP path doesn't finish in a stable state"); LOG_ERROR("BUG: TAP path doesn't finish in a stable state");
jtag_set_error(ERROR_JTAG_NOT_STABLE_STATE); jtag_set_error(ERROR_JTAG_NOT_STABLE_STATE);
return; return;
} }
for (int i = 0; i < num_states; i++) for (int i = 0; i < num_states; i++) {
{ if (path[i] == TAP_RESET) {
if (path[i] == TAP_RESET)
{
LOG_ERROR("BUG: TAP_RESET is not a valid state for pathmove sequences"); LOG_ERROR("BUG: TAP_RESET is not a valid state for pathmove sequences");
jtag_set_error(ERROR_JTAG_STATE_INVALID); jtag_set_error(ERROR_JTAG_STATE_INVALID);
return; return;
} }
if (tap_state_transition(cur_state, true) != path[i] if (tap_state_transition(cur_state, true) != path[i] &&
&& tap_state_transition(cur_state, false) != path[i]) tap_state_transition(cur_state, false) != path[i]) {
{
LOG_ERROR("BUG: %s -> %s isn't a valid TAP transition", LOG_ERROR("BUG: %s -> %s isn't a valid TAP transition",
tap_state_name(cur_state), tap_state_name(path[i])); tap_state_name(cur_state), tap_state_name(path[i]));
jtag_set_error(ERROR_JTAG_TRANSITION_INVALID); jtag_set_error(ERROR_JTAG_TRANSITION_INVALID);
@ -548,8 +547,7 @@ int jtag_add_statemove(tap_state_t goal_state)
{ {
tap_state_t cur_state = cmd_queue_cur_state; tap_state_t cur_state = cmd_queue_cur_state;
if (goal_state != cur_state) if (goal_state != cur_state) {
{
LOG_DEBUG("cur_state=%s goal_state=%s", LOG_DEBUG("cur_state=%s goal_state=%s",
tap_state_name(cur_state), tap_state_name(cur_state),
tap_state_name(goal_state)); tap_state_name(goal_state));
@ -561,17 +559,15 @@ int jtag_add_statemove(tap_state_t goal_state)
if (goal_state == TAP_RESET) if (goal_state == TAP_RESET)
jtag_add_tlr(); jtag_add_tlr();
else if (goal_state == cur_state) else if (goal_state == cur_state)
/* nothing to do */ ; /* nothing to do */;
else if (tap_is_state_stable(cur_state) && tap_is_state_stable(goal_state)) else if (tap_is_state_stable(cur_state) && tap_is_state_stable(goal_state)) {
{
unsigned tms_bits = tap_get_tms_path(cur_state, goal_state); unsigned tms_bits = tap_get_tms_path(cur_state, goal_state);
unsigned tms_count = tap_get_tms_path_len(cur_state, goal_state); unsigned tms_count = tap_get_tms_path_len(cur_state, goal_state);
tap_state_t moves[8]; tap_state_t moves[8];
assert(tms_count < ARRAY_SIZE(moves)); assert(tms_count < ARRAY_SIZE(moves));
for (unsigned i = 0; i < tms_count; i++, tms_bits >>= 1) for (unsigned i = 0; i < tms_count; i++, tms_bits >>= 1) {
{
bool bit = tms_bits & 1; bool bit = tms_bits & 1;
cur_state = tap_state_transition(cur_state, bit); cur_state = tap_state_transition(cur_state, bit);
@ -579,13 +575,9 @@ int jtag_add_statemove(tap_state_t goal_state)
} }
jtag_add_pathmove(tms_count, moves); jtag_add_pathmove(tms_count, moves);
} } else if (tap_state_transition(cur_state, true) == goal_state
else if (tap_state_transition(cur_state, true) == goal_state
|| tap_state_transition(cur_state, false) == goal_state) || tap_state_transition(cur_state, false) == goal_state)
{
jtag_add_pathmove(1, &goal_state); jtag_add_pathmove(1, &goal_state);
}
else else
return ERROR_FAIL; return ERROR_FAIL;
@ -601,16 +593,14 @@ void jtag_add_runtest(int num_cycles, tap_state_t state)
void jtag_add_clocks(int num_cycles) void jtag_add_clocks(int num_cycles)
{ {
if (!tap_is_state_stable(cmd_queue_cur_state)) if (!tap_is_state_stable(cmd_queue_cur_state)) {
{
LOG_ERROR("jtag_add_clocks() called with TAP in unstable state \"%s\"", LOG_ERROR("jtag_add_clocks() called with TAP in unstable state \"%s\"",
tap_state_name(cmd_queue_cur_state)); tap_state_name(cmd_queue_cur_state));
jtag_set_error(ERROR_JTAG_NOT_STABLE_STATE); jtag_set_error(ERROR_JTAG_NOT_STABLE_STATE);
return; return;
} }
if (num_cycles > 0) if (num_cycles > 0) {
{
jtag_checks(); jtag_checks();
jtag_set_error(interface_jtag_add_clocks(num_cycles)); jtag_set_error(interface_jtag_add_clocks(num_cycles));
} }
@ -680,13 +670,11 @@ void jtag_add_reset(int req_tlr_or_trst, int req_srst)
/* SRST resets everything hooked up to that signal */ /* SRST resets everything hooked up to that signal */
if (jtag_srst != new_srst) { if (jtag_srst != new_srst) {
jtag_srst = new_srst; jtag_srst = new_srst;
if (jtag_srst) if (jtag_srst) {
{
LOG_DEBUG("SRST line asserted"); LOG_DEBUG("SRST line asserted");
if (adapter_nsrst_assert_width) if (adapter_nsrst_assert_width)
jtag_add_sleep(adapter_nsrst_assert_width * 1000); jtag_add_sleep(adapter_nsrst_assert_width * 1000);
} } else {
else {
LOG_DEBUG("SRST line released"); LOG_DEBUG("SRST line released");
if (adapter_nsrst_delay) if (adapter_nsrst_delay)
jtag_add_sleep(adapter_nsrst_delay * 1000); jtag_add_sleep(adapter_nsrst_delay * 1000);
@ -728,7 +716,7 @@ void jtag_add_reset(int req_tlr_or_trst, int req_srst)
void jtag_add_sleep(uint32_t us) void jtag_add_sleep(uint32_t us)
{ {
/// @todo Here, keep_alive() appears to be a layering violation!!! /* / @todo Here, keep_alive() appears to be a layering violation!!! */
keep_alive(); keep_alive();
jtag_set_error(interface_jtag_add_sleep(us)); jtag_set_error(interface_jtag_add_sleep(us));
} }
@ -746,9 +734,7 @@ static int jtag_check_value_inner(uint8_t *captured, uint8_t *in_check_value,
if (compare_failed) { if (compare_failed) {
char *captured_str, *in_check_value_str; char *captured_str, *in_check_value_str;
int bits = (num_bits > DEBUG_JTAG_IOZ) int bits = (num_bits > DEBUG_JTAG_IOZ) ? DEBUG_JTAG_IOZ : num_bits;
? DEBUG_JTAG_IOZ
: num_bits;
/* NOTE: we've lost diagnostic context here -- 'which tap' */ /* NOTE: we've lost diagnostic context here -- 'which tap' */
@ -779,8 +765,7 @@ void jtag_check_value_mask(struct scan_field *field, uint8_t *value, uint8_t *ma
{ {
assert(field->in_value != NULL); assert(field->in_value != NULL);
if (value == NULL) if (value == NULL) {
{
/* no checking to do */ /* no checking to do */
return; return;
} }
@ -791,12 +776,9 @@ void jtag_check_value_mask(struct scan_field *field, uint8_t *value, uint8_t *ma
jtag_set_error(retval); jtag_set_error(retval);
} }
int default_interface_jtag_execute_queue(void) int default_interface_jtag_execute_queue(void)
{ {
if (NULL == jtag) if (NULL == jtag) {
{
LOG_ERROR("No JTAG interface configured yet. " LOG_ERROR("No JTAG interface configured yet. "
"Issue 'init' command in startup scripts " "Issue 'init' command in startup scripts "
"before communicating with targets."); "before communicating with targets.");
@ -811,8 +793,7 @@ void jtag_execute_queue_noclear(void)
jtag_flush_queue_count++; jtag_flush_queue_count++;
jtag_set_error(interface_jtag_execute_queue()); jtag_set_error(interface_jtag_execute_queue());
if (jtag_flush_queue_sleep > 0) if (jtag_flush_queue_sleep > 0) {
{
/* For debug purposes it can be useful to test performance /* For debug purposes it can be useful to test performance
* or behavior when delaying after flushing the queue, * or behavior when delaying after flushing the queue,
* e.g. to simulate long roundtrip times. * e.g. to simulate long roundtrip times.
@ -836,8 +817,7 @@ static int jtag_reset_callback(enum jtag_event event, void *priv)
{ {
struct jtag_tap *tap = priv; struct jtag_tap *tap = priv;
if (event == JTAG_TRST_ASSERTED) if (event == JTAG_TRST_ASSERTED) {
{
tap->enabled = !tap->disabled_after_reset; tap->enabled = !tap->disabled_after_reset;
/* current instruction is either BYPASS or IDCODE */ /* current instruction is either BYPASS or IDCODE */
@ -886,7 +866,7 @@ static int jtag_examine_chain_execute(uint8_t *idcode_buffer, unsigned num_idcod
.in_value = idcode_buffer, .in_value = idcode_buffer,
}; };
// initialize to the end of chain ID value /* initialize to the end of chain ID value */
for (unsigned i = 0; i < JTAG_MAX_CHAIN_SIZE; i++) for (unsigned i = 0; i < JTAG_MAX_CHAIN_SIZE; i++)
buf_set_u32(idcode_buffer, i * 32, 32, END_OF_CHAIN_FLAG); buf_set_u32(idcode_buffer, i * 32, 32, END_OF_CHAIN_FLAG);
@ -900,8 +880,7 @@ static bool jtag_examine_chain_check(uint8_t *idcodes, unsigned count)
uint8_t zero_check = 0x0; uint8_t zero_check = 0x0;
uint8_t one_check = 0xff; uint8_t one_check = 0xff;
for (unsigned i = 0; i < count * 4; i++) for (unsigned i = 0; i < count * 4; i++) {
{
zero_check |= idcodes[i]; zero_check |= idcodes[i];
one_check &= idcodes[i]; one_check &= idcodes[i];
} }
@ -916,8 +895,7 @@ static bool jtag_examine_chain_check(uint8_t *idcodes, unsigned count)
* + there are several hundreds of TAPs in bypass, or * + there are several hundreds of TAPs in bypass, or
* + at least a few dozen TAPs all have an all-ones IDCODE * + at least a few dozen TAPs all have an all-ones IDCODE
*/ */
if (zero_check == 0x00 || one_check == 0xff) if (zero_check == 0x00 || one_check == 0xff) {
{
LOG_ERROR("JTAG scan chain interrogation failed: all %s", LOG_ERROR("JTAG scan chain interrogation failed: all %s",
(zero_check == 0x00) ? "zeroes" : "ones"); (zero_check == 0x00) ? "zeroes" : "ones");
LOG_ERROR("Check JTAG interface, timings, target power, etc."); LOG_ERROR("Check JTAG interface, timings, target power, etc.");
@ -929,7 +907,7 @@ static bool jtag_examine_chain_check(uint8_t *idcodes, unsigned count)
static void jtag_examine_chain_display(enum log_levels level, const char *msg, static void jtag_examine_chain_display(enum log_levels level, const char *msg,
const char *name, uint32_t idcode) const char *name, uint32_t idcode)
{ {
log_printf_lf(level, __FILE__, __LINE__, __FUNCTION__, log_printf_lf(level, __FILE__, __LINE__, __func__,
"JTAG tap: %s %16.16s: 0x%08x " "JTAG tap: %s %16.16s: 0x%08x "
"(mfg: 0x%3.3x, part: 0x%4.4x, ver: 0x%1.1x)", "(mfg: 0x%3.3x, part: 0x%4.4x, ver: 0x%1.1x)",
name, msg, name, msg,
@ -959,8 +937,7 @@ static bool jtag_idcode_is_final(uint32_t idcode)
static bool jtag_examine_chain_end(uint8_t *idcodes, unsigned count, unsigned max) static bool jtag_examine_chain_end(uint8_t *idcodes, unsigned count, unsigned max)
{ {
bool triggered = false; bool triggered = false;
for (; count < max - 31; count += 32) for (; count < max - 31; count += 32) {
{
uint32_t idcode = buf_get_u32(idcodes, count, 32); uint32_t idcode = buf_get_u32(idcodes, count, 32);
/* do not trigger the warning if the data looks good */ /* do not trigger the warning if the data looks good */
@ -989,8 +966,7 @@ static bool jtag_examine_chain_match_tap(const struct jtag_tap *tap)
/* Loop over the expected identification codes and test for a match */ /* Loop over the expected identification codes and test for a match */
unsigned ii, limit = tap->expected_ids_cnt; unsigned ii, limit = tap->expected_ids_cnt;
for (ii = 0; ii < limit; ii++) for (ii = 0; ii < limit; ii++) {
{
uint32_t expected = tap->expected_ids[ii] & mask; uint32_t expected = tap->expected_ids[ii] & mask;
if (idcode == expected) if (idcode == expected)
@ -1004,8 +980,7 @@ static bool jtag_examine_chain_match_tap(const struct jtag_tap *tap)
/* If none of the expected ids matched, warn */ /* If none of the expected ids matched, warn */
jtag_examine_chain_display(LOG_LVL_WARNING, "UNEXPECTED", jtag_examine_chain_display(LOG_LVL_WARNING, "UNEXPECTED",
tap->dotted_name, tap->idcode); tap->dotted_name, tap->idcode);
for (ii = 0; ii < limit; ii++) for (ii = 0; ii < limit; ii++) {
{
char msg[32]; char msg[32];
snprintf(msg, sizeof(msg), "expected %u of %u", ii + 1, limit); snprintf(msg, sizeof(msg), "expected %u of %u", ii + 1, limit);
@ -1044,12 +1019,10 @@ static int jtag_examine_chain(void)
for (bit_count = 0; for (bit_count = 0;
tap && bit_count < (JTAG_MAX_CHAIN_SIZE * 32) - 31; tap && bit_count < (JTAG_MAX_CHAIN_SIZE * 32) - 31;
tap = jtag_tap_next_enabled(tap)) tap = jtag_tap_next_enabled(tap)) {
{
uint32_t idcode = buf_get_u32(idcode_buffer, bit_count, 32); uint32_t idcode = buf_get_u32(idcode_buffer, bit_count, 32);
if ((idcode & 1) == 0) if ((idcode & 1) == 0) {
{
/* Zero for LSB indicates a device in bypass */ /* Zero for LSB indicates a device in bypass */
LOG_INFO("TAP %s does not have IDCODE", LOG_INFO("TAP %s does not have IDCODE",
tap->dotted_name); tap->dotted_name);
@ -1057,9 +1030,7 @@ static int jtag_examine_chain(void)
tap->hasidcode = false; tap->hasidcode = false;
bit_count += 1; bit_count += 1;
} } else {
else
{
/* Friendly devices support IDCODE */ /* Friendly devices support IDCODE */
tap->hasidcode = true; tap->hasidcode = true;
jtag_examine_chain_display(LOG_LVL_INFO, jtag_examine_chain_display(LOG_LVL_INFO,
@ -1201,11 +1172,10 @@ static int jtag_validate_ircapture(void)
tap = NULL; tap = NULL;
chain_pos = 0; chain_pos = 0;
for (;;) { for (;; ) {
tap = jtag_tap_next_enabled(tap); tap = jtag_tap_next_enabled(tap);
if (tap == NULL) { if (tap == NULL)
break; break;
}
/* If we're autoprobing, guess IR lengths. They must be at /* If we're autoprobing, guess IR lengths. They must be at
* least two bits. Guessing will fail if (a) any TAP does * least two bits. Guessing will fail if (a) any TAP does
@ -1225,8 +1195,7 @@ static int jtag_validate_ircapture(void)
*/ */
if (tap->ir_length == 0) { if (tap->ir_length == 0) {
tap->ir_length = 2; tap->ir_length = 2;
while ((val = buf_get_u32(ir_test, chain_pos, while ((val = buf_get_u32(ir_test, chain_pos, tap->ir_length + 1)) == 1
tap->ir_length + 1)) == 1
&& tap->ir_length <= 32) { && tap->ir_length <= 32) {
tap->ir_length++; tap->ir_length++;
} }
@ -1260,8 +1229,7 @@ static int jtag_validate_ircapture(void)
/* verify the '11' sentinel we wrote is returned at the end */ /* verify the '11' sentinel we wrote is returned at the end */
val = buf_get_u32(ir_test, chain_pos, 2); val = buf_get_u32(ir_test, chain_pos, 2);
if (val != 0x3) if (val != 0x3) {
{
char *cbuf = buf_to_str(ir_test, total_ir_length, 16); char *cbuf = buf_to_str(ir_test, total_ir_length, 16);
LOG_ERROR("IR capture error at bit %d, saw 0x%s not 0x...3", LOG_ERROR("IR capture error at bit %d, saw 0x%s not 0x...3",
@ -1279,7 +1247,6 @@ done:
return retval; return retval;
} }
void jtag_tap_init(struct jtag_tap *tap) void jtag_tap_init(struct jtag_tap *tap)
{ {
unsigned ir_len_bits; unsigned ir_len_bits;
@ -1293,18 +1260,18 @@ void jtag_tap_init(struct jtag_tap *tap)
tap->expected_mask = calloc(1, ir_len_bytes); tap->expected_mask = calloc(1, ir_len_bytes);
tap->cur_instr = malloc(ir_len_bytes); tap->cur_instr = malloc(ir_len_bytes);
/// @todo cope better with ir_length bigger than 32 bits /* / @todo cope better with ir_length bigger than 32 bits */
if (ir_len_bits > 32) if (ir_len_bits > 32)
ir_len_bits = 32; ir_len_bits = 32;
buf_set_u32(tap->expected, 0, ir_len_bits, tap->ir_capture_value); buf_set_u32(tap->expected, 0, ir_len_bits, tap->ir_capture_value);
buf_set_u32(tap->expected_mask, 0, ir_len_bits, tap->ir_capture_mask); buf_set_u32(tap->expected_mask, 0, ir_len_bits, tap->ir_capture_mask);
// TAP will be in bypass mode after jtag_validate_ircapture() /* TAP will be in bypass mode after jtag_validate_ircapture() */
tap->bypass = 1; tap->bypass = 1;
buf_set_ones(tap->cur_instr, tap->ir_length); buf_set_ones(tap->cur_instr, tap->ir_length);
// register the reset callback for the TAP /* register the reset callback for the TAP */
jtag_register_event_callback(&jtag_reset_callback, tap); jtag_register_event_callback(&jtag_reset_callback, tap);
LOG_DEBUG("Created Tap: %s @ abs position %d, " LOG_DEBUG("Created Tap: %s @ abs position %d, "
@ -1319,7 +1286,7 @@ void jtag_tap_free(struct jtag_tap *tap)
{ {
jtag_unregister_event_callback(&jtag_reset_callback, tap); jtag_unregister_event_callback(&jtag_reset_callback, tap);
/// @todo is anything missing? no memory leaks please /* / @todo is anything missing? no memory leaks please */
free((void *)tap->expected); free((void *)tap->expected);
free((void *)tap->expected_ids); free((void *)tap->expected_ids);
free((void *)tap->chip); free((void *)tap->chip);
@ -1337,8 +1304,7 @@ int adapter_init(struct command_context *cmd_ctx)
if (jtag) if (jtag)
return ERROR_OK; return ERROR_OK;
if (!jtag_interface) if (!jtag_interface) {
{
/* nothing was previously specified by "interface" command */ /* nothing was previously specified by "interface" command */
LOG_ERROR("Debug Adapter has to be specified, " LOG_ERROR("Debug Adapter has to be specified, "
"see \"interface\" command"); "see \"interface\" command");
@ -1348,9 +1314,7 @@ int adapter_init(struct command_context *cmd_ctx)
int retval; int retval;
retval = jtag_interface->init(); retval = jtag_interface->init();
if (retval != ERROR_OK) if (retval != ERROR_OK)
{
return retval; return retval;
}
jtag = jtag_interface; jtag = jtag_interface;
/* LEGACY SUPPORT ... adapter drivers must declare what /* LEGACY SUPPORT ... adapter drivers must declare what
@ -1366,8 +1330,7 @@ int adapter_init(struct command_context *cmd_ctx)
return retval; return retval;
} }
if (CLOCK_MODE_UNSELECTED == clock_mode) if (CLOCK_MODE_UNSELECTED == clock_mode) {
{
LOG_ERROR("An adapter speed is not selected in the init script." LOG_ERROR("An adapter speed is not selected in the init script."
" Insert a call to adapter_khz or jtag_rclk to proceed."); " Insert a call to adapter_khz or jtag_rclk to proceed.");
return ERROR_JTAG_INIT_FAILED; return ERROR_JTAG_INIT_FAILED;
@ -1385,19 +1348,15 @@ int adapter_init(struct command_context *cmd_ctx)
retval = jtag_get_speed_readable(&actual_khz); retval = jtag_get_speed_readable(&actual_khz);
if (ERROR_OK != retval) if (ERROR_OK != retval)
LOG_INFO("adapter-specific clock speed value %d", jtag_speed_var); LOG_INFO("adapter-specific clock speed value %d", jtag_speed_var);
else if (actual_khz) else if (actual_khz) {
{
/* Adaptive clocking -- JTAG-specific */ /* Adaptive clocking -- JTAG-specific */
if ((CLOCK_MODE_RCLK == clock_mode) if ((CLOCK_MODE_RCLK == clock_mode)
|| ((CLOCK_MODE_KHZ == clock_mode) && !requested_khz)) || ((CLOCK_MODE_KHZ == clock_mode) && !requested_khz)) {
{
LOG_INFO("RCLK (adaptive clock speed) not supported - fallback to %d kHz" LOG_INFO("RCLK (adaptive clock speed) not supported - fallback to %d kHz"
, actual_khz); , actual_khz);
} } else
else
LOG_INFO("clock speed %d kHz", actual_khz); LOG_INFO("clock speed %d kHz", actual_khz);
} } else
else
LOG_INFO("RCLK (adaptive clock speed)"); LOG_INFO("RCLK (adaptive clock speed)");
return ERROR_OK; return ERROR_OK;
@ -1431,7 +1390,8 @@ int jtag_init_inner(struct command_context *cmd_ctx)
} }
jtag_add_tlr(); jtag_add_tlr();
if ((retval = jtag_execute_queue()) != ERROR_OK) retval = jtag_execute_queue();
if (retval != ERROR_OK)
return retval; return retval;
/* Examine DR values first. This discovers problems which will /* Examine DR values first. This discovers problems which will
@ -1465,8 +1425,7 @@ int jtag_init_inner(struct command_context *cmd_ctx)
* ircapture/irmask values during TAP setup.) * ircapture/irmask values during TAP setup.)
*/ */
retval = jtag_validate_ircapture(); retval = jtag_validate_ircapture();
if (retval != ERROR_OK) if (retval != ERROR_OK) {
{
/* The target might be powered down. The user /* The target might be powered down. The user
* can power it up and reset it after firing * can power it up and reset it after firing
* up OpenOCD. * up OpenOCD.
@ -1488,7 +1447,7 @@ int adapter_quit(void)
if (!jtag || !jtag->quit) if (!jtag || !jtag->quit)
return ERROR_OK; return ERROR_OK;
// close the JTAG interface /* close the JTAG interface */
int result = jtag->quit(); int result = jtag->quit();
if (ERROR_OK != result) if (ERROR_OK != result)
LOG_ERROR("failed: %d", result); LOG_ERROR("failed: %d", result);
@ -1499,9 +1458,8 @@ int adapter_quit(void)
int jtag_init_reset(struct command_context *cmd_ctx) int jtag_init_reset(struct command_context *cmd_ctx)
{ {
int retval; int retval = adapter_init(cmd_ctx);
if (retval != ERROR_OK)
if ((retval = adapter_init(cmd_ctx)) != ERROR_OK)
return retval; return retval;
LOG_DEBUG("Initializing with hard TRST+SRST reset"); LOG_DEBUG("Initializing with hard TRST+SRST reset");
@ -1531,14 +1489,14 @@ int jtag_init_reset(struct command_context *cmd_ctx)
* need to be a C routine at all... * need to be a C routine at all...
*/ */
jtag_add_reset(1, 0); /* TAP_RESET, using TMS+TCK or TRST */ jtag_add_reset(1, 0); /* TAP_RESET, using TMS+TCK or TRST */
if (jtag_reset_config & RESET_HAS_SRST) if (jtag_reset_config & RESET_HAS_SRST) {
{
jtag_add_reset(1, 1); jtag_add_reset(1, 1);
if ((jtag_reset_config & RESET_SRST_PULLS_TRST) == 0) if ((jtag_reset_config & RESET_SRST_PULLS_TRST) == 0)
jtag_add_reset(0, 1); jtag_add_reset(0, 1);
} }
jtag_add_reset(0, 0); jtag_add_reset(0, 0);
if ((retval = jtag_execute_queue()) != ERROR_OK) retval = jtag_execute_queue();
if (retval != ERROR_OK)
return retval; return retval;
/* Check that we can communication on the JTAG chain + eventually we want to /* Check that we can communication on the JTAG chain + eventually we want to
@ -1553,14 +1511,14 @@ int jtag_init_reset(struct command_context *cmd_ctx)
int jtag_init(struct command_context *cmd_ctx) int jtag_init(struct command_context *cmd_ctx)
{ {
int retval; int retval = adapter_init(cmd_ctx);
if (retval != ERROR_OK)
if ((retval = adapter_init(cmd_ctx)) != ERROR_OK)
return retval; return retval;
/* guard against oddball hardware: force resets to be inactive */ /* guard against oddball hardware: force resets to be inactive */
jtag_add_reset(0, 0); jtag_add_reset(0, 0);
if ((retval = jtag_execute_queue()) != ERROR_OK) retval = jtag_execute_queue();
if (retval != ERROR_OK)
return retval; return retval;
if (Jim_Eval_Named(cmd_ctx->interp, "jtag_init", __FILE__, __LINE__) != JIM_OK) if (Jim_Eval_Named(cmd_ctx->interp, "jtag_init", __FILE__, __LINE__) != JIM_OK)
@ -1574,29 +1532,25 @@ unsigned jtag_get_speed_khz(void)
return speed_khz; return speed_khz;
} }
static int adapter_khz_to_speed(unsigned khz, int* speed) static int adapter_khz_to_speed(unsigned khz, int *speed)
{ {
LOG_DEBUG("convert khz to interface specific speed value"); LOG_DEBUG("convert khz to interface specific speed value");
speed_khz = khz; speed_khz = khz;
if (jtag != NULL) if (jtag != NULL) {
{
LOG_DEBUG("have interface set up"); LOG_DEBUG("have interface set up");
int speed_div1; int speed_div1;
int retval = jtag->khz(jtag_get_speed_khz(), &speed_div1); int retval = jtag->khz(jtag_get_speed_khz(), &speed_div1);
if (ERROR_OK != retval) if (ERROR_OK != retval)
{
return retval; return retval;
}
*speed = speed_div1; *speed = speed_div1;
} }
return ERROR_OK; return ERROR_OK;
} }
static int jtag_rclk_to_speed(unsigned fallback_speed_khz, int* speed) static int jtag_rclk_to_speed(unsigned fallback_speed_khz, int *speed)
{ {
int retval = adapter_khz_to_speed(0, speed); int retval = adapter_khz_to_speed(0, speed);
if ((ERROR_OK != retval) && fallback_speed_khz) if ((ERROR_OK != retval) && fallback_speed_khz) {
{
LOG_DEBUG("trying fallback speed..."); LOG_DEBUG("trying fallback speed...");
retval = adapter_khz_to_speed(fallback_speed_khz, speed); retval = adapter_khz_to_speed(fallback_speed_khz, speed);
} }
@ -1632,8 +1586,7 @@ int jtag_config_rclk(unsigned fallback_speed_khz)
int jtag_get_speed(int *speed) int jtag_get_speed(int *speed)
{ {
switch(clock_mode) switch (clock_mode) {
{
case CLOCK_MODE_KHZ: case CLOCK_MODE_KHZ:
adapter_khz_to_speed(jtag_get_speed_khz(), speed); adapter_khz_to_speed(jtag_get_speed_khz(), speed);
break; break;
@ -1678,8 +1631,7 @@ bool jtag_will_verify_capture_ir()
int jtag_power_dropout(int *dropout) int jtag_power_dropout(int *dropout)
{ {
if (jtag == NULL) if (jtag == NULL) {
{
/* TODO: as the jtag interface is not valid all /* TODO: as the jtag interface is not valid all
* we can do at the moment is exit OpenOCD */ * we can do at the moment is exit OpenOCD */
LOG_ERROR("No Valid JTAG Interface Configured."); LOG_ERROR("No Valid JTAG Interface Configured.");

View File

@ -1,4 +1,28 @@
/***************************************************************************
* Copyright (C) 2005 by Dominic Rath *
* Dominic.Rath@gmx.de *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifndef JTAG_DRIVER_H
#define JTAG_DRIVER_H
struct command_context; struct command_context;
int interface_register_commands(struct command_context *ctx); int interface_register_commands(struct command_context *ctx);
#endif /* JTAG_DRIVER_H */

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -60,7 +61,7 @@ static tap_state_t end_state_follower = TAP_RESET;
void tap_set_end_state(tap_state_t new_end_state) void tap_set_end_state(tap_state_t new_end_state)
{ {
/* this is the state we think the TAPs will be in at completion of the /* this is the state we think the TAPs will be in at completion of the
current TAP operation, was end_state * current TAP operation, was end_state
*/ */
end_state_follower = new_end_state; end_state_follower = new_end_state;
} }
@ -70,7 +71,6 @@ tap_state_t tap_get_end_state()
return end_state_follower; return end_state_follower;
} }
int tap_move_ndx(tap_state_t astate) int tap_move_ndx(tap_state_t astate)
{ {
/* given a stable state, return the index into the tms_seqs[] /* given a stable state, return the index into the tms_seqs[]
@ -79,14 +79,25 @@ int tap_move_ndx(tap_state_t astate)
int ndx; int ndx;
switch (astate) switch (astate) {
{ case TAP_RESET:
case TAP_RESET: ndx = 0; break; ndx = 0;
case TAP_IDLE: ndx = 1; break; break;
case TAP_DRSHIFT: ndx = 2; break; case TAP_IDLE:
case TAP_DRPAUSE: ndx = 3; break; ndx = 1;
case TAP_IRSHIFT: ndx = 4; break; break;
case TAP_IRPAUSE: ndx = 5; break; case TAP_DRSHIFT:
ndx = 2;
break;
case TAP_DRPAUSE:
ndx = 3;
break;
case TAP_IRSHIFT:
ndx = 4;
break;
case TAP_IRPAUSE:
ndx = 5;
break;
default: default:
LOG_ERROR("FATAL: unstable state \"%s\" in tap_move_ndx()", LOG_ERROR("FATAL: unstable state \"%s\" in tap_move_ndx()",
tap_state_name(astate)); tap_state_name(astate));
@ -96,14 +107,12 @@ int tap_move_ndx(tap_state_t astate)
return ndx; return ndx;
} }
/* tap_move[i][j]: tap movement command to go from state i to state j /* tap_move[i][j]: tap movement command to go from state i to state j
* encodings of i and j are what tap_move_ndx() reports. * encodings of i and j are what tap_move_ndx() reports.
* *
* DRSHIFT->DRSHIFT and IRSHIFT->IRSHIFT have to be caught in interface specific code * DRSHIFT->DRSHIFT and IRSHIFT->IRSHIFT have to be caught in interface specific code
*/ */
struct tms_sequences struct tms_sequences {
{
uint8_t bits; uint8_t bits;
uint8_t bit_count; uint8_t bit_count;
}; };
@ -115,39 +124,35 @@ struct tms_sequences
#define HEX__(n) 0x##n##LU #define HEX__(n) 0x##n##LU
#define B8__(x) \ #define B8__(x) \
(((x) & 0x0000000FLU)?(1 << 0):0) \ ((((x) & 0x0000000FLU) ? (1 << 0) : 0) \
+(((x) & 0x000000F0LU)?(1 << 1):0) \ +(((x) & 0x000000F0LU) ? (1 << 1) : 0) \
+(((x) & 0x00000F00LU)?(1 << 2):0) \ +(((x) & 0x00000F00LU) ? (1 << 2) : 0) \
+(((x) & 0x0000F000LU)?(1 << 3):0) \ +(((x) & 0x0000F000LU) ? (1 << 3) : 0) \
+(((x) & 0x000F0000LU)?(1 << 4):0) \ +(((x) & 0x000F0000LU) ? (1 << 4) : 0) \
+(((x) & 0x00F00000LU)?(1 << 5):0) \ +(((x) & 0x00F00000LU) ? (1 << 5) : 0) \
+(((x) & 0x0F000000LU)?(1 << 6):0) \ +(((x) & 0x0F000000LU) ? (1 << 6) : 0) \
+(((x) & 0xF0000000LU)?(1 << 7):0) +(((x) & 0xF0000000LU) ? (1 << 7) : 0))
#define B8(bits,count) { ((uint8_t)B8__(HEX__(bits))), (count) } #define B8(bits, count) {((uint8_t)B8__(HEX__(bits))), (count)}
static const struct tms_sequences old_tms_seqs[6][6] = /* [from_state_ndx][to_state_ndx] */ static const struct tms_sequences old_tms_seqs[6][6] = { /* [from_state_ndx][to_state_ndx] */
{
/* value clocked to TMS to move from one of six stable states to another. /* value clocked to TMS to move from one of six stable states to another.
* N.B. OOCD clocks TMS from LSB first, so read these right-to-left. * N.B. OOCD clocks TMS from LSB first, so read these right-to-left.
* N.B. Reset only needs to be 0b11111, but in JLink an even byte of 1's is more stable. * N.B. Reset only needs to be 0b11111, but in JLink an even byte of 1's is more stable.
* These extra ones cause no TAP state problem, because we go into reset and stay in reset. * These extra ones cause no TAP state problem, because we go into reset and stay in reset.
*/ */
/* to state: */ /* to state: */
/* RESET IDLE DRSHIFT DRPAUSE IRSHIFT IRPAUSE */ /* from state: */ /* RESET IDLE DRSHIFT DRPAUSE IRSHIFT IRPAUSE */ /* from state: */
{ B8(1111111,7), B8(0000000,7), B8(0010111,7), B8(0001010,7), B8(0011011,7), B8(0010110,7) }, /* RESET */ {B8(1111111, 7), B8(0000000, 7), B8(0010111, 7), B8(0001010, 7), B8(0011011, 7), B8(0010110, 7)},/* RESET */
{ B8(1111111,7), B8(0000000,7), B8(0100101,7), B8(0000101,7), B8(0101011,7), B8(0001011,7) }, /* IDLE */ {B8(1111111, 7), B8(0000000, 7), B8(0100101, 7), B8(0000101, 7), B8(0101011, 7), B8(0001011, 7)},/* IDLE */
{ B8(1111111,7), B8(0110001,7), B8(0000000,7), B8(0000001,7), B8(0001111,7), B8(0101111,7) }, /* DRSHIFT */ {B8(1111111, 7), B8(0110001, 7), B8(0000000, 7), B8(0000001, 7), B8(0001111, 7), B8(0101111, 7)},/* DRSHIFT */
{ B8(1111111,7), B8(0110000,7), B8(0100000,7), B8(0010111,7), B8(0011110,7), B8(0101111,7) }, /* DRPAUSE */ {B8(1111111, 7), B8(0110000, 7), B8(0100000, 7), B8(0010111, 7), B8(0011110, 7), B8(0101111, 7)},/* DRPAUSE */
{ B8(1111111,7), B8(0110001,7), B8(0000111,7), B8(0010111,7), B8(0000000,7), B8(0000001,7) }, /* IRSHIFT */ {B8(1111111, 7), B8(0110001, 7), B8(0000111, 7), B8(0010111, 7), B8(0000000, 7), B8(0000001, 7)},/* IRSHIFT */
{ B8(1111111,7), B8(0110000,7), B8(0011100,7), B8(0010111,7), B8(0011110,7), B8(0101111,7) }, /* IRPAUSE */ {B8(1111111, 7), B8(0110000, 7), B8(0011100, 7), B8(0010111, 7), B8(0011110, 7), B8(0101111, 7)},/* IRPAUSE */
}; };
static const struct tms_sequences short_tms_seqs[6][6] = { /* [from_state_ndx][to_state_ndx] */
static const struct tms_sequences short_tms_seqs[6][6] = /* [from_state_ndx][to_state_ndx] */
{
/* this is the table submitted by Jeff Williams on 3/30/2009 with this comment: /* this is the table submitted by Jeff Williams on 3/30/2009 with this comment:
OK, I added Peter's version of the state table, and it works OK for OK, I added Peter's version of the state table, and it works OK for
@ -179,44 +184,40 @@ static const struct tms_sequences short_tms_seqs[6][6] = /* [from_state_ndx][t
The X-to-X transitions always add clocks; from *SHIFT, they go The X-to-X transitions always add clocks; from *SHIFT, they go
via IDLE and thus *DO HAVE SIDE EFFECTS* (capture and update). via IDLE and thus *DO HAVE SIDE EFFECTS* (capture and update).
*/ */
/* to state: */
/* RESET IDLE DRSHIFT DRPAUSE IRSHIFT IRPAUSE */ /* from state: */
{ B8(1111111,7), B8(0000000,7), B8(0010111,7), B8(0001010,7), B8(0011011,7), B8(0010110,7) }, /* RESET */
{ B8(1111111,7), B8(0000000,7), B8(001,3), B8(0101,4), B8(0011,4), B8(01011,5) }, /* IDLE */
{ B8(1111111,7), B8(011,3), B8(00111,5), B8(01,2), B8(001111,6), B8(0101111,7) }, /* DRSHIFT */
{ B8(1111111,7), B8(011,3), B8(01,2), B8(0,1), B8(001111,6), B8(0101111,7) }, /* DRPAUSE */
{ B8(1111111,7), B8(011,3), B8(00111,5), B8(010111,6), B8(001111,6), B8(01,2) }, /* IRSHIFT */
{ B8(1111111,7), B8(011,3), B8(00111,5), B8(010111,6), B8(01,2), B8(0,1)} /* IRPAUSE */
/* to state: */
/* RESET IDLE DRSHIFT DRPAUSE IRSHIFT IRPAUSE */ /* from state: */
{B8(1111111, 7), B8(0000000, 7), B8(0010111, 7), B8(0001010, 7), B8(0011011, 7), B8(0010110, 7)}, /* RESET */
{B8(1111111, 7), B8(0000000, 7), B8(001, 3), B8(0101, 4), B8(0011, 4), B8(01011, 5)}, /* IDLE */
{B8(1111111, 7), B8(011, 3), B8(00111, 5), B8(01, 2), B8(001111, 6), B8(0101111, 7)}, /* DRSHIFT */
{B8(1111111, 7), B8(011, 3), B8(01, 2), B8(0, 1), B8(001111, 6), B8(0101111, 7)}, /* DRPAUSE */
{B8(1111111, 7), B8(011, 3), B8(00111, 5), B8(010111, 6), B8(001111, 6), B8(01, 2)}, /* IRSHIFT */
{B8(1111111, 7), B8(011, 3), B8(00111, 5), B8(010111, 6), B8(01, 2), B8(0, 1)} /* IRPAUSE */
}; };
typedef const struct tms_sequences tms_table[6][6]; typedef const struct tms_sequences tms_table[6][6];
static tms_table *tms_seqs=&short_tms_seqs; static tms_table *tms_seqs = &short_tms_seqs;
int tap_get_tms_path(tap_state_t from, tap_state_t to) int tap_get_tms_path(tap_state_t from, tap_state_t to)
{ {
return (*tms_seqs)[tap_move_ndx(from)][tap_move_ndx(to)].bits; return (*tms_seqs)[tap_move_ndx(from)][tap_move_ndx(to)].bits;
} }
int tap_get_tms_path_len(tap_state_t from, tap_state_t to) int tap_get_tms_path_len(tap_state_t from, tap_state_t to)
{ {
return (*tms_seqs)[tap_move_ndx(from)][tap_move_ndx(to)].bit_count; return (*tms_seqs)[tap_move_ndx(from)][tap_move_ndx(to)].bit_count;
} }
bool tap_is_state_stable(tap_state_t astate) bool tap_is_state_stable(tap_state_t astate)
{ {
bool is_stable; bool is_stable;
/* A switch () is used because it is symbol dependent /* A switch () is used because it is symbol dependent
(not value dependent like an array), and can also check bounds. * (not value dependent like an array), and can also check bounds.
*/ */
switch (astate) switch (astate) {
{
case TAP_RESET: case TAP_RESET:
case TAP_IDLE: case TAP_IDLE:
case TAP_DRSHIFT: case TAP_DRSHIFT:
@ -237,13 +238,11 @@ tap_state_t tap_state_transition(tap_state_t cur_state, bool tms)
tap_state_t new_state; tap_state_t new_state;
/* A switch is used because it is symbol dependent and not value dependent /* A switch is used because it is symbol dependent and not value dependent
like an array. Also it can check for out of range conditions. * like an array. Also it can check for out of range conditions.
*/ */
if (tms) if (tms) {
{ switch (cur_state) {
switch (cur_state)
{
case TAP_RESET: case TAP_RESET:
new_state = cur_state; new_state = cur_state;
break; break;
@ -285,11 +284,8 @@ tap_state_t tap_state_transition(tap_state_t cur_state, bool tms)
exit(1); exit(1);
break; break;
} }
} } else {
else switch (cur_state) {
{
switch (cur_state)
{
case TAP_RESET: case TAP_RESET:
case TAP_IDLE: case TAP_IDLE:
case TAP_DRUPDATE: case TAP_DRUPDATE:
@ -330,7 +326,6 @@ tap_state_t tap_state_transition(tap_state_t cur_state, bool tms)
return new_state; return new_state;
} }
/* NOTE: do not change these state names. They're documented, /* NOTE: do not change these state names. They're documented,
* and we rely on them to match SVF input (except for "RUN/IDLE"). * and we rely on them to match SVF input (except for "RUN/IDLE").
*/ */
@ -341,14 +336,14 @@ static const struct name_mapping {
{ TAP_RESET, "RESET", }, { TAP_RESET, "RESET", },
{ TAP_IDLE, "RUN/IDLE", }, { TAP_IDLE, "RUN/IDLE", },
{ TAP_DRSELECT, "DRSELECT", }, { TAP_DRSELECT, "DRSELECT", },
{ TAP_DRCAPTURE,"DRCAPTURE", }, { TAP_DRCAPTURE, "DRCAPTURE", },
{ TAP_DRSHIFT, "DRSHIFT", }, { TAP_DRSHIFT, "DRSHIFT", },
{ TAP_DREXIT1, "DREXIT1", }, { TAP_DREXIT1, "DREXIT1", },
{ TAP_DRPAUSE, "DRPAUSE", }, { TAP_DRPAUSE, "DRPAUSE", },
{ TAP_DREXIT2, "DREXIT2", }, { TAP_DREXIT2, "DREXIT2", },
{ TAP_DRUPDATE, "DRUPDATE", }, { TAP_DRUPDATE, "DRUPDATE", },
{ TAP_IRSELECT, "IRSELECT", }, { TAP_IRSELECT, "IRSELECT", },
{ TAP_IRCAPTURE,"IRCAPTURE", }, { TAP_IRCAPTURE, "IRCAPTURE", },
{ TAP_IRSHIFT, "IRSHIFT", }, { TAP_IRSHIFT, "IRSHIFT", },
{ TAP_IREXIT1, "IREXIT1", }, { TAP_IREXIT1, "IREXIT1", },
{ TAP_IRPAUSE, "IRPAUSE", }, { TAP_IRPAUSE, "IRPAUSE", },
@ -406,7 +401,7 @@ tap_state_t jtag_debug_state_machine(const void *tms_buf, const void *tdi_buf,
tap_state_t last_state; tap_state_t last_state;
// set startstate (and possibly last, if tap_bits == 0) /* set startstate (and possibly last, if tap_bits == 0) */
last_state = next_state; last_state = next_state;
DEBUG_JTAG_IO("TAP/SM: START state: %s", tap_state_name(next_state)); DEBUG_JTAG_IO("TAP/SM: START state: %s", tap_state_name(next_state));
@ -417,47 +412,44 @@ tap_state_t jtag_debug_state_machine(const void *tms_buf, const void *tdi_buf,
DEBUG_JTAG_IO("TAP/SM: TMS bits: %u (bytes: %u)", tap_bits, tap_bytes); DEBUG_JTAG_IO("TAP/SM: TMS bits: %u (bytes: %u)", tap_bits, tap_bytes);
tap_out_bits = 0; tap_out_bits = 0;
for (cur_byte = 0; cur_byte < tap_bytes; cur_byte++) for (cur_byte = 0; cur_byte < tap_bytes; cur_byte++) {
{ for (cur_bit = 0; cur_bit < 8; cur_bit++) {
for (cur_bit = 0; cur_bit < 8; cur_bit++) /* make sure we do not run off the end of the buffers */
{
// make sure we do not run off the end of the buffers
unsigned tap_bit = cur_byte * 8 + cur_bit; unsigned tap_bit = cur_byte * 8 + cur_bit;
if (tap_bit == tap_bits) if (tap_bit == tap_bits)
break; break;
// check and save TMS bit /* check and save TMS bit */
tap_bit = !!(tms_buffer[cur_byte] & (1 << cur_bit)); tap_bit = !!(tms_buffer[cur_byte] & (1 << cur_bit));
JTAG_DEBUG_STATE_APPEND(tms_str, tap_out_bits, tap_bit); JTAG_DEBUG_STATE_APPEND(tms_str, tap_out_bits, tap_bit);
// use TMS bit to find the next TAP state /* use TMS bit to find the next TAP state */
next_state = tap_state_transition(last_state, tap_bit); next_state = tap_state_transition(last_state, tap_bit);
// check and store TDI bit /* check and store TDI bit */
tap_bit = !!(tdi_buffer[cur_byte] & (1 << cur_bit)); tap_bit = !!(tdi_buffer[cur_byte] & (1 << cur_bit));
JTAG_DEBUG_STATE_APPEND(tdi_str, tap_out_bits, tap_bit); JTAG_DEBUG_STATE_APPEND(tdi_str, tap_out_bits, tap_bit);
// increment TAP bits /* increment TAP bits */
tap_out_bits++; tap_out_bits++;
// Only show TDO bits on state transitions, or /* Only show TDO bits on state transitions, or */
// after some number of bits in the same state. /* after some number of bits in the same state. */
if ((next_state == last_state) && (tap_out_bits < 32)) if ((next_state == last_state) && (tap_out_bits < 32))
continue; continue;
// terminate strings and display state transition /* terminate strings and display state transition */
tms_str[tap_out_bits] = tdi_str[tap_out_bits] = 0; tms_str[tap_out_bits] = tdi_str[tap_out_bits] = 0;
JTAG_DEBUG_STATE_PRINT(last_state, next_state, tms_str, tdi_str); JTAG_DEBUG_STATE_PRINT(last_state, next_state, tms_str, tdi_str);
// reset state /* reset state */
last_state = next_state; last_state = next_state;
tap_out_bits = 0; tap_out_bits = 0;
} }
} }
if (tap_out_bits) if (tap_out_bits) {
{ /* terminate strings and display state transition */
// terminate strings and display state transition
tms_str[tap_out_bits] = tdi_str[tap_out_bits] = 0; tms_str[tap_out_bits] = tdi_str[tap_out_bits] = 0;
JTAG_DEBUG_STATE_PRINT(last_state, next_state, tms_str, tdi_str); JTAG_DEBUG_STATE_PRINT(last_state, next_state, tms_str, tdi_str);
} }
@ -466,7 +458,7 @@ tap_state_t jtag_debug_state_machine(const void *tms_buf, const void *tdi_buf,
return next_state; return next_state;
} }
#endif // _DEBUG_JTAG_IO_ #endif /* _DEBUG_JTAG_IO_ */
void tap_use_new_tms_table(bool use_new) void tap_use_new_tms_table(bool use_new)
{ {
@ -476,4 +468,3 @@ bool tap_uses_new_tms_table(void)
{ {
return tms_seqs == &short_tms_seqs; return tms_seqs == &short_tms_seqs;
} }

View File

@ -23,6 +23,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifndef OPENOCD_JTAG_INTERFACE_H #ifndef OPENOCD_JTAG_INTERFACE_H
#define OPENOCD_JTAG_INTERFACE_H #define OPENOCD_JTAG_INTERFACE_H
@ -110,7 +111,6 @@ tap_state_t tap_get_end_state(void);
*/ */
int tap_get_tms_path(tap_state_t from, tap_state_t to); int tap_get_tms_path(tap_state_t from, tap_state_t to);
/** /**
* Function int tap_get_tms_path_len * Function int tap_get_tms_path_len
* returns the total number of bits that represents a TMS path * returns the total number of bits that represents a TMS path
@ -160,9 +160,9 @@ bool tap_is_state_stable(tap_state_t astate);
*/ */
tap_state_t tap_state_transition(tap_state_t current_state, bool tms); tap_state_t tap_state_transition(tap_state_t current_state, bool tms);
/// Allow switching between old and new TMS tables. @see tap_get_tms_path /** Allow switching between old and new TMS tables. @see tap_get_tms_path */
void tap_use_new_tms_table(bool use_new); void tap_use_new_tms_table(bool use_new);
/// @returns True if new TMS table is active; false otherwise. /** @returns True if new TMS table is active; false otherwise. */
bool tap_uses_new_tms_table(void); bool tap_uses_new_tms_table(void);
#ifdef _DEBUG_JTAG_IO_ #ifdef _DEBUG_JTAG_IO_
@ -182,7 +182,7 @@ static inline tap_state_t jtag_debug_state_machine(const void *tms_buf,
{ {
return start_tap_state; return start_tap_state;
} }
#endif // _DEBUG_JTAG_IO_ #endif /* _DEBUG_JTAG_IO_ */
/** /**
* Represents a driver for a debugging interface. * Represents a driver for a debugging interface.
@ -197,8 +197,8 @@ static inline tap_state_t jtag_debug_state_machine(const void *tms_buf,
* debugging interface. * debugging interface.
*/ */
struct jtag_interface { struct jtag_interface {
/// The name of the JTAG interface driver. /** The name of the JTAG interface driver. */
char* name; char *name;
/** /**
* Bit vector listing capabilities exposed by this driver. * Bit vector listing capabilities exposed by this driver.
@ -261,7 +261,7 @@ struct jtag_interface {
* and use a fallback kHz TCK. * and use a fallback kHz TCK.
* @returns ERROR_OK on success, or an error code on failure. * @returns ERROR_OK on success, or an error code on failure.
*/ */
int (*khz)(int khz, int* jtag_speed); int (*khz)(int khz, int *jtag_speed);
/** /**
* Calculate the clock frequency (in KHz) for the given @a speed. * Calculate the clock frequency (in KHz) for the given @a speed.
@ -270,7 +270,7 @@ struct jtag_interface {
* @returns ERROR_OK on success, or an error code if the * @returns ERROR_OK on success, or an error code if the
* interface cannot support the specified speed (KHz or RTCK). * interface cannot support the specified speed (KHz or RTCK).
*/ */
int (*speed_div)(int speed, int* khz); int (*speed_div)(int speed, int *khz);
/** /**
* Read and clear the power dropout flag. Note that a power dropout * Read and clear the power dropout flag. Note that a power dropout
@ -283,7 +283,7 @@ struct jtag_interface {
* *
* @returns ERROR_OK on success, or an error code on failure. * @returns ERROR_OK on success, or an error code on failure.
*/ */
int (*power_dropout)(int* power_dropout); int (*power_dropout)(int *power_dropout);
/** /**
* Read and clear the srst asserted detection flag. * Read and clear the srst asserted detection flag.
@ -297,12 +297,11 @@ struct jtag_interface {
* been asserted. * been asserted.
* @returns ERROR_OK on success, or an error code on failure. * @returns ERROR_OK on success, or an error code on failure.
*/ */
int (*srst_asserted)(int* srst_asserted); int (*srst_asserted)(int *srst_asserted);
}; };
extern const char *jtag_only[]; extern const char *jtag_only[];
extern const struct swd_driver *swd; extern const struct swd_driver *swd;
#endif // OPENOCD_JTAG_INTERFACE_H #endif /* OPENOCD_JTAG_INTERFACE_H */

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -45,7 +46,7 @@
extern struct jtag_interface zy1000_interface; extern struct jtag_interface zy1000_interface;
#elif defined(BUILD_MINIDRIVER_DUMMY) #elif defined(BUILD_MINIDRIVER_DUMMY)
extern struct jtag_interface minidummy_interface; extern struct jtag_interface minidummy_interface;
#else // standard drivers #else /* standard drivers */
#if BUILD_PARPORT == 1 #if BUILD_PARPORT == 1
extern struct jtag_interface parport_interface; extern struct jtag_interface parport_interface;
#endif #endif
@ -103,7 +104,7 @@ extern struct jtag_interface remote_bitbang_interface;
#if BUILD_STLINK == 1 #if BUILD_STLINK == 1
extern struct jtag_interface stlink_interface; extern struct jtag_interface stlink_interface;
#endif #endif
#endif // standard drivers #endif /* standard drivers */
/** /**
* The list of built-in JTAG interfaces, containing entries for those * The list of built-in JTAG interfaces, containing entries for those
@ -117,7 +118,7 @@ struct jtag_interface *jtag_interfaces[] = {
&zy1000_interface, &zy1000_interface,
#elif defined(BUILD_MINIDRIVER_DUMMY) #elif defined(BUILD_MINIDRIVER_DUMMY)
&minidummy_interface, &minidummy_interface,
#else // standard drivers #else /* standard drivers */
#if BUILD_PARPORT == 1 #if BUILD_PARPORT == 1
&parport_interface, &parport_interface,
#endif #endif
@ -175,11 +176,11 @@ struct jtag_interface *jtag_interfaces[] = {
#if BUILD_STLINK == 1 #if BUILD_STLINK == 1
&stlink_interface, &stlink_interface,
#endif #endif
#endif // standard drivers #endif /* standard drivers */
NULL, NULL,
}; };
void jtag_interface_modules_load(const char *path) void jtag_interface_modules_load(const char *path)
{ {
// @todo: implement dynamic module loading for JTAG interface drivers /* @todo: implement dynamic module loading for JTAG interface drivers */
} }

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifndef OPENOCD_JTAG_INTERFACES_H #ifndef OPENOCD_JTAG_INTERFACES_H
#define OPENOCD_JTAG_INTERFACES_H #define OPENOCD_JTAG_INTERFACES_H
@ -37,9 +38,9 @@
#include <jtag/interface.h> #include <jtag/interface.h>
/// Dynamically load all JTAG interface modules from specified directory. /** Dynamically load all JTAG interface modules from specified directory. */
void jtag_interface_modules_load(const char *path); void jtag_interface_modules_load(const char *path);
extern struct jtag_interface *jtag_interfaces[]; extern struct jtag_interface *jtag_interfaces[];
#endif // OPENOCD_JTAG_INTERFACES_H #endif /* OPENOCD_JTAG_INTERFACES_H */

View File

@ -20,6 +20,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifndef JTAG_H #ifndef JTAG_H
#define JTAG_H #define JTAG_H
@ -52,8 +53,7 @@
* Fix those drivers to map as appropriate ... then pick some * Fix those drivers to map as appropriate ... then pick some
* sane set of numbers here (where 0/uninitialized == INVALID). * sane set of numbers here (where 0/uninitialized == INVALID).
*/ */
typedef enum tap_state typedef enum tap_state {
{
TAP_INVALID = -1, TAP_INVALID = -1,
#if BUILD_ZY1000 #if BUILD_ZY1000
@ -92,10 +92,10 @@ typedef enum tap_state
*/ */
const char *tap_state_name(tap_state_t state); const char *tap_state_name(tap_state_t state);
/// Provides user-friendly name lookup of TAP states. /** Provides user-friendly name lookup of TAP states. */
tap_state_t tap_state_by_name(const char *name); tap_state_t tap_state_by_name(const char *name);
/// The current TAP state of the pending JTAG command queue. /** The current TAP state of the pending JTAG command queue. */
extern tap_state_t cmd_queue_cur_state; extern tap_state_t cmd_queue_cur_state;
/** /**
@ -107,54 +107,54 @@ extern tap_state_t cmd_queue_cur_state;
* jtag_add_dr_scan_check() to validate the value that was scanned out. * jtag_add_dr_scan_check() to validate the value that was scanned out.
*/ */
struct scan_field { struct scan_field {
/// The number of bits this field specifies (up to 32) /** The number of bits this field specifies (up to 32) */
int num_bits; int num_bits;
/// A pointer to value to be scanned into the device /** A pointer to value to be scanned into the device */
const uint8_t* out_value; const uint8_t *out_value;
/// A pointer to a 32-bit memory location for data scanned out /** A pointer to a 32-bit memory location for data scanned out */
uint8_t* in_value; uint8_t *in_value;
/// The value used to check the data scanned out. /** The value used to check the data scanned out. */
uint8_t* check_value; uint8_t *check_value;
/// The mask to go with check_value /** The mask to go with check_value */
uint8_t* check_mask; uint8_t *check_mask;
}; };
struct jtag_tap { struct jtag_tap {
const char* chip; const char *chip;
const char* tapname; const char *tapname;
const char* dotted_name; const char *dotted_name;
int abs_chain_position; int abs_chain_position;
/// Is this TAP disabled after JTAG reset? /** Is this TAP disabled after JTAG reset? */
bool disabled_after_reset; bool disabled_after_reset;
/// Is this TAP currently enabled? /** Is this TAP currently enabled? */
bool enabled; bool enabled;
int ir_length; /**< size of instruction register */ int ir_length; /**< size of instruction register */
uint32_t ir_capture_value; uint32_t ir_capture_value;
uint8_t* expected; /**< Capture-IR expected value */ uint8_t *expected; /**< Capture-IR expected value */
uint32_t ir_capture_mask; uint32_t ir_capture_mask;
uint8_t* expected_mask; /**< Capture-IR expected mask */ uint8_t *expected_mask; /**< Capture-IR expected mask */
uint32_t idcode; /**< device identification code */ uint32_t idcode; /**< device identification code */
/** not all devices have idcode, /** not all devices have idcode,
* we'll discover this during chain examination */ * we'll discover this during chain examination */
bool hasidcode; bool hasidcode;
/// Array of expected identification codes */ /** Array of expected identification codes */
uint32_t* expected_ids; uint32_t *expected_ids;
/// Number of expected identification codes /** Number of expected identification codes */
uint8_t expected_ids_cnt; uint8_t expected_ids_cnt;
/// Flag saying whether to ignore version field in expected_ids[] /** Flag saying whether to ignore version field in expected_ids[] */
bool ignore_version; bool ignore_version;
/// current instruction /** current instruction */
uint8_t* cur_instr; uint8_t *cur_instr;
/// Bypass register selected /** Bypass register selected */
int bypass; int bypass;
struct jtag_tap_event_action *event_action; struct jtag_tap_event_action *event_action;
struct jtag_tap* next_tap; struct jtag_tap *next_tap;
/* dap instance if some null if no instance , initialized to 0 by calloc*/ /* dap instance if some null if no instance , initialized to 0 by calloc*/
struct adiv5_dap *dap; struct adiv5_dap *dap;
/* private pointer to support none-jtag specific functions */ /* private pointer to support none-jtag specific functions */
@ -164,16 +164,15 @@ struct jtag_tap {
void jtag_tap_init(struct jtag_tap *tap); void jtag_tap_init(struct jtag_tap *tap);
void jtag_tap_free(struct jtag_tap *tap); void jtag_tap_free(struct jtag_tap *tap);
struct jtag_tap* jtag_all_taps(void); struct jtag_tap *jtag_all_taps(void);
const char *jtag_tap_name(const struct jtag_tap *tap); const char *jtag_tap_name(const struct jtag_tap *tap);
struct jtag_tap* jtag_tap_by_string(const char* dotted_name); struct jtag_tap *jtag_tap_by_string(const char* dotted_name);
struct jtag_tap* jtag_tap_by_jim_obj(Jim_Interp* interp, Jim_Obj* obj); struct jtag_tap *jtag_tap_by_jim_obj(Jim_Interp* interp, Jim_Obj *obj);
struct jtag_tap* jtag_tap_by_position(unsigned abs_position); struct jtag_tap *jtag_tap_by_position(unsigned abs_position);
struct jtag_tap* jtag_tap_next_enabled(struct jtag_tap* p); struct jtag_tap *jtag_tap_next_enabled(struct jtag_tap *p);
unsigned jtag_tap_count_enabled(void); unsigned jtag_tap_count_enabled(void);
unsigned jtag_tap_count(void); unsigned jtag_tap_count(void);
/* /*
* - TRST_ASSERTED triggers two sets of callbacks, after operations to * - TRST_ASSERTED triggers two sets of callbacks, after operations to
* reset the scan chain -- via TMS+TCK signaling, or deasserting the * reset the scan chain -- via TMS+TCK signaling, or deasserting the
@ -203,15 +202,14 @@ enum jtag_event {
JTAG_TAP_EVENT_DISABLE, JTAG_TAP_EVENT_DISABLE,
}; };
struct jtag_tap_event_action struct jtag_tap_event_action {
{ /** The event for which this action will be triggered. */
/// The event for which this action will be triggered.
enum jtag_event event; enum jtag_event event;
/// The interpreter to use for evaluating the @c body. /** The interpreter to use for evaluating the @c body. */
Jim_Interp *interp; Jim_Interp *interp;
/// Contains a script to 'eval' when the @c event is triggered. /** Contains a script to 'eval' when the @c event is triggered. */
Jim_Obj *body; Jim_Obj *body;
// next action in linked list /* next action in linked list */
struct jtag_tap_event_action *next; struct jtag_tap_event_action *next;
}; };
@ -226,7 +224,7 @@ struct jtag_tap_event_action
* *
* @todo Change to return void or define a use for its return code. * @todo Change to return void or define a use for its return code.
*/ */
typedef int (*jtag_event_handler_t)(enum jtag_event event, void* priv); typedef int (*jtag_event_handler_t)(enum jtag_event event, void *priv);
int jtag_register_event_callback(jtag_event_handler_t f, void *x); int jtag_register_event_callback(jtag_event_handler_t f, void *x);
int jtag_unregister_event_callback(jtag_event_handler_t f, void *x); int jtag_unregister_event_callback(jtag_event_handler_t f, void *x);
@ -234,7 +232,7 @@ int jtag_unregister_event_callback(jtag_event_handler_t f, void *x);
int jtag_call_event_callbacks(enum jtag_event event); int jtag_call_event_callbacks(enum jtag_event event);
/// @returns The current JTAG speed setting. /** @returns The current JTAG speed setting. */
int jtag_get_speed(int *speed); int jtag_get_speed(int *speed);
/** /**
@ -246,7 +244,7 @@ int jtag_get_speed(int *speed);
*/ */
int jtag_get_speed_readable(int *speed); int jtag_get_speed_readable(int *speed);
/// Attempt to configure the interface for the specified KHz. /** Attempt to configure the interface for the specified KHz. */
int jtag_config_khz(unsigned khz); int jtag_config_khz(unsigned khz);
/** /**
@ -255,10 +253,9 @@ int jtag_config_khz(unsigned khz);
*/ */
int jtag_config_rclk(unsigned fallback_speed_khz); int jtag_config_rclk(unsigned fallback_speed_khz);
/// Retreives the clock speed of the JTAG interface in KHz. /** Retreives the clock speed of the JTAG interface in KHz. */
unsigned jtag_get_speed_khz(void); unsigned jtag_get_speed_khz(void);
enum reset_types { enum reset_types {
RESET_NONE = 0x0, RESET_NONE = 0x0,
RESET_HAS_TRST = 0x1, RESET_HAS_TRST = 0x1,
@ -286,40 +283,39 @@ unsigned jtag_get_nsrst_assert_width(void);
void jtag_set_ntrst_assert_width(unsigned delay); void jtag_set_ntrst_assert_width(unsigned delay);
unsigned jtag_get_ntrst_assert_width(void); unsigned jtag_get_ntrst_assert_width(void);
/// @returns The current state of TRST. /** @returns The current state of TRST. */
int jtag_get_trst(void); int jtag_get_trst(void);
/// @returns The current state of SRST. /** @returns The current state of SRST. */
int jtag_get_srst(void); int jtag_get_srst(void);
/// Enable or disable data scan verification checking. /** Enable or disable data scan verification checking. */
void jtag_set_verify(bool enable); void jtag_set_verify(bool enable);
/// @returns True if data scan verification will be performed. /** @returns True if data scan verification will be performed. */
bool jtag_will_verify(void); bool jtag_will_verify(void);
/// Enable or disable verification of IR scan checking. /** Enable or disable verification of IR scan checking. */
void jtag_set_verify_capture_ir(bool enable); void jtag_set_verify_capture_ir(bool enable);
/// @returns True if IR scan verification will be performed. /** @returns True if IR scan verification will be performed. */
bool jtag_will_verify_capture_ir(void); bool jtag_will_verify_capture_ir(void);
/** Initialize debug adapter upon startup. */ /** Initialize debug adapter upon startup. */
int adapter_init(struct command_context* cmd_ctx); int adapter_init(struct command_context *cmd_ctx);
/// Shutdown the debug adapter upon program exit. /** Shutdown the debug adapter upon program exit. */
int adapter_quit(void); int adapter_quit(void);
/// Set ms to sleep after jtag_execute_queue() flushes queue. Debug /** Set ms to sleep after jtag_execute_queue() flushes queue. Debug purposes. */
/// purposes.
void jtag_set_flush_queue_sleep(int ms); void jtag_set_flush_queue_sleep(int ms);
/** /**
* Initialize JTAG chain using only a RESET reset. If init fails, * Initialize JTAG chain using only a RESET reset. If init fails,
* try reset + init. * try reset + init.
*/ */
int jtag_init(struct command_context* cmd_ctx); int jtag_init(struct command_context *cmd_ctx);
/// reset, then initialize JTAG chain /** reset, then initialize JTAG chain */
int jtag_init_reset(struct command_context* cmd_ctx); int jtag_init_reset(struct command_context *cmd_ctx);
int jtag_register_commands(struct command_context* cmd_ctx); int jtag_register_commands(struct command_context *cmd_ctx);
int jtag_init_inner(struct command_context *cmd_ctx); int jtag_init_inner(struct command_context *cmd_ctx);
/** /**
@ -347,13 +343,13 @@ int jtag_init_inner(struct command_context *cmd_ctx);
* subsequent DR SCANs. * subsequent DR SCANs.
* *
*/ */
void jtag_add_ir_scan(struct jtag_tap* tap, void jtag_add_ir_scan(struct jtag_tap *tap,
struct scan_field* fields, tap_state_t endstate); struct scan_field *fields, tap_state_t endstate);
/** /**
* The same as jtag_add_ir_scan except no verification is performed out * The same as jtag_add_ir_scan except no verification is performed out
* the output values. * the output values.
*/ */
void jtag_add_ir_scan_noverify(struct jtag_tap* tap, void jtag_add_ir_scan_noverify(struct jtag_tap *tap,
const struct scan_field *fields, tap_state_t state); const struct scan_field *fields, tap_state_t state);
/** /**
* Scan out the bits in ir scan mode. * Scan out the bits in ir scan mode.
@ -363,18 +359,17 @@ void jtag_add_ir_scan_noverify(struct jtag_tap* tap,
void jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits, void jtag_add_plain_ir_scan(int num_bits, const uint8_t *out_bits, uint8_t *in_bits,
tap_state_t endstate); tap_state_t endstate);
/** /**
* Generate a DR SCAN using the fields passed to the function. * Generate a DR SCAN using the fields passed to the function.
* For connected TAPs, the function checks in_fields and uses fields * For connected TAPs, the function checks in_fields and uses fields
* specified there. For bypassed TAPs, the function generates a dummy * specified there. For bypassed TAPs, the function generates a dummy
* 1-bit field. The bypass status of TAPs is set by jtag_add_ir_scan(). * 1-bit field. The bypass status of TAPs is set by jtag_add_ir_scan().
*/ */
void jtag_add_dr_scan(struct jtag_tap* tap, int num_fields, void jtag_add_dr_scan(struct jtag_tap *tap, int num_fields,
const struct scan_field* fields, tap_state_t endstate); const struct scan_field *fields, tap_state_t endstate);
/// A version of jtag_add_dr_scan() that uses the check_value/mask fields /** A version of jtag_add_dr_scan() that uses the check_value/mask fields */
void jtag_add_dr_scan_check(struct jtag_tap* tap, int num_fields, void jtag_add_dr_scan_check(struct jtag_tap *tap, int num_fields,
struct scan_field* fields, tap_state_t endstate); struct scan_field *fields, tap_state_t endstate);
/** /**
* Scan out the bits in ir scan mode. * Scan out the bits in ir scan mode.
* *
@ -399,7 +394,7 @@ typedef intptr_t jtag_callback_data_t;
*/ */
typedef void (*jtag_callback1_t)(jtag_callback_data_t data0); typedef void (*jtag_callback1_t)(jtag_callback_data_t data0);
/// A simpler version of jtag_add_callback4(). /** A simpler version of jtag_add_callback4(). */
void jtag_add_callback(jtag_callback1_t, jtag_callback_data_t data0); void jtag_add_callback(jtag_callback1_t, jtag_callback_data_t data0);
@ -489,7 +484,7 @@ void jtag_add_tlr(void);
* - ERROR_JTAG_TRANSITION_INVALID -- The path includes invalid * - ERROR_JTAG_TRANSITION_INVALID -- The path includes invalid
* state transitions. * state transitions.
*/ */
void jtag_add_pathmove(int num_states, const tap_state_t* path); void jtag_add_pathmove(int num_states, const tap_state_t *path);
/** /**
* jtag_add_statemove() moves from the current state to @a goal_state. * jtag_add_statemove() moves from the current state to @a goal_state.
@ -550,7 +545,6 @@ int jtag_add_tms_seq(unsigned nbits, const uint8_t *seq, enum tap_state t);
*/ */
void jtag_add_clocks(int num_cycles); void jtag_add_clocks(int num_cycles);
/** /**
* For software FIFO implementations, the queued commands can be executed * For software FIFO implementations, the queued commands can be executed
* during this call or earlier. A sw queue might decide to push out * during this call or earlier. A sw queue might decide to push out
@ -573,19 +567,18 @@ void jtag_add_clocks(int num_cycles);
*/ */
int jtag_execute_queue(void); int jtag_execute_queue(void);
/// same as jtag_execute_queue() but does not clear the error flag /** same as jtag_execute_queue() but does not clear the error flag */
void jtag_execute_queue_noclear(void); void jtag_execute_queue_noclear(void);
/// @returns the number of times the scan queue has been flushed /** @returns the number of times the scan queue has been flushed */
int jtag_get_flush_queue_count(void); int jtag_get_flush_queue_count(void);
/// Report Tcl event to all TAPs /** Report Tcl event to all TAPs */
void jtag_notify_event(enum jtag_event); void jtag_notify_event(enum jtag_event);
/* can be implemented by hw + sw */ /* can be implemented by hw + sw */
int jtag_power_dropout(int* dropout); int jtag_power_dropout(int *dropout);
int jtag_srst_asserted(int* srst_asserted); int jtag_srst_asserted(int *srst_asserted);
/* JTAG support functions */ /* JTAG support functions */
@ -642,7 +635,6 @@ void jtag_sleep(uint32_t us);
* clocking data back in. Patches gladly accepted! * clocking data back in. Patches gladly accepted!
*/ */
/** /**
* Set the current JTAG core execution error, unless one was set * Set the current JTAG core execution error, unless one was set
* by a previous call previously. Driver or application code must * by a previous call previously. Driver or application code must

View File

@ -23,6 +23,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifndef MINIDRIVER_H #ifndef MINIDRIVER_H
#define MINIDRIVER_H #define MINIDRIVER_H
@ -45,26 +46,26 @@
* - default_interface_jtag_execute_queue() * - default_interface_jtag_execute_queue()
*/ */
// this header will be provided by the minidriver implementation, /* this header will be provided by the minidriver implementation, */
// and it may provide additional declarations that must be defined. /* and it may provide additional declarations that must be defined. */
#include <jtag/minidriver_imp.h> #include <jtag/minidriver_imp.h>
int interface_jtag_add_ir_scan(struct jtag_tap* active, int interface_jtag_add_ir_scan(struct jtag_tap *active,
const struct scan_field* fields, const struct scan_field *fields,
tap_state_t endstate); tap_state_t endstate);
int interface_jtag_add_plain_ir_scan( int interface_jtag_add_plain_ir_scan(
int num_bits, const uint8_t *out_bits, uint8_t *in_bits, int num_bits, const uint8_t *out_bits, uint8_t *in_bits,
tap_state_t endstate); tap_state_t endstate);
int interface_jtag_add_dr_scan(struct jtag_tap* active, int interface_jtag_add_dr_scan(struct jtag_tap *active,
int num_fields, const struct scan_field* fields, int num_fields, const struct scan_field *fields,
tap_state_t endstate); tap_state_t endstate);
int interface_jtag_add_plain_dr_scan( int interface_jtag_add_plain_dr_scan(
int num_bits, const uint8_t *out_bits, uint8_t *in_bits, int num_bits, const uint8_t *out_bits, uint8_t *in_bits,
tap_state_t endstate); tap_state_t endstate);
int interface_jtag_add_tlr(void); int interface_jtag_add_tlr(void);
int interface_jtag_add_pathmove(int num_states, const tap_state_t* path); int interface_jtag_add_pathmove(int num_states, const tap_state_t *path);
int interface_jtag_add_runtest(int num_cycles, tap_state_t endstate); int interface_jtag_add_runtest(int num_cycles, tap_state_t endstate);
int interface_add_tms_seq(unsigned num_bits, int interface_add_tms_seq(unsigned num_bits,
@ -89,4 +90,4 @@ int interface_jtag_execute_queue(void);
*/ */
int default_interface_jtag_execute_queue(void); int default_interface_jtag_execute_queue(void);
#endif // MINIDRIVER_H #endif /* MINIDRIVER_H */

View File

@ -1,4 +1,21 @@
// /***************************************************************************
* Copyright (C) 2009-2010 by David Brownell *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
/* Bits in SWD command packets, written from host to target /* Bits in SWD command packets, written from host to target
* first bit on the wire is START * first bit on the wire is START
@ -33,7 +50,7 @@ static inline uint8_t swd_cmd(bool is_read, bool is_ap, uint8_t regnum)
| (is_read ? SWD_CMD_RnW : 0) | (is_read ? SWD_CMD_RnW : 0)
| ((regnum & 0xc) << 1); | ((regnum & 0xc) << 1);
//8 cmd bits 4:1 may be set /* 8 cmd bits 4:1 may be set */
if (nibble_parity(cmd >> 1)) if (nibble_parity(cmd >> 1))
cmd |= SWD_CMD_PARITY; cmd |= SWD_CMD_PARITY;

View File

@ -27,6 +27,7 @@
* Free Software Foundation, Inc., * * Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/ ***************************************************************************/
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#endif #endif
@ -72,8 +73,7 @@ struct jtag_tap *jtag_tap_by_jim_obj(Jim_Interp *interp, Jim_Obj *o)
static bool scan_is_safe(tap_state_t state) static bool scan_is_safe(tap_state_t state)
{ {
switch (state) switch (state) {
{
case TAP_RESET: case TAP_RESET:
case TAP_IDLE: case TAP_IDLE:
case TAP_DRPAUSE: case TAP_DRPAUSE:
@ -103,8 +103,7 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
* args[N-2] = "-endstate" * args[N-2] = "-endstate"
* args[N-1] = statename * args[N-1] = statename
*/ */
if ((argc < 4) || ((argc % 2) != 0)) if ((argc < 4) || ((argc % 2) != 0)) {
{
Jim_WrongNumArgs(interp, 1, args, "wrong arguments"); Jim_WrongNumArgs(interp, 1, args, "wrong arguments");
return JIM_ERR; return JIM_ERR;
} }
@ -115,16 +114,14 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
/* validate arguments as numbers */ /* validate arguments as numbers */
e = JIM_OK; e = JIM_OK;
for (i = 2; i < argc; i += 2) for (i = 2; i < argc; i += 2) {
{
long bits; long bits;
const char *cp; const char *cp;
e = Jim_GetLong(interp, args[i], &bits); e = Jim_GetLong(interp, args[i], &bits);
/* If valid - try next arg */ /* If valid - try next arg */
if (e == JIM_OK) { if (e == JIM_OK)
continue; continue;
}
/* Not valid.. are we at the end? */ /* Not valid.. are we at the end? */
if (((i + 2) != argc)) { if (((i + 2) != argc)) {
@ -148,7 +145,7 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
endstate = tap_state_by_name(cp); endstate = tap_state_by_name(cp);
if (endstate < 0) { if (endstate < 0) {
/* update the error message */ /* update the error message */
Jim_SetResultFormatted(interp,"endstate: %s invalid", cp); Jim_SetResultFormatted(interp, "endstate: %s invalid", cp);
} else { } else {
if (!scan_is_safe(endstate)) if (!scan_is_safe(endstate))
LOG_WARNING("drscan with unsafe " LOG_WARNING("drscan with unsafe "
@ -162,23 +159,20 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
} }
/* Still an error? */ /* Still an error? */
if (e != JIM_OK) { if (e != JIM_OK)
return e; /* too bad */ return e; /* too bad */
}
} /* validate args */ } /* validate args */
assert(e == JIM_OK); assert(e == JIM_OK);
tap = jtag_tap_by_jim_obj(interp, args[1]); tap = jtag_tap_by_jim_obj(interp, args[1]);
if (tap == NULL) { if (tap == NULL)
return JIM_ERR; return JIM_ERR;
}
num_fields = (argc-2)/2; num_fields = (argc-2)/2;
assert(num_fields > 0); assert(num_fields > 0);
fields = malloc(sizeof(struct scan_field) * num_fields); fields = malloc(sizeof(struct scan_field) * num_fields);
for (i = 2; i < argc; i += 2) for (i = 2; i < argc; i += 2) {
{
long bits; long bits;
int len; int len;
const char *str; const char *str;
@ -187,7 +181,7 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
str = Jim_GetString(args[i + 1], &len); str = Jim_GetString(args[i + 1], &len);
fields[field_count].num_bits = bits; fields[field_count].num_bits = bits;
void * t = malloc(DIV_ROUND_UP(bits, 8)); void *t = malloc(DIV_ROUND_UP(bits, 8));
fields[field_count].out_value = t; fields[field_count].out_value = t;
str_to_buf(str, len, t, bits, 0); str_to_buf(str, len, t, bits, 0);
fields[field_count].in_value = t; fields[field_count].in_value = t;
@ -197,16 +191,14 @@ static int Jim_Command_drscan(Jim_Interp *interp, int argc, Jim_Obj *const *args
jtag_add_dr_scan(tap, num_fields, fields, endstate); jtag_add_dr_scan(tap, num_fields, fields, endstate);
retval = jtag_execute_queue(); retval = jtag_execute_queue();
if (retval != ERROR_OK) if (retval != ERROR_OK) {
{ Jim_SetResultString(interp, "drscan: jtag execute failed", -1);
Jim_SetResultString(interp, "drscan: jtag execute failed",-1);
return JIM_ERR; return JIM_ERR;
} }
field_count = 0; field_count = 0;
Jim_Obj *list = Jim_NewListObj(interp, NULL, 0); Jim_Obj *list = Jim_NewListObj(interp, NULL, 0);
for (i = 2; i < argc; i += 2) for (i = 2; i < argc; i += 2) {
{
long bits; long bits;
char *str; char *str;
@ -231,8 +223,7 @@ static int Jim_Command_pathmove(Jim_Interp *interp, int argc, Jim_Obj *const *ar
{ {
tap_state_t states[8]; tap_state_t states[8];
if ((argc < 2) || ((size_t)argc > (ARRAY_SIZE(states) + 1))) if ((argc < 2) || ((size_t)argc > (ARRAY_SIZE(states) + 1))) {
{
Jim_WrongNumArgs(interp, 1, args, "wrong arguments"); Jim_WrongNumArgs(interp, 1, args, "wrong arguments");
return JIM_ERR; return JIM_ERR;
} }
@ -240,30 +231,26 @@ static int Jim_Command_pathmove(Jim_Interp *interp, int argc, Jim_Obj *const *ar
script_debug(interp, "pathmove", argc, args); script_debug(interp, "pathmove", argc, args);
int i; int i;
for (i = 0; i < argc-1; i++) for (i = 0; i < argc-1; i++) {
{
const char *cp; const char *cp;
cp = Jim_GetString(args[i + 1], NULL); cp = Jim_GetString(args[i + 1], NULL);
states[i] = tap_state_by_name(cp); states[i] = tap_state_by_name(cp);
if (states[i] < 0) if (states[i] < 0) {
{
/* update the error message */ /* update the error message */
Jim_SetResultFormatted(interp,"endstate: %s invalid", cp); Jim_SetResultFormatted(interp, "endstate: %s invalid", cp);
return JIM_ERR; return JIM_ERR;
} }
} }
if ((jtag_add_statemove(states[0]) != ERROR_OK) || (jtag_execute_queue()!= ERROR_OK)) if ((jtag_add_statemove(states[0]) != ERROR_OK) || (jtag_execute_queue() != ERROR_OK)) {
{ Jim_SetResultString(interp, "pathmove: jtag execute failed", -1);
Jim_SetResultString(interp, "pathmove: jtag execute failed",-1);
return JIM_ERR; return JIM_ERR;
} }
jtag_add_pathmove(argc-2, states + 1); jtag_add_pathmove(argc - 2, states + 1);
if (jtag_execute_queue()!= ERROR_OK) if (jtag_execute_queue() != ERROR_OK) {
{ Jim_SetResultString(interp, "pathmove: failed", -1);
Jim_SetResultString(interp, "pathmove: failed",-1);
return JIM_ERR; return JIM_ERR;
} }
@ -328,25 +315,26 @@ static Jim_Nvp nvp_config_opts[] = {
{ .name = NULL, .value = -1 } { .name = NULL, .value = -1 }
}; };
static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap) static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap *tap)
{ {
if (goi->argc == 0) if (goi->argc == 0) {
{
Jim_WrongNumArgs(goi->interp, goi->argc, goi->argv, "-event <event-name> ..."); Jim_WrongNumArgs(goi->interp, goi->argc, goi->argv, "-event <event-name> ...");
return JIM_ERR; return JIM_ERR;
} }
Jim_Nvp *n; Jim_Nvp *n;
int e = Jim_GetOpt_Nvp(goi, nvp_jtag_tap_event, &n); int e = Jim_GetOpt_Nvp(goi, nvp_jtag_tap_event, &n);
if (e != JIM_OK) if (e != JIM_OK) {
{
Jim_GetOpt_NvpUnknown(goi, nvp_jtag_tap_event, 1); Jim_GetOpt_NvpUnknown(goi, nvp_jtag_tap_event, 1);
return e; return e;
} }
if (goi->isconfigure) { if (goi->isconfigure) {
if (goi->argc != 1) { if (goi->argc != 1) {
Jim_WrongNumArgs(goi->interp, goi->argc, goi->argv, "-event <event-name> <event-body>"); Jim_WrongNumArgs(goi->interp,
goi->argc,
goi->argv,
"-event <event-name> <event-body>");
return JIM_ERR; return JIM_ERR;
} }
} else { } else {
@ -359,10 +347,8 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
struct jtag_tap_event_action *jteap = tap->event_action; struct jtag_tap_event_action *jteap = tap->event_action;
/* replace existing event body */ /* replace existing event body */
bool found = false; bool found = false;
while (jteap) while (jteap) {
{ if (jteap->event == (enum jtag_event)n->value) {
if (jteap->event == (enum jtag_event)n->value)
{
found = true; found = true;
break; break;
} }
@ -371,8 +357,7 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
Jim_SetEmptyResult(goi->interp); Jim_SetEmptyResult(goi->interp);
if (goi->isconfigure) if (goi->isconfigure) {
{
if (!found) if (!found)
jteap = calloc(1, sizeof(*jteap)); jteap = calloc(1, sizeof(*jteap));
else if (NULL != jteap->body) else if (NULL != jteap->body)
@ -386,15 +371,12 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
jteap->body = Jim_DuplicateObj(goi->interp, o); jteap->body = Jim_DuplicateObj(goi->interp, o);
Jim_IncrRefCount(jteap->body); Jim_IncrRefCount(jteap->body);
if (!found) if (!found) {
{
/* add to head of event list */ /* add to head of event list */
jteap->next = tap->event_action; jteap->next = tap->event_action;
tap->event_action = jteap; tap->event_action = jteap;
} }
} } else if (found) {
else if (found)
{
jteap->interp = goi->interp; jteap->interp = goi->interp;
Jim_SetResult(goi->interp, Jim_SetResult(goi->interp,
Jim_DuplicateObj(goi->interp, jteap->body)); Jim_DuplicateObj(goi->interp, jteap->body));
@ -402,23 +384,20 @@ static int jtag_tap_configure_event(Jim_GetOptInfo *goi, struct jtag_tap * tap)
return JIM_OK; return JIM_OK;
} }
static int jtag_tap_configure_cmd(Jim_GetOptInfo *goi, struct jtag_tap * tap) static int jtag_tap_configure_cmd(Jim_GetOptInfo *goi, struct jtag_tap *tap)
{ {
/* parse config or cget options */ /* parse config or cget options */
while (goi->argc > 0) while (goi->argc > 0) {
{ Jim_SetEmptyResult(goi->interp);
Jim_SetEmptyResult (goi->interp);
Jim_Nvp *n; Jim_Nvp *n;
int e = Jim_GetOpt_Nvp(goi, nvp_config_opts, &n); int e = Jim_GetOpt_Nvp(goi, nvp_config_opts, &n);
if (e != JIM_OK) if (e != JIM_OK) {
{
Jim_GetOpt_NvpUnknown(goi, nvp_config_opts, 0); Jim_GetOpt_NvpUnknown(goi, nvp_config_opts, 0);
return e; return e;
} }
switch (n->value) switch (n->value) {
{
case JCFG_EVENT: case JCFG_EVENT:
e = jtag_tap_configure_event(goi, tap); e = jtag_tap_configure_event(goi, tap);
if (e != JIM_OK) if (e != JIM_OK)
@ -455,8 +434,7 @@ static int jim_newtap_expected_id(Jim_Nvp *n, Jim_GetOptInfo *goi,
unsigned expected_len = sizeof(uint32_t) * pTap->expected_ids_cnt; unsigned expected_len = sizeof(uint32_t) * pTap->expected_ids_cnt;
uint32_t *new_expected_ids = malloc(expected_len + sizeof(uint32_t)); uint32_t *new_expected_ids = malloc(expected_len + sizeof(uint32_t));
if (new_expected_ids == NULL) if (new_expected_ids == NULL) {
{
Jim_SetResultFormatted(goi->interp, "no memory"); Jim_SetResultFormatted(goi->interp, "no memory");
return JIM_ERR; return JIM_ERR;
} }
@ -485,8 +463,7 @@ static int jim_newtap_ir_param(Jim_Nvp *n, Jim_GetOptInfo *goi,
{ {
jim_wide w; jim_wide w;
int e = Jim_GetOpt_Wide(goi, &w); int e = Jim_GetOpt_Wide(goi, &w);
if (e != JIM_OK) if (e != JIM_OK) {
{
Jim_SetResultFormatted(goi->interp, Jim_SetResultFormatted(goi->interp,
"option: %s bad parameter", n->name); "option: %s bad parameter", n->name);
free((void *)pTap->dotted_name); free((void *)pTap->dotted_name);
@ -494,16 +471,14 @@ static int jim_newtap_ir_param(Jim_Nvp *n, Jim_GetOptInfo *goi,
} }
switch (n->value) { switch (n->value) {
case NTAP_OPT_IRLEN: case NTAP_OPT_IRLEN:
if (w > (jim_wide) (8 * sizeof(pTap->ir_capture_value))) if (w > (jim_wide) (8 * sizeof(pTap->ir_capture_value))) {
{
LOG_WARNING("%s: huge IR length %d", LOG_WARNING("%s: huge IR length %d",
pTap->dotted_name, (int) w); pTap->dotted_name, (int) w);
} }
pTap->ir_length = w; pTap->ir_length = w;
break; break;
case NTAP_OPT_IRMASK: case NTAP_OPT_IRMASK:
if (is_bad_irval(pTap->ir_length, w)) if (is_bad_irval(pTap->ir_length, w)) {
{
LOG_ERROR("%s: IR mask %x too big", LOG_ERROR("%s: IR mask %x too big",
pTap->dotted_name, pTap->dotted_name,
(int) w); (int) w);
@ -514,8 +489,7 @@ static int jim_newtap_ir_param(Jim_Nvp *n, Jim_GetOptInfo *goi,
pTap->ir_capture_mask = w; pTap->ir_capture_mask = w;
break; break;
case NTAP_OPT_IRCAPTURE: case NTAP_OPT_IRCAPTURE:
if (is_bad_irval(pTap->ir_length, w)) if (is_bad_irval(pTap->ir_length, w)) {
{
LOG_ERROR("%s: IR capture %x too big", LOG_ERROR("%s: IR capture %x too big",
pTap->dotted_name, (int) w); pTap->dotted_name, (int) w);
return JIM_ERR; return JIM_ERR;
@ -539,14 +513,14 @@ static int jim_newtap_cmd(Jim_GetOptInfo *goi)
Jim_Nvp *n; Jim_Nvp *n;
char *cp; char *cp;
const Jim_Nvp opts[] = { const Jim_Nvp opts[] = {
{ .name = "-irlen" , .value = NTAP_OPT_IRLEN }, { .name = "-irlen", .value = NTAP_OPT_IRLEN },
{ .name = "-irmask" , .value = NTAP_OPT_IRMASK }, { .name = "-irmask", .value = NTAP_OPT_IRMASK },
{ .name = "-ircapture" , .value = NTAP_OPT_IRCAPTURE }, { .name = "-ircapture", .value = NTAP_OPT_IRCAPTURE },
{ .name = "-enable" , .value = NTAP_OPT_ENABLED }, { .name = "-enable", .value = NTAP_OPT_ENABLED },
{ .name = "-disable" , .value = NTAP_OPT_DISABLED }, { .name = "-disable", .value = NTAP_OPT_DISABLED },
{ .name = "-expected-id" , .value = NTAP_OPT_EXPECTED_ID }, { .name = "-expected-id", .value = NTAP_OPT_EXPECTED_ID },
{ .name = "-ignore-version" , .value = NTAP_OPT_VERSION }, { .name = "-ignore-version", .value = NTAP_OPT_VERSION },
{ .name = NULL , .value = -1 }, { .name = NULL, .value = -1 },
}; };
pTap = calloc(1, sizeof(struct jtag_tap)); pTap = calloc(1, sizeof(struct jtag_tap));
@ -603,8 +577,7 @@ static int jim_newtap_cmd(Jim_GetOptInfo *goi)
break; break;
case NTAP_OPT_EXPECTED_ID: case NTAP_OPT_EXPECTED_ID:
e = jim_newtap_expected_id(n, goi, pTap); e = jim_newtap_expected_id(n, goi, pTap);
if (JIM_OK != e) if (JIM_OK != e) {
{
free((void *)pTap->dotted_name); free((void *)pTap->dotted_name);
free(pTap); free(pTap);
return e; return e;
@ -614,8 +587,7 @@ static int jim_newtap_cmd(Jim_GetOptInfo *goi)
case NTAP_OPT_IRMASK: case NTAP_OPT_IRMASK:
case NTAP_OPT_IRCAPTURE: case NTAP_OPT_IRCAPTURE:
e = jim_newtap_ir_param(n, goi, pTap); e = jim_newtap_ir_param(n, goi, pTap);
if (JIM_OK != e) if (JIM_OK != e) {
{
free((void *)pTap->dotted_name); free((void *)pTap->dotted_name);
free(pTap); free(pTap);
return e; return e;
@ -631,8 +603,7 @@ static int jim_newtap_cmd(Jim_GetOptInfo *goi)
pTap->enabled = !pTap->disabled_after_reset; pTap->enabled = !pTap->disabled_after_reset;
/* Did all the required option bits get cleared? */ /* Did all the required option bits get cleared? */
if (pTap->ir_length != 0) if (pTap->ir_length != 0) {
{
jtag_tap_init(pTap); jtag_tap_init(pTap);
return JIM_OK; return JIM_OK;
} }
@ -646,10 +617,9 @@ static int jim_newtap_cmd(Jim_GetOptInfo *goi)
static void jtag_tap_handle_event(struct jtag_tap *tap, enum jtag_event e) static void jtag_tap_handle_event(struct jtag_tap *tap, enum jtag_event e)
{ {
struct jtag_tap_event_action * jteap; struct jtag_tap_event_action *jteap;
for (jteap = tap->event_action; jteap != NULL; jteap = jteap->next) for (jteap = tap->event_action; jteap != NULL; jteap = jteap->next) {
{
if (jteap->event != e) if (jteap->event != e)
continue; continue;
@ -658,15 +628,13 @@ static void jtag_tap_handle_event(struct jtag_tap *tap, enum jtag_event e)
tap->dotted_name, e, nvp->name, tap->dotted_name, e, nvp->name,
Jim_GetString(jteap->body, NULL)); Jim_GetString(jteap->body, NULL));
if (Jim_EvalObj(jteap->interp, jteap->body) != JIM_OK) if (Jim_EvalObj(jteap->interp, jteap->body) != JIM_OK) {
{
Jim_MakeErrorMessage(jteap->interp); Jim_MakeErrorMessage(jteap->interp);
LOG_USER("%s", Jim_GetString(Jim_GetResult(jteap->interp), NULL)); LOG_USER("%s", Jim_GetString(Jim_GetResult(jteap->interp), NULL));
continue; continue;
} }
switch (e) switch (e) {
{
case JTAG_TAP_EVENT_ENABLE: case JTAG_TAP_EVENT_ENABLE:
case JTAG_TAP_EVENT_DISABLE: case JTAG_TAP_EVENT_DISABLE:
/* NOTE: we currently assume the handlers /* NOTE: we currently assume the handlers
@ -759,7 +727,7 @@ static bool jtag_tap_disable(struct jtag_tap *t)
return true; return true;
} }
int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, Jim_Obj * const *argv) int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
{ {
const char *cmd_name = Jim_GetString(argv[0], NULL); const char *cmd_name = Jim_GetString(argv[0], NULL);
Jim_GetOptInfo goi; Jim_GetOptInfo goi;
@ -776,14 +744,14 @@ int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, Jim_Obj * const *argv)
return JIM_ERR; return JIM_ERR;
if (strcasecmp(cmd_name, "tapisenabled") == 0) { if (strcasecmp(cmd_name, "tapisenabled") == 0) {
// do nothing, just return the value /* do nothing, just return the value */
} else if (strcasecmp(cmd_name, "tapenable") == 0) { } else if (strcasecmp(cmd_name, "tapenable") == 0) {
if (!jtag_tap_enable(t)){ if (!jtag_tap_enable(t)) {
LOG_WARNING("failed to enable tap %s", t->dotted_name); LOG_WARNING("failed to enable tap %s", t->dotted_name);
return JIM_ERR; return JIM_ERR;
} }
} else if (strcasecmp(cmd_name, "tapdisable") == 0) { } else if (strcasecmp(cmd_name, "tapdisable") == 0) {
if (!jtag_tap_disable(t)){ if (!jtag_tap_disable(t)) {
LOG_WARNING("failed to disable tap %s", t->dotted_name); LOG_WARNING("failed to disable tap %s", t->dotted_name);
return JIM_ERR; return JIM_ERR;
} }
@ -796,7 +764,7 @@ int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, Jim_Obj * const *argv)
return JIM_OK; return JIM_OK;
} }
int jim_jtag_configure(Jim_Interp *interp, int argc, Jim_Obj * const *argv) int jim_jtag_configure(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
{ {
const char *cmd_name = Jim_GetString(argv[0], NULL); const char *cmd_name = Jim_GetString(argv[0], NULL);
Jim_GetOptInfo goi; Jim_GetOptInfo goi;
@ -813,9 +781,8 @@ int jim_jtag_configure(Jim_Interp *interp, int argc, Jim_Obj * const *argv)
Jim_Obj *o; Jim_Obj *o;
Jim_GetOpt_Obj(&goi, &o); Jim_GetOpt_Obj(&goi, &o);
t = jtag_tap_by_jim_obj(goi.interp, o); t = jtag_tap_by_jim_obj(goi.interp, o);
if (t == NULL) { if (t == NULL)
return JIM_ERR; return JIM_ERR;
}
return jtag_tap_configure_cmd(&goi, t); return jtag_tap_configure_cmd(&goi, t);
} }
@ -845,9 +812,8 @@ COMMAND_HANDLER(handle_jtag_init_command)
if (CMD_ARGC != 0) if (CMD_ARGC != 0)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
static bool jtag_initialized = false; static bool jtag_initialized;
if (jtag_initialized) if (jtag_initialized) {
{
LOG_INFO("'jtag init' has already been called"); LOG_INFO("'jtag init' has already been called");
return ERROR_OK; return ERROR_OK;
} }
@ -961,9 +927,9 @@ COMMAND_HANDLER(handle_scan_chain_command)
tap = jtag_all_taps(); tap = jtag_all_taps();
command_print(CMD_CTX, command_print(CMD_CTX,
" TapName Enabled IdCode Expected IrLen IrCap IrMask"); " TapName Enabled IdCode Expected IrLen IrCap IrMask");
command_print(CMD_CTX, command_print(CMD_CTX,
"-- ------------------- -------- ---------- ---------- ----- ----- ------"); "-- ------------------- -------- ---------- ---------- ----- ----- ------");
while (tap) { while (tap) {
uint32_t expected, expected_mask, ii; uint32_t expected, expected_mask, ii;
@ -1010,8 +976,7 @@ COMMAND_HANDLER(handle_jtag_ntrst_delay_command)
{ {
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned delay; unsigned delay;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay);
@ -1025,8 +990,7 @@ COMMAND_HANDLER(handle_jtag_ntrst_assert_width_command)
{ {
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned delay; unsigned delay;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], delay);
@ -1042,8 +1006,7 @@ COMMAND_HANDLER(handle_jtag_rclk_command)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
int retval = ERROR_OK; int retval = ERROR_OK;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
unsigned khz = 0; unsigned khz = 0;
COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], khz); COMMAND_PARSE_NUMBER(uint, CMD_ARGV[0], khz);
@ -1121,9 +1084,7 @@ COMMAND_HANDLER(handle_irscan_command)
tap_state_t endstate; tap_state_t endstate;
if ((CMD_ARGC < 2) || (CMD_ARGC % 2)) if ((CMD_ARGC < 2) || (CMD_ARGC % 2))
{
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
}
/* optional "-endstate" "statename" at the end of the arguments, /* optional "-endstate" "statename" at the end of the arguments,
* so that e.g. IRPAUSE can let us load the data register before * so that e.g. IRPAUSE can let us load the data register before
@ -1132,8 +1093,8 @@ COMMAND_HANDLER(handle_irscan_command)
endstate = TAP_IDLE; endstate = TAP_IDLE;
if (CMD_ARGC >= 4) { if (CMD_ARGC >= 4) {
/* have at least one pair of numbers. */ /* have at least one pair of numbers.
/* is last pair the magic text? */ * is last pair the magic text? */
if (strcmp("-endstate", CMD_ARGV[CMD_ARGC - 2]) == 0) { if (strcmp("-endstate", CMD_ARGV[CMD_ARGC - 2]) == 0) {
endstate = tap_state_by_name(CMD_ARGV[CMD_ARGC - 1]); endstate = tap_state_by_name(CMD_ARGV[CMD_ARGC - 1]);
if (endstate == TAP_INVALID) if (endstate == TAP_INVALID)
@ -1146,8 +1107,7 @@ COMMAND_HANDLER(handle_irscan_command)
} }
int num_fields = CMD_ARGC / 2; int num_fields = CMD_ARGC / 2;
if (num_fields > 1) if (num_fields > 1) {
{
/* we really should be looking at plain_ir_scan if we want /* we really should be looking at plain_ir_scan if we want
* anything more fancy. * anything more fancy.
*/ */
@ -1160,11 +1120,9 @@ COMMAND_HANDLER(handle_irscan_command)
memset(fields, 0, fields_len); memset(fields, 0, fields_len);
int retval; int retval;
for (i = 0; i < num_fields; i++) for (i = 0; i < num_fields; i++) {
{
tap = jtag_tap_by_string(CMD_ARGV[i*2]); tap = jtag_tap_by_string(CMD_ARGV[i*2]);
if (tap == NULL) if (tap == NULL) {
{
int j; int j;
for (j = 0; j < i; j++) for (j = 0; j < i; j++)
free((void *)fields[j].out_value); free((void *)fields[j].out_value);
@ -1181,7 +1139,7 @@ COMMAND_HANDLER(handle_irscan_command)
retval = parse_u32(CMD_ARGV[i * 2 + 1], &value); retval = parse_u32(CMD_ARGV[i * 2 + 1], &value);
if (ERROR_OK != retval) if (ERROR_OK != retval)
goto error_return; goto error_return;
void *v = (void *)fields[i].out_value; void *v = (void *)fields[i].out_value;
buf_set_u32(v, 0, field_size, value); buf_set_u32(v, 0, field_size, value);
fields[i].in_value = NULL; fields[i].in_value = NULL;
} }
@ -1192,31 +1150,28 @@ void *v = (void *)fields[i].out_value;
retval = jtag_execute_queue(); retval = jtag_execute_queue();
error_return: error_return:
for (i = 0; i < num_fields; i++) for (i = 0; i < num_fields; i++) {
{
if (NULL != fields[i].out_value) if (NULL != fields[i].out_value)
free((void *)fields[i].out_value); free((void *)fields[i].out_value);
} }
free (fields); free(fields);
return retval; return retval;
} }
COMMAND_HANDLER(handle_verify_ircapture_command) COMMAND_HANDLER(handle_verify_ircapture_command)
{ {
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
bool enable; bool enable;
COMMAND_PARSE_ENABLE(CMD_ARGV[0], enable); COMMAND_PARSE_ENABLE(CMD_ARGV[0], enable);
jtag_set_verify_capture_ir(enable); jtag_set_verify_capture_ir(enable);
} }
const char *status = jtag_will_verify_capture_ir() ? "enabled": "disabled"; const char *status = jtag_will_verify_capture_ir() ? "enabled" : "disabled";
command_print(CMD_CTX, "verify Capture-IR is %s", status); command_print(CMD_CTX, "verify Capture-IR is %s", status);
return ERROR_OK; return ERROR_OK;
@ -1227,14 +1182,13 @@ COMMAND_HANDLER(handle_verify_jtag_command)
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
bool enable; bool enable;
COMMAND_PARSE_ENABLE(CMD_ARGV[0], enable); COMMAND_PARSE_ENABLE(CMD_ARGV[0], enable);
jtag_set_verify(enable); jtag_set_verify(enable);
} }
const char *status = jtag_will_verify() ? "enabled": "disabled"; const char *status = jtag_will_verify() ? "enabled" : "disabled";
command_print(CMD_CTX, "verify jtag capture is %s", status); command_print(CMD_CTX, "verify jtag capture is %s", status);
return ERROR_OK; return ERROR_OK;
@ -1245,8 +1199,7 @@ COMMAND_HANDLER(handle_tms_sequence_command)
if (CMD_ARGC > 1) if (CMD_ARGC > 1)
return ERROR_COMMAND_SYNTAX_ERROR; return ERROR_COMMAND_SYNTAX_ERROR;
if (CMD_ARGC == 1) if (CMD_ARGC == 1) {
{
bool use_new_table; bool use_new_table;
if (strcmp(CMD_ARGV[0], "short") == 0) if (strcmp(CMD_ARGV[0], "short") == 0)
use_new_table = true; use_new_table = true;
@ -1259,7 +1212,7 @@ COMMAND_HANDLER(handle_tms_sequence_command)
} }
command_print(CMD_CTX, "tms sequence is %s", command_print(CMD_CTX, "tms sequence is %s",
tap_uses_new_tms_table() ? "short": "long"); tap_uses_new_tms_table() ? "short" : "long");
return ERROR_OK; return ERROR_OK;
} }
@ -1284,8 +1237,7 @@ COMMAND_HANDLER(handle_wait_srst_deassert)
int timeout_ms; int timeout_ms;
COMMAND_PARSE_NUMBER(int, CMD_ARGV[0], timeout_ms); COMMAND_PARSE_NUMBER(int, CMD_ARGV[0], timeout_ms);
if ((timeout_ms <= 0) || (timeout_ms > 100000)) if ((timeout_ms <= 0) || (timeout_ms > 100000)) {
{
LOG_ERROR("Timeout must be an integer between 0 and 100000"); LOG_ERROR("Timeout must be an integer between 0 and 100000");
return ERROR_FAIL; return ERROR_FAIL;
} }
@ -1293,20 +1245,16 @@ COMMAND_HANDLER(handle_wait_srst_deassert)
LOG_USER("Waiting for srst assert + deassert for at most %dms", timeout_ms); LOG_USER("Waiting for srst assert + deassert for at most %dms", timeout_ms);
int asserted_yet; int asserted_yet;
long long then = timeval_ms(); long long then = timeval_ms();
while (jtag_srst_asserted(&asserted_yet) == ERROR_OK) while (jtag_srst_asserted(&asserted_yet) == ERROR_OK) {
{ if ((timeval_ms() - then) > timeout_ms) {
if ((timeval_ms() - then) > timeout_ms)
{
LOG_ERROR("Timed out"); LOG_ERROR("Timed out");
return ERROR_FAIL; return ERROR_FAIL;
} }
if (asserted_yet) if (asserted_yet)
break; break;
} }
while (jtag_srst_asserted(&asserted_yet) == ERROR_OK) while (jtag_srst_asserted(&asserted_yet) == ERROR_OK) {
{ if ((timeval_ms() - then) > timeout_ms) {
if ((timeval_ms() - then) > timeout_ms)
{
LOG_ERROR("Timed out"); LOG_ERROR("Timed out");
return ERROR_FAIL; return ERROR_FAIL;
} }
@ -1317,8 +1265,6 @@ COMMAND_HANDLER(handle_wait_srst_deassert)
return ERROR_OK; return ERROR_OK;
} }
static const struct command_registration jtag_command_handlers[] = { static const struct command_registration jtag_command_handlers[] = {
{ {

View File

@ -1,3 +1,33 @@
/***************************************************************************
* Copyright (C) 2005 by Dominic Rath *
* Dominic.Rath@gmx.de *
* *
* Copyright (C) 2007-2010 Øyvind Harboe *
* oyvind.harboe@zylin.com *
* *
* Copyright (C) 2009 SoftPLC Corporation *
* http://softplc.com *
* dick@softplc.com *
* *
* Copyright (C) 2009 Zachary T Welch *
* zw@superlucidity.net *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifndef _JTAG_TCL_H_ #ifndef _JTAG_TCL_H_
#define _JTAG_TCL_H_ #define _JTAG_TCL_H_