Commit 1c9043ae authored by Mustafa Ismail's avatar Mustafa Ismail Committed by Jason Gunthorpe

RDMA/irdma: Fix possible crash due to NULL netdev in notifier

For some net events in irdma_net_event notifier, the netdev can be NULL
which will cause a crash in rdma_vlan_dev_real_dev.  Fix this by moving
all processing to the NETEVENT_NEIGH_UPDATE case where the netdev is
guaranteed to not be NULL.

Fixes: 6702bc14 ("RDMA/irdma: Fix netdev notifications for vlan's")
Link: https://lore.kernel.org/r/20220425181703.1634-4-shiraz.saleem@intel.comSigned-off-by: default avatarMustafa Ismail <mustafa.ismail@intel.com>
Signed-off-by: default avatarShiraz Saleem <shiraz.saleem@intel.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent 2df6d895
...@@ -258,18 +258,16 @@ int irdma_net_event(struct notifier_block *notifier, unsigned long event, ...@@ -258,18 +258,16 @@ int irdma_net_event(struct notifier_block *notifier, unsigned long event,
u32 local_ipaddr[4] = {}; u32 local_ipaddr[4] = {};
bool ipv4 = true; bool ipv4 = true;
switch (event) {
case NETEVENT_NEIGH_UPDATE:
real_dev = rdma_vlan_dev_real_dev(netdev); real_dev = rdma_vlan_dev_real_dev(netdev);
if (!real_dev) if (!real_dev)
real_dev = netdev; real_dev = netdev;
ibdev = ib_device_get_by_netdev(real_dev, RDMA_DRIVER_IRDMA); ibdev = ib_device_get_by_netdev(real_dev, RDMA_DRIVER_IRDMA);
if (!ibdev) if (!ibdev)
return NOTIFY_DONE; return NOTIFY_DONE;
iwdev = to_iwdev(ibdev); iwdev = to_iwdev(ibdev);
switch (event) {
case NETEVENT_NEIGH_UPDATE:
p = (__be32 *)neigh->primary_key; p = (__be32 *)neigh->primary_key;
if (neigh->tbl->family == AF_INET6) { if (neigh->tbl->family == AF_INET6) {
ipv4 = false; ipv4 = false;
...@@ -290,13 +288,12 @@ int irdma_net_event(struct notifier_block *notifier, unsigned long event, ...@@ -290,13 +288,12 @@ int irdma_net_event(struct notifier_block *notifier, unsigned long event,
irdma_manage_arp_cache(iwdev->rf, neigh->ha, irdma_manage_arp_cache(iwdev->rf, neigh->ha,
local_ipaddr, ipv4, local_ipaddr, ipv4,
IRDMA_ARP_DELETE); IRDMA_ARP_DELETE);
ib_device_put(ibdev);
break; break;
default: default:
break; break;
} }
ib_device_put(ibdev);
return NOTIFY_DONE; return NOTIFY_DONE;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment