xref: /rk3399_ARM-atf/fdts/tc-fvp.dtsi (revision dd5bf9c5e26ea47988cde76f916495031ecc85c9)
135028bd7SLeo Yan/*
235028bd7SLeo Yan * Copyright (c) 2023-2024, Arm Limited. All rights reserved.
335028bd7SLeo Yan *
435028bd7SLeo Yan * SPDX-License-Identifier: BSD-3-Clause
535028bd7SLeo Yan */
635028bd7SLeo Yan
74e772e6bSLeo Yan#define GIC_CTRL_ADDR		2c010000
84e772e6bSLeo Yan#define GIC_GICR_OFFSET		0x200000
94e772e6bSLeo Yan#define UART_OFFSET		0x1000
10*dd5bf9c5SSergio Alves
11*dd5bf9c5SSergio Alves#ifdef TC_RESOLUTION_1920X1080P60
12*dd5bf9c5SSergio Alves
13*dd5bf9c5SSergio Alves#define VENCODER_TIMING_CLK 148500000
14*dd5bf9c5SSergio Alves#define VENCODER_TIMING								\
15*dd5bf9c5SSergio Alves	clock-frequency = <VENCODER_TIMING_CLK>;				\
16*dd5bf9c5SSergio Alves	hactive = <1920>;							\
17*dd5bf9c5SSergio Alves	vactive = <1080>;							\
18*dd5bf9c5SSergio Alves	hfront-porch = <88>;							\
19*dd5bf9c5SSergio Alves	hback-porch = <148>;							\
20*dd5bf9c5SSergio Alves	hsync-len = <44>;							\
21*dd5bf9c5SSergio Alves	vfront-porch = <4>;							\
22*dd5bf9c5SSergio Alves	vback-porch = <36>;							\
23*dd5bf9c5SSergio Alves	vsync-len = <5>
24*dd5bf9c5SSergio Alves
25*dd5bf9c5SSergio Alves#else /* TC_RESOLUTION_640X480P60 */
26*dd5bf9c5SSergio Alves
274e772e6bSLeo Yan#define VENCODER_TIMING_CLK 25175000
284e772e6bSLeo Yan#define VENCODER_TIMING								\
294e772e6bSLeo Yan	clock-frequency = <VENCODER_TIMING_CLK>;				\
304e772e6bSLeo Yan	hactive = <640>;							\
314e772e6bSLeo Yan	vactive = <480>;							\
324e772e6bSLeo Yan	hfront-porch = <16>;							\
334e772e6bSLeo Yan	hback-porch = <48>;							\
344e772e6bSLeo Yan	hsync-len = <96>;							\
354e772e6bSLeo Yan	vfront-porch = <10>;							\
364e772e6bSLeo Yan	vback-porch = <33>;							\
374e772e6bSLeo Yan	vsync-len = <2>
384e772e6bSLeo Yan
39*dd5bf9c5SSergio Alves#endif
40*dd5bf9c5SSergio Alves
4135028bd7SLeo Yan/ {
42e6ef3ef0SLeo Yan	chosen {
43e6ef3ef0SLeo Yan		stdout-path = "serial0:115200n8";
44e6ef3ef0SLeo Yan	};
45e6ef3ef0SLeo Yan
46e6ef3ef0SLeo Yan	ethernet: ethernet@18000000 {
47e6ef3ef0SLeo Yan		compatible = "smsc,lan91c111";
48e6ef3ef0SLeo Yan	};
49e6ef3ef0SLeo Yan
50e6ef3ef0SLeo Yan	mmci: mmci@1c050000 {
51e6ef3ef0SLeo Yan		cd-gpios = <&sysreg 0 0>;
52e6ef3ef0SLeo Yan	};
53e6ef3ef0SLeo Yan
5435028bd7SLeo Yan	rtc@1c170000 {
5535028bd7SLeo Yan		compatible = "arm,pl031", "arm,primecell";
5635028bd7SLeo Yan		reg = <0x0 0x1C170000 0x0 0x1000>;
5735028bd7SLeo Yan		interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
5835028bd7SLeo Yan		clocks = <&soc_refclk>;
5935028bd7SLeo Yan		clock-names = "apb_pclk";
6035028bd7SLeo Yan	};
6135028bd7SLeo Yan
6235028bd7SLeo Yan	kmi@1c060000 {
6335028bd7SLeo Yan		compatible = "arm,pl050", "arm,primecell";
6435028bd7SLeo Yan		reg = <0x0 0x001c060000 0x0 0x1000>;
6535028bd7SLeo Yan		interrupts = <GIC_SPI 197 IRQ_TYPE_LEVEL_HIGH>;
6635028bd7SLeo Yan		clocks = <&bp_clock24mhz>, <&bp_clock24mhz>;
6735028bd7SLeo Yan		clock-names = "KMIREFCLK", "apb_pclk";
6835028bd7SLeo Yan	};
6935028bd7SLeo Yan
7035028bd7SLeo Yan	kmi@1c070000 {
7135028bd7SLeo Yan		compatible = "arm,pl050", "arm,primecell";
7235028bd7SLeo Yan		reg = <0x0 0x001c070000 0x0 0x1000>;
7335028bd7SLeo Yan		interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
7435028bd7SLeo Yan		clocks = <&bp_clock24mhz>, <&bp_clock24mhz>;
7535028bd7SLeo Yan		clock-names = "KMIREFCLK", "apb_pclk";
7635028bd7SLeo Yan	};
7735028bd7SLeo Yan
7835028bd7SLeo Yan	virtio_block@1c130000 {
7935028bd7SLeo Yan		compatible = "virtio,mmio";
8035028bd7SLeo Yan		reg = <0x0 0x1c130000 0x0 0x200>;
8135028bd7SLeo Yan		/* spec lists this wrong */
8235028bd7SLeo Yan		interrupts = <GIC_SPI 204 IRQ_TYPE_LEVEL_HIGH>;
8335028bd7SLeo Yan	};
8435028bd7SLeo Yan};
85