Message ID | 20231219174526.2235150-1-sunilvl@ventanamicro.com |
---|---|
Headers |
Return-Path: <linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:a05:7300:24d3:b0:fb:cd0c:d3e with SMTP id r19csp2109058dyi; Tue, 19 Dec 2023 09:46:49 -0800 (PST) X-Google-Smtp-Source: AGHT+IGiO5HAlDSwuENaJ6XvcZ0Me0yxtBuijZQXTqvPe/fK7fPGj17cRw1ZXXT35thtlqhTJ6Wz X-Received: by 2002:aa7:9308:0:b0:6cd:f3f4:56c9 with SMTP id cz8-20020aa79308000000b006cdf3f456c9mr1596996pfb.17.1703008009626; Tue, 19 Dec 2023 09:46:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1703008009; cv=none; d=google.com; s=arc-20160816; b=Netispm2fBNKb9Ky7okVY4lRpykcaksMyZv4PSLLDIqJyzLMBZ4yjofgOML0zjMs8W 9zq1qwyPCpykjO0SXSwDcBq/iR0gN1KZSC1eLbTJLv4NQEwNe8lmOXOyE261QKWPZs8P /7403/Y/wmF/fmB7QMXiqRerzv67UPeipZawsGAs83dX/5ssUBvAV4WuWAne4DH2XYXF sk21HzYhCSnwFhtaE05KLFrKsEa/L/R8btD6/znBdGDRbKkAvu30s6oQUJSt79v96Guw j0twr6J9LsIWUCocRYiWJcjxS83MxZIdVoaJoxIZgbm/VjD88aBOrjUmNcItcBIyH96r UsUg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=959oPX30wMegwb1RPQMugDw8tMBDjS9o+5BG/fh0FBc=; fh=G3MkS2cP7FkeH+7kxy0LRzNpJgfwnUWZciURRBohxGI=; b=b95OkyW08MNA5jh5tn636s+f0X2PucRPbAKbb/rK+y3/ug0HN41HWt8YqSR7tSDIlI tD0DhU1Ff0wTuLzy8oV0wWJ5DjOhfxONmBPv0YKdxgmKrjw4kXRTqTF/Ef0rYUM+CPZv gLcXSZ5IijNk6FKz/NYAEyfs3Fy+LGnaizhP1bG3RboGxTBG9wFEf1z3h37ZeL9WTwq8 JUZ4RRX7dbgQYZuhfXo+iB5pPJjI1Jby8g0fX5ytpmcXxUmB+9pT8/YpiFXv6Q6QyyVP pTBbDGW+P3hWyT2MhG4/5Wvlk2dv7iNdV26tD/s53uThdM7lEWX/dhZfHOhJaI7/R6Ci 3O8Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=G7zB6JWl; spf=pass (google.com: domain of linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org" Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id d27-20020a631d5b000000b005bd42f6085fsi19897783pgm.344.2023.12.19.09.46.49 for <ouuuleilei@gmail.com> (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Dec 2023 09:46:49 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=G7zB6JWl; spf=pass (google.com: domain of linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-5712-ouuuleilei=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 39AEBB249FC for <ouuuleilei@gmail.com>; Tue, 19 Dec 2023 17:46:03 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B453437870; Tue, 19 Dec 2023 17:45:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ventanamicro.com header.i=@ventanamicro.com header.b="G7zB6JWl" X-Original-To: linux-kernel@vger.kernel.org Received: from mail-pf1-f176.google.com (mail-pf1-f176.google.com [209.85.210.176]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9942F31755 for <linux-kernel@vger.kernel.org>; Tue, 19 Dec 2023 17:45:37 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ventanamicro.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ventanamicro.com Received: by mail-pf1-f176.google.com with SMTP id d2e1a72fcca58-6d411636a95so2188431b3a.0 for <linux-kernel@vger.kernel.org>; Tue, 19 Dec 2023 09:45:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1703007937; x=1703612737; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=959oPX30wMegwb1RPQMugDw8tMBDjS9o+5BG/fh0FBc=; b=G7zB6JWltfhL+hfXQnIoYIV5sdpPY+NymWT4cEZDWxG8smsr/mf30/SYfVLOwgI3Yt owzOlvbml8ubI6NOtbCYkIqtNyOIAPlnLsMN9dMWXRIxwfa07atBVyxlhnsEalS+BwZA BvxG1+W+j1aHpa/iPmIYp6/gFaB8iHCvuY/hShn1XA6h2bswKgkSkSQXRpVBJFo9dIQw Ug+t1q99ZddFCbaOzy18vvLjvWBj1hsYkvS0vnoTqMQiFZq/yIuBrGTiPALrBKTPMid4 E2Eup05wb3CbXFCNC+SxjJW/e7BD7PME0l7M8SUeeL6Veew4SbnUAF0twPL0piopkVsA D8NQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1703007937; x=1703612737; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=959oPX30wMegwb1RPQMugDw8tMBDjS9o+5BG/fh0FBc=; b=PldY0kOnc5dAxKxSIdphJkwQVswW8F4KFLyZXwMkPQCFJA4levp6LEhmXV3ZeB/Bsq p42NwqxpdZRi/m6tp1/Z2mOiJg57qLiiPfhBNcONT43om4JtqUaWp5Qhtzdtn1vg0GLe ZyrzhS5Kzhnwt5iTt4gYbc3X/Fe7Ids8HUIPCjQvAAbD1ENonayLCR3r0jATzQ8sOIuR dos7X6jD4kHg4W4IXK5AS/qbaXYPOLjVlQQaFFzvvigqN3sHtSr6VSFAnXRqQ48ktBBJ BdwMOTmnhKXzXSbuf1aqlzQmGK66lSieQUOikPSwWeCXzsc1z8dBdjYwHfMi480O58vV 6RIw== X-Gm-Message-State: AOJu0YxGW9IfL0ccHrKQ/uKXMAT+Lf+ch96F6A0y31+7qsOqAPHSuV40 z1qBI2Mp4XRjRHq3C02T/pv6DQ== X-Received: by 2002:a17:903:11d1:b0:1d0:6ffd:6117 with SMTP id q17-20020a17090311d100b001d06ffd6117mr1910887plh.57.1703007935507; Tue, 19 Dec 2023 09:45:35 -0800 (PST) Received: from sunil-pc.Dlink ([106.51.188.200]) by smtp.gmail.com with ESMTPSA id n16-20020a170903111000b001d3320f6143sm14453015plh.269.2023.12.19.09.45.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 19 Dec 2023 09:45:35 -0800 (PST) From: Sunil V L <sunilvl@ventanamicro.com> To: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, linux-acpi@vger.kernel.org, linux-pci@vger.kernel.org Cc: Catalin Marinas <catalin.marinas@arm.com>, Will Deacon <will@kernel.org>, Paul Walmsley <paul.walmsley@sifive.com>, Palmer Dabbelt <palmer@dabbelt.com>, Albert Ou <aou@eecs.berkeley.edu>, "Rafael J . Wysocki" <rafael@kernel.org>, Len Brown <lenb@kernel.org>, Anup Patel <anup@brainfault.org>, Thomas Gleixner <tglx@linutronix.de>, Bjorn Helgaas <bhelgaas@google.com>, Haibo Xu <haibo1.xu@intel.com>, Conor Dooley <conor.dooley@microchip.com>, Andrew Jones <ajones@ventanamicro.com>, =?utf-8?b?QmrDtnJuIFTDtnBlbA==?= <bjorn@kernel.org>, Marc Zyngier <maz@kernel.org>, Sunil V L <sunilvl@ventanamicro.com> Subject: [RFC PATCH v3 00/17] RISC-V: ACPI: Add external interrupt controller support Date: Tue, 19 Dec 2023 23:15:09 +0530 Message-Id: <20231219174526.2235150-1-sunilvl@ventanamicro.com> X-Mailer: git-send-email 2.39.2 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: <linux-kernel.vger.kernel.org> List-Subscribe: <mailto:linux-kernel+subscribe@vger.kernel.org> List-Unsubscribe: <mailto:linux-kernel+unsubscribe@vger.kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1785733326584484050 X-GMAIL-MSGID: 1785733326584484050 |
Series |
RISC-V: ACPI: Add external interrupt controller support
|
|
Message
Sunil V L
Dec. 19, 2023, 5:45 p.m. UTC
This series adds support for the below ECR approved by ASWG. 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing The series primarily enables irqchip drivers for RISC-V ACPI based platforms. The series can be broadly categorized like below. 1) PCI ACPI related functions are migrated from arm64 to common file so that we don't need to duplicate them for RISC-V. 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. This helps to support deferred probe of interrupt controller drivers. 3) Modified pnp_irq() to try registering the IRQ again if it sees it in disabled state. This solution is similar to how platform_get_irq_optional() works for regular platform devices. 4) Added support for re-ordering the probe of interrupt controllers when IRQCHIP_ACPI_DECLARE is used. 5) ACPI support added in RISC-V interrupt controller drivers. This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is not merged yet and first time introducing fw_devlink, deferred probe and reordering support for IRQCHIP probe, this series is still kept as RFC. Looking forward for the feedback! Changes since RFC v2: 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. 2) Dropped patches in drivers which are not required due to fw_devlink support. 3) Dropped pci_set_msi() patch and added a patch in pci_create_root_bus(). 4) Updated pnp_irq() patch so that none of the actual PNP drivers need to change. Changes since RFC v1: 1) Abandoned swnode approach as per Marc's feedback. 2) To cope up with AIA series changes which changed irqchip driver probe from core_initcall() to platform_driver, added patches to support deferred probing. 3) Rebased on top of Anup's AIA v11 and added tags. To test the series, 1) Qemu should be built using the riscv_acpi_b2_v8 branch at https://github.com/vlsunil/qemu.git 2) EDK2 should be built using the instructions at: https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md 3) Build Linux using this series on top of Anup's AIA v11 series. Run Qemu: qemu-system-riscv64 \ -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ -m 2G -smp 8 \ -serial mon:stdio \ -device virtio-gpu-pci -full-screen \ -device qemu-xhci \ -device usb-kbd \ -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ -kernel arch/riscv/boot/Image \ -initrd rootfs.cpio \ -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" To boot with APLIC only, use aia=aplic. To boot with PLIC, remove aia= option. This series is also available in acpi_b2_v3_riscv_aia_v11 branch at https://github.com/vlsunil/linux.git Based-on: 20231023172800.315343-1-apatel@ventanamicro.com (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) Sunil V L (17): arm64: PCI: Migrate ACPI related functions to pci-acpi.c RISC-V: ACPI: Implement PCI related functionality PCI: Make pci_create_root_bus() declare its reliance on MSI domains ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency ACPI: irq: Add support for deferred probe in acpi_register_gsi() pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP probe ACPI: RISC-V: Implement arch function to reorder irqchip probe entries irqchip: riscv-intc: Add ACPI support for AIA irqchip: riscv-imsic: Add ACPI support irqchip: riscv-aplic: Add ACPI support irqchip: irq-sifive-plic: Add ACPI support ACPI: bus: Add RINTC IRQ model for RISC-V ACPI: bus: Add acpi_riscv_init function ACPI: RISC-V: Create APLIC platform device ACPI: RISC-V: Create PLIC platform device irqchip: riscv-intc: Set ACPI irqmodel arch/arm64/kernel/pci.c | 191 --------------------- arch/riscv/Kconfig | 2 + arch/riscv/include/asm/irq.h | 46 +++++ arch/riscv/kernel/acpi.c | 31 ++-- drivers/acpi/bus.c | 4 + drivers/acpi/irq.c | 22 +++ drivers/acpi/property.c | 20 +++ drivers/acpi/riscv/Makefile | 2 +- drivers/acpi/riscv/init.c | 15 ++ drivers/acpi/riscv/init.h | 6 + drivers/acpi/riscv/irq.c | 169 ++++++++++++++++++ drivers/acpi/scan.c | 3 + drivers/irqchip/irq-riscv-aplic-direct.c | 21 ++- drivers/irqchip/irq-riscv-aplic-main.c | 64 ++++--- drivers/irqchip/irq-riscv-aplic-main.h | 1 + drivers/irqchip/irq-riscv-aplic-msi.c | 9 +- drivers/irqchip/irq-riscv-imsic-early.c | 52 +++++- drivers/irqchip/irq-riscv-imsic-platform.c | 51 ++++-- drivers/irqchip/irq-riscv-imsic-state.c | 128 +++++++------- drivers/irqchip/irq-riscv-imsic-state.h | 2 +- drivers/irqchip/irq-riscv-intc.c | 96 ++++++++++- drivers/irqchip/irq-sifive-plic.c | 76 ++++++-- drivers/pci/pci-acpi.c | 182 ++++++++++++++++++++ drivers/pci/probe.c | 1 + drivers/pnp/pnpacpi/core.c | 7 + include/linux/acpi.h | 18 ++ include/linux/irqchip/riscv-imsic.h | 10 ++ include/linux/pnp.h | 14 +- 28 files changed, 895 insertions(+), 348 deletions(-) create mode 100644 drivers/acpi/riscv/init.c create mode 100644 drivers/acpi/riscv/init.h create mode 100644 drivers/acpi/riscv/irq.c
Comments
On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicro.com> wrote: > > This series adds support for the below ECR approved by ASWG. > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > The series primarily enables irqchip drivers for RISC-V ACPI based > platforms. > > The series can be broadly categorized like below. > > 1) PCI ACPI related functions are migrated from arm64 to common file so > that we don't need to duplicate them for RISC-V. > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > This helps to support deferred probe of interrupt controller drivers. > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > disabled state. This solution is similar to how > platform_get_irq_optional() works for regular platform devices. > > 4) Added support for re-ordering the probe of interrupt controllers when > IRQCHIP_ACPI_DECLARE is used. > > 5) ACPI support added in RISC-V interrupt controller drivers. > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > not merged yet and first time introducing fw_devlink, deferred probe and > reordering support for IRQCHIP probe, this series is still kept as RFC. > Looking forward for the feedback! > > Changes since RFC v2: > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > 2) Dropped patches in drivers which are not required due to > fw_devlink support. > 3) Dropped pci_set_msi() patch and added a patch in > pci_create_root_bus(). > 4) Updated pnp_irq() patch so that none of the actual PNP > drivers need to change. > > Changes since RFC v1: > 1) Abandoned swnode approach as per Marc's feedback. > 2) To cope up with AIA series changes which changed irqchip driver > probe from core_initcall() to platform_driver, added patches > to support deferred probing. > 3) Rebased on top of Anup's AIA v11 and added tags. > > To test the series, > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > https://github.com/vlsunil/qemu.git > > 2) EDK2 should be built using the instructions at: > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > Run Qemu: > qemu-system-riscv64 \ > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > -m 2G -smp 8 \ > -serial mon:stdio \ > -device virtio-gpu-pci -full-screen \ > -device qemu-xhci \ > -device usb-kbd \ > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > -kernel arch/riscv/boot/Image \ > -initrd rootfs.cpio \ > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > To boot with APLIC only, use aia=aplic. > To boot with PLIC, remove aia= option. > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > https://github.com/vlsunil/linux.git > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > Sunil V L (17): > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > RISC-V: ACPI: Implement PCI related functionality > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > probe > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > irqchip: riscv-intc: Add ACPI support for AIA > irqchip: riscv-imsic: Add ACPI support > irqchip: riscv-aplic: Add ACPI support > irqchip: irq-sifive-plic: Add ACPI support > ACPI: bus: Add RINTC IRQ model for RISC-V > ACPI: bus: Add acpi_riscv_init function > ACPI: RISC-V: Create APLIC platform device > ACPI: RISC-V: Create PLIC platform device > irqchip: riscv-intc: Set ACPI irqmodel JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. Thanks!
On Tue, Dec 19, 2023 at 06:50:19PM +0100, Rafael J. Wysocki wrote: > On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > This series adds support for the below ECR approved by ASWG. > > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > > > The series primarily enables irqchip drivers for RISC-V ACPI based > > platforms. > > > > The series can be broadly categorized like below. > > > > 1) PCI ACPI related functions are migrated from arm64 to common file so > > that we don't need to duplicate them for RISC-V. > > > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > > This helps to support deferred probe of interrupt controller drivers. > > > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > > disabled state. This solution is similar to how > > platform_get_irq_optional() works for regular platform devices. > > > > 4) Added support for re-ordering the probe of interrupt controllers when > > IRQCHIP_ACPI_DECLARE is used. > > > > 5) ACPI support added in RISC-V interrupt controller drivers. > > > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > > not merged yet and first time introducing fw_devlink, deferred probe and > > reordering support for IRQCHIP probe, this series is still kept as RFC. > > Looking forward for the feedback! > > > > Changes since RFC v2: > > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > > 2) Dropped patches in drivers which are not required due to > > fw_devlink support. > > 3) Dropped pci_set_msi() patch and added a patch in > > pci_create_root_bus(). > > 4) Updated pnp_irq() patch so that none of the actual PNP > > drivers need to change. > > > > Changes since RFC v1: > > 1) Abandoned swnode approach as per Marc's feedback. > > 2) To cope up with AIA series changes which changed irqchip driver > > probe from core_initcall() to platform_driver, added patches > > to support deferred probing. > > 3) Rebased on top of Anup's AIA v11 and added tags. > > > > To test the series, > > > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > > https://github.com/vlsunil/qemu.git > > > > 2) EDK2 should be built using the instructions at: > > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > > > Run Qemu: > > qemu-system-riscv64 \ > > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > > -m 2G -smp 8 \ > > -serial mon:stdio \ > > -device virtio-gpu-pci -full-screen \ > > -device qemu-xhci \ > > -device usb-kbd \ > > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > > -kernel arch/riscv/boot/Image \ > > -initrd rootfs.cpio \ > > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > > > To boot with APLIC only, use aia=aplic. > > To boot with PLIC, remove aia= option. > > > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > > https://github.com/vlsunil/linux.git > > > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > > > Sunil V L (17): > > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > > RISC-V: ACPI: Implement PCI related functionality > > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > > probe > > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > > irqchip: riscv-intc: Add ACPI support for AIA > > irqchip: riscv-imsic: Add ACPI support > > irqchip: riscv-aplic: Add ACPI support > > irqchip: irq-sifive-plic: Add ACPI support > > ACPI: bus: Add RINTC IRQ model for RISC-V > > ACPI: bus: Add acpi_riscv_init function > > ACPI: RISC-V: Create APLIC platform device > > ACPI: RISC-V: Create PLIC platform device > > irqchip: riscv-intc: Set ACPI irqmodel > > JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. > No worries!. I will wait for your feedback. Thanks! Sunil
On Tue, Dec 19, 2023 at 06:50:19PM +0100, Rafael J. Wysocki wrote: > On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > This series adds support for the below ECR approved by ASWG. > > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > > > The series primarily enables irqchip drivers for RISC-V ACPI based > > platforms. > > > > The series can be broadly categorized like below. > > > > 1) PCI ACPI related functions are migrated from arm64 to common file so > > that we don't need to duplicate them for RISC-V. > > > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > > This helps to support deferred probe of interrupt controller drivers. > > > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > > disabled state. This solution is similar to how > > platform_get_irq_optional() works for regular platform devices. > > > > 4) Added support for re-ordering the probe of interrupt controllers when > > IRQCHIP_ACPI_DECLARE is used. > > > > 5) ACPI support added in RISC-V interrupt controller drivers. > > > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > > not merged yet and first time introducing fw_devlink, deferred probe and > > reordering support for IRQCHIP probe, this series is still kept as RFC. > > Looking forward for the feedback! > > > > Changes since RFC v2: > > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > > 2) Dropped patches in drivers which are not required due to > > fw_devlink support. > > 3) Dropped pci_set_msi() patch and added a patch in > > pci_create_root_bus(). > > 4) Updated pnp_irq() patch so that none of the actual PNP > > drivers need to change. > > > > Changes since RFC v1: > > 1) Abandoned swnode approach as per Marc's feedback. > > 2) To cope up with AIA series changes which changed irqchip driver > > probe from core_initcall() to platform_driver, added patches > > to support deferred probing. > > 3) Rebased on top of Anup's AIA v11 and added tags. > > > > To test the series, > > > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > > https://github.com/vlsunil/qemu.git > > > > 2) EDK2 should be built using the instructions at: > > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > > > Run Qemu: > > qemu-system-riscv64 \ > > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > > -m 2G -smp 8 \ > > -serial mon:stdio \ > > -device virtio-gpu-pci -full-screen \ > > -device qemu-xhci \ > > -device usb-kbd \ > > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > > -kernel arch/riscv/boot/Image \ > > -initrd rootfs.cpio \ > > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > > > To boot with APLIC only, use aia=aplic. > > To boot with PLIC, remove aia= option. > > > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > > https://github.com/vlsunil/linux.git > > > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > > > Sunil V L (17): > > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > > RISC-V: ACPI: Implement PCI related functionality > > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > > probe > > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > > irqchip: riscv-intc: Add ACPI support for AIA > > irqchip: riscv-imsic: Add ACPI support > > irqchip: riscv-aplic: Add ACPI support > > irqchip: irq-sifive-plic: Add ACPI support > > ACPI: bus: Add RINTC IRQ model for RISC-V > > ACPI: bus: Add acpi_riscv_init function > > ACPI: RISC-V: Create APLIC platform device > > ACPI: RISC-V: Create PLIC platform device > > irqchip: riscv-intc: Set ACPI irqmodel > > JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. > Hi Rafael, Gentle ping. Could you please provide feedback on the series? Patches 4, 5, 6, 7 and 8 are bit critical IMO. So, I really look forward for your and other ACPI experts!. Thanks! Sunil
On Tue, Jan 30, 2024 at 7:02 AM Sunil V L <sunilvl@ventanamicro.com> wrote: > > On Tue, Dec 19, 2023 at 06:50:19PM +0100, Rafael J. Wysocki wrote: > > On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicrocom> wrote: > > > > > > This series adds support for the below ECR approved by ASWG. > > > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > > > > > The series primarily enables irqchip drivers for RISC-V ACPI based > > > platforms. > > > > > > The series can be broadly categorized like below. > > > > > > 1) PCI ACPI related functions are migrated from arm64 to common file so > > > that we don't need to duplicate them for RISC-V. > > > > > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > > > This helps to support deferred probe of interrupt controller drivers. > > > > > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > > > disabled state. This solution is similar to how > > > platform_get_irq_optional() works for regular platform devices. > > > > > > 4) Added support for re-ordering the probe of interrupt controllers when > > > IRQCHIP_ACPI_DECLARE is used. > > > > > > 5) ACPI support added in RISC-V interrupt controller drivers. > > > > > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > > > not merged yet and first time introducing fw_devlink, deferred probe and > > > reordering support for IRQCHIP probe, this series is still kept as RFC. > > > Looking forward for the feedback! > > > > > > Changes since RFC v2: > > > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > > > 2) Dropped patches in drivers which are not required due to > > > fw_devlink support. > > > 3) Dropped pci_set_msi() patch and added a patch in > > > pci_create_root_bus(). > > > 4) Updated pnp_irq() patch so that none of the actual PNP > > > drivers need to change. > > > > > > Changes since RFC v1: > > > 1) Abandoned swnode approach as per Marc's feedback. > > > 2) To cope up with AIA series changes which changed irqchip driver > > > probe from core_initcall() to platform_driver, added patches > > > to support deferred probing. > > > 3) Rebased on top of Anup's AIA v11 and added tags. > > > > > > To test the series, > > > > > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > > > https://github.com/vlsunil/qemu.git > > > > > > 2) EDK2 should be built using the instructions at: > > > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > > > > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > > > > > Run Qemu: > > > qemu-system-riscv64 \ > > > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > > > -m 2G -smp 8 \ > > > -serial mon:stdio \ > > > -device virtio-gpu-pci -full-screen \ > > > -device qemu-xhci \ > > > -device usb-kbd \ > > > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > > > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > > > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > > > -kernel arch/riscv/boot/Image \ > > > -initrd rootfs.cpio \ > > > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > > > > > To boot with APLIC only, use aia=aplic. > > > To boot with PLIC, remove aia= option. > > > > > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > > > https://github.com/vlsunil/linux.git > > > > > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > > > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > > > > > Sunil V L (17): > > > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > > > RISC-V: ACPI: Implement PCI related functionality > > > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > > > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > > > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > > > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > > > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > > > probe > > > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > > > irqchip: riscv-intc: Add ACPI support for AIA > > > irqchip: riscv-imsic: Add ACPI support > > > irqchip: riscv-aplic: Add ACPI support > > > irqchip: irq-sifive-plic: Add ACPI support > > > ACPI: bus: Add RINTC IRQ model for RISC-V > > > ACPI: bus: Add acpi_riscv_init function > > > ACPI: RISC-V: Create APLIC platform device > > > ACPI: RISC-V: Create PLIC platform device > > > irqchip: riscv-intc: Set ACPI irqmodel > > > > JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. > > > Hi Rafael, > > Gentle ping. > > Could you please provide feedback on the series? Patches 4, 5, 6, 7 and > 8 are bit critical IMO. So, I really look forward for your and other > ACPI experts!. There was quite a bit of discussion on patch [6/21] and it still seems relevant to me. ACPI actually has a way to at least indicate what the probe ordering should be which is _DEP. The current handling of _DEP in the kernel may not be covering this particular use case, but I would rather extend it (if necessary) instead of doing all of the -EPROBE_DEFER dance which seems fragile to me. Thanks!
On Thu, Feb 01, 2024 at 07:10:28PM +0100, Rafael J. Wysocki wrote: > On Tue, Jan 30, 2024 at 7:02 AM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > On Tue, Dec 19, 2023 at 06:50:19PM +0100, Rafael J. Wysocki wrote: > > > On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > > > > > This series adds support for the below ECR approved by ASWG. > > > > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > > > > > > > The series primarily enables irqchip drivers for RISC-V ACPI based > > > > platforms. > > > > > > > > The series can be broadly categorized like below. > > > > > > > > 1) PCI ACPI related functions are migrated from arm64 to common file so > > > > that we don't need to duplicate them for RISC-V. > > > > > > > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > > > > This helps to support deferred probe of interrupt controller drivers. > > > > > > > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > > > > disabled state. This solution is similar to how > > > > platform_get_irq_optional() works for regular platform devices. > > > > > > > > 4) Added support for re-ordering the probe of interrupt controllers when > > > > IRQCHIP_ACPI_DECLARE is used. > > > > > > > > 5) ACPI support added in RISC-V interrupt controller drivers. > > > > > > > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > > > > not merged yet and first time introducing fw_devlink, deferred probe and > > > > reordering support for IRQCHIP probe, this series is still kept as RFC. > > > > Looking forward for the feedback! > > > > > > > > Changes since RFC v2: > > > > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > > > > 2) Dropped patches in drivers which are not required due to > > > > fw_devlink support. > > > > 3) Dropped pci_set_msi() patch and added a patch in > > > > pci_create_root_bus(). > > > > 4) Updated pnp_irq() patch so that none of the actual PNP > > > > drivers need to change. > > > > > > > > Changes since RFC v1: > > > > 1) Abandoned swnode approach as per Marc's feedback. > > > > 2) To cope up with AIA series changes which changed irqchip driver > > > > probe from core_initcall() to platform_driver, added patches > > > > to support deferred probing. > > > > 3) Rebased on top of Anup's AIA v11 and added tags. > > > > > > > > To test the series, > > > > > > > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > > > > https://github.com/vlsunil/qemu.git > > > > > > > > 2) EDK2 should be built using the instructions at: > > > > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > > > > > > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > > > > > > > Run Qemu: > > > > qemu-system-riscv64 \ > > > > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > > > > -m 2G -smp 8 \ > > > > -serial mon:stdio \ > > > > -device virtio-gpu-pci -full-screen \ > > > > -device qemu-xhci \ > > > > -device usb-kbd \ > > > > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > > > > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > > > > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > > > > -kernel arch/riscv/boot/Image \ > > > > -initrd rootfs.cpio \ > > > > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > > > > > > > To boot with APLIC only, use aia=aplic. > > > > To boot with PLIC, remove aia= option. > > > > > > > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > > > > https://github.com/vlsunil/linux.git > > > > > > > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > > > > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > > > > > > > Sunil V L (17): > > > > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > > > > RISC-V: ACPI: Implement PCI related functionality > > > > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > > > > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > > > > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > > > > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > > > > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > > > > probe > > > > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > > > > irqchip: riscv-intc: Add ACPI support for AIA > > > > irqchip: riscv-imsic: Add ACPI support > > > > irqchip: riscv-aplic: Add ACPI support > > > > irqchip: irq-sifive-plic: Add ACPI support > > > > ACPI: bus: Add RINTC IRQ model for RISC-V > > > > ACPI: bus: Add acpi_riscv_init function > > > > ACPI: RISC-V: Create APLIC platform device > > > > ACPI: RISC-V: Create PLIC platform device > > > > irqchip: riscv-intc: Set ACPI irqmodel > > > > > > JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. > > > > > Hi Rafael, > > > > Gentle ping. > > > > Could you please provide feedback on the series? Patches 4, 5, 6, 7 and > > 8 are bit critical IMO. So, I really look forward for your and other > > ACPI experts!. > > There was quite a bit of discussion on patch [6/21] and it still seems > relevant to me. > > ACPI actually has a way to at least indicate what the probe ordering > should be which is _DEP. > > The current handling of _DEP in the kernel may not be covering this > particular use case, but I would rather extend it (if necessary) > instead of doing all of the -EPROBE_DEFER dance which seems fragile to > me. > Hi Rafael, Appreciate your help to look at the patches. Thank you very much!. I am not very sure whether you looked into patches in the v3 of the series. Because, unlike in v2, v3 doesn't need changing all drivers to handle EPROBE_DEFER. In v3, it creates fw_devlink for the dependency as suggested by Marc. Please take a look at PATCH 4/17. For the IRQ dependency, I think adding _DEP is not required. The "Extended Interrupt Descriptor" supports ResourceSource to indicate the dependency. Or GSI mapping can indicate the source. This is already handled in acpi_irq_parse_one_cb(). PATCH 4 uses this information to create links between producer and consumer so that DD framework probes the driver in the required order. As you know, PNP devices are enumerated in a different way. I don't know why it was done like this. But pnpacpi_init() is called via fs_initcall() and acpi_dev_resource_interrupt() called from pnpacpi_allocated_resource() doesn't handle the ResourceSource dependency. It caches the information in PNP data structure and expects the IRQ mapping to be available. Even if we add support to handle extended interrupt descriptor, it is not going to help. Hence, I had to add PATCH 5/17 and PATCH 6/17. Again, the change is mainly in pnp_irq() now and hence it doesn't need changing all drivers. Thanks, Sunil
On Fri, Feb 02, 2024 at 05:47:16PM +0530, Sunil V L wrote: > On Thu, Feb 01, 2024 at 07:10:28PM +0100, Rafael J. Wysocki wrote: > > On Tue, Jan 30, 2024 at 7:02 AM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > > > On Tue, Dec 19, 2023 at 06:50:19PM +0100, Rafael J. Wysocki wrote: > > > > On Tue, Dec 19, 2023 at 6:45 PM Sunil V L <sunilvl@ventanamicro.com> wrote: > > > > > > > > > > This series adds support for the below ECR approved by ASWG. > > > > > 1) MADT - https://drive.google.com/file/d/1oMGPyOD58JaPgMl1pKasT-VKsIKia7zR/view?usp=sharing > > > > > > > > > > The series primarily enables irqchip drivers for RISC-V ACPI based > > > > > platforms. > > > > > > > > > > The series can be broadly categorized like below. > > > > > > > > > > 1) PCI ACPI related functions are migrated from arm64 to common file so > > > > > that we don't need to duplicate them for RISC-V. > > > > > > > > > > 2) Introduced support for fw_devlink for ACPI nodes for IRQ dependency. > > > > > This helps to support deferred probe of interrupt controller drivers. > > > > > > > > > > 3) Modified pnp_irq() to try registering the IRQ again if it sees it in > > > > > disabled state. This solution is similar to how > > > > > platform_get_irq_optional() works for regular platform devices. > > > > > > > > > > 4) Added support for re-ordering the probe of interrupt controllers when > > > > > IRQCHIP_ACPI_DECLARE is used. > > > > > > > > > > 5) ACPI support added in RISC-V interrupt controller drivers. > > > > > > > > > > This series is based on Anup's AIA v11 series. Since Anup's AIA v11 is > > > > > not merged yet and first time introducing fw_devlink, deferred probe and > > > > > reordering support for IRQCHIP probe, this series is still kept as RFC. > > > > > Looking forward for the feedback! > > > > > > > > > > Changes since RFC v2: > > > > > 1) Introduced fw_devlink for ACPI nodes for IRQ dependency. > > > > > 2) Dropped patches in drivers which are not required due to > > > > > fw_devlink support. > > > > > 3) Dropped pci_set_msi() patch and added a patch in > > > > > pci_create_root_bus(). > > > > > 4) Updated pnp_irq() patch so that none of the actual PNP > > > > > drivers need to change. > > > > > > > > > > Changes since RFC v1: > > > > > 1) Abandoned swnode approach as per Marc's feedback. > > > > > 2) To cope up with AIA series changes which changed irqchip driver > > > > > probe from core_initcall() to platform_driver, added patches > > > > > to support deferred probing. > > > > > 3) Rebased on top of Anup's AIA v11 and added tags. > > > > > > > > > > To test the series, > > > > > > > > > > 1) Qemu should be built using the riscv_acpi_b2_v8 branch at > > > > > https://github.com/vlsunil/qemu.git > > > > > > > > > > 2) EDK2 should be built using the instructions at: > > > > > https://github.com/tianocore/edk2/blob/master/OvmfPkg/RiscVVirt/README.md > > > > > > > > > > 3) Build Linux using this series on top of Anup's AIA v11 series. > > > > > > > > > > Run Qemu: > > > > > qemu-system-riscv64 \ > > > > > -M virt,pflash0=pflash0,pflash1=pflash1,aia=aplic-imsic \ > > > > > -m 2G -smp 8 \ > > > > > -serial mon:stdio \ > > > > > -device virtio-gpu-pci -full-screen \ > > > > > -device qemu-xhci \ > > > > > -device usb-kbd \ > > > > > -blockdev node-name=pflash0,driver=file,read-only=on,filename=RISCV_VIRT_CODE.fd \ > > > > > -blockdev node-name=pflash1,driver=file,filename=RISCV_VIRT_VARS.fd \ > > > > > -netdev user,id=net0 -device virtio-net-pci,netdev=net0 \ > > > > > -kernel arch/riscv/boot/Image \ > > > > > -initrd rootfs.cpio \ > > > > > -append "root=/dev/ram ro console=ttyS0 rootwait earlycon=uart8250,mmio,0x10000000" > > > > > > > > > > To boot with APLIC only, use aia=aplic. > > > > > To boot with PLIC, remove aia= option. > > > > > > > > > > This series is also available in acpi_b2_v3_riscv_aia_v11 branch at > > > > > https://github.com/vlsunil/linux.git > > > > > > > > > > Based-on: 20231023172800.315343-1-apatel@ventanamicro.com > > > > > (https://lore.kernel.org/lkml/20231023172800.315343-1-apatel@ventanamicro.com/) > > > > > > > > > > Sunil V L (17): > > > > > arm64: PCI: Migrate ACPI related functions to pci-acpi.c > > > > > RISC-V: ACPI: Implement PCI related functionality > > > > > PCI: Make pci_create_root_bus() declare its reliance on MSI domains > > > > > ACPI: Add fw_devlink support for ACPI fwnode for IRQ dependency > > > > > ACPI: irq: Add support for deferred probe in acpi_register_gsi() > > > > > pnp.h: Reconfigure IRQ in pnp_irq() to support deferred probe > > > > > ACPI: scan.c: Add weak arch specific function to reorder the IRQCHIP > > > > > probe > > > > > ACPI: RISC-V: Implement arch function to reorder irqchip probe entries > > > > > irqchip: riscv-intc: Add ACPI support for AIA > > > > > irqchip: riscv-imsic: Add ACPI support > > > > > irqchip: riscv-aplic: Add ACPI support > > > > > irqchip: irq-sifive-plic: Add ACPI support > > > > > ACPI: bus: Add RINTC IRQ model for RISC-V > > > > > ACPI: bus: Add acpi_riscv_init function > > > > > ACPI: RISC-V: Create APLIC platform device > > > > > ACPI: RISC-V: Create PLIC platform device > > > > > irqchip: riscv-intc: Set ACPI irqmodel > > > > > > > > JFYI, I have no capacity to provide any feedback on this till 6.8-rc1 is out. > > > > > > > Hi Rafael, > > > > > > Gentle ping. > > > > > > Could you please provide feedback on the series? Patches 4, 5, 6, 7 and > > > 8 are bit critical IMO. So, I really look forward for your and other > > > ACPI experts!. > > > > There was quite a bit of discussion on patch [6/21] and it still seems > > relevant to me. > > > > ACPI actually has a way to at least indicate what the probe ordering > > should be which is _DEP. > > > > The current handling of _DEP in the kernel may not be covering this > > particular use case, but I would rather extend it (if necessary) > > instead of doing all of the -EPROBE_DEFER dance which seems fragile to > > me. > > > Hi Rafael, > > Appreciate your help to look at the patches. Thank you very much!. > > I am not very sure whether you looked into patches in the v3 of the > series. Because, unlike in v2, v3 doesn't need changing all drivers to > handle EPROBE_DEFER. In v3, it creates fw_devlink for the dependency as > suggested by Marc. Please take a look at PATCH 4/17. > > For the IRQ dependency, I think adding _DEP is not required. The > "Extended Interrupt Descriptor" supports ResourceSource to > indicate the dependency. Or GSI mapping can indicate the source. This is > already handled in acpi_irq_parse_one_cb(). PATCH 4 uses this > information to create links between producer and consumer so that DD > framework probes the driver in the required order. > > As you know, PNP devices are enumerated in a different way. I don't know > why it was done like this. But pnpacpi_init() is called via > fs_initcall() and acpi_dev_resource_interrupt() called from > pnpacpi_allocated_resource() doesn't handle the ResourceSource > dependency. It caches the information in PNP data structure and expects > the IRQ mapping to be available. Even if we add support to > handle extended interrupt descriptor, it is not going to help. Hence, I > had to add PATCH 5/17 and PATCH 6/17. Again, the change is mainly in > pnp_irq() now and hence it doesn't need changing all drivers. > Hi Rafael, Any further feedback on this? Do you see any issues with fw_devlink and pnp_irq() changes for the interrupt controller dependency? BTW, I explored the _DEP option you mentioned. But I think the current approach would probably be better with lesser impact than _DEP. Below are my findings. 1) When PNP device like PNP0501 (16550A UART) has _DEP, it does not get created in the first pass (as expected) but they won't get created even after the supplier clears the dependency. This is because acpi_pnp_attach() returns success without calling pnpacpi_add_device() when acpi_scan_clear_dep_fn() calls acpi_bus_attach(). Either acpi_pnp_attach() needs to be modified or pnpacpi_add_device() should be called as part of clearing the dependency. I may be wrong but I think modifying pnp_irq() would probably affect only RISC-V than any of the approaches above. 2) _DEP doesn't support PCI devices. When we have PCI link devices (PNP0C0F) in the _PRT, the PCI driver probe as part of PCI scan can happen prior to link device probe since link device will have dependency on the interrupt controller which may not be probed yet. This will cause issue to the PCI device driver init because _PRT says there is link device for legacy PCI interrupt routing but the link driver is not probed yet. 3) _DEP needs namespace interrupt controllers. We would like to avoid adding namespace devices also along with MADT. Please let me know your thoughts. Thanks, Sunil