Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1680034ybl; Thu, 19 Dec 2019 00:53:08 -0800 (PST) X-Google-Smtp-Source: APXvYqzgHs20QjfJM3zNXd/XuVFuDslzrsmHDcvKzhA5/tcROqdoOO7nh/0TcB5GBOf3KLfmMbBN X-Received: by 2002:a9d:66c1:: with SMTP id t1mr6655405otm.73.1576745588606; Thu, 19 Dec 2019 00:53:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1576745588; cv=none; d=google.com; s=arc-20160816; b=lXwq4n3jCVUY/GmlZWhv0xGYjb/nHK7vZ16rvl1ZFeOlSPhHZ2VM53EiISBHmbS8Og jAZ2fdGOompavVHfw+veetd7RI6aybdkIXKaXmfVFlLjIAXN60YS0/yOjjCQteRqvul+ P3mDtewQ8wm2g4cCdGDNW3F70LIXT0wdVJAc8k+2+KtlNnETgbaB7bAcQtCP1M3qCffE rPu53iHp3U/5bTZKgG1UPfeKGl8qvkFpdG2kmChffdbRezlNVWIHK7TPQi1AHGUqTKED RwthUbTd40rm6UlyjAXjIIWev1LIDfWMlKMuweJxBD4qlGveHTvA/vOrhJ04bTFeT73G TOMw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=MMRt837GZHR6iSeApBy+QvfglbevqG194kfwcSJd9N0=; b=QcnAh1+5RZ/tZ6bfVMtuDwzvQmLiJFqGXVeLAGeoqNukR+VO6/GP7Z+CR4wOLPcIgV AyusyhPLDhncQTCKmADiRJF6xWazDlUCZ/WC6RlVLYw+bi9Xafln0T/53S6KidN+sx6/ ZPkgfTjnIBEG9e4PoBz4x7b7iQzJ1yRKO0UI5OSkmrEMzAnTppw4LCBvuSBh9zhvyeT4 k3w7s569mln5bgxKwSbHBPjKEokkif9HLtRPwmauAZWtgXN5P65qZb+x9Y5FBU5xvNMM RsOBHD33mN+dQuUP4fkElWtafCiScWcApBUQmdz6/sgcRxoIwTNsgODHQz/2OcVZU8Y5 yZSA== 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 e1si2835833oie.168.2019.12.19.00.52.57; Thu, 19 Dec 2019 00:53:08 -0800 (PST) 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 S1726719AbfLSIvp (ORCPT + 99 others); Thu, 19 Dec 2019 03:51:45 -0500 Received: from szxga06-in.huawei.com ([45.249.212.32]:51196 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726591AbfLSIvp (ORCPT ); Thu, 19 Dec 2019 03:51:45 -0500 Received: from DGGEMS412-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id E1C6F1B3979B511D2B53; Thu, 19 Dec 2019 16:51:42 +0800 (CST) Received: from [127.0.0.1] (10.184.52.56) by DGGEMS412-HUB.china.huawei.com (10.3.19.212) with Microsoft SMTP Server id 14.3.439.0; Thu, 19 Dec 2019 16:51:35 +0800 Subject: Re: [PATCH v2] PCI: Add quirk for HiSilicon NP 5896 devices To: Bjorn Helgaas CC: , , , LKML , , , References: <20191218142831.GA101587@google.com> From: Xiongfeng Wang Message-ID: <03ef3686-2cbb-8495-bf5a-f6927ad25179@huawei.com> Date: Thu, 19 Dec 2019 16:51:34 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <20191218142831.GA101587@google.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.184.52.56] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019/12/18 22:28, Bjorn Helgaas wrote: > On Wed, Dec 18, 2019 at 05:16:03PM +0800, Xiongfeng Wang wrote: >> On 2019/12/11 12:10, Bjorn Helgaas wrote: >>> On Tue, Dec 10, 2019 at 9:28 PM Xiongfeng Wang >>> wrote: >>>> On 2019/12/7 2:10, Bjorn Helgaas wrote: >>>>> On Fri, Dec 06, 2019 at 03:01:45PM +0800, Xiongfeng Wang wrote: >>>>>> HiSilicon PCI Network Processor 5896 devices misreport the >>>>>> class type as 'NOT_DEFINED', but it is actually a network >>>>>> device. Also the size of BAR3 is reported as 265T, but this BAR >>>>>> is actually unused. This patch modify the class type to >>>>>> 'CLASS_NETWORK' and disable the unused BAR3. > >>>>> The question is not whether the BAR is used by the driver; the >>>>> question is whether the device responds to accesses to the >>>>> region described by the BAR when PCI_COMMAND_MEMORY is turned >>>>> on. >>>> >>>> I asked the hardware engineer. He said I can not write an address >>>> into that BAR. >>> >>> If the BAR is not writable, I think sizing should fail, so I >>> suspect some of the bits are actually writable. >> >> Sorry for the delayed response. It's not so convenient for me to get >> to the hardware guys. BAR0 BAR1 BAR2 are 32-bit and can be used to >> access the registers and memory within 5896 devices. These three >> BARs can meet the need for most scenario. BAR3 is 64-bit and can be >> used to access all the registers and memory within 5896 devices. >> (BAR3 is writable. Sorry for the non-confirmed information before.) >> But BAR3 is not used by the driver and the size is very >> large(larger than 100G, still didn't get the precise size). So I >> think maybe we can disable this BAR for now, otherwise the >> unassigned resource will cause 'pci_enable_device()' returning >> failure. > > Here's the problem: the proposed patch (below) clears the struct > resource corresponding to BAR 3, but that doesn't actually disable the > BAR. It hides the BAR from Linux, so Linux will pretend it doesn't > exist, but it's still there in the hardware. > > The hardware BAR 3 still contains some value (possibly zero), and if > PCI_COMMAND_MEMORY is set (which you need to do if you want to use > *any* memory BARs on the device), the device will respond to any > transactions in the BAR 3 range. Depending on the topology and all > the other BAR and window assignments, this may cause address > conflicts. Yes, there does exist this problem. I will check it with the hardware engineers. Thanks. > > + * HiSilicon NP 5896 devices BAR3 size is reported as 256T and causes problem > + * when assigning the resources. But this BAR is actually unused by the driver, > + * so let's disable it. > + */ > +static void quirk_hisi_fixup_np_bar(struct pci_dev *pdev) > +{ > + struct resource *r = &pdev->resource[3]; > + > + r->start = 0; > + r->end = 0; > + r->flags = 0; > + > + pci_info(pdev, "Disabling invalid BAR 3\n"); > > . >