Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp4287214imm; Mon, 15 Oct 2018 12:08:06 -0700 (PDT) X-Google-Smtp-Source: ACcGV618+gee5B89KW9doz6fRLA+l+3hIiX2F670mdHqL33hp+7Lv7VQXoSBRYo7q3Y7XKHQr5oS X-Received: by 2002:a17:902:103:: with SMTP id 3-v6mr18297552plb.58.1539630486336; Mon, 15 Oct 2018 12:08:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539630486; cv=none; d=google.com; s=arc-20160816; b=BbHdTVVDHmfPJgNn0IHnipdl3Zl05qA3QS7eG3SdmJR+K6luAv3n8glftdFBSB73t9 KzyRDX1oc44BT7rbfue8arsoXP1NniQk8/ugwan6lw+Ry1MTguSSQUxBYSInk+P2q+tK 754j+Fn+vf/esKGh/+u2O67L2IPHCW88cg6wkWy3VbyEmEV3p0SHeC9RJS5SGl/kcZ1b dUol2VnpKg7nqOsyHFNexOFSCfjmRrGaamJw3HLRzowJmFYZ/f72N3gD14xZMpl0RXg9 GXh/DZ09umgCniFjRX30yyLLN/jHH+62QZnrHErSlsayo5D7rphmhC8dy1suUAquWvFn iMtQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:reply-to:message-id:date:subject:cc:to :from; bh=MQkxDw507U/e5MVwYZVBlt+IV3VJjV09lNAgHPVcSLo=; b=a2loA1q7jc2Mnyb7UGIjyz9wHORot4LIp5f98GUbjutZIHSWOERK31eYj5MazJgC2M c1k7SqfN2UzT0aVXGzC8aYi95hMgxuVn4M1BQlUsE9Yd4gvJXk2n+vz6TnikDXc1esQ4 Mt9APg0Z/qxcq8isov/sNCwNls5+bbcm9b+yBmlAAyss+tSSBgYJOsJWwRunaIqD2Itx FFb5lpuX1SIZJ0XhfxldBKLpi0L9dP+rLY2yqAlr9uS62Gs/2B20czViwIpW1/soTu0v TC8/AA/yBZaAmG9YPk5+dR2q+/NAlaoBUPLU52S3xr6T/GbOHchJb+htgWpGm/9Km/Aa 5kDQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 142-v6si11311982pga.540.2018.10.15.12.07.50; Mon, 15 Oct 2018 12:08:06 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726927AbeJPCx6 (ORCPT + 99 others); Mon, 15 Oct 2018 22:53:58 -0400 Received: from a2nlsmtp01-03.prod.iad2.secureserver.net ([198.71.225.37]:60302 "EHLO a2nlsmtp01-03.prod.iad2.secureserver.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726719AbeJPCx6 (ORCPT ); Mon, 15 Oct 2018 22:53:58 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with ESMTP id C8C7gCss9wkZtC8C7g25D5; Mon, 15 Oct 2018 12:06:24 -0700 x-originating-ip: 107.180.71.197 Received: from haiyangz by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1gC8C7-0007yf-NO; Mon, 15 Oct 2018 12:06:23 -0700 From: Haiyang Zhang To: davem@davemloft.net, netdev@vger.kernel.org Cc: haiyangz@microsoft.com, kys@microsoft.com, sthemmin@microsoft.com, olaf@aepfle.de, vkuznets@redhat.com, devel@linuxdriverproject.org, linux-kernel@vger.kernel.org Subject: [PATCH net-next,v3] hv_netvsc: fix vf serial matching with pci slot info Date: Mon, 15 Oct 2018 19:06:15 +0000 Message-Id: <20181015190615.30628-1-haiyangz@linuxonhyperv.com> X-Mailer: git-send-email 2.18.0 Reply-To: haiyangz@microsoft.com X-CMAE-Envelope: MS4wfIVdSSeCnp+/h3mrNYRpq7qOQN0bz2f1R5JENVGGNEjfq+YnZ1LalclIw9cxA6TBpbkyOTAjFk4G+iwRg4l3ia7IfvIaUoguxqFIqF//fgkldrrxJJOg mIAfwSGPV4UXzOg6OrC5x+QKFb/LBzLLTFbIFS4jHSZPyaQ/AFyijMx/6DuSA5n4B4dhg70GF5y4lpD2hDqOOyGPgK2FJF7b9LgC071iVedX5l7U1KbxL+Lm AreuxZheOsbyUMy+QL89hWcfdub73tC0BRtZ7hMIBljlNlAaR57dWQUSaZXFPtU/kBZhjaaV5vt9vAfholnRLHHicBC3prw9o1iYqJlV9kkVgAiPRyHX9H8B bqASbzuK79egWslL7DRW5/2Xh1vyttblTTbXXKbqliXqOIx1Bi00h/JJlsfUz8s1piO7cKpD9bMsco1pLWU7YCm7eemDvTWDeeyujZoJx6+SW4PajbQ2radA ogY9E4r6V6uGvfbNDaaj7zokCL/lUY/k5n+iag== Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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") Reported-by: Vitaly Kuznetsov 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..cf36e7ff3191 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(pci_slot_name(pdev->slot), 10, &serial)) { + netdev_notice(vf_netdev, "Invalid vf serial:%s\n", + pci_slot_name(pdev->slot)); + return NULL; + } + list_for_each_entry(ndev_ctx, &netvsc_dev_list, list) { if (!ndev_ctx->vf_alloc) continue; - if (ndev_ctx->vf_serial == pdev->slot->number) + if (ndev_ctx->vf_serial == serial) return hv_get_drvdata(ndev_ctx->device_ctx); } netdev_notice(vf_netdev, - "no netdev found for slot %u\n", pdev->slot->number); + "no netdev found for vf serial:%u\n", serial); return NULL; } -- 2.18.0