diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c index 9fc9aed6ca9a756c695eb4a96ee601d6d3c28626..410415ec918e8914bc316e4fb34bf9fc3040ac65 100644 --- a/drivers/net/vxlan.c +++ b/drivers/net/vxlan.c @@ -2460,6 +2460,8 @@ static void vxlan_uninit(struct net_device *dev) { struct vxlan_dev *vxlan = netdev_priv(dev); + gro_cells_destroy(&vxlan->gro_cells); + vxlan_fdb_delete_default(vxlan, vxlan->cfg.vni); free_percpu(dev->tstats); @@ -3526,7 +3528,6 @@ static void vxlan_dellink(struct net_device *dev, struct list_head *head) vxlan_flush(vxlan, true); - gro_cells_destroy(&vxlan->gro_cells); list_del(&vxlan->next); unregister_netdevice_queue(dev, head); }