From fc510d4448d1cf3fcff6d4be1d01c2e0fc20ce32 Mon Sep 17 00:00:00 2001 From: Matthew Hall Date: Wed, 9 Oct 2024 14:01:18 -0400 Subject: [PATCH] Fix fieldAlignment check for AtomicLong on Z "value" field in AtomicLong is of type "long" and therefore should be aligned to 8-byte boundary. checkFieldAlignmentForAtomicLong was incorrectly checking that the offset of the field is a multiple of 4 instead of a multiple of 8. This commit fixes that. Closes: https://github.com/eclipse-openj9/openj9/issues/20235 Signed-off-by: Matthew Hall --- runtime/compiler/z/codegen/J9CodeGenerator.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/runtime/compiler/z/codegen/J9CodeGenerator.cpp b/runtime/compiler/z/codegen/J9CodeGenerator.cpp index ca13349d986..fbeba5875d0 100644 --- a/runtime/compiler/z/codegen/J9CodeGenerator.cpp +++ b/runtime/compiler/z/codegen/J9CodeGenerator.cpp @@ -3267,8 +3267,8 @@ J9::Z::CodeGenerator::checkFieldAlignmentForAtomicLong() int32_t fieldNameLen = 5; const char * fieldSig = "J"; int32_t fieldSigLen = 1; - int32_t intOrBoolOffset = self()->fe()->getObjectHeaderSizeInBytes() + self()->fej9()->getInstanceFieldOffset(classBlock, fieldName, fieldNameLen, fieldSig, fieldSigLen); - return (intOrBoolOffset & 0x3) == 0; + int32_t longOffset = self()->fe()->getObjectHeaderSizeInBytes() + self()->fej9()->getInstanceFieldOffset(classBlock, fieldName, fieldNameLen, fieldSig, fieldSigLen); + return (longOffset & 0x7) == 0; }