target/cortex_m: allow poll quickly get out of TARGET_RESET state

cortex_m_poll_one() detects reset testing S_RESET_ST sticky bit.
If the signal comes unexpectedly, poll must return TARGET_RESET state.

On the contrary in case of polling inside of an OpenOCD reset command,
TARGET_RESET has been has already been set and we need to get out of
it as quickly as possible.

The original code needs 2 polls: the first clears S_RESET_ST
and keeps TARGET_RESET state, the current TARGET_RUNNING or TARGET_HALTED
is reflected as late as the second poll is done.

Change the logic to keep in TARGET_RESET only when necessary.

See also [1]

Link: [1] 8284: tcl/target: ti_cc3220sf: Use halt for CC3320SF targets | https://review.openocd.org/c/openocd/+/8284
Fixes: https://sourceforge.net/p/openocd/tickets/360/
Signed-off-by: Tomas Vanek <vanekt@fbl.cz>
Change-Id: I759461e5f89ca48a6e16e4b4101570260421dba1
Reviewed-on: https://review.openocd.org/c/openocd/+/8285
Tested-by: jenkins
Reviewed-by: Dhruva Gole <d-gole@ti.com>
This commit is contained in:
Tomas Vanek 2024-05-17 21:27:24 +02:00
parent bf4be566a7
commit 4892e32294
1 changed files with 5 additions and 1 deletions

View File

@ -931,9 +931,13 @@ static int cortex_m_poll_one(struct target *target)
if (target->state != TARGET_RESET) { if (target->state != TARGET_RESET) {
target->state = TARGET_RESET; target->state = TARGET_RESET;
LOG_TARGET_INFO(target, "external reset detected"); LOG_TARGET_INFO(target, "external reset detected");
} /* In case of an unexpected S_RESET_ST set TARGET_RESET state
* and keep it until the next poll to allow its detection */
return ERROR_OK; return ERROR_OK;
} }
/* S_RESET_ST was expected (in a reset command). Continue processing
* to quickly get out of TARGET_RESET state */
}
if (target->state == TARGET_RESET) { if (target->state == TARGET_RESET) {
/* Cannot switch context while running so endreset is /* Cannot switch context while running so endreset is