blob: 9915685f75fd2ae741371a5b09abbadc81b95a35 [file] [log] [blame]
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +00001/*
2 * Copyright (c) 2023-2024, Arm Limited. All rights reserved.
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7#include <dt-bindings/interrupt-controller/arm-gic.h>
8#include <dt-bindings/interrupt-controller/irq.h>
9
Kshitij Sisodia090a6aa2023-11-22 17:03:45 +000010/* If SCMI power domain control is enabled */
11#if TC_SCMI_PD_CTRL_EN
Boyan Karatotev192ad5d2023-12-12 15:59:01 +000012#define GPU_SCMI_PD_IDX (PLAT_MAX_CPUS_PER_CLUSTER + 1)
13#define DPU_SCMI_PD_IDX (PLAT_MAX_CPUS_PER_CLUSTER + 2)
Kshitij Sisodia090a6aa2023-11-22 17:03:45 +000014#endif /* TC_SCMI_PD_CTRL_EN */
Boyan Karatotev192ad5d2023-12-12 15:59:01 +000015
16/* All perf is normalized against the big core */
17#define BIG_CAPACITY 1024
18
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +000019#if TARGET_PLATFORM <= 2
Boyan Karatotev192ad5d2023-12-12 15:59:01 +000020#if TARGET_FLAVOUR_FVP
21#define LIT_CAPACITY 406
22#define MID_CAPACITY 912
23#else /* TARGET_FLAVOUR_FPGA */
24#define LIT_CAPACITY 280
25#define MID_CAPACITY 775
26/* this is an area optimized configuration of the big core */
27#define BIG2_CAPACITY 930
28#endif /* TARGET_FLAVOUR_FPGA */
29
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +000030#define INT_MBOX_RX 317
31#define MHU_TX_ADDR(pref) pref##45000000 /* hex */
32#define MHU_RX_ADDR(pref) pref##45010000 /* hex */
33#define MPAM_ADDR 0x1 0x00010000 /* 0x1_0001_0000 */
34#define UARTCLK_FREQ 5000000
35#elif TARGET_PLATFORM == 3
Boyan Karatotev192ad5d2023-12-12 15:59:01 +000036
37#define LIT_CAPACITY 239
38#define MID_CAPACITY 686
39
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +000040#define INT_MBOX_RX 300
41#define MHU_TX_ADDR(pref) pref##46040000 /* hex */
42#define MHU_RX_ADDR(pref) pref##46140000 /* hex */
43#define MPAM_ADDR 0x0 0x5f010000 /* 0x5f01_0000 */
44#define UARTCLK_FREQ 3750000
45#endif /* TARGET_PLATFORM == 3 */
46
Boyan Karatotev95562762023-11-15 11:54:33 +000047#if TARGET_FLAVOUR_FVP
48#define STDOUT_PATH "serial0:115200n8"
49#define GIC_CTRL_ADDR 2c010000
50#define GIC_GICR_OFFSET 0x200000
51#define UART_OFFSET 0x1000
52#define VENCODER_TIMING_CLK 25175000
53#define VENCODER_TIMING \
54 clock-frequency = <VENCODER_TIMING_CLK>; \
55 hactive = <640>; \
56 vactive = <480>; \
57 hfront-porch = <16>; \
58 hback-porch = <48>; \
59 hsync-len = <96>; \
60 vfront-porch = <10>; \
61 vback-porch = <33>; \
62 vsync-len = <2>
63#define ETH_COMPATIBLE "smsc,lan91c111"
64#define MMC_REMOVABLE cd-gpios = <&sysreg 0 0>
65
66#else /* TARGET_FLAVOUR_FPGA */
67
68#define STDOUT_PATH "serial0:38400n8"
69#define GIC_CTRL_ADDR 30000000
70#define GIC_GICR_OFFSET 0x1000000
71#define UART_OFFSET 0x10000
72/* 1440x3200@120 framebuffer */
73#define VENCODER_TIMING_CLK 836000000
74#define VENCODER_TIMING \
75 clock-frequency = <VENCODER_TIMING_CLK>; \
76 hactive = <1440>; \
77 vactive = <3200>; \
78 hfront-porch = <136>; \
79 hback-porch = <296>; \
80 hsync-len = <160>; \
81 vfront-porch = <3>; \
82 vback-porch = <217>; \
83 vsync-len = <10>
84#define ETH_COMPATIBLE "smsc,lan9115"
85#define MMC_REMOVABLE non-removable
86#endif /* TARGET_FLAVOUR_FPGA */
87
88/* Use SCMI controlled clocks */
89#if TC_DPU_USE_SCMI_CLK
90#define DPU_CLK_ATTR1 \
91 clocks = <&scmi_clk 0>; \
92 clock-names = "aclk"
93
94#define DPU_CLK_ATTR2 \
95 clocks = <&scmi_clk 1>; \
96 clock-names = "pxclk"
97
98#define DPU_CLK_ATTR3 \
99 clocks = <&scmi_clk 2>; \
100 clock-names = "pxclk" \
101/* Use fixed clocks */
102#else /* !TC_DPU_USE_SCMI_CLK */
103#define DPU_CLK_ATTR1 \
104 clocks = <&dpu_aclk>; \
105 clock-names = "aclk"
106
107#define DPU_CLK_ATTR2 \
108 clocks = <&dpu_pixel_clk>, <&dpu_aclk>; \
109 clock-names = "pxclk", "aclk"
110
111#define DPU_CLK_ATTR3 DPU_CLK_ATTR2
112#endif /* !TC_DPU_USE_SCMI_CLK */
113
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +0000114/ {
115#if TARGET_PLATFORM <= 2
116 cmn-pmu {
117 compatible = "arm,ci-700";
118 reg = <0x0 0x50000000 0x0 0x10000000>;
119 interrupts = <GIC_SPI 460 IRQ_TYPE_LEVEL_HIGH>;
120 };
121#endif /* TARGET_PLATFORM <= 2 */
Boyan Karatotev95562762023-11-15 11:54:33 +0000122
123#if !TC_DPU_USE_SCMI_CLK
124 dpu_aclk: dpu_aclk {
125 compatible = "fixed-clock";
126 #clock-cells = <0>;
127 clock-frequency = <VENCODER_TIMING_CLK>;
128 clock-output-names = "fpga:dpu_aclk";
129 };
130
131 dpu_pixel_clk: dpu-pixel-clk {
132 compatible = "fixed-clock";
133 #clock-cells = <0>;
134 clock-frequency = <VENCODER_TIMING_CLK>;
135 clock-output-names = "pxclk";
136 };
137#endif /* !TC_DPU_USE_SCMI_CLK */
Boyan Karatotev6ed3bf62023-07-07 13:33:19 +0000138};