Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merge jdk #930

Closed
wants to merge 77 commits into from
Closed
Changes from all commits
Commits
Show all changes
77 commits
Select commit Hold shift + click to select a range
36d578c
8311653: Modify -XshowSettings launcher behavior
coffeys Jul 27, 2023
b7545a6
8313164: src/java.desktop/windows/native/libawt/windows/awt_Robot.cpp…
MBaesken Jul 27, 2023
01e135c
8312440: assert(cast != nullptr) failed: must have added a cast to pi…
rwestrel Jul 27, 2023
7cbab1f
8312218: Print additional debug information when hitting assert(in_hash)
enothum Jul 27, 2023
86821a7
8312235: [JVMCI] ConstantPool should not force eager resolution
Jul 27, 2023
44576a7
8312466: /bin/nm usage in AIX makes needs -X64 flag
ansteiner Jul 27, 2023
271417a
8312579: [JVMCI] JVMCI support for virtual Vector API objects
Jul 27, 2023
486c784
8312433: HttpClient request fails due to connection being considered …
jaikiran Jul 27, 2023
8661b8e
8312495: assert(0 <= i && i < _len) failed: illegal index after JDK-8…
reinrich Jul 27, 2023
25058cd
8312620: WSL Linux build crashes after JDK-8310233
tstuefe Jul 27, 2023
8650026
8310033: Clarify return value of Java Time compareTo methods
Jul 27, 2023
169b6e3
8313174: Create fewer predictable port clashes in management tests
kevinjwalls Jul 27, 2023
c05ba48
8313250: Exclude java/foreign/TestByteBuffer.java on AIX
TOatGithub Jul 27, 2023
0ca2bfd
8311104: dangling-gsl warning in libwixhelper.cpp
Jul 27, 2023
c55d29f
8312626: Resolve multiple definition of 'start_timer' when statically…
jianglizhou Jul 27, 2023
c27c877
8302017: Allocate BadPaddingException only if it will be thrown
slumericanB Jul 27, 2023
ba645da
8313082: Enable CreateCoredumpOnCrash for testing in makefiles
lmesnik Jul 28, 2023
cad6114
8304954: SegmentedCodeCache fails when using large pages
dafedafe Jul 28, 2023
4ae5a3e
8306446: java/lang/management/ThreadMXBean/Locks.java transient failures
kevinjwalls Jul 28, 2023
a3d6723
8311033: [macos] PrinterJob does not take into account Sides attribute
Jul 28, 2023
47c4b99
8312121: Fix -Wconversion warnings in tribool.hpp
coleenp Jul 28, 2023
34173ff
8312574: jdk/jdk/jfr/jvm/TestChunkIntegrity.java fails with timeout
MBaesken Jul 28, 2023
d9559f9
8312612: handle WideCharToMultiByte return values
MBaesken Jul 28, 2023
a9a3463
8312416: Tests in Locale should have more descriptive names
Jul 28, 2023
e897041
8312262: Klass::array_klass() should return ArrayKlass pointer
coleenp Jul 28, 2023
4ae75ca
8313253: Rename methods in javadoc Comparators class
jonathan-gibbons Jul 28, 2023
e2cb0bc
8313204: Inconsistent order of sections in generated class documentation
jonathan-gibbons Jul 28, 2023
23755f9
8312411: MessageFormat.formatToCharacterIterator() can be improved
Jul 28, 2023
402cb6a
8312201: Clean up common behavior in "page writers" and "member writers"
jonathan-gibbons Jul 28, 2023
d6245b6
8310268: RISC-V: misaligned memory access in String.Compare intrinsic
Jul 28, 2023
ad34be1
8312525: New test runtime/os/TestTrimNative.java#trimNative is failin…
tstuefe Jul 29, 2023
807ca2d
8313316: Disable runtime/ErrorHandling/MachCodeFramesInErrorFile.java…
RealCLanger Jul 31, 2023
f8c2b7f
8313231: Redundant if statement in ZoneInfoFile
Jul 31, 2023
6fca289
8313023: Return value corrupted when using CCS + isTrivial (mainline)
JornVernee Jul 31, 2023
408987e
8313307: java/util/Formatter/Padding.java fails on some Locales
shipilev Jul 31, 2023
b60e0ad
8313207: Remove MetaspaceShared::_has_error_classes
Jul 31, 2023
3671d83
8313252: Java_sun_awt_windows_ThemeReader_paintBackground release res…
MBaesken Jul 31, 2023
97b6883
8295059: test/langtools/tools/javap 12 test classes use com.sun.tools…
xqoasis Jul 31, 2023
78f6799
8293972: runtime/NMT/NMTInitializationTest.java#default_long-off fail…
Jul 31, 2023
e47a84f
8312489: Increase jdk.jar.maxSignatureFileSize default which is too l…
Jul 31, 2023
5362ec9
8312492: Remove THP sanity checks at VM startup
tstuefe Jul 31, 2023
86783b9
8301996: Move field resolution information out of the cpCache
Jul 31, 2023
6af0af5
8310913: Move ReferencedKeyMap to jdk.internal so it may be shared
Jul 31, 2023
c91a300
8307312: Replace "int which" with "int cp_index" in constantPool
Jul 31, 2023
0a3c6d6
8280482: Window transparency bug on Linux
Aug 1, 2023
e36960e
8312420: Integrate Graal's blender micro benchmark
caojoshua Aug 1, 2023
ee3e091
8313249: Fix -Wconversion warnings in verifier code
coleenp Aug 1, 2023
94b50b7
8313404: Fix section label in test/jdk/ProblemList.txt
RealCLanger Aug 1, 2023
98a915a
8313256: Exclude failing multicast tests on AIX
TOatGithub Aug 1, 2023
ec2f38f
8313428: GHA: Bump GCC versions for July 2023 updates
shipilev Aug 1, 2023
7ba8c69
8312596: Null pointer access in Compile::TracePhase::~TracePhase afte…
ashu-mehra Aug 1, 2023
bf70777
8312181: CDS dynamic dump crashes when verifying unlinked class from …
calvinccheung Aug 1, 2023
dc14247
8309240: Array classes should be stored in dynamic CDS archive
calvinccheung Aug 1, 2023
28be34c
8313226: Redundant condition test in X509CRLImpl
Aug 1, 2023
9b55e9a
8312572: JDK 21 RDP2 L10n resource files update
Aug 1, 2023
f14245b
8312814: Compiler crash when template processor type is a captured wi…
Aug 2, 2023
528596f
8310991: missing @since tags in java.xml
JoeWang-Java Aug 2, 2023
e8471f6
8313507: Remove pkcs11/Cipher/TestKATForGCM.java from ProblemList
djelinski Aug 2, 2023
6a853bb
8311821: Simplify ParallelGCThreadsConstraintFunc after CMS removal
kspeeyu Aug 2, 2023
9454b2b
8312591: GCC 6 build failure after JDK-8280982
shipilev Aug 2, 2023
5d1b911
8310311: Serial: move Generation::contribute_scratch to DefNewGeneration
albertnetymk Aug 2, 2023
6faf05c
8311989: Test java/lang/Thread/virtual/Reflection.java timed out
Aug 2, 2023
46fbedb
8313402: C1: Incorrect LoadIndexed value numbering
shipilev Aug 2, 2023
19e2c8c
8313593: Generational ZGC: NMT assert when the heap fails to expand
stefank Aug 2, 2023
b093880
8313322: RISC-V: implement MD5 intrinsic
gctony Aug 2, 2023
6446792
8312617: SIGSEGV in ConnectionGraph::verify_ram_nodes
Aug 2, 2023
c1a3f14
8312078: [PPC] JcmdScale.java Failing on AIX
deepa181 Aug 2, 2023
4ba81f6
8313368: (fc) FileChannel.size returns 0 on block special files
Aug 2, 2023
cff25dd
8306582: Remove MetaspaceShared::exit_after_static_dump()
Aug 2, 2023
66f3765
Merge commit '5362ec9c6e9123d00288497ac9d1879a2bb1ca64' into lworld_m…
MrSimms Sep 18, 2023
d6468d0
Logical merge fixes
MrSimms Sep 18, 2023
cea0228
Merge ResolvedFieldEntry
MrSimms Sep 27, 2023
ffe4188
Merge fixes to ResolvedFieldEntry
MrSimms Sep 27, 2023
f5770f5
Merge tag 'jdk-22+9' into lworld_merge_jdk_22_9_incr
MrSimms Sep 27, 2023
f6181b0
Merge fixes
MrSimms Sep 27, 2023
44ed6b1
Deferred test issues
MrSimms Sep 28, 2023
ed15759
Suggested usage of scratch register
MrSimms Sep 29, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
18 changes: 9 additions & 9 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
@@ -130,7 +130,7 @@ jobs:
with:
platform: linux-x64
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
# The linux-x64 jdk bundle is used as buildjdk for the cross-compile job
@@ -144,7 +144,7 @@ jobs:
platform: linux-x86
gcc-major-version: '10'
gcc-package-suffix: '-multilib'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
apt-architecture: 'i386'
# Some multilib libraries do not have proper inter-dependencies, so we have to
# install their dependencies manually.
@@ -163,7 +163,7 @@ jobs:
make-target: 'hotspot'
debug-levels: '[ "debug" ]'
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
extra-conf-options: '--disable-precompiled-headers'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
@@ -178,7 +178,7 @@ jobs:
make-target: 'hotspot'
debug-levels: '[ "debug" ]'
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
extra-conf-options: '--with-jvm-variants=zero --disable-precompiled-headers'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
@@ -193,7 +193,7 @@ jobs:
make-target: 'hotspot'
debug-levels: '[ "debug" ]'
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
extra-conf-options: '--with-jvm-variants=minimal --disable-precompiled-headers'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
@@ -209,7 +209,7 @@ jobs:
# Technically this is not the "debug" level, but we can't inject a new matrix state for just this job
debug-levels: '[ "debug" ]'
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
extra-conf-options: '--with-debug-level=optimized --disable-precompiled-headers'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
@@ -223,8 +223,8 @@ jobs:
uses: ./.github/workflows/build-cross-compile.yml
with:
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-cross-version: '10.4.0-4ubuntu1~22.04cross1'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
apt-gcc-cross-version: '10.5.0-1ubuntu1~22.04cross1'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
if: needs.select.outputs.linux-cross-compile == 'true'
@@ -290,7 +290,7 @@ jobs:
# build JDK, and we do not need the additional testing of the graphs.
extra-conf-options: '--disable-full-docs'
gcc-major-version: '10'
apt-gcc-version: '10.4.0-4ubuntu1~22.04'
apt-gcc-version: '10.5.0-1ubuntu1~22.04'
configure-arguments: ${{ github.event.inputs.configure-arguments }}
make-arguments: ${{ github.event.inputs.make-arguments }}
if: needs.select.outputs.docs == 'true'
2 changes: 2 additions & 0 deletions make/RunTests.gmk
Original file line number Diff line number Diff line change
@@ -800,8 +800,10 @@ define SetupRunJtregTestBody
$1_JTREG_BASIC_OPTIONS += -e:JIB_DATA_DIR
# If running on Windows, propagate the _NT_SYMBOL_PATH to enable
# symbol lookup in hserr files
# The minidumps are disabled by default on client Windows, so enable them
ifeq ($$(call isTargetOs, windows), true)
$1_JTREG_BASIC_OPTIONS += -e:_NT_SYMBOL_PATH
$1_JTREG_BASIC_OPTIONS += -vmoption:-XX:+CreateCoredumpOnCrash
else ifeq ($$(call isTargetOs, linux), true)
$1_JTREG_BASIC_OPTIONS += -e:_JVM_DWARF_PATH=$$(SYMBOLS_IMAGE_DIR)
endif
6 changes: 6 additions & 0 deletions make/hotspot/lib/CompileJvm.gmk
Original file line number Diff line number Diff line change
@@ -281,6 +281,12 @@ ifneq ($(GENERATE_COMPILE_COMMANDS_ONLY), true)
#
UNDEF_PATTERN := ' U '

