From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-pl1-f181.google.com (mail-pl1-f181.google.com [209.85.214.181]) (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 DCF803E1D01 for ; Tue, 30 Jun 2026 04:58:22 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.214.181 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782795505; cv=none; b=qONvTKyTfnfxTVbY+T1nANW7qDA7iXA7Ce0uDI6Mv7zO1BN2lwXr+qmiQ0N1GVvt6oJbITrZi50nctK0QmBAeCLdsbCBSmZHjFebMzSuSAqph/49gsvoOsxRz3QiBVow2O5UZCwwXykRKxSlkUy8q/lRraav/OcDpMCx6lsN2jA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1782795505; c=relaxed/simple; bh=PDtmAlN/l3AacalC3gwsynICMhrvd+rFwPMR8b97xBw=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=aYs3P9D5p+PkEcfxza7fHtVnLr7RjU66Y50Iyp123Og2uNsSv//IdCb89boXVozBBSMILK7COxQ5+dYoHUBurf6q/ajvP1MhJ6v4d+ipwfhkwt0YTtmo6VLDsB7rIpXhHVTds752sOpILY5GHTECcUVYhe7w9UkTQcIRXBcKMPs= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com; spf=pass smtp.mailfrom=google.com; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b=aZ5TrwG0; arc=none smtp.client-ip=209.85.214.181 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=reject dis=none) header.from=google.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=google.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=google.com header.i=@google.com header.b="aZ5TrwG0" Received: by mail-pl1-f181.google.com with SMTP id d9443c01a7336-2c9b2ac97cdso19385ad.1 for ; Mon, 29 Jun 2026 21:58:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20251104; t=1782795502; x=1783400302; darn=vger.kernel.org; h=in-reply-to:content-disposition:content-type:mime-version :references:message-id:subject:cc:to:from:date:from:to:cc:subject :date:message-id:reply-to:content-type; bh=BTfbnMUIEG0n8Nzn7+iH305BTPpn6kW1wYaDzBzIPgA=; b=aZ5TrwG0ZDfXuB2hdL/WI4s7/Pi+ZVcwWlZ0C9QJ0yjJnFEX1Iu7UCXH50SuipX9i2 IOFvFUvYaW3uYq24erGhXg0C7yjxan9Qr0RHo0oscZDXnzNIM1yFHhvdLT91nA3peRHl TeIuIb1bDcJpqGIOZUFU7gysw3kYMImlbYjHOKO1y+XhRypDpd7LKc/wasZSGCEFln/2 HCRgWxl/bqkB1SJdk8T0X8mWpaB3EYtNYHecjRgyxA/d3GwE7TM8/GKm6CZ3w/C8HwW1 2omkhQIGyzvdIDRdAO+mgA+CRyIqyIVbi6U+wzd+iYoKLCrZQsQxvjvGwWZ5qC83fUld k2ZA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20251104; t=1782795502; x=1783400302; h=in-reply-to:content-disposition:content-type:mime-version :references:message-id:subject:cc:to:from:date:x-gm-gg :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to :content-type; bh=BTfbnMUIEG0n8Nzn7+iH305BTPpn6kW1wYaDzBzIPgA=; b=MSakBb3LMB9Q9gr7DZgPYiznHYcxA7REMSmdSJitKJki9WkPlr/jaTXD9IsBDcWTtg lzuzjhckYm2zqI/jJBms26cOXuOJIbTs62R3F9ZdX4hy2ovhNUspKveVkf3p7wIqPzW/ C6J0wF/3525Sh21RrU07yXAcpTMuR9lz4NsKagNZiIqM+gyEWC8b6zMy3UCfc8nFMDZn Ws2tMoSDDW8F6lft2AcFIdtWhMguxChf9m4sMtLG5eTFOJMiHkMWNBUWwezRfgFr6YaK kBqYV1pVROjFAsFK+LwMLpyr5M9q4kMm0l9FuHxOlZgzkgMewBtH1usfpre28IRnrdwy OnkA== X-Forwarded-Encrypted: i=1; AHgh+RoPdOefpIKSxE0P6TtxtLVaIdMsG3viSqRPKnFS4BNofXwe2pQgt590JaSUJbo2anWDhl28D3xwSwXagos=@vger.kernel.org X-Gm-Message-State: AOJu0Yx08d5dUhHI03uzXwLDpPZ7AGdqkg7guSue7ZmcU8zPTLlKaijN H/nVevIPT/cROTMX0WQ3D04uJitxctNSUV8LYd87zlF9yP/Eak7Za/PscWv46JNoAg== X-Gm-Gg: AfdE7cnxvDRiIeLueBs8PZsTy9Iknl5azkN69dae4Vzgm2eXlU4nE2wZlLrRcox+73J Fw3p8lFWb5c6cM6+4M6ceYht5+fBq/MFwk6JA+V1xpMlQ/0dFogtdRs6+DT/BNiCkvJp9iM8XSz I5CRM1gIkRHTIjTtTaaeXpdVxTOkSi9HjrUa2kEKq8+3RHQrjhlSQgr9l9E6m5pBI9BvKjWR+Aa LEhTsAsUi/OExjXdnMLtCytg63s4rAEqa2zhAfmYGBPgMX2V28XykpUVC3yNGkPZZrbkbNZckMo r04IbAXrxQ0h3CZ5ZR1ulkopCeMc1Jej4vH3YSxSPZ7E3/517R1GJNMUBkQVStAd2RDgMigq9Wl JxB5njUOgqdOn0uNKbIqgzGVWNbGAfkbX1z0JPyVt4YrosykTr/qQt3J/L2OgKj6iSZ0qRs5dWH xh7XCagFK1X5JdQpZshgX355NS5nqmIW/lf8ubp1FvgJswp4U= X-Received: by 2002:a17:903:26c5:b0:2bf:3579:cdaa with SMTP id d9443c01a7336-2ca380db35emr922105ad.10.1782795501571; Mon, 29 Jun 2026 21:58:21 -0700 (PDT) Received: from google.com (10.129.124.34.bc.googleusercontent.com. [34.124.129.10]) by smtp.gmail.com with ESMTPSA id 98e67ed59e1d1-38052f3281dsm859454a91.12.2026.06.29.21.58.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 29 Jun 2026 21:58:20 -0700 (PDT) Date: Tue, 30 Jun 2026 04:58:14 +0000 From: Pranjal Shrivastava To: Nicolin Chen Cc: will@kernel.org, robin.murphy@arm.com, jgg@nvidia.com, joro@8bytes.org, kees@kernel.org, baolu.lu@linux.intel.com, kevin.tian@intel.com, miko.lenczewski@arm.com, smostafa@google.com, linux-arm-kernel@lists.infradead.org, iommu@lists.linux.dev, linux-kernel@vger.kernel.org, stable@vger.kernel.org, jamien@nvidia.com Subject: Re: [PATCH rc v6 3/7] iommu/arm-smmu-v3: Do not enable EVTQ/PRIQ interrupts in kdump kernel Message-ID: References: Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: On Mon, Jun 29, 2026 at 09:14:48PM -0700, Nicolin Chen wrote: > On Mon, Jun 29, 2026 at 08:48:11AM +0000, Pranjal Shrivastava wrote: > > On Wed, May 20, 2026 at 10:03:20AM -0700, Nicolin Chen wrote: > > > @@ -5020,19 +5029,30 @@ static int arm_smmu_setup_irqs(struct arm_smmu_device *smmu) > > > /* > > > * Cavium ThunderX2 implementation doesn't support unique irq > > > * lines. Use a single irq line for all the SMMUv3 interrupts. > > > + * > > > + * In kdump, EVTQ/PRIQ are disabled, so no threaded handling. > > > */ > > > - ret = devm_request_threaded_irq(smmu->dev, irq, > > > - arm_smmu_combined_irq_handler, > > > - arm_smmu_combined_irq_thread, > > > - IRQF_ONESHOT, > > > - "arm-smmu-v3-combined-irq", smmu); > > > + if (is_kdump_kernel()) > > > + ret = devm_request_irq(smmu->dev, irq, > > > + arm_smmu_combined_irq_handler, 0, > > > + "arm-smmu-v3-combined-irq", > > > + smmu); > > > > This `if` isn't needed, we can continue using devm_request_threaded_irq, > > if you look at the doc for devm_request_threaded_irq [1] it says: > [...] > > So, we can pass handler() here while leaving the thread_fn == NULL: > > > > ret = devm_request_threaded_irq(smmu->dev, irq, > > arm_smmu_combined_irq_handler, > > is_kdump_kernel() ? NULL : arm_smmu_combined_irq_thread, > > IRQF_ONESHOT, > > "arm-smmu-v3-combined-irq", smmu); > > Are you sure? > > __setup_irq(): > 1497- /* > 1498: * IRQF_ONESHOT means the interrupt source in the IRQ chip will be > 1499- * masked until the threaded handled is done. If there is no thread > 1500: * handler then it makes no sense to have IRQF_ONESHOT. > 1501- */ > 1502: WARN_ON_ONCE(new->flags & IRQF_ONESHOT && !new->thread_fn); I meant without IRQF_ONESHOT: is_kdump_kernel() ? 0 : IRQF_ONESHOT, note that devm_request_irq is just: static inline int __must_check devm_request_irq(struct device *dev, unsigned int irq, irq_handler_t handler, unsigned long irqflags, const char *devname, void *dev_id) { return devm_request_threaded_irq(dev, irq, handler, NULL, irqflags | IRQF_COND_ONESHOT, devname, dev_id); } Not a strong opinion though, just suggesting a way to remove the if. > > > Additionally, the arm_smmu_combined_irq_handler() returns > > IRQ_WAKE_THREAD unconditionally, which causes us to hit the warn_on[3] in > > __handle_irq_event_percpu. > > arm_smmu_combined_irq_handler() does not return IRQ_WAKE_THREAD > unconditionally. > > This is the first part of PATCH-3 in v6: Ahh I missed that, somehow. Thanks, Praan