Does the LPC2148 (which I have) exhibit the same problem?
I can not test the attached patch here, but it is intended
to allow switching between the long(old) or new (short)
tms_sequence tables. The patch uses the short table
as default.
Try:
tms_sequence long
tms_sequence short
--
Øyvind Harboe
Embedded software and hardware consulting services
http://consulting.zylin.com
Index: C:/workspace/openocd/src/jtag/jtag.c
===================================================================
--- C:/workspace/openocd/src/jtag/jtag.c (revision 1830)
+++ C:/workspace/openocd/src/jtag/jtag.c (working copy)
@@ -261,6 +261,7 @@
static int handle_verify_ircapture_command(struct command_context_s *cmd_ctx,
char *cmd, char **args, int argc);
static int handle_verify_jtag_command(struct command_context_s *cmd_ctx, char
*cmd, char **args, int argc);
+static int handle_tms_sequence_command(struct command_context_s *cmd_ctx, char
*cmd, char **args, int argc);
jtag_tap_t *jtag_AllTaps(void)
{
@@ -2310,6 +2311,8 @@
COMMAND_ANY, "verify value captured during Capture-IR
<enable|disable>");
register_command(cmd_ctx, NULL, "verify_jtag",
handle_verify_jtag_command,
COMMAND_ANY, "verify value capture <enable|disable>");
+ register_command(cmd_ctx, NULL, "tms_sequence",
handle_tms_sequence_command,
+ COMMAND_ANY, "choose short(default) or long tms_sequence
<short|long>");
return ERROR_OK;
}
@@ -3129,6 +3132,7 @@
return ERROR_OK;
}
+
int jtag_power_dropout(int *dropout)
{
return jtag->power_dropout(dropout);
@@ -3248,7 +3252,7 @@
*
* DRSHIFT->DRSHIFT and IRSHIFT->IRSHIFT have to be caught in interface
specific code
*/
-static struct
+struct tms_sequences
{
u8 bits;
u8 bit_count;
@@ -3253,14 +3257,7 @@
u8 bits;
u8 bit_count;
-} tms_seqs[6][6] = /* [from_state_ndx][to_state_ndx] */
-{
- /* 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. These values are tightly bound to the table in
tap_get_tms_path_len().
- * 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 macros allow us to specify TMS state transitions by bits rather than
hex bytes.
@@ -3280,7 +3277,31 @@
#define B8(bits,count) { ((u8)B8__(HEX__(bits))), (count) }
-#if 1 && ((BUILD_FT2232_FTD2XX==1) || (BUILD_FT2232_LIBFTDI==1) ||
(BUILD_JLINK==1))
+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.
+ * N.B. OOCD clocks TMS from LSB first, so read these right-to-left.
+ * N.B. These values are tightly bound to the table in
tap_get_tms_path_len().
+ * 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.
+ */
+
+
+
+ /* 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(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(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(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] */
+{
/* 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
@@ -3314,34 +3335,15 @@
{ 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 */
-#else /* this is the old table, converted from hex and with the bit_count set
to 7 for each combo, like before */
-
- /* 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(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(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(0110000,7), B8(0011100,7), B8(0010111,7),
B8(0011110,7), B8(0101111,7) }, /* IRPAUSE */
-
-#endif
+};
-#if 0 /* keeping old hex stuff for awhile, for reference */
- /* RESET IDLE DRSHIFT
DRPAUSE IRSHIFT IRPAUSE */
- { 0x7f, 0x00, 0x17,
0x0a, 0x1b, 0x16 }, /* RESET */
- { 0x7f, 0x00, 0x25,
0x05, 0x2b, 0x0b }, /* IDLE */
- { 0x7f, 0x31, 0x00,
0x01, 0x0f, 0x2f }, /* DRSHIFT */
- { 0x7f, 0x30, 0x20,
0x17, 0x1e, 0x2f }, /* DRPAUSE */
- { 0x7f, 0x31, 0x07,
0x17, 0x00, 0x01 }, /* IRSHIFT */
- { 0x7f, 0x30, 0x1c,
0x17, 0x20, 0x2f } /* IRPAUSE */
-#endif
-};
+typedef const struct tms_sequences tms_table[6][6];
+static tms_table *tms_seqs=&short_tms_seqs;
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;
}
@@ -3347,7 +3349,7 @@
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;
}
@@ -3607,5 +3609,29 @@
}
#endif
+static int handle_tms_sequence_command(struct command_context_s *cmd_ctx, char
*cmd, char **args, int argc)
+{
+ if (argc == 1)
+ {
+ if (strcmp(args[0], "short") == 0)
+ {
+ tms_seqs=&short_tms_seqs;
+ }
+ else if (strcmp(args[0], "long") == 0)
+ {
+ tms_seqs=&old_tms_seqs;
+ } else
+ {
+ return ERROR_COMMAND_SYNTAX_ERROR;
+ }
+ } else if (argc != 0)
+ {
+ return ERROR_COMMAND_SYNTAX_ERROR;
+ }
+
+ command_print(cmd_ctx, "tms sequence is %s",
(tms_seqs==&short_tms_seqs) ? "short": "long");
+
+ return ERROR_OK;
+}
/*-----</Cable Helper API>--------------------------------------*/
_______________________________________________
Openocd-development mailing list
[email protected]
https://lists.berlios.de/mailman/listinfo/openocd-development