-
Notifications
You must be signed in to change notification settings - Fork 163
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: match imported functions to libraries? #363
Comments
Unlike e.g., PE or mach-o, elf binaries that "import" a symbol does not have an explicit mapping from symbol -> library providing it (the term for this in mach-o is "two-level namespaces" iirc). In other words the namespace for symbol lookup is "flat", and afaik, the dynamic linker will:
consequently, if you have two libraries, versym might be (abused) to implement something like two level namespaces in elf format, but it's mostly for versioning the same symbol within a particular shared library. it's possible to write such a function, but one would have to effectively implement symbol searching like a dynamic linker does. there isn't anything stopping the user from doing that, but it's probably outside the scope of goblin imho. |
You could perhaps use the GnuHash (although i see it's only constructor is unsafe) to do fast symbol lookups with: Line 199 in d7e8e29
in order to find which library exports a symbol that another library imports. There might be a better way to do this, I'm not sure, would have to dig into it :) |
It seems that the Elf parser has the functionality to get the libraries which the binary will get at runtime, via the
elf.libraries
Vec. After playing around with the library, it seems that theelf.dynstrtab
field has the functions from the various imported libraries. But how do you figure out which library is imported for each function?In Go, there's a function which returns an array of structs which have the function name and the library name, debug/elf/file.go:ImportedSymbols(). How could similar functionality be implemented using Goblin?
From trying to learn more about the Elf format, it seems that the
elf.versym
field might have the linking between the two, but I'm clearly missing something.I also don't know if this is what was being discussed in #282, since that issue doesn't mention anything about function names, but maybe there is some structure which connects versions, functions, and libraries. Again, I'm still learning about the nitty-gritty of ELFs, and yesterday was the first time I tried anything with Goblin.
Ultimately, I'd like to have a way to do import hashing for malware analysis with Rust in my MalwareDB project, which I had done previously in Go.
The text was updated successfully, but these errors were encountered: