mirror of
https://github.com/torvalds/linux.git
synced 2026-06-08 14:42:37 +02:00
xsk: avoid store-tearing when assigning umem
[ Upstream commit9764f4b301] The umem member of struct xdp_sock is read outside of the control mutex, in the mmap implementation, and needs a WRITE_ONCE to avoid potential store-tearing. Acked-by: Jonathan Lemon <jonathan.lemon@gmail.com> Fixes:423f38329d("xsk: add umem fill queue support and mmap") Signed-off-by: Björn Töpel <bjorn.topel@intel.com> Signed-off-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
c31ead3c88
commit
43a8075419
|
|
@ -454,7 +454,7 @@ static int xsk_bind(struct socket *sock, struct sockaddr *addr, int addr_len)
|
|||
}
|
||||
|
||||
xdp_get_umem(umem_xs->umem);
|
||||
xs->umem = umem_xs->umem;
|
||||
WRITE_ONCE(xs->umem, umem_xs->umem);
|
||||
sockfd_put(sock);
|
||||
} else if (!xs->umem || !xdp_umem_validate_queues(xs->umem)) {
|
||||
err = -EINVAL;
|
||||
|
|
@ -534,7 +534,7 @@ static int xsk_setsockopt(struct socket *sock, int level, int optname,
|
|||
|
||||
/* Make sure umem is ready before it can be seen by others */
|
||||
smp_wmb();
|
||||
xs->umem = umem;
|
||||
WRITE_ONCE(xs->umem, umem);
|
||||
mutex_unlock(&xs->mutex);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user