-
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
Trigger match on csrrs/csrrc to tdata1 #1026
Comments
I had always assumed that csrrs/csrrc are just like csrw. Not sure what to make of the line you quote that "Other bits in the CSR are not explicitly written." Regardless, I think the hit bit will be set. If timing=before, then the CSR isn't modified before the action is taken, so there's no conflict. If timing=after, then the trigger fires after the instruction has retired, so there's no conflict either. In both cases there's a clear ordering of the CSR being updated by the instruction, and the CSR being updated because the trigger fires. They don't happen simultaneously. |
Apologies I forgot to mention another important part of this example - the action being 2-4 (trace related) and the timing being "before" so the triggering instruction still executes. If the action is 0-1 then it's more clear because the triggering instruction doesn't execute because we've entered debug mode or taken an exception. And if timing is "after" it's more clear as well because the triggering instruction has fully executed and retired before the trigger fires. The quote I mentioned was because if the CSR instruction were to explicitly write all bits then it would be reasonable to assume that I guess another important point that complicates things is that the spec allows instructions to partially execute before firing, even when timing=before. So it could be argued that it's reasonable for both HW (trigger) and SW (CSR instruction) updates to the CSR to happen simultaneously. However I tend to agree with you that in my example the HW write to the CSR should happen first (when the trigger fires) and then (if the action is not 0-1) the instruction executes and does the SW update afterwards. With both CSR updates occurring independently. |
I looked at Zicsr and I don't see the sentence about "Other bits in the CSR are not explicitly written." Where is that? |
Ah I was looking at an older version of the Unprivileged spec, it looks like that section has been reworded in a more recent version. Although I'm not sure if that really affects the discussion here. |
I think that your concern is with this:
If you have:
One concern I have is that there is no "increment" as stated in the last sentence I quoted. If that should be read as "the software write is done instead of the hardware write" then I think that the hit bit should not be set in the above situation because setting hit is a side effect. If the sentence literally only applies to CSRs that are written as side effects of instruction execution where such side effects involve incrementing the CSR, then the hit bit probably should be set. I assume that it was not meant to be limited to incrementing. @aswaterman: You have a perspective on the history of Zicsr. What are your thoughts? |
The text wasn't meant to be limiting to incrementing; that choice of word was in the context of the instret example. My reading of the spec concurs with your first interpretation, @pdonahue-ventana. |
Thanks. That's what I figured. The Zicsr text should probably change the word "increment" to something more generic. |
@pdonahue-ventana What do you think about "the explicit write is done instead of the update from the side effect"? |
That sounds good. |
That looks good. (Frankly, I'm not a big fan of this rule. But setting that aside, the change looks good from the point of view of clarifying the intent.) |
I'm not planning on proposing changing anything, but out of curiosity, what would you have preferred: invert the order so that the write happens first, and the side-effecting update considers the new value of the register; or make it unspecified which order they happen in? (I can't think of a case where it matters much, to be honest...) |
The current requirement leads to hacks like https://github.com/riscv-software-src/riscv-isa-sim/blob/master/riscv/csrs.cc#L1042 in Spike and similar unnatural tricks in hardware. It seems more natural for the CSR write to occur during the execution of the instruction and the side effect to happen after the instruction (seeing the new value). That would obviously be a (verboten) normative change to Zicsr because it causes a |
If we do a
csrrs/csrrc
instruction totdata1
that does not set/clear thehit
bit oftdata1
, and that same instruction causes a trigger to fire (e.g. PC match on amcontrol6
trigger), is it expected that thehit
bit will be set?Generally it's expected that software writes to CSRs have higher priority that implicit hardware writes. In the
csrrw
case it's clear because the instruction always updates the whole register. And in thecsrr
case it's clear because the instruction wasn't updating the register at all. But what if it's a software write that wasn't explicitly updating the bits that the hardware was?The description for
csrrs/csrrc
say: "Other bits in the CSR are not explicitly written.". But it's ambiguous.Perhaps this is not a debug spec specific question, but it's hard to come up with another example like this for other CSRs that doesn't involve triggers.
The text was updated successfully, but these errors were encountered: