[PATCH 3/3 v6] ARC: hsdk: initial port for HSDK board
Alexey Brodkin
Alexey.Brodkin at synopsys.com
Mon Jun 26 09:25:35 PDT 2017
Hi Rob,
On Mon, 2017-06-26 at 10:51 -0500, Rob Herring wrote:
> On Mon, Jun 26, 2017 at 10:11 AM, Eugeniy Paltsev
> <Eugeniy.Paltsev at synopsys.com> wrote:
> >
> > From: Alexey Brodkin <abrodkin at synopsys.com>
> >
[snip]
> > +
> > + chosen {
> > + bootargs = "earlycon=uart8250,mmio32,0xf0005000,115200n8 console=ttyS0,115200n8 debug print-fatal-signals=1";
>
> Use stdout-path for the console. Really, the bootargs should be blank
> and populated by the bootloader especially debug options.
Agree but in case of devboards we quite often disable bootloader and
load Linux image in memory via JTAG. So in that case bootargs make perfect sense IMHO.
> >
> > + };
> > +
> > + cpu {
>
> 'cpu' is for cpu nodes, so need something different.
Agree.
> >
> > + compatible = "simple-bus";
> > + #address-cells = <1>;
> > + #size-cells = <1>;
>
> There are no reg properties, so these aren't needed. This doesn't look
> like a simple-bus either.
>
> Probably these child nodes should just be moved up to root level.
Looks like that. Thanks.
> >
> > + interrupt-parent = <&core_intc>;
> > +
> > + core_clk: core_clk {
>
> core-clk {
Ok.
> >
> > + #clock-cells = <0>;
> > + compatible = "fixed-clock";
> > + clock-frequency = <1000000000>;
> > + };
> > +
> > + core_intc: archs-intc at cpu {
>
> cpu is not a valid unit-address. How are these interrupt controllers addressed?
We have per-core INTC so each core communicates to its own INTC and there's no way
for any core to talk with INTC of another core.
But then we have the next level INTC which is IDU (Interrupt Distribution Unit)
which dispatches "common" IRQs to different upstream per-core INTC, see below its node.
> >
> > + compatible = "snps,archs-intc";
> > + interrupt-controller;
> > + #interrupt-cells = <1>;
> > + };
> > +
> > + idu_intc: idu-interrupt-controller {
> > + compatible = "snps,archs-idu-intc";
> > + interrupt-controller;
> > + #interrupt-cells = <1>;
> > + };
> > +
> > + arcpct0: pct {
> > + compatible = "snps,archs-pct";
> > + };
> > + };
> > +
> > + soc {
> > + compatible = "simple-bus";
> > + #address-cells = <1>;
> > + #size-cells = <1>;
> > + interrupt-parent = <&idu_intc>;
> > +
> > + ranges = <0x00000000 0xf0000000 0x10000000>;
> > +
> > + uart: dw-apb-uart at 5000 {
>
> serial at ...
Yep.
> >
> > + compatible = "snps,dw-apb-uart";
> > + reg = <0x5000 0x100>;
> > + clock-frequency = <33330000>;
> > + interrupts = <6>;
> > + baud = <115200>;
> > + reg-shift = <2>;
> > + reg-io-width = <4>;
> > + };
> > +
> > + gmacclk: gmacclk {
> > + compatible = "fixed-clock";
> > + clock-frequency = <400000000>;
> > + #clock-cells = <0>;
> > + };
> > +
> > + mmcclk_ciu: mmcclk_ciu {
>
> Don't use underscores in node names.
Ok.
> >
> > + compatible = "fixed-clock";
> > + clock-frequency = <100000000>;
> > + #clock-cells = <0>;
> > + };
> > +
> > + mmcclk_biu: mmcclk_biu {
> > + compatible = "fixed-clock";
> > + clock-frequency = <400000000>;
> > + #clock-cells = <0>;
> > + };
> > +
> > + ethernet at 8000 {
> > + #interrupt-cells = <1>;
> > + compatible = "snps,dwmac";
> > + reg = <0x8000 0x2000>;
> > + interrupts = <10>;
> > + interrupt-names = "macirq";
> > + phy-mode = "rgmii";
> > + snps,pbl = <32>;
> > + clocks = <&gmacclk>;
> > + clock-names = "stmmaceth";
> > + phy-handle = <&phy0>;
> > +
> > + mdio0 {
>
> mdio {
>
> >
> > + #address-cells = <1>;
> > + #size-cells = <0>;
> > + compatible = "snps,dwmac-mdio";
> > + phy0: ethernet-phy at 0 {
> > + reg = <0>;
> > + ti,rx-internal-delay = <DP83867_RGMIIDCTL_2_00_NS>;
> > + ti,tx-internal-delay = <DP83867_RGMIIDCTL_2_00_NS>;
> > + ti,fifo-depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
> > + };
> > + };
> > + };
> > +
> > + ohci at 60000 {
> > + compatible = "generic-ohci";
>
> This should have an SoC specific compatible.
But why? We don't have any SoC-specific extensions.
This essentially applies to EHCI as well.
> >
> > + reg = <0x60000 0x100>;
> > + interrupts = <15>;
> > + };
> > +
> > + ehci at 40000 {
> > + compatible = "generic-ehci";
>
> This should have an SoC specific compatible.
>
> >
> > + reg = <0x40000 0x100>;
> > + interrupts = <15>;
> > + };
> > +
> > + mmc at a000 {
> > + compatible = "altr,socfpga-dw-mshc";
> > + reg = <0xa000 0x400>;
> > + num-slots = <1>;
> > + fifo-depth = <16>;
> > + card-detect-delay = <200>;
> > + clocks = <&mmcclk_biu>, <&mmcclk_ciu>;
> > + clock-names = "biu", "ciu";
> > + interrupts = <12>;
> > + bus-width = <4>;
> > + };
> > + };
> > +
> > + memory {
>
> memory at 80000000
Ok.
>
> >
> > + #address-cells = <1>;
> > + #size-cells = <1>;
> > + device_type = "memory";
> > + reg = <0x80000000 0x40000000>; /* 1 GiB */
> > + };
> > +};
> > diff --git a/arch/arc/configs/hsdk_defconfig b/arch/arc/configs/hsdk_defconfig
> > new file mode 100644
> > index 0000000..53bc9f3
> > --- /dev/null
> > +++ b/arch/arc/configs/hsdk_defconfig
> > @@ -0,0 +1,75 @@
> > +CONFIG_DEFAULT_HOSTNAME="ARCLinux"
> > +CONFIG_SYSVIPC=y
> > +# CONFIG_CROSS_MEMORY_ATTACH is not set
> > +CONFIG_NO_HZ_IDLE=y
> > +CONFIG_HIGH_RES_TIMERS=y
> > +CONFIG_IKCONFIG=y
> > +CONFIG_IKCONFIG_PROC=y
> > +CONFIG_NAMESPACES=y
> > +# CONFIG_UTS_NS is not set
> > +# CONFIG_PID_NS is not set
> > +CONFIG_BLK_DEV_INITRD=y
> > +CONFIG_INITRAMFS_SOURCE="../../arc_initramfs_hs/"
> > +CONFIG_EMBEDDED=y
> > +CONFIG_PERF_EVENTS=y
> > +# CONFIG_VM_EVENT_COUNTERS is not set
> > +# CONFIG_COMPAT_BRK is not set
> > +CONFIG_SLAB=y
> > +CONFIG_ARC_PLAT_HSDK=y
> > +CONFIG_ISA_ARCV2=y
> > +CONFIG_SMP=y
> > +CONFIG_LINUX_LINK_BASE=0x90000000
> > +CONFIG_KERNEL_RAM_BASE_ADDRESS=0x80000000
> > +CONFIG_ARC_BUILTIN_DTB_NAME="hsdk"
> > +CONFIG_PREEMPT=y
> > +# CONFIG_COMPACTION is not set
> > +CONFIG_NET=y
> > +CONFIG_PACKET=y
> > +CONFIG_UNIX=y
> > +CONFIG_INET=y
> > +CONFIG_DEVTMPFS=y
> > +# CONFIG_STANDALONE is not set
> > +# CONFIG_PREVENT_FIRMWARE_BUILD is not set
> > +# CONFIG_FIRMWARE_IN_KERNEL is not set
> > +CONFIG_SCSI=y
> > +CONFIG_BLK_DEV_SD=y
> > +CONFIG_NETDEVICES=y
> > +CONFIG_STMMAC_ETH=y
> > +CONFIG_MICREL_PHY=y
> > +# CONFIG_INPUT_KEYBOARD is not set
> > +# CONFIG_INPUT_MOUSE is not set
> > +# CONFIG_SERIO is not set
> > +# CONFIG_LEGACY_PTYS is not set
> > +CONFIG_SERIAL_8250=y
> > +CONFIG_SERIAL_8250_CONSOLE=y
> > +CONFIG_SERIAL_8250_DW=y
> > +CONFIG_SERIAL_OF_PLATFORM=y
> > +# CONFIG_HW_RANDOM is not set
> > +# CONFIG_HWMON is not set
> > +CONFIG_FB=y
> > +CONFIG_FB_UDL=y
> > +CONFIG_FRAMEBUFFER_CONSOLE=y
> > +CONFIG_USB=y
> > +CONFIG_USB_EHCI_HCD=y
> > +CONFIG_USB_EHCI_HCD_PLATFORM=y
> > +CONFIG_USB_OHCI_HCD=y
> > +CONFIG_USB_OHCI_HCD_PLATFORM=y
> > +CONFIG_USB_STORAGE=y
> > +CONFIG_MMC=y
> > +CONFIG_MMC_SDHCI=y
> > +CONFIG_MMC_SDHCI_PLTFM=y
> > +CONFIG_MMC_DW=y
> > +# CONFIG_IOMMU_SUPPORT is not set
> > +CONFIG_EXT3_FS=y
> > +CONFIG_VFAT_FS=y
> > +CONFIG_TMPFS=y
> > +CONFIG_NLS_CODEPAGE_437=y
> > +CONFIG_NLS_ISO8859_1=y
> > +# CONFIG_ENABLE_WARN_DEPRECATED is not set
> > +# CONFIG_ENABLE_MUST_CHECK is not set
> > +CONFIG_STRIP_ASM_SYMS=y
> > +CONFIG_LOCKUP_DETECTOR=y
> > +CONFIG_DEFAULT_HUNG_TASK_TIMEOUT=10
> > +# CONFIG_SCHED_DEBUG is not set
> > +# CONFIG_DEBUG_PREEMPT is not set
> > +# CONFIG_FTRACE is not set
> > diff --git a/arch/arc/kernel/devtree.c b/arch/arc/kernel/devtree.c
> > index 3b67f53..521ef35 100644
> > --- a/arch/arc/kernel/devtree.c
> > +++ b/arch/arc/kernel/devtree.c
> > @@ -29,8 +29,9 @@ static void __init arc_set_early_base_baud(unsigned long dt_root)
> > {
> > if (of_flat_dt_is_compatible(dt_root, "abilis,arc-tb10x"))
> > arc_base_baud = 166666666; /* Fixed 166.6MHz clk (TB10x) */
> > - else if (of_flat_dt_is_compatible(dt_root, "snps,arc-sdp"))
> > - arc_base_baud = 33333333; /* Fixed 33MHz clk (AXS10x) */
> > + else if (of_flat_dt_is_compatible(dt_root, "snps,arc-sdp") ||
> > + of_flat_dt_is_compatible(dt_root, "snps,hsdk"))
> > + arc_base_baud = 33333333; /* Fixed 33MHz clk (AXS10x & HSDK) */
>
> You should get this info from DT. You don't need to address that now though.
For normal UART we indeed don't need that. But this is really required for early
console otherwise how may we start outputting stuff even before we have .dtb
unflattened.
The only thing I may think of early platform code that extracts this value from .dtb
image but:
1) I'm not sure it is more elegant
2) Still it will be a bit too late - now we start printing very-very early.
> >
> > else if (of_flat_dt_is_compatible(dt_root, "ezchip,arc-nps"))
> > arc_base_baud = 800000000; /* Fixed 800MHz clk (NPS) */
> > else
> > diff --git a/arch/arc/plat-hsdk/Kconfig b/arch/arc/plat-hsdk/Kconfig
> > new file mode 100644
> > index 0000000..29dffed
> > --- /dev/null
> > +++ b/arch/arc/plat-hsdk/Kconfig
> > @@ -0,0 +1,12 @@
> > +#
> > +# Copyright (C) 2017 Synopsys, Inc. (www.synopsys.com)
> > +#
> > +# This program is free software; you can redistribute it and/or modify
> > +# it under the terms of the GNU General Public License version 2 as
> > +# published by the Free Software Foundation.
> > +#
> > +
> > +menuconfig ARC_PLAT_HSDK
> > + bool "ARC HS Development Kit board"
>
> Per board config options don't scale and shouldn't be necessary with DT...
Not sure if I understand that completely.
Could you please explain in a bit more details?
-Alexey
More information about the linux-snps-arc
mailing list