summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/display/dc/resource/dcn42/dcn42_resource.h
blob: 60acf0e423d97ea2bc41f3ebaccafef88094ec50 (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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
/* SPDX-License-Identifier: MIT */
/*
 * Copyright 2026 Advanced Micro Devices, Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 *
 * Authors: AMD
 *
 */

#ifndef _DCN42_RESOURCE_H_
#define _DCN42_RESOURCE_H_

#include "core_types.h"

#define TO_DCN42_RES_POOL(pool) \
	container_of(pool, struct dcn42_resource_pool, base)

/* DPP */
#define DPP_REG_LIST_DCN42_COMMON_RI(id)                                        \
	SRI_ARR(CM_DEALPHA, CM, id), SRI_ARR(CM_MEM_PWR_STATUS, CM, id),            \
		SRI_ARR(CM_BIAS_CR_R, CM, id), SRI_ARR(CM_BIAS_Y_G_CB_B, CM, id),       \
		SRI_ARR(PRE_DEGAM, CNVC_CFG, id), SRI_ARR(CM_GAMCOR_CONTROL, CM, id),   \
		SRI_ARR(CM_GAMCOR_LUT_CONTROL, CM, id),                                 \
		SRI_ARR(CM_GAMCOR_LUT_INDEX, CM, id),                                   \
		SRI_ARR(CM_GAMCOR_LUT_INDEX, CM, id),                                   \
		SRI_ARR(CM_GAMCOR_LUT_DATA, CM, id),                                    \
		SRI_ARR(CM_GAMCOR_RAMB_START_CNTL_B, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMB_START_CNTL_G, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMB_START_CNTL_R, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMB_START_SLOPE_CNTL_B, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMB_START_SLOPE_CNTL_G, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMB_START_SLOPE_CNTL_R, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL1_B, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL2_B, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL1_G, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL2_G, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL1_R, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_END_CNTL2_R, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMB_REGION_0_1, CM, id),                             \
		SRI_ARR(CM_GAMCOR_RAMB_REGION_32_33, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMB_OFFSET_B, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMB_OFFSET_G, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMB_OFFSET_R, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMB_START_BASE_CNTL_B, CM, id),                      \
		SRI_ARR(CM_GAMCOR_RAMB_START_BASE_CNTL_G, CM, id),                      \
		SRI_ARR(CM_GAMCOR_RAMB_START_BASE_CNTL_R, CM, id),                      \
		SRI_ARR(CM_GAMCOR_RAMA_START_CNTL_B, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMA_START_CNTL_G, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMA_START_CNTL_R, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMA_START_SLOPE_CNTL_B, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMA_START_SLOPE_CNTL_G, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMA_START_SLOPE_CNTL_R, CM, id),                     \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL1_B, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL2_B, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL1_G, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL2_G, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL1_R, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_END_CNTL2_R, CM, id),                            \
		SRI_ARR(CM_GAMCOR_RAMA_REGION_0_1, CM, id),                             \
		SRI_ARR(CM_GAMCOR_RAMA_REGION_32_33, CM, id),                           \
		SRI_ARR(CM_GAMCOR_RAMA_OFFSET_B, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMA_OFFSET_G, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMA_OFFSET_R, CM, id),                               \
		SRI_ARR(CM_GAMCOR_RAMA_START_BASE_CNTL_B, CM, id),                      \
		SRI_ARR(CM_GAMCOR_RAMA_START_BASE_CNTL_G, CM, id),                      \
		SRI_ARR(CM_GAMCOR_RAMA_START_BASE_CNTL_R, CM, id),                      \
		SRI_ARR(CM_HIST_CNTL, CM, id),                                          \
		SRI_ARR(CM_HIST_LOCK, CM, id),                                          \
		SRI_ARR(CM_HIST_INDEX, CM, id),                                         \
		SRI_ARR(CM_HIST_DATA, CM, id),                                          \
		SRI_ARR(CM_HIST_STATUS, CM, id),                                        \
		SRI_ARR(CM_HIST_SCALE_SRC1, CM, id),                                    \
		SRI_ARR(CM_HIST_COEFA_SRC2, CM, id),                                    \
		SRI_ARR(CM_HIST_COEFB_SRC2, CM, id),                                    \
		SRI_ARR(CM_HIST_COEFC_SRC2, CM, id),                                    \
		SRI_ARR(CM_HIST_SCALE_SRC3, CM, id),                                    \
		SRI_ARR(CM_HIST_BIAS_SRC1, CM, id),                                     \
		SRI_ARR(CM_HIST_BIAS_SRC2, CM, id),                                     \
		SRI_ARR(CM_HIST_BIAS_SRC3, CM, id),                                     \
		SRI_ARR(DSCL_EXT_OVERSCAN_LEFT_RIGHT, DSCL, id),                        \
		SRI_ARR(DSCL_EXT_OVERSCAN_TOP_BOTTOM, DSCL, id),                        \
		SRI_ARR(OTG_H_BLANK, DSCL, id), SRI_ARR(OTG_V_BLANK, DSCL, id),         \
		SRI_ARR(SCL_MODE, DSCL, id), SRI_ARR(LB_DATA_FORMAT, DSCL, id),         \
		SRI_ARR(LB_MEMORY_CTRL, DSCL, id), SRI_ARR(DSCL_AUTOCAL, DSCL, id),     \
		SRI_ARR(SCL_TAP_CONTROL, DSCL, id),                                     \
		SRI_ARR(SCL_COEF_RAM_TAP_SELECT, DSCL, id),                             \
		SRI_ARR(SCL_COEF_RAM_TAP_DATA, DSCL, id),                               \
		SRI_ARR(DSCL_2TAP_CONTROL, DSCL, id), SRI_ARR(MPC_SIZE, DSCL, id),      \
		SRI_ARR(SCL_HORZ_FILTER_SCALE_RATIO, DSCL, id),                         \
		SRI_ARR(SCL_VERT_FILTER_SCALE_RATIO, DSCL, id),                         \
		SRI_ARR(SCL_HORZ_FILTER_SCALE_RATIO_C, DSCL, id),                       \
		SRI_ARR(SCL_VERT_FILTER_SCALE_RATIO_C, DSCL, id),                       \
		SRI_ARR(SCL_HORZ_FILTER_INIT, DSCL, id),                                \
		SRI_ARR(SCL_HORZ_FILTER_INIT_C, DSCL, id),                              \
		SRI_ARR(SCL_VERT_FILTER_INIT, DSCL, id),                                \
		SRI_ARR(SCL_VERT_FILTER_INIT_C, DSCL, id),                              \
		SRI_ARR(RECOUT_START, DSCL, id), SRI_ARR(RECOUT_SIZE, DSCL, id),        \
		SRI_ARR(PRE_DEALPHA, CNVC_CFG, id), SRI_ARR(PRE_REALPHA, CNVC_CFG, id), \
		SRI_ARR(PRE_CSC_MODE, CNVC_CFG, id),                                    \
		SRI_ARR(PRE_CSC_C11_C12, CNVC_CFG, id),                                 \
		SRI_ARR(PRE_CSC_C33_C34, CNVC_CFG, id),                                 \
		SRI_ARR(PRE_CSC_B_C11_C12, CNVC_CFG, id),                               \
		SRI_ARR(PRE_CSC_B_C33_C34, CNVC_CFG, id),                               \
		SRI_ARR(CM_POST_CSC_CONTROL, CM, id),                                   \
		SRI_ARR(CM_POST_CSC_C11_C12, CM, id),                                   \
		SRI_ARR(CM_POST_CSC_C33_C34, CM, id),                                   \
		SRI_ARR(CM_POST_CSC_B_C11_C12, CM, id),                                 \
		SRI_ARR(CM_POST_CSC_B_C33_C34, CM, id),                                 \
		SRI_ARR(CM_MEM_PWR_CTRL, CM, id), SRI_ARR(CM_CONTROL, CM, id),          \
		SRI_ARR(CM_TEST_DEBUG_INDEX, CM, id),                                   \
		SRI_ARR(CM_TEST_DEBUG_DATA, CM, id),                                    \
		SRI_ARR(FORMAT_CONTROL, CNVC_CFG, id),                                  \
		SRI_ARR(CNVC_SURFACE_PIXEL_FORMAT, CNVC_CFG, id),                       \
		SRI_ARR(CURSOR0_CONTROL, CM_CUR, id),                                   \
		SRI_ARR(CURSOR0_COLOR0, CM_CUR, id),                                    \
		SRI_ARR(CURSOR0_COLOR1, CM_CUR, id),                                    \
		SRI_ARR(CURSOR0_FP_SCALE_BIAS_G_Y, CM_CUR, id),                         \
		SRI_ARR(CURSOR0_FP_SCALE_BIAS_RB_CRCB, CM_CUR, id),                     \
		SRI_ARR(CUR0_MATRIX_MODE, CM_CUR, id),                                  \
		SRI_ARR(CUR0_MATRIX_C11_C12_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C13_C14_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C21_C22_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C23_C24_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C31_C32_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C33_C34_A, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C11_C12_B, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C13_C14_B, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C21_C22_B, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C23_C24_B, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C31_C32_B, CM_CUR, id),                             \
		SRI_ARR(CUR0_MATRIX_C33_C34_B, CM_CUR, id),                             \
		SRI_ARR(DPP_CONTROL, DPP_TOP, id), SRI_ARR(CM_HDR_MULT_COEF, CM, id),   \
		SRI_ARR(CURSOR_CONTROL, CURSOR0_, id),                                  \
		SRI_ARR(ALPHA_2BIT_LUT01, CNVC_CFG, id),                                \
		SRI_ARR(ALPHA_2BIT_LUT23, CNVC_CFG, id),                                \
		SRI_ARR(FCNV_FP_BIAS_R, CNVC_CFG, id),                                  \
		SRI_ARR(FCNV_FP_BIAS_G, CNVC_CFG, id),                                  \
		SRI_ARR(FCNV_FP_BIAS_B, CNVC_CFG, id),                                  \
		SRI_ARR(FCNV_FP_SCALE_R, CNVC_CFG, id),                                 \
		SRI_ARR(FCNV_FP_SCALE_G, CNVC_CFG, id),                                 \
		SRI_ARR(FCNV_FP_SCALE_B, CNVC_CFG, id),                                 \
		SRI_ARR(COLOR_KEYER_CONTROL, CNVC_CFG, id),                             \
		SRI_ARR(COLOR_KEYER_ALPHA, CNVC_CFG, id),                               \
		SRI_ARR(COLOR_KEYER_RED, CNVC_CFG, id),                                 \
		SRI_ARR(COLOR_KEYER_GREEN, CNVC_CFG, id),                               \
		SRI_ARR(COLOR_KEYER_BLUE, CNVC_CFG, id),                                \
		SRI_ARR(OBUF_MEM_PWR_CTRL, DSCL, id),                                   \
		SRI_ARR(DSCL_MEM_PWR_STATUS, DSCL, id),                                 \
		SRI_ARR(DSCL_MEM_PWR_CTRL, DSCL, id),                                   \
		SRI_ARR(DSCL_CONTROL, DSCL, id),                                        \
		SRI_ARR(DSCL_SC_MODE, DSCL, id),                                        \
		SRI_ARR(DSCL_EASF_H_MODE, DSCL, id),                                    \
		SRI_ARR(DSCL_EASF_H_BF_CNTL, DSCL, id),                                 \
		SRI_ARR(DSCL_EASF_H_RINGEST_EVENTAP_REDUCE, DSCL, id),                  \
		SRI_ARR(DSCL_EASF_H_RINGEST_EVENTAP_GAIN, DSCL, id),                    \
		SRI_ARR(DSCL_EASF_H_BF_FINAL_MAX_MIN, DSCL, id),                        \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG0, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG1, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG2, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG3, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG4, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG5, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG6, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF1_PWL_SEG7, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG0, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG1, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG2, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG3, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG4, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_H_BF3_PWL_SEG5, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_MODE, DSCL, id),                                    \
		SRI_ARR(DSCL_EASF_V_BF_CNTL, DSCL, id),                                 \
		SRI_ARR(DSCL_EASF_V_RINGEST_3TAP_CNTL1, DSCL, id),                      \
		SRI_ARR(DSCL_EASF_V_RINGEST_3TAP_CNTL2, DSCL, id),                      \
		SRI_ARR(DSCL_EASF_V_RINGEST_3TAP_CNTL3, DSCL, id),                      \
		SRI_ARR(DSCL_EASF_V_RINGEST_EVENTAP_REDUCE, DSCL, id),                  \
		SRI_ARR(DSCL_EASF_V_RINGEST_EVENTAP_GAIN, DSCL, id),                    \
		SRI_ARR(DSCL_EASF_V_BF_FINAL_MAX_MIN, DSCL, id),                        \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG0, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG1, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG2, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG3, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG4, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG5, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG6, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF1_PWL_SEG7, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG0, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG1, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG2, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG3, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG4, DSCL, id),                            \
		SRI_ARR(DSCL_EASF_V_BF3_PWL_SEG5, DSCL, id),                            \
		SRI_ARR(DSCL_SC_MATRIX_C0C1, DSCL, id),                                 \
		SRI_ARR(DSCL_SC_MATRIX_C2C3, DSCL, id),                                 \
		SRI_ARR(ISHARP_MODE, DSCL, id),                                         \
		SRI_ARR(ISHARP_DELTA_LUT_MEM_PWR_CTRL, DSCL, id),                       \
		SRI_ARR(ISHARP_NOISEDET_THRESHOLD, DSCL, id),                           \
		SRI_ARR(ISHARP_NOISE_GAIN_PWL, DSCL, id),                               \
		SRI_ARR(ISHARP_LBA_PWL_SEG0, DSCL, id),                                 \
		SRI_ARR(ISHARP_LBA_PWL_SEG1, DSCL, id),                                 \
		SRI_ARR(ISHARP_LBA_PWL_SEG2, DSCL, id),                                 \
		SRI_ARR(ISHARP_LBA_PWL_SEG3, DSCL, id),                                 \
		SRI_ARR(ISHARP_LBA_PWL_SEG4, DSCL, id),                                 \
		SRI_ARR(ISHARP_LBA_PWL_SEG5, DSCL, id),                                 \
		SRI_ARR(ISHARP_DELTA_CTRL, DSCL, id),                                   \
		SRI_ARR(ISHARP_DELTA_DATA, DSCL, id),                                   \
		SRI_ARR(ISHARP_DELTA_INDEX, DSCL, id),                                  \
		SRI_ARR(ISHARP_NLDELTA_SOFT_CLIP, DSCL, id),                            \
		SRI_ARR(SCL_VERT_FILTER_INIT_BOT, DSCL, id),                            \
		SRI_ARR(SCL_VERT_FILTER_INIT_BOT_C, DSCL, id)

/* Stream encoder */
#define SE_DCN42_REG_LIST_RI(id)                                                \
	SRI_ARR(HDMI_CONTROL, DIG, id), SRI_ARR(HDMI_DB_CONTROL, DIG, id),          \
		SRI_ARR(HDMI_GC, DIG, id),                                              \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL0, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL1, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL2, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL3, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL4, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL5, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL6, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL7, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL8, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL9, DIG, id),                         \
		SRI_ARR(HDMI_GENERIC_PACKET_CONTROL10, DIG, id),                        \
		SRI_ARR(HDMI_INFOFRAME_CONTROL0, DIG, id),                              \
		SRI_ARR(HDMI_VBI_PACKET_CONTROL, DIG, id),                              \
		SRI_ARR(HDMI_AUDIO_PACKET_CONTROL, DIG, id),                            \
		SRI_ARR(HDMI_ACR_PACKET_CONTROL, DIG, id),                              \
		SRI_ARR(HDMI_ACR_32_0, DIG, id), SRI_ARR(HDMI_ACR_32_1, DIG, id),       \
		SRI_ARR(HDMI_ACR_44_0, DIG, id), SRI_ARR(HDMI_ACR_44_1, DIG, id),       \
		SRI_ARR(HDMI_ACR_48_0, DIG, id), SRI_ARR(HDMI_ACR_48_1, DIG, id),       \
		SRI_ARR(DP_DB_CNTL, DP, id), SRI_ARR(DP_MSA_MISC, DP, id),              \
		SRI_ARR(DP_MSA_VBID_MISC, DP, id), SRI_ARR(DP_MSA_COLORIMETRY, DP, id), \
		SRI_ARR(DP_MSA_TIMING_PARAM1, DP, id),                                  \
		SRI_ARR(DP_MSA_TIMING_PARAM2, DP, id),                                  \
		SRI_ARR(DP_MSA_TIMING_PARAM3, DP, id),                                  \
		SRI_ARR(DP_MSA_TIMING_PARAM4, DP, id),                                  \
		SRI_ARR(DP_MSE_RATE_CNTL, DP, id), SRI_ARR(DP_MSE_RATE_UPDATE, DP, id), \
		SRI_ARR(DP_PIXEL_FORMAT, DP, id), SRI_ARR(DP_SEC_CNTL, DP, id),         \
		SRI_ARR(DP_SEC_CNTL1, DP, id), SRI_ARR(DP_SEC_CNTL2, DP, id),           \
		SRI_ARR(DP_SEC_CNTL5, DP, id), SRI_ARR(DP_SEC_CNTL6, DP, id),           \
		SRI_ARR(DP_STEER_FIFO, DP, id), SRI_ARR(DP_VID_M, DP, id),              \
		SRI_ARR(DP_VID_N, DP, id), SRI_ARR(DP_VID_STREAM_CNTL, DP, id),         \
		SRI_ARR(DP_VID_TIMING, DP, id), SRI_ARR(DP_SEC_AUD_N, DP, id),          \
		SRI_ARR(DP_SEC_TIMESTAMP, DP, id),                                      \
		SRI_ARR(DP_SEC_METADATA_TRANSMISSION, DP, id),                          \
		SRI_ARR(HDMI_METADATA_PACKET_CONTROL, DIG, id),                         \
		SRI_ARR(DP_SEC_FRAMING4, DP, id), SRI_ARR(DP_GSP11_CNTL, DP, id),       \
		SRI_ARR(DME_CONTROL, DME, id),                                          \
		SRI_ARR(DP_SEC_METADATA_TRANSMISSION, DP, id),                          \
		SRI_ARR(HDMI_METADATA_PACKET_CONTROL, DIG, id),                         \
		SRI_ARR(DIG_FE_CNTL, DIG, id),                                          \
		SRI_ARR(DIG_FE_EN_CNTL, DIG, id),                                       \
		SRI_ARR(DIG_FE_CLK_CNTL, DIG, id),                                      \
		SRI_ARR(DIG_CLOCK_PATTERN, DIG, id),                                    \
		SRI_ARR(DIG_FIFO_CTRL0, DIG, id),                                       \
		SRI_ARR(STREAM_MAPPER_CONTROL, DIG, id),\
		SRI_ARR(DIG_FE_AUDIO_CNTL, DIG, id)

