diff --git a/test/hotspot/jtreg/TEST.ROOT b/test/hotspot/jtreg/TEST.ROOT index 56979e2303d..339c67a2d30 100644 --- a/test/hotspot/jtreg/TEST.ROOT +++ b/test/hotspot/jtreg/TEST.ROOT @@ -58,6 +58,7 @@ requires.properties= \ vm.jvmci \ vm.emulatedClient \ vm.cpu.features \ + vm.pageSize \ vm.debug \ vm.hasSA \ vm.hasJFR \ diff --git a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack008.java b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack008.java index cf69b5ab9d6..a90f237aa76 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack008.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack008.java @@ -44,10 +44,10 @@ * and 1.4 on Win32. * See the bug: * 4366625 (P4/S4) multiple stack overflow causes HS crash - * The stack size is too small to run on aarch64. Making it bigger - * could cause timeouts on other platform. + * The stack size is too small to run on systems with > 4K page size. + * Making it bigger could cause timeouts on other platform. * - * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp" & os.arch != "aarch64") + * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp" & vm.pageSize == 4096) * @run main/othervm/timeout=900 -Xss200K nsk.stress.stack.stack008 */ diff --git a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack018.java b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack018.java index 46622d7088b..48fe41a67fa 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack018.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack018.java @@ -46,10 +46,10 @@ * See the bug: * 4366625 (P4/S4) multiple stack overflow causes HS crash * - * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp") + * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp" & vm.pageSize == 4096) * @library /vmTestbase * @build nsk.share.Terminator - * @run main/othervm/timeout=900 -Xss448K nsk.stress.stack.stack018 -eager + * @run main/othervm/timeout=900 -Xss220K nsk.stress.stack.stack018 -eager */ package nsk.stress.stack; diff --git a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack019.java b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack019.java index e8937def709..c6c5efbb36f 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack019.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/stress/stack/stack019.java @@ -38,10 +38,10 @@ * Solaris and Win32 platforms. * See the bug: * 4366625 (P4/S4) multiple stack overflow causes HS crash - * The stack size is too small to run on aarch64. Making it bigger - * could cause timeouts on other platform. + * The stack size is too small to run on systems with > 4K page size. + * Making it bigger could cause timeouts on other platform. * - * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp" & os.arch != "aarch64") + * @requires (vm.opt.DeoptimizeALot != true & vm.compMode != "Xcomp" & vm.pageSize == 4096) * @requires os.family != "windows" * @library /vmTestbase * @build nsk.share.Terminator diff --git a/test/jtreg-ext/requires/VMProps.java b/test/jtreg-ext/requires/VMProps.java index e75163fa3ed..95ff81104b3 100644 --- a/test/jtreg-ext/requires/VMProps.java +++ b/test/jtreg-ext/requires/VMProps.java @@ -101,6 +101,7 @@ public class VMProps implements Callable> { map.put("vm.hasJFR", this::vmHasJFR); map.put("vm.jvmti", this::vmHasJVMTI); map.put("vm.cpu.features", this::cpuFeatures); + map.put("vm.pageSize", this::vmPageSize); map.put("vm.rtm.cpu", this::vmRTMCPU); map.put("vm.rtm.compiler", this::vmRTMCompiler); map.put("vm.aot", this::vmAOT); @@ -441,6 +442,13 @@ public class VMProps implements Callable> { return "" + ("true".equals(vmCDS()) && WB.isJavaHeapArchiveSupported()); } + /** + * @return System page size in bytes. + */ + protected String vmPageSize() { + return "" + WB.getVMPageSize(); + } + /** * Check if Graal is used as JIT compiler. *