Skip to content
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

dlls #8

Open
heavenly opened this issue Dec 17, 2018 · 8 comments
Open

dlls #8

heavenly opened this issue Dec 17, 2018 · 8 comments

Comments

@heavenly
Copy link

does this work with dlls that are injected (i'm assuming probably yes because of the ability to attach to running projects, but I'm not sure).

@crosire
Copy link
Owner

crosire commented Dec 17, 2018

It does not work on code for which there are no symbols in the application PDB. These are used to determine function addresses etc. in the loaded image, so are a hard requirement.

blink does not currently load the PDBs for DLLs loaded by the application (it could do that though).

@shadowndacorner
Copy link

@crosire Any sort of guidance on how one might start on this? I've started dissecting the code a bit and think I understand the overall flow (though surely not the specifics - not nearly familiar enough with the Windows executable format for that), but I'm not totally sure where to begin in tracking changes to loaded DLL sources, especially those which are loaded at runtime (the use case I'm looking to support).

Thanks in advance!

@crosire
Copy link
Owner

crosire commented Apr 3, 2019

There are two ways DLLs can be loaded, either via a static import or dynamically via LoadLibrary.

The first case can be covered by retrieving the PDB info here:

const auto name = reinterpret_cast<const char *>(_image_base + import_directory_entries[i].Name);

Same way it is done for the main application (get a pointer to the PE header via GetModuleHandle and then just locate the PDB path and read the symbol information in the same way):
{ print("Reading PE debug info directory ...");

The second case would involve hooking the LoadLibrary functions and doing the same thing every time a new DLL was loaded.

@bsviglo
Copy link

bsviglo commented Apr 15, 2019

Has anyone tried to implement patching *.dlls loaded by main executable via static or dynamic import?

@crosire
Copy link
Owner

crosire commented Apr 15, 2019

Added an untested, experimental branch which loads symbols for statically linked DLLs: https://github.com/crosire/blink/tree/dlls

EDIT: This is now in master.

@bsviglo
Copy link

bsviglo commented Apr 16, 2019

@crosire, thanks. I'll give it a try soon.

@kimsama
Copy link

kimsama commented Apr 27, 2019

I have a host.exe app which loads a plugin DLL at runtime. No access to the source code of host.exe app but only have for DLL's. Is that also possible to use blink for this case? If it is, could you let me know how to use blink for that? Thanks in advance.

@crosire
Copy link
Owner

crosire commented Apr 28, 2019

blink does not currently support dynamically loaded DLLs.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants