-
Notifications
You must be signed in to change notification settings - Fork 26
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
Machine mode indicator #174
base: main
Are you sure you want to change the base?
Conversation
…hine mode solves openhwgroup#8 Signed-off-by: Szymon Bieganski <[email protected]>
I am thinking if there shouldnt be two different signal. 1, the mode. 2, the effective mode. privilege can be different for fetches and for data accesses, if mstatus.MPRV is set. |
resolves #8 |
hi @christian-herber-nxp , what do you mean effective mode or just mode? when you change mode to be sure 100% nothing in flights (newer than the change mode instruction) you should clear the internal instruction buffer filled by the prefetcher, and before changing the mode, flush the pipeline (e.g. if there are in flights loads/stores) The cv32e2 pipeline should not have anything inflight from the ld/st viewpoint as 2 pipeline stage, so no issues in that part, but it won't be true from the pre-fetching part - one simple solution would be to make this specific instruction JUMP to the next instruction (PC+4) as jumping fetches the instruction from the memory, hence, the new fetch will come with the updated privilege mode). But this won't belong to this PR, it would rather be a bug (like |
I think we are not quite in sync. My point is, that if mstatus.MPRV = 1, loads/and stores use a different privilege level than instruction fetches. At this point, there is no PMP. The ibex PMP is integrated, so i would expect this solves it. But exposing the privilege level to the busses is a more complicated thing, because you dont know what checks to expect. |
I had a look into the OBI spec (probably should have done this before). |
Signed-off-by: Szymon Bieganski <[email protected]>
…the exposed signals closes openhwgroup#175 Signed-off-by: Szymon Bieganski <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
change needed to:
- have prot[] signal for each OBI interface
- prot based on effective privilege level for the data interface
Signed-off-by: Szymon Bieganski <[email protected]>
Hi @davideschiavone, can you review the latest update by @szbieg? |
I still do not see what @christian-herber-nxp requested here: have prot[] signal for each OBI interface |
The aim of this task is to expose privilege (effective) level status. OBI interface will be connected to those exposed signals, and as such is already covered in task #70. @davideschiavone please clarify what exactly do you expect to see if not the exposed privilege mode. |
Expose to the output ports whether the core is running in user or machine mode
solves #8