tor

The Tor anonymity network
git clone https://git.dasho.dev/tor.git
Log | Files | Refs | README | LICENSE

commit eacaff6ccc8ea25859a1a9e14795bd4d4eac360f
parent a5ed62f96cafa1be251f9a7b4aafa519de4c2645
Author: Nick Mathewson <nickm@torproject.org>
Date:   Fri,  7 Sep 2018 08:46:41 -0400

Merge remote-tracking branch 'teor/bug27461-032' into maint-0.3.2

Diffstat:
Achanges/bug27461 | 5+++++
Msrc/or/main.c | 8++++++++
2 files changed, 13 insertions(+), 0 deletions(-)

diff --git a/changes/bug27461 b/changes/bug27461 @@ -0,0 +1,5 @@ + o Minor bugfixes (compilation): + - Stop calling SetProcessDEPPolicy() on 64-bit Windows. It is not + supported, and always fails. Some compilers warn about the function + pointer cast on 64-bit Windows. + Fixes bug 27461; bugfix on 0.2.2.23-alpha. diff --git a/src/or/main.c b/src/or/main.c @@ -3719,6 +3719,13 @@ tor_main(int argc, char *argv[]) #endif /* On heap corruption, just give up; don't try to play along. */ HeapSetInformation(NULL, HeapEnableTerminationOnCorruption, NULL, 0); + + /* SetProcessDEPPolicy is only supported on 32-bit Windows. + * (On 64-bit Windows it always fails, and some compilers don't like the + * PSETDEP cast.) + * 32-bit Windows defines _WIN32. + * 64-bit Windows defines _WIN32 and _WIN64. */ +#ifndef _WIN64 /* Call SetProcessDEPPolicy to permanently enable DEP. The function will not resolve on earlier versions of Windows, and failure is not dangerous. */ @@ -3732,6 +3739,7 @@ tor_main(int argc, char *argv[]) setdeppolicy(3); } } +#endif /* !defined(_WIN64) */ #endif /* defined(_WIN32) */ configure_backtrace_handler(get_version());