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

Downgrade isIndexableDataAddrPresent to U_32 #20819

Merged

Conversation

amicic
Copy link
Contributor

@amicic amicic commented Dec 11, 2024

Effectively this was used as a BOOLEAN (which is typedef of U_32/I_32), but being UDATA just taking more space than necessary on 64bit platforms.

Thus compiler will be able to better pack 2 consecutive boolean fields (isIndexableDataAddrPresent and isVirtualLargeObjectHeapEnabled)

Using U_32 rather than BOOLEAN to be able to consistently update DDR code (which seems not to use BOOLEAN)

Effectively this was used as a BOOLEAN (which is typedef of U_32/I_32),
but being UDATA just taking more space than necessary on 64bit
platforms.

Thus compiler will be able to better pack 2 consecutive boolean fields
(isIndexableDataAddrPresent and isVirtualLargeObjectHeapEnabled)

Using U_32 rather than BOOLEAN to be able to consistently update DDR
code (which seems not to use BOOLEAN)

Signed-off-by: Aleksandar Micic <[email protected]>
@amicic
Copy link
Contributor Author

amicic commented Dec 11, 2024

jenkins compile all jdk21

@pshipton
Copy link
Member

Pls pass it by a vmfarm build.

@dmitripivkine dmitripivkine merged commit 30b5e75 into eclipse-openj9:master Dec 11, 2024
9 of 11 checks passed
Comment on lines -6081 to +6083
UDATA isIndexableDataAddrPresent;
BOOLEAN isVirtualLargeObjectHeapEnabled;
BOOLEAN isIndexableDualHeaderShapeEnabled;
U_32 isIndexableDataAddrPresent;
U_32 isVirtualLargeObjectHeapEnabled;
U_32 isIndexableDualHeaderShapeEnabled;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Type changes like these cause compatibility problems for DDR accessing older system dumps where the fields had different types. See my earlier comment: #20804 (review).

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK, I see that javaVM.isIndexableDataAddrPresent() was indeed explicitly used in DDR. I don't see explicit usages of the other 2 fields, though.

Soon, we will be removing all these 3 fields and replacing them with one composite field (a bit-wise union), at which point we will be forced to properly implement isIndexableDataAddrPresent() to extract the value from the composite field or try to return the field itself, if it exists, for older cores.

That should resolve potential compatibility problems between DDR and cores for released JVMs (although some non-released JVMs could still experience incompatibilities).

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This only serves to complicate matters as now there are (at least) two kinds of "older cores". It would have been better to leave the fields as they were and switch to the bit-mask in one step.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We haven't shipped this change yet, until the 0.51 release.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also the change seems to be causing an -Xint startup perf regression.
https://github.ibm.com/runtimes/javanext/issues/491

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants