summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThiago Genez <thiagogenez@ebi.ac.uk>2023-09-22 00:41:22 +0100
committerGitHub <noreply@github.com>2023-09-22 01:41:22 +0200
commit43ed8a12b7ce28ceb2afb360617b88dd15bd8bd1 (patch)
tree7792d8cb4c14f062abd0ffb5e4c50b8c256fa938
parent3f5b4a490723808eebb5d40031fda6c8a0ccc03b (diff)
downloadspack-43ed8a12b7ce28ceb2afb360617b88dd15bd8bd1.tar.gz
spack-43ed8a12b7ce28ceb2afb360617b88dd15bd8bd1.tar.bz2
spack-43ed8a12b7ce28ceb2afb360617b88dd15bd8bd1.tar.xz
spack-43ed8a12b7ce28ceb2afb360617b88dd15bd8bd1.zip
openssh: Fix segfault on x86_64-darwin (#40044)
Import patches from homebrew
-rwxr-xr-xvar/spack/repos/builtin/packages/openssh/package.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/var/spack/repos/builtin/packages/openssh/package.py b/var/spack/repos/builtin/packages/openssh/package.py
index 35680a9d52..73b82a7fe5 100755
--- a/var/spack/repos/builtin/packages/openssh/package.py
+++ b/var/spack/repos/builtin/packages/openssh/package.py
@@ -72,6 +72,21 @@ class Openssh(AutotoolsPackage):
"^ssh-keyscan$",
]
+ # Both these patches are applied by Apple.
+ # https://github.com/Homebrew/homebrew-core/blob/7aabdeb30506be9b01708793ae553502c115dfc8/Formula/o/openssh.rb#L40-L45
+ patch(
+ "https://raw.githubusercontent.com/Homebrew/patches/1860b0a745f1fe726900974845d1b0dd3c3398d6/openssh/patch-sandbox-darwin.c-apple-sandbox-named-external.diff",
+ sha256="d886b98f99fd27e3157b02b5b57f3fb49f43fd33806195970d4567f12be66e71",
+ when="platform=darwin",
+ )
+
+ # https://github.com/Homebrew/homebrew-core/blob/7aabdeb30506be9b01708793ae553502c115dfc8/Formula/o/openssh.rb#L48-L52C6
+ patch(
+ "https://raw.githubusercontent.com/Homebrew/patches/d8b2d8c2612fd251ac6de17bf0cc5174c3aab94c/openssh/patch-sshd.c-apple-sandbox-named-external.diff",
+ sha256="3505c58bf1e584c8af92d916fe5f3f1899a6b15cc64a00ddece1dc0874b2f78f",
+ when="platform=darwin",
+ )
+
@classmethod
def determine_version(cls, exe):
output = Executable(exe)("-V", output=str, error=str).rstrip()
@@ -82,6 +97,10 @@ class Openssh(AutotoolsPackage):
# #29938: skip set-suid (also see man ssh-key-sign: it's not enabled by default)
filter_file(r"\$\(INSTALL\) -m 4711", "$(INSTALL) -m711", "Makefile.in")
+ # https://github.com/Homebrew/homebrew-core/blob/7aabdeb30506be9b01708793ae553502c115dfc8/Formula/o/openssh.rb#L71-L77
+ if self.spec.target.family == "x86_64" and self.spec.platform == "darwin":
+ filter_file(r"-fzero-call-used-regs=all", "-fzero-call-used-regs=used", "configure")
+
def configure_args(self):
# OpenSSH's privilege separation path defaults to /var/empty. At
# least newer versions want to create the directory during the
@@ -104,6 +123,11 @@ class Openssh(AutotoolsPackage):
if self.run_tests:
self.setup_test_environment(env)
+ # https://github.com/Homebrew/homebrew-core/blob/7aabdeb30506be9b01708793ae553502c115dfc8/Formula/o/openssh.rb#L65C31-L65C65
+ # to use the MacOS patches
+ if self.spec.platform == "darwin":
+ env.append_flags("CPPFLAGS", "-D__APPLE_SANDBOX_NAMED_EXTERNAL__")
+
def setup_test_environment(self, env):
"""Configure the regression test suite like Debian's openssh-tests package"""
p = self.prefix