| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
|
| |
After this change there is no usage of of CRT library function. This allows
to build CRT-neutral variant of libdl.dll library, which can be used in any
application.
|
|
|
|
|
|
|
|
|
|
|
| |
in release mode
In debug mode is still used malloc() and free() for as part of memory leak
testing done by _CRTDBG_MAP_ALLOC and _CrtDumpMemoryLeaks() in test.c.
This change allows to wrap CRT's malloc() via dlsym's RTLD_NEXT.
See #112
|
|
|
|
|
|
| |
* Remove unused include stdio.h
* Add used include string.h
* Add reason comments for includes
|
|
|
|
|
|
|
| |
This is undefined in C and also C++. Both gcc and msvc allows to cast
between two incompatible function pointers without triggering warnings
transitionally via void(*)(void) function pointer. Replace transitional
LPVOID cast by void(*)(void) cast.
|
|
|
|
| |
signedness: ‘int’ and ‘DWORD’ {aka ‘long unsigned int’}
|
|
|
|
| |
loss of data
|
|
|
|
|
| |
It follows compile warning C4164: '_ReturnAddress' : intrinsic function not declared
Declaration can be included also via intrin.h header file.
|
|
|
|
|
| |
When compiling in C++ mode, it is required to have C declaration for
_alloca. Declaration can be included also via malloc.h header file.
|
|
|
|
| |
Add missing casts which are required in C++.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Returned structure is valid only if the function return value is same as
the size of the structure. So check for the correct size, not just for the
non-zero size.
"AllocationProtect" member contains the initial protection, valid at the
time when VirtualAlloc() was called. "Protect" member contains the current
protection of the requested address, valid at the time when VirtualQuery()
was called. So is_valid_address() function has to check "Protect" member,
not the "AllocationProtect".
If "State" member is MEM_FREE or MEM_RESERVE then "Protect" member is
undefined. So check "State" member before "Protect" member.
|
| |
|
| |
|
|
|
|
|
|
|
|
|
| |
Do not expect that non-ARM code is automatically X86 code as it does not
have to be. Returns failure (not thunk) in other case.
Make sure that windows test code is not called on non-windows platforms.
Test code tests/test-dladdr.c is written to be validated on any platforms,
including non-windows.
|
| |
|
|
|
|
|
| |
dlopen(NULL, ...) does not call LoadLibrary(), so do not call FreeLibrary()
in dlclose() for this case.
|
|
|
|
| |
Number is stored in NumberOfRvaAndSizes and it may be less than IMAGE_NUMBEROF_DIRECTORY_ENTRIES.
|
|
|
|
|
| |
First NT SDK available in the first 32-bit MSVC NT compiler does not
provide some defines. Add them for compatibility.
|
|
|
|
|
| |
Old pre-4.0 MSVC does not support _ReturnAddress() intrinsic. Provide for
it simple implementation via inline assembly.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Do not use SIZE_T which is not defined in older SDK. There is only size_t
type, so use it instead.
Do not use IMAGE_DIRECTORY_ENTRY_COM_DESCRIPTOR which is not defined in
older SDK. Use IMAGE_NUMBEROF_DIRECTORY_ENTRIES macro for checking if
directory index is valid. In all SDKs is DataDirectory[] array size defined
from IMAGE_NUMBEROF_DIRECTORY_ENTRIES macro.
Cast members in IMAGE_EXPORT_DIRECTORY and IMAGE_DIRECTORY_ENTRY_IMPORT to
DWORD as in older SDK they are defined as PDWORD and compiler throws error
'cannot add two pointers'.
|
| |
|
| |
|
| |
|
|
|
|
|
|
|
| |
process-global function SetErrorMode()
Use GetProcAddress() wrapper as SetThreadErrorMode() is not available on
older Windows versions.
|
|
|
|
|
|
| |
‘FARPROC’
warning: cast between incompatible function types from ‘FARPROC’ {aka ‘long long int (*)()’} to ‘BOOL (*)(DWORD, const CHAR *, struct HINSTANCE__ **)’ {aka ‘int (*)(long unsigned int, const char *, struct HINSTANCE__ **)’} [-Wcast-function-type]
|
|
|
|
|
| |
on unix the addr argument seems to be const
fix that for consistency
|
|
|
|
|
|
| |
Visual Studio 6.0 does not support __declspec(noinline) and throw error.
Add checks for compilers which support noinline to prevent compile errors.
|
|
|
|
|
|
| |
If compiling with _WIN32_WINNT target prior 0x0500 then SDK does not define
ULONG_PTR type. Such systems are only 32bit so define it explicitly to
32bit type ULONG.
|
|
|
|
| |
'ULONG_PTR' to 'char', possible loss of data
|
|
|
|
|
|
|
|
|
|
| |
This function implements calling GetModuleHandleExA() with correct flags to
retrieve hModule from passed address.
To allow compilation also with older compilers and environments (like WDK)
with any _WIN32_WINNT value, retrieve pointer to this function via
GetProcAddress(). And as a fallback implementation use old code via
VirtualQuery() which was there prior commit 8ec5ffef2eca.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
Call SetErrorMode(SEM_FAILCRITICALERRORS) prior opening Psapi.dll library
to avoid GUI error messages.
Close Psapi.dll library via FreeLibrary() if symbol was not retrieved to
prevent possible memory leaks.
Try to get K32EnumProcessModules symbol from Kernel32.dll library as it is
preferred way how to call EnumProcessModules() on Windows 7 and newer
versions.
If retrieving EnumProcessModules symbol failed with both methods then do
not try it again on next MyEnumProcessModules() function call.
|
|
|
|
|
|
| |
There is no need for propagating internal errors via SetLastError() and
GetLastError() calls. Just use additional argument for save_err_str()
function. Also dlfcn API is POSIX and does not use GetLastError().
|
| |
|
| |
|
|
|
|
| |
is_valid_address() already rejects NULL addresses, so there is no need to check address for NULL.
|
|
|
|
|
|
| |
It is not required as import table can use only symbols which are exported
and therefore are in export table. So if symbol is not found in export
table it cannot be in import table.
|
|
|
|
|
|
| |
export and import tables
dladdr tests for Windows now should always pass like on other systems.
|
| |
|
|
|
|
|
|
|
|
| |
sprintf() is marked by MSVC as unsafe and suppressing compile warning does
not work. It is still generated on AppVeyor. So rewrite code for converting
pointer number to string via open coded for-loop and do not use unsafe
sprintf() function anymore. New code correctly handles both 32bit and 64bit
variants and does not use any #ifdef _MSC_VER anymore.
|
|
|