mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-02 00:14:14 +08:00
mdbx-make: add cross-compile targets for testing.
This commit is contained in:
parent
61a2c56784
commit
09ab6dd777
45
Makefile
45
Makefile
@ -37,6 +37,7 @@ TESTLOG ?= $(shell [ -d /dev/shm ] && echo /dev/shm || echo /tmp)/mdbx-test.log
|
|||||||
|
|
||||||
# LY: '--no-as-needed,-lrt' for ability to built with modern glibc, but then run with the old
|
# LY: '--no-as-needed,-lrt' for ability to built with modern glibc, but then run with the old
|
||||||
LDFLAGS ?= -Wl,--gc-sections,-z,relro,-O,--no-as-needed,-lrt
|
LDFLAGS ?= -Wl,--gc-sections,-z,relro,-O,--no-as-needed,-lrt
|
||||||
|
EXE_LDFLAGS ?= $(LDFLAGS) -static
|
||||||
|
|
||||||
# LY: just for benchmarking
|
# LY: just for benchmarking
|
||||||
IOARENA ?= $(shell \
|
IOARENA ?= $(shell \
|
||||||
@ -87,6 +88,9 @@ clean:
|
|||||||
check: all
|
check: all
|
||||||
rm -f $(TESTDB) $(TESTLOG) && (set -o pipefail; test/test --pathname=$(TESTDB) --dont-cleanup-after basic | tee -a $(TESTLOG) | tail -n 42) && ./mdbx_chk -vvn $(TESTDB)
|
rm -f $(TESTDB) $(TESTLOG) && (set -o pipefail; test/test --pathname=$(TESTDB) --dont-cleanup-after basic | tee -a $(TESTLOG) | tail -n 42) && ./mdbx_chk -vvn $(TESTDB)
|
||||||
|
|
||||||
|
check-singleprocess: all
|
||||||
|
rm -f $(TESTDB) $(TESTLOG) && (set -o pipefail; test/test --pathname=$(TESTDB) --dont-cleanup-after --hill | tee -a $(TESTLOG) | tail -n 42) && ./mdbx_chk -vvn $(TESTDB)
|
||||||
|
|
||||||
check-fault: all
|
check-fault: all
|
||||||
rm -f $(TESTDB) $(TESTLOG) && (set -o pipefail; test/test --pathname=$(TESTDB) --inject-writefault=42 --dump-config --dont-cleanup-after basic | tee -a $(TESTLOG) | tail -n 42) && ./mdbx_chk -vvn $(TESTDB)
|
rm -f $(TESTDB) $(TESTLOG) && (set -o pipefail; test/test --pathname=$(TESTDB) --inject-writefault=42 --dump-config --dont-cleanup-after basic | tee -a $(TESTLOG) | tail -n 42) && ./mdbx_chk -vvn $(TESTDB)
|
||||||
|
|
||||||
@ -111,10 +115,12 @@ libmdbx.so: $(CORE_OBJ)
|
|||||||
$(CC) $(CFLAGS) -save-temps $^ -pthread -shared $(LDFLAGS) -o $@
|
$(CC) $(CFLAGS) -save-temps $^ -pthread -shared $(LDFLAGS) -o $@
|
||||||
|
|
||||||
mdbx_%: src/tools/mdbx_%.c libmdbx.a
|
mdbx_%: src/tools/mdbx_%.c libmdbx.a
|
||||||
$(CC) $(CFLAGS) $^ $(LDFLAGS) -o $@
|
$(CC) $(CFLAGS) $^ $(EXE_LDFLAGS) -o $@
|
||||||
|
|
||||||
test/test: $(TEST_OBJ) libmdbx.a
|
test/test: $(TEST_OBJ) libmdbx.a
|
||||||
$(CXX) $(CXXFLAGS) $^ $(LDFLAGS) -o $@
|
$(CXX) $(CXXFLAGS) $^ $(EXE_LDFLAGS) -o $@
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
ifneq ($(wildcard $(IOARENA)),)
|
ifneq ($(wildcard $(IOARENA)),)
|
||||||
|
|
||||||
@ -163,6 +169,8 @@ bench-quartet: bench-mdbx_$(NN).txt bench-lmdb_$(NN).txt bench-rocksdb_$(NN).txt
|
|||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
ci-rule = ( CC=$$(which $1); if [ -n "$$CC" ]; then \
|
ci-rule = ( CC=$$(which $1); if [ -n "$$CC" ]; then \
|
||||||
echo -n "probe by $2 ($$(readlink -f $$(which $$CC))): " && \
|
echo -n "probe by $2 ($$(readlink -f $$(which $$CC))): " && \
|
||||||
$(MAKE) clean >$1.log 2>$1.err && \
|
$(MAKE) clean >$1.log 2>$1.err && \
|
||||||
@ -178,3 +186,36 @@ ci:
|
|||||||
@$(call ci-rule,gcc,GCC)
|
@$(call ci-rule,gcc,GCC)
|
||||||
@$(call ci-rule,clang,clang LLVM)
|
@$(call ci-rule,clang,clang LLVM)
|
||||||
@$(call ci-rule,icc,Intel C)
|
@$(call ci-rule,icc,Intel C)
|
||||||
|
|
||||||
|
###############################################################################
|
||||||
|
|
||||||
|
CROSS_LIST = alpha-linux-gnu-gcc mips-linux-gnu-gcc \
|
||||||
|
powerpc64-linux-gnu-gcc powerpc-linux-gnu-gcc \
|
||||||
|
arm-linux-gnueabihf-gcc aarch64-linux-gnu-gcc
|
||||||
|
|
||||||
|
# hppa-linux-gnu-gcc - don't supported by current qemu release
|
||||||
|
# s390x-linux-gnu-gcc - qemu troubles (hang/abort)
|
||||||
|
# sh4-linux-gnu-gcc - qemu troubles (pread syscall, etc)
|
||||||
|
# mips64-linux-gnuabi64-gcc - qemu troubles (pread syscall, etc)
|
||||||
|
# sparc64-linux-gnu-gcc - qemu troubles (fcntl for F_SETLK/F_GETLK)
|
||||||
|
CROSS_LIST_NOQEMU = hppa-linux-gnu-gcc s390x-linux-gnu-gcc \
|
||||||
|
sh4-linux-gnu-gcc mips64-linux-gnuabi64-gcc sparc64-linux-gnu-gcc
|
||||||
|
|
||||||
|
cross-gcc:
|
||||||
|
@echo "CORRESPONDING CROSS-COMPILERs ARE REQUIRED."
|
||||||
|
@echo "FOR INSTANCE: apt install g++-aarch64-linux-gnu g++-alpha-linux-gnu g++-arm-linux-gnueabihf g++-hppa-linux-gnu g++-mips-linux-gnu g++-mips64-linux-gnuabi64 g++-powerpc-linux-gnu g++-powerpc64-linux-gnu g++-s390x-linux-gnu g++-sh4-linux-gnu"
|
||||||
|
@for CC in $(CROSS_LIST_NOQEMU) $(CROSS_LIST); do \
|
||||||
|
echo "===================== $$CC"; \
|
||||||
|
$(MAKE) clean && CC=$$CC CXX=$$(echo $$CC | sed 's/-gcc/-g++/') EXE_LDFLAGS=-static $(MAKE) all || exit $$?; \
|
||||||
|
done
|
||||||
|
|
||||||
|
#
|
||||||
|
# Unfortunately qemu don't provide robust support for futexes.
|
||||||
|
# Therefore it is impossible to run full multi-process tests.
|
||||||
|
cross-qemu:
|
||||||
|
@echo "CORRESPONDING CROSS-COMPILERs AND QEMUs ARE REQUIRED."
|
||||||
|
@echo "FOR INSTANCE: apt install binfmt-support qemu-user-static qemu-user qemu-system-arm qemu-system-mips qemu-system-misc qemu-system-ppc qemu-system-sparc g++-aarch64-linux-gnu g++-alpha-linux-gnu g++-arm-linux-gnueabihf g++-hppa-linux-gnu g++-mips-linux-gnu g++-mips64-linux-gnuabi64 g++-powerpc-linux-gnu g++-powerpc64-linux-gnu g++-s390x-linux-gnu g++-sh4-linux-gnu"
|
||||||
|
@for CC in $(CROSS_LIST); do \
|
||||||
|
echo "===================== $$CC + qemu"; \
|
||||||
|
$(MAKE) clean && CC=$$CC CXX=$$(echo $$CC | sed 's/-gcc/-g++/') EXE_LDFLAGS=-static $(MAKE) check-singleprocess || exit $$?; \
|
||||||
|
done
|
||||||
|
Loading…
x
Reference in New Issue
Block a user