rds: rds_rm_zerocopy_callback() correct order for list_add_tail()
[ Upstream commit 68762148d1b011d47bc2ceed7321739b5aea1e63 ]
rds_rm_zerocopy_callback() uses list_add_tail() with swapped
arguments. This links the list head with the new entry, losing
the references to the remaining part of the list.
Fixes: 9426bbc6de
("rds: use list structure to track information for zerocopy completion notification")
Suggested-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Pietro Borrello <borrello@diag.uniroma1.it>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
291e6a6820
commit
8c1447495f
@ -118,7 +118,7 @@ static void rds_rm_zerocopy_callback(struct rds_sock *rs,
|
|||||||
ck = &info->zcookies;
|
ck = &info->zcookies;
|
||||||
memset(ck, 0, sizeof(*ck));
|
memset(ck, 0, sizeof(*ck));
|
||||||
WARN_ON(!rds_zcookie_add(info, cookie));
|
WARN_ON(!rds_zcookie_add(info, cookie));
|
||||||
list_add_tail(&q->zcookie_head, &info->rs_zcookie_next);
|
list_add_tail(&info->rs_zcookie_next, &q->zcookie_head);
|
||||||
|
|
||||||
spin_unlock_irqrestore(&q->lock, flags);
|
spin_unlock_irqrestore(&q->lock, flags);
|
||||||
/* caller invokes rds_wake_sk_sleep() */
|
/* caller invokes rds_wake_sk_sleep() */
|
||||||
|
Loading…
Reference in New Issue
Block a user