jtag/drivers/bitbang: use LOG_CUSTOM_LEVEL() macro for SWD
Log SWD commands with not OK response but WAIT retries at debug level. For commands responded OK and WAIT retries use debug io level not to flood the log. Signed-off-by: Tomas Vanek <vanekt@fbl.cz> Change-Id: Idf658e82ed970061c155945df55d06908ed25e09 Reviewed-on: https://review.openocd.org/c/openocd/+/8152 Tested-by: jenkins Reviewed-by: Antonio Borneo <borneo.antonio@gmail.com>
This commit is contained in:
parent
b63e065f23
commit
f7f4fa84f1
|
@ -474,7 +474,7 @@ static void bitbang_swd_read_reg(uint8_t cmd, uint32_t *value, uint32_t ap_delay
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (;;) {
|
for (unsigned int retry = 0;; retry++) {
|
||||||
uint8_t trn_ack_data_parity_trn[DIV_ROUND_UP(4 + 3 + 32 + 1 + 4, 8)];
|
uint8_t trn_ack_data_parity_trn[DIV_ROUND_UP(4 + 3 + 32 + 1 + 4, 8)];
|
||||||
|
|
||||||
cmd |= SWD_CMD_START | SWD_CMD_PARK;
|
cmd |= SWD_CMD_START | SWD_CMD_PARK;
|
||||||
|
@ -488,16 +488,22 @@ static void bitbang_swd_read_reg(uint8_t cmd, uint32_t *value, uint32_t ap_delay
|
||||||
uint32_t data = buf_get_u32(trn_ack_data_parity_trn, 1 + 3, 32);
|
uint32_t data = buf_get_u32(trn_ack_data_parity_trn, 1 + 3, 32);
|
||||||
int parity = buf_get_u32(trn_ack_data_parity_trn, 1 + 3 + 32, 1);
|
int parity = buf_get_u32(trn_ack_data_parity_trn, 1 + 3 + 32, 1);
|
||||||
|
|
||||||
LOG_DEBUG_IO("%s %s read reg %X = %08" PRIx32,
|
LOG_CUSTOM_LEVEL((ack != SWD_ACK_OK && (retry == 0 || ack != SWD_ACK_WAIT))
|
||||||
ack == SWD_ACK_OK ? "OK" : ack == SWD_ACK_WAIT ? "WAIT" : ack == SWD_ACK_FAULT ? "FAULT" : "JUNK",
|
? LOG_LVL_DEBUG : LOG_LVL_DEBUG_IO,
|
||||||
cmd & SWD_CMD_APNDP ? "AP" : "DP",
|
"%s %s read reg %X = %08" PRIx32,
|
||||||
(cmd & SWD_CMD_A32) >> 1,
|
ack == SWD_ACK_OK ? "OK" : ack == SWD_ACK_WAIT ? "WAIT" : ack == SWD_ACK_FAULT ? "FAULT" : "JUNK",
|
||||||
data);
|
cmd & SWD_CMD_APNDP ? "AP" : "DP",
|
||||||
|
(cmd & SWD_CMD_A32) >> 1,
|
||||||
|
data);
|
||||||
|
|
||||||
if (ack == SWD_ACK_WAIT) {
|
if (ack == SWD_ACK_WAIT) {
|
||||||
swd_clear_sticky_errors();
|
swd_clear_sticky_errors();
|
||||||
continue;
|
continue;
|
||||||
} else if (ack != SWD_ACK_OK) {
|
}
|
||||||
|
if (retry > 1)
|
||||||
|
LOG_DEBUG("SWD WAIT: retried %u times", retry);
|
||||||
|
|
||||||
|
if (ack != SWD_ACK_OK) {
|
||||||
queued_retval = swd_ack_to_error_code(ack);
|
queued_retval = swd_ack_to_error_code(ack);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -529,7 +535,7 @@ static void bitbang_swd_write_reg(uint8_t cmd, uint32_t value, uint32_t ap_delay
|
||||||
|
|
||||||
/* init the array to silence scan-build */
|
/* init the array to silence scan-build */
|
||||||
uint8_t trn_ack_data_parity_trn[DIV_ROUND_UP(4 + 3 + 32 + 1 + 4, 8)] = {0};
|
uint8_t trn_ack_data_parity_trn[DIV_ROUND_UP(4 + 3 + 32 + 1 + 4, 8)] = {0};
|
||||||
for (;;) {
|
for (unsigned int retry = 0;; retry++) {
|
||||||
buf_set_u32(trn_ack_data_parity_trn, 1 + 3 + 1, 32, value);
|
buf_set_u32(trn_ack_data_parity_trn, 1 + 3 + 1, 32, value);
|
||||||
buf_set_u32(trn_ack_data_parity_trn, 1 + 3 + 1 + 32, 1, parity_u32(value));
|
buf_set_u32(trn_ack_data_parity_trn, 1 + 3 + 1 + 32, 1, parity_u32(value));
|
||||||
|
|
||||||
|
@ -554,22 +560,26 @@ static void bitbang_swd_write_reg(uint8_t cmd, uint32_t value, uint32_t ap_delay
|
||||||
bitbang_swd_exchange(false, trn_ack_data_parity_trn, 1 + 3 + 1, 32 + 1);
|
bitbang_swd_exchange(false, trn_ack_data_parity_trn, 1 + 3 + 1, 32 + 1);
|
||||||
|
|
||||||
int ack = buf_get_u32(trn_ack_data_parity_trn, 1, 3);
|
int ack = buf_get_u32(trn_ack_data_parity_trn, 1, 3);
|
||||||
|
LOG_CUSTOM_LEVEL((check_ack && ack != SWD_ACK_OK && (retry == 0 || ack != SWD_ACK_WAIT))
|
||||||
|
? LOG_LVL_DEBUG : LOG_LVL_DEBUG_IO,
|
||||||
|
"%s%s %s write reg %X = %08" PRIx32,
|
||||||
|
check_ack ? "" : "ack ignored ",
|
||||||
|
ack == SWD_ACK_OK ? "OK" : ack == SWD_ACK_WAIT ? "WAIT" : ack == SWD_ACK_FAULT ? "FAULT" : "JUNK",
|
||||||
|
cmd & SWD_CMD_APNDP ? "AP" : "DP",
|
||||||
|
(cmd & SWD_CMD_A32) >> 1,
|
||||||
|
buf_get_u32(trn_ack_data_parity_trn, 1 + 3 + 1, 32));
|
||||||
|
|
||||||
LOG_DEBUG_IO("%s%s %s write reg %X = %08" PRIx32,
|
if (check_ack && ack == SWD_ACK_WAIT) {
|
||||||
check_ack ? "" : "ack ignored ",
|
swd_clear_sticky_errors();
|
||||||
ack == SWD_ACK_OK ? "OK" : ack == SWD_ACK_WAIT ? "WAIT" : ack == SWD_ACK_FAULT ? "FAULT" : "JUNK",
|
continue;
|
||||||
cmd & SWD_CMD_APNDP ? "AP" : "DP",
|
}
|
||||||
(cmd & SWD_CMD_A32) >> 1,
|
|
||||||
buf_get_u32(trn_ack_data_parity_trn, 1 + 3 + 1, 32));
|
|
||||||
|
|
||||||
if (check_ack) {
|
if (retry > 1)
|
||||||
if (ack == SWD_ACK_WAIT) {
|
LOG_DEBUG("SWD WAIT: retried %u times", retry);
|
||||||
swd_clear_sticky_errors();
|
|
||||||
continue;
|
if (check_ack && ack != SWD_ACK_OK) {
|
||||||
} else if (ack != SWD_ACK_OK) {
|
queued_retval = swd_ack_to_error_code(ack);
|
||||||
queued_retval = swd_ack_to_error_code(ack);
|
return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cmd & SWD_CMD_APNDP)
|
if (cmd & SWD_CMD_APNDP)
|
||||||
|
|
Loading…
Reference in New Issue