2015-12-15 17:31:18 +03:00
|
|
|
/*
|
2021-03-13 14:51:53 +00:00
|
|
|
* Copyright (c) 2015, 2021, Oracle and/or its affiliates. All rights reserved.
|
2015-12-15 17:31:18 +03: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
|
2016-08-19 10:06:30 -04:00
|
|
|
* @library /test/lib /
|
2016-04-09 23:03:39 +01:00
|
|
|
* @modules java.base/jdk.internal.misc
|
2015-12-15 17:31:18 +03:00
|
|
|
* java.management
|
2017-10-02 14:31:34 -07:00
|
|
|
* @requires vm.cpu.features ~= ".*aes.*" & !vm.graal.enabled
|
2016-08-19 10:06:30 -04:00
|
|
|
* @build sun.hotspot.WhiteBox
|
2021-03-13 14:51:53 +00:00
|
|
|
* @run driver jdk.test.lib.helpers.ClassFileInstaller sun.hotspot.WhiteBox
|
2016-09-09 19:30:08 +03:00
|
|
|
* @run main/othervm/timeout=600 -Xbootclasspath/a:.
|
|
|
|
* -XX:+UnlockDiagnosticVMOptions
|
2015-12-15 17:31:18 +03:00
|
|
|
* -XX:+WhiteBoxAPI -Xbatch
|
2016-07-12 18:24:48 +03:00
|
|
|
* compiler.cpuflags.TestAESIntrinsicsOnSupportedConfig
|
2015-12-15 17:31:18 +03:00
|
|
|
*/
|
2016-06-22 00:29:32 +03:00
|
|
|
|
2016-07-12 18:24:48 +03:00
|
|
|
package compiler.cpuflags;
|
|
|
|
|
2016-08-19 10:06:30 -04:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
2016-06-22 00:29:32 +03:00
|
|
|
import jdk.test.lib.Platform;
|
2016-08-19 10:06:30 -04:00
|
|
|
import jdk.test.lib.process.ProcessTools;
|
2017-06-01 17:33:07 -07:00
|
|
|
import sun.hotspot.WhiteBox;
|
|
|
|
import static jdk.test.lib.cli.CommandLineOptionTest.*;
|
2016-06-22 00:29:32 +03:00
|
|
|
|
2015-12-15 17:31:18 +03:00
|
|
|
public class TestAESIntrinsicsOnSupportedConfig extends AESIntrinsicsBase {
|
|
|
|
|
|
|
|
protected void runTestCases() throws Throwable {
|
|
|
|
testUseAES();
|
|
|
|
testUseAESUseSSE2();
|
|
|
|
testNoUseAES();
|
|
|
|
testNoUseAESUseSSE2();
|
|
|
|
testNoUseAESIntrinsic();
|
|
|
|
}
|
|
|
|
|
2017-06-01 17:33:07 -07:00
|
|
|
/**
|
|
|
|
* Check if value of TieredStopAtLevel flag is greater than specified level.
|
|
|
|
*
|
|
|
|
* @param level tiered compilation level to compare with
|
|
|
|
*/
|
|
|
|
private boolean isTieredLevelGreaterThan(int level) {
|
|
|
|
Long val = WhiteBox.getWhiteBox().getIntxVMFlag("TieredStopAtLevel");
|
|
|
|
return (val != null && val > level);
|
|
|
|
}
|
|
|
|
|
2015-12-15 17:31:18 +03:00
|
|
|
/**
|
|
|
|
* Test checks following situation: <br/>
|
|
|
|
* UseAES flag is set to true, TestAESMain is executed <br/>
|
|
|
|
* Expected result: UseAESIntrinsics flag is set to true <br/>
|
|
|
|
* If vm type is server then output should contain intrinsics usage <br/>
|
|
|
|
*
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
private void testUseAES() throws Throwable {
|
|
|
|
OutputAnalyzer outputAnalyzer = ProcessTools.executeTestJvm(
|
|
|
|
prepareArguments(prepareBooleanFlag(AESIntrinsicsBase
|
|
|
|
.USE_AES, true)));
|
|
|
|
final String errorMessage = "Case testUseAES failed";
|
2017-06-01 17:33:07 -07:00
|
|
|
if (Platform.isServer() && !Platform.isEmulatedClient() && isTieredLevelGreaterThan(3)) {
|
2015-12-15 17:31:18 +03:00
|
|
|
verifyOutput(new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC}, null, errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
} else {
|
|
|
|
verifyOutput(null, new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC}, errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
}
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES, "true", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES_INTRINSICS, "true",
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test checks following situation: <br/>
|
|
|
|
* UseAES flag is set to true, UseSSE flag is set to 2,
|
|
|
|
* Platform should support UseSSE (x86 or x64) <br/>
|
|
|
|
* TestAESMain is executed <br/>
|
|
|
|
* Expected result: UseAESIntrinsics flag is set to false <br/>
|
|
|
|
* Output shouldn't contain intrinsics usage <br/>
|
|
|
|
*
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
private void testUseAESUseSSE2() throws Throwable {
|
|
|
|
if (Platform.isX86() || Platform.isX64()) {
|
|
|
|
OutputAnalyzer outputAnalyzer = ProcessTools.executeTestJvm(
|
|
|
|
prepareArguments(prepareBooleanFlag(AESIntrinsicsBase
|
|
|
|
.USE_AES_INTRINSICS, true),
|
|
|
|
prepareNumericFlag(AESIntrinsicsBase.USE_SSE, 2)));
|
|
|
|
final String errorMessage = "Case testUseAESUseSSE2 failed";
|
|
|
|
verifyOutput(null, new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC},
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES, "true", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES_INTRINSICS, "false",
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_SSE, "2", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test checks following situation: <br/>
|
|
|
|
* UseAES flag is set to false, UseSSE flag is set to 2,
|
|
|
|
* Platform should support UseSSE (x86 or x64) <br/>
|
|
|
|
* TestAESMain is executed <br/>
|
|
|
|
* Expected result: UseAESIntrinsics flag is set to false <br/>
|
|
|
|
* Output shouldn't contain intrinsics usage <br/>
|
|
|
|
*
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
private void testNoUseAESUseSSE2() throws Throwable {
|
|
|
|
if (Platform.isX86() || Platform.isX64()) {
|
|
|
|
OutputAnalyzer outputAnalyzer = ProcessTools.executeTestJvm(
|
|
|
|
prepareArguments(prepareBooleanFlag(AESIntrinsicsBase
|
|
|
|
.USE_AES, false),
|
|
|
|
prepareNumericFlag(AESIntrinsicsBase.USE_SSE, 2)));
|
|
|
|
final String errorMessage = "Case testNoUseAESUseSSE2 failed";
|
|
|
|
verifyOutput(null, new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC},
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES, "false", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES_INTRINSICS, "false",
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_SSE, "2", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test checks following situation: <br/>
|
|
|
|
* UseAES flag is set to false, TestAESMain is executed <br/>
|
|
|
|
* Expected result: UseAESIntrinsics flag is set to false <br/>
|
|
|
|
* Output shouldn't contain intrinsics usage <br/>
|
|
|
|
*
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
private void testNoUseAES() throws Throwable {
|
|
|
|
OutputAnalyzer outputAnalyzer = ProcessTools.executeTestJvm(
|
|
|
|
prepareArguments(prepareBooleanFlag(AESIntrinsicsBase
|
|
|
|
.USE_AES, false)));
|
|
|
|
final String errorMessage = "Case testNoUseAES failed";
|
|
|
|
verifyOutput(null, new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC},
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES, "false", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES_INTRINSICS, "false",
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Test checks following situation: <br/>
|
|
|
|
* UseAESIntrinsics flag is set to false, TestAESMain is executed <br/>
|
|
|
|
* Expected result: UseAES flag is set to true <br/>
|
|
|
|
* Output shouldn't contain intrinsics usage <br/>
|
|
|
|
*
|
|
|
|
* @throws Throwable
|
|
|
|
*/
|
|
|
|
private void testNoUseAESIntrinsic() throws Throwable {
|
|
|
|
OutputAnalyzer outputAnalyzer = ProcessTools.executeTestJvm(
|
|
|
|
prepareArguments(prepareBooleanFlag(AESIntrinsicsBase
|
|
|
|
.USE_AES_INTRINSICS, false)));
|
|
|
|
final String errorMessage = "Case testNoUseAESIntrinsic failed";
|
|
|
|
verifyOutput(null, new String[]{AESIntrinsicsBase.CIPHER_INTRINSIC,
|
|
|
|
AESIntrinsicsBase.AES_INTRINSIC}, errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES, "true", errorMessage,
|
|
|
|
outputAnalyzer);
|
|
|
|
verifyOptionValue(AESIntrinsicsBase.USE_AES_INTRINSICS, "false",
|
|
|
|
errorMessage, outputAnalyzer);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String args[]) throws Throwable {
|
2017-06-01 17:33:07 -07:00
|
|
|
new TestAESIntrinsicsOnSupportedConfig().runTestCases();
|
2015-12-15 17:31:18 +03:00
|
|
|
}
|
|
|
|
}
|