summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authorHarmen Stoppels <harmenstoppels@gmail.com>2023-01-26 10:28:26 +0100
committerGitHub <noreply@github.com>2023-01-26 10:28:26 +0100
commitc329f7de33ad14af5bafaf57d3a0d581cc7b6cfe (patch)
tree7769870d21f75f03af256148dc1ffbb091da9c51 /var
parentf686a90779354f1a670c7774a3335473043a5e36 (diff)
downloadspack-c329f7de33ad14af5bafaf57d3a0d581cc7b6cfe.tar.gz
spack-c329f7de33ad14af5bafaf57d3a0d581cc7b6cfe.tar.bz2
spack-c329f7de33ad14af5bafaf57d3a0d581cc7b6cfe.tar.xz
spack-c329f7de33ad14af5bafaf57d3a0d581cc7b6cfe.zip
binutils: v2.30, 2.39, 2.40 (#35128)
- Add `binutils +pgo` - Add dejagnu build dep and fix its deps - Default to -O3 -g0 when using gcc/clang to make binutils faster and smaller
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/binutils/package.py76
-rw-r--r--var/spack/repos/builtin/packages/dejagnu/package.py4
2 files changed, 61 insertions, 19 deletions
diff --git a/var/spack/repos/builtin/packages/binutils/package.py b/var/spack/repos/builtin/packages/binutils/package.py
index 6bc2ae9e15..c5a66427f6 100644
--- a/var/spack/repos/builtin/packages/binutils/package.py
+++ b/var/spack/repos/builtin/packages/binutils/package.py
@@ -20,6 +20,8 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
executables = ["^nm$", "^readelf$"]
+ version("2.40", sha256="f8298eb153a4b37d112e945aa5cb2850040bcf26a3ea65b5a715c83afe05e48a")
+ version("2.39", sha256="da24a84fef220102dd24042df06fdea851c2614a5377f86effa28f33b7b16148")
version("2.38", sha256="070ec71cf077a6a58e0b959f05a09a35015378c2d8a51e90f3aeabfe30590ef8")
version("2.37", sha256="67fc1a4030d08ee877a4867d3dcab35828148f87e1fd05da6db585ed5a166bd4")
version("2.36.1", sha256="5b4bd2e79e30ce8db0abd76dd2c2eae14a94ce212cfc59d3c37d23e24bc6d7a3")
@@ -30,6 +32,7 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
version("2.33.1", sha256="0cb4843da15a65a953907c96bad658283f3c4419d6bcc56bf2789db16306adb2")
version("2.32", sha256="de38b15c902eb2725eac6af21183a5f34ea4634cb0bcef19612b50e5ed31072d")
version("2.31.1", sha256="ffcc382695bf947da6135e7436b8ed52d991cf270db897190f19d6f9838564d0")
+ version("2.30", sha256="efeade848067e9a03f1918b1da0d37aaffa0b0127a06b5e9236229851d9d0c09")
version("2.29.1", sha256="1509dff41369fb70aed23682351b663b56db894034773e6dbf7d5d6071fc55cc")
version("2.28", sha256="6297433ee120b11b4b0a1c8f3512d7d73501753142ab9e2daa13c5a3edd32a72")
version("2.27", sha256="369737ce51587f92466041a97ab7d2358c6d9e1b6490b3940eb09fb0a9a6ac88")
@@ -45,9 +48,15 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
# --disable-ld flag
variant("gold", default=False, when="+ld", description="build the gold linker")
variant("libiberty", default=False, description="Also install libiberty.")
- variant("nls", default=True, description="Enable Native Language Support")
+ variant("nls", default=False, description="Enable Native Language Support")
variant("headers", default=False, description="Install extra headers (e.g. ELF)")
variant("lto", default=False, description="Enable lto.")
+ variant(
+ "pgo",
+ default=False,
+ description="Build with profile-guided optimization (slow)",
+ when="@2.37:",
+ )
variant("ld", default=False, description="Enable ld.")
# When you build binutils with ~ld and +gas and load it in your PATH, you
# may end up with incompatibilities between a potentially older system ld
@@ -57,6 +66,7 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
# when compiling with debug symbols on gcc.
variant("gas", default=False, when="+ld", description="Enable as assembler.")
variant("interwork", default=False, description="Enable interwork.")
+ variant("gprofng", default=False, description="Enable gprofng.", when="@2.39:")
variant(
"libs",
default="shared,static",
@@ -76,16 +86,26 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
depends_on("diffutils", type="build")
depends_on("gettext", when="+nls")
+ # PGO runs tests, which requires `runtest` from dejagnu
+ depends_on("dejagnu", when="+pgo", type="build")
+
# Prior to 2.30, gold did not distribute the generated files and
# thus needs bison, even for a one-time build.
depends_on("m4", type="build", when="@:2.29 +gold")
depends_on("bison", type="build", when="@:2.29 +gold")
- # 2.34:2.38 needs makeinfo due to a bug, see:
+ # 2.34:2.40 needs makeinfo due to a bug, see:
# https://sourceware.org/bugzilla/show_bug.cgi?id=25491
- depends_on("texinfo", type="build", when="@2.34:2.38")
+ # https://sourceware.org/bugzilla/show_bug.cgi?id=28909
+ depends_on("texinfo", type="build", when="@2.34:2.40")
+
+ # gprofng requires bison
+ depends_on("bison@3.0.4:", type="build", when="+gprofng")
conflicts("+gold", when="platform=darwin", msg="Binutils cannot build linkers on macOS")
+ conflicts(
+ "~lto", when="+pgo", msg="Profile-guided optimization enables link-time optimization"
+ )
@classmethod
def determine_version(cls, exe):
@@ -95,6 +115,13 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
def flag_handler(self, name, flags):
spec = self.spec
+
+ # Set -O3 -g0 by default when using gcc or clang, since it improves performance
+ # a bit and significantly reduces install size
+ if name in ("cflags", "cxxflags") and self.compiler.name in ("gcc", "clang"):
+ flags.insert(0, "-g0")
+ flags.insert(0, "-O3")
+
# Use a separate variable for injecting flags. This way, installing
# `binutils cflags='-O2'` will still work as expected.
iflags = []
@@ -105,10 +132,8 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
):
iflags.append("-Wno-narrowing")
elif name == "cflags":
- if spec.satisfies("@:2.34 %gcc@10:"):
+ if spec.satisfies("@:2.34 %gcc@10:") or spec.satisfies("%cce"):
iflags.append("-fcommon")
- if spec.satisfies("%cce") or spec.satisfies("@2.38 %gcc"):
- iflags.extend([self.compiler.cc_pic_flag, "-fcommon"])
elif name == "ldflags":
if spec.satisfies("%cce") or spec.satisfies("@2.38 %gcc"):
iflags.append("-Wl,-z,notext")
@@ -143,28 +168,45 @@ class Binutils(AutotoolsPackage, GNUMirrorPackage):
class AutotoolsBuilder(spack.build_systems.autotools.AutotoolsBuilder):
def configure_args(self):
+ known_targets = {
+ "x86_64": "x86_64",
+ "aarch64": "aarch64",
+ "ppc64le": "powerpc",
+ }
+ known_platforms = {"linux": "linux-gnu", "cray": "linux-gnu", "darwin": "apple-darwin"}
+
+ family = str(self.spec.target.family)
+ platform = self.spec.platform
+
+ if family in known_targets and platform in known_platforms:
+ targets = "{}-{}".format(known_targets[family], known_platforms[platform])
+ else:
+ targets = "all"
+
args = [
"--disable-dependency-tracking",
"--disable-werror",
- "--enable-multilib",
"--enable-64-bit-bfd",
- "--enable-targets=all",
- "--with-system-zlib",
+ "--enable-multilib",
+ "--enable-pic",
+ "--enable-targets={}".format(targets),
"--with-sysroot=/",
+ "--with-system-zlib",
]
- args += self.enable_or_disable("libs")
- args += self.enable_or_disable("lto")
- args += self.enable_or_disable("ld")
args += self.enable_or_disable("gas")
- args += self.enable_or_disable("interwork")
args += self.enable_or_disable("gold")
+ args += self.enable_or_disable("gprofng")
+ args += self.enable_or_disable("install-libiberty", variant="libiberty")
+ args += self.enable_or_disable("interwork")
+ args += self.enable_or_disable("ld")
+ args += self.enable_or_disable("libs")
+ args += self.enable_or_disable("lto")
args += self.enable_or_disable("nls")
args += self.enable_or_disable("plugins")
-
- if "+libiberty" in self.spec:
- args.append("--enable-install-libiberty")
+ if "+pgo" in self.spec:
+ args.append("--enable-pgo-build=lto")
else:
- args.append("--disable-install-libiberty")
+ args.append("--disable-pgo-build")
# To avoid namespace collisions with Darwin/BSD system tools,
# prefix executables with "g", e.g., gar, gnm; see Homebrew
diff --git a/var/spack/repos/builtin/packages/dejagnu/package.py b/var/spack/repos/builtin/packages/dejagnu/package.py
index bd8bfd2df6..99cd5aaedf 100644
--- a/var/spack/repos/builtin/packages/dejagnu/package.py
+++ b/var/spack/repos/builtin/packages/dejagnu/package.py
@@ -13,11 +13,11 @@ class Dejagnu(AutotoolsPackage, GNUMirrorPackage):
homepage = "https://www.gnu.org/software/dejagnu/"
gnu_mirror_path = "dejagnu/dejagnu-1.6.tar.gz"
+ version("1.6.3", sha256="87daefacd7958b4a69f88c6856dbd1634261963c414079d0c371f589cd66a2e3")
version("1.6", sha256="00b64a618e2b6b581b16eb9131ee80f721baa2669fa0cdee93c500d1a652d763")
version("1.4.4", sha256="d0fbedef20fb0843318d60551023631176b27ceb1e11de7468a971770d0e048d")
- depends_on("expect")
- depends_on("tcl@8.5:")
+ depends_on("expect", type=("run", "link", "build"))
# DejaGnu 1.4.4 cannot be built in parallel
# `make check` also fails but this can be ignored