From patchwork Tue Sep 14 10:04:13 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Daniel Palmer X-Patchwork-Id: 512481 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-23.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, MENTIONS_GIT_HOSTING, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 48A56C433F5 for ; Tue, 14 Sep 2021 10:04:26 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 2B0D3610E6 for ; Tue, 14 Sep 2021 10:04:26 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230359AbhINKFm (ORCPT ); Tue, 14 Sep 2021 06:05:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60662 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230045AbhINKFm (ORCPT ); Tue, 14 Sep 2021 06:05:42 -0400 Received: from mail-pj1-x102b.google.com (mail-pj1-x102b.google.com [IPv6:2607:f8b0:4864:20::102b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3E43EC061574 for ; Tue, 14 Sep 2021 03:04:25 -0700 (PDT) Received: by mail-pj1-x102b.google.com with SMTP id j1so8476164pjv.3 for ; Tue, 14 Sep 2021 03:04:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=0x0f.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=KCtvujwOhok5kSxQj+KzouqiVUVy5jYTWpWg3/YjBhw=; b=qI7UFfAd9gT9HX4gx5WI0QIU16IruNCOAh603JoE+0MinA53YtAK/mA/kPASgPkNF5 jr6P3ZRA4znm9fwYarhtsYmVTHNjG957ndbiCVACkHRYPUP+154rQT7+fTgZdZQIR3to zSji+B/ix71b9zTIScDC3A1p6iUqsOy9OpKVo= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=KCtvujwOhok5kSxQj+KzouqiVUVy5jYTWpWg3/YjBhw=; b=fRuOkfA9My8NiraLXLi1mDjz0hEdnpJMD2clO0tJmKT36s/ta+wYqweRMMbH+YBLIC R9cIzqyQv/meYdHosfBMGTJIibhh3s8YbhPiJth/k6a5nRctufU2ctPA7uFsTyiQ1zA9 wPMGznoUmQQvvh4TCx8heMXSCylyqCDbSElZzoeAYZ72x0ZCV3kGWblYINEmkJTAKmBr YNI8k3em/X1QFB/yg5tut+9IOWZygfArm2/8fnErB7jWXvFAlKHyqm5XY6eiQyfB1R2X OFtHjau///HMinUKUeI8nMoov42wxqE1A9sDfFzAKHdVPVLq7TnCxVgZm3RUk8g+6E2o p5Tw== X-Gm-Message-State: AOAM532iLrIAaGB1Qg8BEbeJyvdSXJhVGwBDj/zqZNlnpCwlr0wniKSj Yo9GxPlIb6jvtBkslFC1xiwj6YaAyWdWxg== X-Google-Smtp-Source: ABdhPJw9iIKtgoHvSkRwEB73nLz3TWzHd2se6aSAVAwYhii6CrkTf9cKu1gEm0jOD7cY76J0KB/Ukg== X-Received: by 2002:a17:90b:4f49:: with SMTP id pj9mr1181702pjb.188.1631613864520; Tue, 14 Sep 2021 03:04:24 -0700 (PDT) Received: from shiro.work (p864106-ipngn200510sizuokaden.shizuoka.ocn.ne.jp. [180.9.58.106]) by smtp.googlemail.com with ESMTPSA id b5sm1193140pjq.2.2021.09.14.03.04.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Sep 2021 03:04:24 -0700 (PDT) From: Daniel Palmer To: devicetree@vger.kernel.org, robh+dt@kernel.org, maz@kernel.org, tglx@linutronix.de Cc: linux-arm-kernel@lists.infradead.org, romain.perier@gmail.com, Daniel Palmer Subject: [PATCH 1/3] dt-bindings: interrupt-controller: Add SigmaStar SSD20xD gpi Date: Tue, 14 Sep 2021 19:04:13 +0900 Message-Id: <20210914100415.1549208-2-daniel@0x0f.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210914100415.1549208-1-daniel@0x0f.com> References: <20210914100415.1549208-1-daniel@0x0f.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Add a binding description for the SigmaStar GPIO interrupt controller, gpi, found on the SSD201 and SSD202D. Signed-off-by: Daniel Palmer Reviewed-by: Rob Herring --- .../sstar,ssd20xd-gpi.yaml | 53 +++++++++++++++++++ MAINTAINERS | 1 + 2 files changed, 54 insertions(+) create mode 100644 Documentation/devicetree/bindings/interrupt-controller/sstar,ssd20xd-gpi.yaml diff --git a/Documentation/devicetree/bindings/interrupt-controller/sstar,ssd20xd-gpi.yaml b/Documentation/devicetree/bindings/interrupt-controller/sstar,ssd20xd-gpi.yaml new file mode 100644 index 000000000000..1f7e6c5fef52 --- /dev/null +++ b/Documentation/devicetree/bindings/interrupt-controller/sstar,ssd20xd-gpi.yaml @@ -0,0 +1,53 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/interrupt-controller/sstar,ssd20xd-gpi.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: SigmaStar GPIO Interrupt Controller + +maintainers: + - Daniel Palmer + +description: |+ + Newer SigmaStar SoCs from the SSD201/SSD202D have an extra + interrupt controller that is just for handling interrupts + on GPIOs and then routing a single interrupt to the peripheral + interrupt controller instead of only having a few interrupt + capable GPIOs that are routed directly to the peripheral + interrupt controller like older SoCs. + +properties: + compatible: + const: sstar,ssd20xd-gpi + + interrupt-controller: true + + "#interrupt-cells": + const: 2 + + reg: + maxItems: 1 + + interrupts: + maxItems: 1 + +required: + - compatible + - reg + - interrupts + +additionalProperties: false + +examples: + - | + #include + #include + interrupt-controller@207a00 { + compatible = "sstar,ssd20xd-gpi"; + reg = <0x207a00 0x200>; + #interrupt-cells = <2>; + interrupt-controller; + interrupts-extended = <&intc_irq GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>; + }; +... diff --git a/MAINTAINERS b/MAINTAINERS index eeb4c70b3d5b..3004c0f735b6 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -2243,6 +2243,7 @@ T: git git://github.com/linux-chenxing/linux.git F: Documentation/devicetree/bindings/arm/mstar/* F: Documentation/devicetree/bindings/clock/mstar,msc313-mpll.yaml F: Documentation/devicetree/bindings/gpio/mstar,msc313-gpio.yaml +F: Documentation/devicetree/bindings/interrupt-controller/sstar,ssd20xd-gpi.yaml F: arch/arm/boot/dts/mstar-* F: arch/arm/mach-mstar/ F: drivers/clk/mstar/ From patchwork Tue Sep 14 10:04:14 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Daniel Palmer X-Patchwork-Id: 511115 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E87ECC433F5 for ; Tue, 14 Sep 2021 10:04:28 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id D11456112D for ; Tue, 14 Sep 2021 10:04:28 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231156AbhINKFp (ORCPT ); Tue, 14 Sep 2021 06:05:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60682 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231240AbhINKFo (ORCPT ); Tue, 14 Sep 2021 06:05:44 -0400 Received: from mail-pj1-x1033.google.com (mail-pj1-x1033.google.com [IPv6:2607:f8b0:4864:20::1033]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 80C95C061766 for ; Tue, 14 Sep 2021 03:04:27 -0700 (PDT) Received: by mail-pj1-x1033.google.com with SMTP id w19-20020a17090aaf9300b00191e6d10a19so2336783pjq.1 for ; Tue, 14 Sep 2021 03:04:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=0x0f.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=vHkk05mDrsY3KSWdrb6INb6B11AEbP7JuzmBb5hOuY4=; b=ecFBrR0fSOfE9+OGSU8GT73gk99SCkl+JeI8eT/FHSXpr0mtqxU42PRa/Nb8UKFCQc ZmMKT7zI0JnhXqO5qxumXEmU0zSYmHs7xEYyen6S+jKHcUkhciACz1NxnkwNfGrZ1jel rAHwng9Cx5atuLc90M8VD2zyLmG0ilkb0cAeA= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=vHkk05mDrsY3KSWdrb6INb6B11AEbP7JuzmBb5hOuY4=; b=O73VkRp5slo6KkOS/aywzq+sCWm5BPayNbXnYpAmI7VQvCqL97+NdEzejuGNRC+9BY O+8bShxlCCgtsQFcY/U5AJiym+99sJjy1VV1D8YPDaLLBk7NFrqTT5jWOMSh/qJ1TrIf BZHzGkDcxOYraUL0jiBIQhmPflt/26c3IgjJwet5rDZ/i0MWITv5cewLQILf71pjwLmp LpYP1fq5aK84jBdIWibfd/xRntxLXntYpxyv1Nlk2BlkrgMC3fCQBPVcfUOwi3aKajlW av1U24orWNx4aeKU9kTjq4xv+w3LMRjkuPLio/0nGHnN6o2XzMETR0K9IFDCjGSATJWw 055A== X-Gm-Message-State: AOAM5326uoksw4H/0vUqDz3ctrUm6EbOc39hI/9yb/NdHZABIOrGzDdl XI/I5cJe8nzWzMkFh74a6ho0GmZixo2UYA== X-Google-Smtp-Source: ABdhPJzFkUyVSzv8/bupd/h8mqoFQH/4MV5egQzmJw3d6Llp+KaZZZt6L04XsAkAl2X1fW8UuWCPkQ== X-Received: by 2002:a17:90b:616:: with SMTP id gb22mr1132136pjb.191.1631613866810; Tue, 14 Sep 2021 03:04:26 -0700 (PDT) Received: from shiro.work (p864106-ipngn200510sizuokaden.shizuoka.ocn.ne.jp. [180.9.58.106]) by smtp.googlemail.com with ESMTPSA id b5sm1193140pjq.2.2021.09.14.03.04.24 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Sep 2021 03:04:26 -0700 (PDT) From: Daniel Palmer To: devicetree@vger.kernel.org, robh+dt@kernel.org, maz@kernel.org, tglx@linutronix.de Cc: linux-arm-kernel@lists.infradead.org, romain.perier@gmail.com, Daniel Palmer Subject: [PATCH 2/3] irqchip: SigmaStar SSD20xD gpi Date: Tue, 14 Sep 2021 19:04:14 +0900 Message-Id: <20210914100415.1549208-3-daniel@0x0f.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210914100415.1549208-1-daniel@0x0f.com> References: <20210914100415.1549208-1-daniel@0x0f.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Add support for the SigmaStar GPIO interrupt controller, gpi, that is present in SSD201 and SSD202D SoCs. This routes interrupts from many interrupts into a single interrupt that is connected to the peripheral interrupt controller. Signed-off-by: Daniel Palmer --- MAINTAINERS | 1 + drivers/irqchip/Kconfig | 11 ++ drivers/irqchip/Makefile | 2 + drivers/irqchip/irq-ssd20xd-gpi.c | 211 ++++++++++++++++++++++++++++++ 4 files changed, 225 insertions(+) create mode 100644 drivers/irqchip/irq-ssd20xd-gpi.c diff --git a/MAINTAINERS b/MAINTAINERS index 3004c0f735b6..487d5e62c287 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -2248,6 +2248,7 @@ F: arch/arm/boot/dts/mstar-* F: arch/arm/mach-mstar/ F: drivers/clk/mstar/ F: drivers/gpio/gpio-msc313.c +F: drivers/irqchip/irq-ssd20xd-gpi.c F: drivers/watchdog/msc313e_wdt.c F: include/dt-bindings/clock/mstar-* F: include/dt-bindings/gpio/msc313-gpio.h diff --git a/drivers/irqchip/Kconfig b/drivers/irqchip/Kconfig index 4d5924e9f766..8786aed7f776 100644 --- a/drivers/irqchip/Kconfig +++ b/drivers/irqchip/Kconfig @@ -582,6 +582,17 @@ config MST_IRQ help Support MStar Interrupt Controller. +config SSD20XD_GPI + bool "SigmaStar SSD20xD GPIO Interrupt Controller" + depends on ARCH_MSTARV7 || COMPILE_TEST + default ARCH_MSTARV7 + select IRQ_DOMAIN + select IRQ_DOMAIN_HIERARCHY + select REGMAP + help + Support for the SigmaStar GPIO interrupt controller + found in SSD201, SSD202D and others. + config WPCM450_AIC bool "Nuvoton WPCM450 Advanced Interrupt Controller" depends on ARCH_WPCM450 diff --git a/drivers/irqchip/Makefile b/drivers/irqchip/Makefile index f88cbf36a9d2..1a6c3dbd67a8 100644 --- a/drivers/irqchip/Makefile +++ b/drivers/irqchip/Makefile @@ -116,3 +116,5 @@ obj-$(CONFIG_MACH_REALTEK_RTL) += irq-realtek-rtl.o obj-$(CONFIG_WPCM450_AIC) += irq-wpcm450-aic.o obj-$(CONFIG_IRQ_IDT3243X) += irq-idt3243x.o obj-$(CONFIG_APPLE_AIC) += irq-apple-aic.o +obj-$(CONFIG_SSD20XD_GPI) += irq-ssd20xd-gpi.o + diff --git a/drivers/irqchip/irq-ssd20xd-gpi.c b/drivers/irqchip/irq-ssd20xd-gpi.c new file mode 100644 index 000000000000..c34f41380717 --- /dev/null +++ b/drivers/irqchip/irq-ssd20xd-gpi.c @@ -0,0 +1,211 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright (C) 2021 Daniel Palmer + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#define NUM_IRQ 76 +#define IRQS_PER_REG 16 +#define STRIDE 4 + +#define REG_MASK 0x0 +#define REG_ACK 0x28 +#define REG_TYPE 0x40 +#define REG_STATUS 0xc0 + +struct ssd20xd_gpi { + struct regmap *regmap; + struct irq_domain *domain; +}; + +#define REG_OFFSET(_hwirq) ((hwirq >> 4) * STRIDE) +#define BIT_OFFSET(_hwirq) (1 << (hwirq & 0xf)) + +static void ssd20xd_gpi_mask_irq(struct irq_data *data) +{ + irq_hw_number_t hwirq = irqd_to_hwirq(data); + struct ssd20xd_gpi *gpi = irq_data_get_irq_chip_data(data); + int offset_reg = REG_OFFSET(hwirq); + int offset_bit = BIT_OFFSET(hwirq); + + regmap_update_bits(gpi->regmap, REG_MASK + offset_reg, offset_bit, offset_bit); +} + +static void ssd20xd_gpi_unmask_irq(struct irq_data *data) +{ + irq_hw_number_t hwirq = irqd_to_hwirq(data); + struct ssd20xd_gpi *gpi = irq_data_get_irq_chip_data(data); + int offset_reg = REG_OFFSET(hwirq); + int offset_bit = BIT_OFFSET(hwirq); + + regmap_update_bits(gpi->regmap, REG_MASK + offset_reg, offset_bit, 0); +} + +static void ssd20xd_gpi_irq_eoi(struct irq_data *data) +{ + struct ssd20xd_gpi *gpi = irq_data_get_irq_chip_data(data); + irq_hw_number_t hwirq = irqd_to_hwirq(data); + int offset_reg = REG_OFFSET(hwirq); + int offset_bit = BIT_OFFSET(hwirq); + + regmap_update_bits_base(gpi->regmap, REG_ACK + offset_reg, + offset_bit, offset_bit, NULL, false, true); +} + +static int ssd20xd_gpi_set_type_irq(struct irq_data *data, unsigned int flow_type) +{ + irq_hw_number_t hwirq = irqd_to_hwirq(data); + struct ssd20xd_gpi *gpi = irq_data_get_irq_chip_data(data); + int offset_reg = REG_OFFSET(hwirq); + int offset_bit = BIT_OFFSET(hwirq); + + switch (flow_type) { + case IRQ_TYPE_EDGE_FALLING: + regmap_update_bits(gpi->regmap, REG_TYPE + offset_reg, offset_bit, offset_bit); + break; + case IRQ_TYPE_EDGE_RISING: + regmap_update_bits(gpi->regmap, REG_TYPE + offset_reg, offset_bit, 0); + break; + default: + return -EINVAL; + } + + return 0; +} + +static struct irq_chip ssd20xd_gpi_chip = { + .name = "GPI", + .irq_mask = ssd20xd_gpi_mask_irq, + .irq_unmask = ssd20xd_gpi_unmask_irq, + .irq_eoi = ssd20xd_gpi_irq_eoi, + .irq_set_type = ssd20xd_gpi_set_type_irq, +}; + +static int ssd20xd_gpi_domain_alloc(struct irq_domain *domain, unsigned int virq, + unsigned int nr_irqs, void *arg) +{ + struct ssd20xd_gpi *intc = domain->host_data; + struct irq_fwspec *fwspec = arg; + int i; + + for (i = 0; i < nr_irqs; i++) + irq_domain_set_info(domain, virq + i, fwspec->param[0] + i, + &ssd20xd_gpi_chip, intc, handle_fasteoi_irq, NULL, NULL); + + return 0; +} + +static void ssd20xd_gpi_domain_free(struct irq_domain *domain, unsigned int virq, + unsigned int nr_irqs) +{ + int i; + + for (i = 0; i < nr_irqs; i++) { + struct irq_data *d = irq_domain_get_irq_data(domain, virq + i); + + irq_set_handler(virq + i, NULL); + irq_domain_reset_irq_data(d); + } +} + +static const struct irq_domain_ops ssd20xd_gpi_domain_ops = { + .alloc = ssd20xd_gpi_domain_alloc, + .free = ssd20xd_gpi_domain_free, +}; + +static const struct regmap_config ssd20xd_gpi_regmap_config = { + .reg_bits = 16, + .val_bits = 16, + .reg_stride = 4, +}; + +static void ssd20x_gpi_chainedhandler(struct irq_desc *desc) +{ + struct ssd20xd_gpi *intc = irq_desc_get_handler_data(desc); + struct irq_chip *chip = irq_desc_get_chip(desc); + unsigned int irqbit, hwirq, virq, status; + int i; + + chained_irq_enter(chip, desc); + + for (i = 0; i < NUM_IRQ / IRQS_PER_REG; i++) { + int offset_reg = STRIDE * i; + int offset_irq = IRQS_PER_REG * i; + + regmap_read(intc->regmap, REG_STATUS + offset_reg, &status); + + while (status) { + irqbit = __ffs(status); + hwirq = offset_irq + irqbit; + virq = irq_find_mapping(intc->domain, hwirq); + if (virq) + generic_handle_irq(virq); + status &= ~BIT(irqbit); + } + } + + chained_irq_exit(chip, desc); +} + +static int __init ssd20xd_gpi_of_init(struct device_node *node, + struct device_node *parent) +{ + struct ssd20xd_gpi *intc; + void __iomem *base; + int irq, ret; + + intc = kzalloc(sizeof(*intc), GFP_KERNEL); + if (!intc) + return -ENOMEM; + + base = of_iomap(node, 0); + if (!base) { + ret = -ENODEV; + goto out_free; + } + + intc->regmap = regmap_init_mmio(NULL, base, &ssd20xd_gpi_regmap_config); + if (IS_ERR(intc->regmap)) { + ret = PTR_ERR(intc->regmap); + goto out_unmap; + } + + intc->domain = irq_domain_add_linear(node, NUM_IRQ, &ssd20xd_gpi_domain_ops, intc); + if (!intc->domain) { + ret = -ENOMEM; + goto out_free_regmap; + } + + irq = of_irq_get(node, 0); + if (irq <= 0) { + ret = irq; + goto out_free_domain; + } + + irq_set_chained_handler_and_data(irq, ssd20x_gpi_chainedhandler, + intc); + + return 0; + +out_free_domain: + irq_domain_remove(intc->domain); +out_free_regmap: + regmap_exit(intc->regmap); +out_unmap: + iounmap(base); +out_free: + kfree(intc); + return ret; +} + +IRQCHIP_DECLARE(ssd20xd_gpi, "sstar,ssd20xd-gpi", ssd20xd_gpi_of_init); From patchwork Tue Sep 14 10:04:15 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Daniel Palmer X-Patchwork-Id: 512480 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-18.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID, DKIM_VALID_AU, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_CR_TRAILER, INCLUDES_PATCH, MAILING_LIST_MULTI, SPF_HELO_NONE, SPF_PASS, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 4BB1BC433EF for ; Tue, 14 Sep 2021 10:04:31 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 33F61610E6 for ; Tue, 14 Sep 2021 10:04:31 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230045AbhINKFr (ORCPT ); Tue, 14 Sep 2021 06:05:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60698 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231206AbhINKFq (ORCPT ); Tue, 14 Sep 2021 06:05:46 -0400 Received: from mail-pg1-x52b.google.com (mail-pg1-x52b.google.com [IPv6:2607:f8b0:4864:20::52b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8A407C061574 for ; Tue, 14 Sep 2021 03:04:29 -0700 (PDT) Received: by mail-pg1-x52b.google.com with SMTP id u18so12280746pgf.0 for ; Tue, 14 Sep 2021 03:04:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=0x0f.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=YTelFZ4YtHf/yrnhtZbgR71tzP43nh7KX3YNOVUak+s=; b=CDiYaRE8KSSxIhfQOOhRsN6w0ItvBOupzSsXso1Cg0qX2Idl25xAonAUlcRIV68n3J dqiF8rLbw4zsk11oMl5LIjNtFau/hfFbp73LbkkjWVzJhUersS7r6ZUmop4bdzy871gm 4Zf8dMsmSLsM+OCtvMDx706DiUTGdqZVrlUmA= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=YTelFZ4YtHf/yrnhtZbgR71tzP43nh7KX3YNOVUak+s=; b=2EdLYlRI6NLBZKmhWutTGUqX8ReyDVJ3SepMFHuMSIzHGZEX8vY6qRaZj3OsOxCMRo j5NoLr1AUqAwuMGOy/k6vt2/nJ7R2Zes703W62E9lQmMPNWcmxzkroZ9M5/7zm5Vy82P Sk7A+o1B1s89lb8I59svRa7CWinIE13+IiSVWrooDG0iEkIwiDW3F8XgJo+CV0f4Bjoi sUUfONH200GQJZUMOaMhLsYlbiqzbesVhlXcHBPcgrlzcTq1DlXl0OYdndwIvXiTddA5 YeUx1yGLfBqlSt0xypxsr60ho7xCOJBSpfS50UyJXzrWEPvxsOiLNXXmwrYR7q6OhQnu +Ccw== X-Gm-Message-State: AOAM531QeDh6koYlZOVQ6QZXteRUVUG7I67K5rFs8vr8aKUXO98a7IVG f+o+/3RvRkTNNNaC/TD0Y2zCbaW/xMc4gA== X-Google-Smtp-Source: ABdhPJyCIXrzQ5K0STeAbnPCw0Q3hAIFcsHGW/ThZZ3HavCLvmQJU8byUMa+tJQKdG6lXAWzTFobJw== X-Received: by 2002:a62:2c51:0:b029:329:932b:9484 with SMTP id s78-20020a622c510000b0290329932b9484mr3901155pfs.13.1631613868913; Tue, 14 Sep 2021 03:04:28 -0700 (PDT) Received: from shiro.work (p864106-ipngn200510sizuokaden.shizuoka.ocn.ne.jp. [180.9.58.106]) by smtp.googlemail.com with ESMTPSA id b5sm1193140pjq.2.2021.09.14.03.04.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 14 Sep 2021 03:04:28 -0700 (PDT) From: Daniel Palmer To: devicetree@vger.kernel.org, robh+dt@kernel.org, maz@kernel.org, tglx@linutronix.de Cc: linux-arm-kernel@lists.infradead.org, romain.perier@gmail.com, Daniel Palmer Subject: [PATCH 3/3] ARM: dts: mstar: Add gpi interrupt controller to i2m Date: Tue, 14 Sep 2021 19:04:15 +0900 Message-Id: <20210914100415.1549208-4-daniel@0x0f.com> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210914100415.1549208-1-daniel@0x0f.com> References: <20210914100415.1549208-1-daniel@0x0f.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org infinity2m chips have the GPI interrupt controller for GPIOs so add it to the dtsi for infinity2m. Signed-off-by: Daniel Palmer --- arch/arm/boot/dts/mstar-infinity2m.dtsi | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/arch/arm/boot/dts/mstar-infinity2m.dtsi b/arch/arm/boot/dts/mstar-infinity2m.dtsi index 6d4d1d224e96..0ec8e4cadf5c 100644 --- a/arch/arm/boot/dts/mstar-infinity2m.dtsi +++ b/arch/arm/boot/dts/mstar-infinity2m.dtsi @@ -19,4 +19,12 @@ smpctrl: smpctrl@204000 { reg = <0x204000 0x200>; status = "disabled"; }; + + gpi: interrupt-controller@207a00 { + compatible = "sstar,ssd20xd-gpi"; + reg = <0x207a00 0x200>; + #interrupt-cells = <2>; + interrupt-controller; + interrupts-extended = <&intc_irq GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>; + }; };