# 'nm' on AIX needs -X64 option

ifeq ($(call isTargetOs, aix), true)
NM := $(NM) -X64
endif

define SetupOperatorNewDeleteCheck
$1.op_check: $1
$$(call ExecuteWithLog, $1.op_check, \
2 changes: 2 additions & 0 deletions make/modules/java.desktop/lib/Awt2dLibraries.gmk
Original file line number Diff line number Diff line change
@@ -245,6 +245,8 @@ ifeq ($(call isTargetOs, windows macosx), false)
DISABLED_WARNINGS_gcc_gtk3_interface.c := parentheses type-limits unused-function, \
DISABLED_WARNINGS_gcc_OGLBufImgOps.c := format-nonliteral, \
DISABLED_WARNINGS_gcc_OGLPaints.c := format-nonliteral, \
DISABLED_WARNINGS_gcc_screencast_pipewire.c := undef, \
DISABLED_WARNINGS_gcc_screencast_portal.c := undef, \
DISABLED_WARNINGS_gcc_sun_awt_X11_GtkFileDialogPeer.c := parentheses, \
DISABLED_WARNINGS_gcc_X11SurfaceData.c := implicit-fallthrough pointer-to-int-cast, \
DISABLED_WARNINGS_gcc_XlibWrapper.c := type-limits pointer-to-int-cast, \
2 changes: 1 addition & 1 deletion src/hotspot/cpu/aarch64/downcallLinker_aarch64.cpp
Original file line number Diff line number Diff line change
@@ -168,7 +168,7 @@ void DowncallStubGenerator::generate() {
assert(_abi._shadow_space_bytes == 0, "not expecting shadow space on AArch64");
allocated_frame_size += arg_shuffle.out_arg_bytes();

bool should_save_return_value = !_needs_return_buffer && _needs_transition;
bool should_save_return_value = !_needs_return_buffer;
RegSpiller out_reg_spiller(_output_registers);
int spill_offset = -1;

19 changes: 18 additions & 1 deletion src/hotspot/cpu/aarch64/interp_masm_aarch64.cpp
Original file line number Diff line number Diff line change
@@ -38,6 +38,7 @@
#include "oops/method.hpp"
#include "oops/methodData.hpp"
#include "oops/inlineKlass.hpp"
#include "oops/resolvedFieldEntry.hpp"
#include "oops/resolvedIndyEntry.hpp"
#include "prims/jvmtiExport.hpp"
#include "prims/jvmtiThreadState.hpp"
@@ -2066,8 +2067,24 @@ void InterpreterMacroAssembler::load_resolved_indy_entry(Register cache, Registe
get_cache_index_at_bcp(index, 1, sizeof(u4));
// Get address of invokedynamic array
ldr(cache, Address(rcpool, in_bytes(ConstantPoolCache::invokedynamic_entries_offset())));
// Scale the index to be the entry index * sizeof(ResolvedInvokeDynamicInfo)
// Scale the index to be the entry index * sizeof(ResolvedIndyEntry)
lsl(index, index, log2i_exact(sizeof(ResolvedIndyEntry)));
add(cache, cache, Array<ResolvedIndyEntry>::base_offset_in_bytes());
lea(cache, Address(cache, index));
}

void InterpreterMacroAssembler::load_field_entry(Register cache, Register index, int bcp_offset) {
// Get index out of bytecode pointer
get_cache_index_at_bcp(index, bcp_offset, sizeof(u2));
// Take shortcut if the size is a power of 2
if (is_power_of_2(sizeof(ResolvedFieldEntry))) {
lsl(index, index, log2i_exact(sizeof(ResolvedFieldEntry))); // Scale index by power of 2
} else {
mov(cache, sizeof(ResolvedFieldEntry));
mul(index, index, cache); // Scale the index to be the entry index * sizeof(ResolvedFieldEntry)
}
// Get address of field entries array
ldr(cache, Address(rcpool, ConstantPoolCache::field_entries_offset()));
add(cache, cache, Array<ResolvedFieldEntry>::base_offset_in_bytes());
lea(cache, Address(cache, index));
}
1 change: 1 addition & 0 deletions src/hotspot/cpu/aarch64/interp_masm_aarch64.hpp
Original file line number Diff line number Diff line change
@@ -346,6 +346,7 @@ class InterpreterMacroAssembler: public MacroAssembler {
}

void load_resolved_indy_entry(Register cache, Register index);
void load_field_entry(Register cache, Register index, int bcp_offset = 1);
};

#endif // CPU_AARCH64_INTERP_MASM_AARCH64_HPP
7 changes: 4 additions & 3 deletions src/hotspot/cpu/aarch64/macroAssembler_aarch64.cpp
Original file line number Diff line number Diff line change
@@ -49,6 +49,7 @@
#include "oops/compressedKlass.inline.hpp"
#include "oops/compressedOops.inline.hpp"
#include "oops/klass.inline.hpp"
#include "oops/resolvedFieldEntry.hpp"
#include "runtime/continuation.hpp"
#include "runtime/icache.hpp"
#include "runtime/interfaceSupport.inline.hpp"
@@ -1737,17 +1738,17 @@ void MacroAssembler::test_klass_is_empty_inline_type(Register klass, Register te

void MacroAssembler::test_field_is_null_free_inline_type(Register flags, Register temp_reg, Label& is_null_free_inline_type) {
assert(temp_reg == noreg, "not needed"); // keep signature uniform with x86
tbnz(flags, ConstantPoolCacheEntry::is_null_free_inline_type_shift, is_null_free_inline_type);
tbnz(flags, ResolvedFieldEntry::is_null_free_inline_type_shift, is_null_free_inline_type);
}

void MacroAssembler::test_field_is_not_null_free_inline_type(Register flags, Register temp_reg, Label& not_null_free_inline_type) {
assert(temp_reg == noreg, "not needed"); // keep signature uniform with x86
tbz(flags, ConstantPoolCacheEntry::is_null_free_inline_type_shift, not_null_free_inline_type);
tbz(flags, ResolvedFieldEntry::is_null_free_inline_type_shift, not_null_free_inline_type);
}

void MacroAssembler::test_field_is_flat(Register flags, Register temp_reg, Label& is_flat) {
assert(temp_reg == noreg, "not needed"); // keep signature uniform with x86
tbnz(flags, ConstantPoolCacheEntry::is_flat_shift, is_flat);
tbnz(flags, ResolvedFieldEntry::is_flat_shift, is_flat);
}

void MacroAssembler::test_oop_prototype_bit(Register oop, Register temp_reg, int32_t test_bit, bool jmp_set, Label& jmp_label) {
Loading