On Thu, Feb 09, 2023 at 10:56:26AM +0000, Paul Cercueil wrote: > This reverts commit 321b59870f850a10dbb211ecd2bd87b41497ea6f. > > This commit broke USB networking on Ingenic SoCs and maybe elsewhere. > The actual reason is unknown; and while a proper fix would be better, > we're sitting at -rc7 now, so a revert is justified - and we can work on > re-introducing this change for 6.3. > > Fixes: 321b59870f85 ("usb: gadget: u_ether: Do not make UDC parent of the net device") > Signed-off-by: Paul Cercueil <paul@xxxxxxxxxxxxxxx> > Cc: Sascha Hauer <s.hauer@xxxxxxxxxxxxxx> > Cc: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> > --- > drivers/usb/gadget/function/u_ether.c | 4 ++++ > 1 file changed, 4 insertions(+) Acked-by: Sascha Hauer <s.hauer@xxxxxxxxxxxxxx> Sascha > > diff --git a/drivers/usb/gadget/function/u_ether.c b/drivers/usb/gadget/function/u_ether.c > index 8f12f3f8f6ee..e06022873df1 100644 > --- a/drivers/usb/gadget/function/u_ether.c > +++ b/drivers/usb/gadget/function/u_ether.c > @@ -798,6 +798,7 @@ struct eth_dev *gether_setup_name(struct usb_gadget *g, > net->max_mtu = GETHER_MAX_MTU_SIZE; > > dev->gadget = g; > + SET_NETDEV_DEV(net, &g->dev); > SET_NETDEV_DEVTYPE(net, &gadget_type); > > status = register_netdev(net); > @@ -872,6 +873,8 @@ int gether_register_netdev(struct net_device *net) > struct usb_gadget *g; > int status; > > + if (!net->dev.parent) > + return -EINVAL; > dev = netdev_priv(net); > g = dev->gadget; > > @@ -902,6 +905,7 @@ void gether_set_gadget(struct net_device *net, struct usb_gadget *g) > > dev = netdev_priv(net); > dev->gadget = g; > + SET_NETDEV_DEV(net, &g->dev); > } > EXPORT_SYMBOL_GPL(gether_set_gadget); > > -- > 2.39.1 > > -- Pengutronix e.K. | | Steuerwalder Str. 21 | http://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |