target: fix display halt message logic
If a target is run from gdb and then stopped from OpenOCD telnet interface, halt does not show message with status and PC registers. While on it rename 'display' to 'verbose_halt_msg' and use bool type instead of int. Change-Id: Ibe6589015b302e0be97258b06938c297745436a5 Signed-off-by: Tomas Vanek <vanekt@fbl.cz> Reviewed-on: http://openocd.zylin.com/4475 Tested-by: jenkins Reviewed-by: Matthias Welwarsky <matthias@welwarsky.de>
This commit is contained in:
parent
f035b0851b
commit
37deb37593
|
@ -87,13 +87,13 @@ static int log_target_callback_event_handler(struct target *target,
|
||||||
{
|
{
|
||||||
switch (event) {
|
switch (event) {
|
||||||
case TARGET_EVENT_GDB_START:
|
case TARGET_EVENT_GDB_START:
|
||||||
target->display = 0;
|
target->verbose_halt_msg = false;
|
||||||
break;
|
break;
|
||||||
case TARGET_EVENT_GDB_END:
|
case TARGET_EVENT_GDB_END:
|
||||||
target->display = 1;
|
target->verbose_halt_msg = true;
|
||||||
break;
|
break;
|
||||||
case TARGET_EVENT_HALTED:
|
case TARGET_EVENT_HALTED:
|
||||||
if (target->display) {
|
if (target->verbose_halt_msg) {
|
||||||
/* do not display information when debugger caused the halt */
|
/* do not display information when debugger caused the halt */
|
||||||
target_arch_state(target);
|
target_arch_state(target);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2959,6 +2959,9 @@ COMMAND_HANDLER(handle_halt_command)
|
||||||
LOG_DEBUG("-");
|
LOG_DEBUG("-");
|
||||||
|
|
||||||
struct target *target = get_current_target(CMD_CTX);
|
struct target *target = get_current_target(CMD_CTX);
|
||||||
|
|
||||||
|
target->verbose_halt_msg = true;
|
||||||
|
|
||||||
int retval = target_halt(target);
|
int retval = target_halt(target);
|
||||||
if (ERROR_OK != retval)
|
if (ERROR_OK != retval)
|
||||||
return retval;
|
return retval;
|
||||||
|
@ -5579,7 +5582,7 @@ static int target_create(Jim_GetOptInfo *goi)
|
||||||
target->next = NULL;
|
target->next = NULL;
|
||||||
target->arch_info = NULL;
|
target->arch_info = NULL;
|
||||||
|
|
||||||
target->display = 1;
|
target->verbose_halt_msg = true;
|
||||||
|
|
||||||
target->halt_issued = false;
|
target->halt_issued = false;
|
||||||
|
|
||||||
|
|
|
@ -176,7 +176,7 @@ struct target {
|
||||||
void *private_config; /* pointer to target specific config data (for jim_configure hook) */
|
void *private_config; /* pointer to target specific config data (for jim_configure hook) */
|
||||||
struct target *next; /* next target in list */
|
struct target *next; /* next target in list */
|
||||||
|
|
||||||
int display; /* display async info in telnet session. Do not display
|
bool verbose_halt_msg; /* display async info in telnet session. Do not display
|
||||||
* lots of halted/resumed info when stepping in debugger. */
|
* lots of halted/resumed info when stepping in debugger. */
|
||||||
bool halt_issued; /* did we transition to halted state? */
|
bool halt_issued; /* did we transition to halted state? */
|
||||||
int64_t halt_issued_time; /* Note time when halt was issued */
|
int64_t halt_issued_time; /* Note time when halt was issued */
|
||||||
|
|
Loading…
Reference in New Issue