- jtag minidriver work in progress
- svn:eol-style=native. Let's see how that works out :-) git-svn-id: svn://svn.berlios.de/openocd/trunk@349 b42882b7-edfa-0310-969c-e2dbd0fdcd60__archive__
parent
5279d519f8
commit
11fa148944
178
src/jtag/jtag.c
178
src/jtag/jtag.c
|
@ -33,6 +33,18 @@
|
||||||
#include "string.h"
|
#include "string.h"
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#ifndef INTERFACE
|
||||||
|
/* this allows JTAG devices to implement the entire jtag_xxx() layer in hw/sw */
|
||||||
|
#define INTERFACE(a) a
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* note that this is not marked as static as it must be available from outside jtag.c for those
|
||||||
|
that implement the jtag_xxx() minidriver layer
|
||||||
|
*/
|
||||||
|
int jtag_error=ERROR_OK;
|
||||||
|
|
||||||
|
|
||||||
char* tap_state_strings[16] =
|
char* tap_state_strings[16] =
|
||||||
{
|
{
|
||||||
"tlr",
|
"tlr",
|
||||||
|
@ -380,17 +392,38 @@ void cmd_queue_free()
|
||||||
}
|
}
|
||||||
|
|
||||||
int jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state state)
|
int jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state state)
|
||||||
|
{
|
||||||
|
if (jtag_trst == 1)
|
||||||
|
{
|
||||||
|
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
||||||
|
jtag_error=ERROR_JTAG_TRST_ASSERTED;
|
||||||
|
return ERROR_JTAG_TRST_ASSERTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (state != -1)
|
||||||
|
cmd_queue_end_state = state;
|
||||||
|
|
||||||
|
if (cmd_queue_cur_state == TAP_TLR && cmd_queue_end_state != TAP_TLR)
|
||||||
|
jtag_call_event_callbacks(JTAG_TRST_RELEASED);
|
||||||
|
|
||||||
|
if (cmd_queue_end_state == TAP_TLR)
|
||||||
|
jtag_call_event_callbacks(JTAG_TRST_ASSERTED);
|
||||||
|
|
||||||
|
cmd_queue_cur_state = cmd_queue_end_state;
|
||||||
|
|
||||||
|
int retval=interface_jtag_add_ir_scan(num_fields, fields, state);
|
||||||
|
if (retval!=ERROR_OK)
|
||||||
|
jtag_error=retval;
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int INTERFACE(interface_jtag_add_ir_scan)(int num_fields, scan_field_t *fields, enum tap_state state)
|
||||||
{
|
{
|
||||||
jtag_command_t **last_cmd;
|
jtag_command_t **last_cmd;
|
||||||
jtag_device_t *device;
|
jtag_device_t *device;
|
||||||
int i, j;
|
int i, j;
|
||||||
int scan_size = 0;
|
int scan_size = 0;
|
||||||
|
|
||||||
if (jtag_trst == 1)
|
|
||||||
{
|
|
||||||
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
|
||||||
return ERROR_JTAG_TRST_ASSERTED;
|
|
||||||
}
|
|
||||||
|
|
||||||
last_cmd = jtag_get_last_command_p();
|
last_cmd = jtag_get_last_command_p();
|
||||||
|
|
||||||
|
@ -407,17 +440,6 @@ int jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state state)
|
||||||
(*last_cmd)->cmd.scan->fields = cmd_queue_alloc(jtag_num_devices * sizeof(scan_field_t));
|
(*last_cmd)->cmd.scan->fields = cmd_queue_alloc(jtag_num_devices * sizeof(scan_field_t));
|
||||||
(*last_cmd)->cmd.scan->end_state = state;
|
(*last_cmd)->cmd.scan->end_state = state;
|
||||||
|
|
||||||
if (state != -1)
|
|
||||||
cmd_queue_end_state = state;
|
|
||||||
|
|
||||||
if (cmd_queue_cur_state == TAP_TLR && cmd_queue_end_state != TAP_TLR)
|
|
||||||
jtag_call_event_callbacks(JTAG_TRST_RELEASED);
|
|
||||||
|
|
||||||
if (cmd_queue_end_state == TAP_TLR)
|
|
||||||
jtag_call_event_callbacks(JTAG_TRST_ASSERTED);
|
|
||||||
|
|
||||||
cmd_queue_cur_state = cmd_queue_end_state;
|
|
||||||
|
|
||||||
for (i = 0; i < jtag_num_devices; i++)
|
for (i = 0; i < jtag_num_devices; i++)
|
||||||
{
|
{
|
||||||
int found = 0;
|
int found = 0;
|
||||||
|
@ -680,23 +702,12 @@ int jtag_add_plain_dr_scan(int num_fields, scan_field_t *fields, enum tap_state
|
||||||
}
|
}
|
||||||
int jtag_add_statemove(enum tap_state state)
|
int jtag_add_statemove(enum tap_state state)
|
||||||
{
|
{
|
||||||
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
|
||||||
|
|
||||||
if (jtag_trst == 1)
|
if (jtag_trst == 1)
|
||||||
{
|
{
|
||||||
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
||||||
return ERROR_JTAG_TRST_ASSERTED;
|
return jtag_error=ERROR_JTAG_TRST_ASSERTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* allocate memory for a new list member */
|
|
||||||
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
|
||||||
last_comand_pointer = &((*last_cmd)->next);
|
|
||||||
(*last_cmd)->next = NULL;
|
|
||||||
(*last_cmd)->type = JTAG_STATEMOVE;
|
|
||||||
|
|
||||||
(*last_cmd)->cmd.statemove = cmd_queue_alloc(sizeof(statemove_command_t));
|
|
||||||
(*last_cmd)->cmd.statemove->end_state = state;
|
|
||||||
|
|
||||||
if (state != -1)
|
if (state != -1)
|
||||||
cmd_queue_end_state = state;
|
cmd_queue_end_state = state;
|
||||||
|
|
||||||
|
@ -708,6 +719,23 @@ int jtag_add_statemove(enum tap_state state)
|
||||||
|
|
||||||
cmd_queue_cur_state = cmd_queue_end_state;
|
cmd_queue_cur_state = cmd_queue_end_state;
|
||||||
|
|
||||||
|
return interface_jtag_add_statemove(state);
|
||||||
|
}
|
||||||
|
|
||||||
|
int INTERFACE(interface_jtag_add_statemove)(enum tap_state state)
|
||||||
|
{
|
||||||
|
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
||||||
|
|
||||||
|
/* allocate memory for a new list member */
|
||||||
|
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
||||||
|
last_comand_pointer = &((*last_cmd)->next);
|
||||||
|
(*last_cmd)->next = NULL;
|
||||||
|
(*last_cmd)->type = JTAG_STATEMOVE;
|
||||||
|
|
||||||
|
(*last_cmd)->cmd.statemove = cmd_queue_alloc(sizeof(statemove_command_t));
|
||||||
|
(*last_cmd)->cmd.statemove->end_state = state;
|
||||||
|
|
||||||
|
|
||||||
return ERROR_OK;
|
return ERROR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -753,16 +781,10 @@ int jtag_add_pathmove(int num_states, enum tap_state *path)
|
||||||
return ERROR_OK;
|
return ERROR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
int jtag_add_runtest(int num_cycles, enum tap_state state)
|
int INTERFACE(interface_jtag_add_runtest)(int num_cycles, enum tap_state state)
|
||||||
{
|
{
|
||||||
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
||||||
|
|
||||||
if (jtag_trst == 1)
|
|
||||||
{
|
|
||||||
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
|
||||||
return ERROR_JTAG_TRST_ASSERTED;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* allocate memory for a new list member */
|
/* allocate memory for a new list member */
|
||||||
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
||||||
(*last_cmd)->next = NULL;
|
(*last_cmd)->next = NULL;
|
||||||
|
@ -773,6 +795,18 @@ int jtag_add_runtest(int num_cycles, enum tap_state state)
|
||||||
(*last_cmd)->cmd.runtest->num_cycles = num_cycles;
|
(*last_cmd)->cmd.runtest->num_cycles = num_cycles;
|
||||||
(*last_cmd)->cmd.runtest->end_state = state;
|
(*last_cmd)->cmd.runtest->end_state = state;
|
||||||
|
|
||||||
|
return ERROR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
int jtag_add_runtest(int num_cycles, enum tap_state state)
|
||||||
|
{
|
||||||
|
if (jtag_trst == 1)
|
||||||
|
{
|
||||||
|
jtag_error=ERROR_JTAG_QUEUE_FAILED;
|
||||||
|
WARNING("JTAG command queued, while TRST is low (TAP in reset)");
|
||||||
|
return ERROR_JTAG_TRST_ASSERTED;
|
||||||
|
}
|
||||||
|
|
||||||
if (state != -1)
|
if (state != -1)
|
||||||
cmd_queue_end_state = state;
|
cmd_queue_end_state = state;
|
||||||
|
|
||||||
|
@ -784,14 +818,14 @@ int jtag_add_runtest(int num_cycles, enum tap_state state)
|
||||||
|
|
||||||
cmd_queue_cur_state = cmd_queue_end_state;
|
cmd_queue_cur_state = cmd_queue_end_state;
|
||||||
|
|
||||||
return ERROR_OK;
|
/* executed by sw or hw fifo */
|
||||||
|
return interface_jtag_add_runtest(num_cycles, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
int jtag_add_reset(int req_trst, int req_srst)
|
int jtag_add_reset(int req_trst, int req_srst)
|
||||||
{
|
{
|
||||||
int trst_with_tms = 0;
|
int trst_with_tms = 0;
|
||||||
|
int retval;
|
||||||
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
|
||||||
|
|
||||||
if (req_trst == -1)
|
if (req_trst == -1)
|
||||||
req_trst = jtag_trst;
|
req_trst = jtag_trst;
|
||||||
|
@ -802,7 +836,9 @@ int jtag_add_reset(int req_trst, int req_srst)
|
||||||
/* Make sure that jtag_reset_config allows the requested reset */
|
/* Make sure that jtag_reset_config allows the requested reset */
|
||||||
/* if SRST pulls TRST, we can't fulfill srst == 1 with trst == 0 */
|
/* if SRST pulls TRST, we can't fulfill srst == 1 with trst == 0 */
|
||||||
if (((jtag_reset_config & RESET_SRST_PULLS_TRST) && (req_srst == 1)) && (req_trst == 0))
|
if (((jtag_reset_config & RESET_SRST_PULLS_TRST) && (req_srst == 1)) && (req_trst == 0))
|
||||||
return ERROR_JTAG_RESET_WOULD_ASSERT_TRST;
|
{
|
||||||
|
return jtag_error=ERROR_JTAG_RESET_WOULD_ASSERT_TRST;
|
||||||
|
}
|
||||||
|
|
||||||
/* if TRST pulls SRST, we reset with TAP T-L-R */
|
/* if TRST pulls SRST, we reset with TAP T-L-R */
|
||||||
if (((jtag_reset_config & RESET_TRST_PULLS_SRST) && (req_trst == 1)) && (req_srst == 0))
|
if (((jtag_reset_config & RESET_TRST_PULLS_SRST) && (req_trst == 1)) && (req_srst == 0))
|
||||||
|
@ -814,7 +850,7 @@ int jtag_add_reset(int req_trst, int req_srst)
|
||||||
if (req_srst && !(jtag_reset_config & RESET_HAS_SRST))
|
if (req_srst && !(jtag_reset_config & RESET_HAS_SRST))
|
||||||
{
|
{
|
||||||
ERROR("requested nSRST assertion, but the current configuration doesn't support this");
|
ERROR("requested nSRST assertion, but the current configuration doesn't support this");
|
||||||
return ERROR_JTAG_RESET_CANT_SRST;
|
return jtag_error=ERROR_JTAG_RESET_CANT_SRST;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (req_trst && !(jtag_reset_config & RESET_HAS_TRST))
|
if (req_trst && !(jtag_reset_config & RESET_HAS_TRST))
|
||||||
|
@ -823,16 +859,6 @@ int jtag_add_reset(int req_trst, int req_srst)
|
||||||
trst_with_tms = 1;
|
trst_with_tms = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* allocate memory for a new list member */
|
|
||||||
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
|
||||||
(*last_cmd)->next = NULL;
|
|
||||||
last_comand_pointer = &((*last_cmd)->next);
|
|
||||||
(*last_cmd)->type = JTAG_RESET;
|
|
||||||
|
|
||||||
(*last_cmd)->cmd.reset = cmd_queue_alloc(sizeof(reset_command_t));
|
|
||||||
(*last_cmd)->cmd.reset->trst = req_trst;
|
|
||||||
(*last_cmd)->cmd.reset->srst = req_srst;
|
|
||||||
|
|
||||||
jtag_trst = req_trst;
|
jtag_trst = req_trst;
|
||||||
jtag_srst = req_srst;
|
jtag_srst = req_srst;
|
||||||
|
|
||||||
|
@ -849,17 +875,6 @@ int jtag_add_reset(int req_trst, int req_srst)
|
||||||
|
|
||||||
if (trst_with_tms)
|
if (trst_with_tms)
|
||||||
{
|
{
|
||||||
last_cmd = &((*last_cmd)->next);
|
|
||||||
|
|
||||||
/* allocate memory for a new list member */
|
|
||||||
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
|
||||||
(*last_cmd)->next = NULL;
|
|
||||||
last_comand_pointer = &((*last_cmd)->next);
|
|
||||||
(*last_cmd)->type = JTAG_STATEMOVE;
|
|
||||||
|
|
||||||
(*last_cmd)->cmd.statemove = cmd_queue_alloc(sizeof(statemove_command_t));
|
|
||||||
(*last_cmd)->cmd.statemove->end_state = TAP_TLR;
|
|
||||||
|
|
||||||
jtag_call_event_callbacks(JTAG_TRST_ASSERTED);
|
jtag_call_event_callbacks(JTAG_TRST_ASSERTED);
|
||||||
cmd_queue_cur_state = TAP_TLR;
|
cmd_queue_cur_state = TAP_TLR;
|
||||||
cmd_queue_end_state = TAP_TLR;
|
cmd_queue_end_state = TAP_TLR;
|
||||||
|
@ -885,6 +900,33 @@ int jtag_add_reset(int req_trst, int req_srst)
|
||||||
jtag_add_sleep(jtag_ntrst_delay * 1000);
|
jtag_add_sleep(jtag_ntrst_delay * 1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
retval = interface_jtag_add_reset(req_trst, req_srst);
|
||||||
|
if (retval!=ERROR_OK)
|
||||||
|
jtag_error=retval;
|
||||||
|
|
||||||
|
if (trst_with_tms)
|
||||||
|
{
|
||||||
|
jtag_add_statemove(TAP_TLR);
|
||||||
|
}
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int INTERFACE(interface_jtag_add_reset)(int req_trst, int req_srst)
|
||||||
|
{
|
||||||
|
jtag_command_t **last_cmd = jtag_get_last_command_p();
|
||||||
|
|
||||||
|
/* allocate memory for a new list member */
|
||||||
|
*last_cmd = cmd_queue_alloc(sizeof(jtag_command_t));
|
||||||
|
(*last_cmd)->next = NULL;
|
||||||
|
last_comand_pointer = &((*last_cmd)->next);
|
||||||
|
(*last_cmd)->type = JTAG_RESET;
|
||||||
|
|
||||||
|
(*last_cmd)->cmd.reset = cmd_queue_alloc(sizeof(reset_command_t));
|
||||||
|
(*last_cmd)->cmd.reset->trst = req_trst;
|
||||||
|
(*last_cmd)->cmd.reset->srst = req_srst;
|
||||||
|
|
||||||
|
|
||||||
return ERROR_OK;
|
return ERROR_OK;
|
||||||
}
|
}
|
||||||
|
@ -1107,7 +1149,7 @@ enum scan_type jtag_scan_type(scan_command_t *cmd)
|
||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
|
|
||||||
int jtag_execute_queue(void)
|
int INTERFACE(interface_jtag_execute_queue)(void)
|
||||||
{
|
{
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
|
@ -1118,6 +1160,18 @@ int jtag_execute_queue(void)
|
||||||
jtag_command_queue = NULL;
|
jtag_command_queue = NULL;
|
||||||
last_comand_pointer = &jtag_command_queue;
|
last_comand_pointer = &jtag_command_queue;
|
||||||
|
|
||||||
|
jtag_error=ERROR_OK;
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int jtag_execute_queue(void)
|
||||||
|
{
|
||||||
|
int retval=interface_jtag_execute_queue();
|
||||||
|
if (retval!=ERROR_OK)
|
||||||
|
return retval;
|
||||||
|
retval=jtag_error;
|
||||||
|
jtag_error=ERROR_OK;
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,12 +77,13 @@ typedef struct scan_field_s
|
||||||
u8 *out_mask; /* only masked bits care */
|
u8 *out_mask; /* only masked bits care */
|
||||||
u8 *in_value; /* pointer to a 32-bit memory location to take data scanned out */
|
u8 *in_value; /* pointer to a 32-bit memory location to take data scanned out */
|
||||||
/* in_check_value/mask, in_handler_error_handler, in_handler_priv can be used by the in handler, otherwise they contain garbage */
|
/* in_check_value/mask, in_handler_error_handler, in_handler_priv can be used by the in handler, otherwise they contain garbage */
|
||||||
u8 *in_check_value; /* used to validate scan results */
|
u8 *in_check_value; /* used to validate scan results */
|
||||||
u8 *in_check_mask; /* check specified bits against check_value */
|
u8 *in_check_mask; /* check specified bits against check_value */
|
||||||
in_handler_t in_handler; /* process received buffer using this handler */
|
in_handler_t in_handler; /* process received buffer using this handler */
|
||||||
void *in_handler_priv; /* additional information for the in_handler */
|
void *in_handler_priv; /* additional information for the in_handler */
|
||||||
} scan_field_t;
|
} scan_field_t;
|
||||||
|
|
||||||
|
|
||||||
enum scan_type
|
enum scan_type
|
||||||
{
|
{
|
||||||
/* IN: from device to host, OUT: from host to device */
|
/* IN: from device to host, OUT: from host to device */
|
||||||
|
@ -244,9 +245,13 @@ extern int jtag_register_commands(struct command_context_s *cmd_ctx);
|
||||||
|
|
||||||
/* JTAG interface, can be implemented with a software or hardware fifo */
|
/* JTAG interface, can be implemented with a software or hardware fifo */
|
||||||
extern int jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
extern int jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
extern int jtag_add_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
extern int jtag_add_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
extern int jtag_add_plain_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
extern int jtag_add_plain_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_plain_ir_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
extern int jtag_add_plain_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
extern int jtag_add_plain_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_plain_dr_scan(int num_fields, scan_field_t *fields, enum tap_state endstate);
|
||||||
/* execute a state transition within the JTAG standard, but the exact path
|
/* execute a state transition within the JTAG standard, but the exact path
|
||||||
* path that is taken is undefined. Many implementations use precisely
|
* path that is taken is undefined. Many implementations use precisely
|
||||||
* 7 clocks to perform a transition, but it could be more or less
|
* 7 clocks to perform a transition, but it could be more or less
|
||||||
|
@ -266,16 +271,22 @@ extern int jtag_add_plain_dr_scan(int num_fields, scan_field_t *fields, enum tap
|
||||||
* side effects.
|
* side effects.
|
||||||
*/
|
*/
|
||||||
extern int jtag_add_statemove(enum tap_state endstate);
|
extern int jtag_add_statemove(enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_statemove(enum tap_state endstate);
|
||||||
/* A list of unambigious single clock state transitions, not
|
/* A list of unambigious single clock state transitions, not
|
||||||
* all drivers can support this, but it is required for e.g.
|
* all drivers can support this, but it is required for e.g.
|
||||||
* XScale and Xilinx support
|
* XScale and Xilinx support
|
||||||
*/
|
*/
|
||||||
extern int jtag_add_pathmove(int num_states, enum tap_state *path);
|
extern int jtag_add_pathmove(int num_states, enum tap_state *path);
|
||||||
|
extern int interface_jtag_add_pathmove(int num_states, enum tap_state *path);
|
||||||
/* cycle precisely num_cycles in the TAP_RTI state */
|
/* cycle precisely num_cycles in the TAP_RTI state */
|
||||||
extern int jtag_add_runtest(int num_cycles, enum tap_state endstate);
|
extern int jtag_add_runtest(int num_cycles, enum tap_state endstate);
|
||||||
|
extern int interface_jtag_add_runtest(int num_cycles, enum tap_state endstate);
|
||||||
extern int jtag_add_reset(int trst, int srst);
|
extern int jtag_add_reset(int trst, int srst);
|
||||||
|
extern int interface_jtag_add_reset(int trst, int srst);
|
||||||
extern int jtag_add_end_state(enum tap_state endstate);
|
extern int jtag_add_end_state(enum tap_state endstate);
|
||||||
|
extern int inteface_jtag_add_end_state(enum tap_state endstate);
|
||||||
extern int jtag_add_sleep(u32 us);
|
extern int jtag_add_sleep(u32 us);
|
||||||
|
extern int interface_jtag_add_sleep(u32 us);
|
||||||
/*
|
/*
|
||||||
* 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
|
||||||
|
@ -297,6 +308,8 @@ extern int jtag_add_sleep(u32 us);
|
||||||
* at some time between the jtag_add_xxx() fn call and jtag_execute_queue().
|
* at some time between the jtag_add_xxx() fn call and jtag_execute_queue().
|
||||||
*/
|
*/
|
||||||
extern int jtag_execute_queue(void);
|
extern int jtag_execute_queue(void);
|
||||||
|
/* can be implemented by hw+sw */
|
||||||
|
extern int interface_jtag_execute_queue(void);
|
||||||
|
|
||||||
/* JTAG support functions */
|
/* JTAG support functions */
|
||||||
extern void jtag_set_check_value(scan_field_t *field, u8 *value, u8 *mask, error_handler_t *in_error_handler);
|
extern void jtag_set_check_value(scan_field_t *field, u8 *value, u8 *mask, error_handler_t *in_error_handler);
|
||||||
|
@ -323,4 +336,6 @@ extern int jtag_verify_capture_ir;
|
||||||
#define ERROR_JTAG_RESET_WOULD_ASSERT_TRST (-105)
|
#define ERROR_JTAG_RESET_WOULD_ASSERT_TRST (-105)
|
||||||
#define ERROR_JTAG_RESET_CANT_SRST (-106)
|
#define ERROR_JTAG_RESET_CANT_SRST (-106)
|
||||||
#define ERROR_JTAG_DEVICE_ERROR (-107)
|
#define ERROR_JTAG_DEVICE_ERROR (-107)
|
||||||
|
|
||||||
|
|
||||||
#endif /* JTAG_H */
|
#endif /* JTAG_H */
|
||||||
|
|
Loading…
Reference in New Issue