-
Notifications
You must be signed in to change notification settings - Fork 19
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
ELF Parser in Lean #18
Comments
Also this paper |
@shigoel / others, is anyone working on this yet? I'm interested in helping. |
@tenedor Hi Daniel -- no, there isn't anyone working on this. It'd be great to have your help! |
@shigoel Sounds good, I'll take a stab at it! This isn't an area I've worked in before but hopefully I can still be useful. Thanks for all the links to resources on ELF. Are you looking for just an implementation of the parser at this stage, or does it need to be a verified implementation? |
@tenedor Thank you, Daniel!! Just a parser implementation would do, to begin with. It may be interesting to keep verification in mind during development though, so that we can imagine what a potential proof would look like and structure code appropriately. The paper Jim linked above does a pretty deep dive into ELF Linking, and may be of interest after some basics are lined up. |
@shigoel Great! Okay, here are some scoping questions: It sounds like at some point this parser may be useful as a standalone project, but I'm going to focus on the LNSym use case for now. What parts of ELF parsing are important for LNSym? E.g. do you just care about running programs (so, executables and shared libraries need to be parsed), or do you care about linking or additional capabilities ELF supports? When you say that the parser should render the parsed binary "into a form suitable for use by LNSym", what representation do you have in mind? E.g. do you just need a parser from the binary-encoded data to nice-to-work-with data structures, or does the scope for this include mapping program segments into simulated memory, doing dynamic linking, relocation, etc.? Let me know if there's a clear hand-off point that's already written in LNSym. (I figure I should also look at how you're running the SHA256 tests.) What level of performance do you need from an initial version? / How soon will you care about performance? Do you have an example ELF file that I should start with? The simpler the better =). I figure I'll get a standalone executable working first before I consider shared libraries. That's probably enough questions to throw at you at once! But if you have other recommendations I'll happily take them. I can also find time to set up a call if that's useful. Either way, I'll try to get some basic code to you soon so we can start iterating on that. |
I'd suggest starting small with the ability to parse (deserialize) an ELF
binary (executables and shared libraries) into easy to use data-structures.
But, as Shilpi says, think about what one might prove about it and how.
But, dream big, also image deserializing those data-structures back into an
ELF binary. Imagine one day loading in a binary, applying a
correctness preserving optimization to it, and writing it back out again as
an optimized executable. That's a long way off, but it's fun to deam.
…On Wed, Mar 20, 2024 at 5:16 PM Daniel Windham ***@***.***> wrote:
@shigoel <https://github.com/shigoel> Great! Okay, here are some scoping
questions:
It sounds like at some point this parser may be useful as a standalone
project, but I'm going to focus on the LNSym use case for now.
What parts of ELF parsing are important for LNSym? E.g. do you just care
about running programs (so, executables and shared libraries need to be
parsed), or do you care about linking or additional capabilities ELF
supports?
When you say that the parser should render the parsed binary "into a form
suitable for use by LNSym", what representation do you have in mind? E.g.
do you just need a parser from the binary-encoded data to nice-to-work-with
data structures, or does the scope for this include mapping program
segments into simulated memory, doing dynamic linking, relocation, etc.?
Let me know if there's a clear hand-off point that's already written in
LNSym. (I figure I should also look at how you're running the SHA256 tests.)
What level of performance do you need from an initial version? / How soon
will you care about performance?
Do you have an example ELF file that I should start with? The simpler the
better =). I figure I'll get a standalone executable working first before I
consider shared libraries.
That's probably enough questions to throw at you at once! But if you have
other recommendations I'll happily take them. I can also find time to set
up a call if that's useful. Either way, I'll try to get some basic code to
you soon so we can start iterating on that.
—
Reply to this email directly, view it on GitHub
<#18 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AUPXYT345PVXYLVFOJPMORLYZIDD7AVCNFSM6AAAAABDVGHT7GVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDAMJQG42DEOJQHE>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
Serializing back to a file will come for free - writing the round trip deserialize + serialize from the start more than pays for itself in testing gains. But I'll leave the optimizing rewrites for the future 🙂 |
Possibly relevant: I'm currently working on an ELF model and parser in Lean. So far, it's basically a port of the ELF model from https://github.com/rems-project/linksem, accompanied by an (unpolished)
Anyhow, I'm working on getting permission to make the repo public. Would that be of interest to you all? (Also, I noticed in CONTRIBUTING.md that you don't want to take on any external dependencies. Would that rule out using a standalone ELF parsing library? I'm planning to release it under MIT, so it'd also be possible to fold whatever pieces you want into your own codebase.) |
@gleachkr This is exciting! Thanks for letting us know! Your repo. would definitely be of interest to us, especially if Arm64 platforms are supported. Please keep us posted. BTW, does your library include a Lean proof of correctness of relocation for some platform, similar to the REMS' ELF work? Re. external dependencies: we try to limit what we import because we often need to be on the bleeding edge of Lean versions (i.e., nightly releases). We found in the past that other libraries sometimes weren't bumped up to use the same |
Wonderful! Here's the repo (please excuse the lack of polish right now): https://github.com/draperlaboratory/ELFSage. I just bumped the tool chain to catch up with you all.
That would be in scope, but I think it's some ways off. Would something like the ELF file structures, from https://github.com/rems-project/linksem/blob/master/src/elf_file.lem be a useful parsing output for you all? I think that's a pretty natural next step on my side. |
Sweet! @gleachkr, would you want help developing ELFSage? Incidentally I'm also based in Cambridge. |
On Thu Mar 21, 2024 at 5:35 PM EDT, Daniel Windham wrote:
Sweet! @gleachkr, would you want help developing ELFSage?
Sure thing, absolutely!
Incidentally I'm also based in Cambridge.
That's neat, small world :)
|
Indeed -- that looks great! |
@gleachkr great - how do you want to coordinate on ways I can help? I'm happy to get on a call (or meet in person) if that's convenient. |
A meetup sounds good (the geographical coincidence kinda calls out for it). My email is [email protected], if you want to send me a note maybe we can take it from there. |
Great, I sent you an email.
…On Fri, Mar 22, 2024, 13:15 Graham Leach-Krouse ***@***.***> wrote:
A meetup sounds good (the geographical coincidence kinda calls out for
it). My email is ***@***.***, if you want to send me a note maybe
we can take it from there.
—
Reply to this email directly, view it on GitHub
<#18 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AALOGU77FVGZQKNHNFBUWATYZRRJ3AVCNFSM6AAAAABDVGHT7GVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDAMJVGU2DGNJZGI>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
Update: we've now got a stable-ish implementation of something corresponding to the rems-project It's essentially:
With the fields implemented as: ELF64Header, ELF64ProgramHeaderTableEntry, InterpretedSegment, ELF64SectionHeaderTableEntry, and InterpretedSection. Hopefully it's all pretty uncontroversial and boring-in-a-good-way, but we thought it might be a good idea to check in to make sure that this is going in a direction that looks useful to you, before anything gets too locked in. |
Hi @shigoel! What do you see as the integration path for using ELFSage in LNSym?
|
@gleachkr |
@tenedor I'm temporarily working on another project right now, and unfortunately, I don't have the bandwidth to actively work on LNSym. I'll be back on LNSym in July, and I'm looking forward to properly trying out ELFSage then. But I'll answer your "shortest path" question. An immediately useful capability for us (which I suspect already exists in ELFSage) would be to read in a given executable, and get all the bytes corresponding to a given symbol in any section ( |
Okay thanks @shigoel, good to know! Is LMSym paused until July, or is there
someone else we should coordinate with?
…On Fri, Apr 19, 2024, 16:54 Shilpi Goel ***@***.***> wrote:
@tenedor <https://github.com/tenedor> I'm temporarily working on another
project right now, and unfortunately, I don't have the bandwidth to
actively work on LNSym. I'll be back on LNSym in July, and I'm looking
forward to properly trying out ELFSage then.
But I'll answer your "shortest path" question. An immediately useful
capability for us (which I suspect already exists in ELFSage) would be to
read in a given executable, and get all the bytes corresponding to a given
symbol in any section (.text, .rodata, etc.). This would replace our
clumsy way of representing programs right now: here's an example
<https://github.com/leanprover/LNSym/blob/bdfadd596f64940993650e6378543a9ddebd27a1/Tests/SHA512ProgramTest.lean#L16>.
This interface would be one of the most important to keep stable.
—
Reply to this email directly, view it on GitHub
<#18 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AALOGU2ACEZ26REXA6SW2QDY6GABJAVCNFSM6AAAAABDVGHT7GVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDANRXGI3TAOJYGU>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
@tenedor LNSym's paused till July unfortunately, especially for such changes that have no precedence so far. We may still commit some code meanwhile, if and when we find some pockets of time. |
@shigoel okay, we'll keep our focus on Draper's ELF needs til you're back. Good luck with your other project! |
@tenedor Thank you so much, Daniel! |
Hi @gleachkr and @tenedor! You may have already received a notification for this, but thought I'd ping here just in case: I've opened a PR in ELFSage to bump its Lean toolchain, as a first step towards using ELFSage with LNSym. Thanks! |
Update: Another PR opened in ELFSage! |
Update: another minor PR opened. Thanks! |
PR bumping toolchain. |
Heya @gleachkr , gentle nudge on draperlaboratory/ELFSage#11 -- this fixes a stack overflow we witness from the latest ElfSage. |
Thanks for the nudge! I've been on vacation, but will be back as of this Monday. |
Hi @gleachkr! Minor ELFSage PR to bump Lean's toolchain: |
Hi again @gleachkr! Another PR to bump Lean's toolchain |
We need an ELF binary file parser in Lean, specifically for an Arm (Aarch64) machine, so that we can read in the program, data, and other relevant sections, and render them into a form suitable for use by LNSym. We intend to verify programs in LNSym that have been obtained directly from the ELF binary.
Here are some references that can come in useful when developing the ELF parser:
Has better information than Linux headers on Arm relocation types
Has better information than Linux headers on Arm relocation types
The text was updated successfully, but these errors were encountered: