]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commit
net: do not keep the dst cache when uncloning an skb dst and its metadata
authorAntoine Tenart <atenart@kernel.org>
Mon, 7 Feb 2022 17:13:18 +0000 (18:13 +0100)
committerStefan Bader <stefan.bader@canonical.com>
Thu, 14 Apr 2022 09:32:05 +0000 (11:32 +0200)
commitef0009afbd9114c66a46a441802583766877b320
treefdbd6fc0d63ae60af2992a5d72e857a45a9bacdd
parentd96f84cc1bfb53c2639bd639c9557031bb4b51a7
net: do not keep the dst cache when uncloning an skb dst and its metadata

BugLink: https://bugs.launchpad.net/bugs/1966118
[ Upstream commit cfc56f85e72f5b9c5c5be26dc2b16518d36a7868 ]

When uncloning an skb dst and its associated metadata a new dst+metadata
is allocated and the tunnel information from the old metadata is copied
over there.

The issue is the tunnel metadata has references to cached dst, which are
copied along the way. When a dst+metadata refcount drops to 0 the
metadata is freed including the cached dst entries. As they are also
referenced in the initial dst+metadata, this ends up in UaFs.

In practice the above did not happen because of another issue, the
dst+metadata was never freed because its refcount never dropped to 0
(this will be fixed in a subsequent patch).

Fix this by initializing the dst cache after copying the tunnel
information from the old metadata to also unshare the dst cache.

Fixes: d71785ffc7e7 ("net: add dst_cache to ovs vxlan lwtunnel")
Cc: Paolo Abeni <pabeni@redhat.com>
Reported-by: Vlad Buslov <vladbu@nvidia.com>
Tested-by: Vlad Buslov <vladbu@nvidia.com>
Signed-off-by: Antoine Tenart <atenart@kernel.org>
Acked-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
include/net/dst_metadata.h