summaryrefslogtreecommitdiffstats
path: root/src/soc/mediatek/mt8183/include/soc/smi.h
blob: 6ec9317af93dfd08363ef2e14467ad6f061760f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/* SPDX-License-Identifier: GPL-2.0-only */

#ifndef SOC_MEDIATEK_MT8183_SMI_H
#define SOC_MEDIATEK_MT8183_SMI_H

#include <soc/addressmap.h>
#include <types.h>

struct mt8183_smi_regs {
	u32 reserved1[64];
	u32 smi_l1len;
	u32 smi_l1arb0;
	u32 smi_l1arb1;
	u32 smi_l1arb2;
	u32 smi_l1arb3;
	u32 smi_l1arb4;
	u32 smi_l1arb5;
	u32 smi_l1arb6;
	u32 smi_l1arb7;
	u32 reserved2[31];
	u32 smi_mon_axi_ena;
	u32 smi_mon_axi_clr;
	u32 reserved3[1];
	u32 smi_mon_axi_type;
	u32 smi_mon_axi_con;
	u32 reserved4[3];
	u32 smi_mon_axi_act_cnt;
	u32 smi_mon_axi_req_cnt;
	u32 smi_mon_axi_ostd_cnt;
	u32 smi_mon_axi_bea_cnt;
	u32 smi_mon_axi_byt_cnt;
	u32 smi_mon_axi_cp_cnt;
	u32 smi_mon_axi_dp_cnt;
	u32 smi_mon_axi_cp_max;
	u32 smi_mon_axi_cos_max;
	u32 reserved5[15];
	u32 smi_bus_sel;
	u32 reserved6[1];
	u32 smi_wrr_reg0;
	u32 smi_wrr_reg1;
	u32 smi_read_fifo_th;
	u32 smi_m4u_th;
	u32 smi_fifo_th1;
	u32 smi_fifo_th2;
	u32 smi_preultra_mask0;
	u32 smi_preultra_mask1;
	u32 reserved7[46];
	u32 smi_dcm;
	u32 smi_ela;
	u32 smi_m1_rultra_wrr0;
	u32 smi_m1_rultra_wrr1;
	u32 smi_m1_wultra_wrr0;
	u32 smi_m1_wultra_wrr1;
	u32 smi_m2_rultra_wrr0;
	u32 smi_m2_rultra_wrr1;
	u32 smi_m2_wultra_wrr0;
	u32 smi_m2_wultra_wrr1;
	u32 reserved8[38];
	u32 smi_common_clamp_en;
	u32 smi_common_clamp_en_set;
	u32 smi_common_clamp_en_clr;
	u32 reserved9[13];
	u32 smi_debug_s0;
	u32 smi_debug_s1;
	u32 smi_debug_s2;
	u32 smi_debug_s3;
	u32 smi_debug_s4;
	u32 smi_debug_s5;
	u32 smi_debug_s6;
	u32 smi_debug_s7;
	u32 reserved10[4];
	u32 smi_debug_m0;
	u32 smi_debug_m1;
	u32 reserved11[2];
	u32 smi_debug_misc;
	u32 smi_dummy;
	u32 reserved12[46];
	u32 smi_hist_rec0;
	u32 smi_hist_rec_data0;
	u32 smi_hist_rec_data1;
	u32 smi_hist_rec_data2;
	u32 smi_hist_rec_data3;
	u32 smi_hist_rec_data4;
	u32 smi_hist_rec_data5;
	u32 smi_hist_rec_data6;
	u32 smi_hist_rec_data7;
	u32 smi_hist_rec_data8;
	u32 smi_hist_rec_data9;
};

check_member(mt8183_smi_regs, smi_l1len, 0x0100);
check_member(mt8183_smi_regs, smi_mon_axi_ena, 0x01a0);
check_member(mt8183_smi_regs, smi_mon_axi_act_cnt, 0x01c0);
check_member(mt8183_smi_regs, smi_bus_sel, 0x0220);
check_member(mt8183_smi_regs, smi_dcm, 0x0300);
check_member(mt8183_smi_regs, smi_common_clamp_en, 0x03c0);
check_member(mt8183_smi_regs, smi_debug_s0, 0x0400);
check_member(mt8183_smi_regs, smi_debug_m0, 0x0430);
check_member(mt8183_smi_regs, smi_debug_misc, 0x0440);
check_member(mt8183_smi_regs, smi_hist_rec0, 0x0500);
check_member(mt8183_smi_regs, smi_hist_rec_data9, 0x0528);

static struct mt8183_smi_regs *const mt8183_smi = (void *)SMI_BASE;

#endif  /* SOC_MEDIATEK_MT8183_SMI_H */