Received: by 2002:a05:7412:798b:b0:fc:a2b0:25d7 with SMTP id fb11csp849124rdb; Fri, 23 Feb 2024 01:44:18 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCVFlBtqm9wdL0OYFpcoONJ+ZcYy3xcZhc9FeWZ+iapMX4kmxWAJ9RalG6yn9gsLsQUJ20R/iBBy+PCSOKP1FiredPml3+WwIxt3Eos6gw== X-Google-Smtp-Source: AGHT+IFvbh+xuRtf01KuNuEp4Yzrn2pLUbfBRpnZo6ykQDoJRvP/UyLfVZKfM5yhNeqlXHhOj9oO X-Received: by 2002:a17:906:f8d1:b0:a3f:b0a1:3e73 with SMTP id lh17-20020a170906f8d100b00a3fb0a13e73mr901798ejb.76.1708681458762; Fri, 23 Feb 2024 01:44:18 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1708681458; cv=pass; d=google.com; s=arc-20160816; b=JwmPAs3IE46PS7NogiwvxJChRC8z2iLEDAJQvUMMmZoiIvTOoKxN7SHaLG0EesDW4H LQAjs8J68EC1VqtOtg8RMOOOZt5FyvU/J/mqsbnTUv2v27ZrJDXGIyR3qcntO3C/klJL sqWwtQbO3vka+6BKRJ632u0xaVQs31/xqk+NasYchvDd3Ps6fMKjkTXd7hT2YkZSmNem yYjePgAPlZVHZAh0MZxR0jMHASlMvURBEIpgR/SJ9ABBYiromqR2NkmDV6AhwmQuiwAQ OiHG6FT12QH+FhJNPS3ehjS0XL1fXGkcGgUCNPzjflquvnQ5PzFF1SY+GY0fi1owIxNy k5Mg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:precedence:robot-unsubscribe:robot-id :message-id:mime-version:list-unsubscribe:list-subscribe:list-id :precedence:references:in-reply-to:cc:subject:to:reply-to:sender :from:dkim-signature:dkim-signature:date; bh=rhY6wNGyVkEGV1ZTL629R+rhoNXWo3iUoaalM1Zf5wY=; fh=546OEPtoZUYjWwSPOd/hX3L3p6biPmSjgTUnSRYaJpA=; b=djUEwnr5hr7aSxNYXS9Hg3EQPu7jkQG8x+aSKgK2ne9G2zC6ojlTb6catOirkX6BL6 Fx9s7zUuk0tib7CCemG6H/469pdjMJ9UiobeaZwl6a6TARaD6Z1xIKuwdiZRvf36QYvs SrJqPaE+QVwEcKtNXAP8s5AShhRVPCY0up8remEHHp91zxvESy3RC43s0YZ0qdbtQcXh YWqsn5byD7NdPwjEA4mJXCEql/Y5Mys6ek38bcAuxL3aE3yLRLFAmfYlp5QD5flhUYjk DikkowdFV0AzazsK09s3eoRL7pQEeXbFeHGbY11URdKNeXydIIUy73o/b1dm/uCCjxLs F/mg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=tIH4JwsV; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; arc=pass (i=1 spf=pass spfdomain=linutronix.de dkim=pass dkdomain=linutronix.de dmarc=pass fromdomain=linutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-78049-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-78049-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id v6-20020a17090606c600b00a3ede866628si3509559ejb.381.2024.02.23.01.44.18 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 23 Feb 2024 01:44:18 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-78049-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=tIH4JwsV; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; arc=pass (i=1 spf=pass spfdomain=linutronix.de dkim=pass dkdomain=linutronix.de dmarc=pass fromdomain=linutronix.de); spf=pass (google.com: domain of linux-kernel+bounces-78049-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-78049-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de 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 am.mirrors.kernel.org (Postfix) with ESMTPS id 509641F2621A for ; Fri, 23 Feb 2024 09:44:18 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 9A79F5CDCF; Fri, 23 Feb 2024 09:44:03 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linutronix.de header.i=@linutronix.de header.b="tIH4JwsV"; dkim=permerror (0-bit key) header.d=linutronix.de header.i=@linutronix.de header.b="bDG8t8Fj" Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F06111642A; Fri, 23 Feb 2024 09:44:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=193.142.43.55 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708681442; cv=none; b=Ezwgsa/ASl7LKE1zncLpCvWq3BQJ9PxEQ6U8TeyD1B5P+pKLwB4IaNHvFEhmuxGN4jjT+cHfIgwjGP4la9BKAfZrvcLZy+H4se66+EaHW+TeCaiBOuHCzvE8BhoZX4ji2VYH7Fidtp45B2EH0lOqF0Qw7OUYne1qKG1nBHUuKuc= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1708681442; c=relaxed/simple; bh=vYSSZVoi/wBbqaWlFLBAgIMVOuN0+7HYb6A3C7Km8m0=; h=Date:From:To:Subject:Cc:In-Reply-To:References:MIME-Version: Message-ID:Content-Type; b=Z36NOQrpm1cyUged6MxnQTlqdvBs8QYTyn2/BUf+s1QqxoOCs05owlE81TpY5E7zVjIs8wwWZP9Wn/QQwHaGng3lXyfzwNf2EerNT6lWvB5UMd1Ti3mOQXXLmkhHN27JCtaM9dSdjDRm+333A1ne8Es0NqQG+l+Dm4qsGFlgrt0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linutronix.de; spf=pass smtp.mailfrom=linutronix.de; dkim=pass (2048-bit key) header.d=linutronix.de header.i=@linutronix.de header.b=tIH4JwsV; dkim=permerror (0-bit key) header.d=linutronix.de header.i=@linutronix.de header.b=bDG8t8Fj; arc=none smtp.client-ip=193.142.43.55 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linutronix.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linutronix.de Date: Fri, 23 Feb 2024 09:43:52 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1708681433; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=rhY6wNGyVkEGV1ZTL629R+rhoNXWo3iUoaalM1Zf5wY=; b=tIH4JwsVq1pU4s9erNVKEj/c73GWhTmRyqYSU+H4wklcZIRWImqF9r2OU7U6ausDb27jS/ WTX7expgav5xGGh2l9d699yJCgBsEdgKPLMqrZc1DMwrMKwPZR98UeGGq5Wn/TQ6hVYUKD RXtWl+AVnvfDZ59VM6y2YoF4/L1LY95ELMfyRY3mOxVQC8KIbydzMmec85YQq2uLdpu3wQ VIKdgbF8Ym792iSMAwnU3BHA5uydW7wsOhqNtReaKNqkDlFR8k1DgPMLlK4vBBSMYaVDqC hv5QH3ezQZU++2tL8qMjj8VLl/axYTpNLR2XzUunOm6J6dqlg0df/8EYf8SkLg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1708681433; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=rhY6wNGyVkEGV1ZTL629R+rhoNXWo3iUoaalM1Zf5wY=; b=bDG8t8Fjq3dBOcp5tyhe8k/FdV+bQXYfUe/d10wWBr3w0mQfsat6Fas9yRVvp73XhWxZ2r XdVhdO47KMQp/sAw== From: "tip-bot2 for Anup Patel" Sender: tip-bot2@linutronix.de Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: irq/msi] irqchip/riscv-intc: Add support for RISC-V AIA Cc: Anup Patel , Thomas Gleixner , x86@kernel.org, linux-kernel@vger.kernel.org In-Reply-To: <20240222094006.1030709-9-apatel@ventanamicro.com> References: <20240222094006.1030709-9-apatel@ventanamicro.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Message-ID: <170868143221.398.5826038525907165938.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Precedence: bulk Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit The following commit has been merged into the irq/msi branch of tip: Commit-ID: 3c46fc5b5507be1f4aa144a1fbd83b0ccba04cc6 Gitweb: https://git.kernel.org/tip/3c46fc5b5507be1f4aa144a1fbd83b0ccba04cc6 Author: Anup Patel AuthorDate: Thu, 22 Feb 2024 15:09:56 +05:30 Committer: Thomas Gleixner CommitterDate: Fri, 23 Feb 2024 10:18:44 +01:00 irqchip/riscv-intc: Add support for RISC-V AIA The RISC-V advanced interrupt architecture (AIA) extends the per-HART local interrupts in following ways: 1. Minimum 64 local interrupts for both RV32 and RV64 2. Ability to process multiple pending local interrupts in same interrupt handler 3. Priority configuration for each local interrupts 4. Special CSRs to configure/access the per-HART MSI controller Add support for #1 and #2 described above in the RISC-V intc driver. Signed-off-by: Anup Patel Signed-off-by: Thomas Gleixner Link: https://lore.kernel.org/r/20240222094006.1030709-9-apatel@ventanamicro.com --- drivers/irqchip/irq-riscv-intc.c | 32 ++++++++++++++++++++++--------- 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/drivers/irqchip/irq-riscv-intc.c b/drivers/irqchip/irq-riscv-intc.c index 0cd6b48..cccb653 100644 --- a/drivers/irqchip/irq-riscv-intc.c +++ b/drivers/irqchip/irq-riscv-intc.c @@ -19,6 +19,8 @@ #include #include +#include + static struct irq_domain *intc_domain; static unsigned int riscv_intc_nr_irqs __ro_after_init = BITS_PER_LONG; static unsigned int riscv_intc_custom_base __ro_after_init = BITS_PER_LONG; @@ -32,6 +34,14 @@ static asmlinkage void riscv_intc_irq(struct pt_regs *regs) pr_warn_ratelimited("Failed to handle interrupt (cause: %ld)\n", cause); } +static asmlinkage void riscv_intc_aia_irq(struct pt_regs *regs) +{ + unsigned long topi; + + while ((topi = csr_read(CSR_TOPI))) + generic_handle_domain_irq(intc_domain, topi >> TOPI_IID_SHIFT); +} + /* * On RISC-V systems local interrupts are masked or unmasked by writing * the SIE (Supervisor Interrupt Enable) CSR. As CSRs can only be written @@ -41,12 +51,18 @@ static asmlinkage void riscv_intc_irq(struct pt_regs *regs) static void riscv_intc_irq_mask(struct irq_data *d) { - csr_clear(CSR_IE, BIT(d->hwirq)); + if (IS_ENABLED(CONFIG_32BIT) && d->hwirq >= BITS_PER_LONG) + csr_clear(CSR_IEH, BIT(d->hwirq - BITS_PER_LONG)); + else + csr_clear(CSR_IE, BIT(d->hwirq)); } static void riscv_intc_irq_unmask(struct irq_data *d) { - csr_set(CSR_IE, BIT(d->hwirq)); + if (IS_ENABLED(CONFIG_32BIT) && d->hwirq >= BITS_PER_LONG) + csr_set(CSR_IEH, BIT(d->hwirq - BITS_PER_LONG)); + else + csr_set(CSR_IE, BIT(d->hwirq)); } static void andes_intc_irq_mask(struct irq_data *d) @@ -157,8 +173,7 @@ static struct fwnode_handle *riscv_intc_hwnode(void) return intc_domain->fwnode; } -static int __init riscv_intc_init_common(struct fwnode_handle *fn, - struct irq_chip *chip) +static int __init riscv_intc_init_common(struct fwnode_handle *fn, struct irq_chip *chip) { int rc; @@ -176,11 +191,10 @@ static int __init riscv_intc_init_common(struct fwnode_handle *fn, riscv_set_intc_hwnode_fn(riscv_intc_hwnode); - pr_info("%d local interrupts mapped\n", riscv_intc_nr_irqs); - if (riscv_intc_custom_nr_irqs) { - pr_info("%d custom local interrupts mapped\n", - riscv_intc_custom_nr_irqs); - } + pr_info("%d local interrupts mapped\n", + riscv_isa_extension_available(NULL, SxAIA) ? 64 : riscv_intc_nr_irqs); + if (riscv_intc_custom_nr_irqs) + pr_info("%d custom local interrupts mapped\n", riscv_intc_custom_nr_irqs); return 0; }