Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp2109611pxa; Fri, 7 Aug 2020 03:27:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzqIYUjWP51lcJ17kwCnd6JPnMzy269xfQJdSAjd9vUx0jNKA9tzZpwts93qmw7h/qQ6k59 X-Received: by 2002:a17:906:7155:: with SMTP id z21mr9211429ejj.282.1596796051812; Fri, 07 Aug 2020 03:27:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596796051; cv=none; d=google.com; s=arc-20160816; b=mKd4L+vRamytGkyj+qp5RynqrtGsorjbcT1J6POJf1APo1sIqh7UZAJjo/+HqMjCB3 EraBh5nhYyuGyMWRZILY99P7UnwoRntuLfxHrBEHah3TthkMhHj8wIVRbYY+GfNVULBT U5WjU10oWO/0kXw0ybHDXKtsCKQMIetTRjYu7lhOui8oPv7XV08jMl9oMJ1s9AO6C9bL AMqDtQIe5FE53bey4ZczPm/PMAvVWI4rNiXhCacarBO8nVz5SH7Jf2vcsEID4Aqpb+ef qsFhc0PzVw4rS5joNme+ZpWfSGVhAO+XraINdwV7OF/35E185Cz0jE7cMUOtzR6P5emJ XXcA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=jMZ9Np59mwhB1Am+VWBP836eeb5+NFJxhLBg98/mYBo=; b=n5gvJZr9sPbqHXV5K6LiXsrRt7YHhINBBcx1HePBO5VT/X0Vg9FaJg+1Zw23f760gI WYC4UZkdV/U1L06/r/DjBe4nMvwIf7a6EPkZOCdItxUtHGNYsmmh6RIUya+dQ2Bgr/gM f9m+2RPJom5Yb0LDtULv4EoRnWi5EBbD3D0OnbzgeFKRMABPr3iWrDp8hb6pvzz/QLnc yDRsPEa5r918ec4kasNcV9yaS2Bk8LxZubYn3yHzSLxVfg3ucR6DDG/Ftcknah9L1ay6 FpK3mHWcpahhyM3mQZny+sxCx+joIS9RWpq8eFGwGf5onzLpmqUjpuXGb/58FViPmHJK kr1g== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j7si4856486edy.176.2020.08.07.03.27.08; Fri, 07 Aug 2020 03:27:31 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728353AbgHGKZw (ORCPT + 99 others); Fri, 7 Aug 2020 06:25:52 -0400 Received: from mx.socionext.com ([202.248.49.38]:31578 "EHLO mx.socionext.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726619AbgHGKZc (ORCPT ); Fri, 7 Aug 2020 06:25:32 -0400 Received: from unknown (HELO kinkan-ex.css.socionext.com) ([172.31.9.52]) by mx.socionext.com with ESMTP; 07 Aug 2020 19:25:30 +0900 Received: from mail.mfilter.local (m-filter-1 [10.213.24.61]) by kinkan-ex.css.socionext.com (Postfix) with ESMTP id 8D29A180BB5; Fri, 7 Aug 2020 19:25:30 +0900 (JST) Received: from 172.31.9.51 (172.31.9.51) by m-FILTER with ESMTP; Fri, 7 Aug 2020 19:25:30 +0900 Received: from plum.e01.socionext.com (unknown [10.213.132.32]) by kinkan.css.socionext.com (Postfix) with ESMTP id 2A0681A050B; Fri, 7 Aug 2020 19:25:30 +0900 (JST) From: Kunihiko Hayashi To: Lorenzo Pieralisi , Bjorn Helgaas , Jingoo Han , Gustavo Pimentel , Rob Herring , Masahiro Yamada , Marc Zyngier Cc: linux-pci@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Masami Hiramatsu , Jassi Brar , Kunihiko Hayashi Subject: [PATCH v6 2/6] PCI: dwc: Add msi_host_isr() callback Date: Fri, 7 Aug 2020 19:25:18 +0900 Message-Id: <1596795922-705-3-git-send-email-hayashi.kunihiko@socionext.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1596795922-705-1-git-send-email-hayashi.kunihiko@socionext.com> References: <1596795922-705-1-git-send-email-hayashi.kunihiko@socionext.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This adds msi_host_isr() callback function support to describe SoC-dependent service triggered by MSI. For example, when AER interrupt is triggered by MSI, the callback function reads SoC-dependent registers and detects that the interrupt is from AER, and invoke AER interrupts related to MSI. Cc: Marc Zyngier Cc: Jingoo Han Cc: Gustavo Pimentel Signed-off-by: Kunihiko Hayashi Acked-by: Gustavo Pimentel --- drivers/pci/controller/dwc/pcie-designware-host.c | 3 +++ drivers/pci/controller/dwc/pcie-designware.h | 1 + 2 files changed, 4 insertions(+) diff --git a/drivers/pci/controller/dwc/pcie-designware-host.c b/drivers/pci/controller/dwc/pcie-designware-host.c index 9dafecb..7948bf1 100644 --- a/drivers/pci/controller/dwc/pcie-designware-host.c +++ b/drivers/pci/controller/dwc/pcie-designware-host.c @@ -83,6 +83,9 @@ irqreturn_t dw_handle_msi_irq(struct pcie_port *pp) u32 status, num_ctrls; irqreturn_t ret = IRQ_NONE; + if (pp->ops->msi_host_isr) + pp->ops->msi_host_isr(pp); + num_ctrls = pp->num_vectors / MAX_MSI_IRQS_PER_CTRL; for (i = 0; i < num_ctrls; i++) { diff --git a/drivers/pci/controller/dwc/pcie-designware.h b/drivers/pci/controller/dwc/pcie-designware.h index f911760..401cbd9 100644 --- a/drivers/pci/controller/dwc/pcie-designware.h +++ b/drivers/pci/controller/dwc/pcie-designware.h @@ -170,6 +170,7 @@ struct dw_pcie_host_ops { void (*scan_bus)(struct pcie_port *pp); void (*set_num_vectors)(struct pcie_port *pp); int (*msi_host_init)(struct pcie_port *pp); + void (*msi_host_isr)(struct pcie_port *pp); }; struct pcie_port { -- 2.7.4