/* HPO DP stream encoder */
#define DCN42_HPO_DP_STREAM_ENC_REG_LIST_RI(id)                                             \
	SR_ARR(DP_STREAM_MAPPER_CONTROL0, id),                                                  \
		SR_ARR(DP_STREAM_MAPPER_CONTROL1, id),                                              \
		SR_ARR(DP_STREAM_MAPPER_CONTROL2, id),                                              \
		SR_ARR(DP_STREAM_MAPPER_CONTROL3, id),                                              \
		SRI_ARR(DP_STREAM_ENC_CLOCK_CONTROL, DP_STREAM_ENC, id),                            \
		SRI_ARR(DP_STREAM_ENC_INPUT_MUX_CONTROL, DP_STREAM_ENC, id),                        \
		SRI_ARR(DP_STREAM_ENC_AUDIO_CONTROL, DP_STREAM_ENC, id),                            \
		SRI_ARR(DP_STREAM_ENC_CLOCK_RAMP_ADJUSTER_FIFO_STATUS_CONTROL0, DP_STREAM_ENC, id), \
		SRI_ARR(DP_SYM32_ENC_CONTROL, DP_SYM32_ENC, id),                                    \
		SRI_ARR(DP_SYM32_ENC_VID_PIXEL_FORMAT, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_VID_PIXEL_FORMAT_DOUBLE_BUFFER_CONTROL, DP_SYM32_ENC, id),     \
		SRI_ARR(DP_SYM32_ENC_VID_MSA0, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA1, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA2, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA3, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA4, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA5, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA6, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA7, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA8, DP_SYM32_ENC, id),                                   \
		SRI_ARR(DP_SYM32_ENC_VID_MSA_CONTROL, DP_SYM32_ENC, id),                            \
		SRI_ARR(DP_SYM32_ENC_VID_MSA_DOUBLE_BUFFER_CONTROL, DP_SYM32_ENC, id),              \
		SRI_ARR(DP_SYM32_ENC_VID_FIFO_CONTROL, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_VID_STREAM_CONTROL, DP_SYM32_ENC, id),                         \
		SRI_ARR(DP_SYM32_ENC_VID_VBID_CONTROL, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_SDP_CONTROL, DP_SYM32_ENC, id),                                \
		SRI_ARR(DP_SYM32_ENC_SDP_GSP_CONTROL0, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_SDP_GSP_CONTROL2, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_SDP_GSP_CONTROL3, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_SDP_GSP_CONTROL5, DP_SYM32_ENC, id),                           \
		SRI_ARR(DP_SYM32_ENC_SDP_GSP_CONTROL11, DP_SYM32_ENC, id),                          \
		SRI_ARR(DP_SYM32_ENC_SDP_METADATA_PACKET_CONTROL, DP_SYM32_ENC, id),                \
		SRI_ARR(DP_SYM32_ENC_SDP_AUDIO_CONTROL0, DP_SYM32_ENC, id),                         \
		SRI_ARR(DP_SYM32_ENC_VID_CRC_CONTROL, DP_SYM32_ENC, id),                            \
		SRI_ARR(DP_SYM32_ENC_HBLANK_CONTROL, DP_SYM32_ENC, id)

