[gn build] Use lld-link's new /winsysroot: flag

If `clang_base_path` is set, it must now point to a directory that contains
an lld-link built with D118070.

(If this is a problem for anyone, we can guard this behind a
lld_link_understands_winsysroot gn arg, but let's see if we can get away
without that for now.)

With this, it's possible to build everything in a normal cmd.exe Window,
an MSVC shell isn't needed \o/

(Assuming you set `clang_base_path`, and you set `sysroot` to a directory
that contains a win sysroot. If you have MSVC installed,
`python3 llvm\utils\sysroot.py make-fake --out-dir=my-sysroot` and
setting `sysroot = "//my-sysroot"` in args.gn works, for example.)

Differential Revision: https://reviews.llvm.org/D121871
This commit is contained in:
Nico Weber 2022-03-21 13:42:28 -04:00
parent 7678e8ebbb
commit 312ec6f156
1 changed files with 6 additions and 0 deletions

View File

@ -297,6 +297,12 @@ config("compiler_defaults") {
if (current_os == "win") {
assert(is_clang, "sysroot only works with clang-cl as host compiler")
cflags += [ "/winsysroot" + rebase_path(sysroot, root_build_dir) ]
if (use_lld) {
ldflags += [ "/winsysroot:" + rebase_path(sysroot, root_build_dir) ]
# FIXME: Remove once PR54409 is fixed.
ldflags += [ "/machine:x64" ]
}
} else if (current_os != "ios" && current_os != "mac" &&
current_os != "android") {
cflags += [ "--sysroot=" + rebase_path(sysroot, root_build_dir) ]