RE: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot info
> -Original Message- > From: Greg KH > Sent: Friday, October 12, 2018 2:36 AM > To: Haiyang Zhang > Cc: da...@davemloft.net; net...@vger.kernel.org; o...@aepfle.de; Stephen > Hemminger ; linux-ker...@vger.kernel.org; > de...@linuxdriverproject.org; vkuznets > Subject: Re: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot > info > > On Thu, Oct 11, 2018 at 08:14:34PM +, Haiyang Zhang wrote: > > From: Haiyang Zhang > > > > The VF device's serial number is saved as a string in PCI slot's kobj > > name, not the slot->number. This patch corrects the netvsc driver, so > > the VF device can be successfully paired with synthetic NIC. > > > > Fixes: 00d7ddba1143 ("hv_netvsc: pair VF based on serial number") > > Signed-off-by: Haiyang Zhang > > --- > > drivers/net/hyperv/netvsc_drv.c | 15 +++ > > 1 file changed, 11 insertions(+), 4 deletions(-) > > > > diff --git a/drivers/net/hyperv/netvsc_drv.c > > b/drivers/net/hyperv/netvsc_drv.c index 9bcaf204a7d4..8121ce34a39f > > 100644 > > --- a/drivers/net/hyperv/netvsc_drv.c > > +++ b/drivers/net/hyperv/netvsc_drv.c > > @@ -2030,14 +2030,15 @@ static void netvsc_vf_setup(struct work_struct > *w) > > rtnl_unlock(); > > } > > > > -/* Find netvsc by VMBus serial number. > > - * The PCI hyperv controller records the serial number as the slot. > > +/* Find netvsc by VF serial number. > > + * The PCI hyperv controller records the serial number as the slot kobj > > name. > > */ > > static struct net_device *get_netvsc_byslot(const struct net_device > > *vf_netdev) { > > struct device *parent = vf_netdev->dev.parent; > > struct net_device_context *ndev_ctx; > > struct pci_dev *pdev; > > + u32 serial; > > > > if (!parent || !dev_is_pci(parent)) > > return NULL; /* not a PCI device */ @@ -2048,16 +2049,22 > @@ static > > struct net_device *get_netvsc_byslot(const struct net_device *vf_netdev) > > return NULL; > > } > > > > + if (kstrtou32(pdev->slot->kobj.name, 10, &serial)) { > > kobject_name()? > > And that feels _very_ fragile to me. This is now an api that you are > guaranteeing will never change? Thanks for the suggestion -- I will update it to use kobject_name() to access the name. For stability, the VF NIC's serial numbers are always unique according to the Hyper-V documents. Other devices may have same numbers, but they are not handled by netvsc driver. Thanks, - Haiyang ___ devel mailing list de...@linuxdriverproject.org http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel
Re: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot info
On Thu, Oct 11, 2018 at 08:14:34PM +, Haiyang Zhang wrote: > From: Haiyang Zhang > > The VF device's serial number is saved as a string in PCI slot's > kobj name, not the slot->number. This patch corrects the netvsc > driver, so the VF device can be successfully paired with synthetic > NIC. > > Fixes: 00d7ddba1143 ("hv_netvsc: pair VF based on serial number") > Signed-off-by: Haiyang Zhang > --- > drivers/net/hyperv/netvsc_drv.c | 15 +++ > 1 file changed, 11 insertions(+), 4 deletions(-) > > diff --git a/drivers/net/hyperv/netvsc_drv.c b/drivers/net/hyperv/netvsc_drv.c > index 9bcaf204a7d4..8121ce34a39f 100644 > --- a/drivers/net/hyperv/netvsc_drv.c > +++ b/drivers/net/hyperv/netvsc_drv.c > @@ -2030,14 +2030,15 @@ static void netvsc_vf_setup(struct work_struct *w) > rtnl_unlock(); > } > > -/* Find netvsc by VMBus serial number. > - * The PCI hyperv controller records the serial number as the slot. > +/* Find netvsc by VF serial number. > + * The PCI hyperv controller records the serial number as the slot kobj name. > */ > static struct net_device *get_netvsc_byslot(const struct net_device > *vf_netdev) > { > struct device *parent = vf_netdev->dev.parent; > struct net_device_context *ndev_ctx; > struct pci_dev *pdev; > + u32 serial; > > if (!parent || !dev_is_pci(parent)) > return NULL; /* not a PCI device */ > @@ -2048,16 +2049,22 @@ static struct net_device *get_netvsc_byslot(const > struct net_device *vf_netdev) > return NULL; > } > > + if (kstrtou32(pdev->slot->kobj.name, 10, &serial)) { kobject_name()? And that feels _very_ fragile to me. This is now an api that you are guaranteeing will never change? Good luck with that! greg k-h ___ devel mailing list de...@linuxdriverproject.org http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel
RE: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot info
Haiyang Zhang writes: >> -Original Message- >> From: Haiyang Zhang >> Sent: Thursday, October 11, 2018 4:15 PM >> To: da...@davemloft.net; net...@vger.kernel.org >> Cc: Haiyang Zhang ; KY Srinivasan >> ; Stephen Hemminger ; >> o...@aepfle.de; vkuznets ; >> de...@linuxdriverproject.org; linux-ker...@vger.kernel.org >> Subject: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot >> info >> >> From: Haiyang Zhang >> >> The VF device's serial number is saved as a string in PCI slot's kobj name, >> not >> the slot->number. This patch corrects the netvsc driver, so the VF device >> can be >> successfully paired with synthetic NIC. >> >> Fixes: 00d7ddba1143 ("hv_netvsc: pair VF based on serial number") >> Signed-off-by: Haiyang Zhang > > Thanks Stephen for the reminder -- I added the "reported-by" here: > > Reported-by: Vitaly Kuznetsov Thanks) The difference in the hack I sent to Stephen was that instead of using kstrtou32() and checking the return value I opted for snprintf() and doing strncmp(). -- Vitaly ___ devel mailing list de...@linuxdriverproject.org http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel
RE: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot info
> -Original Message- > From: Haiyang Zhang > Sent: Thursday, October 11, 2018 4:15 PM > To: da...@davemloft.net; net...@vger.kernel.org > Cc: Haiyang Zhang ; KY Srinivasan > ; Stephen Hemminger ; > o...@aepfle.de; vkuznets ; > de...@linuxdriverproject.org; linux-ker...@vger.kernel.org > Subject: [PATCH net-next] hv_netvsc: fix vf serial matching with pci slot info > > From: Haiyang Zhang > > The VF device's serial number is saved as a string in PCI slot's kobj name, > not > the slot->number. This patch corrects the netvsc driver, so the VF device can > be > successfully paired with synthetic NIC. > > Fixes: 00d7ddba1143 ("hv_netvsc: pair VF based on serial number") > Signed-off-by: Haiyang Zhang Thanks Stephen for the reminder -- I added the "reported-by" here: Reported-by: Vitaly Kuznetsov ___ devel mailing list de...@linuxdriverproject.org http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel