aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2016-11-01 13:29:18 +0200
committerTimo Teräs <timo.teras@iki.fi>2016-11-01 13:31:02 +0200
commitf105a8c53fca39fbb5d2a2d1e57c0f13fb5e9279 (patch)
tree1d2d82708c47d695b82eef15064fdbf14e5f3a7a
parent746dedd0692115e85edce087178d57893632fd16 (diff)
downloadaports-f105a8c53fca39fbb5d2a2d1e57c0f13fb5e9279.tar.bz2
aports-f105a8c53fca39fbb5d2a2d1e57c0f13fb5e9279.tar.xz
testing/mongodb: various fixes
- fixes #6187 - paxmark all executables for JIT to work - increase default stack size for std::thread compatiblity - fix to compile with boost 1.62
-rw-r--r--testing/mongodb/APKBUILD20
-rw-r--r--testing/mongodb/boost162.patch15
-rw-r--r--testing/mongodb/musl-available-stack.patch17
-rw-r--r--testing/mongodb/set-default-stacksize.patch20
4 files changed, 48 insertions, 24 deletions
diff --git a/testing/mongodb/APKBUILD b/testing/mongodb/APKBUILD
index 19558f35e6..1d2301ee2f 100644
--- a/testing/mongodb/APKBUILD
+++ b/testing/mongodb/APKBUILD
@@ -2,25 +2,25 @@
# Contributor: Marc Vertes <marc.vertes@ugrid.net>
pkgname=mongodb
pkgver=3.2.10
-pkgrel=0
+pkgrel=1
pkgdesc='A high-performance, open source, schema-free document-oriented database'
url='http://www.mongodb.org'
arch='x86_64'
license='AGPL3'
pkgusers="mongodb"
depends=
-depends_dev="scons libressl-dev pcre-dev snappy-dev boost-dev asio-dev
+makedepends="scons paxmark libressl-dev pcre-dev snappy-dev boost-dev asio-dev
libpcap-dev wiredtiger-dev zlib-dev cyrus-sasl-dev yaml-cpp-dev"
-makedepends="$depends_dev"
install="$pkgname.pre-install"
source="http://downloads.mongodb.org/src/mongodb-src-r${pkgver}.tar.gz
20-fix-libc-version.patch
40-fix-elf-native-class.patch
backtrace.patch
fix-asio-strerror_r.patch
- musl-available-stack.patch
+ set-default-stacksize.patch
wiredtiger-strtouq.patch
boost160.patch
+ boost162.patch
mongodb.confd
mongodb.initd
@@ -82,6 +82,9 @@ package() {
export SCONSFLAGS="$MAKEFLAGS"
scons $_buildopts --prefix=$pkgdir/usr install
+ # java jit requires paxmark
+ paxmark -m "$pkgdir"/usr/bin/mongo*
+
# install alpine specific files
install -dm700 "$pkgdir/var/lib/mongodb"
install -dm755 "$pkgdir/var/log/mongodb"
@@ -100,9 +103,10 @@ md5sums="a7ade13ff46add5544d285a04be24c22 mongodb-src-r3.2.10.tar.gz
04a348397be8ca7471d404056d8a1490 40-fix-elf-native-class.patch
86a988b5d4402227d177b8a1167008e8 backtrace.patch
cd0833592e3a23e729ebd71eb756318c fix-asio-strerror_r.patch
-a0e1d0ef5df415965a20a5da67d853c9 musl-available-stack.patch
+2d4de6cff2918ad610efead9f7c85f4f set-default-stacksize.patch
e6016216b02afd44164e17ae31e3ce7d wiredtiger-strtouq.patch
1df24dc2aa6b8f4c6da22f097a921ebb boost160.patch
+79cfc7e792d1e8e30cc203a8c63ac65b boost162.patch
7d2f94bed7bfacd32fcd52dfd931f077 mongodb.confd
792a0b53b3e843cf14176c5beb8cdfe1 mongodb.initd
49df78833de4cb6e2b9b1ab9da52c3ac mongodb.logrotate
@@ -113,9 +117,10 @@ sha256sums="3bef44f50f302159c26194bcac9d51c81d98d57ea728f55400774850a70f5120 mo
3a863660113d29728d7a852b3fba73926697b496848f8ccc4d8e73e6614cfdfc 40-fix-elf-native-class.patch
300d9f6b819730de54018d4b418eb7f921ba9c83fad4958a040544b076160848 backtrace.patch
ec6d404221f02706ef2e52e00e414e98666dcc3606e78c9b3d33dfbd42a1eae7 fix-asio-strerror_r.patch
-68dba3180f0aedac2a3b9f868723552a2945882e53c9635e0d0585be9fd1e47b musl-available-stack.patch
+85f2e5c5de90e43446ad3a13d661c211deb64cfce9e639ba1c2fa2a4573414ae set-default-stacksize.patch
20c465ae169e5e3642ca0c8486b2165a412dabe171e8e249c134e0a4688342a4 wiredtiger-strtouq.patch
0e9da35f4303e53daf51e78961c517895f2d12f4fa49298f01e1665e15246d73 boost160.patch
+bf373d1514b7947dc4747e11babf87a4bd8e7d581781c6771a844e69c1c4d273 boost162.patch
a4ca29c577428c02cd0b0a8b46756df5f53a05519c9d13c270533cf99b9b819d mongodb.confd
7e39fbd4dc18dba21c8767931683f4795e58e0e91b9f9a5842539923ded453c9 mongodb.initd
76994c32d999def5c925bd7be3f96687b3406f1d67b89aa6a4df8053025b1e01 mongodb.logrotate
@@ -126,9 +131,10 @@ b9fdacb273d5a4e1e60735846b262287f84ca6cbded9393d182f69158d3162a50cae5d834f76860d
56db8f43afc94713ac65b174189e2dd903b5e1eff0b65f1bdac159e52ad4de6606c449865d73bd47bffad6a8fc339777e2b11395596e9a476867d94a219c7925 40-fix-elf-native-class.patch
7d097f497cb910c9cb81086cd8c222e43456d1a6de4adfe3e97a4d99add454279350fdeb7305dab84b3deca04afd824036d4065ee0fb8cdd8c03e96d98ee86af backtrace.patch
f829b1ad542db3ee776d444243b8b47ab4e48a7386d9b199d7b1adafd31556cf173a5683b78ee735d6a69999ad9af5ad152fde955bbe8865f7910718991ce97c fix-asio-strerror_r.patch
-4251ad85c6a76cb5d87e7e1a3bb2f67c6abb046b3c145b86201310d89b43e99f3b4124da8a8df1f92dfcbcfc2187c14c14a85f48980cfd419ddb2e38508da071 musl-available-stack.patch
+1492137b0e3456d90a79617c1cd5ead5c71b1cfaae9ee41c75d56cd25f404ec73a690f95ce0d8c064c0a14206daca8070aa769b7cdfa904a338a425b52c293fa set-default-stacksize.patch
bbb323d428d59584703e8692bf4df7fe0d37c0324c23822bade2edd1ca78759191f778230b7107502a9d2f7f22afc84d4ea350139fc1d751ceb2fff219b9ddf8 wiredtiger-strtouq.patch
385c82875174caae433a3b381eb10f98a6fed0c8943788ddefff1de80a898e480bdbbf094a7783285cf2ae11ce3fc6878e57d58183d05be2f0837b206aaa4da6 boost160.patch
+79edfd1a6eaba597b31a82e54722dccab288d8b8840a53f79140b5fca221b5acd9fbc770d99e46ea9fa0da502cdf18dd35d982c95a4aa341806c3d8b61fc732f boost162.patch
9bcd870742c31bf25f34188ddc3c414de1103e9860dea9f54eee276b89bc2cf1226abab1749c5cda6a6fb0880e541373754e5e83d63cc7189d4b9c274fd555c3 mongodb.confd
2cb295ac0eb44acb4533c86d6d0988d5f760361a43cff7845713f3e2cf0e37023d23790a2926c613bf2b0668060c0b68d59000db52daaacd8af10e701a8b4192 mongodb.initd
8c089b1a11f494e4148fb4646265964c925bf937633a65e395ee1361d42facf837871dd493a9a2e0f480ae0e0829dbd3ed60794c5334e2716332e131fc5c2c51 mongodb.logrotate
diff --git a/testing/mongodb/boost162.patch b/testing/mongodb/boost162.patch
new file mode 100644
index 0000000000..30a3bdff45
--- /dev/null
+++ b/testing/mongodb/boost162.patch
@@ -0,0 +1,15 @@
+Derived from http://cvsweb.netbsd.org/bsdweb.cgi/pkgsrc/databases/mongodb/patches/patch-src_mongo_db_fts_unicode_string.cpp v1.1
+
+* Fix build with boost 1.62.0
+
+--- a/src/mongo/db/fts/unicode/string.cpp 2016-09-26 12:10:04.000000000 +0000
++++ b/src/mongo/db/fts/unicode/string.cpp
+@@ -274,7 +274,7 @@ bool String::substrMatch(const std::stri
+
+ // Case sensitive and diacritic sensitive.
+ return boost::algorithm::boyer_moore_search(
+- haystack.begin(), haystack.end(), needle.begin(), needle.end()) != haystack.end();
++ haystack.begin(), haystack.end(), needle.begin(), needle.end()) != std::make_pair(haystack.end(), haystack.end());
+ }
+
+ } // namespace unicode
diff --git a/testing/mongodb/musl-available-stack.patch b/testing/mongodb/musl-available-stack.patch
deleted file mode 100644
index 4774b6210a..0000000000
--- a/testing/mongodb/musl-available-stack.patch
+++ /dev/null
@@ -1,17 +0,0 @@
---- mongodb-src-r3.2.1/src/mongo/scripting/mozjs/implscope.cpp.orig
-+++ mongodb-src-r3.2.1/src/mongo/scripting/mozjs/implscope.cpp
-@@ -258,7 +258,13 @@
- //
- // TODO: What if we are running on a platform with very
- // large pages, like 4MB?
-- JS_SetNativeStackQuota(_runtime, available.get() - (64 * 1024));
-+ //JS_SetNativeStackQuota(_runtime, available.get() - (64 * 1024));
-+
-+ // For musl libc: We adjust the reserved quota to 32k instead of
-+ // 64k because the default musl libc thread stack size is small
-+ // (80k) and we can not set stack size for C++ threads.
-+ // Note also that with musl, stack size does not include guard page.
-+ JS_SetNativeStackQuota(_runtime, available.get() - (32 * 1024));
- }
-
- // The memory limit is in megabytes
diff --git a/testing/mongodb/set-default-stacksize.patch b/testing/mongodb/set-default-stacksize.patch
new file mode 100644
index 0000000000..d40a2d4b6e
--- /dev/null
+++ b/testing/mongodb/set-default-stacksize.patch
@@ -0,0 +1,20 @@
+diff -ru mongodb-src-r3.2.10.orig/src/mongo/platform/stack_locator_pthread_getattr_np.cpp mongodb-src-r3.2.10/src/mongo/platform/stack_locator_pthread_getattr_np.cpp
+--- mongodb-src-r3.2.10.orig/src/mongo/platform/stack_locator_pthread_getattr_np.cpp 2016-09-26 15:10:04.000000000 +0300
++++ mongodb-src-r3.2.10/src/mongo/platform/stack_locator_pthread_getattr_np.cpp 2016-11-01 10:47:31.062284560 +0200
+@@ -35,6 +35,16 @@
+ #include "mongo/util/assert_util.h"
+ #include "mongo/util/scopeguard.h"
+
++__attribute__((constructor))
++static void set_default_stack_size(void)
++{
++ pthread_attr_t attr;
++ invariant(pthread_attr_init(&attr) == 0);
++ invariant(pthread_attr_setstacksize(&attr, 256*1024) == 0);
++ pthread_setattr_default_np(&attr);
++ invariant(pthread_attr_destroy(&attr) == 0);
++}
++
+ namespace mongo {
+
+ StackLocator::StackLocator() {