Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp1215111imm; Fri, 12 Oct 2018 13:57:12 -0700 (PDT) X-Google-Smtp-Source: ACcGV61SxI0qzA67jKQpVHS7oKeMo1F1cFZwbRdDdq1ToUogQnyQ81eTPgjTPbqvWoNhRsjizT/Z X-Received: by 2002:a17:902:6b82:: with SMTP id p2-v6mr7399580plk.50.1539377832896; Fri, 12 Oct 2018 13:57:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539377832; cv=none; d=google.com; s=arc-20160816; b=Iup82IhuVqSTTfuZmAvhjDnBfiTN2EKuTox1c/G+OawPqmNzQnkhAJRCN/2HE3iVVP SPsx4D3k0FoniBzXz9dJIKr/xj+dp1cjT8ZA14pS1b3VNPiNTUJBenuYIEsNKP0E9wxi SDtYN2lddsC+IKLjPkt+2a45hlHGQxbVMuYoSkH+Ib3sOBZ/2rnhYm36cSZZdYWXZkOv Co1kmtZahZA+pyEMIufv6hR+T1Kx0WqdIuqWaQ3idD76uQ9Rt8bg6+OD+HYeSff2Tvvt 6ql1j6RhHpuMZSfuxXOIj5NiYqHjw0VjwneDCLALn/+75jeKNaYixtGtKbk68N2iweZY lfIw== 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=LZMa1jl8JpAlo6g0MZgB45dHxkKyifikJWAkKyQeCoQ=; b=LlMQS8AKPeIubgi9gYZ/8CNL/62/bMnb7SH1vS7+VYdIjY+ulcHEBSxo2HVmMC4hhh wOWcOE+y4t43P22reXW52+jmxl5VZ24AY8pBhRn72wT3iicdsyblD7hodAb4bHIsX9E1 /yKHN6spxS72oUhOpVMynB94RY9uJP5kBPNe+1TXHgLDOPpvdbjVe0/iwrTz5f4/FQKj jyYsxhyerCEuK8UO2lZIOXLRh4/Q+p3wAR/o61BExl63jyJW9Cn2ybcguWCtljn1GaSX MN4dV8EFZc6oVZ4d5HD6FcLX9xhbqCXaBEEXCwMRMguIGxEXzSoFMLdII3zSiE28P0n7 JsRg== 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 u27-v6si2491286pfk.82.2018.10.12.13.56.57; Fri, 12 Oct 2018 13:57:12 -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 S1726231AbeJMEap (ORCPT + 99 others); Sat, 13 Oct 2018 00:30:45 -0400 Received: from a2nlsmtp01-03.prod.iad2.secureserver.net ([198.71.225.37]:51402 "EHLO a2nlsmtp01-03.prod.iad2.secureserver.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725743AbeJMEap (ORCPT ); Sat, 13 Oct 2018 00:30:45 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with ESMTP id B4T0gPGYLwkZtB4T0gO6oq; Fri, 12 Oct 2018 13:55:26 -0700 x-originating-ip: 107.180.71.197 Received: from haiyangz by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1gB4T0-00065N-7G; Fri, 12 Oct 2018 13:55:26 -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,v2] hv_netvsc: fix vf serial matching with pci slot info Date: Fri, 12 Oct 2018 20:55:15 +0000 Message-Id: <20181012205515.23355-1-haiyangz@linuxonhyperv.com> X-Mailer: git-send-email 2.18.0 Reply-To: haiyangz@microsoft.com X-CMAE-Envelope: MS4wfKEzHapas58IyylVXkAXOeOYnXFsWfI5FveW+kReS9CZHMx4wSz+haycsIPtav0PIr3NDIcgoqFv7Ub+o7Gya+Nso4BrgriMj1fiZHYDTC+oRdTwFLt6 Tu3LtPE7TKjh2d4eO8IzCp2kviFjv6QR9160/AfGVXGootvqPTDk668e1s7h9mWdY5gfAfs4OXW+YHjzXRIsMELWOdQ45XRzC+1LUv/heZyO3pOTnw/peWJD OpiqZOShG/rJdnD0zXLzDbO+uPLncmw0a+zDqdcR8+7PtP7OTI7X1Qqb0oJHrSNYE+WN3WCkfaRRdwEuBNUUlHjjG/rJSbjudcK3v0yR0Tt95QE+zbyvLYy5 KVshvCvrfocEONtAihG9pNgNFwqzUoVxR0buFQ/jFsphtgQXkR/8vPxBdJkRq5T569nZUUY4JmD3Tp7X/Lo2RM4axWD+QAI0VcRU0ulXsrhqGpYQ2HEdzitc XLJaYKAHbnL7P8xRhabPxuq4Owti1HfMsjVNbg== 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..ded623862003 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(kobject_name(&pdev->slot->kobj), 10, &serial)) { + netdev_notice(vf_netdev, "Invalid vf serial:%s\n", + pdev->slot->kobj.name); + 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