Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4564447pxj; Wed, 12 May 2021 08:17:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxZJWVkFNpwoguJcp7ibjF2sMDR9CCfleY7t26NFkDydJlVKQ5d2jNZUH9XVwzfUT3f3AHe X-Received: by 2002:aa7:c845:: with SMTP id g5mr44569284edt.219.1620832634278; Wed, 12 May 2021 08:17:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620832634; cv=none; d=google.com; s=arc-20160816; b=zjXN3o/9dSNcfUD8tyZ9W5vVki3u1smTMjGwEK4pGnumWz0sIqjPsNWlO8KC06RXaD 1Finfr94WTs2zK3GoF2c3OIfi/K55/KUQB9wv4aAKk1sN4pIBIqHWk/Azd5z03Mr850v tul7zvUXdrNQSs4i6FXL1K9VYbqxNpaBuO8XMo6Su+3fvD/ySCI0aZL6ddMv2VZnN9K1 lFVx1jbLlVdDxV7V1Tn68emiM52qJcqDRTdC3d1jCGoN3K0tTVUDgOnZquEXFQa3eqd+ ngdYrKR42k0bYdX8xnfrmH3wPDpz2wJ3g19tvx8jPdGyk/eeCO2uLjJtiaGl6aYxYlwy vLnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Z04KID4efhshlunsGNiahNtdAyZ/NIv/CQBWXp0fQIo=; b=XJbyIWUsmAm9c0S0z2Zty4MgOJ0HuQAevDrS1xcGYyJefkMSuGjAdWIjyc7bQpohep BOLY2aHRWhWSv515w9l5gDV9LW1hHu00+nz0jlyq2/jkAZraZgXwd/Xqb52l5vTzvlKw vKuuVn0US0LzlcKF6KsjKQBg7K+/XV5XsWOh01y+LiO3uaDIGYv8OsSzjluh0qTo+/W8 Pp8U+6f/YIfsbqooo9s1v/NAtyEw8PDiDGPYeRMkmRIbZHzq1dytCiV/jVYHEkX+5ocs qG2LkDq4u/c3Kueo95m7nRT3OuJJyIPvun9/PSLLDiRKapKa3yyHdpZ/w0a+G0RNUI/p 9cuw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=myl6zSMB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id nb17si321803ejc.226.2021.05.12.08.16.49; Wed, 12 May 2021 08:17:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=myl6zSMB; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233980AbhELPPv (ORCPT + 99 others); Wed, 12 May 2021 11:15:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:58514 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232444AbhELPGF (ORCPT ); Wed, 12 May 2021 11:06:05 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E2B7561955; Wed, 12 May 2021 15:00:47 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620831648; bh=/16dDmNvYVlxnKuY4DJUg6LCH4aOE9dIxnPsFX9iCeA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=myl6zSMBoIeUvXszYwkKlm5Mhbbh851vGl4XGHzVpVhLpjQvpRxzpqJB3pPtpNDDU hOjGhdHGMRmTkt162FBWLteTUTdSZ9n3QG0u0uivOaeAMIRy+UekVJKaYu3FZmo4V4 0awmbUtFMQhIW+aWkjZuwGnQal18CEGCf+raRffg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, kernel test robot , Dan Carpenter , =?UTF-8?q?C=C3=A9dric=20Le=20Goater?= , Greg Kurz , Michael Ellerman , Sasha Levin Subject: [PATCH 5.4 205/244] powerpc/xive: Fix xmon command "dxi" Date: Wed, 12 May 2021 16:49:36 +0200 Message-Id: <20210512144749.555504757@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144743.039977287@linuxfoundation.org> References: <20210512144743.039977287@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Cédric Le Goater [ Upstream commit 33e4bc5946432a4ac173fd08e8e30a13ab94d06d ] When under xmon, the "dxi" command dumps the state of the XIVE interrupts. If an interrupt number is specified, only the state of the associated XIVE interrupt is dumped. This form of the command lacks an irq_data parameter which is nevertheless used by xmon_xive_get_irq_config(), leading to an xmon crash. Fix that by doing a lookup in the system IRQ mapping to query the IRQ descriptor data. Invalid interrupt numbers, or not belonging to the XIVE IRQ domain, OPAL event interrupt number for instance, should be caught by the previous query done at the firmware level. Fixes: 97ef27507793 ("powerpc/xive: Fix xmon support on the PowerNV platform") Reported-by: kernel test robot Reported-by: Dan Carpenter Signed-off-by: Cédric Le Goater Tested-by: Greg Kurz Reviewed-by: Greg Kurz Signed-off-by: Michael Ellerman Link: https://lore.kernel.org/r/20210331144514.892250-8-clg@kaod.org Signed-off-by: Sasha Levin --- arch/powerpc/sysdev/xive/common.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/arch/powerpc/sysdev/xive/common.c b/arch/powerpc/sysdev/xive/common.c index 16df9cc8f360..2d4c09a77910 100644 --- a/arch/powerpc/sysdev/xive/common.c +++ b/arch/powerpc/sysdev/xive/common.c @@ -257,17 +257,20 @@ notrace void xmon_xive_do_dump(int cpu) xmon_printf("\n"); } +static struct irq_data *xive_get_irq_data(u32 hw_irq) +{ + unsigned int irq = irq_find_mapping(xive_irq_domain, hw_irq); + + return irq ? irq_get_irq_data(irq) : NULL; +} + int xmon_xive_get_irq_config(u32 hw_irq, struct irq_data *d) { - struct irq_chip *chip = irq_data_get_irq_chip(d); int rc; u32 target; u8 prio; u32 lirq; - if (!is_xive_irq(chip)) - return -EINVAL; - rc = xive_ops->get_irq_config(hw_irq, &target, &prio, &lirq); if (rc) { xmon_printf("IRQ 0x%08x : no config rc=%d\n", hw_irq, rc); @@ -277,6 +280,9 @@ int xmon_xive_get_irq_config(u32 hw_irq, struct irq_data *d) xmon_printf("IRQ 0x%08x : target=0x%x prio=%02x lirq=0x%x ", hw_irq, target, prio, lirq); + if (!d) + d = xive_get_irq_data(hw_irq); + if (d) { struct xive_irq_data *xd = irq_data_get_irq_handler_data(d); u64 val = xive_esb_read(xd, XIVE_ESB_GET); -- 2.30.2