-
Notifications
You must be signed in to change notification settings - Fork 44
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
Support additional 64bit immediate instruction modes #763
Comments
This documentation has helped me understand relocations: https://docs.kernel.org/bpf/llvm_reloc.html |
I have spent some time on the relocation issue. Consider the following simple example:
Its disassembly looks like this:
The relocations are at instructions
The symbol table:
The |
@Alan-Jowett, based on the algorithm you suggested above, should we keep each relocation in a separate region of its own (i.e., one region for I apologize if this seems confusing. I have limited knowledge about relocations and how the verifier already implements map relocations, and there is a possibility I am way off with the above description. |
https://www.ietf.org/archive/id/draft-ietf-bpf-isa-04.html#name-platform-variables
The BPF ISA at the IETF defines various 64bit immediate loads:
Currently the verifier only supports type 0 and type 1 loads.
Type 1 loads are supported here:
https://github.com/vbpf/ebpf-verifier/blob/16e06cf98c36848c0da804d71310041e4243642b/src/asm_files.cpp#L431C1-L435C22
To support type 3, the code should handle the case where the relocation is to a .rodata section (aka platform variables).
Behavior would be:
At that point, the rest of the code should operate correctly.
The text was updated successfully, but these errors were encountered: