Merge pull request #1552 from JoelLinn/fix-msc-flags

Fix MSC LTO, runtime, subsystem
This commit is contained in:
starkos 2020-11-10 08:36:32 -05:00 committed by GitHub
commit 4138c3e7b9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 76 additions and 6 deletions

View File

@ -28,6 +28,15 @@
-- Returns list of C compiler flags for a configuration. -- Returns list of C compiler flags for a configuration.
-- --
local function getRuntimeFlag(cfg, isstatic)
local rt = cfg.runtime
local flag = iif(isstatic, "/MT", "/MD")
if (rt == "Debug") or (rt == nil and config.isDebugBuild(cfg)) then
flag = flag .. "d"
end
return flag
end
msc.shared = { msc.shared = {
clr = { clr = {
On = "/clr", On = "/clr",
@ -37,6 +46,7 @@
}, },
flags = { flags = {
FatalCompileWarnings = "/WX", FatalCompileWarnings = "/WX",
LinkTimeOptimization = "/GL",
MultiProcessorCompile = "/MP", MultiProcessorCompile = "/MP",
NoMinimalRebuild = "/Gm-", NoMinimalRebuild = "/Gm-",
OmitDefaultLibrary = "/Zl" OmitDefaultLibrary = "/Zl"
@ -87,11 +97,11 @@
}, },
staticruntime = { staticruntime = {
-- this option must always be emit (does it??) -- this option must always be emit (does it??)
_ = function(cfg) return iif(config.isDebugBuild(cfg), "/MDd", "/MD") end, _ = function(cfg) return getRuntimeFlag(cfg, false) end,
-- runtime defaults to dynamic in VS -- runtime defaults to dynamic in VS
Default = function(cfg) return iif(config.isDebugBuild(cfg), "/MDd", "/MD") end, Default = function(cfg) return getRuntimeFlag(cfg, false) end,
On = function(cfg) return iif(config.isDebugBuild(cfg), "/MTd", "/MT") end, On = function(cfg) return getRuntimeFlag(cfg, true) end,
Off = function(cfg) return iif(config.isDebugBuild(cfg), "/MDd", "/MD") end, Off = function(cfg) return getRuntimeFlag(cfg, false) end,
}, },
stringpooling = { stringpooling = {
On = "/GF", On = "/GF",
@ -239,13 +249,14 @@
msc.linkerFlags = { msc.linkerFlags = {
flags = { flags = {
FatalLinkWarnings = "/WX", FatalLinkWarnings = "/WX",
LinkTimeOptimization = "/GL", LinkTimeOptimization = "/LTCG",
NoIncrementalLink = "/INCREMENTAL:NO", NoIncrementalLink = "/INCREMENTAL:NO",
NoManifest = "/MANIFEST:NO", NoManifest = "/MANIFEST:NO",
OmitDefaultLibrary = "/NODEFAULTLIB", OmitDefaultLibrary = "/NODEFAULTLIB",
}, },
kind = { kind = {
SharedLib = "/DLL", SharedLib = "/DLL",
WindowedApp = "/SUBSYSTEM:WINDOWS"
}, },
symbols = { symbols = {
On = "/DEBUG" On = "/DEBUG"

View File

@ -84,10 +84,16 @@
test.excludes("/Oy", msc.getcflags(cfg)) test.excludes("/Oy", msc.getcflags(cfg))
end end
function suite.cflags_onLinkTimeOptimizations()
flags "LinkTimeOptimization"
prepare()
test.contains("/GL", msc.getcflags(cfg))
end
function suite.ldflags_onLinkTimeOptimizations() function suite.ldflags_onLinkTimeOptimizations()
flags "LinkTimeOptimization" flags "LinkTimeOptimization"
prepare() prepare()
test.contains("/GL", msc.getldflags(cfg)) test.contains("/LTCG", msc.getldflags(cfg))
end end
function suite.cflags_onStringPoolingOn() function suite.cflags_onStringPoolingOn()
@ -512,3 +518,56 @@
prepare() prepare()
test.isequal({ "/WX", "/MD", "/EHsc" }, msc.getcxxflags(cfg)) test.isequal({ "/WX", "/MD", "/EHsc" }, msc.getcxxflags(cfg))
end end
--
-- Check handling of Run-Time Library flags.
--
function suite.cflags_onStaticRuntime()
staticruntime "On"
prepare()
test.isequal({ "/MT" }, msc.getcflags(cfg))
end
function suite.cflags_onDynamicRuntime()
staticruntime "Off"
prepare()
test.isequal({ "/MD" }, msc.getcflags(cfg))
end
function suite.cflags_onStaticRuntimeAndDebug()
staticruntime "On"
runtime "Debug"
prepare()
test.isequal({ "/MTd" }, msc.getcflags(cfg))
end
function suite.cflags_onDynamicRuntimeAndDebug()
staticruntime "Off"
runtime "Debug"
prepare()
test.isequal({ "/MDd" }, msc.getcflags(cfg))
end
function suite.cflags_onStaticRuntimeAndSymbols()
staticruntime "On"
symbols "On"
prepare()
test.isequal({ "/MTd", "/Z7" }, msc.getcflags(cfg))
end
function suite.cflags_onDynamicRuntimeAndSymbols()
staticruntime "Off"
symbols "On"
prepare()
test.isequal({ "/MDd", "/Z7" }, msc.getcflags(cfg))
end
function suite.cflags_onDynamicRuntimeAndReleaseAndSymbols()
staticruntime "Off"
runtime "Release"
symbols "On"
prepare()
test.isequal({ "/MD", "/Z7" }, msc.getcflags(cfg))
end