/*HPO DP link encoder regs */
#define DCN42_HPO_DP_LINK_ENC_REG_LIST_RI(id)                    \
	SRI_ARR(DP_LINK_ENC_CLOCK_CONTROL, DP_LINK_ENC, id),         \
		SRI_ARR(DP_DPHY_SYM32_CONTROL, DP_DPHY_SYM32, id),       \
		SRI_ARR(DP_DPHY_SYM32_STATUS, DP_DPHY_SYM32, id),        \
		SRI_ARR(DP_DPHY_SYM32_TP_CONFIG, DP_DPHY_SYM32, id),     \
		SRI_ARR(DP_DPHY_SYM32_TP_PRBS_SEED0, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_TP_PRBS_SEED1, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_TP_PRBS_SEED2, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_TP_PRBS_SEED3, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_TP_SQ_PULSE, DP_DPHY_SYM32, id),   \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM0, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM1, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM2, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM3, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM4, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM5, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM6, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM7, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM8, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM9, DP_DPHY_SYM32, id),    \
		SRI_ARR(DP_DPHY_SYM32_TP_CUSTOM10, DP_DPHY_SYM32, id),   \
		SRI_ARR(DP_DPHY_SYM32_SAT_VC0, DP_DPHY_SYM32, id),       \
		SRI_ARR(DP_DPHY_SYM32_SAT_VC1, DP_DPHY_SYM32, id),       \
		SRI_ARR(DP_DPHY_SYM32_SAT_VC2, DP_DPHY_SYM32, id),       \
		SRI_ARR(DP_DPHY_SYM32_SAT_VC3, DP_DPHY_SYM32, id),       \
		SRI_ARR(DP_DPHY_SYM32_VC_RATE_CNTL0, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_VC_RATE_CNTL1, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_VC_RATE_CNTL2, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_VC_RATE_CNTL3, DP_DPHY_SYM32, id), \
		SRI_ARR(DP_DPHY_SYM32_SAT_UPDATE, DP_DPHY_SYM32, id)

