-
Notifications
You must be signed in to change notification settings - Fork 95
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
etrigger priority #1084
Comments
"etrigger" is defined to be higher priority than "mcontrol6 execute address before" on the first instruction of the handler. To do it the other way would lose the etrigger. As specified:
The alternative is worse because the etrigger doesn't ever happen:
Depending on how the debugger is written, this might matter. (It also would matter if you're simultaneously running an external debugger and a native debugger and the two triggers belong to the two different debuggers. We don't always guarantee that two concurrent debuggers will work, but they would in this case.) |
I meant more in the scenario if the mcontrol6 address was the address of the exception-causing instruction. |
This scenario?
|
Yep. I'm wondering if the etrigger still has to fire before the mcontrol6. |
The etrigger won't fire at all. Table 13 in the debug spec says that "mcontrol6 execute address before" is higher priority than load page fault (cause 13). The etrigger will fire only if we take a load page fault. The mcontrol6 trigger fired which prevents the page fault from happening which prevents the etrigger from happening. |
Good to know. This doesn't seem very clear in the spec. "etrigger" is a generic term for an exception-related trigger. Perhaps it would be clearer to indicate the etrigger priority corresponds to its programmed exception(s). The way I read it, the "etrigger" priority superseded the original exception. In which case, the fact that the load page fault could only occur if there was no mcontrol6 address trigger didn't matter (therefore, we have to evaluate for all possible exceptions). |
What is the original exception? In the scenario above there is no exception at all.
We never access address Y. We actually never even access address X because mcontrol6 fires before we fetch the instruction. If the mcontrol6 didn't exist then I agree that we would have taken the page fault and then the etrigger. Looking at the priv spec's synchronous exception priority, the RISC-V execution model is basically:
Any exceptions are dealt with in the appropriate phase:
Debug adds triggers to each phase and it adds a phase before fetch:
If you get an execute trigger firing in the fetch phase then you don't successfully fetch an instruction. Therefore, there's no instruction to decode and there's no load to execute and you won't know that it got a page fault. Of course, implementations can possibly run ahead but they need to preserve the illusion that everything happens sequentially like this. |
By "original exception" I mean the exception corresponding to the etrigger. I agree that is the presumed execution model, but it's not like this is something stated either. The confusion I had with the debug spec's priority table is it does seem to require "runahead" behavior to determine possible exceptions. For instance, there is no text that the etrigger priority called out in the table deals with
Instead, it is a blanket statement that says etrigger is higher priority than an instruction address breakpoint. If you feel the text is clear enough about this I'll close the issue. |
I don't exactly understand the scenario you're worried about but I do agree that etrigger isn't defined very well. For example, itrigger clearly says "This trigger can fire when an interrupt trap is taken." On the other hand, etrigger doesn't really say when it matches. It says that it fires on codes in mcause rather than firing on exceptions. Would it be clearer if etrigger said this?
Then it already explains what happens next:
That clearly separates matching from firing. Matching happens on the trap itself (subject to per-trap filtering) and firing happens immediately before fetching the first instruction of the handler. |
Yes, that is much clearer. I just realized I was looking at an older version that did not even have this statement
|
Must all etrigger-firing exceptions have the highest priority, or can a subset have lower priorities? For example, a load page fault etrigger having lower priority than an instruction address mcontrol6 trigger.
The text was updated successfully, but these errors were encountered: