Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/micro/org/openjdk/bench/javax/crypto/AES.java
41159 views
1
/*
2
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*/
23
package org.openjdk.bench.javax.crypto;
24
25
import org.openjdk.jmh.annotations.Fork;
26
import org.openjdk.jmh.annotations.Benchmark;
27
import org.openjdk.jmh.annotations.OutputTimeUnit;
28
import org.openjdk.jmh.annotations.Param;
29
import org.openjdk.jmh.annotations.Scope;
30
import org.openjdk.jmh.annotations.Setup;
31
import org.openjdk.jmh.annotations.State;
32
33
import javax.crypto.Cipher;
34
import javax.crypto.spec.IvParameterSpec;
35
import javax.crypto.spec.SecretKeySpec;
36
import java.util.Random;
37
import java.util.concurrent.TimeUnit;
38
39
@OutputTimeUnit(TimeUnit.SECONDS)
40
@State(Scope.Thread)
41
public class AES {
42
43
@Param("10000000")
44
private int count;
45
46
private Cipher cipher;
47
private byte[] src;
48
49
@Setup
50
public void setup() throws Exception {
51
SecretKeySpec keySpec = new SecretKeySpec(new byte[]{-80, -103, -1, 68, -29, -94, 61, -52, 93, -59, -128, 105, 110, 88, 44, 105}, "AES");
52
IvParameterSpec iv = new IvParameterSpec(new byte[]{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00});
53
54
cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
55
cipher.init(Cipher.ENCRYPT_MODE, keySpec, iv);
56
57
src = new byte[count];
58
new Random(1).nextBytes(src);
59
}
60
61
@Benchmark
62
@Fork(jvmArgsAppend = {"-XX:+UnlockDiagnosticVMOptions", "-XX:-UseAES", "-XX:-UseAESIntrinsics"})
63
public byte[] testBaseline() throws Exception {
64
return cipher.doFinal(src);
65
}
66
67
@Benchmark
68
@Fork(jvmArgsAppend = {"-XX:+UnlockDiagnosticVMOptions", "-XX:+UseAES", "-XX:-UseAESIntrinsics"})
69
public byte[] testUseAes() throws Exception {
70
return cipher.doFinal(src);
71
}
72
73
@Benchmark
74
@Fork(jvmArgsAppend = {"-XX:+UnlockDiagnosticVMOptions", "-XX:+UseAES", "-XX:+UseAESIntrinsics"})
75
public byte[] testUseAesIntrinsics() throws Exception {
76
return cipher.doFinal(src);
77
}
78
79
}
80
81