Merge pull request #1109 from xq114/dev

update llvm
pull/1115/head
ruki 3 years ago committed by GitHub
commit 3eb4d9790d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 101
      packages/l/llvm/xmake.lua
  2. 6
      packages/o/openssl/xmake.lua

@ -4,68 +4,66 @@ package("llvm")
set_homepage("https://llvm.org/") set_homepage("https://llvm.org/")
set_description("The LLVM Compiler Infrastructure") set_description("The LLVM Compiler Infrastructure")
if is_host("macosx") then if is_host("windows") then
if os.arch() == "x86_64" then if os.arch() == "x86" then
set_urls("https://github.com/xmake-mirror/llvm-windows/releases/download/$(version)/clang+llvm-$(version)-win32.zip")
add_versions("11.0.0", "268043ae0b656cf6272ccb9b8e3f21f51170b74ed8997ddc0b99587983b821ca")
add_versions("14.0.0", "63afc3c472cb279978c5a7efc25b8783a700aeb416df67886b7057eba52a8742")
else
set_urls("https://github.com/xmake-mirror/llvm-windows/releases/download/$(version)/clang+llvm-$(version)-win64.zip")
add_versions("11.0.0", "db5b3a44f8f784ebc71f716b54eb63c0d8d21aead12449f36291ab00820271c7")
add_versions("14.0.0", "c1e1ddf11aa73c58073956d9217086550544328ed5e6ec64c1a709badb231711")
end
elseif is_host("macosx") and os.arch() == "x86_64" then
set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-x86_64-apple-darwin.tar.xz") set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-x86_64-apple-darwin.tar.xz")
add_versions("11.0.0", "b93886ab0025cbbdbb08b46e5e403a462b0ce034811c929e96ed66c2b07fe63a") add_versions("11.0.0", "b93886ab0025cbbdbb08b46e5e403a462b0ce034811c929e96ed66c2b07fe63a")
end add_versions("14.0.0", "cf5af0f32d78dcf4413ef6966abbfd5b1445fe80bba57f2ff8a08f77e672b9b3")
elseif is_host("bsd") then elseif is_host("bsd") then
if os.arch() == "x86_64" then if os.arch() == "x86_64" then
set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-amd64-unknown-freebsd11.tar.xz") set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-amd64-unknown-freebsd13.tar.xz")
add_versions("11.0.0", "3a3bcac4da7d1ed431fef469fe52ccf9a525016d6900718a447986c7ab850d45") add_versions("14.0.0", "b68d73fd57be385e7f06046a87381f7520c8861f492c294e6301d2843d9a1f57")
elseif os.arch() == "i386" then elseif os.arch() == "i386" then
set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-i386-unknown-freebsd11.tar.xz") set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-i386-unknown-freebsd13.tar.xz")
add_versions("11.0.0", "649ae62e8b85cd44b872678b118c8cbc75e2e29d94d995fddd9149fc6c3a4040") add_versions("14.0.0", "81f49eb466ce9149335ac8918a5f02fa724d562a94464ed13745db0165b4a220")
end end
elseif is_host("windows") then
if os.arch() == "x86" then
set_urls("https://github.com/xmake-mirror/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-win32.tar.xz")
add_versions("11.0.0", "fd7f3862e6d2a7ed1855e4692702f60d0f49c04514202c8b1d6659ce1872ecb9")
else
set_urls("https://github.com/xmake-mirror/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-win64.tar.xz")
add_versions("11.0.0", "de2dce781b70a66c28b389905ae825998b18b33b7b1e3e94f947a2ec57fb328d")
end
elseif is_host("linux") then
if linuxos.name() == "ubuntu" and linuxos.version():eq("20.04") and os.arch() == "x86_64" then
set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/clang+llvm-$(version)-x86_64-linux-gnu-ubuntu-20.04.tar.xz")
add_versions("11.0.0", "829f5fb0ebda1d8716464394f97d5475d465ddc7bea2879c0601316b611ff6db")
else else
set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/llvm-project-$(version).tar.xz") set_urls("https://github.com/llvm/llvm-project/releases/download/llvmorg-$(version)/llvm-project-$(version).src.tar.xz")
add_versions("11.0.0", "b7b639fc675fa1c86dd6d0bc32267be9eb34451748d2efd03f674b773000e92b") add_versions("11.0.0", "b7b639fc675fa1c86dd6d0bc32267be9eb34451748d2efd03f674b773000e92b")
end add_versions("14.0.0", "35ce9edbc8f774fe07c8f4acdf89ec8ac695c8016c165dd86b8d10e7cba07e23")
end end
add_configs("all", {description = "Enable all projects.", default = false, type = "boolean"})
add_configs("bolt", {description = "Enable bolt project.", default = false, type = "boolean"})
add_configs("clang", {description = "Enable clang project.", default = true, type = "boolean"}) add_configs("clang", {description = "Enable clang project.", default = true, type = "boolean"})
add_configs("clang-tools-extra", {description = "Enable extra clang tools project.", default = false, type = "boolean"}) add_configs("clang-tools-extra", {description = "Enable extra clang tools project.", default = false, type = "boolean"})
add_configs("libclc", {description = "Enable libclc project.", default = false, type = "boolean"})
add_configs("lld", {description = "Enable lld project.", default = false, type = "boolean"}) add_configs("lld", {description = "Enable lld project.", default = false, type = "boolean"})
add_configs("lldb", {description = "Enable lldb project.", default = false, type = "boolean"}) add_configs("lldb", {description = "Enable lldb project.", default = false, type = "boolean"})
add_configs("openmp", {description = "Enable openmp project.", default = false, type = "boolean"})
add_configs("polly", {description = "Enable polly project.", default = false, type = "boolean"}) add_configs("polly", {description = "Enable polly project.", default = false, type = "boolean"})
add_configs("pstl", {description = "Enable pstl project.", default = false, type = "boolean"})
add_configs("mlir", {description = "Enable mlir project.", default = false, type = "boolean"}) add_configs("mlir", {description = "Enable mlir project.", default = false, type = "boolean"})
add_configs("flang", {description = "Enable flang project.", default = false, type = "boolean"})
add_configs("compiler-rt", {description = "Enable compiler-rt project.", default = true, type = "boolean"})
add_configs("compiler-rt", {description = "Enable compiler-rt runtime.", default = true, type = "boolean"})
add_configs("libunwind", {description = "Enable libunwind runtime.", default = true, type = "boolean"}) add_configs("libunwind", {description = "Enable libunwind runtime.", default = true, type = "boolean"})
add_configs("libcxxabi", {description = "Enable clang runtime.", default = true, type = "boolean"}) add_configs("libc", {description = "Enable libc runtime.", default = false, type = "boolean"})
add_configs("libcxx", {description = "Enable libcxx runtime.", default = true, type = "boolean"})
add_configs("libcxxabi", {description = "Enable libcxxabi runtime.", default = true, type = "boolean"})
add_configs("openmp", {description = "Enable openmp runtime.", default = false, type = "boolean"})
if is_host("linux") then if is_host("linux") then
if linuxos.name() == "ubuntu" and linuxos.version():eq("20.04") and os.arch() == "x86_64" then
-- use binary directly
else
add_deps("cmake") add_deps("cmake")
add_deps("libffi", {host = true}) add_deps("python 3.x", {kind = "binary", host = true})
add_deps("zlib", "libffi", {host = true})
add_deps("binutils", {host = true}) -- needed for gold and strip add_deps("binutils", {host = true}) -- needed for gold and strip
end end
end
on_load("@linux", function (package) on_load("@linux", "@bsd", function (package)
if linuxos.name() == "ubuntu" and linuxos.version():eq("20.04") and os.arch() == "x86_64" then if package:config("openmp") then
return
elseif package:config("openmp") then
package:add("deps", "libelf", {host = true}) package:add("deps", "libelf", {host = true})
end end
end) end)
if on_fetch then
on_fetch(function (package, opt) on_fetch(function (package, opt)
if opt.system then if opt.system then
local version = try {function() return os.iorunv("llvm-config --version") end} local version = try {function() return os.iorunv("llvm-config --version") end}
@ -74,37 +72,41 @@ package("llvm")
end end
end end
end) end)
end
on_install("@macosx", "@windows", "@msys", "@bsd", function (package) on_install("@macosx|x86_64", "@windows", "@msys", "@bsd", function (package)
os.cp("*", package:installdir()) os.cp("*", package:installdir())
end) end)
on_install("@linux", function (package) on_install("@linux", function (package)
if linuxos.name() == "ubuntu" and linuxos.version():eq("20.04") and os.arch() == "x86_64" then
os.cp("*", package:installdir())
return
end
local projects = { local projects = {
"bolt",
"clang", "clang",
"clang-tools-extra", "clang-tools-extra",
"libclc",
"lld", "lld",
"lldb", "lldb",
"openmp", "openmp",
"polly", "polly",
"pstl",
"mlir", "mlir",
"flang",
"compiler-rt",
"openmp"
} }
local projects_enabled = {} local projects_enabled = {}
if package:config("all") then
table.insert(projects_enabled, "all")
else
for _, project in ipairs(projects) do for _, project in ipairs(projects) do
if package:config(project) then if package:config(project) then
table.insert(projects_enabled, project) table.insert(projects_enabled, project)
end end
end end
end
local runtimes = { local runtimes = {
"compiler-rt", "libc",
"libunwind", "libunwind",
"libcxx",
"libcxxabi" "libcxxabi"
} }
local runtimes_enabled = {} local runtimes_enabled = {}
@ -135,17 +137,14 @@ package("llvm")
"-DLLDB_ENABLE_PYTHON=OFF", "-DLLDB_ENABLE_PYTHON=OFF",
"-DLLDB_ENABLE_LUA=OFF", "-DLLDB_ENABLE_LUA=OFF",
"-DLLDB_ENABLE_LZMA=OFF", "-DLLDB_ENABLE_LZMA=OFF",
"-DLIBOMP_INSTALL_ALIASES=OFF", "-DLIBOMP_INSTALL_ALIASES=OFF"
"-DCLANG_PYTHON_BINDINGS_VERSIONS=#{py_ver}"
} }
if package:is_plat("macosx") then table.insert(configs, "-DLLVM_CREATE_XCODE_TOOLCHAIN=" .. (package:is_plat("macosx") and "ON" or "OFF")) -- TODO
table.insert(configs, "-DLLVM_BUILD_LLVM_C_DYLIB=ON") table.insert(configs, "-DLLVM_BUILD_LLVM_C_DYLIB=" .. (package:is_plat("macosx") and "ON" or "OFF"))
if package:has_tool("cxx", "clang", "clangxx") then
table.insert(configs, "-DLLVM_ENABLE_LIBCXX=ON") table.insert(configs, "-DLLVM_ENABLE_LIBCXX=ON")
table.insert(configs, "-DLLVM_CREATE_XCODE_TOOLCHAIN=ON") -- TODO
else else
table.insert(configs, "-DLLVM_BUILD_LLVM_C_DYLIB=OFF")
table.insert(configs, "-DLLVM_ENABLE_LIBCXX=OFF") table.insert(configs, "-DLLVM_ENABLE_LIBCXX=OFF")
table.insert(configs, "-DLLVM_CREATE_XCODE_TOOLCHAIN=OFF")
table.insert(configs, "-DCLANG_DEFAULT_CXX_STDLIB=libstdc++") table.insert(configs, "-DCLANG_DEFAULT_CXX_STDLIB=libstdc++")
-- enable llvm gold plugin for LTO -- enable llvm gold plugin for LTO
table.insert(configs, "-DLLVM_BINUTILS_INCDIR=" .. package:dep("binutils"):installdir("include")) table.insert(configs, "-DLLVM_BINUTILS_INCDIR=" .. package:dep("binutils"):installdir("include"))
@ -155,7 +154,7 @@ package("llvm")
end) end)
on_test(function (package) on_test(function (package)
if not package:is_plat("windows", "mingw") then if not is_host("windows") then
os.vrun("llvm-config --version") os.vrun("llvm-config --version")
end end
if package:config("clang") then if package:config("clang") then

@ -14,10 +14,6 @@ package("openssl")
add_versions("1.0.2u", "493f8b34574d0cf8598adbdec33c84b8a06f0617787c3710d20827c01291c09c") add_versions("1.0.2u", "493f8b34574d0cf8598adbdec33c84b8a06f0617787c3710d20827c01291c09c")
add_versions("1.0.0", "9b67e5ad1a4234c1170ada75b66321e914da4f3ebaeaef6b28400173aaa6b378") add_versions("1.0.0", "9b67e5ad1a4234c1170ada75b66321e914da4f3ebaeaef6b28400173aaa6b378")
if is_plat("linux") then
add_syslinks("pthread")
end
on_fetch("fetch") on_fetch("fetch")
on_load(function (package) on_load(function (package)
@ -37,7 +33,7 @@ package("openssl")
if package:is_plat("windows", "mingw") then if package:is_plat("windows", "mingw") then
package:add("syslinks", "ws2_32", "user32", "crypt32", "advapi32") package:add("syslinks", "ws2_32", "user32", "crypt32", "advapi32")
elseif package:is_plat("linux", "cross") then elseif package:is_plat("linux", "cross") then
package:add("syslinks", "dl") package:add("syslinks", "pthread", "dl")
end end
if package:is_plat("linux") then if package:is_plat("linux") then
package:add("extsources", "apt::libssl-dev") package:add("extsources", "apt::libssl-dev")

Loading…
Cancel
Save