Merge pull request #1854 from Kelimion/dll-entry-point

Add runtime.dll_forward_reason for Windows DLLs.
This commit is contained in:
Jeroen van Rijn
2022-06-21 18:02:47 +02:00
committed by GitHub
2 changed files with 22 additions and 5 deletions

View File

@@ -267,6 +267,19 @@ type_table: []Type_Info
args__: []cstring
when ODIN_OS == .Windows {
// NOTE(Jeroen): If we're a Windows DLL, fwdReason will be populated.
// This tells a DLL if it's first loaded, about to be unloaded, or a thread is joining/exiting.
DLL_Forward_Reason :: enum u32 {
Process_Detach = 0, // About to unload DLL
Process_Attach = 1, // Entry point
Thread_Attach = 2,
Thread_Detach = 3,
}
dll_forward_reason: DLL_Forward_Reason
}
// IMPORTANT NOTE(bill): Must be in this order (as the compiler relies upon it)

View File

@@ -8,15 +8,19 @@ when ODIN_BUILD_MODE == .Dynamic {
@(link_name="DllMain", linkage="strong", require)
DllMain :: proc "stdcall" (hinstDLL: rawptr, fdwReason: u32, lpReserved: rawptr) -> b32 {
context = default_context()
switch fdwReason {
case 1: // DLL_PROCESS_ATTACH
// Populate Windows DLL-specific global
dll_forward_reason = DLL_Forward_Reason(fdwReason)
switch dll_forward_reason {
case .Process_Attach:
#force_no_inline _startup_runtime()
intrinsics.__entry_point()
case 0: // DLL_PROCESS_DETACH
case .Process_Detach:
#force_no_inline _cleanup_runtime()
case 2: // DLL_THREAD_ATTACH
case .Thread_Attach:
break
case 3: // DLL_THREAD_DETACH
case .Thread_Detach:
break
}
return true