-
Notifications
You must be signed in to change notification settings - Fork 25
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
Revised Virtual Memory #45
Conversation
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Victor Roest <[email protected]>
29c0a89
to
952cda6
Compare
Co-authored-by: Victor Roest <[email protected]>
make panic exit codes more obvious.
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Victor Roest <[email protected]>
Co-authored-by: Jonathan Dönszelmann <[email protected]>
* Resolved easy TODOs where possible * Converted `panic` calls to `FATAL` (for better logging) * Resolved some code analysis issues CLion flagged
Co-authored-by: Victor Roest <[email protected]>
…om the OS pagetable. This saves 8KiB (!) per process. It also makes caching more efficient. Co-authored-by: Jonathan Dönszelmann <[email protected]>
@dsluijk I think we addressed most if not all of your issues, if you could look at the changes again that would be appreciated. |
And removed some unused header files.
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.
I'll try and test it later. Apart from some very minor things it looks good!
|
||
// Switch back SVC/Kernel | ||
MSR CPSR_c, #Mode_SVC | ||
ADD fp, sp, #0 // ??? |
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.
What the difference with a regular mov here?
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.
I do not know, this was there in the original and I'm too scared to change it
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.
according to 10 minutes of research it's faster nor different to a simple mov. Compilers may generate it as part of a function header to help debuggers identify them. the #0 can be replaced by n for n variables in the stackframe. In this position it's confusing and useless and can be replaced by a simple mov.
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.
2 more minutes of research found that add is actually faster in 1 nonsequential cycle.
paraphrased from the arm manual:
The data operations ADD, SUB, RSB, ADC, SBC are 2S + 1I while RSC, ORR, EOR, MOV, BIC are 2S + 1N + 1I where I means internal cycle, N means nonsequential cycle and S means sequential cycle
Shouldn't make much of a difference here though, and is mostly confusing
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.
should be a mov imo
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.
LGTM
No description provided.