diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/jtag/jtag.c | 107 |
1 files changed, 14 insertions, 93 deletions
diff --git a/src/jtag/jtag.c b/src/jtag/jtag.c index 48cd0595..a28250ff 100644 --- a/src/jtag/jtag.c +++ b/src/jtag/jtag.c @@ -28,7 +28,6 @@ #include "command.h" #include "log.h" #include "interpreter.h" -#include "target.h" #include "stdlib.h" #include "string.h" @@ -1328,10 +1327,11 @@ void jtag_sleep(u32 us) /* Try to examine chain layout according to IEEE 1149.1 §12 */ -int jtag_examine_chain(u8 idcode_buffer[JTAG_MAX_CHAIN_SIZE * 4] ) +int jtag_examine_chain() { jtag_device_t *device = jtag_devices; scan_field_t field; + u8 idcode_buffer[JTAG_MAX_CHAIN_SIZE * 4]; int i; int bit_count; int device_count = 0; @@ -1533,36 +1533,9 @@ int jtag_interface_init(struct command_context_s *cmd_ctx) return ERROR_OK; } -extern int jtag_init_chain(struct command_context_s *cmd_ctx); - -static int jtag_sense_handler(void *priv) -{ - struct command_context_s *cmd_ctx; - cmd_ctx=(struct command_context_s *)priv; - - static int scan_complete = 0; - if (!scan_complete) - { - if (jtag_init_chain(cmd_ctx)==ERROR_OK) - { - scan_complete = 1; - } - return ERROR_OK; - } - - return ERROR_OK; -} - -/* OpenOCD will start telnet/gdb servers before the JTAG chain has - * been enumerated. This is to allow e.g. GDB init script to - * run monitor commands to initialize the target so jtag_init_chain() - * will succeed. - * - * A timer callback is added where sensing is retried once every second - * until it succeeds. - */ int jtag_init(struct command_context_s *cmd_ctx) { + int validate_tries = 0; jtag_device_t *device; DEBUG("-"); @@ -1583,76 +1556,24 @@ int jtag_init(struct command_context_s *cmd_ctx) jtag_add_statemove(TAP_TLR); jtag_execute_queue(); - target_register_timer_callback(jtag_sense_handler, 1000, 1, cmd_ctx); - - return ERROR_OK; - } - -static int jtag_test_chain(u8 idcode_buffer[JTAG_MAX_CHAIN_SIZE * 4]) -{ - jtag_add_statemove(TAP_TLR); - jtag_execute_queue(); - /* examine chain first, as this could discover the real chain layout */ - if (jtag_examine_chain(idcode_buffer)!=ERROR_OK) + if (jtag_examine_chain() != ERROR_OK) { - WARNING("trying to validate configured JTAG chain anyway..."); + ERROR("trying to validate configured JTAG chain anyway..."); } - - return jtag_validate_chain(); -} -/* Unless we can do this successfully 10 times, we're not - * satisfied with the quality of the JTAG communication. - * - * Since we're continously repeating this operation, be a bit - * wary of filling the log with megabytes of data. - * - * Keep increasing the jtag_divisor until we've got a solid - * result. - */ -int jtag_init_chain(struct command_context_s *cmd_ctx) -{ - int i, j; - int retval; - for (i=jtag_speed; i<64; i++) - { - u8 idcode_buffer[JTAG_MAX_CHAIN_SIZE * 4]; - jtag_speed=i; - if ((retval=jtag->speed(jtag_speed))!=ERROR_OK) - continue; - for (j=0; j<10; j++) - { - u8 idcode_current[JTAG_MAX_CHAIN_SIZE * 4]; - enum log_levels save_log_level=debug_level; - /* avoid spamming log */ - debug_level=LOG_SILENT; - retval=jtag_test_chain(idcode_current); - if (retval==ERROR_OK) - { - if (j==0) - { - memcpy(idcode_buffer, idcode_current, sizeof(idcode_buffer)); - } else - { - retval=(memcmp(idcode_buffer, idcode_current, sizeof(idcode_buffer))==0)?ERROR_OK:ERROR_JTAG_INIT_FAILED; - } - } - debug_level = save_log_level; - if (retval!=ERROR_OK) - { - break; - } - } - if (retval==ERROR_OK) + while (jtag_validate_chain() != ERROR_OK) + { + validate_tries++; + if (validate_tries > 5) { - /* Print out result */ - INFO("Succeeded jtag chain test jtag_speed=%d", jtag_speed); - return jtag_test_chain(idcode_buffer); + ERROR("Could not validate JTAG chain, exit"); + return ERROR_JTAG_INVALID_INTERFACE; } - DEBUG("Failed jtag chain test, dropping clock rate. Trying jtag_speed=%d\n", i+1); + usleep(10000); } - return retval; + + return ERROR_OK; } int handle_interface_command(struct command_context_s *cmd_ctx, char *cmd, char **args, int argc) |