xref: /linux/drivers/gpu/drm/msm/disp/dpu1/catalog/dpu_4_1_sdm670.h (revision 2c1ed907520c50326b8f604907a8478b27881a2e)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (c) 2015-2018, The Linux Foundation. All rights reserved.
4  * Copyright (c) 2022. Qualcomm Innovation Center, Inc. All rights reserved.
5  * Copyright (c) 2023, Richard Acayan. All rights reserved.
6  */
7 
8 #ifndef _DPU_4_1_SDM670_H
9 #define _DPU_4_1_SDM670_H
10 
11 static const struct dpu_mdp_cfg sdm670_mdp = {
12 	.name = "top_0",
13 	.base = 0x0, .len = 0x45c,
14 	.features = BIT(DPU_MDP_AUDIO_SELECT),
15 	.clk_ctrls = {
16 		[DPU_CLK_CTRL_VIG0] = { .reg_off = 0x2ac, .bit_off = 0 },
17 		[DPU_CLK_CTRL_VIG1] = { .reg_off = 0x2b4, .bit_off = 0 },
18 		[DPU_CLK_CTRL_DMA0] = { .reg_off = 0x2ac, .bit_off = 8 },
19 		[DPU_CLK_CTRL_DMA1] = { .reg_off = 0x2b4, .bit_off = 8 },
20 		[DPU_CLK_CTRL_DMA2] = { .reg_off = 0x2bc, .bit_off = 8 },
21 	},
22 };
23 
24 static const struct dpu_sspp_cfg sdm670_sspp[] = {
25 	{
26 		.name = "sspp_0", .id = SSPP_VIG0,
27 		.base = 0x4000, .len = 0x1c8,
28 		.features = VIG_SDM845_MASK_SDMA,
29 		.sblk = &dpu_vig_sblk_qseed3_1_3,
30 		.xin_id = 0,
31 		.type = SSPP_TYPE_VIG,
32 		.clk_ctrl = DPU_CLK_CTRL_VIG0,
33 	}, {
34 		.name = "sspp_1", .id = SSPP_VIG1,
35 		.base = 0x6000, .len = 0x1c8,
36 		.features = VIG_SDM845_MASK_SDMA,
37 		.sblk = &dpu_vig_sblk_qseed3_1_3,
38 		.xin_id = 4,
39 		.type = SSPP_TYPE_VIG,
40 		.clk_ctrl = DPU_CLK_CTRL_VIG0,
41 	}, {
42 		.name = "sspp_8", .id = SSPP_DMA0,
43 		.base = 0x24000, .len = 0x1c8,
44 		.features = DMA_SDM845_MASK_SDMA,
45 		.sblk = &dpu_dma_sblk,
46 		.xin_id = 1,
47 		.type = SSPP_TYPE_DMA,
48 		.clk_ctrl = DPU_CLK_CTRL_DMA0,
49 	}, {
50 		.name = "sspp_9", .id = SSPP_DMA1,
51 		.base = 0x26000, .len = 0x1c8,
52 		.features = DMA_CURSOR_SDM845_MASK_SDMA,
53 		.sblk = &dpu_dma_sblk,
54 		.xin_id = 5,
55 		.type = SSPP_TYPE_DMA,
56 		.clk_ctrl = DPU_CLK_CTRL_DMA1,
57 	}, {
58 		.name = "sspp_10", .id = SSPP_DMA2,
59 		.base = 0x28000, .len = 0x1c8,
60 		.features = DMA_CURSOR_SDM845_MASK_SDMA,
61 		.sblk = &dpu_dma_sblk,
62 		.xin_id = 9,
63 		.type = SSPP_TYPE_DMA,
64 		.clk_ctrl = DPU_CLK_CTRL_DMA2,
65 	},
66 };
67 
68 static const struct dpu_lm_cfg sdm670_lm[] = {
69 	{
70 		.name = "lm_0", .id = LM_0,
71 		.base = 0x44000, .len = 0x320,
72 		.features = MIXER_SDM845_MASK,
73 		.sblk = &sdm845_lm_sblk,
74 		.lm_pair = LM_1,
75 		.pingpong = PINGPONG_0,
76 		.dspp = DSPP_0,
77 	}, {
78 		.name = "lm_1", .id = LM_1,
79 		.base = 0x45000, .len = 0x320,
80 		.features = MIXER_SDM845_MASK,
81 		.sblk = &sdm845_lm_sblk,
82 		.lm_pair = LM_0,
83 		.pingpong = PINGPONG_1,
84 		.dspp = DSPP_1,
85 	}, {
86 		.name = "lm_2", .id = LM_2,
87 		.base = 0x46000, .len = 0x320,
88 		.features = MIXER_SDM845_MASK,
89 		.sblk = &sdm845_lm_sblk,
90 		.lm_pair = LM_5,
91 		.pingpong = PINGPONG_2,
92 	}, {
93 		.name = "lm_5", .id = LM_5,
94 		.base = 0x49000, .len = 0x320,
95 		.features = MIXER_SDM845_MASK,
96 		.sblk = &sdm845_lm_sblk,
97 		.lm_pair = LM_2,
98 		.pingpong = PINGPONG_3,
99 	},
100 };
101 
102 static const struct dpu_dspp_cfg sdm670_dspp[] = {
103 	{
104 		.name = "dspp_0", .id = DSPP_0,
105 		.base = 0x54000, .len = 0x1800,
106 		.features = DSPP_SC7180_MASK,
107 		.sblk = &sdm845_dspp_sblk,
108 	}, {
109 		.name = "dspp_1", .id = DSPP_1,
110 		.base = 0x56000, .len = 0x1800,
111 		.features = DSPP_SC7180_MASK,
112 		.sblk = &sdm845_dspp_sblk,
113 	},
114 };
115 
116 static const struct dpu_dsc_cfg sdm670_dsc[] = {
117 	{
118 		.name = "dsc_0", .id = DSC_0,
119 		.base = 0x80000, .len = 0x140,
120 	}, {
121 		.name = "dsc_1", .id = DSC_1,
122 		.base = 0x80400, .len = 0x140,
123 	},
124 };
125 
126 static const struct dpu_mdss_version sdm670_mdss_ver = {
127 	.core_major_ver = 4,
128 	.core_minor_ver = 1,
129 };
130 
131 const struct dpu_mdss_cfg dpu_sdm670_cfg = {
132 	.mdss_ver = &sdm670_mdss_ver,
133 	.caps = &sdm845_dpu_caps,
134 	.mdp = &sdm670_mdp,
135 	.ctl_count = ARRAY_SIZE(sdm845_ctl),
136 	.ctl = sdm845_ctl,
137 	.sspp_count = ARRAY_SIZE(sdm670_sspp),
138 	.sspp = sdm670_sspp,
139 	.mixer_count = ARRAY_SIZE(sdm670_lm),
140 	.mixer = sdm670_lm,
141 	.dspp_count = ARRAY_SIZE(sdm670_dspp),
142 	.dspp = sdm670_dspp,
143 	.pingpong_count = ARRAY_SIZE(sdm845_pp),
144 	.pingpong = sdm845_pp,
145 	.dsc_count = ARRAY_SIZE(sdm670_dsc),
146 	.dsc = sdm670_dsc,
147 	.intf_count = ARRAY_SIZE(sdm845_intf),
148 	.intf = sdm845_intf,
149 	.vbif_count = ARRAY_SIZE(sdm845_vbif),
150 	.vbif = sdm845_vbif,
151 	.perf = &sdm845_perf_data,
152 };
153 
154 #endif
155