helper/command: change prototype of command_print/command_print_sameline
To prepare for handling TCL return values consistently, all calls to command_print/command_print_sameline should switch to CMD as first parameter. Change prototype of command_print() and command_print_sameline() to pass CMD instead of CMD_CTX. Since the first parameter is currently not used, the change can be done though scripts without manual coding. This patch is created using the command: sed -i PATTERN $(find src/ doc/ -type f) with all the following patters: 's/\(command_print(cmd\)->ctx,/\1,/' 's/\(command_print(CMD\)_CTX,/\1,/' 's/\(command_print(struct command_\)context \*context,/\1invocation *cmd,/' 's/\(command_print_sameline(cmd\)->ctx,/\1,/' 's/\(command_print_sameline(CMD\)_CTX,/\1,/' 's/\(command_print_sameline(struct command_\)context \*context,/\1invocation *cmd,/' This change is inspired by http://openocd.zylin.com/1815 from Paul Fertser but is now done through scripting. Change-Id: I3386d8f96cdc477e7a2308dd18269de3bed04385 Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com> Signed-off-by: Paul Fertser <fercerpav@gmail.com> Reviewed-on: http://openocd.zylin.com/5081 Tested-by: jenkins Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
This commit is contained in:
committed by
Tomas Vanek
parent
6916550938
commit
6cb5ba6f11
178
src/target/etm.c
178
src/target/etm.c
@@ -869,7 +869,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
ctx->capture_driver->read_trace(ctx);
|
||||
|
||||
if (ctx->trace_depth == 0) {
|
||||
command_print(cmd->ctx, "Trace is empty.");
|
||||
command_print(cmd, "Trace is empty.");
|
||||
return ERROR_OK;
|
||||
}
|
||||
|
||||
@@ -893,7 +893,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
int current_pc_ok = ctx->pc_ok;
|
||||
|
||||
if (ctx->trace_data[ctx->pipe_index].flags & ETMV1_TRIGGER_CYCLE)
|
||||
command_print(cmd->ctx, "--- trigger ---");
|
||||
command_print(cmd, "--- trigger ---");
|
||||
|
||||
/* instructions execute in IE/D or BE/D cycles */
|
||||
if ((pipestat == STAT_IE) || (pipestat == STAT_ID))
|
||||
@@ -942,7 +942,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
next_pc = ctx->last_branch;
|
||||
break;
|
||||
case 0x1: /* tracing enabled */
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"--- tracing enabled at 0x%8.8" PRIx32 " ---",
|
||||
ctx->last_branch);
|
||||
ctx->current_pc = ctx->last_branch;
|
||||
@@ -950,7 +950,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
continue;
|
||||
break;
|
||||
case 0x2: /* trace restarted after FIFO overflow */
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"--- trace restarted after FIFO overflow at 0x%8.8" PRIx32 " ---",
|
||||
ctx->last_branch);
|
||||
ctx->current_pc = ctx->last_branch;
|
||||
@@ -958,7 +958,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
continue;
|
||||
break;
|
||||
case 0x3: /* exit from debug state */
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"--- exit from debug state at 0x%8.8" PRIx32 " ---",
|
||||
ctx->last_branch);
|
||||
ctx->current_pc = ctx->last_branch;
|
||||
@@ -971,7 +971,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
* we have to move on with the next trace cycle
|
||||
*/
|
||||
if (!current_pc_ok) {
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"--- periodic synchronization point at 0x%8.8" PRIx32 " ---",
|
||||
next_pc);
|
||||
ctx->current_pc = next_pc;
|
||||
@@ -998,9 +998,9 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
|| ((ctx->last_branch >= 0xffff0000) &&
|
||||
(ctx->last_branch <= 0xffff0020))) {
|
||||
if ((ctx->last_branch & 0xff) == 0x10)
|
||||
command_print(cmd->ctx, "data abort");
|
||||
command_print(cmd, "data abort");
|
||||
else {
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"exception vector 0x%2.2" PRIx32 "",
|
||||
ctx->last_branch);
|
||||
ctx->current_pc = ctx->last_branch;
|
||||
@@ -1058,7 +1058,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
ctx->ptr_ok = 1;
|
||||
|
||||
if (ctx->ptr_ok)
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"address: 0x%8.8" PRIx32 "",
|
||||
ctx->last_ptr);
|
||||
}
|
||||
@@ -1073,7 +1073,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
uint32_t data;
|
||||
if (etmv1_data(ctx, 4, &data) != 0)
|
||||
return ERROR_ETM_ANALYSIS_FAILED;
|
||||
command_print(cmd->ctx,
|
||||
command_print(cmd,
|
||||
"data: 0x%8.8" PRIx32 "",
|
||||
data);
|
||||
}
|
||||
@@ -1084,7 +1084,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
if (etmv1_data(ctx, arm_access_size(&instruction),
|
||||
&data) != 0)
|
||||
return ERROR_ETM_ANALYSIS_FAILED;
|
||||
command_print(cmd->ctx, "data: 0x%8.8" PRIx32 "", data);
|
||||
command_print(cmd, "data: 0x%8.8" PRIx32 "", data);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1119,7 +1119,7 @@ static int etmv1_analyze_trace(struct etm_context *ctx, struct command_invocatio
|
||||
(cycles == 1) ? "cycle" : "cycles");
|
||||
}
|
||||
|
||||
command_print(cmd->ctx, "%s%s%s",
|
||||
command_print(cmd, "%s%s%s",
|
||||
instruction.text,
|
||||
(pipestat == STAT_IN) ? " (not executed)" : "",
|
||||
cycles_text);
|
||||
@@ -1156,7 +1156,7 @@ static COMMAND_HELPER(handle_etm_tracemode_command_update,
|
||||
else if (strcmp(CMD_ARGV[0], "all") == 0)
|
||||
tracemode = ETM_CTRL_TRACE_DATA | ETM_CTRL_TRACE_ADDR;
|
||||
else {
|
||||
command_print(CMD_CTX, "invalid option '%s'", CMD_ARGV[0]);
|
||||
command_print(CMD, "invalid option '%s'", CMD_ARGV[0]);
|
||||
return ERROR_COMMAND_SYNTAX_ERROR;
|
||||
}
|
||||
|
||||
@@ -1176,7 +1176,7 @@ static COMMAND_HELPER(handle_etm_tracemode_command_update,
|
||||
tracemode |= ETM_CTRL_CONTEXTID_32;
|
||||
break;
|
||||
default:
|
||||
command_print(CMD_CTX, "invalid option '%s'", CMD_ARGV[1]);
|
||||
command_print(CMD, "invalid option '%s'", CMD_ARGV[1]);
|
||||
return ERROR_COMMAND_SYNTAX_ERROR;
|
||||
}
|
||||
|
||||
@@ -1207,13 +1207,13 @@ COMMAND_HANDLER(handle_etm_tracemode_command)
|
||||
struct etm_context *etm;
|
||||
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm = arm->etm;
|
||||
if (!etm) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1235,47 +1235,47 @@ COMMAND_HANDLER(handle_etm_tracemode_command)
|
||||
* or couldn't be written; display actual hardware state...
|
||||
*/
|
||||
|
||||
command_print(CMD_CTX, "current tracemode configuration:");
|
||||
command_print(CMD, "current tracemode configuration:");
|
||||
|
||||
switch (tracemode & ETM_CTRL_TRACE_MASK) {
|
||||
default:
|
||||
command_print(CMD_CTX, "data tracing: none");
|
||||
command_print(CMD, "data tracing: none");
|
||||
break;
|
||||
case ETM_CTRL_TRACE_DATA:
|
||||
command_print(CMD_CTX, "data tracing: data only");
|
||||
command_print(CMD, "data tracing: data only");
|
||||
break;
|
||||
case ETM_CTRL_TRACE_ADDR:
|
||||
command_print(CMD_CTX, "data tracing: address only");
|
||||
command_print(CMD, "data tracing: address only");
|
||||
break;
|
||||
case ETM_CTRL_TRACE_DATA | ETM_CTRL_TRACE_ADDR:
|
||||
command_print(CMD_CTX, "data tracing: address and data");
|
||||
command_print(CMD, "data tracing: address and data");
|
||||
break;
|
||||
}
|
||||
|
||||
switch (tracemode & ETM_CTRL_CONTEXTID_MASK) {
|
||||
case ETM_CTRL_CONTEXTID_NONE:
|
||||
command_print(CMD_CTX, "contextid tracing: none");
|
||||
command_print(CMD, "contextid tracing: none");
|
||||
break;
|
||||
case ETM_CTRL_CONTEXTID_8:
|
||||
command_print(CMD_CTX, "contextid tracing: 8 bit");
|
||||
command_print(CMD, "contextid tracing: 8 bit");
|
||||
break;
|
||||
case ETM_CTRL_CONTEXTID_16:
|
||||
command_print(CMD_CTX, "contextid tracing: 16 bit");
|
||||
command_print(CMD, "contextid tracing: 16 bit");
|
||||
break;
|
||||
case ETM_CTRL_CONTEXTID_32:
|
||||
command_print(CMD_CTX, "contextid tracing: 32 bit");
|
||||
command_print(CMD, "contextid tracing: 32 bit");
|
||||
break;
|
||||
}
|
||||
|
||||
if (tracemode & ETM_CTRL_CYCLE_ACCURATE)
|
||||
command_print(CMD_CTX, "cycle-accurate tracing enabled");
|
||||
command_print(CMD, "cycle-accurate tracing enabled");
|
||||
else
|
||||
command_print(CMD_CTX, "cycle-accurate tracing disabled");
|
||||
command_print(CMD, "cycle-accurate tracing disabled");
|
||||
|
||||
if (tracemode & ETM_CTRL_BRANCH_OUTPUT)
|
||||
command_print(CMD_CTX, "full branch address output enabled");
|
||||
command_print(CMD, "full branch address output enabled");
|
||||
else
|
||||
command_print(CMD_CTX, "full branch address output disabled");
|
||||
command_print(CMD, "full branch address output disabled");
|
||||
|
||||
#define TRACEMODE_MASK ( \
|
||||
ETM_CTRL_CONTEXTID_MASK \
|
||||
@@ -1331,7 +1331,7 @@ COMMAND_HANDLER(handle_etm_config_command)
|
||||
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "target '%s' is '%s'; not an ARM",
|
||||
command_print(CMD, "target '%s' is '%s'; not an ARM",
|
||||
target_name(target),
|
||||
target_type_name(target));
|
||||
return ERROR_FAIL;
|
||||
@@ -1382,7 +1382,7 @@ COMMAND_HANDLER(handle_etm_config_command)
|
||||
portmode |= ETM_PORT_2BIT;
|
||||
break;
|
||||
default:
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"unsupported ETM port width '%s'", CMD_ARGV[1]);
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
@@ -1394,7 +1394,7 @@ COMMAND_HANDLER(handle_etm_config_command)
|
||||
else if (strcmp("demultiplexed", CMD_ARGV[2]) == 0)
|
||||
portmode |= ETM_PORT_DEMUXED;
|
||||
else {
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"unsupported ETM port mode '%s', must be 'normal', 'multiplexed' or 'demultiplexed'",
|
||||
CMD_ARGV[2]);
|
||||
return ERROR_FAIL;
|
||||
@@ -1405,7 +1405,7 @@ COMMAND_HANDLER(handle_etm_config_command)
|
||||
else if (strcmp("full", CMD_ARGV[3]) == 0)
|
||||
portmode |= ETM_PORT_FULL_CLOCK;
|
||||
else {
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"unsupported ETM port clocking '%s', must be 'full' or 'half'",
|
||||
CMD_ARGV[3]);
|
||||
return ERROR_FAIL;
|
||||
@@ -1461,44 +1461,44 @@ COMMAND_HANDLER(handle_etm_info_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm = arm->etm;
|
||||
if (!etm) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
command_print(CMD_CTX, "ETM v%d.%d",
|
||||
command_print(CMD, "ETM v%d.%d",
|
||||
etm->bcd_vers >> 4, etm->bcd_vers & 0xf);
|
||||
command_print(CMD_CTX, "pairs of address comparators: %i",
|
||||
command_print(CMD, "pairs of address comparators: %i",
|
||||
(int) (etm->config >> 0) & 0x0f);
|
||||
command_print(CMD_CTX, "data comparators: %i",
|
||||
command_print(CMD, "data comparators: %i",
|
||||
(int) (etm->config >> 4) & 0x0f);
|
||||
command_print(CMD_CTX, "memory map decoders: %i",
|
||||
command_print(CMD, "memory map decoders: %i",
|
||||
(int) (etm->config >> 8) & 0x1f);
|
||||
command_print(CMD_CTX, "number of counters: %i",
|
||||
command_print(CMD, "number of counters: %i",
|
||||
(int) (etm->config >> 13) & 0x07);
|
||||
command_print(CMD_CTX, "sequencer %spresent",
|
||||
command_print(CMD, "sequencer %spresent",
|
||||
(int) (etm->config & (1 << 16)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "number of ext. inputs: %i",
|
||||
command_print(CMD, "number of ext. inputs: %i",
|
||||
(int) (etm->config >> 17) & 0x07);
|
||||
command_print(CMD_CTX, "number of ext. outputs: %i",
|
||||
command_print(CMD, "number of ext. outputs: %i",
|
||||
(int) (etm->config >> 20) & 0x07);
|
||||
command_print(CMD_CTX, "FIFO full %spresent",
|
||||
command_print(CMD, "FIFO full %spresent",
|
||||
(int) (etm->config & (1 << 23)) ? "" : "not ");
|
||||
if (etm->bcd_vers < 0x20)
|
||||
command_print(CMD_CTX, "protocol version: %i",
|
||||
command_print(CMD, "protocol version: %i",
|
||||
(int) (etm->config >> 28) & 0x07);
|
||||
else {
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"coprocessor and memory access %ssupported",
|
||||
(etm->config & (1 << 26)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "trace start/stop %spresent",
|
||||
command_print(CMD, "trace start/stop %spresent",
|
||||
(etm->config & (1 << 26)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "number of context comparators: %i",
|
||||
command_print(CMD, "number of context comparators: %i",
|
||||
(int) (etm->config >> 24) & 0x03);
|
||||
}
|
||||
|
||||
@@ -1549,30 +1549,30 @@ COMMAND_HANDLER(handle_etm_info_command)
|
||||
LOG_ERROR("Illegal max_port_size");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
command_print(CMD_CTX, "max. port size: %i", max_port_size);
|
||||
command_print(CMD, "max. port size: %i", max_port_size);
|
||||
|
||||
if (etm->bcd_vers < 0x30) {
|
||||
command_print(CMD_CTX, "half-rate clocking %ssupported",
|
||||
command_print(CMD, "half-rate clocking %ssupported",
|
||||
(config & (1 << 3)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "full-rate clocking %ssupported",
|
||||
command_print(CMD, "full-rate clocking %ssupported",
|
||||
(config & (1 << 4)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "normal trace format %ssupported",
|
||||
command_print(CMD, "normal trace format %ssupported",
|
||||
(config & (1 << 5)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "multiplex trace format %ssupported",
|
||||
command_print(CMD, "multiplex trace format %ssupported",
|
||||
(config & (1 << 6)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "demultiplex trace format %ssupported",
|
||||
command_print(CMD, "demultiplex trace format %ssupported",
|
||||
(config & (1 << 7)) ? "" : "not ");
|
||||
} else {
|
||||
/* REVISIT show which size and format are selected ... */
|
||||
command_print(CMD_CTX, "current port size %ssupported",
|
||||
command_print(CMD, "current port size %ssupported",
|
||||
(config & (1 << 10)) ? "" : "not ");
|
||||
command_print(CMD_CTX, "current trace format %ssupported",
|
||||
command_print(CMD, "current trace format %ssupported",
|
||||
(config & (1 << 11)) ? "" : "not ");
|
||||
}
|
||||
if (etm->bcd_vers >= 0x21)
|
||||
command_print(CMD_CTX, "fetch comparisons %ssupported",
|
||||
command_print(CMD, "fetch comparisons %ssupported",
|
||||
(config & (1 << 17)) ? "not " : "");
|
||||
command_print(CMD_CTX, "FIFO full %ssupported",
|
||||
command_print(CMD, "FIFO full %ssupported",
|
||||
(config & (1 << 8)) ? "" : "not ");
|
||||
|
||||
return ERROR_OK;
|
||||
@@ -1588,13 +1588,13 @@ COMMAND_HANDLER(handle_etm_status_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm = arm->etm;
|
||||
if (!etm) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1608,7 +1608,7 @@ COMMAND_HANDLER(handle_etm_status_command)
|
||||
if (etm_get_reg(reg) == ERROR_OK) {
|
||||
unsigned s = buf_get_u32(reg->value, 0, reg->size);
|
||||
|
||||
command_print(CMD_CTX, "etm: %s%s%s%s",
|
||||
command_print(CMD, "etm: %s%s%s%s",
|
||||
/* bit(1) == progbit */
|
||||
(etm->bcd_vers >= 0x12)
|
||||
? ((s & (1 << 1))
|
||||
@@ -1626,21 +1626,21 @@ COMMAND_HANDLER(handle_etm_status_command)
|
||||
/* Trace Port Driver status */
|
||||
trace_status = etm->capture_driver->status(etm);
|
||||
if (trace_status == TRACE_IDLE)
|
||||
command_print(CMD_CTX, "%s: idle", etm->capture_driver->name);
|
||||
command_print(CMD, "%s: idle", etm->capture_driver->name);
|
||||
else {
|
||||
static char *completed = " completed";
|
||||
static char *running = " is running";
|
||||
static char *overflowed = ", overflowed";
|
||||
static char *triggered = ", triggered";
|
||||
|
||||
command_print(CMD_CTX, "%s: trace collection%s%s%s",
|
||||
command_print(CMD, "%s: trace collection%s%s%s",
|
||||
etm->capture_driver->name,
|
||||
(trace_status & TRACE_RUNNING) ? running : completed,
|
||||
(trace_status & TRACE_OVERFLOWED) ? overflowed : "",
|
||||
(trace_status & TRACE_TRIGGERED) ? triggered : "");
|
||||
|
||||
if (etm->trace_depth > 0) {
|
||||
command_print(CMD_CTX, "%i frames of trace data read",
|
||||
command_print(CMD, "%i frames of trace data read",
|
||||
(int)(etm->trace_depth));
|
||||
}
|
||||
}
|
||||
@@ -1660,20 +1660,20 @@ COMMAND_HANDLER(handle_etm_image_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
if (etm_ctx->image) {
|
||||
image_close(etm_ctx->image);
|
||||
free(etm_ctx->image);
|
||||
command_print(CMD_CTX, "previously loaded image found and closed");
|
||||
command_print(CMD, "previously loaded image found and closed");
|
||||
}
|
||||
|
||||
etm_ctx->image = malloc(sizeof(struct image));
|
||||
@@ -1711,24 +1711,24 @@ COMMAND_HANDLER(handle_etm_dump_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
if (etm_ctx->capture_driver->status == TRACE_IDLE) {
|
||||
command_print(CMD_CTX, "trace capture wasn't enabled, no trace data captured");
|
||||
command_print(CMD, "trace capture wasn't enabled, no trace data captured");
|
||||
return ERROR_OK;
|
||||
}
|
||||
|
||||
if (etm_ctx->capture_driver->status(etm_ctx) & TRACE_RUNNING) {
|
||||
/* TODO: if on-the-fly capture is to be supported, this needs to be changed */
|
||||
command_print(CMD_CTX, "trace capture not completed");
|
||||
command_print(CMD, "trace capture not completed");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1768,18 +1768,18 @@ COMMAND_HANDLER(handle_etm_load_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
if (etm_ctx->capture_driver->status(etm_ctx) & TRACE_RUNNING) {
|
||||
command_print(CMD_CTX, "trace capture running, stop first");
|
||||
command_print(CMD, "trace capture running, stop first");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1794,7 +1794,7 @@ COMMAND_HANDLER(handle_etm_load_command)
|
||||
}
|
||||
|
||||
if (filesize % 4) {
|
||||
command_print(CMD_CTX, "size isn't a multiple of 4, no valid trace data");
|
||||
command_print(CMD, "size isn't a multiple of 4, no valid trace data");
|
||||
fileio_close(file);
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
@@ -1812,7 +1812,7 @@ COMMAND_HANDLER(handle_etm_load_command)
|
||||
}
|
||||
etm_ctx->trace_data = malloc(sizeof(struct etmv1_trace_data) * etm_ctx->trace_depth);
|
||||
if (etm_ctx->trace_data == NULL) {
|
||||
command_print(CMD_CTX, "not enough memory to perform operation");
|
||||
command_print(CMD, "not enough memory to perform operation");
|
||||
fileio_close(file);
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
@@ -1842,13 +1842,13 @@ COMMAND_HANDLER(handle_etm_start_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1887,13 +1887,13 @@ COMMAND_HANDLER(handle_etm_stop_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1923,14 +1923,14 @@ COMMAND_HANDLER(handle_etm_trigger_debug_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: %s isn't an ARM",
|
||||
command_print(CMD, "ETM: %s isn't an ARM",
|
||||
target_name(target));
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm = arm->etm;
|
||||
if (!etm) {
|
||||
command_print(CMD_CTX, "ETM: no ETM configured for %s",
|
||||
command_print(CMD, "ETM: no ETM configured for %s",
|
||||
target_name(target));
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
@@ -1955,7 +1955,7 @@ COMMAND_HANDLER(handle_etm_trigger_debug_command)
|
||||
buf_set_u32(etm_ctrl_reg->value, 0, 32, etm->control);
|
||||
}
|
||||
|
||||
command_print(CMD_CTX, "ETM: %s debug halt",
|
||||
command_print(CMD, "ETM: %s debug halt",
|
||||
(etm->control & ETM_CTRL_DBGRQ)
|
||||
? "triggers"
|
||||
: "does not trigger");
|
||||
@@ -1972,13 +1972,13 @@ COMMAND_HANDLER(handle_etm_analyze_command)
|
||||
target = get_current_target(CMD_CTX);
|
||||
arm = target_to_arm(target);
|
||||
if (!is_arm(arm)) {
|
||||
command_print(CMD_CTX, "ETM: current target isn't an ARM");
|
||||
command_print(CMD, "ETM: current target isn't an ARM");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
etm_ctx = arm->etm;
|
||||
if (!etm_ctx) {
|
||||
command_print(CMD_CTX, "current target doesn't have an ETM configured");
|
||||
command_print(CMD, "current target doesn't have an ETM configured");
|
||||
return ERROR_FAIL;
|
||||
}
|
||||
|
||||
@@ -1987,18 +1987,18 @@ COMMAND_HANDLER(handle_etm_analyze_command)
|
||||
/* FIX! error should be reported inside etmv1_analyze_trace() */
|
||||
switch (retval) {
|
||||
case ERROR_ETM_ANALYSIS_FAILED:
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"further analysis failed (corrupted trace data or just end of data");
|
||||
break;
|
||||
case ERROR_TRACE_INSTRUCTION_UNAVAILABLE:
|
||||
command_print(CMD_CTX,
|
||||
command_print(CMD,
|
||||
"no instruction for current address available, analysis aborted");
|
||||
break;
|
||||
case ERROR_TRACE_IMAGE_UNAVAILABLE:
|
||||
command_print(CMD_CTX, "no image available for trace analysis");
|
||||
command_print(CMD, "no image available for trace analysis");
|
||||
break;
|
||||
default:
|
||||
command_print(CMD_CTX, "unknown error");
|
||||
command_print(CMD, "unknown error");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user