jtag: rewrite jim_jtag_tap_enabler() as COMMAND_HANDLER

The function is used for commands:
- jtag tapisenabled
- jtag tapenable
- jtag tapdisable

While there, add the missing .help and .usage fields and fix the
incorrect check in jtag_tap_enable() and jtag_tap_disable().

Change-Id: I0e1c9f0b8d9fbad19d09610a97498bec8003c27e
Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com>
Reviewed-on: https://review.openocd.org/c/openocd/+/7554
Tested-by: jenkins
This commit is contained in:
Antonio Borneo 2023-01-02 17:12:04 +01:00
parent 5dd047fbbe
commit 8297836170
4 changed files with 44 additions and 37 deletions

View File

@ -97,12 +97,18 @@ static const struct command_registration hl_transport_jtag_subcommand_handlers[]
{ {
.name = "tapisenabled", .name = "tapisenabled",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Returns a Tcl boolean (0/1) indicating whether "
"the TAP is enabled (1) or not (0).",
.usage = "tap_name",
}, },
{ {
.name = "tapenable", .name = "tapenable",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Try to enable the specified TAP using the "
"'tap-enable' TAP event.",
.usage = "tap_name",
}, },
{ {
.name = "tapdisable", .name = "tapdisable",

View File

@ -604,7 +604,7 @@ COMMAND_HANDLER(handle_jtag_arp_init_reset)
static bool jtag_tap_enable(struct jtag_tap *t) static bool jtag_tap_enable(struct jtag_tap *t)
{ {
if (t->enabled) if (t->enabled)
return false; return true;
jtag_tap_handle_event(t, JTAG_TAP_EVENT_ENABLE); jtag_tap_handle_event(t, JTAG_TAP_EVENT_ENABLE);
if (!t->enabled) if (!t->enabled)
return false; return false;
@ -619,7 +619,7 @@ static bool jtag_tap_enable(struct jtag_tap *t)
static bool jtag_tap_disable(struct jtag_tap *t) static bool jtag_tap_disable(struct jtag_tap *t)
{ {
if (!t->enabled) if (!t->enabled)
return false; return true;
jtag_tap_handle_event(t, JTAG_TAP_EVENT_DISABLE); jtag_tap_handle_event(t, JTAG_TAP_EVENT_DISABLE);
if (t->enabled) if (t->enabled)
return false; return false;
@ -632,42 +632,36 @@ static bool jtag_tap_disable(struct jtag_tap *t)
return true; return true;
} }
int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, Jim_Obj *const *argv) __COMMAND_HANDLER(handle_jtag_tap_enabler)
{ {
struct command *c = jim_to_command(interp); if (CMD_ARGC != 1)
const char *cmd_name = c->name; return ERROR_COMMAND_SYNTAX_ERROR;
struct jim_getopt_info goi;
jim_getopt_setup(&goi, interp, argc-1, argv + 1); struct jtag_tap *t = jtag_tap_by_string(CMD_ARGV[0]);
if (goi.argc != 1) { if (!t) {
Jim_SetResultFormatted(goi.interp, "usage: %s <name>", cmd_name); command_print(CMD, "Tap '%s' could not be found", CMD_ARGV[0]);
return JIM_ERR; return ERROR_COMMAND_ARGUMENT_INVALID;
} }
struct jtag_tap *t; if (strcmp(CMD_NAME, "tapisenabled") == 0) {
t = jtag_tap_by_jim_obj(goi.interp, goi.argv[0]);
if (!t)
return JIM_ERR;
if (strcasecmp(cmd_name, "tapisenabled") == 0) {
/* do nothing, just return the value */ /* do nothing, just return the value */
} else if (strcasecmp(cmd_name, "tapenable") == 0) { } else if (strcmp(CMD_NAME, "tapenable") == 0) {
if (!jtag_tap_enable(t)) { if (!jtag_tap_enable(t)) {
LOG_WARNING("failed to enable tap %s", t->dotted_name); command_print(CMD, "failed to enable tap %s", t->dotted_name);
return JIM_ERR; return ERROR_FAIL;
} }
} else if (strcasecmp(cmd_name, "tapdisable") == 0) { } else if (strcmp(CMD_NAME, "tapdisable") == 0) {
if (!jtag_tap_disable(t)) { if (!jtag_tap_disable(t)) {
LOG_WARNING("failed to disable tap %s", t->dotted_name); command_print(CMD, "failed to disable tap %s", t->dotted_name);
return JIM_ERR; return ERROR_FAIL;
} }
} else { } else {
LOG_ERROR("command '%s' unknown", cmd_name); command_print(CMD, "command '%s' unknown", CMD_NAME);
return JIM_ERR; return ERROR_FAIL;
} }
bool e = t->enabled;
Jim_SetResult(goi.interp, Jim_NewIntObj(goi.interp, e)); command_print(CMD, "%d", t->enabled ? 1 : 0);
return JIM_OK; return ERROR_OK;
} }
int jim_jtag_configure(Jim_Interp *interp, int argc, Jim_Obj *const *argv) int jim_jtag_configure(Jim_Interp *interp, int argc, Jim_Obj *const *argv)
@ -763,7 +757,7 @@ static const struct command_registration jtag_subcommand_handlers[] = {
{ {
.name = "tapisenabled", .name = "tapisenabled",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Returns a Tcl boolean (0/1) indicating whether " .help = "Returns a Tcl boolean (0/1) indicating whether "
"the TAP is enabled (1) or not (0).", "the TAP is enabled (1) or not (0).",
.usage = "tap_name", .usage = "tap_name",
@ -771,7 +765,7 @@ static const struct command_registration jtag_subcommand_handlers[] = {
{ {
.name = "tapenable", .name = "tapenable",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Try to enable the specified TAP using the " .help = "Try to enable the specified TAP using the "
"'tap-enable' TAP event.", "'tap-enable' TAP event.",
.usage = "tap_name", .usage = "tap_name",
@ -779,7 +773,7 @@ static const struct command_registration jtag_subcommand_handlers[] = {
{ {
.name = "tapdisable", .name = "tapdisable",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Try to disable the specified TAP using the " .help = "Try to disable the specified TAP using the "
"'tap-disable' TAP event.", "'tap-disable' TAP event.",
.usage = "tap_name", .usage = "tap_name",

View File

@ -18,9 +18,10 @@
#ifndef OPENOCD_JTAG_TCL_H #ifndef OPENOCD_JTAG_TCL_H
#define OPENOCD_JTAG_TCL_H #define OPENOCD_JTAG_TCL_H
#include <helper/command.h>
int jim_jtag_configure(Jim_Interp *interp, int argc, int jim_jtag_configure(Jim_Interp *interp, int argc,
Jim_Obj * const *argv); Jim_Obj * const *argv);
int jim_jtag_tap_enabler(Jim_Interp *interp, int argc, __COMMAND_HANDLER(handle_jtag_tap_enabler);
Jim_Obj * const *argv);
#endif /* OPENOCD_JTAG_TCL_H */ #endif /* OPENOCD_JTAG_TCL_H */

View File

@ -89,12 +89,18 @@ static const struct command_registration dapdirect_jtag_subcommand_handlers[] =
{ {
.name = "tapisenabled", .name = "tapisenabled",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Returns a Tcl boolean (0/1) indicating whether "
"the TAP is enabled (1) or not (0).",
.usage = "tap_name",
}, },
{ {
.name = "tapenable", .name = "tapenable",
.mode = COMMAND_EXEC, .mode = COMMAND_EXEC,
.jim_handler = jim_jtag_tap_enabler, .handler = handle_jtag_tap_enabler,
.help = "Try to enable the specified TAP using the "
"'tap-enable' TAP event.",
.usage = "tap_name",
}, },
{ {
.name = "tapdisable", .name = "tapdisable",