mdbx-test: add workarounds for QEMU (all 32-bit, Alpha, Sparc).

This commit is contained in:
Leonid Yuriev 2021-07-13 12:38:58 +03:00
parent f749b3deee
commit 1995754bc3
3 changed files with 51 additions and 4 deletions

View File

@ -618,7 +618,6 @@ cross-qemu:
$(QUIET)for CC in $(CROSS_LIST); do \ $(QUIET)for CC in $(CROSS_LIST); do \
echo "===================== $$CC + qemu"; \ echo "===================== $$CC + qemu"; \
$(MAKE) CXXSTD= clean && \ $(MAKE) CXXSTD= clean && \
MDBX_SMOKE_EXTRA="$(MDBX_SMOKE_EXTRA)$$(echo $$CC | grep -q -e alpha -e sparc && echo ' --size-upper=64M --size-lower=64M')" \
CC=$$CC CXX=$$(echo $$CC | sed 's/-gcc/-g++/') EXE_LDFLAGS=-static MDBX_BUILD_OPTIONS="-DMDBX_SAFE4QEMU $(MDBX_BUILD_OPTIONS)" \ CC=$$CC CXX=$$(echo $$CC | sed 's/-gcc/-g++/') EXE_LDFLAGS=-static MDBX_BUILD_OPTIONS="-DMDBX_SAFE4QEMU $(MDBX_BUILD_OPTIONS)" \
$(MAKE) test-singleprocess || exit $$?; \ $(MAKE) test-singleprocess || exit $$?; \
done done

View File

@ -222,6 +222,43 @@ void cleanup() {
log_trace("<< cleanup"); log_trace("<< cleanup");
} }
static void fixup4qemu(actor_params &params) {
#ifdef MDBX_SAFE4QEMU
#if MDBX_WORDBITS == 32
intptr_t safe4qemu_limit = size_t(512) << 20 /* 512 megabytes */;
#if defined(__SANITIZE_ADDRESS__)
safe4qemu_limit >>= 1;
#else
if (RUNNING_ON_VALGRIND)
safe4qemu_limit >>= 1;
#endif /* __SANITIZE_ADDRESS__ */
if (params.size_lower > safe4qemu_limit ||
params.size_now > safe4qemu_limit ||
params.size_upper > safe4qemu_limit) {
params.size_upper = std::min(params.size_upper, safe4qemu_limit);
params.size_now = std::min(params.size_now, params.size_upper);
params.size_lower = std::min(params.size_lower, params.size_now);
log_notice("workaround: for conformance 32-bit build with "
"QEMU/ASAN/Valgrind database size reduced to %zu megabytes",
safe4qemu_limit >> 20);
}
#endif /* MDBX_WORDBITS == 32 */
#if defined(__alpha__) || defined(__alpha) || defined(__sparc__) || \
defined(__sparc) || defined(__sparc64__) || defined(__sparc64)
if (params.size_lower != params.size_upper) {
log_notice(
"workaround: for conformance Alpha/Sparc build with QEMU/ASAN/Valgrind "
"enforce fixed database size %zu megabytes",
params.size_upper >> 20);
params.size_lower = params.size_now = params.size_upper;
}
#endif /* Alpha || Sparc */
#endif /* MDBX_SAFE4QEMU */
(void)params;
}
int main(int argc, char *const argv[]) { int main(int argc, char *const argv[]) {
#ifdef _DEBUG #ifdef _DEBUG
@ -254,6 +291,7 @@ int main(int argc, char *const argv[]) {
const char *value = nullptr; const char *value = nullptr;
if (config::parse_option(argc, argv, narg, "case", &value)) { if (config::parse_option(argc, argv, narg, "case", &value)) {
fixup4qemu(params);
testcase_setup(value, params, last_space_id); testcase_setup(value, params, last_space_id);
continue; continue;
} }
@ -486,38 +524,47 @@ int main(int argc, char *const argv[]) {
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "hill", &value, "auto")) { if (config::parse_option(argc, argv, narg, "hill", &value, "auto")) {
fixup4qemu(params);
configure_actor(last_space_id, ac_hill, value, params); configure_actor(last_space_id, ac_hill, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "jitter", nullptr)) { if (config::parse_option(argc, argv, narg, "jitter", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_jitter, value, params); configure_actor(last_space_id, ac_jitter, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "dead.reader", nullptr)) { if (config::parse_option(argc, argv, narg, "dead.reader", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_deadread, value, params); configure_actor(last_space_id, ac_deadread, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "dead.writer", nullptr)) { if (config::parse_option(argc, argv, narg, "dead.writer", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_deadwrite, value, params); configure_actor(last_space_id, ac_deadwrite, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "try", nullptr)) { if (config::parse_option(argc, argv, narg, "try", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_try, value, params); configure_actor(last_space_id, ac_try, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "copy", nullptr)) { if (config::parse_option(argc, argv, narg, "copy", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_copy, value, params); configure_actor(last_space_id, ac_copy, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "append", nullptr)) { if (config::parse_option(argc, argv, narg, "append", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_append, value, params); configure_actor(last_space_id, ac_append, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "ttl", nullptr)) { if (config::parse_option(argc, argv, narg, "ttl", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_ttl, value, params); configure_actor(last_space_id, ac_ttl, value, params);
continue; continue;
} }
if (config::parse_option(argc, argv, narg, "nested", nullptr)) { if (config::parse_option(argc, argv, narg, "nested", nullptr)) {
fixup4qemu(params);
configure_actor(last_space_id, ac_nested, value, params); configure_actor(last_space_id, ac_nested, value, params);
continue; continue;
} }
@ -531,9 +578,10 @@ int main(int argc, char *const argv[]) {
global::config::console_mode)) global::config::console_mode))
continue; continue;
if (*argv[narg] != '-') if (*argv[narg] != '-') {
fixup4qemu(params);
testcase_setup(argv[narg], params, last_space_id); testcase_setup(argv[narg], params, last_space_id);
else } else
failure("Unknown option '%s'. Try --help\n", argv[narg]); failure("Unknown option '%s'. Try --help\n", argv[narg]);
} }

View File

@ -129,7 +129,7 @@ uint64_t entropy_ticks(void) {
uint64_t ticks; uint64_t ticks;
__asm __volatile("stck 0(%0)" : : "a"(&(ticks)) : "memory", "cc"); __asm __volatile("stck 0(%0)" : : "a"(&(ticks)) : "memory", "cc");
return ticks; return ticks;
#elif defined(__alpha__) #elif defined(__alpha__) || defined(__alpha)
uint64_t ticks; uint64_t ticks;
__asm __volatile("rpcc %0" : "=r"(ticks)); __asm __volatile("rpcc %0" : "=r"(ticks));
return ticks; return ticks;