Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/test/hotspot/jtreg/compiler/intrinsics/bigInteger/TestMulAdd.java
41153 views
1
/*
2
* Copyright (c) 2015, 2021, 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
24
/**
25
* @test
26
* @key randomness
27
* @bug 8081778
28
* @summary Add C2 x86 intrinsic for BigInteger::mulAdd() method
29
*
30
* @library /test/lib
31
* @run main/othervm/timeout=600 -XX:-TieredCompilation -Xbatch
32
* -XX:+IgnoreUnrecognizedVMOptions -XX:+UnlockDiagnosticVMOptions -XX:-UseSquareToLenIntrinsic -XX:-UseMultiplyToLenIntrinsic
33
* -XX:CompileCommand=dontinline,compiler.intrinsics.bigInteger.TestMulAdd::main
34
* -XX:CompileCommand=option,compiler.intrinsics.bigInteger.TestMulAdd::base_multiply,ccstr,DisableIntrinsic,_mulAdd
35
* -XX:CompileCommand=option,java.math.BigInteger::multiply,ccstr,DisableIntrinsic,_mulAdd
36
* -XX:CompileCommand=option,java.math.BigInteger::square,ccstr,DisableIntrinsic,_mulAdd
37
* -XX:CompileCommand=option,java.math.BigInteger::squareToLen,ccstr,DisableIntrinsic,_mulAdd
38
* -XX:CompileCommand=option,java.math.BigInteger::mulAdd,ccstr,DisableIntrinsic,_mulAdd
39
* -XX:CompileCommand=inline,java.math.BigInteger::multiply
40
* -XX:CompileCommand=inline,java.math.BigInteger::square
41
* -XX:CompileCommand=inline,java.math.BigInteger::squareToLen
42
* -XX:CompileCommand=inline,java.math.BigInteger::mulAdd
43
* compiler.intrinsics.bigInteger.TestMulAdd
44
*/
45
46
package compiler.intrinsics.bigInteger;
47
48
import java.math.BigInteger;
49
import java.util.Random;
50
import jdk.test.lib.Utils;
51
52
public class TestMulAdd {
53
54
// Avoid intrinsic by preventing inlining multiply() and mulAdd().
55
public static BigInteger base_multiply(BigInteger op1) {
56
return op1.multiply(op1);
57
}
58
59
// Generate mulAdd() intrinsic by inlining multiply().
60
public static BigInteger new_multiply(BigInteger op1) {
61
return op1.multiply(op1);
62
}
63
64
public static boolean bytecompare(BigInteger b1, BigInteger b2) {
65
byte[] data1 = b1.toByteArray();
66
byte[] data2 = b2.toByteArray();
67
if (data1.length != data2.length)
68
return false;
69
for (int i = 0; i < data1.length; i++) {
70
if (data1[i] != data2[i])
71
return false;
72
}
73
return true;
74
}
75
76
public static String stringify(BigInteger b) {
77
String strout= "";
78
byte [] data = b.toByteArray();
79
for (int i = 0; i < data.length; i++) {
80
strout += (String.format("%02x",data[i]) + " ");
81
}
82
return strout;
83
}
84
85
public static void main(String args[]) throws Exception {
86
87
BigInteger oldsum = new BigInteger("0");
88
BigInteger newsum = new BigInteger("0");
89
90
BigInteger b1, b2, oldres, newres;
91
92
Random rand = new Random(Utils.getRandomInstance().nextLong());
93
Random rand1 = new Random(Utils.getRandomInstance().nextLong());
94
95
for (int j = 0; j < 100000; j++) {
96
int rand_int = rand1.nextInt(3136)+32;
97
b1 = new BigInteger(rand_int, rand);
98
99
oldres = base_multiply(b1);
100
newres = new_multiply(b1);
101
102
oldsum = oldsum.add(oldres);
103
newsum = newsum.add(newres);
104
105
if (!bytecompare(oldres,newres)) {
106
System.out.print("mismatch for:b1:" + stringify(b1) + " :oldres:" + stringify(oldres) + " :newres:" + stringify(newres));
107
System.out.println(b1);
108
throw new Exception("Failed");
109
}
110
}
111
if (!bytecompare(oldsum,newsum)) {
112
System.out.println("Failure: oldsum:" + stringify(oldsum) + " newsum:" + stringify(newsum));
113
throw new Exception("Failed");
114
} else {
115
System.out.println("Success");
116
}
117
}
118
}
119
120