Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp264112imj; Wed, 13 Feb 2019 08:00:36 -0800 (PST) X-Google-Smtp-Source: AHgI3IapPBgNYyqg0tTdqz7FoauuT/Ufc2y5G1iC4X8lEmB0dV+rdlk8CioPbAtk/YtSSf0z+e8x X-Received: by 2002:a62:345:: with SMTP id 66mr1116305pfd.189.1550073636260; Wed, 13 Feb 2019 08:00:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550073636; cv=none; d=google.com; s=arc-20160816; b=PaXySWHtUJljz4YpyJjjTbSwL0EuneE4kDN9EFHl2tZKtOPXFA+IH9bqz6FkdBvy34 /sa1uehDF4FybKMztpX0gOdKQpVHE8OFkbwa2PlD4y0tixydL0wCHwtxHPo1wQvDYlU+ oiWzWlTSIY6tH3MUQdaQDYv1ziqc5HQjX7Hny6N5j5Pf6PVjRSkA76zuhVnBB4nBUN5h LdJx7MrYRwr2ObhBfUcVZz+8g1a9gb3kulA02AvWFlp2LgV09+Sk3fLdZ98OqiQYdUMh 3rm9VXj1wkRK84jzyyV4P2CiaMBWvkCU83XZdxt8p8bov3iidCE0GZm0hODvIWKFhvn6 hzEA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=R9/nk9LwPdVCxWLdDQ37rFVVDHz6s2URpVAM7GDcxzk=; b=f/510gIlcyc2Yr2s87EGEuKE0QaVdMYX56HKUrGJFUserKLXA7ncwRdof7Uk53FY0H 6s61h34eqJiiqAun38ECQmgrjbI4rk+XhXtcDi62QrSQt/sdX1tlrZmfBZCFwx9timla kB4AToacV8YR/7W+sSbr9WoFBnaPR6VIZnbj6eKAJZyptM7C1C6pLj4UWbLiSykGjdXk AVN21pVWphgva4ijKTaZp4WDY2GyCs0l6dLo0Vb9kHI63pToIN/KWZ64K9bgNLzmJ7O3 T3FdxGIikEL90632Hum+cNGt5aedpyGRxKxkLbRNqZic/5hm+chlAc7Wnt7rscxt39tg QdgA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f10si15848903plo.53.2019.02.13.08.00.18; Wed, 13 Feb 2019 08:00:36 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2392265AbfBMPcV (ORCPT + 99 others); Wed, 13 Feb 2019 10:32:21 -0500 Received: from muru.com ([72.249.23.125]:38512 "EHLO muru.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730097AbfBMPcU (ORCPT ); Wed, 13 Feb 2019 10:32:20 -0500 Received: from atomide.com (localhost [127.0.0.1]) by muru.com (Postfix) with ESMTPS id A361080AE; Wed, 13 Feb 2019 15:32:28 +0000 (UTC) Date: Wed, 13 Feb 2019 07:32:15 -0800 From: Tony Lindgren To: Lokesh Vutla Cc: marc.zyngier@arm.com, Nishanth Menon , Santosh Shilimkar , Rob Herring , tglx@linutronix.de, jason@lakedaemon.net, Linux ARM Mailing List , linux-kernel@vger.kernel.org, Device Tree Mailing List , Sekhar Nori , Tero Kristo , Peter Ujfalusi Subject: Re: [PATCH v5 05/10] dt-bindings: irqchip: Introduce TISCI Interrupt router bindings Message-ID: <20190213153215.GT5720@atomide.com> References: <20190212074237.2875-1-lokeshvutla@ti.com> <20190212074237.2875-6-lokeshvutla@ti.com> <20190212163018.GL5720@atomide.com> <5b5d86b9-2aa7-718c-c1da-70bbf9bf589e@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <5b5d86b9-2aa7-718c-c1da-70bbf9bf589e@ti.com> User-Agent: Mutt/1.11.2 (2019-01-07) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Lokesh Vutla [190213 04:23]: > Hi Tony, > > On 12/02/19 10:00 PM, Tony Lindgren wrote: > > Hi, > > > > * Lokesh Vutla [190212 07:43]: > >> +The Interrupt Router (INTR) module provides a mechanism to route 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 | | > >> + | +-----+ | > >> + +----------------------+ > > > > Is this always one-to-one mapping or can the same interrupt be routed to > > multiple targets like to the SoC and some coprocessor? > > Yes, it is always one-to-one. Output of INTR can only be attached to one of the > processor. OK > >> +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 > > > > Care to describe a bit why the interrupts need to be routed by a system > > controller? > > K3 architecture defines a heterogeneous system where multiple heterogeneous > cores are serving its own usecases. Given that there are multiple ways in which > a device IRQ can be routed using INTR, like either it can be routed to HLOS > core(A53 int this case) or it can be routed to any other coprocessor available > in the system(like R5). If every sw running in each co-processor is allowed to > program this INTR then there is a high probability that one sw executing on one > core can damage other heterogeneous core. Mainly to avoid this damage the > configuration of all the INTRs and INTAs are done in a centralized place(sysfw). > Any user for programming its IRQ route should send a message to sysfw with the > parameters. These parameters are policed by sysfw and does the configuration. OK so maybe update the description along those lines saying it's a shared piece of hardware between various independent SoC clusters which may or may not be running Linux. Regards, Tony