Skip to content

Commit

Permalink
Clarify the restriction on dmcontrol writes while abstractcs.busy
Browse files Browse the repository at this point in the history
… is high

With the clarification, it's obvious that the DM can be reset without
knowing the `hartsel`.

Fixes #1021
  • Loading branch information
en-sc committed May 17, 2024
1 parent 4bd3bc9 commit 6a08d8c
Showing 1 changed file with 2 additions and 1 deletion.
3 changes: 2 additions & 1 deletion debug_module.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -368,7 +368,8 @@ of {dm-data0}) or hart (e.g. contents of a register modified by a Program Buffe

Before starting an abstract command, a debugger must ensure that {dmcontrol-haltreq}, {dmcontrol-resumereq}, and {dmcontrol-ackhavereset} are all 0.

While an abstract command is executing ({abstractcs-busy} in {dm-abstractcs} is high), a debugger must not change {hartsel}, and must not write 1 to {dmcontrol-haltreq}, {dmcontrol-resumereq}, {dmcontrol-ackhavereset}, {dmcontrol-setresethaltreq}, or {dmcontrol-clrresethaltreq}.
While an abstract command is executing ({abstractcs-busy} in {dm-abstractcs} is high), a debugger must not change {hartsel}, and must not write 1 to {dmcontrol-haltreq}, {dmcontrol-resumereq}, {dmcontrol-ackhavereset}, {dmcontrol-setresethaltreq}, or {dmcontrol-clrresethaltreq},
unless the DM is reset by the same write to {dm-dmcontrol} ({dmcontrol-dmactive} is lowered).

If an abstract command does not complete in the expected time and
appears to be hung, the debugger can try to reset the hart (using {dmcontrol-hartreset} or {dmcontrol-ndmreset}).
Expand Down

0 comments on commit 6a08d8c

Please sign in to comment.