#define VPG_DCN42_REG_LIST_RI(id) \
	SRI(VPG_GENERIC_STATUS, VPG, id), \
	SRI(VPG_GENERIC_PACKET_ACCESS_CTRL, VPG, id), \
	SRI(VPG_GENERIC_PACKET_DATA, VPG, id), \
	SRI(VPG_GSP_FRAME_UPDATE_CTRL, VPG, id), \
	SRI(VPG_GSP_IMMEDIATE_UPDATE_CTRL, VPG, id), \
	SRI(VPG_MEM_PWR, VPG, id)

/* DCCG */
#define DCCG_REG_LIST_DCN42_RI()               \
	SR(DPPCLK_DTO_CTRL),                       \
	DCCG_SRII(DTO_PARAM, DPPCLK, 0),       \
	DCCG_SRII(DTO_PARAM, DPPCLK, 1),       \
	DCCG_SRII(DTO_PARAM, DPPCLK, 2),       \
	DCCG_SRII(DTO_PARAM, DPPCLK, 3),       \
	DCCG_SRII(CLOCK_CNTL, HDMICHARCLK, 0), \
	SR(HDMISTREAMCLK0_DTO_PARAM),\
	SR(DCCG_GLOBAL_FGCG_REP_CNTL),\
	SR(DISPCLK_FREQ_CHANGE_CNTL), \
	SR(PHYASYMCLK_CLOCK_CNTL),  \
	SR(PHYBSYMCLK_CLOCK_CNTL), \
	SR(PHYCSYMCLK_CLOCK_CNTL), \
	SR(PHYDSYMCLK_CLOCK_CNTL), \
	SR(PHYESYMCLK_CLOCK_CNTL), \
	SR(DPSTREAMCLK_CNTL), \
	SR(HDMISTREAMCLK_CNTL), \
	SR(SYMCLK32_SE_CNTL), \
	SR(SYMCLK32_LE_CNTL), \
	DCCG_SRII(PIXEL_RATE_CNTL, OTG, 0), \
	DCCG_SRII(PIXEL_RATE_CNTL, OTG, 1), \
	DCCG_SRII(PIXEL_RATE_CNTL, OTG, 2), \
	DCCG_SRII(PIXEL_RATE_CNTL, OTG, 3), \
	SR(OTG_PIXEL_RATE_DIV), \
	SR(DTBCLK_P_CNTL), \
	SR(DCCG_AUDIO_DTO_SOURCE), \
	SR(DENTIST_DISPCLK_CNTL), \
	SR(DPPCLK_CTRL), \
	DCCG_SRII(MODULO, DP_DTO, 0), \
	DCCG_SRII(MODULO, DP_DTO, 1), \
	DCCG_SRII(MODULO, DP_DTO, 2), \
	DCCG_SRII(MODULO, DP_DTO, 3), \
	DCCG_SRII(PHASE, DP_DTO, 0), \
	DCCG_SRII(PHASE, DP_DTO, 1), \
	DCCG_SRII(PHASE, DP_DTO, 2), \
	DCCG_SRII(PHASE, DP_DTO, 3), \
	SR(OTG_ADD_DROP_PIXEL_CNTL), \
	SR(DSCCLK0_DTO_PARAM), \
	SR(DSCCLK1_DTO_PARAM), \
	SR(DSCCLK2_DTO_PARAM), \
	SR(DSCCLK3_DTO_PARAM), \
	SR(DSCCLK_DTO_CTRL), \
	SR(DCCG_GATE_DISABLE_CNTL), \
	SR(DCCG_GATE_DISABLE_CNTL2), \
	SR(DCCG_GATE_DISABLE_CNTL3), \
	SR(DCCG_GATE_DISABLE_CNTL4), \
	SR(DCCG_GATE_DISABLE_CNTL5), \
	SR(DCCG_GATE_DISABLE_CNTL6), \
	SR(SYMCLKA_CLOCK_ENABLE), \
	SR(SYMCLKB_CLOCK_ENABLE), \
	SR(SYMCLKC_CLOCK_ENABLE), \
	SR(SYMCLKD_CLOCK_ENABLE), \
	SR(SYMCLKE_CLOCK_ENABLE)

