-
Notifications
You must be signed in to change notification settings - Fork 395
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
prov/efa: Add unit tests for reordering messages in receive window
Signed-off-by: Jessie Yang <[email protected]>
- Loading branch information
Showing
4 changed files
with
165 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,155 @@ | ||
/* SPDX-License-Identifier: BSD-2-Clause OR GPL-2.0-only */ | ||
/* SPDX-FileCopyrightText: Copyright Amazon.com, Inc. or its affiliates. All rights reserved. */ | ||
|
||
#include "efa_unit_tests.h" | ||
|
||
/** | ||
* @brief Test efa_rdm_peer_reorder_msg | ||
* | ||
* @param resource efa_resource | ||
* | ||
*/ | ||
void test_efa_rdm_peer_reorder_msg_impl(struct efa_resource *resource, | ||
u_int32_t exp_msg_id, u_int32_t msg_id, | ||
int expected_ret) | ||
{ | ||
struct efa_rdm_ep *efa_rdm_ep; | ||
struct efa_rdm_peer *peer; | ||
struct efa_ep_addr raw_addr; | ||
fi_addr_t addr; | ||
struct efa_rdm_pke *pkt_entry; | ||
struct efa_unit_test_eager_rtm_pkt_attr pkt_attr = {0}; | ||
size_t raw_addr_len = sizeof(raw_addr); | ||
int ret; | ||
|
||
efa_rdm_ep = container_of(resource->ep, struct efa_rdm_ep, | ||
base_ep.util_ep.ep_fid); | ||
|
||
/* Create and register a fake peer */ | ||
ret = fi_getname(&resource->ep->fid, &raw_addr, &raw_addr_len); | ||
assert_int_equal(ret, 0); | ||
raw_addr.qpn = 1; | ||
raw_addr.qkey = 0x1234; | ||
ret = fi_av_insert(resource->av, &raw_addr, 1, &addr, 0 /* flags */, NULL /* context */); | ||
assert_int_equal(ret, 1); | ||
peer = efa_rdm_ep_get_peer(efa_rdm_ep, addr); | ||
assert_non_null(peer); | ||
ofi_recvwin_buf_alloc(&peer->robuf, efa_env.recvwin_size); | ||
dlist_init(&peer->overflow_pke_list); | ||
|
||
pkt_entry = efa_rdm_pke_alloc(efa_rdm_ep, efa_rdm_ep->efa_rx_pkt_pool, | ||
EFA_RDM_PKE_FROM_EFA_RX_POOL); | ||
assert_non_null(pkt_entry); | ||
efa_rdm_ep->efa_rx_pkts_posted = efa_rdm_ep_get_rx_pool_size(efa_rdm_ep); | ||
|
||
pkt_attr.msg_id = msg_id; | ||
pkt_attr.connid = raw_addr.qkey; | ||
/* Packet type must be >= EFA_RDM_REQ_PKT_BEGIN */ | ||
efa_unit_test_eager_msgrtm_pkt_construct(pkt_entry, &pkt_attr); | ||
|
||
(&peer->robuf)->exp_msg_id = exp_msg_id; | ||
ret = efa_rdm_peer_reorder_msg(peer, efa_rdm_ep, pkt_entry); | ||
assert_int_equal(ret, expected_ret); | ||
(&peer->robuf)->exp_msg_id = 0; | ||
} | ||
|
||
void test_efa_rdm_peer_reorder_expected_msg_id(struct efa_resource **state) { | ||
struct efa_resource *resource = *state; | ||
u_int32_t msg_id, exp_msg_id; | ||
int expected_ret; | ||
|
||
efa_unit_test_resource_construct(resource, FI_EP_RDM); | ||
|
||
msg_id = 0; | ||
exp_msg_id = 0; | ||
expected_ret = 0; | ||
/* Receiving expected message id should return 0 */ | ||
test_efa_rdm_peer_reorder_msg_impl(resource, exp_msg_id, msg_id, expected_ret); | ||
} | ||
|
||
|
||
void test_efa_rdm_peer_reorder_smaller_msg_id(struct efa_resource **state) { | ||
struct efa_resource *resource = *state; | ||
u_int32_t msg_id, exp_msg_id; | ||
int expected_ret; | ||
|
||
efa_unit_test_resource_construct(resource, FI_EP_RDM); | ||
|
||
msg_id = 1; | ||
exp_msg_id = 10; | ||
expected_ret = -FI_EALREADY; | ||
/* Receiving message id smaller than expected should return -FI_EALREADY */ | ||
test_efa_rdm_peer_reorder_msg_impl(resource, exp_msg_id, msg_id, expected_ret); | ||
} | ||
|
||
void test_efa_rdm_peer_reorder_larger_msg_id(struct efa_resource **state) { | ||
struct efa_resource *resource = *state; | ||
u_int32_t msg_id, exp_msg_id; | ||
int expected_ret; | ||
|
||
efa_unit_test_resource_construct(resource, FI_EP_RDM); | ||
|
||
msg_id = 1; | ||
exp_msg_id = 0; | ||
expected_ret = 1; | ||
/* Receiving message id larger than expected should return 1 */ | ||
test_efa_rdm_peer_reorder_msg_impl(resource, exp_msg_id, msg_id, expected_ret); | ||
} | ||
|
||
void test_efa_rdm_peer_reorder_overflow_msg_id(struct efa_resource **state) { | ||
struct efa_resource *resource = *state; | ||
struct efa_rdm_peer_overflow_pke_list_entry *overflow_pke_list_entry; | ||
struct efa_rdm_pke *overflow_pkt_entry; | ||
struct dlist_entry *tmp; | ||
u_int32_t msg_id; | ||
|
||
efa_unit_test_resource_construct(resource, FI_EP_RDM); | ||
|
||
struct efa_rdm_ep *efa_rdm_ep; | ||
struct efa_rdm_peer *peer; | ||
struct efa_ep_addr raw_addr; | ||
fi_addr_t addr; | ||
struct efa_rdm_pke *pkt_entry; | ||
struct efa_unit_test_eager_rtm_pkt_attr pkt_attr = {0}; | ||
size_t raw_addr_len = sizeof(raw_addr); | ||
int ret; | ||
|
||
efa_rdm_ep = container_of(resource->ep, struct efa_rdm_ep, | ||
base_ep.util_ep.ep_fid); | ||
|
||
/* Create and register a fake peer */ | ||
ret = fi_getname(&resource->ep->fid, &raw_addr, &raw_addr_len); | ||
assert_int_equal(ret, 0); | ||
raw_addr.qpn = 1; | ||
raw_addr.qkey = 0x1234; | ||
ret = fi_av_insert(resource->av, &raw_addr, 1, &addr, 0 /* flags */, NULL /* context */); | ||
assert_int_equal(ret, 1); | ||
peer = efa_rdm_ep_get_peer(efa_rdm_ep, addr); | ||
assert_non_null(peer); | ||
ofi_recvwin_buf_alloc(&peer->robuf, efa_env.recvwin_size); | ||
dlist_init(&peer->overflow_pke_list); | ||
|
||
pkt_entry = efa_rdm_pke_alloc(efa_rdm_ep, efa_rdm_ep->efa_rx_pkt_pool, | ||
EFA_RDM_PKE_FROM_EFA_RX_POOL); | ||
assert_non_null(pkt_entry); | ||
efa_rdm_ep->efa_rx_pkts_posted = efa_rdm_ep_get_rx_pool_size(efa_rdm_ep); | ||
|
||
pkt_attr.msg_id = 16384; | ||
pkt_attr.connid = raw_addr.qkey; | ||
/* Packet type must be >= EFA_RDM_REQ_PKT_BEGIN */ | ||
efa_unit_test_eager_msgrtm_pkt_construct(pkt_entry, &pkt_attr); | ||
|
||
(&peer->robuf)->exp_msg_id = 0; | ||
ret = efa_rdm_peer_reorder_msg(peer, efa_rdm_ep, pkt_entry); | ||
/* Overflow message should be put in the overflow_pke_list and return 1 */ | ||
assert_int_equal(ret, 1); | ||
assert_int_equal(efa_unit_test_get_dlist_length(&peer->overflow_pke_list), 1); | ||
dlist_foreach_container_safe ( | ||
&peer->overflow_pke_list, | ||
struct efa_rdm_peer_overflow_pke_list_entry, | ||
overflow_pke_list_entry, entry, tmp) { | ||
overflow_pkt_entry = overflow_pke_list_entry->pkt_entry; | ||
msg_id = ((struct efa_rdm_rtm_base_hdr *) overflow_pkt_entry->wiredata)->msg_id; | ||
assert_int_equal(msg_id, 16384); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters