Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp588779imm; Wed, 25 Jul 2018 02:38:21 -0700 (PDT) X-Google-Smtp-Source: AAOMgpd1snBii1WeFYZYQ2g9IUSAc0sdJgDs032KTtC6eEKezvw9ziggwFJDgNP2e1m6dxnJFD95 X-Received: by 2002:a63:be05:: with SMTP id l5-v6mr19582001pgf.330.1532511501698; Wed, 25 Jul 2018 02:38:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1532511501; cv=none; d=google.com; s=arc-20160816; b=Xzsw2yYVb/+mjcR4EbxqMOgNG3qHf/5A+lWfok3MZrXVaoOdcKc7RU0QxPkgafmRj1 wM+Off5vZULaVNF1KvshFvErHQmQuKPtujBab4Tl0HOolP+4hSRKhAakqCve/38yepcr 7pnlLzSZa133+WYOYZTFV5hjxOZIl1EVRUqKO0Fg8g+MvINHJ1i+2kBDpeok4ZLQcOtN k+1/elyeNAdQ48ryT1NnBFs5VcHTuIGPsANMMpwIXReCg7MqfQjebcuRKU+03gc0YUcq 1WN3wJOUEPVMeM2ji/mf+BFds7LisZa94JaLCx0GgO1mX4dTmYO4fZy3jpr6AazHmdRX Fv0Q== 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:dkim-signature:arc-authentication-results; bh=tIXrVvq9OSoPk2KsHRsT/SmHJfZnosDj8UGX6gqpiOs=; b=vkVQVjT/QU1fxsV9U0TFJitwRSQEaav1TD5Juuj94XRkBpuOdKhuzcklm9cJcfHK0X 3nTqoEdTMG3Mt2xFsqp/Zo1a/CXn4Rk1y2J7WPfV36k2QN3LxqbSugmzyWO+o9klSCi5 RzoV2bt7vF2qRw4PYFbS8rmS6mQlot4FhP65rKkChSwGpTowKmPC/QHMtwXtr3jSS1q+ SbYWRX0y7Ltzp3Pl5PK0f53XyKU7RdTY/kj5pBaZjyLBwz/Atw5ZjqTHdtUYnagjCEvI mE3OdB5BLdZbB+wzfdiW4w3sM4/W8czqYQtKtdNXHQ1Bs6Gr0c1veSE/HeUNuBxh6+fi YJWw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b="bPSK/ieK"; 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 89-v6si13162816plf.224.2018.07.25.02.38.07; Wed, 25 Jul 2018 02:38: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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b="bPSK/ieK"; 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 S1728864AbeGYKsB (ORCPT + 99 others); Wed, 25 Jul 2018 06:48:01 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:42882 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728844AbeGYKsA (ORCPT ); Wed, 25 Jul 2018 06:48:00 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=References:In-Reply-To:Message-Id: Date:Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=tIXrVvq9OSoPk2KsHRsT/SmHJfZnosDj8UGX6gqpiOs=; b=bPSK/ieKzG6PryrnoXjwRwdrY 720EloLSbs5fQToJO9I19CGJ9uRT3A47ugV01LmWqLGM6cYdGfTDbawsQ2sRPRXWiM5l4KVDuTcTc M0FnsTAVk0oS6wpa0vxg6AVh7No6LHWirfz2izDE6coZhPFmp5XN1Vdc830Xjb/NOWGeBRZ/QWFJU B9xFAdsYb+W2e51ZlfOovchC5LxDB/AYKWVNvzuLqpsWFMdi4Zgr3U0EzCRp5rQ2rL1+WX8pHGfXR Ce0PMIP/m6eS7CDEMtJl4OOYlV2M3t/9234f6Arvdop5wSmeQdTs6NGNi+KkfgUYMFsoLgYRR4+bs /tWRkIhIw==; Received: from [91.112.108.175] (helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1fiGED-0005IV-R8; Wed, 25 Jul 2018 09:37:06 +0000 From: Christoph Hellwig To: tglx@linutronix.de, palmer@sifive.com, jason@lakedaemon.net, marc.zyngier@arm.com, robh+dt@kernel.org, mark.rutland@arm.com Cc: devicetree@vger.kernel.org, aou@eecs.berkeley.edu, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, shorne@gmail.com, Palmer Dabbelt Subject: [PATCH 4/6] dt-bindings: interrupt-controller: RISC-V local interrupt controller docs Date: Wed, 25 Jul 2018 11:36:47 +0200 Message-Id: <20180725093649.32332-5-hch@lst.de> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180725093649.32332-1-hch@lst.de> References: <20180725093649.32332-1-hch@lst.de> X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Palmer Dabbelt This patch adds documentation on the RISC-V local interrupt controller, which is a per-hart interrupt controller that manages all interrupts entering a RISC-V hart. This interrupt controller is present on all RISC-V systems. Signed-off-by: Palmer Dabbelt --- .../interrupt-controller/riscv,cpu-intc.txt | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 Documentation/devicetree/bindings/interrupt-controller/riscv,cpu-intc.txt diff --git a/Documentation/devicetree/bindings/interrupt-controller/riscv,cpu-intc.txt b/Documentation/devicetree/bindings/interrupt-controller/riscv,cpu-intc.txt new file mode 100644 index 000000000000..61900e2e3868 --- /dev/null +++ b/Documentation/devicetree/bindings/interrupt-controller/riscv,cpu-intc.txt @@ -0,0 +1,41 @@ +RISC-V Hart-Level Interrupt Controller (HLIC) +--------------------------------------------- + +RISC-V cores include Control Status Registers (CSRs) which are local to each +hart and can be read or written by software. Some of these CSRs are used to +control local interrupts connected to the core. Every interrupt is ultimately +routed through a hart's HLIC before it interrupts that hart. + +The RISC-V supervisor ISA manual specifies three interrupt sources that are +attached to every HLIC: software interrupts, the timer interrupt, and external +interrupts. Software interrupts are used to send IPIs between cores. The +timer interrupt comes from an architecturally mandated real-time timer that is +controller via SBI calls and CSR reads. External interrupts connect all other +device interrupts to the HLIC, which are routed via the platform-level +interrupt controller (PLIC). + +All RISC-V systems that conform to the supervisor ISA specification are +required to have a HLIC with these three interrupt sources present. Since the +interrupt map is defined by the ISA it's not listed in the HLIC's device tree +entry, though external interrupt controllers (like the PLIC, for example) will +need to define how their interrupts map to the relevant HLICs. + +Required properties: +- compatible : "riscv,cpu-intc" +- #interrupt-cells : should be <1> +- interrupt-controller : Identifies the node as an interrupt controller + +Furthermore, this interrupt-controller MUST be embedded inside the cpu +definition of the hart whose CSRs control these local interrupts. + +An example device tree entry for a HLIC is show below. + + cpu1: cpu@1 { + compatible = "riscv"; + ... + cpu1-intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; -- 2.18.0