#define DCN42_AUD_COMMON_MASK_SH_LIST(mask_sh)                                             \
	SF(AZF0ENDPOINT0_AZALIA_F0_CODEC_ENDPOINT_INDEX, AZALIA_ENDPOINT_REG_INDEX, mask_sh),   \
		SF(AZF0ENDPOINT0_AZALIA_F0_CODEC_ENDPOINT_DATA, AZALIA_ENDPOINT_REG_DATA, mask_sh),\
		SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO0_SOURCE_SEL, mask_sh),\
		SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO_SEL, mask_sh),\
		SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO0_USE_512FBR_DTO, mask_sh),\
		SF(DCCG_AUDIO_DTO_SOURCE, DCCG_AUDIO_DTO1_USE_512FBR_DTO, mask_sh),\
		SF(DCCG_AUDIO_DTO0_MODULE, DCCG_AUDIO_DTO0_MODULE, mask_sh),\
		SF(DCCG_AUDIO_DTO0_PHASE, DCCG_AUDIO_DTO0_PHASE, mask_sh),\
		SF(DCCG_AUDIO_DTO1_MODULE, DCCG_AUDIO_DTO1_MODULE, mask_sh),\
		SF(DCCG_AUDIO_DTO1_PHASE, DCCG_AUDIO_DTO1_PHASE, mask_sh),\
		SF(AZALIA_F0_CODEC_FUNCTION_PARAMETER_SUPPORTED_SIZE_RATES, AUDIO_RATE_CAPABILITIES, mask_sh),\
		SF(AZALIA_F0_CODEC_FUNCTION_PARAMETER_POWER_STATES, CLKSTOP, mask_sh),\
		SF(AZALIA_F0_CODEC_FUNCTION_PARAMETER_POWER_STATES, EPSS, mask_sh)

	/* HPO FRL stream encoder */
#define DCN42_HPO_FRL_STREAM_ENC_REG_LIST_RI(id)                                 \
	DCN3_0_HPO_FRL_STREAM_ENC_REG_LIST_RI(id),                               \
	SR_ARR(HDMI_STREAM_ENC_AUDIO_CONTROL, id),\
	SR_ARR(HDMI_TB_ENC_MEM_CTRL, id),\
	SR_ARR(HDMI_FRL_ENC_MEM_CTRL, id)
