2
0
mirror of https://github.com/edk2-porting/linux-next.git synced 2025-01-04 03:33:58 +08:00

mctp: Allow MCTP on tun devices

Allowing TUN is useful for testing, to route packets to userspace or to
tunnel between machines.

Signed-off-by: Matt Johnston <matt@codeconstruct.com.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Matt Johnston 2021-09-29 15:26:05 +08:00 committed by David S. Miller
parent 7c2dcfa295
commit f364dd71d9
2 changed files with 13 additions and 7 deletions

View File

@ -356,9 +356,12 @@ static int mctp_register(struct net_device *dev)
if (rtnl_dereference(dev->mctp_ptr)) if (rtnl_dereference(dev->mctp_ptr))
return 0; return 0;
/* only register specific types; MCTP-specific and loopback for now */ /* only register specific types (inc. NONE for TUN devices) */
if (dev->type != ARPHRD_MCTP && dev->type != ARPHRD_LOOPBACK) if (!(dev->type == ARPHRD_MCTP ||
dev->type == ARPHRD_LOOPBACK ||
dev->type == ARPHRD_NONE)) {
return 0; return 0;
}
mdev = mctp_add_dev(dev); mdev = mctp_add_dev(dev);
if (IS_ERR(mdev)) if (IS_ERR(mdev))

View File

@ -821,13 +821,18 @@ static int mctp_pkttype_receive(struct sk_buff *skb, struct net_device *dev,
struct net_device *orig_dev) struct net_device *orig_dev)
{ {
struct net *net = dev_net(dev); struct net *net = dev_net(dev);
struct mctp_dev *mdev;
struct mctp_skb_cb *cb; struct mctp_skb_cb *cb;
struct mctp_route *rt; struct mctp_route *rt;
struct mctp_hdr *mh; struct mctp_hdr *mh;
/* basic non-data sanity checks */ rcu_read_lock();
if (dev->type != ARPHRD_MCTP) mdev = __mctp_dev_get(dev);
rcu_read_unlock();
if (!mdev) {
/* basic non-data sanity checks */
goto err_drop; goto err_drop;
}
if (!pskb_may_pull(skb, sizeof(struct mctp_hdr))) if (!pskb_may_pull(skb, sizeof(struct mctp_hdr)))
goto err_drop; goto err_drop;
@ -841,9 +846,7 @@ static int mctp_pkttype_receive(struct sk_buff *skb, struct net_device *dev,
goto err_drop; goto err_drop;
cb = __mctp_cb(skb); cb = __mctp_cb(skb);
rcu_read_lock(); cb->net = READ_ONCE(mdev->net);
cb->net = READ_ONCE(__mctp_dev_get(dev)->net);
rcu_read_unlock();
rt = mctp_route_lookup(net, cb->net, mh->dest); rt = mctp_route_lookup(net, cb->net, mh->dest);
if (!rt) if (!rt)