Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp248864rwn; Fri, 16 Sep 2022 19:41:00 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4CAeslJt22n7rcUcjFFUyoT3BzEV60OFgVp0FmKsIsWVjs9IPb2angP54fAnYF7OiHu6z+ X-Received: by 2002:a17:907:6d90:b0:77c:6b3d:bec3 with SMTP id sb16-20020a1709076d9000b0077c6b3dbec3mr5346996ejc.445.1663382460427; Fri, 16 Sep 2022 19:41:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663382460; cv=none; d=google.com; s=arc-20160816; b=zhS21PmouQkYUEAouZSH7IYtvNGC/vGiy+lbp/S7rgbFkopBGPVbOZCwGTDPl8ujjk LByiDGJ0ZyoJMv9+SUNVcqOTulX3e+4769PF/K2qvOLc8srxPYZPhvxsYqxndnKaSKR7 j4wutGDwXvHGVBABgQEfE8c+xhWsNfc425c/H+W5Z2uzyuaWfGJVfCTKadhgdNXdIr6/ PvghhB6dZGjXvKLslNcuQ3ZLDpTn9d+ThrtOaFP++MXkBGwcH6+65OmJ90FKT71nSEYc MvNMJ07cq2tkrEnoX6Nk++ZRNvtptP8ifSd+9IZYfNIgWyO7YGuDivhJ0w3PINDAckCe gYcA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=wd/X4Q/HuSE2Qw+DWpdqC419UdWHX1hpD68aLZRzuDU=; b=NKgkgiTF2oNgKvhnTTbSOlneppTbfWDx+61ThPm8q8SMqRUvLl2fVja0DUFsQx3udq 9nFb9CbT0pZr5rbCLozpgYlnz+u9XwqoTzfLGSwN5KdrN/Agmg27AQCN40w7OxhBaoJ/ TpfaF+VFXfjPxFsPMtKI+ZbFFUSH9Zl+UShOFJx7SoxvYUfjh+kruETU/TNQTJAY6szw ++p0eKqHKkuezgH1BTq0R9uLpX3WO1mZ9ewUtUp5hy1EQ69dSk9+77DivNqlfuy5U+Tr 5W4MOOarbDQ2FCTheRANIxcUteeYS9dvsP2EIafd/Ay75HOJmZjH53UOeMlkMkytXZOq mJVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=RGWKbMrG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g15-20020a1709065d0f00b0077f92be81aasi13405941ejt.379.2022.09.16.19.40.34; Fri, 16 Sep 2022 19:41:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=RGWKbMrG; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229498AbiIQCX4 (ORCPT + 99 others); Fri, 16 Sep 2022 22:23:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60858 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229379AbiIQCXy (ORCPT ); Fri, 16 Sep 2022 22:23:54 -0400 Received: from mail-oa1-x2d.google.com (mail-oa1-x2d.google.com [IPv6:2001:4860:4864:20::2d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 958295B055; Fri, 16 Sep 2022 19:23:53 -0700 (PDT) Received: by mail-oa1-x2d.google.com with SMTP id 586e51a60fabf-12c8312131fso4437847fac.4; Fri, 16 Sep 2022 19:23:53 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date; bh=wd/X4Q/HuSE2Qw+DWpdqC419UdWHX1hpD68aLZRzuDU=; b=RGWKbMrGnY8V0rdijnisOslZ8dfMhFRiMvrdYKckLFGgeAsMNgg58mmw29UDNQKiCl e3smoe2XxHNaVtdVcv8q8h+ceM3ekp/r2Idzwu62SUl/gIG7tMunDhPKR36vIRHPDWr0 95a+7bbz9dzCBCWRaUuv5Omr2hZOAZdtoYaNp4eNlTsL9pOdkoDJvmM6iI4C4azXT6yi XpwNVNOVDXSieFVAkRWYeO/dFqOpZ/0pkCcyEJr3LvIAuf7u3HO+gjY37nUw3MbrqyV1 ZqI6oQ4WoxyfucObfrFQiynr+aarN2G8gkCLwB9CE7SOO2MkdWh17Dk66dlaR5hE/CD2 wGdA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date; bh=wd/X4Q/HuSE2Qw+DWpdqC419UdWHX1hpD68aLZRzuDU=; b=LteSBflcf+B5asVFsuTpVIt8/d5Lph+BgvI4zbtnPggeC5w9a5x9oGYu0gPkRRsaQV R2jz7fAsRMRCcJnsV/Xwu4dDkeiJX6YwurqNnUCrKLGCVQDbQdw9RdBZY0FjFEWdQHb+ 1m67yR+17fGmin20QkavJ3Tgp3GqoR5tZc45o8s1t8q2mreRm+7m+zwW/fJ3KsjQhZeU dIbs56SeboiAyQpEy9uFc97Su0sqpJfoAMkAWd3ukU6yaGWf6mR30vFG08dIi7n8Wr7k DEsEM4CrAhI1F+O3laveIFgTE/FnebH/5QFot1u1elwhpAAzqCY2u26vs4Aw9xMnPRVn rwOQ== X-Gm-Message-State: ACrzQf1lGkLjjZIgB120t8odR6RFu+QY4Y8NkcAQzvfpCHZ2qnmejyii yNax3nxxrsOGZfaXHH2baV0= X-Received: by 2002:a05:6870:6314:b0:10b:9595:62db with SMTP id s20-20020a056870631400b0010b959562dbmr4401943oao.128.1663381432901; Fri, 16 Sep 2022 19:23:52 -0700 (PDT) Received: from ?IPV6:2600:1700:2442:6db0:90c9:b1c1:5c9e:9030? ([2600:1700:2442:6db0:90c9:b1c1:5c9e:9030]) by smtp.gmail.com with ESMTPSA id h12-20020a056870538c00b0012757d4e556sm3994792oan.48.2022.09.16.19.23.51 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 16 Sep 2022 19:23:52 -0700 (PDT) Message-ID: Date: Fri, 16 Sep 2022 21:23:51 -0500 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.11.0 Subject: Re: [PATCH RFC 0/2] Generate device tree node for pci devices Content-Language: en-US To: Lizhi Hou , linux-pci@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, robh@kernel.org, helgaas@kernel.org Cc: clement.leger@bootlin.com, max.zhen@amd.com, sonal.santan@amd.com, larry.liu@amd.com, brian.xu@amd.com, stefano.stabellini@xilinx.com, trix@redhat.com References: <1661809417-11370-1-git-send-email-lizhi.hou@amd.com> <1d9faa2e-e3fc-d104-c85f-4035233848d6@gmail.com> <78211af5-171c-ef4f-a8c2-17f63dc479bc@gmail.com> <8bee1ddd-0a84-62cd-9beb-3bbb09d83de1@amd.com> From: Frank Rowand In-Reply-To: <8bee1ddd-0a84-62cd-9beb-3bbb09d83de1@amd.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham 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 9/13/22 16:02, Lizhi Hou wrote: > > On 9/13/22 10:41, Frank Rowand wrote: >> On 9/13/22 12:10, Lizhi Hou wrote: >>> On 9/13/22 00:00, Frank Rowand wrote: >>>> On 8/29/22 16:43, Lizhi Hou wrote: >>>>> This patch series introduces OF overlay support for PCI devices which >>>>> primarily addresses two use cases. First, it provides a data driven method >>>>> to describe hardware peripherals that are present in a PCI endpoint and >>>>> hence can be accessed by the PCI host. An example device is Xilinx/AMD >>>>> Alveo PCIe accelerators. Second, it allows reuse of a OF compatible >>>>> driver -- often used in SoC platforms -- in a PCI host based system. An >>>>> example device is Microchip LAN9662 Ethernet Controller. >>>>> >>>>> This patch series consolidates previous efforts to define such an >>>>> infrastructure: >>>>> https://lore.kernel.org/lkml/20220305052304.726050-1-lizhi.hou@xilinx.com/ >>>>> https://lore.kernel.org/lkml/20220427094502.456111-1-clement.leger@bootlin.com/ >>>>> >>>>> Normally, the PCI core discovers PCI devices and their BARs using the >>>>> PCI enumeration process. However, the process does not provide a way to >>>>> discover the hardware peripherals that are present in a PCI device, and >>>>> which can be accessed through the PCI BARs. Also, the enumeration process >>>>> does not provide a way to associate MSI-X vectors of a PCI device with the >>>>> hardware peripherals that are present in the device. PCI device drivers >>>>> often use header files to describe the hardware peripherals and their >>>>> resources as there is no standard data driven way to do so. This patch >>>>> series proposes to use flattened device tree blob to describe the >>>>> peripherals in a data driven way. Based on previous discussion, using >>>>> device tree overlay is the best way to unflatten the blob and populate >>>>> platform devices. To use device tree overlay, there are three obvious >>>>> problems that need to be resolved. >>>>> >>>>> First, we need to create a base tree for non-DT system such as x86_64. A >>>>> patch series has been submitted for this: >>>>> https://lore.kernel.org/lkml/20220624034327.2542112-1-frowand.list@gmail.com/ >>>>> https://lore.kernel.org/lkml/20220216050056.311496-1-lizhi.hou@xilinx.com/ >>>>> >>>>> Second, a device tree node corresponding to the PCI endpoint is required >>>>> for overlaying the flattened device tree blob for that PCI endpoint. >>>>> Because PCI is a self-discoverable bus, a device tree node is usually not >>>>> created for PCI devices. This series adds support to generate a device >>>>> tree node for a PCI device which advertises itself using PCI quirks >>>>> infrastructure. >>>>> >>>>> Third, we need to generate device tree nodes for PCI bridges since a child >>>>> PCI endpoint may choose to have a device tree node created. >>>>> >>>>> This patch series is made up of two patches. >>>>> >>>>> The first patch is adding OF interface to allocate an OF node. It is copied >>>>> from: >>>>> https://lore.kernel.org/lkml/20220620104123.341054-5-clement.leger@bootlin.com/ >>>>> >>>>> The second patch introduces a kernel option, CONFIG_PCI_OF. When the option >>>>> is turned on, the kernel will generate device tree nodes for all PCI >>>>> bridges unconditionally. The patch also shows how to use the PCI quirks >>>>> infrastructure, DECLARE_PCI_FIXUP_FINAL to generate a device tree node for >>>>> a device. Specifically, the patch generates a device tree node for Xilinx >>>>> Alveo U50 PCIe accelerator device. The generated device tree nodes do not >>>>> have any property. Future patches will add the necessary properties. >>>>> >>>>> Clément Léger (1): >>>>>     of: dynamic: add of_node_alloc() >>>>> >>>>> Lizhi Hou (1): >>>>>     pci: create device tree node for selected devices >>>>> >>>>>    drivers/of/dynamic.c        |  50 +++++++++++++---- >>>>>    drivers/pci/Kconfig         |  11 ++++ >>>>>    drivers/pci/bus.c           |   2 + >>>>>    drivers/pci/msi/irqdomain.c |   6 +- >>>>>    drivers/pci/of.c            | 106 ++++++++++++++++++++++++++++++++++++ >>>>>    drivers/pci/pci-driver.c    |   3 +- >>>>>    drivers/pci/pci.h           |  16 ++++++ >>>>>    drivers/pci/quirks.c        |  11 ++++ >>>>>    drivers/pci/remove.c        |   1 + >>>>>    include/linux/of.h          |   7 +++ >>>>>    10 files changed, 200 insertions(+), 13 deletions(-) >>>>> >>>> The patch description leaves out the most important piece of information. >>>> >>>> The device located at the PCI endpoint is implemented via FPGA >>>>      - which is programmed after Linux boots (or somewhere late in the boot process) >>>>         - (A) and thus can not be described by static data available pre-boot because >>>>               it is dynamic (and the FPGA program will often change while the Linux >>>>               kernel is already booted >>>>         - (B) can be described by static data available pre-boot because the FPGA >>>>               program will always be the same for this device on this system >>>> >>>> I am not positive what part of what I wrote above is correct and would appreciate >>>> some confirmation of what is correct or incorrect. >>> There are 2 series devices rely on this patch: >>> >>>      1) Xilinx Alveo Accelerator cards (FPGA based device) >>> >>>      2) lan9662 PCIe card >>> >>>            please see: https://lore.kernel.org/lkml/20220427094502.456111-1-clement.leger@bootlin.com/ >> Thanks.  Please include this information in future versions of the patch series. >> >> For device 2 I have strongly recommended using pre-boot apply of the overlay to the base >> device tree.  I realize that this suggestion is only a partial solution if one wants to >> use hotplug to change system configuration (as opposed to using hotplug only to replace >> an existing device (eg a broken device) with another instance of the same device).  I >> also realize that this increased the system administration overhead.  On the other hand >> an overlay based solution is likely to be fragile and possibly flaky. > Can you clarify the pre-boot apply approach? How will it work for PCI devices? >> >>> For Xilinx Alveo device, it is (A). The FPGA partitions can be programmed dynamically after boot. >> I looked at the Xilinx Alveo web page, and there are a variety of types of Alveo cards >> available.  So the answer to my next question may vary by type of card. >> >> Is it expected that the fpga program on a given card will change frequently (eg multiple >> times per day), where the changed program results in a new device that would require a >> different hardware description in the device tree? > > Different images may be loaded to a FPGA partition several times a > day. The PCI topology (Device IDs, BARs, MSIx, etc) does not change. > New IPs may appear (and old IPs may disappear) on the BARs when a new > image is loaded. We would like to use flattened device tree to > describe the IPs on the BARs. That was kind of a non-answer. I know that images _may_ change at some frequency. I was trying to get a sense of whether the images were _likely_ to be changing on a frequent basis for these types of boards, or whether frequent image changes are likely to be a rare edge use case. If there is a good design for the 99.999% use case that does not support the 0.001% use case then it may be better to not create an inferior design that also supports the 0.001% use case. I hope that gives a better idea of the reason why I was asking the question and how the answer could impact design and implementation decisions. As a point of reference, some other fpga users have indicated a desire to change images many times per second. The current driver and overlay architecture did not seem to me to be a good match to that use case (depending on the definition of "many"). -Frank > > Thanks, > > Lizhi > >> >> Or is the fpga program expected to change on an infrequent basis (eg monthly, quarterly, >> annually), in the same way as device firmware and operating systems are updated on a regular >> basis for bug fixes and new functionality? >> >> >>> >>> Thanks, >>> >>> Lzhi >>> >>>> -Frank