/* OPTC */
#define OPTC_COMMON_REG_LIST_DCN42_RI(inst)                                      \
		SRI_ARR(OTG_VSTARTUP_PARAM, OTG, inst),                                      \
		SRI_ARR(OTG_VUPDATE_PARAM, OTG, inst),                                   \
		SRI_ARR(OTG_VREADY_PARAM, OTG, inst),                                    \
		SRI_ARR(OTG_MASTER_UPDATE_LOCK, OTG, inst),                              \
		SRI_ARR(OTG_MASTER_UPDATE_MODE, OTG, inst),                              \
		SRI_ARR(OTG_V_COUNT_STOP_CONTROL, OTG, inst),                            \
		SRI_ARR(OTG_V_COUNT_STOP_CONTROL2, OTG, inst),                           \
		SRI_ARR(OTG_GSL_CONTROL, OTG, inst),					 \
		SRI2_ARR(OPTC_CLOCK_CONTROL, OPTC, inst),\
		SRI_ARR(OTG_GLOBAL_CONTROL0, OTG, inst),                                 \
		SRI_ARR(OTG_GLOBAL_CONTROL1, OTG, inst),                                 \
		SRI_ARR(OTG_GLOBAL_CONTROL2, OTG, inst),                                 \
		SRI_ARR(OTG_GLOBAL_CONTROL4, OTG, inst),                                 \
		SRI_ARR(OTG_DOUBLE_BUFFER_CONTROL, OTG, inst),                           \
		SRI_ARR(OTG_H_TOTAL, OTG, inst),                                         \
		SRI_ARR(OTG_H_BLANK_START_END, OTG, inst),                               \
		SRI_ARR(OTG_H_SYNC_A, OTG, inst),\
		SRI_ARR(OTG_H_SYNC_A_CNTL, OTG, inst), \
		SRI_ARR(OTG_H_TIMING_CNTL, OTG, inst), \
		SRI_ARR(OTG_V_TOTAL, OTG, inst),  \
		SRI_ARR(OTG_V_BLANK_START_END, OTG, inst),                               \
		SRI_ARR(OTG_V_SYNC_A, OTG, inst), \
		SRI_ARR(OTG_V_SYNC_A_CNTL, OTG, inst), \
		SRI_ARR(OTG_CONTROL, OTG, inst), \
		SRI_ARR(OTG_STEREO_CONTROL, OTG, inst), \
		SRI_ARR(OTG_3D_STRUCTURE_CONTROL, OTG, inst),                            \
		SRI_ARR(OTG_STEREO_STATUS, OTG, inst),                                   \
		SRI_ARR(OTG_V_TOTAL_MAX, OTG, inst),                                     \
		SRI_ARR(OTG_V_TOTAL_MIN, OTG, inst),                                     \
		SRI_ARR(OTG_V_TOTAL_CONTROL, OTG, inst),                                 \
		SRI_ARR(OTG_TRIGA_CNTL, OTG, inst),                                      \
		SRI_ARR(OTG_FORCE_COUNT_NOW_CNTL, OTG, inst),                            \
		SRI_ARR(OTG_STATIC_SCREEN_CONTROL, OTG, inst),                           \
		SRI_ARR(OTG_STATUS_FRAME_COUNT, OTG, inst),                              \
		SRI_ARR(OTG_STATUS, OTG, inst), 										\
		SRI_ARR(OTG_STATUS_POSITION, OTG, inst), \
		SRI_ARR(OTG_NOM_VERT_POSITION, OTG, inst),                               \
		SRI_ARR(OTG_M_CONST_DTO0, OTG, inst),                                    \
		SRI_ARR(OTG_M_CONST_DTO1, OTG, inst),                                    \
		SRI_ARR(OTG_CLOCK_CONTROL, OTG, inst),                                   \
		SRI_ARR(OTG_VERTICAL_INTERRUPT0_CONTROL, OTG, inst),                     \
		SRI_ARR(OTG_VERTICAL_INTERRUPT0_POSITION, OTG, inst),                    \
		SRI_ARR(OTG_VERTICAL_INTERRUPT1_CONTROL, OTG, inst),                     \
		SRI_ARR(OTG_VERTICAL_INTERRUPT1_POSITION, OTG, inst),                    \
		SRI_ARR(OTG_VERTICAL_INTERRUPT2_CONTROL, OTG, inst),                     \
		SRI_ARR(OTG_VERTICAL_INTERRUPT2_POSITION, OTG, inst),                    \
		SRI_ARR(OPTC_INPUT_CLOCK_CONTROL, ODM, inst),                            \
		SRI_ARR(OPTC_DATA_SOURCE_SELECT, ODM, inst),                             \
		SRI_ARR(OPTC_INPUT_GLOBAL_CONTROL, ODM, inst),                           \
		SRI_ARR(OPTC_RSMU_UNDERFLOW, ODM, inst),                                 \
		SRI_ARR(OPTC_UNDERFLOW_THRESHOLD, ODM, inst),                            \
		SRI_ARR(CONTROL, VTG, inst), \
		SRI_ARR(OTG_VERT_SYNC_CONTROL, OTG, inst),  \
		SRI_ARR(OTG_GSL_CONTROL, OTG, inst), \
		SRI_ARR(OTG_CRC_CNTL, OTG, inst),   \
		SRI_ARR(OTG_CRC0_DATA_R, OTG, inst),                                     \
		SRI_ARR(OTG_CRC0_DATA_G, OTG, inst),                                     \
		SRI_ARR(OTG_CRC0_DATA_B, OTG, inst),                                     \
		SRI_ARR(OTG_CRC1_DATA_R, OTG, inst),                                     \
		SRI_ARR(OTG_CRC1_DATA_G, OTG, inst),                                     \
		SRI_ARR(OTG_CRC1_DATA_B, OTG, inst),                                     \
		SRI_ARR(OTG_CRC0_WINDOWA_X_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC0_WINDOWA_Y_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC0_WINDOWB_X_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC0_WINDOWB_Y_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC1_WINDOWA_X_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC1_WINDOWA_Y_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC1_WINDOWB_X_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC1_WINDOWB_Y_CONTROL, OTG, inst),                          \
		SRI_ARR(OTG_CRC0_WINDOWA_X_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC0_WINDOWA_Y_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC0_WINDOWB_X_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC0_WINDOWB_Y_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC1_WINDOWA_X_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC1_WINDOWA_Y_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC1_WINDOWB_X_CONTROL_READBACK, OTG, inst),\
		SRI_ARR(OTG_CRC1_WINDOWB_Y_CONTROL_READBACK, OTG, inst),\
		SR_ARR(GSL_SOURCE_SELECT, inst),                                         \
		SRI_ARR(OTG_TRIGA_MANUAL_TRIG, OTG, inst),                               \
		SRI_ARR(OTG_GLOBAL_CONTROL1, OTG, inst),                                 \
		SRI_ARR(OTG_GLOBAL_CONTROL2, OTG, inst),                                 \
		SRI_ARR(OTG_GSL_WINDOW_X, OTG, inst),                                    \
		SRI_ARR(OTG_GSL_WINDOW_Y, OTG, inst),                                    \
		SRI_ARR(OTG_VUPDATE_KEEPOUT, OTG, inst),                                 \
		SRI_ARR(OTG_DRR_TRIGGER_WINDOW, OTG, inst),                              \
		SRI_ARR(OTG_DRR_V_TOTAL_CHANGE, OTG, inst),                              \
		SRI_ARR(OPTC_DATA_FORMAT_CONTROL, ODM, inst),                            \
		SRI_ARR(OPTC_BYTES_PER_PIXEL, ODM, inst),                                \
		SRI_ARR(OPTC_WIDTH_CONTROL, ODM, inst),                                  \
		SRI_ARR(OPTC_WIDTH_CONTROL2, ODM, inst),                                 \
		SRI_ARR(OPTC_MEMORY_CONFIG, ODM, inst),                                  \
		SRI_ARR(OTG_DRR_CONTROL, OTG, inst),                                     \
		SRI_ARR(OTG_PSTATE_REGISTER, OTG, inst),                                 \
		SRI_ARR(OTG_PWA_FRAME_SYNC_CONTROL, OTG, inst),\
		SRI_ARR(OTG_PIPE_UPDATE_STATUS, OTG, inst),\
		SRI_ARR(INTERRUPT_DEST, OTG, inst)

