target: factor init to 'target init'
Adds 'target init' command handler, called as part of 'init'.
This commit is contained in:
parent
e03f3c57a5
commit
62fbb0f545
|
@ -111,11 +111,9 @@ COMMAND_HANDLER(handle_init_command)
|
||||||
|
|
||||||
initialized = 1;
|
initialized = 1;
|
||||||
|
|
||||||
command_context_mode(CMD_CTX, COMMAND_EXEC);
|
retval = command_run_line(CMD_CTX, "target init");
|
||||||
|
if (ERROR_OK != retval)
|
||||||
if (target_init(CMD_CTX) != ERROR_OK)
|
|
||||||
return ERROR_FAIL;
|
return ERROR_FAIL;
|
||||||
LOG_DEBUG("target init complete");
|
|
||||||
|
|
||||||
if ((retval = jtag_interface_init(CMD_CTX)) != ERROR_OK)
|
if ((retval = jtag_interface_init(CMD_CTX)) != ERROR_OK)
|
||||||
{
|
{
|
||||||
|
@ -126,7 +124,6 @@ COMMAND_HANDLER(handle_init_command)
|
||||||
|
|
||||||
/* Try to initialize & examine the JTAG chain at this point, but
|
/* Try to initialize & examine the JTAG chain at this point, but
|
||||||
* continue startup regardless */
|
* continue startup regardless */
|
||||||
command_context_mode(CMD_CTX, COMMAND_CONFIG);
|
|
||||||
if (command_run_line(CMD_CTX, "jtag init") == ERROR_OK)
|
if (command_run_line(CMD_CTX, "jtag init") == ERROR_OK)
|
||||||
{
|
{
|
||||||
command_context_mode(CMD_CTX, COMMAND_EXEC);
|
command_context_mode(CMD_CTX, COMMAND_EXEC);
|
||||||
|
|
|
@ -787,6 +787,23 @@ int target_init(struct command_context *cmd_ctx)
|
||||||
return ERROR_OK;
|
return ERROR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
COMMAND_HANDLER(handle_target_init_command)
|
||||||
|
{
|
||||||
|
if (CMD_ARGC != 0)
|
||||||
|
return ERROR_COMMAND_SYNTAX_ERROR;
|
||||||
|
|
||||||
|
static bool target_initialized = false;
|
||||||
|
if (target_initialized)
|
||||||
|
{
|
||||||
|
LOG_INFO("'target init' has already been called");
|
||||||
|
return ERROR_OK;
|
||||||
|
}
|
||||||
|
target_initialized = true;
|
||||||
|
|
||||||
|
LOG_DEBUG("Initializing targets...");
|
||||||
|
return target_init(CMD_CTX);
|
||||||
|
}
|
||||||
|
|
||||||
int target_register_event_callback(int (*callback)(struct target *target, enum target_event event, void *priv), void *priv)
|
int target_register_event_callback(int (*callback)(struct target *target, enum target_event event, void *priv), void *priv)
|
||||||
{
|
{
|
||||||
struct target_event_callback **callbacks_p = &target_event_callbacks;
|
struct target_event_callback **callbacks_p = &target_event_callbacks;
|
||||||
|
@ -4786,6 +4803,12 @@ COMMAND_HANDLER(handle_fast_load_command)
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct command_registration target_command_handlers[] = {
|
static const struct command_registration target_command_handlers[] = {
|
||||||
|
{
|
||||||
|
.name = "init",
|
||||||
|
.mode = COMMAND_CONFIG,
|
||||||
|
.handler = &handle_target_init_command,
|
||||||
|
.help = "initialize targets",
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = "targets",
|
.name = "targets",
|
||||||
.handler = &handle_targets_command,
|
.handler = &handle_targets_command,
|
||||||
|
|
Loading…
Reference in New Issue