Received: by 2002:ab2:69cc:0:b0:1f4:be93:e15a with SMTP id n12csp1567859lqp; Mon, 15 Apr 2024 10:01:35 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVLtCUpK6PlixWxL7gCIP/iI+ny5sYCsAWNip/y/Acg2g/hbsP224rbLdKFPU0Iplzx3MTHxOT4NGrl90J0/Vm8EGVU6uSOiPoVZDA4Rg== X-Google-Smtp-Source: AGHT+IHFDsd7W+KS5HRpVknJv+Feaq3SP8DQoDK1RS4lXwbAB/cVK6UMtj6vzg9FfVUtehhWsjPA X-Received: by 2002:a05:620a:394f:b0:78b:ac85:3b79 with SMTP id qs15-20020a05620a394f00b0078bac853b79mr14564821qkn.40.1713200495525; Mon, 15 Apr 2024 10:01:35 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713200495; cv=pass; d=google.com; s=arc-20160816; b=SpLFNEJp7CfXDSpkblJXQL4WHUCaM5vqEceFe8KhOU5h0mwi+FVkdyMrw9xZvVbhla aikqxojK4MkmO4UvY+QcaRWdDqYWPx3rLbCSyRRelMC5z447wEdPAQSflUPcs0plWoh1 TmDg/A4tDKwiLQAEj60iZBtW2hnI758mQrThRsh8BkwueGcQIUgHDrMIPQHO6t60zacd cJmfRU7ESAf/iIYHlXXLrKNKfQ4Ndq6qAISCjb2ELeajOqQqyWEffgM8pkP1XcK+W0c3 Z3zU7ZO9tZqzptxsx+bYFFizuePNy3N3vsmULX2V429wgi1hvPc647qimTjqARcImhlG VRHg== ARC-Message-Signature: i=2; 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=afQUKb3+bReZJJVzkqw/D/pAyQK9zbCbxN1Z3zQxUCM=; fh=jhNQWzaWVQcqV5cUxyzuLIb/ho4UWwt1LsUxQlkoa5E=; b=C5pGmATFQfenkvMcZsXNartl7aB0a6z4e4S3WVTtWtHelLEYgu8k4Y9C5A0//W0Fjf p6G6+Fet33hfaUjO65LdLSt9VG9bWZoh9Jz5TdFAOThKkxs0apJAaPG6ty4z2G7c7vYy 87XDGKUN9xa7TZ1lVss2wL0H14Bj9EiYTBfRWXo6pCU1HS+Cf1e8BxvoO6ufJ/curlMU 1WBDBTmoV/mFUaK0bphOHtNqKwYTXhl8ONAkpI8pN67bMhevaCIZAqN+ur6a4OGAxE/7 Y2irnAsTrF415OQPWNOA1VcKm7nGYHdiKTwGz0Pi/q0//XXhaYsSo6xFnmUln2XB9RlC 6pmA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=b22mihX2; arc=pass (i=1 spf=pass spfdomain=ventanamicro.com dkim=pass dkdomain=ventanamicro.com); spf=pass (google.com: domain of linux-kernel+bounces-145599-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-145599-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id t26-20020a05620a035a00b0078d645d0cefsi10475696qkm.452.2024.04.15.10.01.35 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Apr 2024 10:01:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-145599-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@ventanamicro.com header.s=google header.b=b22mihX2; arc=pass (i=1 spf=pass spfdomain=ventanamicro.com dkim=pass dkdomain=ventanamicro.com); spf=pass (google.com: domain of linux-kernel+bounces-145599-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-145599-linux.lists.archive=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 ny.mirrors.kernel.org (Postfix) with ESMTPS id 1F8EA1C20F9E for ; Mon, 15 Apr 2024 17:01:35 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B362082C7D; Mon, 15 Apr 2024 17:01:26 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=ventanamicro.com header.i=@ventanamicro.com header.b="b22mihX2" Received: from mail-pf1-f171.google.com (mail-pf1-f171.google.com [209.85.210.171]) (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 4CB0B8286A for ; Mon, 15 Apr 2024 17:01:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.171 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713200485; cv=none; b=tzf4W7KSOibQHpWmRb3h0JnoeipEySSOP1xjl4rAP7v+IjaCAPFs7O+qRQqJiTlYPxrdwY690D7eqd4Q0AP8+iCJeTNEM6AnAgxI2/21Byq+75a/g2V+2R3L/2N4MkYvPNwSr40QzUuQkVBBqVtK72zDR9bw+fyUNzV47mfsntI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713200485; c=relaxed/simple; bh=7lHC5xJ2vTJLbnQv7GLzUK6SG2A6vOhK+oNuADq/XBE=; h=From:To:Cc:Subject:Date:Message-Id:MIME-Version; b=t/SztOZOipKIs/9S9DGdc7FT3lbcEAFkc+LF2W166VNriJ/eS886dISdaatOvYKbDlVUW5qfY4Ed4EVz81Uj4IH2Hcblzw0xt50ZmTP/TcIFecimVCJdhgGGGhxU+6faxh8Hiy12Pk+DlwR+WgAsphqEizX2M9tou/aePkdIPWo= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ventanamicro.com; spf=pass smtp.mailfrom=ventanamicro.com; dkim=pass (2048-bit key) header.d=ventanamicro.com header.i=@ventanamicro.com header.b=b22mihX2; arc=none smtp.client-ip=209.85.210.171 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-f171.google.com with SMTP id d2e1a72fcca58-6ed691fb83eso2822448b3a.1 for ; Mon, 15 Apr 2024 10:01:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ventanamicro.com; s=google; t=1713200483; x=1713805283; 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=afQUKb3+bReZJJVzkqw/D/pAyQK9zbCbxN1Z3zQxUCM=; b=b22mihX2WScfzVsCGOHVG3gU289tgmXuabT2gtqWlRpgnM+FvKOrTFYXU6XtKIIv4y m820HHbUcgiJ2+/FkbBwXVIHoyhbcJ1zPKfzRDu0PunZMuYROsUJv8adwCEsJX4v6oMo xQm5fdld3Cm/VVHHEaCrzcUUsw3+Z79g8N/H88w77NgmWgsTfibOsQ2/IvN5I+QWfASh 5F2M7tNAb0El1BmPBfCp/80PlC5kIfmoDHBkdahK+fZdZ5LVeWcqDGCiPif80bj8upxw GKKLyeI5ph1kvIyYxa7YWALX+M39HUypt313yVEYcfguij8zoomcUq8nXg9AQGqjoWwQ MmGA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1713200483; x=1713805283; 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=afQUKb3+bReZJJVzkqw/D/pAyQK9zbCbxN1Z3zQxUCM=; b=gj0PFRQ7xZtscabcaaH7s1PiJ9v3D60eitA5Ue0eOwRqTcIPwKhk3zNzE2vo9YZIRH ZsYnBf9c38HienOTqZkvtBJs5R6L49dR27K8vN4RV7SZQDGJ0WJxHbjhSnQWvSMLHVMf 9ONciVmVoClB3y9Yc1LQrEy5aA/u/YJlZ4cb/78pczZ6oywhAIJZr3dvPDmw+LhDx/f0 iQhyhcChE3j7i3MBXS+J4lRAH/cOVVqYf/+UO6C7tEk5cU7FsKGK6ehas9x88pwHXvQL YICRNFCEz9Yqovg4WwGMIIlmhv2JFV5Jv543R0PkxfM6CkHUtZkisutJ28IFp6U3rs6+ mH9g== X-Forwarded-Encrypted: i=1; AJvYcCWv7/jeibSkGwghdlMT4d2/kV+mJvE3Fpllcc81KlA78nXlZ1jsV534BNn7VNLZTN8RqERYo6uyBWJqewo10l/rI3cNS5ELvGS6Xd8H X-Gm-Message-State: AOJu0YwPXqQQ8zLJrg87VtTegGONjT4dIhqGFHxopkQaiXDYGl/j+wwT ckjr3uj/jGbB/2+GxsktWDM/g4k9toxaDaapF6SlJYy+rkYf/dNjy+HJacUgwKA= X-Received: by 2002:a05:6a20:4e29:b0:1a3:a8da:918b with SMTP id gk41-20020a056a204e2900b001a3a8da918bmr7760997pzb.47.1713200483351; Mon, 15 Apr 2024 10:01:23 -0700 (PDT) Received: from sunil-pc.Dlink ([106.51.187.230]) by smtp.gmail.com with ESMTPSA id 1-20020a056a00072100b006ed045e3a70sm7433158pfm.25.2024.04.15.10.01.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 Apr 2024 10:01:22 -0700 (PDT) From: Sunil V L 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, acpica-devel@lists.linux.dev Cc: Catalin Marinas , Will Deacon , Paul Walmsley , Palmer Dabbelt , Albert Ou , "Rafael J . Wysocki" , Len Brown , Bjorn Helgaas , Anup Patel , Thomas Gleixner , Samuel Holland , Robert Moore , Haibo1 Xu , Conor Dooley , Andrew Jones , Atish Kumar Patra , Andrei Warkentin , Marc Zyngier , =?UTF-8?q?Bj=C3=B6rn=20T=C3=B6pel?= , Sunil V L Subject: [RFC PATCH v4 00/20] RISC-V: ACPI: Add external interrupt controller support Date: Mon, 15 Apr 2024 22:30:53 +0530 Message-Id: <20240415170113.662318-1-sunilvl@ventanamicro.com> X-Mailer: git-send-email 2.40.1 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit 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) Added support for re-ordering the probe of interrupt controllers when IRQCHIP_ACPI_DECLARE is used. 3) To ensure probe order between interrupt controllers and devices, implicit dependency is created similar to when _DEP is present. 4) When PNP devices like Generic 16550A UART, have the dependency on the interrupt controller, they will not be added to PNP data structures. So, added second phase of pnpacpi_init to handle this. 5) ACPI support added in RISC-V interrupt controller drivers. This series is still kept as RFC to seek feedback on above design changes. Looking forward for the feedback! Changes since RFC v3: 1) Moved to _DEP method instead of fw_devlink. 2) PLIC/APLIC driver probe using namespace devices. 3) Handling PNP devices as part of clearing dependency. 4) Rebased to latest linux-next to get AIA DT drivers. 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_namespace_v1 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. 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_v4_autodep_v1 branch at https://github.com/vlsunil/linux.git Based-on: https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/tag/?h=next-20240415 Sunil V L (20): 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: scan.c: Add weak arch specific function to reorder the IRQCHIP probe ACPI: RISC-V: Implement arch function to reorder irqchip probe entries ACPI: bus: Add acpi_riscv_init function RISC-V: Kconfig: Select deferred GSI probe for ACPI systems ACPI: scan: Refactor dependency creation drivers/acpi/scan.c: Update _DEP honor list RISC-V: ACPI: Initialize GSI mapping structures ACPI: scan.c: Define weak function to populate dependencies RISC-V: ACPI: Implement function to add implicit dependencies ACPI/PNP: Initialize PNP devices skipped due to _DEP 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 irqchip: riscv-intc: Set ACPI irqmodel ACPI: pci_link: Clear the dependencies after probe arch/arm64/kernel/pci.c | 191 ------------ arch/riscv/Kconfig | 3 + arch/riscv/include/asm/irq.h | 57 ++++ arch/riscv/kernel/acpi.c | 31 +- drivers/acpi/Kconfig | 3 + drivers/acpi/bus.c | 4 + drivers/acpi/pci_link.c | 3 + drivers/acpi/riscv/Makefile | 2 +- drivers/acpi/riscv/init.c | 14 + drivers/acpi/riscv/init.h | 4 + drivers/acpi/riscv/irq.c | 323 +++++++++++++++++++++ drivers/acpi/scan.c | 69 +++-- drivers/irqchip/irq-riscv-aplic-direct.c | 20 +- drivers/irqchip/irq-riscv-aplic-main.c | 70 +++-- 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 | 32 +- drivers/irqchip/irq-riscv-imsic-state.c | 115 ++++---- drivers/irqchip/irq-riscv-imsic-state.h | 2 +- drivers/irqchip/irq-riscv-intc.c | 102 ++++++- drivers/irqchip/irq-sifive-plic.c | 89 ++++-- drivers/pci/pci-acpi.c | 182 ++++++++++++ drivers/pci/probe.c | 3 + drivers/pnp/pnpacpi/core.c | 24 +- drivers/pnp/pnpacpi/rsparser.c | 63 ++-- include/acpi/acpi_bus.h | 2 + include/linux/acpi.h | 9 + include/linux/irqchip/riscv-imsic.h | 10 + include/linux/pnp.h | 7 + 30 files changed, 1108 insertions(+), 388 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 -- 2.40.1