Received: by 2002:ac0:aa62:0:0:0:0:0 with SMTP id w31-v6csp409761ima; Thu, 25 Oct 2018 23:42:21 -0700 (PDT) X-Google-Smtp-Source: AJdET5c1aNXLXAhgJNMUAaZBhYpwWSmEOet3QGLEMmSiw4hnft7mhC3EXfw5EpR3BwL1/yrYnQSr X-Received: by 2002:a62:b50a:: with SMTP id y10-v6mr2428317pfe.199.1540536141305; Thu, 25 Oct 2018 23:42:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1540536141; cv=none; d=google.com; s=arc-20160816; b=eYNM9rtYLHH536ZONF3duRh8sjytu2Dt/G1fMIaNHSIzjusX4r5CmcKDcmtQe95QZ0 pSo6OUkmROdQKkXZOeQXqzbfnXxpHvV3oth2G+hFeuvgoCXyogd8znUxfc5vbOSHxq8D 4Q0TxW0N2x++LwQt+Tlr327i4la0sjwCKWbTmeQUICiRIkXgPQ+ZzDpxC8kyQk1J4SEb AbBxCU5ar4NPXxU1wqB5yd1DMyikbrRFn0y6U5ecf9yfIZgA1ujSNzqMqeQRGcTsc+4c 23mm4Q5Vj7RDNO6iF/tAJJ+pY1Nv1eVLx4hiK8NQ6uQKuXEpJkK9F9X0enEV89Bmnnn6 kQgA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=Omqjo9OavGDfWSFSLMCvC47iqh9+a28U5wzQyrRb8Qg=; b=lEahnZ7CeDWobRQZFK8ql6egWCPm2RDo2YJUF7T5pbxIST98a4MVYMyMA+XEpX6HuW nYltC8DCPFgzBbcDQYsBgfkGUKP7+lOFtr3bIjySx/0ObGYphcBQ/+jgfL0ehvZaGZnj JyLs5r24CzGTbuaWKWl8j4RL+3cwqH+Uc6bxflIYS5k/5wi2bhWTmf73HF04qUYvVpK4 hiYBYoQtqd9+ggeNAszHjJshTuCeg8UpBZkT+c0QTHMXTwGhGEYxPJqAKr3SaYhGXyE5 lyrbIDLMZgHKOgp4DgRxTF+VhTEC0SQxsrNKGrdv6nxJQ2fYaCgM+VOjOrDt8zytg26v NRIg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r24-v6si10170928pgv.380.2018.10.25.23.42.05; Thu, 25 Oct 2018 23:42:21 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726493AbeJZPPZ (ORCPT + 99 others); Fri, 26 Oct 2018 11:15:25 -0400 Received: from fllv0015.ext.ti.com ([198.47.19.141]:35900 "EHLO fllv0015.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725993AbeJZPPZ (ORCPT ); Fri, 26 Oct 2018 11:15:25 -0400 Received: from lelv0265.itg.ti.com ([10.180.67.224]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id w9Q6d9dm110649; Fri, 26 Oct 2018 01:39:09 -0500 Received: from DLEE107.ent.ti.com (dlee107.ent.ti.com [157.170.170.37]) by lelv0265.itg.ti.com (8.15.2/8.15.2) with ESMTPS id w9Q6d9HK046251 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Fri, 26 Oct 2018 01:39:09 -0500 Received: from DLEE109.ent.ti.com (157.170.170.41) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1466.3; Fri, 26 Oct 2018 01:39:09 -0500 Received: from dflp32.itg.ti.com (10.64.6.15) by DLEE109.ent.ti.com (157.170.170.41) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.1466.3 via Frontend Transport; Fri, 26 Oct 2018 01:39:09 -0500 Received: from [172.24.190.117] (ileax41-snat.itg.ti.com [10.172.224.153]) by dflp32.itg.ti.com (8.14.3/8.13.8) with ESMTP id w9Q6d4fv019413; Fri, 26 Oct 2018 01:39:05 -0500 Subject: Re: [PATCH v2 06/10] dt-bindings: irqchip: Introduce TISCI Interrupt router bindings To: Rob Herring CC: Nishanth Menon , Santosh Shilimkar , , , , Linux ARM Mailing List , , Tero Kristo , Sekhar Nori , Device Tree Mailing List , Grygorii Strashko , Peter Ujfalusi References: <20181018154017.7112-1-lokeshvutla@ti.com> <20181018154017.7112-7-lokeshvutla@ti.com> <20181025184556.GA19597@bogus> From: Lokesh Vutla Message-ID: Date: Fri, 26 Oct 2018 12:08:55 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <20181025184556.GA19597@bogus> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Rob, On Friday 26 October 2018 12:15 AM, Rob Herring wrote: > On Thu, Oct 18, 2018 at 09:10:13PM +0530, Lokesh Vutla wrote: >> Add the DT binding documentation for Interrupt router driver. >> >> Signed-off-by: Lokesh Vutla >> --- >> Changes since v1: >> - Drop dependency on GIC >> - Updated supported interrupt types. >> >> .../interrupt-controller/ti,sci-intr.txt | 81 +++++++++++++++++++ >> MAINTAINERS | 1 + >> 2 files changed, 82 insertions(+) >> create mode 100644 Documentation/devicetree/bindings/interrupt-controller/ti,sci-intr.txt >> >> diff --git a/Documentation/devicetree/bindings/interrupt-controller/ti,sci-intr.txt b/Documentation/devicetree/bindings/interrupt-controller/ti,sci-intr.txt >> new file mode 100644 >> index 000000000000..276bb4f0ad12 >> --- /dev/null >> +++ b/Documentation/devicetree/bindings/interrupt-controller/ti,sci-intr.txt >> @@ -0,0 +1,81 @@ >> +Texas Instruments K3 Interrupt Router >> +===================================== >> + >> +The Interrupt Router (INTR) module provides a mechanism to mux M >> +interrupt inputs to N interrupt outputs, where all M inputs are selectable >> +to be driven per N output. There is one register per output (MUXCNTL_N) that >> +controls the selection. >> + >> + >> + Interrupt Router >> + +----------------------+ >> + | Inputs Outputs | >> + +-------+ | +------+ | >> + | GPIO |----------->| | irq0 | | Host IRQ >> + +-------+ | +------+ | controller >> + | . +-----+ | +-------+ >> + +-------+ | . | 0 | |----->| IRQ | >> + | INTA |----------->| . +-----+ | +-------+ >> + +-------+ | . . | >> + | +------+ . | >> + | | irqM | +-----+ | >> + | +------+ | N | | >> + | +-----+ | >> + +----------------------+ >> + >> +Configuration of these MUXCNTL_N registers is done by a system controller >> +(like the Device Memory and Security Controller on K3 AM654 SoC). System >> +controller will keep track of the used and unused registers within the Router. >> +Driver should request the system controller to get the range of GIC IRQs >> +assigned to the requesting hosts. It is the drivers responsibility to keep >> +track of Host IRQs. >> + >> +Communication between the host processor running an OS and the system >> +controller happens through a protocol called TI System Control Interface >> +(TISCI protocol). For more details refer: >> +Documentation/devicetree/bindings/arm/keystone/ti,sci.txt >> + >> +TISCI Interrupt Router Node: >> +---------------------------- >> +- compatible: Must be "ti,sci-intr". >> +- interrupt-controller: Identifies the node as an interrupt controller >> +- #interrupt-cells: Specifies the number of cells needed to encode an >> + interrupt source. The value should be 3. >> + First cell should contain the TISCI device ID of source >> + Second cell should contain the interrupt source offset >> + within the device >> + Third cell specifies the trigger type as defined >> + in interrupts.txt in this directory. Only level >> + sensitive trigger types are supported. >> +- interrupt-parent: phandle of irq parent for TISCI intr. > > This is implied and could be in a parent node. okay, will drop it in next version. > >> +- ti,sci: Phandle to TI-SCI compatible System controller node. >> +- ti,sci-dst-id: TISCI device ID of the destination IRQ controller. >> +- ti,sci-rm-range-girq: TISCI subtype id representing the host irqs assigned >> + to this interrupt router. > > These need a better explanation and there's still some questions on v1 > asked of me that I tried to answer. Before I jump into the details, I would like to provide a brief on TISCI resource management: - Host_id: Typically it is the representation of the host processing entities (example: A53 cores running in a VM) as identified by the TISCI.[1] - Device_id: Each Device in SoC is uniquely identified by TISCI using an ID. - Each device has Resources like interrupts, DMA channels etc. A simple example would be Interrupt Router and GIC($subject). There are n physical GIC interrupts connected to Interrupt Router. Such resources are are uniquely identified by TISCI using a type ID.[2] For the sake of simplicity lets consider an Interrupt Router(IR) to which GIC line 32-63 are connected. Considering Isolation for each VM in picture, TISCI allows for a certain range within [32-63] to be assigned to a specific Host_ID. This is mainly to provide the ability for OSs running in virtual machines to be able to independently communicate with the firmware without the need going through a hypervisor. - Now for Linux to know the GIC irq range that can be used by this Interrupt router, IR driver should send a message to system-controller using TISCI protocol with the resource type as parameter. - For configuring the IRQ,(i.e. attaching an input to IR to a GIC irq), IR driver should send a message to system-controller using TISCI protocol with gic-device-id and an irq from the provided range as parameters. For covering the above two scenarios, ti,sci-dst-id and ti,sci-rm-range-girq is introduced in DT. [1] http://downloads.ti.com/tisci/esd/latest/5_soc_doc/am6x/hosts.html [2] http://downloads.ti.com/tisci/esd/latest/5_soc_doc/am6x/resasg_types.html > >> + >> +Example: >> +-------- >> +The following example demonstrates both interrupt router node and the consumer >> +node(main gpio) on the AM654 SoC: >> + >> +main_intr: interrupt-controller@1 { >> + compatible = "ti,sci-intr"; >> + interrupt-controller; >> + interrupt-parent = <&gic>; >> + #interrupt-cells = <3>; >> + ti,sci = <&dmsc>; >> + ti,sci-dst-id = <56>; >> + ti,sci-rm-range-girq = <0x1>; >> +}; >> + >> +main_gpio0: main_gpio0@600000 { > > gpio@... Sure, will fix it in next version. Thanks and regards, Lokesh