From 339016a0f2cbbbbc3560e50c6726e14afbf547f6 Mon Sep 17 00:00:00 2001 From: Ludovic Henry Date: Wed, 5 Aug 2020 11:32:15 -0700 Subject: [PATCH 01/53] 8250902: Implement MD5 Intrinsics on x86 Reviewed-by: kvn, vdeshpande, ascarpino --- .../cpu/aarch64/vm_version_aarch64.cpp | 5 + src/hotspot/cpu/arm/vm_version_arm_32.cpp | 7 +- src/hotspot/cpu/ppc/vm_version_ppc.cpp | 5 + src/hotspot/cpu/s390/vm_version_s390.cpp | 9 +- src/hotspot/cpu/x86/assembler_x86.cpp | 10 + src/hotspot/cpu/x86/assembler_x86.hpp | 2 + src/hotspot/cpu/x86/macroAssembler_x86.hpp | 3 + .../cpu/x86/macroAssembler_x86_md5.cpp | 204 ++++++++++++++++++ src/hotspot/cpu/x86/stubGenerator_x86_32.cpp | 44 ++++ src/hotspot/cpu/x86/stubGenerator_x86_64.cpp | 41 ++++ src/hotspot/cpu/x86/vm_version_x86.cpp | 4 + src/hotspot/share/classfile/vmSymbols.cpp | 7 +- src/hotspot/share/classfile/vmSymbols.hpp | 8 +- src/hotspot/share/opto/c2compiler.cpp | 1 + src/hotspot/share/opto/escape.cpp | 2 + src/hotspot/share/opto/library_call.cpp | 170 ++++++++------- src/hotspot/share/opto/runtime.cpp | 4 +- src/hotspot/share/opto/runtime.hpp | 4 +- src/hotspot/share/runtime/globals.hpp | 3 + src/hotspot/share/runtime/stubRoutines.cpp | 4 +- src/hotspot/share/runtime/stubRoutines.hpp | 6 +- .../classes/sun/security/provider/MD5.java | 25 ++- .../classes/sun/security/provider/SHA.java | 6 +- .../hotspot/test/CheckGraalIntrinsics.java | 13 ++ .../sha/{TestSHA.java => TestDigest.java} | 76 ++++--- ...ptionsBase.java => DigestOptionsBase.java} | 38 ++-- ...tUseMD5IntrinsicsOptionOnSupportedCPU.java | 48 +++++ ...seMD5IntrinsicsOptionOnUnsupportedCPU.java | 56 +++++ ...UseSHA1IntrinsicsOptionOnSupportedCPU.java | 4 +- ...eSHA1IntrinsicsOptionOnUnsupportedCPU.java | 10 +- ...eSHA256IntrinsicsOptionOnSupportedCPU.java | 4 +- ...HA256IntrinsicsOptionOnUnsupportedCPU.java | 10 +- ...eSHA512IntrinsicsOptionOnSupportedCPU.java | 4 +- ...HA512IntrinsicsOptionOnUnsupportedCPU.java | 10 +- .../cli/TestUseSHAOptionOnSupportedCPU.java | 6 +- .../cli/TestUseSHAOptionOnUnsupportedCPU.java | 10 +- .../testcases/GenericTestCaseForOtherCPU.java | 41 ++-- .../GenericTestCaseForSupportedCPU.java | 127 ++++++----- ...nericTestCaseForUnsupportedAArch64CPU.java | 77 ++++--- .../GenericTestCaseForUnsupportedX86CPU.java | 55 +++-- ...sicsSpecificTestCaseForUnsupportedCPU.java | 12 +- ...UseSHASpecificTestCaseForSupportedCPU.java | 68 +++--- ...eSHASpecificTestCaseForUnsupportedCPU.java | 42 ++-- ...estBase.java => DigestSanityTestBase.java} | 20 +- .../sha/sanity/TestMD5Intrinsics.java | 65 ++++++ .../sanity/TestMD5MultiBlockIntrinsics.java | 73 +++++++ .../sha/sanity/TestSHA1Intrinsics.java | 4 +- .../sanity/TestSHA1MultiBlockIntrinsics.java | 8 +- .../sha/sanity/TestSHA256Intrinsics.java | 4 +- .../TestSHA256MultiBlockIntrinsics.java | 12 +- .../sha/sanity/TestSHA512Intrinsics.java | 4 +- .../TestSHA512MultiBlockIntrinsics.java | 12 +- .../sha/predicate/IntrinsicPredicates.java | 11 + 53 files changed, 1110 insertions(+), 388 deletions(-) create mode 100644 src/hotspot/cpu/x86/macroAssembler_x86_md5.cpp rename test/hotspot/jtreg/compiler/intrinsics/sha/{TestSHA.java => TestDigest.java} (71%) rename test/hotspot/jtreg/compiler/intrinsics/sha/cli/{SHAOptionsBase.java => DigestOptionsBase.java} (79%) create mode 100644 test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnSupportedCPU.java create mode 100644 test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnUnsupportedCPU.java rename test/hotspot/jtreg/compiler/intrinsics/sha/sanity/{SHASanityTestBase.java => DigestSanityTestBase.java} (85%) create mode 100644 test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java create mode 100644 test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java diff --git a/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp b/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp index f302f798271..25d6b853378 100644 --- a/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp @@ -358,6 +358,11 @@ void VM_Version::get_processor_features() { FLAG_SET_DEFAULT(UseFMA, true); } + if (UseMD5Intrinsics) { + warning("MD5 intrinsics are not available on this CPU"); + FLAG_SET_DEFAULT(UseMD5Intrinsics, false); + } + if (auxv & (HWCAP_SHA1 | HWCAP_SHA2)) { if (FLAG_IS_DEFAULT(UseSHA)) { FLAG_SET_DEFAULT(UseSHA, true); diff --git a/src/hotspot/cpu/arm/vm_version_arm_32.cpp b/src/hotspot/cpu/arm/vm_version_arm_32.cpp index bec10b5afdd..7d1949d2e2b 100644 --- a/src/hotspot/cpu/arm/vm_version_arm_32.cpp +++ b/src/hotspot/cpu/arm/vm_version_arm_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -209,6 +209,11 @@ void VM_Version::initialize() { FLAG_SET_DEFAULT(UseFMA, false); } + if (UseMD5Intrinsics) { + warning("MD5 intrinsics are not available on this CPU"); + FLAG_SET_DEFAULT(UseMD5Intrinsics, false); + } + if (UseSHA) { warning("SHA instructions are not available on this CPU"); FLAG_SET_DEFAULT(UseSHA, false); diff --git a/src/hotspot/cpu/ppc/vm_version_ppc.cpp b/src/hotspot/cpu/ppc/vm_version_ppc.cpp index a62255eb72f..306db53018a 100644 --- a/src/hotspot/cpu/ppc/vm_version_ppc.cpp +++ b/src/hotspot/cpu/ppc/vm_version_ppc.cpp @@ -284,6 +284,11 @@ void VM_Version::initialize() { FLAG_SET_DEFAULT(UseFMA, true); } + if (UseMD5Intrinsics) { + warning("MD5 intrinsics are not available on this CPU"); + FLAG_SET_DEFAULT(UseMD5Intrinsics, false); + } + if (has_vshasig()) { if (FLAG_IS_DEFAULT(UseSHA)) { UseSHA = true; diff --git a/src/hotspot/cpu/s390/vm_version_s390.cpp b/src/hotspot/cpu/s390/vm_version_s390.cpp index 3aab4203179..663b8d1dc44 100644 --- a/src/hotspot/cpu/s390/vm_version_s390.cpp +++ b/src/hotspot/cpu/s390/vm_version_s390.cpp @@ -1,6 +1,6 @@ /* - * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2016, 2019 SAP SE. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -179,6 +179,11 @@ void VM_Version::initialize() { FLAG_SET_DEFAULT(UseFMA, true); } + if (UseMD5Intrinsics) { + warning("MD5 intrinsics are not available on this CPU"); + FLAG_SET_DEFAULT(UseMD5Intrinsics, false); + } + // On z/Architecture, we take UseSHA as the general switch to enable/disable the SHA intrinsics. // The specific switches UseSHAxxxIntrinsics will then be set depending on the actual // machine capabilities. diff --git a/src/hotspot/cpu/x86/assembler_x86.cpp b/src/hotspot/cpu/x86/assembler_x86.cpp index 1cb1df54968..20b0dbc4f89 100644 --- a/src/hotspot/cpu/x86/assembler_x86.cpp +++ b/src/hotspot/cpu/x86/assembler_x86.cpp @@ -4301,6 +4301,16 @@ void Assembler::ret(int imm16) { } } +void Assembler::roll(Register dst, int imm8) { + assert(isShiftCount(imm8 >> 1), "illegal shift count"); + int encode = prefix_and_encode(dst->encoding()); + if (imm8 == 1) { + emit_int16((unsigned char)0xD1, (0xC0 | encode)); + } else { + emit_int24((unsigned char)0xC1, (0xc0 | encode), imm8); + } +} + void Assembler::sahf() { #ifdef _LP64 // Not supported in 64bit mode diff --git a/src/hotspot/cpu/x86/assembler_x86.hpp b/src/hotspot/cpu/x86/assembler_x86.hpp index 01d92f896f3..38637cc2a32 100644 --- a/src/hotspot/cpu/x86/assembler_x86.hpp +++ b/src/hotspot/cpu/x86/assembler_x86.hpp @@ -1827,6 +1827,8 @@ private: void ret(int imm16); + void roll(Register dst, int imm8); + #ifdef _LP64 void rorq(Register dst, int imm8); void rorxq(Register dst, Register src, int imm8); diff --git a/src/hotspot/cpu/x86/macroAssembler_x86.hpp b/src/hotspot/cpu/x86/macroAssembler_x86.hpp index a939e7794d4..d77d74311a6 100644 --- a/src/hotspot/cpu/x86/macroAssembler_x86.hpp +++ b/src/hotspot/cpu/x86/macroAssembler_x86.hpp @@ -956,6 +956,9 @@ public: #endif + void fast_md5(Register buf, Address state, Address ofs, Address limit, + bool multi_block); + void fast_sha1(XMMRegister abcd, XMMRegister e0, XMMRegister e1, XMMRegister msg0, XMMRegister msg1, XMMRegister msg2, XMMRegister msg3, XMMRegister shuf_mask, Register buf, Register state, Register ofs, Register limit, Register rsp, diff --git a/src/hotspot/cpu/x86/macroAssembler_x86_md5.cpp b/src/hotspot/cpu/x86/macroAssembler_x86_md5.cpp new file mode 100644 index 00000000000..506147166de --- /dev/null +++ b/src/hotspot/cpu/x86/macroAssembler_x86_md5.cpp @@ -0,0 +1,204 @@ +/* + * Copyright (c) 2020 Microsoft Corporation. All rights reserved. + * 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. + * + */ + +/* + * Copyright (c) 2017 Project Nayuki. (MIT License) + * https://www.nayuki.io/page/fast-md5-hash-implementation-in-x86-assembly + * + * Permission is hereby granted, free of charge, to any person obtaining a copy of + * this software and associated documentation files (the "Software"), to deal in + * the Software without restriction, including without limitation the rights to + * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of + * the Software, and to permit persons to whom the Software is furnished to do so, + * subject to the following conditions: + * - The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * - The Software is provided "as is", without warranty of any kind, express or + * implied, including but not limited to the warranties of merchantability, + * fitness for a particular purpose and noninfringement. In no event shall the + * authors or copyright holders be liable for any claim, damages or other + * liability, whether in an action of contract, tort or otherwise, arising from, + * out of or in connection with the Software or the use or other dealings in the + * Software. + */ + +#include "precompiled.hpp" +#include "asm/assembler.hpp" +#include "asm/assembler.inline.hpp" +#include "runtime/stubRoutines.hpp" +#include "macroAssembler_x86.hpp" + +// int com.sun.security.provider.MD5.implCompress0(byte[] b, int ofs) +void MacroAssembler::fast_md5(Register buf, Address state, Address ofs, Address limit, bool multi_block) { + + Label start, done_hash, loop0; + + bind(start); + + bind(loop0); + + // Save hash values for addition after rounds + movptr(rdi, state); + movl(rax, Address(rdi, 0)); + movl(rbx, Address(rdi, 4)); + movl(rcx, Address(rdi, 8)); + movl(rdx, Address(rdi, 12)); + +#define FF(r1, r2, r3, r4, k, s, t) \ + movl(rsi, r3); \ + addl(r1, Address(buf, k*4)); \ + xorl(rsi, r4); \ + andl(rsi, r2); \ + xorl(rsi, r4); \ + leal(r1, Address(r1, rsi, Address::times_1, t)); \ + roll(r1, s); \ + addl(r1, r2); + +#define GG(r1, r2, r3, r4, k, s, t) \ + movl(rsi, r4); \ + movl(rdi, r4); \ + addl(r1, Address(buf, k*4)); \ + notl(rsi); \ + andl(rdi, r2); \ + andl(rsi, r3); \ + orl(rsi, rdi); \ + leal(r1, Address(r1, rsi, Address::times_1, t)); \ + roll(r1, s); \ + addl(r1, r2); + +#define HH(r1, r2, r3, r4, k, s, t) \ + movl(rsi, r3); \ + addl(r1, Address(buf, k*4)); \ + xorl(rsi, r4); \ + xorl(rsi, r2); \ + leal(r1, Address(r1, rsi, Address::times_1, t)); \ + roll(r1, s); \ + addl(r1, r2); + +#define II(r1, r2, r3, r4, k, s, t) \ + movl(rsi, r4); \ + notl(rsi); \ + addl(r1, Address(buf, k*4)); \ + orl(rsi, r2); \ + xorl(rsi, r3); \ + leal(r1, Address(r1, rsi, Address::times_1, t)); \ + roll(r1, s); \ + addl(r1, r2); + + // Round 1 + FF(rax, rbx, rcx, rdx, 0, 7, 0xd76aa478) + FF(rdx, rax, rbx, rcx, 1, 12, 0xe8c7b756) + FF(rcx, rdx, rax, rbx, 2, 17, 0x242070db) + FF(rbx, rcx, rdx, rax, 3, 22, 0xc1bdceee) + FF(rax, rbx, rcx, rdx, 4, 7, 0xf57c0faf) + FF(rdx, rax, rbx, rcx, 5, 12, 0x4787c62a) + FF(rcx, rdx, rax, rbx, 6, 17, 0xa8304613) + FF(rbx, rcx, rdx, rax, 7, 22, 0xfd469501) + FF(rax, rbx, rcx, rdx, 8, 7, 0x698098d8) + FF(rdx, rax, rbx, rcx, 9, 12, 0x8b44f7af) + FF(rcx, rdx, rax, rbx, 10, 17, 0xffff5bb1) + FF(rbx, rcx, rdx, rax, 11, 22, 0x895cd7be) + FF(rax, rbx, rcx, rdx, 12, 7, 0x6b901122) + FF(rdx, rax, rbx, rcx, 13, 12, 0xfd987193) + FF(rcx, rdx, rax, rbx, 14, 17, 0xa679438e) + FF(rbx, rcx, rdx, rax, 15, 22, 0x49b40821) + + // Round 2 + GG(rax, rbx, rcx, rdx, 1, 5, 0xf61e2562) + GG(rdx, rax, rbx, rcx, 6, 9, 0xc040b340) + GG(rcx, rdx, rax, rbx, 11, 14, 0x265e5a51) + GG(rbx, rcx, rdx, rax, 0, 20, 0xe9b6c7aa) + GG(rax, rbx, rcx, rdx, 5, 5, 0xd62f105d) + GG(rdx, rax, rbx, rcx, 10, 9, 0x02441453) + GG(rcx, rdx, rax, rbx, 15, 14, 0xd8a1e681) + GG(rbx, rcx, rdx, rax, 4, 20, 0xe7d3fbc8) + GG(rax, rbx, rcx, rdx, 9, 5, 0x21e1cde6) + GG(rdx, rax, rbx, rcx, 14, 9, 0xc33707d6) + GG(rcx, rdx, rax, rbx, 3, 14, 0xf4d50d87) + GG(rbx, rcx, rdx, rax, 8, 20, 0x455a14ed) + GG(rax, rbx, rcx, rdx, 13, 5, 0xa9e3e905) + GG(rdx, rax, rbx, rcx, 2, 9, 0xfcefa3f8) + GG(rcx, rdx, rax, rbx, 7, 14, 0x676f02d9) + GG(rbx, rcx, rdx, rax, 12, 20, 0x8d2a4c8a) + + // Round 3 + HH(rax, rbx, rcx, rdx, 5, 4, 0xfffa3942) + HH(rdx, rax, rbx, rcx, 8, 11, 0x8771f681) + HH(rcx, rdx, rax, rbx, 11, 16, 0x6d9d6122) + HH(rbx, rcx, rdx, rax, 14, 23, 0xfde5380c) + HH(rax, rbx, rcx, rdx, 1, 4, 0xa4beea44) + HH(rdx, rax, rbx, rcx, 4, 11, 0x4bdecfa9) + HH(rcx, rdx, rax, rbx, 7, 16, 0xf6bb4b60) + HH(rbx, rcx, rdx, rax, 10, 23, 0xbebfbc70) + HH(rax, rbx, rcx, rdx, 13, 4, 0x289b7ec6) + HH(rdx, rax, rbx, rcx, 0, 11, 0xeaa127fa) + HH(rcx, rdx, rax, rbx, 3, 16, 0xd4ef3085) + HH(rbx, rcx, rdx, rax, 6, 23, 0x04881d05) + HH(rax, rbx, rcx, rdx, 9, 4, 0xd9d4d039) + HH(rdx, rax, rbx, rcx, 12, 11, 0xe6db99e5) + HH(rcx, rdx, rax, rbx, 15, 16, 0x1fa27cf8) + HH(rbx, rcx, rdx, rax, 2, 23, 0xc4ac5665) + + // Round 4 + II(rax, rbx, rcx, rdx, 0, 6, 0xf4292244) + II(rdx, rax, rbx, rcx, 7, 10, 0x432aff97) + II(rcx, rdx, rax, rbx, 14, 15, 0xab9423a7) + II(rbx, rcx, rdx, rax, 5, 21, 0xfc93a039) + II(rax, rbx, rcx, rdx, 12, 6, 0x655b59c3) + II(rdx, rax, rbx, rcx, 3, 10, 0x8f0ccc92) + II(rcx, rdx, rax, rbx, 10, 15, 0xffeff47d) + II(rbx, rcx, rdx, rax, 1, 21, 0x85845dd1) + II(rax, rbx, rcx, rdx, 8, 6, 0x6fa87e4f) + II(rdx, rax, rbx, rcx, 15, 10, 0xfe2ce6e0) + II(rcx, rdx, rax, rbx, 6, 15, 0xa3014314) + II(rbx, rcx, rdx, rax, 13, 21, 0x4e0811a1) + II(rax, rbx, rcx, rdx, 4, 6, 0xf7537e82) + II(rdx, rax, rbx, rcx, 11, 10, 0xbd3af235) + II(rcx, rdx, rax, rbx, 2, 15, 0x2ad7d2bb) + II(rbx, rcx, rdx, rax, 9, 21, 0xeb86d391) + +#undef FF +#undef GG +#undef HH +#undef II + + // write hash values back in the correct order + movptr(rdi, state); + addl(Address(rdi, 0), rax); + addl(Address(rdi, 4), rbx); + addl(Address(rdi, 8), rcx); + addl(Address(rdi, 12), rdx); + + if (multi_block) { + // increment data pointer and loop if more to process + addptr(buf, 64); + addl(ofs, 64); + movl(rsi, ofs); + cmpl(rsi, limit); + jcc(Assembler::belowEqual, loop0); + movptr(rax, rsi); //return ofs + } + + bind(done_hash); +} diff --git a/src/hotspot/cpu/x86/stubGenerator_x86_32.cpp b/src/hotspot/cpu/x86/stubGenerator_x86_32.cpp index 2d05442a940..c5d0effae0f 100644 --- a/src/hotspot/cpu/x86/stubGenerator_x86_32.cpp +++ b/src/hotspot/cpu/x86/stubGenerator_x86_32.cpp @@ -2884,6 +2884,46 @@ class StubGenerator: public StubCodeGenerator { return start; } + // ofs and limit are use for multi-block byte array. + // int com.sun.security.provider.MD5.implCompress(byte[] b, int ofs) + address generate_md5_implCompress(bool multi_block, const char *name) { + __ align(CodeEntryAlignment); + StubCodeMark mark(this, "StubRoutines", name); + address start = __ pc(); + + const Register buf_param = rbp; + const Address state_param(rsp, 0 * wordSize); + const Address ofs_param (rsp, 1 * wordSize); + const Address limit_param(rsp, 2 * wordSize); + + __ enter(); + __ push(rbx); + __ push(rdi); + __ push(rsi); + __ push(rbp); + __ subptr(rsp, 3 * wordSize); + + __ movptr(rsi, Address(rbp, 8 + 4)); + __ movptr(state_param, rsi); + if (multi_block) { + __ movptr(rsi, Address(rbp, 8 + 8)); + __ movptr(ofs_param, rsi); + __ movptr(rsi, Address(rbp, 8 + 12)); + __ movptr(limit_param, rsi); + } + __ movptr(buf_param, Address(rbp, 8 + 0)); // do it last because it override rbp + __ fast_md5(buf_param, state_param, ofs_param, limit_param, multi_block); + + __ addptr(rsp, 3 * wordSize); + __ pop(rbp); + __ pop(rsi); + __ pop(rdi); + __ pop(rbx); + __ leave(); + __ ret(0); + return start; + } + address generate_upper_word_mask() { __ align(64); StubCodeMark mark(this, "StubRoutines", "upper_word_mask"); @@ -3886,6 +3926,10 @@ class StubGenerator: public StubCodeGenerator { StubRoutines::_counterMode_AESCrypt = generate_counterMode_AESCrypt_Parallel(); } + if (UseMD5Intrinsics) { + StubRoutines::_md5_implCompress = generate_md5_implCompress(false, "md5_implCompress"); + StubRoutines::_md5_implCompressMB = generate_md5_implCompress(true, "md5_implCompressMB"); + } if (UseSHA1Intrinsics) { StubRoutines::x86::_upper_word_mask_addr = generate_upper_word_mask(); StubRoutines::x86::_shuffle_byte_flip_mask_addr = generate_shuffle_byte_flip_mask(); diff --git a/src/hotspot/cpu/x86/stubGenerator_x86_64.cpp b/src/hotspot/cpu/x86/stubGenerator_x86_64.cpp index a127f48bf6c..3d2c7671304 100644 --- a/src/hotspot/cpu/x86/stubGenerator_x86_64.cpp +++ b/src/hotspot/cpu/x86/stubGenerator_x86_64.cpp @@ -3646,6 +3646,43 @@ class StubGenerator: public StubCodeGenerator { return start; } + // ofs and limit are use for multi-block byte array. + // int com.sun.security.provider.MD5.implCompress(byte[] b, int ofs) + address generate_md5_implCompress(bool multi_block, const char *name) { + __ align(CodeEntryAlignment); + StubCodeMark mark(this, "StubRoutines", name); + address start = __ pc(); + + const Register buf_param = r15; + const Address state_param(rsp, 0 * wordSize); + const Address ofs_param (rsp, 1 * wordSize ); + const Address limit_param(rsp, 1 * wordSize + 4); + + __ enter(); + __ push(rbx); + __ push(rdi); + __ push(rsi); + __ push(r15); + __ subptr(rsp, 2 * wordSize); + + __ movptr(buf_param, c_rarg0); + __ movptr(state_param, c_rarg1); + if (multi_block) { + __ movl(ofs_param, c_rarg2); + __ movl(limit_param, c_rarg3); + } + __ fast_md5(buf_param, state_param, ofs_param, limit_param, multi_block); + + __ addptr(rsp, 2 * wordSize); + __ pop(r15); + __ pop(rsi); + __ pop(rdi); + __ pop(rbx); + __ leave(); + __ ret(0); + return start; + } + address generate_upper_word_mask() { __ align(64); StubCodeMark mark(this, "StubRoutines", "upper_word_mask"); @@ -6327,6 +6364,10 @@ address generate_avx_ghash_processBlocks() { } } + if (UseMD5Intrinsics) { + StubRoutines::_md5_implCompress = generate_md5_implCompress(false, "md5_implCompress"); + StubRoutines::_md5_implCompressMB = generate_md5_implCompress(true, "md5_implCompressMB"); + } if (UseSHA1Intrinsics) { StubRoutines::x86::_upper_word_mask_addr = generate_upper_word_mask(); StubRoutines::x86::_shuffle_byte_flip_mask_addr = generate_shuffle_byte_flip_mask(); diff --git a/src/hotspot/cpu/x86/vm_version_x86.cpp b/src/hotspot/cpu/x86/vm_version_x86.cpp index b57507ed617..42289037576 100644 --- a/src/hotspot/cpu/x86/vm_version_x86.cpp +++ b/src/hotspot/cpu/x86/vm_version_x86.cpp @@ -945,6 +945,10 @@ void VM_Version::get_processor_features() { FLAG_SET_DEFAULT(UseFMA, false); } + if (FLAG_IS_DEFAULT(UseMD5Intrinsics)) { + UseMD5Intrinsics = true; + } + if (supports_sha() LP64_ONLY(|| supports_avx2() && supports_bmi2())) { if (FLAG_IS_DEFAULT(UseSHA)) { UseSHA = true; diff --git a/src/hotspot/share/classfile/vmSymbols.cpp b/src/hotspot/share/classfile/vmSymbols.cpp index 1b33b8c1cf4..32ce4aa3bc1 100644 --- a/src/hotspot/share/classfile/vmSymbols.cpp +++ b/src/hotspot/share/classfile/vmSymbols.cpp @@ -455,7 +455,7 @@ int vmIntrinsics::predicates_needed(vmIntrinsics::ID id) { case vmIntrinsics::_counterMode_AESCrypt: return 1; case vmIntrinsics::_digestBase_implCompressMB: - return 3; + return 4; default: return 0; } @@ -699,6 +699,9 @@ bool vmIntrinsics::disabled_by_jvm_flags(vmIntrinsics::ID id) { case vmIntrinsics::_counterMode_AESCrypt: if (!UseAESCTRIntrinsics) return true; break; + case vmIntrinsics::_md5_implCompress: + if (!UseMD5Intrinsics) return true; + break; case vmIntrinsics::_sha_implCompress: if (!UseSHA1Intrinsics) return true; break; @@ -709,7 +712,7 @@ bool vmIntrinsics::disabled_by_jvm_flags(vmIntrinsics::ID id) { if (!UseSHA512Intrinsics) return true; break; case vmIntrinsics::_digestBase_implCompressMB: - if (!(UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics)) return true; + if (!(UseMD5Intrinsics || UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics)) return true; break; case vmIntrinsics::_ghash_processBlocks: if (!UseGHASHIntrinsics) return true; diff --git a/src/hotspot/share/classfile/vmSymbols.hpp b/src/hotspot/share/classfile/vmSymbols.hpp index 44915b4320f..ab0a108b240 100644 --- a/src/hotspot/share/classfile/vmSymbols.hpp +++ b/src/hotspot/share/classfile/vmSymbols.hpp @@ -1044,11 +1044,15 @@ do_intrinsic(_counterMode_AESCrypt, com_sun_crypto_provider_counterMode, crypt_name, byteArray_int_int_byteArray_int_signature, F_R) \ do_name( crypt_name, "implCrypt") \ \ + /* support for sun.security.provider.MD5 */ \ + do_class(sun_security_provider_md5, "sun/security/provider/MD5") \ + do_intrinsic(_md5_implCompress, sun_security_provider_md5, implCompress_name, implCompress_signature, F_R) \ + do_name( implCompress_name, "implCompress0") \ + do_signature(implCompress_signature, "([BI)V") \ + \ /* support for sun.security.provider.SHA */ \ do_class(sun_security_provider_sha, "sun/security/provider/SHA") \ do_intrinsic(_sha_implCompress, sun_security_provider_sha, implCompress_name, implCompress_signature, F_R) \ - do_name( implCompress_name, "implCompress0") \ - do_signature(implCompress_signature, "([BI)V") \ \ /* support for sun.security.provider.SHA2 */ \ do_class(sun_security_provider_sha2, "sun/security/provider/SHA2") \ diff --git a/src/hotspot/share/opto/c2compiler.cpp b/src/hotspot/share/opto/c2compiler.cpp index 6fa827018f4..e1ac66968a4 100644 --- a/src/hotspot/share/opto/c2compiler.cpp +++ b/src/hotspot/share/opto/c2compiler.cpp @@ -620,6 +620,7 @@ bool C2Compiler::is_intrinsic_supported(const methodHandle& method, bool is_virt case vmIntrinsics::_electronicCodeBook_encryptAESCrypt: case vmIntrinsics::_electronicCodeBook_decryptAESCrypt: case vmIntrinsics::_counterMode_AESCrypt: + case vmIntrinsics::_md5_implCompress: case vmIntrinsics::_sha_implCompress: case vmIntrinsics::_sha2_implCompress: case vmIntrinsics::_sha5_implCompress: diff --git a/src/hotspot/share/opto/escape.cpp b/src/hotspot/share/opto/escape.cpp index 5d0147ba04e..681fdb82510 100644 --- a/src/hotspot/share/opto/escape.cpp +++ b/src/hotspot/share/opto/escape.cpp @@ -993,6 +993,8 @@ void ConnectionGraph::process_call_arguments(CallNode *call) { strcmp(call->as_CallLeaf()->_name, "counterMode_AESCrypt") == 0 || strcmp(call->as_CallLeaf()->_name, "ghash_processBlocks") == 0 || strcmp(call->as_CallLeaf()->_name, "encodeBlock") == 0 || + strcmp(call->as_CallLeaf()->_name, "md5_implCompress") == 0 || + strcmp(call->as_CallLeaf()->_name, "md5_implCompressMB") == 0 || strcmp(call->as_CallLeaf()->_name, "sha1_implCompress") == 0 || strcmp(call->as_CallLeaf()->_name, "sha1_implCompressMB") == 0 || strcmp(call->as_CallLeaf()->_name, "sha256_implCompress") == 0 || diff --git a/src/hotspot/share/opto/library_call.cpp b/src/hotspot/share/opto/library_call.cpp index 87ac8964c54..d8e09638e01 100644 --- a/src/hotspot/share/opto/library_call.cpp +++ b/src/hotspot/share/opto/library_call.cpp @@ -305,13 +305,13 @@ class LibraryCallKit : public GraphKit { Node* get_original_key_start_from_aescrypt_object(Node* aescrypt_object); bool inline_ghash_processBlocks(); bool inline_base64_encodeBlock(); - bool inline_sha_implCompress(vmIntrinsics::ID id); + bool inline_digestBase_implCompress(vmIntrinsics::ID id); bool inline_digestBase_implCompressMB(int predicate); - bool inline_sha_implCompressMB(Node* digestBaseObj, ciInstanceKlass* instklass_SHA, - bool long_state, address stubAddr, const char *stubName, - Node* src_start, Node* ofs, Node* limit); - Node* get_state_from_sha_object(Node *sha_object); - Node* get_state_from_sha5_object(Node *sha_object); + bool inline_digestBase_implCompressMB(Node* digestBaseObj, ciInstanceKlass* instklass, + bool long_state, address stubAddr, const char *stubName, + Node* src_start, Node* ofs, Node* limit); + Node* get_state_from_digest_object(Node *digestBase_object); + Node* get_long_state_from_digest_object(Node *digestBase_object); Node* inline_digestBase_implCompressMB_predicate(int predicate); bool inline_encodeISOArray(); bool inline_updateCRC32(); @@ -826,10 +826,11 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_counterMode_AESCrypt: return inline_counterMode_AESCrypt(intrinsic_id()); + case vmIntrinsics::_md5_implCompress: case vmIntrinsics::_sha_implCompress: case vmIntrinsics::_sha2_implCompress: case vmIntrinsics::_sha5_implCompress: - return inline_sha_implCompress(intrinsic_id()); + return inline_digestBase_implCompress(intrinsic_id()); case vmIntrinsics::_digestBase_implCompressMB: return inline_digestBase_implCompressMB(predicate); @@ -6412,7 +6413,10 @@ bool LibraryCallKit::inline_base64_encodeBlock() { return true; } -//------------------------------inline_sha_implCompress----------------------- +//------------------------------inline_digestBase_implCompress----------------------- +// +// Calculate MD5 for single-block byte[] array. +// void com.sun.security.provider.MD5.implCompress(byte[] buf, int ofs) // // Calculate SHA (i.e., SHA-1) for single-block byte[] array. // void com.sun.security.provider.SHA.implCompress(byte[] buf, int ofs) @@ -6423,12 +6427,12 @@ bool LibraryCallKit::inline_base64_encodeBlock() { // Calculate SHA5 (i.e., SHA-384 or SHA-512) for single-block byte[] array. // void com.sun.security.provider.SHA5.implCompress(byte[] buf, int ofs) // -bool LibraryCallKit::inline_sha_implCompress(vmIntrinsics::ID id) { +bool LibraryCallKit::inline_digestBase_implCompress(vmIntrinsics::ID id) { assert(callee()->signature()->size() == 2, "sha_implCompress has 2 parameters"); - Node* sha_obj = argument(0); - Node* src = argument(1); // type oop - Node* ofs = argument(2); // type int + Node* digestBase_obj = argument(0); + Node* src = argument(1); // type oop + Node* ofs = argument(2); // type int const Type* src_type = src->Value(&_gvn); const TypeAryPtr* top_src = src_type->isa_aryptr(); @@ -6449,21 +6453,27 @@ bool LibraryCallKit::inline_sha_implCompress(vmIntrinsics::ID id) { const char *stubName; switch(id) { + case vmIntrinsics::_md5_implCompress: + assert(UseMD5Intrinsics, "need MD5 instruction support"); + state = get_state_from_digest_object(digestBase_obj); + stubAddr = StubRoutines::md5_implCompress(); + stubName = "md5_implCompress"; + break; case vmIntrinsics::_sha_implCompress: assert(UseSHA1Intrinsics, "need SHA1 instruction support"); - state = get_state_from_sha_object(sha_obj); + state = get_state_from_digest_object(digestBase_obj); stubAddr = StubRoutines::sha1_implCompress(); stubName = "sha1_implCompress"; break; case vmIntrinsics::_sha2_implCompress: assert(UseSHA256Intrinsics, "need SHA256 instruction support"); - state = get_state_from_sha_object(sha_obj); + state = get_state_from_digest_object(digestBase_obj); stubAddr = StubRoutines::sha256_implCompress(); stubName = "sha256_implCompress"; break; case vmIntrinsics::_sha5_implCompress: assert(UseSHA512Intrinsics, "need SHA512 instruction support"); - state = get_state_from_sha5_object(sha_obj); + state = get_long_state_from_digest_object(digestBase_obj); stubAddr = StubRoutines::sha512_implCompress(); stubName = "sha512_implCompress"; break; @@ -6477,7 +6487,7 @@ bool LibraryCallKit::inline_sha_implCompress(vmIntrinsics::ID id) { if (stubAddr == NULL) return false; // Call the stub. - Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::sha_implCompress_Type(), + Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::digestBase_implCompress_Type(), stubAddr, stubName, TypePtr::BOTTOM, src_start, state); @@ -6486,13 +6496,13 @@ bool LibraryCallKit::inline_sha_implCompress(vmIntrinsics::ID id) { //------------------------------inline_digestBase_implCompressMB----------------------- // -// Calculate SHA/SHA2/SHA5 for multi-block byte[] array. +// Calculate MD5/SHA/SHA2/SHA5 for multi-block byte[] array. // int com.sun.security.provider.DigestBase.implCompressMultiBlock(byte[] b, int ofs, int limit) // bool LibraryCallKit::inline_digestBase_implCompressMB(int predicate) { - assert(UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics, - "need SHA1/SHA256/SHA512 instruction support"); - assert((uint)predicate < 3, "sanity"); + assert(UseMD5Intrinsics || UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics, + "need MD5/SHA1/SHA256/SHA512 instruction support"); + assert((uint)predicate < 4, "sanity"); assert(callee()->signature()->size() == 3, "digestBase_implCompressMB has 3 parameters"); Node* digestBase_obj = argument(0); // The receiver was checked for NULL already. @@ -6515,38 +6525,45 @@ bool LibraryCallKit::inline_digestBase_implCompressMB(int predicate) { src = must_be_not_null(src, false); Node* src_start = array_element_address(src, ofs, src_elem); - const char* klass_SHA_name = NULL; + const char* klass_digestBase_name = NULL; const char* stub_name = NULL; address stub_addr = NULL; bool long_state = false; switch (predicate) { case 0: + if (vmIntrinsics::is_intrinsic_available(vmIntrinsics::_md5_implCompress)) { + klass_digestBase_name = "sun/security/provider/MD5"; + stub_name = "md5_implCompressMB"; + stub_addr = StubRoutines::md5_implCompressMB(); + } + break; + case 1: if (vmIntrinsics::is_intrinsic_available(vmIntrinsics::_sha_implCompress)) { - klass_SHA_name = "sun/security/provider/SHA"; + klass_digestBase_name = "sun/security/provider/SHA"; stub_name = "sha1_implCompressMB"; stub_addr = StubRoutines::sha1_implCompressMB(); } break; - case 1: + case 2: if (vmIntrinsics::is_intrinsic_available(vmIntrinsics::_sha2_implCompress)) { - klass_SHA_name = "sun/security/provider/SHA2"; + klass_digestBase_name = "sun/security/provider/SHA2"; stub_name = "sha256_implCompressMB"; stub_addr = StubRoutines::sha256_implCompressMB(); } break; - case 2: + case 3: if (vmIntrinsics::is_intrinsic_available(vmIntrinsics::_sha5_implCompress)) { - klass_SHA_name = "sun/security/provider/SHA5"; + klass_digestBase_name = "sun/security/provider/SHA5"; stub_name = "sha512_implCompressMB"; stub_addr = StubRoutines::sha512_implCompressMB(); long_state = true; } break; default: - fatal("unknown SHA intrinsic predicate: %d", predicate); + fatal("unknown DigestBase intrinsic predicate: %d", predicate); } - if (klass_SHA_name != NULL) { + if (klass_digestBase_name != NULL) { assert(stub_addr != NULL, "Stub is generated"); if (stub_addr == NULL) return false; @@ -6555,27 +6572,28 @@ bool LibraryCallKit::inline_digestBase_implCompressMB(int predicate) { assert(tinst != NULL, "digestBase_obj is not instance???"); assert(tinst->klass()->is_loaded(), "DigestBase is not loaded"); - ciKlass* klass_SHA = tinst->klass()->as_instance_klass()->find_klass(ciSymbol::make(klass_SHA_name)); - assert(klass_SHA->is_loaded(), "predicate checks that this class is loaded"); - ciInstanceKlass* instklass_SHA = klass_SHA->as_instance_klass(); - return inline_sha_implCompressMB(digestBase_obj, instklass_SHA, long_state, stub_addr, stub_name, src_start, ofs, limit); + ciKlass* klass_digestBase = tinst->klass()->as_instance_klass()->find_klass(ciSymbol::make(klass_digestBase_name)); + assert(klass_digestBase->is_loaded(), "predicate checks that this class is loaded"); + ciInstanceKlass* instklass_digestBase = klass_digestBase->as_instance_klass(); + return inline_digestBase_implCompressMB(digestBase_obj, instklass_digestBase, long_state, stub_addr, stub_name, src_start, ofs, limit); } return false; } -//------------------------------inline_sha_implCompressMB----------------------- -bool LibraryCallKit::inline_sha_implCompressMB(Node* digestBase_obj, ciInstanceKlass* instklass_SHA, - bool long_state, address stubAddr, const char *stubName, - Node* src_start, Node* ofs, Node* limit) { - const TypeKlassPtr* aklass = TypeKlassPtr::make(instklass_SHA); + +//------------------------------inline_digestBase_implCompressMB----------------------- +bool LibraryCallKit::inline_digestBase_implCompressMB(Node* digestBase_obj, ciInstanceKlass* instklass_digestBase, + bool long_state, address stubAddr, const char *stubName, + Node* src_start, Node* ofs, Node* limit) { + const TypeKlassPtr* aklass = TypeKlassPtr::make(instklass_digestBase); const TypeOopPtr* xtype = aklass->as_instance_type(); - Node* sha_obj = new CheckCastPPNode(control(), digestBase_obj, xtype); - sha_obj = _gvn.transform(sha_obj); + Node* digest_obj = new CheckCastPPNode(control(), digestBase_obj, xtype); + digest_obj = _gvn.transform(digest_obj); Node* state; if (long_state) { - state = get_state_from_sha5_object(sha_obj); + state = get_long_state_from_digest_object(digest_obj); } else { - state = get_state_from_sha_object(sha_obj); + state = get_state_from_digest_object(digest_obj); } if (state == NULL) return false; @@ -6591,37 +6609,37 @@ bool LibraryCallKit::inline_sha_implCompressMB(Node* digestBase_obj, ciInstanceK return true; } -//------------------------------get_state_from_sha_object----------------------- -Node * LibraryCallKit::get_state_from_sha_object(Node *sha_object) { - Node* sha_state = load_field_from_object(sha_object, "state", "[I", /*is_exact*/ false); - assert (sha_state != NULL, "wrong version of sun.security.provider.SHA/SHA2"); - if (sha_state == NULL) return (Node *) NULL; +//------------------------------get_state_from_digest_object----------------------- +Node * LibraryCallKit::get_state_from_digest_object(Node *digest_object) { + Node* digest_state = load_field_from_object(digest_object, "state", "[I", /*is_exact*/ false); + assert (digest_state != NULL, "wrong version of sun.security.provider.MD5/SHA/SHA2"); + if (digest_state == NULL) return (Node *) NULL; // now have the array, need to get the start address of the state array - Node* state = array_element_address(sha_state, intcon(0), T_INT); + Node* state = array_element_address(digest_state, intcon(0), T_INT); return state; } -//------------------------------get_state_from_sha5_object----------------------- -Node * LibraryCallKit::get_state_from_sha5_object(Node *sha_object) { - Node* sha_state = load_field_from_object(sha_object, "state", "[J", /*is_exact*/ false); - assert (sha_state != NULL, "wrong version of sun.security.provider.SHA5"); - if (sha_state == NULL) return (Node *) NULL; +//------------------------------get_long_state_from_digest_object----------------------- +Node * LibraryCallKit::get_long_state_from_digest_object(Node *digest_object) { + Node* digest_state = load_field_from_object(digest_object, "state", "[J", /*is_exact*/ false); + assert (digest_state != NULL, "wrong version of sun.security.provider.SHA5"); + if (digest_state == NULL) return (Node *) NULL; // now have the array, need to get the start address of the state array - Node* state = array_element_address(sha_state, intcon(0), T_LONG); + Node* state = array_element_address(digest_state, intcon(0), T_LONG); return state; } //----------------------------inline_digestBase_implCompressMB_predicate---------------------------- // Return node representing slow path of predicate check. // the pseudo code we want to emulate with this predicate is: -// if (digestBaseObj instanceof SHA/SHA2/SHA5) do_intrinsic, else do_javapath +// if (digestBaseObj instanceof MD5/SHA/SHA2/SHA5) do_intrinsic, else do_javapath // Node* LibraryCallKit::inline_digestBase_implCompressMB_predicate(int predicate) { - assert(UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics, - "need SHA1/SHA256/SHA512 instruction support"); - assert((uint)predicate < 3, "sanity"); + assert(UseMD5Intrinsics || UseSHA1Intrinsics || UseSHA256Intrinsics || UseSHA512Intrinsics, + "need MD5/SHA1/SHA256/SHA512 instruction support"); + assert((uint)predicate < 4, "sanity"); // The receiver was checked for NULL already. Node* digestBaseObj = argument(0); @@ -6631,44 +6649,50 @@ Node* LibraryCallKit::inline_digestBase_implCompressMB_predicate(int predicate) assert(tinst != NULL, "digestBaseObj is null"); assert(tinst->klass()->is_loaded(), "DigestBase is not loaded"); - const char* klass_SHA_name = NULL; + const char* klass_name = NULL; switch (predicate) { case 0: - if (UseSHA1Intrinsics) { - // we want to do an instanceof comparison against the SHA class - klass_SHA_name = "sun/security/provider/SHA"; + if (UseMD5Intrinsics) { + // we want to do an instanceof comparison against the MD5 class + klass_name = "sun/security/provider/MD5"; } break; case 1: - if (UseSHA256Intrinsics) { - // we want to do an instanceof comparison against the SHA2 class - klass_SHA_name = "sun/security/provider/SHA2"; + if (UseSHA1Intrinsics) { + // we want to do an instanceof comparison against the SHA class + klass_name = "sun/security/provider/SHA"; } break; case 2: + if (UseSHA256Intrinsics) { + // we want to do an instanceof comparison against the SHA2 class + klass_name = "sun/security/provider/SHA2"; + } + break; + case 3: if (UseSHA512Intrinsics) { // we want to do an instanceof comparison against the SHA5 class - klass_SHA_name = "sun/security/provider/SHA5"; + klass_name = "sun/security/provider/SHA5"; } break; default: fatal("unknown SHA intrinsic predicate: %d", predicate); } - ciKlass* klass_SHA = NULL; - if (klass_SHA_name != NULL) { - klass_SHA = tinst->klass()->as_instance_klass()->find_klass(ciSymbol::make(klass_SHA_name)); + ciKlass* klass = NULL; + if (klass_name != NULL) { + klass = tinst->klass()->as_instance_klass()->find_klass(ciSymbol::make(klass_name)); } - if ((klass_SHA == NULL) || !klass_SHA->is_loaded()) { - // if none of SHA/SHA2/SHA5 is loaded, we never take the intrinsic fast path + if ((klass == NULL) || !klass->is_loaded()) { + // if none of MD5/SHA/SHA2/SHA5 is loaded, we never take the intrinsic fast path Node* ctrl = control(); set_control(top()); // no intrinsic path return ctrl; } - ciInstanceKlass* instklass_SHA = klass_SHA->as_instance_klass(); + ciInstanceKlass* instklass = klass->as_instance_klass(); - Node* instofSHA = gen_instanceof(digestBaseObj, makecon(TypeKlassPtr::make(instklass_SHA))); - Node* cmp_instof = _gvn.transform(new CmpINode(instofSHA, intcon(1))); + Node* instof = gen_instanceof(digestBaseObj, makecon(TypeKlassPtr::make(instklass))); + Node* cmp_instof = _gvn.transform(new CmpINode(instof, intcon(1))); Node* bool_instof = _gvn.transform(new BoolNode(cmp_instof, BoolTest::ne)); Node* instof_false = generate_guard(bool_instof, NULL, PROB_MIN); diff --git a/src/hotspot/share/opto/runtime.cpp b/src/hotspot/share/opto/runtime.cpp index a5928ae3178..fa84e3bd0b2 100644 --- a/src/hotspot/share/opto/runtime.cpp +++ b/src/hotspot/share/opto/runtime.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -960,7 +960,7 @@ const TypeFunc* OptoRuntime::counterMode_aescrypt_Type() { /* * void implCompress(byte[] buf, int ofs) */ -const TypeFunc* OptoRuntime::sha_implCompress_Type() { +const TypeFunc* OptoRuntime::digestBase_implCompress_Type() { // create input type (domain) int num_args = 2; int argcnt = num_args; diff --git a/src/hotspot/share/opto/runtime.hpp b/src/hotspot/share/opto/runtime.hpp index c4c62538d67..c0985c6958a 100644 --- a/src/hotspot/share/opto/runtime.hpp +++ b/src/hotspot/share/opto/runtime.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -278,7 +278,7 @@ private: static const TypeFunc* electronicCodeBook_aescrypt_Type(); static const TypeFunc* counterMode_aescrypt_Type(); - static const TypeFunc* sha_implCompress_Type(); + static const TypeFunc* digestBase_implCompress_Type(); static const TypeFunc* digestBase_implCompressMB_Type(); static const TypeFunc* multiplyToLen_Type(); diff --git a/src/hotspot/share/runtime/globals.hpp b/src/hotspot/share/runtime/globals.hpp index b540f74286d..1a1b11cc009 100644 --- a/src/hotspot/share/runtime/globals.hpp +++ b/src/hotspot/share/runtime/globals.hpp @@ -323,6 +323,9 @@ const size_t minimumSymbolTableSize = 1024; diagnostic(bool, UseAESCTRIntrinsics, false, \ "Use intrinsics for the paralleled version of AES/CTR crypto") \ \ + diagnostic(bool, UseMD5Intrinsics, false, \ + "Use intrinsics for MD5 crypto hash function") \ + \ diagnostic(bool, UseSHA1Intrinsics, false, \ "Use intrinsics for SHA-1 crypto hash function. " \ "Requires that UseSHA is enabled.") \ diff --git a/src/hotspot/share/runtime/stubRoutines.cpp b/src/hotspot/share/runtime/stubRoutines.cpp index 5823106f3ef..5fd47ff57ac 100644 --- a/src/hotspot/share/runtime/stubRoutines.cpp +++ b/src/hotspot/share/runtime/stubRoutines.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -138,6 +138,8 @@ address StubRoutines::_counterMode_AESCrypt = NULL; address StubRoutines::_ghash_processBlocks = NULL; address StubRoutines::_base64_encodeBlock = NULL; +address StubRoutines::_md5_implCompress = NULL; +address StubRoutines::_md5_implCompressMB = NULL; address StubRoutines::_sha1_implCompress = NULL; address StubRoutines::_sha1_implCompressMB = NULL; address StubRoutines::_sha256_implCompress = NULL; diff --git a/src/hotspot/share/runtime/stubRoutines.hpp b/src/hotspot/share/runtime/stubRoutines.hpp index 5b7aa2bcf93..6af4caaaa14 100644 --- a/src/hotspot/share/runtime/stubRoutines.hpp +++ b/src/hotspot/share/runtime/stubRoutines.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -220,6 +220,8 @@ class StubRoutines: AllStatic { static address _ghash_processBlocks; static address _base64_encodeBlock; + static address _md5_implCompress; + static address _md5_implCompressMB; static address _sha1_implCompress; static address _sha1_implCompressMB; static address _sha256_implCompress; @@ -397,6 +399,8 @@ class StubRoutines: AllStatic { static address counterMode_AESCrypt() { return _counterMode_AESCrypt; } static address ghash_processBlocks() { return _ghash_processBlocks; } static address base64_encodeBlock() { return _base64_encodeBlock; } + static address md5_implCompress() { return _md5_implCompress; } + static address md5_implCompressMB() { return _md5_implCompressMB; } static address sha1_implCompress() { return _sha1_implCompress; } static address sha1_implCompressMB() { return _sha1_implCompressMB; } static address sha256_implCompress() { return _sha256_implCompress; } diff --git a/src/java.base/share/classes/sun/security/provider/MD5.java b/src/java.base/share/classes/sun/security/provider/MD5.java index c168ace71a3..497e0286cf5 100644 --- a/src/java.base/share/classes/sun/security/provider/MD5.java +++ b/src/java.base/share/classes/sun/security/provider/MD5.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,8 +26,10 @@ package sun.security.provider; import java.util.Arrays; +import java.util.Objects; import static sun.security.provider.ByteArrayAccess.*; +import jdk.internal.HotSpotIntrinsicCandidate; /** * The MD5 class is used to compute an MD5 message digest over a given @@ -147,8 +149,27 @@ public final class MD5 extends DigestBase { * bytes from the buffer, beginning at the specified offset. */ void implCompress(byte[] buf, int ofs) { - b2iLittle64(buf, ofs, x); + implCompressCheck(buf, ofs); + implCompress0(buf, ofs); + } + private void implCompressCheck(byte[] buf, int ofs) { + Objects.requireNonNull(buf); + + // The checks performed by the method 'b2iBig64' + // are sufficient for the case when the method + // 'implCompressImpl' is replaced with a compiler + // intrinsic. + b2iLittle64(buf, ofs, x); + } + + // The method 'implCompress0 seems not to use its parameters. + // The method can, however, be replaced with a compiler intrinsic + // that operates directly on the array 'buf' (starting from + // offset 'ofs') and not on array 'x', therefore 'buf' and 'ofs' + // must be passed as parameter to the method. + @HotSpotIntrinsicCandidate + void implCompress0(byte[] buf, int ofs) { int a = state[0]; int b = state[1]; int c = state[2]; diff --git a/src/java.base/share/classes/sun/security/provider/SHA.java b/src/java.base/share/classes/sun/security/provider/SHA.java index 1eaeaa4ffc3..1dbbb45f131 100644 --- a/src/java.base/share/classes/sun/security/provider/SHA.java +++ b/src/java.base/share/classes/sun/security/provider/SHA.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -134,12 +134,12 @@ public final class SHA extends DigestBase { // The checks performed by the method 'b2iBig64' // are sufficient for the case when the method - // 'implCompressImpl' is replaced with a compiler + // 'implCompress0' is replaced with a compiler // intrinsic. b2iBig64(buf, ofs, W); } - // The method 'implCompressImpl seems not to use its parameters. + // The method 'implCompress0 seems not to use its parameters. // The method can, however, be replaced with a compiler intrinsic // that operates directly on the array 'buf' (starting from // offset 'ofs') and not on array 'W', therefore 'buf' and 'ofs' diff --git a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot.test/src/org/graalvm/compiler/hotspot/test/CheckGraalIntrinsics.java b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot.test/src/org/graalvm/compiler/hotspot/test/CheckGraalIntrinsics.java index c1302421d6f..6d2fdbdbf81 100644 --- a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot.test/src/org/graalvm/compiler/hotspot/test/CheckGraalIntrinsics.java +++ b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot.test/src/org/graalvm/compiler/hotspot/test/CheckGraalIntrinsics.java @@ -423,6 +423,11 @@ public class CheckGraalIntrinsics extends GraalTest { "java/math/BigInteger.shiftRightImplWorker([I[IIII)V"); } + if (isJDK16OrHigher()) { + add(toBeInvestigated, + "sun/security/provider/MD5.implCompress0([BI)V"); + } + if (!config.inlineNotify()) { add(ignore, "java/lang/Object.notify()V"); } @@ -593,6 +598,14 @@ public class CheckGraalIntrinsics extends GraalTest { return JavaVersionUtil.JAVA_SPEC >= 14; } + private static boolean isJDK15OrHigher() { + return JavaVersionUtil.JAVA_SPEC >= 15; + } + + private static boolean isJDK16OrHigher() { + return JavaVersionUtil.JAVA_SPEC >= 16; + } + public interface Refiner { void refine(CheckGraalIntrinsics checker); } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/TestSHA.java b/test/hotspot/jtreg/compiler/intrinsics/sha/TestDigest.java similarity index 71% rename from test/hotspot/jtreg/compiler/intrinsics/sha/TestSHA.java rename to test/hotspot/jtreg/compiler/intrinsics/sha/TestDigest.java index 5ecb7a255f9..4801c3c43fa 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/TestSHA.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/TestDigest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,56 +24,62 @@ /** * @test * @bug 8035968 - * @summary C2 support for SHA on SPARC + * @summary C2 support for MD5/SHA-1/SHA-224/SHA-256/SHA-384/SHA-512 * * @run main/othervm/timeout=600 -Xbatch + * -Dalgorithm=MD5 + * compiler.intrinsics.sha.TestDigest + * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-224 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-256 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-384 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-512 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * * @run main/othervm/timeout=600 -Xbatch + * -Dalgorithm=MD5 -Doffset=1 + * compiler.intrinsics.sha.TestDigest + * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-1 -Doffset=1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-224 -Doffset=1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-256 -Doffset=1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-384 -Doffset=1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-512 -Doffset=1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-1 -Dalgorithm2=SHA-256 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-1 -Dalgorithm2=SHA-512 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-256 -Dalgorithm2=SHA-512 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=SHA-1 -Dalgorithm2=MD5 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest * @run main/othervm/timeout=600 -Xbatch * -Dalgorithm=MD5 -Dalgorithm2=SHA-1 - * compiler.intrinsics.sha.TestSHA + * compiler.intrinsics.sha.TestDigest */ package compiler.intrinsics.sha; @@ -81,7 +87,7 @@ package compiler.intrinsics.sha; import java.security.MessageDigest; import java.util.Arrays; -public class TestSHA { +public class TestDigest { private static final int HASH_LEN = 64; /* up to 512-bit */ private static final int ALIGN = 8; /* for different data alignments */ @@ -94,14 +100,14 @@ public class TestSHA { int iters = (args.length > 0 ? Integer.valueOf(args[0]) : 100000); int warmupIters = (args.length > 1 ? Integer.valueOf(args[1]) : 20000); - testSHA(provider, algorithm, msgSize, offset, iters, warmupIters); + testDigest(provider, algorithm, msgSize, offset, iters, warmupIters); if (algorithm2.equals("") == false) { - testSHA(provider, algorithm2, msgSize, offset, iters, warmupIters); + testDigest(provider, algorithm2, msgSize, offset, iters, warmupIters); } } - public static void testSHA(String provider, String algorithm, int msgSize, + public static void testDigest(String provider, String algorithm, int msgSize, int offset, int iters, int warmupIters) throws Exception { System.out.println("provider = " + provider); System.out.println("algorithm = " + algorithm); @@ -117,27 +123,27 @@ public class TestSHA { } try { - MessageDigest sha = MessageDigest.getInstance(algorithm, provider); + MessageDigest digest = MessageDigest.getInstance(algorithm, provider); /* do once, which doesn't use intrinsics */ - sha.reset(); - sha.update(data, offset, msgSize); - expectedHash = sha.digest(); + digest.reset(); + digest.update(data, offset, msgSize); + expectedHash = digest.digest(); /* warm up */ for (int i = 0; i < warmupIters; i++) { - sha.reset(); - sha.update(data, offset, msgSize); - hash = sha.digest(); + digest.reset(); + digest.update(data, offset, msgSize); + hash = digest.digest(); } /* check result */ if (Arrays.equals(hash, expectedHash) == false) { - System.out.println("TestSHA Error: "); + System.out.println("TestDigest Error: "); showArray(expectedHash, "expectedHash"); showArray(hash, "computedHash"); //System.exit(1); - throw new Exception("TestSHA Error"); + throw new Exception("TestDigest Error"); } else { showArray(hash, "hash"); } @@ -145,15 +151,15 @@ public class TestSHA { /* measure performance */ long start = System.nanoTime(); for (int i = 0; i < iters; i++) { - sha.reset(); - sha.update(data, offset, msgSize); - hash = sha.digest(); + digest.reset(); + digest.update(data, offset, msgSize); + hash = digest.digest(); } long end = System.nanoTime(); double total = (double)(end - start)/1e9; /* in seconds */ double thruput = (double)msgSize*iters/1e6/total; /* in MB/s */ - System.out.println("TestSHA runtime = " + total + " seconds"); - System.out.println("TestSHA throughput = " + thruput + " MB/s"); + System.out.println("TestDigest runtime = " + total + " seconds"); + System.out.println("TestDigest throughput = " + thruput + " MB/s"); System.out.println(); } catch (Exception e) { System.out.println("Exception: " + e); diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/SHAOptionsBase.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/DigestOptionsBase.java similarity index 79% rename from test/hotspot/jtreg/compiler/intrinsics/sha/cli/SHAOptionsBase.java rename to test/hotspot/jtreg/compiler/intrinsics/sha/cli/DigestOptionsBase.java index 22d027e80a1..04a1f311cec 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/SHAOptionsBase.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/DigestOptionsBase.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -35,7 +35,9 @@ import java.util.function.BooleanSupplier; * Instead of using huge complex tests for each option, each test is constructed * from several test cases shared among different tests. */ -public class SHAOptionsBase extends CommandLineOptionTest { +public class DigestOptionsBase extends CommandLineOptionTest { + public static final String USE_MD5_INTRINSICS_OPTION + = "UseMD5Intrinsics"; public static final String USE_SHA_OPTION = "UseSHA"; public static final String USE_SHA1_INTRINSICS_OPTION = "UseSHA1Intrinsics"; @@ -52,6 +54,8 @@ public class SHAOptionsBase extends CommandLineOptionTest { // Note that strings below will be passed to // CommandLineOptionTest.verifySameJVMStartup and thus are regular // expressions, not just a plain strings. + protected static final String MD5_INTRINSICS_ARE_NOT_AVAILABLE + = "Intrinsics for MD5 crypto hash functions not available on this CPU."; protected static final String SHA_INSTRUCTIONS_ARE_NOT_AVAILABLE = "SHA instructions are not available on this CPU"; protected static final String SHA1_INTRINSICS_ARE_NOT_AVAILABLE @@ -75,14 +79,16 @@ public class SHAOptionsBase extends CommandLineOptionTest { */ public static String getWarningForUnsupportedCPU(String optionName) { switch (optionName) { - case SHAOptionsBase.USE_SHA_OPTION: - return SHAOptionsBase.SHA_INSTRUCTIONS_ARE_NOT_AVAILABLE; - case SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION: - return SHAOptionsBase.SHA1_INTRINSICS_ARE_NOT_AVAILABLE; - case SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION: - return SHAOptionsBase.SHA256_INTRINSICS_ARE_NOT_AVAILABLE; - case SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION: - return SHAOptionsBase.SHA512_INTRINSICS_ARE_NOT_AVAILABLE; + case DigestOptionsBase.USE_MD5_INTRINSICS_OPTION: + return DigestOptionsBase.MD5_INTRINSICS_ARE_NOT_AVAILABLE; + case DigestOptionsBase.USE_SHA_OPTION: + return DigestOptionsBase.SHA_INSTRUCTIONS_ARE_NOT_AVAILABLE; + case DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION: + return DigestOptionsBase.SHA1_INTRINSICS_ARE_NOT_AVAILABLE; + case DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION: + return DigestOptionsBase.SHA256_INTRINSICS_ARE_NOT_AVAILABLE; + case DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION: + return DigestOptionsBase.SHA512_INTRINSICS_ARE_NOT_AVAILABLE; default: throw new Error("Unexpected option " + optionName); } @@ -99,20 +105,22 @@ public class SHAOptionsBase extends CommandLineOptionTest { */ public static BooleanSupplier getPredicateForOption(String optionName) { switch (optionName) { - case SHAOptionsBase.USE_SHA_OPTION: + case DigestOptionsBase.USE_MD5_INTRINSICS_OPTION: + return IntrinsicPredicates.MD5_INSTRUCTION_AVAILABLE; + case DigestOptionsBase.USE_SHA_OPTION: return IntrinsicPredicates.ANY_SHA_INSTRUCTION_AVAILABLE; - case SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION: + case DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION: return IntrinsicPredicates.SHA1_INSTRUCTION_AVAILABLE; - case SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION: + case DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION: return IntrinsicPredicates.SHA256_INSTRUCTION_AVAILABLE; - case SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION: + case DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION: return IntrinsicPredicates.SHA512_INSTRUCTION_AVAILABLE; default: throw new Error("Unexpected option " + optionName); } } - public SHAOptionsBase(TestCase... testCases) { + public DigestOptionsBase(TestCase... testCases) { super(Boolean.TRUE::booleanValue); this.testCases = testCases; } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnSupportedCPU.java new file mode 100644 index 00000000000..47a1dcba814 --- /dev/null +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnSupportedCPU.java @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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 + * @bug 8035968 + * @summary Verify UseMD5Intrinsics option processing on supported CPU. + * @library /test/lib testcases / + * @modules java.base/jdk.internal.misc + * java.management + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI + * compiler.intrinsics.sha.cli.TestUseMD5IntrinsicsOptionOnSupportedCPU + */ + +package compiler.intrinsics.sha.cli; + +import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForSupportedCPU; + +public class TestUseMD5IntrinsicsOptionOnSupportedCPU { + public static void main(String args[]) throws Throwable { + new DigestOptionsBase(new GenericTestCaseForSupportedCPU( + DigestOptionsBase.USE_MD5_INTRINSICS_OPTION, /* checkUseSHA = */ false)).test(); + } +} diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnUnsupportedCPU.java new file mode 100644 index 00000000000..719c5790f2b --- /dev/null +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseMD5IntrinsicsOptionOnUnsupportedCPU.java @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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 + * @bug 8035968 + * @summary Verify UseMD5Intrinsics option processing on unsupported CPU. + * @library /test/lib testcases / + * @modules java.base/jdk.internal.misc + * java.management + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI + * compiler.intrinsics.sha.cli.TestUseMD5IntrinsicsOptionOnUnsupportedCPU + */ + +package compiler.intrinsics.sha.cli; + +import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForOtherCPU; +import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForUnsupportedAArch64CPU; +import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForUnsupportedX86CPU; +import compiler.intrinsics.sha.cli.testcases.UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU; + +public class TestUseMD5IntrinsicsOptionOnUnsupportedCPU { + public static void main(String args[]) throws Throwable { + new DigestOptionsBase( + new GenericTestCaseForUnsupportedX86CPU( + DigestOptionsBase.USE_MD5_INTRINSICS_OPTION, /* checkUseSHA = */ false), + new GenericTestCaseForUnsupportedAArch64CPU( + DigestOptionsBase.USE_MD5_INTRINSICS_OPTION, /* checkUseSHA = */ false), + new GenericTestCaseForOtherCPU( + DigestOptionsBase.USE_MD5_INTRINSICS_OPTION, /* checkUseSHA = */ false)).test(); + } +} diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java index 5662b970c95..0542966f15d 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnSupportedCPU.java @@ -42,7 +42,7 @@ import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForSupportedCPU; public class TestUseSHA1IntrinsicsOptionOnSupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase(new GenericTestCaseForSupportedCPU( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION)).test(); + new DigestOptionsBase(new GenericTestCaseForSupportedCPU( + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java index a92c2e47eb4..6f6c484d430 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA1IntrinsicsOptionOnUnsupportedCPU.java @@ -45,14 +45,14 @@ import compiler.intrinsics.sha.cli.testcases.UseSHAIntrinsicsSpecificTestCaseFor public class TestUseSHA1IntrinsicsOptionOnUnsupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase( + new DigestOptionsBase( new GenericTestCaseForUnsupportedX86CPU( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION), new GenericTestCaseForUnsupportedAArch64CPU( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION), new UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION), new GenericTestCaseForOtherCPU( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION)).test(); + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java index 26e20400349..e30793afcf2 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnSupportedCPU.java @@ -42,7 +42,7 @@ import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForSupportedCPU; public class TestUseSHA256IntrinsicsOptionOnSupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase(new GenericTestCaseForSupportedCPU( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION)).test(); + new DigestOptionsBase(new GenericTestCaseForSupportedCPU( + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java index c896ccce34b..b3c40580373 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA256IntrinsicsOptionOnUnsupportedCPU.java @@ -45,14 +45,14 @@ import compiler.intrinsics.sha.cli.testcases.UseSHAIntrinsicsSpecificTestCaseFor public class TestUseSHA256IntrinsicsOptionOnUnsupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase( + new DigestOptionsBase( new GenericTestCaseForUnsupportedX86CPU( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION), new GenericTestCaseForUnsupportedAArch64CPU( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION), new UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION), new GenericTestCaseForOtherCPU( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION)).test(); + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java index 222a48f46cd..857c1276feb 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnSupportedCPU.java @@ -42,7 +42,7 @@ import compiler.intrinsics.sha.cli.testcases.GenericTestCaseForSupportedCPU; public class TestUseSHA512IntrinsicsOptionOnSupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase(new GenericTestCaseForSupportedCPU( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION)).test(); + new DigestOptionsBase(new GenericTestCaseForSupportedCPU( + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java index 83881d0b171..500b608641c 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHA512IntrinsicsOptionOnUnsupportedCPU.java @@ -45,14 +45,14 @@ import compiler.intrinsics.sha.cli.testcases.UseSHAIntrinsicsSpecificTestCaseFor public class TestUseSHA512IntrinsicsOptionOnUnsupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase( + new DigestOptionsBase( new GenericTestCaseForUnsupportedX86CPU( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION), new GenericTestCaseForUnsupportedAArch64CPU( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION), new UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION), + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION), new GenericTestCaseForOtherCPU( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION)).test(); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java index 102ad506cd9..23d37cce1a1 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnSupportedCPU.java @@ -43,10 +43,10 @@ import compiler.intrinsics.sha.cli.testcases.UseSHASpecificTestCaseForSupportedC public class TestUseSHAOptionOnSupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase( + new DigestOptionsBase( new GenericTestCaseForSupportedCPU( - SHAOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.USE_SHA_OPTION), new UseSHASpecificTestCaseForSupportedCPU( - SHAOptionsBase.USE_SHA_OPTION)).test(); + DigestOptionsBase.USE_SHA_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java index bcc40cd357e..1f343756583 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/TestUseSHAOptionOnUnsupportedCPU.java @@ -44,14 +44,14 @@ import compiler.intrinsics.sha.cli.testcases.UseSHASpecificTestCaseForUnsupporte public class TestUseSHAOptionOnUnsupportedCPU { public static void main(String args[]) throws Throwable { - new SHAOptionsBase( + new DigestOptionsBase( new GenericTestCaseForUnsupportedX86CPU( - SHAOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.USE_SHA_OPTION), new GenericTestCaseForUnsupportedAArch64CPU( - SHAOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.USE_SHA_OPTION), new UseSHASpecificTestCaseForUnsupportedCPU( - SHAOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.USE_SHA_OPTION), new GenericTestCaseForOtherCPU( - SHAOptionsBase.USE_SHA_OPTION)).test(); + DigestOptionsBase.USE_SHA_OPTION)).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForOtherCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForOtherCPU.java index 157e9dc200b..2b8d143dd68 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForOtherCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForOtherCPU.java @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import jdk.test.lib.process.ExitCode; import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; @@ -35,8 +35,15 @@ import jdk.test.lib.cli.predicate.OrPredicate; * AArch64, PPC, S390x, and X86. */ public class GenericTestCaseForOtherCPU extends - SHAOptionsBase.TestCase { + DigestOptionsBase.TestCase { + + final private boolean checkUseSHA; + public GenericTestCaseForOtherCPU(String optionName) { + this(optionName, true); + } + + public GenericTestCaseForOtherCPU(String optionName, boolean checkUseSHA) { // Execute the test case on any CPU except AArch64, PPC, S390x, and X86. super(optionName, new NotPredicate( new OrPredicate(Platform::isAArch64, @@ -44,6 +51,8 @@ public class GenericTestCaseForOtherCPU extends new OrPredicate(Platform::isPPC, new OrPredicate(Platform::isX64, Platform::isX86)))))); + + this.checkUseSHA = checkUseSHA; } @Override @@ -55,13 +64,13 @@ public class GenericTestCaseForOtherCPU extends CommandLineOptionTest.verifySameJVMStartup(null, new String[] { ".*" + optionName + ".*" }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); CommandLineOptionTest.verifySameJVMStartup(null, new String[] { ".*" + optionName + ".*" }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, false)); } @@ -71,24 +80,26 @@ public class GenericTestCaseForOtherCPU extends CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be disabled by default", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); // Verify that option is disabled even if it was explicitly enabled // using CLI options. CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be off on unsupported " + "CPU even if set to true directly", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); - // Verify that option is disabled when it explicitly disabled - // using CLI options. - CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", - String.format("Option '%s' should be off on unsupported CPU" - + " even if '%s' flag set to JVM", optionName, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag(optionName, false)); + if (checkUseSHA) { + // Verify that option is disabled when it explicitly disabled + // using CLI options. + CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", + String.format("Option '%s' should be off on unsupported CPU" + + " even if '%s' flag set to JVM", optionName, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag(optionName, false)); + } } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForSupportedCPU.java index f158a807aa5..4b3914e75fd 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForSupportedCPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import jdk.test.lib.process.ExitCode; import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; @@ -35,9 +35,18 @@ import jdk.test.lib.cli.predicate.OrPredicate; * support instructions required by the tested option. */ public class GenericTestCaseForSupportedCPU extends - SHAOptionsBase.TestCase { + DigestOptionsBase.TestCase { + + final private boolean checkUseSHA; + public GenericTestCaseForSupportedCPU(String optionName) { - super(optionName, SHAOptionsBase.getPredicateForOption(optionName)); + this(optionName, true); + } + + public GenericTestCaseForSupportedCPU(String optionName, boolean checkUseSHA) { + super(optionName, DigestOptionsBase.getPredicateForOption(optionName)); + + this.checkUseSHA = checkUseSHA; } @Override @@ -47,39 +56,41 @@ public class GenericTestCaseForSupportedCPU extends + " '%s' without any warnings", optionName); // Verify that there are no warning when option is explicitly enabled. CommandLineOptionTest.verifySameJVMStartup(null, new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); - // Verify that option could be disabled even if +UseSHA was passed to - // JVM. - CommandLineOptionTest.verifySameJVMStartup(null, new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) - }, shouldPassMessage, String.format("It should be able to " - + "disable option '%s' even if %s was passed to JVM", - optionName, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true), - CommandLineOptionTest.prepareBooleanFlag(optionName, false)); - - if (!optionName.equals(SHAOptionsBase.USE_SHA_OPTION)) { - // Verify that if -XX:-UseSHA is passed to the JVM, it is not possible - // to enable the tested option and a warning is printed. - CommandLineOptionTest.verifySameJVMStartup( - new String[] { SHAOptionsBase.getWarningForUnsupportedCPU(optionName) }, - null, - shouldPassMessage, - String.format("Enabling option '%s' should not be possible and should result in a warning if %s was passed to JVM", - optionName, - CommandLineOptionTest.prepareBooleanFlag(SHAOptionsBase.USE_SHA_OPTION, false)), + if (checkUseSHA) { + // Verify that option could be disabled even if +UseSHA was passed to + // JVM. + CommandLineOptionTest.verifySameJVMStartup(null, new String[] { + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) + }, shouldPassMessage, String.format("It should be able to " + + "disable option '%s' even if %s was passed to JVM", + optionName, CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)), ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag(SHAOptionsBase.USE_SHA_OPTION, false), - CommandLineOptionTest.prepareBooleanFlag(optionName, true)); + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true), + CommandLineOptionTest.prepareBooleanFlag(optionName, false)); + + if (!optionName.equals(DigestOptionsBase.USE_SHA_OPTION)) { + // Verify that if -XX:-UseSHA is passed to the JVM, it is not possible + // to enable the tested option and a warning is printed. + CommandLineOptionTest.verifySameJVMStartup( + new String[] { DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, + null, + shouldPassMessage, + String.format("Enabling option '%s' should not be possible and should result in a warning if %s was passed to JVM", + optionName, + CommandLineOptionTest.prepareBooleanFlag(DigestOptionsBase.USE_SHA_OPTION, false)), + ExitCode.OK, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag(DigestOptionsBase.USE_SHA_OPTION, false), + CommandLineOptionTest.prepareBooleanFlag(optionName, true)); + } } } @@ -90,43 +101,45 @@ public class GenericTestCaseForSupportedCPU extends CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "true", String.format("Option '%s' should be enabled by default", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); // Verify that it is possible to explicitly enable the option. CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "true", String.format("Option '%s' was set to have value 'true'", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); // Verify that it is possible to explicitly disable the option. CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' was set to have value 'false'", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, false)); - // verify that option is disabled when -UseSHA was passed to JVM. - CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", - String.format("Option '%s' should have value 'false' when %s" - + " flag set to JVM", optionName, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, false)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag(optionName, true), - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, false)); + if (checkUseSHA) { + // verify that option is disabled when -UseSHA was passed to JVM. + CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", + String.format("Option '%s' should have value 'false' when %s" + + " flag set to JVM", optionName, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, false)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag(optionName, true), + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, false)); - // Verify that it is possible to explicitly disable the tested option - // even if +UseSHA was passed to JVM. - CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", - String.format("Option '%s' should have value 'false' if set so" - + " even if %s flag set to JVM", optionName, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true), - CommandLineOptionTest.prepareBooleanFlag(optionName, false)); + // Verify that it is possible to explicitly disable the tested option + // even if +UseSHA was passed to JVM. + CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", + String.format("Option '%s' should have value 'false' if set so" + + " even if %s flag set to JVM", optionName, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true), + CommandLineOptionTest.prepareBooleanFlag(optionName, false)); + } } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedAArch64CPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedAArch64CPU.java index 0c8543341d8..4a257c74fc4 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedAArch64CPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedAArch64CPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import jdk.test.lib.process.ExitCode; import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; @@ -35,11 +35,20 @@ import jdk.test.lib.cli.predicate.NotPredicate; * which don't support instruction required by the tested option. */ public class GenericTestCaseForUnsupportedAArch64CPU extends - SHAOptionsBase.TestCase { + DigestOptionsBase.TestCase { + + final private boolean checkUseSHA; + public GenericTestCaseForUnsupportedAArch64CPU(String optionName) { + this(optionName, true); + } + + public GenericTestCaseForUnsupportedAArch64CPU(String optionName, boolean checkUseSHA) { super(optionName, new AndPredicate(Platform::isAArch64, - new NotPredicate(SHAOptionsBase.getPredicateForOption( + new NotPredicate(DigestOptionsBase.getPredicateForOption( optionName)))); + + this.checkUseSHA = checkUseSHA; } @Override @@ -48,27 +57,29 @@ public class GenericTestCaseForUnsupportedAArch64CPU extends + "option '-XX:-%s' without any warnings", optionName); //Verify that option could be disabled without any warnings. CommandLineOptionTest.verifySameJVMStartup(null, new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, false)); - shouldPassMessage = String.format("If JVM is started with '-XX:-" - + "%s' '-XX:+%s', output should contain warning.", - SHAOptionsBase.USE_SHA_OPTION, optionName); + if (checkUseSHA) { + shouldPassMessage = String.format("If JVM is started with '-XX:-" + + "%s' '-XX:+%s', output should contain warning.", + DigestOptionsBase.USE_SHA_OPTION, optionName); - // Verify that when the tested option is enabled, then - // a warning will occur in VM output if UseSHA is disabled. - if (!optionName.equals(SHAOptionsBase.USE_SHA_OPTION)) { - CommandLineOptionTest.verifySameJVMStartup( - new String[] { SHAOptionsBase.getWarningForUnsupportedCPU(optionName) }, - null, - shouldPassMessage, - shouldPassMessage, - ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag(SHAOptionsBase.USE_SHA_OPTION, false), - CommandLineOptionTest.prepareBooleanFlag(optionName, true)); + // Verify that when the tested option is enabled, then + // a warning will occur in VM output if UseSHA is disabled. + if (!optionName.equals(DigestOptionsBase.USE_SHA_OPTION)) { + CommandLineOptionTest.verifySameJVMStartup( + new String[] { DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, + null, + shouldPassMessage, + shouldPassMessage, + ExitCode.OK, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag(DigestOptionsBase.USE_SHA_OPTION, false), + CommandLineOptionTest.prepareBooleanFlag(optionName, true)); + } } } @@ -78,24 +89,26 @@ public class GenericTestCaseForUnsupportedAArch64CPU extends CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be disabled by default", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); // Verify that option is disabled even if it was explicitly enabled // using CLI options. CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be off on unsupported " + "AArch64CPU even if set to true directly", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); - // Verify that option is disabled when +UseSHA was passed to JVM. - CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", - String.format("Option '%s' should be off on unsupported " - + "AArch64CPU even if %s flag set to JVM", - optionName, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)); + if (checkUseSHA) { + // Verify that option is disabled when +UseSHA was passed to JVM. + CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", + String.format("Option '%s' should be off on unsupported " + + "AArch64CPU even if %s flag set to JVM", + optionName, CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)); + } } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedX86CPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedX86CPU.java index 3f94cdf2e6b..27548dd0e27 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedX86CPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/GenericTestCaseForUnsupportedX86CPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import jdk.test.lib.process.ExitCode; import jdk.test.lib.Platform; import jdk.test.lib.cli.CommandLineOptionTest; @@ -36,11 +36,20 @@ import jdk.test.lib.cli.predicate.OrPredicate; * support SHA-related instructions. */ public class GenericTestCaseForUnsupportedX86CPU - extends SHAOptionsBase.TestCase { + extends DigestOptionsBase.TestCase { + + final private boolean checkUseSHA; + public GenericTestCaseForUnsupportedX86CPU(String optionName) { + this(optionName, true); + } + + public GenericTestCaseForUnsupportedX86CPU(String optionName, boolean checkUseSHA) { super(optionName, new AndPredicate(new OrPredicate(Platform::isX64, Platform::isX86), - new NotPredicate(SHAOptionsBase.getPredicateForOption( + new NotPredicate(DigestOptionsBase.getPredicateForOption( optionName)))); + + this.checkUseSHA = checkUseSHA; } @Override @@ -50,22 +59,22 @@ public class GenericTestCaseForUnsupportedX86CPU // Verify that the tested option could be explicitly disabled without // a warning. CommandLineOptionTest.verifySameJVMStartup(null, new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, false)); // Verify that when the tested option is enabled, then // a warning will occur in VM output if UseSHA is disabled. - if (!optionName.equals(SHAOptionsBase.USE_SHA_OPTION)) { + if (checkUseSHA && !optionName.equals(DigestOptionsBase.USE_SHA_OPTION)) { CommandLineOptionTest.verifySameJVMStartup( - new String[] { SHAOptionsBase.getWarningForUnsupportedCPU(optionName) }, + new String[] { DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, null, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag(SHAOptionsBase.USE_SHA_OPTION, false), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag(DigestOptionsBase.USE_SHA_OPTION, false), CommandLineOptionTest.prepareBooleanFlag(optionName, true)); } } @@ -76,24 +85,26 @@ public class GenericTestCaseForUnsupportedX86CPU CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be disabled by default", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS); // Verify that it is not possible to explicitly enable the option. CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", String.format("Option '%s' should be off on unsupported " + "X86CPU even if set to true directly", optionName), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); - // Verify that the tested option is disabled even if +UseSHA was passed - // to JVM. - CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", - String.format("Option '%s' should be off on unsupported " - + "X86CPU even if %s flag set to JVM", - optionName, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, - CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)); + if (checkUseSHA) { + // Verify that the tested option is disabled even if +UseSHA was passed + // to JVM. + CommandLineOptionTest.verifyOptionValueForSameVM(optionName, "false", + String.format("Option '%s' should be off on unsupported " + + "X86CPU even if %s flag set to JVM", + optionName, CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + CommandLineOptionTest.prepareBooleanFlag( + DigestOptionsBase.USE_SHA_OPTION, true)); + } } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java index e77b49672ba..da189e3b626 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import compiler.testlibrary.sha.predicate.IntrinsicPredicates; import jdk.test.lib.process.ExitCode; import jdk.test.lib.Platform; @@ -41,14 +41,14 @@ import jdk.test.lib.cli.predicate.OrPredicate; * sha512. */ public class UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU - extends SHAOptionsBase.TestCase { + extends DigestOptionsBase.TestCase { public UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU( String optionName) { // execute test case on CPU that supports any sha* instructions, // but does not support sha* instruction required by the tested option. super(optionName, new AndPredicate( IntrinsicPredicates.ANY_SHA_INSTRUCTION_AVAILABLE, - new NotPredicate(SHAOptionsBase.getPredicateForOption(optionName)))); + new NotPredicate(DigestOptionsBase.getPredicateForOption(optionName)))); } @Override protected void verifyWarnings() throws Throwable { @@ -57,9 +57,9 @@ public class UseSHAIntrinsicsSpecificTestCaseForUnsupportedCPU optionName); // Verify that attempt to enable the tested option will cause a warning CommandLineOptionTest.verifySameJVMStartup(new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, null, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java index 5559ec5e5e5..8f3add508d6 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForSupportedCPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import compiler.testlibrary.sha.predicate.IntrinsicPredicates; import jdk.test.lib.Asserts; import jdk.test.lib.process.ExitCode; @@ -36,14 +36,14 @@ import jdk.test.lib.cli.predicate.OrPredicate; * UseSHA specific test case targeted to CPUs which support any sha* instruction. */ public class UseSHASpecificTestCaseForSupportedCPU - extends SHAOptionsBase.TestCase { + extends DigestOptionsBase.TestCase { public UseSHASpecificTestCaseForSupportedCPU(String optionName) { - super(SHAOptionsBase.USE_SHA_OPTION, + super(DigestOptionsBase.USE_SHA_OPTION, IntrinsicPredicates.ANY_SHA_INSTRUCTION_AVAILABLE); - Asserts.assertEQ(optionName, SHAOptionsBase.USE_SHA_OPTION, + Asserts.assertEQ(optionName, DigestOptionsBase.USE_SHA_OPTION, String.format("Test case should be used for '%s' option only.", - SHAOptionsBase.USE_SHA_OPTION)); + DigestOptionsBase.USE_SHA_OPTION)); } @Override @@ -52,21 +52,21 @@ public class UseSHASpecificTestCaseForSupportedCPU + " %s was passed and all UseSHA*Intrinsics options " + "were disabled", CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)); + DigestOptionsBase.USE_SHA_OPTION, true)); // Verify that there will be no warnings when +UseSHA was passed and // all UseSHA*Intrinsics options were disabled. CommandLineOptionTest.verifySameJVMStartup( null, new String[] { ".*UseSHA.*" }, shouldPassMessage, shouldPassMessage, ExitCode.OK, - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true), + DigestOptionsBase.USE_SHA_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); } @Override @@ -74,53 +74,53 @@ public class UseSHASpecificTestCaseForSupportedCPU // Verify that UseSHA is disabled when all UseSHA*Intrinsics are // disabled. CommandLineOptionTest.verifyOptionValueForSameVM( - SHAOptionsBase.USE_SHA_OPTION, "false", String.format( + DigestOptionsBase.USE_SHA_OPTION, "false", String.format( "'%s' option should be disabled when all UseSHA*Intrinsics are" - + " disabled", SHAOptionsBase.USE_SHA_OPTION), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + + " disabled", DigestOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); CommandLineOptionTest.verifyOptionValueForSameVM( // Verify that UseSHA is disabled when all UseSHA*Intrinsics are // disabled even if it was explicitly enabled. - SHAOptionsBase.USE_SHA_OPTION, "false", + DigestOptionsBase.USE_SHA_OPTION, "false", String.format("'%s' option should be disabled when all " + "UseSHA*Intrinsics are disabled even if %s flag set " - + "to JVM", SHAOptionsBase.USE_SHA_OPTION, + + "to JVM", DigestOptionsBase.USE_SHA_OPTION, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.USE_SHA_OPTION, true)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true), + DigestOptionsBase.USE_SHA_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, false)); // Verify that explicitly disabled UseSHA option remains disabled even // if all UseSHA*Intrinsics options were enabled. CommandLineOptionTest.verifyOptionValueForSameVM( - SHAOptionsBase.USE_SHA_OPTION, "false", + DigestOptionsBase.USE_SHA_OPTION, "false", String.format("'%s' option should be disabled if %s flag " + "set even if all UseSHA*Intrinsics were enabled", - SHAOptionsBase.USE_SHA_OPTION, + DigestOptionsBase.USE_SHA_OPTION, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, false)), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.USE_SHA_OPTION, false)), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, false), + DigestOptionsBase.USE_SHA_OPTION, false), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java index 1a3c6166879..4dd8e921e69 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/cli/testcases/UseSHASpecificTestCaseForUnsupportedCPU.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.cli.testcases; -import compiler.intrinsics.sha.cli.SHAOptionsBase; +import compiler.intrinsics.sha.cli.DigestOptionsBase; import compiler.testlibrary.sha.predicate.IntrinsicPredicates; import jdk.test.lib.Asserts; import jdk.test.lib.process.ExitCode; @@ -38,13 +38,13 @@ import jdk.test.lib.cli.predicate.OrPredicate; * sha* instructions. */ public class UseSHASpecificTestCaseForUnsupportedCPU - extends SHAOptionsBase.TestCase { + extends DigestOptionsBase.TestCase { public UseSHASpecificTestCaseForUnsupportedCPU(String optionName) { - super(SHAOptionsBase.USE_SHA_OPTION, new NotPredicate( + super(DigestOptionsBase.USE_SHA_OPTION, new NotPredicate( IntrinsicPredicates.ANY_SHA_INSTRUCTION_AVAILABLE)); - Asserts.assertEQ(optionName, SHAOptionsBase.USE_SHA_OPTION, - "Test case should be used for " + SHAOptionsBase.USE_SHA_OPTION + Asserts.assertEQ(optionName, DigestOptionsBase.USE_SHA_OPTION, + "Test case should be used for " + DigestOptionsBase.USE_SHA_OPTION + " option only."); } @@ -55,7 +55,7 @@ public class UseSHASpecificTestCaseForUnsupportedCPU + " '%s' option on unsupported CPU, but there should be" + "the message shown.", optionName); CommandLineOptionTest.verifySameJVMStartup(new String[] { - SHAOptionsBase.getWarningForUnsupportedCPU(optionName) + DigestOptionsBase.getWarningForUnsupportedCPU(optionName) }, null, shouldPassMessage, shouldPassMessage, ExitCode.OK, CommandLineOptionTest.prepareBooleanFlag(optionName, true)); } @@ -65,35 +65,35 @@ public class UseSHASpecificTestCaseForUnsupportedCPU // Verify that UseSHA option remains disabled even if all // UseSHA*Intrinsics were enabled. CommandLineOptionTest.verifyOptionValueForSameVM( - SHAOptionsBase.USE_SHA_OPTION, "false", String.format( + DigestOptionsBase.USE_SHA_OPTION, "false", String.format( "%s option should be disabled on unsupported CPU" + " even if all UseSHA*Intrinsics options were enabled.", - SHAOptionsBase.USE_SHA_OPTION), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); // Verify that UseSHA option remains disabled even if all // UseSHA*Intrinsics options were enabled and UseSHA was enabled as well. CommandLineOptionTest.verifyOptionValueForSameVM( - SHAOptionsBase.USE_SHA_OPTION, "false", String.format( + DigestOptionsBase.USE_SHA_OPTION, "false", String.format( "%s option should be disabled on unsupported CPU" + " even if all UseSHA*Intrinsics options were enabled" + " and %s was enabled as well", - SHAOptionsBase.USE_SHA_OPTION, - SHAOptionsBase.USE_SHA_OPTION), - SHAOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, + DigestOptionsBase.USE_SHA_OPTION, + DigestOptionsBase.USE_SHA_OPTION), + DigestOptionsBase.UNLOCK_DIAGNOSTIC_VM_OPTIONS, CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA_OPTION, true), + DigestOptionsBase.USE_SHA_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA1_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), + DigestOptionsBase.USE_SHA256_INTRINSICS_OPTION, true), CommandLineOptionTest.prepareBooleanFlag( - SHAOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); + DigestOptionsBase.USE_SHA512_INTRINSICS_OPTION, true)); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/SHASanityTestBase.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/DigestSanityTestBase.java similarity index 85% rename from test/hotspot/jtreg/compiler/intrinsics/sha/sanity/SHASanityTestBase.java rename to test/hotspot/jtreg/compiler/intrinsics/sha/sanity/DigestSanityTestBase.java index c476d27b143..a2e31ef41bb 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/SHASanityTestBase.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/DigestSanityTestBase.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -23,7 +23,7 @@ package compiler.intrinsics.sha.sanity; -import compiler.intrinsics.sha.TestSHA; +import compiler.intrinsics.sha.TestDigest; import compiler.testlibrary.intrinsics.Verifier; import sun.hotspot.WhiteBox; @@ -36,7 +36,9 @@ import java.util.function.BooleanSupplier; /** * Base class for sanity tests on SHA intrinsics support. */ -public class SHASanityTestBase { +public class DigestSanityTestBase { + protected static final String MD5_INTRINSIC_ID + = "_md5_implCompress"; protected static final String SHA1_INTRINSIC_ID = "_sha_implCompress"; protected static final String SHA256_INTRINSIC_ID @@ -65,7 +67,7 @@ public class SHASanityTestBase { * be used. * @param intrinsicID The ID of the intrinsic to be tested. */ - protected SHASanityTestBase(BooleanSupplier predicate, String intrinsicID) { + protected DigestSanityTestBase(BooleanSupplier predicate, String intrinsicID) { this.predicate = predicate; this.intrinsicID = intrinsicID; } @@ -82,10 +84,10 @@ public class SHASanityTestBase { dumpProperties(); - TestSHA.testSHA(SHASanityTestBase.PROVIDER, algorithm, - SHASanityTestBase.MSG_SIZE, SHASanityTestBase.OFFSET, - SHASanityTestBase.ITERATIONS, - SHASanityTestBase.WARMUP_ITERATIONS); + TestDigest.testDigest(DigestSanityTestBase.PROVIDER, algorithm, + DigestSanityTestBase.MSG_SIZE, DigestSanityTestBase.OFFSET, + DigestSanityTestBase.ITERATIONS, + DigestSanityTestBase.WARMUP_ITERATIONS); } /** @@ -102,7 +104,7 @@ public class SHASanityTestBase { String.valueOf(predicate.getAsBoolean())); String logFileName - = SHASanityTestBase.WHITE_BOX.getStringVMFlag("LogFile"); + = DigestSanityTestBase.WHITE_BOX.getStringVMFlag("LogFile"); FileOutputStream fileOutputStream = new FileOutputStream(logFileName + Verifier.PROPERTY_FILE_SUFFIX); diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java new file mode 100644 index 00000000000..4c712b1afdc --- /dev/null +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java @@ -0,0 +1,65 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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 + * @bug 8035968 + * @summary Verify that MD5 intrinsic is actually used. + * @library /test/lib / + * @modules java.base/jdk.internal.misc + * java.management + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 + * -XX:Tier4InvocationThreshold=500 + * -XX:+LogCompilation -XX:LogFile=positive.log + * -XX:CompileOnly=sun/security/provider/DigestBase + * -XX:CompileOnly=sun/security/provider/MD5 + * -XX:+UseMD5Intrinsics + * -Dalgorithm=MD5 + * compiler.intrinsics.sha.sanity.TestMD5Intrinsics + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 + * -XX:Tier4InvocationThreshold=500 + * -XX:+LogCompilation -XX:LogFile=negative.log + * -XX:CompileOnly=sun/security/provider/DigestBase + * -XX:CompileOnly=sun/security/provider/MD5 + * -XX:-UseMD5Intrinsics + * -Dalgorithm=MD5 + * compiler.intrinsics.sha.sanity.TestMD5Intrinsics + * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE + * compiler.testlibrary.intrinsics.Verifier positive.log negative.log + */ + +package compiler.intrinsics.sha.sanity; + +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + +public class TestMD5Intrinsics { + public static void main(String args[]) throws Exception { + new DigestSanityTestBase(IntrinsicPredicates.isMD5IntrinsicAvailable(), + DigestSanityTestBase.MD5_INTRINSIC_ID).test(); + } +} diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java new file mode 100644 index 00000000000..bbce5531d71 --- /dev/null +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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 + * @bug 8035968 + * @summary Verify that MD5 multi block intrinsic is actually used. + * @library /test/lib / + * @modules java.base/jdk.internal.misc + * java.management + * + * @build sun.hotspot.WhiteBox + * @run driver ClassFileInstaller sun.hotspot.WhiteBox + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 + * -XX:Tier4InvocationThreshold=500 + * -XX:+LogCompilation -XX:LogFile=positive.log + * -XX:CompileOnly=sun/security/provider/DigestBase + * -XX:CompileOnly=sun/security/provider/MD5 + * -XX:+UseMD5Intrinsics -XX:-UseSHA1Intrinsics + * -XX:-UseSHA256Intrinsics -XX:-UseSHA512Intrinsics + * -Dalgorithm=MD5 + * compiler.intrinsics.sha.sanity.TestMD5MultiBlockIntrinsics + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 + * -XX:Tier4InvocationThreshold=500 + * -XX:+LogCompilation -XX:LogFile=positive_def.log + * -XX:CompileOnly=sun/security/provider/DigestBase + * -XX:CompileOnly=sun/security/provider/MD5 + * -XX:+UseMD5Intrinsics -Dalgorithm=MD5 + * compiler.intrinsics.sha.sanity.TestMD5MultiBlockIntrinsics + * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions + * -XX:+WhiteBoxAPI -Xbatch -XX:CompileThreshold=500 + * -XX:Tier4InvocationThreshold=500 + * -XX:+LogCompilation -XX:LogFile=negative.log + * -XX:CompileOnly=sun/security/provider/DigestBase + * -XX:CompileOnly=sun/security/provider/MD5 + * -Dalgorithm=MD5 + * compiler.intrinsics.sha.sanity.TestMD5MultiBlockIntrinsics + * @run main/othervm -DverificationStrategy=VERIFY_INTRINSIC_USAGE + * compiler.testlibrary.intrinsics.Verifier positive.log positive_def.log + * negative.log + */ + +package compiler.intrinsics.sha.sanity; +import compiler.testlibrary.sha.predicate.IntrinsicPredicates; + +public class TestMD5MultiBlockIntrinsics { + public static void main(String args[]) throws Exception { + new DigestSanityTestBase(IntrinsicPredicates.isMD5IntrinsicAvailable(), + DigestSanityTestBase.MB_INTRINSIC_ID).test(); + } +} diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java index ec55b3a4725..04963960d95 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java @@ -59,7 +59,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA1Intrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA1IntrinsicAvailable(), - SHASanityTestBase.SHA1_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA1IntrinsicAvailable(), + DigestSanityTestBase.SHA1_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java index e2aa952c8ee..7c239bbc641 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java @@ -37,8 +37,8 @@ * -XX:+LogCompilation -XX:LogFile=positive.log * -XX:CompileOnly=sun/security/provider/DigestBase * -XX:CompileOnly=sun/security/provider/SHA - * -XX:+UseSHA1Intrinsics -XX:-UseSHA256Intrinsics - * -XX:-UseSHA512Intrinsics + * -XX:+UseSHA1Intrinsics -XX:-UseMD5Intrinsics + * -XX:-UseSHA256Intrinsics -XX:-UseSHA512Intrinsics * -Dalgorithm=SHA-1 * compiler.intrinsics.sha.sanity.TestSHA1MultiBlockIntrinsics * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions @@ -67,7 +67,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA1MultiBlockIntrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA1IntrinsicAvailable(), - SHASanityTestBase.MB_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA1IntrinsicAvailable(), + DigestSanityTestBase.MB_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java index 1852b52910b..cfca8fa1e13 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java @@ -78,7 +78,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA256Intrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA256IntrinsicAvailable(), - SHASanityTestBase.SHA256_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA256IntrinsicAvailable(), + DigestSanityTestBase.SHA256_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java index e7694f01f5d..cdaaf049adb 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java @@ -37,8 +37,8 @@ * -XX:+LogCompilation -XX:LogFile=positive_224.log * -XX:CompileOnly=sun/security/provider/DigestBase * -XX:CompileOnly=sun/security/provider/SHA2 - * -XX:+UseSHA256Intrinsics -XX:-UseSHA1Intrinsics - * -XX:-UseSHA512Intrinsics + * -XX:+UseSHA256Intrinsics -XX:-UseMD5Intrinsics + * -XX:-UseSHA1Intrinsics -XX:-UseSHA512Intrinsics * -Dalgorithm=SHA-224 * compiler.intrinsics.sha.sanity.TestSHA256MultiBlockIntrinsics * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions @@ -63,8 +63,8 @@ * -XX:+LogCompilation -XX:LogFile=positive_256.log * -XX:CompileOnly=sun/security/provider/DigestBase * -XX:CompileOnly=sun/security/provider/SHA2 - * -XX:+UseSHA256Intrinsics -XX:-UseSHA1Intrinsics - * -XX:-UseSHA512Intrinsics + * -XX:+UseSHA256Intrinsics -XX:-UseMD5Intrinsics + * -XX:-UseSHA1Intrinsics -XX:-UseSHA512Intrinsics * -Dalgorithm=SHA-256 * compiler.intrinsics.sha.sanity.TestSHA256MultiBlockIntrinsics * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions @@ -94,7 +94,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA256MultiBlockIntrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA256IntrinsicAvailable(), - SHASanityTestBase.MB_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA256IntrinsicAvailable(), + DigestSanityTestBase.MB_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java index 937c64aa785..42427c0c6ea 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java @@ -78,7 +78,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA512Intrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA512IntrinsicAvailable(), - SHASanityTestBase.SHA512_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA512IntrinsicAvailable(), + DigestSanityTestBase.SHA512_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java index 62e773fb1a9..7521337b222 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java @@ -37,8 +37,8 @@ * -XX:+LogCompilation -XX:LogFile=positive_384.log * -XX:CompileOnly=sun/security/provider/DigestBase * -XX:CompileOnly=sun/security/provider/SHA5 - * -XX:+UseSHA512Intrinsics -XX:-UseSHA1Intrinsics - * -XX:-UseSHA256Intrinsics + * -XX:+UseSHA512Intrinsics -XX:-UseMD5Intrinsics + * -XX:-UseSHA1Intrinsics -XX:-UseSHA256Intrinsics * -Dalgorithm=SHA-384 * compiler.intrinsics.sha.sanity.TestSHA512MultiBlockIntrinsics * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions @@ -63,8 +63,8 @@ * -XX:+LogCompilation -XX:LogFile=positive_512.log * -XX:CompileOnly=sun/security/provider/DigestBase * -XX:CompileOnly=sun/security/provider/SHA5 - * -XX:+UseSHA512Intrinsics -XX:-UseSHA1Intrinsics - * -XX:-UseSHA256Intrinsics + * -XX:+UseSHA512Intrinsics -XX:-UseMD5Intrinsics + * -XX:-UseSHA1Intrinsics -XX:-UseSHA256Intrinsics * -Dalgorithm=SHA-512 * compiler.intrinsics.sha.sanity.TestSHA512MultiBlockIntrinsics * @run main/othervm -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions @@ -95,7 +95,7 @@ import compiler.testlibrary.sha.predicate.IntrinsicPredicates; public class TestSHA512MultiBlockIntrinsics { public static void main(String args[]) throws Exception { - new SHASanityTestBase(IntrinsicPredicates.isSHA512IntrinsicAvailable(), - SHASanityTestBase.MB_INTRINSIC_ID).test(); + new DigestSanityTestBase(IntrinsicPredicates.isSHA512IntrinsicAvailable(), + DigestSanityTestBase.MB_INTRINSIC_ID).test(); } } diff --git a/test/hotspot/jtreg/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java b/test/hotspot/jtreg/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java index edfeeb23b91..2b00c742ff0 100644 --- a/test/hotspot/jtreg/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java +++ b/test/hotspot/jtreg/compiler/testlibrary/sha/predicate/IntrinsicPredicates.java @@ -59,6 +59,12 @@ public class IntrinsicPredicates { return Platform.isServer() && !Platform.isEmulatedClient() && (!isTiered || maxLevelIsReachable); }; + public static final BooleanSupplier MD5_INSTRUCTION_AVAILABLE + = // x86 variants + new OrPredicate(new CPUSpecificPredicate("amd64.*", null, null), + new OrPredicate(new CPUSpecificPredicate("i386.*", null, null), + new CPUSpecificPredicate("x86.*", null, null))); + public static final BooleanSupplier SHA1_INSTRUCTION_AVAILABLE = new OrPredicate(new CPUSpecificPredicate("aarch64.*", new String[] { "sha1" }, null), new OrPredicate(new CPUSpecificPredicate("s390.*", new String[] { "sha1" }, null), @@ -97,6 +103,11 @@ public class IntrinsicPredicates { IntrinsicPredicates.SHA256_INSTRUCTION_AVAILABLE, IntrinsicPredicates.SHA512_INSTRUCTION_AVAILABLE)); + public static BooleanSupplier isMD5IntrinsicAvailable() { + return new AndPredicate(IntrinsicPredicates.COMPILABLE_BY_C2, + IntrinsicPredicates.isIntrinsicAvailable("sun.security.provider.MD5", "implCompress0")); + } + public static BooleanSupplier isSHA1IntrinsicAvailable() { return new AndPredicate(IntrinsicPredicates.COMPILABLE_BY_C2, IntrinsicPredicates.isIntrinsicAvailable("sun.security.provider.SHA", "implCompress0")); From 3ea5fdc9ac2825a30dbd21aaa64aa6ce800d97ce Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Wed, 5 Aug 2020 11:40:07 -0700 Subject: [PATCH 02/53] 8235792: LineNumberReader.getLineNumber() behavior is inconsistent with respect to EOF Reviewed-by: alanb, darcy, rriggs --- .../share/classes/java/io/BufferedReader.java | 10 +- .../classes/java/io/LineNumberReader.java | 91 +++++++++++++++---- test/jdk/java/io/LineNumberReader/Read.java | 59 +++++++++++- 3 files changed, 136 insertions(+), 24 deletions(-) diff --git a/src/java.base/share/classes/java/io/BufferedReader.java b/src/java.base/share/classes/java/io/BufferedReader.java index 6825dc530e9..25ceaf3f25c 100644 --- a/src/java.base/share/classes/java/io/BufferedReader.java +++ b/src/java.base/share/classes/java/io/BufferedReader.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -302,6 +302,8 @@ public class BufferedReader extends Reader { * (EOF). * * @param ignoreLF If true, the next '\n' will be skipped + * @param term Output: Whether a line terminator was encountered + * while reading the line; may be {@code null}. * * @return A String containing the contents of the line, not including * any line-termination characters, or null if the end of the @@ -311,13 +313,14 @@ public class BufferedReader extends Reader { * * @throws IOException If an I/O error occurs */ - String readLine(boolean ignoreLF) throws IOException { + String readLine(boolean ignoreLF, boolean[] term) throws IOException { StringBuilder s = null; int startChar; synchronized (lock) { ensureOpen(); boolean omitLF = ignoreLF || skipLF; + if (term != null) term[0] = false; bufferLoop: for (;;) { @@ -344,6 +347,7 @@ public class BufferedReader extends Reader { for (i = nextChar; i < nChars; i++) { c = cb[i]; if ((c == '\n') || (c == '\r')) { + if (term != null) term[0] = true; eol = true; break charLoop; } @@ -389,7 +393,7 @@ public class BufferedReader extends Reader { * @see java.nio.file.Files#readAllLines */ public String readLine() throws IOException { - return readLine(false); + return readLine(false, null); } /** diff --git a/src/java.base/share/classes/java/io/LineNumberReader.java b/src/java.base/share/classes/java/io/LineNumberReader.java index bffda6e1c2c..49e6a2ea99a 100644 --- a/src/java.base/share/classes/java/io/LineNumberReader.java +++ b/src/java.base/share/classes/java/io/LineNumberReader.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,7 +25,6 @@ package java.io; - /** * A buffered character-input stream that keeps track of line numbers. This * class defines methods {@link #setLineNumber(int)} and {@link @@ -33,15 +32,17 @@ package java.io; * respectively. * *

By default, line numbering begins at 0. This number increments at every - * line terminator as the data is read, and can be changed - * with a call to {@code setLineNumber(int)}. Note however, that - * {@code setLineNumber(int)} does not actually change the current position in - * the stream; it only changes the value that will be returned by + * line terminator as the data is read, and at the end of the + * stream if the last character in the stream is not a line terminator. This + * number can be changed with a call to {@code setLineNumber(int)}. Note + * however, that {@code setLineNumber(int)} does not actually change the current + * position in the stream; it only changes the value that will be returned by * {@code getLineNumber()}. * *

A line is considered to be terminated by any one of a * line feed ('\n'), a carriage return ('\r'), or a carriage return followed - * immediately by a linefeed. + * immediately by a linefeed, or any of the previous terminators followed by + * end of stream, or end of stream not preceded by another terminator. * * @author Mark Reinhold * @since 1.1 @@ -49,6 +50,15 @@ package java.io; public class LineNumberReader extends BufferedReader { + /** Previous character types */ + private static final int NONE = 0; // no previous character + private static final int CHAR = 1; // non-line terminator + private static final int EOL = 2; // line terminator + private static final int EOF = 3; // end-of-file + + /** The previous character type */ + private int prevChar = NONE; + /** The current line number */ private int lineNumber = 0; @@ -111,8 +121,10 @@ public class LineNumberReader extends BufferedReader { /** * Read a single character. Line terminators are - * compressed into single newline ('\n') characters. Whenever a line - * terminator is read the current line number is incremented. + * compressed into single newline ('\n') characters. The current line + * number is incremented whenever a line terminator is read, or when the + * end of the stream is reached and the last character in the stream is + * not a line terminator. * * @return The character read, or -1 if the end of the stream has been * reached @@ -134,16 +146,27 @@ public class LineNumberReader extends BufferedReader { skipLF = true; case '\n': /* Fall through */ lineNumber++; + prevChar = EOL; return '\n'; + case -1: + if (prevChar == CHAR) + lineNumber++; + prevChar = EOF; + break; + default: + prevChar = CHAR; + break; } return c; } } /** - * Read characters into a portion of an array. Whenever a line terminator is read the current line number is - * incremented. + * Read characters into a portion of an array. + * Line terminators are compressed into single newline + * ('\n') characters. The current line number is incremented whenever a + * line terminator is read, or when the end of the stream is reached and + * the last character in the stream is not a line terminator. * * @param cbuf * Destination buffer @@ -154,8 +177,8 @@ public class LineNumberReader extends BufferedReader { * @param len * Maximum number of characters to read * - * @return The number of bytes read, or -1 if the end of the stream has - * already been reached + * @return The number of characters read, or -1 if the end of the stream + * has already been reached * * @throws IOException * If an I/O error occurs @@ -167,6 +190,13 @@ public class LineNumberReader extends BufferedReader { synchronized (lock) { int n = super.read(cbuf, off, len); + if (n == -1) { + if (prevChar == CHAR) + lineNumber++; + prevChar = EOF; + return -1; + } + for (int i = off; i < off + n; i++) { int c = cbuf[i]; if (skipLF) { @@ -183,13 +213,28 @@ public class LineNumberReader extends BufferedReader { } } + if (n > 0) { + switch ((int)cbuf[off + n - 1]) { + case '\r': + case '\n': /* Fall through */ + prevChar = EOL; + break; + default: + prevChar = CHAR; + break; + } + } + return n; } } /** - * Read a line of text. Whenever a line terminator is - * read the current line number is incremented. + * Read a line of text. Line terminators are compressed + * into single newline ('\n') characters. The current line number is + * incremented whenever a line terminator is read, or when the end of the + * stream is reached and the last character in the stream is not a line + * terminator. * * @return A String containing the contents of the line, not including * any line termination characters, or @@ -200,10 +245,17 @@ public class LineNumberReader extends BufferedReader { */ public String readLine() throws IOException { synchronized (lock) { - String l = super.readLine(skipLF); + boolean[] term = new boolean[1]; + String l = super.readLine(skipLF, term); skipLF = false; - if (l != null) + if (l != null) { lineNumber++; + prevChar = term[0] ? EOL : EOF; + } else { // l == null + if (prevChar == CHAR) + lineNumber++; + prevChar = EOF; + } return l; } } @@ -242,6 +294,9 @@ public class LineNumberReader extends BufferedReader { break; r -= nc; } + if (n - r > 0) { + prevChar = NONE; + } return n - r; } } diff --git a/test/jdk/java/io/LineNumberReader/Read.java b/test/jdk/java/io/LineNumberReader/Read.java index 0e1968b372f..7619884a562 100644 --- a/test/jdk/java/io/LineNumberReader/Read.java +++ b/test/jdk/java/io/LineNumberReader/Read.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,16 +22,24 @@ */ /* @test - @bug 4074875 4063511 + @bug 4074875 4063511 8235792 @summary Make sure LineNumberReader.read(char, int , int) will increase the linenumber correctly. */ -import java.io.*; +import java.io.IOException; +import java.io.LineNumberReader; +import java.io.StringReader; +import java.util.function.Consumer; public class Read { public static void main(String[] args) throws Exception { + testReadChars(); + testEofs(); + } + + private static void testReadChars() throws Exception { String s = "aaaa\nbbb\n"; char[] buf = new char[5]; int n = 0; @@ -49,4 +57,49 @@ public class Read { throw new Exception("Failed test: Expected line number: 2, got " + line); } + + private static void testEofs() throws Exception { + String string = "first \n second"; + + Consumer c = (LineNumberReader r) -> { + try { + while (r.read() != -1) + continue; + } catch (IOException e) { + throw new RuntimeException(e); + } + }; + testEof(c, string, 2); + + c = (LineNumberReader r) -> { + try { + char[] buf = new char[128]; + while (r.read(buf) != -1) + continue; + } catch (IOException e) { + throw new RuntimeException(e); + } + }; + testEof(c, string, 2); + + c = (LineNumberReader r) -> { + try { + while (r.readLine() != null) + continue; + } catch (IOException e) { + throw new RuntimeException(e); + } + }; + testEof(c, string, 2); + } + + private static void testEof(Consumer c, String s, int n) + throws Exception { + LineNumberReader r = new LineNumberReader(new StringReader(s)); + c.accept(r); + int line; + if ((line = r.getLineNumber()) != n) + throw new Exception("Failed test: Expected line number: " + n + + " , got " + line); + } } From 65577cf58a3b3221ca4a84e22ae0fc386dbc4c1e Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Wed, 5 Aug 2020 16:39:08 -0700 Subject: [PATCH 03/53] 8251132: make main classes public in vmTestbase/jit tests Reviewed-by: kvn --- test/hotspot/jtreg/vmTestbase/jit/DivTest/DivTest.java | 5 ++--- .../jit/FloatingPoint/gen_math/Filtering/Filtering.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops01/Loops01.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops02/Loops02.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops03/Loops03.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops04/Loops04.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops05/Loops05.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops06/Loops06.java | 5 ++--- .../jit/FloatingPoint/gen_math/Loops07/Loops07.java | 5 ++--- .../jit/FloatingPoint/gen_math/Matrix_3d/Matrix_3d.java | 5 ++--- .../vmTestbase/jit/FloatingPoint/gen_math/Summ/Summ.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/Robert/Robert.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/Sleeper/Sleeper.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/bounds/bounds.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/collapse/collapse.java | 7 +++---- .../jtreg/vmTestbase/jit/deoptimization/test01/test01.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test02/test02.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test03/test03.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test04/test04.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test05/test05.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test06/test06.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test07/test07.java | 5 ++--- .../jtreg/vmTestbase/jit/deoptimization/test08/test08.java | 5 ++--- .../vmTestbase/jit/escape/LockElision/MatMul/MatMul.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/exception/exception.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/init/init01/init01.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/init/init02/init02.java | 5 ++--- .../jtreg/vmTestbase/jit/inline/inline003/inline003.java | 7 +++---- .../jtreg/vmTestbase/jit/inline/inline004/inline004.java | 7 +++---- .../jtreg/vmTestbase/jit/inline/inline007/inline007.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/misctests/Pi/Pi.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/misctests/t5/t5.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/overflow/overflow.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/series/series.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t001/t001.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t002/t002.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t003/t003.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t004/t004.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t005/t005.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t006/t006.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t007/t007.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t008/t008.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t009/t009.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t011/t011.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t012/t012.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t013/t013.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t014/t014.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t015/t015.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t016/t016.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t017/t017.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t018/t018.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t019/t019.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t020/t020.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t021/t021.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t022/t022.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t023/t023.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t024/t024.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t025/t025.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t026/t026.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t027/t027.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t028/t028.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t029/t029.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t030/t030.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t031/t031.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t032/t032.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t033/t033.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t034/t034.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t035/t035.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t036/t036.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t037/t037.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t038/t038.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t039/t039.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t040/t040.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t041/t041.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t042/t042.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t043/t043.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t044/t044.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t045/t045.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t046/t046.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t047/t047.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t048/t048.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t049/t049.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t050/t050.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t051/t051.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t052/t052.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t053/t053.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t054/t054.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t055/t055.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t056/t056.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t057/t057.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t058/t058.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t059/t059.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t060/t060.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t061/t061.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t062/t062.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t063/t063.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t064/t064.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t065/t065.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t066/t066.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/t/t067/t067.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t068/t068.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t069/t069.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t070/t070.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t071/t071.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t072/t072.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t073/t073.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t074/t074.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t075/t075.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t076/t076.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t077/t077.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t078/t078.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t079/t079.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t080/t080.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t081/t081.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t086/t086.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t091/t091.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t093/t093.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t094/t094.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t095/t095.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t096/t096.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t098/t098.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t099/t099.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t100/t100.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t101/t101.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t102/t102.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t103/t103.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t104/t104.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t105/t105.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t106/t106.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t107/t107.java | 7 +++---- test/hotspot/jtreg/vmTestbase/jit/t/t108/t108.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/t/t109/t109.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/t/t110/t110.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/t/t111/t111.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/t/t112/t112.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/t/t113/t113.java | 4 ++-- test/hotspot/jtreg/vmTestbase/jit/wide/wide01/wide01.java | 5 ++--- test/hotspot/jtreg/vmTestbase/jit/wide/wide02/wide02.java | 5 ++--- 138 files changed, 366 insertions(+), 498 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/jit/DivTest/DivTest.java b/test/hotspot/jtreg/vmTestbase/jit/DivTest/DivTest.java index 235833e0575..1d886fa661b 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/DivTest/DivTest.java +++ b/test/hotspot/jtreg/vmTestbase/jit/DivTest/DivTest.java @@ -32,15 +32,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.DivTest.DivTest - * @run driver ExecDriver --java jit.DivTest.DivTest + * @run main/othervm jit.DivTest.DivTest */ package jit.DivTest; import nsk.share.TestFailure; -class DivTest{ +public class DivTest{ static int n; static boolean test1 (int n1, int n2) { try { diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Filtering/Filtering.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Filtering/Filtering.java index 5619b06673d..5f7882282bc 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Filtering/Filtering.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Filtering/Filtering.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Filtering.Filtering - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Filtering.Filtering + * @run main/othervm jit.FloatingPoint.gen_math.Filtering.Filtering */ package jit.FloatingPoint.gen_math.Filtering; import nsk.share.TestFailure; -class Filtering +public class Filtering { static int N = 1000; static double xx[]; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops01/Loops01.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops01/Loops01.java index 1016d204be3..4a7db873035 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops01/Loops01.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops01/Loops01.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops01.Loops01 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops01.Loops01 + * @run main/othervm jit.FloatingPoint.gen_math.Loops01.Loops01 */ package jit.FloatingPoint.gen_math.Loops01; import nsk.share.TestFailure; -class Loops01 +public class Loops01 { static final int N = 500; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops02/Loops02.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops02/Loops02.java index 71d591b50bc..cc58c06ef00 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops02/Loops02.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops02/Loops02.java @@ -30,8 +30,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops02.Loops02 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops02.Loops02 + * @run main/othervm jit.FloatingPoint.gen_math.Loops02.Loops02 */ package jit.FloatingPoint.gen_math.Loops02; @@ -39,7 +38,7 @@ package jit.FloatingPoint.gen_math.Loops02; // Test working with loops and random functions. import nsk.share.TestFailure; -class Loops02 +public class Loops02 { static final int N = 300; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops03/Loops03.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops03/Loops03.java index a0773829d08..ebedfa6fafa 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops03/Loops03.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops03/Loops03.java @@ -30,15 +30,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops03.Loops03 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops03.Loops03 + * @run main/othervm jit.FloatingPoint.gen_math.Loops03.Loops03 */ package jit.FloatingPoint.gen_math.Loops03; import nsk.share.TestFailure; -class Loops03 +public class Loops03 { static final int N = 100000; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops04/Loops04.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops04/Loops04.java index 9c5a2eb993c..6f953eb275e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops04/Loops04.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops04/Loops04.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops04.Loops04 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops04.Loops04 + * @run main/othervm jit.FloatingPoint.gen_math.Loops04.Loops04 */ package jit.FloatingPoint.gen_math.Loops04; @@ -38,7 +37,7 @@ package jit.FloatingPoint.gen_math.Loops04; // Test working with nested loops. import nsk.share.TestFailure; -class Loops04 +public class Loops04 { public static void main (String args[]) diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops05/Loops05.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops05/Loops05.java index 8bfeeeff93e..c014d7b79af 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops05/Loops05.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops05/Loops05.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops05.Loops05 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops05.Loops05 + * @run main/othervm jit.FloatingPoint.gen_math.Loops05.Loops05 */ package jit.FloatingPoint.gen_math.Loops05; import nsk.share.TestFailure; -class Loops05 +public class Loops05 { static final int N = 100; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops06/Loops06.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops06/Loops06.java index d9ab3ecd056..8705059ab13 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops06/Loops06.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops06/Loops06.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops06.Loops06 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops06.Loops06 + * @run main/othervm jit.FloatingPoint.gen_math.Loops06.Loops06 */ package jit.FloatingPoint.gen_math.Loops06; import nsk.share.TestFailure; -class Loops06 +public class Loops06 { static final int N = 20; diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops07/Loops07.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops07/Loops07.java index 4934dde82bf..0da54ca5194 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops07/Loops07.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Loops07/Loops07.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Loops07.Loops07 - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Loops07.Loops07 + * @run main/othervm jit.FloatingPoint.gen_math.Loops07.Loops07 */ package jit.FloatingPoint.gen_math.Loops07; @@ -41,7 +40,7 @@ package jit.FloatingPoint.gen_math.Loops07; import nsk.share.TestFailure; -class Loops07 +public class Loops07 { public static void main (String args[]) diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Matrix_3d/Matrix_3d.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Matrix_3d/Matrix_3d.java index aa85b40e2e1..3818b12f58c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Matrix_3d/Matrix_3d.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Matrix_3d/Matrix_3d.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Matrix_3d.Matrix_3d - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Matrix_3d.Matrix_3d + * @run main/othervm jit.FloatingPoint.gen_math.Matrix_3d.Matrix_3d */ package jit.FloatingPoint.gen_math.Matrix_3d; @@ -40,7 +39,7 @@ package jit.FloatingPoint.gen_math.Matrix_3d; import nsk.share.TestFailure; -class Matrix_3d +public class Matrix_3d { public static void main (String args[]) diff --git a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Summ/Summ.java b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Summ/Summ.java index ee287ef797b..a72cfa9f482 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Summ/Summ.java +++ b/test/hotspot/jtreg/vmTestbase/jit/FloatingPoint/gen_math/Summ/Summ.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.FloatingPoint.gen_math.Summ.Summ - * @run driver ExecDriver --java jit.FloatingPoint.gen_math.Summ.Summ + * @run main/othervm jit.FloatingPoint.gen_math.Summ.Summ */ package jit.FloatingPoint.gen_math.Summ; @@ -39,7 +38,7 @@ package jit.FloatingPoint.gen_math.Summ; import nsk.share.TestFailure; -class Summ +public class Summ { public static void main (String args[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/Robert/Robert.java b/test/hotspot/jtreg/vmTestbase/jit/Robert/Robert.java index 161464dc64e..0fad087405b 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/Robert/Robert.java +++ b/test/hotspot/jtreg/vmTestbase/jit/Robert/Robert.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.Robert.Robert - * @run driver ExecDriver --java jit.Robert.Robert + * @run main/othervm jit.Robert.Robert */ package jit.Robert; @@ -38,7 +37,7 @@ package jit.Robert; import java.io.*; import nsk.share.TestFailure; -class Robert +public class Robert { Robert() throws Exception diff --git a/test/hotspot/jtreg/vmTestbase/jit/Sleeper/Sleeper.java b/test/hotspot/jtreg/vmTestbase/jit/Sleeper/Sleeper.java index c1f92405ea8..f163a2dc35f 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/Sleeper/Sleeper.java +++ b/test/hotspot/jtreg/vmTestbase/jit/Sleeper/Sleeper.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.Sleeper.Sleeper - * @run driver ExecDriver --java jit.Sleeper.Sleeper + * @run main/othervm jit.Sleeper.Sleeper */ package jit.Sleeper; import nsk.share.TestFailure; -class Sleeper { +public class Sleeper { public static void main(String args[] ) { System.out.println ("1"); try { Thread.sleep(1000); } catch (InterruptedException e) {} diff --git a/test/hotspot/jtreg/vmTestbase/jit/bounds/bounds.java b/test/hotspot/jtreg/vmTestbase/jit/bounds/bounds.java index 9e3af6a959f..12e3103ccdd 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/bounds/bounds.java +++ b/test/hotspot/jtreg/vmTestbase/jit/bounds/bounds.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.bounds.bounds - * @run driver ExecDriver --java jit.bounds.bounds + * @run main/othervm jit.bounds.bounds */ package jit.bounds; @@ -40,7 +39,7 @@ package jit.bounds; import nsk.share.TestFailure; -class bounds { +public class bounds { public static void main(String[] argv) { int i; int a[] = new int[2]; diff --git a/test/hotspot/jtreg/vmTestbase/jit/collapse/collapse.java b/test/hotspot/jtreg/vmTestbase/jit/collapse/collapse.java index 661eaa159c5..41431ac88f4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/collapse/collapse.java +++ b/test/hotspot/jtreg/vmTestbase/jit/collapse/collapse.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.collapse.collapse - * @run driver ExecDriver --java jit.collapse.collapse + * @run main/othervm jit.collapse.collapse */ package jit.collapse; @@ -39,7 +38,7 @@ package jit.collapse; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class collapse { +public class collapse { public static final GoldChecker goldChecker = new GoldChecker( "collapse" ); public static void main( String[] argv ) diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test01/test01.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test01/test01.java index 299a0a82a80..00b1de4c998 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test01/test01.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test01/test01.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test01.test01 - * @run driver ExecDriver --java jit.deoptimization.test01.test01 + * @run main/othervm jit.deoptimization.test01.test01 */ package jit.deoptimization.test01; @@ -44,7 +43,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test01 { +public class test01 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 100; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test02/test02.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test02/test02.java index 5bf18f034f0..c5829b840ee 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test02/test02.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test02/test02.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test02.test02 - * @run driver ExecDriver --java jit.deoptimization.test02.test02 + * @run main/othervm jit.deoptimization.test02.test02 */ package jit.deoptimization.test02; @@ -44,7 +43,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test02 { +public class test02 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 100; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test03/test03.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test03/test03.java index b9f870c65b2..066c7b84f42 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test03/test03.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test03/test03.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test03.test03 - * @run driver ExecDriver --java jit.deoptimization.test03.test03 + * @run main/othervm jit.deoptimization.test03.test03 */ package jit.deoptimization.test03; @@ -44,7 +43,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test03 { +public class test03 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 100; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test04/test04.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test04/test04.java index 8f61dc668b8..8e892e0f7b2 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test04/test04.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test04/test04.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test04.test04 - * @run driver ExecDriver --java jit.deoptimization.test04.test04 + * @run main/othervm jit.deoptimization.test04.test04 */ package jit.deoptimization.test04; @@ -41,7 +40,7 @@ import nsk.share.TestFailure; * */ -class test04 { +public class test04 { public static void main (String[] args) { A obj = new A(); diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test05/test05.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test05/test05.java index 02e7f7ef22c..468f4f11c63 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test05/test05.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test05/test05.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test05.test05 - * @run driver ExecDriver --java jit.deoptimization.test05.test05 + * @run main/othervm jit.deoptimization.test05.test05 */ package jit.deoptimization.test05; @@ -41,7 +40,7 @@ import nsk.share.TestFailure; * */ -class test05 { +public class test05 { public static void main (String[] args) { A obj = new A(); diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test06/test06.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test06/test06.java index c6ca77cadbc..8445df48d5c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test06/test06.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test06/test06.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test06.test06 - * @run driver ExecDriver --java jit.deoptimization.test06.test06 + * @run main/othervm jit.deoptimization.test06.test06 */ package jit.deoptimization.test06; @@ -45,7 +44,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test06 { +public class test06 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 1; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test07/test07.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test07/test07.java index b2d2da0a4d1..9ad8027bdee 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test07/test07.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test07/test07.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test07.test07 - * @run driver ExecDriver --java jit.deoptimization.test07.test07 + * @run main/othervm jit.deoptimization.test07.test07 */ package jit.deoptimization.test07; @@ -45,7 +44,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test07 { +public class test07 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 1; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test08/test08.java b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test08/test08.java index 9595557a605..469be301354 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test08/test08.java +++ b/test/hotspot/jtreg/vmTestbase/jit/deoptimization/test08/test08.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.deoptimization.test08.test08 - * @run driver ExecDriver --java jit.deoptimization.test08.test08 + * @run main/othervm jit.deoptimization.test08.test08 */ package jit.deoptimization.test08; @@ -45,7 +44,7 @@ import nsk.share.TestFailure; * run with the -XX:TraceDeoptimization to observ the result. */ -class test08 { +public class test08 { public static void main (String[] args) { A obj = new A(); for (int index = 0; index < 1; index++) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/escape/LockElision/MatMul/MatMul.java b/test/hotspot/jtreg/vmTestbase/jit/escape/LockElision/MatMul/MatMul.java index aeed1ed0727..cf20b0df8a0 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/escape/LockElision/MatMul/MatMul.java +++ b/test/hotspot/jtreg/vmTestbase/jit/escape/LockElision/MatMul/MatMul.java @@ -41,8 +41,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.escape.LockElision.MatMul.MatMul - * @run driver ExecDriver --java jit.escape.LockElision.MatMul.MatMul -dim 30 -threadCount 10 + * @run main/othervm jit.escape.LockElision.MatMul.MatMul -dim 30 -threadCount 10 */ package jit.escape.LockElision.MatMul; @@ -62,7 +61,7 @@ import vm.share.options.Options; import jdk.test.lib.Utils; -class MatMul { +public class MatMul { @Option(name = "dim", description = "dimension of matrices") int dim; diff --git a/test/hotspot/jtreg/vmTestbase/jit/exception/exception.java b/test/hotspot/jtreg/vmTestbase/jit/exception/exception.java index 32e72e030b4..42037d1eb8e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/exception/exception.java +++ b/test/hotspot/jtreg/vmTestbase/jit/exception/exception.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.exception.exception - * @run driver ExecDriver --java jit.exception.exception + * @run main/othervm jit.exception.exception */ package jit.exception; @@ -49,7 +48,7 @@ package jit.exception; import nsk.share.TestFailure; -class exception { +public class exception { public static void main(String[] args) { int i, j; diff --git a/test/hotspot/jtreg/vmTestbase/jit/init/init01/init01.java b/test/hotspot/jtreg/vmTestbase/jit/init/init01/init01.java index d60cf0eaa7e..c54f4f09b1a 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/init/init01/init01.java +++ b/test/hotspot/jtreg/vmTestbase/jit/init/init01/init01.java @@ -31,8 +31,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.init.init01.init01 - * @run driver ExecDriver --java jit.init.init01.init01 + * @run main/othervm jit.init.init01.init01 */ package jit.init.init01; @@ -52,7 +51,7 @@ class InitTest2 { static InitTest1 oop = new InitTest1(); } -class init01 { +public class init01 { public static void main (String s[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/init/init02/init02.java b/test/hotspot/jtreg/vmTestbase/jit/init/init02/init02.java index edbde0bf43c..e2a8148fa43 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/init/init02/init02.java +++ b/test/hotspot/jtreg/vmTestbase/jit/init/init02/init02.java @@ -35,15 +35,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.init.init02.init02 - * @run driver ExecDriver --java jit.init.init02.init02 + * @run main/othervm jit.init.init02.init02 */ package jit.init.init02; import nsk.share.TestFailure; -class init02 { +public class init02 { public static boolean failed = false; public static void main(String args[]) { int i, x; diff --git a/test/hotspot/jtreg/vmTestbase/jit/inline/inline003/inline003.java b/test/hotspot/jtreg/vmTestbase/jit/inline/inline003/inline003.java index af69d62d189..24792decd7c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/inline/inline003/inline003.java +++ b/test/hotspot/jtreg/vmTestbase/jit/inline/inline003/inline003.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.inline.inline003.inline003 - * @run driver ExecDriver --java jit.inline.inline003.inline003 + * @run main/othervm jit.inline.inline003.inline003 */ package jit.inline.inline003; @@ -48,7 +47,7 @@ class inline003_1 { final protected static int[] trash = { 10, 11}; } -class inline003 extends inline003_1 { +public class inline003 extends inline003_1 { public static final GoldChecker goldChecker = new GoldChecker( "inline003" ); final private static int ITERS=4; diff --git a/test/hotspot/jtreg/vmTestbase/jit/inline/inline004/inline004.java b/test/hotspot/jtreg/vmTestbase/jit/inline/inline004/inline004.java index 5f279e7190e..689b8b768d2 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/inline/inline004/inline004.java +++ b/test/hotspot/jtreg/vmTestbase/jit/inline/inline004/inline004.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.inline.inline004.inline004 - * @run driver ExecDriver --java jit.inline.inline004.inline004 + * @run main/othervm jit.inline.inline004.inline004 */ package jit.inline.inline004; @@ -51,7 +50,7 @@ class inline004_1 { } } -class inline004 extends inline004_1 { +public class inline004 extends inline004_1 { public static final GoldChecker goldChecker = new GoldChecker( "inline004" ); static int pFlag = 0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/inline/inline007/inline007.java b/test/hotspot/jtreg/vmTestbase/jit/inline/inline007/inline007.java index 3db807f949e..b570ce540dd 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/inline/inline007/inline007.java +++ b/test/hotspot/jtreg/vmTestbase/jit/inline/inline007/inline007.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,8 +34,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.inline.inline007.inline007 - * @run driver ExecDriver --java jit.inline.inline007.inline007 + * @run main/othervm jit.inline.inline007.inline007 */ package jit.inline.inline007; @@ -158,7 +157,7 @@ class inline007Sub extends inline007Sup { } } -class inline007 extends inline007_1 { +public class inline007 extends inline007_1 { public static final GoldChecker goldChecker = new GoldChecker( "inline007" ); static int[] myIters = new int[14]; diff --git a/test/hotspot/jtreg/vmTestbase/jit/misctests/Pi/Pi.java b/test/hotspot/jtreg/vmTestbase/jit/misctests/Pi/Pi.java index f1786298635..9cd520c8b43 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/misctests/Pi/Pi.java +++ b/test/hotspot/jtreg/vmTestbase/jit/misctests/Pi/Pi.java @@ -30,8 +30,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.misctests.Pi.Pi - * @run driver ExecDriver --java jit.misctests.Pi.Pi + * @run main/othervm jit.misctests.Pi.Pi */ package jit.misctests.Pi; @@ -40,7 +39,7 @@ import java.util.Random; import nsk.share.TestFailure; import jdk.test.lib.Utils; -class Pi{ +public class Pi{ static double pi; static int imKreis=0, imQuadrat=0, i=0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/misctests/t5/t5.java b/test/hotspot/jtreg/vmTestbase/jit/misctests/t5/t5.java index 7f46842052c..68a656b1471 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/misctests/t5/t5.java +++ b/test/hotspot/jtreg/vmTestbase/jit/misctests/t5/t5.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.misctests.t5.t5 - * @run driver ExecDriver --java jit.misctests.t5.t5 + * @run main/othervm jit.misctests.t5.t5 */ package jit.misctests.t5; import nsk.share.TestFailure; -class t5 +public class t5 { public static void main (String [] args) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/overflow/overflow.java b/test/hotspot/jtreg/vmTestbase/jit/overflow/overflow.java index 0471083e427..1d5845d8792 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/overflow/overflow.java +++ b/test/hotspot/jtreg/vmTestbase/jit/overflow/overflow.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.overflow.overflow - * @run driver ExecDriver --java jit.overflow.overflow + * @run main/othervm jit.overflow.overflow */ package jit.overflow; @@ -46,7 +45,7 @@ import java.lang.*; import nsk.share.TestFailure; -class overflow { +public class overflow { public static void main(String[] args) { try { recurse(1); diff --git a/test/hotspot/jtreg/vmTestbase/jit/series/series.java b/test/hotspot/jtreg/vmTestbase/jit/series/series.java index 68e1aedded2..a7b063090a2 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/series/series.java +++ b/test/hotspot/jtreg/vmTestbase/jit/series/series.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.series.series - * @run driver ExecDriver --java jit.series.series + * @run main/othervm jit.series.series */ package jit.series; @@ -39,7 +38,7 @@ package jit.series; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class series { +public class series { public static final GoldChecker goldChecker = new GoldChecker( "series" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t001/t001.java b/test/hotspot/jtreg/vmTestbase/jit/t/t001/t001.java index 947376ea15a..4bbd176806f 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t001/t001.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t001/t001.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t001.t001 - * @run driver ExecDriver --java jit.t.t001.t001 + * @run main/othervm jit.t.t001.t001 */ package jit.t.t001; @@ -39,7 +38,7 @@ package jit.t.t001; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t001 +public class t001 { public static final GoldChecker goldChecker = new GoldChecker( "t001" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t002/t002.java b/test/hotspot/jtreg/vmTestbase/jit/t/t002/t002.java index ac147f89b3a..f64e0f6b811 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t002/t002.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t002/t002.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t002.t002 - * @run driver ExecDriver --java jit.t.t002.t002 + * @run main/othervm jit.t.t002.t002 */ package jit.t.t002; @@ -39,7 +38,7 @@ package jit.t.t002; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t002 +public class t002 { public static final GoldChecker goldChecker = new GoldChecker( "t002" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t003/t003.java b/test/hotspot/jtreg/vmTestbase/jit/t/t003/t003.java index 643f8365577..161485862fb 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t003/t003.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t003/t003.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t003.t003 - * @run driver ExecDriver --java jit.t.t003.t003 + * @run main/othervm jit.t.t003.t003 */ package jit.t.t003; @@ -39,7 +38,7 @@ package jit.t.t003; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t003 +public class t003 { public static final GoldChecker goldChecker = new GoldChecker( "t003" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t004/t004.java b/test/hotspot/jtreg/vmTestbase/jit/t/t004/t004.java index 13fb1507867..122c24832c3 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t004/t004.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t004/t004.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t004.t004 - * @run driver ExecDriver --java jit.t.t004.t004 + * @run main/othervm jit.t.t004.t004 */ package jit.t.t004; @@ -39,7 +38,7 @@ package jit.t.t004; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t004 +public class t004 { public static final GoldChecker goldChecker = new GoldChecker( "t004" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t005/t005.java b/test/hotspot/jtreg/vmTestbase/jit/t/t005/t005.java index 9d3eeae0d66..23e12f16955 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t005/t005.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t005/t005.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t005.t005 - * @run driver ExecDriver --java jit.t.t005.t005 + * @run main/othervm jit.t.t005.t005 */ package jit.t.t005; @@ -39,7 +38,7 @@ package jit.t.t005; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t005 +public class t005 { public static final GoldChecker goldChecker = new GoldChecker( "t005" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t006/t006.java b/test/hotspot/jtreg/vmTestbase/jit/t/t006/t006.java index 7e55b409ae6..cea3a24e922 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t006/t006.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t006/t006.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t006.t006 - * @run driver ExecDriver --java jit.t.t006.t006 + * @run main/othervm jit.t.t006.t006 */ package jit.t.t006; @@ -39,7 +38,7 @@ package jit.t.t006; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t006 +public class t006 { public static final GoldChecker goldChecker = new GoldChecker( "t006" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t007/t007.java b/test/hotspot/jtreg/vmTestbase/jit/t/t007/t007.java index 73c251f4373..18cb99eacb4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t007/t007.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t007/t007.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t007.t007 - * @run driver ExecDriver --java jit.t.t007.t007 + * @run main/othervm jit.t.t007.t007 */ package jit.t.t007; import nsk.share.TestFailure; -class t007 +public class t007 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t008/t008.java b/test/hotspot/jtreg/vmTestbase/jit/t/t008/t008.java index 2ec131110a3..0e3d807dfda 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t008/t008.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t008/t008.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t008.t008 - * @run driver ExecDriver --java jit.t.t008.t008 + * @run main/othervm jit.t.t008.t008 */ package jit.t.t008; import nsk.share.TestFailure; -class t008 +public class t008 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t009/t009.java b/test/hotspot/jtreg/vmTestbase/jit/t/t009/t009.java index 0497e50f90f..c1d7a3bc8d7 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t009/t009.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t009/t009.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t009.t009 - * @run driver ExecDriver --java jit.t.t009.t009 + * @run main/othervm jit.t.t009.t009 */ package jit.t.t009; import nsk.share.TestFailure; -class t009 +public class t009 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t011/t011.java b/test/hotspot/jtreg/vmTestbase/jit/t/t011/t011.java index 537204c28cf..d2c38cb0910 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t011/t011.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t011/t011.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t011.t011 - * @run driver ExecDriver --java jit.t.t011.t011 + * @run main/othervm jit.t.t011.t011 */ package jit.t.t011; @@ -39,7 +38,7 @@ package jit.t.t011; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t011 +public class t011 { public static final GoldChecker goldChecker = new GoldChecker( "t011" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t012/t012.java b/test/hotspot/jtreg/vmTestbase/jit/t/t012/t012.java index 0f8d5261d7b..ef09580e5fe 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t012/t012.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t012/t012.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t012.t012 - * @run driver ExecDriver --java jit.t.t012.t012 + * @run main/othervm jit.t.t012.t012 */ package jit.t.t012; import nsk.share.TestFailure; -class t012 +public class t012 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t013/t013.java b/test/hotspot/jtreg/vmTestbase/jit/t/t013/t013.java index 597aa364ba5..b36ee5e8823 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t013/t013.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t013/t013.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t013.t013 - * @run driver ExecDriver --java jit.t.t013.t013 + * @run main/othervm jit.t.t013.t013 */ package jit.t.t013; @@ -44,7 +43,7 @@ class Globals { static public int MaxDisks = 64; // this will do! } -class t013 { +public class t013 { public static final GoldChecker goldChecker = new GoldChecker( "t013" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t014/t014.java b/test/hotspot/jtreg/vmTestbase/jit/t/t014/t014.java index 65f02d0bfe0..35c17ef2798 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t014/t014.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t014/t014.java @@ -29,15 +29,14 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t014.t014 - * @run driver ExecDriver --java jit.t.t014.t014 + * @run main/othervm jit.t.t014.t014 */ package jit.t.t014; import nsk.share.TestFailure; -class t014 +public class t014 { void foo() { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t015/t015.java b/test/hotspot/jtreg/vmTestbase/jit/t/t015/t015.java index e969f8ab549..3592b3d325e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t015/t015.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t015/t015.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t015.t015 - * @run driver ExecDriver --java jit.t.t015.t015 + * @run main/othervm jit.t.t015.t015 */ package jit.t.t015; @@ -39,7 +38,7 @@ package jit.t.t015; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t015 +public class t015 { public static final GoldChecker goldChecker = new GoldChecker( "t015" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t016/t016.java b/test/hotspot/jtreg/vmTestbase/jit/t/t016/t016.java index 00d9097b380..ceb7fcd131c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t016/t016.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t016/t016.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t016.t016 - * @run driver ExecDriver --java jit.t.t016.t016 + * @run main/othervm jit.t.t016.t016 */ package jit.t.t016; @@ -39,7 +38,7 @@ package jit.t.t016; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t016 +public class t016 { public static final GoldChecker goldChecker = new GoldChecker( "t016" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t017/t017.java b/test/hotspot/jtreg/vmTestbase/jit/t/t017/t017.java index 18ec1b4e077..cd86dea3774 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t017/t017.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t017/t017.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t017.t017 - * @run driver ExecDriver --java jit.t.t017.t017 + * @run main/othervm jit.t.t017.t017 */ package jit.t.t017; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_arraylength -class t017 +public class t017 { public static final GoldChecker goldChecker = new GoldChecker( "t017" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t018/t018.java b/test/hotspot/jtreg/vmTestbase/jit/t/t018/t018.java index 70439d515ae..36ae1c28405 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t018/t018.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t018/t018.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t018.t018 - * @run driver ExecDriver --java jit.t.t018.t018 + * @run main/othervm jit.t.t018.t018 */ package jit.t.t018; @@ -51,7 +50,7 @@ class jj extends Throwable } } -class t018 +public class t018 { public static final GoldChecker goldChecker = new GoldChecker( "t018" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t019/t019.java b/test/hotspot/jtreg/vmTestbase/jit/t/t019/t019.java index 641482bcef6..41e5e4f1d6d 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t019/t019.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t019/t019.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t019.t019 - * @run driver ExecDriver --java jit.t.t019.t019 + * @run main/othervm jit.t.t019.t019 */ package jit.t.t019; @@ -43,7 +42,7 @@ import nsk.share.GoldChecker; // opc_caload, opc_castore, // opc_saload, opc_sastore -class t019 +public class t019 { public static final GoldChecker goldChecker = new GoldChecker( "t019" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t020/t020.java b/test/hotspot/jtreg/vmTestbase/jit/t/t020/t020.java index 2c4167a0c7c..7a272eed4d5 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t020/t020.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t020/t020.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t020.t020 - * @run driver ExecDriver --java jit.t.t020.t020 + * @run main/othervm jit.t.t020.t020 */ package jit.t.t020; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_checkcast, opc_instanceof, opc_ifnull, opc_ifnonnull -class t020 +public class t020 { public static final GoldChecker goldChecker = new GoldChecker( "t020" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t021/t021.java b/test/hotspot/jtreg/vmTestbase/jit/t/t021/t021.java index 9caed6caf4f..9e85e4b9168 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t021/t021.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t021/t021.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t021.t021 - * @run driver ExecDriver --java jit.t.t021.t021 + * @run main/othervm jit.t.t021.t021 */ package jit.t.t021; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_fconst_0, opc_fconst_1, opc_fconst_2, opc_fload_, opc_fload, // opc_fadd, opc_fsub, opc_fmul, opc_fdiv -class t021 +public class t021 { public static final GoldChecker goldChecker = new GoldChecker( "t021" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t022/t022.java b/test/hotspot/jtreg/vmTestbase/jit/t/t022/t022.java index a1188b2998e..72f1b1a3e71 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t022/t022.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t022/t022.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t022.t022 - * @run driver ExecDriver --java jit.t.t022.t022 + * @run main/othervm jit.t.t022.t022 */ package jit.t.t022; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // The double-precision version of t021.java. -class t022 +public class t022 { public static final GoldChecker goldChecker = new GoldChecker( "t022" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t023/t023.java b/test/hotspot/jtreg/vmTestbase/jit/t/t023/t023.java index 0d2ef87fb46..b6b1e9c91df 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t023/t023.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t023/t023.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t023.t023 - * @run driver ExecDriver --java jit.t.t023.t023 + * @run main/othervm jit.t.t023.t023 */ package jit.t.t023; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_d2f, opc_d2i, opc_d2l -class t023 +public class t023 { public static final GoldChecker goldChecker = new GoldChecker( "t023" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t024/t024.java b/test/hotspot/jtreg/vmTestbase/jit/t/t024/t024.java index 2ca8683620e..7490f1bcb66 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t024/t024.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t024/t024.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t024.t024 - * @run driver ExecDriver --java jit.t.t024.t024 + * @run main/othervm jit.t.t024.t024 */ package jit.t.t024; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_f2d, opc_f2i, opc_f2l -class t024 +public class t024 { public static final GoldChecker goldChecker = new GoldChecker( "t024" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t025/t025.java b/test/hotspot/jtreg/vmTestbase/jit/t/t025/t025.java index c84421f3d80..ec40c2f2e49 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t025/t025.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t025/t025.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t025.t025 - * @run driver ExecDriver --java jit.t.t025.t025 + * @run main/othervm jit.t.t025.t025 */ package jit.t.t025; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_daload, opc_dastore, opc_faload, opc_fastore -class t025 +public class t025 { public static final GoldChecker goldChecker = new GoldChecker( "t025" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t026/t026.java b/test/hotspot/jtreg/vmTestbase/jit/t/t026/t026.java index 0a531426491..0e61e267cc5 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t026/t026.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t026/t026.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t026.t026 - * @run driver ExecDriver --java jit.t.t026.t026 + * @run main/othervm jit.t.t026.t026 */ package jit.t.t026; @@ -39,7 +38,7 @@ import nsk.share.TestFailure; // opc_areturn -class t026 +public class t026 { t026 foo() { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t027/t027.java b/test/hotspot/jtreg/vmTestbase/jit/t/t027/t027.java index f9a3dd7a23d..7474412bca4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t027/t027.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t027/t027.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t027.t027 - * @run driver ExecDriver --java jit.t.t027.t027 + * @run main/othervm jit.t.t027.t027 */ package jit.t.t027; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_dcmpg, opc_dcmpl -class t027 +public class t027 { public static final GoldChecker goldChecker = new GoldChecker( "t027" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t028/t028.java b/test/hotspot/jtreg/vmTestbase/jit/t/t028/t028.java index c8d5316bbe7..0b2f28f7c16 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t028/t028.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t028/t028.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t028.t028 - * @run driver ExecDriver --java jit.t.t028.t028 + * @run main/othervm jit.t.t028.t028 */ package jit.t.t028; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_dneg, opc_fneg -class t028 +public class t028 { public static final GoldChecker goldChecker = new GoldChecker( "t028" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t029/t029.java b/test/hotspot/jtreg/vmTestbase/jit/t/t029/t029.java index 68f06352380..cf86aea3166 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t029/t029.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t029/t029.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t029.t029 - * @run driver ExecDriver --java jit.t.t029.t029 + * @run main/othervm jit.t.t029.t029 */ package jit.t.t029; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_drem, opc_frem, opc_dreturn opc_freturn -class t029 +public class t029 { public static final GoldChecker goldChecker = new GoldChecker( "t029" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t030/t030.java b/test/hotspot/jtreg/vmTestbase/jit/t/t030/t030.java index 9955e58d3cf..3121d6217be 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t030/t030.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t030/t030.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t030.t030 - * @run driver ExecDriver --java jit.t.t030.t030 + * @run main/othervm jit.t.t030.t030 */ package jit.t.t030; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_dup2, opc_dup2_x1, opc_dup2_x2 -class t030 +public class t030 { public static final GoldChecker goldChecker = new GoldChecker( "t030" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t031/t031.java b/test/hotspot/jtreg/vmTestbase/jit/t/t031/t031.java index 60890bae826..485172cca47 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t031/t031.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t031/t031.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t031.t031 - * @run driver ExecDriver --java jit.t.t031.t031 + * @run main/othervm jit.t.t031.t031 */ package jit.t.t031; @@ -42,7 +41,7 @@ import nsk.share.GoldChecker; // opc_fcmpg, opc_fcmpl -class t031 +public class t031 { public static final GoldChecker goldChecker = new GoldChecker( "t031" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t032/t032.java b/test/hotspot/jtreg/vmTestbase/jit/t/t032/t032.java index 796c2516fc7..55277399e2f 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t032/t032.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t032/t032.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t032.t032 - * @run driver ExecDriver --java jit.t.t032.t032 + * @run main/othervm jit.t.t032.t032 */ package jit.t.t032; @@ -42,7 +41,7 @@ import nsk.share.GoldChecker; // opc_i2d, opc_i2f, opc_i2l // opc_l2d, opc_l2f, opc_l2i -class t032 +public class t032 { public static final GoldChecker goldChecker = new GoldChecker( "t032" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t033/t033.java b/test/hotspot/jtreg/vmTestbase/jit/t/t033/t033.java index b27b5215d96..8e0c4be2522 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t033/t033.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t033/t033.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t033.t033 - * @run driver ExecDriver --java jit.t.t033.t033 + * @run main/othervm jit.t.t033.t033 */ package jit.t.t033; @@ -42,7 +41,7 @@ import nsk.share.GoldChecker; // opc_iand, opc_ior, opc_ixor // opc_land, opc_lor, opc_lxor -class t033 +public class t033 { public static final GoldChecker goldChecker = new GoldChecker( "t033" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t034/t034.java b/test/hotspot/jtreg/vmTestbase/jit/t/t034/t034.java index 1385fb2f52b..f92b971ec30 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t034/t034.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t034/t034.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t034.t034 - * @run driver ExecDriver --java jit.t.t034.t034 + * @run main/othervm jit.t.t034.t034 */ package jit.t.t034; @@ -50,7 +49,7 @@ import nsk.share.GoldChecker; // opc_lrem // opc_lsub -class t034 +public class t034 { public static final GoldChecker goldChecker = new GoldChecker( "t034" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t035/t035.java b/test/hotspot/jtreg/vmTestbase/jit/t/t035/t035.java index a28188cc20e..99bdb5a2f7e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t035/t035.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t035/t035.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t035.t035 - * @run driver ExecDriver --java jit.t.t035.t035 + * @run main/othervm jit.t.t035.t035 */ package jit.t.t035; @@ -50,7 +49,7 @@ import nsk.share.GoldChecker; // opc_lrem // opc_lsub -class t035 +public class t035 { public static final GoldChecker goldChecker = new GoldChecker( "t035" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t036/t036.java b/test/hotspot/jtreg/vmTestbase/jit/t/t036/t036.java index ab4c81ac9ac..41ce4d38cfa 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t036/t036.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t036/t036.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t036.t036 - * @run driver ExecDriver --java jit.t.t036.t036 + * @run main/othervm jit.t.t036.t036 */ package jit.t.t036; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_int2byte, opc_int2char, opc_int2short -class t036 +public class t036 { public static final GoldChecker goldChecker = new GoldChecker( "t036" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t037/t037.java b/test/hotspot/jtreg/vmTestbase/jit/t/t037/t037.java index 87ac4f7540b..ab9cec8a087 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t037/t037.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t037/t037.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t037.t037 - * @run driver ExecDriver --java jit.t.t037.t037 + * @run main/othervm jit.t.t037.t037 */ package jit.t.t037; @@ -46,7 +45,7 @@ interface foo void doit(); } -class t037 implements foo +public class t037 implements foo { public static final GoldChecker goldChecker = new GoldChecker( "t037" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t038/t038.java b/test/hotspot/jtreg/vmTestbase/jit/t/t038/t038.java index 8ba0fab425c..7e999415dd7 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t038/t038.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t038/t038.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t038.t038 - * @run driver ExecDriver --java jit.t.t038.t038 + * @run main/othervm jit.t.t038.t038 */ package jit.t.t038; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_laload, opc_lastore, opc_lconst_0 -class t038 +public class t038 { public static final GoldChecker goldChecker = new GoldChecker( "t038" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t039/t039.java b/test/hotspot/jtreg/vmTestbase/jit/t/t039/t039.java index ce4ca0b3aa4..a48e51cd1a4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t039/t039.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t039/t039.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t039.t039 - * @run driver ExecDriver --java jit.t.t039.t039 + * @run main/othervm jit.t.t039.t039 */ package jit.t.t039; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // opc_lreturn, opc_monitorenter, opc_monitorexit -class t039 +public class t039 { public static final GoldChecker goldChecker = new GoldChecker( "t039" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t040/t040.java b/test/hotspot/jtreg/vmTestbase/jit/t/t040/t040.java index b6390a013b7..3ee452c3404 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t040/t040.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t040/t040.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t040.t040 - * @run driver ExecDriver --java jit.t.t040.t040 + * @run main/othervm jit.t.t040.t040 */ package jit.t.t040; @@ -42,7 +41,7 @@ import nsk.share.GoldChecker; // opc_multianewarray -class t040 +public class t040 { public static final GoldChecker goldChecker = new GoldChecker( "t040" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t041/t041.java b/test/hotspot/jtreg/vmTestbase/jit/t/t041/t041.java index cb7791270dd..dcd810e71ea 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t041/t041.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t041/t041.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t041.t041 - * @run driver ExecDriver --java jit.t.t041.t041 + * @run main/othervm jit.t.t041.t041 */ package jit.t.t041; @@ -39,7 +38,7 @@ import nsk.share.TestFailure; // opc_swap -class t041 +public class t041 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t042/t042.java b/test/hotspot/jtreg/vmTestbase/jit/t/t042/t042.java index 9d8f0eb2513..f1db6947173 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t042/t042.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t042/t042.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t042.t042 - * @run driver ExecDriver --java jit.t.t042.t042 + * @run main/othervm jit.t.t042.t042 */ package jit.t.t042; @@ -42,7 +41,7 @@ import nsk.share.GoldChecker; // The special little twiddle that occurs when you invoke a method // of an array. -class t042 +public class t042 { public static final GoldChecker goldChecker = new GoldChecker( "t042" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t043/t043.java b/test/hotspot/jtreg/vmTestbase/jit/t/t043/t043.java index d5d9f347fc2..ce2abfb4ff9 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t043/t043.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t043/t043.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t043.t043 - * @run driver ExecDriver --java jit.t.t043.t043 + * @run main/othervm jit.t.t043.t043 */ package jit.t.t043; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Register jams and spills -class t043 +public class t043 { public static final GoldChecker goldChecker = new GoldChecker( "t043" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t044/t044.java b/test/hotspot/jtreg/vmTestbase/jit/t/t044/t044.java index dba9c007966..29c277d4829 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t044/t044.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t044/t044.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t044.t044 - * @run driver ExecDriver --java jit.t.t044.t044 + * @run main/othervm jit.t.t044.t044 */ package jit.t.t044; @@ -39,7 +38,7 @@ import nsk.share.TestFailure; // Call interferes with one lazy load but not the other. -class t044 +public class t044 { static double x = 409.0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t045/t045.java b/test/hotspot/jtreg/vmTestbase/jit/t/t045/t045.java index 2f37a96b413..1fe84be05b8 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t045/t045.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t045/t045.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t045.t045 - * @run driver ExecDriver --java jit.t.t045.t045 + * @run main/othervm jit.t.t045.t045 */ package jit.t.t045; @@ -39,7 +38,7 @@ import nsk.share.TestFailure; // Putfield interferes with one lazy load but not the other. -class t045 +public class t045 { static double x = 409.0; static double y; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t046/t046.java b/test/hotspot/jtreg/vmTestbase/jit/t/t046/t046.java index ff595b81fbd..34991b68b64 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t046/t046.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t046/t046.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t046.t046 - * @run driver ExecDriver --java jit.t.t046.t046 + * @run main/othervm jit.t.t046.t046 */ package jit.t.t046; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Register jams and spills -class t046 +public class t046 { public static final GoldChecker goldChecker = new GoldChecker( "t046" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t047/t047.java b/test/hotspot/jtreg/vmTestbase/jit/t/t047/t047.java index f44ba40a789..e447dd4992e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t047/t047.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t047/t047.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t047.t047 - * @run driver ExecDriver --java jit.t.t047.t047 + * @run main/othervm jit.t.t047.t047 */ package jit.t.t047; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Register jams and spills -class t047 +public class t047 { public static final GoldChecker goldChecker = new GoldChecker( "t047" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t048/t048.java b/test/hotspot/jtreg/vmTestbase/jit/t/t048/t048.java index 3abc9f42d91..24378f8f885 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t048/t048.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t048/t048.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t048.t048 - * @run driver ExecDriver --java jit.t.t048.t048 + * @run main/othervm jit.t.t048.t048 */ package jit.t.t048; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Register jams and spills -class t048 +public class t048 { public static final GoldChecker goldChecker = new GoldChecker( "t048" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t049/t049.java b/test/hotspot/jtreg/vmTestbase/jit/t/t049/t049.java index 1d19325cee5..bb0ac8e5cf4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t049/t049.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t049/t049.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t049.t049 - * @run driver ExecDriver --java jit.t.t049.t049 + * @run main/othervm jit.t.t049.t049 */ package jit.t.t049; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Register jams and spills -class t049 +public class t049 { public static final GoldChecker goldChecker = new GoldChecker( "t049" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t050/t050.java b/test/hotspot/jtreg/vmTestbase/jit/t/t050/t050.java index adc3eb4ace0..316187bfa59 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t050/t050.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t050/t050.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t050.t050 - * @run driver ExecDriver --java jit.t.t050.t050 + * @run main/othervm jit.t.t050.t050 */ package jit.t.t050; @@ -39,7 +38,7 @@ import nsk.share.TestFailure; // Pending local load clobbered by local store. -class t050 +public class t050 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t051/t051.java b/test/hotspot/jtreg/vmTestbase/jit/t/t051/t051.java index 8cd0d32abe6..075c99a22d4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t051/t051.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t051/t051.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t051.t051 - * @run driver ExecDriver --java jit.t.t051.t051 + * @run main/othervm jit.t.t051.t051 */ package jit.t.t051; @@ -39,7 +38,7 @@ package jit.t.t051; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t051 +public class t051 { public static final GoldChecker goldChecker = new GoldChecker( "t051" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t052/t052.java b/test/hotspot/jtreg/vmTestbase/jit/t/t052/t052.java index f3c534f5183..57b82d6bdf8 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t052/t052.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t052/t052.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t052.t052 - * @run driver ExecDriver --java jit.t.t052.t052 + * @run main/othervm jit.t.t052.t052 */ package jit.t.t052; @@ -43,7 +42,7 @@ import nsk.share.GoldChecker; // its way in among the tests, it failed because of a failure correctly // to reverse the sense of an integer branch when swapping the operands. -class t052 { +public class t052 { public static final GoldChecker goldChecker = new GoldChecker( "t052" ); static double aa[][],dd[][],x[][],y[][], diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t053/t053.java b/test/hotspot/jtreg/vmTestbase/jit/t/t053/t053.java index c36b239c2dd..fabf8e12529 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t053/t053.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t053/t053.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t053.t053 - * @run driver ExecDriver --java jit.t.t053.t053 + * @run main/othervm jit.t.t053.t053 */ package jit.t.t053; @@ -43,7 +42,7 @@ import nsk.share.GoldChecker; // Tomcatv in java, with prints active // -class t053 { +public class t053 { public static final GoldChecker goldChecker = new GoldChecker( "t053" ); static double aa[][],dd[][],x[][],y[][], diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t054/t054.java b/test/hotspot/jtreg/vmTestbase/jit/t/t054/t054.java index 439add7ce39..0c35006c451 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t054/t054.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t054/t054.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t054.t054 - * @run driver ExecDriver --java jit.t.t054.t054 + * @run main/othervm jit.t.t054.t054 */ package jit.t.t054; @@ -43,7 +42,7 @@ import nsk.share.GoldChecker; // A more comprehensive test for the tomcatv bug, that being failure // correctly to reverse the sense of a jump. -class t054 +public class t054 { public static final GoldChecker goldChecker = new GoldChecker( "t054" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t055/t055.java b/test/hotspot/jtreg/vmTestbase/jit/t/t055/t055.java index 3d6c64f7f0a..5c64917c432 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t055/t055.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t055/t055.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t055.t055 - * @run driver ExecDriver --java jit.t.t055.t055 + * @run main/othervm jit.t.t055.t055 */ package jit.t.t055; @@ -39,7 +38,7 @@ package jit.t.t055; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t055 +public class t055 { public static final GoldChecker goldChecker = new GoldChecker( "t055" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t056/t056.java b/test/hotspot/jtreg/vmTestbase/jit/t/t056/t056.java index 81605c82aed..ab6c99c44d0 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t056/t056.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t056/t056.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t056.t056 - * @run driver ExecDriver --java jit.t.t056.t056 + * @run main/othervm jit.t.t056.t056 */ package jit.t.t056; @@ -39,7 +38,7 @@ package jit.t.t056; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t056 +public class t056 { // Routine nest in which exception is thrown and caught in // the fourth routine. diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t057/t057.java b/test/hotspot/jtreg/vmTestbase/jit/t/t057/t057.java index 1509ee6d6b6..cbbb34cf56a 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t057/t057.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t057/t057.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t057.t057 - * @run driver ExecDriver --java jit.t.t057.t057 + * @run main/othervm jit.t.t057.t057 */ package jit.t.t057; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Just like t056 except here the exception is not explicitly thrown. -class t057 +public class t057 { public static final GoldChecker goldChecker = new GoldChecker( "t057" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t058/t058.java b/test/hotspot/jtreg/vmTestbase/jit/t/t058/t058.java index fa388d76c3f..0ecac5408ea 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t058/t058.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t058/t058.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t058.t058 - * @run driver ExecDriver --java jit.t.t058.t058 + * @run main/othervm jit.t.t058.t058 */ package jit.t.t058; @@ -83,7 +82,7 @@ class k implements l } } -class t058 +public class t058 { public static final GoldChecker goldChecker = new GoldChecker( "t058" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t059/t059.java b/test/hotspot/jtreg/vmTestbase/jit/t/t059/t059.java index 7a07bc0298c..6e057d604c6 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t059/t059.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t059/t059.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t059.t059 - * @run driver ExecDriver --java jit.t.t059.t059 + * @run main/othervm jit.t.t059.t059 */ package jit.t.t059; @@ -39,7 +38,7 @@ package jit.t.t059; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t059 +public class t059 { public static final GoldChecker goldChecker = new GoldChecker( "t059" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t060/t060.java b/test/hotspot/jtreg/vmTestbase/jit/t/t060/t060.java index affab1d22d6..8e27e457061 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t060/t060.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t060/t060.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t060.t060 - * @run driver ExecDriver --java jit.t.t060.t060 + * @run main/othervm jit.t.t060.t060 */ package jit.t.t060; @@ -39,7 +38,7 @@ package jit.t.t060; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t060 +public class t060 { public static final GoldChecker goldChecker = new GoldChecker( "t060" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t061/t061.java b/test/hotspot/jtreg/vmTestbase/jit/t/t061/t061.java index d7982cb22bb..c4c8c407a80 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t061/t061.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t061/t061.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t061.t061 - * @run driver ExecDriver --java jit.t.t061.t061 + * @run main/othervm jit.t.t061.t061 */ package jit.t.t061; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Long and double array loads with variable and constant subscripts. -class t061 +public class t061 { public static final GoldChecker goldChecker = new GoldChecker( "t061" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t062/t062.java b/test/hotspot/jtreg/vmTestbase/jit/t/t062/t062.java index f6515d4d62c..ba65213b278 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t062/t062.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t062/t062.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t062.t062 - * @run driver ExecDriver --java jit.t.t062.t062 + * @run main/othervm jit.t.t062.t062 */ package jit.t.t062; @@ -47,7 +46,7 @@ interface l void voodoo(); } -class t062 implements l +public class t062 implements l { public static final GoldChecker goldChecker = new GoldChecker( "t062" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t063/t063.java b/test/hotspot/jtreg/vmTestbase/jit/t/t063/t063.java index df0779adb0b..08fe0994cc4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t063/t063.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t063/t063.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t063.t063 - * @run driver ExecDriver --java jit.t.t063.t063 + * @run main/othervm jit.t.t063.t063 */ package jit.t.t063; @@ -39,7 +38,7 @@ package jit.t.t063; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t063 +public class t063 { public static final GoldChecker goldChecker = new GoldChecker( "t063" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t064/t064.java b/test/hotspot/jtreg/vmTestbase/jit/t/t064/t064.java index aee68aef1d1..cb5faa5db30 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t064/t064.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t064/t064.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t064.t064 - * @run driver ExecDriver --java jit.t.t064.t064 + * @run main/othervm jit.t.t064.t064 */ package jit.t.t064; @@ -64,7 +63,7 @@ class l } } -class t064 +public class t064 { public static final GoldChecker goldChecker = new GoldChecker( "t064" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t065/t065.java b/test/hotspot/jtreg/vmTestbase/jit/t/t065/t065.java index e120f8bcf79..588aa2d2956 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t065/t065.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t065/t065.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t065.t065 - * @run driver ExecDriver --java jit.t.t065.t065 + * @run main/othervm jit.t.t065.t065 */ package jit.t.t065; @@ -64,7 +63,7 @@ class l } } -class t065 +public class t065 { public static final GoldChecker goldChecker = new GoldChecker( "t065" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t066/t066.java b/test/hotspot/jtreg/vmTestbase/jit/t/t066/t066.java index 5b2dc9f9e8c..fd7b3725447 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t066/t066.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t066/t066.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.t.t066.t066 - * @run driver ExecDriver --java jit.t.t066.t066 + * @run main/othervm jit.t.t066.t066 */ package jit.t.t066; @@ -41,7 +40,7 @@ import nsk.share.TestFailure; // offsets on the stores of the two halves of the double // constant. -class t066 +public class t066 { public static void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t067/t067.java b/test/hotspot/jtreg/vmTestbase/jit/t/t067/t067.java index cd5890a9451..5f44d56f6ed 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t067/t067.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t067/t067.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t067.t067 - * @run driver ExecDriver --java jit.t.t067.t067 + * @run main/othervm jit.t.t067.t067 */ package jit.t.t067; @@ -39,7 +38,7 @@ package jit.t.t067; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t067 +public class t067 { public static final GoldChecker goldChecker = new GoldChecker( "t067" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t068/t068.java b/test/hotspot/jtreg/vmTestbase/jit/t/t068/t068.java index 320b7db2b08..359fcce291a 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t068/t068.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t068/t068.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t068.t068 - * @run driver ExecDriver --java jit.t.t068.t068 + * @run main/othervm jit.t.t068.t068 */ package jit.t.t068; @@ -39,7 +38,7 @@ package jit.t.t068; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t068 +public class t068 { public static final GoldChecker goldChecker = new GoldChecker( "t068" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t069/t069.java b/test/hotspot/jtreg/vmTestbase/jit/t/t069/t069.java index c0c183bf045..3b1f2263754 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t069/t069.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t069/t069.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t069.t069 - * @run driver ExecDriver --java jit.t.t069.t069 + * @run main/othervm jit.t.t069.t069 */ package jit.t.t069; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Dup, dup_x2, and dup2_x2. -class t069 +public class t069 { public static final GoldChecker goldChecker = new GoldChecker( "t069" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t070/t070.java b/test/hotspot/jtreg/vmTestbase/jit/t/t070/t070.java index ba67926c901..c8efe911b79 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t070/t070.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t070/t070.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t070.t070 - * @run driver ExecDriver --java jit.t.t070.t070 + * @run main/othervm jit.t.t070.t070 */ package jit.t.t070; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Dup, dup_x2, and dup2_x2. -class t070 +public class t070 { public static final GoldChecker goldChecker = new GoldChecker( "t070" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t071/t071.java b/test/hotspot/jtreg/vmTestbase/jit/t/t071/t071.java index 8e08230944b..813da07a39c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t071/t071.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t071/t071.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t071.t071 - * @run driver ExecDriver --java jit.t.t071.t071 + * @run main/othervm jit.t.t071.t071 */ package jit.t.t071; @@ -39,7 +38,7 @@ package jit.t.t071; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t071 +public class t071 { public static final GoldChecker goldChecker = new GoldChecker( "t071" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t072/t072.java b/test/hotspot/jtreg/vmTestbase/jit/t/t072/t072.java index 601d4fd8969..76f7694817b 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t072/t072.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t072/t072.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t072.t072 - * @run driver ExecDriver --java jit.t.t072.t072 + * @run main/othervm jit.t.t072.t072 */ package jit.t.t072; @@ -39,7 +38,7 @@ package jit.t.t072; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t072 +public class t072 { public static final GoldChecker goldChecker = new GoldChecker( "t072" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t073/t073.java b/test/hotspot/jtreg/vmTestbase/jit/t/t073/t073.java index e215adbca04..8fef239324e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t073/t073.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t073/t073.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t073.t073 - * @run driver ExecDriver --java jit.t.t073.t073 + * @run main/othervm jit.t.t073.t073 */ package jit.t.t073; @@ -39,7 +38,7 @@ package jit.t.t073; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t073{ +public class t073{ public static final GoldChecker goldChecker = new GoldChecker( "t073" ); static int i0 = 0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t074/t074.java b/test/hotspot/jtreg/vmTestbase/jit/t/t074/t074.java index 8c07663e365..a65c703ae9e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t074/t074.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t074/t074.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t074.t074 - * @run driver ExecDriver --java jit.t.t074.t074 + * @run main/othervm jit.t.t074.t074 */ package jit.t.t074; @@ -39,7 +38,7 @@ package jit.t.t074; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t074{ +public class t074{ public static final GoldChecker goldChecker = new GoldChecker( "t074" ); static int i0 = 0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t075/t075.java b/test/hotspot/jtreg/vmTestbase/jit/t/t075/t075.java index 85a0b6c9540..9a4d93cda46 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t075/t075.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t075/t075.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t075.t075 - * @run driver ExecDriver --java jit.t.t075.t075 + * @run main/othervm jit.t.t075.t075 */ package jit.t.t075; @@ -39,7 +38,7 @@ package jit.t.t075; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t075{ +public class t075{ public static final GoldChecker goldChecker = new GoldChecker( "t075" ); static int i0 = 0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t076/t076.java b/test/hotspot/jtreg/vmTestbase/jit/t/t076/t076.java index 76bdd70fdcb..7ddd4317b4b 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t076/t076.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t076/t076.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t076.t076 - * @run driver ExecDriver --java jit.t.t076.t076 + * @run main/othervm jit.t.t076.t076 */ package jit.t.t076; @@ -39,7 +38,7 @@ package jit.t.t076; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t076{ +public class t076{ public static final GoldChecker goldChecker = new GoldChecker( "t076" ); static long i0 = 0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t077/t077.java b/test/hotspot/jtreg/vmTestbase/jit/t/t077/t077.java index 9f8a2f2b1b8..ad7c8dc88c4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t077/t077.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t077/t077.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t077.t077 - * @run driver ExecDriver --java jit.t.t077.t077 + * @run main/othervm jit.t.t077.t077 */ package jit.t.t077; @@ -39,7 +38,7 @@ package jit.t.t077; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t077{ +public class t077{ public static final GoldChecker goldChecker = new GoldChecker( "t077" ); static float i0 = 0.0f; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t078/t078.java b/test/hotspot/jtreg/vmTestbase/jit/t/t078/t078.java index 45048e4ab9e..5c15fcf106e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t078/t078.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t078/t078.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t078.t078 - * @run driver ExecDriver --java jit.t.t078.t078 + * @run main/othervm jit.t.t078.t078 */ package jit.t.t078; @@ -39,7 +38,7 @@ package jit.t.t078; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t078{ +public class t078{ public static final GoldChecker goldChecker = new GoldChecker( "t078" ); static double i0 = 0.0; diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t079/t079.java b/test/hotspot/jtreg/vmTestbase/jit/t/t079/t079.java index a5a2b078ecb..126420c001d 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t079/t079.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t079/t079.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t079.t079 - * @run driver ExecDriver --java jit.t.t079.t079 + * @run main/othervm jit.t.t079.t079 */ package jit.t.t079; @@ -39,7 +38,7 @@ package jit.t.t079; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t079 +public class t079 { public static final GoldChecker goldChecker = new GoldChecker( "t079" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t080/t080.java b/test/hotspot/jtreg/vmTestbase/jit/t/t080/t080.java index 694ef5a3802..b667ec05942 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t080/t080.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t080/t080.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t080.t080 - * @run driver ExecDriver --java jit.t.t080.t080 + * @run main/othervm jit.t.t080.t080 */ package jit.t.t080; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Like t079.java except this one has lots of local variables. -class t080 +public class t080 { public static final GoldChecker goldChecker = new GoldChecker( "t080" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t081/t081.java b/test/hotspot/jtreg/vmTestbase/jit/t/t081/t081.java index c087fd07f96..0767b075908 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t081/t081.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t081/t081.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t081.t081 - * @run driver ExecDriver --java jit.t.t081.t081 + * @run main/othervm jit.t.t081.t081 */ package jit.t.t081; @@ -39,7 +38,7 @@ package jit.t.t081; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t081 +public class t081 { public static final GoldChecker goldChecker = new GoldChecker( "t081" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t086/t086.java b/test/hotspot/jtreg/vmTestbase/jit/t/t086/t086.java index fc7886b97e0..66110f510ae 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t086/t086.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t086/t086.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t086.t086 - * @run driver ExecDriver --java jit.t.t086.t086 + * @run main/othervm jit.t.t086.t086 */ package jit.t.t086; @@ -58,7 +57,7 @@ class foo } } -class t086 +public class t086 { public static final GoldChecker goldChecker = new GoldChecker( "t086" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t091/t091.java b/test/hotspot/jtreg/vmTestbase/jit/t/t091/t091.java index c4bbc7aeaa0..2f2447ff170 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t091/t091.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t091/t091.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t091.t091 - * @run driver ExecDriver --java jit.t.t091.t091 + * @run main/othervm jit.t.t091.t091 */ package jit.t.t091; @@ -49,7 +48,7 @@ import nsk.share.GoldChecker; // screwing up the flags in the state[] vector around the wide // instructions. -class t091 +public class t091 { public static final GoldChecker goldChecker = new GoldChecker( "t091" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t093/t093.java b/test/hotspot/jtreg/vmTestbase/jit/t/t093/t093.java index 08f9a41717e..666e69c3b21 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t093/t093.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t093/t093.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t093.t093 - * @run driver ExecDriver --java jit.t.t093.t093 + * @run main/othervm jit.t.t093.t093 */ package jit.t.t093; @@ -39,7 +38,7 @@ package jit.t.t093; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t093 +public class t093 { public static final GoldChecker goldChecker = new GoldChecker( "t093" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t094/t094.java b/test/hotspot/jtreg/vmTestbase/jit/t/t094/t094.java index 8fead244030..03712bcacc1 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t094/t094.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t094/t094.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t094.t094 - * @run driver ExecDriver --java jit.t.t094.t094 + * @run main/othervm jit.t.t094.t094 */ package jit.t.t094; @@ -39,7 +38,7 @@ package jit.t.t094; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t094 +public class t094 { public static final GoldChecker goldChecker = new GoldChecker( "t094" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t095/t095.java b/test/hotspot/jtreg/vmTestbase/jit/t/t095/t095.java index 4f5a1dd8d50..9b44d7ef085 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t095/t095.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t095/t095.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t095.t095 - * @run driver ExecDriver --java jit.t.t095.t095 + * @run main/othervm jit.t.t095.t095 */ package jit.t.t095; @@ -39,7 +38,7 @@ package jit.t.t095; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t095 +public class t095 { public static final GoldChecker goldChecker = new GoldChecker( "t095" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t096/t096.java b/test/hotspot/jtreg/vmTestbase/jit/t/t096/t096.java index fc37d4f1a5c..38e08467911 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t096/t096.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t096/t096.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t096.t096 - * @run driver ExecDriver --java jit.t.t096.t096 + * @run main/othervm jit.t.t096.t096 */ package jit.t.t096; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Empty synchronized methods. -class t096 +public class t096 { public static final GoldChecker goldChecker = new GoldChecker( "t096" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t098/t098.java b/test/hotspot/jtreg/vmTestbase/jit/t/t098/t098.java index d89afe96062..3970930d779 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t098/t098.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t098/t098.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t098.t098 - * @run driver ExecDriver --java jit.t.t098.t098 + * @run main/othervm jit.t.t098.t098 */ package jit.t.t098; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Check for too-wide intermediate results. -class t098 +public class t098 { public static final GoldChecker goldChecker = new GoldChecker( "t098" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t099/t099.java b/test/hotspot/jtreg/vmTestbase/jit/t/t099/t099.java index 06044a38dc1..e09fa3948f2 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t099/t099.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t099/t099.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t099.t099 - * @run driver ExecDriver --java jit.t.t099.t099 + * @run main/othervm jit.t.t099.t099 */ package jit.t.t099; @@ -39,7 +38,7 @@ package jit.t.t099; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t099 +public class t099 { public static final GoldChecker goldChecker = new GoldChecker( "t099" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t100/t100.java b/test/hotspot/jtreg/vmTestbase/jit/t/t100/t100.java index 91a1fd35c9d..22976eb35bf 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t100/t100.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t100/t100.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t100.t100 - * @run driver ExecDriver --java jit.t.t100.t100 + * @run main/othervm jit.t.t100.t100 */ package jit.t.t100; @@ -47,7 +46,7 @@ import java.lang.*; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t100 { +public class t100 { public static final GoldChecker goldChecker = new GoldChecker( "t100" ); public static void main(String[] args) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t101/t101.java b/test/hotspot/jtreg/vmTestbase/jit/t/t101/t101.java index cc8e3f5951d..6c32fd2da9c 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t101/t101.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t101/t101.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t101.t101 - * @run driver ExecDriver --java jit.t.t101.t101 + * @run main/othervm jit.t.t101.t101 */ package jit.t.t101; @@ -45,7 +44,7 @@ import nsk.share.GoldChecker; // // , which ain't anything Ma Intel understands. -class t101 +public class t101 { public static final GoldChecker goldChecker = new GoldChecker( "t101" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t102/t102.java b/test/hotspot/jtreg/vmTestbase/jit/t/t102/t102.java index c73b15eb220..16af8218a5a 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t102/t102.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t102/t102.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t102.t102 - * @run driver ExecDriver --java jit.t.t102.t102 + * @run main/othervm jit.t.t102.t102 */ package jit.t.t102; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Like t101.java except the short intege type is short instead of char. -class t102 +public class t102 { public static final GoldChecker goldChecker = new GoldChecker( "t102" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t103/t103.java b/test/hotspot/jtreg/vmTestbase/jit/t/t103/t103.java index f54a30a76dc..3e96b7c7121 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t103/t103.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t103/t103.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t103.t103 - * @run driver ExecDriver --java jit.t.t103.t103 + * @run main/othervm jit.t.t103.t103 */ package jit.t.t103; @@ -41,7 +40,7 @@ import nsk.share.GoldChecker; // Like t101.java except the short intege type is byte instead of char. -class t103 +public class t103 { public static final GoldChecker goldChecker = new GoldChecker( "t103" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t104/t104.java b/test/hotspot/jtreg/vmTestbase/jit/t/t104/t104.java index 999d7a35c12..1b9c5173389 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t104/t104.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t104/t104.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t104.t104 - * @run driver ExecDriver --java jit.t.t104.t104 + * @run main/othervm jit.t.t104.t104 */ package jit.t.t104; @@ -39,7 +38,7 @@ package jit.t.t104; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t104 +public class t104 { public static final GoldChecker goldChecker = new GoldChecker( "t104" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t105/t105.java b/test/hotspot/jtreg/vmTestbase/jit/t/t105/t105.java index 631f99492c1..9b9f60cf2a9 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t105/t105.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t105/t105.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t105.t105 - * @run driver ExecDriver --java jit.t.t105.t105 + * @run main/othervm jit.t.t105.t105 */ package jit.t.t105; @@ -39,7 +38,7 @@ package jit.t.t105; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t105 +public class t105 { public static final GoldChecker goldChecker = new GoldChecker( "t105" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t106/t106.java b/test/hotspot/jtreg/vmTestbase/jit/t/t106/t106.java index 6169deccd81..a30727543f3 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t106/t106.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t106/t106.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t106.t106 - * @run driver ExecDriver --java jit.t.t106.t106 + * @run main/othervm jit.t.t106.t106 */ package jit.t.t106; @@ -39,7 +38,7 @@ package jit.t.t106; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t106 { +public class t106 { public static final GoldChecker goldChecker = new GoldChecker( "t106" ); static public void main(String argv[]) { diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t107/t107.java b/test/hotspot/jtreg/vmTestbase/jit/t/t107/t107.java index b9d8fd67f51..7b60290cbb2 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t107/t107.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t107/t107.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,8 +30,7 @@ * @library /vmTestbase * /test/lib * @run driver jdk.test.lib.FileInstaller . . - * @build jit.t.t107.t107 - * @run driver ExecDriver --java jit.t.t107.t107 + * @run main/othervm jit.t.t107.t107 */ package jit.t.t107; @@ -39,7 +38,7 @@ package jit.t.t107; import nsk.share.TestFailure; import nsk.share.GoldChecker; -class t107 { +public class t107 { public static final GoldChecker goldChecker = new GoldChecker( "t107" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t108/t108.java b/test/hotspot/jtreg/vmTestbase/jit/t/t108/t108.java index 428324fbd8f..f6897ae5517 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t108/t108.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t108/t108.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import nsk.share.GoldChecker; // Uncaught exception, one jit'd frame on the stack. -class t108 +public class t108 { public static final GoldChecker goldChecker = new GoldChecker( "t108" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t109/t109.java b/test/hotspot/jtreg/vmTestbase/jit/t/t109/t109.java index 7c8683f594f..350dc6eba0e 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t109/t109.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t109/t109.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import nsk.share.GoldChecker; // Uncaught exception, one jit'd frame on the stack, implicit exception. -class t109 +public class t109 { public static final GoldChecker goldChecker = new GoldChecker( "t109" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t110/t110.java b/test/hotspot/jtreg/vmTestbase/jit/t/t110/t110.java index b5ef1388914..c4980144b83 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t110/t110.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t110/t110.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import nsk.share.GoldChecker; // Uncaught exception, one jit'd frame on the stack, implicit exception. -class t110 +public class t110 { public static final GoldChecker goldChecker = new GoldChecker( "t110" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t111/t111.java b/test/hotspot/jtreg/vmTestbase/jit/t/t111/t111.java index d0d82716480..9a78ead1a87 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t111/t111.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t111/t111.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import nsk.share.GoldChecker; // Uncaught exception, one jit'd frame on the stack. -class t111 +public class t111 { public static final GoldChecker goldChecker = new GoldChecker( "t111" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t112/t112.java b/test/hotspot/jtreg/vmTestbase/jit/t/t112/t112.java index 76d422c87fa..32513c7ae40 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t112/t112.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t112/t112.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,7 +30,7 @@ import nsk.share.GoldChecker; // Uncaught exception, one jit'd frame on the stack. -class t112 +public class t112 { public static final GoldChecker goldChecker = new GoldChecker( "t112" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/t/t113/t113.java b/test/hotspot/jtreg/vmTestbase/jit/t/t113/t113.java index f29ddd99f5b..8d484d81d46 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/t/t113/t113.java +++ b/test/hotspot/jtreg/vmTestbase/jit/t/t113/t113.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,7 +44,7 @@ class kid2 extends parent int j; } -class t113 +public class t113 { public static final GoldChecker goldChecker = new GoldChecker( "t113" ); diff --git a/test/hotspot/jtreg/vmTestbase/jit/wide/wide01/wide01.java b/test/hotspot/jtreg/vmTestbase/jit/wide/wide01/wide01.java index b9ef01021cf..caf0b7722f4 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/wide/wide01/wide01.java +++ b/test/hotspot/jtreg/vmTestbase/jit/wide/wide01/wide01.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.wide.wide01.wide01 - * @run driver ExecDriver --java jit.wide.wide01.wide01 + * @run main/othervm jit.wide.wide01.wide01 */ package jit.wide.wide01; @@ -45,7 +44,7 @@ import nsk.share.TestFailure; greater-than-double precision. */ -strictfp class wide01 +strictfp public class wide01 { public static void main(String[] arg) { float f1 = Float.MAX_VALUE; diff --git a/test/hotspot/jtreg/vmTestbase/jit/wide/wide02/wide02.java b/test/hotspot/jtreg/vmTestbase/jit/wide/wide02/wide02.java index 996875d96da..c7e56463e62 100644 --- a/test/hotspot/jtreg/vmTestbase/jit/wide/wide02/wide02.java +++ b/test/hotspot/jtreg/vmTestbase/jit/wide/wide02/wide02.java @@ -29,8 +29,7 @@ * * @library /vmTestbase * /test/lib - * @build jit.wide.wide02.wide02 - * @run driver ExecDriver --java jit.wide.wide02.wide02 + * @run main/othervm jit.wide.wide02.wide02 */ package jit.wide.wide02; @@ -44,7 +43,7 @@ import nsk.share.TestFailure; or if the result of the expression (d0+d53) is maintained in greater-than-double precision. */ -class wide02 +public class wide02 { static double twoto(int n) { double res = 1.0; From b37b1a391a467d1670fc8c4b236a6c4c5518bef6 Mon Sep 17 00:00:00 2001 From: Igor Ignatyev Date: Wed, 5 Aug 2020 16:39:38 -0700 Subject: [PATCH 04/53] 8251126: nsk.share.GoldChecker should read golden file from ${test.src} Reviewed-by: dholmes --- .../vmTestbase/nsk/share/GoldChecker.java | 47 +++++++------------ 1 file changed, 17 insertions(+), 30 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/nsk/share/GoldChecker.java b/test/hotspot/jtreg/vmTestbase/nsk/share/GoldChecker.java index 60821011e2f..6fae81ca7f3 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/share/GoldChecker.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/share/GoldChecker.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -20,16 +20,21 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package nsk.share; -import java.io.*; +import jdk.test.lib.Utils; -public class GoldChecker extends AbstractGoldChecker -{ +import java.io.IOException; +import java.nio.charset.StandardCharsets; +import java.nio.file.Files; +import java.nio.file.Path; + +public class GoldChecker extends AbstractGoldChecker { private final String goldOutput; - public GoldChecker(String main_class_name) { - goldOutput = readGoldStr(main_class_name + ".gold"); + public GoldChecker(String mainClassName) { + goldOutput = readGoldStr(Path.of(Utils.TEST_SRC, mainClassName + ".gold")); } @Override @@ -37,35 +42,17 @@ public class GoldChecker extends AbstractGoldChecker return goldOutput; } - private String readGoldStr(String gold_file_name) { - RandomAccessFile f; - - try { - f = new RandomAccessFile(gold_file_name, "r"); - } catch (FileNotFoundException e) { - throw new TestBug("Unable to open golden file '" + gold_file_name + "' for reading"); + private String readGoldStr(Path goldenFile) { + if (Files.notExists(goldenFile)) { + throw new TestBug("Unable to open golden file '" + goldenFile + "' for reading"); } - byte[] data; - try { - int len = (int)f.length(); - data = new byte[len]; - f.read(data); + data = Files.readAllBytes(goldenFile); } catch (IOException e) { - throw new TestBug("Error reading from golden file'" + gold_file_name + "'"); - } - - try { - f.close(); - } catch (IOException e) { - } - - try { - return new String(data, "US-ASCII"); - } catch (UnsupportedEncodingException e) { - throw new TestFailure( e ); + throw new TestBug("Error reading from golden file '" + goldenFile + "'", e); } + return new String(data, StandardCharsets.US_ASCII); } } From dc86b2e22bd1ab61f3c22105130a3fb9c0fdf8de Mon Sep 17 00:00:00 2001 From: Mikael Vidstedt Date: Wed, 5 Aug 2020 19:05:05 -0700 Subject: [PATCH 05/53] Added tag jdk-16+9 for changeset c075a286cc7d --- .hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags b/.hgtags index 4e4f1670db5..80e6992d687 100644 --- a/.hgtags +++ b/.hgtags @@ -654,3 +654,4 @@ a32f58c6b8be81877411767de7ba9c4cf087c1b5 jdk-15+31 c3a4a7ea7c304cabdacdc31741eb94c51351668d jdk-16+7 b0817631d2f4395508cb10e81c3858a94d9ae4de jdk-15+34 0a73d6f3aab48ff6d7e61e47f0bc2d87a054f217 jdk-16+8 +c075a286cc7df767cce28e8057d6ec5051786490 jdk-16+9 From 2d3372c8b5cad126a93f8290ebc18e116748c71f Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 5 Aug 2020 23:02:22 -0700 Subject: [PATCH 06/53] 8250660: Clarify that WildcardType and AnnotatedWildcardType bounds methods return one Reviewed-by: mchung, dholmes --- .../java/lang/reflect/AnnotatedWildcardType.java | 8 ++++++++ .../share/classes/java/lang/reflect/WildcardType.java | 10 ++++++++-- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java b/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java index 8a211eab6bf..b837143712f 100644 --- a/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java +++ b/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java @@ -40,6 +40,10 @@ public interface AnnotatedWildcardType extends AnnotatedType { * If no lower bound is explicitly declared, the lower bound is the * type of null. In this case, a zero length array is returned. * + * @apiNote While to date a wildcard may have at most one lower + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return the potentially annotated lower bounds of this wildcard type or * an empty array if no lower bound is explicitly declared. * @see WildcardType#getLowerBounds() @@ -51,6 +55,10 @@ public interface AnnotatedWildcardType extends AnnotatedType { * If no upper bound is explicitly declared, the upper bound is * unannotated {@code Object} * + * @apiNote While to date a wildcard may have at most one upper + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return the potentially annotated upper bounds of this wildcard type * @see WildcardType#getUpperBounds() */ diff --git a/src/java.base/share/classes/java/lang/reflect/WildcardType.java b/src/java.base/share/classes/java/lang/reflect/WildcardType.java index 0ef18413ea4..124deb41f4c 100644 --- a/src/java.base/share/classes/java/lang/reflect/WildcardType.java +++ b/src/java.base/share/classes/java/lang/reflect/WildcardType.java @@ -46,6 +46,10 @@ public interface WildcardType extends Type { *

  • Otherwise, B is resolved. * * + * @apiNote While to date a wildcard may have at most one upper + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return an array of Types representing the upper bound(s) of this * type variable * @throws TypeNotPresentException if any of the @@ -70,6 +74,10 @@ public interface WildcardType extends Type { *
  • Otherwise, B is resolved. * * + * @apiNote While to date a wildcard may have at most one lower + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return an array of Types representing the lower bound(s) of this * type variable * @throws TypeNotPresentException if any of the @@ -79,6 +87,4 @@ public interface WildcardType extends Type { * for any reason */ Type[] getLowerBounds(); - // one or many? Up to language spec; currently only one, but this API - // allows for generalization. } From b0e4e9a2e455d3bad45c2d3362fe83ba004b3f96 Mon Sep 17 00:00:00 2001 From: Zhengyu Gu Date: Thu, 6 Aug 2020 08:30:37 -0400 Subject: [PATCH 07/53] 8251192: Shenandoah: Shenandoah build failed after JDK-8235573 Reviewed-by: stuefe, ysuenaga, adityam --- src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp | 1 + 1 file changed, 1 insertion(+) diff --git a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp index c354f510c93..e7b6310b5f2 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp @@ -25,6 +25,7 @@ #ifndef SHARE_GC_SHENANDOAH_SHENANDOAHPHASETIMINGS_HPP #define SHARE_GC_SHENANDOAH_SHENANDOAHPHASETIMINGS_HPP +#include "jfr/jfrEvents.hpp" #include "gc/shenandoah/shenandoahNumberSeq.hpp" #include "gc/shared/workerDataArray.hpp" #include "memory/allocation.hpp" From db4d59cc0c96a6658f8eba3d3bc76f74475ce302 Mon Sep 17 00:00:00 2001 From: Chihiro Ito Date: Thu, 6 Aug 2020 23:47:55 +0900 Subject: [PATCH 08/53] 8250912: Recording#copy() doesn't copy the flush interval Reviewed-by: jbachorik --- src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java | 1 + 1 file changed, 1 insertion(+) diff --git a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java index 7f1f25d61d5..9965f106a7c 100644 --- a/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java +++ b/src/jdk.jfr/share/classes/jdk/jfr/internal/PlatformRecorder.java @@ -505,6 +505,7 @@ public final class PlatformRecorder { copy.setInternalDuration(r.getDuration()); copy.setStartTime(r.getStartTime()); copy.setStopTime(r.getStopTime()); + copy.setFlushInterval(r.getFlushInterval()); if (r.getState() == RecordingState.NEW) { return newRec; From 99c7b2b85b0d3bd138d4dcad083a6ecf1de30b3d Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Thu, 6 Aug 2020 09:58:57 -0700 Subject: [PATCH 09/53] 8249273: Documentation of BigInteger(String) constructor does not mention leading plus Reviewed-by: bpb --- .../share/classes/java/math/BigInteger.java | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/java.base/share/classes/java/math/BigInteger.java b/src/java.base/share/classes/java/math/BigInteger.java index e9fc2d42593..1a73abcf1b7 100644 --- a/src/java.base/share/classes/java/math/BigInteger.java +++ b/src/java.base/share/classes/java/math/BigInteger.java @@ -464,9 +464,10 @@ public class BigInteger extends Number implements Comparable { * specified radix into a BigInteger. The String representation * consists of an optional minus or plus sign followed by a * sequence of one or more digits in the specified radix. The - * character-to-digit mapping is provided by {@code - * Character.digit}. The String may not contain any extraneous - * characters (whitespace, for example). + * character-to-digit mapping is provided by {@link + * Character#digit(char, char) Character.digit}. The String may + * not contain any extraneous characters (whitespace, for + * example). * * @param val String representation of BigInteger. * @param radix radix to be used in interpreting {@code val}. @@ -474,7 +475,6 @@ public class BigInteger extends Number implements Comparable { * of a BigInteger in the specified radix, or {@code radix} is * outside the range from {@link Character#MIN_RADIX} to * {@link Character#MAX_RADIX}, inclusive. - * @see Character#digit */ public BigInteger(String val, int radix) { int cursor = 0, numDigits; @@ -658,17 +658,17 @@ public class BigInteger extends Number implements Comparable { } /** - * Translates the decimal String representation of a BigInteger into a - * BigInteger. The String representation consists of an optional minus - * sign followed by a sequence of one or more decimal digits. The - * character-to-digit mapping is provided by {@code Character.digit}. - * The String may not contain any extraneous characters (whitespace, for - * example). + * Translates the decimal String representation of a BigInteger + * into a BigInteger. The String representation consists of an + * optional minus or plus sign followed by a sequence of one or + * more decimal digits. The character-to-digit mapping is + * provided by {@link Character#digit(char, char) + * Character.digit}. The String may not contain any extraneous + * characters (whitespace, for example). * * @param val decimal String representation of BigInteger. * @throws NumberFormatException {@code val} is not a valid representation * of a BigInteger. - * @see Character#digit */ public BigInteger(String val) { this(val, 10); From deaadfad5247026206a0c8c3068656bff7f68128 Mon Sep 17 00:00:00 2001 From: Lois Foltan Date: Thu, 6 Aug 2020 18:13:56 +0000 Subject: [PATCH 10/53] 8247938: Change various JVM enums like LinkInfo::AccessCheck and Klass::DefaultsLookupMode to enum class Use C++11 scoped enumeration declarations for several different Klass and LinkInfo enumerations. Reviewed-by: coleenp, hseigel, kbarrett --- src/hotspot/share/ci/ciEnv.cpp | 2 +- src/hotspot/share/ci/ciMethod.cpp | 4 +-- src/hotspot/share/classfile/javaClasses.cpp | 2 +- src/hotspot/share/classfile/verifier.cpp | 4 +-- src/hotspot/share/code/dependencies.cpp | 6 ++-- .../share/interpreter/linkResolver.cpp | 20 +++++++------ .../share/interpreter/linkResolver.hpp | 13 ++++----- src/hotspot/share/jvmci/jvmciJavaClasses.cpp | 4 +-- src/hotspot/share/jvmci/jvmciRuntime.cpp | 2 +- src/hotspot/share/oops/arrayKlass.cpp | 2 +- src/hotspot/share/oops/arrayKlass.hpp | 2 +- src/hotspot/share/oops/instanceKlass.cpp | 29 ++++++++++--------- src/hotspot/share/oops/instanceKlass.hpp | 2 +- src/hotspot/share/oops/klass.hpp | 12 ++++---- src/hotspot/share/oops/klassVtable.cpp | 14 +++++---- src/hotspot/share/prims/methodHandles.cpp | 6 ++-- src/hotspot/share/prims/nativeLookup.cpp | 2 +- 17 files changed, 66 insertions(+), 60 deletions(-) diff --git a/src/hotspot/share/ci/ciEnv.cpp b/src/hotspot/share/ci/ciEnv.cpp index 6bee64931c3..15bea52565a 100644 --- a/src/hotspot/share/ci/ciEnv.cpp +++ b/src/hotspot/share/ci/ciEnv.cpp @@ -761,7 +761,7 @@ Method* ciEnv::lookup_method(ciInstanceKlass* accessor, InstanceKlass* accessor_klass = accessor->get_instanceKlass(); Klass* holder_klass = holder->get_Klass(); Method* dest_method; - LinkInfo link_info(holder_klass, name, sig, accessor_klass, LinkInfo::needs_access_check, tag); + LinkInfo link_info(holder_klass, name, sig, accessor_klass, LinkInfo::AccessCheck::required, tag); switch (bc) { case Bytecodes::_invokestatic: dest_method = diff --git a/src/hotspot/share/ci/ciMethod.cpp b/src/hotspot/share/ci/ciMethod.cpp index d771be8dac2..7b2a0fad32b 100644 --- a/src/hotspot/share/ci/ciMethod.cpp +++ b/src/hotspot/share/ci/ciMethod.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -809,7 +809,7 @@ ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver, boo Symbol* h_signature = signature()->get_symbol(); LinkInfo link_info(resolved, h_name, h_signature, caller_klass, - check_access ? LinkInfo::needs_access_check : LinkInfo::skip_access_check); + check_access ? LinkInfo::AccessCheck::required : LinkInfo::AccessCheck::skip); Method* m = NULL; // Only do exact lookup if receiver klass has been linked. Otherwise, // the vtable has not been setup, and the LinkResolver will fail. diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index 393e325b3d3..2e0d93e1859 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -3237,7 +3237,7 @@ oop java_lang_reflect_RecordComponent::create(InstanceKlass* holder, RecordCompo char* sig = NEW_RESOURCE_ARRAY(char, sig_len); jio_snprintf(sig, sig_len, "%c%c%s", JVM_SIGNATURE_FUNC, JVM_SIGNATURE_ENDFUNC, type->as_C_string()); TempNewSymbol full_sig = SymbolTable::new_symbol(sig); - accessor_method = holder->find_instance_method(name, full_sig, Klass::find_private); + accessor_method = holder->find_instance_method(name, full_sig, Klass::PrivateLookupMode::find); } if (accessor_method != NULL) { diff --git a/src/hotspot/share/classfile/verifier.cpp b/src/hotspot/share/classfile/verifier.cpp index 7f0346608a6..15d46af56b2 100644 --- a/src/hotspot/share/classfile/verifier.cpp +++ b/src/hotspot/share/classfile/verifier.cpp @@ -2116,7 +2116,7 @@ bool ClassVerifier::is_protected_access(InstanceKlass* this_class, InstanceKlass* target_instance = InstanceKlass::cast(target_class); fieldDescriptor fd; if (is_method) { - Method* m = target_instance->uncached_lookup_method(field_name, field_sig, Klass::find_overpass); + Method* m = target_instance->uncached_lookup_method(field_name, field_sig, Klass::OverpassLookupMode::find); if (m != NULL && m->is_protected()) { if (!this_class->is_same_class_package(m->method_holder())) { return true; @@ -2709,7 +2709,7 @@ void ClassVerifier::verify_invoke_init( Method* m = InstanceKlass::cast(ref_klass)->uncached_lookup_method( vmSymbols::object_initializer_name(), cp->signature_ref_at(bcs->get_index_u2()), - Klass::find_overpass); + Klass::OverpassLookupMode::find); // Do nothing if method is not found. Let resolution detect the error. if (m != NULL) { InstanceKlass* mh = m->method_holder(); diff --git a/src/hotspot/share/code/dependencies.cpp b/src/hotspot/share/code/dependencies.cpp index 04cfbc90058..ff1956d5c5d 100644 --- a/src/hotspot/share/code/dependencies.cpp +++ b/src/hotspot/share/code/dependencies.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -1197,7 +1197,7 @@ class ClassHierarchyWalker { } else { // Search class hierarchy first, skipping private implementations // as they never override any inherited methods - Method* m = InstanceKlass::cast(k)->find_instance_method(_name, _signature, Klass::skip_private); + Method* m = InstanceKlass::cast(k)->find_instance_method(_name, _signature, Klass::PrivateLookupMode::skip); if (!Dependencies::is_concrete_method(m, k)) { // Check for re-abstraction of method if (!k->is_interface() && m != NULL && m->is_abstract()) { @@ -1207,7 +1207,7 @@ class ClassHierarchyWalker { ClassHierarchyWalker wf(_participants, _num_participants); Klass* w = wf.find_witness_subtype(k); if (w != NULL) { - Method* wm = InstanceKlass::cast(w)->find_instance_method(_name, _signature, Klass::skip_private); + Method* wm = InstanceKlass::cast(w)->find_instance_method(_name, _signature, Klass::PrivateLookupMode::skip); if (!Dependencies::is_concrete_method(wm, w)) { // Found a concrete subtype 'w' which does not override abstract method 'm'. // Bail out because 'm' could be called with 'w' as receiver (leading to an diff --git a/src/hotspot/share/interpreter/linkResolver.cpp b/src/hotspot/share/interpreter/linkResolver.cpp index d8e01e80d2e..c2e01eecf2f 100644 --- a/src/hotspot/share/interpreter/linkResolver.cpp +++ b/src/hotspot/share/interpreter/linkResolver.cpp @@ -328,7 +328,7 @@ Method* LinkResolver::lookup_method_in_klasses(const LinkInfo& link_info, Symbol* signature = link_info.signature(); // Ignore overpasses so statics can be found during resolution - Method* result = klass->uncached_lookup_method(name, signature, Klass::skip_overpass); + Method* result = klass->uncached_lookup_method(name, signature, Klass::OverpassLookupMode::skip); if (klass->is_array_klass()) { // Only consider klass and super klass for arrays @@ -377,11 +377,11 @@ Method* LinkResolver::lookup_instance_method_in_klasses(Klass* klass, Symbol* name, Symbol* signature, Klass::PrivateLookupMode private_mode, TRAPS) { - Method* result = klass->uncached_lookup_method(name, signature, Klass::find_overpass, private_mode); + Method* result = klass->uncached_lookup_method(name, signature, Klass::OverpassLookupMode::find, private_mode); while (result != NULL && result->is_static() && result->method_holder()->super() != NULL) { Klass* super_klass = result->method_holder()->super(); - result = super_klass->uncached_lookup_method(name, signature, Klass::find_overpass, private_mode); + result = super_klass->uncached_lookup_method(name, signature, Klass::OverpassLookupMode::find, private_mode); } if (klass->is_array_klass()) { @@ -410,8 +410,10 @@ int LinkResolver::vtable_index_of_interface_method(Klass* klass, // First check in default method array if (!resolved_method->is_abstract() && ik->default_methods() != NULL) { int index = InstanceKlass::find_method_index(ik->default_methods(), - name, signature, Klass::find_overpass, - Klass::find_static, Klass::find_private); + name, signature, + Klass::OverpassLookupMode::find, + Klass::StaticLookupMode::find, + Klass::PrivateLookupMode::find); if (index >= 0 ) { vtable_index = ik->default_vtable_indices()->at(index); } @@ -430,7 +432,7 @@ Method* LinkResolver::lookup_method_in_interfaces(const LinkInfo& cp_info) { // Specify 'true' in order to skip default methods when searching the // interfaces. Function lookup_method_in_klasses() already looked for // the method in the default methods table. - return ik->lookup_method_in_all_interfaces(cp_info.name(), cp_info.signature(), Klass::skip_defaults); + return ik->lookup_method_in_all_interfaces(cp_info.name(), cp_info.signature(), Klass::DefaultsLookupMode::skip); } Method* LinkResolver::lookup_polymorphic_method(const LinkInfo& link_info, @@ -1087,7 +1089,7 @@ void LinkResolver::resolve_static_call(CallInfo& result, // Use updated LinkInfo to reresolve with resolved method holder LinkInfo new_info(resolved_klass, link_info.name(), link_info.signature(), link_info.current_klass(), - link_info.check_access() ? LinkInfo::needs_access_check : LinkInfo::skip_access_check); + link_info.check_access() ? LinkInfo::AccessCheck::required : LinkInfo::AccessCheck::skip); resolved_method = linktime_resolve_static_method(new_info, CHECK); } @@ -1236,7 +1238,7 @@ void LinkResolver::runtime_resolve_special_method(CallInfo& result, Method* instance_method = lookup_instance_method_in_klasses(super_klass, resolved_method->name(), resolved_method->signature(), - Klass::find_private, CHECK); + Klass::PrivateLookupMode::find, CHECK); sel_method = methodHandle(THREAD, instance_method); // check if found @@ -1478,7 +1480,7 @@ void LinkResolver::runtime_resolve_interface_method(CallInfo& result, Method* method = lookup_instance_method_in_klasses(recv_klass, resolved_method->name(), resolved_method->signature(), - Klass::skip_private, CHECK); + Klass::PrivateLookupMode::skip, CHECK); selected_method = methodHandle(THREAD, method); if (selected_method.is_null() && !check_null_and_abstract) { diff --git a/src/hotspot/share/interpreter/linkResolver.hpp b/src/hotspot/share/interpreter/linkResolver.hpp index a139a8e7a23..96e65f1fac2 100644 --- a/src/hotspot/share/interpreter/linkResolver.hpp +++ b/src/hotspot/share/interpreter/linkResolver.hpp @@ -144,28 +144,25 @@ class LinkInfo : public StackObj { constantTag _tag; public: - enum AccessCheck { - needs_access_check, - skip_access_check - }; + enum class AccessCheck { required, skip }; LinkInfo(const constantPoolHandle& pool, int index, const methodHandle& current_method, TRAPS); LinkInfo(const constantPoolHandle& pool, int index, TRAPS); // Condensed information from other call sites within the vm. LinkInfo(Klass* resolved_klass, Symbol* name, Symbol* signature, Klass* current_klass, - AccessCheck check_access = needs_access_check, + AccessCheck check_access = AccessCheck::required, constantTag tag = JVM_CONSTANT_Invalid) : _name(name), _signature(signature), _resolved_klass(resolved_klass), _current_klass(current_klass), _current_method(methodHandle()), - _check_access(check_access == needs_access_check), _tag(tag) {} + _check_access(check_access == AccessCheck::required), _tag(tag) {} LinkInfo(Klass* resolved_klass, Symbol* name, Symbol* signature, const methodHandle& current_method, - AccessCheck check_access = needs_access_check, + AccessCheck check_access = AccessCheck::required, constantTag tag = JVM_CONSTANT_Invalid) : _name(name), _signature(signature), _resolved_klass(resolved_klass), _current_klass(current_method->method_holder()), _current_method(current_method), - _check_access(check_access == needs_access_check), _tag(tag) {} + _check_access(check_access == AccessCheck::required), _tag(tag) {} // Case where we just find the method and don't check access against the current class LinkInfo(Klass* resolved_klass, Symbol*name, Symbol* signature) : diff --git a/src/hotspot/share/jvmci/jvmciJavaClasses.cpp b/src/hotspot/share/jvmci/jvmciJavaClasses.cpp index 770265f3c1e..4ca4d7cbde0 100644 --- a/src/hotspot/share/jvmci/jvmciJavaClasses.cpp +++ b/src/hotspot/share/jvmci/jvmciJavaClasses.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -89,7 +89,7 @@ void HotSpotJVMCI::compute_offset(int &dest_offset, Klass* klass, const char* na #ifndef PRODUCT static void check_resolve_method(const char* call_type, Klass* resolved_klass, Symbol* method_name, Symbol* method_signature, TRAPS) { Method* method; - LinkInfo link_info(resolved_klass, method_name, method_signature, NULL, LinkInfo::skip_access_check); + LinkInfo link_info(resolved_klass, method_name, method_signature, NULL, LinkInfo::AccessCheck::skip); if (strcmp(call_type, "call_static") == 0) { method = LinkResolver::resolve_static_call_or_null(link_info); } else if (strcmp(call_type, "call_virtual") == 0) { diff --git a/src/hotspot/share/jvmci/jvmciRuntime.cpp b/src/hotspot/share/jvmci/jvmciRuntime.cpp index 84392e4c430..f4bda1ebd7a 100644 --- a/src/hotspot/share/jvmci/jvmciRuntime.cpp +++ b/src/hotspot/share/jvmci/jvmciRuntime.cpp @@ -1322,7 +1322,7 @@ Method* JVMCIRuntime::lookup_method(InstanceKlass* accessor, assert(check_klass_accessibility(accessor, holder), "holder not accessible"); Method* dest_method; - LinkInfo link_info(holder, name, sig, accessor, LinkInfo::needs_access_check, tag); + LinkInfo link_info(holder, name, sig, accessor, LinkInfo::AccessCheck::required, tag); switch (bc) { case Bytecodes::_invokestatic: dest_method = diff --git a/src/hotspot/share/oops/arrayKlass.cpp b/src/hotspot/share/oops/arrayKlass.cpp index 0c116801874..1fdcd175198 100644 --- a/src/hotspot/share/oops/arrayKlass.cpp +++ b/src/hotspot/share/oops/arrayKlass.cpp @@ -79,7 +79,7 @@ Method* ArrayKlass::uncached_lookup_method(const Symbol* name, // Always ignore overpass methods in superclasses, although technically the // super klass of an array, (j.l.Object) should not have // any overpass methods present. - return super()->uncached_lookup_method(name, signature, Klass::skip_overpass, private_mode); + return super()->uncached_lookup_method(name, signature, OverpassLookupMode::skip, private_mode); } ArrayKlass::ArrayKlass(Symbol* name, KlassID id) : diff --git a/src/hotspot/share/oops/arrayKlass.hpp b/src/hotspot/share/oops/arrayKlass.hpp index 5839a630d54..913d2174b0f 100644 --- a/src/hotspot/share/oops/arrayKlass.hpp +++ b/src/hotspot/share/oops/arrayKlass.hpp @@ -85,7 +85,7 @@ class ArrayKlass: public Klass { Method* uncached_lookup_method(const Symbol* name, const Symbol* signature, OverpassLookupMode overpass_mode, - PrivateLookupMode private_mode = find_private) const; + PrivateLookupMode private_mode = PrivateLookupMode::find) const; static ArrayKlass* cast(Klass* k) { return const_cast(cast(const_cast(k))); diff --git a/src/hotspot/share/oops/instanceKlass.cpp b/src/hotspot/share/oops/instanceKlass.cpp index a0f8f3eb7c8..feadda0017d 100644 --- a/src/hotspot/share/oops/instanceKlass.cpp +++ b/src/hotspot/share/oops/instanceKlass.cpp @@ -1769,7 +1769,10 @@ inline int InstanceKlass::quick_search(const Array* methods, const Symb // find_method looks up the name/signature in the local methods array Method* InstanceKlass::find_method(const Symbol* name, const Symbol* signature) const { - return find_method_impl(name, signature, find_overpass, find_static, find_private); + return find_method_impl(name, signature, + OverpassLookupMode::find, + StaticLookupMode::find, + PrivateLookupMode::find); } Method* InstanceKlass::find_method_impl(const Symbol* name, @@ -1794,8 +1797,8 @@ Method* InstanceKlass::find_instance_method(const Array* methods, Method* const meth = InstanceKlass::find_method_impl(methods, name, signature, - find_overpass, - skip_static, + OverpassLookupMode::find, + StaticLookupMode::skip, private_mode); assert(((meth == NULL) || !meth->is_static()), "find_instance_method should have skipped statics"); @@ -1853,9 +1856,9 @@ Method* InstanceKlass::find_method(const Array* methods, return InstanceKlass::find_method_impl(methods, name, signature, - find_overpass, - find_static, - find_private); + OverpassLookupMode::find, + StaticLookupMode::find, + PrivateLookupMode::find); } Method* InstanceKlass::find_method_impl(const Array* methods, @@ -1898,9 +1901,9 @@ int InstanceKlass::find_method_index(const Array* methods, OverpassLookupMode overpass_mode, StaticLookupMode static_mode, PrivateLookupMode private_mode) { - const bool skipping_overpass = (overpass_mode == skip_overpass); - const bool skipping_static = (static_mode == skip_static); - const bool skipping_private = (private_mode == skip_private); + const bool skipping_overpass = (overpass_mode == OverpassLookupMode::skip); + const bool skipping_static = (static_mode == StaticLookupMode::skip); + const bool skipping_private = (private_mode == PrivateLookupMode::skip); const int hit = quick_search(methods, name); if (hit != -1) { const Method* const m = methods->at(hit); @@ -1976,13 +1979,13 @@ Method* InstanceKlass::uncached_lookup_method(const Symbol* name, Method* const method = InstanceKlass::cast(klass)->find_method_impl(name, signature, overpass_local_mode, - find_static, + StaticLookupMode::find, private_mode); if (method != NULL) { return method; } klass = klass->super(); - overpass_local_mode = skip_overpass; // Always ignore overpass methods in superclasses + overpass_local_mode = OverpassLookupMode::skip; // Always ignore overpass methods in superclasses } return NULL; } @@ -2012,7 +2015,7 @@ Method* InstanceKlass::lookup_method_in_ordered_interfaces(Symbol* name, } // Look up interfaces if (m == NULL) { - m = lookup_method_in_all_interfaces(name, signature, find_defaults); + m = lookup_method_in_all_interfaces(name, signature, DefaultsLookupMode::find); } return m; } @@ -2030,7 +2033,7 @@ Method* InstanceKlass::lookup_method_in_all_interfaces(Symbol* name, ik = all_ifs->at(i); Method* m = ik->lookup_method(name, signature); if (m != NULL && m->is_public() && !m->is_static() && - ((defaults_mode != skip_defaults) || !m->is_default_method())) { + ((defaults_mode != DefaultsLookupMode::skip) || !m->is_default_method())) { return m; } } diff --git a/src/hotspot/share/oops/instanceKlass.hpp b/src/hotspot/share/oops/instanceKlass.hpp index b1894200fc1..a4ce90ab882 100644 --- a/src/hotspot/share/oops/instanceKlass.hpp +++ b/src/hotspot/share/oops/instanceKlass.hpp @@ -662,7 +662,7 @@ public: Method* uncached_lookup_method(const Symbol* name, const Symbol* signature, OverpassLookupMode overpass_mode, - PrivateLookupMode private_mode = find_private) const; + PrivateLookupMode private_mode = PrivateLookupMode::find) const; // lookup a method in all the interfaces that this class implements // (returns NULL if not found) diff --git a/src/hotspot/share/oops/klass.hpp b/src/hotspot/share/oops/klass.hpp index 103c82ea6d2..b7f1579d648 100644 --- a/src/hotspot/share/oops/klass.hpp +++ b/src/hotspot/share/oops/klass.hpp @@ -196,10 +196,10 @@ protected: public: int id() { return _id; } - enum DefaultsLookupMode { find_defaults, skip_defaults }; - enum OverpassLookupMode { find_overpass, skip_overpass }; - enum StaticLookupMode { find_static, skip_static }; - enum PrivateLookupMode { find_private, skip_private }; + enum class DefaultsLookupMode { find, skip }; + enum class OverpassLookupMode { find, skip }; + enum class StaticLookupMode { find, skip }; + enum class PrivateLookupMode { find, skip }; virtual bool is_klass() const { return true; } @@ -482,10 +482,10 @@ protected: virtual Klass* find_field(Symbol* name, Symbol* signature, fieldDescriptor* fd) const; virtual Method* uncached_lookup_method(const Symbol* name, const Symbol* signature, OverpassLookupMode overpass_mode, - PrivateLookupMode = find_private) const; + PrivateLookupMode = PrivateLookupMode::find) const; public: Method* lookup_method(const Symbol* name, const Symbol* signature) const { - return uncached_lookup_method(name, signature, find_overpass); + return uncached_lookup_method(name, signature, OverpassLookupMode::find); } // array class with specific rank diff --git a/src/hotspot/share/oops/klassVtable.cpp b/src/hotspot/share/oops/klassVtable.cpp index b1cda7452fa..e2dcaf413b3 100644 --- a/src/hotspot/share/oops/klassVtable.cpp +++ b/src/hotspot/share/oops/klassVtable.cpp @@ -692,7 +692,7 @@ bool klassVtable::needs_new_vtable_entry(const methodHandle& target_method, // this check for all access permissions. const InstanceKlass *sk = InstanceKlass::cast(super); if (sk->has_miranda_methods()) { - if (sk->lookup_method_in_all_interfaces(name, signature, Klass::find_defaults) != NULL) { + if (sk->lookup_method_in_all_interfaces(name, signature, Klass::DefaultsLookupMode::find) != NULL) { return false; // found a matching miranda; we do not need a new entry } } @@ -797,7 +797,9 @@ bool klassVtable::is_miranda(Method* m, Array* class_methods, // First look in local methods to see if already covered if (InstanceKlass::find_local_method(class_methods, name, signature, - Klass::find_overpass, Klass::skip_static, Klass::skip_private) != NULL) + Klass::OverpassLookupMode::find, + Klass::StaticLookupMode::skip, + Klass::PrivateLookupMode::skip) != NULL) { return false; } @@ -817,7 +819,9 @@ bool klassVtable::is_miranda(Method* m, Array* class_methods, for (const Klass* cursuper = super; cursuper != NULL; cursuper = cursuper->super()) { Method* found_mth = InstanceKlass::cast(cursuper)->find_local_method(name, signature, - Klass::find_overpass, Klass::skip_static, Klass::skip_private); + Klass::OverpassLookupMode::find, + Klass::StaticLookupMode::skip, + Klass::PrivateLookupMode::skip); // Ignore non-public methods in java.lang.Object if klass is an interface. if (found_mth != NULL && (!is_interface || !SystemDictionary::is_nonpublic_Object_method(found_mth))) { @@ -861,7 +865,7 @@ void klassVtable::add_new_mirandas_to_lists( if (is_miranda(im, class_methods, default_methods, super, is_interface)) { // is it a miranda at all? const InstanceKlass *sk = InstanceKlass::cast(super); // check if it is a duplicate of a super's miranda - if (sk->lookup_method_in_all_interfaces(im->name(), im->signature(), Klass::find_defaults) == NULL) { + if (sk->lookup_method_in_all_interfaces(im->name(), im->signature(), Klass::DefaultsLookupMode::find) == NULL) { new_mirandas->append(im); } if (all_mirandas != NULL) { @@ -1213,7 +1217,7 @@ void klassItable::initialize_itable_for_interface(int method_table_offset, Insta // Invokespecial does not perform selection based on the receiver, so it does not use // the cached itable. target = LinkResolver::lookup_instance_method_in_klasses(_klass, m->name(), m->signature(), - Klass::skip_private, CHECK); + Klass::PrivateLookupMode::skip, CHECK); } if (target == NULL || !target->is_public() || target->is_abstract() || target->is_overpass()) { assert(target == NULL || !target->is_overpass() || target->is_public(), diff --git a/src/hotspot/share/prims/methodHandles.cpp b/src/hotspot/share/prims/methodHandles.cpp index ba373616273..a5241f124ab 100644 --- a/src/hotspot/share/prims/methodHandles.cpp +++ b/src/hotspot/share/prims/methodHandles.cpp @@ -745,8 +745,8 @@ Handle MethodHandles::resolve_MemberName(Handle mname, Klass* caller, if (type == NULL) return empty; // no such signature exists in the VM LinkInfo::AccessCheck access_check = caller != NULL ? - LinkInfo::needs_access_check : - LinkInfo::skip_access_check; + LinkInfo::AccessCheck::required : + LinkInfo::AccessCheck::skip; // Time to do the lookup. switch (flags & ALL_KINDS) { @@ -819,7 +819,7 @@ Handle MethodHandles::resolve_MemberName(Handle mname, Klass* caller, fieldDescriptor result; // find_field initializes fd if found { assert(!HAS_PENDING_EXCEPTION, ""); - LinkInfo link_info(defc, name, type, caller, LinkInfo::skip_access_check); + LinkInfo link_info(defc, name, type, caller, LinkInfo::AccessCheck::skip); LinkResolver::resolve_field(result, link_info, Bytecodes::_nop, false, THREAD); if (HAS_PENDING_EXCEPTION) { if (speculative_resolve) { diff --git a/src/hotspot/share/prims/nativeLookup.cpp b/src/hotspot/share/prims/nativeLookup.cpp index dad4ceb87ca..9e3e96f2953 100644 --- a/src/hotspot/share/prims/nativeLookup.cpp +++ b/src/hotspot/share/prims/nativeLookup.cpp @@ -438,7 +438,7 @@ address NativeLookup::base_library_lookup(const char* class_name, const char* me // Find method and invoke standard lookup methodHandle method (THREAD, - klass->uncached_lookup_method(m_name, s_name, Klass::find_overpass)); + klass->uncached_lookup_method(m_name, s_name, Klass::OverpassLookupMode::find)); address result = lookup(method, in_base_library, CATCH); assert(in_base_library, "must be in basic library"); guarantee(result != NULL, "must be non NULL"); From 9886b7e9e9f3ef7c2e08586dee030a4fb5a8a908 Mon Sep 17 00:00:00 2001 From: Chris Plummer Date: Thu, 6 Aug 2020 13:14:15 -0700 Subject: [PATCH 11/53] 8248879: SA core file support on OSX has some bugs trying to locate the jvm libraries Reviewed-by: sspitsyn, amenkov --- .../macosx/native/libsaproc/ps_core.c | 157 ++++++++++-------- 1 file changed, 91 insertions(+), 66 deletions(-) diff --git a/src/jdk.hotspot.agent/macosx/native/libsaproc/ps_core.c b/src/jdk.hotspot.agent/macosx/native/libsaproc/ps_core.c index 229abedadad..d06b53351b5 100644 --- a/src/jdk.hotspot.agent/macosx/native/libsaproc/ps_core.c +++ b/src/jdk.hotspot.agent/macosx/native/libsaproc/ps_core.c @@ -28,6 +28,7 @@ #include #include #include +#include #include "libproc_impl.h" #include "ps_core_common.h" @@ -335,86 +336,110 @@ err: return false; } -/**local function **/ -bool exists(const char *fname) { +static bool exists(const char *fname) { return access(fname, F_OK) == 0; } -// we check: 1. lib -// 2. lib/server -// 3. jre/lib -// 4. jre/lib/server -// from: 1. exe path -// 2. JAVA_HOME -// 3. DYLD_LIBRARY_PATH +// reverse strstr() +static char* rstrstr(const char *str, const char *sub) { + char *result = NULL; + for (char *p = strstr(str, sub); p != NULL; p = strstr(p + 1, sub)) { + result = p; + } + return result; +} + +// Check if exists in the directory of . +// Note and already have '/' prepended. +static bool get_real_path_jdk_subdir(char* rpath, char* filename, char* jdk_dir, char* jdk_subdir) { + char filepath[BUF_SIZE]; + strncpy(filepath, jdk_dir, BUF_SIZE); + filepath[BUF_SIZE - 1] = '\0'; // just in case jdk_dir didn't fit + strncat(filepath, jdk_subdir, BUF_SIZE - 1 - strlen(filepath)); + strncat(filepath, filename, BUF_SIZE - 1 - strlen(filepath)); + if (exists(filepath)) { + strcpy(rpath, filepath); + return true; + } + return false; +} + +// Look for in various subdirs of . +static bool get_real_path_jdk_dir(char* rpath, char* filename, char* jdk_dir) { + if (get_real_path_jdk_subdir(rpath, filename, jdk_dir, "/lib")) { + return true; + } + if (get_real_path_jdk_subdir(rpath, filename, jdk_dir, "/lib/server")) { + return true; + } + if (get_real_path_jdk_subdir(rpath, filename, jdk_dir, "/jre/lib")) { + return true; + } + if (get_real_path_jdk_subdir(rpath, filename, jdk_dir, "/jre/lib/server")) { + return true; + } + return false; +} + +// Get the file specified by rpath. We check various directories for it. static bool get_real_path(struct ps_prochandle* ph, char *rpath) { - /** check if they exist in JAVA ***/ char* execname = ph->core->exec_path; - char filepath[4096]; - char* filename = strrchr(rpath, '/'); // like /libjvm.dylib + char jdk_dir[BUF_SIZE]; + char* posbin; + char* filename = strrchr(rpath, '/'); // like /libjvm.dylib if (filename == NULL) { return false; } - char* posbin = strstr(execname, "/bin/java"); + // First look for the library in 3 places where the JDK might be located. For each of + // these 3 potential JDK locations we look in lib, lib/server, jre/lib, and jre/lib/server. + + posbin = rstrstr(execname, "/bin/java"); if (posbin != NULL) { - memcpy(filepath, execname, posbin - execname); // not include trailing '/' - filepath[posbin - execname] = '\0'; - } else { - char* java_home = getenv("JAVA_HOME"); - if (java_home != NULL) { - strcpy(filepath, java_home); - } else { - char* dyldpath = getenv("DYLD_LIBRARY_PATH"); - char* save_ptr; - char* dypath = strtok_r(dyldpath, ":", &save_ptr); - while (dypath != NULL) { - strcpy(filepath, dypath); - strcat(filepath, filename); - if (exists(filepath)) { - strcpy(rpath, filepath); - return true; - } - dypath = strtok_r(NULL, ":", &save_ptr); - } - // not found - return false; + strncpy(jdk_dir, execname, posbin - execname); + jdk_dir[posbin - execname] = '\0'; + if (get_real_path_jdk_dir(rpath, filename, jdk_dir)) { + return true; } } - // for exec and java_home, jdkpath now is filepath - size_t filepath_base_size = strlen(filepath); - // first try /lib/ and /lib/server - strcat(filepath, "/lib"); - strcat(filepath, filename); - if (exists(filepath)) { - strcpy(rpath, filepath); - return true; - } - char* pos = strstr(filepath, filename); // like /libjvm.dylib - *pos = '\0'; - strcat(filepath, "/server"); - strcat(filepath, filename); - if (exists(filepath)) { - strcpy(rpath, filepath); - return true; + char* java_home = getenv("JAVA_HOME"); + if (java_home != NULL) { + if (get_real_path_jdk_dir(rpath, filename, java_home)) { + return true; + } } - // then try /jre/lib/ and /jre/lib/server - filepath[filepath_base_size] = '\0'; - strcat(filepath, "/jre/lib"); - strcat(filepath, filename); - if (exists(filepath)) { - strcpy(rpath, filepath); - return true; + // Look for bin directory in path. This is useful when attaching to a core file + // that was launched with a JDK tool other than "java". + posbin = rstrstr(execname, "/bin/"); // look for the last occurence of "/bin/" + if (posbin != NULL) { + strncpy(jdk_dir, execname, posbin - execname); + jdk_dir[posbin - execname] = '\0'; + if (get_real_path_jdk_dir(rpath, filename, jdk_dir)) { + return true; + } } - pos = strstr(filepath, filename); - *pos = '\0'; - strcat(filepath, "/server"); - strcat(filepath, filename); - if (exists(filepath)) { - strcpy(rpath, filepath); - return true; + + // If we didn't find the library in any of the 3 above potential JDK locations, then look in + // DYLD_LIBRARY_PATH. This is where user libraries might be. We don't treat these + // paths as JDK paths, so we don't append the various JDK subdirs like lib/server. + // However, that doesn't preclude JDK libraries from actually being in one of the paths. + char* dyldpath = getenv("DYLD_LIBRARY_PATH"); + if (dyldpath != NULL) { + char* save_ptr; + char filepath[BUF_SIZE]; + char* dypath = strtok_r(dyldpath, ":", &save_ptr); + while (dypath != NULL) { + strncpy(filepath, dypath, BUF_SIZE); + filepath[BUF_SIZE - 1] = '\0'; // just in case dypath didn't fit + strncat(filepath, filename, BUF_SIZE - 1 - strlen(filepath)); + if (exists(filepath)) { + strcpy(rpath, filepath); + return true; + } + dypath = strtok_r(NULL, ":", &save_ptr); + } } return false; @@ -563,13 +588,13 @@ struct ps_prochandle* Pgrab_core(const char* exec_file, const char* core_file) { ph->core->exec_fd = -1; ph->core->interp_fd = -1; - print_debug("exec: %s core: %s", exec_file, core_file); + print_debug("exec: %s core: %s\n", exec_file, core_file); strncpy(ph->core->exec_path, exec_file, sizeof(ph->core->exec_path)); // open the core file if ((ph->core->core_fd = open(core_file, O_RDONLY)) < 0) { - print_error("can't open core file\n"); + print_error("can't open core file: %s\n", strerror(errno)); goto err; } From c02b75705fa2ffe9825f65d6dd671a0e7ea473ef Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Thu, 6 Aug 2020 13:29:15 -0700 Subject: [PATCH 12/53] 8161684: [testconf] Add VerifyOops' testing into compiler tiers Reviewed-by: kvn --- test/jtreg-ext/requires/VMProps.java | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/test/jtreg-ext/requires/VMProps.java b/test/jtreg-ext/requires/VMProps.java index 59fd751416a..948f0b92da1 100644 --- a/test/jtreg-ext/requires/VMProps.java +++ b/test/jtreg-ext/requires/VMProps.java @@ -380,6 +380,11 @@ public class VMProps implements Callable> { return "false"; } + if (WB.getBooleanVMFlag("VerifyOops")) { + // Should be enabled when JDK-8209961 is fixed + return "false"; + } + switch (GC.selected()) { case Serial: case Parallel: From 111ba18ac6334103909757b71dcf83e8f93f6020 Mon Sep 17 00:00:00 2001 From: Alex Menkov Date: Thu, 6 Aug 2020 15:59:47 -0700 Subject: [PATCH 13/53] 8249550: jdb should use loopback address when not using remote agent Reviewed-by: cjplummer, sspitsyn --- .../share/classes/com/sun/tools/jdi/SocketTransportService.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/jdk.jdi/share/classes/com/sun/tools/jdi/SocketTransportService.java b/src/jdk.jdi/share/classes/com/sun/tools/jdi/SocketTransportService.java index c62128bc442..e57ae4ff032 100644 --- a/src/jdk.jdi/share/classes/com/sun/tools/jdi/SocketTransportService.java +++ b/src/jdk.jdi/share/classes/com/sun/tools/jdi/SocketTransportService.java @@ -314,7 +314,7 @@ public class SocketTransportService extends TransportService { * Listen on the default address */ public ListenKey startListening() throws IOException { - return startListening(null, 0); + return startListening(null); } /** From c202bd705e829c158cd337b63f154ec5fe0ea92e Mon Sep 17 00:00:00 2001 From: David Holmes Date: Thu, 6 Aug 2020 21:03:18 -0400 Subject: [PATCH 14/53] 8250606: Remove unnecessary assertions in ObjectSynchronizer FastHashcode and inflate Reviewed-by: dcubed, coleenp --- src/hotspot/share/runtime/synchronizer.cpp | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/src/hotspot/share/runtime/synchronizer.cpp b/src/hotspot/share/runtime/synchronizer.cpp index 688d49b5521..9a92fca6130 100644 --- a/src/hotspot/share/runtime/synchronizer.cpp +++ b/src/hotspot/share/runtime/synchronizer.cpp @@ -1017,15 +1017,6 @@ intptr_t ObjectSynchronizer::FastHashCode(Thread* self, oop obj) { } } - // hashCode() is a heap mutator ... - // Relaxing assertion for bug 6320749. - assert(Universe::verify_in_progress() || DumpSharedSpaces || - !SafepointSynchronize::is_at_safepoint(), "invariant"); - assert(Universe::verify_in_progress() || DumpSharedSpaces || - self->is_Java_thread() , "invariant"); - assert(Universe::verify_in_progress() || DumpSharedSpaces || - ((JavaThread *)self)->thread_state() != _thread_blocked, "invariant"); - while (true) { ObjectMonitor* monitor = NULL; markWord temp, test; @@ -1807,11 +1798,6 @@ void ObjectSynchronizer::inflate_helper(oop obj) { ObjectMonitor* ObjectSynchronizer::inflate(Thread* self, oop object, const InflateCause cause) { - // Inflate mutates the heap ... - // Relaxing assertion for bug 6320749. - assert(Universe::verify_in_progress() || - !SafepointSynchronize::is_at_safepoint(), "invariant"); - EventJavaMonitorInflate event; for (;;) { From db46b297faa308ce476363fa798931ac1d7be144 Mon Sep 17 00:00:00 2001 From: Chris Plummer Date: Thu, 6 Aug 2020 18:21:21 -0700 Subject: [PATCH 15/53] 8251121: six SA tests leave core files behind on macOS Reviewed-by: dholmes, dcubed --- .../jtreg/serviceability/sa/ClhsdbCDSCore.java | 1 - test/lib/jdk/test/lib/util/CoreUtils.java | 14 +++++++++++++- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSCore.java b/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSCore.java index 107d0cd2e06..2d0013250b6 100644 --- a/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSCore.java +++ b/test/hotspot/jtreg/serviceability/sa/ClhsdbCDSCore.java @@ -174,7 +174,6 @@ public class ClhsdbCDSCore { } private static void cleanup() { - if (coreFileName != null) remove(coreFileName); remove(SHARED_ARCHIVE_NAME); } diff --git a/test/lib/jdk/test/lib/util/CoreUtils.java b/test/lib/jdk/test/lib/util/CoreUtils.java index a48465f1e37..c189aad2dae 100644 --- a/test/lib/jdk/test/lib/util/CoreUtils.java +++ b/test/lib/jdk/test/lib/util/CoreUtils.java @@ -107,8 +107,20 @@ public class CoreUtils { // Find the core file String coreFileLocation = parseCoreFileLocationFromOutput(crashOutputString); if (coreFileLocation != null) { - Asserts.assertGT(new File(coreFileLocation).length(), 0L, "Unexpected core size"); System.out.println("Found core file: " + coreFileLocation); + Asserts.assertGT(new File(coreFileLocation).length(), 0L, "Unexpected core size"); + + // Make sure the core file is moved into the cwd if not already there. + Path corePath = Paths.get(coreFileLocation); + if (corePath.getParent() != null) { + Path coreFileName = corePath.getFileName(); + System.out.println("Moving core file to cwd: " + coreFileName); + long startTime = System.currentTimeMillis(); + Files.move(corePath, coreFileName); + System.out.println("Core file move took " + (System.currentTimeMillis() - startTime) + "ms"); + coreFileLocation = coreFileName.toString(); + } + return coreFileLocation; // success! } From d02e7d55e82c2aa02c9221938ed20bb5d10519ef Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Thu, 6 Aug 2020 18:23:21 -0700 Subject: [PATCH 16/53] 8251272: Typo in java.util.Formatter: "Numberic" should be "Numeric" Reviewed-by: bchristi, naoto, jlaskey --- src/java.base/share/classes/java/util/Formatter.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/java.base/share/classes/java/util/Formatter.java b/src/java.base/share/classes/java/util/Formatter.java index 327f910e4b1..184bd0bc124 100644 --- a/src/java.base/share/classes/java/util/Formatter.java +++ b/src/java.base/share/classes/java/util/Formatter.java @@ -277,7 +277,7 @@ import sun.util.locale.provider.ResourceBundleBasedAdapter; * * * - *

    For category General, Character, Numberic, + *

    For category General, Character, Numeric, * Integral and Date/Time conversion, unless otherwise specified, * if the argument arg is {@code null}, then the result is "{@code null}". * @@ -703,7 +703,7 @@ import sun.util.locale.provider.ResourceBundleBasedAdapter; * methods such as {@link String#format(String,Object...) String.format} and * {@link java.io.PrintStream#printf(String,Object...) PrintStream.printf}. * - *

    For category General, Character, Numberic, + *

    For category General, Character, Numeric, * Integral and Date/Time conversion, unless otherwise specified, * if the argument arg is {@code null}, then the result is "{@code null}". * From ef86f06c424316f6b9fc3ac27ce0dc3284a57c62 Mon Sep 17 00:00:00 2001 From: Leo Jiang Date: Fri, 7 Aug 2020 01:48:31 +0000 Subject: [PATCH 17/53] 8250665: Wrong translation for the month name of May in ar_JO,LB,SY Reviewed-by: naoto --- .../sun/text/resources/ext/FormatData_ar_JO.java | 6 +++--- .../sun/text/resources/ext/FormatData_ar_LB.java | 6 +++--- .../sun/text/resources/ext/FormatData_ar_SY.java | 8 ++++---- test/jdk/sun/text/resources/LocaleData | 14 +++++++------- test/jdk/sun/text/resources/LocaleDataTest.java | 4 ++-- 5 files changed, 19 insertions(+), 19 deletions(-) diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_JO.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_JO.java index 81211d18cfa..2517cd8feee 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_JO.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_JO.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -56,7 +56,7 @@ public class FormatData_ar_JO extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // february "\u0622\u0630\u0627\u0631", // march "\u0646\u064a\u0633\u0627\u0646", // april - "\u0646\u0648\u0627\u0631", // may + "\u0623\u064a\u0627\u0631", // may "\u062d\u0632\u064a\u0631\u0627\u0646", // june "\u062a\u0645\u0648\u0632", // july "\u0622\u0628", // august @@ -73,7 +73,7 @@ public class FormatData_ar_JO extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // abb february "\u0622\u0630\u0627\u0631", // abb march "\u0646\u064a\u0633\u0627\u0646", // abb april - "\u0646\u0648\u0627\u0631", // abb may + "\u0623\u064a\u0627\u0631", // abb may "\u062d\u0632\u064a\u0631\u0627\u0646", // abb june "\u062a\u0645\u0648\u0632", // abb july "\u0622\u0628", // abb august diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_LB.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_LB.java index 48e2dbcddd4..b66c937c796 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_LB.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_LB.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -56,7 +56,7 @@ public class FormatData_ar_LB extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // february "\u0622\u0630\u0627\u0631", // march "\u0646\u064a\u0633\u0627\u0646", // april - "\u0646\u0648\u0627\u0631", // may + "\u0623\u064a\u0627\u0631", // may "\u062d\u0632\u064a\u0631\u0627\u0646", // june "\u062a\u0645\u0648\u0632", // july "\u0622\u0628", // august @@ -73,7 +73,7 @@ public class FormatData_ar_LB extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // abb february "\u0622\u0630\u0627\u0631", // abb march "\u0646\u064a\u0633\u0627\u0646", // abb april - "\u0646\u0648\u0627\u0631", // abb may + "\u0623\u064a\u0627\u0631", // abb may "\u062d\u0632\u064a\u0631\u0627\u0646", // abb june "\u062a\u0645\u0648\u0632", // abb july "\u0622\u0628", // abb august diff --git a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_SY.java b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_SY.java index 5f8bbca8a24..6b903349e0b 100644 --- a/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_SY.java +++ b/src/jdk.localedata/share/classes/sun/text/resources/ext/FormatData_ar_SY.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -56,8 +56,8 @@ public class FormatData_ar_SY extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // february "\u0622\u0630\u0627\u0631", // march "\u0646\u064a\u0633\u0627\u0646", // april - "\u0646\u0648\u0627\u0631\u0627\u0646", // may - "\u062d\u0632\u064a\u0631", // june + "\u0623\u064a\u0627\u0631", // may + "\u062d\u0632\u064a\u0631\u0627\u0646", // june "\u062a\u0645\u0648\u0632", // july "\u0622\u0628", // august "\u0623\u064a\u0644\u0648\u0644", // september @@ -73,7 +73,7 @@ public class FormatData_ar_SY extends ParallelListResourceBundle { "\u0634\u0628\u0627\u0637", // abb february "\u0622\u0630\u0627\u0631", // abb march "\u0646\u064a\u0633\u0627\u0646", // abb april - "\u0646\u0648\u0627\u0631", // abb may + "\u0623\u064a\u0627\u0631", // abb may "\u062d\u0632\u064a\u0631\u0627\u0646", // abb june "\u062a\u0645\u0648\u0632", // abb july "\u0622\u0628", // abb august diff --git a/test/jdk/sun/text/resources/LocaleData b/test/jdk/sun/text/resources/LocaleData index 3aefd36382c..54989fc24f1 100644 --- a/test/jdk/sun/text/resources/LocaleData +++ b/test/jdk/sun/text/resources/LocaleData @@ -1187,7 +1187,7 @@ FormatData/ar_JO/MonthNames/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\ FormatData/ar_JO/MonthNames/1=\u0634\u0628\u0627\u0637 FormatData/ar_JO/MonthNames/2=\u0622\u0630\u0627\u0631 FormatData/ar_JO/MonthNames/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_JO/MonthNames/4=\u0646\u0648\u0627\u0631 +FormatData/ar_JO/MonthNames/4=\u0623\u064a\u0627\u0631 FormatData/ar_JO/MonthNames/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_JO/MonthNames/6=\u062a\u0645\u0648\u0632 FormatData/ar_JO/MonthNames/7=\u0622\u0628 @@ -1200,7 +1200,7 @@ FormatData/ar_JO/MonthAbbreviations/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u064 FormatData/ar_JO/MonthAbbreviations/1=\u0634\u0628\u0627\u0637 FormatData/ar_JO/MonthAbbreviations/2=\u0622\u0630\u0627\u0631 FormatData/ar_JO/MonthAbbreviations/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_JO/MonthAbbreviations/4=\u0646\u0648\u0627\u0631 +FormatData/ar_JO/MonthAbbreviations/4=\u0623\u064a\u0627\u0631 FormatData/ar_JO/MonthAbbreviations/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_JO/MonthAbbreviations/6=\u062a\u0645\u0648\u0632 FormatData/ar_JO/MonthAbbreviations/7=\u0622\u0628 @@ -1363,7 +1363,7 @@ FormatData/ar_LB/MonthNames/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\ FormatData/ar_LB/MonthNames/1=\u0634\u0628\u0627\u0637 FormatData/ar_LB/MonthNames/2=\u0622\u0630\u0627\u0631 FormatData/ar_LB/MonthNames/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_LB/MonthNames/4=\u0646\u0648\u0627\u0631 +FormatData/ar_LB/MonthNames/4=\u0623\u064a\u0627\u0631 FormatData/ar_LB/MonthNames/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_LB/MonthNames/6=\u062a\u0645\u0648\u0632 FormatData/ar_LB/MonthNames/7=\u0622\u0628 @@ -1376,7 +1376,7 @@ FormatData/ar_LB/MonthAbbreviations/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u064 FormatData/ar_LB/MonthAbbreviations/1=\u0634\u0628\u0627\u0637 FormatData/ar_LB/MonthAbbreviations/2=\u0622\u0630\u0627\u0631 FormatData/ar_LB/MonthAbbreviations/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_LB/MonthAbbreviations/4=\u0646\u0648\u0627\u0631 +FormatData/ar_LB/MonthAbbreviations/4=\u0623\u064a\u0627\u0631 FormatData/ar_LB/MonthAbbreviations/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_LB/MonthAbbreviations/6=\u062a\u0645\u0648\u0632 FormatData/ar_LB/MonthAbbreviations/7=\u0622\u0628 @@ -1980,8 +1980,8 @@ FormatData/ar_SY/MonthNames/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u0644\u062b\ FormatData/ar_SY/MonthNames/1=\u0634\u0628\u0627\u0637 FormatData/ar_SY/MonthNames/2=\u0622\u0630\u0627\u0631 FormatData/ar_SY/MonthNames/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_SY/MonthNames/4=\u0646\u0648\u0627\u0631\u0627\u0646 -FormatData/ar_SY/MonthNames/5=\u062d\u0632\u064a\u0631 +FormatData/ar_SY/MonthNames/4=\u0623\u064a\u0627\u0631 +FormatData/ar_SY/MonthNames/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_SY/MonthNames/6=\u062a\u0645\u0648\u0632 FormatData/ar_SY/MonthNames/7=\u0622\u0628 FormatData/ar_SY/MonthNames/8=\u0623\u064a\u0644\u0648\u0644 @@ -1993,7 +1993,7 @@ FormatData/ar_SY/MonthAbbreviations/0=\u0643\u0627\u0646\u0648\u0646 \u0627\u064 FormatData/ar_SY/MonthAbbreviations/1=\u0634\u0628\u0627\u0637 FormatData/ar_SY/MonthAbbreviations/2=\u0622\u0630\u0627\u0631 FormatData/ar_SY/MonthAbbreviations/3=\u0646\u064a\u0633\u0627\u0646 -FormatData/ar_SY/MonthAbbreviations/4=\u0646\u0648\u0627\u0631 +FormatData/ar_SY/MonthAbbreviations/4=\u0623\u064a\u0627\u0631 FormatData/ar_SY/MonthAbbreviations/5=\u062d\u0632\u064a\u0631\u0627\u0646 FormatData/ar_SY/MonthAbbreviations/6=\u062a\u0645\u0648\u0632 FormatData/ar_SY/MonthAbbreviations/7=\u0622\u0628 diff --git a/test/jdk/sun/text/resources/LocaleDataTest.java b/test/jdk/sun/text/resources/LocaleDataTest.java index d23aa3ef60d..8cb88df3097 100644 --- a/test/jdk/sun/text/resources/LocaleDataTest.java +++ b/test/jdk/sun/text/resources/LocaleDataTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -39,7 +39,7 @@ * 8017142 8037343 8055222 8042126 8074791 8075173 8080774 8129361 8134916 * 8145136 8145952 8164784 8037111 8081643 7037368 8178872 8185841 8190918 * 8187946 8195478 8181157 8179071 8193552 8202026 8204269 8202537 8208746 - * 8209775 8221432 8227127 8230284 8231273 8233579 8234288 + * 8209775 8221432 8227127 8230284 8231273 8233579 8234288 8250665 * @summary Verify locale data * @modules java.base/sun.util.resources * @modules jdk.localedata From 12879e91b43798750f9c7656dacc5085dd20cc96 Mon Sep 17 00:00:00 2001 From: Gabriel Reid Date: Fri, 7 Aug 2020 04:21:57 +0200 Subject: [PATCH 18/53] 8250928: JFR: Improve hash algorithm for stack traces Reviewed-by: egahlin --- src/hotspot/share/jfr/recorder/stacktrace/jfrStackTrace.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/jfr/recorder/stacktrace/jfrStackTrace.cpp b/src/hotspot/share/jfr/recorder/stacktrace/jfrStackTrace.cpp index 92ebf3265c2..aae8054125e 100644 --- a/src/hotspot/share/jfr/recorder/stacktrace/jfrStackTrace.cpp +++ b/src/hotspot/share/jfr/recorder/stacktrace/jfrStackTrace.cpp @@ -240,6 +240,7 @@ bool JfrStackTrace::record_safe(JavaThread* thread, int skip) { vfs.next(); } + _hash = 1; while (!vfs.at_end()) { if (count >= _max_frames) { _reached_root = false; @@ -255,8 +256,9 @@ bool JfrStackTrace::record_safe(JavaThread* thread, int skip) { else { bci = vfs.bci(); } - // Can we determine if it's inlined? - _hash = (_hash << 2) + (unsigned int)(((size_t)mid >> 2) + (bci << 4) + type); + _hash = (_hash * 31) + mid; + _hash = (_hash * 31) + bci; + _hash = (_hash * 31) + type; _frames[count] = JfrStackFrame(mid, bci, type, method->method_holder()); vfs.next(); count++; From 555f0e6e2ad24dfdd34558d3d43d922516b63525 Mon Sep 17 00:00:00 2001 From: Mikael Vidstedt Date: Thu, 6 Aug 2020 20:56:46 -0700 Subject: [PATCH 19/53] Added tag jdk-16+10 for changeset b01985b4f88f --- .hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags b/.hgtags index 80e6992d687..ce18503274c 100644 --- a/.hgtags +++ b/.hgtags @@ -655,3 +655,4 @@ c3a4a7ea7c304cabdacdc31741eb94c51351668d jdk-16+7 b0817631d2f4395508cb10e81c3858a94d9ae4de jdk-15+34 0a73d6f3aab48ff6d7e61e47f0bc2d87a054f217 jdk-16+8 c075a286cc7df767cce28e8057d6ec5051786490 jdk-16+9 +b01985b4f88f554f97901e53e1ba314681dd9c19 jdk-16+10 From c148c2c1764ff1272986fd6fdfcdb64c576abc16 Mon Sep 17 00:00:00 2001 From: Dong Bo Date: Fri, 7 Aug 2020 12:35:30 +0800 Subject: [PATCH 20/53] 8165404: AArch64: Implement SHA512 accelerator/intrinsic Reviewed-by: aph --- src/hotspot/cpu/aarch64/aarch64-asmtest.py | 37 +- src/hotspot/cpu/aarch64/assembler_aarch64.cpp | 2401 +++++++++-------- src/hotspot/cpu/aarch64/assembler_aarch64.hpp | 24 + .../cpu/aarch64/stubGenerator_aarch64.cpp | 170 ++ .../cpu/aarch64/vm_version_aarch64.cpp | 12 +- 5 files changed, 1446 insertions(+), 1198 deletions(-) diff --git a/src/hotspot/cpu/aarch64/aarch64-asmtest.py b/src/hotspot/cpu/aarch64/aarch64-asmtest.py index ddfc715b5d7..651b816c420 100644 --- a/src/hotspot/cpu/aarch64/aarch64-asmtest.py +++ b/src/hotspot/cpu/aarch64/aarch64-asmtest.py @@ -865,6 +865,37 @@ class LdStSIMDOp(Instruction): def aname(self): return self._name +class SHA512SIMDOp(Instruction): + + def generate(self): + if (self._name == 'sha512su0'): + self.reg = [FloatRegister().generate(), FloatRegister().generate()] + else: + self.reg = [FloatRegister().generate(), FloatRegister().generate(), + FloatRegister().generate()] + return self + + def cstr(self): + if (self._name == 'sha512su0'): + return (super(SHA512SIMDOp, self).cstr() + + ('%s, __ T2D, %s);' % (self.reg[0], self.reg[1]))) + else: + return (super(SHA512SIMDOp, self).cstr() + + ('%s, __ T2D, %s, %s);' % (self.reg[0], self.reg[1], self.reg[2]))) + + def astr(self): + if (self._name == 'sha512su0'): + return (super(SHA512SIMDOp, self).astr() + + ('\t%s.2D, %s.2D' % (self.reg[0].astr("v"), self.reg[1].astr("v")))) + elif (self._name == 'sha512su1'): + return (super(SHA512SIMDOp, self).astr() + + ('\t%s.2D, %s.2D, %s.2D' % (self.reg[0].astr("v"), + self.reg[1].astr("v"), self.reg[2].astr("v")))) + else: + return (super(SHA512SIMDOp, self).astr() + + ('\t%s, %s, %s.2D' % (self.reg[0].astr("q"), + self.reg[1].astr("q"), self.reg[2].astr("v")))) + class LSEOp(Instruction): def __init__(self, args): self._name, self.asmname, self.size, self.suffix = args @@ -1100,6 +1131,8 @@ generate(LdStSIMDOp, [["ld1", 1, "8B", Address.base_only], ["ld4r", 4, "2S", Address.post_reg], ]) +generate(SHA512SIMDOp, ["sha512h", "sha512h2", "sha512su0", "sha512su1"]) + generate(SpecialCases, [["ccmn", "__ ccmn(zr, zr, 3u, Assembler::LE);", "ccmn\txzr, xzr, #3, LE"], ["ccmnw", "__ ccmnw(zr, zr, 5u, Assembler::EQ);", "ccmn\twzr, wzr, #5, EQ"], ["ccmp", "__ ccmp(zr, 1, 4u, Assembler::NE);", "ccmp\txzr, 1, #4, NE"], @@ -1147,8 +1180,8 @@ outfile.close() import subprocess import sys -# compile for 8.1 because of lse atomics -subprocess.check_call([AARCH64_AS, "-march=armv8.1-a", "aarch64ops.s", "-o", "aarch64ops.o"]) +# compile for 8.1 and sha2 because of lse atomics and sha512 crypto extension. +subprocess.check_call([AARCH64_AS, "-march=armv8.1-a+sha2", "aarch64ops.s", "-o", "aarch64ops.o"]) print print "/*", diff --git a/src/hotspot/cpu/aarch64/assembler_aarch64.cpp b/src/hotspot/cpu/aarch64/assembler_aarch64.cpp index 3c0fb466190..977dd289056 100644 --- a/src/hotspot/cpu/aarch64/assembler_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/assembler_aarch64.cpp @@ -96,662 +96,668 @@ void entry(CodeBuffer *cb) { __ bind(back); // ArithOp - __ add(r15, r12, r16, Assembler::LSR, 30); // add x15, x12, x16, LSR #30 - __ sub(r1, r15, r3, Assembler::LSR, 32); // sub x1, x15, x3, LSR #32 - __ adds(r13, r25, r5, Assembler::LSL, 13); // adds x13, x25, x5, LSL #13 - __ subs(r22, r28, r6, Assembler::ASR, 17); // subs x22, x28, x6, ASR #17 - __ addw(r0, r9, r22, Assembler::ASR, 6); // add w0, w9, w22, ASR #6 - __ subw(r19, r3, r25, Assembler::LSL, 21); // sub w19, w3, w25, LSL #21 - __ addsw(r4, r19, r11, Assembler::LSL, 20); // adds w4, w19, w11, LSL #20 - __ subsw(r24, r7, r19, Assembler::ASR, 0); // subs w24, w7, w19, ASR #0 - __ andr(r30, r7, r11, Assembler::LSL, 48); // and x30, x7, x11, LSL #48 - __ orr(r24, r8, r15, Assembler::LSL, 12); // orr x24, x8, x15, LSL #12 - __ eor(r17, r9, r23, Assembler::LSL, 1); // eor x17, x9, x23, LSL #1 - __ ands(r14, r11, r4, Assembler::LSR, 55); // ands x14, x11, x4, LSR #55 - __ andw(r19, r7, r12, Assembler::LSR, 17); // and w19, w7, w12, LSR #17 - __ orrw(r19, r27, r11, Assembler::ASR, 28); // orr w19, w27, w11, ASR #28 - __ eorw(r30, r3, r22, Assembler::LSR, 31); // eor w30, w3, w22, LSR #31 - __ andsw(r19, r26, r28, Assembler::ASR, 0); // ands w19, w26, w28, ASR #0 - __ bic(r29, r6, r26, Assembler::LSL, 51); // bic x29, x6, x26, LSL #51 - __ orn(r26, r27, r17, Assembler::LSL, 35); // orn x26, x27, x17, LSL #35 - __ eon(r21, r4, r14, Assembler::LSL, 5); // eon x21, x4, x14, LSL #5 - __ bics(r2, r15, r0, Assembler::ASR, 5); // bics x2, x15, x0, ASR #5 - __ bicw(r2, r7, r2, Assembler::LSL, 29); // bic w2, w7, w2, LSL #29 - __ ornw(r24, r12, r21, Assembler::LSR, 5); // orn w24, w12, w21, LSR #5 - __ eonw(r30, r15, r19, Assembler::LSL, 2); // eon w30, w15, w19, LSL #2 - __ bicsw(r30, r23, r17, Assembler::ASR, 28); // bics w30, w23, w17, ASR #28 + __ add(r4, r3, r0, Assembler::LSR, 9); // add x4, x3, x0, LSR #9 + __ sub(r8, r29, r4, Assembler::LSL, 17); // sub x8, x29, x4, LSL #17 + __ adds(r7, r27, r23, Assembler::LSL, 17); // adds x7, x27, x23, LSL #17 + __ subs(r6, r15, r9, Assembler::LSR, 41); // subs x6, x15, x9, LSR #41 + __ addw(r12, r3, r16, Assembler::ASR, 23); // add w12, w3, w16, ASR #23 + __ subw(r8, r24, r29, Assembler::LSR, 31); // sub w8, w24, w29, LSR #31 + __ addsw(r7, r28, r15, Assembler::LSL, 7); // adds w7, w28, w15, LSL #7 + __ subsw(r26, r15, r28, Assembler::LSR, 13); // subs w26, w15, w28, LSR #13 + __ andr(r1, r8, r2, Assembler::ASR, 28); // and x1, x8, x2, ASR #28 + __ orr(r19, r27, r12, Assembler::LSR, 10); // orr x19, x27, x12, LSR #10 + __ eor(r4, r11, r10, Assembler::LSR, 59); // eor x4, x11, x10, LSR #59 + __ ands(r5, r17, r2, Assembler::LSL, 28); // ands x5, x17, x2, LSL #28 + __ andw(r28, r15, r12, Assembler::LSR, 13); // and w28, w15, w12, LSR #13 + __ orrw(r14, r21, r25, Assembler::LSR, 16); // orr w14, w21, w25, LSR #16 + __ eorw(r13, r16, r0, Assembler::LSR, 4); // eor w13, w16, w0, LSR #4 + __ andsw(r30, r26, r16, Assembler::LSR, 19); // ands w30, w26, w16, LSR #19 + __ bic(r12, r23, r25, Assembler::LSR, 21); // bic x12, x23, x25, LSR #21 + __ orn(r11, r5, r1, Assembler::LSR, 8); // orn x11, x5, x1, LSR #8 + __ eon(r6, r17, r5, Assembler::ASR, 54); // eon x6, x17, x5, ASR #54 + __ bics(r30, r19, r15, Assembler::ASR, 50); // bics x30, x19, x15, ASR #50 + __ bicw(r15, r6, r27, Assembler::LSR, 6); // bic w15, w6, w27, LSR #6 + __ ornw(r22, r3, r6, Assembler::ASR, 4); // orn w22, w3, w6, ASR #4 + __ eonw(r2, r4, r23, Assembler::ASR, 5); // eon w2, w4, w23, ASR #5 + __ bicsw(r2, r5, r30, Assembler::ASR, 19); // bics w2, w5, w30, ASR #19 // AddSubImmOp - __ addw(r4, r20, 660u); // add w4, w20, #660 - __ addsw(r2, r10, 710u); // adds w2, w10, #710 - __ subw(r19, r26, 244u); // sub w19, w26, #244 - __ subsw(r28, r13, 73u); // subs w28, w13, #73 - __ add(r2, r30, 862u); // add x2, x30, #862 - __ adds(r27, r16, 574u); // adds x27, x16, #574 - __ sub(r22, r9, 589u); // sub x22, x9, #589 - __ subs(r4, r1, 698u); // subs x4, x1, #698 + __ addw(r12, r16, 900u); // add w12, w16, #900 + __ addsw(r11, r8, 680u); // adds w11, w8, #680 + __ subw(r8, r7, 44u); // sub w8, w7, #44 + __ subsw(r8, r15, 994u); // subs w8, w15, #994 + __ add(r0, r26, 9u); // add x0, x26, #9 + __ adds(r27, r18, 929u); // adds x27, x18, #929 + __ sub(r18, r8, 300u); // sub x18, x8, #300 + __ subs(r20, r13, 583u); // subs x20, x13, #583 // LogicalImmOp - __ andw(r28, r19, 4294709247ull); // and w28, w19, #0xfffc0fff - __ orrw(r27, r5, 536870910ull); // orr w27, w5, #0x1ffffffe - __ eorw(r30, r20, 4294840319ull); // eor w30, w20, #0xfffe0fff - __ andsw(r22, r26, 4294959615ull); // ands w22, w26, #0xffffe1ff - __ andr(r5, r7, 4194300ull); // and x5, x7, #0x3ffffc - __ orr(r13, r7, 18014398509481728ull); // orr x13, x7, #0x3fffffffffff00 - __ eor(r7, r9, 18442240474082197503ull); // eor x7, x9, #0xfff0000000003fff - __ ands(r3, r0, 18374686479671656447ull); // ands x3, x0, #0xff00000000007fff + __ andw(r29, r19, 8388600ull); // and w29, w19, #0x7ffff8 + __ orrw(r14, r3, 4294965263ull); // orr w14, w3, #0xfffff80f + __ eorw(r14, r29, 1048576ull); // eor w14, w29, #0x100000 + __ andsw(r24, r17, 134217216ull); // ands w24, w17, #0x7fffe00 + __ andr(r17, r3, 13835058603964235903ull); // and x17, x3, #0xc000007fc000007f + __ orr(r7, r14, 18158513714670600195ull); // orr x7, x14, #0xfc000003fc000003 + __ eor(r5, r26, 17870287719452639231ull); // eor x5, x26, #0xf80003ffffffffff + __ ands(r26, r21, 9205357640488583168ull); // ands x26, x21, #0x7fc000007fc00000 // AbsOp - __ b(__ pc()); // b . - __ b(back); // b back - __ b(forth); // b forth - __ bl(__ pc()); // bl . - __ bl(back); // bl back - __ bl(forth); // bl forth + __ b(__ pc()); // b . + __ b(back); // b back + __ b(forth); // b forth + __ bl(__ pc()); // bl . + __ bl(back); // bl back + __ bl(forth); // bl forth // RegAndAbsOp - __ cbzw(r16, __ pc()); // cbz w16, . - __ cbzw(r16, back); // cbz w16, back - __ cbzw(r16, forth); // cbz w16, forth - __ cbnzw(r19, __ pc()); // cbnz w19, . - __ cbnzw(r19, back); // cbnz w19, back - __ cbnzw(r19, forth); // cbnz w19, forth - __ cbz(r5, __ pc()); // cbz x5, . - __ cbz(r5, back); // cbz x5, back - __ cbz(r5, forth); // cbz x5, forth - __ cbnz(r4, __ pc()); // cbnz x4, . - __ cbnz(r4, back); // cbnz x4, back - __ cbnz(r4, forth); // cbnz x4, forth - __ adr(r27, __ pc()); // adr x27, . - __ adr(r27, back); // adr x27, back - __ adr(r27, forth); // adr x27, forth - __ _adrp(r16, __ pc()); // adrp x16, . + __ cbzw(r0, __ pc()); // cbz w0, . + __ cbzw(r0, back); // cbz w0, back + __ cbzw(r0, forth); // cbz w0, forth + __ cbnzw(r11, __ pc()); // cbnz w11, . + __ cbnzw(r11, back); // cbnz w11, back + __ cbnzw(r11, forth); // cbnz w11, forth + __ cbz(r21, __ pc()); // cbz x21, . + __ cbz(r21, back); // cbz x21, back + __ cbz(r21, forth); // cbz x21, forth + __ cbnz(r8, __ pc()); // cbnz x8, . + __ cbnz(r8, back); // cbnz x8, back + __ cbnz(r8, forth); // cbnz x8, forth + __ adr(r11, __ pc()); // adr x11, . + __ adr(r11, back); // adr x11, back + __ adr(r11, forth); // adr x11, forth + __ _adrp(r0, __ pc()); // adrp x0, . // RegImmAbsOp - __ tbz(r28, 8, __ pc()); // tbz x28, #8, . - __ tbz(r28, 8, back); // tbz x28, #8, back - __ tbz(r28, 8, forth); // tbz x28, #8, forth - __ tbnz(r1, 1, __ pc()); // tbnz x1, #1, . - __ tbnz(r1, 1, back); // tbnz x1, #1, back - __ tbnz(r1, 1, forth); // tbnz x1, #1, forth + __ tbz(r5, 2, __ pc()); // tbz x5, #2, . + __ tbz(r5, 2, back); // tbz x5, #2, back + __ tbz(r5, 2, forth); // tbz x5, #2, forth + __ tbnz(r22, 4, __ pc()); // tbnz x22, #4, . + __ tbnz(r22, 4, back); // tbnz x22, #4, back + __ tbnz(r22, 4, forth); // tbnz x22, #4, forth // MoveWideImmOp - __ movnw(r20, 8639, 16); // movn w20, #8639, lsl 16 - __ movzw(r7, 25835, 0); // movz w7, #25835, lsl 0 - __ movkw(r17, 7261, 0); // movk w17, #7261, lsl 0 - __ movn(r14, 2097, 32); // movn x14, #2097, lsl 32 - __ movz(r9, 16082, 0); // movz x9, #16082, lsl 0 - __ movk(r19, 13962, 16); // movk x19, #13962, lsl 16 + __ movnw(r22, 11702, 16); // movn w22, #11702, lsl 16 + __ movzw(r20, 27561, 16); // movz w20, #27561, lsl 16 + __ movkw(r30, 30436, 0); // movk w30, #30436, lsl 0 + __ movn(r27, 29470, 32); // movn x27, #29470, lsl 32 + __ movz(r1, 7779, 48); // movz x1, #7779, lsl 48 + __ movk(r9, 3765, 16); // movk x9, #3765, lsl 16 // BitfieldOp - __ sbfm(r9, r22, 6, 22); // sbfm x9, x22, #6, #22 - __ bfmw(r19, r0, 11, 0); // bfm w19, w0, #11, #0 - __ ubfmw(r10, r19, 11, 19); // ubfm w10, w19, #11, #19 - __ sbfm(r4, r15, 5, 17); // sbfm x4, x15, #5, #17 - __ bfm(r3, r5, 19, 28); // bfm x3, x5, #19, #28 - __ ubfm(r12, r28, 17, 2); // ubfm x12, x28, #17, #2 + __ sbfm(r28, r28, 21, 28); // sbfm x28, x28, #21, #28 + __ bfmw(r15, r4, 8, 2); // bfm w15, w4, #8, #2 + __ ubfmw(r21, r9, 23, 16); // ubfm w21, w9, #23, #16 + __ sbfm(r14, r27, 26, 21); // sbfm x14, x27, #26, #21 + __ bfm(r19, r6, 28, 29); // bfm x19, x6, #28, #29 + __ ubfm(r11, r22, 16, 2); // ubfm x11, x22, #16, #2 // ExtractOp - __ extrw(r15, r0, r22, 3); // extr w15, w0, w22, #3 - __ extr(r6, r14, r14, 55); // extr x6, x14, x14, #55 + __ extrw(r7, r22, r1, 28); // extr w7, w22, w1, #28 + __ extr(r21, r27, r14, 54); // extr x21, x27, x14, #54 // CondBranchOp - __ br(Assembler::EQ, __ pc()); // b.EQ . - __ br(Assembler::EQ, back); // b.EQ back - __ br(Assembler::EQ, forth); // b.EQ forth - __ br(Assembler::NE, __ pc()); // b.NE . - __ br(Assembler::NE, back); // b.NE back - __ br(Assembler::NE, forth); // b.NE forth - __ br(Assembler::HS, __ pc()); // b.HS . - __ br(Assembler::HS, back); // b.HS back - __ br(Assembler::HS, forth); // b.HS forth - __ br(Assembler::CS, __ pc()); // b.CS . - __ br(Assembler::CS, back); // b.CS back - __ br(Assembler::CS, forth); // b.CS forth - __ br(Assembler::LO, __ pc()); // b.LO . - __ br(Assembler::LO, back); // b.LO back - __ br(Assembler::LO, forth); // b.LO forth - __ br(Assembler::CC, __ pc()); // b.CC . - __ br(Assembler::CC, back); // b.CC back - __ br(Assembler::CC, forth); // b.CC forth - __ br(Assembler::MI, __ pc()); // b.MI . - __ br(Assembler::MI, back); // b.MI back - __ br(Assembler::MI, forth); // b.MI forth - __ br(Assembler::PL, __ pc()); // b.PL . - __ br(Assembler::PL, back); // b.PL back - __ br(Assembler::PL, forth); // b.PL forth - __ br(Assembler::VS, __ pc()); // b.VS . - __ br(Assembler::VS, back); // b.VS back - __ br(Assembler::VS, forth); // b.VS forth - __ br(Assembler::VC, __ pc()); // b.VC . - __ br(Assembler::VC, back); // b.VC back - __ br(Assembler::VC, forth); // b.VC forth - __ br(Assembler::HI, __ pc()); // b.HI . - __ br(Assembler::HI, back); // b.HI back - __ br(Assembler::HI, forth); // b.HI forth - __ br(Assembler::LS, __ pc()); // b.LS . - __ br(Assembler::LS, back); // b.LS back - __ br(Assembler::LS, forth); // b.LS forth - __ br(Assembler::GE, __ pc()); // b.GE . - __ br(Assembler::GE, back); // b.GE back - __ br(Assembler::GE, forth); // b.GE forth - __ br(Assembler::LT, __ pc()); // b.LT . - __ br(Assembler::LT, back); // b.LT back - __ br(Assembler::LT, forth); // b.LT forth - __ br(Assembler::GT, __ pc()); // b.GT . - __ br(Assembler::GT, back); // b.GT back - __ br(Assembler::GT, forth); // b.GT forth - __ br(Assembler::LE, __ pc()); // b.LE . - __ br(Assembler::LE, back); // b.LE back - __ br(Assembler::LE, forth); // b.LE forth - __ br(Assembler::AL, __ pc()); // b.AL . - __ br(Assembler::AL, back); // b.AL back - __ br(Assembler::AL, forth); // b.AL forth - __ br(Assembler::NV, __ pc()); // b.NV . - __ br(Assembler::NV, back); // b.NV back - __ br(Assembler::NV, forth); // b.NV forth + __ br(Assembler::EQ, __ pc()); // b.EQ . + __ br(Assembler::EQ, back); // b.EQ back + __ br(Assembler::EQ, forth); // b.EQ forth + __ br(Assembler::NE, __ pc()); // b.NE . + __ br(Assembler::NE, back); // b.NE back + __ br(Assembler::NE, forth); // b.NE forth + __ br(Assembler::HS, __ pc()); // b.HS . + __ br(Assembler::HS, back); // b.HS back + __ br(Assembler::HS, forth); // b.HS forth + __ br(Assembler::CS, __ pc()); // b.CS . + __ br(Assembler::CS, back); // b.CS back + __ br(Assembler::CS, forth); // b.CS forth + __ br(Assembler::LO, __ pc()); // b.LO . + __ br(Assembler::LO, back); // b.LO back + __ br(Assembler::LO, forth); // b.LO forth + __ br(Assembler::CC, __ pc()); // b.CC . + __ br(Assembler::CC, back); // b.CC back + __ br(Assembler::CC, forth); // b.CC forth + __ br(Assembler::MI, __ pc()); // b.MI . + __ br(Assembler::MI, back); // b.MI back + __ br(Assembler::MI, forth); // b.MI forth + __ br(Assembler::PL, __ pc()); // b.PL . + __ br(Assembler::PL, back); // b.PL back + __ br(Assembler::PL, forth); // b.PL forth + __ br(Assembler::VS, __ pc()); // b.VS . + __ br(Assembler::VS, back); // b.VS back + __ br(Assembler::VS, forth); // b.VS forth + __ br(Assembler::VC, __ pc()); // b.VC . + __ br(Assembler::VC, back); // b.VC back + __ br(Assembler::VC, forth); // b.VC forth + __ br(Assembler::HI, __ pc()); // b.HI . + __ br(Assembler::HI, back); // b.HI back + __ br(Assembler::HI, forth); // b.HI forth + __ br(Assembler::LS, __ pc()); // b.LS . + __ br(Assembler::LS, back); // b.LS back + __ br(Assembler::LS, forth); // b.LS forth + __ br(Assembler::GE, __ pc()); // b.GE . + __ br(Assembler::GE, back); // b.GE back + __ br(Assembler::GE, forth); // b.GE forth + __ br(Assembler::LT, __ pc()); // b.LT . + __ br(Assembler::LT, back); // b.LT back + __ br(Assembler::LT, forth); // b.LT forth + __ br(Assembler::GT, __ pc()); // b.GT . + __ br(Assembler::GT, back); // b.GT back + __ br(Assembler::GT, forth); // b.GT forth + __ br(Assembler::LE, __ pc()); // b.LE . + __ br(Assembler::LE, back); // b.LE back + __ br(Assembler::LE, forth); // b.LE forth + __ br(Assembler::AL, __ pc()); // b.AL . + __ br(Assembler::AL, back); // b.AL back + __ br(Assembler::AL, forth); // b.AL forth + __ br(Assembler::NV, __ pc()); // b.NV . + __ br(Assembler::NV, back); // b.NV back + __ br(Assembler::NV, forth); // b.NV forth // ImmOp - __ svc(22064); // svc #22064 - __ hvc(533); // hvc #533 - __ smc(9942); // smc #9942 - __ brk(4714); // brk #4714 - __ hlt(4302); // hlt #4302 + __ svc(32085); // svc #32085 + __ hvc(4810); // hvc #4810 + __ smc(21956); // smc #21956 + __ brk(21112); // brk #21112 + __ hlt(15915); // hlt #15915 // Op - __ nop(); // nop - __ eret(); // eret - __ drps(); // drps - __ isb(); // isb + __ nop(); // nop + __ eret(); // eret + __ drps(); // drps + __ isb(); // isb // SystemOp - __ dsb(Assembler::OSH); // dsb OSH - __ dmb(Assembler::NSHLD); // dmb NSHLD + __ dsb(Assembler::ISHST); // dsb ISHST + __ dmb(Assembler::ISHST); // dmb ISHST // OneRegOp - __ br(r20); // br x20 - __ blr(r2); // blr x2 + __ br(r17); // br x17 + __ blr(r0); // blr x0 // LoadStoreExclusiveOp - __ stxr(r18, r23, r0); // stxr w18, x23, [x0] - __ stlxr(r30, r5, r22); // stlxr w30, x5, [x22] - __ ldxr(r5, r8); // ldxr x5, [x8] - __ ldaxr(r20, r16); // ldaxr x20, [x16] - __ stlr(r6, r11); // stlr x6, [x11] - __ ldar(r6, r27); // ldar x6, [x27] + __ stxr(r3, r7, r12); // stxr w3, x7, [x12] + __ stlxr(r16, r13, r18); // stlxr w16, x13, [x18] + __ ldxr(r11, r30); // ldxr x11, [x30] + __ ldaxr(r21, r3); // ldaxr x21, [x3] + __ stlr(r22, r26); // stlr x22, [x26] + __ ldar(r2, r27); // ldar x2, [x27] // LoadStoreExclusiveOp - __ stxrw(r10, r17, r5); // stxr w10, w17, [x5] - __ stlxrw(r22, r9, r12); // stlxr w22, w9, [x12] - __ ldxrw(r27, r8); // ldxr w27, [x8] - __ ldaxrw(r23, r2); // ldaxr w23, [x2] - __ stlrw(r26, r29); // stlr w26, [x29] - __ ldarw(r13, r10); // ldar w13, [x10] + __ stxrw(r20, r15, r2); // stxr w20, w15, [x2] + __ stlxrw(r11, r8, r13); // stlxr w11, w8, [x13] + __ ldxrw(r16, r26); // ldxr w16, [x26] + __ ldaxrw(r27, r11); // ldaxr w27, [x11] + __ stlrw(r30, r4); // stlr w30, [x4] + __ ldarw(r2, r11); // ldar w2, [x11] // LoadStoreExclusiveOp - __ stxrh(r25, r28, r27); // stxrh w25, w28, [x27] - __ stlxrh(r29, r22, r12); // stlxrh w29, w22, [x12] - __ ldxrh(r22, r28); // ldxrh w22, [x28] - __ ldaxrh(r3, r30); // ldaxrh w3, [x30] - __ stlrh(r24, r15); // stlrh w24, [x15] - __ ldarh(r27, r26); // ldarh w27, [x26] + __ stxrh(r22, r27, r18); // stxrh w22, w27, [x18] + __ stlxrh(r25, r10, r23); // stlxrh w25, w10, [x23] + __ ldxrh(r13, r30); // ldxrh w13, [x30] + __ ldaxrh(r13, r2); // ldaxrh w13, [x2] + __ stlrh(r2, r24); // stlrh w2, [x24] + __ ldarh(r25, r23); // ldarh w25, [x23] // LoadStoreExclusiveOp - __ stxrb(r11, r10, r19); // stxrb w11, w10, [x19] - __ stlxrb(r23, r27, r22); // stlxrb w23, w27, [x22] - __ ldxrb(r24, r16); // ldxrb w24, [x16] - __ ldaxrb(r24, r1); // ldaxrb w24, [x1] - __ stlrb(r5, r29); // stlrb w5, [x29] - __ ldarb(r24, r16); // ldarb w24, [x16] + __ stxrb(r13, r0, r29); // stxrb w13, w0, [x29] + __ stlxrb(r8, r20, r6); // stlxrb w8, w20, [x6] + __ ldxrb(r15, r5); // ldxrb w15, [x5] + __ ldaxrb(r0, r10); // ldaxrb w0, [x10] + __ stlrb(r12, r26); // stlrb w12, [x26] + __ ldarb(r11, r2); // ldarb w11, [x2] // LoadStoreExclusiveOp - __ ldxp(r25, r24, r17); // ldxp x25, x24, [x17] - __ ldaxp(r22, r12, r19); // ldaxp x22, x12, [x19] - __ stxp(r0, r26, r21, r25); // stxp w0, x26, x21, [x25] - __ stlxp(r1, r6, r11, r5); // stlxp w1, x6, x11, [x5] + __ ldxp(r23, r17, r9); // ldxp x23, x17, [x9] + __ ldaxp(r1, r7, r13); // ldaxp x1, x7, [x13] + __ stxp(r7, r0, r11, r29); // stxp w7, x0, x11, [x29] + __ stlxp(r25, r22, r5, r11); // stlxp w25, x22, x5, [x11] // LoadStoreExclusiveOp - __ ldxpw(r13, r14, r4); // ldxp w13, w14, [x4] - __ ldaxpw(r17, r2, r6); // ldaxp w17, w2, [x6] - __ stxpw(r15, r3, r9, r18); // stxp w15, w3, w9, [x18] - __ stlxpw(r18, r17, r4, r9); // stlxp w18, w17, w4, [x9] + __ ldxpw(r7, r6, r27); // ldxp w7, w6, [x27] + __ ldaxpw(r7, r2, r24); // ldaxp w7, w2, [x24] + __ stxpw(r6, r5, r30, r19); // stxp w6, w5, w30, [x19] + __ stlxpw(r2, r29, r7, r18); // stlxp w2, w29, w7, [x18] // base_plus_unscaled_offset // LoadStoreOp - __ str(r23, Address(r21, -49)); // str x23, [x21, -49] - __ strw(r21, Address(r2, 63)); // str w21, [x2, 63] - __ strb(r27, Address(r28, 11)); // strb w27, [x28, 11] - __ strh(r29, Address(r15, -13)); // strh w29, [x15, -13] - __ ldr(r14, Address(r30, -45)); // ldr x14, [x30, -45] - __ ldrw(r29, Address(r28, 53)); // ldr w29, [x28, 53] - __ ldrb(r20, Address(r26, 7)); // ldrb w20, [x26, 7] - __ ldrh(r25, Address(r2, -50)); // ldrh w25, [x2, -50] - __ ldrsb(r3, Address(r10, -15)); // ldrsb x3, [x10, -15] - __ ldrsh(r14, Address(r15, 19)); // ldrsh x14, [x15, 19] - __ ldrshw(r29, Address(r11, -5)); // ldrsh w29, [x11, -5] - __ ldrsw(r15, Address(r5, -71)); // ldrsw x15, [x5, -71] - __ ldrd(v19, Address(r12, 3)); // ldr d19, [x12, 3] - __ ldrs(v12, Address(r27, 42)); // ldr s12, [x27, 42] - __ strd(v22, Address(r28, 125)); // str d22, [x28, 125] - __ strs(v24, Address(r15, -20)); // str s24, [x15, -20] + __ str(r29, Address(r20, -183)); // str x29, [x20, -183] + __ strw(r6, Address(r13, -39)); // str w6, [x13, -39] + __ strb(r9, Address(r5, -11)); // strb w9, [x5, -11] + __ strh(r22, Address(r8, 21)); // strh w22, [x8, 21] + __ ldr(r1, Address(r29, -81)); // ldr x1, [x29, -81] + __ ldrw(r20, Address(r29, -27)); // ldr w20, [x29, -27] + __ ldrb(r15, Address(r12, -8)); // ldrb w15, [x12, -8] + __ ldrh(r9, Address(r7, -62)); // ldrh w9, [x7, -62] + __ ldrsb(r23, Address(r13, -9)); // ldrsb x23, [x13, -9] + __ ldrsh(r18, Address(r13, 30)); // ldrsh x18, [x13, 30] + __ ldrshw(r17, Address(r30, 26)); // ldrsh w17, [x30, 26] + __ ldrsw(r21, Address(r14, -125)); // ldrsw x21, [x14, -125] + __ ldrd(v21, Address(r13, 59)); // ldr d21, [x13, 59] + __ ldrs(v21, Address(r8, 63)); // ldr s21, [x8, 63] + __ strd(v22, Address(r24, 53)); // str d22, [x24, 53] + __ strs(v26, Address(r0, 21)); // str s26, [x0, 21] // pre // LoadStoreOp - __ str(r8, Address(__ pre(r28, -24))); // str x8, [x28, -24]! - __ strw(r6, Address(__ pre(r15, 37))); // str w6, [x15, 37]! - __ strb(r7, Address(__ pre(r1, 7))); // strb w7, [x1, 7]! - __ strh(r0, Address(__ pre(r17, 30))); // strh w0, [x17, 30]! - __ ldr(r25, Address(__ pre(r29, 84))); // ldr x25, [x29, 84]! - __ ldrw(r26, Address(__ pre(r20, -52))); // ldr w26, [x20, -52]! - __ ldrb(r26, Address(__ pre(r29, -25))); // ldrb w26, [x29, -25]! - __ ldrh(r4, Address(__ pre(r25, 26))); // ldrh w4, [x25, 26]! - __ ldrsb(r28, Address(__ pre(r8, -21))); // ldrsb x28, [x8, -21]! - __ ldrsh(r17, Address(__ pre(r14, -6))); // ldrsh x17, [x14, -6]! - __ ldrshw(r28, Address(__ pre(r23, 10))); // ldrsh w28, [x23, 10]! - __ ldrsw(r30, Address(__ pre(r27, -64))); // ldrsw x30, [x27, -64]! - __ ldrd(v20, Address(__ pre(r30, -242))); // ldr d20, [x30, -242]! - __ ldrs(v17, Address(__ pre(r27, 20))); // ldr s17, [x27, 20]! - __ strd(v7, Address(__ pre(r3, 17))); // str d7, [x3, 17]! - __ strs(v13, Address(__ pre(r11, -16))); // str s13, [x11, -16]! + __ str(r23, Address(__ pre(r22, -215))); // str x23, [x22, -215]! + __ strw(r30, Address(__ pre(r29, -3))); // str w30, [x29, -3]! + __ strb(r2, Address(__ pre(r7, -18))); // strb w2, [x7, -18]! + __ strh(r23, Address(__ pre(r12, 19))); // strh w23, [x12, 19]! + __ ldr(r18, Address(__ pre(r4, -210))); // ldr x18, [x4, -210]! + __ ldrw(r19, Address(__ pre(r30, -71))); // ldr w19, [x30, -71]! + __ ldrb(r17, Address(__ pre(r20, -11))); // ldrb w17, [x20, -11]! + __ ldrh(r9, Address(__ pre(r14, -64))); // ldrh w9, [x14, -64]! + __ ldrsb(r6, Address(__ pre(r3, 11))); // ldrsb x6, [x3, 11]! + __ ldrsh(r11, Address(__ pre(r22, -6))); // ldrsh x11, [x22, -6]! + __ ldrshw(r6, Address(__ pre(r11, -27))); // ldrsh w6, [x11, -27]! + __ ldrsw(r25, Address(__ pre(r18, 54))); // ldrsw x25, [x18, 54]! + __ ldrd(v21, Address(__ pre(r23, -8))); // ldr d21, [x23, -8]! + __ ldrs(v30, Address(__ pre(r10, -39))); // ldr s30, [x10, -39]! + __ strd(v2, Address(__ pre(r1, -129))); // str d2, [x1, -129]! + __ strs(v26, Address(__ pre(r0, 1))); // str s26, [x0, 1]! // post // LoadStoreOp - __ str(r6, Address(__ post(r9, -61))); // str x6, [x9], -61 - __ strw(r16, Address(__ post(r5, -29))); // str w16, [x5], -29 - __ strb(r29, Address(__ post(r29, 15))); // strb w29, [x29], 15 - __ strh(r4, Address(__ post(r20, 18))); // strh w4, [x20], 18 - __ ldr(r19, Address(__ post(r18, 46))); // ldr x19, [x18], 46 - __ ldrw(r22, Address(__ post(r2, 23))); // ldr w22, [x2], 23 - __ ldrb(r7, Address(__ post(r3, -30))); // ldrb w7, [x3], -30 - __ ldrh(r11, Address(__ post(r12, -29))); // ldrh w11, [x12], -29 - __ ldrsb(r8, Address(__ post(r6, -29))); // ldrsb x8, [x6], -29 - __ ldrsh(r24, Address(__ post(r23, 4))); // ldrsh x24, [x23], 4 - __ ldrshw(r17, Address(__ post(r16, 0))); // ldrsh w17, [x16], 0 - __ ldrsw(r0, Address(__ post(r20, -8))); // ldrsw x0, [x20], -8 - __ ldrd(v20, Address(__ post(r2, -126))); // ldr d20, [x2], -126 - __ ldrs(v19, Address(__ post(r30, -104))); // ldr s19, [x30], -104 - __ strd(v4, Address(__ post(r17, 118))); // str d4, [x17], 118 - __ strs(v21, Address(__ post(r19, -112))); // str s21, [x19], -112 + __ str(r9, Address(__ post(r26, -99))); // str x9, [x26], -99 + __ strw(r9, Address(__ post(r14, 62))); // str w9, [x14], 62 + __ strb(r30, Address(__ post(r26, -30))); // strb w30, [x26], -30 + __ strh(r28, Address(__ post(r16, 11))); // strh w28, [x16], 11 + __ ldr(r29, Address(__ post(r26, 77))); // ldr x29, [x26], 77 + __ ldrw(r0, Address(__ post(r23, 53))); // ldr w0, [x23], 53 + __ ldrb(r7, Address(__ post(r21, -18))); // ldrb w7, [x21], -18 + __ ldrh(r24, Address(__ post(r13, 24))); // ldrh w24, [x13], 24 + __ ldrsb(r1, Address(__ post(r8, -17))); // ldrsb x1, [x8], -17 + __ ldrsh(r17, Address(__ post(r27, -34))); // ldrsh x17, [x27], -34 + __ ldrshw(r21, Address(__ post(r1, -26))); // ldrsh w21, [x1], -26 + __ ldrsw(r6, Address(__ post(r21, 0))); // ldrsw x6, [x21], 0 + __ ldrd(v5, Address(__ post(r3, 58))); // ldr d5, [x3], 58 + __ ldrs(v7, Address(__ post(r19, -80))); // ldr s7, [x19], -80 + __ strd(v1, Address(__ post(r16, 27))); // str d1, [x16], 27 + __ strs(v7, Address(__ post(r25, 62))); // str s7, [x25], 62 // base_plus_reg // LoadStoreOp - __ str(r26, Address(r2, r19, Address::lsl(3))); // str x26, [x2, x19, lsl #3] - __ strw(r9, Address(r0, r15, Address::sxtw(2))); // str w9, [x0, w15, sxtw #2] - __ strb(r26, Address(r12, r1, Address::lsl(0))); // strb w26, [x12, x1, lsl #0] - __ strh(r21, Address(r11, r10, Address::lsl(1))); // strh w21, [x11, x10, lsl #1] - __ ldr(r16, Address(r23, r16, Address::sxtx(0))); // ldr x16, [x23, x16, sxtx #0] - __ ldrw(r10, Address(r11, r17, Address::sxtw(2))); // ldr w10, [x11, w17, sxtw #2] - __ ldrb(r13, Address(r23, r11, Address::lsl(0))); // ldrb w13, [x23, x11, lsl #0] - __ ldrh(r27, Address(r4, r21, Address::lsl(0))); // ldrh w27, [x4, x21, lsl #0] - __ ldrsb(r26, Address(r8, r15, Address::sxtw(0))); // ldrsb x26, [x8, w15, sxtw #0] - __ ldrsh(r21, Address(r10, r2, Address::sxtw(0))); // ldrsh x21, [x10, w2, sxtw #0] - __ ldrshw(r8, Address(r30, r14, Address::lsl(0))); // ldrsh w8, [x30, x14, lsl #0] - __ ldrsw(r29, Address(r14, r20, Address::sxtx(2))); // ldrsw x29, [x14, x20, sxtx #2] - __ ldrd(v30, Address(r27, r22, Address::sxtx(0))); // ldr d30, [x27, x22, sxtx #0] - __ ldrs(v13, Address(r9, r22, Address::lsl(0))); // ldr s13, [x9, x22, lsl #0] - __ strd(v8, Address(r25, r17, Address::sxtw(3))); // str d8, [x25, w17, sxtw #3] - __ strs(v1, Address(r24, r5, Address::uxtw(2))); // str s1, [x24, w5, uxtw #2] + __ str(r13, Address(r3, r30, Address::uxtw(3))); // str x13, [x3, w30, uxtw #3] + __ strw(r17, Address(r3, r1, Address::sxtx(0))); // str w17, [x3, x1, sxtx #0] + __ strb(r23, Address(r19, r27, Address::lsl(0))); // strb w23, [x19, x27, lsl #0] + __ strh(r5, Address(r20, r10, Address::uxtw(1))); // strh w5, [x20, w10, uxtw #1] + __ ldr(r29, Address(r2, r16, Address::sxtw(3))); // ldr x29, [x2, w16, sxtw #3] + __ ldrw(r16, Address(r17, r21, Address::sxtx(2))); // ldr w16, [x17, x21, sxtx #2] + __ ldrb(r10, Address(r16, r16, Address::uxtw(0))); // ldrb w10, [x16, w16, uxtw #0] + __ ldrh(r23, Address(r27, r26, Address::sxtw(1))); // ldrh w23, [x27, w26, sxtw #1] + __ ldrsb(r13, Address(r0, r7, Address::lsl(0))); // ldrsb x13, [x0, x7, lsl #0] + __ ldrsh(r15, Address(r5, r18, Address::uxtw(0))); // ldrsh x15, [x5, w18, uxtw #0] + __ ldrshw(r18, Address(r20, r18, Address::lsl(1))); // ldrsh w18, [x20, x18, lsl #1] + __ ldrsw(r30, Address(r14, r17, Address::uxtw(0))); // ldrsw x30, [x14, w17, uxtw #0] + __ ldrd(v19, Address(r6, r26, Address::uxtw(3))); // ldr d19, [x6, w26, uxtw #3] + __ ldrs(v30, Address(r23, r2, Address::sxtw(0))); // ldr s30, [x23, w2, sxtw #0] + __ strd(v27, Address(r22, r7, Address::uxtw(0))); // str d27, [x22, w7, uxtw #0] + __ strs(v9, Address(r24, r26, Address::sxtx(2))); // str s9, [x24, x26, sxtx #2] // base_plus_scaled_offset // LoadStoreOp - __ str(r10, Address(r21, 14496)); // str x10, [x21, 14496] - __ strw(r18, Address(r29, 7228)); // str w18, [x29, 7228] - __ strb(r23, Address(r3, 2018)); // strb w23, [x3, 2018] - __ strh(r28, Address(r11, 3428)); // strh w28, [x11, 3428] - __ ldr(r24, Address(r26, 14376)); // ldr x24, [x26, 14376] - __ ldrw(r21, Address(r2, 6972)); // ldr w21, [x2, 6972] - __ ldrb(r4, Address(r5, 1848)); // ldrb w4, [x5, 1848] - __ ldrh(r14, Address(r14, 3112)); // ldrh w14, [x14, 3112] - __ ldrsb(r4, Address(r27, 1959)); // ldrsb x4, [x27, 1959] - __ ldrsh(r4, Address(r27, 3226)); // ldrsh x4, [x27, 3226] - __ ldrshw(r10, Address(r28, 3286)); // ldrsh w10, [x28, 3286] - __ ldrsw(r10, Address(r17, 7912)); // ldrsw x10, [x17, 7912] - __ ldrd(v13, Address(r28, 13400)); // ldr d13, [x28, 13400] - __ ldrs(v24, Address(r3, 7596)); // ldr s24, [x3, 7596] - __ strd(v2, Address(r12, 15360)); // str d2, [x12, 15360] - __ strs(v17, Address(r1, 6492)); // str s17, [x1, 6492] + __ str(r14, Address(r28, 16104)); // str x14, [x28, 16104] + __ strw(r16, Address(r13, 7864)); // str w16, [x13, 7864] + __ strb(r20, Address(r27, 1562)); // strb w20, [x27, 1562] + __ strh(r16, Address(r7, 3268)); // strh w16, [x7, 3268] + __ ldr(r5, Address(r21, 15512)); // ldr x5, [x21, 15512] + __ ldrw(r0, Address(r8, 7656)); // ldr w0, [x8, 7656] + __ ldrb(r1, Address(r7, 2020)); // ldrb w1, [x7, 2020] + __ ldrh(r1, Address(r14, 3294)); // ldrh w1, [x14, 3294] + __ ldrsb(r6, Address(r25, 1766)); // ldrsb x6, [x25, 1766] + __ ldrsh(r9, Address(r16, 3248)); // ldrsh x9, [x16, 3248] + __ ldrshw(r27, Address(r4, 3608)); // ldrsh w27, [x4, 3608] + __ ldrsw(r2, Address(r16, 7308)); // ldrsw x2, [x16, 7308] + __ ldrd(v5, Address(r26, 16192)); // ldr d5, [x26, 16192] + __ ldrs(v19, Address(r13, 7932)); // ldr s19, [x13, 7932] + __ strd(v22, Address(r7, 13376)); // str d22, [x7, 13376] + __ strs(v8, Address(r9, 7816)); // str s8, [x9, 7816] // pcrel // LoadStoreOp - __ ldr(r16, __ pc()); // ldr x16, . - __ ldrw(r13, __ pc()); // ldr w13, . + __ ldr(r26, back); // ldr x26, back + __ ldrw(r12, back); // ldr w12, back // LoadStoreOp - __ prfm(Address(r18, -127)); // prfm PLDL1KEEP, [x18, -127] + __ prfm(Address(r10, 47)); // prfm PLDL1KEEP, [x10, 47] // LoadStoreOp - __ prfm(back); // prfm PLDL1KEEP, back + __ prfm(forth); // prfm PLDL1KEEP, forth // LoadStoreOp - __ prfm(Address(r20, r2, Address::lsl(3))); // prfm PLDL1KEEP, [x20, x2, lsl #3] + __ prfm(Address(r21, r20, Address::lsl(3))); // prfm PLDL1KEEP, [x21, x20, lsl #3] // LoadStoreOp - __ prfm(Address(r9, 13808)); // prfm PLDL1KEEP, [x9, 13808] + __ prfm(Address(r13, 15776)); // prfm PLDL1KEEP, [x13, 15776] // AddSubCarryOp - __ adcw(r8, r23, r2); // adc w8, w23, w2 - __ adcsw(r24, r3, r19); // adcs w24, w3, w19 - __ sbcw(r22, r24, r29); // sbc w22, w24, w29 - __ sbcsw(r12, r27, r3); // sbcs w12, w27, w3 - __ adc(r11, r23, r1); // adc x11, x23, x1 - __ adcs(r29, r5, r23); // adcs x29, x5, x23 - __ sbc(r9, r25, r12); // sbc x9, x25, x12 - __ sbcs(r12, r0, r22); // sbcs x12, x0, x22 + __ adcw(r26, r8, r3); // adc w26, w8, w3 + __ adcsw(r9, r30, r7); // adcs w9, w30, w7 + __ sbcw(r24, r15, r11); // sbc w24, w15, w11 + __ sbcsw(r4, r21, r11); // sbcs w4, w21, w11 + __ adc(r15, r17, r30); // adc x15, x17, x30 + __ adcs(r6, r15, r16); // adcs x6, x15, x16 + __ sbc(r1, r2, r10); // sbc x1, x2, x10 + __ sbcs(r9, r4, r11); // sbcs x9, x4, x11 // AddSubExtendedOp - __ addw(r26, r12, r3, ext::uxtw, 1); // add w26, w12, w3, uxtw #1 - __ addsw(r20, r16, r18, ext::sxtb, 2); // adds w20, w16, w18, sxtb #2 - __ sub(r30, r30, r7, ext::uxtw, 2); // sub x30, x30, x7, uxtw #2 - __ subsw(r11, r21, r2, ext::uxth, 3); // subs w11, w21, w2, uxth #3 - __ add(r2, r26, r1, ext::uxtw, 2); // add x2, x26, x1, uxtw #2 - __ adds(r18, r29, r20, ext::sxth, 1); // adds x18, x29, x20, sxth #1 - __ sub(r14, r16, r4, ext::uxtw, 4); // sub x14, x16, x4, uxtw #4 - __ subs(r0, r17, r23, ext::sxtb, 3); // subs x0, x17, x23, sxtb #3 + __ addw(r23, r29, r17, ext::uxtx, 1); // add w23, w29, w17, uxtx #1 + __ addsw(r15, r11, r11, ext::sxtx, 3); // adds w15, w11, w11, sxtx #3 + __ sub(r2, r30, r7, ext::uxtw, 4); // sub x2, x30, x7, uxtw #4 + __ subsw(r30, r19, r26, ext::sxtb, 1); // subs w30, w19, w26, sxtb #1 + __ add(r2, r0, r12, ext::uxtx, 3); // add x2, x0, x12, uxtx #3 + __ adds(r14, r1, r16, ext::sxtb, 4); // adds x14, x1, x16, sxtb #4 + __ sub(r15, r22, r23, ext::sxtb, 3); // sub x15, x22, x23, sxtb #3 + __ subs(r0, r4, r28, ext::uxtw, 1); // subs x0, x4, x28, uxtw #1 // ConditionalCompareOp - __ ccmnw(r20, r22, 3u, Assembler::PL); // ccmn w20, w22, #3, PL - __ ccmpw(r25, r2, 1u, Assembler::EQ); // ccmp w25, w2, #1, EQ - __ ccmn(r18, r24, 7u, Assembler::GT); // ccmn x18, x24, #7, GT - __ ccmp(r8, r13, 6u, Assembler::PL); // ccmp x8, x13, #6, PL + __ ccmnw(r5, r18, 11u, Assembler::CS); // ccmn w5, w18, #11, CS + __ ccmpw(r18, r21, 8u, Assembler::HS); // ccmp w18, w21, #8, HS + __ ccmn(r15, r17, 15u, Assembler::CC); // ccmn x15, x17, #15, CC + __ ccmp(r13, r23, 6u, Assembler::NE); // ccmp x13, x23, #6, NE // ConditionalCompareImmedOp - __ ccmnw(r9, 2, 4, Assembler::VS); // ccmn w9, #2, #4, VS - __ ccmpw(r2, 27, 7, Assembler::EQ); // ccmp w2, #27, #7, EQ - __ ccmn(r16, 1, 2, Assembler::CC); // ccmn x16, #1, #2, CC - __ ccmp(r17, 31, 3, Assembler::LT); // ccmp x17, #31, #3, LT + __ ccmnw(r28, 9, 15, Assembler::CC); // ccmn w28, #9, #15, CC + __ ccmpw(r14, 12, 9, Assembler::LS); // ccmp w14, #12, #9, LS + __ ccmn(r22, 6, 2, Assembler::LO); // ccmn x22, #6, #2, LO + __ ccmp(r21, 12, 0, Assembler::MI); // ccmp x21, #12, #0, MI // ConditionalSelectOp - __ cselw(r23, r27, r23, Assembler::LS); // csel w23, w27, w23, LS - __ csincw(r10, r0, r6, Assembler::VS); // csinc w10, w0, w6, VS - __ csinvw(r11, r0, r9, Assembler::CC); // csinv w11, w0, w9, CC - __ csnegw(r17, r27, r18, Assembler::LO); // csneg w17, w27, w18, LO - __ csel(r12, r16, r11, Assembler::VC); // csel x12, x16, x11, VC - __ csinc(r6, r28, r6, Assembler::HI); // csinc x6, x28, x6, HI - __ csinv(r13, r27, r26, Assembler::VC); // csinv x13, x27, x26, VC - __ csneg(r29, r22, r18, Assembler::PL); // csneg x29, x22, x18, PL + __ cselw(r14, r21, r28, Assembler::GT); // csel w14, w21, w28, GT + __ csincw(r25, r14, r17, Assembler::GT); // csinc w25, w14, w17, GT + __ csinvw(r17, r6, r25, Assembler::HS); // csinv w17, w6, w25, HS + __ csnegw(r21, r2, r14, Assembler::HS); // csneg w21, w2, w14, HS + __ csel(r3, r11, r17, Assembler::HS); // csel x3, x11, x17, HS + __ csinc(r27, r30, r27, Assembler::HS); // csinc x27, x30, x27, HS + __ csinv(r0, r15, r5, Assembler::HI); // csinv x0, x15, x5, HI + __ csneg(r2, r11, r8, Assembler::CS); // csneg x2, x11, x8, CS // TwoRegOp - __ rbitw(r12, r19); // rbit w12, w19 - __ rev16w(r23, r18); // rev16 w23, w18 - __ revw(r9, r28); // rev w9, w28 - __ clzw(r2, r19); // clz w2, w19 - __ clsw(r25, r29); // cls w25, w29 - __ rbit(r4, r23); // rbit x4, x23 - __ rev16(r29, r18); // rev16 x29, x18 - __ rev32(r7, r8); // rev32 x7, x8 - __ rev(r13, r17); // rev x13, x17 - __ clz(r17, r0); // clz x17, x0 - __ cls(r18, r26); // cls x18, x26 + __ rbitw(r2, r19); // rbit w2, w19 + __ rev16w(r22, r12); // rev16 w22, w12 + __ revw(r5, r22); // rev w5, w22 + __ clzw(r3, r27); // clz w3, w27 + __ clsw(r18, r4); // cls w18, w4 + __ rbit(r22, r27); // rbit x22, x27 + __ rev16(r12, r10); // rev16 x12, x10 + __ rev32(r5, r4); // rev32 x5, x4 + __ rev(r22, r10); // rev x22, x10 + __ clz(r13, r7); // clz x13, x7 + __ cls(r6, r10); // cls x6, x10 // ThreeRegOp - __ udivw(r11, r12, r16); // udiv w11, w12, w16 - __ sdivw(r4, r9, r7); // sdiv w4, w9, w7 - __ lslvw(r12, r7, r16); // lslv w12, w7, w16 - __ lsrvw(r19, r16, r23); // lsrv w19, w16, w23 - __ asrvw(r7, r4, r6); // asrv w7, w4, w6 - __ rorvw(r21, r20, r23); // rorv w21, w20, w23 - __ udiv(r16, r12, r28); // udiv x16, x12, x28 - __ sdiv(r4, r12, r13); // sdiv x4, x12, x13 - __ lslv(r9, r13, r7); // lslv x9, x13, x7 - __ lsrv(r28, r27, r15); // lsrv x28, x27, x15 - __ asrv(r20, r30, r14); // asrv x20, x30, x14 - __ rorv(r14, r18, r30); // rorv x14, x18, x30 - __ umulh(r3, r11, r7); // umulh x3, x11, x7 - __ smulh(r23, r20, r24); // smulh x23, x20, x24 + __ udivw(r2, r16, r28); // udiv w2, w16, w28 + __ sdivw(r8, r23, r8); // sdiv w8, w23, w8 + __ lslvw(r18, r17, r14); // lslv w18, w17, w14 + __ lsrvw(r30, r25, r22); // lsrv w30, w25, w22 + __ asrvw(r16, r2, r5); // asrv w16, w2, w5 + __ rorvw(r15, r28, r0); // rorv w15, w28, w0 + __ udiv(r13, r20, r1); // udiv x13, x20, x1 + __ sdiv(r28, r30, r18); // sdiv x28, x30, x18 + __ lslv(r17, r28, r9); // lslv x17, x28, x9 + __ lsrv(r18, r13, r4); // lsrv x18, x13, x4 + __ asrv(r12, r24, r16); // asrv x12, x24, x16 + __ rorv(r14, r9, r24); // rorv x14, x9, x24 + __ umulh(r20, r4, r24); // umulh x20, x4, x24 + __ smulh(r18, r5, r28); // smulh x18, x5, x28 // FourRegMulOp - __ maddw(r2, r5, r21, r9); // madd w2, w5, w21, w9 - __ msubw(r24, r24, r4, r8); // msub w24, w24, w4, w8 - __ madd(r11, r12, r15, r19); // madd x11, x12, x15, x19 - __ msub(r29, r25, r12, r25); // msub x29, x25, x12, x25 - __ smaddl(r17, r11, r12, r22); // smaddl x17, w11, w12, x22 - __ smsubl(r28, r3, r20, r18); // smsubl x28, w3, w20, x18 - __ umaddl(r7, r4, r28, r26); // umaddl x7, w4, w28, x26 - __ umsubl(r22, r10, r17, r5); // umsubl x22, w10, w17, x5 + __ maddw(r19, r29, r17, r18); // madd w19, w29, w17, w18 + __ msubw(r14, r22, r15, r19); // msub w14, w22, w15, w19 + __ madd(r12, r5, r1, r8); // madd x12, x5, x1, x8 + __ msub(r22, r18, r11, r16); // msub x22, x18, x11, x16 + __ smaddl(r0, r11, r12, r30); // smaddl x0, w11, w12, x30 + __ smsubl(r19, r8, r13, r12); // smsubl x19, w8, w13, x12 + __ umaddl(r13, r30, r17, r5); // umaddl x13, w30, w17, x5 + __ umsubl(r16, r12, r23, r9); // umsubl x16, w12, w23, x9 // ThreeRegFloatOp - __ fmuls(v17, v3, v17); // fmul s17, s3, s17 - __ fdivs(v11, v17, v6); // fdiv s11, s17, s6 - __ fadds(v29, v7, v9); // fadd s29, s7, s9 - __ fsubs(v7, v12, v19); // fsub s7, s12, s19 - __ fmuls(v0, v23, v3); // fmul s0, s23, s3 - __ fmuld(v26, v3, v21); // fmul d26, d3, d21 - __ fdivd(v0, v19, v5); // fdiv d0, d19, d5 - __ faddd(v0, v26, v9); // fadd d0, d26, d9 - __ fsubd(v25, v21, v21); // fsub d25, d21, d21 - __ fmuld(v16, v13, v19); // fmul d16, d13, d19 + __ fmuls(v6, v20, v0); // fmul s6, s20, s0 + __ fdivs(v21, v6, v15); // fdiv s21, s6, s15 + __ fadds(v24, v9, v25); // fadd s24, s9, s25 + __ fsubs(v9, v24, v18); // fsub s9, s24, s18 + __ fmuls(v26, v24, v10); // fmul s26, s24, s10 + __ fmuld(v12, v20, v0); // fmul d12, d20, d0 + __ fdivd(v12, v15, v16); // fdiv d12, d15, d16 + __ faddd(v24, v6, v29); // fadd d24, d6, d29 + __ fsubd(v24, v6, v14); // fsub d24, d6, d14 + __ fmuld(v21, v29, v15); // fmul d21, d29, d15 // FourRegFloatOp - __ fmadds(v29, v18, v0, v16); // fmadd s29, s18, s0, s16 - __ fmsubs(v23, v13, v29, v5); // fmsub s23, s13, s29, s5 - __ fnmadds(v9, v7, v10, v14); // fnmadd s9, s7, s10, s14 - __ fnmadds(v25, v28, v15, v23); // fnmadd s25, s28, s15, s23 - __ fmaddd(v6, v13, v21, v17); // fmadd d6, d13, d21, d17 - __ fmsubd(v3, v21, v2, v7); // fmsub d3, d21, d2, d7 - __ fnmaddd(v10, v25, v5, v17); // fnmadd d10, d25, d5, d17 - __ fnmaddd(v14, v14, v20, v18); // fnmadd d14, d14, d20, d18 + __ fmadds(v9, v25, v1, v29); // fmadd s9, s25, s1, s29 + __ fmsubs(v13, v20, v10, v29); // fmsub s13, s20, s10, s29 + __ fnmadds(v28, v11, v11, v7); // fnmadd s28, s11, s11, s7 + __ fnmadds(v7, v28, v21, v1); // fnmadd s7, s28, s21, s1 + __ fmaddd(v30, v29, v15, v1); // fmadd d30, d29, d15, d1 + __ fmsubd(v12, v8, v27, v26); // fmsub d12, d8, d27, d26 + __ fnmaddd(v17, v24, v11, v25); // fnmadd d17, d24, d11, d25 + __ fnmaddd(v30, v1, v8, v0); // fnmadd d30, d1, d8, d0 // TwoRegFloatOp - __ fmovs(v15, v2); // fmov s15, s2 - __ fabss(v18, v7); // fabs s18, s7 - __ fnegs(v3, v6); // fneg s3, s6 - __ fsqrts(v12, v1); // fsqrt s12, s1 - __ fcvts(v9, v0); // fcvt d9, s0 - __ fmovd(v4, v5); // fmov d4, d5 - __ fabsd(v3, v15); // fabs d3, d15 - __ fnegd(v17, v25); // fneg d17, d25 - __ fsqrtd(v12, v24); // fsqrt d12, d24 - __ fcvtd(v21, v5); // fcvt s21, d5 + __ fmovs(v1, v5); // fmov s1, s5 + __ fabss(v6, v19); // fabs s6, s19 + __ fnegs(v4, v0); // fneg s4, s0 + __ fsqrts(v9, v10); // fsqrt s9, s10 + __ fcvts(v20, v14); // fcvt d20, s14 + __ fmovd(v0, v19); // fmov d0, d19 + __ fabsd(v30, v18); // fabs d30, d18 + __ fnegd(v0, v8); // fneg d0, d8 + __ fsqrtd(v0, v8); // fsqrt d0, d8 + __ fcvtd(v14, v30); // fcvt s14, d30 // FloatConvertOp - __ fcvtzsw(r4, v21); // fcvtzs w4, s21 - __ fcvtzs(r27, v3); // fcvtzs x27, s3 - __ fcvtzdw(r29, v8); // fcvtzs w29, d8 - __ fcvtzd(r9, v21); // fcvtzs x9, d21 - __ scvtfws(v20, r29); // scvtf s20, w29 - __ scvtfs(v7, r8); // scvtf s7, x8 - __ scvtfwd(v12, r21); // scvtf d12, w21 - __ scvtfd(v16, r21); // scvtf d16, x21 - __ fmovs(r18, v5); // fmov w18, s5 - __ fmovd(r25, v8); // fmov x25, d8 - __ fmovs(v18, r26); // fmov s18, w26 - __ fmovd(v0, r11); // fmov d0, x11 + __ fcvtzsw(r19, v22); // fcvtzs w19, s22 + __ fcvtzs(r17, v10); // fcvtzs x17, s10 + __ fcvtzdw(r27, v21); // fcvtzs w27, d21 + __ fcvtzd(r7, v4); // fcvtzs x7, d4 + __ scvtfws(v30, r25); // scvtf s30, w25 + __ scvtfs(v25, r16); // scvtf s25, x16 + __ scvtfwd(v9, r26); // scvtf d9, w26 + __ scvtfd(v7, r0); // scvtf d7, x0 + __ fmovs(r0, v15); // fmov w0, s15 + __ fmovd(r11, v4); // fmov x11, d4 + __ fmovs(v30, r15); // fmov s30, w15 + __ fmovd(v2, r23); // fmov d2, x23 // TwoRegFloatOp - __ fcmps(v16, v6); // fcmp s16, s6 - __ fcmpd(v16, v29); // fcmp d16, d29 - __ fcmps(v30, 0.0); // fcmp s30, #0.0 - __ fcmpd(v9, 0.0); // fcmp d9, #0.0 + __ fcmps(v14, v10); // fcmp s14, s10 + __ fcmpd(v30, v0); // fcmp d30, d0 + __ fcmps(v11, 0.0); // fcmp s11, #0.0 + __ fcmpd(v24, 0.0); // fcmp d24, #0.0 // LoadStorePairOp - __ stpw(r27, r4, Address(r12, -16)); // stp w27, w4, [x12, #-16] - __ ldpw(r3, r9, Address(r10, 80)); // ldp w3, w9, [x10, #80] - __ ldpsw(r16, r3, Address(r3, 64)); // ldpsw x16, x3, [x3, #64] - __ stp(r10, r28, Address(r19, -192)); // stp x10, x28, [x19, #-192] - __ ldp(r19, r18, Address(r7, -192)); // ldp x19, x18, [x7, #-192] + __ stpw(r28, r16, Address(r1, -240)); // stp w28, w16, [x1, #-240] + __ ldpw(r23, r21, Address(r14, 96)); // ldp w23, w21, [x14, #96] + __ ldpsw(r0, r24, Address(r7, -64)); // ldpsw x0, x24, [x7, #-64] + __ stp(r21, r20, Address(r16, 128)); // stp x21, x20, [x16, #128] + __ ldp(r1, r3, Address(r26, -112)); // ldp x1, x3, [x26, #-112] // LoadStorePairOp - __ stpw(r10, r16, Address(__ pre(r30, 16))); // stp w10, w16, [x30, #16]! - __ ldpw(r2, r4, Address(__ pre(r18, -240))); // ldp w2, w4, [x18, #-240]! - __ ldpsw(r24, r19, Address(__ pre(r13, 48))); // ldpsw x24, x19, [x13, #48]! - __ stp(r17, r0, Address(__ pre(r24, 0))); // stp x17, x0, [x24, #0]! - __ ldp(r14, r26, Address(__ pre(r3, -192))); // ldp x14, x26, [x3, #-192]! + __ stpw(r12, r14, Address(__ pre(r10, -240))); // stp w12, w14, [x10, #-240]! + __ ldpw(r3, r0, Address(__ pre(r7, -240))); // ldp w3, w0, [x7, #-240]! + __ ldpsw(r26, r24, Address(__ pre(r5, -208))); // ldpsw x26, x24, [x5, #-208]! + __ stp(r16, r22, Address(__ pre(r8, -160))); // stp x16, x22, [x8, #-160]! + __ ldp(r26, r4, Address(__ pre(r15, -144))); // ldp x26, x4, [x15, #-144]! // LoadStorePairOp - __ stpw(r22, r1, Address(__ post(r0, 80))); // stp w22, w1, [x0], #80 - __ ldpw(r18, r10, Address(__ post(r0, -16))); // ldp w18, w10, [x0], #-16 - __ ldpsw(r24, r24, Address(__ post(r22, -16))); // ldpsw x24, x24, [x22], #-16 - __ stp(r12, r12, Address(__ post(r4, 80))); // stp x12, x12, [x4], #80 - __ ldp(r4, r9, Address(__ post(r19, -240))); // ldp x4, x9, [x19], #-240 + __ stpw(r9, r28, Address(__ post(r29, 112))); // stp w9, w28, [x29], #112 + __ ldpw(r8, r5, Address(__ post(r3, 64))); // ldp w8, w5, [x3], #64 + __ ldpsw(r30, r4, Address(__ post(r12, -208))); // ldpsw x30, x4, [x12], #-208 + __ stp(r14, r30, Address(__ post(r16, -160))); // stp x14, x30, [x16], #-160 + __ ldp(r27, r22, Address(__ post(r9, -208))); // ldp x27, x22, [x9], #-208 // LoadStorePairOp - __ stnpw(r18, r26, Address(r6, -224)); // stnp w18, w26, [x6, #-224] - __ ldnpw(r21, r20, Address(r1, 112)); // ldnp w21, w20, [x1, #112] - __ stnp(r25, r29, Address(r20, -224)); // stnp x25, x29, [x20, #-224] - __ ldnp(r1, r5, Address(r23, 112)); // ldnp x1, x5, [x23, #112] + __ stnpw(r26, r21, Address(r24, -256)); // stnp w26, w21, [x24, #-256] + __ ldnpw(r20, r9, Address(r15, -48)); // ldnp w20, w9, [x15, #-48] + __ stnp(r15, r26, Address(r13, -240)); // stnp x15, x26, [x13, #-240] + __ ldnp(r5, r26, Address(r5, 16)); // ldnp x5, x26, [x5, #16] // LdStSIMDOp - __ ld1(v4, __ T8B, Address(r20)); // ld1 {v4.8B}, [x20] - __ ld1(v24, v25, __ T16B, Address(__ post(r10, 32))); // ld1 {v24.16B, v25.16B}, [x10], 32 - __ ld1(v24, v25, v26, __ T1D, Address(__ post(r6, r15))); // ld1 {v24.1D, v25.1D, v26.1D}, [x6], x15 - __ ld1(v3, v4, v5, v6, __ T8H, Address(__ post(r4, 64))); // ld1 {v3.8H, v4.8H, v5.8H, v6.8H}, [x4], 64 - __ ld1r(v2, __ T8B, Address(r6)); // ld1r {v2.8B}, [x6] - __ ld1r(v13, __ T4S, Address(__ post(r14, 4))); // ld1r {v13.4S}, [x14], 4 - __ ld1r(v15, __ T1D, Address(__ post(r21, r24))); // ld1r {v15.1D}, [x21], x24 - __ ld2(v9, v10, __ T2D, Address(r21)); // ld2 {v9.2D, v10.2D}, [x21] - __ ld2(v29, v30, __ T4H, Address(__ post(r21, 16))); // ld2 {v29.4H, v30.4H}, [x21], 16 - __ ld2r(v8, v9, __ T16B, Address(r14)); // ld2r {v8.16B, v9.16B}, [x14] - __ ld2r(v7, v8, __ T2S, Address(__ post(r20, 8))); // ld2r {v7.2S, v8.2S}, [x20], 8 - __ ld2r(v28, v29, __ T2D, Address(__ post(r3, r3))); // ld2r {v28.2D, v29.2D}, [x3], x3 - __ ld3(v27, v28, v29, __ T4S, Address(__ post(r11, r29))); // ld3 {v27.4S, v28.4S, v29.4S}, [x11], x29 - __ ld3(v16, v17, v18, __ T2S, Address(r10)); // ld3 {v16.2S, v17.2S, v18.2S}, [x10] - __ ld3r(v21, v22, v23, __ T8H, Address(r12)); // ld3r {v21.8H, v22.8H, v23.8H}, [x12] - __ ld3r(v4, v5, v6, __ T4S, Address(__ post(r29, 12))); // ld3r {v4.4S, v5.4S, v6.4S}, [x29], 12 - __ ld3r(v24, v25, v26, __ T1D, Address(__ post(r9, r19))); // ld3r {v24.1D, v25.1D, v26.1D}, [x9], x19 - __ ld4(v10, v11, v12, v13, __ T8H, Address(__ post(r3, 64))); // ld4 {v10.8H, v11.8H, v12.8H, v13.8H}, [x3], 64 - __ ld4(v27, v28, v29, v30, __ T8B, Address(__ post(r28, r9))); // ld4 {v27.8B, v28.8B, v29.8B, v30.8B}, [x28], x9 - __ ld4r(v21, v22, v23, v24, __ T8B, Address(r30)); // ld4r {v21.8B, v22.8B, v23.8B, v24.8B}, [x30] - __ ld4r(v23, v24, v25, v26, __ T4H, Address(__ post(r14, 8))); // ld4r {v23.4H, v24.4H, v25.4H, v26.4H}, [x14], 8 - __ ld4r(v4, v5, v6, v7, __ T2S, Address(__ post(r13, r20))); // ld4r {v4.2S, v5.2S, v6.2S, v7.2S}, [x13], x20 + __ ld1(v19, __ T8B, Address(r26)); // ld1 {v19.8B}, [x26] + __ ld1(v1, v2, __ T16B, Address(__ post(r14, 32))); // ld1 {v1.16B, v2.16B}, [x14], 32 + __ ld1(v29, v30, v31, __ T1D, Address(__ post(r24, r25))); // ld1 {v29.1D, v30.1D, v31.1D}, [x24], x25 + __ ld1(v20, v21, v22, v23, __ T8H, Address(__ post(r0, 64))); // ld1 {v20.8H, v21.8H, v22.8H, v23.8H}, [x0], 64 + __ ld1r(v25, __ T8B, Address(r27)); // ld1r {v25.8B}, [x27] + __ ld1r(v30, __ T4S, Address(__ post(r26, 4))); // ld1r {v30.4S}, [x26], 4 + __ ld1r(v9, __ T1D, Address(__ post(r21, r10))); // ld1r {v9.1D}, [x21], x10 + __ ld2(v2, v3, __ T2D, Address(r14)); // ld2 {v2.2D, v3.2D}, [x14] + __ ld2(v14, v15, __ T4H, Address(__ post(r18, 16))); // ld2 {v14.4H, v15.4H}, [x18], 16 + __ ld2r(v4, v5, __ T16B, Address(r0)); // ld2r {v4.16B, v5.16B}, [x0] + __ ld2r(v18, v19, __ T2S, Address(__ post(r1, 8))); // ld2r {v18.2S, v19.2S}, [x1], 8 + __ ld2r(v26, v27, __ T2D, Address(__ post(r0, r27))); // ld2r {v26.2D, v27.2D}, [x0], x27 + __ ld3(v7, v8, v9, __ T4S, Address(__ post(r22, r3))); // ld3 {v7.4S, v8.4S, v9.4S}, [x22], x3 + __ ld3(v5, v6, v7, __ T2S, Address(r21)); // ld3 {v5.2S, v6.2S, v7.2S}, [x21] + __ ld3r(v30, v31, v0, __ T8H, Address(r7)); // ld3r {v30.8H, v31.8H, v0.8H}, [x7] + __ ld3r(v7, v8, v9, __ T4S, Address(__ post(r23, 12))); // ld3r {v7.4S, v8.4S, v9.4S}, [x23], 12 + __ ld3r(v15, v16, v17, __ T1D, Address(__ post(r10, r6))); // ld3r {v15.1D, v16.1D, v17.1D}, [x10], x6 + __ ld4(v20, v21, v22, v23, __ T8H, Address(__ post(r25, 64))); // ld4 {v20.8H, v21.8H, v22.8H, v23.8H}, [x25], 64 + __ ld4(v5, v6, v7, v8, __ T8B, Address(__ post(r27, r24))); // ld4 {v5.8B, v6.8B, v7.8B, v8.8B}, [x27], x24 + __ ld4r(v5, v6, v7, v8, __ T8B, Address(r21)); // ld4r {v5.8B, v6.8B, v7.8B, v8.8B}, [x21] + __ ld4r(v19, v20, v21, v22, __ T4H, Address(__ post(r27, 8))); // ld4r {v19.4H, v20.4H, v21.4H, v22.4H}, [x27], 8 + __ ld4r(v6, v7, v8, v9, __ T2S, Address(__ post(r30, r22))); // ld4r {v6.2S, v7.2S, v8.2S, v9.2S}, [x30], x22 + +// SHA512SIMDOp + __ sha512h(v4, __ T2D, v23, v1); // sha512h q4, q23, v1.2D + __ sha512h2(v3, __ T2D, v12, v13); // sha512h2 q3, q12, v13.2D + __ sha512su0(v27, __ T2D, v6); // sha512su0 v27.2D, v6.2D + __ sha512su1(v9, __ T2D, v21, v10); // sha512su1 v9.2D, v21.2D, v10.2D // SpecialCases - __ ccmn(zr, zr, 3u, Assembler::LE); // ccmn xzr, xzr, #3, LE - __ ccmnw(zr, zr, 5u, Assembler::EQ); // ccmn wzr, wzr, #5, EQ - __ ccmp(zr, 1, 4u, Assembler::NE); // ccmp xzr, 1, #4, NE - __ ccmpw(zr, 2, 2, Assembler::GT); // ccmp wzr, 2, #2, GT - __ extr(zr, zr, zr, 0); // extr xzr, xzr, xzr, 0 - __ stlxp(r0, zr, zr, sp); // stlxp w0, xzr, xzr, [sp] - __ stlxpw(r2, zr, zr, r3); // stlxp w2, wzr, wzr, [x3] - __ stxp(r4, zr, zr, r5); // stxp w4, xzr, xzr, [x5] - __ stxpw(r6, zr, zr, sp); // stxp w6, wzr, wzr, [sp] - __ dup(v0, __ T16B, zr); // dup v0.16b, wzr - __ mov(v1, __ T1D, 0, zr); // mov v1.d[0], xzr - __ mov(v1, __ T2S, 1, zr); // mov v1.s[1], wzr - __ mov(v1, __ T4H, 2, zr); // mov v1.h[2], wzr - __ mov(v1, __ T8B, 3, zr); // mov v1.b[3], wzr - __ ld1(v31, v0, __ T2D, Address(__ post(r1, r0))); // ld1 {v31.2d, v0.2d}, [x1], x0 + __ ccmn(zr, zr, 3u, Assembler::LE); // ccmn xzr, xzr, #3, LE + __ ccmnw(zr, zr, 5u, Assembler::EQ); // ccmn wzr, wzr, #5, EQ + __ ccmp(zr, 1, 4u, Assembler::NE); // ccmp xzr, 1, #4, NE + __ ccmpw(zr, 2, 2, Assembler::GT); // ccmp wzr, 2, #2, GT + __ extr(zr, zr, zr, 0); // extr xzr, xzr, xzr, 0 + __ stlxp(r0, zr, zr, sp); // stlxp w0, xzr, xzr, [sp] + __ stlxpw(r2, zr, zr, r3); // stlxp w2, wzr, wzr, [x3] + __ stxp(r4, zr, zr, r5); // stxp w4, xzr, xzr, [x5] + __ stxpw(r6, zr, zr, sp); // stxp w6, wzr, wzr, [sp] + __ dup(v0, __ T16B, zr); // dup v0.16b, wzr + __ mov(v1, __ T1D, 0, zr); // mov v1.d[0], xzr + __ mov(v1, __ T2S, 1, zr); // mov v1.s[1], wzr + __ mov(v1, __ T4H, 2, zr); // mov v1.h[2], wzr + __ mov(v1, __ T8B, 3, zr); // mov v1.b[3], wzr + __ ld1(v31, v0, __ T2D, Address(__ post(r1, r0))); // ld1 {v31.2d, v0.2d}, [x1], x0 // FloatImmediateOp - __ fmovd(v0, 2.0); // fmov d0, #2.0 - __ fmovd(v0, 2.125); // fmov d0, #2.125 - __ fmovd(v0, 4.0); // fmov d0, #4.0 - __ fmovd(v0, 4.25); // fmov d0, #4.25 - __ fmovd(v0, 8.0); // fmov d0, #8.0 - __ fmovd(v0, 8.5); // fmov d0, #8.5 - __ fmovd(v0, 16.0); // fmov d0, #16.0 - __ fmovd(v0, 17.0); // fmov d0, #17.0 - __ fmovd(v0, 0.125); // fmov d0, #0.125 - __ fmovd(v0, 0.1328125); // fmov d0, #0.1328125 - __ fmovd(v0, 0.25); // fmov d0, #0.25 - __ fmovd(v0, 0.265625); // fmov d0, #0.265625 - __ fmovd(v0, 0.5); // fmov d0, #0.5 - __ fmovd(v0, 0.53125); // fmov d0, #0.53125 - __ fmovd(v0, 1.0); // fmov d0, #1.0 - __ fmovd(v0, 1.0625); // fmov d0, #1.0625 - __ fmovd(v0, -2.0); // fmov d0, #-2.0 - __ fmovd(v0, -2.125); // fmov d0, #-2.125 - __ fmovd(v0, -4.0); // fmov d0, #-4.0 - __ fmovd(v0, -4.25); // fmov d0, #-4.25 - __ fmovd(v0, -8.0); // fmov d0, #-8.0 - __ fmovd(v0, -8.5); // fmov d0, #-8.5 - __ fmovd(v0, -16.0); // fmov d0, #-16.0 - __ fmovd(v0, -17.0); // fmov d0, #-17.0 - __ fmovd(v0, -0.125); // fmov d0, #-0.125 - __ fmovd(v0, -0.1328125); // fmov d0, #-0.1328125 - __ fmovd(v0, -0.25); // fmov d0, #-0.25 - __ fmovd(v0, -0.265625); // fmov d0, #-0.265625 - __ fmovd(v0, -0.5); // fmov d0, #-0.5 - __ fmovd(v0, -0.53125); // fmov d0, #-0.53125 - __ fmovd(v0, -1.0); // fmov d0, #-1.0 - __ fmovd(v0, -1.0625); // fmov d0, #-1.0625 + __ fmovd(v0, 2.0); // fmov d0, #2.0 + __ fmovd(v0, 2.125); // fmov d0, #2.125 + __ fmovd(v0, 4.0); // fmov d0, #4.0 + __ fmovd(v0, 4.25); // fmov d0, #4.25 + __ fmovd(v0, 8.0); // fmov d0, #8.0 + __ fmovd(v0, 8.5); // fmov d0, #8.5 + __ fmovd(v0, 16.0); // fmov d0, #16.0 + __ fmovd(v0, 17.0); // fmov d0, #17.0 + __ fmovd(v0, 0.125); // fmov d0, #0.125 + __ fmovd(v0, 0.1328125); // fmov d0, #0.1328125 + __ fmovd(v0, 0.25); // fmov d0, #0.25 + __ fmovd(v0, 0.265625); // fmov d0, #0.265625 + __ fmovd(v0, 0.5); // fmov d0, #0.5 + __ fmovd(v0, 0.53125); // fmov d0, #0.53125 + __ fmovd(v0, 1.0); // fmov d0, #1.0 + __ fmovd(v0, 1.0625); // fmov d0, #1.0625 + __ fmovd(v0, -2.0); // fmov d0, #-2.0 + __ fmovd(v0, -2.125); // fmov d0, #-2.125 + __ fmovd(v0, -4.0); // fmov d0, #-4.0 + __ fmovd(v0, -4.25); // fmov d0, #-4.25 + __ fmovd(v0, -8.0); // fmov d0, #-8.0 + __ fmovd(v0, -8.5); // fmov d0, #-8.5 + __ fmovd(v0, -16.0); // fmov d0, #-16.0 + __ fmovd(v0, -17.0); // fmov d0, #-17.0 + __ fmovd(v0, -0.125); // fmov d0, #-0.125 + __ fmovd(v0, -0.1328125); // fmov d0, #-0.1328125 + __ fmovd(v0, -0.25); // fmov d0, #-0.25 + __ fmovd(v0, -0.265625); // fmov d0, #-0.265625 + __ fmovd(v0, -0.5); // fmov d0, #-0.5 + __ fmovd(v0, -0.53125); // fmov d0, #-0.53125 + __ fmovd(v0, -1.0); // fmov d0, #-1.0 + __ fmovd(v0, -1.0625); // fmov d0, #-1.0625 // LSEOp - __ swp(Assembler::xword, r21, r5, r24); // swp x21, x5, [x24] - __ ldadd(Assembler::xword, r13, r13, r15); // ldadd x13, x13, [x15] - __ ldbic(Assembler::xword, r22, r19, r26); // ldclr x22, x19, [x26] - __ ldeor(Assembler::xword, r25, r10, r26); // ldeor x25, x10, [x26] - __ ldorr(Assembler::xword, r5, r27, r15); // ldset x5, x27, [x15] - __ ldsmin(Assembler::xword, r19, r5, r11); // ldsmin x19, x5, [x11] - __ ldsmax(Assembler::xword, r26, r0, r4); // ldsmax x26, x0, [x4] - __ ldumin(Assembler::xword, r22, r23, r30); // ldumin x22, x23, [x30] - __ ldumax(Assembler::xword, r18, r28, r8); // ldumax x18, x28, [x8] + __ swp(Assembler::xword, r24, zr, r3); // swp x24, xzr, [x3] + __ ldadd(Assembler::xword, r5, r6, r5); // ldadd x5, x6, [x5] + __ ldbic(Assembler::xword, r25, r9, r12); // ldclr x25, x9, [x12] + __ ldeor(Assembler::xword, r9, r22, r9); // ldeor x9, x22, [x9] + __ ldorr(Assembler::xword, r14, r4, r1); // ldset x14, x4, [x1] + __ ldsmin(Assembler::xword, r23, r30, r29); // ldsmin x23, x30, [x29] + __ ldsmax(Assembler::xword, r21, r13, r26); // ldsmax x21, x13, [x26] + __ ldumin(Assembler::xword, r16, r9, r11); // ldumin x16, x9, [x11] + __ ldumax(Assembler::xword, r21, r17, r21); // ldumax x21, x17, [x21] // LSEOp - __ swpa(Assembler::xword, r13, r29, r27); // swpa x13, x29, [x27] - __ ldadda(Assembler::xword, r11, r5, r13); // ldadda x11, x5, [x13] - __ ldbica(Assembler::xword, r1, r24, r21); // ldclra x1, x24, [x21] - __ ldeora(Assembler::xword, r27, r17, r24); // ldeora x27, x17, [x24] - __ ldorra(Assembler::xword, r18, r30, r5); // ldseta x18, x30, [x5] - __ ldsmina(Assembler::xword, r7, r22, r25); // ldsmina x7, x22, [x25] - __ ldsmaxa(Assembler::xword, r4, r26, r19); // ldsmaxa x4, x26, [x19] - __ ldumina(Assembler::xword, r6, r30, r3); // ldumina x6, x30, [x3] - __ ldumaxa(Assembler::xword, r24, r23, r5); // ldumaxa x24, x23, [x5] + __ swpa(Assembler::xword, r25, r25, r9); // swpa x25, x25, [x9] + __ ldadda(Assembler::xword, r5, r25, r6); // ldadda x5, x25, [x6] + __ ldbica(Assembler::xword, r24, r14, r23); // ldclra x24, x14, [x23] + __ ldeora(Assembler::xword, r19, r24, r26); // ldeora x19, x24, [x26] + __ ldorra(Assembler::xword, r15, r23, r2); // ldseta x15, x23, [x2] + __ ldsmina(Assembler::xword, r6, r7, r7); // ldsmina x6, x7, [x7] + __ ldsmaxa(Assembler::xword, r30, r15, r14); // ldsmaxa x30, x15, [x14] + __ ldumina(Assembler::xword, zr, r7, r5); // ldumina xzr, x7, [x5] + __ ldumaxa(Assembler::xword, r20, r25, r1); // ldumaxa x20, x25, [x1] // LSEOp - __ swpal(Assembler::xword, r24, r18, r28); // swpal x24, x18, [x28] - __ ldaddal(Assembler::xword, r19, zr, r7); // ldaddal x19, xzr, [x7] - __ ldbical(Assembler::xword, r13, r6, r28); // ldclral x13, x6, [x28] - __ ldeoral(Assembler::xword, r8, r15, r21); // ldeoral x8, x15, [x21] - __ ldorral(Assembler::xword, r2, r13, r1); // ldsetal x2, x13, [x1] - __ ldsminal(Assembler::xword, r17, r29, r25); // ldsminal x17, x29, [x25] - __ ldsmaxal(Assembler::xword, r25, r18, r14); // ldsmaxal x25, x18, [x14] - __ lduminal(Assembler::xword, zr, r6, r27); // lduminal xzr, x6, [x27] - __ ldumaxal(Assembler::xword, r16, r5, r15); // ldumaxal x16, x5, [x15] + __ swpal(Assembler::xword, r16, r18, r17); // swpal x16, x18, [x17] + __ ldaddal(Assembler::xword, r0, r15, r11); // ldaddal x0, x15, [x11] + __ ldbical(Assembler::xword, r9, r17, r7); // ldclral x9, x17, [x7] + __ ldeoral(Assembler::xword, r1, r23, r23); // ldeoral x1, x23, [x23] + __ ldorral(Assembler::xword, r18, r1, r3); // ldsetal x18, x1, [x3] + __ ldsminal(Assembler::xword, r27, zr, r8); // ldsminal x27, xzr, [x8] + __ ldsmaxal(Assembler::xword, r9, r27, r11); // ldsmaxal x9, x27, [x11] + __ lduminal(Assembler::xword, r25, r3, r3); // lduminal x25, x3, [x3] + __ ldumaxal(Assembler::xword, r16, r24, r25); // ldumaxal x16, x24, [x25] // LSEOp - __ swpl(Assembler::xword, r11, r18, r3); // swpl x11, x18, [x3] - __ ldaddl(Assembler::xword, r26, r20, r2); // ldaddl x26, x20, [x2] - __ ldbicl(Assembler::xword, r11, r4, r11); // ldclrl x11, x4, [x11] - __ ldeorl(Assembler::xword, r30, r19, r23); // ldeorl x30, x19, [x23] - __ ldorrl(Assembler::xword, r3, r15, r14); // ldsetl x3, x15, [x14] - __ ldsminl(Assembler::xword, r30, r22, r20); // ldsminl x30, x22, [x20] - __ ldsmaxl(Assembler::xword, r7, r5, r24); // ldsmaxl x7, x5, [x24] - __ lduminl(Assembler::xword, r23, r16, r15); // lduminl x23, x16, [x15] - __ ldumaxl(Assembler::xword, r11, r19, r0); // ldumaxl x11, x19, [x0] + __ swpl(Assembler::xword, r6, r2, r29); // swpl x6, x2, [x29] + __ ldaddl(Assembler::xword, r23, r25, r12); // ldaddl x23, x25, [x12] + __ ldbicl(Assembler::xword, r9, r29, r23); // ldclrl x9, x29, [x23] + __ ldeorl(Assembler::xword, r29, r0, r2); // ldeorl x29, x0, [x2] + __ ldorrl(Assembler::xword, r19, r6, r10); // ldsetl x19, x6, [x10] + __ ldsminl(Assembler::xword, r17, r13, r25); // ldsminl x17, x13, [x25] + __ ldsmaxl(Assembler::xword, r1, r23, r25); // ldsmaxl x1, x23, [x25] + __ lduminl(Assembler::xword, r20, r26, r6); // lduminl x20, x26, [x6] + __ ldumaxl(Assembler::xword, r13, r22, r12); // ldumaxl x13, x22, [x12] // LSEOp - __ swp(Assembler::word, r28, r28, r1); // swp w28, w28, [x1] - __ ldadd(Assembler::word, r11, r21, r12); // ldadd w11, w21, [x12] - __ ldbic(Assembler::word, r29, r0, r18); // ldclr w29, w0, [x18] - __ ldeor(Assembler::word, r5, r0, r25); // ldeor w5, w0, [x25] - __ ldorr(Assembler::word, r14, r0, r26); // ldset w14, w0, [x26] - __ ldsmin(Assembler::word, r28, r18, r29); // ldsmin w28, w18, [x29] - __ ldsmax(Assembler::word, r15, r1, r29); // ldsmax w15, w1, [x29] - __ ldumin(Assembler::word, r8, r26, r28); // ldumin w8, w26, [x28] - __ ldumax(Assembler::word, r17, r14, r4); // ldumax w17, w14, [x4] + __ swp(Assembler::word, r23, r24, r27); // swp w23, w24, [x27] + __ ldadd(Assembler::word, r3, r7, r20); // ldadd w3, w7, [x20] + __ ldbic(Assembler::word, r10, r21, r23); // ldclr w10, w21, [x23] + __ ldeor(Assembler::word, r9, r26, r12); // ldeor w9, w26, [x12] + __ ldorr(Assembler::word, r26, r23, r27); // ldset w26, w23, [x27] + __ ldsmin(Assembler::word, r4, r14, r21); // ldsmin w4, w14, [x21] + __ ldsmax(Assembler::word, r10, r0, r9); // ldsmax w10, w0, [x9] + __ ldumin(Assembler::word, r9, r13, r6); // ldumin w9, w13, [x6] + __ ldumax(Assembler::word, r9, zr, r21); // ldumax w9, wzr, [x21] // LSEOp - __ swpa(Assembler::word, r24, r25, r1); // swpa w24, w25, [x1] - __ ldadda(Assembler::word, r10, r17, r17); // ldadda w10, w17, [x17] - __ ldbica(Assembler::word, r29, r20, r21); // ldclra w29, w20, [x21] - __ ldeora(Assembler::word, r29, r9, r12); // ldeora w29, w9, [x12] - __ ldorra(Assembler::word, r11, r6, r5); // ldseta w11, w6, [x5] - __ ldsmina(Assembler::word, r21, r7, r21); // ldsmina w21, w7, [x21] - __ ldsmaxa(Assembler::word, r10, r23, r12); // ldsmaxa w10, w23, [x12] - __ ldumina(Assembler::word, r21, r5, r10); // ldumina w21, w5, [x10] - __ ldumaxa(Assembler::word, r30, r20, r18); // ldumaxa w30, w20, [x18] + __ swpa(Assembler::word, r12, r28, r11); // swpa w12, w28, [x11] + __ ldadda(Assembler::word, r8, r0, r12); // ldadda w8, w0, [x12] + __ ldbica(Assembler::word, r29, r7, r1); // ldclra w29, w7, [x1] + __ ldeora(Assembler::word, r29, r27, r25); // ldeora w29, w27, [x25] + __ ldorra(Assembler::word, r27, r16, r8); // ldseta w27, w16, [x8] + __ ldsmina(Assembler::word, r13, r18, sp); // ldsmina w13, w18, [sp] + __ ldsmaxa(Assembler::word, r28, r0, r24); // ldsmaxa w28, w0, [x24] + __ ldumina(Assembler::word, r28, r28, r13); // ldumina w28, w28, [x13] + __ ldumaxa(Assembler::word, r14, r29, r2); // ldumaxa w14, w29, [x2] // LSEOp - __ swpal(Assembler::word, r13, r23, r5); // swpal w13, w23, [x5] - __ ldaddal(Assembler::word, r15, r24, r5); // ldaddal w15, w24, [x5] - __ ldbical(Assembler::word, r9, r10, r25); // ldclral w9, w10, [x25] - __ ldeoral(Assembler::word, r20, r17, r17); // ldeoral w20, w17, [x17] - __ ldorral(Assembler::word, r12, r18, r30); // ldsetal w12, w18, [x30] - __ ldsminal(Assembler::word, r3, r3, r25); // ldsminal w3, w3, [x25] - __ ldsmaxal(Assembler::word, r26, r25, r10); // ldsmaxal w26, w25, [x10] - __ lduminal(Assembler::word, r2, r11, sp); // lduminal w2, w11, [sp] - __ ldumaxal(Assembler::word, r7, r2, r5); // ldumaxal w7, w2, [x5] + __ swpal(Assembler::word, r8, r28, r17); // swpal w8, w28, [x17] + __ ldaddal(Assembler::word, r4, r10, r2); // ldaddal w4, w10, [x2] + __ ldbical(Assembler::word, r0, r28, r14); // ldclral w0, w28, [x14] + __ ldeoral(Assembler::word, r8, r12, r4); // ldeoral w8, w12, [x4] + __ ldorral(Assembler::word, r1, r22, r13); // ldsetal w1, w22, [x13] + __ ldsminal(Assembler::word, r24, r6, r20); // ldsminal w24, w6, [x20] + __ ldsmaxal(Assembler::word, r14, r14, r4); // ldsmaxal w14, w14, [x4] + __ lduminal(Assembler::word, r30, r2, r14); // lduminal w30, w2, [x14] + __ ldumaxal(Assembler::word, r2, r18, r22); // ldumaxal w2, w18, [x22] // LSEOp - __ swpl(Assembler::word, r0, r7, r20); // swpl w0, w7, [x20] - __ ldaddl(Assembler::word, r5, zr, r2); // ldaddl w5, wzr, [x2] - __ ldbicl(Assembler::word, r27, r25, r27); // ldclrl w27, w25, [x27] - __ ldeorl(Assembler::word, r30, r24, r26); // ldeorl w30, w24, [x26] - __ ldorrl(Assembler::word, r15, r2, r22); // ldsetl w15, w2, [x22] - __ ldsminl(Assembler::word, r0, r3, sp); // ldsminl w0, w3, [sp] - __ ldsmaxl(Assembler::word, r15, r20, r10); // ldsmaxl w15, w20, [x10] - __ lduminl(Assembler::word, r22, r21, r14); // lduminl w22, w21, [x14] - __ ldumaxl(Assembler::word, r6, r30, r2); // ldumaxl w6, w30, [x2] + __ swpl(Assembler::word, r25, r25, r17); // swpl w25, w25, [x17] + __ ldaddl(Assembler::word, r4, r19, r7); // ldaddl w4, w19, [x7] + __ ldbicl(Assembler::word, r19, r15, r11); // ldclrl w19, w15, [x11] + __ ldeorl(Assembler::word, r23, r29, r16); // ldeorl w23, w29, [x16] + __ ldorrl(Assembler::word, r27, r5, r26); // ldsetl w27, w5, [x26] + __ ldsminl(Assembler::word, zr, r27, r0); // ldsminl wzr, w27, [x0] + __ ldsmaxl(Assembler::word, r22, r6, r4); // ldsmaxl w22, w6, [x4] + __ lduminl(Assembler::word, r13, r30, r2); // lduminl w13, w30, [x2] + __ ldumaxl(Assembler::word, r19, r26, r12); // ldumaxl w19, w26, [x12] __ bind(forth); @@ -762,651 +768,656 @@ aarch64ops.o: file format elf64-littleaarch64 Disassembly of section .text: 0000000000000000 : - 0: 8b50798f add x15, x12, x16, lsr #30 - 4: cb4381e1 sub x1, x15, x3, lsr #32 - 8: ab05372d adds x13, x25, x5, lsl #13 - c: eb864796 subs x22, x28, x6, asr #17 - 10: 0b961920 add w0, w9, w22, asr #6 - 14: 4b195473 sub w19, w3, w25, lsl #21 - 18: 2b0b5264 adds w4, w19, w11, lsl #20 - 1c: 6b9300f8 subs w24, w7, w19, asr #0 - 20: 8a0bc0fe and x30, x7, x11, lsl #48 - 24: aa0f3118 orr x24, x8, x15, lsl #12 - 28: ca170531 eor x17, x9, x23, lsl #1 - 2c: ea44dd6e ands x14, x11, x4, lsr #55 - 30: 0a4c44f3 and w19, w7, w12, lsr #17 - 34: 2a8b7373 orr w19, w27, w11, asr #28 - 38: 4a567c7e eor w30, w3, w22, lsr #31 - 3c: 6a9c0353 ands w19, w26, w28, asr #0 - 40: 8a3accdd bic x29, x6, x26, lsl #51 - 44: aa318f7a orn x26, x27, x17, lsl #35 - 48: ca2e1495 eon x21, x4, x14, lsl #5 - 4c: eaa015e2 bics x2, x15, x0, asr #5 - 50: 0a2274e2 bic w2, w7, w2, lsl #29 - 54: 2a751598 orn w24, w12, w21, lsr #5 - 58: 4a3309fe eon w30, w15, w19, lsl #2 - 5c: 6ab172fe bics w30, w23, w17, asr #28 - 60: 110a5284 add w4, w20, #0x294 - 64: 310b1942 adds w2, w10, #0x2c6 - 68: 5103d353 sub w19, w26, #0xf4 - 6c: 710125bc subs w28, w13, #0x49 - 70: 910d7bc2 add x2, x30, #0x35e - 74: b108fa1b adds x27, x16, #0x23e - 78: d1093536 sub x22, x9, #0x24d - 7c: f10ae824 subs x4, x1, #0x2ba - 80: 120e667c and w28, w19, #0xfffc0fff - 84: 321f6cbb orr w27, w5, #0x1ffffffe - 88: 520f6a9e eor w30, w20, #0xfffe0fff - 8c: 72136f56 ands w22, w26, #0xffffe1ff - 90: 927e4ce5 and x5, x7, #0x3ffffc - 94: b278b4ed orr x13, x7, #0x3fffffffffff00 - 98: d24c6527 eor x7, x9, #0xfff0000000003fff - 9c: f2485803 ands x3, x0, #0xff00000000007fff - a0: 14000000 b a0 - a4: 17ffffd7 b 0 - a8: 140001ee b 860 - ac: 94000000 bl ac - b0: 97ffffd4 bl 0 - b4: 940001eb bl 860 - b8: 34000010 cbz w16, b8 - bc: 34fffa30 cbz w16, 0 - c0: 34003d10 cbz w16, 860 - c4: 35000013 cbnz w19, c4 - c8: 35fff9d3 cbnz w19, 0 - cc: 35003cb3 cbnz w19, 860 - d0: b4000005 cbz x5, d0 - d4: b4fff965 cbz x5, 0 - d8: b4003c45 cbz x5, 860 - dc: b5000004 cbnz x4, dc - e0: b5fff904 cbnz x4, 0 - e4: b5003be4 cbnz x4, 860 - e8: 1000001b adr x27, e8 - ec: 10fff8bb adr x27, 0 - f0: 10003b9b adr x27, 860 - f4: 90000010 adrp x16, 0 - f8: 3640001c tbz w28, #8, f8 - fc: 3647f83c tbz w28, #8, 0 - 100: 36403b1c tbz w28, #8, 860 - 104: 37080001 tbnz w1, #1, 104 - 108: 370ff7c1 tbnz w1, #1, 0 - 10c: 37083aa1 tbnz w1, #1, 860 - 110: 12a437f4 mov w20, #0xde40ffff // #-566165505 - 114: 528c9d67 mov w7, #0x64eb // #25835 - 118: 72838bb1 movk w17, #0x1c5d - 11c: 92c1062e mov x14, #0xfffff7ceffffffff // #-9006546419713 - 120: d287da49 mov x9, #0x3ed2 // #16082 - 124: f2a6d153 movk x19, #0x368a, lsl #16 - 128: 93465ac9 sbfx x9, x22, #6, #17 - 12c: 330b0013 bfi w19, w0, #21, #1 - 130: 530b4e6a ubfx w10, w19, #11, #9 - 134: 934545e4 sbfx x4, x15, #5, #13 - 138: b35370a3 bfxil x3, x5, #19, #10 - 13c: d3510b8c ubfiz x12, x28, #47, #3 - 140: 13960c0f extr w15, w0, w22, #3 - 144: 93ceddc6 ror x6, x14, #55 - 148: 54000000 b.eq 148 // b.none - 14c: 54fff5a0 b.eq 0 // b.none - 150: 54003880 b.eq 860 // b.none - 154: 54000001 b.ne 154 // b.any - 158: 54fff541 b.ne 0 // b.any - 15c: 54003821 b.ne 860 // b.any - 160: 54000002 b.cs 160 // b.hs, b.nlast - 164: 54fff4e2 b.cs 0 // b.hs, b.nlast - 168: 540037c2 b.cs 860 // b.hs, b.nlast - 16c: 54000002 b.cs 16c // b.hs, b.nlast - 170: 54fff482 b.cs 0 // b.hs, b.nlast - 174: 54003762 b.cs 860 // b.hs, b.nlast - 178: 54000003 b.cc 178 // b.lo, b.ul, b.last - 17c: 54fff423 b.cc 0 // b.lo, b.ul, b.last - 180: 54003703 b.cc 860 // b.lo, b.ul, b.last - 184: 54000003 b.cc 184 // b.lo, b.ul, b.last - 188: 54fff3c3 b.cc 0 // b.lo, b.ul, b.last - 18c: 540036a3 b.cc 860 // b.lo, b.ul, b.last - 190: 54000004 b.mi 190 // b.first - 194: 54fff364 b.mi 0 // b.first - 198: 54003644 b.mi 860 // b.first - 19c: 54000005 b.pl 19c // b.nfrst - 1a0: 54fff305 b.pl 0 // b.nfrst - 1a4: 540035e5 b.pl 860 // b.nfrst - 1a8: 54000006 b.vs 1a8 - 1ac: 54fff2a6 b.vs 0 - 1b0: 54003586 b.vs 860 - 1b4: 54000007 b.vc 1b4 - 1b8: 54fff247 b.vc 0 - 1bc: 54003527 b.vc 860 - 1c0: 54000008 b.hi 1c0 // b.pmore - 1c4: 54fff1e8 b.hi 0 // b.pmore - 1c8: 540034c8 b.hi 860 // b.pmore - 1cc: 54000009 b.ls 1cc // b.plast - 1d0: 54fff189 b.ls 0 // b.plast - 1d4: 54003469 b.ls 860 // b.plast - 1d8: 5400000a b.ge 1d8 // b.tcont - 1dc: 54fff12a b.ge 0 // b.tcont - 1e0: 5400340a b.ge 860 // b.tcont - 1e4: 5400000b b.lt 1e4 // b.tstop - 1e8: 54fff0cb b.lt 0 // b.tstop - 1ec: 540033ab b.lt 860 // b.tstop - 1f0: 5400000c b.gt 1f0 - 1f4: 54fff06c b.gt 0 - 1f8: 5400334c b.gt 860 - 1fc: 5400000d b.le 1fc - 200: 54fff00d b.le 0 - 204: 540032ed b.le 860 - 208: 5400000e b.al 208 - 20c: 54ffefae b.al 0 - 210: 5400328e b.al 860 - 214: 5400000f b.nv 214 - 218: 54ffef4f b.nv 0 - 21c: 5400322f b.nv 860 - 220: d40ac601 svc #0x5630 - 224: d40042a2 hvc #0x215 - 228: d404dac3 smc #0x26d6 - 22c: d4224d40 brk #0x126a - 230: d44219c0 hlt #0x10ce - 234: d503201f nop - 238: d69f03e0 eret - 23c: d6bf03e0 drps - 240: d5033fdf isb - 244: d503339f dsb osh - 248: d50335bf dmb nshld - 24c: d61f0280 br x20 - 250: d63f0040 blr x2 - 254: c8127c17 stxr w18, x23, [x0] - 258: c81efec5 stlxr w30, x5, [x22] - 25c: c85f7d05 ldxr x5, [x8] - 260: c85ffe14 ldaxr x20, [x16] - 264: c89ffd66 stlr x6, [x11] - 268: c8dfff66 ldar x6, [x27] - 26c: 880a7cb1 stxr w10, w17, [x5] - 270: 8816fd89 stlxr w22, w9, [x12] - 274: 885f7d1b ldxr w27, [x8] - 278: 885ffc57 ldaxr w23, [x2] - 27c: 889fffba stlr w26, [x29] - 280: 88dffd4d ldar w13, [x10] - 284: 48197f7c stxrh w25, w28, [x27] - 288: 481dfd96 stlxrh w29, w22, [x12] - 28c: 485f7f96 ldxrh w22, [x28] - 290: 485fffc3 ldaxrh w3, [x30] - 294: 489ffdf8 stlrh w24, [x15] - 298: 48dfff5b ldarh w27, [x26] - 29c: 080b7e6a stxrb w11, w10, [x19] - 2a0: 0817fedb stlxrb w23, w27, [x22] - 2a4: 085f7e18 ldxrb w24, [x16] - 2a8: 085ffc38 ldaxrb w24, [x1] - 2ac: 089fffa5 stlrb w5, [x29] - 2b0: 08dffe18 ldarb w24, [x16] - 2b4: c87f6239 ldxp x25, x24, [x17] - 2b8: c87fb276 ldaxp x22, x12, [x19] - 2bc: c820573a stxp w0, x26, x21, [x25] - 2c0: c821aca6 stlxp w1, x6, x11, [x5] - 2c4: 887f388d ldxp w13, w14, [x4] - 2c8: 887f88d1 ldaxp w17, w2, [x6] - 2cc: 882f2643 stxp w15, w3, w9, [x18] - 2d0: 88329131 stlxp w18, w17, w4, [x9] - 2d4: f81cf2b7 stur x23, [x21, #-49] - 2d8: b803f055 stur w21, [x2, #63] - 2dc: 39002f9b strb w27, [x28, #11] - 2e0: 781f31fd sturh w29, [x15, #-13] - 2e4: f85d33ce ldur x14, [x30, #-45] - 2e8: b843539d ldur w29, [x28, #53] - 2ec: 39401f54 ldrb w20, [x26, #7] - 2f0: 785ce059 ldurh w25, [x2, #-50] - 2f4: 389f1143 ldursb x3, [x10, #-15] - 2f8: 788131ee ldursh x14, [x15, #19] - 2fc: 78dfb17d ldursh w29, [x11, #-5] - 300: b89b90af ldursw x15, [x5, #-71] - 304: fc403193 ldur d19, [x12, #3] - 308: bc42a36c ldur s12, [x27, #42] - 30c: fc07d396 stur d22, [x28, #125] - 310: bc1ec1f8 stur s24, [x15, #-20] - 314: f81e8f88 str x8, [x28, #-24]! - 318: b8025de6 str w6, [x15, #37]! - 31c: 38007c27 strb w7, [x1, #7]! - 320: 7801ee20 strh w0, [x17, #30]! - 324: f8454fb9 ldr x25, [x29, #84]! - 328: b85cce9a ldr w26, [x20, #-52]! - 32c: 385e7fba ldrb w26, [x29, #-25]! - 330: 7841af24 ldrh w4, [x25, #26]! - 334: 389ebd1c ldrsb x28, [x8, #-21]! - 338: 789fadd1 ldrsh x17, [x14, #-6]! - 33c: 78c0aefc ldrsh w28, [x23, #10]! - 340: b89c0f7e ldrsw x30, [x27, #-64]! - 344: fc50efd4 ldr d20, [x30, #-242]! - 348: bc414f71 ldr s17, [x27, #20]! - 34c: fc011c67 str d7, [x3, #17]! - 350: bc1f0d6d str s13, [x11, #-16]! - 354: f81c3526 str x6, [x9], #-61 - 358: b81e34b0 str w16, [x5], #-29 - 35c: 3800f7bd strb w29, [x29], #15 - 360: 78012684 strh w4, [x20], #18 - 364: f842e653 ldr x19, [x18], #46 - 368: b8417456 ldr w22, [x2], #23 - 36c: 385e2467 ldrb w7, [x3], #-30 - 370: 785e358b ldrh w11, [x12], #-29 - 374: 389e34c8 ldrsb x8, [x6], #-29 - 378: 788046f8 ldrsh x24, [x23], #4 - 37c: 78c00611 ldrsh w17, [x16], #0 - 380: b89f8680 ldrsw x0, [x20], #-8 - 384: fc582454 ldr d20, [x2], #-126 - 388: bc5987d3 ldr s19, [x30], #-104 - 38c: fc076624 str d4, [x17], #118 - 390: bc190675 str s21, [x19], #-112 - 394: f833785a str x26, [x2, x19, lsl #3] - 398: b82fd809 str w9, [x0, w15, sxtw #2] - 39c: 3821799a strb w26, [x12, x1, lsl #0] - 3a0: 782a7975 strh w21, [x11, x10, lsl #1] - 3a4: f870eaf0 ldr x16, [x23, x16, sxtx] - 3a8: b871d96a ldr w10, [x11, w17, sxtw #2] - 3ac: 386b7aed ldrb w13, [x23, x11, lsl #0] - 3b0: 7875689b ldrh w27, [x4, x21] - 3b4: 38afd91a ldrsb x26, [x8, w15, sxtw #0] - 3b8: 78a2c955 ldrsh x21, [x10, w2, sxtw] - 3bc: 78ee6bc8 ldrsh w8, [x30, x14] - 3c0: b8b4f9dd ldrsw x29, [x14, x20, sxtx #2] - 3c4: fc76eb7e ldr d30, [x27, x22, sxtx] - 3c8: bc76692d ldr s13, [x9, x22] - 3cc: fc31db28 str d8, [x25, w17, sxtw #3] - 3d0: bc255b01 str s1, [x24, w5, uxtw #2] - 3d4: f91c52aa str x10, [x21, #14496] - 3d8: b91c3fb2 str w18, [x29, #7228] - 3dc: 391f8877 strb w23, [x3, #2018] - 3e0: 791ac97c strh w28, [x11, #3428] - 3e4: f95c1758 ldr x24, [x26, #14376] - 3e8: b95b3c55 ldr w21, [x2, #6972] - 3ec: 395ce0a4 ldrb w4, [x5, #1848] - 3f0: 795851ce ldrh w14, [x14, #3112] - 3f4: 399e9f64 ldrsb x4, [x27, #1959] - 3f8: 79993764 ldrsh x4, [x27, #3226] - 3fc: 79d9af8a ldrsh w10, [x28, #3286] - 400: b99eea2a ldrsw x10, [x17, #7912] - 404: fd5a2f8d ldr d13, [x28, #13400] - 408: bd5dac78 ldr s24, [x3, #7596] - 40c: fd1e0182 str d2, [x12, #15360] - 410: bd195c31 str s17, [x1, #6492] - 414: 58000010 ldr x16, 414 - 418: 1800000d ldr w13, 418 - 41c: f8981240 prfum pldl1keep, [x18, #-127] - 420: d8ffdf00 prfm pldl1keep, 0 - 424: f8a27a80 prfm pldl1keep, [x20, x2, lsl #3] - 428: f99af920 prfm pldl1keep, [x9, #13808] - 42c: 1a0202e8 adc w8, w23, w2 - 430: 3a130078 adcs w24, w3, w19 - 434: 5a1d0316 sbc w22, w24, w29 - 438: 7a03036c sbcs w12, w27, w3 - 43c: 9a0102eb adc x11, x23, x1 - 440: ba1700bd adcs x29, x5, x23 - 444: da0c0329 sbc x9, x25, x12 - 448: fa16000c sbcs x12, x0, x22 - 44c: 0b23459a add w26, w12, w3, uxtw #1 - 450: 2b328a14 adds w20, w16, w18, sxtb #2 - 454: cb274bde sub x30, x30, w7, uxtw #2 - 458: 6b222eab subs w11, w21, w2, uxth #3 - 45c: 8b214b42 add x2, x26, w1, uxtw #2 - 460: ab34a7b2 adds x18, x29, w20, sxth #1 - 464: cb24520e sub x14, x16, w4, uxtw #4 - 468: eb378e20 subs x0, x17, w23, sxtb #3 - 46c: 3a565283 ccmn w20, w22, #0x3, pl // pl = nfrst - 470: 7a420321 ccmp w25, w2, #0x1, eq // eq = none - 474: ba58c247 ccmn x18, x24, #0x7, gt - 478: fa4d5106 ccmp x8, x13, #0x6, pl // pl = nfrst - 47c: 3a426924 ccmn w9, #0x2, #0x4, vs - 480: 7a5b0847 ccmp w2, #0x1b, #0x7, eq // eq = none - 484: ba413a02 ccmn x16, #0x1, #0x2, cc // cc = lo, ul, last - 488: fa5fba23 ccmp x17, #0x1f, #0x3, lt // lt = tstop - 48c: 1a979377 csel w23, w27, w23, ls // ls = plast - 490: 1a86640a csinc w10, w0, w6, vs - 494: 5a89300b csinv w11, w0, w9, cc // cc = lo, ul, last - 498: 5a923771 csneg w17, w27, w18, cc // cc = lo, ul, last - 49c: 9a8b720c csel x12, x16, x11, vc - 4a0: 9a868786 csinc x6, x28, x6, hi // hi = pmore - 4a4: da9a736d csinv x13, x27, x26, vc - 4a8: da9256dd csneg x29, x22, x18, pl // pl = nfrst - 4ac: 5ac0026c rbit w12, w19 - 4b0: 5ac00657 rev16 w23, w18 - 4b4: 5ac00b89 rev w9, w28 - 4b8: 5ac01262 clz w2, w19 - 4bc: 5ac017b9 cls w25, w29 - 4c0: dac002e4 rbit x4, x23 - 4c4: dac0065d rev16 x29, x18 - 4c8: dac00907 rev32 x7, x8 - 4cc: dac00e2d rev x13, x17 - 4d0: dac01011 clz x17, x0 - 4d4: dac01752 cls x18, x26 - 4d8: 1ad0098b udiv w11, w12, w16 - 4dc: 1ac70d24 sdiv w4, w9, w7 - 4e0: 1ad020ec lsl w12, w7, w16 - 4e4: 1ad72613 lsr w19, w16, w23 - 4e8: 1ac62887 asr w7, w4, w6 - 4ec: 1ad72e95 ror w21, w20, w23 - 4f0: 9adc0990 udiv x16, x12, x28 - 4f4: 9acd0d84 sdiv x4, x12, x13 - 4f8: 9ac721a9 lsl x9, x13, x7 - 4fc: 9acf277c lsr x28, x27, x15 - 500: 9ace2bd4 asr x20, x30, x14 - 504: 9ade2e4e ror x14, x18, x30 - 508: 9bc77d63 umulh x3, x11, x7 - 50c: 9b587e97 smulh x23, x20, x24 - 510: 1b1524a2 madd w2, w5, w21, w9 - 514: 1b04a318 msub w24, w24, w4, w8 - 518: 9b0f4d8b madd x11, x12, x15, x19 - 51c: 9b0ce73d msub x29, x25, x12, x25 - 520: 9b2c5971 smaddl x17, w11, w12, x22 - 524: 9b34c87c smsubl x28, w3, w20, x18 - 528: 9bbc6887 umaddl x7, w4, w28, x26 - 52c: 9bb19556 umsubl x22, w10, w17, x5 - 530: 1e310871 fmul s17, s3, s17 - 534: 1e261a2b fdiv s11, s17, s6 - 538: 1e2928fd fadd s29, s7, s9 - 53c: 1e333987 fsub s7, s12, s19 - 540: 1e230ae0 fmul s0, s23, s3 - 544: 1e75087a fmul d26, d3, d21 - 548: 1e651a60 fdiv d0, d19, d5 - 54c: 1e692b40 fadd d0, d26, d9 - 550: 1e753ab9 fsub d25, d21, d21 - 554: 1e7309b0 fmul d16, d13, d19 - 558: 1f00425d fmadd s29, s18, s0, s16 - 55c: 1f1d95b7 fmsub s23, s13, s29, s5 - 560: 1f2a38e9 fnmadd s9, s7, s10, s14 - 564: 1f2f5f99 fnmadd s25, s28, s15, s23 - 568: 1f5545a6 fmadd d6, d13, d21, d17 - 56c: 1f429ea3 fmsub d3, d21, d2, d7 - 570: 1f65472a fnmadd d10, d25, d5, d17 - 574: 1f7449ce fnmadd d14, d14, d20, d18 - 578: 1e20404f fmov s15, s2 - 57c: 1e20c0f2 fabs s18, s7 - 580: 1e2140c3 fneg s3, s6 - 584: 1e21c02c fsqrt s12, s1 - 588: 1e22c009 fcvt d9, s0 - 58c: 1e6040a4 fmov d4, d5 - 590: 1e60c1e3 fabs d3, d15 - 594: 1e614331 fneg d17, d25 - 598: 1e61c30c fsqrt d12, d24 - 59c: 1e6240b5 fcvt s21, d5 - 5a0: 1e3802a4 fcvtzs w4, s21 - 5a4: 9e38007b fcvtzs x27, s3 - 5a8: 1e78011d fcvtzs w29, d8 - 5ac: 9e7802a9 fcvtzs x9, d21 - 5b0: 1e2203b4 scvtf s20, w29 - 5b4: 9e220107 scvtf s7, x8 - 5b8: 1e6202ac scvtf d12, w21 - 5bc: 9e6202b0 scvtf d16, x21 - 5c0: 1e2600b2 fmov w18, s5 - 5c4: 9e660119 fmov x25, d8 - 5c8: 1e270352 fmov s18, w26 - 5cc: 9e670160 fmov d0, x11 - 5d0: 1e262200 fcmp s16, s6 - 5d4: 1e7d2200 fcmp d16, d29 - 5d8: 1e2023c8 fcmp s30, #0.0 - 5dc: 1e602128 fcmp d9, #0.0 - 5e0: 293e119b stp w27, w4, [x12, #-16] - 5e4: 294a2543 ldp w3, w9, [x10, #80] - 5e8: 69480c70 ldpsw x16, x3, [x3, #64] - 5ec: a934726a stp x10, x28, [x19, #-192] - 5f0: a97448f3 ldp x19, x18, [x7, #-192] - 5f4: 298243ca stp w10, w16, [x30, #16]! - 5f8: 29e21242 ldp w2, w4, [x18, #-240]! - 5fc: 69c64db8 ldpsw x24, x19, [x13, #48]! - 600: a9800311 stp x17, x0, [x24, #0]! - 604: a9f4686e ldp x14, x26, [x3, #-192]! - 608: 288a0416 stp w22, w1, [x0], #80 - 60c: 28fe2812 ldp w18, w10, [x0], #-16 - 610: 68fe62d8 .inst 0x68fe62d8 ; undefined - 614: a885308c stp x12, x12, [x4], #80 - 618: a8f12664 ldp x4, x9, [x19], #-240 - 61c: 282468d2 stnp w18, w26, [x6, #-224] - 620: 284e5035 ldnp w21, w20, [x1, #112] - 624: a8327699 stnp x25, x29, [x20, #-224] - 628: a84716e1 ldnp x1, x5, [x23, #112] - 62c: 0c407284 ld1 {v4.8b}, [x20] - 630: 4cdfa158 ld1 {v24.16b, v25.16b}, [x10], #32 - 634: 0ccf6cd8 ld1 {v24.1d-v26.1d}, [x6], x15 - 638: 4cdf2483 ld1 {v3.8h-v6.8h}, [x4], #64 - 63c: 0d40c0c2 ld1r {v2.8b}, [x6] - 640: 4ddfc9cd ld1r {v13.4s}, [x14], #4 - 644: 0dd8ceaf ld1r {v15.1d}, [x21], x24 - 648: 4c408ea9 ld2 {v9.2d, v10.2d}, [x21] - 64c: 0cdf86bd ld2 {v29.4h, v30.4h}, [x21], #16 - 650: 4d60c1c8 ld2r {v8.16b, v9.16b}, [x14] - 654: 0dffca87 ld2r {v7.2s, v8.2s}, [x20], #8 - 658: 4de3cc7c ld2r {v28.2d, v29.2d}, [x3], x3 - 65c: 4cdd497b ld3 {v27.4s-v29.4s}, [x11], x29 - 660: 0c404950 ld3 {v16.2s-v18.2s}, [x10] - 664: 4d40e595 ld3r {v21.8h-v23.8h}, [x12] - 668: 4ddfeba4 ld3r {v4.4s-v6.4s}, [x29], #12 - 66c: 0dd3ed38 ld3r {v24.1d-v26.1d}, [x9], x19 - 670: 4cdf046a ld4 {v10.8h-v13.8h}, [x3], #64 - 674: 0cc9039b ld4 {v27.8b-v30.8b}, [x28], x9 - 678: 0d60e3d5 ld4r {v21.8b-v24.8b}, [x30] - 67c: 0dffe5d7 ld4r {v23.4h-v26.4h}, [x14], #8 - 680: 0df4e9a4 ld4r {v4.2s-v7.2s}, [x13], x20 - 684: ba5fd3e3 ccmn xzr, xzr, #0x3, le - 688: 3a5f03e5 ccmn wzr, wzr, #0x5, eq // eq = none - 68c: fa411be4 ccmp xzr, #0x1, #0x4, ne // ne = any - 690: 7a42cbe2 ccmp wzr, #0x2, #0x2, gt - 694: 93df03ff ror xzr, xzr, #0 - 698: c820ffff stlxp w0, xzr, xzr, [sp] - 69c: 8822fc7f stlxp w2, wzr, wzr, [x3] - 6a0: c8247cbf stxp w4, xzr, xzr, [x5] - 6a4: 88267fff stxp w6, wzr, wzr, [sp] - 6a8: 4e010fe0 dup v0.16b, wzr - 6ac: 4e081fe1 mov v1.d[0], xzr - 6b0: 4e0c1fe1 mov v1.s[1], wzr - 6b4: 4e0a1fe1 mov v1.h[2], wzr - 6b8: 4e071fe1 mov v1.b[3], wzr - 6bc: 4cc0ac3f ld1 {v31.2d, v0.2d}, [x1], x0 - 6c0: 1e601000 fmov d0, #2.000000000000000000e+00 - 6c4: 1e603000 fmov d0, #2.125000000000000000e+00 - 6c8: 1e621000 fmov d0, #4.000000000000000000e+00 - 6cc: 1e623000 fmov d0, #4.250000000000000000e+00 - 6d0: 1e641000 fmov d0, #8.000000000000000000e+00 - 6d4: 1e643000 fmov d0, #8.500000000000000000e+00 - 6d8: 1e661000 fmov d0, #1.600000000000000000e+01 - 6dc: 1e663000 fmov d0, #1.700000000000000000e+01 - 6e0: 1e681000 fmov d0, #1.250000000000000000e-01 - 6e4: 1e683000 fmov d0, #1.328125000000000000e-01 - 6e8: 1e6a1000 fmov d0, #2.500000000000000000e-01 - 6ec: 1e6a3000 fmov d0, #2.656250000000000000e-01 - 6f0: 1e6c1000 fmov d0, #5.000000000000000000e-01 - 6f4: 1e6c3000 fmov d0, #5.312500000000000000e-01 - 6f8: 1e6e1000 fmov d0, #1.000000000000000000e+00 - 6fc: 1e6e3000 fmov d0, #1.062500000000000000e+00 - 700: 1e701000 fmov d0, #-2.000000000000000000e+00 - 704: 1e703000 fmov d0, #-2.125000000000000000e+00 - 708: 1e721000 fmov d0, #-4.000000000000000000e+00 - 70c: 1e723000 fmov d0, #-4.250000000000000000e+00 - 710: 1e741000 fmov d0, #-8.000000000000000000e+00 - 714: 1e743000 fmov d0, #-8.500000000000000000e+00 - 718: 1e761000 fmov d0, #-1.600000000000000000e+01 - 71c: 1e763000 fmov d0, #-1.700000000000000000e+01 - 720: 1e781000 fmov d0, #-1.250000000000000000e-01 - 724: 1e783000 fmov d0, #-1.328125000000000000e-01 - 728: 1e7a1000 fmov d0, #-2.500000000000000000e-01 - 72c: 1e7a3000 fmov d0, #-2.656250000000000000e-01 - 730: 1e7c1000 fmov d0, #-5.000000000000000000e-01 - 734: 1e7c3000 fmov d0, #-5.312500000000000000e-01 - 738: 1e7e1000 fmov d0, #-1.000000000000000000e+00 - 73c: 1e7e3000 fmov d0, #-1.062500000000000000e+00 - 740: f8358305 swp x21, x5, [x24] - 744: f82d01ed ldadd x13, x13, [x15] - 748: f8361353 ldclr x22, x19, [x26] - 74c: f839234a ldeor x25, x10, [x26] - 750: f82531fb ldset x5, x27, [x15] - 754: f8335165 ldsmin x19, x5, [x11] - 758: f83a4080 ldsmax x26, x0, [x4] - 75c: f83673d7 ldumin x22, x23, [x30] - 760: f832611c ldumax x18, x28, [x8] - 764: f8ad837d swpa x13, x29, [x27] - 768: f8ab01a5 ldadda x11, x5, [x13] - 76c: f8a112b8 ldclra x1, x24, [x21] - 770: f8bb2311 ldeora x27, x17, [x24] - 774: f8b230be ldseta x18, x30, [x5] - 778: f8a75336 ldsmina x7, x22, [x25] - 77c: f8a4427a ldsmaxa x4, x26, [x19] - 780: f8a6707e ldumina x6, x30, [x3] - 784: f8b860b7 ldumaxa x24, x23, [x5] - 788: f8f88392 swpal x24, x18, [x28] - 78c: f8f300ff ldaddal x19, xzr, [x7] - 790: f8ed1386 ldclral x13, x6, [x28] - 794: f8e822af ldeoral x8, x15, [x21] - 798: f8e2302d ldsetal x2, x13, [x1] - 79c: f8f1533d ldsminal x17, x29, [x25] - 7a0: f8f941d2 ldsmaxal x25, x18, [x14] - 7a4: f8ff7366 lduminal xzr, x6, [x27] - 7a8: f8f061e5 ldumaxal x16, x5, [x15] - 7ac: f86b8072 swpl x11, x18, [x3] - 7b0: f87a0054 ldaddl x26, x20, [x2] - 7b4: f86b1164 ldclrl x11, x4, [x11] - 7b8: f87e22f3 ldeorl x30, x19, [x23] - 7bc: f86331cf ldsetl x3, x15, [x14] - 7c0: f87e5296 ldsminl x30, x22, [x20] - 7c4: f8674305 ldsmaxl x7, x5, [x24] - 7c8: f87771f0 lduminl x23, x16, [x15] - 7cc: f86b6013 ldumaxl x11, x19, [x0] - 7d0: b83c803c swp w28, w28, [x1] - 7d4: b82b0195 ldadd w11, w21, [x12] - 7d8: b83d1240 ldclr w29, w0, [x18] - 7dc: b8252320 ldeor w5, w0, [x25] - 7e0: b82e3340 ldset w14, w0, [x26] - 7e4: b83c53b2 ldsmin w28, w18, [x29] - 7e8: b82f43a1 ldsmax w15, w1, [x29] - 7ec: b828739a ldumin w8, w26, [x28] - 7f0: b831608e ldumax w17, w14, [x4] - 7f4: b8b88039 swpa w24, w25, [x1] - 7f8: b8aa0231 ldadda w10, w17, [x17] - 7fc: b8bd12b4 ldclra w29, w20, [x21] - 800: b8bd2189 ldeora w29, w9, [x12] - 804: b8ab30a6 ldseta w11, w6, [x5] - 808: b8b552a7 ldsmina w21, w7, [x21] - 80c: b8aa4197 ldsmaxa w10, w23, [x12] - 810: b8b57145 ldumina w21, w5, [x10] - 814: b8be6254 ldumaxa w30, w20, [x18] - 818: b8ed80b7 swpal w13, w23, [x5] - 81c: b8ef00b8 ldaddal w15, w24, [x5] - 820: b8e9132a ldclral w9, w10, [x25] - 824: b8f42231 ldeoral w20, w17, [x17] - 828: b8ec33d2 ldsetal w12, w18, [x30] - 82c: b8e35323 ldsminal w3, w3, [x25] - 830: b8fa4159 ldsmaxal w26, w25, [x10] - 834: b8e273eb lduminal w2, w11, [sp] - 838: b8e760a2 ldumaxal w7, w2, [x5] - 83c: b8608287 swpl w0, w7, [x20] - 840: b865005f staddl w5, [x2] - 844: b87b1379 ldclrl w27, w25, [x27] - 848: b87e2358 ldeorl w30, w24, [x26] - 84c: b86f32c2 ldsetl w15, w2, [x22] - 850: b86053e3 ldsminl w0, w3, [sp] - 854: b86f4154 ldsmaxl w15, w20, [x10] - 858: b87671d5 lduminl w22, w21, [x14] - 85c: b866605e ldumaxl w6, w30, [x2] + 0: 8b402464 add x4, x3, x0, lsr #9 + 4: cb0447a8 sub x8, x29, x4, lsl #17 + 8: ab174767 adds x7, x27, x23, lsl #17 + c: eb49a5e6 subs x6, x15, x9, lsr #41 + 10: 0b905c6c add w12, w3, w16, asr #23 + 14: 4b5d7f08 sub w8, w24, w29, lsr #31 + 18: 2b0f1f87 adds w7, w28, w15, lsl #7 + 1c: 6b5c35fa subs w26, w15, w28, lsr #13 + 20: 8a827101 and x1, x8, x2, asr #28 + 24: aa4c2b73 orr x19, x27, x12, lsr #10 + 28: ca4aed64 eor x4, x11, x10, lsr #59 + 2c: ea027225 ands x5, x17, x2, lsl #28 + 30: 0a4c35fc and w28, w15, w12, lsr #13 + 34: 2a5942ae orr w14, w21, w25, lsr #16 + 38: 4a40120d eor w13, w16, w0, lsr #4 + 3c: 6a504f5e ands w30, w26, w16, lsr #19 + 40: 8a7956ec bic x12, x23, x25, lsr #21 + 44: aa6120ab orn x11, x5, x1, lsr #8 + 48: caa5da26 eon x6, x17, x5, asr #54 + 4c: eaafca7e bics x30, x19, x15, asr #50 + 50: 0a7b18cf bic w15, w6, w27, lsr #6 + 54: 2aa61076 orn w22, w3, w6, asr #4 + 58: 4ab71482 eon w2, w4, w23, asr #5 + 5c: 6abe4ca2 bics w2, w5, w30, asr #19 + 60: 110e120c add w12, w16, #0x384 + 64: 310aa10b adds w11, w8, #0x2a8 + 68: 5100b0e8 sub w8, w7, #0x2c + 6c: 710f89e8 subs w8, w15, #0x3e2 + 70: 91002740 add x0, x26, #0x9 + 74: b10e865b adds x27, x18, #0x3a1 + 78: d104b112 sub x18, x8, #0x12c + 7c: f1091db4 subs x20, x13, #0x247 + 80: 121d4e7d and w29, w19, #0x7ffff8 + 84: 3215606e orr w14, w3, #0xfffff80f + 88: 520c03ae eor w14, w29, #0x100000 + 8c: 72174638 ands w24, w17, #0x7fffe00 + 90: 92022071 and x17, x3, #0xc000007fc000007f + 94: b2061dc7 orr x7, x14, #0xfc000003fc000003 + 98: d245bb45 eor x5, x26, #0xf80003ffffffffff + 9c: f20a22ba ands x26, x21, #0x7fc000007fc00000 + a0: 14000000 b a0 + a4: 17ffffd7 b 0 + a8: 140001f2 b 870 + ac: 94000000 bl ac + b0: 97ffffd4 bl 0 + b4: 940001ef bl 870 + b8: 34000000 cbz w0, b8 + bc: 34fffa20 cbz w0, 0 + c0: 34003d80 cbz w0, 870 + c4: 3500000b cbnz w11, c4 + c8: 35fff9cb cbnz w11, 0 + cc: 35003d2b cbnz w11, 870 + d0: b4000015 cbz x21, d0 + d4: b4fff975 cbz x21, 0 + d8: b4003cd5 cbz x21, 870 + dc: b5000008 cbnz x8, dc + e0: b5fff908 cbnz x8, 0 + e4: b5003c68 cbnz x8, 870 + e8: 1000000b adr x11, e8 + ec: 10fff8ab adr x11, 0 + f0: 10003c0b adr x11, 870 + f4: 90000000 adrp x0, 0 + f8: 36100005 tbz w5, #2, f8 + fc: 3617f825 tbz w5, #2, 0 + 100: 36103b85 tbz w5, #2, 870 + 104: 37200016 tbnz w22, #4, 104 + 108: 3727f7d6 tbnz w22, #4, 0 + 10c: 37203b36 tbnz w22, #4, 870 + 110: 12a5b6d6 mov w22, #0xd249ffff // #-766902273 + 114: 52ad7534 mov w20, #0x6ba90000 // #1806237696 + 118: 728edc9e movk w30, #0x76e4 + 11c: 92ce63db mov x27, #0xffff8ce1ffffffff // #-126572686213121 + 120: d2e3cc61 mov x1, #0x1e63000000000000 // #2189593843832193024 + 124: f2a1d6a9 movk x9, #0xeb5, lsl #16 + 128: 9355739c sbfx x28, x28, #21, #8 + 12c: 3308088f bfi w15, w4, #24, #3 + 130: 53174135 ubfiz w21, w9, #9, #17 + 134: 935a576e sbfiz x14, x27, #38, #22 + 138: b35c74d3 bfxil x19, x6, #28, #2 + 13c: d3500acb ubfiz x11, x22, #48, #3 + 140: 138172c7 extr w7, w22, w1, #28 + 144: 93cedb75 extr x21, x27, x14, #54 + 148: 54000000 b.eq 148 // b.none + 14c: 54fff5a0 b.eq 0 // b.none + 150: 54003900 b.eq 870 // b.none + 154: 54000001 b.ne 154 // b.any + 158: 54fff541 b.ne 0 // b.any + 15c: 540038a1 b.ne 870 // b.any + 160: 54000002 b.cs 160 // b.hs, b.nlast + 164: 54fff4e2 b.cs 0 // b.hs, b.nlast + 168: 54003842 b.cs 870 // b.hs, b.nlast + 16c: 54000002 b.cs 16c // b.hs, b.nlast + 170: 54fff482 b.cs 0 // b.hs, b.nlast + 174: 540037e2 b.cs 870 // b.hs, b.nlast + 178: 54000003 b.cc 178 // b.lo, b.ul, b.last + 17c: 54fff423 b.cc 0 // b.lo, b.ul, b.last + 180: 54003783 b.cc 870 // b.lo, b.ul, b.last + 184: 54000003 b.cc 184 // b.lo, b.ul, b.last + 188: 54fff3c3 b.cc 0 // b.lo, b.ul, b.last + 18c: 54003723 b.cc 870 // b.lo, b.ul, b.last + 190: 54000004 b.mi 190 // b.first + 194: 54fff364 b.mi 0 // b.first + 198: 540036c4 b.mi 870 // b.first + 19c: 54000005 b.pl 19c // b.nfrst + 1a0: 54fff305 b.pl 0 // b.nfrst + 1a4: 54003665 b.pl 870 // b.nfrst + 1a8: 54000006 b.vs 1a8 + 1ac: 54fff2a6 b.vs 0 + 1b0: 54003606 b.vs 870 + 1b4: 54000007 b.vc 1b4 + 1b8: 54fff247 b.vc 0 + 1bc: 540035a7 b.vc 870 + 1c0: 54000008 b.hi 1c0 // b.pmore + 1c4: 54fff1e8 b.hi 0 // b.pmore + 1c8: 54003548 b.hi 870 // b.pmore + 1cc: 54000009 b.ls 1cc // b.plast + 1d0: 54fff189 b.ls 0 // b.plast + 1d4: 540034e9 b.ls 870 // b.plast + 1d8: 5400000a b.ge 1d8 // b.tcont + 1dc: 54fff12a b.ge 0 // b.tcont + 1e0: 5400348a b.ge 870 // b.tcont + 1e4: 5400000b b.lt 1e4 // b.tstop + 1e8: 54fff0cb b.lt 0 // b.tstop + 1ec: 5400342b b.lt 870 // b.tstop + 1f0: 5400000c b.gt 1f0 + 1f4: 54fff06c b.gt 0 + 1f8: 540033cc b.gt 870 + 1fc: 5400000d b.le 1fc + 200: 54fff00d b.le 0 + 204: 5400336d b.le 870 + 208: 5400000e b.al 208 + 20c: 54ffefae b.al 0 + 210: 5400330e b.al 870 + 214: 5400000f b.nv 214 + 218: 54ffef4f b.nv 0 + 21c: 540032af b.nv 870 + 220: d40faaa1 svc #0x7d55 + 224: d4025942 hvc #0x12ca + 228: d40ab883 smc #0x55c4 + 22c: d42a4f00 brk #0x5278 + 230: d447c560 hlt #0x3e2b + 234: d503201f nop + 238: d69f03e0 eret + 23c: d6bf03e0 drps + 240: d5033fdf isb + 244: d5033a9f dsb ishst + 248: d5033abf dmb ishst + 24c: d61f0220 br x17 + 250: d63f0000 blr x0 + 254: c8037d87 stxr w3, x7, [x12] + 258: c810fe4d stlxr w16, x13, [x18] + 25c: c85f7fcb ldxr x11, [x30] + 260: c85ffc75 ldaxr x21, [x3] + 264: c89fff56 stlr x22, [x26] + 268: c8dfff62 ldar x2, [x27] + 26c: 88147c4f stxr w20, w15, [x2] + 270: 880bfda8 stlxr w11, w8, [x13] + 274: 885f7f50 ldxr w16, [x26] + 278: 885ffd7b ldaxr w27, [x11] + 27c: 889ffc9e stlr w30, [x4] + 280: 88dffd62 ldar w2, [x11] + 284: 48167e5b stxrh w22, w27, [x18] + 288: 4819feea stlxrh w25, w10, [x23] + 28c: 485f7fcd ldxrh w13, [x30] + 290: 485ffc4d ldaxrh w13, [x2] + 294: 489fff02 stlrh w2, [x24] + 298: 48dffef9 ldarh w25, [x23] + 29c: 080d7fa0 stxrb w13, w0, [x29] + 2a0: 0808fcd4 stlxrb w8, w20, [x6] + 2a4: 085f7caf ldxrb w15, [x5] + 2a8: 085ffd40 ldaxrb w0, [x10] + 2ac: 089fff4c stlrb w12, [x26] + 2b0: 08dffc4b ldarb w11, [x2] + 2b4: c87f4537 ldxp x23, x17, [x9] + 2b8: c87f9da1 ldaxp x1, x7, [x13] + 2bc: c8272fa0 stxp w7, x0, x11, [x29] + 2c0: c8399576 stlxp w25, x22, x5, [x11] + 2c4: 887f1b67 ldxp w7, w6, [x27] + 2c8: 887f8b07 ldaxp w7, w2, [x24] + 2cc: 88267a65 stxp w6, w5, w30, [x19] + 2d0: 88229e5d stlxp w2, w29, w7, [x18] + 2d4: f814929d stur x29, [x20, #-183] + 2d8: b81d91a6 stur w6, [x13, #-39] + 2dc: 381f50a9 sturb w9, [x5, #-11] + 2e0: 78015116 sturh w22, [x8, #21] + 2e4: f85af3a1 ldur x1, [x29, #-81] + 2e8: b85e53b4 ldur w20, [x29, #-27] + 2ec: 385f818f ldurb w15, [x12, #-8] + 2f0: 785c20e9 ldurh w9, [x7, #-62] + 2f4: 389f71b7 ldursb x23, [x13, #-9] + 2f8: 79803db2 ldrsh x18, [x13, #30] + 2fc: 79c037d1 ldrsh w17, [x30, #26] + 300: b89831d5 ldursw x21, [x14, #-125] + 304: fc43b1b5 ldur d21, [x13, #59] + 308: bc43f115 ldur s21, [x8, #63] + 30c: fc035316 stur d22, [x24, #53] + 310: bc01501a stur s26, [x0, #21] + 314: f8129ed7 str x23, [x22, #-215]! + 318: b81fdfbe str w30, [x29, #-3]! + 31c: 381eece2 strb w2, [x7, #-18]! + 320: 78013d97 strh w23, [x12, #19]! + 324: f852ec92 ldr x18, [x4, #-210]! + 328: b85b9fd3 ldr w19, [x30, #-71]! + 32c: 385f5e91 ldrb w17, [x20, #-11]! + 330: 785c0dc9 ldrh w9, [x14, #-64]! + 334: 3880bc66 ldrsb x6, [x3, #11]! + 338: 789faecb ldrsh x11, [x22, #-6]! + 33c: 78de5d66 ldrsh w6, [x11, #-27]! + 340: b8836e59 ldrsw x25, [x18, #54]! + 344: fc5f8ef5 ldr d21, [x23, #-8]! + 348: bc5d9d5e ldr s30, [x10, #-39]! + 34c: fc17fc22 str d2, [x1, #-129]! + 350: bc001c1a str s26, [x0, #1]! + 354: f819d749 str x9, [x26], #-99 + 358: b803e5c9 str w9, [x14], #62 + 35c: 381e275e strb w30, [x26], #-30 + 360: 7800b61c strh w28, [x16], #11 + 364: f844d75d ldr x29, [x26], #77 + 368: b84356e0 ldr w0, [x23], #53 + 36c: 385ee6a7 ldrb w7, [x21], #-18 + 370: 784185b8 ldrh w24, [x13], #24 + 374: 389ef501 ldrsb x1, [x8], #-17 + 378: 789de771 ldrsh x17, [x27], #-34 + 37c: 78de6435 ldrsh w21, [x1], #-26 + 380: b88006a6 ldrsw x6, [x21], #0 + 384: fc43a465 ldr d5, [x3], #58 + 388: bc5b0667 ldr s7, [x19], #-80 + 38c: fc01b601 str d1, [x16], #27 + 390: bc03e727 str s7, [x25], #62 + 394: f83e586d str x13, [x3, w30, uxtw #3] + 398: b821e871 str w17, [x3, x1, sxtx] + 39c: 383b7a77 strb w23, [x19, x27, lsl #0] + 3a0: 782a5a85 strh w5, [x20, w10, uxtw #1] + 3a4: f870d85d ldr x29, [x2, w16, sxtw #3] + 3a8: b875fa30 ldr w16, [x17, x21, sxtx #2] + 3ac: 38705a0a ldrb w10, [x16, w16, uxtw #0] + 3b0: 787adb77 ldrh w23, [x27, w26, sxtw #1] + 3b4: 38a7780d ldrsb x13, [x0, x7, lsl #0] + 3b8: 78b248af ldrsh x15, [x5, w18, uxtw] + 3bc: 78f27a92 ldrsh w18, [x20, x18, lsl #1] + 3c0: b8b149de ldrsw x30, [x14, w17, uxtw] + 3c4: fc7a58d3 ldr d19, [x6, w26, uxtw #3] + 3c8: bc62cafe ldr s30, [x23, w2, sxtw] + 3cc: fc274adb str d27, [x22, w7, uxtw] + 3d0: bc3afb09 str s9, [x24, x26, sxtx #2] + 3d4: f91f778e str x14, [x28, #16104] + 3d8: b91eb9b0 str w16, [x13, #7864] + 3dc: 39186b74 strb w20, [x27, #1562] + 3e0: 791988f0 strh w16, [x7, #3268] + 3e4: f95e4ea5 ldr x5, [x21, #15512] + 3e8: b95de900 ldr w0, [x8, #7656] + 3ec: 395f90e1 ldrb w1, [x7, #2020] + 3f0: 7959bdc1 ldrh w1, [x14, #3294] + 3f4: 399b9b26 ldrsb x6, [x25, #1766] + 3f8: 79996209 ldrsh x9, [x16, #3248] + 3fc: 79dc309b ldrsh w27, [x4, #3608] + 400: b99c8e02 ldrsw x2, [x16, #7308] + 404: fd5fa345 ldr d5, [x26, #16192] + 408: bd5efdb3 ldr s19, [x13, #7932] + 40c: fd1a20f6 str d22, [x7, #13376] + 410: bd1e8928 str s8, [x9, #7816] + 414: 58ffdf7a ldr x26, 0 + 418: 18ffdf4c ldr w12, 0 + 41c: f882f140 prfum pldl1keep, [x10, #47] + 420: d8002280 prfm pldl1keep, 870 + 424: f8b47aa0 prfm pldl1keep, [x21, x20, lsl #3] + 428: f99ed1a0 prfm pldl1keep, [x13, #15776] + 42c: 1a03011a adc w26, w8, w3 + 430: 3a0703c9 adcs w9, w30, w7 + 434: 5a0b01f8 sbc w24, w15, w11 + 438: 7a0b02a4 sbcs w4, w21, w11 + 43c: 9a1e022f adc x15, x17, x30 + 440: ba1001e6 adcs x6, x15, x16 + 444: da0a0041 sbc x1, x2, x10 + 448: fa0b0089 sbcs x9, x4, x11 + 44c: 0b3167b7 add w23, w29, w17, uxtx #1 + 450: 2b2bed6f adds w15, w11, w11, sxtx #3 + 454: cb2753c2 sub x2, x30, w7, uxtw #4 + 458: 6b3a867e subs w30, w19, w26, sxtb #1 + 45c: 8b2c6c02 add x2, x0, x12, uxtx #3 + 460: ab30902e adds x14, x1, w16, sxtb #4 + 464: cb378ecf sub x15, x22, w23, sxtb #3 + 468: eb3c4480 subs x0, x4, w28, uxtw #1 + 46c: 3a5220ab ccmn w5, w18, #0xb, cs // cs = hs, nlast + 470: 7a552248 ccmp w18, w21, #0x8, cs // cs = hs, nlast + 474: ba5131ef ccmn x15, x17, #0xf, cc // cc = lo, ul, last + 478: fa5711a6 ccmp x13, x23, #0x6, ne // ne = any + 47c: 3a493b8f ccmn w28, #0x9, #0xf, cc // cc = lo, ul, last + 480: 7a4c99c9 ccmp w14, #0xc, #0x9, ls // ls = plast + 484: ba463ac2 ccmn x22, #0x6, #0x2, cc // cc = lo, ul, last + 488: fa4c4aa0 ccmp x21, #0xc, #0x0, mi // mi = first + 48c: 1a9cc2ae csel w14, w21, w28, gt + 490: 1a91c5d9 csinc w25, w14, w17, gt + 494: 5a9920d1 csinv w17, w6, w25, cs // cs = hs, nlast + 498: 5a8e2455 csneg w21, w2, w14, cs // cs = hs, nlast + 49c: 9a912163 csel x3, x11, x17, cs // cs = hs, nlast + 4a0: 9a9b27db csinc x27, x30, x27, cs // cs = hs, nlast + 4a4: da8581e0 csinv x0, x15, x5, hi // hi = pmore + 4a8: da882562 csneg x2, x11, x8, cs // cs = hs, nlast + 4ac: 5ac00262 rbit w2, w19 + 4b0: 5ac00596 rev16 w22, w12 + 4b4: 5ac00ac5 rev w5, w22 + 4b8: 5ac01363 clz w3, w27 + 4bc: 5ac01492 cls w18, w4 + 4c0: dac00376 rbit x22, x27 + 4c4: dac0054c rev16 x12, x10 + 4c8: dac00885 rev32 x5, x4 + 4cc: dac00d56 rev x22, x10 + 4d0: dac010ed clz x13, x7 + 4d4: dac01546 cls x6, x10 + 4d8: 1adc0a02 udiv w2, w16, w28 + 4dc: 1ac80ee8 sdiv w8, w23, w8 + 4e0: 1ace2232 lsl w18, w17, w14 + 4e4: 1ad6273e lsr w30, w25, w22 + 4e8: 1ac52850 asr w16, w2, w5 + 4ec: 1ac02f8f ror w15, w28, w0 + 4f0: 9ac10a8d udiv x13, x20, x1 + 4f4: 9ad20fdc sdiv x28, x30, x18 + 4f8: 9ac92391 lsl x17, x28, x9 + 4fc: 9ac425b2 lsr x18, x13, x4 + 500: 9ad02b0c asr x12, x24, x16 + 504: 9ad82d2e ror x14, x9, x24 + 508: 9bd87c94 umulh x20, x4, x24 + 50c: 9b5c7cb2 smulh x18, x5, x28 + 510: 1b114bb3 madd w19, w29, w17, w18 + 514: 1b0fcece msub w14, w22, w15, w19 + 518: 9b0120ac madd x12, x5, x1, x8 + 51c: 9b0bc256 msub x22, x18, x11, x16 + 520: 9b2c7960 smaddl x0, w11, w12, x30 + 524: 9b2db113 smsubl x19, w8, w13, x12 + 528: 9bb117cd umaddl x13, w30, w17, x5 + 52c: 9bb7a590 umsubl x16, w12, w23, x9 + 530: 1e200a86 fmul s6, s20, s0 + 534: 1e2f18d5 fdiv s21, s6, s15 + 538: 1e392938 fadd s24, s9, s25 + 53c: 1e323b09 fsub s9, s24, s18 + 540: 1e2a0b1a fmul s26, s24, s10 + 544: 1e600a8c fmul d12, d20, d0 + 548: 1e7019ec fdiv d12, d15, d16 + 54c: 1e7d28d8 fadd d24, d6, d29 + 550: 1e6e38d8 fsub d24, d6, d14 + 554: 1e6f0bb5 fmul d21, d29, d15 + 558: 1f017729 fmadd s9, s25, s1, s29 + 55c: 1f0af68d fmsub s13, s20, s10, s29 + 560: 1f2b1d7c fnmadd s28, s11, s11, s7 + 564: 1f350787 fnmadd s7, s28, s21, s1 + 568: 1f4f07be fmadd d30, d29, d15, d1 + 56c: 1f5be90c fmsub d12, d8, d27, d26 + 570: 1f6b6711 fnmadd d17, d24, d11, d25 + 574: 1f68003e fnmadd d30, d1, d8, d0 + 578: 1e2040a1 fmov s1, s5 + 57c: 1e20c266 fabs s6, s19 + 580: 1e214004 fneg s4, s0 + 584: 1e21c149 fsqrt s9, s10 + 588: 1e22c1d4 fcvt d20, s14 + 58c: 1e604260 fmov d0, d19 + 590: 1e60c25e fabs d30, d18 + 594: 1e614100 fneg d0, d8 + 598: 1e61c100 fsqrt d0, d8 + 59c: 1e6243ce fcvt s14, d30 + 5a0: 1e3802d3 fcvtzs w19, s22 + 5a4: 9e380151 fcvtzs x17, s10 + 5a8: 1e7802bb fcvtzs w27, d21 + 5ac: 9e780087 fcvtzs x7, d4 + 5b0: 1e22033e scvtf s30, w25 + 5b4: 9e220219 scvtf s25, x16 + 5b8: 1e620349 scvtf d9, w26 + 5bc: 9e620007 scvtf d7, x0 + 5c0: 1e2601e0 fmov w0, s15 + 5c4: 9e66008b fmov x11, d4 + 5c8: 1e2701fe fmov s30, w15 + 5cc: 9e6702e2 fmov d2, x23 + 5d0: 1e2a21c0 fcmp s14, s10 + 5d4: 1e6023c0 fcmp d30, d0 + 5d8: 1e202168 fcmp s11, #0.0 + 5dc: 1e602308 fcmp d24, #0.0 + 5e0: 2922403c stp w28, w16, [x1, #-240] + 5e4: 294c55d7 ldp w23, w21, [x14, #96] + 5e8: 697860e0 ldpsw x0, x24, [x7, #-64] + 5ec: a9085215 stp x21, x20, [x16, #128] + 5f0: a9790f41 ldp x1, x3, [x26, #-112] + 5f4: 29a2394c stp w12, w14, [x10, #-240]! + 5f8: 29e200e3 ldp w3, w0, [x7, #-240]! + 5fc: 69e660ba ldpsw x26, x24, [x5, #-208]! + 600: a9b65910 stp x16, x22, [x8, #-160]! + 604: a9f711fa ldp x26, x4, [x15, #-144]! + 608: 288e73a9 stp w9, w28, [x29], #112 + 60c: 28c81468 ldp w8, w5, [x3], #64 + 610: 68e6119e ldpsw x30, x4, [x12], #-208 + 614: a8b67a0e stp x14, x30, [x16], #-160 + 618: a8f3593b ldp x27, x22, [x9], #-208 + 61c: 2820571a stnp w26, w21, [x24, #-256] + 620: 287a25f4 ldnp w20, w9, [x15, #-48] + 624: a83169af stnp x15, x26, [x13, #-240] + 628: a84168a5 ldnp x5, x26, [x5, #16] + 62c: 0c407353 ld1 {v19.8b}, [x26] + 630: 4cdfa1c1 ld1 {v1.16b, v2.16b}, [x14], #32 + 634: 0cd96f1d ld1 {v29.1d-v31.1d}, [x24], x25 + 638: 4cdf2414 ld1 {v20.8h-v23.8h}, [x0], #64 + 63c: 0d40c379 ld1r {v25.8b}, [x27] + 640: 4ddfcb5e ld1r {v30.4s}, [x26], #4 + 644: 0dcacea9 ld1r {v9.1d}, [x21], x10 + 648: 4c408dc2 ld2 {v2.2d, v3.2d}, [x14] + 64c: 0cdf864e ld2 {v14.4h, v15.4h}, [x18], #16 + 650: 4d60c004 ld2r {v4.16b, v5.16b}, [x0] + 654: 0dffc832 ld2r {v18.2s, v19.2s}, [x1], #8 + 658: 4dfbcc1a ld2r {v26.2d, v27.2d}, [x0], x27 + 65c: 4cc34ac7 ld3 {v7.4s-v9.4s}, [x22], x3 + 660: 0c404aa5 ld3 {v5.2s-v7.2s}, [x21] + 664: 4d40e4fe ld3r {v30.8h, v31.8h, v0.8h}, [x7] + 668: 4ddfeae7 ld3r {v7.4s-v9.4s}, [x23], #12 + 66c: 0dc6ed4f ld3r {v15.1d-v17.1d}, [x10], x6 + 670: 4cdf0734 ld4 {v20.8h-v23.8h}, [x25], #64 + 674: 0cd80365 ld4 {v5.8b-v8.8b}, [x27], x24 + 678: 0d60e2a5 ld4r {v5.8b-v8.8b}, [x21] + 67c: 0dffe773 ld4r {v19.4h-v22.4h}, [x27], #8 + 680: 0df6ebc6 ld4r {v6.2s-v9.2s}, [x30], x22 + 684: ce6182e4 sha512h q4, q23, v1.2d + 688: ce6d8583 sha512h2 q3, q12, v13.2d + 68c: cec080db sha512su0 v27.2d, v6.2d + 690: ce6a8aa9 sha512su1 v9.2d, v21.2d, v10.2d + 694: ba5fd3e3 ccmn xzr, xzr, #0x3, le + 698: 3a5f03e5 ccmn wzr, wzr, #0x5, eq // eq = none + 69c: fa411be4 ccmp xzr, #0x1, #0x4, ne // ne = any + 6a0: 7a42cbe2 ccmp wzr, #0x2, #0x2, gt + 6a4: 93df03ff ror xzr, xzr, #0 + 6a8: c820ffff stlxp w0, xzr, xzr, [sp] + 6ac: 8822fc7f stlxp w2, wzr, wzr, [x3] + 6b0: c8247cbf stxp w4, xzr, xzr, [x5] + 6b4: 88267fff stxp w6, wzr, wzr, [sp] + 6b8: 4e010fe0 dup v0.16b, wzr + 6bc: 4e081fe1 mov v1.d[0], xzr + 6c0: 4e0c1fe1 mov v1.s[1], wzr + 6c4: 4e0a1fe1 mov v1.h[2], wzr + 6c8: 4e071fe1 mov v1.b[3], wzr + 6cc: 4cc0ac3f ld1 {v31.2d, v0.2d}, [x1], x0 + 6d0: 1e601000 fmov d0, #2.000000000000000000e+00 + 6d4: 1e603000 fmov d0, #2.125000000000000000e+00 + 6d8: 1e621000 fmov d0, #4.000000000000000000e+00 + 6dc: 1e623000 fmov d0, #4.250000000000000000e+00 + 6e0: 1e641000 fmov d0, #8.000000000000000000e+00 + 6e4: 1e643000 fmov d0, #8.500000000000000000e+00 + 6e8: 1e661000 fmov d0, #1.600000000000000000e+01 + 6ec: 1e663000 fmov d0, #1.700000000000000000e+01 + 6f0: 1e681000 fmov d0, #1.250000000000000000e-01 + 6f4: 1e683000 fmov d0, #1.328125000000000000e-01 + 6f8: 1e6a1000 fmov d0, #2.500000000000000000e-01 + 6fc: 1e6a3000 fmov d0, #2.656250000000000000e-01 + 700: 1e6c1000 fmov d0, #5.000000000000000000e-01 + 704: 1e6c3000 fmov d0, #5.312500000000000000e-01 + 708: 1e6e1000 fmov d0, #1.000000000000000000e+00 + 70c: 1e6e3000 fmov d0, #1.062500000000000000e+00 + 710: 1e701000 fmov d0, #-2.000000000000000000e+00 + 714: 1e703000 fmov d0, #-2.125000000000000000e+00 + 718: 1e721000 fmov d0, #-4.000000000000000000e+00 + 71c: 1e723000 fmov d0, #-4.250000000000000000e+00 + 720: 1e741000 fmov d0, #-8.000000000000000000e+00 + 724: 1e743000 fmov d0, #-8.500000000000000000e+00 + 728: 1e761000 fmov d0, #-1.600000000000000000e+01 + 72c: 1e763000 fmov d0, #-1.700000000000000000e+01 + 730: 1e781000 fmov d0, #-1.250000000000000000e-01 + 734: 1e783000 fmov d0, #-1.328125000000000000e-01 + 738: 1e7a1000 fmov d0, #-2.500000000000000000e-01 + 73c: 1e7a3000 fmov d0, #-2.656250000000000000e-01 + 740: 1e7c1000 fmov d0, #-5.000000000000000000e-01 + 744: 1e7c3000 fmov d0, #-5.312500000000000000e-01 + 748: 1e7e1000 fmov d0, #-1.000000000000000000e+00 + 74c: 1e7e3000 fmov d0, #-1.062500000000000000e+00 + 750: f838807f swp x24, xzr, [x3] + 754: f82500a6 ldadd x5, x6, [x5] + 758: f8391189 ldclr x25, x9, [x12] + 75c: f8292136 ldeor x9, x22, [x9] + 760: f82e3024 ldset x14, x4, [x1] + 764: f83753be ldsmin x23, x30, [x29] + 768: f835434d ldsmax x21, x13, [x26] + 76c: f8307169 ldumin x16, x9, [x11] + 770: f83562b1 ldumax x21, x17, [x21] + 774: f8b98139 swpa x25, x25, [x9] + 778: f8a500d9 ldadda x5, x25, [x6] + 77c: f8b812ee ldclra x24, x14, [x23] + 780: f8b32358 ldeora x19, x24, [x26] + 784: f8af3057 ldseta x15, x23, [x2] + 788: f8a650e7 ldsmina x6, x7, [x7] + 78c: f8be41cf ldsmaxa x30, x15, [x14] + 790: f8bf70a7 ldumina xzr, x7, [x5] + 794: f8b46039 ldumaxa x20, x25, [x1] + 798: f8f08232 swpal x16, x18, [x17] + 79c: f8e0016f ldaddal x0, x15, [x11] + 7a0: f8e910f1 ldclral x9, x17, [x7] + 7a4: f8e122f7 ldeoral x1, x23, [x23] + 7a8: f8f23061 ldsetal x18, x1, [x3] + 7ac: f8fb511f ldsminal x27, xzr, [x8] + 7b0: f8e9417b ldsmaxal x9, x27, [x11] + 7b4: f8f97063 lduminal x25, x3, [x3] + 7b8: f8f06338 ldumaxal x16, x24, [x25] + 7bc: f86683a2 swpl x6, x2, [x29] + 7c0: f8770199 ldaddl x23, x25, [x12] + 7c4: f86912fd ldclrl x9, x29, [x23] + 7c8: f87d2040 ldeorl x29, x0, [x2] + 7cc: f8733146 ldsetl x19, x6, [x10] + 7d0: f871532d ldsminl x17, x13, [x25] + 7d4: f8614337 ldsmaxl x1, x23, [x25] + 7d8: f87470da lduminl x20, x26, [x6] + 7dc: f86d6196 ldumaxl x13, x22, [x12] + 7e0: b8378378 swp w23, w24, [x27] + 7e4: b8230287 ldadd w3, w7, [x20] + 7e8: b82a12f5 ldclr w10, w21, [x23] + 7ec: b829219a ldeor w9, w26, [x12] + 7f0: b83a3377 ldset w26, w23, [x27] + 7f4: b82452ae ldsmin w4, w14, [x21] + 7f8: b82a4120 ldsmax w10, w0, [x9] + 7fc: b82970cd ldumin w9, w13, [x6] + 800: b82962bf stumax w9, [x21] + 804: b8ac817c swpa w12, w28, [x11] + 808: b8a80180 ldadda w8, w0, [x12] + 80c: b8bd1027 ldclra w29, w7, [x1] + 810: b8bd233b ldeora w29, w27, [x25] + 814: b8bb3110 ldseta w27, w16, [x8] + 818: b8ad53f2 ldsmina w13, w18, [sp] + 81c: b8bc4300 ldsmaxa w28, w0, [x24] + 820: b8bc71bc ldumina w28, w28, [x13] + 824: b8ae605d ldumaxa w14, w29, [x2] + 828: b8e8823c swpal w8, w28, [x17] + 82c: b8e4004a ldaddal w4, w10, [x2] + 830: b8e011dc ldclral w0, w28, [x14] + 834: b8e8208c ldeoral w8, w12, [x4] + 838: b8e131b6 ldsetal w1, w22, [x13] + 83c: b8f85286 ldsminal w24, w6, [x20] + 840: b8ee408e ldsmaxal w14, w14, [x4] + 844: b8fe71c2 lduminal w30, w2, [x14] + 848: b8e262d2 ldumaxal w2, w18, [x22] + 84c: b8798239 swpl w25, w25, [x17] + 850: b86400f3 ldaddl w4, w19, [x7] + 854: b873116f ldclrl w19, w15, [x11] + 858: b877221d ldeorl w23, w29, [x16] + 85c: b87b3345 ldsetl w27, w5, [x26] + 860: b87f501b ldsminl wzr, w27, [x0] + 864: b8764086 ldsmaxl w22, w6, [x4] + 868: b86d705e lduminl w13, w30, [x2] + 86c: b873619a ldumaxl w19, w26, [x12] */ static const unsigned int insns[] = { - 0x8b50798f, 0xcb4381e1, 0xab05372d, 0xeb864796, - 0x0b961920, 0x4b195473, 0x2b0b5264, 0x6b9300f8, - 0x8a0bc0fe, 0xaa0f3118, 0xca170531, 0xea44dd6e, - 0x0a4c44f3, 0x2a8b7373, 0x4a567c7e, 0x6a9c0353, - 0x8a3accdd, 0xaa318f7a, 0xca2e1495, 0xeaa015e2, - 0x0a2274e2, 0x2a751598, 0x4a3309fe, 0x6ab172fe, - 0x110a5284, 0x310b1942, 0x5103d353, 0x710125bc, - 0x910d7bc2, 0xb108fa1b, 0xd1093536, 0xf10ae824, - 0x120e667c, 0x321f6cbb, 0x520f6a9e, 0x72136f56, - 0x927e4ce5, 0xb278b4ed, 0xd24c6527, 0xf2485803, - 0x14000000, 0x17ffffd7, 0x140001ee, 0x94000000, - 0x97ffffd4, 0x940001eb, 0x34000010, 0x34fffa30, - 0x34003d10, 0x35000013, 0x35fff9d3, 0x35003cb3, - 0xb4000005, 0xb4fff965, 0xb4003c45, 0xb5000004, - 0xb5fff904, 0xb5003be4, 0x1000001b, 0x10fff8bb, - 0x10003b9b, 0x90000010, 0x3640001c, 0x3647f83c, - 0x36403b1c, 0x37080001, 0x370ff7c1, 0x37083aa1, - 0x12a437f4, 0x528c9d67, 0x72838bb1, 0x92c1062e, - 0xd287da49, 0xf2a6d153, 0x93465ac9, 0x330b0013, - 0x530b4e6a, 0x934545e4, 0xb35370a3, 0xd3510b8c, - 0x13960c0f, 0x93ceddc6, 0x54000000, 0x54fff5a0, - 0x54003880, 0x54000001, 0x54fff541, 0x54003821, - 0x54000002, 0x54fff4e2, 0x540037c2, 0x54000002, - 0x54fff482, 0x54003762, 0x54000003, 0x54fff423, - 0x54003703, 0x54000003, 0x54fff3c3, 0x540036a3, - 0x54000004, 0x54fff364, 0x54003644, 0x54000005, - 0x54fff305, 0x540035e5, 0x54000006, 0x54fff2a6, - 0x54003586, 0x54000007, 0x54fff247, 0x54003527, - 0x54000008, 0x54fff1e8, 0x540034c8, 0x54000009, - 0x54fff189, 0x54003469, 0x5400000a, 0x54fff12a, - 0x5400340a, 0x5400000b, 0x54fff0cb, 0x540033ab, - 0x5400000c, 0x54fff06c, 0x5400334c, 0x5400000d, - 0x54fff00d, 0x540032ed, 0x5400000e, 0x54ffefae, - 0x5400328e, 0x5400000f, 0x54ffef4f, 0x5400322f, - 0xd40ac601, 0xd40042a2, 0xd404dac3, 0xd4224d40, - 0xd44219c0, 0xd503201f, 0xd69f03e0, 0xd6bf03e0, - 0xd5033fdf, 0xd503339f, 0xd50335bf, 0xd61f0280, - 0xd63f0040, 0xc8127c17, 0xc81efec5, 0xc85f7d05, - 0xc85ffe14, 0xc89ffd66, 0xc8dfff66, 0x880a7cb1, - 0x8816fd89, 0x885f7d1b, 0x885ffc57, 0x889fffba, - 0x88dffd4d, 0x48197f7c, 0x481dfd96, 0x485f7f96, - 0x485fffc3, 0x489ffdf8, 0x48dfff5b, 0x080b7e6a, - 0x0817fedb, 0x085f7e18, 0x085ffc38, 0x089fffa5, - 0x08dffe18, 0xc87f6239, 0xc87fb276, 0xc820573a, - 0xc821aca6, 0x887f388d, 0x887f88d1, 0x882f2643, - 0x88329131, 0xf81cf2b7, 0xb803f055, 0x39002f9b, - 0x781f31fd, 0xf85d33ce, 0xb843539d, 0x39401f54, - 0x785ce059, 0x389f1143, 0x788131ee, 0x78dfb17d, - 0xb89b90af, 0xfc403193, 0xbc42a36c, 0xfc07d396, - 0xbc1ec1f8, 0xf81e8f88, 0xb8025de6, 0x38007c27, - 0x7801ee20, 0xf8454fb9, 0xb85cce9a, 0x385e7fba, - 0x7841af24, 0x389ebd1c, 0x789fadd1, 0x78c0aefc, - 0xb89c0f7e, 0xfc50efd4, 0xbc414f71, 0xfc011c67, - 0xbc1f0d6d, 0xf81c3526, 0xb81e34b0, 0x3800f7bd, - 0x78012684, 0xf842e653, 0xb8417456, 0x385e2467, - 0x785e358b, 0x389e34c8, 0x788046f8, 0x78c00611, - 0xb89f8680, 0xfc582454, 0xbc5987d3, 0xfc076624, - 0xbc190675, 0xf833785a, 0xb82fd809, 0x3821799a, - 0x782a7975, 0xf870eaf0, 0xb871d96a, 0x386b7aed, - 0x7875689b, 0x38afd91a, 0x78a2c955, 0x78ee6bc8, - 0xb8b4f9dd, 0xfc76eb7e, 0xbc76692d, 0xfc31db28, - 0xbc255b01, 0xf91c52aa, 0xb91c3fb2, 0x391f8877, - 0x791ac97c, 0xf95c1758, 0xb95b3c55, 0x395ce0a4, - 0x795851ce, 0x399e9f64, 0x79993764, 0x79d9af8a, - 0xb99eea2a, 0xfd5a2f8d, 0xbd5dac78, 0xfd1e0182, - 0xbd195c31, 0x58000010, 0x1800000d, 0xf8981240, - 0xd8ffdf00, 0xf8a27a80, 0xf99af920, 0x1a0202e8, - 0x3a130078, 0x5a1d0316, 0x7a03036c, 0x9a0102eb, - 0xba1700bd, 0xda0c0329, 0xfa16000c, 0x0b23459a, - 0x2b328a14, 0xcb274bde, 0x6b222eab, 0x8b214b42, - 0xab34a7b2, 0xcb24520e, 0xeb378e20, 0x3a565283, - 0x7a420321, 0xba58c247, 0xfa4d5106, 0x3a426924, - 0x7a5b0847, 0xba413a02, 0xfa5fba23, 0x1a979377, - 0x1a86640a, 0x5a89300b, 0x5a923771, 0x9a8b720c, - 0x9a868786, 0xda9a736d, 0xda9256dd, 0x5ac0026c, - 0x5ac00657, 0x5ac00b89, 0x5ac01262, 0x5ac017b9, - 0xdac002e4, 0xdac0065d, 0xdac00907, 0xdac00e2d, - 0xdac01011, 0xdac01752, 0x1ad0098b, 0x1ac70d24, - 0x1ad020ec, 0x1ad72613, 0x1ac62887, 0x1ad72e95, - 0x9adc0990, 0x9acd0d84, 0x9ac721a9, 0x9acf277c, - 0x9ace2bd4, 0x9ade2e4e, 0x9bc77d63, 0x9b587e97, - 0x1b1524a2, 0x1b04a318, 0x9b0f4d8b, 0x9b0ce73d, - 0x9b2c5971, 0x9b34c87c, 0x9bbc6887, 0x9bb19556, - 0x1e310871, 0x1e261a2b, 0x1e2928fd, 0x1e333987, - 0x1e230ae0, 0x1e75087a, 0x1e651a60, 0x1e692b40, - 0x1e753ab9, 0x1e7309b0, 0x1f00425d, 0x1f1d95b7, - 0x1f2a38e9, 0x1f2f5f99, 0x1f5545a6, 0x1f429ea3, - 0x1f65472a, 0x1f7449ce, 0x1e20404f, 0x1e20c0f2, - 0x1e2140c3, 0x1e21c02c, 0x1e22c009, 0x1e6040a4, - 0x1e60c1e3, 0x1e614331, 0x1e61c30c, 0x1e6240b5, - 0x1e3802a4, 0x9e38007b, 0x1e78011d, 0x9e7802a9, - 0x1e2203b4, 0x9e220107, 0x1e6202ac, 0x9e6202b0, - 0x1e2600b2, 0x9e660119, 0x1e270352, 0x9e670160, - 0x1e262200, 0x1e7d2200, 0x1e2023c8, 0x1e602128, - 0x293e119b, 0x294a2543, 0x69480c70, 0xa934726a, - 0xa97448f3, 0x298243ca, 0x29e21242, 0x69c64db8, - 0xa9800311, 0xa9f4686e, 0x288a0416, 0x28fe2812, - 0x68fe62d8, 0xa885308c, 0xa8f12664, 0x282468d2, - 0x284e5035, 0xa8327699, 0xa84716e1, 0x0c407284, - 0x4cdfa158, 0x0ccf6cd8, 0x4cdf2483, 0x0d40c0c2, - 0x4ddfc9cd, 0x0dd8ceaf, 0x4c408ea9, 0x0cdf86bd, - 0x4d60c1c8, 0x0dffca87, 0x4de3cc7c, 0x4cdd497b, - 0x0c404950, 0x4d40e595, 0x4ddfeba4, 0x0dd3ed38, - 0x4cdf046a, 0x0cc9039b, 0x0d60e3d5, 0x0dffe5d7, - 0x0df4e9a4, 0xba5fd3e3, 0x3a5f03e5, 0xfa411be4, + 0x8b402464, 0xcb0447a8, 0xab174767, 0xeb49a5e6, + 0x0b905c6c, 0x4b5d7f08, 0x2b0f1f87, 0x6b5c35fa, + 0x8a827101, 0xaa4c2b73, 0xca4aed64, 0xea027225, + 0x0a4c35fc, 0x2a5942ae, 0x4a40120d, 0x6a504f5e, + 0x8a7956ec, 0xaa6120ab, 0xcaa5da26, 0xeaafca7e, + 0x0a7b18cf, 0x2aa61076, 0x4ab71482, 0x6abe4ca2, + 0x110e120c, 0x310aa10b, 0x5100b0e8, 0x710f89e8, + 0x91002740, 0xb10e865b, 0xd104b112, 0xf1091db4, + 0x121d4e7d, 0x3215606e, 0x520c03ae, 0x72174638, + 0x92022071, 0xb2061dc7, 0xd245bb45, 0xf20a22ba, + 0x14000000, 0x17ffffd7, 0x140001f2, 0x94000000, + 0x97ffffd4, 0x940001ef, 0x34000000, 0x34fffa20, + 0x34003d80, 0x3500000b, 0x35fff9cb, 0x35003d2b, + 0xb4000015, 0xb4fff975, 0xb4003cd5, 0xb5000008, + 0xb5fff908, 0xb5003c68, 0x1000000b, 0x10fff8ab, + 0x10003c0b, 0x90000000, 0x36100005, 0x3617f825, + 0x36103b85, 0x37200016, 0x3727f7d6, 0x37203b36, + 0x12a5b6d6, 0x52ad7534, 0x728edc9e, 0x92ce63db, + 0xd2e3cc61, 0xf2a1d6a9, 0x9355739c, 0x3308088f, + 0x53174135, 0x935a576e, 0xb35c74d3, 0xd3500acb, + 0x138172c7, 0x93cedb75, 0x54000000, 0x54fff5a0, + 0x54003900, 0x54000001, 0x54fff541, 0x540038a1, + 0x54000002, 0x54fff4e2, 0x54003842, 0x54000002, + 0x54fff482, 0x540037e2, 0x54000003, 0x54fff423, + 0x54003783, 0x54000003, 0x54fff3c3, 0x54003723, + 0x54000004, 0x54fff364, 0x540036c4, 0x54000005, + 0x54fff305, 0x54003665, 0x54000006, 0x54fff2a6, + 0x54003606, 0x54000007, 0x54fff247, 0x540035a7, + 0x54000008, 0x54fff1e8, 0x54003548, 0x54000009, + 0x54fff189, 0x540034e9, 0x5400000a, 0x54fff12a, + 0x5400348a, 0x5400000b, 0x54fff0cb, 0x5400342b, + 0x5400000c, 0x54fff06c, 0x540033cc, 0x5400000d, + 0x54fff00d, 0x5400336d, 0x5400000e, 0x54ffefae, + 0x5400330e, 0x5400000f, 0x54ffef4f, 0x540032af, + 0xd40faaa1, 0xd4025942, 0xd40ab883, 0xd42a4f00, + 0xd447c560, 0xd503201f, 0xd69f03e0, 0xd6bf03e0, + 0xd5033fdf, 0xd5033a9f, 0xd5033abf, 0xd61f0220, + 0xd63f0000, 0xc8037d87, 0xc810fe4d, 0xc85f7fcb, + 0xc85ffc75, 0xc89fff56, 0xc8dfff62, 0x88147c4f, + 0x880bfda8, 0x885f7f50, 0x885ffd7b, 0x889ffc9e, + 0x88dffd62, 0x48167e5b, 0x4819feea, 0x485f7fcd, + 0x485ffc4d, 0x489fff02, 0x48dffef9, 0x080d7fa0, + 0x0808fcd4, 0x085f7caf, 0x085ffd40, 0x089fff4c, + 0x08dffc4b, 0xc87f4537, 0xc87f9da1, 0xc8272fa0, + 0xc8399576, 0x887f1b67, 0x887f8b07, 0x88267a65, + 0x88229e5d, 0xf814929d, 0xb81d91a6, 0x381f50a9, + 0x78015116, 0xf85af3a1, 0xb85e53b4, 0x385f818f, + 0x785c20e9, 0x389f71b7, 0x79803db2, 0x79c037d1, + 0xb89831d5, 0xfc43b1b5, 0xbc43f115, 0xfc035316, + 0xbc01501a, 0xf8129ed7, 0xb81fdfbe, 0x381eece2, + 0x78013d97, 0xf852ec92, 0xb85b9fd3, 0x385f5e91, + 0x785c0dc9, 0x3880bc66, 0x789faecb, 0x78de5d66, + 0xb8836e59, 0xfc5f8ef5, 0xbc5d9d5e, 0xfc17fc22, + 0xbc001c1a, 0xf819d749, 0xb803e5c9, 0x381e275e, + 0x7800b61c, 0xf844d75d, 0xb84356e0, 0x385ee6a7, + 0x784185b8, 0x389ef501, 0x789de771, 0x78de6435, + 0xb88006a6, 0xfc43a465, 0xbc5b0667, 0xfc01b601, + 0xbc03e727, 0xf83e586d, 0xb821e871, 0x383b7a77, + 0x782a5a85, 0xf870d85d, 0xb875fa30, 0x38705a0a, + 0x787adb77, 0x38a7780d, 0x78b248af, 0x78f27a92, + 0xb8b149de, 0xfc7a58d3, 0xbc62cafe, 0xfc274adb, + 0xbc3afb09, 0xf91f778e, 0xb91eb9b0, 0x39186b74, + 0x791988f0, 0xf95e4ea5, 0xb95de900, 0x395f90e1, + 0x7959bdc1, 0x399b9b26, 0x79996209, 0x79dc309b, + 0xb99c8e02, 0xfd5fa345, 0xbd5efdb3, 0xfd1a20f6, + 0xbd1e8928, 0x58ffdf7a, 0x18ffdf4c, 0xf882f140, + 0xd8002280, 0xf8b47aa0, 0xf99ed1a0, 0x1a03011a, + 0x3a0703c9, 0x5a0b01f8, 0x7a0b02a4, 0x9a1e022f, + 0xba1001e6, 0xda0a0041, 0xfa0b0089, 0x0b3167b7, + 0x2b2bed6f, 0xcb2753c2, 0x6b3a867e, 0x8b2c6c02, + 0xab30902e, 0xcb378ecf, 0xeb3c4480, 0x3a5220ab, + 0x7a552248, 0xba5131ef, 0xfa5711a6, 0x3a493b8f, + 0x7a4c99c9, 0xba463ac2, 0xfa4c4aa0, 0x1a9cc2ae, + 0x1a91c5d9, 0x5a9920d1, 0x5a8e2455, 0x9a912163, + 0x9a9b27db, 0xda8581e0, 0xda882562, 0x5ac00262, + 0x5ac00596, 0x5ac00ac5, 0x5ac01363, 0x5ac01492, + 0xdac00376, 0xdac0054c, 0xdac00885, 0xdac00d56, + 0xdac010ed, 0xdac01546, 0x1adc0a02, 0x1ac80ee8, + 0x1ace2232, 0x1ad6273e, 0x1ac52850, 0x1ac02f8f, + 0x9ac10a8d, 0x9ad20fdc, 0x9ac92391, 0x9ac425b2, + 0x9ad02b0c, 0x9ad82d2e, 0x9bd87c94, 0x9b5c7cb2, + 0x1b114bb3, 0x1b0fcece, 0x9b0120ac, 0x9b0bc256, + 0x9b2c7960, 0x9b2db113, 0x9bb117cd, 0x9bb7a590, + 0x1e200a86, 0x1e2f18d5, 0x1e392938, 0x1e323b09, + 0x1e2a0b1a, 0x1e600a8c, 0x1e7019ec, 0x1e7d28d8, + 0x1e6e38d8, 0x1e6f0bb5, 0x1f017729, 0x1f0af68d, + 0x1f2b1d7c, 0x1f350787, 0x1f4f07be, 0x1f5be90c, + 0x1f6b6711, 0x1f68003e, 0x1e2040a1, 0x1e20c266, + 0x1e214004, 0x1e21c149, 0x1e22c1d4, 0x1e604260, + 0x1e60c25e, 0x1e614100, 0x1e61c100, 0x1e6243ce, + 0x1e3802d3, 0x9e380151, 0x1e7802bb, 0x9e780087, + 0x1e22033e, 0x9e220219, 0x1e620349, 0x9e620007, + 0x1e2601e0, 0x9e66008b, 0x1e2701fe, 0x9e6702e2, + 0x1e2a21c0, 0x1e6023c0, 0x1e202168, 0x1e602308, + 0x2922403c, 0x294c55d7, 0x697860e0, 0xa9085215, + 0xa9790f41, 0x29a2394c, 0x29e200e3, 0x69e660ba, + 0xa9b65910, 0xa9f711fa, 0x288e73a9, 0x28c81468, + 0x68e6119e, 0xa8b67a0e, 0xa8f3593b, 0x2820571a, + 0x287a25f4, 0xa83169af, 0xa84168a5, 0x0c407353, + 0x4cdfa1c1, 0x0cd96f1d, 0x4cdf2414, 0x0d40c379, + 0x4ddfcb5e, 0x0dcacea9, 0x4c408dc2, 0x0cdf864e, + 0x4d60c004, 0x0dffc832, 0x4dfbcc1a, 0x4cc34ac7, + 0x0c404aa5, 0x4d40e4fe, 0x4ddfeae7, 0x0dc6ed4f, + 0x4cdf0734, 0x0cd80365, 0x0d60e2a5, 0x0dffe773, + 0x0df6ebc6, 0xce6182e4, 0xce6d8583, 0xcec080db, + 0xce6a8aa9, 0xba5fd3e3, 0x3a5f03e5, 0xfa411be4, 0x7a42cbe2, 0x93df03ff, 0xc820ffff, 0x8822fc7f, 0xc8247cbf, 0x88267fff, 0x4e010fe0, 0x4e081fe1, 0x4e0c1fe1, 0x4e0a1fe1, 0x4e071fe1, 0x4cc0ac3f, @@ -1418,24 +1429,24 @@ Disassembly of section .text: 0x1e741000, 0x1e743000, 0x1e761000, 0x1e763000, 0x1e781000, 0x1e783000, 0x1e7a1000, 0x1e7a3000, 0x1e7c1000, 0x1e7c3000, 0x1e7e1000, 0x1e7e3000, - 0xf8358305, 0xf82d01ed, 0xf8361353, 0xf839234a, - 0xf82531fb, 0xf8335165, 0xf83a4080, 0xf83673d7, - 0xf832611c, 0xf8ad837d, 0xf8ab01a5, 0xf8a112b8, - 0xf8bb2311, 0xf8b230be, 0xf8a75336, 0xf8a4427a, - 0xf8a6707e, 0xf8b860b7, 0xf8f88392, 0xf8f300ff, - 0xf8ed1386, 0xf8e822af, 0xf8e2302d, 0xf8f1533d, - 0xf8f941d2, 0xf8ff7366, 0xf8f061e5, 0xf86b8072, - 0xf87a0054, 0xf86b1164, 0xf87e22f3, 0xf86331cf, - 0xf87e5296, 0xf8674305, 0xf87771f0, 0xf86b6013, - 0xb83c803c, 0xb82b0195, 0xb83d1240, 0xb8252320, - 0xb82e3340, 0xb83c53b2, 0xb82f43a1, 0xb828739a, - 0xb831608e, 0xb8b88039, 0xb8aa0231, 0xb8bd12b4, - 0xb8bd2189, 0xb8ab30a6, 0xb8b552a7, 0xb8aa4197, - 0xb8b57145, 0xb8be6254, 0xb8ed80b7, 0xb8ef00b8, - 0xb8e9132a, 0xb8f42231, 0xb8ec33d2, 0xb8e35323, - 0xb8fa4159, 0xb8e273eb, 0xb8e760a2, 0xb8608287, - 0xb865005f, 0xb87b1379, 0xb87e2358, 0xb86f32c2, - 0xb86053e3, 0xb86f4154, 0xb87671d5, 0xb866605e, + 0xf838807f, 0xf82500a6, 0xf8391189, 0xf8292136, + 0xf82e3024, 0xf83753be, 0xf835434d, 0xf8307169, + 0xf83562b1, 0xf8b98139, 0xf8a500d9, 0xf8b812ee, + 0xf8b32358, 0xf8af3057, 0xf8a650e7, 0xf8be41cf, + 0xf8bf70a7, 0xf8b46039, 0xf8f08232, 0xf8e0016f, + 0xf8e910f1, 0xf8e122f7, 0xf8f23061, 0xf8fb511f, + 0xf8e9417b, 0xf8f97063, 0xf8f06338, 0xf86683a2, + 0xf8770199, 0xf86912fd, 0xf87d2040, 0xf8733146, + 0xf871532d, 0xf8614337, 0xf87470da, 0xf86d6196, + 0xb8378378, 0xb8230287, 0xb82a12f5, 0xb829219a, + 0xb83a3377, 0xb82452ae, 0xb82a4120, 0xb82970cd, + 0xb82962bf, 0xb8ac817c, 0xb8a80180, 0xb8bd1027, + 0xb8bd233b, 0xb8bb3110, 0xb8ad53f2, 0xb8bc4300, + 0xb8bc71bc, 0xb8ae605d, 0xb8e8823c, 0xb8e4004a, + 0xb8e011dc, 0xb8e8208c, 0xb8e131b6, 0xb8f85286, + 0xb8ee408e, 0xb8fe71c2, 0xb8e262d2, 0xb8798239, + 0xb86400f3, 0xb873116f, 0xb877221d, 0xb87b3345, + 0xb87f501b, 0xb8764086, 0xb86d705e, 0xb873619a, }; // END Generated code -- do not edit diff --git a/src/hotspot/cpu/aarch64/assembler_aarch64.hpp b/src/hotspot/cpu/aarch64/assembler_aarch64.hpp index 2aad7cdbabd..e7790f3b018 100644 --- a/src/hotspot/cpu/aarch64/assembler_aarch64.hpp +++ b/src/hotspot/cpu/aarch64/assembler_aarch64.hpp @@ -2372,6 +2372,30 @@ public: #undef INSN +#define INSN(NAME, opc) \ + void NAME(FloatRegister Vd, SIMD_Arrangement T, FloatRegister Vn, FloatRegister Vm) { \ + starti; \ + assert(T == T2D, "arrangement must be T2D"); \ + f(0b11001110011, 31, 21), rf(Vm, 16), f(opc, 15, 10), rf(Vn, 5), rf(Vd, 0); \ + } + + INSN(sha512h, 0b100000); + INSN(sha512h2, 0b100001); + INSN(sha512su1, 0b100010); + +#undef INSN + +#define INSN(NAME, opc) \ + void NAME(FloatRegister Vd, SIMD_Arrangement T, FloatRegister Vn) { \ + starti; \ + assert(T == T2D, "arrangement must be T2D"); \ + f(opc, 31, 10), rf(Vn, 5), rf(Vd, 0); \ + } + + INSN(sha512su0, 0b1100111011000000100000); + +#undef INSN + #define INSN(NAME, opc) \ void NAME(FloatRegister Vd, FloatRegister Vn) { \ starti; \ diff --git a/src/hotspot/cpu/aarch64/stubGenerator_aarch64.cpp b/src/hotspot/cpu/aarch64/stubGenerator_aarch64.cpp index d4b7d29d70a..e7c375e192e 100644 --- a/src/hotspot/cpu/aarch64/stubGenerator_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/stubGenerator_aarch64.cpp @@ -3125,6 +3125,172 @@ class StubGenerator: public StubCodeGenerator { return start; } + // Arguments: + // + // Inputs: + // c_rarg0 - byte[] source+offset + // c_rarg1 - int[] SHA.state + // c_rarg2 - int offset + // c_rarg3 - int limit + // + address generate_sha512_implCompress(bool multi_block, const char *name) { + static const uint64_t round_consts[80] = { + 0x428A2F98D728AE22L, 0x7137449123EF65CDL, 0xB5C0FBCFEC4D3B2FL, + 0xE9B5DBA58189DBBCL, 0x3956C25BF348B538L, 0x59F111F1B605D019L, + 0x923F82A4AF194F9BL, 0xAB1C5ED5DA6D8118L, 0xD807AA98A3030242L, + 0x12835B0145706FBEL, 0x243185BE4EE4B28CL, 0x550C7DC3D5FFB4E2L, + 0x72BE5D74F27B896FL, 0x80DEB1FE3B1696B1L, 0x9BDC06A725C71235L, + 0xC19BF174CF692694L, 0xE49B69C19EF14AD2L, 0xEFBE4786384F25E3L, + 0x0FC19DC68B8CD5B5L, 0x240CA1CC77AC9C65L, 0x2DE92C6F592B0275L, + 0x4A7484AA6EA6E483L, 0x5CB0A9DCBD41FBD4L, 0x76F988DA831153B5L, + 0x983E5152EE66DFABL, 0xA831C66D2DB43210L, 0xB00327C898FB213FL, + 0xBF597FC7BEEF0EE4L, 0xC6E00BF33DA88FC2L, 0xD5A79147930AA725L, + 0x06CA6351E003826FL, 0x142929670A0E6E70L, 0x27B70A8546D22FFCL, + 0x2E1B21385C26C926L, 0x4D2C6DFC5AC42AEDL, 0x53380D139D95B3DFL, + 0x650A73548BAF63DEL, 0x766A0ABB3C77B2A8L, 0x81C2C92E47EDAEE6L, + 0x92722C851482353BL, 0xA2BFE8A14CF10364L, 0xA81A664BBC423001L, + 0xC24B8B70D0F89791L, 0xC76C51A30654BE30L, 0xD192E819D6EF5218L, + 0xD69906245565A910L, 0xF40E35855771202AL, 0x106AA07032BBD1B8L, + 0x19A4C116B8D2D0C8L, 0x1E376C085141AB53L, 0x2748774CDF8EEB99L, + 0x34B0BCB5E19B48A8L, 0x391C0CB3C5C95A63L, 0x4ED8AA4AE3418ACBL, + 0x5B9CCA4F7763E373L, 0x682E6FF3D6B2B8A3L, 0x748F82EE5DEFB2FCL, + 0x78A5636F43172F60L, 0x84C87814A1F0AB72L, 0x8CC702081A6439ECL, + 0x90BEFFFA23631E28L, 0xA4506CEBDE82BDE9L, 0xBEF9A3F7B2C67915L, + 0xC67178F2E372532BL, 0xCA273ECEEA26619CL, 0xD186B8C721C0C207L, + 0xEADA7DD6CDE0EB1EL, 0xF57D4F7FEE6ED178L, 0x06F067AA72176FBAL, + 0x0A637DC5A2C898A6L, 0x113F9804BEF90DAEL, 0x1B710B35131C471BL, + 0x28DB77F523047D84L, 0x32CAAB7B40C72493L, 0x3C9EBE0A15C9BEBCL, + 0x431D67C49C100D4CL, 0x4CC5D4BECB3E42B6L, 0x597F299CFC657E2AL, + 0x5FCB6FAB3AD6FAECL, 0x6C44198C4A475817L + }; + + // Double rounds for sha512. + #define sha512_dround(dr, i0, i1, i2, i3, i4, rc0, rc1, in0, in1, in2, in3, in4) \ + if (dr < 36) \ + __ ld1(v##rc1, __ T2D, __ post(rscratch2, 16)); \ + __ addv(v5, __ T2D, v##rc0, v##in0); \ + __ ext(v6, __ T16B, v##i2, v##i3, 8); \ + __ ext(v5, __ T16B, v5, v5, 8); \ + __ ext(v7, __ T16B, v##i1, v##i2, 8); \ + __ addv(v##i3, __ T2D, v##i3, v5); \ + if (dr < 32) { \ + __ ext(v5, __ T16B, v##in3, v##in4, 8); \ + __ sha512su0(v##in0, __ T2D, v##in1); \ + } \ + __ sha512h(v##i3, __ T2D, v6, v7); \ + if (dr < 32) \ + __ sha512su1(v##in0, __ T2D, v##in2, v5); \ + __ addv(v##i4, __ T2D, v##i1, v##i3); \ + __ sha512h2(v##i3, __ T2D, v##i1, v##i0); \ + + __ align(CodeEntryAlignment); + StubCodeMark mark(this, "StubRoutines", name); + address start = __ pc(); + + Register buf = c_rarg0; + Register state = c_rarg1; + Register ofs = c_rarg2; + Register limit = c_rarg3; + + __ stpd(v8, v9, __ pre(sp, -64)); + __ stpd(v10, v11, Address(sp, 16)); + __ stpd(v12, v13, Address(sp, 32)); + __ stpd(v14, v15, Address(sp, 48)); + + Label sha512_loop; + + // load state + __ ld1(v8, v9, v10, v11, __ T2D, state); + + // load first 4 round constants + __ lea(rscratch1, ExternalAddress((address)round_consts)); + __ ld1(v20, v21, v22, v23, __ T2D, __ post(rscratch1, 64)); + + __ BIND(sha512_loop); + // load 128B of data into v12..v19 + __ ld1(v12, v13, v14, v15, __ T2D, __ post(buf, 64)); + __ ld1(v16, v17, v18, v19, __ T2D, __ post(buf, 64)); + __ rev64(v12, __ T16B, v12); + __ rev64(v13, __ T16B, v13); + __ rev64(v14, __ T16B, v14); + __ rev64(v15, __ T16B, v15); + __ rev64(v16, __ T16B, v16); + __ rev64(v17, __ T16B, v17); + __ rev64(v18, __ T16B, v18); + __ rev64(v19, __ T16B, v19); + + __ mov(rscratch2, rscratch1); + + __ mov(v0, __ T16B, v8); + __ mov(v1, __ T16B, v9); + __ mov(v2, __ T16B, v10); + __ mov(v3, __ T16B, v11); + + sha512_dround( 0, 0, 1, 2, 3, 4, 20, 24, 12, 13, 19, 16, 17); + sha512_dround( 1, 3, 0, 4, 2, 1, 21, 25, 13, 14, 12, 17, 18); + sha512_dround( 2, 2, 3, 1, 4, 0, 22, 26, 14, 15, 13, 18, 19); + sha512_dround( 3, 4, 2, 0, 1, 3, 23, 27, 15, 16, 14, 19, 12); + sha512_dround( 4, 1, 4, 3, 0, 2, 24, 28, 16, 17, 15, 12, 13); + sha512_dround( 5, 0, 1, 2, 3, 4, 25, 29, 17, 18, 16, 13, 14); + sha512_dround( 6, 3, 0, 4, 2, 1, 26, 30, 18, 19, 17, 14, 15); + sha512_dround( 7, 2, 3, 1, 4, 0, 27, 31, 19, 12, 18, 15, 16); + sha512_dround( 8, 4, 2, 0, 1, 3, 28, 24, 12, 13, 19, 16, 17); + sha512_dround( 9, 1, 4, 3, 0, 2, 29, 25, 13, 14, 12, 17, 18); + sha512_dround(10, 0, 1, 2, 3, 4, 30, 26, 14, 15, 13, 18, 19); + sha512_dround(11, 3, 0, 4, 2, 1, 31, 27, 15, 16, 14, 19, 12); + sha512_dround(12, 2, 3, 1, 4, 0, 24, 28, 16, 17, 15, 12, 13); + sha512_dround(13, 4, 2, 0, 1, 3, 25, 29, 17, 18, 16, 13, 14); + sha512_dround(14, 1, 4, 3, 0, 2, 26, 30, 18, 19, 17, 14, 15); + sha512_dround(15, 0, 1, 2, 3, 4, 27, 31, 19, 12, 18, 15, 16); + sha512_dround(16, 3, 0, 4, 2, 1, 28, 24, 12, 13, 19, 16, 17); + sha512_dround(17, 2, 3, 1, 4, 0, 29, 25, 13, 14, 12, 17, 18); + sha512_dround(18, 4, 2, 0, 1, 3, 30, 26, 14, 15, 13, 18, 19); + sha512_dround(19, 1, 4, 3, 0, 2, 31, 27, 15, 16, 14, 19, 12); + sha512_dround(20, 0, 1, 2, 3, 4, 24, 28, 16, 17, 15, 12, 13); + sha512_dround(21, 3, 0, 4, 2, 1, 25, 29, 17, 18, 16, 13, 14); + sha512_dround(22, 2, 3, 1, 4, 0, 26, 30, 18, 19, 17, 14, 15); + sha512_dround(23, 4, 2, 0, 1, 3, 27, 31, 19, 12, 18, 15, 16); + sha512_dround(24, 1, 4, 3, 0, 2, 28, 24, 12, 13, 19, 16, 17); + sha512_dround(25, 0, 1, 2, 3, 4, 29, 25, 13, 14, 12, 17, 18); + sha512_dround(26, 3, 0, 4, 2, 1, 30, 26, 14, 15, 13, 18, 19); + sha512_dround(27, 2, 3, 1, 4, 0, 31, 27, 15, 16, 14, 19, 12); + sha512_dround(28, 4, 2, 0, 1, 3, 24, 28, 16, 17, 15, 12, 13); + sha512_dround(29, 1, 4, 3, 0, 2, 25, 29, 17, 18, 16, 13, 14); + sha512_dround(30, 0, 1, 2, 3, 4, 26, 30, 18, 19, 17, 14, 15); + sha512_dround(31, 3, 0, 4, 2, 1, 27, 31, 19, 12, 18, 15, 16); + sha512_dround(32, 2, 3, 1, 4, 0, 28, 24, 12, 0, 0, 0, 0); + sha512_dround(33, 4, 2, 0, 1, 3, 29, 25, 13, 0, 0, 0, 0); + sha512_dround(34, 1, 4, 3, 0, 2, 30, 26, 14, 0, 0, 0, 0); + sha512_dround(35, 0, 1, 2, 3, 4, 31, 27, 15, 0, 0, 0, 0); + sha512_dround(36, 3, 0, 4, 2, 1, 24, 0, 16, 0, 0, 0, 0); + sha512_dround(37, 2, 3, 1, 4, 0, 25, 0, 17, 0, 0, 0, 0); + sha512_dround(38, 4, 2, 0, 1, 3, 26, 0, 18, 0, 0, 0, 0); + sha512_dround(39, 1, 4, 3, 0, 2, 27, 0, 19, 0, 0, 0, 0); + + __ addv(v8, __ T2D, v8, v0); + __ addv(v9, __ T2D, v9, v1); + __ addv(v10, __ T2D, v10, v2); + __ addv(v11, __ T2D, v11, v3); + + if (multi_block) { + __ add(ofs, ofs, 128); + __ cmp(ofs, limit); + __ br(Assembler::LE, sha512_loop); + __ mov(c_rarg0, ofs); // return ofs + } + + __ st1(v8, v9, v10, v11, __ T2D, state); + + __ ldpd(v14, v15, Address(sp, 48)); + __ ldpd(v12, v13, Address(sp, 32)); + __ ldpd(v10, v11, Address(sp, 16)); + __ ldpd(v8, v9, __ post(sp, 64)); + + __ ret(lr); + + return start; + } + // Safefetch stubs. void generate_safefetch(const char* name, int size, address* entry, address* fault_pc, address* continuation_pc) { @@ -5852,6 +6018,10 @@ class StubGenerator: public StubCodeGenerator { StubRoutines::_sha256_implCompress = generate_sha256_implCompress(false, "sha256_implCompress"); StubRoutines::_sha256_implCompressMB = generate_sha256_implCompress(true, "sha256_implCompressMB"); } + if (UseSHA512Intrinsics) { + StubRoutines::_sha512_implCompress = generate_sha512_implCompress(false, "sha512_implCompress"); + StubRoutines::_sha512_implCompressMB = generate_sha512_implCompress(true, "sha512_implCompressMB"); + } // generate Adler32 intrinsics code if (UseAdler32Intrinsics) { diff --git a/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp b/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp index 25d6b853378..ab8c27ad716 100644 --- a/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/vm_version_aarch64.cpp @@ -62,6 +62,10 @@ #define HWCAP_ATOMICS (1<<8) #endif +#ifndef HWCAP_SHA512 +#define HWCAP_SHA512 (1 << 21) +#endif + int VM_Version::_cpu; int VM_Version::_model; int VM_Version::_model2; @@ -285,6 +289,7 @@ void VM_Version::get_processor_features() { if (auxv & HWCAP_AES) strcat(buf, ", aes"); if (auxv & HWCAP_SHA1) strcat(buf, ", sha1"); if (auxv & HWCAP_SHA2) strcat(buf, ", sha256"); + if (auxv & HWCAP_SHA512) strcat(buf, ", sha512"); if (auxv & HWCAP_ATOMICS) strcat(buf, ", lse"); _features_string = os::strdup(buf); @@ -390,7 +395,12 @@ void VM_Version::get_processor_features() { FLAG_SET_DEFAULT(UseSHA256Intrinsics, false); } - if (UseSHA512Intrinsics) { + if (UseSHA && (auxv & HWCAP_SHA512)) { + // Do not auto-enable UseSHA512Intrinsics until it has been fully tested on hardware + // if (FLAG_IS_DEFAULT(UseSHA512Intrinsics)) { + // FLAG_SET_DEFAULT(UseSHA512Intrinsics, true); + // } + } else if (UseSHA512Intrinsics) { warning("Intrinsics for SHA-384 and SHA-512 crypto hash functions not available on this CPU."); FLAG_SET_DEFAULT(UseSHA512Intrinsics, false); } From 4d3baa2d377c5c300c104c5a31f447310326203d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Markus=20Gr=C3=B6nlund?= Date: Fri, 7 Aug 2020 11:52:09 +0200 Subject: [PATCH 21/53] 8251179: Word tearing problem with _last_sweep Reviewed-by: coleenp, dholmes, kbarrett --- .../jfr/leakprofiler/checkpoint/eventEmitter.cpp | 2 +- .../checkpoint/objectSampleCheckpoint.cpp | 4 ++-- .../jfr/leakprofiler/sampling/objectSampler.cpp | 12 +++++++----- .../jfr/leakprofiler/sampling/objectSampler.hpp | 3 +-- 4 files changed, 11 insertions(+), 10 deletions(-) diff --git a/src/hotspot/share/jfr/leakprofiler/checkpoint/eventEmitter.cpp b/src/hotspot/share/jfr/leakprofiler/checkpoint/eventEmitter.cpp index 4dc703a9d1a..0cb3841a64f 100644 --- a/src/hotspot/share/jfr/leakprofiler/checkpoint/eventEmitter.cpp +++ b/src/hotspot/share/jfr/leakprofiler/checkpoint/eventEmitter.cpp @@ -74,7 +74,7 @@ size_t EventEmitter::write_events(ObjectSampler* object_sampler, EdgeStore* edge assert(object_sampler != NULL, "invariant"); assert(edge_store != NULL, "invariant"); - const jlong last_sweep = emit_all ? max_jlong : object_sampler->last_sweep().value(); + const jlong last_sweep = emit_all ? max_jlong : ObjectSampler::last_sweep(); size_t count = 0; // First pass associates a live sample with its immediate edge diff --git a/src/hotspot/share/jfr/leakprofiler/checkpoint/objectSampleCheckpoint.cpp b/src/hotspot/share/jfr/leakprofiler/checkpoint/objectSampleCheckpoint.cpp index 45779b14c71..0faf97ac7cf 100644 --- a/src/hotspot/share/jfr/leakprofiler/checkpoint/objectSampleCheckpoint.cpp +++ b/src/hotspot/share/jfr/leakprofiler/checkpoint/objectSampleCheckpoint.cpp @@ -133,7 +133,7 @@ int ObjectSampleCheckpoint::save_mark_words(const ObjectSampler* sampler, Object if (sampler->last() == NULL) { return 0; } - SampleMarker sample_marker(marker, emit_all ? max_jlong : sampler->last_sweep().value()); + SampleMarker sample_marker(marker, emit_all ? max_jlong : ObjectSampler::last_sweep()); iterate_samples(sample_marker, true); return sample_marker.count(); } @@ -361,7 +361,7 @@ class BlobWriter { static void write_sample_blobs(const ObjectSampler* sampler, bool emit_all, Thread* thread) { // sample set is predicated on time of last sweep - const jlong last_sweep = emit_all ? max_jlong : sampler->last_sweep().value(); + const jlong last_sweep = emit_all ? max_jlong : ObjectSampler::last_sweep(); JfrCheckpointWriter writer(thread, false); BlobWriter cbw(sampler, writer, last_sweep); iterate_samples(cbw, true); diff --git a/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.cpp b/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.cpp index 9c956edf73d..273d8ab12d5 100644 --- a/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.cpp +++ b/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.cpp @@ -34,6 +34,7 @@ #include "jfr/recorder/checkpoint/jfrCheckpointManager.hpp" #include "jfr/recorder/stacktrace/jfrStackTraceRepository.hpp" #include "jfr/support/jfrThreadLocal.hpp" +#include "jfr/utilities/jfrTime.hpp" #include "jfr/utilities/jfrTryLock.hpp" #include "logging/log.hpp" #include "memory/universe.hpp" @@ -44,7 +45,8 @@ #include "runtime/thread.hpp" // Timestamp of when the gc last processed the set of sampled objects. -static JfrTicks _last_sweep; +// Atomic access to prevent word tearing on 32-bit platforms. +static volatile int64_t _last_sweep; // Condition variable to communicate that some sampled objects have been cleared by the gc // and can therefore be removed from the sample priority queue. @@ -66,7 +68,7 @@ void ObjectSampler::oop_storage_gc_notification(size_t num_dead) { // instance was created concurrently. This allows for a small race where cleaning // could be done again. Atomic::store(&_dead_samples, true); - _last_sweep = JfrTicks::now(); + Atomic::store(&_last_sweep, (int64_t)JfrTicks::now().value()); } } @@ -90,8 +92,8 @@ ObjectSampler::ObjectSampler(size_t size) : _total_allocated(0), _threshold(0), _size(size) { - _last_sweep = JfrTicks::now(); Atomic::store(&_dead_samples, false); + Atomic::store(&_last_sweep, (int64_t)JfrTicks::now().value()); } ObjectSampler::~ObjectSampler() { @@ -285,6 +287,6 @@ ObjectSample* ObjectSampler::item_at(int index) { ); } -const JfrTicks& ObjectSampler::last_sweep() { - return _last_sweep; +int64_t ObjectSampler::last_sweep() { + return Atomic::load(&_last_sweep); } diff --git a/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.hpp b/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.hpp index 962735a309c..1e942cba5b0 100644 --- a/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.hpp +++ b/src/hotspot/share/jfr/leakprofiler/sampling/objectSampler.hpp @@ -26,7 +26,6 @@ #define SHARE_JFR_LEAKPROFILER_SAMPLING_OBJECTSAMPLER_HPP #include "memory/allocation.hpp" -#include "jfr/utilities/jfrTime.hpp" typedef u8 traceid; @@ -80,7 +79,7 @@ class ObjectSampler : public CHeapObj { // For operations that require exclusive access (non-safepoint) static ObjectSampler* acquire(); static void release(); - static const JfrTicks& last_sweep(); + static int64_t last_sweep(); const ObjectSample* first() const; ObjectSample* last() const; const ObjectSample* last_resolved() const; From 0c9e0c2e7fbefe7449144c5ada8ae2a20931bfc7 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Fri, 7 Aug 2020 07:53:26 -0400 Subject: [PATCH 22/53] 8244997: Convert the JavaThread::_threadObj oop to use OopStorage Move the oop and handle releasing it in the service thread. Remove Universe::oops_do from callers. Co-authored-by: Erik Osterlund Co-authored-by: Tom Rodriguez Reviewed-by: dholmes, zgu, eosterlund, cjplummer --- src/hotspot/cpu/aarch64/c1_LIR_aarch64.cpp | 4 +- src/hotspot/cpu/arm/c1_LIR_arm.cpp | 6 +- src/hotspot/cpu/ppc/c1_LIR_ppc.cpp | 6 +- src/hotspot/cpu/s390/c1_LIR_s390.cpp | 4 +- src/hotspot/cpu/x86/c1_LIR_x86.cpp | 6 +- src/hotspot/share/c1/c1_LIRGenerator.cpp | 6 +- src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp | 1 - src/hotspot/share/gc/g1/g1GCPhaseTimes.hpp | 1 - src/hotspot/share/gc/g1/g1RootProcessor.cpp | 8 --- .../share/gc/parallel/psParallelCompact.cpp | 5 -- src/hotspot/share/gc/parallel/psRootType.hpp | 3 +- src/hotspot/share/gc/parallel/psScavenge.cpp | 4 -- .../share/gc/shared/c2/barrierSetC2.cpp | 13 +++-- .../share/gc/shared/c2/barrierSetC2.hpp | 4 +- .../share/gc/shared/genCollectedHeap.cpp | 4 -- .../share/gc/shared/genCollectedHeap.hpp | 1 - src/hotspot/share/gc/shared/oopStorageSet.hpp | 4 +- .../gc/shenandoah/shenandoahPhaseTimings.hpp | 1 - .../gc/shenandoah/shenandoahRootProcessor.cpp | 3 - .../gc/shenandoah/shenandoahRootProcessor.hpp | 1 - .../gc/shenandoah/shenandoahRootVerifier.cpp | 4 -- src/hotspot/share/gc/z/zRootsIterator.cpp | 8 --- src/hotspot/share/gc/z/zRootsIterator.hpp | 2 - .../leakprofiler/chains/rootSetClosure.cpp | 2 - .../leakprofiler/checkpoint/rootResolver.cpp | 14 ----- src/hotspot/share/jvmci/vmStructs_jvmci.cpp | 2 +- src/hotspot/share/memory/universe.cpp | 5 -- src/hotspot/share/memory/universe.hpp | 6 -- src/hotspot/share/opto/graphKit.cpp | 2 +- src/hotspot/share/opto/library_call.cpp | 5 +- src/hotspot/share/opto/memnode.cpp | 4 +- src/hotspot/share/prims/jvmtiTagMap.cpp | 2 +- src/hotspot/share/runtime/serviceThread.cpp | 37 +++++++++++++ src/hotspot/share/runtime/serviceThread.hpp | 3 +- src/hotspot/share/runtime/thread.cpp | 55 +++++++++++++------ src/hotspot/share/runtime/thread.hpp | 9 ++- src/hotspot/share/runtime/threadSMR.cpp | 50 ----------------- src/hotspot/share/runtime/threadSMR.hpp | 27 --------- src/hotspot/share/runtime/vmStructs.cpp | 2 +- src/hotspot/share/services/heapDumper.cpp | 5 +- .../sun/jvm/hotspot/runtime/JavaThread.java | 9 ++- .../hotspot/GraalHotSpotVMConfig.java | 14 ++++- .../meta/HotSpotGraphBuilderPlugins.java | 12 +++- .../replacements/HotSpotReplacementsUtil.java | 2 + .../jtreg/gc/g1/TestGCLogMessages.java | 1 - .../gc/collection/TestG1ParallelPhases.java | 2 +- 46 files changed, 162 insertions(+), 207 deletions(-) diff --git a/src/hotspot/cpu/aarch64/c1_LIR_aarch64.cpp b/src/hotspot/cpu/aarch64/c1_LIR_aarch64.cpp index ce75dc552a9..58e1cf5ae63 100644 --- a/src/hotspot/cpu/aarch64/c1_LIR_aarch64.cpp +++ b/src/hotspot/cpu/aarch64/c1_LIR_aarch64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -48,7 +48,7 @@ LIR_Opr LIR_OprFact::double_fpu(int reg1, int reg2) { void LIR_Address::verify() const { assert(base()->is_cpu_register(), "wrong base operand"); assert(index()->is_illegal() || index()->is_double_cpu() || index()->is_single_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); } #endif // PRODUCT diff --git a/src/hotspot/cpu/arm/c1_LIR_arm.cpp b/src/hotspot/cpu/arm/c1_LIR_arm.cpp index 791c6985137..60bd5265bfb 100644 --- a/src/hotspot/cpu/arm/c1_LIR_arm.cpp +++ b/src/hotspot/cpu/arm/c1_LIR_arm.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,12 +52,12 @@ void LIR_Address::verify() const { // be handled by the back-end or will be rejected if not. #ifdef _LP64 assert(index()->is_illegal() || index()->is_double_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); #else assert(base()->is_single_cpu(), "wrong base operand"); assert(index()->is_illegal() || index()->is_single_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, "wrong type for addresses"); #endif } diff --git a/src/hotspot/cpu/ppc/c1_LIR_ppc.cpp b/src/hotspot/cpu/ppc/c1_LIR_ppc.cpp index ef9b0833d38..fb234e82985 100644 --- a/src/hotspot/cpu/ppc/c1_LIR_ppc.cpp +++ b/src/hotspot/cpu/ppc/c1_LIR_ppc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -52,12 +52,12 @@ void LIR_Address::verify() const { #ifdef _LP64 assert(base()->is_cpu_register(), "wrong base operand"); assert(index()->is_illegal() || index()->is_double_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); #else assert(base()->is_single_cpu(), "wrong base operand"); assert(index()->is_illegal() || index()->is_single_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, "wrong type for addresses"); #endif } diff --git a/src/hotspot/cpu/s390/c1_LIR_s390.cpp b/src/hotspot/cpu/s390/c1_LIR_s390.cpp index 9507ca08561..3c46915e475 100644 --- a/src/hotspot/cpu/s390/c1_LIR_s390.cpp +++ b/src/hotspot/cpu/s390/c1_LIR_s390.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016 SAP SE. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -51,7 +51,7 @@ LIR_Opr LIR_OprFact::double_fpu(int reg1, int reg2) { void LIR_Address::verify() const { assert(base()->is_cpu_register(), "wrong base operand"); assert(index()->is_illegal() || index()->is_double_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); } #endif // PRODUCT diff --git a/src/hotspot/cpu/x86/c1_LIR_x86.cpp b/src/hotspot/cpu/x86/c1_LIR_x86.cpp index 92277ee0631..f7e3392d2e5 100644 --- a/src/hotspot/cpu/x86/c1_LIR_x86.cpp +++ b/src/hotspot/cpu/x86/c1_LIR_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -62,12 +62,12 @@ void LIR_Address::verify() const { #ifdef _LP64 assert(base()->is_cpu_register(), "wrong base operand"); assert(index()->is_illegal() || index()->is_double_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_LONG || base()->type() == T_METADATA, "wrong type for addresses"); #else assert(base()->is_single_cpu(), "wrong base operand"); assert(index()->is_illegal() || index()->is_single_cpu(), "wrong index operand"); - assert(base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, + assert(base()->type() == T_ADDRESS || base()->type() == T_OBJECT || base()->type() == T_INT || base()->type() == T_METADATA, "wrong type for addresses"); #endif } diff --git a/src/hotspot/share/c1/c1_LIRGenerator.cpp b/src/hotspot/share/c1/c1_LIRGenerator.cpp index 781839cd279..8fd7576526c 100644 --- a/src/hotspot/share/c1/c1_LIRGenerator.cpp +++ b/src/hotspot/share/c1/c1_LIRGenerator.cpp @@ -1315,8 +1315,12 @@ void LIRGenerator::do_isPrimitive(Intrinsic* x) { // Example: Thread.currentThread() void LIRGenerator::do_currentThread(Intrinsic* x) { assert(x->number_of_arguments() == 0, "wrong type"); + LIR_Opr temp = new_register(T_ADDRESS); LIR_Opr reg = rlock_result(x); - __ move_wide(new LIR_Address(getThreadPointer(), in_bytes(JavaThread::threadObj_offset()), T_OBJECT), reg); + __ move(new LIR_Address(getThreadPointer(), in_bytes(JavaThread::threadObj_offset()), T_ADDRESS), temp); + // threadObj = ((OopHandle)_threadObj)->resolve(); + access_load(IN_NATIVE, T_OBJECT, + LIR_OprFact::address(new LIR_Address(temp, T_OBJECT)), reg); } diff --git a/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp b/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp index 598a98be07a..2c3ae1e711f 100644 --- a/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp +++ b/src/hotspot/share/gc/g1/g1GCPhaseTimes.cpp @@ -58,7 +58,6 @@ G1GCPhaseTimes::G1GCPhaseTimes(STWGCTimer* gc_timer, uint max_gc_threads) : // Root scanning phases _gc_par_phases[ThreadRoots] = new WorkerDataArray("ThreadRoots", "Thread Roots (ms):", max_gc_threads); - _gc_par_phases[UniverseRoots] = new WorkerDataArray("UniverseRoots", "Universe Roots (ms):", max_gc_threads); _gc_par_phases[ObjectSynchronizerRoots] = new WorkerDataArray("ObjectSynchronizerRoots", "ObjectSynchronizer Roots (ms):", max_gc_threads); _gc_par_phases[CLDGRoots] = new WorkerDataArray("CLDGRoots", "CLDG Roots (ms):", max_gc_threads); AOT_ONLY(_gc_par_phases[AOTCodeRoots] = new WorkerDataArray("AOTCodeRoots", "AOT Root Scan (ms):", max_gc_threads);) diff --git a/src/hotspot/share/gc/g1/g1GCPhaseTimes.hpp b/src/hotspot/share/gc/g1/g1GCPhaseTimes.hpp index 6d1484552f9..1daebe1e41f 100644 --- a/src/hotspot/share/gc/g1/g1GCPhaseTimes.hpp +++ b/src/hotspot/share/gc/g1/g1GCPhaseTimes.hpp @@ -48,7 +48,6 @@ class G1GCPhaseTimes : public CHeapObj { GCWorkerStart, ExtRootScan, ThreadRoots, - UniverseRoots, ObjectSynchronizerRoots, CLDGRoots, AOT_ONLY(AOTCodeRoots COMMA) diff --git a/src/hotspot/share/gc/g1/g1RootProcessor.cpp b/src/hotspot/share/gc/g1/g1RootProcessor.cpp index f43304f1061..d70ad7c4cf5 100644 --- a/src/hotspot/share/gc/g1/g1RootProcessor.cpp +++ b/src/hotspot/share/gc/g1/g1RootProcessor.cpp @@ -43,7 +43,6 @@ #include "gc/shared/oopStorageSetParState.inline.hpp" #include "gc/shared/referenceProcessor.hpp" #include "memory/allocation.inline.hpp" -#include "memory/universe.hpp" #include "runtime/mutex.hpp" #include "utilities/macros.hpp" @@ -181,13 +180,6 @@ void G1RootProcessor::process_vm_roots(G1RootClosures* closures, uint worker_id) { OopClosure* strong_roots = closures->strong_oops(); - { - G1GCParPhaseTimesTracker x(phase_times, G1GCPhaseTimes::UniverseRoots, worker_id); - if (_process_strong_tasks.try_claim_task(G1RP_PS_Universe_oops_do)) { - Universe::oops_do(strong_roots); - } - } - { G1GCParPhaseTimesTracker x(phase_times, G1GCPhaseTimes::ObjectSynchronizerRoots, worker_id); if (_process_strong_tasks.try_claim_task(G1RP_PS_ObjectSynchronizer_oops_do)) { diff --git a/src/hotspot/share/gc/parallel/psParallelCompact.cpp b/src/hotspot/share/gc/parallel/psParallelCompact.cpp index a9bc67c75cb..b7bb059d77f 100644 --- a/src/hotspot/share/gc/parallel/psParallelCompact.cpp +++ b/src/hotspot/share/gc/parallel/psParallelCompact.cpp @@ -2008,10 +2008,6 @@ static void mark_from_roots_work(ParallelRootType::Value root_type, uint worker_ PCMarkAndPushClosure mark_and_push_closure(cm); switch (root_type) { - case ParallelRootType::universe: - Universe::oops_do(&mark_and_push_closure); - break; - case ParallelRootType::object_synchronizer: ObjectSynchronizer::oops_do(&mark_and_push_closure); break; @@ -2225,7 +2221,6 @@ void PSParallelCompact::adjust_roots(ParCompactionManager* cm) { PCAdjustPointerClosure oop_closure(cm); // General strong roots. - Universe::oops_do(&oop_closure); Threads::oops_do(&oop_closure, NULL); ObjectSynchronizer::oops_do(&oop_closure); OopStorageSet::strong_oops_do(&oop_closure); diff --git a/src/hotspot/share/gc/parallel/psRootType.hpp b/src/hotspot/share/gc/parallel/psRootType.hpp index 8cced17f7f0..de60d8e01f6 100644 --- a/src/hotspot/share/gc/parallel/psRootType.hpp +++ b/src/hotspot/share/gc/parallel/psRootType.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,7 +34,6 @@ public: // The order reflects the order these roots are to be processed, // We do not want any holes in the enum as we enumerate these values by incrementing them. enum Value { - universe, object_synchronizer, class_loader_data, code_cache, diff --git a/src/hotspot/share/gc/parallel/psScavenge.cpp b/src/hotspot/share/gc/parallel/psScavenge.cpp index e44cf30348a..5625d3d5bfe 100644 --- a/src/hotspot/share/gc/parallel/psScavenge.cpp +++ b/src/hotspot/share/gc/parallel/psScavenge.cpp @@ -92,10 +92,6 @@ static void scavenge_roots_work(ParallelRootType::Value root_type, uint worker_i PSPromoteRootsClosure roots_to_old_closure(pm); switch (root_type) { - case ParallelRootType::universe: - Universe::oops_do(&roots_closure); - break; - case ParallelRootType::object_synchronizer: ObjectSynchronizer::oops_do(&roots_closure); break; diff --git a/src/hotspot/share/gc/shared/c2/barrierSetC2.cpp b/src/hotspot/share/gc/shared/c2/barrierSetC2.cpp index 393830bc44b..377391e24aa 100644 --- a/src/hotspot/share/gc/shared/c2/barrierSetC2.cpp +++ b/src/hotspot/share/gc/shared/c2/barrierSetC2.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -141,6 +141,7 @@ Node* BarrierSetC2::load_at_resolved(C2Access& access, const Type* val_type) con bool control_dependent = (decorators & C2_CONTROL_DEPENDENT_LOAD) != 0; bool unknown_control = (decorators & C2_UNKNOWN_CONTROL_LOAD) != 0; bool unsafe = (decorators & C2_UNSAFE_ACCESS) != 0; + bool immutable = (decorators & C2_IMMUTABLE_MEMORY) != 0; bool in_native = (decorators & IN_NATIVE) != 0; @@ -153,10 +154,14 @@ Node* BarrierSetC2::load_at_resolved(C2Access& access, const Type* val_type) con GraphKit* kit = parse_access.kit(); Node* control = control_dependent ? kit->control() : NULL; - if (in_native) { - load = kit->make_load(control, adr, val_type, access.type(), mo, dep, - requires_atomic_access, unaligned, + if (immutable) { + assert(!requires_atomic_access, "can't ensure atomicity"); + Compile* C = Compile::current(); + Node* mem = kit->immutable_memory(); + load = LoadNode::make(kit->gvn(), control, mem, adr, + adr_type, val_type, access.type(), mo, dep, unaligned, mismatched, unsafe, access.barrier_data()); + load = kit->gvn().transform(load); } else { load = kit->make_load(control, adr, val_type, access.type(), adr_type, mo, dep, requires_atomic_access, unaligned, mismatched, unsafe, diff --git a/src/hotspot/share/gc/shared/c2/barrierSetC2.hpp b/src/hotspot/share/gc/shared/c2/barrierSetC2.hpp index c962336d72d..91bbe5426b8 100644 --- a/src/hotspot/share/gc/shared/c2/barrierSetC2.hpp +++ b/src/hotspot/share/gc/shared/c2/barrierSetC2.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -54,6 +54,8 @@ const DecoratorSet C2_READ_ACCESS = DECORATOR_LAST << 8; const DecoratorSet C2_TIGHTLY_COUPLED_ALLOC = DECORATOR_LAST << 9; // Loads and stores from an arraycopy being optimized const DecoratorSet C2_ARRAY_COPY = DECORATOR_LAST << 10; +// Loads from immutable memory +const DecoratorSet C2_IMMUTABLE_MEMORY = DECORATOR_LAST << 11; class Compile; class ConnectionGraph; diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.cpp b/src/hotspot/share/gc/shared/genCollectedHeap.cpp index 5b30fc4d2fe..06df00ce324 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.cpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.cpp @@ -817,10 +817,6 @@ void GenCollectedHeap::process_roots(StrongRootsScope* scope, bool is_par = scope->n_threads() > 1; Threads::possibly_parallel_oops_do(is_par, strong_roots, roots_from_code_p); - if (_process_strong_tasks->try_claim_task(GCH_PS_Universe_oops_do)) { - Universe::oops_do(strong_roots); - } - if (_process_strong_tasks->try_claim_task(GCH_PS_ObjectSynchronizer_oops_do)) { ObjectSynchronizer::oops_do(strong_roots); } diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.hpp b/src/hotspot/share/gc/shared/genCollectedHeap.hpp index 6501b5fd553..af96e618544 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.hpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.hpp @@ -105,7 +105,6 @@ protected: // The set of potentially parallel tasks in root scanning. enum GCH_strong_roots_tasks { - GCH_PS_Universe_oops_do, GCH_PS_ObjectSynchronizer_oops_do, GCH_PS_OopStorageSet_oops_do, GCH_PS_ClassLoaderDataGraph_oops_do, diff --git a/src/hotspot/share/gc/shared/oopStorageSet.hpp b/src/hotspot/share/gc/shared/oopStorageSet.hpp index ff8a43bd65a..66c39414889 100644 --- a/src/hotspot/share/gc/shared/oopStorageSet.hpp +++ b/src/hotspot/share/gc/shared/oopStorageSet.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -37,7 +37,7 @@ class OopStorageSet : public AllStatic { public: // Must be updated when new OopStorages are introduced - static const uint strong_count = 2; + static const uint strong_count = 3; static const uint weak_count = 4 JFR_ONLY(+ 1); static const uint all_count = strong_count + weak_count; diff --git a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp index e7b6310b5f2..8a69ac7c8c6 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp @@ -37,7 +37,6 @@ class outputStream; f(CNT_PREFIX ## TotalWork, DESC_PREFIX "") \ f(CNT_PREFIX ## ThreadRoots, DESC_PREFIX "Thread Roots") \ f(CNT_PREFIX ## CodeCacheRoots, DESC_PREFIX "Code Cache Roots") \ - f(CNT_PREFIX ## UniverseRoots, DESC_PREFIX "Universe Roots") \ f(CNT_PREFIX ## VMStrongRoots, DESC_PREFIX "VM Strong Roots") \ f(CNT_PREFIX ## VMWeakRoots, DESC_PREFIX "VM Weak Roots") \ f(CNT_PREFIX ## ObjectSynchronizerRoots, DESC_PREFIX "Synchronizer Roots") \ diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.cpp b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.cpp index 4f8cebab6f9..39d7d2a9056 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.cpp @@ -37,7 +37,6 @@ #include "gc/shenandoah/shenandoahVMOperations.hpp" #include "memory/iterator.hpp" #include "memory/resourceArea.hpp" -#include "memory/universe.hpp" #include "runtime/thread.hpp" ShenandoahSerialRoot::ShenandoahSerialRoot(ShenandoahSerialRoot::OopsDo oops_do, @@ -53,12 +52,10 @@ void ShenandoahSerialRoot::oops_do(OopClosure* cl, uint worker_id) { } ShenandoahSerialRoots::ShenandoahSerialRoots(ShenandoahPhaseTimings::Phase phase) : - _universe_root(&Universe::oops_do, phase, ShenandoahPhaseTimings::UniverseRoots), _object_synchronizer_root(&ObjectSynchronizer::oops_do, phase, ShenandoahPhaseTimings::ObjectSynchronizerRoots) { } void ShenandoahSerialRoots::oops_do(OopClosure* cl, uint worker_id) { - _universe_root.oops_do(cl, worker_id); _object_synchronizer_root.oops_do(cl, worker_id); } diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.hpp b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.hpp index efafc134ce3..895e3444efd 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.hpp @@ -51,7 +51,6 @@ public: class ShenandoahSerialRoots { private: - ShenandoahSerialRoot _universe_root; ShenandoahSerialRoot _object_synchronizer_root; public: ShenandoahSerialRoots(ShenandoahPhaseTimings::Phase phase); diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp index 45f5139da36..c1d0394e617 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp @@ -37,7 +37,6 @@ #include "gc/shared/oopStorage.inline.hpp" #include "gc/shared/oopStorageSet.hpp" #include "gc/shared/weakProcessor.inline.hpp" -#include "memory/universe.hpp" #include "runtime/thread.hpp" #include "utilities/debug.hpp" @@ -75,7 +74,6 @@ void ShenandoahRootVerifier::oops_do(OopClosure* oops) { if (verify(SerialRoots)) { shenandoah_assert_safepoint(); - Universe::oops_do(oops); ObjectSynchronizer::oops_do(oops); } @@ -119,7 +117,6 @@ void ShenandoahRootVerifier::roots_do(OopClosure* oops) { CLDToOopClosure clds(oops, ClassLoaderData::_claim_none); ClassLoaderDataGraph::cld_do(&clds); - Universe::oops_do(oops); JNIHandles::oops_do(oops); ObjectSynchronizer::oops_do(oops); Universe::vm_global()->oops_do(oops); @@ -145,7 +142,6 @@ void ShenandoahRootVerifier::strong_roots_do(OopClosure* oops) { CLDToOopClosure clds(oops, ClassLoaderData::_claim_none); ClassLoaderDataGraph::roots_cld_do(&clds, NULL); - Universe::oops_do(oops); JNIHandles::oops_do(oops); ObjectSynchronizer::oops_do(oops); Universe::vm_global()->oops_do(oops); diff --git a/src/hotspot/share/gc/z/zRootsIterator.cpp b/src/hotspot/share/gc/z/zRootsIterator.cpp index 53b76f1f62c..a50772f96d1 100644 --- a/src/hotspot/share/gc/z/zRootsIterator.cpp +++ b/src/hotspot/share/gc/z/zRootsIterator.cpp @@ -54,7 +54,6 @@ static const ZStatSubPhase ZSubPhasePauseRootsSetup("Pause Roots Setup"); static const ZStatSubPhase ZSubPhasePauseRoots("Pause Roots"); static const ZStatSubPhase ZSubPhasePauseRootsTeardown("Pause Roots Teardown"); -static const ZStatSubPhase ZSubPhasePauseRootsUniverse("Pause Roots Universe"); static const ZStatSubPhase ZSubPhasePauseRootsObjectSynchronizer("Pause Roots ObjectSynchronizer"); static const ZStatSubPhase ZSubPhasePauseRootsJVMTIWeakExport("Pause Roots JVMTIWeakExport"); static const ZStatSubPhase ZSubPhasePauseRootsVMThread("Pause Roots VM Thread"); @@ -185,7 +184,6 @@ void ZJavaThreadsIterator::threads_do(ThreadClosure* cl) { ZRootsIterator::ZRootsIterator(bool visit_jvmti_weak_export) : _visit_jvmti_weak_export(visit_jvmti_weak_export), _java_threads_iter(), - _universe(this), _object_synchronizer(this), _jvmti_weak_export(this), _vm_thread(this), @@ -213,11 +211,6 @@ ZRootsIterator::~ZRootsIterator() { COMPILER2_OR_JVMCI_PRESENT(DerivedPointerTable::update_pointers()); } -void ZRootsIterator::do_universe(ZRootsIteratorClosure* cl) { - ZStatTimer timer(ZSubPhasePauseRootsUniverse); - Universe::oops_do(cl); -} - void ZRootsIterator::do_object_synchronizer(ZRootsIteratorClosure* cl) { ZStatTimer timer(ZSubPhasePauseRootsObjectSynchronizer); ObjectSynchronizer::oops_do(cl); @@ -248,7 +241,6 @@ void ZRootsIterator::do_code_cache(ZRootsIteratorClosure* cl) { void ZRootsIterator::oops_do(ZRootsIteratorClosure* cl) { ZStatTimer timer(ZSubPhasePauseRoots); - _universe.oops_do(cl); _object_synchronizer.oops_do(cl); _vm_thread.oops_do(cl); _java_threads.oops_do(cl); diff --git a/src/hotspot/share/gc/z/zRootsIterator.hpp b/src/hotspot/share/gc/z/zRootsIterator.hpp index 0f2496e0be7..ea60739b529 100644 --- a/src/hotspot/share/gc/z/zRootsIterator.hpp +++ b/src/hotspot/share/gc/z/zRootsIterator.hpp @@ -110,14 +110,12 @@ private: const bool _visit_jvmti_weak_export; ZJavaThreadsIterator _java_threads_iter; - void do_universe(ZRootsIteratorClosure* cl); void do_object_synchronizer(ZRootsIteratorClosure* cl); void do_jvmti_weak_export(ZRootsIteratorClosure* cl); void do_vm_thread(ZRootsIteratorClosure* cl); void do_java_threads(ZRootsIteratorClosure* cl); void do_code_cache(ZRootsIteratorClosure* cl); - ZSerialOopsDo _universe; ZSerialOopsDo _object_synchronizer; ZSerialOopsDo _jvmti_weak_export; ZSerialOopsDo _vm_thread; diff --git a/src/hotspot/share/jfr/leakprofiler/chains/rootSetClosure.cpp b/src/hotspot/share/jfr/leakprofiler/chains/rootSetClosure.cpp index e1c528b3156..947291bef0b 100644 --- a/src/hotspot/share/jfr/leakprofiler/chains/rootSetClosure.cpp +++ b/src/hotspot/share/jfr/leakprofiler/chains/rootSetClosure.cpp @@ -34,7 +34,6 @@ #include "jfr/leakprofiler/chains/edgeQueue.hpp" #include "jfr/leakprofiler/chains/rootSetClosure.hpp" #include "jfr/leakprofiler/utilities/unifiedOopRef.inline.hpp" -#include "memory/universe.hpp" #include "oops/access.inline.hpp" #include "oops/oop.inline.hpp" #include "runtime/synchronizer.hpp" @@ -73,7 +72,6 @@ void RootSetClosure::process() { // We don't follow code blob oops, because they have misaligned oops. Threads::oops_do(this, NULL); ObjectSynchronizer::oops_do(this); - Universe::oops_do(this); OopStorageSet::strong_oops_do(this); AOTLoader::oops_do(this); } diff --git a/src/hotspot/share/jfr/leakprofiler/checkpoint/rootResolver.cpp b/src/hotspot/share/jfr/leakprofiler/checkpoint/rootResolver.cpp index 17d3ba40e1d..be8d9ff0db8 100644 --- a/src/hotspot/share/jfr/leakprofiler/checkpoint/rootResolver.cpp +++ b/src/hotspot/share/jfr/leakprofiler/checkpoint/rootResolver.cpp @@ -33,7 +33,6 @@ #include "jfr/leakprofiler/checkpoint/rootResolver.hpp" #include "jfr/utilities/jfrThreadIterator.hpp" #include "memory/iterator.hpp" -#include "memory/universe.hpp" #include "oops/klass.hpp" #include "oops/oop.hpp" #include "prims/jvmtiThreadState.hpp" @@ -97,7 +96,6 @@ class ReferenceToRootClosure : public StackObj { bool do_cldg_roots(); bool do_object_synchronizer_roots(); - bool do_universe_roots(); bool do_oop_storage_roots(); bool do_string_table_roots(); bool do_aot_loader_roots(); @@ -138,13 +136,6 @@ bool ReferenceToRootClosure::do_object_synchronizer_roots() { return rlc.complete(); } -bool ReferenceToRootClosure::do_universe_roots() { - assert(!complete(), "invariant"); - ReferenceLocateClosure rlc(_callback, OldObjectRoot::_universe, OldObjectRoot::_type_undetermined, NULL); - Universe::oops_do(&rlc); - return rlc.complete(); -} - bool ReferenceToRootClosure::do_oop_storage_roots() { int i = 0; for (OopStorageSet::Iterator it = OopStorageSet::strong_iterator(); !it.is_end(); ++it, ++i) { @@ -185,11 +176,6 @@ bool ReferenceToRootClosure::do_roots() { return true; } - if (do_universe_roots()) { - _complete = true; - return true; - } - if (do_oop_storage_roots()) { _complete = true; return true; diff --git a/src/hotspot/share/jvmci/vmStructs_jvmci.cpp b/src/hotspot/share/jvmci/vmStructs_jvmci.cpp index 26968786571..f6aec1f3f1e 100644 --- a/src/hotspot/share/jvmci/vmStructs_jvmci.cpp +++ b/src/hotspot/share/jvmci/vmStructs_jvmci.cpp @@ -170,7 +170,7 @@ nonstatic_field(JVMCICompileState, _jvmti_can_post_on_exceptions, jbyte) \ nonstatic_field(JVMCICompileState, _jvmti_can_pop_frame, jbyte) \ \ - nonstatic_field(JavaThread, _threadObj, oop) \ + nonstatic_field(JavaThread, _threadObj, OopHandle) \ nonstatic_field(JavaThread, _anchor, JavaFrameAnchor) \ nonstatic_field(JavaThread, _vm_result, oop) \ volatile_nonstatic_field(JavaThread, _exception_oop, oop) \ diff --git a/src/hotspot/share/memory/universe.cpp b/src/hotspot/share/memory/universe.cpp index 1cf9b5d552b..992ff28892e 100644 --- a/src/hotspot/share/memory/universe.cpp +++ b/src/hotspot/share/memory/universe.cpp @@ -223,11 +223,6 @@ void Universe::basic_type_classes_do(KlassClosure *closure) { } } -void Universe::oops_do(OopClosure* f) { - - ThreadsSMRSupport::exiting_threads_oops_do(f); -} - void LatestMethodCache::metaspace_pointers_do(MetaspaceClosure* it) { it->push(&_klass); } diff --git a/src/hotspot/share/memory/universe.hpp b/src/hotspot/share/memory/universe.hpp index 652f566af46..d73b9cdac18 100644 --- a/src/hotspot/share/memory/universe.hpp +++ b/src/hotspot/share/memory/universe.hpp @@ -328,12 +328,6 @@ class Universe: AllStatic { static bool should_fill_in_stack_trace(Handle throwable); static void check_alignment(uintx size, uintx alignment, const char* name); - // Iteration - - // Apply "f" to the addresses of all the direct heap pointers maintained - // as static fields of "Universe". - static void oops_do(OopClosure* f); - // CDS support static void serialize(SerializeClosure* f); diff --git a/src/hotspot/share/opto/graphKit.cpp b/src/hotspot/share/opto/graphKit.cpp index d09380c0548..9861fd8800f 100644 --- a/src/hotspot/share/opto/graphKit.cpp +++ b/src/hotspot/share/opto/graphKit.cpp @@ -1614,7 +1614,7 @@ Node* GraphKit::access_load(Node* adr, // actual adress to load val at return top(); // Dead path ? } - C2AccessValuePtr addr(adr, NULL); + C2AccessValuePtr addr(adr, adr->bottom_type()->is_ptr()); C2ParseAccess access(this, decorators | C2_READ_ACCESS, bt, NULL, addr); if (access.is_raw()) { return _barrier_set->BarrierSetC2::load_at(access, val_type); diff --git a/src/hotspot/share/opto/library_call.cpp b/src/hotspot/share/opto/library_call.cpp index d8e09638e01..4e81922816f 100644 --- a/src/hotspot/share/opto/library_call.cpp +++ b/src/hotspot/share/opto/library_call.cpp @@ -1096,9 +1096,10 @@ Node* LibraryCallKit::generate_current_thread(Node* &tls_output) { const Type* thread_type = TypeOopPtr::make_from_klass(thread_klass)->cast_to_ptr_type(TypePtr::NotNull); Node* thread = _gvn.transform(new ThreadLocalNode()); Node* p = basic_plus_adr(top()/*!oop*/, thread, in_bytes(JavaThread::threadObj_offset())); - Node* threadObj = _gvn.transform(LoadNode::make(_gvn, NULL, immutable_memory(), p, p->bottom_type()->is_ptr(), thread_type, T_OBJECT, MemNode::unordered)); tls_output = thread; - return threadObj; + Node* thread_obj_handle = LoadNode::make(_gvn, NULL, immutable_memory(), p, p->bottom_type()->is_ptr(), TypeRawPtr::NOTNULL, T_ADDRESS, MemNode::unordered); + thread_obj_handle = _gvn.transform(thread_obj_handle); + return access_load(thread_obj_handle, thread_type, T_OBJECT, IN_NATIVE | C2_IMMUTABLE_MEMORY); } diff --git a/src/hotspot/share/opto/memnode.cpp b/src/hotspot/share/opto/memnode.cpp index dc113a94e6e..52edcca640f 100644 --- a/src/hotspot/share/opto/memnode.cpp +++ b/src/hotspot/share/opto/memnode.cpp @@ -811,7 +811,9 @@ bool LoadNode::is_immutable_value(Node* adr) { return (adr->is_AddP() && adr->in(AddPNode::Base)->is_top() && adr->in(AddPNode::Address)->Opcode() == Op_ThreadLocal && (adr->in(AddPNode::Offset)->find_intptr_t_con(-1) == - in_bytes(JavaThread::osthread_offset()))); + in_bytes(JavaThread::osthread_offset()) || + adr->in(AddPNode::Offset)->find_intptr_t_con(-1) == + in_bytes(JavaThread::threadObj_offset()))); } #endif diff --git a/src/hotspot/share/prims/jvmtiTagMap.cpp b/src/hotspot/share/prims/jvmtiTagMap.cpp index 33d0ca3f409..263d1ec0c82 100644 --- a/src/hotspot/share/prims/jvmtiTagMap.cpp +++ b/src/hotspot/share/prims/jvmtiTagMap.cpp @@ -3030,7 +3030,7 @@ inline bool VM_HeapWalkOperation::collect_simple_roots() { // Many of these won't be visible but others (such as instances of important // exceptions) will be visible. blk.set_kind(JVMTI_HEAP_REFERENCE_OTHER); - Universe::oops_do(&blk); + Universe::vm_global()->oops_do(&blk); if (blk.stopped()) { return false; } diff --git a/src/hotspot/share/runtime/serviceThread.cpp b/src/hotspot/share/runtime/serviceThread.cpp index 8ebdb14b5c1..dda2017f887 100644 --- a/src/hotspot/share/runtime/serviceThread.cpp +++ b/src/hotspot/share/runtime/serviceThread.cpp @@ -31,6 +31,7 @@ #include "gc/shared/oopStorage.hpp" #include "gc/shared/oopStorageSet.hpp" #include "memory/universe.hpp" +#include "oops/oopHandle.inline.hpp" #include "runtime/handles.inline.hpp" #include "runtime/interfaceSupport.inline.hpp" #include "runtime/javaCalls.hpp" @@ -53,6 +54,29 @@ JvmtiDeferredEvent* ServiceThread::_jvmti_event = NULL; // to add this field to the per-JavaThread event queue. TODO: fix this sometime later JvmtiDeferredEventQueue ServiceThread::_jvmti_service_queue; +// Defer releasing JavaThread OopHandle to the ServiceThread +class OopHandleList : public CHeapObj { + OopHandle _handle; + OopHandleList* _next; + public: + OopHandleList(OopHandle h, OopHandleList* next) : _handle(h), _next(next) {} + ~OopHandleList() { + _handle.release(JavaThread::thread_oop_storage()); + } + OopHandleList* next() const { return _next; } +}; + +static OopHandleList* _oop_handle_list = NULL; + +static void release_oop_handles() { + assert_lock_strong(Service_lock); + while (_oop_handle_list != NULL) { + OopHandleList* l = _oop_handle_list; + _oop_handle_list = l->next(); + delete l; + } +} + void ServiceThread::initialize() { EXCEPTION_MARK; @@ -139,6 +163,7 @@ void ServiceThread::service_thread_entry(JavaThread* jt, TRAPS) { (thread_id_table_work = ThreadIdTable::has_work()) | (protection_domain_table_work = SystemDictionary::pd_cache_table()->has_work()) | (oopstorage_work = OopStorage::has_cleanup_work_and_reset()) | + (_oop_handle_list != NULL) | (deflate_idle_monitors = ObjectSynchronizer::is_async_deflation_needed()) ) == 0) { // Wait until notified that there is some work to do. @@ -152,6 +177,11 @@ void ServiceThread::service_thread_entry(JavaThread* jt, TRAPS) { jvmti_event = _jvmti_service_queue.dequeue(); _jvmti_event = &jvmti_event; } + + // Release thread OopHandles in lock + if (_oop_handle_list != NULL) { + release_oop_handles(); + } } if (stringtable_work) { @@ -238,3 +268,10 @@ void ServiceThread::nmethods_do(CodeBlobClosure* cf) { _jvmti_service_queue.nmethods_do(cf); } } + +void ServiceThread::add_oop_handle_release(OopHandle handle) { + MutexLocker ml(Service_lock, Mutex::_no_safepoint_check_flag); + OopHandleList* new_head = new OopHandleList(handle, _oop_handle_list); + _oop_handle_list = new_head; + Service_lock->notify_all(); +} diff --git a/src/hotspot/share/runtime/serviceThread.hpp b/src/hotspot/share/runtime/serviceThread.hpp index d0650416dfb..f8bd3d9d65b 100644 --- a/src/hotspot/share/runtime/serviceThread.hpp +++ b/src/hotspot/share/runtime/serviceThread.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -52,6 +52,7 @@ class ServiceThread : public JavaThread { // Add event to the service thread event queue. static void enqueue_deferred_event(JvmtiDeferredEvent* event); + static void add_oop_handle_release(OopHandle handle); // GC support void oops_do(OopClosure* f, CodeBlobClosure* cf); diff --git a/src/hotspot/share/runtime/thread.cpp b/src/hotspot/share/runtime/thread.cpp index f71bc313ec3..0d0536fe4de 100644 --- a/src/hotspot/share/runtime/thread.cpp +++ b/src/hotspot/share/runtime/thread.cpp @@ -37,6 +37,8 @@ #include "gc/shared/barrierSet.hpp" #include "gc/shared/gcId.hpp" #include "gc/shared/gcLocker.inline.hpp" +#include "gc/shared/oopStorage.hpp" +#include "gc/shared/oopStorageSet.hpp" #include "gc/shared/workgroup.hpp" #include "interpreter/interpreter.hpp" #include "interpreter/linkResolver.hpp" @@ -1055,12 +1057,12 @@ static Handle create_initial_thread_group(TRAPS) { return main_instance; } -// Creates the initial Thread -static oop create_initial_thread(Handle thread_group, JavaThread* thread, +// Creates the initial Thread, and sets it to running. +static void create_initial_thread(Handle thread_group, JavaThread* thread, TRAPS) { InstanceKlass* ik = SystemDictionary::Thread_klass(); assert(ik->is_initialized(), "must be"); - instanceHandle thread_oop = ik->allocate_instance_handle(CHECK_NULL); + instanceHandle thread_oop = ik->allocate_instance_handle(CHECK); // Cannot use JavaCalls::construct_new_instance because the java.lang.Thread // constructor calls Thread.current(), which must be set here for the @@ -1069,7 +1071,7 @@ static oop create_initial_thread(Handle thread_group, JavaThread* thread, java_lang_Thread::set_priority(thread_oop(), NormPriority); thread->set_threadObj(thread_oop()); - Handle string = java_lang_String::create_from_str("main", CHECK_NULL); + Handle string = java_lang_String::create_from_str("main", CHECK); JavaValue result(T_VOID); JavaCalls::call_special(&result, thread_oop, @@ -1078,8 +1080,12 @@ static oop create_initial_thread(Handle thread_group, JavaThread* thread, vmSymbols::threadgroup_string_void_signature(), thread_group, string, - CHECK_NULL); - return thread_oop(); + CHECK); + + // Set thread status to running since main thread has + // been started and running. + java_lang_Thread::set_thread_status(thread_oop(), + java_lang_Thread::RUNNABLE); } char java_runtime_name[128] = ""; @@ -1187,6 +1193,23 @@ static void call_postVMInitHook(TRAPS) { } } +// Initialized by VMThread at vm_global_init +static OopStorage* _thread_oop_storage = NULL; + +oop JavaThread::threadObj() const { + return _threadObj.resolve(); +} + +void JavaThread::set_threadObj(oop p) { + assert(_thread_oop_storage != NULL, "not yet initialized"); + _threadObj = OopHandle(_thread_oop_storage, p); +} + +OopStorage* JavaThread::thread_oop_storage() { + assert(_thread_oop_storage != NULL, "not yet initialized"); + return _thread_oop_storage; +} + void JavaThread::allocate_threadObj(Handle thread_group, const char* thread_name, bool daemon, TRAPS) { assert(thread_group.not_null(), "thread group should be specified"); @@ -1653,7 +1676,6 @@ void JavaThread::initialize() { // Initialize fields set_saved_exception_pc(NULL); - set_threadObj(NULL); _anchor.clear(); set_entry_point(NULL); set_jni_functions(jni_functions()); @@ -1758,7 +1780,7 @@ void JavaThread::interrupt() { bool JavaThread::is_interrupted(bool clear_interrupted) { debug_only(check_for_dangling_thread_pointer(this);) - if (threadObj() == NULL) { + if (_threadObj.peek() == NULL) { // If there is no j.l.Thread then it is impossible to have // been interrupted. We can find NULL during VM initialization // or when a JNI thread is still in the process of attaching. @@ -1871,6 +1893,9 @@ JavaThread::JavaThread(ThreadFunction entry_point, size_t stack_sz) : JavaThread::~JavaThread() { + // Ask ServiceThread to release the threadObj OopHandle + ServiceThread::add_oop_handle_release(_threadObj); + // JSR166 -- return the parker to the free list Parker::Release(_parker); _parker = NULL; @@ -1971,7 +1996,7 @@ void JavaThread::run() { void JavaThread::thread_main_inner() { assert(JavaThread::current() == this, "sanity check"); - assert(this->threadObj() != NULL, "just checking"); + assert(_threadObj.peek() != NULL, "just checking"); // Execute thread entry point unless this thread has a pending exception // or has been stopped before starting. @@ -3015,7 +3040,6 @@ void JavaThread::oops_do(OopClosure* f, CodeBlobClosure* cf) { // Traverse instance variables at the end since the GC may be moving things // around using this function - f->do_oop((oop*) &_threadObj); f->do_oop((oop*) &_vm_result); f->do_oop((oop*) &_exception_oop); f->do_oop((oop*) &_pending_async_exception); @@ -3717,13 +3741,7 @@ void Threads::initialize_java_lang_classes(JavaThread* main_thread, TRAPS) { Handle thread_group = create_initial_thread_group(CHECK); Universe::set_main_thread_group(thread_group()); initialize_class(vmSymbols::java_lang_Thread(), CHECK); - oop thread_object = create_initial_thread(thread_group, main_thread, CHECK); - main_thread->set_threadObj(thread_object); - - // Set thread status to running since main thread has - // been started and running. - java_lang_Thread::set_thread_status(thread_object, - java_lang_Thread::RUNNABLE); + create_initial_thread(thread_group, main_thread, CHECK); // The VM creates objects of this class. initialize_class(vmSymbols::java_lang_Module(), CHECK); @@ -3886,6 +3904,9 @@ jint Threads::create_vm(JavaVMInitArgs* args, bool* canTryAgain) { } #endif // INCLUDE_JVMCI + // Initialize OopStorage for threadObj + _thread_oop_storage = OopStorageSet::create_strong("Thread OopStorage"); + // Attach the main thread to this os thread JavaThread* main_thread = new JavaThread(); main_thread->set_thread_state(_thread_in_vm); diff --git a/src/hotspot/share/runtime/thread.hpp b/src/hotspot/share/runtime/thread.hpp index 8b717804675..97bbe7e76c1 100644 --- a/src/hotspot/share/runtime/thread.hpp +++ b/src/hotspot/share/runtime/thread.hpp @@ -92,6 +92,8 @@ class JVMCIPrimitiveArray; class Metadata; class ResourceArea; +class OopStorage; + DEBUG_ONLY(class ResourceMark;) class WorkerThread; @@ -1017,7 +1019,7 @@ class JavaThread: public Thread { friend class ThreadsSMRSupport; // to access _threadObj for exiting_threads_oops_do private: bool _on_thread_list; // Is set when this JavaThread is added to the Threads list - oop _threadObj; // The Java level thread object + OopHandle _threadObj; // The Java level thread object #ifdef ASSERT private: @@ -1277,8 +1279,8 @@ class JavaThread: public Thread { // Thread oop. threadObj() can be NULL for initial JavaThread // (or for threads attached via JNI) - oop threadObj() const { return _threadObj; } - void set_threadObj(oop p) { _threadObj = p; } + oop threadObj() const; + void set_threadObj(oop p); // Prepare thread and add to priority queue. If a priority is // not specified, use the priority of the thread object. Threads_lock @@ -2112,6 +2114,7 @@ public: void interrupt(); bool is_interrupted(bool clear_interrupted); + static OopStorage* thread_oop_storage(); }; // Inline implementation of JavaThread::current diff --git a/src/hotspot/share/runtime/threadSMR.cpp b/src/hotspot/share/runtime/threadSMR.cpp index 2cfac944fa3..41c5af29dc0 100644 --- a/src/hotspot/share/runtime/threadSMR.cpp +++ b/src/hotspot/share/runtime/threadSMR.cpp @@ -41,9 +41,6 @@ #include "utilities/resourceHash.hpp" #include "utilities/vmError.hpp" -// List of exiting threads -ThreadsSMRSupport::Holder* ThreadsSMRSupport::_exiting_threads = NULL; - // The '_cnt', '_max' and '_times" fields are enabled via // -XX:+EnableThreadSMRStatistics: @@ -927,8 +924,6 @@ void ThreadsSMRSupport::release_stable_list_wake_up(bool is_nested) { void ThreadsSMRSupport::remove_thread(JavaThread *thread) { - ThreadsSMRSupport::add_exiting_thread(thread); - if (ThreadIdTable::is_initialized()) { jlong tid = SharedRuntime::get_java_tid(thread); ThreadIdTable::remove_thread(tid); @@ -998,7 +993,6 @@ void ThreadsSMRSupport::wait_until_not_protected(JavaThread *thread) { // This is the common case. ThreadsSMRSupport::clear_delete_notify(); ThreadsSMRSupport::delete_lock()->unlock(); - ThreadsSMRSupport::remove_exiting_thread(thread); break; } if (!has_logged_once) { @@ -1188,47 +1182,3 @@ void ThreadsSMRSupport::print_info_elements_on(outputStream* st, ThreadsList* t_ cnt++; } } - -void ThreadsSMRSupport::add_exiting_thread(JavaThread* thread) { - assert(thread == JavaThread::current(), "invariant"); - assert(Threads_lock->owned_by_self(), "invariant"); - assert(!contains_exiting_thread(thread), "invariant"); - Holder* h = new Holder(thread, _exiting_threads); - _exiting_threads = h; -} - -void ThreadsSMRSupport::remove_exiting_thread(JavaThread* thread) { - assert(thread == JavaThread::current(), "invariant"); - assert(Threads_lock->owned_by_self(), "invariant"); - // If a thread fails to initialize fully it can be deleted immediately - // so we won't remove it from the ThreadsList and so never add it to the - // exiting thread list - so we can't assert(contains_exiting_thread(p)) here. - - for (Holder* current = _exiting_threads, **prev_next = &_exiting_threads; - current != NULL; - prev_next = ¤t->_next, current = current->_next) { - if (current->_thread == thread) { - *prev_next = current->_next; - delete current; - break; - } - } -} - -#ifdef ASSERT -bool ThreadsSMRSupport::contains_exiting_thread(JavaThread* thread) { - for (Holder* current = _exiting_threads; current != NULL; current = current->_next) { - if (current->_thread == thread) { - return true; - } - } - return false; -} -#endif - -void ThreadsSMRSupport::exiting_threads_oops_do(OopClosure* f) { - assert_locked_or_safepoint(Threads_lock); - for (Holder* current = _exiting_threads; current != NULL; current = current->_next) { - f->do_oop((oop*) ¤t->_thread->_threadObj); - } -} diff --git a/src/hotspot/share/runtime/threadSMR.hpp b/src/hotspot/share/runtime/threadSMR.hpp index 6b68353de2a..a8c9d0475a6 100644 --- a/src/hotspot/share/runtime/threadSMR.hpp +++ b/src/hotspot/share/runtime/threadSMR.hpp @@ -82,33 +82,12 @@ class ThreadClosure; // but that target JavaThread * will not be deleted until it is no // longer protected by a ThreadsListHandle. // -// Once a JavaThread has removed itself from the main ThreadsList it is -// no longer visited by GC. To ensure that thread's threadObj() oop remains -// valid while the thread is still accessible from a ThreadsListHandle we -// maintain a special list of exiting threads: -// - In remove() we add the exiting thread to the list (under the Threads_lock). -// - In wait_until_not_protected() we remove it from the list (again under the -// Threads_lock). -// - Universe::oops_do walks the list (at a safepoint so VMThread holds -// Threads_lock) and visits the _threadObj oop of each JavaThread. - // SMR Support for the Threads class. // class ThreadsSMRSupport : AllStatic { friend class VMStructs; friend class SafeThreadsListPtr; // for _nested_thread_list_max, delete_notify(), release_stable_list_wake_up() access - // Helper class for the exiting thread list - class Holder : public CHeapObj { - public: - JavaThread* _thread; - Holder* _next; - Holder(JavaThread* thread, Holder* next) : _thread(thread), _next(next) {} - }; - - // The list of exiting threads - static Holder* _exiting_threads; - // The coordination between ThreadsSMRSupport::release_stable_list() and // ThreadsSMRSupport::smr_delete() uses the delete_lock in order to // reduce the traffic on the Threads_lock. @@ -170,12 +149,6 @@ class ThreadsSMRSupport : AllStatic { static void smr_delete(JavaThread *thread); static void update_tlh_stats(uint millis); - // Exiting thread list maintenance - static void add_exiting_thread(JavaThread* thread); - static void remove_exiting_thread(JavaThread* thread); - DEBUG_ONLY(static bool contains_exiting_thread(JavaThread* thread);) - static void exiting_threads_oops_do(OopClosure* f); - // Logging and printing support: static void log_statistics(); static void print_info_elements_on(outputStream* st, ThreadsList* t_list); diff --git a/src/hotspot/share/runtime/vmStructs.cpp b/src/hotspot/share/runtime/vmStructs.cpp index 514aa648049..16d85947f0f 100644 --- a/src/hotspot/share/runtime/vmStructs.cpp +++ b/src/hotspot/share/runtime/vmStructs.cpp @@ -740,7 +740,7 @@ typedef HashtableEntry KlassHashtableEntry; nonstatic_field(Thread, _current_waiting_monitor, ObjectMonitor*) \ nonstatic_field(NamedThread, _name, char*) \ nonstatic_field(NamedThread, _processed_thread, JavaThread*) \ - nonstatic_field(JavaThread, _threadObj, oop) \ + nonstatic_field(JavaThread, _threadObj, OopHandle) \ nonstatic_field(JavaThread, _anchor, JavaFrameAnchor) \ nonstatic_field(JavaThread, _vm_result, oop) \ nonstatic_field(JavaThread, _vm_result_2, Metadata*) \ diff --git a/src/hotspot/share/services/heapDumper.cpp b/src/hotspot/share/services/heapDumper.cpp index c85087e9595..61584ffac71 100644 --- a/src/hotspot/share/services/heapDumper.cpp +++ b/src/hotspot/share/services/heapDumper.cpp @@ -1859,8 +1859,9 @@ void VM_HeapDumper::work(uint worker_id) { // HPROF_GC_ROOT_JNI_GLOBAL JNIGlobalsDumper jni_dumper(writer()); JNIHandles::oops_do(&jni_dumper); - Universe::oops_do(&jni_dumper); // technically not jni roots, but global roots - // for things like preallocated throwable backtraces + // technically not jni roots, but global roots + // for things like preallocated throwable backtraces + Universe::vm_global()->oops_do(&jni_dumper); // HPROF_GC_ROOT_STICKY_CLASS // These should be classes in the NULL class loader data, and not all classes diff --git a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/runtime/JavaThread.java b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/runtime/JavaThread.java index ec2a4cabfe7..aafd48a89b8 100644 --- a/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/runtime/JavaThread.java +++ b/src/jdk.hotspot.agent/share/classes/sun/jvm/hotspot/runtime/JavaThread.java @@ -43,7 +43,7 @@ import sun.jvm.hotspot.utilities.Observer; public class JavaThread extends Thread { private static final boolean DEBUG = System.getProperty("sun.jvm.hotspot.runtime.JavaThread.DEBUG") != null; - private static sun.jvm.hotspot.types.OopField threadObjField; + private static long threadObjFieldOffset; private static AddressField anchorField; private static AddressField lastJavaSPField; private static AddressField lastJavaPCField; @@ -85,7 +85,8 @@ public class JavaThread extends Thread { Type type = db.lookupType("JavaThread"); Type anchorType = db.lookupType("JavaFrameAnchor"); - threadObjField = type.getOopField("_threadObj"); + threadObjFieldOffset = type.getField("_threadObj").getOffset(); + anchorField = type.getAddressField("_anchor"); lastJavaSPField = anchorType.getAddressField("_last_Java_sp"); lastJavaPCField = anchorType.getAddressField("_last_Java_pc"); @@ -347,7 +348,9 @@ public class JavaThread extends Thread { public Oop getThreadObj() { Oop obj = null; try { - obj = VM.getVM().getObjectHeap().newOop(threadObjField.getValue(addr)); + Address addr = getAddress().addOffsetTo(threadObjFieldOffset); + VMOopHandle vmOopHandle = VMObjectFactory.newObject(VMOopHandle.class, addr); + obj = vmOopHandle.resolve(); } catch (Exception e) { e.printStackTrace(); } diff --git a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/GraalHotSpotVMConfig.java b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/GraalHotSpotVMConfig.java index e0a7cf15cdb..e2c3d0aad6d 100644 --- a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/GraalHotSpotVMConfig.java +++ b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/GraalHotSpotVMConfig.java @@ -375,7 +375,19 @@ public class GraalHotSpotVMConfig extends GraalHotSpotVMConfigAccess { public final int threadTlabOffset = getFieldOffset("Thread::_tlab", Integer.class, "ThreadLocalAllocBuffer"); public final int javaThreadAnchorOffset = getFieldOffset("JavaThread::_anchor", Integer.class, "JavaFrameAnchor"); public final int javaThreadShouldPostOnExceptionsFlagOffset = getFieldOffset("JavaThread::_should_post_on_exceptions_flag", Integer.class, "int", Integer.MIN_VALUE, JVMCI || JDK >= 12); - public final int threadObjectOffset = getFieldOffset("JavaThread::_threadObj", Integer.class, "oop"); + + public final boolean threadObjectFieldIsHandle; + public final int threadObjectOffset; + { + if (JDK <= 15) { + threadObjectFieldIsHandle = false; + threadObjectOffset = getFieldOffset("JavaThread::_threadObj", Integer.class, "oop"); + } else { + threadObjectFieldIsHandle = true; + threadObjectOffset = getFieldOffset("JavaThread::_threadObj", Integer.class, "OopHandle"); + } + } + public final int osThreadOffset = getFieldOffset("JavaThread::_osthread", Integer.class, "OSThread*"); public final int threadIsMethodHandleReturnOffset = getFieldOffset("JavaThread::_is_method_handle_return", Integer.class, "int"); public final int threadObjectResultOffset = getFieldOffset("JavaThread::_vm_result", Integer.class, "oop"); diff --git a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/meta/HotSpotGraphBuilderPlugins.java b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/meta/HotSpotGraphBuilderPlugins.java index 0a661accd75..597df07b54a 100644 --- a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/meta/HotSpotGraphBuilderPlugins.java +++ b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/meta/HotSpotGraphBuilderPlugins.java @@ -30,6 +30,7 @@ import static org.graalvm.compiler.hotspot.GraalHotSpotVMConfigAccess.JDK; import static org.graalvm.compiler.hotspot.HotSpotBackend.BASE64_ENCODE_BLOCK; import static org.graalvm.compiler.hotspot.HotSpotBackend.GHASH_PROCESS_BLOCKS; import static org.graalvm.compiler.hotspot.meta.HotSpotAOTProfilingPlugin.Options.TieredAOT; +import static org.graalvm.compiler.hotspot.replacements.HotSpotReplacementsUtil.JAVA_THREAD_THREAD_OBJECT_HANDLE_LOCATION; import static org.graalvm.compiler.hotspot.replacements.HotSpotReplacementsUtil.JAVA_THREAD_THREAD_OBJECT_LOCATION; import static org.graalvm.compiler.java.BytecodeParserOptions.InlineDuringParsing; @@ -427,12 +428,21 @@ public class HotSpotGraphBuilderPlugins { AddressNode address = b.add(new OffsetAddressNode(thread, offset)); // JavaThread::_threadObj is never compressed ObjectStamp stamp = StampFactory.objectNonNull(TypeReference.create(b.getAssumptions(), metaAccess.lookupJavaType(Thread.class))); - b.addPush(JavaKind.Object, new ReadNode(address, JAVA_THREAD_THREAD_OBJECT_LOCATION, stamp, BarrierType.NONE)); + ReadNode value = b.add(new ReadNode(address, JAVA_THREAD_THREAD_OBJECT_LOCATION, + config.threadObjectFieldIsHandle ? StampFactory.forKind(wordTypes.getWordKind()) : stamp, BarrierType.NONE)); + if (config.threadObjectFieldIsHandle) { + ValueNode handleOffset = ConstantNode.forIntegerKind(wordTypes.getWordKind(), 0, b.getGraph()); + AddressNode handleAddress = b.add(new OffsetAddressNode(value, handleOffset)); + value = b.add(new ReadNode(handleAddress, JAVA_THREAD_THREAD_OBJECT_HANDLE_LOCATION, stamp, BarrierType.NONE)); + } + b.push(JavaKind.Object, value); return true; } }); if (config.osThreadInterruptedOffset != Integer.MAX_VALUE) { + // This substitution is no longer in use when threadObj is a handle + assert !config.threadObjectFieldIsHandle; r.registerMethodSubstitution(ThreadSubstitutions.class, "isInterrupted", Receiver.class, boolean.class); } diff --git a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/replacements/HotSpotReplacementsUtil.java b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/replacements/HotSpotReplacementsUtil.java index e0a1f7e0c8b..51384944046 100644 --- a/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/replacements/HotSpotReplacementsUtil.java +++ b/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.hotspot/src/org/graalvm/compiler/hotspot/replacements/HotSpotReplacementsUtil.java @@ -308,6 +308,8 @@ public class HotSpotReplacementsUtil { */ public static final LocationIdentity JAVA_THREAD_THREAD_OBJECT_LOCATION = NamedLocationIdentity.immutable("JavaThread::_threadObj"); + public static final LocationIdentity JAVA_THREAD_THREAD_OBJECT_HANDLE_LOCATION = NamedLocationIdentity.immutable("JavaThread::_threadObj handle"); + @Fold public static int threadObjectOffset(@InjectedParameter GraalHotSpotVMConfig config) { return config.threadObjectOffset; diff --git a/test/hotspot/jtreg/gc/g1/TestGCLogMessages.java b/test/hotspot/jtreg/gc/g1/TestGCLogMessages.java index 0f5743dc288..3a6eee9528c 100644 --- a/test/hotspot/jtreg/gc/g1/TestGCLogMessages.java +++ b/test/hotspot/jtreg/gc/g1/TestGCLogMessages.java @@ -121,7 +121,6 @@ public class TestGCLogMessages { new LogMessageWithLevel("LAB Undo Waste", Level.DEBUG), // Ext Root Scan new LogMessageWithLevel("Thread Roots", Level.TRACE), - new LogMessageWithLevel("Universe Roots", Level.TRACE), new LogMessageWithLevel("ObjectSynchronizer Roots", Level.TRACE), new LogMessageWithLevel("CLDG Roots", Level.TRACE), new LogMessageWithLevel("CM RefProcessor Roots", Level.TRACE), diff --git a/test/jdk/jdk/jfr/event/gc/collection/TestG1ParallelPhases.java b/test/jdk/jdk/jfr/event/gc/collection/TestG1ParallelPhases.java index 13bde4901ca..90667c97cd1 100644 --- a/test/jdk/jdk/jfr/event/gc/collection/TestG1ParallelPhases.java +++ b/test/jdk/jdk/jfr/event/gc/collection/TestG1ParallelPhases.java @@ -91,10 +91,10 @@ public class TestG1ParallelPhases { Set allPhases = of( "ExtRootScan", "ThreadRoots", - "UniverseRoots", "ObjectSynchronizerRoots", "VM Global", "JNI Global", + "Thread OopStorage", "CLDGRoots", "CMRefRoots", "MergeER", From 45c89daf72c37dbb5401f796f033eb33c31d703d Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Fri, 7 Aug 2020 15:09:19 +0100 Subject: [PATCH 23/53] 8249786: java/net/httpclient/websocket/PendingPingTextClose.java fails very infrequently TransportImpl is modified to make sure the CLOSED state is recorded before the channel is closed. The tests are modified to enable their retry mechanism on windows, similar to what was done previously for macOS. Reviewed-by: prappo, chegar --- .../net/http/websocket/TransportImpl.java | 8 +- .../websocket/PendingBinaryPingClose.java | 5 +- .../websocket/PendingBinaryPongClose.java | 5 +- .../websocket/PendingOperations.java | 18 +++- .../websocket/PendingPingBinaryClose.java | 5 +- .../websocket/PendingPingTextClose.java | 83 +++++++++++-------- .../websocket/PendingPongBinaryClose.java | 5 +- .../websocket/PendingPongTextClose.java | 5 +- .../websocket/PendingTextPingClose.java | 5 +- .../websocket/PendingTextPongClose.java | 5 +- .../net/httpclient/websocket/Support.java | 5 ++ 11 files changed, 98 insertions(+), 51 deletions(-) diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/websocket/TransportImpl.java b/src/java.net.http/share/classes/jdk/internal/net/http/websocket/TransportImpl.java index 8b4a43a8661..4a23ec27fdf 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/websocket/TransportImpl.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/websocket/TransportImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -308,13 +308,15 @@ public class TransportImpl implements Transport { try { channel.shutdownOutput(); } finally { + writeState.set(CLOSED); if (inputClosed) { channel.close(); } } } } - writeState.set(CLOSED); + ChannelState s = writeState.get(); + assert s == CLOSED : s; sendScheduler.runOrSchedule(); } @@ -335,6 +337,8 @@ public class TransportImpl implements Transport { channel.shutdownInput(); } finally { if (outputClosed) { + ChannelState s = writeState.get(); + assert s == CLOSED : s; channel.close(); } } diff --git a/test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java b/test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java index 8116e8dc722..f48797da7f5 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingBinaryPingClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -79,8 +79,9 @@ public class PendingBinaryPingClose extends PendingOperations { assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfBinary); return null; - }, () -> cfBinary.isDone() ? true : false); + }, () -> cfBinary.isDone()); webSocket.abort(); assertFails(IOE, cfBinary); assertFails(IOE, cfPing); diff --git a/test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java b/test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java index b810a47eaba..81a8e05b496 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingBinaryPongClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -79,8 +79,9 @@ public class PendingBinaryPongClose extends PendingOperations { assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfBinary); return null; - }, () -> cfBinary.isDone() ? true : false); + }, () -> cfBinary.isDone()); webSocket.abort(); assertFails(IOE, cfBinary); assertFails(IOE, cfPong); diff --git a/test/jdk/java/net/httpclient/websocket/PendingOperations.java b/test/jdk/java/net/httpclient/websocket/PendingOperations.java index d0a7e21db67..ddfc4453e73 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingOperations.java +++ b/test/jdk/java/net/httpclient/websocket/PendingOperations.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,6 +27,7 @@ import org.testng.annotations.DataProvider; import java.io.IOException; import java.net.http.WebSocket; import java.util.concurrent.Callable; +import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletionStage; import java.util.function.BooleanSupplier; @@ -46,6 +47,7 @@ public class PendingOperations { @AfterTest public void cleanup() { + System.err.println("cleanup: Closing server"); server.close(); webSocket.abort(); } @@ -61,6 +63,10 @@ public class PendingOperations { Support.assertCompletesExceptionally(clazz, stage); } + static void assertNotDone(CompletableFuture future) { + Support.assertNotDone(future); + } + @DataProvider(name = "booleans") public Object[][] booleans() { return new Object[][]{{Boolean.TRUE}, {Boolean.FALSE}}; @@ -69,6 +75,9 @@ public class PendingOperations { static boolean isMacOS() { return System.getProperty("os.name").contains("OS X"); } + static boolean isWindows() { + return System.getProperty("os.name").toLowerCase().startsWith("win"); + } private static final int ITERATIONS = 3; @@ -84,7 +93,12 @@ public class PendingOperations { callable.call(); break; } catch (AssertionError e) { - if (isMacOS() && repeatCondition.getAsBoolean()) { + var isMac = isMacOS(); + var isWindows = isWindows(); + var repeat = repeatCondition.getAsBoolean(); + System.out.printf("repeatable: isMac=%s, isWindows=%s, repeat=%s, iterations=%d%n", + isMac, isWindows, repeat, iterations); + if ((isMac || isWindows) && repeat) { // ## This is loathsome, but necessary because of observed // ## automagic socket buffer resizing on recent macOS platforms continue; diff --git a/test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java b/test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java index 99d5847a6bd..b7ea161b936 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingPingBinaryClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -77,8 +77,9 @@ public class PendingPingBinaryClose extends PendingOperations { assertHangs(cfBinary); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfPing); return null; - }, () -> cfPing.isDone() ? true : false); + }, () -> cfPing.isDone()); webSocket.abort(); assertFails(IOE, cfPing); assertFails(IOE, cfBinary); diff --git a/test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java b/test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java index 050f8098d2d..468bb868814 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingPingTextClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -44,44 +44,61 @@ import static java.net.http.HttpClient.newBuilder; public class PendingPingTextClose extends PendingOperations { + static boolean debug = false; // avoid too verbose output CompletableFuture cfText; CompletableFuture cfPing; CompletableFuture cfClose; @Test(dataProvider = "booleans") public void pendingPingTextClose(boolean last) throws Exception { - repeatable( () -> { - server = Support.notReadingServer(); - server.open(); - webSocket = newBuilder().proxy(NO_PROXY).build().newWebSocketBuilder() - .buildAsync(server.getURI(), new WebSocket.Listener() { }) - .join(); - ByteBuffer data = ByteBuffer.allocate(125); - for (int i = 0; ; i++) { // fill up the send buffer - long start = System.currentTimeMillis(); - System.out.printf("begin cycle #%s at %s%n", i, start); - cfPing = webSocket.sendPing(data); - try { - cfPing.get(MAX_WAIT_SEC, TimeUnit.SECONDS); - data.clear(); - } catch (TimeoutException e) { - break; - } finally { - long stop = System.currentTimeMillis(); - System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + try { + repeatable(() -> { + server = Support.notReadingServer(); + server.open(); + webSocket = newBuilder().proxy(NO_PROXY).build().newWebSocketBuilder() + .buildAsync(server.getURI(), new WebSocket.Listener() { + }) + .join(); + ByteBuffer data = ByteBuffer.allocate(125); + boolean done = false; + for (int i = 0; ; i++) { // fill up the send buffer + long start = System.currentTimeMillis(); + if (debug) System.out.printf("begin cycle #%s at %s%n", i, start); + cfPing = webSocket.sendPing(data); + try { + cfPing.get(MAX_WAIT_SEC, TimeUnit.SECONDS); + data.clear(); + } catch (TimeoutException e) { + done = true; + System.out.printf("Got expected timeout after %d iterations%n", i); + break; + } finally { + long stop = System.currentTimeMillis(); + if (debug || done || (stop - start) > (MAX_WAIT_SEC * 1000L)/2L) + System.out.printf("end cycle #%s at %s (%s ms)%n", i, stop, stop - start); + } } - } - assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); - assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); - cfText = webSocket.sendText("hello", last); - assertHangs(cfText); - cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); - assertHangs(cfClose); - return null; - }, () -> cfPing.isDone() ? true : false); - webSocket.abort(); - assertFails(IOE, cfPing); - assertFails(IOE, cfText); - assertFails(IOE, cfClose); + assertFails(ISE, webSocket.sendPing(ByteBuffer.allocate(125))); + assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); + System.out.println("asserting that sendText hangs"); + cfText = webSocket.sendText("hello", last); + assertHangs(cfText); + System.out.println("asserting that sendClose hangs"); + cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); + assertHangs(cfClose); + System.out.println("asserting that cfPing is not completed"); + assertNotDone(cfPing); + System.out.println("finishing"); + return null; + }, () -> cfPing.isDone()); // can't use method ref: cfPing not initialized + webSocket.abort(); + assertFails(IOE, cfPing); + assertFails(IOE, cfText); + assertFails(IOE, cfClose); + } catch (Throwable t) { + System.err.printf("pendingPingTextClose(%s) failed: %s%n", last, t); + t.printStackTrace(); + throw t; + } } } diff --git a/test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java b/test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java index e715a83b7e9..21cd4c9c765 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingPongBinaryClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -77,8 +77,9 @@ public class PendingPongBinaryClose extends PendingOperations { assertHangs(cfBinary); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfPong); return null; - }, () -> cfPong.isDone() ? true : false); + }, () -> cfPong.isDone()); webSocket.abort(); assertFails(IOE, cfPong); assertFails(IOE, cfBinary); diff --git a/test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java b/test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java index fddec8da4c1..19a7dac9cd6 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingPongTextClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -79,8 +79,9 @@ public class PendingPongTextClose extends PendingOperations { assertHangs(cfText); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfPong); return null; - }, () -> cfPong.isDone() ? true : false); + }, () -> cfPong.isDone()); webSocket.abort(); assertFails(IOE, cfPong); assertFails(IOE, cfText); diff --git a/test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java b/test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java index c5fc62e018a..e529bc277ae 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingTextPingClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -80,8 +80,9 @@ public class PendingTextPingClose extends PendingOperations { assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfText); return null; - }, () -> cfText.isDone() ? true : false); + }, () -> cfText.isDone()); webSocket.abort(); assertFails(IOE, cfText); assertFails(IOE, cfPing); diff --git a/test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java b/test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java index e688d42125e..e16b844f699 100644 --- a/test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java +++ b/test/jdk/java/net/httpclient/websocket/PendingTextPongClose.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -80,8 +80,9 @@ public class PendingTextPongClose extends PendingOperations { assertFails(ISE, webSocket.sendPong(ByteBuffer.allocate(125))); cfClose = webSocket.sendClose(WebSocket.NORMAL_CLOSURE, "ok"); assertHangs(cfClose); + assertNotDone(cfText); return null; - }, () -> cfText.isDone() ? true : false); + }, () -> cfText.isDone()); webSocket.abort(); assertFails(IOE, cfText); assertFails(IOE, cfPong); diff --git a/test/jdk/java/net/httpclient/websocket/Support.java b/test/jdk/java/net/httpclient/websocket/Support.java index ca847c26cea..9f7f5c43578 100644 --- a/test/jdk/java/net/httpclient/websocket/Support.java +++ b/test/jdk/java/net/httpclient/websocket/Support.java @@ -33,6 +33,7 @@ import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeoutException; import static org.testng.Assert.assertThrows; +import static org.testng.Assert.assertFalse; public class Support { @@ -43,6 +44,10 @@ public class Support { Support.assertCompletesExceptionally(clazz, stage); } + public static void assertNotDone(CompletableFuture future) { + assertFalse(future.isDone()); + } + public static void assertCompletesExceptionally(Class clazz, CompletionStage stage) { CompletableFuture cf = From 77c46ea9112b0c2632b4af1d899d59a132878da3 Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Fri, 7 Aug 2020 16:16:45 +0100 Subject: [PATCH 24/53] 8229822: ThrowingPushPromises tests sometimes fail due to EOF SocketTube is fixed to cater for errors caused by pausing/resuming events on an asynchronously closed connection, from within the selector's manager thread. Http2Connection and Stream are fixed to prevent sending a DataFrame on a stream after Reset has been sent. Reviewed-by: chegar --- .../internal/net/http/Http2Connection.java | 44 ++++-- .../jdk/internal/net/http/SocketTube.java | 13 +- .../classes/jdk/internal/net/http/Stream.java | 134 +++++++++++++++--- ...rowingPushPromisesAsInputStreamCustom.java | 1 + .../ThrowingPushPromisesAsInputStreamIO.java | 1 + .../ThrowingPushPromisesAsLinesCustom.java | 1 + .../ThrowingPushPromisesAsLinesIO.java | 1 + .../ThrowingPushPromisesAsStringCustom.java | 1 + .../ThrowingPushPromisesAsStringIO.java | 1 + .../ThrowingPushPromisesSanity.java | 1 + 10 files changed, 169 insertions(+), 29 deletions(-) diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/Http2Connection.java b/src/java.net.http/share/classes/jdk/internal/net/http/Http2Connection.java index 004ca5656a8..f7e6117c7c0 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/Http2Connection.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/Http2Connection.java @@ -329,7 +329,11 @@ class Http2Connection { Log.logTrace("Connection send window size {0} ", windowController.connectionWindowSize()); Stream initialStream = createStream(exchange); - initialStream.registerStream(1); + boolean opened = initialStream.registerStream(1, true); + if (debug.on() && !opened) { + debug.log("Initial stream was cancelled - but connection is maintained: " + + "reset frame will need to be sent later"); + } windowController.registerStream(1, getInitialSendWindowSize()); initialStream.requestSent(); // Upgrading: @@ -338,6 +342,11 @@ class Http2Connection { this.initial = initial; connectFlows(connection); sendConnectionPreface(); + if (!opened) { + debug.log("ensure reset frame is sent to cancel initial stream"); + initialStream.sendCancelStreamFrame(); + } + } // Used when upgrading an HTTP/1.1 connection to HTTP/2 after receiving @@ -849,7 +858,7 @@ class Http2Connection { Exchange pushExch = new Exchange<>(pushReq, parent.exchange.multi); Stream.PushedStream pushStream = createPushStream(parent, pushExch); pushExch.exchImpl = pushStream; - pushStream.registerStream(promisedStreamid); + pushStream.registerStream(promisedStreamid, true); parent.incoming_pushPromise(pushReq, pushStream); } @@ -874,7 +883,7 @@ class Http2Connection { } } - void resetStream(int streamid, int code) throws IOException { + void resetStream(int streamid, int code) { try { if (connection.channel().isOpen()) { // no need to try & send a reset frame if the @@ -882,6 +891,7 @@ class Http2Connection { Log.logError( "Resetting stream {0,number,integer} with error code {1,number,integer}", streamid, code); + markStream(streamid, code); ResetFrame frame = new ResetFrame(streamid, code); sendFrame(frame); } else if (debug.on()) { @@ -894,6 +904,11 @@ class Http2Connection { } } + private void markStream(int streamid, int code) { + Stream s = streams.get(streamid); + if (s != null) s.markStream(code); + } + // reduce count of streams by 1 if stream still exists synchronized void decrementStreamsCount(int streamid) { Stream s = streams.get(streamid); @@ -1192,12 +1207,19 @@ class Http2Connection { Stream stream = oh.getAttachment(); assert stream.streamid == 0; int streamid = nextstreamid; - nextstreamid += 2; - stream.registerStream(streamid); - // set outgoing window here. This allows thread sending - // body to proceed. - windowController.registerStream(streamid, getInitialSendWindowSize()); - return stream; + if (stream.registerStream(streamid, false)) { + // set outgoing window here. This allows thread sending + // body to proceed. + nextstreamid += 2; + windowController.registerStream(streamid, getInitialSendWindowSize()); + return stream; + } else { + stream.cancelImpl(new IOException("Request cancelled")); + if (finalStream() && streams.isEmpty()) { + close(); + } + return null; + } } private final Object sendlock = new Object(); @@ -1211,7 +1233,9 @@ class Http2Connection { OutgoingHeaders> oh = (OutgoingHeaders>) frame; Stream stream = registerNewStream(oh); // provide protection from inserting unordered frames between Headers and Continuation - publisher.enqueue(encodeHeaders(oh, stream)); + if (stream != null) { + publisher.enqueue(encodeHeaders(oh, stream)); + } } else { publisher.enqueue(encodeFrame(frame)); } diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/SocketTube.java b/src/java.net.http/share/classes/jdk/internal/net/http/SocketTube.java index 666251da6ab..2ff82bb6a91 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/SocketTube.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/SocketTube.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -246,7 +246,7 @@ final class SocketTube implements FlowTube { } @Override public final void abort(IOException error) { - debug().log(() -> "abort: " + error); + debug().log(() -> this.getClass().getSimpleName() + " abort: " + error); pause(); // pause, then signal signalError(error); // should not be resumed after abort (not checked) } @@ -724,10 +724,12 @@ final class SocketTube implements FlowTube { @Override public final void cancel() { pauseReadEvent(); + if (debug.on()) debug.log("Read subscription cancelled"); if (Log.channel()) { Log.logChannel("Read subscription cancelled for channel {0}", channelDescr()); } + if (debug.on()) debug.log("Stopping read scheduler"); readScheduler.stop(); } @@ -748,6 +750,7 @@ final class SocketTube implements FlowTube { } final void signalError(Throwable error) { + if (debug.on()) debug.log("signal read error: " + error); if (!errorRef.compareAndSet(null, error)) { return; } @@ -808,6 +811,7 @@ final class SocketTube implements FlowTube { } current.errorRef.compareAndSet(null, error); current.signalCompletion(); + if (debug.on()) debug.log("Stopping read scheduler"); readScheduler.stop(); debugState("leaving read() loop with error: "); return; @@ -831,6 +835,7 @@ final class SocketTube implements FlowTube { // anyway. pauseReadEvent(); current.signalCompletion(); + if (debug.on()) debug.log("Stopping read scheduler"); readScheduler.stop(); } debugState("leaving read() loop after EOF: "); @@ -850,6 +855,7 @@ final class SocketTube implements FlowTube { // waiting for this event to terminate. // So resume the read event and return now... resumeReadEvent(); + if (errorRef.get() != null) continue; debugState("leaving read() loop after onNext: "); return; } else { @@ -861,6 +867,7 @@ final class SocketTube implements FlowTube { // readable again. demand.increase(1); resumeReadEvent(); + if (errorRef.get() != null) continue; debugState("leaving read() loop with no bytes"); return; } @@ -879,6 +886,7 @@ final class SocketTube implements FlowTube { // Trying to pause the event here would actually // introduce a race condition between this loop and // request(n). + if (errorRef.get() != null) continue; debugState("leaving read() loop with no demand"); break; } @@ -946,6 +954,7 @@ final class SocketTube implements FlowTube { @Override protected final void signalError(Throwable error) { + if (debug.on()) debug.log("signalError to %s (%s)", sub, error); sub.signalError(error); } diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/Stream.java b/src/java.net.http/share/classes/jdk/internal/net/http/Stream.java index b65294a8367..0fafa0dba5b 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/Stream.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/Stream.java @@ -28,6 +28,8 @@ package jdk.internal.net.http; import java.io.EOFException; import java.io.IOException; import java.io.UncheckedIOException; +import java.lang.invoke.MethodHandles; +import java.lang.invoke.VarHandle; import java.net.URI; import java.nio.ByteBuffer; import java.util.ArrayList; @@ -133,12 +135,18 @@ class Stream extends ExchangeImpl { private volatile boolean remotelyClosed; private volatile boolean closed; private volatile boolean endStreamSent; - - final AtomicBoolean deRegistered = new AtomicBoolean(false); + // Indicates the first reason that was invoked when sending a ResetFrame + // to the server. A streamState of 0 indicates that no reset was sent. + // (see markStream(int code) + private volatile int streamState; // assigned using STREAM_STATE varhandle. + private volatile boolean deRegistered; // assigned using DEREGISTERED varhandle. // state flags private boolean requestSent, responseReceived; + // send lock: prevent sending DataFrames after reset occurred. + private final Object sendLock = new Object(); + /** * A reference to this Stream's connection Send Window controller. The * stream MUST acquire the appropriate amount of Send Window before @@ -292,7 +300,7 @@ class Stream extends ExchangeImpl { } boolean deRegister() { - return deRegistered.compareAndSet(false, true); + return DEREGISTERED.compareAndSet(this, false, true); } @Override @@ -338,6 +346,36 @@ class Stream extends ExchangeImpl { sched.runOrSchedule(); } + /** + * Records the first reason which was invoked when sending a ResetFrame + * to the server in the streamState, and return the previous value + * of the streamState. This is an atomic operation. + * A possible use of this method would be to send a ResetFrame only + * if no previous reset frame has been sent. + * For instance:

    {@code
    +     *  if (markStream(ResetFrame.CANCEL) == 0) {
    +     *      connection.sendResetFrame(streamId, ResetFrame.CANCEL);
    +     *  }
    +     *  }
    + * @param code the reason code as per HTTP/2 protocol + * @return the previous value of the stream state. + */ + int markStream(int code) { + if (code == 0) return streamState; + synchronized (sendLock) { + return (int) STREAM_STATE.compareAndExchange(this, 0, code); + } + } + + private void sendDataFrame(DataFrame frame) { + synchronized (sendLock) { + // must not send DataFrame after reset. + if (streamState == 0) { + connection.sendDataFrame(frame); + } + } + } + // pushes entire response body into response subscriber // blocking when required by local or remote flow control CompletableFuture receiveData(BodySubscriber bodySubscriber, Executor executor) { @@ -384,6 +422,7 @@ class Stream extends ExchangeImpl { */ void incoming(Http2Frame frame) throws IOException { if (debug.on()) debug.log("incoming: %s", frame); + var cancelled = closed || streamState != 0; if ((frame instanceof HeaderFrame)) { HeaderFrame hframe = (HeaderFrame)frame; if (hframe.endHeaders()) { @@ -395,9 +434,10 @@ class Stream extends ExchangeImpl { receiveDataFrame(new DataFrame(streamid, DataFrame.END_STREAM, List.of())); } } else if (frame instanceof DataFrame) { - receiveDataFrame((DataFrame)frame); + if (cancelled) connection.dropDataFrame((DataFrame) frame); + else receiveDataFrame((DataFrame) frame); } else { - otherFrame(frame); + if (!cancelled) otherFrame(frame); } } @@ -720,6 +760,16 @@ class Stream extends ExchangeImpl { } else { requestContentLen = 0; } + + // At this point the stream doesn't have a streamid yet. + // It will be allocated if we send the request headers. + Throwable t = errorRef.get(); + if (t != null) { + if (debug.on()) debug.log("stream already cancelled, headers not sent: %s", (Object)t); + return MinimalFuture.failedFuture(t); + } + + // sending the headers will cause the allocation of the stream id OutgoingHeaders> f = headerFrame(requestContentLen); connection.sendFrame(f); CompletableFuture> cf = new MinimalFuture<>(); @@ -745,10 +795,17 @@ class Stream extends ExchangeImpl { // been already closed (or will be closed shortly after). } - void registerStream(int id) { - this.streamid = id; - connection.putStream(this, streamid); - if (debug.on()) debug.log("Registered stream %d", id); + boolean registerStream(int id, boolean registerIfCancelled) { + boolean cancelled = closed; + if (!cancelled || registerIfCancelled) { + this.streamid = id; + connection.putStream(this, streamid); + if (debug.on()) { + debug.log("Stream %d registered (cancelled: %b, registerIfCancelled: %b)", + streamid, cancelled, registerIfCancelled); + } + } + return !cancelled; } void signalWindowUpdate() { @@ -853,6 +910,7 @@ class Stream extends ExchangeImpl { cancelImpl(t); return; } + int state = streamState; do { // handle COMPLETED; @@ -865,7 +923,7 @@ class Stream extends ExchangeImpl { } // handle bytes to send downstream - while (item.hasRemaining()) { + while (item.hasRemaining() && state == 0) { if (debug.on()) debug.log("trySend: %d", item.remaining()); assert !endStreamSent : "internal error, send data after END_STREAM flag"; DataFrame df = getDataFrame(item); @@ -884,6 +942,7 @@ class Stream extends ExchangeImpl { + "Too many bytes in request body. Expected: " + contentLength + ", got: " + (contentLength - remainingContentLength); + assert streamid > 0; connection.resetStream(streamid, ResetFrame.PROTOCOL_ERROR); throw new IOException(msg); } else if (remainingContentLength == 0) { @@ -891,15 +950,26 @@ class Stream extends ExchangeImpl { endStreamSent = true; } } + if ((state = streamState) != 0) { + if (debug.on()) debug.log("trySend: cancelled: %s", String.valueOf(t)); + break; + } if (debug.on()) debug.log("trySend: sending: %d", df.getDataLength()); - connection.sendDataFrame(df); + sendDataFrame(df); } + if (state != 0) break; assert !item.hasRemaining(); ByteBuffer b = outgoing.removeFirst(); assert b == item; } while (outgoing.peekFirst() != null); + if (state != 0) { + t = errorRef.get(); + if (t == null) t = new IOException(ResetFrame.stringForCode(streamState)); + throw t; + } + if (debug.on()) debug.log("trySend: request 1"); subscription.request(1); } catch (Throwable ex) { @@ -1102,7 +1172,11 @@ class Stream extends ExchangeImpl { @Override void cancel() { - cancel(new IOException("Stream " + streamid + " cancelled")); + if ((streamid == 0)) { + cancel(new IOException("Stream cancelled before streamid assigned")); + } else { + cancel(new IOException("Stream " + streamid + " cancelled")); + } } void onSubscriptionError(Throwable t) { @@ -1135,9 +1209,13 @@ class Stream extends ExchangeImpl { // This method sends a RST_STREAM frame void cancelImpl(Throwable e) { errorRef.compareAndSet(null, e); - if (debug.on()) debug.log("cancelling stream {0}: {1}", streamid, e); + if (debug.on()) { + if (streamid == 0) debug.log("cancelling stream: %s", (Object)e); + else debug.log("cancelling stream %d: %s", streamid, e); + } if (Log.trace()) { - Log.logTrace("cancelling stream {0}: {1}\n", streamid, e); + if (streamid == 0) Log.logTrace("cancelling stream: {0}\n", e); + else Log.logTrace("cancelling stream {0}: {1}\n", streamid, e); } boolean closing; if (closing = !closed) { // assigning closing to !closed @@ -1160,14 +1238,15 @@ class Stream extends ExchangeImpl { } try { // will send a RST_STREAM frame - if (streamid != 0) { - connection.decrementStreamsCount(streamid); + if (streamid != 0 && streamState == 0) { e = Utils.getCompletionCause(e); if (e instanceof EOFException) { // read EOF: no need to try & send reset + connection.decrementStreamsCount(streamid); connection.closeStream(streamid); } else { - connection.resetStream(streamid, ResetFrame.CANCEL); + // no use to send CANCEL if already closed. + sendCancelStreamFrame(); } } } catch (Throwable ex) { @@ -1175,6 +1254,14 @@ class Stream extends ExchangeImpl { } } + void sendCancelStreamFrame() { + // do not reset a stream until it has a streamid. + if (streamid > 0 && markStream(ResetFrame.CANCEL) == 0) { + connection.resetStream(streamid, ResetFrame.CANCEL); + } + close(); + } + // This method doesn't send any frame void close() { if (closed) return; @@ -1390,4 +1477,17 @@ class Stream extends ExchangeImpl { } } } + + private static final VarHandle STREAM_STATE; + private static final VarHandle DEREGISTERED; + static { + try { + STREAM_STATE = MethodHandles.lookup() + .findVarHandle(Stream.class, "streamState", int.class); + DEREGISTERED = MethodHandles.lookup() + .findVarHandle(Stream.class, "deRegistered", boolean.class); + } catch (Exception x) { + throw new ExceptionInInitializerError(x); + } + } } diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamCustom.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamCustom.java index c3801a0c429..95671d6a3ff 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamCustom.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamCustom.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamIO.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamIO.java index f11c31421a1..7f22bdf4961 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamIO.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsInputStreamIO.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesCustom.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesCustom.java index 847bc382838..e17a72a21dc 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesCustom.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesCustom.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesIO.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesIO.java index 7b7ffab49a2..678a58530c1 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesIO.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsLinesIO.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringCustom.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringCustom.java index eb6f2a7c8f9..be94c2fa4ff 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringCustom.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringCustom.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringIO.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringIO.java index 24d38f1a6df..a7120964869 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringIO.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesAsStringIO.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server diff --git a/test/jdk/java/net/httpclient/ThrowingPushPromisesSanity.java b/test/jdk/java/net/httpclient/ThrowingPushPromisesSanity.java index b2ffd374d2e..d064c322599 100644 --- a/test/jdk/java/net/httpclient/ThrowingPushPromisesSanity.java +++ b/test/jdk/java/net/httpclient/ThrowingPushPromisesSanity.java @@ -23,6 +23,7 @@ /* * @test + * @bug 8229822 * @summary Tests what happens when push promise handlers and their * response body handlers and subscribers throw unexpected exceptions. * @library /test/lib http2/server From e800cc2d2dd3c1290754c6e2c305976afec095ff Mon Sep 17 00:00:00 2001 From: Andy Herrick Date: Fri, 7 Aug 2020 11:42:42 -0400 Subject: [PATCH 25/53] 8251184: File association without description causes exception Reviewed-by: asemenyuk, almatvee --- .../incubator/jpackage/internal/FileAssociation.java | 10 +++++++--- .../jpackage/internal/StandardBundlerParam.java | 4 ++-- .../helpers/jdk/jpackage/test/FileAssociations.java | 6 ++++-- .../tools/jpackage/share/FileAssociationsTest.java | 11 +++++++++-- 4 files changed, 22 insertions(+), 9 deletions(-) diff --git a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java index 20d9ed9c121..b4b9be9f150 100644 --- a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java +++ b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/FileAssociation.java @@ -79,11 +79,15 @@ final class FileAssociation { FileAssociation assoc = new FileAssociation(); assoc.launcherPath = Path.of(launcherName); - assoc.description = FA_DESCRIPTION.fetchFrom(fa); + assoc.description = Optional.ofNullable( + FA_DESCRIPTION.fetchFrom(fa)) + .orElse(launcherName + " association"); assoc.extensions = Optional.ofNullable( - FA_EXTENSIONS.fetchFrom(fa)).orElse(Collections.emptyList()); + FA_EXTENSIONS.fetchFrom(fa)) + .orElse(Collections.emptyList()); assoc.mimeTypes = Optional.ofNullable( - FA_CONTENT_TYPE.fetchFrom(fa)).orElse(Collections.emptyList()); + FA_CONTENT_TYPE.fetchFrom(fa)) + .orElse(Collections.emptyList()); Path icon = FA_ICON.fetchFrom(fa); if (icon != null) { diff --git a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java index d36b08baafa..173e5183f94 100644 --- a/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java +++ b/src/jdk.incubator.jpackage/share/classes/jdk/incubator/jpackage/internal/StandardBundlerParam.java @@ -338,8 +338,8 @@ class StandardBundlerParam extends BundlerParamInfo { new StandardBundlerParam<>( "fileAssociation.description", String.class, - params -> APP_NAME.fetchFrom(params) + " Path", - null + p -> null, + (s, p) -> s ); static final StandardBundlerParam FA_ICON = diff --git a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java index 91fefc91c06..732cbb9240f 100644 --- a/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java +++ b/test/jdk/tools/jpackage/helpers/jdk/jpackage/test/FileAssociations.java @@ -38,9 +38,11 @@ final public class FileAssociations { private void createFile() { Map entries = new HashMap<>(Map.of( "extension", suffixName, - "mime-type", getMime(), - "description", description + "mime-type", getMime() )); + if (description != null) { + entries.put("description", description); + } if (icon != null) { if (TKit.isWindows()) { entries.put("icon", icon.toString().replace("\\", "/")); diff --git a/test/jdk/tools/jpackage/share/FileAssociationsTest.java b/test/jdk/tools/jpackage/share/FileAssociationsTest.java index 0b0a97c057b..fcad5e7d15d 100644 --- a/test/jdk/tools/jpackage/share/FileAssociationsTest.java +++ b/test/jdk/tools/jpackage/share/FileAssociationsTest.java @@ -29,6 +29,7 @@ import jdk.jpackage.test.PackageTest; import jdk.jpackage.test.PackageType; import jdk.jpackage.test.FileAssociations; import jdk.jpackage.test.Annotations.Test; +import jdk.jpackage.test.Annotations.Parameter; /** * Test --file-associations parameter. Output of the test should be @@ -81,13 +82,19 @@ import jdk.jpackage.test.Annotations.Test; public class FileAssociationsTest { @Test - public static void test() { + @Parameter("true") + @Parameter("false") + public static void test(boolean includeDescription) { PackageTest packageTest = new PackageTest(); // Not supported packageTest.excludeTypes(PackageType.MAC_DMG); - new FileAssociations("jptest1").applyTo(packageTest); + FileAssociations fa = new FileAssociations("jptest1"); + if (!includeDescription) { + fa.setDescription(null); + } + fa.applyTo(packageTest); Path icon = TKit.TEST_SRC_ROOT.resolve(Path.of("resources", "icon" + TKit.ICON_SUFFIX)); From 1ad165941313bbaa9e886946081c321f35374f6e Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Fri, 7 Aug 2020 10:16:19 -0700 Subject: [PATCH 26/53] 8251260: two MD5 tests fail "RuntimeException: Unexpected count of intrinsic" Do not run intrinsics/sha/sanity tests with AOTed java.base Reviewed-by: vlivanov --- test/hotspot/jtreg/ProblemList-aot.txt | 7 ------- .../compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java | 3 +++ .../intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java | 3 +++ .../compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java | 3 +++ .../sha/sanity/TestSHA1MultiBlockIntrinsics.java | 3 +++ .../intrinsics/sha/sanity/TestSHA256Intrinsics.java | 3 +++ .../sha/sanity/TestSHA256MultiBlockIntrinsics.java | 3 +++ .../intrinsics/sha/sanity/TestSHA512Intrinsics.java | 3 +++ .../sha/sanity/TestSHA512MultiBlockIntrinsics.java | 3 +++ 9 files changed, 24 insertions(+), 7 deletions(-) diff --git a/test/hotspot/jtreg/ProblemList-aot.txt b/test/hotspot/jtreg/ProblemList-aot.txt index e584c647175..8e05a74457d 100644 --- a/test/hotspot/jtreg/ProblemList-aot.txt +++ b/test/hotspot/jtreg/ProblemList-aot.txt @@ -78,12 +78,5 @@ serviceability/sa/TestRevPtrsForInvokeDynamic.java 8216181 generic-all serviceability/sa/TestType.java 8216181 generic-all serviceability/sa/TestUniverse.java 8216181 generic-all -compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java 8167430 generic-all -compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java 8167430 generic-all -compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java 8167430 generic-all -compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java 8167430 generic-all -compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java 8167430 generic-all -compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java 8167430 generic-all - vmTestbase/vm/mlvm/indy/stress/java/relinkMutableCallSiteFreq/Test.java 8226689 generic-all vmTestbase/vm/mlvm/indy/stress/java/relinkVolatileCallSiteFreq/Test.java 8226689 generic-all diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java index 4c712b1afdc..e75a875d666 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5Intrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that MD5 intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java index bbce5531d71..e3be4116368 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestMD5MultiBlockIntrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that MD5 multi block intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java index 04963960d95..786881dd9f8 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1Intrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-1 intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java index 7c239bbc641..7300d28f9b6 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA1MultiBlockIntrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-1 multi block intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java index cfca8fa1e13..6dbb686e61a 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256Intrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-256 intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java index cdaaf049adb..1fe5160e84f 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA256MultiBlockIntrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-256 multi block intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java index 42427c0c6ea..bc9f001f8f8 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512Intrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-512 intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management diff --git a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java index 7521337b222..c825512c489 100644 --- a/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java +++ b/test/hotspot/jtreg/compiler/intrinsics/sha/sanity/TestSHA512MultiBlockIntrinsics.java @@ -25,6 +25,9 @@ * @test * @bug 8035968 * @summary Verify that SHA-512 multi block intrinsic is actually used. + * @comment the test verifies compilation of java.base methods, so it can't be run w/ AOT'ed java.base + * @requires !vm.aot.enabled + * * @library /test/lib / * @modules java.base/jdk.internal.misc * java.management From 9852a6f75c1449392b46e64db5f9913e8bdef50e Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Fri, 7 Aug 2020 19:23:53 +0200 Subject: [PATCH 27/53] 8248401: Refactor/unify RMI gc support functionality Move recent timestamp of most recent whole heap liveness analysis into CollectedHeap, removing the duplicates in all collectors Reviewed-by: kbarrett, ayang, stefank --- src/hotspot/share/gc/epsilon/epsilonHeap.hpp | 5 --- src/hotspot/share/gc/g1/g1CollectedHeap.cpp | 25 ++++++-------- src/hotspot/share/gc/g1/g1CollectedHeap.hpp | 10 ++++-- .../share/gc/g1/g1ConcurrentMarkThread.cpp | 3 +- src/hotspot/share/gc/g1/g1Policy.cpp | 3 -- src/hotspot/share/gc/g1/g1Policy.hpp | 4 --- .../gc/g1/g1YoungRemSetSamplingThread.cpp | 5 +-- .../gc/parallel/parallelScavengeHeap.cpp | 4 --- .../gc/parallel/parallelScavengeHeap.hpp | 2 -- .../share/gc/parallel/psParallelCompact.cpp | 24 ++----------- .../share/gc/parallel/psParallelCompact.hpp | 7 ---- .../share/gc/serial/defNewGeneration.cpp | 6 ---- src/hotspot/share/gc/serial/genMarkSweep.cpp | 9 ++--- src/hotspot/share/gc/shared/collectedHeap.cpp | 9 +++++ src/hotspot/share/gc/shared/collectedHeap.hpp | 19 ++++++++--- .../share/gc/shared/genCollectedHeap.cpp | 34 ------------------- .../share/gc/shared/genCollectedHeap.hpp | 10 ------ src/hotspot/share/gc/shared/generation.hpp | 20 ----------- .../gc/shenandoah/shenandoahControlThread.cpp | 3 ++ .../share/gc/shenandoah/shenandoahHeap.cpp | 6 ---- .../share/gc/shenandoah/shenandoahHeap.hpp | 3 -- src/hotspot/share/gc/z/zCollectedHeap.cpp | 4 --- src/hotspot/share/gc/z/zCollectedHeap.hpp | 2 -- src/hotspot/share/gc/z/zDriver.cpp | 3 ++ src/hotspot/share/prims/jvm.cpp | 2 +- 25 files changed, 56 insertions(+), 166 deletions(-) diff --git a/src/hotspot/share/gc/epsilon/epsilonHeap.hpp b/src/hotspot/share/gc/epsilon/epsilonHeap.hpp index 8cf9c97187a..f08c67a3c89 100644 --- a/src/hotspot/share/gc/epsilon/epsilonHeap.hpp +++ b/src/hotspot/share/gc/epsilon/epsilonHeap.hpp @@ -129,11 +129,6 @@ public: virtual void prepare_for_verify() {} virtual void verify(VerifyOption option) {} - virtual jlong millis_since_last_gc() { - // Report time since the VM start - return os::elapsed_counter() / NANOSECS_PER_MILLISEC; - } - MemRegion reserved_region() const { return _reserved; } bool is_in_reserved(const void* addr) const { return _reserved.contains(addr); } diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp index 87f290fa609..d97463c406f 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp @@ -1417,6 +1417,7 @@ G1CollectedHeap::G1CollectedHeap() : _young_gen_sampling_thread(NULL), _workers(NULL), _card_table(NULL), + _collection_pause_end(Ticks::now()), _soft_ref_policy(), _old_set("Old Region Set", new OldRegionSetChecker()), _archive_set("Archive Region Set", new ArchiveRegionSetChecker()), @@ -1966,7 +1967,8 @@ void G1CollectedHeap::increment_old_marking_cycles_started() { _old_marking_cycles_started++; } -void G1CollectedHeap::increment_old_marking_cycles_completed(bool concurrent) { +void G1CollectedHeap::increment_old_marking_cycles_completed(bool concurrent, + bool whole_heap_examined) { MonitorLocker ml(G1OldGCCount_lock, Mutex::_no_safepoint_check_flag); // We assume that if concurrent == true, then the caller is a @@ -1998,6 +2000,10 @@ void G1CollectedHeap::increment_old_marking_cycles_completed(bool concurrent) { _old_marking_cycles_started, _old_marking_cycles_completed); _old_marking_cycles_completed += 1; + if (whole_heap_examined) { + // Signal that we have completed a visit to all live objects. + record_whole_heap_examined_timestamp(); + } // We need to clear the "in_progress" flag in the CM thread before // we wake up any waiters (especially when ExplicitInvokesConcurrent @@ -2366,19 +2372,6 @@ size_t G1CollectedHeap::max_reserved_capacity() const { return _hrm->max_length() * HeapRegion::GrainBytes; } -jlong G1CollectedHeap::millis_since_last_gc() { - // See the notes in GenCollectedHeap::millis_since_last_gc() - // for more information about the implementation. - jlong ret_val = (os::javaTimeNanos() / NANOSECS_PER_MILLISEC) - - _policy->collection_pause_end_millis(); - if (ret_val < 0) { - log_warning(gc)("millis_since_last_gc() would return : " JLONG_FORMAT - ". returning zero instead.", ret_val); - return 0; - } - return ret_val; -} - void G1CollectedHeap::deduplicate_string(oop str) { assert(java_lang_String::is_instance(str), "invariant"); @@ -2641,7 +2634,7 @@ void G1CollectedHeap::gc_epilogue(bool full) { // Update common counters. if (full) { // Update the number of full collections that have been completed. - increment_old_marking_cycles_completed(false /* concurrent */); + increment_old_marking_cycles_completed(false /* concurrent */, true /* liveness_completed */); } // We are at the end of the GC. Total collections has already been increased. @@ -2665,6 +2658,8 @@ void G1CollectedHeap::gc_epilogue(bool full) { // Print NUMA statistics. _numa->print_statistics(); + + _collection_pause_end = Ticks::now(); } void G1CollectedHeap::verify_numa_regions(const char* desc) { diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp index 84874367a7c..7aeb775df4d 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp @@ -159,6 +159,8 @@ private: WorkGang* _workers; G1CardTable* _card_table; + Ticks _collection_pause_end; + SoftRefPolicy _soft_ref_policy; static size_t _humongous_object_threshold_in_words; @@ -644,7 +646,10 @@ public: // the G1OldGCCount_lock in case a Java thread is waiting for a full // GC to happen (e.g., it called System.gc() with // +ExplicitGCInvokesConcurrent). - void increment_old_marking_cycles_completed(bool concurrent); + // whole_heap_examined should indicate that during that old marking + // cycle the whole heap has been examined for live objects (as opposed + // to only parts, or aborted before completion). + void increment_old_marking_cycles_completed(bool concurrent, bool whole_heap_examined); uint old_marking_cycles_completed() { return _old_marking_cycles_completed; @@ -1288,8 +1293,7 @@ public: // Return the size of reserved memory. Returns different value than max_capacity() when AllocateOldGenAt is used. virtual size_t max_reserved_capacity() const; - virtual jlong millis_since_last_gc(); - + Tickspan time_since_last_collection() const { return Ticks::now() - _collection_pause_end; } // Convenience function to be used in situations where the heap type can be // asserted to be this type. diff --git a/src/hotspot/share/gc/g1/g1ConcurrentMarkThread.cpp b/src/hotspot/share/gc/g1/g1ConcurrentMarkThread.cpp index 445b4906e50..d297af36b07 100644 --- a/src/hotspot/share/gc/g1/g1ConcurrentMarkThread.cpp +++ b/src/hotspot/share/gc/g1/g1ConcurrentMarkThread.cpp @@ -268,7 +268,8 @@ void G1ConcurrentMarkThread::run_service() { // called System.gc() with +ExplicitGCInvokesConcurrent). { SuspendibleThreadSetJoiner sts_join; - g1h->increment_old_marking_cycles_completed(true /* concurrent */); + g1h->increment_old_marking_cycles_completed(true /* concurrent */, + !_cm->has_aborted() /* liveness_completed */); _cm->concurrent_cycle_end(); ConcurrentGCBreakpoints::notify_active_to_idle(); diff --git a/src/hotspot/share/gc/g1/g1Policy.cpp b/src/hotspot/share/gc/g1/g1Policy.cpp index f3f1edb2dd3..083da52ad84 100644 --- a/src/hotspot/share/gc/g1/g1Policy.cpp +++ b/src/hotspot/share/gc/g1/g1Policy.cpp @@ -60,7 +60,6 @@ G1Policy::G1Policy(STWGCTimer* gc_timer) : _ihop_control(create_ihop_control(&_predictor)), _policy_counters(new GCPolicyCounters("GarbageFirst", 1, 2)), _full_collection_start_sec(0.0), - _collection_pause_end_millis(os::javaTimeNanos() / NANOSECS_PER_MILLISEC), _young_list_target_length(0), _young_list_fixed_length(0), _young_list_max_length(0), @@ -648,8 +647,6 @@ void G1Policy::record_collection_pause_end(double pause_time_ms) { record_pause(this_pause, end_time_sec - pause_time_ms / 1000.0, end_time_sec); - _collection_pause_end_millis = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; - if (is_concurrent_start_pause(this_pause)) { record_concurrent_mark_init_end(0.0); } else { diff --git a/src/hotspot/share/gc/g1/g1Policy.hpp b/src/hotspot/share/gc/g1/g1Policy.hpp index 526717c569d..1f2702d641e 100644 --- a/src/hotspot/share/gc/g1/g1Policy.hpp +++ b/src/hotspot/share/gc/g1/g1Policy.hpp @@ -74,8 +74,6 @@ class G1Policy: public CHeapObj { double _full_collection_start_sec; - jlong _collection_pause_end_millis; - uint _young_list_target_length; uint _young_list_fixed_length; @@ -260,8 +258,6 @@ public: // percentage of the current heap capacity. double reclaimable_bytes_percent(size_t reclaimable_bytes) const; - jlong collection_pause_end_millis() { return _collection_pause_end_millis; } - private: void clear_collection_set_candidates(); // Sets up marking if proper conditions are met. diff --git a/src/hotspot/share/gc/g1/g1YoungRemSetSamplingThread.cpp b/src/hotspot/share/gc/g1/g1YoungRemSetSamplingThread.cpp index c57f3d7ce07..5b240c26d9f 100644 --- a/src/hotspot/share/gc/g1/g1YoungRemSetSamplingThread.cpp +++ b/src/hotspot/share/gc/g1/g1YoungRemSetSamplingThread.cpp @@ -56,14 +56,15 @@ void G1YoungRemSetSamplingThread::sleep_before_next_cycle() { } bool G1YoungRemSetSamplingThread::should_start_periodic_gc() { + G1CollectedHeap* g1h = G1CollectedHeap::heap(); // If we are currently in a concurrent mark we are going to uncommit memory soon. - if (G1CollectedHeap::heap()->concurrent_mark()->cm_thread()->during_cycle()) { + if (g1h->concurrent_mark()->cm_thread()->during_cycle()) { log_debug(gc, periodic)("Concurrent cycle in progress. Skipping."); return false; } // Check if enough time has passed since the last GC. - uintx time_since_last_gc = (uintx)Universe::heap()->millis_since_last_gc(); + uintx time_since_last_gc = (uintx)g1h->time_since_last_collection().milliseconds(); if ((time_since_last_gc < G1PeriodicGCInterval)) { log_debug(gc, periodic)("Last GC occurred " UINTX_FORMAT "ms before which is below threshold " UINTX_FORMAT "ms. Skipping.", time_since_last_gc, G1PeriodicGCInterval); diff --git a/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp b/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp index b2645223d87..edb1ca8a2d0 100644 --- a/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp +++ b/src/hotspot/share/gc/parallel/parallelScavengeHeap.cpp @@ -559,10 +559,6 @@ bool ParallelScavengeHeap::block_is_obj(const HeapWord* addr) const { return block_start(addr) == addr; } -jlong ParallelScavengeHeap::millis_since_last_gc() { - return PSParallelCompact::millis_since_last_gc(); -} - void ParallelScavengeHeap::prepare_for_verify() { ensure_parsability(false); // no need to retire TLABs for verification } diff --git a/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp b/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp index 34321547b7b..b470d5303f2 100644 --- a/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp +++ b/src/hotspot/share/gc/parallel/parallelScavengeHeap.hpp @@ -213,8 +213,6 @@ class ParallelScavengeHeap : public CollectedHeap { HeapWord* block_start(const void* addr) const; bool block_is_obj(const HeapWord* addr) const; - jlong millis_since_last_gc(); - void prepare_for_verify(); PSHeapSummary create_ps_heap_summary(); virtual void print_on(outputStream* st) const; diff --git a/src/hotspot/share/gc/parallel/psParallelCompact.cpp b/src/hotspot/share/gc/parallel/psParallelCompact.cpp index b7bb059d77f..ad50935c0c3 100644 --- a/src/hotspot/share/gc/parallel/psParallelCompact.cpp +++ b/src/hotspot/share/gc/parallel/psParallelCompact.cpp @@ -843,7 +843,6 @@ ParallelOldTracer PSParallelCompact::_gc_tracer; elapsedTimer PSParallelCompact::_accumulated_time; unsigned int PSParallelCompact::_total_invocations = 0; unsigned int PSParallelCompact::_maximum_compaction_gc_num = 0; -jlong PSParallelCompact::_time_of_last_gc = 0; CollectorCounters* PSParallelCompact::_counters = NULL; ParMarkBitMap PSParallelCompact::_mark_bitmap; ParallelCompactData PSParallelCompact::_summary_data; @@ -1070,8 +1069,8 @@ void PSParallelCompact::post_compact() heap->gen_mangle_unused_area(); } - // Update time of last GC - reset_millis_since_last_gc(); + // Signal that we have completed a visit to all live objects. + Universe::heap()->record_whole_heap_examined_timestamp(); } HeapWord* @@ -3192,25 +3191,6 @@ void PSParallelCompact::fill_blocks(size_t region_idx) } } -jlong PSParallelCompact::millis_since_last_gc() { - // We need a monotonically non-decreasing time in ms but - // os::javaTimeMillis() does not guarantee monotonicity. - jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; - jlong ret_val = now - _time_of_last_gc; - // XXX See note in genCollectedHeap::millis_since_last_gc(). - if (ret_val < 0) { - NOT_PRODUCT(log_warning(gc)("time warp: " JLONG_FORMAT, ret_val);) - return 0; - } - return ret_val; -} - -void PSParallelCompact::reset_millis_since_last_gc() { - // We need a monotonically non-decreasing time in ms but - // os::javaTimeMillis() does not guarantee monotonicity. - _time_of_last_gc = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; -} - ParMarkBitMap::IterationStatus MoveAndUpdateClosure::copy_until_full() { if (source() != copy_destination()) { diff --git a/src/hotspot/share/gc/parallel/psParallelCompact.hpp b/src/hotspot/share/gc/parallel/psParallelCompact.hpp index 12443939b98..c14dffb2334 100644 --- a/src/hotspot/share/gc/parallel/psParallelCompact.hpp +++ b/src/hotspot/share/gc/parallel/psParallelCompact.hpp @@ -1009,7 +1009,6 @@ class PSParallelCompact : AllStatic { static elapsedTimer _accumulated_time; static unsigned int _total_invocations; static unsigned int _maximum_compaction_gc_num; - static jlong _time_of_last_gc; // ms static CollectorCounters* _counters; static ParMarkBitMap _mark_bitmap; static ParallelCompactData _summary_data; @@ -1123,9 +1122,6 @@ class PSParallelCompact : AllStatic { static void enqueue_dense_prefix_tasks(TaskQueue& task_queue, uint parallel_gc_threads); - // Reset time since last full gc - static void reset_millis_since_last_gc(); - #ifndef PRODUCT // Print generic summary data static void print_generic_summary_data(ParallelCompactData& summary_data, @@ -1249,9 +1245,6 @@ class PSParallelCompact : AllStatic { // Return the SpaceId for the given address. static SpaceId space_id(HeapWord* addr); - // Time since last full gc (in milliseconds). - static jlong millis_since_last_gc(); - static void print_on_error(outputStream* st); #ifndef PRODUCT diff --git a/src/hotspot/share/gc/serial/defNewGeneration.cpp b/src/hotspot/share/gc/serial/defNewGeneration.cpp index 06bb7c21971..5f9a88a0900 100644 --- a/src/hotspot/share/gc/serial/defNewGeneration.cpp +++ b/src/hotspot/share/gc/serial/defNewGeneration.cpp @@ -680,12 +680,6 @@ void DefNewGeneration::collect(bool full, from()->set_concurrent_iteration_safe_limit(from()->top()); to()->set_concurrent_iteration_safe_limit(to()->top()); - // We need to use a monotonically non-decreasing time in ms - // or we will see time-warp warnings and os::javaTimeMillis() - // does not guarantee monotonicity. - jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; - update_time_of_last_gc(now); - heap->trace_heap_after_gc(&gc_tracer); _gc_timer->register_gc_end(); diff --git a/src/hotspot/share/gc/serial/genMarkSweep.cpp b/src/hotspot/share/gc/serial/genMarkSweep.cpp index 28c5990c66e..33afe2666ee 100644 --- a/src/hotspot/share/gc/serial/genMarkSweep.cpp +++ b/src/hotspot/share/gc/serial/genMarkSweep.cpp @@ -137,13 +137,8 @@ void GenMarkSweep::invoke_at_safepoint(ReferenceProcessor* rp, bool clear_all_so // input to soft ref clearing policy at the next gc. Universe::update_heap_info_at_gc(); - // Update time of last gc for all generations we collected - // (which currently is all the generations in the heap). - // We need to use a monotonically non-decreasing time in ms - // or we will see time-warp warnings and os::javaTimeMillis() - // does not guarantee monotonicity. - jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; - gch->update_time_of_last_gc(now); + // Signal that we have completed a visit to all live objects. + Universe::heap()->record_whole_heap_examined_timestamp(); gch->trace_heap_after_gc(_gc_tracer); } diff --git a/src/hotspot/share/gc/shared/collectedHeap.cpp b/src/hotspot/share/gc/shared/collectedHeap.cpp index 0b7c47ea859..fedb9d3fe88 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.cpp +++ b/src/hotspot/share/gc/shared/collectedHeap.cpp @@ -191,6 +191,7 @@ bool CollectedHeap::is_oop(oop object) const { CollectedHeap::CollectedHeap() : _is_gc_active(false), + _last_whole_heap_examined_time_ns(os::javaTimeNanos()), _total_collections(0), _total_full_collections(0), _gc_cause(GCCause::_no_gc), @@ -488,6 +489,14 @@ void CollectedHeap::resize_all_tlabs() { } } +jlong CollectedHeap::millis_since_last_whole_heap_examined() { + return (os::javaTimeNanos() - _last_whole_heap_examined_time_ns) / NANOSECS_PER_MILLISEC; +} + +void CollectedHeap::record_whole_heap_examined_timestamp() { + _last_whole_heap_examined_time_ns = os::javaTimeNanos(); +} + void CollectedHeap::full_gc_dump(GCTimer* timer, bool before) { assert(timer != NULL, "timer is null"); if ((HeapDumpBeforeFullGC && before) || (HeapDumpAfterFullGC && !before)) { diff --git a/src/hotspot/share/gc/shared/collectedHeap.hpp b/src/hotspot/share/gc/shared/collectedHeap.hpp index 71a3235ba72..b9675eb75b2 100644 --- a/src/hotspot/share/gc/shared/collectedHeap.hpp +++ b/src/hotspot/share/gc/shared/collectedHeap.hpp @@ -112,6 +112,12 @@ class CollectedHeap : public CHeapObj { // Used for filler objects (static, but initialized in ctor). static size_t _filler_array_max_size; + // Last time the whole heap has been examined in support of RMI + // MaxObjectInspectionAge. + // This timestamp must be monotonically non-decreasing to avoid + // time-warp warnings. + jlong _last_whole_heap_examined_time_ns; + unsigned int _total_collections; // ... started unsigned int _total_full_collections; // ... started NOT_PRODUCT(volatile size_t _promotion_failure_alot_count;) @@ -404,15 +410,18 @@ class CollectedHeap : public CHeapObj { // Keep alive an object that was loaded with AS_NO_KEEPALIVE. virtual void keep_alive(oop obj) {} - // Returns the longest time (in ms) that has elapsed since the last - // time that any part of the heap was examined by a garbage collection. - virtual jlong millis_since_last_gc() = 0; - // Perform any cleanup actions necessary before allowing a verification. virtual void prepare_for_verify() = 0; - // Generate any dumps preceding or following a full gc + // Returns the longest time (in ms) that has elapsed since the last + // time that the whole heap has been examined by a garbage collection. + jlong millis_since_last_whole_heap_examined(); + // GC should call this when the next whole heap analysis has completed to + // satisfy above requirement. + void record_whole_heap_examined_timestamp(); + private: + // Generate any dumps preceding or following a full gc void full_gc_dump(GCTimer* timer, bool before); virtual void initialize_serviceability() = 0; diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.cpp b/src/hotspot/share/gc/shared/genCollectedHeap.cpp index 06df00ce324..da133f07d8a 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.cpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.cpp @@ -1354,37 +1354,3 @@ oop GenCollectedHeap::handle_failed_promotion(Generation* old_gen, } return oop(result); } - -class GenTimeOfLastGCClosure: public GenCollectedHeap::GenClosure { - jlong _time; // in ms - jlong _now; // in ms - - public: - GenTimeOfLastGCClosure(jlong now) : _time(now), _now(now) { } - - jlong time() { return _time; } - - void do_generation(Generation* gen) { - _time = MIN2(_time, gen->time_of_last_gc(_now)); - } -}; - -jlong GenCollectedHeap::millis_since_last_gc() { - // javaTimeNanos() is guaranteed to be monotonically non-decreasing - // provided the underlying platform provides such a time source - // (and it is bug free). So we still have to guard against getting - // back a time later than 'now'. - jlong now = os::javaTimeNanos() / NANOSECS_PER_MILLISEC; - GenTimeOfLastGCClosure tolgc_cl(now); - // iterate over generations getting the oldest - // time that a generation was collected - generation_iterate(&tolgc_cl, false); - - jlong retVal = now - tolgc_cl.time(); - if (retVal < 0) { - log_warning(gc)("millis_since_last_gc() would return : " JLONG_FORMAT - ". returning zero instead.", retVal); - return 0; - } - return retVal; -} diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.hpp b/src/hotspot/share/gc/shared/genCollectedHeap.hpp index af96e618544..e3ab3742fe4 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.hpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.hpp @@ -289,10 +289,6 @@ public: // Ensure parsability: override virtual void ensure_parsability(bool retire_tlabs); - // Time in ms since the longest time a collector ran in - // in any generation. - virtual jlong millis_since_last_gc(); - // Total number of full collections completed. unsigned int total_full_collections_completed() { assert(_full_collections_completed <= _total_full_collections, @@ -305,12 +301,6 @@ public: // Update above counter, as appropriate, at the end of a concurrent GC cycle unsigned int update_full_collections_completed(unsigned int count); - // Update "time of last gc" for all generations to "now". - void update_time_of_last_gc(jlong now) { - _young_gen->update_time_of_last_gc(now); - _old_gen->update_time_of_last_gc(now); - } - // Update the gc statistics for each generation. void update_gc_stats(Generation* current_generation, bool full) { _old_gen->update_gc_stats(current_generation, full); diff --git a/src/hotspot/share/gc/shared/generation.hpp b/src/hotspot/share/gc/shared/generation.hpp index b9ea9f60be0..196f83be83d 100644 --- a/src/hotspot/share/gc/shared/generation.hpp +++ b/src/hotspot/share/gc/shared/generation.hpp @@ -75,7 +75,6 @@ struct ScratchBlock { class Generation: public CHeapObj { friend class VMStructs; private: - jlong _time_of_last_gc; // time when last gc on this generation happened (ms) MemRegion _prev_used_region; // for collectors that want to "remember" a value for // used region at some specific point during collection. @@ -363,25 +362,6 @@ class Generation: public CHeapObj { // activity to make them parsable again. The default is to do nothing. virtual void ensure_parsability() {} - // Time (in ms) when we were last collected or now if a collection is - // in progress. - virtual jlong time_of_last_gc(jlong now) { - // Both _time_of_last_gc and now are set using a time source - // that guarantees monotonically non-decreasing values provided - // the underlying platform provides such a source. So we still - // have to guard against non-monotonicity. - NOT_PRODUCT( - if (now < _time_of_last_gc) { - log_warning(gc)("time warp: " JLONG_FORMAT " to " JLONG_FORMAT, _time_of_last_gc, now); - } - ) - return _time_of_last_gc; - } - - virtual void update_time_of_last_gc(jlong now) { - _time_of_last_gc = now; - } - // Generations may keep statistics about collection. This method // updates those statistics. current_generation is the generation // that was most recently collected. This allows the generation to diff --git a/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp b/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp index dd8134a0774..c0fae236f6e 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp @@ -235,6 +235,9 @@ void ShenandoahControlThread::run_service() { // global soft refs policy, and we better report it every time heap // usage goes down. Universe::update_heap_info_at_gc(); + + // Signal that we have completed a visit to all live objects. + Universe::heap()->record_whole_heap_examined_timestamp(); } // Disable forced counters update, and update counters one more time diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp index 0a1350e524f..f5a0579d0c3 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp @@ -1193,12 +1193,6 @@ bool ShenandoahHeap::print_location(outputStream* st, void* addr) const { return BlockLocationPrinter::print_location(st, addr); } -jlong ShenandoahHeap::millis_since_last_gc() { - double v = heuristics()->time_since_last_gc() * 1000; - assert(0 <= v && v <= max_jlong, "value should fit: %f", v); - return (jlong)v; -} - void ShenandoahHeap::prepare_for_verify() { if (SafepointSynchronize::is_at_safepoint() && UseTLAB) { labs_make_parsable(); diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp b/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp index 41f9060b7bc..38cc96b37c7 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp @@ -556,9 +556,6 @@ public: // Keep alive an object that was loaded with AS_NO_KEEPALIVE. void keep_alive(oop obj); - // Used by RMI - jlong millis_since_last_gc(); - // ---------- Safepoint interface hooks // public: diff --git a/src/hotspot/share/gc/z/zCollectedHeap.cpp b/src/hotspot/share/gc/z/zCollectedHeap.cpp index bb7734d707e..ce6b196c28b 100644 --- a/src/hotspot/share/gc/z/zCollectedHeap.cpp +++ b/src/hotspot/share/gc/z/zCollectedHeap.cpp @@ -277,10 +277,6 @@ WorkGang* ZCollectedHeap::get_safepoint_workers() { return _runtime_workers.workers(); } -jlong ZCollectedHeap::millis_since_last_gc() { - return ZStatCycle::time_since_last() / MILLIUNITS; -} - void ZCollectedHeap::gc_threads_do(ThreadClosure* tc) const { tc->do_thread(_director); tc->do_thread(_driver); diff --git a/src/hotspot/share/gc/z/zCollectedHeap.hpp b/src/hotspot/share/gc/z/zCollectedHeap.hpp index a2851e67c3a..b54c70c083d 100644 --- a/src/hotspot/share/gc/z/zCollectedHeap.hpp +++ b/src/hotspot/share/gc/z/zCollectedHeap.hpp @@ -107,8 +107,6 @@ public: virtual WorkGang* get_safepoint_workers(); - virtual jlong millis_since_last_gc(); - virtual void gc_threads_do(ThreadClosure* tc) const; virtual VirtualSpaceSummary create_heap_space_summary(); diff --git a/src/hotspot/share/gc/z/zDriver.cpp b/src/hotspot/share/gc/z/zDriver.cpp index ee25c5ca006..5367d04c4b2 100644 --- a/src/hotspot/share/gc/z/zDriver.cpp +++ b/src/hotspot/share/gc/z/zDriver.cpp @@ -381,6 +381,9 @@ public: // Update data used by soft reference policy Universe::update_heap_info_at_gc(); + + // Signal that we have completed a visit to all live objects + Universe::heap()->record_whole_heap_examined_timestamp(); } }; diff --git a/src/hotspot/share/prims/jvm.cpp b/src/hotspot/share/prims/jvm.cpp index 52ce0042526..f1c29aaf068 100644 --- a/src/hotspot/share/prims/jvm.cpp +++ b/src/hotspot/share/prims/jvm.cpp @@ -502,7 +502,7 @@ JVM_END JVM_LEAF(jlong, JVM_MaxObjectInspectionAge(void)) JVMWrapper("JVM_MaxObjectInspectionAge"); - return Universe::heap()->millis_since_last_gc(); + return Universe::heap()->millis_since_last_whole_heap_examined(); JVM_END From c8c4d8377a0acbe1e1059cfc0aacf416e91df0fc Mon Sep 17 00:00:00 2001 From: Patrick Concannon Date: Fri, 7 Aug 2020 20:39:10 +0100 Subject: [PATCH 28/53] 8250886: java/net/DatagramSocket/SendReceiveMaxSize.java fails in timeout SO_RCVBUF was previously set to match the SO_SNDBUF, however the kernel value for SO_RCVBUF is much larger. This mismatch caused the test to fail, and the fix removes this issue. Reviewed-by: alanb, dfuchs --- src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c | 7 ------- test/jdk/java/net/DatagramSocket/SendReceiveMaxSize.java | 3 ++- 2 files changed, 2 insertions(+), 8 deletions(-) diff --git a/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c b/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c index dc4abafcd68..7c9c5bf4693 100644 --- a/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c +++ b/src/java.base/unix/native/libnet/PlainDatagramSocketImpl.c @@ -908,13 +908,6 @@ Java_java_net_PlainDatagramSocketImpl_datagramSocketCreate(JNIEnv *env, close(fd); return; } - if (setsockopt(fd, SOL_SOCKET, SO_RCVBUF, - (char *)&arg, sizeof(arg)) < 0) { - getErrorString(errno, tmpbuf, sizeof(tmpbuf)); - JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", tmpbuf); - close(fd); - return; - } #endif /* __APPLE__ */ if (setsockopt(fd, SOL_SOCKET, SO_BROADCAST, (char*) &t, sizeof (int)) < 0) { diff --git a/test/jdk/java/net/DatagramSocket/SendReceiveMaxSize.java b/test/jdk/java/net/DatagramSocket/SendReceiveMaxSize.java index 9cb7ddae866..535c4551d85 100644 --- a/test/jdk/java/net/DatagramSocket/SendReceiveMaxSize.java +++ b/test/jdk/java/net/DatagramSocket/SendReceiveMaxSize.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8242885 + * @bug 8242885 8250886 * @summary This test verifies that on macOS, the send buffer size is configured * by default so that none of our implementations of the UDP protocol * will fail with a "packet too large" exception when trying to send a @@ -37,6 +37,7 @@ * @run testng/othervm -Djava.net.preferIPv4Stack=true SendReceiveMaxSize * @run testng/othervm -Djava.net.preferIPv6Addresses=true SendReceiveMaxSize * @run testng/othervm -Djdk.net.usePlainDatagramSocketImpl SendReceiveMaxSize + * @run testng/othervm -Djdk.net.usePlainDatagramSocketImpl -Djava.net.preferIPv4Stack=true SendReceiveMaxSize * @run testng/othervm -Djdk.net.usePlainDatagramSocketImpl -Djava.net.preferIPv6Addresses=true SendReceiveMaxSize */ From 4ac45a3b505d35ccfc1d5ebddb879e693f77e026 Mon Sep 17 00:00:00 2001 From: Raffaello Giulietti Date: Fri, 7 Aug 2020 12:58:40 -0700 Subject: [PATCH 29/53] 8245036: DataInputStream.readFully(byte[], int, int) does not throw expected IndexOutOfBoundsExceptions Reviewed-by: bpb --- .../classes/java/io/DataInputStream.java | 7 +- .../java/io/DataInputStream/ReadFully.java | 116 +++++++++++++++--- 2 files changed, 101 insertions(+), 22 deletions(-) diff --git a/src/java.base/share/classes/java/io/DataInputStream.java b/src/java.base/share/classes/java/io/DataInputStream.java index 5bd76c27466..401a9764c62 100644 --- a/src/java.base/share/classes/java/io/DataInputStream.java +++ b/src/java.base/share/classes/java/io/DataInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1994, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1994, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,6 +25,8 @@ package java.io; +import java.util.Objects; + /** * A data input stream lets an application read primitive Java data * types from an underlying input stream in a machine-independent @@ -192,8 +194,7 @@ public class DataInputStream extends FilterInputStream implements DataInput { * @see java.io.FilterInputStream#in */ public final void readFully(byte b[], int off, int len) throws IOException { - if (len < 0) - throw new IndexOutOfBoundsException(); + Objects.checkFromIndexSize(off, len, b.length); int n = 0; while (n < len) { int count = in.read(b, off + n, len - n); diff --git a/test/jdk/java/io/DataInputStream/ReadFully.java b/test/jdk/java/io/DataInputStream/ReadFully.java index 48408ca4ffa..137655af324 100644 --- a/test/jdk/java/io/DataInputStream/ReadFully.java +++ b/test/jdk/java/io/DataInputStream/ReadFully.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,30 +22,108 @@ */ /* @test - * @bug 4214513 - * @summary Passing a negative length argument for readFully must throw - * IndexOutOfBoundsException. + * @bug 4214513 8245036 + * @summary Passing a negative offset or length, + * or passing a combination of offset and length too big + * for readFully must throw IndexOutOfBoundsException. */ - import java.io.*; + public class ReadFully { - public static final void main(String[] args) throws Exception { - byte[] buffer = new byte[100]; + + private static final void testNegativeOffset() throws Exception { File file = new File(System.getProperty("test.src"), "ReadFully.java"); - FileInputStream in = new FileInputStream(file); - DataInputStream dis = new DataInputStream(in); - - boolean caughtException = false; - try { - dis.readFully(buffer, 0, -20); - } catch (IndexOutOfBoundsException ie) { - caughtException = true; - } finally { - dis.close(); - if (!caughtException) - throw new RuntimeException("Test failed"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, -1, buffer.length); + throw new RuntimeException("Test testNegativeOffset() failed"); + } catch (IndexOutOfBoundsException ignore) { } } + + private static final void testNegativeLength() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, 0, -1); + throw new RuntimeException("Test testNegativeLength() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + private static final void testNegativeOffsetZeroLength() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, -1, 0); + throw new RuntimeException("Test testNegativeOffsetZeroLength() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + private static final void testBigOffsetLength1() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, 0, buffer.length + 1); + throw new RuntimeException("Test testBigOffsetLength1() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + private static final void testBigOffsetLength2() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, 1, buffer.length); + throw new RuntimeException("Test testBigOffsetLength2() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + private static final void testBigOffsetLength3() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, buffer.length, 1); + throw new RuntimeException("Test testBigOffsetLength3() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + private static final void testBigOffsetLength4() throws Exception { + File file = new File(System.getProperty("test.src"), + "ReadFully.java"); + try (FileInputStream in = new FileInputStream(file); + DataInputStream dis = new DataInputStream(in);) { + byte[] buffer = new byte[100]; + dis.readFully(buffer, buffer.length + 1, 0); + throw new RuntimeException("Test testBigOffsetLength4() failed"); + } catch (IndexOutOfBoundsException ignore) { + } + } + + public static final void main(String[] args) throws Exception { + testNegativeOffset(); + testNegativeLength(); + testNegativeOffsetZeroLength(); + testBigOffsetLength1(); + testBigOffsetLength2(); + testBigOffsetLength3(); + testBigOffsetLength4(); + } + } From 3c276ce1fec17ed0238cc977320f2c82965fc45b Mon Sep 17 00:00:00 2001 From: Evgeny Nikitin Date: Mon, 27 Jul 2020 21:17:44 +0200 Subject: [PATCH 30/53] 8067651: LevelTransitionTest.java, fix trivial methods levels logic Make test method really trivial, adjust trivial logic, make logic independent of background compilation. Reviewed-by: iignatyev, thartmann, kvn --- .../ConstantGettersTransitionsTest.java | 4 +- .../compiler/tiered/LevelTransitionTest.java | 61 ++++-------------- .../jtreg/compiler/tiered/MethodHelper.java | 64 +++++++++++++++++++ 3 files changed, 80 insertions(+), 49 deletions(-) create mode 100644 test/hotspot/jtreg/compiler/tiered/MethodHelper.java diff --git a/test/hotspot/jtreg/compiler/tiered/ConstantGettersTransitionsTest.java b/test/hotspot/jtreg/compiler/tiered/ConstantGettersTransitionsTest.java index 6503f4d5b9b..52c466aa3f1 100644 --- a/test/hotspot/jtreg/compiler/tiered/ConstantGettersTransitionsTest.java +++ b/test/hotspot/jtreg/compiler/tiered/ConstantGettersTransitionsTest.java @@ -106,8 +106,8 @@ public class ConstantGettersTransitionsTest extends LevelTransitionTest { private ConstantGettersTestCase() { String name = "make" + this.name(); - this.executable = LevelTransitionTest.Helper.getMethod(TrivialMethods.class, name); - this.callable = LevelTransitionTest.Helper.getCallable(new TrivialMethods(), name); + this.executable = MethodHelper.getMethod(TrivialMethods.class, name); + this.callable = MethodHelper.getCallable(new TrivialMethods(), name); } /** diff --git a/test/hotspot/jtreg/compiler/tiered/LevelTransitionTest.java b/test/hotspot/jtreg/compiler/tiered/LevelTransitionTest.java index 2019f2ec0bb..c5d8e3b6258 100644 --- a/test/hotspot/jtreg/compiler/tiered/LevelTransitionTest.java +++ b/test/hotspot/jtreg/compiler/tiered/LevelTransitionTest.java @@ -23,6 +23,7 @@ /** * @test LevelTransitionTest + * @requires vm.compMode != "Xcomp" * @summary Test the correctness of compilation level transitions for different methods * @library /test/lib / * @modules java.base/jdk.internal.misc @@ -33,6 +34,7 @@ * @run driver ClassFileInstaller sun.hotspot.WhiteBox * @run main/othervm/timeout=240 -Xmixed -Xbootclasspath/a:. -XX:+UnlockDiagnosticVMOptions * -XX:+WhiteBoxAPI -XX:+TieredCompilation -XX:-UseCounterDecay + * -XX:-BackgroundCompilation * -XX:CompileCommand=compileonly,compiler.whitebox.SimpleTestCaseHelper::* * -XX:CompileCommand=compileonly,compiler.tiered.LevelTransitionTest$ExtendedTestCase$CompileMethodHolder::* * compiler.tiered.LevelTransitionTest @@ -42,11 +44,11 @@ package compiler.tiered; import compiler.whitebox.CompilerWhiteBoxTest; import compiler.whitebox.SimpleTestCase; +import jdk.test.lib.Platform; import jtreg.SkippedException; import java.lang.reflect.Executable; import java.lang.reflect.Method; -import java.util.Objects; import java.util.concurrent.Callable; public class LevelTransitionTest extends TieredLevelsTest { @@ -98,6 +100,7 @@ public class LevelTransitionTest extends TieredLevelsTest { int newLevel; int current = getCompLevel(); int expected = getNextLevel(current); + System.out.println("Levels, current: " + current + ", expected: " + expected); if (current == expected) { // if we are on expected level, just execute it more // to ensure that the level won't change @@ -107,9 +110,10 @@ public class LevelTransitionTest extends TieredLevelsTest { finish = true; } else { newLevel = changeCompLevel(); + System.out.printf("Method %s has been compiled to level %d. Expected level is %d%n", + method, newLevel, expected); finish = false; } - System.out.printf("Method %s is compiled on level %d. Expected level is %d%n", method, newLevel, expected); checkLevel(expected, newLevel); printInfo(); } @@ -126,8 +130,9 @@ public class LevelTransitionTest extends TieredLevelsTest { int nextLevel = currentLevel; switch (currentLevel) { case CompilerWhiteBoxTest.COMP_LEVEL_NONE: - nextLevel = isMethodProfiled ? CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION - : CompilerWhiteBoxTest.COMP_LEVEL_FULL_PROFILE; + nextLevel = isTrivial() ? CompilerWhiteBoxTest.COMP_LEVEL_SIMPLE : + isMethodProfiled ? CompilerWhiteBoxTest.COMP_LEVEL_FULL_OPTIMIZATION : + CompilerWhiteBoxTest.COMP_LEVEL_FULL_PROFILE; break; case CompilerWhiteBoxTest.COMP_LEVEL_LIMITED_PROFILE: case CompilerWhiteBoxTest.COMP_LEVEL_FULL_PROFILE: @@ -148,7 +153,7 @@ public class LevelTransitionTest extends TieredLevelsTest { return testCase == ExtendedTestCase.ACCESSOR_TEST || testCase == SimpleTestCase.METHOD_TEST || testCase == SimpleTestCase.STATIC_TEST - || (testCase == ExtendedTestCase.TRIVIAL_CODE_TEST && isMethodProfiled); + || testCase == ExtendedTestCase.TRIVIAL_CODE_TEST; } /** @@ -170,42 +175,6 @@ public class LevelTransitionTest extends TieredLevelsTest { return newLevel; } - protected static class Helper { - /** - * Gets method from a specified class using its name - * - * @param aClass type method belongs to - * @param name the name of the method - * @return {@link Method} that represents corresponding class method - */ - public static Method getMethod(Class aClass, String name) { - Method method; - try { - method = aClass.getDeclaredMethod(name); - } catch (NoSuchMethodException e) { - throw new Error("TESTBUG: Unable to get method " + name, e); - } - return method; - } - - /** - * Gets {@link Callable} that invokes given method from the given object - * - * @param object the object the specified method is invoked from - * @param name the name of the method - */ - public static Callable getCallable(Object object, String name) { - Method method = getMethod(object.getClass(), name); - return () -> { - try { - return Objects.hashCode(method.invoke(object)); - } catch (ReflectiveOperationException e) { - throw new Error("TESTBUG: Invocation failure", e); - } - }; - } - } - private static enum ExtendedTestCase implements CompilerWhiteBoxTest.TestCase { ACCESSOR_TEST("accessor"), NONTRIVIAL_METHOD_TEST("nonTrivialMethod"), @@ -230,8 +199,8 @@ public class LevelTransitionTest extends TieredLevelsTest { } private ExtendedTestCase(String methodName) { - this.executable = LevelTransitionTest.Helper.getMethod(CompileMethodHolder.class, methodName); - this.callable = LevelTransitionTest.Helper.getCallable(new CompileMethodHolder(), methodName); + this.executable = MethodHelper.getMethod(CompileMethodHolder.class, methodName); + this.callable = MethodHelper.getCallable(new CompileMethodHolder(), methodName); } private static class CompileMethodHolder { @@ -257,12 +226,10 @@ public class LevelTransitionTest extends TieredLevelsTest { } /** - * Method considered as trivial by amount of code + * Method considered as trivial by type (constant getter) */ public int trivialCode() { - int var = 0xBAAD_C0DE; - var *= field; - return var; + return 0x42; } } } diff --git a/test/hotspot/jtreg/compiler/tiered/MethodHelper.java b/test/hotspot/jtreg/compiler/tiered/MethodHelper.java new file mode 100644 index 00000000000..ee2fd570e0b --- /dev/null +++ b/test/hotspot/jtreg/compiler/tiered/MethodHelper.java @@ -0,0 +1,64 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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. + */ + +package compiler.tiered; + +import java.lang.reflect.Method; +import java.util.Objects; +import java.util.concurrent.Callable; + +public class MethodHelper { + /** + * Gets method from a specified class using its name + * + * @param aClass type method belongs to + * @param name the name of the method + * @return {@link Method} that represents corresponding class method + */ + public static Method getMethod(Class aClass, String name) { + Method method; + try { + method = aClass.getDeclaredMethod(name); + } catch (NoSuchMethodException e) { + throw new Error("TESTBUG: Unable to get method " + name, e); + } + return method; + } + + /** + * Gets {@link Callable} that invokes given method from the given object + * + * @param object the object the specified method is invoked from + * @param name the name of the method + */ + public static Callable getCallable(Object object, String name) { + Method method = getMethod(object.getClass(), name); + return () -> { + try { + return Objects.hashCode(method.invoke(object)); + } catch (ReflectiveOperationException e) { + throw new Error("TESTBUG: Invocation failure", e); + } + }; + } +} From 084e15bca3d1dc2cbede47f31b15498785aef466 Mon Sep 17 00:00:00 2001 From: Alexander Matveev Date: Fri, 7 Aug 2020 19:04:45 -0700 Subject: [PATCH 31/53] 8248905: [macos] symbolic links not properly resolved Reviewed-by: herrick, asemenyuk --- .../macosx/native/common/MacSysInfo.cpp | 32 +++++++++++++++++-- 1 file changed, 30 insertions(+), 2 deletions(-) diff --git a/src/jdk.incubator.jpackage/macosx/native/common/MacSysInfo.cpp b/src/jdk.incubator.jpackage/macosx/native/common/MacSysInfo.cpp index 838023a3012..401c7b8caf2 100644 --- a/src/jdk.incubator.jpackage/macosx/native/common/MacSysInfo.cpp +++ b/src/jdk.incubator.jpackage/macosx/native/common/MacSysInfo.cpp @@ -23,12 +23,39 @@ * questions. */ +#include +#include #include #include "FileUtils.h" #include "ErrorHandling.h" namespace SysInfo { +tstring getRealPath(const std::vector& in) { + std::vector out(PATH_MAX); + + struct stat sb; + if (lstat(in.data(), &sb) == -1) { + JP_THROW(tstrings::any() << "lstat(" << in.data() + << ") failed. Error: " << lastCRTError()); + } + + // readlink() will fail if called on real path, so if we have real path, then just + // use it + if (!S_ISLNK(sb.st_mode)) { + return tstring(in.data(), in.size() - 1 /* don't count trailing '0' */); + } + + // Get real path, since _NSGetExecutablePath can return symbolic link + ssize_t len = readlink(in.data(), out.data(), PATH_MAX); + if (len < 0) { + JP_THROW(tstrings::any() << "readlink(" << in.data() + << ") failed. Error: " << lastCRTError()); + } + + return tstring(out.data(), len); +} + tstring getProcessModulePath() { std::vector buffer; uint32_t bufferSize = 0; @@ -44,8 +71,9 @@ tstring getProcessModulePath() { buffer.resize(bufferSize); } while (true); - tstring reply = tstring(buffer.data(), - buffer.size() - 1 /* don't count trailing '0' */); + + tstring reply = getRealPath(buffer); + return FileUtils::toAbsolutePath(reply); } From 3ed56830b43d847e99395f22e6b9f4e1f3b418d8 Mon Sep 17 00:00:00 2001 From: Jatin Bhateja Date: Sun, 9 Aug 2020 02:03:09 +0530 Subject: [PATCH 32/53] 8248830: C2: Optimize Rotate API on x86 Improved existing scalar rotate operations, added support for vector rotate operations using new AVX512 instructions. Reviewed-by: vlivanov, kvn --- src/hotspot/cpu/x86/assembler_x86.cpp | 133 ++++++- src/hotspot/cpu/x86/assembler_x86.hpp | 19 + src/hotspot/cpu/x86/c2_MacroAssembler_x86.cpp | 84 +++++ src/hotspot/cpu/x86/c2_MacroAssembler_x86.hpp | 7 + src/hotspot/cpu/x86/x86.ad | 77 ++++ src/hotspot/cpu/x86/x86_64.ad | 354 +++++------------- src/hotspot/share/adlc/formssel.cpp | 4 +- src/hotspot/share/opto/addnode.cpp | 80 ++++ src/hotspot/share/opto/addnode.hpp | 2 + src/hotspot/share/opto/classes.hpp | 4 + src/hotspot/share/opto/mulnode.cpp | 96 +++++ src/hotspot/share/opto/mulnode.hpp | 23 ++ src/hotspot/share/opto/superword.cpp | 28 +- src/hotspot/share/opto/vectornode.cpp | 209 ++++++++++- src/hotspot/share/opto/vectornode.hpp | 25 +- .../compiler/c2/cr6340864/TestIntVect.java | 109 +++++- .../compiler/c2/cr6340864/TestLongVect.java | 106 ++++++ .../jtreg/compiler/intrinsics/TestRotate.java | 309 +++++++++++++++ .../bench/java/lang/RotateBenchmark.java | 87 +++++ 19 files changed, 1474 insertions(+), 282 deletions(-) create mode 100644 test/hotspot/jtreg/compiler/intrinsics/TestRotate.java create mode 100644 test/micro/org/openjdk/bench/java/lang/RotateBenchmark.java diff --git a/src/hotspot/cpu/x86/assembler_x86.cpp b/src/hotspot/cpu/x86/assembler_x86.cpp index 20b0dbc4f89..ef04d33c7f4 100644 --- a/src/hotspot/cpu/x86/assembler_x86.cpp +++ b/src/hotspot/cpu/x86/assembler_x86.cpp @@ -4311,6 +4311,58 @@ void Assembler::roll(Register dst, int imm8) { } } +void Assembler::roll(Register dst) { + int encode = prefix_and_encode(dst->encoding()); + emit_int16((unsigned char)0xD3, (0xC0 | encode)); +} + +void Assembler::rorl(Register dst, int imm8) { + assert(isShiftCount(imm8 >> 1), "illegal shift count"); + int encode = prefix_and_encode(dst->encoding()); + if (imm8 == 1) { + emit_int16((unsigned char)0xD1, (0xC8 | encode)); + } else { + emit_int24((unsigned char)0xC1, (0xc8 | encode), imm8); + } +} + +void Assembler::rorl(Register dst) { + int encode = prefix_and_encode(dst->encoding()); + emit_int16((unsigned char)0xD3, (0xC8 | encode)); +} + +#ifdef _LP64 +void Assembler::rorq(Register dst) { + int encode = prefixq_and_encode(dst->encoding()); + emit_int16((unsigned char)0xD3, (0xC8 | encode)); +} + +void Assembler::rorq(Register dst, int imm8) { + assert(isShiftCount(imm8 >> 1), "illegal shift count"); + int encode = prefixq_and_encode(dst->encoding()); + if (imm8 == 1) { + emit_int16((unsigned char)0xD1, (0xC8 | encode)); + } else { + emit_int24((unsigned char)0xC1, (0xc8 | encode), imm8); + } +} + +void Assembler::rolq(Register dst) { + int encode = prefixq_and_encode(dst->encoding()); + emit_int16((unsigned char)0xD3, (0xC0 | encode)); +} + +void Assembler::rolq(Register dst, int imm8) { + assert(isShiftCount(imm8 >> 1), "illegal shift count"); + int encode = prefixq_and_encode(dst->encoding()); + if (imm8 == 1) { + emit_int16((unsigned char)0xD1, (0xC0 | encode)); + } else { + emit_int24((unsigned char)0xC1, (0xc0 | encode), imm8); + } +} +#endif + void Assembler::sahf() { #ifdef _LP64 // Not supported in 64bit mode @@ -6226,6 +6278,78 @@ void Assembler::evpxorq(XMMRegister dst, XMMRegister nds, Address src, int vecto emit_operand(dst, src); } +void Assembler::evprold(XMMRegister dst, XMMRegister src, int shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(xmm1->encoding(), dst->encoding(), src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F, &attributes); + emit_int24(0x72, (0xC0 | encode), shift & 0xFF); +} + +void Assembler::evprolq(XMMRegister dst, XMMRegister src, int shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ true, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(xmm1->encoding(), dst->encoding(), src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F, &attributes); + emit_int24(0x72, (0xC0 | encode), shift & 0xFF); +} + +void Assembler::evprord(XMMRegister dst, XMMRegister src, int shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(xmm0->encoding(), dst->encoding(), src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F, &attributes); + emit_int24(0x72, (0xC0 | encode), shift & 0xFF); +} + +void Assembler::evprorq(XMMRegister dst, XMMRegister src, int shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ true, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(xmm0->encoding(), dst->encoding(), src->encoding(), VEX_SIMD_66, VEX_OPCODE_0F, &attributes); + emit_int24(0x72, (0xC0 | encode), shift & 0xFF); +} + +void Assembler::evprolvd(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(dst->encoding(), src->encoding(), shift->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); + emit_int16(0x15, (unsigned char)(0xC0 | encode)); +} + +void Assembler::evprolvq(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ true, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(dst->encoding(), src->encoding(), shift->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); + emit_int16(0x15, (unsigned char)(0xC0 | encode)); +} + +void Assembler::evprorvd(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ false, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(dst->encoding(), src->encoding(), shift->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); + emit_int16(0x14, (unsigned char)(0xC0 | encode)); +} + +void Assembler::evprorvq(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len) { + assert(VM_Version::supports_evex(), "requires EVEX support"); + assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); + InstructionAttr attributes(vector_len, /* vex_w */ true, /* legacy_mode */ false, /* no_mask_reg */ true, /* uses_vl */ true); + attributes.set_is_evex_instruction(); + int encode = vex_prefix_and_encode(dst->encoding(), src->encoding(), shift->encoding(), VEX_SIMD_66, VEX_OPCODE_0F_38, &attributes); + emit_int16(0x14, (unsigned char)(0xC0 | encode)); +} + void Assembler::vpternlogd(XMMRegister dst, int imm8, XMMRegister src2, XMMRegister src3, int vector_len) { assert(VM_Version::supports_evex(), "requires EVEX support"); assert(vector_len == Assembler::AVX_512bit || VM_Version::supports_avx512vl(), "requires VL support"); @@ -8905,15 +9029,6 @@ void Assembler::rcrq(Register dst, int imm8) { } } -void Assembler::rorq(Register dst, int imm8) { - assert(isShiftCount(imm8 >> 1), "illegal shift count"); - int encode = prefixq_and_encode(dst->encoding()); - if (imm8 == 1) { - emit_int16((unsigned char)0xD1, (0xC8 | encode)); - } else { - emit_int24((unsigned char)0xC1, (0xc8 | encode), imm8); - } -} void Assembler::rorxq(Register dst, Register src, int imm8) { assert(VM_Version::supports_bmi2(), "bit manipulation instructions not supported"); diff --git a/src/hotspot/cpu/x86/assembler_x86.hpp b/src/hotspot/cpu/x86/assembler_x86.hpp index 38637cc2a32..bbcfb7ec64e 100644 --- a/src/hotspot/cpu/x86/assembler_x86.hpp +++ b/src/hotspot/cpu/x86/assembler_x86.hpp @@ -1827,9 +1827,18 @@ private: void ret(int imm16); + void roll(Register dst); + void roll(Register dst, int imm8); + void rorl(Register dst); + + void rorl(Register dst, int imm8); + #ifdef _LP64 + void rolq(Register dst); + void rolq(Register dst, int imm8); + void rorq(Register dst); void rorq(Register dst, int imm8); void rorxq(Register dst, Register src, int imm8); void rorxd(Register dst, Register src, int imm8); @@ -2205,6 +2214,16 @@ private: void vpternlogd(XMMRegister dst, int imm8, XMMRegister src2, Address src3, int vector_len); void vpternlogq(XMMRegister dst, int imm8, XMMRegister src2, XMMRegister src3, int vector_len); + // Vector Rotate Left/Right instruction. + void evprolvd(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len); + void evprolvq(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len); + void evprorvd(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len); + void evprorvq(XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len); + void evprold(XMMRegister dst, XMMRegister src, int shift, int vector_len); + void evprolq(XMMRegister dst, XMMRegister src, int shift, int vector_len); + void evprord(XMMRegister dst, XMMRegister src, int shift, int vector_len); + void evprorq(XMMRegister dst, XMMRegister src, int shift, int vector_len); + // vinserti forms void vinserti128(XMMRegister dst, XMMRegister nds, XMMRegister src, uint8_t imm8); void vinserti128(XMMRegister dst, XMMRegister nds, Address src, uint8_t imm8); diff --git a/src/hotspot/cpu/x86/c2_MacroAssembler_x86.cpp b/src/hotspot/cpu/x86/c2_MacroAssembler_x86.cpp index a61435b7671..8dc5cd6f3c5 100644 --- a/src/hotspot/cpu/x86/c2_MacroAssembler_x86.cpp +++ b/src/hotspot/cpu/x86/c2_MacroAssembler_x86.cpp @@ -870,6 +870,57 @@ void C2_MacroAssembler::vextendbw(bool sign, XMMRegister dst, XMMRegister src, i } } +void C2_MacroAssembler::vprotate_imm(int opcode, BasicType etype, XMMRegister dst, XMMRegister src, + int shift, int vector_len) { + if (opcode == Op_RotateLeftV) { + if (etype == T_INT) { + evprold(dst, src, shift, vector_len); + } else { + assert(etype == T_LONG, "expected type T_LONG"); + evprolq(dst, src, shift, vector_len); + } + } else { + assert(opcode == Op_RotateRightV, "opcode should be Op_RotateRightV"); + if (etype == T_INT) { + evprord(dst, src, shift, vector_len); + } else { + assert(etype == T_LONG, "expected type T_LONG"); + evprorq(dst, src, shift, vector_len); + } + } +} + +void C2_MacroAssembler::vprotate_var(int opcode, BasicType etype, XMMRegister dst, XMMRegister src, + XMMRegister shift, int vector_len) { + if (opcode == Op_RotateLeftV) { + if (etype == T_INT) { + evprolvd(dst, src, shift, vector_len); + } else { + assert(etype == T_LONG, "expected type T_LONG"); + evprolvq(dst, src, shift, vector_len); + } + } else { + assert(opcode == Op_RotateRightV, "opcode should be Op_RotateRightV"); + if (etype == T_INT) { + evprorvd(dst, src, shift, vector_len); + } else { + assert(etype == T_LONG, "expected type T_LONG"); + evprorvq(dst, src, shift, vector_len); + } + } +} + +void C2_MacroAssembler::vshiftd_imm(int opcode, XMMRegister dst, int shift) { + if (opcode == Op_RShiftVI) { + psrad(dst, shift); + } else if (opcode == Op_LShiftVI) { + pslld(dst, shift); + } else { + assert((opcode == Op_URShiftVI),"opcode should be Op_URShiftVI"); + psrld(dst, shift); + } +} + void C2_MacroAssembler::vshiftd(int opcode, XMMRegister dst, XMMRegister src) { if (opcode == Op_RShiftVI) { psrad(dst, src); @@ -881,6 +932,17 @@ void C2_MacroAssembler::vshiftd(int opcode, XMMRegister dst, XMMRegister src) { } } +void C2_MacroAssembler::vshiftd_imm(int opcode, XMMRegister dst, XMMRegister nds, int shift, int vector_len) { + if (opcode == Op_RShiftVI) { + vpsrad(dst, nds, shift, vector_len); + } else if (opcode == Op_LShiftVI) { + vpslld(dst, nds, shift, vector_len); + } else { + assert((opcode == Op_URShiftVI),"opcode should be Op_URShiftVI"); + vpsrld(dst, nds, shift, vector_len); + } +} + void C2_MacroAssembler::vshiftd(int opcode, XMMRegister dst, XMMRegister nds, XMMRegister src, int vector_len) { if (opcode == Op_RShiftVI) { vpsrad(dst, nds, src, vector_len); @@ -925,6 +987,17 @@ void C2_MacroAssembler::vshiftq(int opcode, XMMRegister dst, XMMRegister src) { } } +void C2_MacroAssembler::vshiftq_imm(int opcode, XMMRegister dst, int shift) { + if (opcode == Op_RShiftVL) { + psrlq(dst, shift); // using srl to implement sra on pre-avs512 systems + } else if (opcode == Op_LShiftVL) { + psllq(dst, shift); + } else { + assert((opcode == Op_URShiftVL),"opcode should be Op_URShiftVL"); + psrlq(dst, shift); + } +} + void C2_MacroAssembler::vshiftq(int opcode, XMMRegister dst, XMMRegister nds, XMMRegister src, int vector_len) { if (opcode == Op_RShiftVL) { evpsraq(dst, nds, src, vector_len); @@ -936,6 +1009,17 @@ void C2_MacroAssembler::vshiftq(int opcode, XMMRegister dst, XMMRegister nds, XM } } +void C2_MacroAssembler::vshiftq_imm(int opcode, XMMRegister dst, XMMRegister nds, int shift, int vector_len) { + if (opcode == Op_RShiftVL) { + evpsraq(dst, nds, shift, vector_len); + } else if (opcode == Op_LShiftVL) { + vpsllq(dst, nds, shift, vector_len); + } else { + assert((opcode == Op_URShiftVL),"opcode should be Op_URShiftVL"); + vpsrlq(dst, nds, shift, vector_len); + } +} + // Reductions for vectors of ints, longs, floats, and doubles. void C2_MacroAssembler::reduce_operation_128(int opcode, XMMRegister dst, XMMRegister src) { diff --git a/src/hotspot/cpu/x86/c2_MacroAssembler_x86.hpp b/src/hotspot/cpu/x86/c2_MacroAssembler_x86.hpp index 6fec6e19649..f16b193a21d 100644 --- a/src/hotspot/cpu/x86/c2_MacroAssembler_x86.hpp +++ b/src/hotspot/cpu/x86/c2_MacroAssembler_x86.hpp @@ -74,11 +74,18 @@ public: void vextendbw(bool sign, XMMRegister dst, XMMRegister src, int vector_len); void vextendbw(bool sign, XMMRegister dst, XMMRegister src); void vshiftd(int opcode, XMMRegister dst, XMMRegister src); + void vshiftd_imm(int opcode, XMMRegister dst, int shift); void vshiftd(int opcode, XMMRegister dst, XMMRegister nds, XMMRegister src, int vector_len); + void vshiftd_imm(int opcode, XMMRegister dst, XMMRegister nds, int shift, int vector_len); void vshiftw(int opcode, XMMRegister dst, XMMRegister src); void vshiftw(int opcode, XMMRegister dst, XMMRegister nds, XMMRegister src, int vector_len); void vshiftq(int opcode, XMMRegister dst, XMMRegister src); + void vshiftq_imm(int opcode, XMMRegister dst, int shift); void vshiftq(int opcode, XMMRegister dst, XMMRegister nds, XMMRegister src, int vector_len); + void vshiftq_imm(int opcode, XMMRegister dst, XMMRegister nds, int shift, int vector_len); + + void vprotate_imm(int opcode, BasicType etype, XMMRegister dst, XMMRegister src, int shift, int vector_len); + void vprotate_var(int opcode, BasicType etype, XMMRegister dst, XMMRegister src, XMMRegister shift, int vector_len); // Reductions for vectors of ints, longs, floats, and doubles. diff --git a/src/hotspot/cpu/x86/x86.ad b/src/hotspot/cpu/x86/x86.ad index 4108d628bb9..4e32b71539b 100644 --- a/src/hotspot/cpu/x86/x86.ad +++ b/src/hotspot/cpu/x86/x86.ad @@ -1469,6 +1469,8 @@ const bool Matcher::match_rule_supported_vector(int opcode, int vlen, BasicType return false; // implementation limitation (only vcmov8F_reg is present) } break; + case Op_RotateRightV: + case Op_RotateLeftV: case Op_MacroLogicV: if (!VM_Version::supports_evex() || ((size_in_bits != 512) && !VM_Version::supports_avx512vl())) { @@ -4955,6 +4957,33 @@ instruct vshiftI(vec dst, vec src, vec shift) %{ ins_pipe( pipe_slow ); %} +// Integers vector left constant shift +instruct vshiftI_imm(vec dst, vec src, immI8 shift) %{ + match(Set dst (LShiftVI src (LShiftCntV shift))); + match(Set dst (RShiftVI src (RShiftCntV shift))); + match(Set dst (URShiftVI src (RShiftCntV shift))); + effect(TEMP dst, USE src); + format %{ "vshiftd_imm $dst,$src,$shift\t! shift packedI" %} + ins_encode %{ + int opcode = this->ideal_Opcode(); + if (UseAVX > 0) { + int vector_len = vector_length_encoding(this); + __ vshiftd_imm(opcode, $dst$$XMMRegister, $src$$XMMRegister, $shift$$constant, vector_len); + } else { + int vlen = vector_length(this); + if (vlen == 2) { + __ movdbl($dst$$XMMRegister, $src$$XMMRegister); + __ vshiftd_imm(opcode, $dst$$XMMRegister, $shift$$constant); + } else { + assert(vlen == 4, "sanity"); + __ movdqu($dst$$XMMRegister, $src$$XMMRegister); + __ vshiftd_imm(opcode, $dst$$XMMRegister, $shift$$constant); + } + } + %} + ins_pipe( pipe_slow ); +%} + // Longs vector shift instruct vshiftL(vec dst, vec src, vec shift) %{ match(Set dst (LShiftVL src shift)); @@ -4975,6 +5004,26 @@ instruct vshiftL(vec dst, vec src, vec shift) %{ ins_pipe( pipe_slow ); %} +// Longs vector constant shift +instruct vshiftL_imm(vec dst, vec src, immI8 shift) %{ + match(Set dst (LShiftVL src (LShiftCntV shift))); + match(Set dst (URShiftVL src (RShiftCntV shift))); + effect(TEMP dst, USE src, USE shift); + format %{ "vshiftq_imm $dst,$src,$shift\t! shift packedL" %} + ins_encode %{ + int opcode = this->ideal_Opcode(); + if (UseAVX > 0) { + int vector_len = vector_length_encoding(this); + __ vshiftq_imm(opcode, $dst$$XMMRegister, $src$$XMMRegister, $shift$$constant, vector_len); + } else { + assert(vector_length(this) == 2, ""); + __ movdqu($dst$$XMMRegister, $src$$XMMRegister); + __ vshiftq_imm(opcode, $dst$$XMMRegister, $shift$$constant); + } + %} + ins_pipe( pipe_slow ); +%} + // -------------------ArithmeticRightShift ----------------------------------- // Long vector arithmetic right shift instruct vshiftL_arith_reg(vec dst, vec src, vec shift, vec tmp, rRegI scratch) %{ @@ -5359,3 +5408,31 @@ instruct vpternlog_mem(vec dst, vec src2, memory src3, immU8 func) %{ %} ins_pipe( pipe_slow ); %} + +// --------------------------------- Rotation Operations ---------------------------------- +instruct vprotate_immI8(vec dst, vec src, immI8 shift) %{ + match(Set dst (RotateLeftV src shift)); + match(Set dst (RotateRightV src shift)); + format %{ "vprotate_imm8 $dst,$src,$shift\t! vector rotate" %} + ins_encode %{ + int opcode = this->ideal_Opcode(); + int vector_len = vector_length_encoding(this); + BasicType etype = this->bottom_type()->is_vect()->element_basic_type(); + __ vprotate_imm(opcode, etype, $dst$$XMMRegister, $src$$XMMRegister, $shift$$constant, vector_len); + %} + ins_pipe( pipe_slow ); +%} + +instruct vprorate(vec dst, vec src, vec shift) %{ + match(Set dst (RotateLeftV src shift)); + match(Set dst (RotateRightV src shift)); + format %{ "vprotate $dst,$src,$shift\t! vector rotate" %} + ins_encode %{ + int opcode = this->ideal_Opcode(); + int vector_len = vector_length_encoding(this); + BasicType etype = this->bottom_type()->is_vect()->element_basic_type(); + __ vprotate_var(opcode, etype, $dst$$XMMRegister, $src$$XMMRegister, $shift$$XMMRegister, vector_len); + %} + ins_pipe( pipe_slow ); +%} + diff --git a/src/hotspot/cpu/x86/x86_64.ad b/src/hotspot/cpu/x86/x86_64.ad index 69da70311bb..70156db5e6f 100644 --- a/src/hotspot/cpu/x86/x86_64.ad +++ b/src/hotspot/cpu/x86/x86_64.ad @@ -3339,19 +3339,6 @@ operand rdi_RegI() interface(REG_INTER); %} -operand no_rcx_RegI() -%{ - constraint(ALLOC_IN_RC(int_no_rcx_reg)); - match(RegI); - match(rax_RegI); - match(rbx_RegI); - match(rdx_RegI); - match(rdi_RegI); - - format %{ %} - interface(REG_INTER); -%} - operand no_rax_rdx_RegI() %{ constraint(ALLOC_IN_RC(int_no_rax_rdx_reg)); @@ -3561,16 +3548,6 @@ operand no_rax_RegL() interface(REG_INTER); %} -operand no_rcx_RegL() -%{ - constraint(ALLOC_IN_RC(long_no_rcx_reg)); - match(RegL); - match(rRegL); - - format %{ %} - interface(REG_INTER); -%} - operand rax_RegL() %{ constraint(ALLOC_IN_RC(long_rax_reg)); @@ -8969,294 +8946,137 @@ instruct i2s(rRegI dst, rRegI src, immI_16 sixteen) // ROL/ROR instructions -// ROL expand -instruct rolI_rReg_imm1(rRegI dst, rFlagsReg cr) %{ - effect(KILL cr, USE_DEF dst); - - format %{ "roll $dst" %} - opcode(0xD1, 0x0); /* Opcode D1 /0 */ - ins_encode(REX_reg(dst), OpcP, reg_opc(dst)); - ins_pipe(ialu_reg); -%} - -instruct rolI_rReg_imm8(rRegI dst, immI8 shift, rFlagsReg cr) %{ - effect(USE_DEF dst, USE shift, KILL cr); - +// Rotate left by constant. +instruct rolI_imm(rRegI dst, immI8 shift, rFlagsReg cr) +%{ + predicate(n->bottom_type()->basic_type() == T_INT); + match(Set dst (RotateLeft dst shift)); + effect(KILL cr); format %{ "roll $dst, $shift" %} - opcode(0xC1, 0x0); /* Opcode C1 /0 ib */ - ins_encode( reg_opc_imm(dst, shift) ); + ins_encode %{ + __ roll($dst$$Register, $shift$$constant); + %} ins_pipe(ialu_reg); %} -instruct rolI_rReg_CL(no_rcx_RegI dst, rcx_RegI shift, rFlagsReg cr) +// Rotate Left by variable +instruct rolI_rReg_Var(rRegI dst, rcx_RegI shift, rFlagsReg cr) %{ - effect(USE_DEF dst, USE shift, KILL cr); - + predicate(n->bottom_type()->basic_type() == T_INT); + match(Set dst (RotateLeft dst shift)); + effect(KILL cr); format %{ "roll $dst, $shift" %} - opcode(0xD3, 0x0); /* Opcode D3 /0 */ - ins_encode(REX_reg(dst), OpcP, reg_opc(dst)); + ins_encode %{ + __ roll($dst$$Register); + %} ins_pipe(ialu_reg_reg); %} -// end of ROL expand -// Rotate Left by one -instruct rolI_rReg_i1(rRegI dst, immI1 lshift, immI_M1 rshift, rFlagsReg cr) +// Rotate Right by constant. +instruct rorI_immI8_legacy(rRegI dst, immI8 shift, rFlagsReg cr) %{ - match(Set dst (OrI (LShiftI dst lshift) (URShiftI dst rshift))); - - expand %{ - rolI_rReg_imm1(dst, cr); - %} -%} - -// Rotate Left by 8-bit immediate -instruct rolI_rReg_i8(rRegI dst, immI8 lshift, immI8 rshift, rFlagsReg cr) -%{ - predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f)); - match(Set dst (OrI (LShiftI dst lshift) (URShiftI dst rshift))); - - expand %{ - rolI_rReg_imm8(dst, lshift, cr); - %} -%} - -// Rotate Left by variable -instruct rolI_rReg_Var_C0(no_rcx_RegI dst, rcx_RegI shift, immI0 zero, rFlagsReg cr) -%{ - match(Set dst (OrI (LShiftI dst shift) (URShiftI dst (SubI zero shift)))); - - expand %{ - rolI_rReg_CL(dst, shift, cr); - %} -%} - -// Rotate Left by variable -instruct rolI_rReg_Var_C32(no_rcx_RegI dst, rcx_RegI shift, immI_32 c32, rFlagsReg cr) -%{ - match(Set dst (OrI (LShiftI dst shift) (URShiftI dst (SubI c32 shift)))); - - expand %{ - rolI_rReg_CL(dst, shift, cr); - %} -%} - -// ROR expand -instruct rorI_rReg_imm1(rRegI dst, rFlagsReg cr) -%{ - effect(USE_DEF dst, KILL cr); - - format %{ "rorl $dst" %} - opcode(0xD1, 0x1); /* D1 /1 */ - ins_encode(REX_reg(dst), OpcP, reg_opc(dst)); - ins_pipe(ialu_reg); -%} - -instruct rorI_rReg_imm8(rRegI dst, immI8 shift, rFlagsReg cr) -%{ - effect(USE_DEF dst, USE shift, KILL cr); - + predicate(!VM_Version::supports_bmi2() && n->bottom_type()->basic_type() == T_INT); + match(Set dst (RotateRight dst shift)); + effect(KILL cr); format %{ "rorl $dst, $shift" %} - opcode(0xC1, 0x1); /* C1 /1 ib */ - ins_encode(reg_opc_imm(dst, shift)); + ins_encode %{ + __ rorl($dst$$Register, $shift$$constant); + %} ins_pipe(ialu_reg); %} -instruct rorI_rReg_CL(no_rcx_RegI dst, rcx_RegI shift, rFlagsReg cr) +// Rotate Right by constant. +instruct rorI_immI8(rRegI dst, immI8 shift) %{ - effect(USE_DEF dst, USE shift, KILL cr); + predicate(VM_Version::supports_bmi2() && n->bottom_type()->basic_type() == T_INT); + match(Set dst (RotateRight dst shift)); + format %{ "rorxd $dst, $shift" %} + ins_encode %{ + __ rorxd($dst$$Register, $dst$$Register, $shift$$constant); + %} + ins_pipe(ialu_reg_reg); +%} +// Rotate Right by variable +instruct rorI_rReg_Var(rRegI dst, rcx_RegI shift, rFlagsReg cr) +%{ + predicate(n->bottom_type()->basic_type() == T_INT); + match(Set dst (RotateRight dst shift)); + effect(KILL cr); format %{ "rorl $dst, $shift" %} - opcode(0xD3, 0x1); /* D3 /1 */ - ins_encode(REX_reg(dst), OpcP, reg_opc(dst)); + ins_encode %{ + __ rorl($dst$$Register); + %} ins_pipe(ialu_reg_reg); %} -// end of ROR expand -// Rotate Right by one -instruct rorI_rReg_i1(rRegI dst, immI1 rshift, immI_M1 lshift, rFlagsReg cr) + +// Rotate Left by constant. +instruct rolL_immI8(rRegL dst, immI8 shift, rFlagsReg cr) %{ - match(Set dst (OrI (URShiftI dst rshift) (LShiftI dst lshift))); - - expand %{ - rorI_rReg_imm1(dst, cr); - %} -%} - -// Rotate Right by 8-bit immediate -instruct rorI_rReg_i8(rRegI dst, immI8 rshift, immI8 lshift, rFlagsReg cr) -%{ - predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x1f)); - match(Set dst (OrI (URShiftI dst rshift) (LShiftI dst lshift))); - - expand %{ - rorI_rReg_imm8(dst, rshift, cr); - %} -%} - -// Rotate Right by variable -instruct rorI_rReg_Var_C0(no_rcx_RegI dst, rcx_RegI shift, immI0 zero, rFlagsReg cr) -%{ - match(Set dst (OrI (URShiftI dst shift) (LShiftI dst (SubI zero shift)))); - - expand %{ - rorI_rReg_CL(dst, shift, cr); - %} -%} - -// Rotate Right by variable -instruct rorI_rReg_Var_C32(no_rcx_RegI dst, rcx_RegI shift, immI_32 c32, rFlagsReg cr) -%{ - match(Set dst (OrI (URShiftI dst shift) (LShiftI dst (SubI c32 shift)))); - - expand %{ - rorI_rReg_CL(dst, shift, cr); - %} -%} - -// for long rotate -// ROL expand -instruct rolL_rReg_imm1(rRegL dst, rFlagsReg cr) %{ - effect(USE_DEF dst, KILL cr); - - format %{ "rolq $dst" %} - opcode(0xD1, 0x0); /* Opcode D1 /0 */ - ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst)); - ins_pipe(ialu_reg); -%} - -instruct rolL_rReg_imm8(rRegL dst, immI8 shift, rFlagsReg cr) %{ - effect(USE_DEF dst, USE shift, KILL cr); - + predicate(n->bottom_type()->basic_type() == T_LONG); + match(Set dst (RotateLeft dst shift)); + effect(KILL cr); format %{ "rolq $dst, $shift" %} - opcode(0xC1, 0x0); /* Opcode C1 /0 ib */ - ins_encode( reg_opc_imm_wide(dst, shift) ); + ins_encode %{ + __ rolq($dst$$Register, $shift$$constant); + %} ins_pipe(ialu_reg); %} -instruct rolL_rReg_CL(no_rcx_RegL dst, rcx_RegI shift, rFlagsReg cr) -%{ - effect(USE_DEF dst, USE shift, KILL cr); - - format %{ "rolq $dst, $shift" %} - opcode(0xD3, 0x0); /* Opcode D3 /0 */ - ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst)); - ins_pipe(ialu_reg_reg); -%} -// end of ROL expand - -// Rotate Left by one -instruct rolL_rReg_i1(rRegL dst, immI1 lshift, immI_M1 rshift, rFlagsReg cr) -%{ - match(Set dst (OrL (LShiftL dst lshift) (URShiftL dst rshift))); - - expand %{ - rolL_rReg_imm1(dst, cr); - %} -%} - -// Rotate Left by 8-bit immediate -instruct rolL_rReg_i8(rRegL dst, immI8 lshift, immI8 rshift, rFlagsReg cr) -%{ - predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x3f)); - match(Set dst (OrL (LShiftL dst lshift) (URShiftL dst rshift))); - - expand %{ - rolL_rReg_imm8(dst, lshift, cr); - %} -%} - // Rotate Left by variable -instruct rolL_rReg_Var_C0(no_rcx_RegL dst, rcx_RegI shift, immI0 zero, rFlagsReg cr) +instruct rolL_rReg_Var(rRegL dst, rcx_RegI shift, rFlagsReg cr) %{ - match(Set dst (OrL (LShiftL dst shift) (URShiftL dst (SubI zero shift)))); - - expand %{ - rolL_rReg_CL(dst, shift, cr); + predicate(n->bottom_type()->basic_type() == T_LONG); + match(Set dst (RotateLeft dst shift)); + effect(KILL cr); + format %{ "rolq $dst, $shift" %} + ins_encode %{ + __ rolq($dst$$Register); %} -%} - -// Rotate Left by variable -instruct rolL_rReg_Var_C64(no_rcx_RegL dst, rcx_RegI shift, immI_64 c64, rFlagsReg cr) -%{ - match(Set dst (OrL (LShiftL dst shift) (URShiftL dst (SubI c64 shift)))); - - expand %{ - rolL_rReg_CL(dst, shift, cr); - %} -%} - -// ROR expand -instruct rorL_rReg_imm1(rRegL dst, rFlagsReg cr) -%{ - effect(USE_DEF dst, KILL cr); - - format %{ "rorq $dst" %} - opcode(0xD1, 0x1); /* D1 /1 */ - ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst)); - ins_pipe(ialu_reg); -%} - -instruct rorL_rReg_imm8(rRegL dst, immI8 shift, rFlagsReg cr) -%{ - effect(USE_DEF dst, USE shift, KILL cr); - - format %{ "rorq $dst, $shift" %} - opcode(0xC1, 0x1); /* C1 /1 ib */ - ins_encode(reg_opc_imm_wide(dst, shift)); - ins_pipe(ialu_reg); -%} - -instruct rorL_rReg_CL(no_rcx_RegL dst, rcx_RegI shift, rFlagsReg cr) -%{ - effect(USE_DEF dst, USE shift, KILL cr); - - format %{ "rorq $dst, $shift" %} - opcode(0xD3, 0x1); /* D3 /1 */ - ins_encode(REX_reg_wide(dst), OpcP, reg_opc(dst)); ins_pipe(ialu_reg_reg); %} -// end of ROR expand -// Rotate Right by one -instruct rorL_rReg_i1(rRegL dst, immI1 rshift, immI_M1 lshift, rFlagsReg cr) + +// Rotate Right by constant. +instruct rorL_immI8_legacy(rRegL dst, immI8 shift, rFlagsReg cr) %{ - match(Set dst (OrL (URShiftL dst rshift) (LShiftL dst lshift))); - - expand %{ - rorL_rReg_imm1(dst, cr); + predicate(!VM_Version::supports_bmi2() && n->bottom_type()->basic_type() == T_LONG); + match(Set dst (RotateRight dst shift)); + effect(KILL cr); + format %{ "rorq $dst, $shift" %} + ins_encode %{ + __ rorq($dst$$Register, $shift$$constant); %} + ins_pipe(ialu_reg); %} -// Rotate Right by 8-bit immediate -instruct rorL_rReg_i8(rRegL dst, immI8 rshift, immI8 lshift, rFlagsReg cr) -%{ - predicate(0 == ((n->in(1)->in(2)->get_int() + n->in(2)->in(2)->get_int()) & 0x3f)); - match(Set dst (OrL (URShiftL dst rshift) (LShiftL dst lshift))); - expand %{ - rorL_rReg_imm8(dst, rshift, cr); +// Rotate Right by constant +instruct rorL_immI8(rRegL dst, immI8 shift) +%{ + predicate(VM_Version::supports_bmi2() && n->bottom_type()->basic_type() == T_LONG); + match(Set dst (RotateRight dst shift)); + format %{ "rorxq $dst, $shift" %} + ins_encode %{ + __ rorxq($dst$$Register, $dst$$Register, $shift$$constant); %} + ins_pipe(ialu_reg_reg); %} // Rotate Right by variable -instruct rorL_rReg_Var_C0(no_rcx_RegL dst, rcx_RegI shift, immI0 zero, rFlagsReg cr) +instruct rorL_rReg_Var(rRegL dst, rcx_RegI shift, rFlagsReg cr) %{ - match(Set dst (OrL (URShiftL dst shift) (LShiftL dst (SubI zero shift)))); - - expand %{ - rorL_rReg_CL(dst, shift, cr); + predicate(n->bottom_type()->basic_type() == T_LONG); + match(Set dst (RotateRight dst shift)); + effect(KILL cr); + format %{ "rorq $dst, $shift" %} + ins_encode %{ + __ rorq($dst$$Register); %} + ins_pipe(ialu_reg_reg); %} -// Rotate Right by variable -instruct rorL_rReg_Var_C64(no_rcx_RegL dst, rcx_RegI shift, immI_64 c64, rFlagsReg cr) -%{ - match(Set dst (OrL (URShiftL dst shift) (LShiftL dst (SubI c64 shift)))); - - expand %{ - rorL_rReg_CL(dst, shift, cr); - %} -%} // Logical Instructions diff --git a/src/hotspot/share/adlc/formssel.cpp b/src/hotspot/share/adlc/formssel.cpp index 4030d336f3c..dab03c87c45 100644 --- a/src/hotspot/share/adlc/formssel.cpp +++ b/src/hotspot/share/adlc/formssel.cpp @@ -773,6 +773,8 @@ bool InstructForm::captures_bottom_type(FormDict &globals) const { !strcmp(_matrule->_rChild->_opType,"CheckCastPP") || !strcmp(_matrule->_rChild->_opType,"GetAndSetP") || !strcmp(_matrule->_rChild->_opType,"GetAndSetN") || + !strcmp(_matrule->_rChild->_opType,"RotateLeft") || + !strcmp(_matrule->_rChild->_opType,"RotateRight") || #if INCLUDE_SHENANDOAHGC !strcmp(_matrule->_rChild->_opType,"ShenandoahCompareAndExchangeP") || !strcmp(_matrule->_rChild->_opType,"ShenandoahCompareAndExchangeN") || @@ -4164,7 +4166,7 @@ bool MatchRule::is_vector() const { "RShiftVB","RShiftVS","RShiftVI","RShiftVL", "URShiftVB","URShiftVS","URShiftVI","URShiftVL", "ReplicateB","ReplicateS","ReplicateI","ReplicateL","ReplicateF","ReplicateD", - "RoundDoubleModeV","LoadVector","StoreVector", + "RoundDoubleModeV","RotateLeftV" , "RotateRightV", "LoadVector","StoreVector", "FmaVD", "FmaVF","PopCountVI", // Next are not supported currently. "PackB","PackS","PackI","PackL","PackF","PackD","Pack2L","Pack2D", diff --git a/src/hotspot/share/opto/addnode.cpp b/src/hotspot/share/opto/addnode.cpp index 61bac396cff..f83938ad28a 100644 --- a/src/hotspot/share/opto/addnode.cpp +++ b/src/hotspot/share/opto/addnode.cpp @@ -743,6 +743,46 @@ Node* OrINode::Identity(PhaseGVN* phase) { return AddNode::Identity(phase); } +Node *OrINode::Ideal(PhaseGVN *phase, bool can_reshape) { + int lopcode = in(1)->Opcode(); + int ropcode = in(2)->Opcode(); + if (Matcher::match_rule_supported(Op_RotateLeft) && + lopcode == Op_LShiftI && ropcode == Op_URShiftI && in(1)->in(1) == in(2)->in(1)) { + Node *lshift = in(1)->in(2); + Node *rshift = in(2)->in(2); + // val << norm_con_shift | val >> (32 - norm_con_shift) => rotate_left val , norm_con_shift + if (lshift->is_Con() && rshift->is_Con() && + ((lshift->get_int() & 0x1F) == (32 - (rshift->get_int() & 0x1F)))) { + return new RotateLeftNode(in(1)->in(1), + phase->intcon(lshift->get_int() & 0x1F), TypeInt::INT); + } + // val << var_shift | val >> (0/32 - var_shift) => rotate_left val , var_shift + if (rshift->Opcode() == Op_SubI && rshift->in(2) == lshift && + rshift->in(1)->is_Con() && + (rshift->in(1)->get_int() == 0 || rshift->in(1)->get_int() == 32)) { + return new RotateLeftNode(in(1)->in(1), lshift, TypeInt::INT); + } + } + if (Matcher::match_rule_supported(Op_RotateRight) && + lopcode == Op_URShiftI && ropcode == Op_LShiftI && in(1)->in(1) == in(2)->in(1)) { + Node *rshift = in(1)->in(2); + Node *lshift = in(2)->in(2); + // val >> norm_con_shift | val << (32 - norm_con_shift) => rotate_right val , norm_con_shift + if (rshift->is_Con() && lshift->is_Con() && + ((rshift->get_int() & 0x1F) == (32 - (lshift->get_int() & 0x1F)))) { + return new RotateRightNode(in(1)->in(1), + phase->intcon(rshift->get_int() & 0x1F), TypeInt::INT); + } + // val >> var_shift | val << (0/32 - var_shift) => rotate_right val , var_shift + if (lshift->Opcode() == Op_SubI && lshift->in(2) == rshift && + lshift->in(1)->is_Con() && + (lshift->in(1)->get_int() == 0 || lshift->in(1)->get_int() == 32)) { + return new RotateRightNode(in(1)->in(1), rshift, TypeInt::INT); + } + } + return NULL; +} + //------------------------------add_ring--------------------------------------- // Supplied function returns the sum of the inputs IN THE CURRENT RING. For // the logical operations the ring's ADD is really a logical OR function. @@ -784,6 +824,46 @@ Node* OrLNode::Identity(PhaseGVN* phase) { return AddNode::Identity(phase); } +Node *OrLNode::Ideal(PhaseGVN *phase, bool can_reshape) { + int lopcode = in(1)->Opcode(); + int ropcode = in(2)->Opcode(); + if (Matcher::match_rule_supported(Op_RotateLeft) && + lopcode == Op_LShiftL && ropcode == Op_URShiftL && in(1)->in(1) == in(2)->in(1)) { + Node *lshift = in(1)->in(2); + Node *rshift = in(2)->in(2); + // val << norm_con_shift | val >> (64 - norm_con_shift) => rotate_left val , norm_con_shift + if (lshift->is_Con() && rshift->is_Con() && + ((lshift->get_int() & 0x3F) == (64 - (rshift->get_int() & 0x3F)))) { + return new RotateLeftNode(in(1)->in(1), + phase->intcon(lshift->get_int() & 0x3F), TypeLong::LONG); + } + // val << var_shift | val >> (0/64 - var_shift) => rotate_left val , var_shift + if (rshift->Opcode() == Op_SubI && rshift->in(2) == lshift && + rshift->in(1)->is_Con() && + (rshift->in(1)->get_int() == 0 || rshift->in(1)->get_int() == 64)) { + return new RotateLeftNode(in(1)->in(1), lshift, TypeLong::LONG); + } + } + if (Matcher::match_rule_supported(Op_RotateRight) && + lopcode == Op_URShiftL && ropcode == Op_LShiftL && in(1)->in(1) == in(2)->in(1)) { + Node *rshift = in(1)->in(2); + Node *lshift = in(2)->in(2); + // val >> norm_con_shift | val << (64 - norm_con_shift) => rotate_right val , norm_con_shift + if (rshift->is_Con() && lshift->is_Con() && + ((rshift->get_int() & 0x3F) == (64 - (lshift->get_int() & 0x3F)))) { + return new RotateRightNode(in(1)->in(1), + phase->intcon(rshift->get_int() & 0x3F), TypeLong::LONG); + } + // val >> var_shift | val << (0/64 - var_shift) => rotate_right val , var_shift + if (lshift->Opcode() == Op_SubI && lshift->in(2) == rshift && + lshift->in(1)->is_Con() && + (lshift->in(1)->get_int() == 0 || lshift->in(1)->get_int() == 64)) { + return new RotateRightNode(in(1)->in(1), rshift, TypeLong::LONG); + } + } + return NULL; +} + //------------------------------add_ring--------------------------------------- const Type *OrLNode::add_ring( const Type *t0, const Type *t1 ) const { const TypeLong *r0 = t0->is_long(); // Handy access diff --git a/src/hotspot/share/opto/addnode.hpp b/src/hotspot/share/opto/addnode.hpp index b7ef2bc5a2e..6e6bca1d493 100644 --- a/src/hotspot/share/opto/addnode.hpp +++ b/src/hotspot/share/opto/addnode.hpp @@ -172,6 +172,7 @@ public: virtual const Type *bottom_type() const { return TypeInt::INT; } virtual Node* Identity(PhaseGVN* phase); virtual uint ideal_reg() const { return Op_RegI; } + virtual Node *Ideal(PhaseGVN *phase, bool can_reshape); }; //------------------------------OrLNode---------------------------------------- @@ -186,6 +187,7 @@ public: virtual const Type *bottom_type() const { return TypeLong::LONG; } virtual Node* Identity(PhaseGVN* phase); virtual uint ideal_reg() const { return Op_RegL; } + virtual Node *Ideal(PhaseGVN *phase, bool can_reshape); }; //------------------------------XorINode--------------------------------------- diff --git a/src/hotspot/share/opto/classes.hpp b/src/hotspot/share/opto/classes.hpp index e609851772f..429cd460a7c 100644 --- a/src/hotspot/share/opto/classes.hpp +++ b/src/hotspot/share/opto/classes.hpp @@ -268,6 +268,10 @@ macro(RoundDouble) macro(RoundDoubleMode) macro(RoundDoubleModeV) macro(RoundFloat) +macro(RotateLeft) +macro(RotateLeftV) +macro(RotateRight) +macro(RotateRightV) macro(SafePoint) macro(SafePointScalarObject) #if INCLUDE_SHENANDOAHGC diff --git a/src/hotspot/share/opto/mulnode.cpp b/src/hotspot/share/opto/mulnode.cpp index bd081df11d2..3df3f7fa040 100644 --- a/src/hotspot/share/opto/mulnode.cpp +++ b/src/hotspot/share/opto/mulnode.cpp @@ -1433,3 +1433,99 @@ const Type* FmaFNode::Value(PhaseGVN* phase) const { uint MulAddS2INode::hash() const { return (uintptr_t)in(1) + (uintptr_t)in(2) + (uintptr_t)in(3) + (uintptr_t)in(4) + Opcode(); } + +//------------------------------Rotate Operations ------------------------------ + +const Type* RotateLeftNode::Value(PhaseGVN* phase) const { + const Type* t1 = phase->type(in(1)); + const Type* t2 = phase->type(in(2)); + // Either input is TOP ==> the result is TOP + if (t1 == Type::TOP || t2 == Type::TOP) { + return Type::TOP; + } + + if (t1->isa_int()) { + const TypeInt* r1 = t1->is_int(); + const TypeInt* r2 = t2->is_int(); + + // Left input is ZERO ==> the result is ZERO. + if (r1 == TypeInt::ZERO) { + return TypeInt::ZERO; + } + // Shift by zero does nothing + if (r2 == TypeInt::ZERO) { + return r1; + } + + if (r1->is_con() && r2->is_con()) { + int shift = r2->get_con() & (BitsPerJavaInteger - 1); // semantics of Java shifts + return TypeInt::make((r1->get_con() << shift) | (r1->get_con() >> (32 - shift))); + } + return TypeInt::INT; + } else { + assert(t1->isa_long(), "Type must be a long"); + const TypeLong* r1 = t1->is_long(); + const TypeInt* r2 = t2->is_int(); + + // Left input is ZERO ==> the result is ZERO. + if (r1 == TypeLong::ZERO) { + return TypeLong::ZERO; + } + // Shift by zero does nothing + if (r2 == TypeInt::ZERO) { + return r1; + } + + if (r1->is_con() && r2->is_con()) { + int shift = r2->get_con() & (BitsPerJavaLong - 1); // semantics of Java shifts + return TypeLong::make((r1->get_con() << shift) | (r1->get_con() >> (64 - shift))); + } + return TypeLong::LONG; + } +} + +const Type* RotateRightNode::Value(PhaseGVN* phase) const { + const Type* t1 = phase->type(in(1)); + const Type* t2 = phase->type(in(2)); + // Either input is TOP ==> the result is TOP + if (t1 == Type::TOP || t2 == Type::TOP) { + return Type::TOP; + } + + if (t1->isa_int()) { + const TypeInt* r1 = t1->is_int(); + const TypeInt* r2 = t2->is_int(); + + // Left input is ZERO ==> the result is ZERO. + if (r1 == TypeInt::ZERO) { + return TypeInt::ZERO; + } + // Shift by zero does nothing + if (r2 == TypeInt::ZERO) { + return r1; + } + if (r1->is_con() && r2->is_con()) { + int shift = r2->get_con() & (BitsPerJavaInteger - 1); // semantics of Java shifts + return TypeInt::make((r1->get_con() >> shift) | (r1->get_con() << (32 - shift))); + } + return TypeInt::INT; + + } else { + assert(t1->isa_long(), "Type must be a long"); + const TypeLong* r1 = t1->is_long(); + const TypeInt* r2 = t2->is_int(); + // Left input is ZERO ==> the result is ZERO. + if (r1 == TypeLong::ZERO) { + return TypeLong::ZERO; + } + // Shift by zero does nothing + if (r2 == TypeInt::ZERO) { + return r1; + } + if (r1->is_con() && r2->is_con()) { + int shift = r2->get_con() & (BitsPerJavaLong - 1); // semantics of Java shifts + return TypeLong::make((r1->get_con() >> shift) | (r1->get_con() << (64 - shift))); + } + return TypeLong::LONG; + } +} diff --git a/src/hotspot/share/opto/mulnode.hpp b/src/hotspot/share/opto/mulnode.hpp index 8945b8aed0d..fce6e02825e 100644 --- a/src/hotspot/share/opto/mulnode.hpp +++ b/src/hotspot/share/opto/mulnode.hpp @@ -211,6 +211,29 @@ public: virtual uint ideal_reg() const { return Op_RegL; } }; + +//------------------------ RotateLeftNode ---------------------------------- +class RotateLeftNode : public TypeNode { + public: + RotateLeftNode(Node* in1, Node* in2, const Type* type) : TypeNode(type, 3) { + init_req(1, in1); + init_req(2, in2); + } + virtual int Opcode() const; + virtual const Type* Value(PhaseGVN* phase) const; +}; + +//----------------------- RotateRightNode ---------------------------------- +class RotateRightNode : public TypeNode { + public: + RotateRightNode(Node* in1, Node* in2, const Type* type) : TypeNode(type, 3) { + init_req(1, in1); + init_req(2, in2); + } + virtual int Opcode() const; + virtual const Type* Value(PhaseGVN* phase) const; +}; + //------------------------------RShiftINode------------------------------------ // Signed shift right class RShiftINode : public Node { diff --git a/src/hotspot/share/opto/superword.cpp b/src/hotspot/share/opto/superword.cpp index 0f4da5e8cfa..3a9b6b555a9 100644 --- a/src/hotspot/share/opto/superword.cpp +++ b/src/hotspot/share/opto/superword.cpp @@ -2464,6 +2464,16 @@ void SuperWord::output() { const TypePtr* atyp = n->adr_type(); vn = StoreVectorNode::make(opc, ctl, mem, adr, atyp, val, vlen); vlen_in_bytes = vn->as_StoreVector()->memory_size(); + } else if (VectorNode::is_scalar_rotate(n)) { + Node* in1 = low_adr->in(1); + Node* in2 = p->at(0)->in(2); + assert(in2->bottom_type()->isa_int(), "Shift must always be an int value"); + // If rotation count is non-constant or greater than 8bit value create a vector. + if (!in2->is_Con() || -0x80 > in2->get_int() || in2->get_int() >= 0x80) { + in2 = vector_opd(p, 2); + } + vn = VectorNode::make(opc, in1, in2, vlen, velt_basic_type(n)); + vlen_in_bytes = vn->as_Vector()->length_in_bytes(); } else if (VectorNode::is_roundopD(n)) { Node* in1 = vector_opd(p, 1); Node* in2 = low_adr->in(2); @@ -2758,8 +2768,22 @@ Node* SuperWord::vector_opd(Node_List* p, int opd_idx) { // Convert scalar input to vector with the same number of elements as // p0's vector. Use p0's type because size of operand's container in // vector should match p0's size regardless operand's size. - const Type* p0_t = velt_type(p0); - VectorNode* vn = VectorNode::scalar2vector(opd, vlen, p0_t); + const Type* p0_t = NULL; + VectorNode* vn = NULL; + if (opd_idx == 2 && VectorNode::is_scalar_rotate(p0)) { + Node* conv = opd; + p0_t = TypeInt::INT; + if (p0->bottom_type()->isa_long()) { + p0_t = TypeLong::LONG; + conv = new ConvI2LNode(opd); + _igvn.register_new_node_with_optimizer(conv); + _phase->set_ctrl(conv, _phase->get_ctrl(opd)); + } + vn = VectorNode::scalar2vector(conv, vlen, p0_t); + } else { + p0_t = velt_type(p0); + vn = VectorNode::scalar2vector(opd, vlen, p0_t); + } _igvn.register_new_node_with_optimizer(vn); _phase->set_ctrl(vn, _phase->get_ctrl(opd)); diff --git a/src/hotspot/share/opto/vectornode.cpp b/src/hotspot/share/opto/vectornode.cpp index 16d3899ba80..0dbe44fe0bf 100644 --- a/src/hotspot/share/opto/vectornode.cpp +++ b/src/hotspot/share/opto/vectornode.cpp @@ -24,8 +24,11 @@ #include "precompiled.hpp" #include "memory/allocation.inline.hpp" #include "opto/connode.hpp" +#include "opto/mulnode.hpp" +#include "opto/subnode.hpp" #include "opto/vectornode.hpp" #include "utilities/powerOfTwo.hpp" +#include "utilities/globalDefinitions.hpp" //------------------------------VectorNode-------------------------------------- @@ -132,6 +135,12 @@ int VectorNode::opcode(int sopc, BasicType bt) { case Op_RoundDoubleMode: assert(bt == T_DOUBLE, "must be"); return Op_RoundDoubleModeV; + case Op_RotateLeft: + assert(bt == T_LONG || bt == T_INT, "must be"); + return Op_RotateLeftV; + case Op_RotateRight: + assert(bt == T_LONG || bt == T_INT, "must be"); + return Op_RotateRightV; case Op_SqrtF: assert(bt == T_FLOAT, "must be"); return Op_SqrtVF; @@ -239,6 +248,12 @@ bool VectorNode::implemented(int opc, uint vlen, BasicType bt) { (vlen > 1) && is_power_of_2(vlen) && Matcher::vector_size_supported(bt, vlen)) { int vopc = VectorNode::opcode(opc, bt); + // For rotate operation we will do a lazy de-generation into + // OrV/LShiftV/URShiftV pattern if the target does not support + // vector rotation instruction. + if (vopc == Op_RotateLeftV || vopc == Op_RotateRightV) { + return is_vector_rotate_supported(vopc, vlen, bt); + } return vopc > 0 && Matcher::match_rule_supported_vector(vopc, vlen, bt); } return false; @@ -263,13 +278,45 @@ bool VectorNode::is_muladds2i(Node* n) { return false; } -bool VectorNode::is_roundopD(Node *n) { +bool VectorNode::is_roundopD(Node* n) { if (n->Opcode() == Op_RoundDoubleMode) { return true; } return false; } +bool VectorNode::is_scalar_rotate(Node* n) { + if (n->Opcode() == Op_RotateLeft || n->Opcode() == Op_RotateRight) { + return true; + } + return false; +} + +bool VectorNode::is_vector_rotate_supported(int vopc, uint vlen, BasicType bt) { + assert(vopc == Op_RotateLeftV || vopc == Op_RotateRightV, "wrong opcode"); + + // If target defines vector rotation patterns then no + // need for degeneration. + if (Matcher::match_rule_supported_vector(vopc, vlen, bt)) { + return true; + } + + // Validate existence of nodes created in case of rotate degeneration. + switch (bt) { + case T_INT: + return Matcher::match_rule_supported_vector(Op_OrV, vlen, bt) && + Matcher::match_rule_supported_vector(Op_LShiftVI, vlen, bt) && + Matcher::match_rule_supported_vector(Op_URShiftVI, vlen, bt); + case T_LONG: + return Matcher::match_rule_supported_vector(Op_OrV, vlen, bt) && + Matcher::match_rule_supported_vector(Op_LShiftVL, vlen, bt) && + Matcher::match_rule_supported_vector(Op_URShiftVL, vlen, bt); + default: + assert(false, "not supported: %s", type2name(bt)); + return false; + } +} + bool VectorNode::is_shift(Node* n) { switch (n->Opcode()) { case Op_LShiftI: @@ -395,6 +442,8 @@ VectorNode* VectorNode::make(int opc, Node* n1, Node* n2, uint vlen, BasicType b case Op_SqrtVD: return new SqrtVDNode(n1, vt); case Op_PopCountVI: return new PopCountVINode(n1, vt); + case Op_RotateLeftV: return new RotateLeftVNode(n1, n2, vt); + case Op_RotateRightV: return new RotateRightVNode(n1, n2, vt); case Op_LShiftVB: return new LShiftVBNode(n1, n2, vt); case Op_LShiftVS: return new LShiftVSNode(n1, n2, vt); @@ -784,3 +833,161 @@ MacroLogicVNode* MacroLogicVNode::make(PhaseGVN& gvn, Node* in1, Node* in2, Node return new MacroLogicVNode(in1, in2, in3, fn, vt); } +Node* VectorNode::degenerate_vector_rotate(Node* src, Node* cnt, bool is_rotate_left, + int vlen, BasicType bt, PhaseGVN* phase) { + int shiftLOpc; + int shiftROpc; + Node* shiftLCnt = NULL; + Node* shiftRCnt = NULL; + const TypeVect* vt = TypeVect::make(bt, vlen); + + // Compute shift values for right rotation and + // later swap them in case of left rotation. + if (cnt->is_Con()) { + // Constant shift case. + if (bt == T_INT) { + int shift = cnt->get_int() & 31; + shiftRCnt = phase->intcon(shift); + shiftLCnt = phase->intcon(32 - shift); + shiftLOpc = Op_LShiftI; + shiftROpc = Op_URShiftI; + } else { + int shift = cnt->get_int() & 63; + shiftRCnt = phase->intcon(shift); + shiftLCnt = phase->intcon(64 - shift); + shiftLOpc = Op_LShiftL; + shiftROpc = Op_URShiftL; + } + } else { + // Variable shift case. + assert(VectorNode::is_invariant_vector(cnt), "Broadcast expected"); + cnt = cnt->in(1); + if (bt == T_INT) { + shiftRCnt = phase->transform(new AndINode(cnt, phase->intcon(31))); + shiftLCnt = phase->transform(new SubINode(phase->intcon(32), shiftRCnt)); + shiftLOpc = Op_LShiftI; + shiftROpc = Op_URShiftI; + } else { + assert(cnt->Opcode() == Op_ConvI2L, "ConvI2L expected"); + cnt = cnt->in(1); + shiftRCnt = phase->transform(new AndINode(cnt, phase->intcon(63))); + shiftLCnt = phase->transform(new SubINode(phase->intcon(64), shiftRCnt)); + shiftLOpc = Op_LShiftL; + shiftROpc = Op_URShiftL; + } + } + + // Swap the computed left and right shift counts. + if (is_rotate_left) { + swap(shiftRCnt,shiftLCnt); + } + + shiftLCnt = phase->transform(new LShiftCntVNode(shiftLCnt, vt)); + shiftRCnt = phase->transform(new RShiftCntVNode(shiftRCnt, vt)); + + return new OrVNode(phase->transform(VectorNode::make(shiftLOpc, src, shiftLCnt, vlen, bt)), + phase->transform(VectorNode::make(shiftROpc, src, shiftRCnt, vlen, bt)), + vt); +} + +Node* RotateLeftVNode::Ideal(PhaseGVN* phase, bool can_reshape) { + int vlen = length(); + BasicType bt = vect_type()->element_basic_type(); + if (!Matcher::match_rule_supported_vector(Op_RotateLeftV, vlen, bt)) { + return VectorNode::degenerate_vector_rotate(in(1), in(2), true, vlen, bt, phase); + } + return NULL; +} + +Node* RotateRightVNode::Ideal(PhaseGVN* phase, bool can_reshape) { + int vlen = length(); + BasicType bt = vect_type()->element_basic_type(); + if (!Matcher::match_rule_supported_vector(Op_RotateRightV, vlen, bt)) { + return VectorNode::degenerate_vector_rotate(in(1), in(2), false, vlen, bt, phase); + } + return NULL; +} + +Node* OrVNode::Ideal(PhaseGVN* phase, bool can_reshape) { + int lopcode = in(1)->Opcode(); + int ropcode = in(2)->Opcode(); + const TypeVect* vt = bottom_type()->is_vect(); + int vec_len = vt->length(); + BasicType bt = vt->element_basic_type(); + + // Vector Rotate operations inferencing, this will be useful when vector + // operations are created via non-SLP route i.e. (VectorAPI). + if (Matcher::match_rule_supported_vector(Op_RotateLeftV, vec_len, bt) && + ((ropcode == Op_LShiftVI && lopcode == Op_URShiftVI) || + (ropcode == Op_LShiftVL && lopcode == Op_URShiftVL)) && + in(1)->in(1) == in(2)->in(1)) { + assert(Op_RShiftCntV == in(1)->in(2)->Opcode(), "LShiftCntV operand expected"); + assert(Op_LShiftCntV == in(2)->in(2)->Opcode(), "RShiftCntV operand expected"); + Node* lshift = in(1)->in(2)->in(1); + Node* rshift = in(2)->in(2)->in(1); + int mod_val = bt == T_LONG ? 64 : 32; + int shift_mask = bt == T_LONG ? 0x3F : 0x1F; + // val >> norm_con_shift | val << (32 - norm_con_shift) => rotate_right val , + // norm_con_shift + if (lshift->is_Con() && rshift->is_Con() && + ((lshift->get_int() & shift_mask) == + (mod_val - (rshift->get_int() & shift_mask)))) { + return new RotateRightVNode( + in(1)->in(1), phase->intcon(lshift->get_int() & shift_mask), vt); + } + if (lshift->Opcode() == Op_AndI && rshift->Opcode() == Op_AndI && + lshift->in(2)->is_Con() && rshift->in(2)->is_Con() && + lshift->in(2)->get_int() == (mod_val - 1) && + rshift->in(2)->get_int() == (mod_val - 1)) { + lshift = lshift->in(1); + rshift = rshift->in(1); + // val << var_shift | val >> (0/32 - var_shift) => rotate_left val , + // var_shift + if (lshift->Opcode() == Op_SubI && lshift->in(2) == rshift && + lshift->in(1)->is_Con() && + (lshift->in(1)->get_int() == 0 || + lshift->in(1)->get_int() == mod_val)) { + Node* rotate_cnt = phase->transform(new ReplicateINode(rshift, vt)); + return new RotateLeftVNode(in(1)->in(1), rotate_cnt, vt); + } + } + } + + if (Matcher::match_rule_supported_vector(Op_RotateRightV, vec_len, bt) && + ((ropcode == Op_URShiftVI && lopcode == Op_LShiftVI) || + (ropcode == Op_URShiftVL && lopcode == Op_LShiftVL)) && + in(1)->in(1) == in(2)->in(1)) { + assert(Op_LShiftCntV == in(1)->in(2)->Opcode(), "RShiftCntV operand expected"); + assert(Op_RShiftCntV == in(2)->in(2)->Opcode(), "LShiftCntV operand expected"); + Node* rshift = in(1)->in(2)->in(1); + Node* lshift = in(2)->in(2)->in(1); + int mod_val = bt == T_LONG ? 64 : 32; + int shift_mask = bt == T_LONG ? 0x3F : 0x1F; + // val << norm_con_shift | val >> (32 - norm_con_shift) => rotate_left val + // , norm_con_shift + if (rshift->is_Con() && lshift->is_Con() && + ((rshift->get_int() & shift_mask) == + (mod_val - (lshift->get_int() & shift_mask)))) { + return new RotateLeftVNode( + in(1)->in(1), phase->intcon(rshift->get_int() & shift_mask), vt); + } + if (lshift->Opcode() == Op_AndI && rshift->Opcode() == Op_AndI && + lshift->in(2)->is_Con() && rshift->in(2)->is_Con() && + rshift->in(2)->get_int() == (mod_val - 1) && + lshift->in(2)->get_int() == (mod_val - 1)) { + rshift = rshift->in(1); + lshift = lshift->in(1); + // val >> var_shift | val << (0/32 - var_shift) => rotate_right val , + // var_shift + if (rshift->Opcode() == Op_SubI && rshift->in(2) == lshift && + rshift->in(1)->is_Con() && + (rshift->in(1)->get_int() == 0 || + rshift->in(1)->get_int() == mod_val)) { + Node* rotate_cnt = phase->transform(new ReplicateINode(lshift, vt)); + return new RotateRightVNode(in(1)->in(1), rotate_cnt, vt); + } + } + } + return NULL; +} + diff --git a/src/hotspot/share/opto/vectornode.hpp b/src/hotspot/share/opto/vectornode.hpp index d6ceacf10b1..570f0645a01 100644 --- a/src/hotspot/share/opto/vectornode.hpp +++ b/src/hotspot/share/opto/vectornode.hpp @@ -78,10 +78,14 @@ class VectorNode : public TypeNode { static bool is_type_transition_short_to_int(Node* n); static bool is_type_transition_to_int(Node* n); static bool is_muladds2i(Node* n); - static bool is_roundopD(Node * n); + static bool is_roundopD(Node* n); + static bool is_scalar_rotate(Node* n); + static bool is_vector_rotate_supported(int vopc, uint vlen, BasicType bt); static bool is_invariant_vector(Node* n); static bool is_all_ones_vector(Node* n); static bool is_vector_bitwise_not_pattern(Node* n); + static Node* degenerate_vector_rotate(Node* n1, Node* n2, bool is_rotate_left, int vlen, + BasicType bt, PhaseGVN* phase); // [Start, end) half-open range defining which operands are vectors static void vector_operands(Node* n, uint* start, uint* end); @@ -620,6 +624,7 @@ class OrVNode : public VectorNode { public: OrVNode(Node* in1, Node* in2, const TypeVect* vt) : VectorNode(in1,in2,vt) {} virtual int Opcode() const; + Node* Ideal(PhaseGVN* phase, bool can_reshape); }; //------------------------------XorVNode--------------------------------------- @@ -1003,4 +1008,22 @@ public: static MacroLogicVNode* make(PhaseGVN& igvn, Node* in1, Node* in2, Node* in3, uint truth_table, const TypeVect* vt); }; +class RotateRightVNode : public VectorNode { +public: + RotateRightVNode(Node* in1, Node* in2, const TypeVect* vt) + : VectorNode(in1, in2, vt) {} + + virtual int Opcode() const; + Node* Ideal(PhaseGVN* phase, bool can_reshape); +}; + +class RotateLeftVNode : public VectorNode { +public: + RotateLeftVNode(Node* in1, Node* in2, const TypeVect* vt) + : VectorNode(in1, in2, vt) {} + + virtual int Opcode() const; + Node* Ideal(PhaseGVN* phase, bool can_reshape); +}; + #endif // SHARE_OPTO_VECTORNODE_HPP diff --git a/test/hotspot/jtreg/compiler/c2/cr6340864/TestIntVect.java b/test/hotspot/jtreg/compiler/c2/cr6340864/TestIntVect.java index 8ac63801df2..1c7129392b7 100644 --- a/test/hotspot/jtreg/compiler/c2/cr6340864/TestIntVect.java +++ b/test/hotspot/jtreg/compiler/c2/cr6340864/TestIntVect.java @@ -30,6 +30,7 @@ * @run main/othervm/timeout=400 -Xbatch -Xmx128m -XX:MaxVectorSize=8 compiler.c2.cr6340864.TestIntVect * @run main/othervm/timeout=400 -Xbatch -Xmx128m -XX:MaxVectorSize=16 compiler.c2.cr6340864.TestIntVect * @run main/othervm/timeout=400 -Xbatch -Xmx128m -XX:MaxVectorSize=32 compiler.c2.cr6340864.TestIntVect + * @run main/othervm/timeout=400 -Xbatch -Xmx128m -XX:+IgnoreUnrecognizedVMOptions -XX:UseAVX=3 compiler.c2.cr6340864.TestIntVect */ package compiler.c2.cr6340864; @@ -41,6 +42,8 @@ public class TestIntVect { private static final int BIT_MASK = 0xEC80F731; private static final int VALUE = 15; private static final int SHIFT = 32; + private static final int SHIFT_LT_IMM8 = -128; + private static final int SHIFT_GT_IMM8 = 128; public static void main(String args[]) { System.out.println("Testing Integer vectors"); @@ -148,6 +151,13 @@ public class TestIntVect { test_srac_and(a0, a1); test_srav_and(a0, a1, BIT_MASK); + test1_ror(a0, a1); + test1_rol(a0, a1); + test2_ror(a0, a1); + test2_rol(a0, a1); + test3_ror(a0, a1, SHIFT); + test3_rol(a0, a1, SHIFT); + test_pack2(p2, a1); test_unpack2(a0, p2); test_pack2_swap(p2, a1); @@ -375,6 +385,30 @@ public class TestIntVect { for (int i=0; i>SHIFT)); } + test1_ror(a0, a1); + for (int i=0; i>>SHIFT_GT_IMM8) | (int)(ADD_INIT+i)<<-SHIFT_GT_IMM8)); + } + test1_rol(a0, a1); + for (int i=0; i>>-SHIFT_GT_IMM8)); + } + test2_ror(a0, a1); + for (int i=0; i>>SHIFT_LT_IMM8) | (int)(ADD_INIT+i)<<-SHIFT_LT_IMM8)); + } + test2_rol(a0, a1); + for (int i=0; i>>-SHIFT_LT_IMM8)); + } + test3_rol(a0, a1, SHIFT); + for (int i=0; i>>-SHIFT)); + } + test3_ror(a0, a1, SHIFT); + for (int i=0; i>>SHIFT) | (int)(ADD_INIT+i)<<-SHIFT)); + } test_sllc_on(a0, a1); for (int i=0; i>VALUE)); } + test1_ror(a0, a1); + for (int i=0; i>>SHIFT_GT_IMM8) | (long)(ADD_INIT+i)<<-SHIFT_GT_IMM8)); + } + test1_rol(a0, a1); + for (int i=0; i>>-SHIFT_GT_IMM8)); + } + test2_ror(a0, a1); + for (int i=0; i>>SHIFT_LT_IMM8) | (long)(ADD_INIT+i)<<-SHIFT_LT_IMM8)); + } + test2_rol(a0, a1); + for (int i=0; i>>-SHIFT_LT_IMM8)); + } + test3_rol(a0, a1, SHIFT); + for (int i=0; i>>-SHIFT)); + } + test3_ror(a0, a1, SHIFT); + for (int i=0; i>>SHIFT) | (long)(ADD_INIT+i)<<-SHIFT)); + } } if (errn > 0) @@ -852,6 +886,48 @@ public class TestLongVect { end = System.currentTimeMillis(); System.out.println("test_srav_and: " + (end - start)); + start = System.currentTimeMillis(); + for (int i=0; i>VALUE); } } + static void test1_rol(long[] a0, long[] a1) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateLeft(a1[i], SHIFT_GT_IMM8)); + } + } + static void test1_ror(long[] a0, long[] a1) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateRight(a1[i], SHIFT_GT_IMM8)); + } + } + static void test2_rol(long[] a0, long[] a1) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateLeft(a1[i], SHIFT_LT_IMM8)); + } + } + static void test2_ror(long[] a0, long[] a1) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateRight(a1[i], SHIFT_LT_IMM8)); + } + } + static void test3_rol(long[] a0, long[] a1, int shift) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateLeft(a1[i], shift)); + } + } + static void test3_ror(long[] a0, long[] a1, int shift) { + for (int i = 0; i < a0.length; i+=1) { + a0[i] = (long)(Long.rotateRight(a1[i], shift)); + } + } static int verify(String text, int i, long elem, long val) { if (elem != val) { diff --git a/test/hotspot/jtreg/compiler/intrinsics/TestRotate.java b/test/hotspot/jtreg/compiler/intrinsics/TestRotate.java new file mode 100644 index 00000000000..0bbc33b1406 --- /dev/null +++ b/test/hotspot/jtreg/compiler/intrinsics/TestRotate.java @@ -0,0 +1,309 @@ +/* + * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. + * 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 + * @bug 8248830 + * @summary Support for scalar rotates ([Integer/Long].rotate[Left/Right]). + * @library /test/lib + * @requires vm.compiler2.enabled + * + * @run main/othervm/timeout=600 -XX:-TieredCompilation -XX:CompileThreshold=1000 -Xbatch + * compiler.intrinsics.TestRotate + * + */ + +package compiler.intrinsics; + +import java.util.Arrays; +import java.util.Random; +import jdk.test.lib.Utils; + +public class TestRotate { + static int ITERS = 500000; + static int SIZE = 32; + static Random rand; + + static final int [] ref_rol_int = {1073741824,2147483647,-1847483168,-762700135,617181014,1499775590,770793873,-921711375,1843194553,618929189,543569581,-1524383055,-1358287055,-2015951670,1688073778,687346128,2069534693,-649937276,-1986172760,-1935023546,1291562794,-1493576900,1682263699,807071113,888440312,1299098553,1799312476,745578744,762073952,-1048231621,479680827,403988906}; + + static final int [] ref_ror_int = {1,2147483647,-1847483168,1244166759,1284961634,1704135065,770793873,-53535600,-1217156379,118049081,1667944966,1766387884,-960747332,849475009,2106366247,-532201309,-111225179,-1590275921,1733962274,-1851577736,1055640211,1872573386,356142481,1649149627,1025605133,1537928787,1799312476,-131305312,190518488,82773525,1321674198,-2126112095}; + + static final long [] ref_rol_long = {4611686018427387904L,9223372036854775807L,-3965526468698771170L,-4285866096636113521L,7635506276746300070L,5413117018148508287L,1868037460083876000L,-3244573585138770353L,7136025216317516898L,-4913621043675642569L,-6391133452542036978L,3902621950534797292L,-4632945906580257763L,4947809816008258399L,5235987658397734862L,2619582334080606650L,1815014778597694835L,-2451797983190531776L,-12499474356882106L,-8308822678069541478L,8441313153103433409L,3994820770127321462L,3403550366464210270L,-5787882067214947834L,-3689654055874130041L,-589861354719079036L,6641098980367723810L,763129181839551415L,4389436227302949880L,-8023110070632385182L,-8486732357167672789L,7236425339463197932L}; + + static final long [] ref_ror_long = {1L,9223372036854775807L,-3965526468698771170L,1303279687165097535L,-6959108088026060186L,681250795361731838L,3705372465420868140L,-8117671657526198993L,-335604442896202624L,-3176041913244586253L,-2152781018329716108L,975655487633699323L,8574521504761035792L,-5473888690750018935L,1581768605333334728L,7674419410656225425L,6685114322387540375L,5780227587575757360L,-799966358840454721L,8284086884492323912L,5288463661042741341L,912426852973757747L,-11970671133582816L,-344117270115783853L,-2106591766031512621L,-857638554601955011L,6641098980367723810L,-5257223391402178581L,1097359056825737470L,-4640791861453503840L,8696676574724001348L,-6526192196514797544L}; + + static final int [] ref_int_rol_shift_1 = {1,-2,600000961,1244166759,642480817,161047955,-1021158430,-2014938908,-1427785869,-467917532,857429648,-1524383055,1807911884,1884072061,845454838,1040479242,1471523198,1301556200,-1713993080,-1641781046,-809831772,-1713031218,-1529278125,-1361538303,1602441032,-689259628,-696342344,93197343,762073952,352644870,1972613577,223396003}; + + static final int [] ref_int_rol_shift_127 = {1073741824 ,-1073741825 ,1223742064 ,-762700135 ,1234362028 ,-1033479836 ,-1329031432 ,570007097 ,-356946468 ,956762441 ,214357412 ,1766387884 ,451977971 ,1544759839 ,-1936119939 ,-1887363838 ,-1779602849 ,325389050 ,645243554 ,-1484187086 ,871283881 ,-1501999629 ,-382319532 ,1807099072 ,400610258 ,901426917 ,899656238 ,-1050442489 ,190518488 ,-2059322431 ,1566895218 ,-1017892824}; + + static final int [] ref_int_rol_shift_128 = {-2147483648 ,2147483647 ,-1847483168 ,-1525400269 ,-1826243240 ,-2066959671 ,1636904433 ,1140014194 ,-713892935 ,1913524882 ,428714824 ,-762191528 ,903955942 ,-1205447618 ,422727419 ,520239621 ,735761599 ,650778100 ,1290487108 ,1326593125 ,1742567762 ,1290968039 ,-764639063 ,-680769152 ,801220516 ,1802853834 ,1799312476 ,-2100884977 ,381036976 ,176322435 ,-1161176860 ,-2035785647}; + + static final int [] ref_int_rol_shift_M128 = {-2147483648 ,2147483647 ,-1847483168 ,-1525400269 ,-1826243240 ,-2066959671 ,1636904433 ,1140014194 ,-713892935 ,1913524882 ,428714824 ,-762191528 ,903955942 ,-1205447618 ,422727419 ,520239621 ,735761599 ,650778100 ,1290487108 ,1326593125 ,1742567762 ,1290968039 ,-764639063 ,-680769152 ,801220516 ,1802853834 ,1799312476 ,-2100884977 ,381036976 ,176322435 ,-1161176860 ,-2035785647}; + + static final int [] ref_int_rol_shift_M129 = {1073741824 ,-1073741825 ,1223742064 ,-762700135 ,1234362028 ,-1033479836 ,-1329031432 ,570007097 ,-356946468 ,956762441 ,214357412 ,1766387884 ,451977971 ,1544759839 ,-1936119939 ,-1887363838 ,-1779602849 ,325389050 ,645243554 ,-1484187086 ,871283881 ,-1501999629 ,-382319532 ,1807099072 ,400610258 ,901426917 ,899656238 ,-1050442489 ,190518488 ,-2059322431 ,1566895218 ,-1017892824}; + + static final int [] ref_int_ror_shift_1 = {1073741824,-1073741825,1223742064,-762700135,1234362028,-1033479836,-1329031432,570007097,-356946468,956762441,214357412,1766387884,451977971,1544759839,-1936119939,-1887363838,-1779602849,325389050,645243554,-1484187086,871283881,-1501999629,-382319532,1807099072,400610258,901426917,899656238,-1050442489,190518488,-2059322431,1566895218,-1017892824}; + + static final int [] ref_int_ror_shift_127 = {1 ,-2 ,600000961 ,1244166759 ,642480817 ,161047955 ,-1021158430 ,-2014938908 ,-1427785869 ,-467917532 ,857429648 ,-1524383055 ,1807911884 ,1884072061 ,845454838 ,1040479242 ,1471523198 ,1301556200 ,-1713993080 ,-1641781046 ,-809831772 ,-1713031218 ,-1529278125 ,-1361538303 ,1602441032 ,-689259628 ,-696342344 ,93197343 ,762073952 ,352644870 ,1972613577 ,223396003}; + + static final int [] ref_int_ror_shift_128 = {-2147483648 ,2147483647 ,-1847483168 ,-1525400269 ,-1826243240 ,-2066959671 ,1636904433 ,1140014194 ,-713892935 ,1913524882 ,428714824 ,-762191528 ,903955942 ,-1205447618 ,422727419 ,520239621 ,735761599 ,650778100 ,1290487108 ,1326593125 ,1742567762 ,1290968039 ,-764639063 ,-680769152 ,801220516 ,1802853834 ,1799312476 ,-2100884977 ,381036976 ,176322435 ,-1161176860 ,-2035785647}; + + static final int [] ref_int_ror_shift_M128 = {-2147483648 ,2147483647 ,-1847483168 ,-1525400269 ,-1826243240 ,-2066959671 ,1636904433 ,1140014194 ,-713892935 ,1913524882 ,428714824 ,-762191528 ,903955942 ,-1205447618 ,422727419 ,520239621 ,735761599 ,650778100 ,1290487108 ,1326593125 ,1742567762 ,1290968039 ,-764639063 ,-680769152 ,801220516 ,1802853834 ,1799312476 ,-2100884977 ,381036976 ,176322435 ,-1161176860 ,-2035785647}; + + static final int [] ref_int_ror_shift_M129 = {1 ,-2 ,600000961 ,1244166759 ,642480817 ,161047955 ,-1021158430 ,-2014938908 ,-1427785869 ,-467917532 ,857429648 ,-1524383055 ,1807911884 ,1884072061 ,845454838 ,1040479242 ,1471523198 ,1301556200 ,-1713993080 ,-1641781046 ,-809831772 ,-1713031218 ,-1529278125 ,-1361538303 ,1602441032 ,-689259628 ,-696342344 ,93197343 ,762073952 ,352644870 ,1972613577 ,223396003}; + + + static final long [] ref_long_rol_shift_1 = { +1L,-2L,-7931052937397542339L,1303279687165097535L,5608201114852140040L,359735415298403453L,4701815018953926360L,8969694797557082089L,324535527229983777L,-3508390168714987589L,-8153196119534272952L,-5889362595358906884L,8065135560209711367L,-3515635332702993867L,-3582426625105780649L,1632572717772861065L,3572202937482896855L,-7534931108784269461L,8161459789691976885L,5213383633793760703L,5933801933688073239L,-6730200469375698045L,6308363257973444605L,-3098812595652498694L,-541332749731694416L,9008962398204287055L,6200852250644175020L,5992317991244719550L,1486051504252676350L,-6863599526811956670L,5846438278934178867L,2838151117945983671L}; + + static final long [] ref_long_rol_shift_127 = {4611686018427387904L,-4611686018427387905L,7240608802505390223L,-4285866096636113521L,1402050278713035010L,4701619872251988767L,1175453754738481590L,6854109717816658426L,4692819900234883848L,-877097542178746898L,2573386988543819666L,3139345369587661183L,-2595402128374960063L,8344463203679027341L,-895606656276445163L,5019829197870603170L,-3718635284056663691L,-1883732777196067366L,6652050965850382125L,-3308340109978947729L,-3128235535005369595L,-1682550117343924512L,6188776832920749055L,-5386389167340512578L,4476352830994464300L,-2359445418876316141L,1550213062661043755L,-7725292539043595921L,-8851859160791606721L,-6327585900130377072L,-3150076448693843188L,-3902148238940891987L}; + + static final long [] ref_long_rol_shift_128 = {-9223372036854775808L,9223372036854775807L,-3965526468698771170L,-8571732193272227041L,2804100557426070020L,-9043504329205574082L,2350907509476963180L,-4738524638076234764L,-9061104273239783920L,-1754195084357493795L,5146773977087639332L,6278690739175322366L,-5190804256749920125L,-1757817666351496934L,-1791213312552890325L,-8407085677968345276L,-7437270568113327381L,-3767465554392134731L,-5142642142008787366L,-6616680219957895457L,-6256471070010739189L,-3365100234687849023L,-6069190407868053506L,7673965739028526461L,8952705661988928600L,-4718890837752632281L,3100426125322087510L,2996158995622359775L,743025752126338175L,5791572273448797473L,-6300152897387686375L,-7804296477881783973L}; + + static final long [] ref_long_rol_shift_M128 = {-9223372036854775808L,9223372036854775807L,-3965526468698771170L,-8571732193272227041L,2804100557426070020L,-9043504329205574082L,2350907509476963180L,-4738524638076234764L,-9061104273239783920L,-1754195084357493795L,5146773977087639332L,6278690739175322366L,-5190804256749920125L,-1757817666351496934L,-1791213312552890325L,-8407085677968345276L,-7437270568113327381L,-3767465554392134731L,-5142642142008787366L,-6616680219957895457L,-6256471070010739189L,-3365100234687849023L,-6069190407868053506L,7673965739028526461L,8952705661988928600L,-4718890837752632281L,3100426125322087510L,2996158995622359775L,743025752126338175L,5791572273448797473L,-6300152897387686375L,-7804296477881783973L}; + + + static final long [] ref_long_rol_shift_M129 = {4611686018427387904L,-4611686018427387905L,7240608802505390223L,-4285866096636113521L,1402050278713035010L,4701619872251988767L,1175453754738481590L,6854109717816658426L,4692819900234883848L,-877097542178746898L,2573386988543819666L,3139345369587661183L,-2595402128374960063L,8344463203679027341L,-895606656276445163L,5019829197870603170L,-3718635284056663691L,-1883732777196067366L,6652050965850382125L,-3308340109978947729L,-3128235535005369595L,-1682550117343924512L,6188776832920749055L,-5386389167340512578L,4476352830994464300L,-2359445418876316141L,1550213062661043755L,-7725292539043595921L,-8851859160791606721L,-6327585900130377072L,-3150076448693843188L,-3902148238940891987L}; + + static final long [] ref_long_ror_shift_1 = {4611686018427387904L,-4611686018427387905L,7240608802505390223L,-4285866096636113521L,1402050278713035010L,4701619872251988767L,1175453754738481590L,6854109717816658426L,4692819900234883848L,-877097542178746898L,2573386988543819666L,3139345369587661183L,-2595402128374960063L,8344463203679027341L,-895606656276445163L,5019829197870603170L,-3718635284056663691L,-1883732777196067366L,6652050965850382125L,-3308340109978947729L,-3128235535005369595L,-1682550117343924512L,6188776832920749055L,-5386389167340512578L,4476352830994464300L,-2359445418876316141L,1550213062661043755L,-7725292539043595921L,-8851859160791606721L,-6327585900130377072L,-3150076448693843188L,-3902148238940891987L}; + + static final long [] ref_long_ror_shift_127 = {1L,-2L,-7931052937397542339L,1303279687165097535L,5608201114852140040L,359735415298403453L,4701815018953926360L,8969694797557082089L,324535527229983777L,-3508390168714987589L,-8153196119534272952L,-5889362595358906884L,8065135560209711367L,-3515635332702993867L,-3582426625105780649L,1632572717772861065L,3572202937482896855L,-7534931108784269461L,8161459789691976885L,5213383633793760703L,5933801933688073239L,-6730200469375698045L,6308363257973444605L,-3098812595652498694L,-541332749731694416L,9008962398204287055L,6200852250644175020L,5992317991244719550L,1486051504252676350L,-6863599526811956670L,5846438278934178867L,2838151117945983671L}; + + + static final long [] ref_long_ror_shift_128 = {-9223372036854775808L,9223372036854775807L,-3965526468698771170L,-8571732193272227041L,2804100557426070020L,-9043504329205574082L,2350907509476963180L,-4738524638076234764L,-9061104273239783920L,-1754195084357493795L,5146773977087639332L,6278690739175322366L,-5190804256749920125L,-1757817666351496934L,-1791213312552890325L,-8407085677968345276L,-7437270568113327381L,-3767465554392134731L,-5142642142008787366L,-6616680219957895457L,-6256471070010739189L,-3365100234687849023L,-6069190407868053506L,7673965739028526461L,8952705661988928600L,-4718890837752632281L,3100426125322087510L,2996158995622359775L,743025752126338175L,5791572273448797473L,-6300152897387686375L,-7804296477881783973L}; + + + static final long [] ref_long_ror_shift_M128 = {-9223372036854775808L,9223372036854775807L,-3965526468698771170L,-8571732193272227041L,2804100557426070020L,-9043504329205574082L,2350907509476963180L,-4738524638076234764L,-9061104273239783920L,-1754195084357493795L,5146773977087639332L,6278690739175322366L,-5190804256749920125L,-1757817666351496934L,-1791213312552890325L,-8407085677968345276L,-7437270568113327381L,-3767465554392134731L,-5142642142008787366L,-6616680219957895457L,-6256471070010739189L,-3365100234687849023L,-6069190407868053506L,7673965739028526461L,8952705661988928600L,-4718890837752632281L,3100426125322087510L,2996158995622359775L,743025752126338175L,5791572273448797473L,-6300152897387686375L,-7804296477881783973L}; + + static final long [] ref_long_ror_shift_M129 = {1L,-2L,-7931052937397542339L,1303279687165097535L,5608201114852140040L,359735415298403453L,4701815018953926360L,8969694797557082089L,324535527229983777L,-3508390168714987589L,-8153196119534272952L,-5889362595358906884L,8065135560209711367L,-3515635332702993867L,-3582426625105780649L,1632572717772861065L,3572202937482896855L,-7534931108784269461L,8161459789691976885L,5213383633793760703L,5933801933688073239L,-6730200469375698045L,6308363257973444605L,-3098812595652498694L,-541332749731694416L,9008962398204287055L,6200852250644175020L,5992317991244719550L,1486051504252676350L,-6863599526811956670L,5846438278934178867L,2838151117945983671L}; + + static void verify(String text, long ref, long actual) { + if (ref != actual) { + System.err.println(text + " " + ref + " != " + actual); + throw new Error("Fail"); + } + } + + public static int [] init_shift_vector(Random rand) { + int [] vec_int = new int [SIZE]; + vec_int[0] = 127; + vec_int[1] = -128; + vec_int[2] = 128; + vec_int[3] = -129; + for (int i = 4 ; i < SIZE ; i++) { + vec_int[i] = rand.nextInt(256); + } + return vec_int; + } + + public static int [] init_int_vector() { + int [] vec_int = new int [SIZE]; + vec_int[0] = Integer.MIN_VALUE; + vec_int[1] = Integer.MAX_VALUE; + for (int i = 2 ; i < SIZE ; i++) { + vec_int[i] = rand.nextInt(); + } + return vec_int; + } + + public static long [] init_long_vector() { + long [] vec_long = new long [SIZE]; + vec_long[0] = Long.MIN_VALUE; + vec_long[1] = Long.MAX_VALUE; + for (int i = 2 ; i < SIZE ; i++) { + vec_long[i] = rand.nextLong(); + } + return vec_long; + } + + public static void test_rol_int(int val, int shift, int index) { + int actual = Integer.rotateLeft(val, shift); + verify("Integer.rotateLeft shift = " + shift, ref_rol_int[index], actual); + actual = (val << shift) | (val >>> -shift); + verify("Pattern1 integer rotateLeft shift = " + shift, ref_rol_int[index], actual); + actual = (val << shift) | (val >>> 32-shift); + verify("Pattern2 integer rotateLeft shift = " + shift, ref_rol_int[index], actual); + } + + public static void test_ror_int(int val, int shift, int index) { + int actual = Integer.rotateRight(val, shift); + verify("Integer.rotateRight shift = " + shift, ref_ror_int[index], actual); + actual = (val >>> shift) | (val <<-shift); + verify("Pattern1 integer rotateRight shift = " + shift, ref_ror_int[index], actual); + actual = (val >>> shift) | (val <<-32-shift); + verify("Pattern2 integer rotateRight shift = " + shift, ref_ror_int[index], actual); + } + + public static void test_rol_long(long val, int shift, int index) { + long actual = Long.rotateLeft(val, shift); + verify("Long.rotateLeft shift = " + shift, ref_rol_long[index], actual); + actual = (val << shift) | (val >>>-shift); + verify("Pattern1 long rotateLeft shift = " + shift, ref_rol_long[index], actual); + actual = (val << shift) | (val >>>64-shift); + verify("Pattern2 long rotateLeft shift = " + shift, ref_rol_long[index], actual); + } + + public static void test_ror_long(long val, int shift, int index) { + long actual = Long.rotateRight(val, shift); + verify("Long.rotateRight shift = " + shift, ref_ror_long[index], actual); + actual = (val >>> shift) | (val <<-shift); + verify("Pattern1 long rotateRight shift = " + shift, ref_ror_long[index], actual); + actual = (val >>> shift) | (val <<64-shift); + verify("Pattern2 long rotateRight shift = " + shift, ref_ror_long[index], actual); + } + + public static void test_rol_int_const(int val, int index) { + int res1 = Integer.rotateLeft(val, 1); + verify("Constant integer rotateLeft shift = 1", res1 , ref_int_rol_shift_1[index]); + int res2 = (val << 1) | (val >>> -1); + verify("Constant integer rotateLeft shift = 1", res2 , ref_int_rol_shift_1[index]); + + res1 = Integer.rotateLeft(val, 127); + verify("Constant integer rotateLeft shift = 127", res1 , ref_int_rol_shift_127[index]); + res2 = (val << 127) | (val >>> -127); + verify("Constant integer rotateLeft shift = 127", res2 , ref_int_rol_shift_127[index]); + + res1 = Integer.rotateLeft(val, 128); + verify("Constant integer rotateLeft shift = 128", res1 , ref_int_rol_shift_128[index]); + res2 = (val << 128) | (val >>> -128); + verify("Constant integer rotateLeft pattern = 128", res2 , ref_int_rol_shift_128[index]); + + res1 = Integer.rotateLeft(val, -128); + verify("Constant integer rotateLeft shift = -128", res1 , ref_int_rol_shift_M128[index]); + res2 = (val << -128) | (val >>> 128); + verify("Constant integer rotateLeft pattern = 128", res2 , ref_int_rol_shift_M128[index]); + + res1 = Integer.rotateLeft(val, -129); + verify("Constant integer rotateLeft shift = -129", res1 , ref_int_rol_shift_M129[index]); + res2 = (val << -129) | (val >>> 129); + verify("Constant integer rotateLeft pattern = 129", res2 , ref_int_rol_shift_M129[index]); + } + + public static void test_ror_int_const(int val, int index) { + int res1 = Integer.rotateRight(val, 1); + verify("Constant integer rotateRight shift = 1", res1 , ref_int_ror_shift_1[index]); + int res2 = (val >>> 1) | (val << -1); + verify("Constant integer rotateRight pattern = 1", res2 , ref_int_ror_shift_1[index]); + + res1 = Integer.rotateRight(val, 127); + verify("Constant integer rotateRight shift = 127", res1 , ref_int_ror_shift_127[index]); + res2 = (val >>> 127) | (val << -127); + verify("Constant integer rotateRight pattern = 127", res2 , ref_int_ror_shift_127[index]); + + res1 = Integer.rotateRight(val, 128); + verify("Constant integer rotateRight shift = 128", res1 , ref_int_ror_shift_128[index]); + res2 = (val >>> 128) | (val << -128); + verify("Constant integer rotateRight pattern = 128", res2 , ref_int_ror_shift_128[index]); + + res1 = Integer.rotateRight(val, -128); + verify("Constant integer rotateRight shift = -128", res1 , ref_int_ror_shift_M128[index]); + res2 = (val >>> -128) | (val << 128); + verify("Constant integer rotateRight pattern = 128", res2 , ref_int_ror_shift_M128[index]); + + res1 = Integer.rotateRight(val, -129); + verify("Constant integer rotateRight shift = -129", res1 , ref_int_ror_shift_M129[index]); + res2 = (val >>> -129) | (val << 129); + verify("Constant integer rotateRight pattern = 129", res2 , ref_int_ror_shift_M129[index]); + } + + public static void test_rol_long_const(long val, int index) { + long res1 = Long.rotateLeft(val, 1); + verify("Constant long rotateLeft shift = 1", res1 , ref_long_rol_shift_1[index]); + long res2 = (val << 1) | (val >>> -1); + verify("Constant long rotateLeft pattern = 1", res2 , ref_long_rol_shift_1[index]); + + res1 = Long.rotateLeft(val, 127); + verify("Constant long rotateLeft shift = 127", res1 , ref_long_rol_shift_127[index]); + res2 = (val << 127) | (val >>> -127); + verify("Constant long rotateLeft pattern = 127", res2 , ref_long_rol_shift_127[index]); + + res1 = Long.rotateLeft(val, 128); + verify("Constant long rotateLeft shift = 128", res1 , ref_long_rol_shift_128[index]); + res2 = (val << 128) | (val >>> -128); + verify("Constant long rotateLeft pattern = 128", res2 , ref_long_rol_shift_128[index]); + + res1 = Long.rotateLeft(val, -128); + verify("Constant long rotateLeft shift = -128", res1 , ref_long_rol_shift_M128[index]); + res2 = (val << -128) | (val >>> 128); + verify("Constant long rotateLeft pattern = 128", res2 , ref_long_rol_shift_M128[index]); + + res1 = Long.rotateLeft(val, -129); + verify("Constant long rotateLeft shift = -129", res1 , ref_long_rol_shift_M129[index]); + res2 = (val << -129) | (val >>> 129); + verify("Constant long rotateLeft pattern = 129", res2 , ref_long_rol_shift_M129[index]); + } + + public static void test_ror_long_const(long val, int index) { + long res1 = Long.rotateRight(val, 1); + verify("Constant long rotateRight shift = 1", res1 , ref_long_ror_shift_1[index]); + long res2 = (val >>> 1) | (val << -1); + verify("Constant long rotateRight pattern = 1", res2 , ref_long_ror_shift_1[index]); + + res1 = Long.rotateRight(val, 127); + verify("Constant long rotateRight shift = 127", res1 , ref_long_ror_shift_127[index]); + res2 = (val >>> 127) | (val << -127); + verify("Constant long rotateRight pattern = 127", res2 , ref_long_ror_shift_127[index]); + + res1 = Long.rotateRight(val, 128); + verify("Constant long rotateRight shift = 128", res1 , ref_long_ror_shift_128[index]); + res2 = (val >>> 128) | (val << -128); + verify("Constant long rotateRight pattern = 128", res2 , ref_long_ror_shift_128[index]); + + res1 = Long.rotateRight(val, -128); + verify("Constant long rotateRight shift = -128", res1 , ref_long_ror_shift_M128[index]); + res2 = (val >>> -128) | (val << 128); + verify("Constant long rotateRight pattern = 128", res2 , ref_long_ror_shift_M128[index]); + + res1 = Long.rotateRight(val, -129); + verify("Constant long rotateRight shift = -129", res1 , ref_long_ror_shift_M129[index]); + res2 = (val >>> -129) | (val << 129); + verify("Constant long rotateRight pattern = 129", res2 , ref_long_ror_shift_M129[index]); + } + + public static void main(String args[]) throws Exception { + rand = new Random(8248830); + + int [] test_int = init_int_vector(); + long [] test_long = init_long_vector(); + int [] shift_vec = init_shift_vector(rand); + + try { + for (int i = 0 ; i < ITERS; i++) { + for (int j = 0 ; j < SIZE ; j++) { + test_rol_int(test_int[j], shift_vec[j], j); + test_ror_int(test_int[j], shift_vec[j], j); + test_rol_long(test_long[j], shift_vec[j], j); + test_ror_long(test_long[j], shift_vec[j], j); + + test_rol_int_const(test_int[j], j); + test_ror_int_const(test_int[j], j); + test_rol_long_const(test_long[j], j); + test_ror_long_const(test_long[j], j); + } + } + System.out.println("test status : PASS"); + } catch (Exception e) { + System.out.println(e.getMessage()); + } + } +} diff --git a/test/micro/org/openjdk/bench/java/lang/RotateBenchmark.java b/test/micro/org/openjdk/bench/java/lang/RotateBenchmark.java new file mode 100644 index 00000000000..81fd956a4e6 --- /dev/null +++ b/test/micro/org/openjdk/bench/java/lang/RotateBenchmark.java @@ -0,0 +1,87 @@ +// +// Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. +// 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. +// +// +package org.openjdk.bench.java.lang; + +import java.util.Random; +import java.util.concurrent.TimeUnit; +import org.openjdk.jmh.annotations.*; +import org.openjdk.jmh.infra.Blackhole; + +@OutputTimeUnit(TimeUnit.MILLISECONDS) +@State(Scope.Thread) +@BenchmarkMode(Mode.Throughput) +public class RotateBenchmark { + + @Param({"1024"}) + public int TESTSIZE; + + @Param({"20"}) + public int SHIFT; + + public long [] larr; + public int [] iarr; + + public long [] lres; + public int [] ires; + + + @Setup(Level.Trial) + public void BmSetup() { + Random r = new Random(1024); + larr = new long[TESTSIZE]; + iarr = new int[TESTSIZE]; + lres = new long[TESTSIZE]; + ires = new int[TESTSIZE]; + + for (int i = 0; i < TESTSIZE; i++) { + larr[i] = r.nextLong(); + } + + for (int i = 0; i < TESTSIZE; i++) { + iarr[i] = r.nextInt(); + } + } + + @Benchmark + public void testRotateLeftI() { + for (int i = 0; i < TESTSIZE; i++) + ires[i] = Integer.rotateLeft(iarr[i], SHIFT); + } + @Benchmark + public void testRotateRightI() { + for (int i = 0; i < TESTSIZE; i++) + ires[i] = Integer.rotateRight(iarr[i], SHIFT); + } + @Benchmark + public void testRotateLeftL() { + for (int i = 0; i < TESTSIZE; i++) + lres[i] = Long.rotateLeft(larr[i], SHIFT); + } + @Benchmark + public void testRotateRightL() { + for (int i = 0; i < TESTSIZE; i++) + lres[i] = Long.rotateRight(larr[i], SHIFT); + } + +} From b5d775f115e4274d8f0c221a8eb4a92d17a9f579 Mon Sep 17 00:00:00 2001 From: Abdul Kolarkunnu Date: Sat, 8 Aug 2020 20:29:27 -0700 Subject: [PATCH 33/53] 8248745: Add jarsigner and keytool tests for restricted algorithms Reviewed-by: mullan, hchao --- .../tools/jarsigner/RestrictedAlgo.java | 201 ++++++++++++++++++ 1 file changed, 201 insertions(+) create mode 100644 test/jdk/sun/security/tools/jarsigner/RestrictedAlgo.java diff --git a/test/jdk/sun/security/tools/jarsigner/RestrictedAlgo.java b/test/jdk/sun/security/tools/jarsigner/RestrictedAlgo.java new file mode 100644 index 00000000000..07dc2e47b4b --- /dev/null +++ b/test/jdk/sun/security/tools/jarsigner/RestrictedAlgo.java @@ -0,0 +1,201 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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. + */ + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.List; +import java.io.File; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import jdk.test.lib.SecurityTools; +import jdk.test.lib.util.JarUtils; +import jdk.test.lib.process.OutputAnalyzer; + +/** + * @test + * @bug 8248745 + * @summary Test key generation and jar signing with disabled algorithms and + * key sizes, with and without entries in jdk.jar.disabledAlgorithms, + * jdk.certpath.disabledAlgorithms + * @library /test/lib + * @run main/othervm RestrictedAlgo RESTRICT + * @run main/othervm RestrictedAlgo NO_RESTRICT + */ + +public class RestrictedAlgo { + + private static final String KEYSTORE = "keystore.jks"; + private static final String PASSWORD = "password"; + private static final String SIGNED_JARFILE = "signed.jar"; + private static final String UNSIGNED_JARFILE = "unsigned.jar"; + private static final String SECURITY_FILE = "java.security"; + private static final String NO_RESTRICT = "-J-Djava.security.properties=" + + SECURITY_FILE; + private static final String FIRST_FILE = "first.txt"; + private static final String WARNING = "Warning:"; + private static final String SECURITY_WARNING = + ".* is considered a security risk and is disabled."; + + private static String algoStatus; + + public static void main(String[] args) throws Exception { + + algoStatus = args[0]; + // create a jar file that contains one file + JarUtils.createJarFile(Path.of(UNSIGNED_JARFILE), Path.of("."), + new File(FIRST_FILE).exists() ? Paths.get(FIRST_FILE) + : Files.createFile(Paths.get(FIRST_FILE))); + if (!isAlgoRestricted()) { + // An alternative security properties + Files.writeString(Files.createFile(Paths.get(SECURITY_FILE)), + "jdk.certpath.disabledAlgorithms=\n" + + "jdk.jar.disabledAlgorithms=\n" + + "jdk.security.legacyAlgorithms="); + } + + System.out.println("\nTesting sigalg MD2\n"); + test("RSA", "MD2withRSA", "SigAlgMD2", "SHA256", true); + + System.out.println("\nTesting sigalg MD5\n"); + test("RSA", "MD5withRSA", "SigAlgMD5", "SHA256", true); + + System.out.println("\nTesting digestalg MD2\n"); + test("RSA", "SHA256withRSA", "DigestAlgMD2", "MD2", false); + + System.out.println("\nTesting digestalg MD5\n"); + test("RSA", "SHA256withRSA", "DigestAlgMD5", "MD5", false); + + System.out.println("\nTesting RSA Keysize: RSA keySize < 1024\n"); + test("RSA", "SHA256withRSA", "KeySizeRSA", "SHA256", true, + "-keysize", "512"); + + System.out.println("\nTesting DSA Keysize: DSA keySize < 1024\n"); + test("DSA", "SHA256withDSA", "KeySizeDSA", "SHA256", true, + "-keysize", "512"); + + System.out.println("\nTesting Native Curve:" + + " include jdk.disabled.namedCurves\n"); + test("EC", "SHA256withECDSA", "curve", "SHA256", true, + "-groupname", "secp112r1"); + } + + private static void test(String keyAlg, String sigAlg, String aliasPrefix, + String digestAlg, boolean isKeyToolVerify, + String... addKeyToolArgs) throws Exception { + + String alias = aliasPrefix + "_" + algoStatus; + testKeytool(keyAlg, sigAlg, alias, isKeyToolVerify, addKeyToolArgs); + testJarSignerSigning(sigAlg, alias, digestAlg); + testJarSignerVerification(); + } + + private static void testKeytool(String keyAlg, String sigAlg, String alias, + boolean isKeyToolVerify, String... additionalCmdArgs) + throws Exception { + + System.out.println("Testing Keytool\n"); + List cmd = prepareCommand( + "-genkeypair", + "-keystore", KEYSTORE, + "-storepass", PASSWORD, + "-dname", "CN=Test", + "-ext", "bc:c", + "-keyalg", keyAlg, + "-sigalg", sigAlg, + "-alias", alias, + "-J-Djdk.sunec.disableNative=false"); + for (String additionalCMDArg : additionalCmdArgs) { + cmd.add(additionalCMDArg); + } + + OutputAnalyzer analyzer = SecurityTools.keytool(cmd) + .shouldHaveExitValue(0); + if (isKeyToolVerify) { + verifyAnalyzer(analyzer); + } + } + + private static void testJarSignerSigning(String sigAlg, String alias, + String digestAlg) throws Exception { + + System.out.println("\nTesting JarSigner Signing\n"); + List cmd = prepareCommand( + "-keystore", KEYSTORE, + "-storepass", PASSWORD, + "-sigalg", sigAlg, + "-digestalg", digestAlg, + "-signedjar", SIGNED_JARFILE, + UNSIGNED_JARFILE, + alias, + "-J-Djdk.sunec.disableNative=false"); + + OutputAnalyzer analyzer = SecurityTools.jarsigner(cmd) + .shouldHaveExitValue(0); + + verifyAnalyzer(analyzer); + } + + private static void testJarSignerVerification() + throws Exception { + + System.out.println("\nTesting JarSigner Verification\n"); + List cmd = prepareCommand( + "-verify", + SIGNED_JARFILE, + "-J-Djdk.sunec.disableNative=false"); + + OutputAnalyzer analyzer = SecurityTools.jarsigner(cmd) + .shouldHaveExitValue(0); + + if (isAlgoRestricted()) { + analyzer.shouldContain("The jar will be treated as unsigned," + + " because it is signed with a weak algorithm that " + + "is now disabled."); + } else { + analyzer.shouldContain("jar verified."); + } + } + + private static List prepareCommand(String... options) { + List cmd = new ArrayList<>(); + cmd.addAll(Arrays.asList(options)); + if (!isAlgoRestricted()) { + cmd.add(NO_RESTRICT); + } + return cmd; + } + + private static void verifyAnalyzer(OutputAnalyzer analyzer) { + if (isAlgoRestricted()) { + analyzer.shouldContain(WARNING) + .shouldMatch(SECURITY_WARNING); + } else { + analyzer.shouldNotMatch(SECURITY_WARNING); + } + } + + private static boolean isAlgoRestricted() { + return ("RESTRICT".equals(algoStatus)) ? true : false; + } +} From 6df465de7309e90bc4de8da66c7059035ffc9bef Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Sun, 9 Aug 2020 09:20:02 +0200 Subject: [PATCH 34/53] 8251257: NMT: jcmd VM.native_memory scale=1 crashes target VM Reviewed-by: zgu, dholmes --- src/hotspot/share/services/nmtCommon.cpp | 1 + test/hotspot/jtreg/runtime/NMT/JcmdScale.java | 8 ++++++++ 2 files changed, 9 insertions(+) diff --git a/src/hotspot/share/services/nmtCommon.cpp b/src/hotspot/share/services/nmtCommon.cpp index 10a6190d783..b90981f5cd2 100644 --- a/src/hotspot/share/services/nmtCommon.cpp +++ b/src/hotspot/share/services/nmtCommon.cpp @@ -35,6 +35,7 @@ const char* NMTUtil::_memory_type_names[] = { const char* NMTUtil::scale_name(size_t scale) { switch(scale) { + case 1: return ""; case K: return "KB"; case M: return "MB"; case G: return "GB"; diff --git a/test/hotspot/jtreg/runtime/NMT/JcmdScale.java b/test/hotspot/jtreg/runtime/NMT/JcmdScale.java index 12a7f649e02..c0c08be0967 100644 --- a/test/hotspot/jtreg/runtime/NMT/JcmdScale.java +++ b/test/hotspot/jtreg/runtime/NMT/JcmdScale.java @@ -42,6 +42,14 @@ public class JcmdScale { // Grab my own PID String pid = Long.toString(ProcessTools.getProcessId()); + pb.command(new String[] { JDKToolFinder.getJDKTool("jcmd"), pid, "VM.native_memory", "scale=1"}); + output = new OutputAnalyzer(pb.start()); + output.shouldContain(", committed="); + + pb.command(new String[] { JDKToolFinder.getJDKTool("jcmd"), pid, "VM.native_memory", "scale=b"}); + output = new OutputAnalyzer(pb.start()); + output.shouldContain(", committed="); + pb.command(new String[] { JDKToolFinder.getJDKTool("jcmd"), pid, "VM.native_memory", "scale=KB"}); output = new OutputAnalyzer(pb.start()); output.shouldContain("KB, committed="); From ee060c777c22515f6fdace1058024adac035cff5 Mon Sep 17 00:00:00 2001 From: Chris Plummer Date: Sun, 9 Aug 2020 19:38:51 -0700 Subject: [PATCH 35/53] 8241951: SA core file tests failed to find core file for signed binaries on OSX 10.15 Reviewed-by: amenkov, dcubed --- test/lib/jdk/test/lib/util/CoreUtils.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/test/lib/jdk/test/lib/util/CoreUtils.java b/test/lib/jdk/test/lib/util/CoreUtils.java index c189aad2dae..cfff57bfd52 100644 --- a/test/lib/jdk/test/lib/util/CoreUtils.java +++ b/test/lib/jdk/test/lib/util/CoreUtils.java @@ -135,6 +135,14 @@ public class CoreUtils { if (!coresDir.canWrite()) { throw new SkippedException("Directory \"" + coresDir + "\" is not writable"); } + if (Platform.isSignedOSX()) { + if (Platform.getOsVersionMajor() > 10 || + (Platform.getOsVersionMajor() == 10 && Platform.getOsVersionMinor() >= 15)) + { + // We can't generate cores files with signed binaries on OSX 10.15 and later. + throw new SkippedException("Cannot produce core file with signed binary on OSX 10.15 and later"); + } + } } else if (Platform.isLinux()) { // Check if a crash report tool is installed. File corePatternFile = new File(CORE_PATTERN_FILE_NAME); From c1093dc2447c39c0bd1e1db3627dd353662a5040 Mon Sep 17 00:00:00 2001 From: Ioi Lam Date: Sun, 9 Aug 2020 20:56:04 -0700 Subject: [PATCH 36/53] 8251213: [TESTBUG] CDS tests shouldn't write output files into test.classes directory Reviewed-by: minqi, ccheung --- .../runtime/cds/appcds/AppendClasspath.java | 9 +++-- .../cds/appcds/BootClassPathMismatch.java | 2 +- .../runtime/cds/appcds/ClassPathAttr.java | 7 ++-- .../jtreg/runtime/cds/appcds/JarBuilder.java | 15 +++---- .../runtime/cds/appcds/LongClassListPath.java | 6 +-- .../jtreg/runtime/cds/appcds/MoveJDKTest.java | 9 +++-- .../runtime/cds/appcds/MultiReleaseJars.java | 5 ++- .../runtime/cds/appcds/NonExistClasspath.java | 11 +++--- .../runtime/cds/appcds/OldClassTest.java | 8 ++-- .../jtreg/runtime/cds/appcds/TestCommon.java | 9 ++--- .../runtime/cds/appcds/VerifierTest.java | 10 ++--- .../dynamicArchive/CDSStreamTestDriver.java | 6 +-- .../dynamicArchive/DoubleSumAverageTest.java | 3 +- .../dynamicArchive/HelloDynamicCustom.java | 4 +- .../HelloDynamicCustomUnload.java | 4 +- .../LambdaForClassInBaseArchive.java | 4 +- .../dynamicArchive/NoClassToArchive.java | 4 +- .../methodHandles/CDSMHTest_generate.sh | 27 +++++++++++-- .../MethodHandlesAsCollectorTest.java | 3 +- .../MethodHandlesCastFailureTest.java | 3 +- .../MethodHandlesGeneralTest.java | 3 +- .../MethodHandlesInvokersTest.java | 3 +- .../MethodHandlesPermuteArgumentsTest.java | 3 +- .../MethodHandlesSpreadArgumentsTest.java | 3 +- test/lib/jdk/test/lib/cds/CDSTestUtils.java | 39 +++++++++++++------ 25 files changed, 113 insertions(+), 87 deletions(-) diff --git a/test/hotspot/jtreg/runtime/cds/appcds/AppendClasspath.java b/test/hotspot/jtreg/runtime/cds/appcds/AppendClasspath.java index a6a670a62a6..be927dbc7b4 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/AppendClasspath.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/AppendClasspath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,6 +36,7 @@ import java.io.File; import java.nio.file.Files; import java.nio.file.Paths; import java.nio.file.StandardCopyOption; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; public class AppendClasspath { @@ -54,11 +55,11 @@ public class AppendClasspath { .assertNormalExit(); // PASS: 2) runtime has an non-existing jar in the -cp - String classDir = System.getProperty("test.classes"); + String outDir = CDSTestUtils.getOutputDir(); String newFile = "non-exist.jar"; - String nonExistPath = classDir + File.separator + newFile; + String nonExistPath = outDir + File.separator + newFile; String classPath = appJar + File.pathSeparator + nonExistPath; - File nonExistJar = new File(classDir, newFile); + File nonExistJar = new File(outDir, newFile); if (nonExistJar.exists()) { nonExistJar.delete(); } diff --git a/test/hotspot/jtreg/runtime/cds/appcds/BootClassPathMismatch.java b/test/hotspot/jtreg/runtime/cds/appcds/BootClassPathMismatch.java index 7016558be9f..279c3286ca1 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/BootClassPathMismatch.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/BootClassPathMismatch.java @@ -237,7 +237,7 @@ public class BootClassPathMismatch { } private static void copyHelloToNewDir() throws Exception { - String classDir = System.getProperty("test.classes"); + String classDir = CDSTestUtils.getOutputDir(); String dstDir = classDir + File.separator + "newdir"; try { Files.createDirectory(Paths.get(dstDir)); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/ClassPathAttr.java b/test/hotspot/jtreg/runtime/cds/appcds/ClassPathAttr.java index 16187f215f5..bf9bb5bb274 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/ClassPathAttr.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/ClassPathAttr.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,6 +30,7 @@ * @run driver/timeout=240 ClassPathAttr */ +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; import java.io.File; import java.nio.file.Files; @@ -101,7 +102,7 @@ public class ClassPathAttr { buildCpAttr("cpattr6", "cpattr6.mf", "CpAttr6", "CpAttr6"); String cp = TestCommon.getTestJar("cpattr6.jar"); - String nonExistPath = System.getProperty("test.classes") + File.separator + "cpattrX.jar"; + String nonExistPath = CDSTestUtils.getOutputDir() + File.separator + "cpattrX.jar"; (new File(nonExistPath)).delete(); TestCommon.testDump(cp, TestCommon.list("CpAttr6"), @@ -129,7 +130,7 @@ public class ClassPathAttr { } private static void buildCpAttr(String jarName, String manifest, String enclosingClassName, String ...testClassNames) throws Exception { - String jarClassesDir = System.getProperty("test.classes") + File.separator + jarName + "_classes"; + String jarClassesDir = CDSTestUtils.getOutputDir() + File.separator + jarName + "_classes"; try { Files.createDirectory(Paths.get(jarClassesDir)); } catch (FileAlreadyExistsException e) { } JarBuilder.compile(jarClassesDir, System.getProperty("test.src") + File.separator + diff --git a/test/hotspot/jtreg/runtime/cds/appcds/JarBuilder.java b/test/hotspot/jtreg/runtime/cds/appcds/JarBuilder.java index 88cfd2437c2..0929d0cc114 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/JarBuilder.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/JarBuilder.java @@ -32,6 +32,7 @@ */ import jdk.test.lib.JDKToolFinder; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.compiler.CompilerUtils; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; @@ -48,7 +49,7 @@ public class JarBuilder { .orElseThrow(() -> new RuntimeException("ToolProvider for jar not found")); public static String getJarFilePath(String jarName) { - return classDir + File.separator + jarName + ".jar"; + return CDSTestUtils.getOutputDir() + File.separator + jarName + ".jar"; } // jar all files under dir, with manifest file man, with an optional versionArgs @@ -59,7 +60,7 @@ public class JarBuilder { // -C .\ // --release 9 -C . // the last line begins with "--release" corresponds to the optional versionArgs. - public static void build(String jarName, File dir, String man, String ...versionArgs) + public static String build(String jarName, File dir, String man, String ...versionArgs) throws Exception { ArrayList args = new ArrayList(); if (man != null) { @@ -67,7 +68,8 @@ public class JarBuilder { } else { args.add("cf"); } - args.add(classDir + File.separator + jarName + ".jar"); + String jarFile = getJarFilePath(jarName); + args.add(jarFile); if (man != null) { args.add(man); } @@ -78,6 +80,7 @@ public class JarBuilder { args.add(verArg); } createJar(args); + return jarFile; } public static String build(String jarName, String ...classNames) @@ -259,8 +262,6 @@ public class JarBuilder { public static void signJar() throws Exception { String keyTool = JDKToolFinder.getJDKTool("keytool"); String jarSigner = JDKToolFinder.getJDKTool("jarsigner"); - String classDir = System.getProperty("test.classes"); - String FS = File.separator; executeProcess(keyTool, "-genkey", "-keystore", "./keystore", "-alias", "mykey", @@ -270,8 +271,8 @@ public class JarBuilder { executeProcess(jarSigner, "-keystore", "./keystore", "-storepass", "abc123", "-keypass", - "abc123", "-signedjar", classDir + FS + "signed_hello.jar", - classDir + FS + "hello.jar", "mykey") + "abc123", "-signedjar", getJarFilePath("signed_hello"), + getJarFilePath("hello"), "mykey") .shouldHaveExitValue(0); } diff --git a/test/hotspot/jtreg/runtime/cds/appcds/LongClassListPath.java b/test/hotspot/jtreg/runtime/cds/appcds/LongClassListPath.java index 59c7b2b3567..b50b0ad47d9 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/LongClassListPath.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/LongClassListPath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -51,14 +51,14 @@ public class LongClassListPath { // Create a directory with long path and copy the classlist file to // the directory. - Path classDir = Paths.get(System.getProperty("test.classes")); + Path classDir = Paths.get(CDSTestUtils.getOutputDir()); Path destDir = classDir; int subDirLen = MAX_PATH - classDir.toString().length() - 2; if (subDirLen > 0) { char[] chars = new char[subDirLen]; Arrays.fill(chars, 'x'); String subPath = new String(chars); - destDir = Paths.get(System.getProperty("test.classes"), subPath); + destDir = Paths.get(CDSTestUtils.getOutputDir(), subPath); } File longDir = destDir.toFile(); longDir.mkdir(); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java b/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java index 09572d1293f..7cfd5b7107c 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/MoveJDKTest.java @@ -41,6 +41,7 @@ import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; import java.nio.file.StandardCopyOption; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; public class MoveJDKTest { @@ -178,12 +179,12 @@ public class MoveJDKTest { } private static String copyFakeModulesFromHelloJar() throws Exception { - String classDir = System.getProperty("test.classes"); + String outDir = CDSTestUtils.getOutputDir(); String newFile = "hello.modules"; - String path = classDir + File.separator + newFile; + String path = outDir + File.separator + newFile; - Files.copy(Paths.get(classDir, "hello.jar"), - Paths.get(classDir, newFile), + Files.copy(Paths.get(outDir, "hello.jar"), + Paths.get(outDir, newFile), StandardCopyOption.REPLACE_EXISTING); return path; } diff --git a/test/hotspot/jtreg/runtime/cds/appcds/MultiReleaseJars.java b/test/hotspot/jtreg/runtime/cds/appcds/MultiReleaseJars.java index 6da874393fa..6563a38d230 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/MultiReleaseJars.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/MultiReleaseJars.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -34,6 +34,7 @@ import java.io.File; import java.io.FileOutputStream; import java.io.PrintStream; import java.io.IOException; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; public class MultiReleaseJars { @@ -90,7 +91,7 @@ public class MultiReleaseJars { * META-INF/versions//version/Version.class */ static void createClassFilesAndJar() throws Exception { - String tempDir = System.getProperty("test.classes"); + String tempDir = CDSTestUtils.getOutputDir(); File baseDir = new File(tempDir + File.separator + "base"); File vDir = new File(tempDir + File.separator + MAJOR_VERSION_STRING); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/NonExistClasspath.java b/test/hotspot/jtreg/runtime/cds/appcds/NonExistClasspath.java index 30f916681ee..a08f1c5ff15 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/NonExistClasspath.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/NonExistClasspath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2019, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,6 +36,7 @@ import java.io.File; import java.nio.file.Files; import java.nio.file.Paths; import java.nio.file.StandardCopyOption; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; public class NonExistClasspath { @@ -46,9 +47,9 @@ public class NonExistClasspath { } static void doTest(String appJar, boolean bootcp) throws Exception { - String classDir = System.getProperty("test.classes"); + String outDir = CDSTestUtils.getOutputDir(); String newFile = "non-exist.jar"; - String nonExistPath = classDir + File.separator + newFile; + String nonExistPath = outDir + File.separator + newFile; final String errorMessage1 = "Unable to use shared archive"; final String errorMessage2 = "shared class paths mismatch"; final String errorMessage3 = (bootcp ? "BOOT" : "APP") + " classpath mismatch"; @@ -90,8 +91,8 @@ public class NonExistClasspath { .assertNormalExit(); // Now make nonExistPath exist. CDS will fail to load. - Files.copy(Paths.get(classDir, "hello.jar"), - Paths.get(classDir, newFile), + Files.copy(Paths.get(outDir, "hello.jar"), + Paths.get(outDir, newFile), StandardCopyOption.REPLACE_EXISTING); TestCommon.run(make_args(bootcp, diff --git a/test/hotspot/jtreg/runtime/cds/appcds/OldClassTest.java b/test/hotspot/jtreg/runtime/cds/appcds/OldClassTest.java index 4869705c87a..b2401f87112 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/OldClassTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/OldClassTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -45,10 +45,8 @@ public class OldClassTest implements Opcodes { public static void main(String[] args) throws Exception { File jarSrcFile = new File(JarBuilder.getOrCreateHelloJar()); - - File dir = new File(System.getProperty("test.classes", ".")); - File jarFile = new File(dir, "OldClassTest_old.jar"); - String jar = jarFile.getPath(); + String jar = JarBuilder.getJarFilePath("OldClassTest_old"); + File jarFile = new File(jar); if (!jarFile.exists() || jarFile.lastModified() < jarSrcFile.lastModified()) { createTestJarFile(jarSrcFile, jarFile); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/TestCommon.java b/test/hotspot/jtreg/runtime/cds/appcds/TestCommon.java index 39ce615ac0e..ec1ca50fabd 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/TestCommon.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/TestCommon.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -321,12 +321,11 @@ public class TestCommon extends CDSTestUtils { firstJar = firstJar.substring(0, n); } String classDir = System.getProperty("test.classes"); - String expected1 = classDir + File.separator; - String expected2 = System.getProperty("user.dir") + File.separator; + String expected = getOutputDir() + File.separator; - if (!firstJar.startsWith(expected1) && !firstJar.startsWith(expected2)) { + if (!firstJar.startsWith(expected)) { throw new RuntimeException("FIXME: jar file not at a supported location ('" - + expected1 + "', or '" + expected2 + "'): " + firstJar); + + expected + "'): " + firstJar); } String replaceJar = firstJar + ".tmp"; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/VerifierTest.java b/test/hotspot/jtreg/runtime/cds/appcds/VerifierTest.java index cbae7c36d54..1a0b29bc80d 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/VerifierTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/VerifierTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -62,15 +62,13 @@ public class VerifierTest implements Opcodes { String jarName_hi = "hi" + "_" + subCaseId; - JarBuilder.build(jarName_verifier_test_tmp, "VerifierTest0", "VerifierTestA", + File jarSrcFile = new File(JarBuilder.build(jarName_verifier_test_tmp, "VerifierTest0", "VerifierTestA", "VerifierTestB", "VerifierTestC", "VerifierTestD", "VerifierTestE", - "UnverifiableBase", "UnverifiableIntf", "UnverifiableIntfSub"); + "UnverifiableBase", "UnverifiableIntf", "UnverifiableIntfSub")); JarBuilder.build(jarName_greet, "Greet"); JarBuilder.build(jarName_hi, "Hi", "Hi$MyClass"); - File dir = new File(System.getProperty("test.classes", ".")); - File jarSrcFile = new File(dir, jarName_verifier_test_tmp + ".jar"); - File jarFile = new File(dir, jarName_verifier_test + ".jar"); + File jarFile = new File(JarBuilder.getJarFilePath(jarName_verifier_test)); String jar = jarFile.getPath(); if (!jarFile.exists() || jarFile.lastModified() < jarSrcFile.lastModified()) { diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/CDSStreamTestDriver.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/CDSStreamTestDriver.java index ba5dedde6bd..9525e12b1e8 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/CDSStreamTestDriver.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/CDSStreamTestDriver.java @@ -36,11 +36,8 @@ */ import org.testng.annotations.Test; - import java.io.File; - import jtreg.SkippedException; - import sun.hotspot.gc.GC; @Test @@ -58,8 +55,7 @@ public class CDSStreamTestDriver extends DynamicArchiveTestBase { static void doTest() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("streamapp", new File(classDir), null); - String appJar = classDir + File.separator + "streamapp.jar"; + String appJar = JarBuilder.build("streamapp", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String testngJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/DoubleSumAverageTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/DoubleSumAverageTest.java index 01b8d7d5849..6d6d3b78c0d 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/DoubleSumAverageTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/DoubleSumAverageTest.java @@ -47,8 +47,7 @@ public class DoubleSumAverageTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("stream", new File(classDir), null); - String appJar = classDir + File.separator + "stream.jar"; + String appJar = JarBuilder.build("stream", new File(classDir), null); dumpAndRun(topArchiveName, "-Xlog:cds,cds+dynamic=debug,class+load=trace", "-cp", appJar, mainClass); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustom.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustom.java index 2dc36726768..69e44f1e419 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustom.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustom.java @@ -36,11 +36,11 @@ */ import java.io.File; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; public class HelloDynamicCustom extends DynamicArchiveTestBase { - private static final String ARCHIVE_NAME = - System.getProperty("test.classes") + File.separator + "HelloDynamicCustom-top.jsa"; + private static final String ARCHIVE_NAME = CDSTestUtils.getOutputFileName("top.jsa"); public static void main(String[] args) throws Exception { runTest(HelloDynamicCustom::testDefaultBase); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustomUnload.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustomUnload.java index d4ada452a18..1f8d907434c 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustomUnload.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/HelloDynamicCustomUnload.java @@ -39,10 +39,10 @@ */ import java.io.File; +import jdk.test.lib.cds.CDSTestUtils; public class HelloDynamicCustomUnload extends DynamicArchiveTestBase { - private static final String ARCHIVE_NAME = - System.getProperty("test.classes") + File.separator + "HelloDynamicCustomUnload.jsa"; + private static final String ARCHIVE_NAME = CDSTestUtils.getOutputFileName("top.jsa"); public static void main(String[] args) throws Exception { runTest(HelloDynamicCustomUnload::testDefaultBase); diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/LambdaForClassInBaseArchive.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/LambdaForClassInBaseArchive.java index e68bf028d7f..4de1f4a188b 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/LambdaForClassInBaseArchive.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/LambdaForClassInBaseArchive.java @@ -37,12 +37,12 @@ */ import java.io.File; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; public class LambdaForClassInBaseArchive extends DynamicArchiveTestBase { - static final String classList = System.getProperty("test.classes") + - File.separator + "LambdaForClassInBaseArchive.list"; + static final String classList = CDSTestUtils.getOutputFileName("classlist"); static final String appClass = "SimpleApp"; public static void main(String[] args) throws Exception { diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/NoClassToArchive.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/NoClassToArchive.java index 1568f60efba..947b1444c10 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/NoClassToArchive.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/NoClassToArchive.java @@ -45,14 +45,14 @@ */ import java.io.File; +import jdk.test.lib.cds.CDSTestUtils; import jdk.test.lib.process.OutputAnalyzer; import jdk.test.lib.process.ProcessTools; public class NoClassToArchive extends DynamicArchiveTestBase { static final String warningMessage = "There is no class to be included in the dynamic archive"; - static final String classList = System.getProperty("test.classes") + - File.separator + "NoClassToArchive.list"; + static final String classList = CDSTestUtils.getOutputFileName("classlist"); static final String appClass = "StrConcatApp"; public static void main(String[] args) throws Exception { diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/CDSMHTest_generate.sh b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/CDSMHTest_generate.sh index def90c398fc..9ac1e5c4749 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/CDSMHTest_generate.sh +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/CDSMHTest_generate.sh @@ -30,7 +30,29 @@ for i in "${testnames[@]}" do fname="$i$name_suffix" cat << EOF > $fname - +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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. + * + */ // this file is auto-generated by $0. Do not edit manually. /* @@ -78,8 +100,7 @@ public class $i extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesAsCollectorTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesAsCollectorTest.java index 20f73d444f9..39066c7f641 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesAsCollectorTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesAsCollectorTest.java @@ -68,8 +68,7 @@ public class MethodHandlesAsCollectorTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesCastFailureTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesCastFailureTest.java index 3405a31b744..0c3482ba95e 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesCastFailureTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesCastFailureTest.java @@ -68,8 +68,7 @@ public class MethodHandlesCastFailureTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesGeneralTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesGeneralTest.java index 0a0655c0c81..4d78b79692e 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesGeneralTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesGeneralTest.java @@ -68,8 +68,7 @@ public class MethodHandlesGeneralTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesInvokersTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesInvokersTest.java index 95b369e2554..15622747bff 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesInvokersTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesInvokersTest.java @@ -68,8 +68,7 @@ public class MethodHandlesInvokersTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesPermuteArgumentsTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesPermuteArgumentsTest.java index f612171432a..d07e1c00ad5 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesPermuteArgumentsTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesPermuteArgumentsTest.java @@ -68,8 +68,7 @@ public class MethodHandlesPermuteArgumentsTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesSpreadArgumentsTest.java b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesSpreadArgumentsTest.java index f9962b6499e..d8d6c77b7d9 100644 --- a/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesSpreadArgumentsTest.java +++ b/test/hotspot/jtreg/runtime/cds/appcds/dynamicArchive/methodHandles/MethodHandlesSpreadArgumentsTest.java @@ -68,8 +68,7 @@ public class MethodHandlesSpreadArgumentsTest extends DynamicArchiveTestBase { static void testImpl() throws Exception { String topArchiveName = getNewArchiveName(); - JarBuilder.build("MH", new File(classDir), null); - String appJar = classDir + File.separator + "MH.jar"; + String appJar = JarBuilder.build("MH", new File(classDir), null); String[] classPaths = javaClassPath.split(File.pathSeparator); String junitJar = null; diff --git a/test/lib/jdk/test/lib/cds/CDSTestUtils.java b/test/lib/jdk/test/lib/cds/CDSTestUtils.java index 2582833e3b3..cfa6bbddfcc 100644 --- a/test/lib/jdk/test/lib/cds/CDSTestUtils.java +++ b/test/lib/jdk/test/lib/cds/CDSTestUtils.java @@ -482,11 +482,21 @@ public class CDSTestUtils { return output; } + private static final String outputDir; + private static final File outputDirAsFile; + + static { + outputDir = System.getProperty("user.dir", "."); + outputDirAsFile = new File(outputDir); + } + + public static String getOutputDir() { + return outputDir; + } // get the file object for the test artifact public static File getTestArtifact(String name, boolean checkExistence) { - File dir = new File(System.getProperty("test.classes", ".")); - File file = new File(dir, name); + File file = new File(outputDirAsFile, name); if (checkExistence && !file.exists()) { throw new RuntimeException("Cannot find " + file.getPath()); @@ -549,14 +559,16 @@ public class CDSTestUtils { // ===================== FILE ACCESS convenience methods public static File getOutputFile(String name) { - File dir = new File(System.getProperty("test.classes", ".")); - return new File(dir, testName + "-" + name); + return new File(outputDirAsFile, testName + "-" + name); + } + + public static String getOutputFileName(String name) { + return getOutputFile(name).getName(); } public static File getOutputSourceFile(String name) { - File dir = new File(System.getProperty("test.classes", ".")); - return new File(dir, name); + return new File(outputDirAsFile, name); } @@ -570,14 +582,17 @@ public class CDSTestUtils { public static OutputAnalyzer executeAndLog(ProcessBuilder pb, String logName) throws Exception { long started = System.currentTimeMillis(); OutputAnalyzer output = new OutputAnalyzer(pb.start()); - String outputFileNamePrefix = - testName + "-" + String.format("%04d", getNextLogCounter()) + "-" + logName; + String logFileNameStem = + String.format("%04d", getNextLogCounter()) + "-" + logName; - writeFile(getOutputFile(outputFileNamePrefix + ".stdout"), output.getStdout()); - writeFile(getOutputFile(outputFileNamePrefix + ".stderr"), output.getStderr()); + File stdout = getOutputFile(logFileNameStem + ".stdout"); + File stderr = getOutputFile(logFileNameStem + ".stderr"); + + writeFile(stdout, output.getStdout()); + writeFile(stderr, output.getStderr()); System.out.println("[ELAPSED: " + (System.currentTimeMillis() - started) + " ms]"); - System.out.println("[logging stdout to " + outputFileNamePrefix + ".stdout]"); - System.out.println("[logging stderr to " + outputFileNamePrefix + ".stderr]"); + System.out.println("[logging stdout to " + stdout + "]"); + System.out.println("[logging stderr to " + stderr + "]"); System.out.println("[STDERR]\n" + output.getStderr()); if (copyChildStdoutToMainStdout) From 970e251a54d3b8871d3b948c1632c124f248cb01 Mon Sep 17 00:00:00 2001 From: Tobias Hartmann Date: Mon, 10 Aug 2020 08:21:14 +0200 Subject: [PATCH 37/53] 8249608: Vector register used by C2 compiled method corrupted at safepoint Always update 'max_vlen_in_bytes'. Reviewed-by: kvn, vlivanov, chagedorn --- src/hotspot/share/opto/superword.cpp | 4 +- .../TestVectorsNotSavedAtSafepoint.java | 102 ++++++++++++++++++ 2 files changed, 105 insertions(+), 1 deletion(-) create mode 100644 test/hotspot/jtreg/compiler/vectorization/TestVectorsNotSavedAtSafepoint.java diff --git a/src/hotspot/share/opto/superword.cpp b/src/hotspot/share/opto/superword.cpp index 3a9b6b555a9..4a708488c42 100644 --- a/src/hotspot/share/opto/superword.cpp +++ b/src/hotspot/share/opto/superword.cpp @@ -2637,8 +2637,10 @@ void SuperWord::output() { } } - if (vlen_in_bytes >= max_vlen_in_bytes && vlen > max_vlen) { + if (vlen > max_vlen) { max_vlen = vlen; + } + if (vlen_in_bytes > max_vlen_in_bytes) { max_vlen_in_bytes = vlen_in_bytes; } #ifdef ASSERT diff --git a/test/hotspot/jtreg/compiler/vectorization/TestVectorsNotSavedAtSafepoint.java b/test/hotspot/jtreg/compiler/vectorization/TestVectorsNotSavedAtSafepoint.java new file mode 100644 index 00000000000..ce524d301ed --- /dev/null +++ b/test/hotspot/jtreg/compiler/vectorization/TestVectorsNotSavedAtSafepoint.java @@ -0,0 +1,102 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2020, Red Hat, Inc. All rights reserved. + * 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 + * @bug 8193518 8249608 + * @summary C2: Vector registers are sometimes corrupted at safepoint + * @run main/othervm -XX:-BackgroundCompilation -XX:+UseCountedLoopSafepoints -XX:LoopStripMiningIter=1000 TestVectorsNotSavedAtSafepoint test1 + * @run main/othervm -XX:-BackgroundCompilation TestVectorsNotSavedAtSafepoint test2 + */ + +import java.util.Arrays; + +public class TestVectorsNotSavedAtSafepoint { + + static void test1(byte[] barray1, byte[] barray2, byte[] barray3, long[] larray, long v) { + // Uses wide vectors, v in vector registers is live at the + // safepoint of the outer strip mined loop + for (int i = 0; i < larray.length; i++) { + larray[i] = v; + } + // Runs for few iterations so limited unrolling and short + // vectors + for (int i = 0; i < barray3.length; i++) { + barray3[i] = (byte)(barray1[i] + barray2[i]); + } + } + + public static void test2(int[] iArr, long[] lArr) { + // Loop with wide and non-wide vectors + for (int i = 0; i < lArr.length; i++) { + iArr[i] = 1; + lArr[i] = 1; + } + } + + static class GarbageProducerThread extends Thread { + public void run() { + for(;;) { + Object[] arrays = new Object[1024]; + for (int i = 0; i < arrays.length; i++) { + arrays[i] = new int[1024]; + } + } + } + } + + public static void main(String[] args) { + Thread garbage_producer = new GarbageProducerThread(); + garbage_producer.setDaemon(true); + garbage_producer.start(); + + if (args[0].equals("test1")) { + byte[] barray = new byte[10]; + long[] larray1 = new long[1000]; + long[] larray2 = new long[100_000_000]; + for (int i = 0; i < 20_000; i++) { + test1(barray, barray, barray, larray1, -1); + } + for (int i = 0; i < 100; i++) { + test1(barray, barray, barray, larray2, -1); + if (larray2[larray2.length-1] != -1) { + System.out.println("Iter " + i + " Failed with " + Long.toHexString(larray2[larray2.length-1])); + throw new RuntimeException("Test1 failed"); + } + } + } else { + int iArr[] = new int[100]; + long lArr[] = new long[100]; + for (int i = 0; i < 600_000; ++i) { + test2(iArr, lArr); + for (int j = 0; j < lArr.length; ++j) { + if (iArr[j] != 1 || lArr[j] != 1) { + throw new RuntimeException("Test2 failed at iteration " + i + ": iArr[" + j + "] = " + iArr[j] + ", lArr[" + j + "] = " + lArr[j]); + } + } + } + } + } +} + From 032a4d6b9f1af0d36ee777ab87d505224d8e1154 Mon Sep 17 00:00:00 2001 From: Nikola Grcevski Date: Mon, 10 Aug 2020 08:36:56 +0200 Subject: [PATCH 38/53] 8241007: Shenandoah: remove ShenandoahCriticalControlThreadPriority support Reviewed-by: adityam, shade --- .../gc/shenandoah/shenandoahControlThread.cpp | 2 +- .../gc/shenandoah/shenandoah_globals.hpp | 3 -- .../TestCriticalControlThreadPriority.java | 41 ------------------- 3 files changed, 1 insertion(+), 45 deletions(-) delete mode 100644 test/hotspot/jtreg/gc/shenandoah/options/TestCriticalControlThreadPriority.java diff --git a/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp b/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp index c0fae236f6e..5076811fbac 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahControlThread.cpp @@ -50,7 +50,7 @@ ShenandoahControlThread::ShenandoahControlThread() : _allocs_seen(0) { reset_gc_id(); - create_and_start(ShenandoahCriticalControlThreadPriority ? CriticalPriority : NearMaxPriority); + create_and_start(); _periodic_task.enroll(); _periodic_satb_flush_task.enroll(); if (ShenandoahPacing) { diff --git a/src/hotspot/share/gc/shenandoah/shenandoah_globals.hpp b/src/hotspot/share/gc/shenandoah/shenandoah_globals.hpp index 217eb550898..b2eb4b2bfdf 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoah_globals.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoah_globals.hpp @@ -191,9 +191,6 @@ "adjustment. Lower values make adjustments faster, at the " \ "expense of higher perf overhead. Time is in milliseconds.") \ \ - experimental(bool, ShenandoahCriticalControlThreadPriority, false, \ - "Run control thread runs at critical scheduling priority.") \ - \ diagnostic(bool, ShenandoahVerify, false, \ "Enable internal verification. This would catch many GC bugs, " \ "but it would also stall the collector during the verification, " \ diff --git a/test/hotspot/jtreg/gc/shenandoah/options/TestCriticalControlThreadPriority.java b/test/hotspot/jtreg/gc/shenandoah/options/TestCriticalControlThreadPriority.java deleted file mode 100644 index 152a1ea077f..00000000000 --- a/test/hotspot/jtreg/gc/shenandoah/options/TestCriticalControlThreadPriority.java +++ /dev/null @@ -1,41 +0,0 @@ -/* - * Copyright (c) 2019, Red Hat, Inc. All rights reserved. - * 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 TestCriticalControlThreadPriority - * @summary Check that ShenandoahCriticalControlThreadPriority works - * @bug 8217343 - * @requires vm.gc.Shenandoah - * - * @run main/othervm -XX:+UnlockExperimentalVMOptions -XX:+UseShenandoahGC -XX:-ShenandoahCriticalControlThreadPriority -Xmx1g TestCriticalControlThreadPriority - * @run main/othervm -XX:+UnlockExperimentalVMOptions -XX:+UseShenandoahGC -XX:+ShenandoahCriticalControlThreadPriority -Xmx1g TestCriticalControlThreadPriority - */ - -public class TestCriticalControlThreadPriority { - - public static void main(String[] args) throws Exception { - // checking the initialization before entering main() - } - -} From 660272ce7cd20a03cacf9abb2983342eb221a388 Mon Sep 17 00:00:00 2001 From: Charlie Gracie Date: Mon, 10 Aug 2020 08:37:05 +0200 Subject: [PATCH 39/53] 8241574: Shenandoah: remove ShenandoahAssertToSpaceClosure Reviewed-by: zgu, bmathiske, shade --- src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp | 14 -------------- src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp | 11 ----------- 2 files changed, 25 deletions(-) diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp index f5a0579d0c3..3050cf07a21 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp @@ -82,20 +82,6 @@ #include "services/mallocTracker.hpp" #include "utilities/powerOfTwo.hpp" -#ifdef ASSERT -template -void ShenandoahAssertToSpaceClosure::do_oop_work(T* p) { - T o = RawAccess<>::oop_load(p); - if (! CompressedOops::is_null(o)) { - oop obj = CompressedOops::decode_not_null(o); - shenandoah_assert_not_forwarded(p, obj); - } -} - -void ShenandoahAssertToSpaceClosure::do_oop(narrowOop* p) { do_oop_work(p); } -void ShenandoahAssertToSpaceClosure::do_oop(oop* p) { do_oop_work(p); } -#endif - class ShenandoahPretouchHeapTask : public AbstractGangTask { private: ShenandoahRegionIterator _regions; diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp b/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp index 38cc96b37c7..72d9450336c 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeap.hpp @@ -105,17 +105,6 @@ public: virtual bool is_thread_safe() { return false; } }; -#ifdef ASSERT -class ShenandoahAssertToSpaceClosure : public OopClosure { -private: - template - void do_oop_work(T* p); -public: - void do_oop(narrowOop* p); - void do_oop(oop* p); -}; -#endif - typedef ShenandoahLock ShenandoahHeapLock; typedef ShenandoahLocker ShenandoahHeapLocker; From 1d480a7b96005f049c1dcb16344ca48f86f01f91 Mon Sep 17 00:00:00 2001 From: Dmitry Cherepanov Date: Mon, 10 Aug 2020 11:25:38 +0300 Subject: [PATCH 40/53] 8250636: iso8601_time returns incorrect offset part on MacOS Reviewed-by: dholmes, gziemski --- src/hotspot/share/runtime/os.cpp | 37 ++++++++++++++------------------ 1 file changed, 16 insertions(+), 21 deletions(-) diff --git a/src/hotspot/share/runtime/os.cpp b/src/hotspot/share/runtime/os.cpp index 8b61b5497cf..0581954e02f 100644 --- a/src/hotspot/share/runtime/os.cpp +++ b/src/hotspot/share/runtime/os.cpp @@ -88,18 +88,6 @@ static size_t cur_malloc_words = 0; // current size for MallocMaxTestWords DEBUG_ONLY(bool os::_mutex_init_done = false;) -static time_t get_timezone(const struct tm* time_struct) { -#if defined(_ALLBSD_SOURCE) - return time_struct->tm_gmtoff; -#elif defined(_WINDOWS) - long zone; - _get_timezone(&zone); - return static_cast(zone); -#else - return timezone; -#endif -} - int os::snprintf(char* buf, size_t len, const char* fmt, ...) { va_list args; va_start(args, fmt); @@ -152,21 +140,28 @@ char* os::iso8601_time(char* buffer, size_t buffer_length, bool utc) { return NULL; } } - const time_t zone = get_timezone(&time_struct); - // If daylight savings time is in effect, - // we are 1 hour East of our time zone const time_t seconds_per_minute = 60; const time_t minutes_per_hour = 60; const time_t seconds_per_hour = seconds_per_minute * minutes_per_hour; - time_t UTC_to_local = zone; - if (time_struct.tm_isdst > 0) { - UTC_to_local = UTC_to_local - seconds_per_hour; - } // No offset when dealing with UTC - if (utc) { - UTC_to_local = 0; + time_t UTC_to_local = 0; + if (!utc) { +#if defined(_WINDOWS) + long zone; + _get_timezone(&zone); + UTC_to_local = static_cast(zone); + + // If daylight savings time is in effect, + // we are 1 hour East of our time zone + if (time_struct.tm_isdst > 0) { + UTC_to_local = UTC_to_local - seconds_per_hour; + } +#else + // tm_gmtoff already includes adjustment for daylight saving + UTC_to_local = -(time_struct.tm_gmtoff); +#endif } // Compute the time zone offset. From 733218137289d6a0eb705103ed7be30f1e68d17a Mon Sep 17 00:00:00 2001 From: Charlie Gracie Date: Mon, 10 Aug 2020 12:12:40 +0300 Subject: [PATCH 41/53] 8251303: C2: remove unused _site_invoke_ratio and related code from InlineTree Reviewed-by: vlivanov, thartmann --- src/hotspot/share/opto/bytecodeInfo.cpp | 20 +++----------------- src/hotspot/share/opto/parse.hpp | 7 ------- 2 files changed, 3 insertions(+), 24 deletions(-) diff --git a/src/hotspot/share/opto/bytecodeInfo.cpp b/src/hotspot/share/opto/bytecodeInfo.cpp index ea32a469d06..10ff5860d33 100644 --- a/src/hotspot/share/opto/bytecodeInfo.cpp +++ b/src/hotspot/share/opto/bytecodeInfo.cpp @@ -42,13 +42,12 @@ InlineTree::InlineTree(Compile* c, const InlineTree *caller_tree, ciMethod* callee, JVMState* caller_jvms, int caller_bci, - float site_invoke_ratio, int max_inline_level) : + int max_inline_level) : C(c), _caller_jvms(caller_jvms), _method(callee), _caller_tree((InlineTree*) caller_tree), _count_inline_bcs(method()->code_size_for_inlining()), - _site_invoke_ratio(site_invoke_ratio), _max_inline_level(max_inline_level), _subtrees(c->comp_arena(), 2, 0, NULL), _msg(NULL) @@ -646,21 +645,8 @@ WarmCallInfo* InlineTree::ok_to_inline(ciMethod* callee_method, JVMState* jvms, return NULL; } -//------------------------------compute_callee_frequency----------------------- -float InlineTree::compute_callee_frequency( int caller_bci ) const { - int count = method()->interpreter_call_site_count(caller_bci); - int invcnt = method()->interpreter_invocation_count(); - float freq = (float)count/(float)invcnt; - // Call-site count / interpreter invocation count, scaled recursively. - // Always between 0.0 and 1.0. Represents the percentage of the method's - // total execution time used at this call site. - - return freq; -} - //------------------------------build_inline_tree_for_callee------------------- InlineTree *InlineTree::build_inline_tree_for_callee( ciMethod* callee_method, JVMState* caller_jvms, int caller_bci) { - float recur_frequency = _site_invoke_ratio * compute_callee_frequency(caller_bci); // Attempt inlining. InlineTree* old_ilt = callee_at(caller_bci, callee_method); if (old_ilt != NULL) { @@ -685,7 +671,7 @@ InlineTree *InlineTree::build_inline_tree_for_callee( ciMethod* callee_method, J } } // Allocate in the comp_arena to make sure the InlineTree is live when dumping a replay compilation file - InlineTree* ilt = new (C->comp_arena()) InlineTree(C, this, callee_method, caller_jvms, caller_bci, recur_frequency, _max_inline_level + max_inline_level_adjust); + InlineTree* ilt = new (C->comp_arena()) InlineTree(C, this, callee_method, caller_jvms, caller_bci, _max_inline_level + max_inline_level_adjust); _subtrees.append(ilt); NOT_PRODUCT( _count_inlines += 1; ) @@ -711,7 +697,7 @@ InlineTree *InlineTree::build_inline_tree_root() { Compile* C = Compile::current(); // Root of inline tree - InlineTree* ilt = new InlineTree(C, NULL, C->method(), NULL, -1, 1.0F, MaxInlineLevel); + InlineTree* ilt = new InlineTree(C, NULL, C->method(), NULL, -1, MaxInlineLevel); return ilt; } diff --git a/src/hotspot/share/opto/parse.hpp b/src/hotspot/share/opto/parse.hpp index adbb5ba3558..a6e7703796a 100644 --- a/src/hotspot/share/opto/parse.hpp +++ b/src/hotspot/share/opto/parse.hpp @@ -48,12 +48,7 @@ class InlineTree : public ResourceObj { ciMethod* _method; // method being called by the caller_jvms InlineTree* _caller_tree; uint _count_inline_bcs; // Accumulated count of inlined bytecodes - // Call-site count / interpreter invocation count, scaled recursively. - // Always between 0.0 and 1.0. Represents the percentage of the method's - // total execution time used at this call site. - const float _site_invoke_ratio; const int _max_inline_level; // the maximum inline level for this sub-tree (may be adjusted) - float compute_callee_frequency( int caller_bci ) const; GrowableArray _subtrees; @@ -67,7 +62,6 @@ protected: ciMethod* callee_method, JVMState* caller_jvms, int caller_bci, - float site_invoke_ratio, int max_inline_level); InlineTree *build_inline_tree_for_callee(ciMethod* callee_method, JVMState* caller_jvms, @@ -125,7 +119,6 @@ public: ciMethod *method() const { return _method; } int caller_bci() const { return _caller_jvms ? _caller_jvms->bci() : InvocationEntryBci; } uint count_inline_bcs() const { return _count_inline_bcs; } - float site_invoke_ratio() const { return _site_invoke_ratio; }; #ifndef PRODUCT private: From c2fa441d8ded94241fdac7005d6420f99b38af0b Mon Sep 17 00:00:00 2001 From: Nikola Grcevski Date: Mon, 10 Aug 2020 12:57:38 +0100 Subject: [PATCH 42/53] 8250521: Configure initial RTO to use minimal retry for loopback connections on Windows Reviewed-by: alanb --- .../windows/native/libnet/net_util_md.c | 51 +++++++++++++++++++ .../windows/native/libnet/net_util_md.h | 24 ++++++++- src/java.base/windows/native/libnio/ch/Net.c | 16 ++++-- 3 files changed, 87 insertions(+), 4 deletions(-) diff --git a/src/java.base/windows/native/libnet/net_util_md.c b/src/java.base/windows/native/libnet/net_util_md.c index e33cd70f5bd..83e30287196 100644 --- a/src/java.base/windows/native/libnet/net_util_md.c +++ b/src/java.base/windows/native/libnet/net_util_md.c @@ -770,6 +770,57 @@ NET_EnableFastTcpLoopback(int fd) { return result == SOCKET_ERROR ? WSAGetLastError() : 0; } +int +IsWindows10RS3OrGreater() { + OSVERSIONINFOEXW osvi = { sizeof(osvi), 0, 0, 0, 0, {0}, 0, 0 }; + DWORDLONG const cond_mask = VerSetConditionMask( + VerSetConditionMask( + VerSetConditionMask( + 0, VER_MAJORVERSION, VER_GREATER_EQUAL), + VER_MINORVERSION, VER_GREATER_EQUAL), + VER_BUILDNUMBER, VER_GREATER_EQUAL); + + osvi.dwMajorVersion = HIBYTE(_WIN32_WINNT_WIN10); + osvi.dwMinorVersion = LOBYTE(_WIN32_WINNT_WIN10); + osvi.dwBuildNumber = 16299; // RS3 (Redstone 3) + + return VerifyVersionInfoW(&osvi, VER_MAJORVERSION | VER_MINORVERSION | VER_BUILDNUMBER, cond_mask) != 0; +} + +/** + * Shortens the default Windows socket + * connect timeout. Recommended for usage + * on the loopback adapter only. + */ +JNIEXPORT jint JNICALL +NET_EnableFastTcpLoopbackConnect(int fd) { + TCP_INITIAL_RTO_PARAMETERS rto = { + TCP_INITIAL_RTO_UNSPECIFIED_RTT, // Use the default or overriden by the Administrator + 1 // Minimum possible value before Windows 10 RS3 + }; + + /** + * In Windows 10 RS3+ we can use the no retransmissions flag to + * completely remove the timeout delay, which is fixed to 500ms + * if Windows receives RST when the destination port is not open. + */ + if (IsWindows10RS3OrGreater()) { + rto.MaxSynRetransmissions = TCP_INITIAL_RTO_NO_SYN_RETRANSMISSIONS; + } + + DWORD result_byte_count = -1; + int result = WSAIoctl(fd, // descriptor identifying a socket + SIO_TCP_INITIAL_RTO, // dwIoControlCode + &rto, // pointer to TCP_INITIAL_RTO_PARAMETERS structure + sizeof(rto), // size, in bytes, of the input buffer + NULL, // pointer to output buffer + 0, // size of output buffer + &result_byte_count, // number of bytes returned + NULL, // OVERLAPPED structure + NULL); // completion routine + return (result == SOCKET_ERROR) ? WSAGetLastError() : 0; +} + /** * See net_util.h for documentation */ diff --git a/src/java.base/windows/native/libnet/net_util_md.h b/src/java.base/windows/native/libnet/net_util_md.h index 2edf008d181..b76935db3de 100644 --- a/src/java.base/windows/native/libnet/net_util_md.h +++ b/src/java.base/windows/native/libnet/net_util_md.h @@ -26,6 +26,7 @@ #include #include #include +#include /* used to disable connection reset messages on Windows XP */ #ifndef SIO_UDP_CONNRESET @@ -86,10 +87,29 @@ struct ipv6bind { #define GET_PORT(X) ((X)->sa.sa_family == AF_INET ? (X)->sa4.sin_port : (X)->sa6.sin6_port) +/** + * With dual socket implementation the + * IPv4 addresseses might be mapped as IPv6. + * The IPv4 loopback adapter address will + * be mapped as the following IPv6 ::ffff:127.0.0.1. + * For example, this is done by NET_InetAddressToSockaddr. + */ +#define IN6_IS_ADDR_V4MAPPED_LOOPBACK(x) ( \ + (((x)->s6_words[0] == 0) && \ + ((x)->s6_words[1] == 0) && \ + ((x)->s6_words[2] == 0) && \ + ((x)->s6_words[3] == 0) && \ + ((x)->s6_words[4] == 0) && \ + ((x)->s6_words[5] == 0xFFFF) && \ + ((x)->s6_words[6] == 0x007F) && \ + ((x)->s6_words[7] == 0x0100)) \ +) + #define IS_LOOPBACK_ADDRESS(x) ( \ ((x)->sa.sa_family == AF_INET) ? \ (ntohl((x)->sa4.sin_addr.s_addr) == INADDR_LOOPBACK) : \ - (IN6ADDR_ISLOOPBACK(x)) \ + ((IN6_IS_ADDR_LOOPBACK(&(x)->sa6.sin6_addr)) || \ + (IN6_IS_ADDR_V4MAPPED_LOOPBACK(&(x)->sa6.sin6_addr))) \ ) JNIEXPORT int JNICALL NET_SocketClose(int fd); @@ -119,6 +139,8 @@ JNIEXPORT int JNICALL NET_BindV6(struct ipv6bind *b, jboolean exclBind); JNIEXPORT int JNICALL NET_WinBind(int s, SOCKETADDRESS *sa, int len, jboolean exclBind); +JNIEXPORT jint JNICALL NET_EnableFastTcpLoopbackConnect(int fd); + /* XP versions of the native routines */ JNIEXPORT jobject JNICALL Java_java_net_NetworkInterface_getByName0_XP diff --git a/src/java.base/windows/native/libnio/ch/Net.c b/src/java.base/windows/native/libnio/ch/Net.c index 01b457cff61..cedb9934286 100644 --- a/src/java.base/windows/native/libnio/ch/Net.c +++ b/src/java.base/windows/native/libnio/ch/Net.c @@ -226,13 +226,25 @@ Java_sun_nio_ch_Net_connect0(JNIEnv *env, jclass clazz, jboolean preferIPv6, job { SOCKETADDRESS sa; int rv; + int so_rv; int sa_len = 0; SOCKET s = (SOCKET)fdval(env, fdo); + int type = 0, optlen = sizeof(type); if (NET_InetAddressToSockaddr(env, iao, port, &sa, &sa_len, preferIPv6) != 0) { return IOS_THROWN; } + so_rv = getsockopt(s, SOL_SOCKET, SO_TYPE, (char*)&type, &optlen); + + /** + * Windows has a very long socket connect timeout of 2 seconds. + * If it's the loopback adapter we can shorten the wait interval. + */ + if (so_rv == 0 && type == SOCK_STREAM && IS_LOOPBACK_ADDRESS(&sa)) { + NET_EnableFastTcpLoopbackConnect((jint)s); + } + rv = connect(s, &sa.sa, sa_len); if (rv != 0) { int err = WSAGetLastError(); @@ -243,9 +255,7 @@ Java_sun_nio_ch_Net_connect0(JNIEnv *env, jclass clazz, jboolean preferIPv6, job return IOS_THROWN; } else { /* Enable WSAECONNRESET errors when a UDP socket is connected */ - int type = 0, optlen = sizeof(type); - rv = getsockopt(s, SOL_SOCKET, SO_TYPE, (char*)&type, &optlen); - if (rv == 0 && type == SOCK_DGRAM) { + if (so_rv == 0 && type == SOCK_DGRAM) { setConnectionReset(s, TRUE); } } From c57d89ad1a7de75a3394a1e1f7a44cd0f05be3e0 Mon Sep 17 00:00:00 2001 From: Thomas Stuefe Date: Mon, 10 Aug 2020 15:42:20 +0200 Subject: [PATCH 43/53] 8251255: [linux] Add process-memory information to hs-err and VM.info Reviewed-by: dholmes, mdoerr --- src/hotspot/os/linux/os_linux.cpp | 67 ++++++++++++++++++++++++++++++- src/hotspot/os/linux/os_linux.hpp | 3 +- 2 files changed, 67 insertions(+), 3 deletions(-) diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index b08caf4d5d3..e410e7a82f9 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -110,6 +110,9 @@ # include # include # include +#ifdef __GLIBC__ +# include +#endif #ifndef _GNU_SOURCE #define _GNU_SOURCE @@ -2156,7 +2159,10 @@ void os::print_os_info(outputStream* st) { os::Posix::print_load_average(st); st->cr(); - os::Linux::print_full_memory_info(st); + os::Linux::print_system_memory_info(st); + st->cr(); + + os::Linux::print_process_memory_info(st); st->cr(); os::Linux::print_proc_sys_info(st); @@ -2314,7 +2320,7 @@ void os::Linux::print_proc_sys_info(outputStream* st) { "/proc/sys/kernel/pid_max", st); } -void os::Linux::print_full_memory_info(outputStream* st) { +void os::Linux::print_system_memory_info(outputStream* st) { _print_ascii_file_h("/proc/meminfo", "/proc/meminfo", st, false); st->cr(); @@ -2326,6 +2332,63 @@ void os::Linux::print_full_memory_info(outputStream* st) { "/sys/kernel/mm/transparent_hugepage/defrag", st); } +void os::Linux::print_process_memory_info(outputStream* st) { + + st->print_cr("Process Memory:"); + + // Print virtual and resident set size; peak values; swap; and for + // rss its components if the kernel is recent enough. + ssize_t vmsize = -1, vmpeak = -1, vmswap = -1, + vmrss = -1, vmhwm = -1, rssanon = -1, rssfile = -1, rssshmem = -1; + const int num_values = 8; + int num_found = 0; + FILE* f = ::fopen("/proc/self/status", "r"); + char buf[256]; + while (::fgets(buf, sizeof(buf), f) != NULL && num_found < num_values) { + if ( (vmsize == -1 && sscanf(buf, "VmSize: " SSIZE_FORMAT " kB", &vmsize) == 1) || + (vmpeak == -1 && sscanf(buf, "VmPeak: " SSIZE_FORMAT " kB", &vmpeak) == 1) || + (vmswap == -1 && sscanf(buf, "VmSwap: " SSIZE_FORMAT " kB", &vmswap) == 1) || + (vmhwm == -1 && sscanf(buf, "VmHWM: " SSIZE_FORMAT " kB", &vmhwm) == 1) || + (vmrss == -1 && sscanf(buf, "VmRSS: " SSIZE_FORMAT " kB", &vmrss) == 1) || + (rssanon == -1 && sscanf(buf, "RssAnon: " SSIZE_FORMAT " kB", &rssanon) == 1) || + (rssfile == -1 && sscanf(buf, "RssFile: " SSIZE_FORMAT " kB", &rssfile) == 1) || + (rssshmem == -1 && sscanf(buf, "RssShmem: " SSIZE_FORMAT " kB", &rssshmem) == 1) + ) + { + num_found ++; + } + } + st->print_cr("Virtual Size: " SSIZE_FORMAT "K (peak: " SSIZE_FORMAT "K)", vmsize, vmpeak); + st->print("Resident Set Size: " SSIZE_FORMAT "K (peak: " SSIZE_FORMAT "K)", vmrss, vmhwm); + if (rssanon != -1) { // requires kernel >= 4.5 + st->print(" (anon: " SSIZE_FORMAT "K, file: " SSIZE_FORMAT "K, shmem: " SSIZE_FORMAT "K)", + rssanon, rssfile, rssshmem); + } + st->cr(); + if (vmswap != -1) { // requires kernel >= 2.6.34 + st->print_cr("Swapped out: " SSIZE_FORMAT "K", vmswap); + } + + // Print glibc outstanding allocations. + // (note: there is no implementation of mallinfo for muslc) +#ifdef __GLIBC__ + struct mallinfo mi = ::mallinfo(); + + // mallinfo is an old API. Member names mean next to nothing and, beyond that, are int. + // So values may have wrapped around. Still useful enough to see how much glibc thinks + // we allocated. + const size_t total_allocated = (size_t)(unsigned)mi.uordblks; + st->print("C-Heap outstanding allocations: " SIZE_FORMAT "K", total_allocated / K); + // Since mallinfo members are int, glibc values may have wrapped. Warn about this. + if ((vmrss * K) > UINT_MAX && (vmrss * K) > (total_allocated + UINT_MAX)) { + st->print(" (may have wrapped)"); + } + st->cr(); + +#endif // __GLIBC__ + +} + bool os::Linux::print_ld_preload_file(outputStream* st) { return _print_ascii_file("/etc/ld.so.preload", st, "/etc/ld.so.preload:"); } diff --git a/src/hotspot/os/linux/os_linux.hpp b/src/hotspot/os/linux/os_linux.hpp index 754773a7d61..c242872945c 100644 --- a/src/hotspot/os/linux/os_linux.hpp +++ b/src/hotspot/os/linux/os_linux.hpp @@ -101,7 +101,8 @@ class Linux { static bool release_memory_special_shm(char* base, size_t bytes); static bool release_memory_special_huge_tlbfs(char* base, size_t bytes); - static void print_full_memory_info(outputStream* st); + static void print_process_memory_info(outputStream* st); + static void print_system_memory_info(outputStream* st); static bool print_container_info(outputStream* st); static void print_steal_info(outputStream* st); static void print_distro_info(outputStream* st); From b35a3bdee96206c042f909f6163b521122b26205 Mon Sep 17 00:00:00 2001 From: Kim Barrett Date: Mon, 10 Aug 2020 10:54:56 -0400 Subject: [PATCH 44/53] 8251322: Improve BitMap::iterate Rewrite and inline BitMap::iterate. Reviewed-by: stuefe, dholmes, tschatzl --- src/hotspot/share/utilities/bitMap.cpp | 26 ------------------- src/hotspot/share/utilities/bitMap.hpp | 20 +++++++------- src/hotspot/share/utilities/bitMap.inline.hpp | 17 +++++++++++- 3 files changed, 27 insertions(+), 36 deletions(-) diff --git a/src/hotspot/share/utilities/bitMap.cpp b/src/hotspot/share/utilities/bitMap.cpp index 8dcc1da6ddc..1d33a5fe580 100644 --- a/src/hotspot/share/utilities/bitMap.cpp +++ b/src/hotspot/share/utilities/bitMap.cpp @@ -627,32 +627,6 @@ void BitMap::clear_large() { clear_large_range_of_words(0, size_in_words()); } -// Note that if the closure itself modifies the bitmap -// then modifications in and to the left of the _bit_ being -// currently sampled will not be seen. Note also that the -// interval [leftOffset, rightOffset) is right open. -bool BitMap::iterate(BitMapClosure* blk, idx_t leftOffset, idx_t rightOffset) { - verify_range(leftOffset, rightOffset); - - idx_t startIndex = to_words_align_down(leftOffset); - idx_t endIndex = to_words_align_up(rightOffset); - for (idx_t index = startIndex, offset = leftOffset; - offset < rightOffset && index < endIndex; - offset = (++index) << LogBitsPerWord) { - idx_t rest = map(index) >> (offset & (BitsPerWord - 1)); - for (; offset < rightOffset && rest != 0; offset++) { - if (rest & 1) { - if (!blk->do_bit(offset)) return false; - // resample at each closure application - // (see, for instance, CMS bug 4525989) - rest = map(index) >> (offset & (BitsPerWord -1)); - } - rest = rest >> 1; - } - } - return true; -} - BitMap::idx_t BitMap::count_one_bits_in_range_of_words(idx_t beg_full_word, idx_t end_full_word) const { idx_t sum = 0; for (idx_t i = beg_full_word; i < end_full_word; i++) { diff --git a/src/hotspot/share/utilities/bitMap.hpp b/src/hotspot/share/utilities/bitMap.hpp index ffd0641f9ad..fb673cd0ae0 100644 --- a/src/hotspot/share/utilities/bitMap.hpp +++ b/src/hotspot/share/utilities/bitMap.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -284,14 +284,16 @@ class BitMap { void clear_large(); inline void clear(); - // Iteration support. Returns "true" if the iteration completed, false - // if the iteration terminated early (because the closure "blk" returned - // false). - bool iterate(BitMapClosure* blk, idx_t leftIndex, idx_t rightIndex); - bool iterate(BitMapClosure* blk) { - // call the version that takes an interval - return iterate(blk, 0, size()); - } + // Iteration support. Applies the closure to the index for each set bit, + // starting from the least index in the range to the greatest, in order. + // The iteration terminates if the closure returns false. Returns true if + // the iteration completed, false if terminated early because the closure + // returned false. If the closure modifies the bitmap, modifications to + // bits at indices greater than the current index will affect which further + // indices the closure will be applied to. + // precondition: beg and end form a valid range. + bool iterate(BitMapClosure* cl, idx_t beg, idx_t end); + bool iterate(BitMapClosure* cl); // Looking for 1's and 0's at indices equal to or greater than "l_index", // stopping if none has been found before "r_index", and returning diff --git a/src/hotspot/share/utilities/bitMap.inline.hpp b/src/hotspot/share/utilities/bitMap.inline.hpp index d8747dfbc5c..fa168d212e1 100644 --- a/src/hotspot/share/utilities/bitMap.inline.hpp +++ b/src/hotspot/share/utilities/bitMap.inline.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -242,6 +242,21 @@ BitMap::get_next_one_offset_aligned_right(idx_t l_offset, idx_t r_offset) const return get_next_bit_impl(l_offset, r_offset); } +inline bool BitMap::iterate(BitMapClosure* cl, idx_t beg, idx_t end) { + for (idx_t index = beg; true; ++index) { + index = get_next_one_offset(index, end); + if (index >= end) { + return true; + } else if (!cl->do_bit(index)) { + return false; + } + } +} + +inline bool BitMap::iterate(BitMapClosure* cl) { + return iterate(cl, 0, size()); +} + // Returns a bit mask for a range of bits [beg, end) within a single word. Each // bit in the mask is 0 if the bit is in the range, 1 if not in the range. The // returned mask can be used directly to clear the range, or inverted to set the From 8e687450d68ae56464fdde7e6712ad9fb5136792 Mon Sep 17 00:00:00 2001 From: Rahul Yadav Date: Mon, 10 Aug 2020 15:15:10 +0100 Subject: [PATCH 45/53] 8248006: Revisit exceptions thrown when creating an HttpClient fails due to unavailability of underlying resources This fix updates jdk.internal.net.http.HttpClientImpl to throw an UncheckedIOException instead of InternalError. Reviewed-by: chegar, dfuchs --- .../classes/java/net/http/HttpClient.java | 11 +- .../jdk/internal/net/http/HttpClientImpl.java | 2 +- .../httpclient/HttpClientExceptionTest.java | 105 ++++++++++++++++++ 3 files changed, 116 insertions(+), 2 deletions(-) create mode 100644 test/jdk/java/net/httpclient/HttpClientExceptionTest.java diff --git a/src/java.net.http/share/classes/java/net/http/HttpClient.java b/src/java.net.http/share/classes/java/net/http/HttpClient.java index 7a383f2fd16..a21ee7f12dc 100644 --- a/src/java.net.http/share/classes/java/net/http/HttpClient.java +++ b/src/java.net.http/share/classes/java/net/http/HttpClient.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -26,6 +26,8 @@ package java.net.http; import java.io.IOException; +import java.io.UncheckedIOException; +import java.nio.channels.Selector; import java.net.Authenticator; import java.net.CookieHandler; import java.net.InetSocketAddress; @@ -153,6 +155,8 @@ public abstract class HttpClient { * built instances. * * @return a new HttpClient + * @throws UncheckedIOException if necessary underlying IO resources required to + * {@linkplain Builder#build() build a new HttpClient} cannot be allocated. */ public static HttpClient newHttpClient() { return newBuilder().build(); @@ -352,6 +356,11 @@ public abstract class HttpClient { * builder. * * @return a new {@code HttpClient} + * + * @throws UncheckedIOException may be thrown if underlying IO resources required + * by the implementation cannot be allocated. For instance, + * if the implementation requires a {@link Selector}, and opening + * one fails due to {@linkplain Selector#open() lack of necessary resources}. */ public HttpClient build(); } diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/HttpClientImpl.java b/src/java.net.http/share/classes/jdk/internal/net/http/HttpClientImpl.java index bf3448cf2f8..1f7ed72cb7a 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/HttpClientImpl.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/HttpClientImpl.java @@ -310,7 +310,7 @@ final class HttpClientImpl extends HttpClient implements Trackable { selmgr = new SelectorManager(this); } catch (IOException e) { // unlikely - throw new InternalError(e); + throw new UncheckedIOException(e); } selmgr.setDaemon(true); filters = new FilterFactory(); diff --git a/test/jdk/java/net/httpclient/HttpClientExceptionTest.java b/test/jdk/java/net/httpclient/HttpClientExceptionTest.java new file mode 100644 index 00000000000..f9c585d955e --- /dev/null +++ b/test/jdk/java/net/httpclient/HttpClientExceptionTest.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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. + */ + +import org.testng.Assert; +import org.testng.annotations.Test; +import java.io.IOException; +import java.net.ProtocolFamily; +import java.net.http.HttpClient; +import java.nio.channels.DatagramChannel; +import java.nio.channels.Pipe; +import java.nio.channels.ServerSocketChannel; +import java.nio.channels.SocketChannel; +import java.nio.channels.Channel; +import java.nio.channels.spi.AbstractSelector; +import java.nio.channels.spi.SelectorProvider; + +/* + * @test + * @bug 8248006 + * @summary The test checks if UncheckedIOException is thrown + * @build HttpClientExceptionTest + * @run testng/othervm -Djava.nio.channels.spi.SelectorProvider=HttpClientExceptionTest$CustomSelectorProvider + * HttpClientExceptionTest + */ + +public class HttpClientExceptionTest { + + static final int ITERATIONS = 10; + + @Test + public void testHttpClientException() { + for(int i = 0; i < ITERATIONS; i++) { + Assert.assertThrows(HttpClient.newBuilder()::build); + Assert.assertThrows(HttpClient::newHttpClient); + } + } + + public static class CustomSelectorProvider extends SelectorProvider { + + @Override + public DatagramChannel openDatagramChannel() throws IOException { + throw new IOException(); + } + + @Override + public DatagramChannel openDatagramChannel(ProtocolFamily family) throws IOException { + throw new IOException(); + } + + @Override + public Pipe openPipe() throws IOException { + throw new IOException(); + } + + @Override + public ServerSocketChannel openServerSocketChannel() throws IOException { + throw new IOException(); + } + + @Override + public SocketChannel openSocketChannel() throws IOException { + throw new IOException(); + } + + @Override + public Channel inheritedChannel() throws IOException { + return super.inheritedChannel(); + } + + @Override + public SocketChannel openSocketChannel(ProtocolFamily family) throws IOException { + return super.openSocketChannel(family); + } + + @Override + public ServerSocketChannel openServerSocketChannel(ProtocolFamily family) throws IOException { + return super.openServerSocketChannel(family); + } + + @Override + public AbstractSelector openSelector() throws IOException { + throw new IOException(); + } + } +} From 55e381b32faab5794a9c797871f800950781571d Mon Sep 17 00:00:00 2001 From: "Tagir F. Valeev" Date: Mon, 10 Aug 2020 16:14:03 +0000 Subject: [PATCH 46/53] 8247605: Avoid array allocation when concatenating with empty string Reviewed-by: redestad, plevart --- .../share/classes/java/util/TreeMap.java | 36 ++ .../java/util/Map/InPlaceOpsCollisions.java | 3 +- .../util/Map/MapWithCollisionsProviders.java | 2 + test/jdk/java/util/NavigableMap/LockStep.java | 467 +++++++++--------- .../bench/java/util/TreeMapUpdate.java | 34 +- 5 files changed, 304 insertions(+), 238 deletions(-) diff --git a/src/java.base/share/classes/java/util/TreeMap.java b/src/java.base/share/classes/java/util/TreeMap.java index 5aa95bc6482..75119d714fe 100644 --- a/src/java.base/share/classes/java/util/TreeMap.java +++ b/src/java.base/share/classes/java/util/TreeMap.java @@ -1790,6 +1790,42 @@ public class TreeMap return m.put(key, value); } + public V putIfAbsent(K key, V value) { + if (!inRange(key)) + throw new IllegalArgumentException("key out of range"); + return m.putIfAbsent(key, value); + } + + public V merge(K key, V value, BiFunction remappingFunction) { + if (!inRange(key)) + throw new IllegalArgumentException("key out of range"); + return m.merge(key, value, remappingFunction); + } + + public V computeIfAbsent(K key, Function mappingFunction) { + if (!inRange(key)) { + // Do not throw if mapping function returns null + // to preserve compatibility with default computeIfAbsent implementation + if (mappingFunction.apply(key) == null) return null; + throw new IllegalArgumentException("key out of range"); + } + return m.computeIfAbsent(key, mappingFunction); + } + + public V compute(K key, BiFunction remappingFunction) { + if (!inRange(key)) { + // Do not throw if remapping function returns null + // to preserve compatibility with default computeIfAbsent implementation + if (remappingFunction.apply(key, null) == null) return null; + throw new IllegalArgumentException("key out of range"); + } + return m.compute(key, remappingFunction); + } + + public V computeIfPresent(K key, BiFunction remappingFunction) { + return !inRange(key) ? null : m.computeIfPresent(key, remappingFunction); + } + public final V get(Object key) { return !inRange(key) ? null : m.get(key); } diff --git a/test/jdk/java/util/Map/InPlaceOpsCollisions.java b/test/jdk/java/util/Map/InPlaceOpsCollisions.java index ce624990f16..fabc30ab7fb 100644 --- a/test/jdk/java/util/Map/InPlaceOpsCollisions.java +++ b/test/jdk/java/util/Map/InPlaceOpsCollisions.java @@ -523,7 +523,8 @@ public class InPlaceOpsCollisions extends MapWithCollisionsProviders { new Object[]{"HashMap", (Supplier>) HashMap::new}, new Object[]{"LinkedHashMap", (Supplier>) LinkedHashMap::new}, new Object[]{"TreeMap", (Supplier>) TreeMap::new}, - new Object[]{"TreeMap(cmp)", (Supplier>) () -> new TreeMap<>(Comparator.reverseOrder())} + new Object[]{"TreeMap(cmp)", (Supplier>) () -> new TreeMap<>(Comparator.reverseOrder())}, + new Object[]{"TreeMap.descendingMap", (Supplier>) () -> new TreeMap<>().descendingMap()} ).iterator(); } } diff --git a/test/jdk/java/util/Map/MapWithCollisionsProviders.java b/test/jdk/java/util/Map/MapWithCollisionsProviders.java index 3e687a21b6f..1cb1998ee5e 100644 --- a/test/jdk/java/util/Map/MapWithCollisionsProviders.java +++ b/test/jdk/java/util/Map/MapWithCollisionsProviders.java @@ -193,6 +193,8 @@ public class MapWithCollisionsProviders { new IdentityHashMap<>(), keys, val)); cases.add(createCase("TreeMap with " + desc, new TreeMap<>(), keys, val)); + cases.add(createCase("Descending TreeMap with " + desc, + new TreeMap<>().descendingMap(), keys, val)); cases.add(createCase("WeakHashMap with " + desc, new WeakHashMap<>(), keys, val)); cases.add(createCase("ConcurrentHashMap with " + desc, diff --git a/test/jdk/java/util/NavigableMap/LockStep.java b/test/jdk/java/util/NavigableMap/LockStep.java index 6823087fb59..26b3b1deda5 100644 --- a/test/jdk/java/util/NavigableMap/LockStep.java +++ b/test/jdk/java/util/NavigableMap/LockStep.java @@ -46,11 +46,11 @@ import java.util.Collections; import java.util.Comparator; import java.util.HashSet; import java.util.Iterator; -import java.util.List; import java.util.Map; import java.util.NavigableMap; import java.util.NavigableSet; import java.util.NoSuchElementException; +import java.util.Objects; import java.util.Random; import java.util.Set; import java.util.TreeMap; @@ -79,26 +79,26 @@ public class LockStep { static void realMain(String[] args) { size = intArg(args, 0, DEFAULT_SIZE); - lockSteps(new TreeMap(), - new ConcurrentSkipListMap()); - lockSteps(new TreeMap(), - Collections.checkedNavigableMap(new TreeMap(), Integer.class, Integer.class)); - lockSteps(new TreeMap(), - Collections.synchronizedNavigableMap(new TreeMap())); - lockSteps(new TreeMap(reverseOrder()), - new ConcurrentSkipListMap(reverseOrder())); + lockSteps(new TreeMap<>(), + new ConcurrentSkipListMap<>()); + lockSteps(new TreeMap<>(), + Collections.checkedNavigableMap(new TreeMap<>(), Integer.class, Integer.class)); + lockSteps(new TreeMap<>(), + Collections.synchronizedNavigableMap(new TreeMap<>())); + lockSteps(new TreeMap<>(reverseOrder()), + new ConcurrentSkipListMap<>(reverseOrder())); - lockSteps(new TreeSet(), - new ConcurrentSkipListSet()); - lockSteps(new TreeSet(), - Collections.checkedNavigableSet(new TreeSet(), Integer.class)); - lockSteps(new TreeSet(), - Collections.synchronizedNavigableSet(new TreeSet())); - lockSteps(new TreeSet(reverseOrder()), - new ConcurrentSkipListSet(reverseOrder())); + lockSteps(new TreeSet<>(), + new ConcurrentSkipListSet<>()); + lockSteps(new TreeSet<>(), + Collections.checkedNavigableSet(new TreeSet<>(), Integer.class)); + lockSteps(new TreeSet<>(), + Collections.synchronizedNavigableSet(new TreeSet<>())); + lockSteps(new TreeSet<>(reverseOrder()), + new ConcurrentSkipListSet<>(reverseOrder())); } - static void lockSteps(NavigableMap m1, NavigableMap m2) { + static void lockSteps(NavigableMap m1, NavigableMap m2) { if (maybe(4)) m1 = serialClone(m1); if (maybe(4)) m2 = serialClone(m2); lockStep(m1, @@ -119,7 +119,7 @@ public class LockStep { fullTailMap(m2.descendingMap())); } - static void lockSteps(NavigableSet s1, NavigableSet s2) { + static void lockSteps(NavigableSet s1, NavigableSet s2) { if (maybe(4)) s1 = serialClone(s1); if (maybe(4)) s2 = serialClone(s2); lockStep(s1, @@ -140,47 +140,47 @@ public class LockStep { fullTailSet(s2.descendingSet())); } - static boolean isAscending(NavigableMap m) { - Comparator cmp = m.comparator(); + static boolean isAscending(NavigableMap m) { + var cmp = m.comparator(); return (cmp == null || cmp.compare(1, 2) < 0); } - static NavigableMap fullSubMap(NavigableMap m) { + static NavigableMap fullSubMap(NavigableMap m) { return isAscending(m) ? m.subMap(Integer.MIN_VALUE, true, Integer.MAX_VALUE, true) : m.subMap(Integer.MAX_VALUE, true, Integer.MIN_VALUE, true); } - static NavigableMap fullHeadMap(NavigableMap m) { + static NavigableMap fullHeadMap(NavigableMap m) { return isAscending(m) ? m.headMap(Integer.MAX_VALUE, true) : m.headMap(Integer.MIN_VALUE, true); } - static NavigableMap fullTailMap(NavigableMap m) { + static NavigableMap fullTailMap(NavigableMap m) { return isAscending(m) ? m.tailMap(Integer.MIN_VALUE, true) : m.tailMap(Integer.MAX_VALUE, true); } - static boolean isAscending(NavigableSet s) { - Comparator cmp = s.comparator(); + static boolean isAscending(NavigableSet s) { + var cmp = s.comparator(); return (cmp == null || cmp.compare(1, 2) < 0); } - static NavigableSet fullSubSet(NavigableSet s) { + static NavigableSet fullSubSet(NavigableSet s) { return isAscending(s) ? s.subSet(Integer.MIN_VALUE, true, Integer.MAX_VALUE, true) : s.subSet(Integer.MAX_VALUE, true, Integer.MIN_VALUE, true); } - static NavigableSet fullHeadSet(NavigableSet s) { + static NavigableSet fullHeadSet(NavigableSet s) { return isAscending(s) ? s.headSet(Integer.MAX_VALUE, true) : s.headSet(Integer.MIN_VALUE, true); } - static NavigableSet fullTailSet(NavigableSet s) { + static NavigableSet fullTailSet(NavigableSet s) { return isAscending(s) ? s.tailSet(Integer.MIN_VALUE, true) : s.tailSet(Integer.MAX_VALUE, true); @@ -231,21 +231,17 @@ public class LockStep { equal(it.next(), expected); } - static Comparator comparator(NavigableSet s) { - Comparator cmp = s.comparator(); - return cmp != null ? cmp : new Comparator() { - public int compare(Object o1, Object o2) { - return ((Comparable) o1).compareTo(o2); }}; + static Comparator comparator(NavigableSet s) { + var cmp = s.comparator(); + return cmp != null ? cmp : Comparator.naturalOrder(); } - static Comparator comparator(NavigableMap m) { - Comparator cmp = m.comparator(); - return cmp != null ? cmp : new Comparator() { - public int compare(Object o1, Object o2) { - return ((Comparable) o1).compareTo(o2); }}; + static Comparator comparator(NavigableMap m) { + var cmp = m.comparator(); + return cmp != null ? cmp : Comparator.naturalOrder(); } - static void checkNavigableSet(final NavigableSet s) { + static void checkNavigableSet(final NavigableSet s) { if (s.comparator() == null) check(s.descendingSet().descendingSet().comparator() == null); equal(s.isEmpty(), s.size() == 0); @@ -259,7 +255,7 @@ public class LockStep { } } } - Comparator cmp = comparator(s); + var cmp = comparator(s); if (s.isEmpty()) { THROWS(NoSuchElementException.class, () -> s.first(), @@ -269,8 +265,8 @@ public class LockStep { equal(null, s.ceiling(1)); equal(null, s.higher(1)); } else { - Object a = s.first(); - Object z = s.last(); + Integer a = s.first(); + Integer z = s.last(); equal(s.lower(a), null); equal(s.higher(z), null); equal2(s, s.tailSet(a)); @@ -285,28 +281,27 @@ public class LockStep { equal2(s.headSet(a, true), singleton(a)); equal2(s.tailSet(z, true), singleton(z)); } - Iterator[] its = new Iterator[] { + Iterator[] its = new Iterator[] { s.iterator(), s.descendingSet().descendingSet().iterator(), }; - for (final Iterator it : its) + for (final Iterator it : its) if (maybe(4)) THROWS(IllegalStateException.class, () -> it.remove()); - Object prev = null; - for (Object e : s) { + Integer prev = null; + for (final Integer e : s) { check(s.contains(e)); - for (Iterator it : its) equalNext(it, e); + for (Iterator it : its) equalNext(it, e); equal(e, s.ceiling(e)); equal(e, s.floor(e)); check(s.higher(e) == null || cmp.compare(e, s.higher(e)) < 0); equal(s.lower(e), prev); - if (prev == null) { - } else { + if (prev != null) { check(cmp.compare(prev, e) < 0); } prev = e; } - for (final Iterator it : its) { + for (final Iterator it : its) { if (maybe(2)) check(! it.hasNext()); Fun fun = () -> it.next(); @@ -324,7 +319,7 @@ public class LockStep { check(! it2.hasNext()); } - static void equalSetsLeaf(final Set s1, final Set s2) { + static void equalSetsLeaf(final Set s1, final Set s2) { equal2(s1, s2); equal( s1.size(), s2.size()); equal( s1.isEmpty(), s2.isEmpty()); @@ -333,8 +328,8 @@ public class LockStep { equal( s1.containsAll(s2), s2.containsAll(s1)); } - static void equalNavigableSetsLeaf(final NavigableSet s1, - final NavigableSet s2) { + static void equalNavigableSetsLeaf(final NavigableSet s1, + final NavigableSet s2) { equal2(s1, s2); equal( s1.size(), s2.size()); equal( s1.isEmpty(), s2.isEmpty()); @@ -350,16 +345,16 @@ public class LockStep { checkNavigableSet(s2); } - static void equalNavigableSets(final NavigableSet s1, - final NavigableSet s2) { + static void equalNavigableSets(final NavigableSet s1, + final NavigableSet s2) { equalNavigableSetsLeaf(s1, s2); equalNavigableSetsLeaf(s1.descendingSet(), s2.descendingSet()); equalNavigableSetsLeaf(s1.descendingSet().descendingSet(), s2); - Object min = s1.isEmpty() ? Integer.MIN_VALUE : s1.first(); - Object max = s2.isEmpty() ? Integer.MAX_VALUE : s2.last(); + Integer min = s1.isEmpty() ? Integer.MIN_VALUE : s1.first(); + Integer max = s2.isEmpty() ? Integer.MAX_VALUE : s2.last(); if (s1.comparator() != null && s1.comparator().compare(min, max) > 0) { - Object tmp = min; min = max; max = tmp; + Integer tmp = min; min = max; max = tmp; } equalNavigableSetsLeaf(s1.subSet(min, true, max, true), @@ -368,31 +363,29 @@ public class LockStep { s2.tailSet(min, true)); equalNavigableSetsLeaf(s1.headSet(max, true), s2.headSet(max, true)); - equalNavigableSetsLeaf((NavigableSet) s1.subSet(min, max), - (NavigableSet) s2.subSet(min, max)); - equalNavigableSetsLeaf((NavigableSet) s1.tailSet(min), - (NavigableSet) s2.tailSet(min)); - equalNavigableSetsLeaf((NavigableSet) s1.headSet(max), - (NavigableSet) s2.headSet(max)); + equalNavigableSetsLeaf((NavigableSet) s1.subSet(min, max), + (NavigableSet) s2.subSet(min, max)); + equalNavigableSetsLeaf((NavigableSet) s1.tailSet(min), + (NavigableSet) s2.tailSet(min)); + equalNavigableSetsLeaf((NavigableSet) s1.headSet(max), + (NavigableSet) s2.headSet(max)); } // Destined for a Collections.java near you? static T[] concat(T[]... arrays) { int len = 0; - for (int i = 0; i < arrays.length; i++) - len += arrays[i].length; + for (T[] arr : arrays) len += arr.length; T[] a = (T[])java.lang.reflect.Array .newInstance(arrays[0].getClass().getComponentType(), len); int k = 0; - for (int i = 0; i < arrays.length; i++) { - T[] array = arrays[i]; - System.arraycopy(array, 0, a, k, array.length); - k += array.length; + for (T[] arr : arrays) { + System.arraycopy(arr, 0, a, k, arr.length); + k += arr.length; } return a; } - static void checkNavigableMap(final NavigableMap m) { + static void checkNavigableMap(final NavigableMap m) { if (m.comparator() == null) { check(m.descendingMap().descendingMap().comparator() == null); check(m.descendingKeySet().descendingSet().comparator() == null); @@ -402,7 +395,7 @@ public class LockStep { if (maybe(4)) equal2(m, serialClone(m)); equal2(m.keySet(), m.descendingKeySet()); - Comparator cmp = comparator(m); + var cmp = comparator(m); if (m.isEmpty()) { THROWS(NoSuchElementException.class, () -> m.firstKey(), @@ -420,8 +413,8 @@ public class LockStep { equal(null, m.ceilingEntry(1)); equal(null, m.higherEntry(1)); } else { - Object a = m.firstKey(); - Object z = m.lastKey(); + Integer a = m.firstKey(); + Integer z = m.lastKey(); equal(m.lowerKey(a), null); equal(m.higherKey(z), null); equal(a, m.firstEntry().getKey()); @@ -439,32 +432,32 @@ public class LockStep { equal2(m.tailMap(z, true), singletonMap(z, m.get(z))); } - Iterator[] kits = new Iterator[] { + Iterator[] kits = new Iterator[] { m.keySet().iterator(), m.descendingMap().descendingKeySet().iterator(), m.descendingKeySet().descendingSet().iterator(), }; - Iterator[] vits = new Iterator[] { + Iterator[] vits = new Iterator[] { m.values().iterator(), m.descendingMap().descendingMap().values().iterator(), }; - Iterator[] eits = new Iterator[] { + Iterator[] eits = new Iterator[] { m.entrySet().iterator(), m.descendingMap().descendingMap().entrySet().iterator(), }; - Iterator[] its = concat(kits, vits, eits); - for (final Iterator it : its) + Iterator[] its = concat(kits, vits, eits); + for (final Iterator it : its) if (maybe(4)) THROWS(IllegalStateException.class, () -> it.remove()); - Map.Entry prev = null; - for (Map.Entry e : (Set) m.entrySet()) { - Object k = e.getKey(); - Object v = e.getValue(); + Map.Entry prev = null; + for (var e : m.entrySet()) { + Integer k = e.getKey(); + Integer v = e.getValue(); check(m.containsKey(k)); check(m.containsValue(v)); - for (Iterator kit : kits) equalNext(kit, k); - for (Iterator vit : vits) equalNext(vit, v); - for (Iterator eit : eits) equalNext(eit, e); + for (var kit : kits) equalNext(kit, k); + for (var vit : vits) equalNext(vit, v); + for (var eit : eits) equalNext(eit, e); equal(k, m.ceilingKey(k)); equal(k, m.ceilingEntry(k).getKey()); equal(k, m.floorKey(k)); @@ -480,7 +473,7 @@ public class LockStep { } prev = e; } - for (final Iterator it : its) { + for (final var it : its) { if (maybe(2)) check(! it.hasNext()); Fun fun = () -> it.next(); @@ -488,8 +481,8 @@ public class LockStep { } } - static void equalNavigableMapsLeaf(final NavigableMap m1, - final NavigableMap m2) { + static void equalNavigableMapsLeaf(final NavigableMap m1, + final NavigableMap m2) { equal2(m1, m2); equal( m1.size(), m2.size()); equal( m1.isEmpty(), m2.isEmpty()); @@ -501,8 +494,8 @@ public class LockStep { checkNavigableMap(m2); } - static void equalNavigableMaps(NavigableMap m1, - NavigableMap m2) { + static void equalNavigableMaps(NavigableMap m1, + NavigableMap m2) { equalNavigableMapsLeaf(m1, m2); equalSetsLeaf(m1.keySet(), m2.keySet()); equalNavigableSets(m1.navigableKeySet(), @@ -515,8 +508,8 @@ public class LockStep { m2.descendingMap()); equalNavigableMapsLeaf(m1.descendingMap().descendingMap(), m2); - equalNavigableSetsLeaf((NavigableSet) m1.descendingMap().keySet(), - (NavigableSet) m2.descendingMap().keySet()); + equalNavigableSetsLeaf((NavigableSet) m1.descendingMap().keySet(), + (NavigableSet) m2.descendingMap().keySet()); equalNavigableSetsLeaf(m1.descendingMap().descendingKeySet(), m2.descendingMap().descendingKeySet()); equal2(m1.descendingMap().entrySet(), @@ -525,11 +518,11 @@ public class LockStep { //---------------------------------------------------------------- // submaps //---------------------------------------------------------------- - Object min = Integer.MIN_VALUE; - Object max = Integer.MAX_VALUE; + Integer min = Integer.MIN_VALUE; + Integer max = Integer.MAX_VALUE; if (m1.comparator() != null && m1.comparator().compare(min, max) > 0) { - Object tmp = min; min = max; max = tmp; + Integer tmp = min; min = max; max = tmp; } switch (rnd.nextInt(6)) { case 0: @@ -545,107 +538,119 @@ public class LockStep { m2.headMap(max, true)); break; case 3: - equalNavigableMapsLeaf((NavigableMap) m1.subMap(min, max), - (NavigableMap) m2.subMap(min, max)); + equalNavigableMapsLeaf((NavigableMap) m1.subMap(min, max), + (NavigableMap) m2.subMap(min, max)); break; case 4: - equalNavigableMapsLeaf((NavigableMap) m1.tailMap(min), - (NavigableMap) m2.tailMap(min)); + equalNavigableMapsLeaf((NavigableMap) m1.tailMap(min), + (NavigableMap) m2.tailMap(min)); break; case 5: - equalNavigableMapsLeaf((NavigableMap) m1.headMap(max), - (NavigableMap) m2.headMap(max)); + equalNavigableMapsLeaf((NavigableMap) m1.headMap(max), + (NavigableMap) m2.headMap(max)); break; } } - abstract static class MapFrobber { abstract void frob(NavigableMap m); } - abstract static class SetFrobber { abstract void frob(NavigableSet m); } + interface MapFrobber { void frob(NavigableMap m); } + interface SetFrobber { void frob(NavigableSet m); } - static MapFrobber randomAdder(NavigableMap m) { + static MapFrobber randomAdder(NavigableMap m) { final Integer k = unusedKey(m); final MapFrobber[] randomAdders = { - new MapFrobber() {void frob(NavigableMap m) { - equal(m.put(k, k+1), null); - equal(m.get(k), k+1); + map -> { + equal(map.put(k, k + 1), null); + equal(map.get(k), k + 1); if (maybe(4)) { - equal(m.put(k, k+1), k+1); - equal(m.get(k), k+1);}}}, - new MapFrobber() {void frob(NavigableMap m) { - m.descendingMap().put(k, k+1); - equal(m.get(k), k+1);}}, - new MapFrobber() {void frob(NavigableMap m) { - m.tailMap(k,true).headMap(k,true).put(k,k+1);}}, - new MapFrobber() {void frob(NavigableMap m) { - m.tailMap(k,true).headMap(k,true).descendingMap().put(k,k+1);}} + equal(map.put(k, k + 1), k + 1); + equal(map.get(k), k + 1);}}, + map -> { + map.descendingMap().put(k, k + 1); + equal(map.get(k), k + 1);}, + map -> map.tailMap(k,true).headMap(k,true).put(k, k + 1), + map -> { + equal(map.tailMap(k,true).headMap(k,true).putIfAbsent(k, k + 1), null); + equal(map.tailMap(k,true).headMap(k,true).putIfAbsent(k, k + 1), k + 1);}, + map -> { + equal(map.tailMap(k,true).headMap(k,true).merge(k,k,Integer::sum), k); + equal(map.tailMap(k,true).headMap(k,true).merge(k,1,Integer::sum), k+1);}, + map -> equal(map.subMap(k,true, k, true).computeIfAbsent(k, key -> key + 1), k + 1), + map -> { + equal(map.subMap(k,true, k, true).computeIfPresent(k, (key, val) -> 1), null); + equal(map.tailMap(k,true).compute(k, (key, val) -> { + equal(val, null); + return 1; + }), 1); + equal(map.headMap(k, true).computeIfPresent(k, (key, val) -> val + key), k + 1); + equal(map.tailMap(k, false).computeIfPresent(k, (key, val) -> 1), null); + equal(map.headMap(k, false).compute(k, (key, val) -> null), null); + equal(map.tailMap(k, false).computeIfAbsent(k, key -> null), null); + }, + map -> map.tailMap(k,true).headMap(k,true).descendingMap().put(k, k + 1) }; - return new MapFrobber() {void frob(NavigableMap m) { - randomAdders[rnd.nextInt(randomAdders.length)].frob(m); - if (maybe(2)) equal(m.get(k), k+1); + return map -> { + randomAdders[rnd.nextInt(randomAdders.length)].frob(map); + if (maybe(2)) equal(map.get(k), k + 1); if (maybe(4)) { - equal(m.put(k, k+1), k+1); - equal(m.get(k), k+1);}}}; + equal(map.put(k, k + 1), k + 1); + equal(map.get(k), k + 1);}}; } - static SetFrobber randomAdder(NavigableSet s) { + static SetFrobber randomAdder(NavigableSet s) { final Integer e = unusedElt(s); final SetFrobber[] randomAdders = { - new SetFrobber() {void frob(NavigableSet s) { - check(s.add(e));}}, - new SetFrobber() {void frob(NavigableSet s) { - s.descendingSet().add(e);}}, - new SetFrobber() {void frob(NavigableSet s) { - s.tailSet(e,true).headSet(e,true).add(e);}}, - new SetFrobber() {void frob(NavigableSet s) { - s.descendingSet().tailSet(e,true).headSet(e,true).add(e);}} + set -> check(set.add(e)), + set -> set.descendingSet().add(e), + set -> set.tailSet(e,true).headSet(e,true).add(e), + set -> set.descendingSet().tailSet(e,true).headSet(e,true).add(e) }; - return new SetFrobber() {void frob(NavigableSet s) { - if (maybe(2)) check(! s.contains(e)); - randomAdders[rnd.nextInt(randomAdders.length)].frob(s); - if (maybe(2)) check(! s.add(e)); - if (maybe(2)) check(s.contains(e));}}; + return set -> { + if (maybe(2)) check(! set.contains(e)); + randomAdders[rnd.nextInt(randomAdders.length)].frob(set); + if (maybe(2)) check(! set.add(e)); + if (maybe(2)) check(set.contains(e));}; } - static Integer unusedElt(NavigableSet s) { + static Integer unusedElt(NavigableSet s) { Integer e; do { e = rnd.nextInt(1024); } while (s.contains(e)); return e; } - static Integer unusedKey(NavigableMap m) { + static Integer unusedKey(NavigableMap m) { Integer k; do { k = rnd.nextInt(1024); } while (m.containsKey(k)); return k; } - static Integer usedKey(NavigableMap m) { + static Integer usedKey(NavigableMap m) { Integer x = rnd.nextInt(1024); - Integer floor = (Integer) m.floorKey(x); - Integer ceiling = (Integer) m.ceilingKey(x); + Integer floor = m.floorKey(x); + Integer ceiling = m.ceilingKey(x); if (floor != null) return floor; check(ceiling != null); return ceiling; } - static Integer usedElt(NavigableSet s) { + static Integer usedElt(NavigableSet s) { Integer x = rnd.nextInt(1024); - Integer floor = (Integer) s.floor(x); - Integer ceiling = (Integer) s.ceiling(x); + Integer floor = s.floor(x); + Integer ceiling = s.ceiling(x); if (floor != null) return floor; check(ceiling != null); return ceiling; } - static void checkUnusedKey(NavigableMap m, Object k) { + static void checkUnusedKey(NavigableMap m, Integer k) { check(! m.containsKey(k)); equal(m.get(k), null); if (maybe(2)) equal(m.remove(k), null); } - static void checkUnusedElt(NavigableSet s, Object e) { + static void checkUnusedElt(NavigableSet s, Integer e) { if (maybe(2)) check(! s.contains(e)); if (maybe(2)) { @@ -656,32 +661,32 @@ public class LockStep { check(! s.remove(e)); } - static Fun remover(final Iterator it) { + static Fun remover(final Iterator it) { return () -> it.remove(); } - static MapFrobber randomRemover(NavigableMap m) { + static MapFrobber randomRemover(NavigableMap m) { final Integer k = usedKey(m); final MapFrobber[] randomRemovers = { - new MapFrobber() {void frob(NavigableMap m) { - Map.Entry e = m.firstEntry(); - equal(m.pollFirstEntry(), e); - checkUnusedKey(m, e.getKey());}}, - new MapFrobber() {void frob(NavigableMap m) { - Map.Entry e = m.lastEntry(); - equal(m.pollLastEntry(), e); - checkUnusedKey(m, e.getKey());}}, - new MapFrobber() {void frob(NavigableMap m) { - check(m.remove(k) != null); - checkUnusedKey(m, k);}}, - new MapFrobber() {void frob(NavigableMap m) { - m.subMap(k, true, k, true).clear(); - checkUnusedKey(m, k);}}, - new MapFrobber() {void frob(NavigableMap m) { - m.descendingMap().subMap(k, true, k, true).clear(); - checkUnusedKey(m, k);}}, - new MapFrobber() {void frob(NavigableMap m) { - final Iterator it = m.keySet().iterator(); + map -> { + var e = map.firstEntry(); + equal(map.pollFirstEntry(), e); + checkUnusedKey(map, e.getKey());}, + map -> { + var e = map.lastEntry(); + equal(map.pollLastEntry(), e); + checkUnusedKey(map, e.getKey());}, + map -> { + check(map.remove(k) != null); + checkUnusedKey(map, k);}, + map -> { + map.subMap(k, true, k, true).clear(); + checkUnusedKey(map, k);}, + map -> { + map.descendingMap().subMap(k, true, k, true).clear(); + checkUnusedKey(map, k);}, + map -> { + final var it = map.keySet().iterator(); while (it.hasNext()) if (it.next().equals(k)) { it.remove(); @@ -689,9 +694,9 @@ public class LockStep { THROWS(IllegalStateException.class, () -> it.remove()); } - checkUnusedKey(m, k);}}, - new MapFrobber() {void frob(NavigableMap m) { - final Iterator it = m.navigableKeySet().descendingIterator(); + checkUnusedKey(map, k);}, + map -> { + final var it = map.navigableKeySet().descendingIterator(); while (it.hasNext()) if (it.next().equals(k)) { it.remove(); @@ -699,44 +704,44 @@ public class LockStep { THROWS(IllegalStateException.class, () -> it.remove()); } - checkUnusedKey(m, k);}}, - new MapFrobber() {void frob(NavigableMap m) { - final Iterator it = m.entrySet().iterator(); + checkUnusedKey(map, k);}, + map -> { + final var it = map.entrySet().iterator(); while (it.hasNext()) if (it.next().getKey().equals(k)) { it.remove(); if (maybe(2)) THROWS(IllegalStateException.class, remover(it)); } - checkUnusedKey(m, k);}}, + checkUnusedKey(map, k);}, }; return randomRemovers[rnd.nextInt(randomRemovers.length)]; } - static SetFrobber randomRemover(NavigableSet s) { + static SetFrobber randomRemover(NavigableSet s) { final Integer e = usedElt(s); final SetFrobber[] randomRemovers = { - new SetFrobber() {void frob(NavigableSet s) { - Object e = s.first(); - equal(s.pollFirst(), e); - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - Object e = s.last(); - equal(s.pollLast(), e); - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - check(s.remove(e)); - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - s.subSet(e, true, e, true).clear(); - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - s.descendingSet().subSet(e, true, e, true).clear(); - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - final Iterator it = s.iterator(); + set -> { + var fst = set.first(); + equal(set.pollFirst(), fst); + checkUnusedElt(set, fst);}, + set -> { + var lst = set.last(); + equal(set.pollLast(), lst); + checkUnusedElt(set, lst);}, + set -> { + check(set.remove(e)); + checkUnusedElt(set, e);}, + set -> { + set.subSet(e, true, e, true).clear(); + checkUnusedElt(set, e);}, + set -> { + set.descendingSet().subSet(e, true, e, true).clear(); + checkUnusedElt(set, e);}, + set -> { + final var it = set.iterator(); while (it.hasNext()) if (it.next().equals(e)) { it.remove(); @@ -744,9 +749,9 @@ public class LockStep { THROWS(IllegalStateException.class, () -> it.remove()); } - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - final Iterator it = s.descendingSet().iterator(); + checkUnusedElt(set, e);}, + set -> { + final var it = set.descendingSet().iterator(); while (it.hasNext()) if (it.next().equals(e)) { it.remove(); @@ -754,9 +759,9 @@ public class LockStep { THROWS(IllegalStateException.class, () -> it.remove()); } - checkUnusedElt(s, e);}}, - new SetFrobber() {void frob(NavigableSet s) { - final Iterator it = s.descendingIterator(); + checkUnusedElt(set, e);}, + set -> { + final var it = set.descendingIterator(); while (it.hasNext()) if (it.next().equals(e)) { it.remove(); @@ -764,94 +769,96 @@ public class LockStep { THROWS(IllegalStateException.class, () -> it.remove()); } - checkUnusedElt(s, e);}} + checkUnusedElt(set, e);} }; return randomRemovers[rnd.nextInt(randomRemovers.length)]; } - static void lockStep(NavigableMap m1, - NavigableMap m2) { + static void lockStep(NavigableMap m1, + NavigableMap m2) { if (! (thorough || maybe(3))) return; if (maybe(4)) m1 = serialClone(m1); if (maybe(4)) m2 = serialClone(m2); - List maps = Arrays.asList(m1, m2); - for (NavigableMap m : maps) testEmptyMap(m); + var maps = Arrays.asList(m1, m2); + for (var m : maps) testEmptyMap(m); final Set ints = new HashSet<>(); while (ints.size() < size) ints.add(rnd.nextInt(1024)); final Integer[] elts = ints.toArray(new Integer[size]); + equal(elts.length, size); for (int i = 0; i < size; i++) { MapFrobber adder = randomAdder(m1); - for (final NavigableMap m : maps) { + for (var m : maps) { adder.frob(m); equal(m.size(), i+1); } equalNavigableMaps(m1, m2); } - for (final NavigableMap m : maps) { - final Object e = usedKey(m); + for (var m : maps) { + final var e = usedKey(m); THROWS(IllegalArgumentException.class, - () -> {m.subMap(e,true,e,false) - .subMap(e,true,e,true);}, - () -> {m.subMap(e,false,e,true) - .subMap(e,true,e,true);}, + () -> m.subMap(e,true,e,false).subMap(e,true,e,true), + () -> m.subMap(e,false,e,true).subMap(e,true,e,true), () -> m.tailMap(e,false).tailMap(e,true), - () -> m.headMap(e,false).headMap(e,true)); + () -> m.headMap(e,false).headMap(e,true), + () -> m.headMap(e, false).put(e, 0), + () -> m.tailMap(e, false).putIfAbsent(e, 0), + () -> m.headMap(e, false).computeIfAbsent(e, k -> 1), + () -> m.tailMap(e, false).compute(e, (k, v) -> 0)); } //System.out.printf("%s%n", m1); for (int i = size; i > 0; i--) { MapFrobber remover = randomRemover(m1); - for (final NavigableMap m : maps) { + for (var m : maps) { remover.frob(m); equal(m.size(), i-1); } equalNavigableMaps(m1, m2); } - for (NavigableMap m : maps) testEmptyMap(m); + for (var m : maps) testEmptyMap(m); } - static void lockStep(NavigableSet s1, - NavigableSet s2) { + static void lockStep(NavigableSet s1, + NavigableSet s2) { if (! (thorough || maybe(3))) return; if (maybe(4)) s1 = serialClone(s1); if (maybe(4)) s2 = serialClone(s2); - List sets = Arrays.asList(s1, s2); - for (NavigableSet s : sets) testEmptySet(s); + var sets = Arrays.asList(s1, s2); + for (var s : sets) testEmptySet(s); final Set ints = new HashSet<>(); while (ints.size() < size) ints.add(rnd.nextInt(1024)); final Integer[] elts = ints.toArray(new Integer[size]); + equal(elts.length, size); for (int i = 0; i < size; i++) { SetFrobber adder = randomAdder(s1); - for (final NavigableSet s : sets) { + for (var s : sets) { adder.frob(s); equal(s.size(), i+1); } equalNavigableSets(s1, s2); } - for (final NavigableSet s : sets) { - final Object e = usedElt(s); + for (var s : sets) { + final Integer e = usedElt(s); THROWS(IllegalArgumentException.class, - () -> {s.subSet(e,true,e,false) - .subSet(e,true,e,true);}, - () -> {s.subSet(e,false,e,true) - .subSet(e,true,e,true);}, + () -> s.subSet(e,true,e,false).subSet(e,true,e,true), + () -> s.subSet(e,false,e,true).subSet(e,true,e,true), () -> s.tailSet(e,false).tailSet(e,true), () -> s.headSet(e,false).headSet(e,true)); } //System.out.printf("%s%n", s1); for (int i = size; i > 0; i--) { SetFrobber remover = randomRemover(s1); - for (final NavigableSet s : sets) { + for (var s : sets) { remover.frob(s); equal(s.size(), i-1); } equalNavigableSets(s1, s2); } - for (NavigableSet s : sets) testEmptySet(s); + for (var s : sets) testEmptySet(s); } //--------------------- Infrastructure --------------------------- @@ -862,7 +869,7 @@ public class LockStep { static void unexpected(Throwable t) { failed++; t.printStackTrace(); } static void check(boolean cond) { if (cond) pass(); else fail(); } static void equal(Object x, Object y) { - if (x == null ? y == null : x.equals(y)) pass(); + if (Objects.equals(x, y)) pass(); else {System.out.println(x + " not equal to " + y); fail();}} static void equal2(Object x, Object y) {equal(x, y); equal(y, x);} public static void main(String[] args) throws Throwable { diff --git a/test/micro/org/openjdk/bench/java/util/TreeMapUpdate.java b/test/micro/org/openjdk/bench/java/util/TreeMapUpdate.java index d43a070cc40..2a5a9cf0bed 100644 --- a/test/micro/org/openjdk/bench/java/util/TreeMapUpdate.java +++ b/test/micro/org/openjdk/bench/java/util/TreeMapUpdate.java @@ -39,11 +39,13 @@ import java.util.Arrays; import java.util.Collections; import java.util.Comparator; import java.util.Map; +import java.util.NavigableMap; import java.util.Random; import java.util.TreeMap; import java.util.concurrent.TimeUnit; import java.util.function.Function; import java.util.function.Supplier; +import java.util.function.UnaryOperator; import java.util.stream.Collectors; import java.util.stream.IntStream; @@ -54,6 +56,9 @@ import java.util.stream.IntStream; @Fork(3) @State(Scope.Thread) public class TreeMapUpdate { + @Param({"TreeMap", "descendingMap", "tailMap"}) + public String mode; + @Param({"10", "1000", "100000"}) public int size; @@ -68,10 +73,25 @@ public class TreeMapUpdate { private Supplier> supplier; + private UnaryOperator> transformer; + private Integer[] keys; @Setup public void setUp() { + switch(mode) { + case "TreeMap": + transformer = map -> map; + break; + case "descendingMap": + transformer = map -> map.descendingMap(); + break; + case "tailMap": + transformer = map -> map.tailMap(0, true); + break; + default: + throw new IllegalStateException(mode); + } supplier = comparator ? () -> new TreeMap<>(Comparator.reverseOrder()) : TreeMap::new; keys = IntStream.range(0, size).boxed().toArray(Integer[]::new); Random rnd = seed == 0 ? new Random() : new Random(seed); @@ -86,12 +106,12 @@ public class TreeMapUpdate { @Benchmark public Map baseline() { // Just create map (empty or pre-filled) - return supplier.get(); + return transformer.apply(supplier.get()); } @Benchmark public Map put(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.put(key, key)); @@ -101,7 +121,7 @@ public class TreeMapUpdate { @Benchmark public Map putIfAbsent(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.putIfAbsent(key, key)); @@ -111,7 +131,7 @@ public class TreeMapUpdate { @Benchmark public Map computeIfAbsent(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.computeIfAbsent(key, k -> k)); @@ -121,7 +141,7 @@ public class TreeMapUpdate { @Benchmark public Map compute(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.compute(key, (k, old) -> k)); @@ -131,7 +151,7 @@ public class TreeMapUpdate { @Benchmark public Map computeIfPresent(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.computeIfPresent(key, (k, old) -> k)); @@ -141,7 +161,7 @@ public class TreeMapUpdate { @Benchmark public Map merge(Blackhole bh) { - Map map = supplier.get(); + Map map = transformer.apply(supplier.get()); Integer[] keys = this.keys; for (Integer key : keys) { bh.consume(map.merge(key, key, (k1, k2) -> k1)); From db1e207a72061e926679499adbd0bd2be88d4e85 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Mon, 10 Aug 2020 09:54:34 -0700 Subject: [PATCH 47/53] 8249703: test/jdk/java/io/File/GetXSpace.java fails on macos Reviewed-by: naoto --- test/jdk/ProblemList.txt | 1 - test/jdk/java/io/File/GetXSpace.java | 35 +++++++++++++++++++++++----- 2 files changed, 29 insertions(+), 7 deletions(-) diff --git a/test/jdk/ProblemList.txt b/test/jdk/ProblemList.txt index cc99f6146b2..30cb4a651db 100644 --- a/test/jdk/ProblemList.txt +++ b/test/jdk/ProblemList.txt @@ -590,7 +590,6 @@ javax/management/monitor/DerivedGaugeMonitorTest.java 8042211 generic-al # jdk_io java/io/pathNames/GeneralWin32.java 8180264 windows-all -java/io/File/GetXSpace.java 8249703 macosx-all ############################################################################ diff --git a/test/jdk/java/io/File/GetXSpace.java b/test/jdk/java/io/File/GetXSpace.java index 6cd31ab12dc..3ca1558ffe6 100644 --- a/test/jdk/java/io/File/GetXSpace.java +++ b/test/jdk/java/io/File/GetXSpace.java @@ -35,6 +35,8 @@ import java.io.File; import java.io.FilePermission; import java.io.InputStreamReader; import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.FileStore; import java.security.Permission; import java.util.ArrayList; import java.util.regex.Matcher; @@ -47,9 +49,12 @@ public class GetXSpace { private static SecurityManager [] sma = { null, new Allow(), new DenyFSA(), new DenyRead() }; - private static final String osName = System.getProperty("os.name"); + private static final String OS_NAME = System.getProperty("os.name"); + private static final boolean IS_MAC = OS_NAME.startsWith("Mac"); + private static final boolean IS_WIN = OS_NAME.startsWith("Windows"); + // FileSystem Total Used Available Use% MountedOn - private static final Pattern dfPattern = Pattern.compile("([^\\s]+)\\s+(\\d+)\\s+\\d+\\s+(\\d+)\\s+\\d+%\\s+([^\\s].*)\n"); + private static final Pattern DF_PATTERN = Pattern.compile("([^\\s]+)\\s+(\\d+)\\s+\\d+\\s+(\\d+)\\s+\\d+%\\s+([^\\s].*)\n"); private static int fail = 0; private static int pass = 0; @@ -129,7 +134,7 @@ public class GetXSpace { } out.println(sb); - Matcher m = dfPattern.matcher(sb); + Matcher m = DF_PATTERN.matcher(sb); int j = 0; while (j < sb.length()) { if (m.find(j)) { @@ -138,7 +143,7 @@ public class GetXSpace { String name = f; if (name == null) { // cygwin's df lists windows path as FileSystem (1st group) - name = osName.startsWith("Windows") ? m.group(1) : m.group(4); + name = IS_WIN ? m.group(1) : m.group(4); } al.add(new Space(m.group(2), m.group(3), name));; } @@ -201,13 +206,31 @@ public class GetXSpace { // if the file system can dynamically change size, this check will fail if (ts != s.total()) { - fail(s.name(), s.total(), "!=", ts); + long blockSize = 1; + long numBlocks = 0; + try { + FileStore fileStore = Files.getFileStore(f.toPath()); + blockSize = fileStore.getBlockSize(); + numBlocks = fileStore.getTotalSpace()/blockSize; + } catch (IOException e) { + throw new RuntimeException(e); + } + + + // On macOS, the number of 1024 byte blocks might be incorrectly + // calculated by 'df' using integer division by 2 of the number of + // 512 byte blocks, resulting in a size smaller than the actual + // value when the number of blocks is odd. + if (!IS_MAC || blockSize != 512 || numBlocks % 2 == 0 + || ts - s.total() != 512) { + fail(s.name(), s.total(), "!=", ts); + } } else { pass(); } // unix df returns statvfs.f_bavail - long tsp = (!osName.startsWith("Windows") ? us : fs); + long tsp = (!IS_WIN ? us : fs); if (!s.woomFree(tsp)) { fail(s.name(), s.free(), "??", tsp); } else { From b5f785ba9bcd9969d153f60d7bbe193778ed3c10 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Mon, 10 Aug 2020 17:16:56 +0000 Subject: [PATCH 48/53] 8246816: XMLGregorianCalendar.hashCode() produces far too many identical hashes Reviewed-by: naoto, rriggs --- .../datatype/XMLGregorianCalendarImpl.java | 47 +---------- .../xml/datatype/XMLGregorianCalendar.java | 17 ++-- .../jaxp/unittest/datatype/HashCodeTest.java | 80 +++++++++++++++++++ 3 files changed, 91 insertions(+), 53 deletions(-) create mode 100644 test/jaxp/javax/xml/jaxp/unittest/datatype/HashCodeTest.java diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/jaxp/datatype/XMLGregorianCalendarImpl.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/jaxp/datatype/XMLGregorianCalendarImpl.java index 68e44a142b6..46582fefd1b 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/jaxp/datatype/XMLGregorianCalendarImpl.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/jaxp/datatype/XMLGregorianCalendarImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -190,7 +190,7 @@ import jdk.xml.internal.SecuritySupport; * @author Sunitha Reddy * @see javax.xml.datatype.Duration * @since 1.5 - * @LastModified: June 2018 + * @LastModified: Aug 2020 */ public class XMLGregorianCalendarImpl @@ -1682,49 +1682,6 @@ public class XMLGregorianCalendarImpl return Pfield.compareTo(Qfield); } - /** - *

    Indicates whether parameter obj is "equal to" this one.

    - * - * @param obj to compare. - * - * @return true when compare(this,(XMLGregorianCalendar)obj) == EQUAL.. - */ - public boolean equals(Object obj) { - - if (obj == null || !(obj instanceof XMLGregorianCalendar)) { - return false; - } - if (obj == this) { - return true; - } - return compare((XMLGregorianCalendar) obj) == DatatypeConstants.EQUAL; - } - - /** - *

    Returns a hash code consistent with the definition of the equals method.

    - * - * @return hash code of this object. - */ - public int hashCode() { - - // Following two dates compare to EQUALS since in different timezones. - // 2000-01-15T12:00:00-05:00 == 2000-01-15T13:00:00-04:00 - // - // Must ensure both instances generate same hashcode by normalizing - // this to UTC timezone. - int timezone = getTimezone(); - if (timezone == DatatypeConstants.FIELD_UNDEFINED) { - timezone = 0; - } - XMLGregorianCalendar gc = this; - if (timezone != 0) { - gc = this.normalizeToTimezone(getTimezone()); - } - return gc.getYear() + gc.getMonth() + gc.getDay() + - gc.getHour() + gc.getMinute() + gc.getSecond(); - } - - /** *

    Constructs a new XMLGregorianCalendar object by * parsing its lexical string representation as defined in diff --git a/src/java.xml/share/classes/javax/xml/datatype/XMLGregorianCalendar.java b/src/java.xml/share/classes/javax/xml/datatype/XMLGregorianCalendar.java index 747d81bccd7..cbaa2553879 100644 --- a/src/java.xml/share/classes/javax/xml/datatype/XMLGregorianCalendar.java +++ b/src/java.xml/share/classes/javax/xml/datatype/XMLGregorianCalendar.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -28,6 +28,7 @@ package javax.xml.datatype; import javax.xml.namespace.QName; import java.math.BigDecimal; import java.math.BigInteger; +import java.util.Arrays; import java.util.TimeZone; import java.util.GregorianCalendar; @@ -688,10 +689,12 @@ public abstract class XMLGregorianCalendar */ @Override public boolean equals(Object obj) { - if (obj == null || !(obj instanceof XMLGregorianCalendar)) { return false; } + if (obj == this) { + return true; + } return compare((XMLGregorianCalendar) obj) == DatatypeConstants.EQUAL; } @@ -716,12 +719,10 @@ public abstract class XMLGregorianCalendar if (timezone != 0) { gc = this.normalize(); } - return gc.getYear() - + gc.getMonth() - + gc.getDay() - + gc.getHour() - + gc.getMinute() - + gc.getSecond(); + + int[] elements = {gc.getYear(), gc.getMonth(), gc.getDay(), gc.getHour(), + gc.getMinute(), gc.getSecond(), gc.getMillisecond()}; + return Arrays.hashCode(elements); } /** diff --git a/test/jaxp/javax/xml/jaxp/unittest/datatype/HashCodeTest.java b/test/jaxp/javax/xml/jaxp/unittest/datatype/HashCodeTest.java new file mode 100644 index 00000000000..6d16c676918 --- /dev/null +++ b/test/jaxp/javax/xml/jaxp/unittest/datatype/HashCodeTest.java @@ -0,0 +1,80 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * 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. + */ + +package datatype; + +import javax.xml.datatype.DatatypeFactory; +import javax.xml.datatype.XMLGregorianCalendar; +import org.testng.annotations.Test; +import org.testng.Assert; +import org.testng.annotations.DataProvider; + +/* + * @test + * @bug 8246816 + * @run testng datatype.HashCodeTest + * @summary Test hashCode generation. + */ +public class HashCodeTest { + /* + DataProvider: for testHashCode + Data: datetime1, datetime2, flag indicating if their hashCodes are equal + */ + @DataProvider(name = "testHashCode") + public Object[][] getData() { + + return new Object[][]{ + // the reported case: identical hash codes before the patch + {"2020-04-24T12:53:00+02:00", "2020-06-04T06:58:17.727Z", false}, + // a case mentioned in the dev note of hashCode() implementation + {"2000-01-15T12:00:00-05:00", "2000-01-15T13:00:00-04:00", true}, + /** + * Comparing with a datetime that needs to be normalized. + * Before the patch, XMLGregorianCalendarImpl called the normalizeToTimezone + * method that will set UNDEFINED fractional second to zero. + */ + {"2000-01-01T03:19:04Z", "1999-12-31T23:49:04-03:30", true}, + // another case mentioned in the javadoc of XMLGregorianCalendar::normalize() + {"2000-03-04T23:00:00+03:00", "2000-03-04T20:00:00Z", true}, + }; + } + + @Test(dataProvider = "testHashCode") + public final void testHashCode(String dt1, String dt2, boolean equal) throws Exception { + DatatypeFactory dataTypeFactory = DatatypeFactory.newInstance(); + XMLGregorianCalendar cal1 = dataTypeFactory.newXMLGregorianCalendar(dt1); + XMLGregorianCalendar cal2 = dataTypeFactory.newXMLGregorianCalendar(dt2); + + // identical hash codes before the patch + int hashCode1 = cal1.hashCode(); + int hashCode2 = cal2.hashCode(); + + if (equal) { + Assert.assertTrue(cal1.equals(cal2)); + Assert.assertEquals(hashCode1, hashCode2); + } else { + Assert.assertFalse(cal1.equals(cal2)); + Assert.assertNotEquals(hashCode1, hashCode2); + } + } +} From d0d925c13a612af8bc1ff43895d01fc4af2e1b60 Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Mon, 10 Aug 2020 10:25:17 -0700 Subject: [PATCH 49/53] 8251017: java/io/File/GetXSpace.java fails on UNIX Reviewed-by: naoto --- test/jdk/java/io/File/GetXSpace.java | 1 + 1 file changed, 1 insertion(+) diff --git a/test/jdk/java/io/File/GetXSpace.java b/test/jdk/java/io/File/GetXSpace.java index 3ca1558ffe6..b3a5ba5d7ca 100644 --- a/test/jdk/java/io/File/GetXSpace.java +++ b/test/jdk/java/io/File/GetXSpace.java @@ -24,6 +24,7 @@ /** * @test * @bug 4057701 6286712 6364377 + * @requires (os.family == "linux" | os.family == "mac" | os.family == "windows") * @run build GetXSpace * @run shell GetXSpace.sh * @summary Basic functionality of File.get-X-Space methods. From ed5696dd2ce318b2480c96b5eeaf319853ce5d89 Mon Sep 17 00:00:00 2001 From: Charlie Gracie Date: Mon, 10 Aug 2020 19:21:50 +0100 Subject: [PATCH 50/53] 8251361: Potential race between Logger configuration and GCs in HttpURLConWithProxy test Keep a static reference to the logger to prevent its inadvertent garbage collection while the test is running. Reviewed-by: dfuchs --- .../net/HttpURLConnection/HttpURLConWithProxy.java | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/test/jdk/java/net/HttpURLConnection/HttpURLConWithProxy.java b/test/jdk/java/net/HttpURLConnection/HttpURLConWithProxy.java index c8ab781ac44..53d74d06c2e 100644 --- a/test/jdk/java/net/HttpURLConnection/HttpURLConWithProxy.java +++ b/test/jdk/java/net/HttpURLConnection/HttpURLConWithProxy.java @@ -48,17 +48,21 @@ import java.util.logging.LogRecord; public class HttpURLConWithProxy { + private static Logger logger = + Logger.getLogger("sun.net.www.protocol.http.HttpURLConnection"); + public static void main(String... arg) throws Exception { // Remove the default nonProxyHosts to use localhost for testing System.setProperty("http.nonProxyHosts", ""); System.setProperty("http.proxyHost", "1.1.1.1"); System.setProperty("http.proxyPort", "1111"); - String HTTPLOG = "sun.net.www.protocol.http.HttpURLConnection"; - Logger.getLogger(HTTPLOG).setLevel(Level.ALL); + + // Use the logger to help verify the Proxy was used + logger.setLevel(Level.ALL); Handler h = new ProxyHandler(); h.setLevel(Level.ALL); - Logger.getLogger(HTTPLOG).addHandler(h); + logger.addHandler(h); ServerSocket ss; URL url; From 1cc09ccaef9a3695dd2862e3ee121e141e0a8a13 Mon Sep 17 00:00:00 2001 From: Zdenek Zambersky Date: Tue, 4 Aug 2020 17:19:21 -0300 Subject: [PATCH 51/53] 8251117: Cannot check P11Key size in P11Cipher and P11AEADCipher Reviewed-by: valeriep --- .../share/classes/sun/security/pkcs11/P11AEADCipher.java | 4 +++- .../share/classes/sun/security/pkcs11/P11Cipher.java | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java index 9f3a5a1e62f..82d0dc164f4 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11AEADCipher.java @@ -280,7 +280,9 @@ final class P11AEADCipher extends CipherSpi { SecureRandom sr) throws InvalidKeyException, InvalidAlgorithmParameterException { reset(true); - if (fixedKeySize != -1 && key.getEncoded().length != fixedKeySize) { + if (fixedKeySize != -1 && + ((key instanceof P11Key) ? ((P11Key) key).length() >> 3 : + key.getEncoded().length) != fixedKeySize) { throw new InvalidKeyException("Key size is invalid"); } P11Key newKey = P11SecretKeyFactory.convertKey(token, key, ALGO); diff --git a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java index 7fa3c0db82a..470a888cd84 100644 --- a/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java +++ b/src/jdk.crypto.cryptoki/share/classes/sun/security/pkcs11/P11Cipher.java @@ -345,7 +345,9 @@ final class P11Cipher extends CipherSpi { SecureRandom random) throws InvalidKeyException, InvalidAlgorithmParameterException { reset(true); - if (fixedKeySize != -1 && key.getEncoded().length != fixedKeySize) { + if (fixedKeySize != -1 && + ((key instanceof P11Key) ? ((P11Key) key).length() >> 3 : + key.getEncoded().length) != fixedKeySize) { throw new InvalidKeyException("Key size is invalid"); } switch (opmode) { From 5e9702d390536a00ccbb7c2b34be8fb9d8911b4a Mon Sep 17 00:00:00 2001 From: Vladimir Kempik Date: Mon, 10 Aug 2020 22:42:09 +0300 Subject: [PATCH 52/53] 8250876: Fix issues with cross-compile on macos Reviewed-by: erikj, ihse --- make/autoconf/flags.m4 | 10 ++++++---- make/autoconf/toolchain.m4 | 9 +++++++-- 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/make/autoconf/flags.m4 b/make/autoconf/flags.m4 index a7f959ff9ef..0301e64dc17 100644 --- a/make/autoconf/flags.m4 +++ b/make/autoconf/flags.m4 @@ -218,10 +218,12 @@ AC_DEFUN([FLAGS_SETUP_SYSROOT_FLAGS], # We also need -iframework/System/Library/Frameworks $1SYSROOT_CFLAGS="[$]$1SYSROOT_CFLAGS -iframework [$]$1SYSROOT/System/Library/Frameworks" $1SYSROOT_LDFLAGS="[$]$1SYSROOT_LDFLAGS -iframework [$]$1SYSROOT/System/Library/Frameworks" - # These always need to be set, or we can't find the frameworks embedded in JavaVM.framework - # set this here so it doesn't have to be peppered throughout the forest - $1SYSROOT_CFLAGS="[$]$1SYSROOT_CFLAGS -F [$]$1SYSROOT/System/Library/Frameworks/JavaVM.framework/Frameworks" - $1SYSROOT_LDFLAGS="[$]$1SYSROOT_LDFLAGS -F [$]$1SYSROOT/System/Library/Frameworks/JavaVM.framework/Frameworks" + if test -d "[$]$1SYSROOT/System/Library/Frameworks/JavaVM.framework/Frameworks" ; then + # These always need to be set on macOS 10.X, or we can't find the frameworks embedded in JavaVM.framework + # set this here so it doesn't have to be peppered throughout the forest + $1SYSROOT_CFLAGS="[$]$1SYSROOT_CFLAGS -F [$]$1SYSROOT/System/Library/Frameworks/JavaVM.framework/Frameworks" + $1SYSROOT_LDFLAGS="[$]$1SYSROOT_LDFLAGS -F [$]$1SYSROOT/System/Library/Frameworks/JavaVM.framework/Frameworks" + fi fi AC_SUBST($1SYSROOT_CFLAGS) diff --git a/make/autoconf/toolchain.m4 b/make/autoconf/toolchain.m4 index 0f1b8eb868e..25b89ecce36 100644 --- a/make/autoconf/toolchain.m4 +++ b/make/autoconf/toolchain.m4 @@ -902,9 +902,14 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_BUILD_COMPILERS], # FIXME: we should list the discovered compilers as an exclude pattern! # If we do that, we can do this detection before POST_DETECTION, and still # find the build compilers in the tools dir, if needed. - UTIL_REQUIRE_PROGS(BUILD_CC, [cl cc gcc]) + if test "x$OPENJDK_BUILD_OS" = xmacosx; then + UTIL_REQUIRE_PROGS(BUILD_CC, [clang cl cc gcc]) + UTIL_REQUIRE_PROGS(BUILD_CXX, [clang++ cl CC g++]) + else + UTIL_REQUIRE_PROGS(BUILD_CC, [cl cc gcc]) + UTIL_REQUIRE_PROGS(BUILD_CXX, [cl CC g++]) + fi UTIL_FIXUP_EXECUTABLE(BUILD_CC) - UTIL_REQUIRE_PROGS(BUILD_CXX, [cl CC g++]) UTIL_FIXUP_EXECUTABLE(BUILD_CXX) UTIL_PATH_PROGS(BUILD_NM, nm gcc-nm) UTIL_FIXUP_EXECUTABLE(BUILD_NM) From e64a25b256e9b46ff4531114f9642b63af6d9362 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Mon, 10 Aug 2020 21:52:02 +0200 Subject: [PATCH 53/53] 8246347: [JVMCI] Set is_method_handle_invoke flag accordingly when describing scope in jvmciCodeInstaller Reviewed-by: kvn, dlong --- src/hotspot/share/code/compiledMethod.hpp | 4 +-- .../share/code/compiledMethod.inline.hpp | 10 ++++++- .../share/jvmci/jvmciCodeInstaller.cpp | 29 ++++++++++++++----- .../share/jvmci/jvmciCodeInstaller.hpp | 9 +++--- src/hotspot/share/jvmci/jvmciJavaClasses.hpp | 3 +- src/hotspot/share/jvmci/vmStructs_jvmci.cpp | 7 ++++- 6 files changed, 45 insertions(+), 17 deletions(-) diff --git a/src/hotspot/share/code/compiledMethod.hpp b/src/hotspot/share/code/compiledMethod.hpp index f43e7ee038e..02cbd4c9a61 100644 --- a/src/hotspot/share/code/compiledMethod.hpp +++ b/src/hotspot/share/code/compiledMethod.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -330,7 +330,7 @@ public: // Deopt // Return true is the PC is one would expect if the frame is being deopted. inline bool is_deopt_pc(address pc); - bool is_deopt_mh_entry(address pc) { return pc == deopt_mh_handler_begin(); } + inline bool is_deopt_mh_entry(address pc); inline bool is_deopt_entry(address pc); virtual bool can_convert_to_zombie() = 0; diff --git a/src/hotspot/share/code/compiledMethod.inline.hpp b/src/hotspot/share/code/compiledMethod.inline.hpp index 99c120ab443..670a2ae2a65 100644 --- a/src/hotspot/share/code/compiledMethod.inline.hpp +++ b/src/hotspot/share/code/compiledMethod.inline.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -41,6 +41,14 @@ inline bool CompiledMethod::is_deopt_entry(address pc) { ; } +inline bool CompiledMethod::is_deopt_mh_entry(address pc) { + return pc == deopt_mh_handler_begin() +#if INCLUDE_JVMCI + || (is_compiled_by_jvmci() && pc == (deopt_mh_handler_begin() + NativeCall::instruction_size)) +#endif + ; +} + // ----------------------------------------------------------------------------- // CompiledMethod::get_deopt_original_pc // diff --git a/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp b/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp index f44a5b8cd55..4f6ad79d558 100644 --- a/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp +++ b/src/hotspot/share/jvmci/jvmciCodeInstaller.cpp @@ -1043,7 +1043,7 @@ GrowableArray* CodeInstaller::record_virtual_objects(JVMCIObject de return objects; } -void CodeInstaller::record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMode scope_mode, bool return_oop, JVMCI_TRAPS) { +void CodeInstaller::record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMode scope_mode, bool is_mh_invoke, bool return_oop, JVMCI_TRAPS) { JVMCIObject position = jvmci_env()->get_DebugInfo_bytecodePosition(debug_info); if (position.is_null()) { // Stubs do not record scope info, just oop maps @@ -1056,7 +1056,7 @@ void CodeInstaller::record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMo } else { objectMapping = NULL; } - record_scope(pc_offset, position, scope_mode, objectMapping, return_oop, JVMCI_CHECK); + record_scope(pc_offset, position, scope_mode, objectMapping, is_mh_invoke, return_oop, JVMCI_CHECK); } int CodeInstaller::map_jvmci_bci(int bci) { @@ -1079,7 +1079,7 @@ int CodeInstaller::map_jvmci_bci(int bci) { return bci; } -void CodeInstaller::record_scope(jint pc_offset, JVMCIObject position, ScopeMode scope_mode, GrowableArray* objects, bool return_oop, JVMCI_TRAPS) { +void CodeInstaller::record_scope(jint pc_offset, JVMCIObject position, ScopeMode scope_mode, GrowableArray* objects, bool is_mh_invoke, bool return_oop, JVMCI_TRAPS) { JVMCIObject frame; if (scope_mode == CodeInstaller::FullFrame) { if (!jvmci_env()->isa_BytecodeFrame(position)) { @@ -1089,7 +1089,7 @@ void CodeInstaller::record_scope(jint pc_offset, JVMCIObject position, ScopeMode } JVMCIObject caller_frame = jvmci_env()->get_BytecodePosition_caller(position); if (caller_frame.is_non_null()) { - record_scope(pc_offset, caller_frame, scope_mode, objects, return_oop, JVMCI_CHECK); + record_scope(pc_offset, caller_frame, scope_mode, objects, is_mh_invoke, return_oop, JVMCI_CHECK); } JVMCIObject hotspot_method = jvmci_env()->get_BytecodePosition_method(position); @@ -1181,7 +1181,7 @@ void CodeInstaller::record_scope(jint pc_offset, JVMCIObject position, ScopeMode throw_exception = jvmci_env()->get_BytecodeFrame_rethrowException(frame) == JNI_TRUE; } - _debug_recorder->describe_scope(pc_offset, method, NULL, bci, reexecute, throw_exception, false, return_oop, + _debug_recorder->describe_scope(pc_offset, method, NULL, bci, reexecute, throw_exception, is_mh_invoke, return_oop, locals_token, expressions_token, monitors_token); } @@ -1236,9 +1236,19 @@ void CodeInstaller::site_Call(CodeBuffer& buffer, jint pc_offset, JVMCIObject si OopMap *map = create_oop_map(debug_info, JVMCI_CHECK); _debug_recorder->add_safepoint(next_pc_offset, map); - bool return_oop = hotspot_method.is_non_null() && jvmci_env()->asMethod(hotspot_method)->is_returning_oop(); - - record_scope(next_pc_offset, debug_info, CodeInstaller::FullFrame, return_oop, JVMCI_CHECK); + if (hotspot_method.is_non_null()) { + Method *method = jvmci_env()->asMethod(hotspot_method); + vmIntrinsics::ID iid = method->intrinsic_id(); + bool is_mh_invoke = false; + if (jvmci_env()->get_site_Call_direct(site)) { + is_mh_invoke = !method->is_static() && (iid == vmIntrinsics::_compiledLambdaForm || + (MethodHandles::is_signature_polymorphic(iid) && MethodHandles::is_signature_polymorphic_intrinsic(iid))); + } + bool return_oop = method->is_returning_oop(); + record_scope(next_pc_offset, debug_info, CodeInstaller::FullFrame, is_mh_invoke, return_oop, JVMCI_CHECK); + } else { + record_scope(next_pc_offset, debug_info, CodeInstaller::FullFrame, JVMCI_CHECK); + } } if (foreign_call.is_non_null()) { @@ -1347,6 +1357,9 @@ void CodeInstaller::site_Mark(CodeBuffer& buffer, jint pc_offset, JVMCIObject si case DEOPT_HANDLER_ENTRY: _offsets.set_value(CodeOffsets::Deopt, pc_offset); break; + case DEOPT_MH_HANDLER_ENTRY: + _offsets.set_value(CodeOffsets::DeoptMH, pc_offset); + break; case FRAME_COMPLETE: _offsets.set_value(CodeOffsets::Frame_Complete, pc_offset); break; diff --git a/src/hotspot/share/jvmci/jvmciCodeInstaller.hpp b/src/hotspot/share/jvmci/jvmciCodeInstaller.hpp index 45f9232b3d1..0bbaf3f3e66 100644 --- a/src/hotspot/share/jvmci/jvmciCodeInstaller.hpp +++ b/src/hotspot/share/jvmci/jvmciCodeInstaller.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -159,6 +159,7 @@ private: CRC_TABLE_ADDRESS, LOG_OF_HEAP_REGION_GRAIN_BYTES, INLINE_CONTIGUOUS_ALLOCATION_SUPPORTED, + DEOPT_MH_HANDLER_ENTRY, INVOKE_INVALID = -1 }; @@ -297,11 +298,11 @@ protected: int map_jvmci_bci(int bci); - void record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMode scope_mode, bool return_oop, JVMCI_TRAPS); + void record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMode scope_mode, bool is_mh_invoke, bool return_oop, JVMCI_TRAPS); void record_scope(jint pc_offset, JVMCIObject debug_info, ScopeMode scope_mode, JVMCI_TRAPS) { - record_scope(pc_offset, debug_info, scope_mode, false /* return_oop */, JVMCIENV); + record_scope(pc_offset, debug_info, scope_mode, false /* is_mh_invoke */, false /* return_oop */, JVMCIENV); } - void record_scope(jint pc_offset, JVMCIObject position, ScopeMode scope_mode, GrowableArray* objects, bool return_oop, JVMCI_TRAPS); + void record_scope(jint pc_offset, JVMCIObject position, ScopeMode scope_mode, GrowableArray* objects, bool is_mh_invoke, bool return_oop, JVMCI_TRAPS); void record_object_value(ObjectValue* sv, JVMCIObject value, GrowableArray* objects, JVMCI_TRAPS); GrowableArray* record_virtual_objects(JVMCIObject debug_info, JVMCI_TRAPS); diff --git a/src/hotspot/share/jvmci/jvmciJavaClasses.hpp b/src/hotspot/share/jvmci/jvmciJavaClasses.hpp index fae548065a5..91c9302729a 100644 --- a/src/hotspot/share/jvmci/jvmciJavaClasses.hpp +++ b/src/hotspot/share/jvmci/jvmciJavaClasses.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -175,6 +175,7 @@ end_class \ start_class(site_Call, jdk_vm_ci_code_site_Call) \ object_field(site_Call, target, "Ljdk/vm/ci/meta/InvokeTarget;") \ + boolean_field(site_Call, direct) \ end_class \ start_class(site_DataPatch, jdk_vm_ci_code_site_DataPatch) \ object_field(site_DataPatch, reference, "Ljdk/vm/ci/code/site/Reference;") \ diff --git a/src/hotspot/share/jvmci/vmStructs_jvmci.cpp b/src/hotspot/share/jvmci/vmStructs_jvmci.cpp index f6aec1f3f1e..e12eca30ff9 100644 --- a/src/hotspot/share/jvmci/vmStructs_jvmci.cpp +++ b/src/hotspot/share/jvmci/vmStructs_jvmci.cpp @@ -471,8 +471,14 @@ declare_constant(CodeInstaller::CRC_TABLE_ADDRESS) \ declare_constant(CodeInstaller::LOG_OF_HEAP_REGION_GRAIN_BYTES) \ declare_constant(CodeInstaller::INLINE_CONTIGUOUS_ALLOCATION_SUPPORTED) \ + declare_constant(CodeInstaller::DEOPT_MH_HANDLER_ENTRY) \ declare_constant(CodeInstaller::INVOKE_INVALID) \ \ + declare_constant(vmIntrinsics::FIRST_MH_SIG_POLY) \ + declare_constant(vmIntrinsics::LAST_MH_SIG_POLY) \ + declare_constant(vmIntrinsics::_invokeGeneric) \ + declare_constant(vmIntrinsics::_compiledLambdaForm) \ + \ declare_constant(CollectedHeap::Serial) \ declare_constant(CollectedHeap::Parallel) \ declare_constant(CollectedHeap::G1) \ @@ -966,4 +972,3 @@ void jvmci_vmStructs_init() { JVMCIVMStructs::init(); } #endif // ASSERT -