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

Add JFR ThreadContextSwitchRate support #20725

Merged
merged 1 commit into from
Jan 3, 2025

Conversation

thallium
Copy link
Contributor

@thallium thallium commented Dec 2, 2024

Depends on: eclipse-omr/omr#7580

@thallium
Copy link
Contributor Author

thallium commented Dec 2, 2024

@tajila FYI

@thallium thallium force-pushed the jfr-context-switch branch 3 times, most recently from 5a1927f to 79fbfc8 Compare December 9, 2024 20:07
@tajila
Copy link
Contributor

tajila commented Dec 11, 2024

@gengchen please rebase these changes

@tajila tajila requested review from tajila and theresa-m December 11, 2024 14:44
@tajila
Copy link
Contributor

tajila commented Dec 11, 2024

@theresa-m please review these changes

@thallium thallium force-pushed the jfr-context-switch branch 2 times, most recently from 921b010 to 1f112d9 Compare December 11, 2024 19:42
Copy link
Contributor

@theresa-m theresa-m left a comment

Choose a reason for hiding this comment

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

Can you either document or point me toward more details for the expected behavior of ThreadContextSwitchRate?

runtime/vm/jfr.cpp Show resolved Hide resolved
runtime/vm/JFRChunkWriter.hpp Show resolved Hide resolved
entry->switchRate = threadContextSwitchRateData->switchRate;

index = _threadContextSwitchRateCount;
_threadContextSwitchRateCount += 1;

done:
return index;
Copy link
Contributor

Choose a reason for hiding this comment

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

Why does this method return a value? The result is not used.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is just to be consistent with the initial JFR code in case we need the result in the future.

Copy link
Contributor

Choose a reason for hiding this comment

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

This is just to be consistent with the initial JFR code in case we need the result in the future.

The old design required the return value for all events but this is no longer needed. You can remove it from this function and we can update the others in a separate PR.

runtime/vm/JFRConstantPoolTypes.cpp Show resolved Hide resolved
PORT_ACCESS_FROM_VMC(currentThread);
OMRPORT_ACCESS_FROM_J9PORT(PORTLIB);

uint64_t switches;
Copy link
Contributor

Choose a reason for hiding this comment

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

Please declare variables as the first line after the if statement.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I don't see a problem here?

Copy link
Contributor

Choose a reason for hiding this comment

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

Generally in vm code variable declarations go at the top to support old compilers. I see both patterns in this file so I'm not sure if that applies to cpp @tajila ?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Do you mean that the switches should be on top of port access?

Copy link
Contributor

Choose a reason for hiding this comment

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

Yes.

Copy link
Contributor

Choose a reason for hiding this comment

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

Generally in vm code variable declarations go at the top to support old compilers. I see both patterns in this file so I'm not sure if that applies to cpp

This does not apply to C++ files. Due to legacy C rules (C89 and before), certain platforms will emit a warning (and error out because of warnings-as-errors) if C code has blocks wherein there are executable statements before variable declarations. From C99 and on, this was no longer a rule, but a convention for C code.

In C++, on the other hand, it is encouraged to declare variables close to the first use; there is no restriction/danger to declaring them anywhere in the block, provided they are declared before they are used of course.

Some VM C++ code looks like C code because it once was. But we don't need to restrict ourselves to legacy C standards going forward with C++.

All that being said, this is still technically valid C since the macros PORT_ACCESS_FROM_VMC and OMRPORT_ACCESS_FROM_J9PORT expand to variable declarations anyways.

However, we should be initializing all variables with an explicit value, which is missing from this line.

@thallium
Copy link
Contributor Author

Can you either document or point me toward more details for the expected behavior of ThreadContextSwitchRate?

See https://sap.github.io/SapMachine/jfrevents/21.html#threadcontextswitchrate, basically it outputs the rate of context switches in the OS.

@thallium thallium force-pushed the jfr-context-switch branch 2 times, most recently from 162aafd to 389cd85 Compare December 12, 2024 15:23
Copy link
Contributor

@theresa-m theresa-m left a comment

Choose a reason for hiding this comment

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

Looks good to me except one spacing issue.

runtime/vm/JFRConstantPoolTypes.cpp Outdated Show resolved Hide resolved
PORT_ACCESS_FROM_VMC(currentThread);
OMRPORT_ACCESS_FROM_J9PORT(PORTLIB);

uint64_t switches;
Copy link
Contributor

Choose a reason for hiding this comment

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

Generally in vm code variable declarations go at the top to support old compilers. I see both patterns in this file so I'm not sure if that applies to cpp @tajila ?

runtime/vm/JFRChunkWriter.hpp Show resolved Hide resolved
@tajila
Copy link
Contributor

tajila commented Jan 2, 2025

jenkins test sanity xlinux jdk17

@tajila
Copy link
Contributor

tajila commented Jan 2, 2025

jenkins test sanity alinux64 jdk21

@tajila
Copy link
Contributor

tajila commented Jan 2, 2025

jenkins compile win jdk8

@tajila tajila merged commit 4c82e0a into eclipse-openj9:master Jan 3, 2025
8 of 10 checks passed
@@ -719,6 +722,7 @@ initializeJFR(J9JavaVM *vm, BOOLEAN lateInit)

vm->jfrState.prevSysCPUTime.timestamp = -1;
vm->jfrState.prevProcTimestamp = -1;
vm->jfrState.prevContextSwitchTimestamp = -1;
Copy link
Contributor

Choose a reason for hiding this comment

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

This should explicitly initialize prevContextSwitches (or have a comment explaining why that's not necessary).

Comment on lines +1012 to +1017
if (-1 == jfrState->prevContextSwitchTimestamp) {
jfrEvent->switchRate = 0;
} else {
int64_t timeDelta = currentTime - jfrState->prevContextSwitchTimestamp;
jfrEvent->switchRate = ((double)(switches - jfrState->prevContextSwitches) / timeDelta) * 1e9;
}
Copy link
Contributor

Choose a reason for hiding this comment

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

This should either use float or have an explicit cast to float (the type of switchRate).

thallium added a commit to thallium/openj9 that referenced this pull request Jan 3, 2025
- explicitly initialize prevContextSwitches
- calculate switchRate with float

Related: eclipse-openj9#20725
Signed-off-by: Gengchen Tuo <[email protected]>
thallium added a commit to thallium/openj9 that referenced this pull request Jan 6, 2025
- explicitly initialize prevContextSwitches
- calculate switchRate with float

Related: eclipse-openj9#20725
Signed-off-by: Gengchen Tuo <[email protected]>
thallium added a commit to thallium/openj9 that referenced this pull request Jan 7, 2025
- explicitly initialize prevContextSwitches
- calculate switchRate with float

Related: eclipse-openj9#20725
Signed-off-by: Gengchen Tuo <[email protected]>
h3110n3rv3 pushed a commit to h3110n3rv3/openj9 that referenced this pull request Jan 9, 2025
- explicitly initialize prevContextSwitches
- calculate switchRate with float

Related: eclipse-openj9#20725
Signed-off-by: Gengchen Tuo <[email protected]>
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