summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeremy Kerr <jk@codeconstruct.com.au>2025-07-02 14:20:11 +0800
committerPaolo Abeni <pabeni@redhat.com>2025-07-08 12:39:24 +0200
commit4a1de053d7f0940936f6602ad53fe077bb10ff7f (patch)
tree51023fcbe9195220f85b8354a6f8f442a9f016e0
parent48e6aa60bf281e86372d174d96fb1147f02743b3 (diff)
net: mctp: remove routes by netid, not by device
In upcoming changes, a route may not have a device associated. Since the route is matched on the (network, eid) tuple, pass the netid itself into mctp_route_remove. Signed-off-by: Jeremy Kerr <jk@codeconstruct.com.au> Link: https://patch.msgid.link/20250702-dev-forwarding-v5-11-1468191da8a4@codeconstruct.com.au Signed-off-by: Paolo Abeni <pabeni@redhat.com>
-rw-r--r--net/mctp/route.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/net/mctp/route.c b/net/mctp/route.c
index 66395f782759..f96265acf16f 100644
--- a/net/mctp/route.c
+++ b/net/mctp/route.c
@@ -1085,6 +1085,11 @@ out_release:
return rc;
}
+static unsigned int mctp_route_netid(struct mctp_route *rt)
+{
+ return rt->dev->net;
+}
+
/* route management */
static int mctp_route_add(struct net *net, struct mctp_dev *mdev,
mctp_eid_t daddr_start, unsigned int daddr_extent,
@@ -1137,7 +1142,7 @@ static int mctp_route_add(struct net *net, struct mctp_dev *mdev,
return 0;
}
-static int mctp_route_remove(struct net *net, struct mctp_dev *mdev,
+static int mctp_route_remove(struct net *net, unsigned int netid,
mctp_eid_t daddr_start, unsigned int daddr_extent,
unsigned char type)
{
@@ -1154,7 +1159,7 @@ static int mctp_route_remove(struct net *net, struct mctp_dev *mdev,
ASSERT_RTNL();
list_for_each_entry_safe(rt, tmp, &net->mctp.routes, list) {
- if (rt->dev == mdev &&
+ if (mctp_route_netid(rt) == netid &&
rt->min == daddr_start && rt->max == daddr_end &&
rt->type == type) {
list_del_rcu(&rt->list);
@@ -1174,7 +1179,8 @@ int mctp_route_add_local(struct mctp_dev *mdev, mctp_eid_t addr)
int mctp_route_remove_local(struct mctp_dev *mdev, mctp_eid_t addr)
{
- return mctp_route_remove(dev_net(mdev->dev), mdev, addr, 0, RTN_LOCAL);
+ return mctp_route_remove(dev_net(mdev->dev), mdev->net,
+ addr, 0, RTN_LOCAL);
}
/* removes all entries for a given device */
@@ -1394,7 +1400,7 @@ static int mctp_delroute(struct sk_buff *skb, struct nlmsghdr *nlh,
if (rtm->rtm_type != RTN_UNICAST)
return -EINVAL;
- rc = mctp_route_remove(net, mdev, daddr_start, rtm->rtm_dst_len,
+ rc = mctp_route_remove(net, mdev->net, daddr_start, rtm->rtm_dst_len,
RTN_UNICAST);
return rc;
}