Merge branch 'tor-gitlab/mr/568'
[tor.git] / src / lib / llharden / winprocess_sys.c
blobe8680e7ab817a2683134440a8129ef3d3328ce60
1 /* Copyright (c) 2018-2021, The Tor Project, Inc. */
2 /* See LICENSE for licensing information */
4 /**
5 * \file winprocess_sys.c
6 * \brief Subsystem object for windows process setup.
7 **/
9 #include "orconfig.h"
10 #include "lib/subsys/subsys.h"
11 #include "lib/llharden/winprocess_sys.h"
13 #include <stdbool.h>
14 #include <stddef.h>
16 #ifdef _WIN32
17 #include <windows.h>
19 #define WINPROCESS_SYS_ENABLED true
21 static int
22 subsys_winprocess_initialize(void)
24 #ifndef HeapEnableTerminationOnCorruption
25 #define HeapEnableTerminationOnCorruption 1
26 #endif
28 /* On heap corruption, just give up; don't try to play along. */
29 HeapSetInformation(NULL, HeapEnableTerminationOnCorruption, NULL, 0);
31 /* SetProcessDEPPolicy is only supported on 32-bit Windows.
32 * (On 64-bit Windows it always fails, and some compilers don't like the
33 * PSETDEP cast.)
34 * 32-bit Windows defines _WIN32.
35 * 64-bit Windows defines _WIN32 and _WIN64. */
36 #ifndef _WIN64
37 /* Call SetProcessDEPPolicy to permanently enable DEP.
38 The function will not resolve on earlier versions of Windows,
39 and failure is not dangerous. */
40 HMODULE hMod = GetModuleHandleA("Kernel32.dll");
41 if (hMod) {
42 typedef BOOL (WINAPI *PSETDEP)(DWORD);
43 PSETDEP setdeppolicy = (PSETDEP)GetProcAddress(hMod,
44 "SetProcessDEPPolicy");
45 if (setdeppolicy) {
46 /* PROCESS_DEP_ENABLE | PROCESS_DEP_DISABLE_ATL_THUNK_EMULATION */
47 setdeppolicy(3);
50 #endif /* !defined(_WIN64) */
52 return 0;
54 #else /* !defined(_WIN32) */
55 #define WINPROCESS_SYS_ENABLED false
56 #define subsys_winprocess_initialize NULL
57 #endif /* defined(_WIN32) */
59 const subsys_fns_t sys_winprocess = {
60 .name = "winprocess",
61 SUBSYS_DECLARE_LOCATION(),
62 /* HeapEnableTerminationOnCorruption and setdeppolicy() are security
63 * features, we want them to run first. */
64 .level = -100,
65 .supported = WINPROCESS_SYS_ENABLED,
66 .initialize = subsys_winprocess_initialize,