aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjihongbin <longma@orbbec.com>2022-04-29 17:03:15 +0800
committerTomas Vanek <vanekt@fbl.cz>2022-05-01 04:48:19 +0000
commit66335683fec62ac89da48d64932fd9d082314225 (patch)
tree60ceb9c77ac3eb0a605dc68a22a7af6e020cd8da
parent12d1ad0c75298d56827debcacc83c679bfbe9ac2 (diff)
downloadriscv-openocd-66335683fec62ac89da48d64932fd9d082314225.zip
riscv-openocd-66335683fec62ac89da48d64932fd9d082314225.tar.gz
riscv-openocd-66335683fec62ac89da48d64932fd9d082314225.tar.bz2
drivers/cmsis-dap: Correct the DAP protocol parameter parsing error
Fixes: 01030fb89354 (drivers/cmsis-dap: tidy up buffer access) Change-Id: Id192d3930a89980d641058b6444d12caec19ce6f Signed-off-by: Hongbin Ji <longma@orbbec.com> Reviewed-on: https://review.openocd.org/c/openocd/+/6954 Tested-by: jenkins Reviewed-by: Tomas Vanek <vanekt@fbl.cz> Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com> Reviewed-by: jihongbin <jhb_ee@163.com>
-rw-r--r--src/jtag/drivers/cmsis_dap.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/src/jtag/drivers/cmsis_dap.c b/src/jtag/drivers/cmsis_dap.c
index 63407be..eaa65ab 100644
--- a/src/jtag/drivers/cmsis_dap.c
+++ b/src/jtag/drivers/cmsis_dap.c
@@ -1405,18 +1405,18 @@ static void debug_parse_cmsis_buf(const uint8_t *cmd, int cmdlen)
for (int i = 0; i < cmdlen; ++i)
printf(" %02x", cmd[i]);
printf("\n");
- switch (cmd[1]) {
+ switch (cmd[0]) {
case CMD_DAP_JTAG_SEQ: {
- printf("cmsis-dap jtag sequence command %02x (n=%d)\n", cmd[1], cmd[2]);
+ printf("cmsis-dap jtag sequence command %02x (n=%d)\n", cmd[0], cmd[1]);
/*
- * #2 = number of sequences
- * #3 = sequence info 1
- * #4...4+n_bytes-1 = sequence 1
+ * #1 = number of sequences
+ * #2 = sequence info 1
+ * #3...4+n_bytes-1 = sequence 1
* #4+n_bytes = sequence info 2
* #5+n_bytes = sequence 2 (single bit)
*/
- int pos = 3;
- for (int seq = 0; seq < cmd[2]; ++seq) {
+ int pos = 2;
+ for (int seq = 0; seq < cmd[1]; ++seq) {
uint8_t info = cmd[pos++];
int len = info & DAP_JTAG_SEQ_TCK;
if (len == 0)