[PATCH v5 5/7] riscv: dts: Add device tree for Microchip Icicle Kit
Padmarao Begari
padmarao.b at gmail.com
Fri Dec 11 12:25:44 CET 2020
Hi Bin,
On Fri, Dec 11, 2020 at 2:55 PM Bin Meng <bmeng.cn at gmail.com> wrote:
> Hi Padmarao,
>
> On Fri, Dec 11, 2020 at 4:32 PM Padmarao Begari <padmarao.b at gmail.com>
> wrote:
> >
> > Hi Bin,
> >
> > On Fri, Dec 11, 2020 at 1:31 PM Bin Meng <bmeng.cn at gmail.com> wrote:
> >>
> >> Hi Padmarao,
> >>
> >> On Thu, Dec 3, 2020 at 4:44 AM Padmarao Begari
> >> <padmarao.begari at microchip.com> wrote:
> >> >
> >> > Add device tree for Microchip PolarFire SoC Icicle Kit.
> >> >
> >> > Signed-off-by: Padmarao Begari <padmarao.begari at microchip.com>
> >> > Reviewed-by: Anup Patel <anup.patel at wdc.com>
> >>
> >> Sorry 2 more warnings, please check below:
> >>
> >> > ---
> >> > arch/riscv/dts/Makefile | 1 +
> >> > .../dts/microchip-mpfs-icicle-kit-u-boot.dtsi | 14 +
> >> > arch/riscv/dts/microchip-mpfs-icicle-kit.dts | 421
> ++++++++++++++++++
> >> > 3 files changed, 436 insertions(+)
> >> > create mode 100644
> arch/riscv/dts/microchip-mpfs-icicle-kit-u-boot.dtsi
> >> > create mode 100644 arch/riscv/dts/microchip-mpfs-icicle-kit.dts
> >> >
> >> > diff --git a/arch/riscv/dts/Makefile b/arch/riscv/dts/Makefile
> >> > index 3a6f96c67d..01331b0aa1 100644
> >> > --- a/arch/riscv/dts/Makefile
> >> > +++ b/arch/riscv/dts/Makefile
> >> > @@ -3,6 +3,7 @@
> >> > dtb-$(CONFIG_TARGET_AX25_AE350) += ae350_32.dtb ae350_64.dtb
> >> > dtb-$(CONFIG_TARGET_SIFIVE_FU540) += hifive-unleashed-a00.dtb
> >> > dtb-$(CONFIG_TARGET_SIPEED_MAIX) += k210-maix-bit.dtb
> >> > +dtb-$(CONFIG_TARGET_MICROCHIP_ICICLE) +=
> microchip-mpfs-icicle-kit.dtb
> >> >
> >> > targets += $(dtb-y)
> >> >
> >> > diff --git a/arch/riscv/dts/microchip-mpfs-icicle-kit-u-boot.dtsi
> b/arch/riscv/dts/microchip-mpfs-icicle-kit-u-boot.dtsi
> >> > new file mode 100644
> >> > index 0000000000..f60283fb6b
> >> > --- /dev/null
> >> > +++ b/arch/riscv/dts/microchip-mpfs-icicle-kit-u-boot.dtsi
> >> > @@ -0,0 +1,14 @@
> >> > +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> >> > +/*
> >> > + * Copyright (C) 2020 Microchip Technology Inc.
> >> > + * Padmarao Begari <padmarao.begari at microchip.com>
> >> > + */
> >> > +
> >> > +/ {
> >> > + aliases {
> >> > + cpu1 = &cpu1;
> >> > + cpu2 = &cpu2;
> >> > + cpu3 = &cpu3;
> >> > + cpu4 = &cpu4;
> >> > + };
> >> > +};
> >> > diff --git a/arch/riscv/dts/microchip-mpfs-icicle-kit.dts
> b/arch/riscv/dts/microchip-mpfs-icicle-kit.dts
> >> > new file mode 100644
> >> > index 0000000000..f5478bf201
> >> > --- /dev/null
> >> > +++ b/arch/riscv/dts/microchip-mpfs-icicle-kit.dts
> >> > @@ -0,0 +1,421 @@
> >> > +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> >> > +/* Copyright (c) 2020 Microchip Technology Inc */
> >> > +
> >> > +/dts-v1/;
> >> > +#include "dt-bindings/clock/microchip,mpfs-clock.h"
> >> > +
> >> > +/* Clock frequency (in Hz) of the rtcclk */
> >> > +#define RTCCLK_FREQ 1000000
> >> > +
> >> > +/ {
> >> > + #address-cells = <2>;
> >> > + #size-cells = <2>;
> >> > + model = "Microchip MPFS Icicle Kit";
> >> > + compatible = "microchip,mpfs-icicle-kit";
> >> > +
> >> > + aliases {
> >> > + serial0 = &uart0;
> >> > + ethernet0 = &emac1;
> >> > + };
> >> > +
> >> > + chosen {
> >> > + stdout-path = "serial0";
> >> > + };
> >> > +
> >> > + cpucomplex: cpus {
> >> > + #address-cells = <1>;
> >> > + #size-cells = <0>;
> >> > + timebase-frequency = <RTCCLK_FREQ>;
> >> > + cpu0: cpu at 0 {
> >> > + clocks = <&clkcfg CLK_CPU>;
> >> > + 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";
> >> > + operating-points = <
> >> > + /* kHz uV */
> >> > + 600000 1100000
> >> > + 300000 950000
> >> > + 150000 750000
> >> > + >;
> >> > + cpu0intc: interrupt-controller {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "riscv,cpu-intc";
> >> > + interrupt-controller;
> >> > + };
> >> > + };
> >> > + cpu1: cpu at 1 {
> >> > + clocks = <&clkcfg CLK_CPU>;
> >> > + 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;
> >> > + status = "okay";
> >> > + operating-points = <
> >> > + /* kHz uV */
> >> > + 600000 1100000
> >> > + 300000 950000
> >> > + 150000 750000
> >> > + >;
> >> > + cpu1intc: interrupt-controller {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "riscv,cpu-intc";
> >> > + interrupt-controller;
> >> > + };
> >> > + };
> >> > + cpu2: cpu at 2 {
> >> > + clocks = <&clkcfg CLK_CPU>;
> >> > + 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;
> >> > + status = "okay";
> >> > + operating-points = <
> >> > + /* kHz uV */
> >> > + 600000 1100000
> >> > + 300000 950000
> >> > + 150000 750000
> >> > + >;
> >> > + cpu2intc: interrupt-controller {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "riscv,cpu-intc";
> >> > + interrupt-controller;
> >> > + };
> >> > + };
> >> > + cpu3: cpu at 3 {
> >> > + clocks = <&clkcfg CLK_CPU>;
> >> > + 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;
> >> > + status = "okay";
> >> > + operating-points = <
> >> > + /* kHz uV */
> >> > + 600000 1100000
> >> > + 300000 950000
> >> > + 150000 750000
> >> > + >;
> >> > + cpu3intc: interrupt-controller {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "riscv,cpu-intc";
> >> > + interrupt-controller;
> >> > + };
> >> > + };
> >> > + cpu4: cpu at 4 {
> >> > + clocks = <&clkcfg CLK_CPU>;
> >> > + 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;
> >> > + status = "okay";
> >> > + operating-points = <
> >> > + /* kHz uV */
> >> > + 600000 1100000
> >> > + 300000 950000
> >> > + 150000 750000
> >> > + >;
> >> > + cpu4intc: interrupt-controller {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "riscv,cpu-intc";
> >> > + interrupt-controller;
> >> > + };
> >> > + };
> >> > + };
> >> > + ddr: memory at 80000000 {
> >> > + device_type = "memory";
> >> > + reg = <0x0 0x80000000 0x0 0x40000000>;
> >> > + clocks = <&clkcfg CLK_DDRC>;
> >> > + };
> >> > + soc: soc {
> >> > + #address-cells = <2>;
> >> > + #size-cells = <2>;
> >> > + compatible = "microchip,mpfs-icicle-kit",
> "simple-bus";
> >> > + ranges;
> >> > + clint0: clint at 2000000 {
> >> > + compatible = "riscv,clint0";
> >> > + interrupts-extended = <&cpu0intc 3 &cpu0intc 7
> >> > + &cpu1intc 3 &cpu1intc
> 7
> >> > + &cpu2intc 3 &cpu2intc
> 7
> >> > + &cpu3intc 3 &cpu3intc
> 7
> >> > + &cpu4intc 3 &cpu4intc
> 7>;
> >> > + reg = <0x0 0x2000000 0x0 0x10000>;
> >> > + reg-names = "control";
> >> > + clock-frequency = <RTCCLK_FREQ>;
> >> > + };
> >> > + cachecontroller: cache-controller at 2010000 {
> >> > + compatible = "sifive,fu540-c000-ccache",
> "cache";
> >> > + cache-block-size = <64>;
> >> > + cache-level = <2>;
> >> > + cache-sets = <1024>;
> >> > + cache-size = <2097152>;
> >> > + cache-unified;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <1 2 3>;
> >> > + reg = <0x0 0x2010000 0x0 0x1000>;
> >> > + };
> >> > + plic: interrupt-controller at c000000 {
> >> > + #interrupt-cells = <1>;
> >> > + compatible = "sifive,plic-1.0.0";
> >> > + reg = <0x0 0xc000000 0x0 0x4000000>;
> >> > + riscv,max-priority = <7>;
> >> > + riscv,ndev = <186>;
> >> > + interrupt-controller;
> >> > + interrupts-extended = <
> >> > + &cpu0intc 11
> >> > + &cpu1intc 11 &cpu1intc 9
> >> > + &cpu2intc 11 &cpu2intc 9
> >> > + &cpu3intc 11 &cpu3intc 9
> >> > + &cpu4intc 11 &cpu4intc 9>;
> >> > + };
> >> > + uart0: serial at 20000000 {
> >> > + compatible = "ns16550a";
> >> > + reg = <0x0 0x20000000 0x0 0x400>;
> >> > + reg-io-width = <4>;
> >> > + reg-shift = <2>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <90>;
> >> > + clock-frequency = <150000000>;
> >> > + clocks = <&clkcfg CLK_MMUART0>;
> >> > + status = "okay";
> >> > + };
> >> > + refclk: refclk {
> >> > + compatible = "fixed-clock";
> >> > + #clock-cells = <0>;
> >> > + clock-frequency = <600000000>;
> >> > + clock-output-names = "msspllclk";
> >> > + };
> >>
> >> Right now this is put under /soc, but with newer dtc, we got warning
> like:
> >> Warning (simple_bus_reg): /soc/refclk: missing or empty reg/ranges
> property
> >>
> >> Should we move this node to / instead?
> >>
> >
> > ok
> >
> >>
> >> > + clkcfg: clkcfg at 20002000 {
> >> > + compatible = "microchip,mpfs-clkcfg";
> >> > + reg = <0x0 0x20002000 0x0 0x1000>;
> >> > + reg-names = "mss_sysreg";
> >> > + clocks = <&refclk>;
> >> > + #clock-cells = <1>;
> >> > + clock-output-names = "cpu", "axi", "ahb",
> "envm",
> >> > + "mac0", "mac1", "mmc",
> "timer",
> >> > + "mmuart0", "mmuart1",
> "mmuart2",
> >> > + "mmuart3", "mmuart4", "spi0",
> "spi1",
> >> > + "i2c0", "i2c1", "can0",
> "can1", "usb",
> >> > + "reserved", "rtc", "qspi",
> "gpio0",
> >> > + "gpio1", "gpio2", "ddrc",
> "fic0",
> >> > + "fic1", "fic2", "fic3",
> "athena",
> >> > + "cfm";
> >> > + };
> >> > + emmc: mmc at 20008000 {
> >> > + compatible = "cdns,sd4hc";
> >> > + reg = <0x0 0x20008000 0x0 0x1000>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <88 89>;
> >> > + pinctrl-names = "default";
> >> > + clocks = <&clkcfg CLK_MMC>;
> >> > + bus-width = <4>;
> >> > + cap-mmc-highspeed;
> >> > + mmc-ddr-3_3v;
> >> > + max-frequency = <200000000>;
> >> > + non-removable;
> >> > + no-sd;
> >> > + no-sdio;
> >> > + voltage-ranges = <3300 3300>;
> >> > + status = "okay";
> >> > + };
> >> > + sdcard: sd at 20008000 {
> >> > + compatible = "cdns,sd4hc";
> >> > + reg = <0x0 0x20008000 0x0 0x1000>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <88>;
> >> > + pinctrl-names = "default";
> >> > + clocks = <&clkcfg CLK_MMC>;
> >> > + bus-width = <4>;
> >> > + disable-wp;
> >> > + cap-sd-highspeed;
> >> > + card-detect-delay = <200>;
> >> > + sd-uhs-sdr12;
> >> > + sd-uhs-sdr25;
> >> > + sd-uhs-sdr50;
> >> > + sd-uhs-sdr104;
> >> > + max-frequency = <200000000>;
> >> > + status = "disabled";
> >> > + };
> >> > + uart1: serial at 20100000 {
> >> > + compatible = "ns16550a";
> >> > + reg = <0x0 0x20100000 0x0 0x400>;
> >> > + reg-io-width = <4>;
> >> > + reg-shift = <2>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <91>;
> >> > + clock-frequency = <150000000>;
> >> > + clocks = <&clkcfg CLK_MMUART1>;
> >> > + status = "okay";
> >> > + };
> >> > + uart2: serial at 20102000 {
> >> > + compatible = "ns16550a";
> >> > + reg = <0x0 0x20102000 0x0 0x400>;
> >> > + reg-io-width = <4>;
> >> > + reg-shift = <2>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <92>;
> >> > + clock-frequency = <150000000>;
> >> > + clocks = <&clkcfg CLK_MMUART2>;
> >> > + status = "okay";
> >> > + };
> >> > + uart3: serial at 20104000 {
> >> > + compatible = "ns16550a";
> >> > + reg = <0x0 0x20104000 0x0 0x400>;
> >> > + reg-io-width = <4>;
> >> > + reg-shift = <2>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <93>;
> >> > + clock-frequency = <150000000>;
> >> > + clocks = <&clkcfg CLK_MMUART3>;
> >> > + status = "okay";
> >> > + };
> >> > + i2c0: i2c at 02010a000 {
> >> > + #address-cells = <1>;
> >> > + #size-cells = <0>;
> >> > + compatible = "microchip,mpfs-mss-i2c";
> >> > + reg = <0x0 0x2010a000 0x0 0x1000>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <58>;
> >> > + clocks = <&clkcfg CLK_I2C0>;
> >> > + status = "disabled";
> >> > + };
> >> > + i2c1: i2c at 02010b000 {
> >> > + #address-cells = <1>;
> >> > + #size-cells = <0>;
> >> > + compatible = "microchip,mpfs-mss-i2c";
> >> > + reg = <0x0 0x2010b000 0x0 0x1000>;
> >> > + interrupt-parent = <&plic>;
> >> > + interrupts = <61>;
> >> > + clocks = <&clkcfg CLK_I2C1>;
> >> > + status = "disabled";
> >> > + pac193x at 0x10 {
> >> > + compatible = "microchip,pac1934";
> >> > + reg = <0x10>;
> >> > + samp-rate = <64>;
> >> > + status = "disabled";
> >> > + ch1: channel at 0 {
> >>
> >> Please remove @0, otherwise with newer dtc, we got:
> >>
> >
> > ok, will remove @0
> >
> > Is the channel at 1, channel at 2, channel at 3 ok? or do we need to remove
> @1, at 2, @3 also?
> >
>
> Same warning. We should remove them too.
>
>
Ok, will remove @1, at 2, @3
Can I replace channel at 0 with channel0, channel at 1 with channel1, channel at 2
with channel2, channel at 3 with channel3?
The ethernet subnode 'ethernet-phy at 8' is using @8 for the device phy
address, is this node also giving warning?
Regards
Padmarao
Regards,
> Bin
>
More information about the U-Boot
mailing list