build: Enable control flow guard on Windows
authorSlawomir Cygan <slawomir.cygan@intel.com>
Wed, 14 Jun 2017 17:15:31 +0000 (19:15 +0200)
committerLenny Komow <lenny@lunarg.com>
Tue, 27 Jun 2017 17:03:12 +0000 (11:03 -0600)
This enables the 'Control Flow Guard' security feature, which
prevents memory corruption vulnerabilites by placing a restriction
on where application can execute from.

The change is applied to both VulkanRT and it's NSIS installer.

WARN:  This change requires re-patching and rebuillding NSIS with
attached patch.
WARN#2: This change requires Visual Studion 2015 or vs140 toolset to
take effect.

Control Flow Guard documentation:
https://msdn.microsoft.com/en-us/library/windows/desktop/mt637065(v=vs.85).aspx

Change-Id: I7683c0570087d994961c79fb64419509f83536a8

CMakeLists.txt
windowsRuntimeInstaller/ConfigureRT.vcxproj
windowsRuntimeInstaller/NSIS_Security.patch
windowsRuntimeInstaller/README.txt

index b4b7d54f0a2f75e7d89b964f54f844ff77bbb45f..ce10e9cd44d4d260f7efe53f7eeea725b4ebd667 100644 (file)
@@ -77,6 +77,14 @@ if(WIN32)
     # Warn about potentially uninitialized variables
     add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/w34701>")
     add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/w34703>")
+
+    if (NOT MSVC_VERSION LESS 1900)
+        # Enable control flow guard
+        message(STATUS "Building with control flow guard")
+        add_compile_options("$<$<CXX_COMPILER_ID:MSVC>:/guard:cf>")
+        set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /guard:cf")
+        set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /guard:cf")
+    endif()
 endif()
 
 if(NOT WIN32)
index 2627b1799f1efb147baa94be0ad2e48952a50a2b..a7181a0c117ba9a3e2a869d92822850714cf34bf 100644 (file)
@@ -1,5 +1,5 @@
 <?xml version="1.0" encoding="utf-8"?>\r
-<Project DefaultTargets="Build" ToolsVersion="12.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">\r
+<Project DefaultTargets="Build" ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">\r
   <ItemGroup Label="ProjectConfigurations">\r
     <ProjectConfiguration Include="Debug|Win32">\r
       <Configuration>Debug</Configuration>\r
   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">\r
     <ConfigurationType>Application</ConfigurationType>\r
     <UseDebugLibraries>true</UseDebugLibraries>\r
-    <PlatformToolset>v120</PlatformToolset>\r
+    <PlatformToolset>v140</PlatformToolset>\r
     <CharacterSet>MultiByte</CharacterSet>\r
   </PropertyGroup>\r
   <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">\r
     <ConfigurationType>Application</ConfigurationType>\r
     <UseDebugLibraries>false</UseDebugLibraries>\r
-    <PlatformToolset>v120</PlatformToolset>\r
+    <PlatformToolset>v140</PlatformToolset>\r
     <WholeProgramOptimization>true</WholeProgramOptimization>\r
     <CharacterSet>MultiByte</CharacterSet>\r
   </PropertyGroup>\r
@@ -45,6 +45,7 @@
       <Optimization>Disabled</Optimization>\r
       <SDLCheck>false</SDLCheck>\r
       <RuntimeLibrary>MultiThreadedDebug</RuntimeLibrary>\r
+      <ControlFlowGuard>Guard</ControlFlowGuard>\r
     </ClCompile>\r
     <Link>\r
       <GenerateDebugInformation>true</GenerateDebugInformation>\r
@@ -60,6 +61,7 @@
       <IntrinsicFunctions>true</IntrinsicFunctions>\r
       <SDLCheck>false</SDLCheck>\r
       <RuntimeLibrary>MultiThreaded</RuntimeLibrary>\r
+      <ControlFlowGuard>Guard</ControlFlowGuard>\r
     </ClCompile>\r
     <Link>\r
       <GenerateDebugInformation>true</GenerateDebugInformation>\r
index 87bf7e6bf93dc74d76f9a1bb01dccdd051856f59..b275aae0a2de30692693cd3eafac75d2805675a0 100644 (file)
@@ -20,7 +20,18 @@ index 32d3d33..d2c4d25 100644
        defenv.Append(CPPDEFINES = ['_CRT_SECURE_NO_WARNINGS', '_CRT_NONSTDC_NO_WARNINGS', '_CRT_SECURE_NO_DEPRECATE', '_CRT_NON_CONFORMING_SWPRINTFS'])
        defenv['MSVCRT_FLAG'] = '/MT' # Avoid msvcr?0.dll dependency
  else:
-@@ -143,9 +143,9 @@ stub_env.Append(CCFLAGS = ['/Fa${TARGET}.lst'])    # listing file name
+@@ -43,6 +43,10 @@ if msvs_version >= 11.0:
+       defenv['SUBSYS_CON'] = '/subsystem:console,5.01' # support windows xp
+       defenv['SUBSYS_WIN'] = '/subsystem:windows,5.01' # support windows xp
++if msvs_version >= 14.0:
++      defenv.Append(CCFLAGS = ['/guard:cf'])
++      defenv.Append(LINKFLAGS = ['/guard:cf'])
++
+ ### defines
+ defenv.Append(CPPDEFINES = [('NSISCALL', '$STDCALL')])
+@@ -143,9 +147,9 @@ stub_env.Append(CCFLAGS = ['/Fa${TARGET}.lst'])    # listing file name
  stub_env.Append(LINKFLAGS = ['$NODEFLIBS_FLAG'])   # no default libraries
  stub_env.Append(LINKFLAGS = ['$MAP_FLAG'])         # generate map file
  
index 2653414d26f3e095167d517d759816fcd0eb43fe..c9863322bb3d5e063f15e502f429dd38fc74d90e 100644 (file)
@@ -21,9 +21,10 @@ To build the Vulkan Runtime Installer:
        Instructions for building NSIS are available at\r
        http://nsis//sourceforge.net/Docs/AppendixG.html.\r
 \r
-       The security changes to NSIS involve adding the /DYMANICBASE and /GS options\r
-       to the NSIS compile/link steps, so that the Runtime Installer and Uninstaller\r
-       are built with address space layout randomization and buffer overrun checks.\r
+       The security changes to NSIS involve adding the /DYMANICBASE, /GS and\r
+       /guard:cf options to the NSIS compile/link steps, so that the Runtime\r
+       Installer and Uninstaller are built with address space layout randomization,\r
+       buffer overrun checks and control flow guard.\r
 \r
        The security changes to NSIS can be made by applying the patch in the\r
        NSIS_Security.patch file in this folder.\r