Message ID | 20191117072109.20402-4-afaerber@suse.de |
---|---|
State | Superseded |
Headers | show |
Series | ARM: Initial RTD1195 and MeLE X1000 support | expand |
Am 17.11.19 um 17:22 schrieb Marc Zyngier: > On Sun, 17 Nov 2019 15:40:59 +0000, > Andreas Färber <afaerber@suse.de> wrote: >> Am 17.11.19 um 11:47 schrieb Marc Zyngier: >>> On Sun, 17 Nov 2019 08:21:04 +0100 >>> Andreas Färber <afaerber@suse.de> wrote: >>>> + timer { >>>> + compatible = "arm,armv7-timer"; >>>> + interrupts = <GIC_PPI 13 >>>> + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, >>>> + <GIC_PPI 14 >>>> + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, >>>> + <GIC_PPI 11 >>>> + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, >>>> + <GIC_PPI 10 >>>> + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>; >>>> + clock-frequency = <27000000>; >>> >>> This is 2019, and yet it feels like 2011. This should be setup in the >>> bootloader, not in DT... >> >> What exactly - the whole node, the GIC CPU mask, the >> clock-frequency? > > The clock frequency. Having to rely on such hacks 8 years down the > line makes me feel like we've achieved nothing... > </depressed> Unfortunately I can confirm that without clock-frequency property I get: [ 0.000000] arch_timer: frequency not available [ 0.000000] ------------[ cut here ]------------ [ 0.000000] WARNING: CPU: 0 PID: 0 at kernel/time/clockevents.c:38 cev_delta2ns+0x148/0x170 [ 0.000000] Modules linked in: [ 0.000000] CPU: 0 PID: 0 Comm: swapper/0 Not tainted 5.4.0-rc7-next-20191115+ #213 [ 0.000000] Hardware name: Realtek RTD1195 [ 0.000000] [<c022f304>] (unwind_backtrace) from [<c022c0d0>] (show_stack+0x10/0x14) [ 0.000000] [<c022c0d0>] (show_stack) from [<c09113e4>] (dump_stack+0x84/0x98) [ 0.000000] [<c09113e4>] (dump_stack) from [<c023c928>] (__warn+0xbc/0xd8) [ 0.000000] [<c023c928>] (__warn) from [<c023c9a8>] (warn_slowpath_fmt+0x64/0xc4) [ 0.000000] [<c023c9a8>] (warn_slowpath_fmt) from [<c02ab910>] (cev_delta2ns+0x148/0x170) [ 0.000000] [<c02ab910>] (cev_delta2ns) from [<c02abf60>] (clockevents_config.part.0+0x54/0x74) [ 0.000000] [<c02abf60>] (clockevents_config.part.0) from [<c02abfa0>] (clockevents_config_and_register+0x20/0x2c) [ 0.000000] [<c02abfa0>] (clockevents_config_and_register) from [<c0789904>] (arch_timer_starting_cpu+0xcc/0x208) [ 0.000000] [<c0789904>] (arch_timer_starting_cpu) from [<c023d7dc>] (cpuhp_issue_call+0x110/0x130) [ 0.000000] [<c023d7dc>] (cpuhp_issue_call) from [<c023d984>] (__cpuhp_setup_state_cpuslocked+0x10c/0x2b4) [ 0.000000] [<c023d984>] (__cpuhp_setup_state_cpuslocked) from [<c023e180>] (__cpuhp_setup_state+0x98/0x14c) [ 0.000000] [<c023e180>] (__cpuhp_setup_state) from [<c0e1f224>] (arch_timer_of_init+0x2a8/0x34c) [ 0.000000] [<c0e1f224>] (arch_timer_of_init) from [<c0e1ecb4>] (timer_probe+0x74/0xec) [ 0.000000] [<c0e1ecb4>] (timer_probe) from [<c0e00c74>] (start_kernel+0x310/0x488) [ 0.000000] [<c0e00c74>] (start_kernel) from [<00000000>] (0x0) [ 0.000000] ---[ end trace c2db367029c1ec1a ]--- [ 0.000000] arch_timer: cp15 timer(s) running at 0.00MHz (virt). [ 0.000000] Division by zero in kernel. [ 0.000000] CPU: 0 PID: 0 Comm: swapper/0 Tainted: G W 5.4.0-rc7-next-20191115+ #213 [ 0.000000] Hardware name: Realtek RTD1195 [ 0.000000] [<c022f304>] (unwind_backtrace) from [<c022c0d0>] (show_stack+0x10/0x14) [ 0.000000] [<c022c0d0>] (show_stack) from [<c09113e4>] (dump_stack+0x84/0x98) [ 0.000000] [<c09113e4>] (dump_stack) from [<c090eb2c>] (Ldiv0_64+0x8/0x18) [ 0.000000] [<c090eb2c>] (Ldiv0_64) from [<c02a43dc>] (clocks_calc_max_nsecs+0x24/0x80) [ 0.000000] [<c02a43dc>] (clocks_calc_max_nsecs) from [<c02a4568>] (__clocksource_update_freq_scale+0x130/0x1ec) [ 0.000000] [<c02a4568>] (__clocksource_update_freq_scale) from [<c02a4638>] (__clocksource_register_scale+0x14/0xc0) [ 0.000000] [<c02a4638>] (__clocksource_register_scale) from [<c0e1ef30>] (arch_timer_common_init+0x198/0x1e4) [ 0.000000] [<c0e1ef30>] (arch_timer_common_init) from [<c0e1ecb4>] (timer_probe+0x74/0xec) [ 0.000000] [<c0e1ecb4>] (timer_probe) from [<c0e00c74>] (start_kernel+0x310/0x488) [ 0.000000] [<c0e00c74>] (start_kernel) from [<00000000>] (0x0) [ 0.000000] clocksource: arch_sys_counter: mask: 0xffffffffffffff max_cycles: 0x0, max_idle_ns: 0 ns [ 0.000000] Division by zero in kernel. [ 0.000000] CPU: 0 PID: 0 Comm: swapper/0 Tainted: G W 5.4.0-rc7-next-20191115+ #213 [ 0.000000] Hardware name: Realtek RTD1195 [ 0.000000] [<c022f304>] (unwind_backtrace) from [<c022c0d0>] (show_stack+0x10/0x14) [ 0.000000] [<c022c0d0>] (show_stack) from [<c09113e4>] (dump_stack+0x84/0x98) [ 0.000000] [<c09113e4>] (dump_stack) from [<c090eb2c>] (Ldiv0_64+0x8/0x18) [ 0.000000] [<c090eb2c>] (Ldiv0_64) from [<c02a418c>] (clocks_calc_mult_shift+0xec/0x10c) [ 0.000000] [<c02a418c>] (clocks_calc_mult_shift) from [<c0e0bb74>] (sched_clock_register+0x80/0x278) [ 0.000000] [<c0e0bb74>] (sched_clock_register) from [<c0e1ef68>] (arch_timer_common_init+0x1d0/0x1e4) [ 0.000000] [<c0e1ef68>] (arch_timer_common_init) from [<c0e1ecb4>] (timer_probe+0x74/0xec) [ 0.000000] [<c0e1ecb4>] (timer_probe) from [<c0e00c74>] (start_kernel+0x310/0x488) [ 0.000000] [<c0e00c74>] (start_kernel) from [<00000000>] (0x0) [ 0.000000] Division by zero in kernel. [ 0.000000] CPU: 0 PID: 0 Comm: swapper/0 Tainted: G W 5.4.0-rc7-next-20191115+ #213 [ 0.000000] Hardware name: Realtek RTD1195 [ 0.000000] [<c022f304>] (unwind_backtrace) from [<c022c0d0>] (show_stack+0x10/0x14) [ 0.000000] [<c022c0d0>] (show_stack) from [<c09113e4>] (dump_stack+0x84/0x98) [ 0.000000] [<c09113e4>] (dump_stack) from [<c090eb2c>] (Ldiv0_64+0x8/0x18) [ 0.000000] [<c090eb2c>] (Ldiv0_64) from [<c02a43dc>] (clocks_calc_max_nsecs+0x24/0x80) [ 0.000000] [<c02a43dc>] (clocks_calc_max_nsecs) from [<c0e0bbb0>] (sched_clock_register+0xbc/0x278) [ 0.000000] [<c0e0bbb0>] (sched_clock_register) from [<c0e1ef68>] (arch_timer_common_init+0x1d0/0x1e4) [ 0.000000] [<c0e1ef68>] (arch_timer_common_init) from [<c0e1ecb4>] (timer_probe+0x74/0xec) [ 0.000000] [<c0e1ecb4>] (timer_probe) from [<c0e00c74>] (start_kernel+0x310/0x488) [ 0.000000] [<c0e00c74>] (start_kernel) from [<00000000>] (0x0) [ 0.000000] sched_clock: 56 bits at 0 Hz, resolution 0ns, wraps every 0ns [ 0.000000] Failed to initialize '/timer': -6 [ 0.000000] timer_probe: no matching timers found Regards, Andreas -- SUSE Software Solutions Germany GmbH Maxfeldstr. 5, 90409 Nürnberg, Germany GF: Felix Imendörffer HRB 36809 (AG Nürnberg)
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile index 08011dc8c7a6..4853a13c8cf2 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile @@ -865,6 +865,8 @@ dtb-$(CONFIG_ARCH_QCOM) += \ dtb-$(CONFIG_ARCH_RDA) += \ rda8810pl-orangepi-2g-iot.dtb \ rda8810pl-orangepi-i96.dtb +dtb-$(CONFIG_ARCH_REALTEK) += \ + rtd1195-mele-x1000.dtb dtb-$(CONFIG_ARCH_REALVIEW) += \ arm-realview-pb1176.dtb \ arm-realview-pb11mp.dtb \ diff --git a/arch/arm/boot/dts/rtd1195-mele-x1000.dts b/arch/arm/boot/dts/rtd1195-mele-x1000.dts new file mode 100644 index 000000000000..834b430e6250 --- /dev/null +++ b/arch/arm/boot/dts/rtd1195-mele-x1000.dts @@ -0,0 +1,31 @@ +// SPDX-License-Identifier: (GPL-2.0-or-later OR BSD-2-Clause) +/* + * Copyright (c) 2017-2019 Andreas Färber + */ + +/dts-v1/; + +#include "rtd1195.dtsi" + +/ { + compatible = "mele,x1000", "realtek,rtd1195"; + model = "MeLE X1000"; + + aliases { + serial0 = &uart0; + }; + + chosen { + stdout-path = "serial0:115200n8"; + }; + + memory@0 { + device_type = "memory"; + reg = <0x0 0x18000000>, + <0x19100000 0x26f00000>; + }; +}; + +&uart0 { + status = "okay"; +}; diff --git a/arch/arm/boot/dts/rtd1195.dtsi b/arch/arm/boot/dts/rtd1195.dtsi new file mode 100644 index 000000000000..4e3866fe8f6e --- /dev/null +++ b/arch/arm/boot/dts/rtd1195.dtsi @@ -0,0 +1,127 @@ +// SPDX-License-Identifier: (GPL-2.0-or-later OR BSD-2-Clause) +/* + * Copyright (c) 2017-2019 Andreas Färber + */ + +/memreserve/ 0x00000000 0x0000a800; /* boot code */ +/memreserve/ 0x0000a800 0x000f5800; +/memreserve/ 0x17fff000 0x00001000; + +#include <dt-bindings/interrupt-controller/arm-gic.h> + +/ { + compatible = "realtek,rtd1195"; + interrupt-parent = <&gic>; + #address-cells = <1>; + #size-cells = <1>; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + + cpu0: cpu@0 { + device_type = "cpu"; + compatible = "arm,cortex-a7"; + reg = <0x0>; + clock-frequency = <1000000000>; + }; + + cpu1: cpu@1 { + device_type = "cpu"; + compatible = "arm,cortex-a7"; + reg = <0x1>; + clock-frequency = <1000000000>; + }; + }; + + reserved-memory { + #address-cells = <1>; + #size-cells = <1>; + ranges; + + rpc_comm: rpc@b000 { + reg = <0x0000b000 0x1000>; + }; + + audio@1b00000 { + reg = <0x01b00000 0x400000>; + }; + + rpc_ringbuf: rpc@1ffe000 { + reg = <0x01ffe000 0x4000>; + }; + + secure@10000000 { + reg = <0x10000000 0x100000>; + no-map; + }; + }; + + arm-pmu { + compatible = "arm,cortex-a7-pmu"; + interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>, + <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>; + interrupt-affinity = <&cpu0>, <&cpu1>; + }; + + timer { + compatible = "arm,armv7-timer"; + interrupts = <GIC_PPI 13 + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, + <GIC_PPI 14 + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, + <GIC_PPI 11 + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>, + <GIC_PPI 10 + (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>; + clock-frequency = <27000000>; + }; + + osc27M: osc { + compatible = "fixed-clock"; + clock-frequency = <27000000>; + #clock-cells = <0>; + clock-output-names = "osc27M"; + }; + + soc { + compatible = "simple-bus"; + #address-cells = <1>; + #size-cells = <1>; + ranges = <0x18000000 0x18000000 0x00070000>, + <0x18100000 0x18100000 0x01000000>, + <0x40000000 0x40000000 0xc0000000>; + + wdt: watchdog@18007680 { + compatible = "realtek,rtd1295-watchdog"; + reg = <0x18007680 0x100>; + clocks = <&osc27M>; + }; + + uart0: serial@18007800 { + compatible = "snps,dw-apb-uart"; + reg = <0x18007800 0x400>; + reg-shift = <2>; + reg-io-width = <4>; + clock-frequency = <27000000>; + status = "disabled"; + }; + + uart1: serial@1801b200 { + compatible = "snps,dw-apb-uart"; + reg = <0x1801b200 0x100>; + reg-shift = <2>; + reg-io-width = <4>; + clock-frequency = <27000000>; + status = "disabled"; + }; + + gic: interrupt-controller@ff011000 { + compatible = "arm,cortex-a7-gic"; + reg = <0xff011000 0x1000>, + <0xff012000 0x2000>; + interrupt-controller; + #interrupt-cells = <3>; + }; + }; +};