Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp2787800ybi; Sun, 2 Jun 2019 01:07:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqyTsu6pw5ToKf0T8bR0aDqfIqMASwtjBoETTKxTLaz2DaKgoQOT/+i/R/71twNorBA1HAg2 X-Received: by 2002:a63:43c2:: with SMTP id q185mr21136421pga.280.1559462870808; Sun, 02 Jun 2019 01:07:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559462870; cv=none; d=google.com; s=arc-20160816; b=oJmXylZZRGJDY87o38lmBlODFQHEXXLXreC0lGRxZtJmX3C3NlbnpUhDnOqTsZwNGA NmKdIX8o4+mrST/IFP57TkSxD0xVDNZitm6dAG6cfnlJNSanvvl6BzmHtTZm4n99itsS DySKJacu52tMMvMjcCx930Qc+U0vQ08SWEv1SJvh1cCoDd6korvBWUCPMJeMkyBW7vED yNktDDACAibAwKkSRKRGtBdCZuwlIVTOn6UilZHzLQvZsgB3VYfpuyBXRB33bX28Orql te0jLVAKeFLLN6sFBuI2qWhf/ln0GdWB9Gw0UGfr97EuMKGOy3FsRYcMHwUB28GEtXkB 1mxA== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=H1tMVKDcnY0AsHYQC7kH5mkhPScubjTBOZaBll4fZ84=; b=rMpDPOkWapzrj8GEpVF6vyr6Zi6mnHq2NItuSVrRbOOVXI+d9qTf7slpOlIOQM5WpB DSKDtS4An3HZ8/T5wJnZqexaVxrAIYq9ckDRRS5UFCSF7lwXf0/H4VBJ86pADa1D5GsL bW+Tin4Zf4ooS2h4dwZyXsid+B2FqxLtGPuFPsihst0CSTx08O5LFADyLjN3uzxsNqn9 5at8LD6QAvMgjGoax3ypp5VmQebnkS35Tjles7rF97OYomTDP3CgFpHlkUWWQHYWzzre EVmSj1hLLPxctC1B3sSlfrHgEMOMMYqlyp00PaplVylQyksKOL9Omn7BIgHB6NkRdVsY ydEA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=Jh2MUFSC; 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 d24si13530868pgk.106.2019.06.02.01.07.35; Sun, 02 Jun 2019 01:07:50 -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=pass header.i=@sifive.com header.s=google header.b=Jh2MUFSC; 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 S1726881AbfFBIFS (ORCPT + 99 others); Sun, 2 Jun 2019 04:05:18 -0400 Received: from mail-wm1-f68.google.com ([209.85.128.68]:50805 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726749AbfFBIFM (ORCPT ); Sun, 2 Jun 2019 04:05:12 -0400 Received: by mail-wm1-f68.google.com with SMTP id f204so4521091wme.0 for ; Sun, 02 Jun 2019 01:05:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=H1tMVKDcnY0AsHYQC7kH5mkhPScubjTBOZaBll4fZ84=; b=Jh2MUFSC6yvbMpDucQG/ilOoM5CYKmfuZDXgiOIRrRnMzB6xhDHg3LBcqIZFuW7AB0 yH38rFadgxa0UKWSqAHjmu+mJTAWeAGkSSgtPLaZKyV4+rRgb199wq7Rv1mzApOmn3XT 1Yi3pz2g50vuQORxfEP6R6v0mM7ehegwwsLIYyRbceyR85TG1ctM5GCOlEwTFHGFe+kA KTAzGPU4nmHh/3k+f6N3PcjcxM/LZEEPiN194Xn9LpsZfynk922KygaBci0s5ufyrmFT BoNMCWJPCrP8xST2d5qYhQlu9bs/tE3Z5nR+VrHIVS1gOTYBaCnyjHI3FwwKhIoZFuyg y5yg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=H1tMVKDcnY0AsHYQC7kH5mkhPScubjTBOZaBll4fZ84=; b=kzcCre4jnju1ztkvHaAZB84T4BFp6t49Wguj2H87tsro6L9Vx1Psj7o+P5dkzoU+fG XCsj4l0rvSUpOVuTroF5mq9Tcl6jfecKwjfgP38mOEqkbR/PvSENH9aAXoL+xWkCy4GG 7rriiF2gw/0O1MOtOcPmWTUSlxc3MkRufdfva5pOEwHjrbIIbsapE5clnZwKPxjPUahk ytOg5hnk5/prFLMevxjVjGIuSh3rOivvMC4yEBojJr5wVmqNn7bo9BRxi0Dhxl3kpr50 pkQAU5Ma/NqLImcqQz34YodTczu7jk76gNjGuU/0+dTE3sNPbaW8CyCyS3S+8ZMx73po TOoQ== X-Gm-Message-State: APjAAAUEShjnB1iMtq7oqqcpXqgMVo2zcf8YvaFSW8Q5zRIfIddxpH/L UfghNWTPmIVA/tuGOJ9iBEs9ybTf7WE= X-Received: by 2002:a1c:6c08:: with SMTP id h8mr3319734wmc.62.1559462709684; Sun, 02 Jun 2019 01:05:09 -0700 (PDT) Received: from viisi.fritz.box (217-76-161-89.static.highway.a1.net. [217.76.161.89]) by smtp.gmail.com with ESMTPSA id l190sm10186301wml.16.2019.06.02.01.05.08 (version=TLS1_3 cipher=AEAD-AES256-GCM-SHA384 bits=256/256); Sun, 02 Jun 2019 01:05:09 -0700 (PDT) From: Paul Walmsley To: linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org Cc: Paul Walmsley , Rob Herring , Mark Rutland , Palmer Dabbelt , Albert Ou , ShihPo Hung , devicetree@vger.kernel.org Subject: [PATCH v3 4/5] riscv: dts: add initial support for the SiFive FU540-C000 SoC Date: Sun, 2 Jun 2019 01:04:59 -0700 Message-Id: <20190602080500.31700-5-paul.walmsley@sifive.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190602080500.31700-1-paul.walmsley@sifive.com> References: <20190602080500.31700-1-paul.walmsley@sifive.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add initial support for the SiFive FU540-C000 SoC. This is a 28nm SoC based around the SiFive U54-MC core complex and a TileLink interconnect. This file is expected to grow as more device drivers are added to the kernel. This patch includes a fix to the QSPI memory map due to a documentation bug, found by ShihPo Hung , adds entries for the I2C controller, and merges all DT changes that formerly were made dynamically by the riscv-pk BBL proxy kernel. Signed-off-by: Paul Walmsley Signed-off-by: Paul Walmsley Cc: Rob Herring Cc: Mark Rutland Cc: Palmer Dabbelt Cc: Albert Ou Cc: ShihPo Hung Cc: devicetree@vger.kernel.org Cc: linux-riscv@lists.infradead.org Cc: linux-kernel@vger.kernel.org --- arch/riscv/boot/dts/sifive/fu540-c000.dtsi | 215 +++++++++++++++++++++ 1 file changed, 215 insertions(+) create mode 100644 arch/riscv/boot/dts/sifive/fu540-c000.dtsi diff --git a/arch/riscv/boot/dts/sifive/fu540-c000.dtsi b/arch/riscv/boot/dts/sifive/fu540-c000.dtsi new file mode 100644 index 000000000000..3c06ee4b2b29 --- /dev/null +++ b/arch/riscv/boot/dts/sifive/fu540-c000.dtsi @@ -0,0 +1,215 @@ +// SPDX-License-Identifier: (GPL-2.0 OR MIT) +/* Copyright (c) 2018-2019 SiFive, Inc */ + +/dts-v1/; + +#include + +/ { + #address-cells = <2>; + #size-cells = <2>; + compatible = "sifive,fu540-c000", "sifive,fu540"; + + aliases { + serial0 = &uart0; + serial1 = &uart1; + }; + + chosen { + }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + timebase-frequency = <1000000>; + cpu0: cpu@0 { + compatible = "sifive,e51", "sifive,rocket0", "riscv"; + device_type = "cpu"; + i-cache-block-size = <64>; + i-cache-sets = <128>; + i-cache-size = <16384>; + reg = <0>; + riscv,isa = "rv64imac"; + status = "disabled"; + cpu0_intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; + cpu1: cpu@1 { + compatible = "sifive,u54-mc", "sifive,rocket0", "riscv"; + d-cache-block-size = <64>; + d-cache-sets = <64>; + d-cache-size = <32768>; + d-tlb-sets = <1>; + d-tlb-size = <32>; + device_type = "cpu"; + i-cache-block-size = <64>; + i-cache-sets = <64>; + i-cache-size = <32768>; + i-tlb-sets = <1>; + i-tlb-size = <32>; + mmu-type = "riscv,sv39"; + reg = <1>; + riscv,isa = "rv64imafdc"; + tlb-split; + cpu1_intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; + cpu2: cpu@2 { + clock-frequency = <0>; + compatible = "sifive,u54-mc", "sifive,rocket0", "riscv"; + d-cache-block-size = <64>; + d-cache-sets = <64>; + d-cache-size = <32768>; + d-tlb-sets = <1>; + d-tlb-size = <32>; + device_type = "cpu"; + i-cache-block-size = <64>; + i-cache-sets = <64>; + i-cache-size = <32768>; + i-tlb-sets = <1>; + i-tlb-size = <32>; + mmu-type = "riscv,sv39"; + reg = <2>; + riscv,isa = "rv64imafdc"; + tlb-split; + cpu2_intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; + cpu3: cpu@3 { + clock-frequency = <0>; + compatible = "sifive,u54-mc", "sifive,rocket0", "riscv"; + d-cache-block-size = <64>; + d-cache-sets = <64>; + d-cache-size = <32768>; + d-tlb-sets = <1>; + d-tlb-size = <32>; + device_type = "cpu"; + i-cache-block-size = <64>; + i-cache-sets = <64>; + i-cache-size = <32768>; + i-tlb-sets = <1>; + i-tlb-size = <32>; + mmu-type = "riscv,sv39"; + reg = <3>; + riscv,isa = "rv64imafdc"; + tlb-split; + cpu3_intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; + cpu4: cpu@4 { + clock-frequency = <0>; + compatible = "sifive,u54-mc", "sifive,rocket0", "riscv"; + d-cache-block-size = <64>; + d-cache-sets = <64>; + d-cache-size = <32768>; + d-tlb-sets = <1>; + d-tlb-size = <32>; + device_type = "cpu"; + i-cache-block-size = <64>; + i-cache-sets = <64>; + i-cache-size = <32768>; + i-tlb-sets = <1>; + i-tlb-size = <32>; + mmu-type = "riscv,sv39"; + reg = <4>; + riscv,isa = "rv64imafdc"; + tlb-split; + cpu4_intc: interrupt-controller { + #interrupt-cells = <1>; + compatible = "riscv,cpu-intc"; + interrupt-controller; + }; + }; + }; + soc { + #address-cells = <2>; + #size-cells = <2>; + compatible = "sifive,fu540-c000", "sifive,fu540", "simple-bus"; + ranges; + plic0: interrupt-controller@c000000 { + #interrupt-cells = <1>; + compatible = "sifive,plic-1.0.0"; + reg = <0x0 0xc000000 0x0 0x4000000>; + riscv,ndev = <53>; + interrupt-controller; + interrupts-extended = < + &cpu0_intc 0xffffffff + &cpu1_intc 0xffffffff &cpu1_intc 9 + &cpu2_intc 0xffffffff &cpu2_intc 9 + &cpu3_intc 0xffffffff &cpu3_intc 9 + &cpu4_intc 0xffffffff &cpu4_intc 9>; + }; + prci: clock-controller@10000000 { + compatible = "sifive,fu540-c000-prci"; + reg = <0x0 0x10000000 0x0 0x1000>; + clocks = <&hfclk>, <&rtcclk>; + #clock-cells = <1>; + }; + uart0: serial@10010000 { + compatible = "sifive,fu540-c000-uart", "sifive,uart0"; + reg = <0x0 0x10010000 0x0 0x1000>; + interrupt-parent = <&plic0>; + interrupts = <4>; + clocks = <&prci PRCI_CLK_TLCLK>; + }; + uart1: serial@10011000 { + compatible = "sifive,fu540-c000-uart", "sifive,uart0"; + reg = <0x0 0x10011000 0x0 0x1000>; + interrupt-parent = <&plic0>; + interrupts = <5>; + clocks = <&prci PRCI_CLK_TLCLK>; + }; + i2c0: i2c@10030000 { + compatible = "sifive,fu540-c000-i2c", "sifive,i2c0"; + reg = <0x0 0x10030000 0x0 0x1000>; + interrupt-parent = <&plic0>; + interrupts = <50>; + clocks = <&prci PRCI_CLK_TLCLK>; + reg-shift = <2>; + reg-io-width = <1>; + #address-cells = <1>; + #size-cells = <0>; + }; + qspi0: spi@10040000 { + compatible = "sifive,fu540-c000-spi", "sifive,spi0"; + reg = <0x0 0x10040000 0x0 0x1000 + 0x0 0x20000000 0x0 0x10000000>; + interrupt-parent = <&plic0>; + interrupts = <51>; + clocks = <&prci PRCI_CLK_TLCLK>; + #address-cells = <1>; + #size-cells = <0>; + }; + qspi1: spi@10041000 { + compatible = "sifive,fu540-c000-spi", "sifive,spi0"; + reg = <0x0 0x10041000 0x0 0x1000 + 0x0 0x30000000 0x0 0x10000000>; + interrupt-parent = <&plic0>; + interrupts = <52>; + clocks = <&prci PRCI_CLK_TLCLK>; + #address-cells = <1>; + #size-cells = <0>; + }; + qspi2: spi@10050000 { + compatible = "sifive,fu540-c000-spi", "sifive,spi0"; + reg = <0x0 0x10050000 0x0 0x1000>; + interrupt-parent = <&plic0>; + interrupts = <6>; + clocks = <&prci PRCI_CLK_TLCLK>; + #address-cells = <1>; + #size-cells = <0>; + }; + }; +}; -- 2.20.1