-
Notifications
You must be signed in to change notification settings - Fork 433
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
UCP/PROTO: Consider RNDV_PERF_DIFF #10401
base: master
Are you sure you want to change the base?
UCP/PROTO: Consider RNDV_PERF_DIFF #10401
Conversation
Test failures should be fixed with #10397. |
test/gtest/ucp/test_ucp_proto.cc
Outdated
@@ -717,6 +717,45 @@ UCS_TEST_F(test_proto_perf, intersect_first) | |||
expect_empty_range(5000, SIZE_MAX); | |||
} | |||
|
|||
UCS_TEST_F(test_proto_perf, apply_zero_bias) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just wondering if it makes sense to add a mock test with RNDV_PERF_DIFF
and make an assertion on selected protocols
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you mean remove this test, and add test case to test_ucp_proto_mock_rcx
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't insist on removing this test
But adding new test to test_ucp_proto_mock_rcx
looks like superior alternative, because we test the entire chain
src/ucp/rndv/proto_rndv.c
Outdated
@@ -403,6 +403,7 @@ static void ucp_proto_rndv_ctrl_variant_probe( | |||
cfg_thresh = remote_proto->cfg_thresh; | |||
} | |||
|
|||
ucp_proto_perf_apply_bias(perf, params->perf_bias); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems applying this bias leads to slightly different performance numbers and therefore breaks the mock test:
log1, log2, log3
Expected protocol:
{8247, 377094, "multi-frag copy-in"},
Actual protocol:
8247-363935 multi-frag copy-in
Could it be due to adding this bias? If so, we should update here the numbers in mock test as well
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, it is because of adding the bias. UCX selects rendezvous earlier with this changes.
In fact none of the test failure can be fixed by that PR. They are triggered by changed perf calculation logic I guess |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for addressing my comments
Please note that there is approved PR for mock refactoring, that will be merged soon. You might need to slightly adapt mock test code
aaa08bd
to
db2470a
Compare
src/ucp/proto/proto_perf.c
Outdated
seg->perf_factors[factor_id] = perf_factor; | ||
if (ucs_linear_func_is_zero(perf_factor, UCP_PROTO_PERF_EPSILON)) { | ||
return; | ||
} | ||
|
||
ucp_proto_perf_node_update_data(seg->node, | ||
ucp_proto_perf_factor_names[factor_id], | ||
perf_factor); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this block seems very similar to ucp_proto_perf_node_update_factors body, can we unite common code?
src/ucp/proto/proto_perf.h
Outdated
* | ||
* @param [in] perf Performance data structure to update. | ||
* @param [in] func Function to apply to performance factors. | ||
* @param [in] title Title for performance node that would be created |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
name
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed.
9d291c6
to
5653bb2
Compare
5653bb2
to
8d06777
Compare
What?
Applies
UCX_RNDV_PERF_DIFF
setting effect for protov2.Cherry-picked from #10292.
Why?
This control effect was removed during introducing perf-factors logic. This PR brings it back.
That how it looks like with that patch: