2018-05-17 14:52:47 -07:00
|
|
|
/*
|
2020-06-02 13:04:21 -07:00
|
|
|
* Copyright (c) 2013, 2020, Oracle and/or its affiliates. All rights reserved.
|
2018-05-17 14:52:47 -07:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* @test
|
2020-06-02 13:04:21 -07:00
|
|
|
* @key stress gc randomness
|
2018-05-17 14:52:47 -07:00
|
|
|
*
|
|
|
|
* @summary converted from VM Testbase gc/memory/LargePagesTest.
|
|
|
|
* VM Testbase keywords: [gc, stress, stressopt]
|
|
|
|
*
|
|
|
|
* @library /vmTestbase
|
|
|
|
* /test/lib
|
|
|
|
* @run driver jdk.test.lib.FileInstaller . .
|
|
|
|
* @run main/othervm gc.memory.LargePagesTest.LargePagesTest noThreads=5 duration=60
|
|
|
|
*/
|
|
|
|
|
|
|
|
package gc.memory.LargePagesTest;
|
|
|
|
|
|
|
|
import java.io.PrintStream;
|
2020-06-02 13:04:21 -07:00
|
|
|
import nsk.share.test.LocalRandom;
|
2018-05-17 14:52:47 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Allocators purpose is to create pressure on the garbage collector
|
|
|
|
* for a certain amount of time.
|
|
|
|
* Note: this test moved from the "jr", the original name is func.vm.largepages.LargePagesTest
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @run main/othervm/timeout=150
|
|
|
|
* -XX:+UseLargePages
|
|
|
|
* -Xmx64m
|
|
|
|
* -Xms16m
|
|
|
|
* LargePagesTest
|
|
|
|
* noThreads=5 duration=60
|
|
|
|
* @summary heap shrink/grow test
|
|
|
|
*/
|
|
|
|
final public class LargePagesTest extends Thread {
|
|
|
|
|
|
|
|
private static int cnt;
|
|
|
|
private static final int SMALL_OBJECT_ALLOCATER = 1;
|
|
|
|
private static final int LARGE_OBJECT_ALLOCATER = 2;
|
|
|
|
private static final int ANY_OBJECT_ALLOCATER = 3;
|
|
|
|
private static final int ANY_NO_MULTIARRAYS_ALLOCATER = 4;
|
|
|
|
private int myType;
|
|
|
|
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy[] d0;
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy[] d1;
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy[][] d2;
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy[][] d3;
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy[][][] d4;
|
|
|
|
/** Dummy thingies to update. */
|
|
|
|
public LargePagesTest.Dummy d5;
|
|
|
|
|
|
|
|
/** Time to run execute(). */
|
|
|
|
private long duration;
|
|
|
|
|
|
|
|
/** Boolean of progress should be printed. */
|
|
|
|
private boolean verbose;
|
|
|
|
|
|
|
|
private static int noThreads = 5;
|
|
|
|
|
|
|
|
/** Iterations. */
|
|
|
|
public long iterations = 0L;
|
|
|
|
|
|
|
|
/** Result. */
|
|
|
|
public boolean result = false;
|
|
|
|
|
|
|
|
private PrintStream out;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates DurAllocator.
|
|
|
|
* @param name Parameter
|
|
|
|
* @param duration Parameter
|
|
|
|
* @param out Parameter
|
|
|
|
* @param verbose Parameter
|
|
|
|
*/
|
|
|
|
LargePagesTest(String name, long duration, PrintStream out, boolean verbose) {
|
|
|
|
|
|
|
|
super(name);
|
|
|
|
this.duration = duration;
|
|
|
|
this.out = out;
|
|
|
|
this.verbose = verbose;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Print status.
|
|
|
|
*/
|
|
|
|
void describe() {
|
|
|
|
out.println("DurAllocator run: ");
|
|
|
|
out.println(" test duration: " + duration / 1000 + " seconds");
|
|
|
|
out.println(" number of threads: " + noThreads + " threads");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allocates memory in a loop.
|
|
|
|
*/
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
long startTime = System.currentTimeMillis();
|
|
|
|
|
|
|
|
while (System.currentTimeMillis() - startTime < duration) {
|
|
|
|
try {
|
|
|
|
allocate();
|
|
|
|
} catch (Throwable t) {
|
|
|
|
out.println(getName() + " FAILED: " + t.getClass().getName() + " in iteration " + iterations + ": " + t.getMessage());
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
iterations++;
|
|
|
|
if (verbose && iterations % 1000 == 0) {
|
|
|
|
out.print(".");
|
|
|
|
}
|
|
|
|
if (verbose && iterations % 60000 == 0) {
|
|
|
|
out.println(".");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (verbose) {
|
|
|
|
out.println("");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
long endTime = System.currentTimeMillis();
|
|
|
|
long runTime = endTime - startTime;
|
|
|
|
if (duration > runTime) {
|
|
|
|
out.println(getName() + " FAILED: Execution time < requested execution time.");
|
|
|
|
out.println(" execution time is " + runTime);
|
|
|
|
out.println(" requested time is " + duration);
|
|
|
|
} else if (iterations <= 0) {
|
|
|
|
out.println(getName() + " FAILED: No executions finished");
|
|
|
|
} else {
|
|
|
|
result = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void allocate() {
|
|
|
|
for (int j = 0; j < 1000; j++) {
|
|
|
|
int i = 0;
|
|
|
|
|
|
|
|
switch (myType) {
|
|
|
|
case SMALL_OBJECT_ALLOCATER:
|
|
|
|
i = 5;
|
|
|
|
break;
|
|
|
|
case LARGE_OBJECT_ALLOCATER:
|
|
|
|
i = 1;
|
|
|
|
break;
|
|
|
|
case ANY_OBJECT_ALLOCATER:
|
2020-06-02 13:04:21 -07:00
|
|
|
i = LocalRandom.nextInt(100);
|
2018-05-17 14:52:47 -07:00
|
|
|
break;
|
|
|
|
case ANY_NO_MULTIARRAYS_ALLOCATER:
|
2020-06-02 13:04:21 -07:00
|
|
|
i = LocalRandom.nextInt(100);
|
2018-05-17 14:52:47 -07:00
|
|
|
if ((i >= 2) && (i <= 4)) {
|
|
|
|
i = 5;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (i) {
|
|
|
|
case 0:
|
|
|
|
d0 = new LargePagesTest.Dummy[10];
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
d1 = new LargePagesTest.Dummy[1000];
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
d2 = new LargePagesTest.Dummy[10][10];
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
d3 = new LargePagesTest.Dummy[100][100];
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
d4 = new LargePagesTest.Dummy[10][10][10];
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
d5 = new LargePagesTest.Dummy();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A Dummy class.
|
|
|
|
*/
|
|
|
|
private class Dummy {
|
|
|
|
/**
|
|
|
|
* Creates a dummy.
|
|
|
|
*/
|
|
|
|
Dummy() {
|
|
|
|
cnt++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param args Input arguments
|
|
|
|
*/
|
|
|
|
public static void main(String[] args) {
|
|
|
|
|
|
|
|
long duration = 30 * 60 * 1000;
|
|
|
|
PrintStream out = System.out;
|
|
|
|
boolean verbose = true;
|
|
|
|
|
|
|
|
for (int i = 0; i < args.length; i++) {
|
|
|
|
String noThreadsArgName = "noThreads=";
|
|
|
|
String executionTimeArgName = "duration=";
|
|
|
|
String verboseArgName = "verbose=";
|
|
|
|
if (args[i].indexOf(noThreadsArgName) != -1) {
|
|
|
|
noThreads = Integer.parseInt(args[i].substring(noThreadsArgName.length(), args[i].length()));
|
|
|
|
} else if (args[i].indexOf(executionTimeArgName) != -1) {
|
|
|
|
duration = 1000 * Long.parseLong(args[i].substring(executionTimeArgName.length(), args[i].length()));
|
|
|
|
} else if (args[i].indexOf(verboseArgName) != -1) {
|
|
|
|
verbose = Boolean.parseBoolean(args[i].substring(verboseArgName.length(), args[i].length()));
|
|
|
|
} else {
|
|
|
|
System.out.println("ERROR: Unknown argument string: " + args[i]);
|
|
|
|
System.exit(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Please don't...
|
|
|
|
if (noThreads <= 0) {
|
|
|
|
noThreads = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
LargePagesTest[] runners = new LargePagesTest[noThreads];
|
|
|
|
|
|
|
|
for (int i = 0; i < noThreads; i++) {
|
|
|
|
runners[i] = new LargePagesTest("DurAllocator " + i, duration, out, verbose);
|
|
|
|
}
|
|
|
|
|
|
|
|
runners[0].describe();
|
|
|
|
|
|
|
|
for (int i = 0; i < noThreads; i++) {
|
|
|
|
runners[i].start();
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < noThreads; i++) {
|
|
|
|
try {
|
|
|
|
runners[i].join(duration + 10 * 60 * 1000);
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
out.println(runners[i].getName() + " FAILED: " + e.getClass().getName() + " " + e.getMessage());
|
|
|
|
System.exit(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < noThreads; i++) {
|
|
|
|
if (!runners[i].result) {
|
|
|
|
out.println(runners[i].getName() + " FAILED: status=" + runners[i].result);
|
|
|
|
System.exit(-1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (verbose) {
|
|
|
|
out.println();
|
|
|
|
}
|
|
|
|
|
|
|
|
out.print("DurAllocator PASSED with (");
|
|
|
|
for (int i = 0; i < noThreads; i++) {
|
|
|
|
out.print("" + runners[i].iterations + (i + 1 < noThreads ? "+" : ""));
|
|
|
|
}
|
|
|
|
out.println(") iterations.");
|
|
|
|
// System.exit(90); // use to return 90 as indication of success
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|