From a96de6d8d273d75a6500e10ed06faab9955f893b Mon Sep 17 00:00:00 2001 From: Richard Reingruber Date: Mon, 15 Jul 2024 07:34:10 +0000 Subject: [PATCH] 8336256: memcpy short value to int local is incorrect in VtableStubs::unsafe_hash Reviewed-by: stuefe, shade, kvn --- src/hotspot/share/code/vtableStubs.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/hotspot/share/code/vtableStubs.cpp b/src/hotspot/share/code/vtableStubs.cpp index a65852e247f..dbae8b8694f 100644 --- a/src/hotspot/share/code/vtableStubs.cpp +++ b/src/hotspot/share/code/vtableStubs.cpp @@ -262,7 +262,8 @@ inline uint VtableStubs::unsafe_hash(address entry_point) { address vtable_type_addr = vtable_stub_addr + offset_of(VtableStub, _type); address vtable_index_addr = vtable_stub_addr + offset_of(VtableStub, _index); bool is_vtable_stub = *vtable_type_addr == static_cast(VtableStub::Type::vtable_stub); - int vtable_index; + short vtable_index; + static_assert(sizeof(VtableStub::_index) == sizeof(vtable_index), "precondition"); memcpy(&vtable_index, vtable_index_addr, sizeof(vtable_index)); return hash(is_vtable_stub, vtable_index); }