Received: by 2002:a05:6a10:7420:0:0:0:0 with SMTP id hk32csp4395637pxb; Mon, 21 Feb 2022 20:11:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJytpIF/tyx8WkxtU63wIglqzl1NPscKY2qlg3o99b6AiJ+lfDctqoZjrPQOshh0B6PKKvOj X-Received: by 2002:a63:3301:0:b0:36c:9009:ec9b with SMTP id z1-20020a633301000000b0036c9009ec9bmr18147404pgz.395.1645503090793; Mon, 21 Feb 2022 20:11:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1645503090; cv=none; d=google.com; s=arc-20160816; b=t+mKt6mlTHMmdB+mNtFpPABl77aZFIWTtqChbBluJzBteDgsVpoKEPMu3ICxHRlMAv iBAKkNsxAvi/+ccxNJyUp/4pdVnhB8QTFh0/48Huf16gCy5uYpExiVFa4o7xv/QKsTPe zjYKPCzUeDwOHEh4dg+mDfAhT7tr5h/MHCYbza7enjMSMF2Zm8W7cZfZJYHXUocj9Dyj 7pYN7C601EfzpZWhx6vJqoLEmMzSEUDlGpwmErI5oW6LCkW4qhlu3k9IHZ3sJGP2hDFl /E9ilI6qWXycXmGeTMnnOKiTSMFoHImy0HCzndB1St129qMsMrca6zUxXWhsRd1PqxtT Osuw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:message-id :in-reply-to:subject:cc:to:from:date:dkim-signature; bh=flgmZRu/NpTqzFAZUQqKD2vg7b28/XeijttbaB5o2Hc=; b=H4ZNOsN6VWxNMyZW0RZCl+xXBbTS7ksXapodJxAKetg1XLYE0v8VgQD9a1FsemTXoL IYJTHx3vGPnowjBUdSu6lxko0GMZN/q8SX8cfpujE/435/gor/5kc0HvSQJuMiE7J0KC Php44ggPrp7e94+30zytZQBdhCK9h14sG3fmkw3yM8HqNW0qBaXVYKByta3usFSRq6f0 up1Pkid5YaOB2Gi1R57y/4ieo7er3a9V5jlul5WLfyVuq+Myn6grITrNEt0iwDln7upg LD8YoSm6kI+eesPBCEDK/ouof8dMnLcb8/ftKnecqxKLeNLzR8qB2LUVTWws5XnQClk8 s52A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=Sr33qjWx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id y7si15899166plp.365.2022.02.21.20.11.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 21 Feb 2022 20:11:30 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=Sr33qjWx; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id AF27F77A8C; Mon, 21 Feb 2022 20:11:20 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1381639AbiBURU6 (ORCPT + 99 others); Mon, 21 Feb 2022 12:20:58 -0500 Received: from mxb-00190b01.gslb.pphosted.com ([23.128.96.19]:51622 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1381645AbiBURUu (ORCPT ); Mon, 21 Feb 2022 12:20:50 -0500 Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id F3C14CFB; Mon, 21 Feb 2022 09:20:26 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1645464027; x=1677000027; h=date:from:to:cc:subject:in-reply-to:message-id: references:mime-version; bh=EldFeMO1JNlmFZXwAPC3sgE5GEkGvYBt67wpkTkIudo=; b=Sr33qjWxAPXhDIZjEIhYg7GsLhYFNA2b6Rt6mhIB/FcqWG41/l/rBSrH 6zOS5+kRYn8yLL07h5SXlmP0iUwOGVGIKPrEI24PxlANxZJ7ewfwPvr9b P/sNDB2nNQjm9RPmaZdAAqiG3iiWmM+Z4Oli3FDafBccWY7ZuKM2tZylo 02MYBo74JkB2b3HQ3hd6MqxiOIYxalPIo/b0S6jtX8epkM3jzGu0pt9sD L3E+TIM89eMAiWrTh/anKwhRd8tf/tp9mhW9a3LmbHHMqfgUoRZNnUv52 e+R/cWZDIQGYxup8UwRgZutd9wmJCVaSnYoNw+C6J5I2ZTrqjWJaGfJ2Y A==; X-IronPort-AV: E=McAfee;i="6200,9189,10265"; a="251497629" X-IronPort-AV: E=Sophos;i="5.88,386,1635231600"; d="scan'208";a="251497629" Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Feb 2022 09:20:26 -0800 X-IronPort-AV: E=Sophos;i="5.88,386,1635231600"; d="scan'208";a="627429277" Received: from rhweight-wrk1.ra.intel.com ([137.102.106.40]) by fmsmga003-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Feb 2022 09:20:25 -0800 Date: Mon, 21 Feb 2022 09:22:29 -0800 (PST) From: matthew.gerlach@linux.intel.com X-X-Sender: mgerlach@rhweight-WRK1 To: Tom Rix cc: "Zhang, Tianfei" , "Wu, Hao" , "mdf@kernel.org" , "Xu, Yilun" , "linux-fpga@vger.kernel.org" , "linux-doc@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "corbet@lwn.net" Subject: Re: [PATCH v1 3/7] fpga: dfl: Allow for ports with no local bar space. In-Reply-To: Message-ID: References: <20220214112619.219761-1-tianfei.zhang@intel.com> <20220214112619.219761-4-tianfei.zhang@intel.com> <0fdd3d0d-d280-8104-eccc-8fa8d8a992c2@redhat.com> User-Agent: Alpine 2.22 (DEB 394 2020-01-19) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 18 Feb 2022, Tom Rix wrote: > > On 2/17/22 11:31 PM, Zhang, Tianfei wrote: >> >>> -----Original Message----- >>> From: Tom Rix >>> Sent: Tuesday, February 15, 2022 11:06 PM >>> To: Zhang, Tianfei ; Wu, Hao ; >>> mdf@kernel.org; Xu, Yilun ; >>> linux-fpga@vger.kernel.org; >>> linux-doc@vger.kernel.org; linux-kernel@vger.kernel.org >>> Cc: corbet@lwn.net; Matthew Gerlach >>> Subject: Re: [PATCH v1 3/7] fpga: dfl: Allow for ports with no local bar >>> space. >>> >>> >>> On 2/14/22 3:26 AM, Tianfei zhang wrote: >>>> From: Matthew Gerlach >>>> >>>> From a fpga partial reconfiguration standpoint, a port may not be >>>> connected any local BAR space. The port could be connected to a >>>> different PCIe Physical Function (PF) or Virtual Function (VF), in >>>> which case another driver instance would manage the endpoint. >>> It is not clear if this is part of iofs or a bug fix. >> This is the new implementation/feature of IOFS. >> On IOFS support multiple methods to access the AFU. >> 1. Legacy Model. This is used for N3000 and N5000 card. >> In this model the entire AFU region is a unit of PR, and there is a Port >> device connected to this AFU. >> On DFL perspective, there is "Next AFU" point to the AFU, and the "BarID" >> is the PCIe Bar ID of AFU. >> In this model, we can use the AFU APIs to access the entire AFU resource, >> like MMIO. >> 2. Micro-Personas in AFU. >> IOFS intruding new model for PR and AFU access. >> Micro-Personas allow the RTL developer to designate their own AFU-defined >> PR regions. >> In this model the unit of PR is not the entire AFU, instead >> the unit of PR can be any size block or blocks inside the AFU. >> 3. Multiple VFs per PR slot. >> In this method, we can instance multiple VFs over SRIOV for one PR slot, >> and access the AFU resource >> by different VFs in virtualization usage. In this case, the Port device >> would not connected to AFU (the BarID of Port device >> should be set to invalid), so this patch want to support this use model. > > What I am looking for is how the older cards using (my term) dfl 1 will still > work with dfl 2 and vice versa. > > No where do I see a version check for dfl 2 nor a pci id check so either this > just works or backward compatibility has not be considered. > > Please add a backward compatibility section to the doc patch > >> >>>> Signed-off-by: Matthew Gerlach >>>> Signed-off-by: Tianfei Zhang >>>> --- >>>> drivers/fpga/dfl-pci.c | 8 ++++++++ >>>> 1 file changed, 8 insertions(+) >>>> >>>> diff --git a/drivers/fpga/dfl-pci.c b/drivers/fpga/dfl-pci.c index >>>> 4d68719e608f..8abd9b408403 100644 >>>> --- a/drivers/fpga/dfl-pci.c >>>> +++ b/drivers/fpga/dfl-pci.c >>>> @@ -243,6 +243,7 @@ static int find_dfls_by_default(struct pci_dev >>>> *pcidev, >>>> v = readq(base + FME_HDR_CAP); >>>> port_num = FIELD_GET(FME_CAP_NUM_PORTS, v); >>>> >>>> + dev_info(&pcidev->dev, "port_num = %d\n", port_num); >>>> WARN_ON(port_num > MAX_DFL_FPGA_PORT_NUM); >>>> >>>> for (i = 0; i < port_num; i++) { >>>> @@ -258,6 +259,13 @@ static int find_dfls_by_default(struct pci_dev >>>> *pcidev, >>>> */ >>>> bar = FIELD_GET(FME_PORT_OFST_BAR_ID, v); >>>> offset = FIELD_GET(FME_PORT_OFST_DFH_OFST, v); >>>> + if (bar >= PCI_STD_NUM_BARS) { >>> Is bar set to a better magic number that pci_std_num_bars ? maybe 0xff's >>> >>> How do you tell between this case and broken hw ? >> Yes, I agree that magic number is better, Currently the RTL using >> PCI_STD_NUM_BARS for an invalid PCIe bar number. > > How do you tell between this case and broken hw ? > > Tom The field, FME_PORT_OFST_BAR_ID, is a three bit field, which is pretty common for BARs on PCI. PCI_STD_NUM_BARS is defined as 6. Current HW implementations are filing this field with the value, 7, which is close to the suggestion of 0xff's. How about we define the following magic number? #define NO_LOCAL_PORT_BAR 7 We should also change the dev_info to be a dev_dbg and more precise to something like the following: if (bar == NO_LOCAL_PORT_BAR) { dev_dbg(&pcidev->dev, "No local port BAR space.\n"); continue; } > >>> Move up a line and skip getting an offset that will not be used. >> Yes, this line is not necessary, I will remove it on next version patch. >> >>>> + dev_info(&pcidev->dev, "skipping port without >>> local BAR space %d\n", >>>> + bar); >>>> + continue; >>>> + } else { >>>> + dev_info(&pcidev->dev, "BAR %d offset %u\n", >>> bar, offset); >>>> + } >>>> start = pci_resource_start(pcidev, bar) + offset; >>>> len = pci_resource_len(pcidev, bar) - offset; >>>> >>> Is similar logic needed for else-if (port) block below this ? >> I think, the else-if is not necessary. I will remove it on next version >> patch. >>> Tom > >