/* CLK SRC */
#define CS_COMMON_REG_LIST_DCN42_RI(index, pllid)               \
	SRI_ARR_ALPHABET(PIXCLK_RESYNC_CNTL, PHYPLL, index, pllid), \
		SRII_ARR_2(PHASE, DP_DTO, 0, index),                    \
		SRII_ARR_2(PHASE, DP_DTO, 1, index),                    \
		SRII_ARR_2(PHASE, DP_DTO, 2, index),                    \
		SRII_ARR_2(PHASE, DP_DTO, 3, index),                    \
		SRII_ARR_2(MODULO, DP_DTO, 0, index),                   \
		SRII_ARR_2(MODULO, DP_DTO, 1, index),                   \
		SRII_ARR_2(MODULO, DP_DTO, 2, index),                   \
		SRII_ARR_2(MODULO, DP_DTO, 3, index),                   \
		SRII_ARR_2(PIXEL_RATE_CNTL, OTG, 0, index),             \
		SRII_ARR_2(PIXEL_RATE_CNTL, OTG, 1, index),             \
		SRII_ARR_2(PIXEL_RATE_CNTL, OTG, 2, index),             \
		SRII_ARR_2(PIXEL_RATE_CNTL, OTG, 3, index)

/* ABM */
#define ABM_DCN42_REG_LIST_RI(id)                               \
	SRI_ARR(DC_ABM1_HG_SAMPLE_RATE, ABM, id),                   \
		SRI_ARR(DC_ABM1_LS_SAMPLE_RATE, ABM, id),               \
		SRI_ARR(DC_ABM1_HG_MISC_CTRL, ABM, id),                 \
		SRI_ARR(DC_ABM1_IPCSC_COEFF_SEL, ABM, id),              \
		SRI_ARR(BL1_PWM_BL_UPDATE_SAMPLE_RATE, ABM, id),        \
		SRI_ARR(BL1_PWM_CURRENT_ABM_LEVEL, ABM, id),            \
		SRI_ARR(BL1_PWM_TARGET_ABM_LEVEL, ABM, id),             \
		SRI_ARR(BL1_PWM_USER_LEVEL, ABM, id),                   \
		SRI_ARR(DC_ABM1_LS_MIN_MAX_PIXEL_VALUE_THRES, ABM, id), \
		SRI_ARR(DC_ABM1_HGLS_REG_READ_PROGRESS, ABM, id),       \
		SRI_ARR(DC_ABM1_HG_BIN_33_40_SHIFT_INDEX, ABM, id),     \
		SRI_ARR(DC_ABM1_HG_BIN_33_64_SHIFT_FLAG, ABM, id),      \
		SRI_ARR(DC_ABM1_HG_BIN_41_48_SHIFT_INDEX, ABM, id),     \
		SRI_ARR(DC_ABM1_HG_BIN_49_56_SHIFT_INDEX, ABM, id),     \
		SRI_ARR(DC_ABM1_HG_BIN_57_64_SHIFT_INDEX, ABM, id),     \
		SRI_ARR(DC_ABM1_HG_RESULT_DATA, ABM, id),               \
		SRI_ARR(DC_ABM1_HG_RESULT_INDEX, ABM, id),              \
		SRI_ARR(DC_ABM1_ACE_OFFSET_SLOPE_DATA, ABM, id),        \
		SRI_ARR(DC_ABM1_ACE_PWL_CNTL, ABM, id)

/* HUBP */
#define HUBP_REG_LIST_DCN42_RI(id)                                     \
	HUBP_REG_LIST_DCN30_RI(id), SRI_ARR(DCHUBP_MALL_CONFIG, HUBP, id), \
		SRI_ARR(DCHUBP_VMPG_CONFIG, HUBP, id),                         \
		SRI_ARR(UCLK_PSTATE_FORCE, HUBPREQ, id),                       \
		SRI_ARR(HUBP_3DLUT_DLG_PARAM, CURSOR0_, id),                   \
		HUBP_3DLUT_FL_REG_LIST_DCN401(id)
struct dcn42_resource_pool {
	struct resource_pool base;
};
struct resource_pool *dcn42_create_resource_pool(
	const struct dc_init_data *init_data,
	struct dc *dc);

enum dc_status dcn42_validate_bandwidth(struct dc *dc,
							  struct dc_state *context,
							  enum dc_validate_mode validate_mode);

void dcn42_prepare_mcache_programming(struct dc *dc, struct dc_state *context);
int dcn42_get_power_profile(const struct dc_state *context);

#endif /* _DCN42_RESOURCE_H_ */