> -static int dsa_cpu_parse(struct device_node *port, u32 index, > - struct dsa_switch_tree *dst, > - struct dsa_switch *ds) > +static int _dsa_cpu_parse(struct dsa_switch_tree *dst, > + struct dsa_switch *ds, > + struct net_device *ethernet_dev, > + u32 index) > { > - struct net_device *ethernet_dev; > - struct device_node *ethernet; > - > - ethernet = of_parse_phandle(port, "ethernet", 0); > - if (!ethernet) > - return -EINVAL; > - > - ethernet_dev = of_find_net_device_by_node(ethernet); > - if (!ethernet_dev) > - return -EPROBE_DEFER; > -
Hi Florian You have just removed all the actual DT parsing. So i would give this a different name, and avoid the _ prefix. > +static int _dsa_register_switch_legacy(struct dsa_switch *ds, struct > device_node *np) > +{ We might want to call this _dsa_register_switch_legacy_sf2, since the code only supports what is needed for your rather odd sf2 binding. It does not appear to work for the generic DSA binding. > static int __dsa_register_switch(struct dsa_switch *ds, struct device_node > *np) > { > struct device_node *ports = dsa_get_ports(ds, np); > @@ -626,8 +736,8 @@ static int _dsa_register_switch(struct dsa_switch *ds, > struct device_node *np) > { > struct device_node *ports = dsa_get_ports(ds, np); > > - if (IS_ERR(ports)) > - return PTR_ERR(ports); > + if (IS_ERR(ports) && PTR_ERR(ports) == -EINVAL) > + return _dsa_register_switch_legacy(ds, np); Maybe put this inside if config_enabled(CONFIG_NET_DSA_BCM_SF2) {}? Andrew