-
Notifications
You must be signed in to change notification settings - Fork 132
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
Fix aarch32 vm install #115
Closed
Closed
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Signed-off-by: Jose Martins <[email protected]>
Signed-off-by: Jose Martins <[email protected]>
Signed-off-by: Jose Martins <[email protected]>
danielRep
force-pushed
the
fix/aarch32_vm_install
branch
from
January 5, 2024 11:38
d043ba8
to
f84b327
Compare
danielRep
approved these changes
Jan 5, 2024
Signed-off-by: Jose Martins <[email protected]>
Add missing uart_putc function prototype to 8250_uart.h and nxp_uart.h files. Signed-off-by: joaopeixoto13 <[email protected]>
Signed-off-by: Jose Martins <[email protected]>
josecm
force-pushed
the
fix/aarch32_vm_install
branch
from
April 15, 2024 10:35
f84b327
to
7189a89
Compare
Signed-off-by: Xiongfei Liu <[email protected]>
First a fence was required to enforce the dependency on `install_info_ready` being set calling vmm_vm_install as there is no real data dependency. Second, we move the write fence which ensures the write to the page table is visible to within the install function. It is it responsibility to ensure it returns with its effects visible. Signed-off-by: Jose Martins <[email protected]>
Signed-off-by: Diogo Costa <[email protected]>
Initial commit for the process of adapting bao to the standard C11. Modified the makefile to compile according to C11 and reject the use of any extension. Signed-off-by: Miguel Silva <[email protected]>
The asm keyword is a GNU extension. Changed all instances to the C11 counterpart __asm__ Signed-off-by: Miguel Silva <[email protected]>
The use of binary constants (e.g., 0b0101) is a GCC extension. Refactor all binary constants to hex (e.g., 0x5). Signed-off-by: Miguel Silva <[email protected]>
GCC issues an error ("initializer element is not constant") when SPINLOCK_INITVAL was defined in a macro. Signed-off-by: Miguel Silva <[email protected]>
Most macros expand to functions. C11 does not allow the use of ; at the end of non-statements. Signed-off-by: Miguel Silva <[email protected]>
sgi_base[0] was used for better legibility while ensuring the the next registers were aligned properly. C11 does not allow these declarations. Signed-off-by: Miguel Silva <[email protected]>
Using an expression in return statement is illegal in C11. In this case, the function has a void return type. Signed-off-by: Miguel Silva <[email protected]>
__VA_OPT__ is only available as a GNU extension or in C23. The error issued by gcc is "error: __VA_OPT__ is not available until C2X" Signed-off-by: Miguel Silva <[email protected]>
C11 does not allow arithmetic operations on void* ptrs. Signed-off-by: Miguel Silva <[email protected]>
Add a dummy uint8_t to the structs page_table_arch and iommu_vm_arch since C11 does not allow structs to be declared without members. This was the best solution available avoiding majors modifications to bao. Considering both structs are only used in a small number of ocasions, the increase in memory usage is acceptable. Signed-off-by: Miguel Silva <[email protected]>
The macro DEFINED evaluates if a given macro was defined or not. Its expansion ends in a variadic macro that was not receiving the correct number of arguments if the evaluated macro was not defined. It was fixed by added a dummy argument that is ignored. Signed-off-by: Miguel Silva <[email protected]>
ISO C forbids zero-size arrays. From our understanding, that declaration does not achieve anything. Signed-off-by: Miguel Silva <[email protected]>
ISO C forbids braced-groups within expressions which was used in the CSRR macro. We use the same strategy as in arm code, by generating static functions accessors for each CSR Signed-off-by: Miguel Silva <[email protected]>
Pedantic C does not allow for the initialization of flexible array members. The presented solution follows the same pattern as other attributes in structs used in the configuration (e.g., shmemlist or regions). Signed-off-by: Miguel Silva <[email protected]>
With the changes to the type of vmlist, the system fails to build to generate the headers without adding an entry to the new vmlist array. Signed-off-by: Miguel Silva <[email protected]>
Signed-off-by: Miguel Silva <[email protected]>
Signed-off-by: Jose Martins <[email protected]>
Signed-off-by: Miguel Silva <[email protected]>
Pedantic C does not allow unused arguments, generating compile time errors. The portable way to circumvent this is to cast it to void which we do using the introduce UNUSED_ARG macro; Signed-off-by: Miguel Silva <[email protected]>
Pedantic C does not allow partial initialization of struct elements. Signed-off-by: Miguel Silva <[email protected]>
Pedantic C forces the 'static' and 'register' keywords to be in the beginning of declarations. Additionally, the 'const' keyword is not need in static inline functions. These errors are issued by the flag -Werror=old-style-declaration Signed-off-by: Miguel Silva <[email protected]>
emul_write and emul_read used comparision between elements with different signedness, which is not permitted by C11. Since these are unused, we opted to remove them. Signed-off-by: Miguel Silva <[email protected]>
The flag -wextra forces comparisons and other operations to have elements with the same signedness. In the commit, we change some variables types to match the operations they are used, or cast them to the correct type. Signed-off-by: Miguel Silva <[email protected]>
start type is unsigned therefore it won't ever be less than 0. Signed-off-by: Miguel Silva <[email protected]>
This commit adds warning flags that are not included in -wall and -wextra. These flags will help dealing with some MISRA directives (e.g., forcing explicit casts, adding missing prototypes, etc.) Signed-off-by: Miguel Silva <[email protected]>
With the additional compiler flags, most implicit casts are not allowed. This commit achieves this by forcing explicit casts, refactoring some variable types and fixing literal values. Signed-off-by: Miguel Silva <[email protected]>
The missing prototype error was being triggered due to one of the following: - the prototype was effectively missing; - the prototype was ill defined (mainly, no paramter function prototypes missed 'void' as paramter list; - the function did not have a prototype but did not require it. Mostly, because it was only used in the compilation unit - in this case to avoid, the error it must be defined as static; In some other cases these functions had a prototype defined which was not necessary and was thus removed. Signed-off-by: Miguel Silva <[email protected]>
Switch statements without a default case cause errors with the -Wswitch-default flag. Signed-off-by: Miguel Silva <[email protected]>
The flag -Wcast-qual issues errors when a qualifier (e.g., const) is removed through a cast. Signed-off-by: Miguel Silva <[email protected]>
Signed-off-by: Miguel Silva <[email protected]>
The Wshadow flag warns whenever a local variable or type declaration shadows another variable (e.g., global variables) Signed-off-by: Miguel Silva <[email protected]>
Signed-off-by: Miguel Silva <[email protected]>
Signed-off-by: Miguel Silva <[email protected]>
The compiler issues errors when trying to get the reference of elements of packed structs since it might result in unaligned pointer values. As such we forced the elements in question to be aligned inside the struct. Signed-off-by: Miguel Silva <[email protected]>
The level of page table where entries are shared for aarch32 is lvl 1. By resharing the lvl 0 pte, this was causing erroneous mappings on secondary cores. Signed-off-by: Jose Martins <[email protected]>
josecm
force-pushed
the
fix/aarch32_vm_install
branch
from
May 23, 2024 14:39
7189a89
to
2603780
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The level of page table where entries are shared for aarch32 is lvl 1. By resharing the lvl 0 pte, this was causing erroneous mappings on secondary cores.
Depends on #114