adiv5_jtagdp: code format

This commit is contained in:
Rafael Silva 2022-08-05 23:02:27 +01:00 committed by Rachel Mant
parent 0fbb6921b9
commit c04b98435a
1 changed files with 21 additions and 24 deletions

View File

@ -29,19 +29,19 @@
#include "jtagtap.h" #include "jtagtap.h"
#include "morse.h" #include "morse.h"
#define JTAGDP_ACK_OK 0x02 #define JTAGDP_ACK_OK 0x02U
#define JTAGDP_ACK_WAIT 0x01 #define JTAGDP_ACK_WAIT 0x01U
/* 35-bit registers that control the ADIv5 DP */ /* 35-bit registers that control the ADIv5 DP */
#define IR_ABORT 0x8 #define IR_ABORT 0x8U
#define IR_DPACC 0xA #define IR_DPACC 0xAU
#define IR_APACC 0xB #define IR_APACC 0xBU
static uint32_t adiv5_jtagdp_error(ADIv5_DP_t *dp); static uint32_t adiv5_jtagdp_error(ADIv5_DP_t *dp);
void adiv5_jtag_dp_handler(uint8_t jd_index) void adiv5_jtag_dp_handler(uint8_t jd_index)
{ {
ADIv5_DP_t *dp = (void*)calloc(1, sizeof(*dp)); ADIv5_DP_t *dp = calloc(1, sizeof(*dp));
if (!dp) { /* calloc failed: heap exhaustion */ if (!dp) { /* calloc failed: heap exhaustion */
DEBUG_WARN("calloc: failed in %s\n", __func__); DEBUG_WARN("calloc: failed in %s\n", __func__);
return; return;
@ -62,36 +62,33 @@ void adiv5_jtag_dp_handler(uint8_t jd_index)
uint32_t fw_adiv5_jtagdp_read(ADIv5_DP_t *dp, uint16_t addr) uint32_t fw_adiv5_jtagdp_read(ADIv5_DP_t *dp, uint16_t addr)
{ {
fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, addr, 0); fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, addr, 0);
return fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, return fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, ADIV5_DP_RDBUFF, 0);
ADIV5_DP_RDBUFF, 0);
} }
static uint32_t adiv5_jtagdp_error(ADIv5_DP_t *dp) static uint32_t adiv5_jtagdp_error(ADIv5_DP_t *dp)
{ {
fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, ADIV5_DP_CTRLSTAT, 0); fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_READ, ADIV5_DP_CTRLSTAT, 0);
return fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_WRITE, return fw_adiv5_jtagdp_low_access(dp, ADIV5_LOW_WRITE, ADIV5_DP_CTRLSTAT, 0xf0000032U) & 0x32U;
ADIV5_DP_CTRLSTAT, 0xF0000032) & 0x32;
} }
uint32_t fw_adiv5_jtagdp_low_access(ADIv5_DP_t *dp, uint8_t RnW, uint32_t fw_adiv5_jtagdp_low_access(ADIv5_DP_t *dp, uint8_t RnW, uint16_t addr, uint32_t value)
uint16_t addr, uint32_t value)
{ {
bool APnDP = addr & ADIV5_APnDP; const bool APnDP = addr & ADIV5_APnDP;
addr &= 0xff; addr &= 0xff;
uint64_t request, response;
uint8_t ack;
platform_timeout timeout;
request = ((uint64_t)value << 3) | ((addr >> 1) & 0x06) | (RnW?1:0); const uint64_t request = ((uint64_t)value << 3U) | ((addr >> 1U) & 0x06U) | (RnW ? 1U : 0U);
uint64_t response;
uint8_t ack;
jtag_dev_write_ir(&jtag_proc, dp->dp_jd_index, APnDP ? IR_APACC : IR_DPACC); jtag_dev_write_ir(&jtag_proc, dp->dp_jd_index, APnDP ? IR_APACC : IR_DPACC);
platform_timeout timeout;
platform_timeout_set(&timeout, 250); platform_timeout_set(&timeout, 250);
do { do {
jtag_dev_shift_dr(&jtag_proc, dp->dp_jd_index, (uint8_t*)&response, jtag_dev_shift_dr(&jtag_proc, dp->dp_jd_index, (uint8_t *)&response, (uint8_t *)&request, 35);
(uint8_t*)&request, 35);
ack = response & 0x07; ack = response & 0x07;
} while(!platform_timeout_is_expired(&timeout) && (ack == JTAGDP_ACK_WAIT)); } while (!platform_timeout_is_expired(&timeout) && ack == JTAGDP_ACK_WAIT);
if (ack == JTAGDP_ACK_WAIT) { if (ack == JTAGDP_ACK_WAIT) {
dp->abort(dp, ADIV5_DP_ABORT_DAPABORT); dp->abort(dp, ADIV5_DP_ABORT_DAPABORT);