diff options
author | Will Sinatra <wpsinatra@gmail.com> | 2019-07-24 15:15:09 -0500 |
---|---|---|
committer | Leo <thinkabit.ukim@gmail.com> | 2019-07-25 10:57:33 -0300 |
commit | ab9ce10828ac25cb38af926c539d5154c2708598 (patch) | |
tree | 175f3cf1fe29de4807dba8f264dbfda4adf17983 /testing/sbcl | |
parent | 256b11a1d5dad56ce03f91b9cc189f9d03947e21 (diff) | |
download | aports-ab9ce10828ac25cb38af926c539d5154c2708598.tar.bz2 aports-ab9ce10828ac25cb38af926c539d5154c2708598.tar.xz |
testing/sbcl: upgrade to 1.5.4, adopt
Removing <signal.h> from musl-fixes.patch allows SBCL to compile correctly. Added myself as the maintainer.
Diffstat (limited to 'testing/sbcl')
-rw-r--r-- | testing/sbcl/APKBUILD | 68 | ||||
-rw-r--r-- | testing/sbcl/fix-generate-version.patch | 13 | ||||
-rw-r--r-- | testing/sbcl/musl-fix-threads.patch | 180 | ||||
-rw-r--r-- | testing/sbcl/musl-fixes.patch | 12 | ||||
-rw-r--r-- | testing/sbcl/pax-genesis-stage-two.patch | 11 | ||||
-rw-r--r-- | testing/sbcl/sbcl_prefix.patch | 11 |
6 files changed, 295 insertions, 0 deletions
diff --git a/testing/sbcl/APKBUILD b/testing/sbcl/APKBUILD new file mode 100644 index 0000000000..9d591f264c --- /dev/null +++ b/testing/sbcl/APKBUILD @@ -0,0 +1,68 @@ +# Contributor: Sören Tempel <soeren+alpine@soeren-tempel.net> +# Maintainer: Will Sinatra <wpsinatra@gmail.com> +pkgname=sbcl +pkgver=1.5.4 +pkgrel=0 +pkgdesc="Steel Bank Common Lisp" +url="http://www.sbcl.org/" +arch="x86_64" +license="custom" +checkdepends="ed" +makedepends="clisp linux-headers paxmark zlib-dev" +subpackages="$pkgname-doc" +source="$pkgname-$pkgver.tar.bz2::https://prdownloads.sourceforge.net/$pkgname/$pkgname-$pkgver-source.tar.bz2 + pax-genesis-stage-two.patch + musl-fixes.patch + musl-fix-threads.patch + sbcl_prefix.patch + fix-generate-version.patch + " +builddir="$srcdir/$pkgname-$pkgver" + +prepare() { + default_prepare + + # FIXME: This test fails (returns incorrect result), don't know why. + rm tests/traceroot.test.sh +} + +build() { + cd "$builddir" + + GNUMAKE=make ./make.sh clisp \ + --prefix=/usr \ + --with-sb-thread \ + --with-sb-test \ + --with-sb-unicode \ + --with-sb-core-compression +} + +check() { + cd "$builddir"/tests + + sh run-tests.sh +} + +package() { + cd "$builddir" + + INSTALL_ROOT="$pkgdir/usr" \ + LIB_DIR="/usr/lib" \ + DOC_DIR="$pkgdir/usr/share/doc/$pkgname" \ + sh install.sh + + paxmark -rm "$pkgdir"/usr/bin/sbcl + + install -Dm644 COPYING \ + "$pkgdir"/usr/share/licenses/$pkgname/LICENSE.txt + + rmdir "$pkgdir"/usr/share/doc/sbcl/html \ + "$pkgdir"/usr/share/info 2>/dev/null || true +} + +sha512sums="052856e7e7f8810903960acf750ba2f073c3b9f4c2141c45714b67a1c499dff9b67a949534a6f0f57299f64103fd7766cd50db24a689cf8e174fbe87fedba78d sbcl-1.5.4.tar.bz2 +cda5c7268b314145a1bdb8293c7970e077aebf3cce5dace12542bf18beb7b124bf97f4754906f2f681428869ca3060300b88cab80055a3d5881dfcdcfbe51d6d pax-genesis-stage-two.patch +507ecaf8fc296586c637d6ad8c91770efe18158a3aa551d0d2993ce9592454f33442d425d076bcb7121525d7942a03d9a0038252251f1540c575e95fb334ef7e musl-fixes.patch +86b8a51d518d71a3c4d3069f80bc00cccd4b97edc6c96ff12875a0727cc2b96208f35c3a11044d98881b5e6c2e607fc65506020b7ff990b257edae55eb6a1c59 musl-fix-threads.patch +bfb6bef3b6512e487e45bc8c9cf36aa519e470690b6c7036bba7d28269bd899c60a4dfa09b5aba44830b8c002e7191276f2cf6f8f134b163d05af7b46f9849ff sbcl_prefix.patch +acd6a154e539dde5c8c6726cc553cc79b1ba98670f61596a3f7754126de35fae1656c98963169ec5dff1551d33632e00e1a40fa65aec73a729317d814825c6a1 fix-generate-version.patch" diff --git a/testing/sbcl/fix-generate-version.patch b/testing/sbcl/fix-generate-version.patch new file mode 100644 index 0000000000..521520e86a --- /dev/null +++ b/testing/sbcl/fix-generate-version.patch @@ -0,0 +1,13 @@ +Don't read sbcl version from the aports git repository. + +--- a/generate-version.sh ++++ b/generate-version.sh +@@ -2,7 +2,7 @@ + + git_available_p() { + # Check that (1) we have git (2) this is a git tree. +- if ( command -v git >/dev/null && git describe >/dev/null 2>/dev/null ) ++ if ( test -d .git && command -v git >/dev/null && git describe >/dev/null 2>/dev/null ) + then + echo "ok" + else diff --git a/testing/sbcl/musl-fix-threads.patch b/testing/sbcl/musl-fix-threads.patch new file mode 100644 index 0000000000..f9705bdcfb --- /dev/null +++ b/testing/sbcl/musl-fix-threads.patch @@ -0,0 +1,180 @@ +Patch-Source: https://bugs.launchpad.net/sbcl/+bug/1768368 + +diff --git a/contrib/sb-bsd-sockets/constants.lisp b/contrib/sb-bsd-sockets/constants.lisp +index 88f5bb7c4..23fd87277 100644 +--- a/contrib/sb-bsd-sockets/constants.lisp ++++ b/contrib/sb-bsd-sockets/constants.lisp +@@ -93,8 +93,8 @@ + (:integer EAFNOSUPPORT "EAFNOSUPPORT") + (:integer EINPROGRESS "EINPROGRESS") + +- (:integer NETDB-INTERNAL #+hpux "h_NETDB_INTERNAL" #-hpux "NETDB_INTERNAL" "See errno.") +- (:integer NETDB-SUCCESS #+hpux "h_NETDB_SUCCESS" #-hpux "NETDB_SUCCESS" "No problem.") ++ (:integer-no-check NETDB-INTERNAL #-os-provides-netdb-internal "-1" #+(and os-provides-netdb-internal hpux) "h_NETDB_INTERNAL" #+(and os-provides-netdb-internal (not hpux)) "NETDB_INTERNAL" "See errno.") ++ (:integer-no-check NETDB-SUCCESS #-os-provides-netdb-internal "0" #+(and os-provides-netdb-internal hpux) "h_NETDB_SUCCESS" #+(and os-provides-netdb-internal (not hpux)) "NETDB_SUCCESS" "No problem.") + (:integer HOST-NOT-FOUND "HOST_NOT_FOUND" "Authoritative Answer Host not found.") + (:integer TRY-AGAIN "TRY_AGAIN" "Non-Authoritative Host not found, or SERVERFAIL.") + (:integer NO-RECOVERY "NO_RECOVERY" "Non recoverable errors, FORMERR, REFUSED, NOTIMP.") +diff --git a/src/runtime/linux-os.c b/src/runtime/linux-os.c +index fa4f5e490..60b5fea4e 100644 +--- a/src/runtime/linux-os.c ++++ b/src/runtime/linux-os.c +@@ -187,8 +187,15 @@ isnptl (void) + if (strstr (buf, "NPTL")) { + return 1; + } ++ else { ++ return 0; ++ } ++ } ++ else { ++ /* If the configuration variable is empty, just assume we have a ++ * good enough thread implementation. */ ++ return 1; + } +- return 0; + } + #endif + +diff --git a/tests/foreign.test.sh b/tests/foreign.test.sh +index 7fb757813..9ba8ed3cf 100755 +--- a/tests/foreign.test.sh ++++ b/tests/foreign.test.sh +@@ -248,16 +248,20 @@ cat > $TEST_FILESTEM.test.lisp <<EOF + (assert (= 13 foo)) + (assert (= 42 (bar))) + (note "/original definitions ok") +- (rename-file "$TEST_FILESTEM-b.so" "$TEST_FILESTEM-b.bak") +- (rename-file "$TEST_FILESTEM-b2.so" "$TEST_FILESTEM-b.so") +- (load-shared-object (truename "$TEST_FILESTEM-b.so")) +- (note "/reloading ok") +- (assert (= 42 foo)) +- (assert (= 13 (bar))) +- (note "/redefined versions ok") +- (rename-file "$TEST_FILESTEM-b.so" "$TEST_FILESTEM-b2.so") +- (rename-file "$TEST_FILESTEM-b.bak" "$TEST_FILESTEM-b.so") +- (note "/renamed back to originals") ++ #+dlclose-is-noop ++ (note "/skipping reloading tests") ++ #-dlclose-is-noop ++ (progn ++ (rename-file "$TEST_FILESTEM-b.so" "$TEST_FILESTEM-b.bak") ++ (rename-file "$TEST_FILESTEM-b2.so" "$TEST_FILESTEM-b.so") ++ (load-shared-object (truename "$TEST_FILESTEM-b.so")) ++ (note "/reloading ok") ++ (assert (= 42 foo)) ++ (assert (= 13 (bar))) ++ (note "/redefined versions ok") ++ (rename-file "$TEST_FILESTEM-b.so" "$TEST_FILESTEM-b2.so") ++ (rename-file "$TEST_FILESTEM-b.bak" "$TEST_FILESTEM-b.so") ++ (note "/renamed back to originals")) + + ;; test late resolution + #+linkage-table +@@ -274,13 +278,17 @@ cat > $TEST_FILESTEM.test.lisp <<EOF + (load-shared-object (truename "$TEST_FILESTEM-c.so")) + (assert (= 43 late-foo)) + (assert (= 14 (late-bar))) +- (unload-shared-object (truename "$TEST_FILESTEM-c.so")) +- (multiple-value-bind (val err) (ignore-errors late-foo) +- (assert (not val)) +- (assert (typep err 'undefined-alien-error))) +- (multiple-value-bind (val err) (ignore-errors (late-bar)) +- (assert (not val)) +- (assert (typep err 'undefined-alien-error))) ++ #+dlclose-is-noop ++ (note "/skipping unloading tests") ++ #-dlclose-is-noop ++ (progn ++ (unload-shared-object (truename "$TEST_FILESTEM-c.so")) ++ (multiple-value-bind (val err) (ignore-errors late-foo) ++ (assert (not val)) ++ (assert (typep err 'undefined-alien-error))) ++ (multiple-value-bind (val err) (ignore-errors (late-bar)) ++ (assert (not val)) ++ (assert (typep err 'undefined-alien-error)))) + (note "/linkage table ok")) + + (sb-ext:exit :code $EXIT_LISP_WIN) ; success convention for Lisp program +diff --git a/tools-for-build/Makefile b/tools-for-build/Makefile +index 3f6e4ecf9..39bab2b92 100644 +--- a/tools-for-build/Makefile ++++ b/tools-for-build/Makefile +@@ -16,6 +16,9 @@ LDLIBS:=$(OS_LIBS) + + all: grovel-headers determine-endianness where-is-mcontext + ++dlclose-is-noop-test-helper.so: dlclose-is-noop-test-helper.c ++ @$(CC) $(LDFLAGS) -shared $< -o $@ $(LOADLIBES) $(LDLIBS) ++ + clean: + rm -f *.o grovel-headers determine-endianness where-is-mcontext + rm -f *.exe +diff --git a/tools-for-build/dlclose-is-noop-test-helper.c b/tools-for-build/dlclose-is-noop-test-helper.c +new file mode 100644 +index 000000000..4be7a8e5b +--- /dev/null ++++ b/tools-for-build/dlclose-is-noop-test-helper.c +@@ -0,0 +1 @@ ++int sbcl_dl_close_test = 42; +diff --git a/tools-for-build/dlclose-is-noop-test.c b/tools-for-build/dlclose-is-noop-test.c +new file mode 100644 +index 000000000..f4eab26a5 +--- /dev/null ++++ b/tools-for-build/dlclose-is-noop-test.c +@@ -0,0 +1,19 @@ ++/* test to build and run so that we know if we have a noop dlclose ++ */ ++ ++#include <dlfcn.h> ++#include <stddef.h> ++ ++int main () ++{ ++ void * handle = dlopen("./dlclose-is-noop-test-helper.so", RTLD_NOW | RTLD_GLOBAL); ++ dlclose(handle); ++ ++ handle = dlopen("./dlclose-is-noop-test-helper.so", RTLD_NOW | RTLD_NOLOAD); ++ ++ if (handle != NULL) { ++ return 104; ++ } else { ++ return 0; ++ } ++} +diff --git a/tools-for-build/grovel-features.sh b/tools-for-build/grovel-features.sh +index ffc4307eb..bf1448a6a 100644 +--- a/tools-for-build/grovel-features.sh ++++ b/tools-for-build/grovel-features.sh +@@ -33,4 +33,13 @@ featurep os-provides-getprotoby-r + + featurep os-provides-poll + ++featurep os-provides-netdb-internal ++ + featurep arm-softfp ++ ++# We need a helper shared library to test dlclose-is-noop ++$GNUMAKE dlclose-is-noop-test-helper.so > /dev/null 2>&1 ++ ++featurep dlclose-is-noop ++ ++rm -f dlclose-is-noop-test-helper.so +diff --git a/tools-for-build/os-provides-netdb-internal-test.c b/tools-for-build/os-provides-netdb-internal-test.c +new file mode 100644 +index 000000000..cab08cc41 +--- /dev/null ++++ b/tools-for-build/os-provides-netdb-internal-test.c +@@ -0,0 +1,12 @@ ++#include <netdb.h> ++ ++int main () ++{ ++#if defined NETDB_INTERNAL && defined NETDB_SUCCESS ++ return 104; ++#elif defined h_NETDB_INTERNAL && defined h_NETDB_SUCCESS ++ return 104; ++#else ++ return 0; ++#endif ++} diff --git a/testing/sbcl/musl-fixes.patch b/testing/sbcl/musl-fixes.patch new file mode 100644 index 0000000000..73a938f290 --- /dev/null +++ b/testing/sbcl/musl-fixes.patch @@ -0,0 +1,12 @@ +diff -upr sbcl-1.3.1.orig/src/runtime/linux-os.h sbcl-1.3.1/src/runtime/linux-os.h +--- sbcl-1.3.1.orig/src/runtime/linux-os.h 2016-04-05 19:48:17.823336398 +0200 ++++ sbcl-1.3.1/src/runtime/linux-os.h 2016-04-05 19:48:47.117967857 +0200 +@@ -24,7 +24,7 @@ + #include <linux/version.h> + + // Needs to be defined before including target-arch.h +-typedef caddr_t os_vm_address_t; ++typedef void *os_vm_address_t; + typedef size_t os_vm_size_t; + typedef off_t os_vm_offset_t; + typedef int os_vm_prot_t; diff --git a/testing/sbcl/pax-genesis-stage-two.patch b/testing/sbcl/pax-genesis-stage-two.patch new file mode 100644 index 0000000000..b06dd22bb2 --- /dev/null +++ b/testing/sbcl/pax-genesis-stage-two.patch @@ -0,0 +1,11 @@ +diff -upr sbcl-1.3.11.orig/make-target-2.sh sbcl-1.3.11/make-target-2.sh +--- sbcl-1.3.11.orig/make-target-2.sh 2016-11-02 10:44:23.226711691 +0100 ++++ sbcl-1.3.11/make-target-2.sh 2016-11-02 10:45:19.043220337 +0100 +@@ -39,6 +39,7 @@ fi + # system with the :SB-SHOW feature enabled, it does it rather silently, + # without trying to tell you about what it's doing. So unless it hangs + # for much longer than that, don't worry, it's likely to be normal. ++paxmark.sh -mr ./src/runtime/sbcl + if [ "$1" != --load ]; then + echo //doing warm init - compilation phase + echo '(load "loader.lisp") (load-sbcl-file "make-host-1.lisp")' | \ diff --git a/testing/sbcl/sbcl_prefix.patch b/testing/sbcl/sbcl_prefix.patch new file mode 100644 index 0000000000..2019d0e7ec --- /dev/null +++ b/testing/sbcl/sbcl_prefix.patch @@ -0,0 +1,11 @@ +--- a/make-config.sh ++++ b/make-config.sh +@@ -30,7 +30,7 @@ + then + SBCL_PREFIX="$PROGRAMFILES/sbcl" + else +- SBCL_PREFIX="/usr/local" ++ SBCL_PREFIX="/usr" + fi + SBCL_XC_HOST="sbcl --no-userinit --no-sysinit" + export SBCL_XC_HOST |