xref: /openbmc/linux/drivers/gpu/drm/amd/amdgpu/si.c (revision ef9303fd)
1 /*
2  * Copyright 2015 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  */
23 
24 #include <linux/firmware.h>
25 #include <linux/slab.h>
26 #include <linux/module.h>
27 #include <linux/pci.h>
28 
29 #include "amdgpu.h"
30 #include "amdgpu_atombios.h"
31 #include "amdgpu_ih.h"
32 #include "amdgpu_uvd.h"
33 #include "amdgpu_vce.h"
34 #include "atom.h"
35 #include "amd_pcie.h"
36 #include "si_dpm.h"
37 #include "sid.h"
38 #include "si_ih.h"
39 #include "gfx_v6_0.h"
40 #include "gmc_v6_0.h"
41 #include "si_dma.h"
42 #include "dce_v6_0.h"
43 #include "si.h"
44 #include "dce_virtual.h"
45 #include "gca/gfx_6_0_d.h"
46 #include "oss/oss_1_0_d.h"
47 #include "gmc/gmc_6_0_d.h"
48 #include "dce/dce_6_0_d.h"
49 #include "uvd/uvd_4_0_d.h"
50 #include "bif/bif_3_0_d.h"
51 #include "bif/bif_3_0_sh_mask.h"
52 
53 static const u32 tahiti_golden_registers[] =
54 {
55 	mmAZALIA_SCLK_CONTROL, 0x00000030, 0x00000011,
56 	mmCB_HW_CONTROL, 0x00010000, 0x00018208,
57 	mmDB_DEBUG, 0xffffffff, 0x00000000,
58 	mmDB_DEBUG2, 0xf00fffff, 0x00000400,
59 	mmDB_DEBUG3, 0x0002021c, 0x00020200,
60 	mmDCI_CLK_CNTL, 0x00000080, 0x00000000,
61 	0x340c, 0x000000c0, 0x00800040,
62 	0x360c, 0x000000c0, 0x00800040,
63 	mmFBC_DEBUG_COMP, 0x000000f0, 0x00000070,
64 	mmFBC_MISC, 0x00200000, 0x50100000,
65 	mmDIG0_HDMI_CONTROL, 0x31000311, 0x00000011,
66 	mmMC_ARB_WTM_CNTL_RD, 0x00000003, 0x000007ff,
67 	mmMC_XPB_P2P_BAR_CFG, 0x000007ff, 0x00000000,
68 	mmPA_CL_ENHANCE, 0xf000001f, 0x00000007,
69 	mmPA_SC_FORCE_EOV_MAX_CNTS, 0xffffffff, 0x00ffffff,
70 	mmPA_SC_LINE_STIPPLE_STATE, 0x0000ff0f, 0x00000000,
71 	mmPA_SC_MODE_CNTL_1, 0x07ffffff, 0x4e000000,
72 	mmPA_SC_RASTER_CONFIG, 0x3f3f3fff, 0x2a00126a,
73 	0x000c, 0xffffffff, 0x0040,
74 	0x000d, 0x00000040, 0x00004040,
75 	mmSPI_CONFIG_CNTL, 0x07ffffff, 0x03000000,
76 	mmSQ_DED_CNT, 0x01ff1f3f, 0x00000000,
77 	mmSQ_SEC_CNT, 0x01ff1f3f, 0x00000000,
78 	mmSX_DEBUG_1, 0x0000007f, 0x00000020,
79 	mmTA_CNTL_AUX, 0x00010000, 0x00010000,
80 	mmTCP_ADDR_CONFIG, 0x00000200, 0x000002fb,
81 	mmTCP_CHAN_STEER_HI, 0xffffffff, 0x0000543b,
82 	mmTCP_CHAN_STEER_LO, 0xffffffff, 0xa9210876,
83 	mmVGT_FIFO_DEPTHS, 0xffffffff, 0x000fff40,
84 	mmVGT_GS_VERTEX_REUSE, 0x0000001f, 0x00000010,
85 	mmVM_CONTEXT0_CNTL, 0x20000000, 0x20fffed8,
86 	mmVM_L2_CG, 0x000c0fc0, 0x000c0400,
87 	mmVM_PRT_APERTURE0_LOW_ADDR, 0x0fffffff, 0xffffffff,
88 	mmVM_PRT_APERTURE1_LOW_ADDR, 0x0fffffff, 0x0fffffff,
89 	mmVM_PRT_APERTURE2_LOW_ADDR, 0x0fffffff, 0x0fffffff,
90 	mmVM_PRT_APERTURE3_LOW_ADDR, 0x0fffffff, 0x0fffffff,
91 };
92 
93 static const u32 tahiti_golden_registers2[] =
94 {
95 	mmMCIF_MEM_CONTROL, 0x00000001, 0x00000001,
96 };
97 
98 static const u32 tahiti_golden_rlc_registers[] =
99 {
100 	mmGB_ADDR_CONFIG, 0xffffffff, 0x12011003,
101 	mmRLC_LB_PARAMS, 0xffffffff, 0x00601005,
102 	0x311f, 0xffffffff, 0x10104040,
103 	0x3122, 0xffffffff, 0x0100000a,
104 	mmRLC_LB_CNTR_MAX, 0xffffffff, 0x00000800,
105 	mmRLC_LB_CNTL, 0xffffffff, 0x800000f4,
106 	mmUVD_CGC_GATE, 0x00000008, 0x00000000,
107 };
108 
109 static const u32 pitcairn_golden_registers[] =
110 {
111 	mmAZALIA_SCLK_CONTROL, 0x00000030, 0x00000011,
112 	mmCB_HW_CONTROL, 0x00010000, 0x00018208,
113 	mmDB_DEBUG, 0xffffffff, 0x00000000,
114 	mmDB_DEBUG2, 0xf00fffff, 0x00000400,
115 	mmDB_DEBUG3, 0x0002021c, 0x00020200,
116 	mmDCI_CLK_CNTL, 0x00000080, 0x00000000,
117 	0x340c, 0x000300c0, 0x00800040,
118 	0x360c, 0x000300c0, 0x00800040,
119 	mmFBC_DEBUG_COMP, 0x000000f0, 0x00000070,
120 	mmFBC_MISC, 0x00200000, 0x50100000,
121 	mmDIG0_HDMI_CONTROL, 0x31000311, 0x00000011,
122 	mmMC_SEQ_PMG_PG_HWCNTL, 0x00073ffe, 0x000022a2,
123 	mmMC_XPB_P2P_BAR_CFG, 0x000007ff, 0x00000000,
124 	mmPA_CL_ENHANCE, 0xf000001f, 0x00000007,
125 	mmPA_SC_FORCE_EOV_MAX_CNTS, 0xffffffff, 0x00ffffff,
126 	mmPA_SC_LINE_STIPPLE_STATE, 0x0000ff0f, 0x00000000,
127 	mmPA_SC_MODE_CNTL_1, 0x07ffffff, 0x4e000000,
128 	mmPA_SC_RASTER_CONFIG, 0x3f3f3fff, 0x2a00126a,
129 	0x000c, 0xffffffff, 0x0040,
130 	0x000d, 0x00000040, 0x00004040,
131 	mmSPI_CONFIG_CNTL, 0x07ffffff, 0x03000000,
132 	mmSX_DEBUG_1, 0x0000007f, 0x00000020,
133 	mmTA_CNTL_AUX, 0x00010000, 0x00010000,
134 	mmTCP_ADDR_CONFIG, 0x000003ff, 0x000000f7,
135 	mmTCP_CHAN_STEER_HI, 0xffffffff, 0x00000000,
136 	mmTCP_CHAN_STEER_LO, 0xffffffff, 0x32761054,
137 	mmVGT_GS_VERTEX_REUSE, 0x0000001f, 0x00000010,
138 	mmVM_L2_CG, 0x000c0fc0, 0x000c0400,
139 	mmVM_PRT_APERTURE0_LOW_ADDR, 0x0fffffff, 0xffffffff,
140 	mmVM_PRT_APERTURE1_LOW_ADDR, 0x0fffffff, 0x0fffffff,
141 	mmVM_PRT_APERTURE2_LOW_ADDR, 0x0fffffff, 0x0fffffff,
142 	mmVM_PRT_APERTURE3_LOW_ADDR, 0x0fffffff, 0x0fffffff,
143 };
144 
145 static const u32 pitcairn_golden_rlc_registers[] =
146 {
147 	mmGB_ADDR_CONFIG, 0xffffffff, 0x12011003,
148 	mmRLC_LB_PARAMS, 0xffffffff, 0x00601004,
149 	0x311f, 0xffffffff, 0x10102020,
150 	0x3122, 0xffffffff, 0x01000020,
151 	mmRLC_LB_CNTR_MAX, 0xffffffff, 0x00000800,
152 	mmRLC_LB_CNTL, 0xffffffff, 0x800000a4,
153 };
154 
155 static const u32 verde_pg_init[] =
156 {
157 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x40000,
158 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x200010ff,
159 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
160 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
161 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
162 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
163 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
164 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x7007,
165 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x300010ff,
166 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
167 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
168 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
169 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
170 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
171 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x400000,
172 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x100010ff,
173 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
174 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
175 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
176 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
177 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
178 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x120200,
179 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x500010ff,
180 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
181 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
182 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
183 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
184 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
185 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x1e1e16,
186 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x600010ff,
187 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
188 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
189 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
190 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
191 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
192 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x171f1e,
193 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x700010ff,
194 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
195 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
196 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
197 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
198 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
199 	mmGMCON_PGFSM_WRITE, 0xffffffff, 0x0,
200 	mmGMCON_PGFSM_CONFIG, 0xffffffff, 0x9ff,
201 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x0,
202 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x10000800,
203 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xf,
204 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xf,
205 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x4,
206 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1000051e,
207 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xffff,
208 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xffff,
209 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x8,
210 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x80500,
211 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x12,
212 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x9050c,
213 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x1d,
214 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xb052c,
215 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x2a,
216 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1053e,
217 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x2d,
218 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x10546,
219 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x30,
220 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xa054e,
221 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x3c,
222 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1055f,
223 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x3f,
224 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x10567,
225 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x42,
226 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1056f,
227 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x45,
228 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x10572,
229 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x48,
230 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x20575,
231 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x4c,
232 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x190801,
233 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x67,
234 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1082a,
235 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x6a,
236 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1b082d,
237 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x87,
238 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x310851,
239 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xba,
240 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x891,
241 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xbc,
242 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x893,
243 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xbe,
244 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x20895,
245 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xc2,
246 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x20899,
247 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xc6,
248 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x2089d,
249 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xca,
250 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x8a1,
251 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xcc,
252 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x8a3,
253 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xce,
254 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x308a5,
255 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0xd3,
256 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x6d08cd,
257 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x142,
258 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x2000095a,
259 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x1,
260 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x144,
261 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x301f095b,
262 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x165,
263 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xc094d,
264 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x173,
265 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xf096d,
266 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x184,
267 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x15097f,
268 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x19b,
269 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xc0998,
270 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x1a9,
271 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x409a7,
272 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x1af,
273 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0xcdc,
274 	mmGMCON_RENG_RAM_INDEX, 0xffffffff, 0x1b1,
275 	mmGMCON_RENG_RAM_DATA, 0xffffffff, 0x800,
276 	mmGMCON_RENG_EXECUTE, 0xffffffff, 0x6c9b2000,
277 	mmGMCON_MISC2, 0xfc00, 0x2000,
278 	mmGMCON_MISC3, 0xffffffff, 0xfc0,
279 	mmMC_PMG_AUTO_CFG, 0x00000100, 0x100,
280 };
281 
282 static const u32 verde_golden_rlc_registers[] =
283 {
284 	mmGB_ADDR_CONFIG, 0xffffffff, 0x02010002,
285 	mmRLC_LB_PARAMS, 0xffffffff, 0x033f1005,
286 	0x311f, 0xffffffff, 0x10808020,
287 	0x3122, 0xffffffff, 0x00800008,
288 	mmRLC_LB_CNTR_MAX, 0xffffffff, 0x00001000,
289 	mmRLC_LB_CNTL, 0xffffffff, 0x80010014,
290 };
291 
292 static const u32 verde_golden_registers[] =
293 {
294 	mmAZALIA_SCLK_CONTROL, 0x00000030, 0x00000011,
295 	mmCB_HW_CONTROL, 0x00010000, 0x00018208,
296 	mmDB_DEBUG, 0xffffffff, 0x00000000,
297 	mmDB_DEBUG2, 0xf00fffff, 0x00000400,
298 	mmDB_DEBUG3, 0x0002021c, 0x00020200,
299 	mmDCI_CLK_CNTL, 0x00000080, 0x00000000,
300 	0x340c, 0x000300c0, 0x00800040,
301 	0x360c, 0x000300c0, 0x00800040,
302 	mmFBC_DEBUG_COMP, 0x000000f0, 0x00000070,
303 	mmFBC_MISC, 0x00200000, 0x50100000,
304 	mmDIG0_HDMI_CONTROL, 0x31000311, 0x00000011,
305 	mmMC_SEQ_PMG_PG_HWCNTL, 0x00073ffe, 0x000022a2,
306 	mmMC_XPB_P2P_BAR_CFG, 0x000007ff, 0x00000000,
307 	mmPA_CL_ENHANCE, 0xf000001f, 0x00000007,
308 	mmPA_SC_FORCE_EOV_MAX_CNTS, 0xffffffff, 0x00ffffff,
309 	mmPA_SC_LINE_STIPPLE_STATE, 0x0000ff0f, 0x00000000,
310 	mmPA_SC_MODE_CNTL_1, 0x07ffffff, 0x4e000000,
311 	mmPA_SC_RASTER_CONFIG, 0x3f3f3fff, 0x0000124a,
312 	0x000c, 0xffffffff, 0x0040,
313 	0x000d, 0x00000040, 0x00004040,
314 	mmSPI_CONFIG_CNTL, 0x07ffffff, 0x03000000,
315 	mmSQ_DED_CNT, 0x01ff1f3f, 0x00000000,
316 	mmSQ_SEC_CNT, 0x01ff1f3f, 0x00000000,
317 	mmSX_DEBUG_1, 0x0000007f, 0x00000020,
318 	mmTA_CNTL_AUX, 0x00010000, 0x00010000,
319 	mmTCP_ADDR_CONFIG, 0x000003ff, 0x00000003,
320 	mmTCP_CHAN_STEER_HI, 0xffffffff, 0x00000000,
321 	mmTCP_CHAN_STEER_LO, 0xffffffff, 0x00001032,
322 	mmVGT_GS_VERTEX_REUSE, 0x0000001f, 0x00000010,
323 	mmVM_L2_CG, 0x000c0fc0, 0x000c0400,
324 	mmVM_PRT_APERTURE0_LOW_ADDR, 0x0fffffff, 0xffffffff,
325 	mmVM_PRT_APERTURE1_LOW_ADDR, 0x0fffffff, 0x0fffffff,
326 	mmVM_PRT_APERTURE2_LOW_ADDR, 0x0fffffff, 0x0fffffff,
327 	mmVM_PRT_APERTURE3_LOW_ADDR, 0x0fffffff, 0x0fffffff,
328 };
329 
330 static const u32 oland_golden_registers[] =
331 {
332 	mmAZALIA_SCLK_CONTROL, 0x00000030, 0x00000011,
333 	mmCB_HW_CONTROL, 0x00010000, 0x00018208,
334 	mmDB_DEBUG, 0xffffffff, 0x00000000,
335 	mmDB_DEBUG2, 0xf00fffff, 0x00000400,
336 	mmDB_DEBUG3, 0x0002021c, 0x00020200,
337 	mmDCI_CLK_CNTL, 0x00000080, 0x00000000,
338 	0x340c, 0x000300c0, 0x00800040,
339 	0x360c, 0x000300c0, 0x00800040,
340 	mmFBC_DEBUG_COMP, 0x000000f0, 0x00000070,
341 	mmFBC_MISC, 0x00200000, 0x50100000,
342 	mmDIG0_HDMI_CONTROL, 0x31000311, 0x00000011,
343 	mmMC_SEQ_PMG_PG_HWCNTL, 0x00073ffe, 0x000022a2,
344 	mmMC_XPB_P2P_BAR_CFG, 0x000007ff, 0x00000000,
345 	mmPA_CL_ENHANCE, 0xf000001f, 0x00000007,
346 	mmPA_SC_FORCE_EOV_MAX_CNTS, 0xffffffff, 0x00ffffff,
347 	mmPA_SC_LINE_STIPPLE_STATE, 0x0000ff0f, 0x00000000,
348 	mmPA_SC_MODE_CNTL_1, 0x07ffffff, 0x4e000000,
349 	mmPA_SC_RASTER_CONFIG, 0x3f3f3fff, 0x00000082,
350 	0x000c, 0xffffffff, 0x0040,
351 	0x000d, 0x00000040, 0x00004040,
352 	mmSPI_CONFIG_CNTL, 0x07ffffff, 0x03000000,
353 	mmSX_DEBUG_1, 0x0000007f, 0x00000020,
354 	mmTA_CNTL_AUX, 0x00010000, 0x00010000,
355 	mmTCP_ADDR_CONFIG, 0x000003ff, 0x000000f3,
356 	mmTCP_CHAN_STEER_HI, 0xffffffff, 0x00000000,
357 	mmTCP_CHAN_STEER_LO, 0xffffffff, 0x00003210,
358 	mmVGT_GS_VERTEX_REUSE, 0x0000001f, 0x00000010,
359 	mmVM_L2_CG, 0x000c0fc0, 0x000c0400,
360 	mmVM_PRT_APERTURE0_LOW_ADDR, 0x0fffffff, 0xffffffff,
361 	mmVM_PRT_APERTURE1_LOW_ADDR, 0x0fffffff, 0x0fffffff,
362 	mmVM_PRT_APERTURE2_LOW_ADDR, 0x0fffffff, 0x0fffffff,
363 	mmVM_PRT_APERTURE3_LOW_ADDR, 0x0fffffff, 0x0fffffff,
364 
365 };
366 
367 static const u32 oland_golden_rlc_registers[] =
368 {
369 	mmGB_ADDR_CONFIG, 0xffffffff, 0x02010002,
370 	mmRLC_LB_PARAMS, 0xffffffff, 0x00601005,
371 	0x311f, 0xffffffff, 0x10104040,
372 	0x3122, 0xffffffff, 0x0100000a,
373 	mmRLC_LB_CNTR_MAX, 0xffffffff, 0x00000800,
374 	mmRLC_LB_CNTL, 0xffffffff, 0x800000f4,
375 };
376 
377 static const u32 hainan_golden_registers[] =
378 {
379 	0x17bc, 0x00000030, 0x00000011,
380 	mmCB_HW_CONTROL, 0x00010000, 0x00018208,
381 	mmDB_DEBUG, 0xffffffff, 0x00000000,
382 	mmDB_DEBUG2, 0xf00fffff, 0x00000400,
383 	mmDB_DEBUG3, 0x0002021c, 0x00020200,
384 	0x031e, 0x00000080, 0x00000000,
385 	0x3430, 0xff000fff, 0x00000100,
386 	0x340c, 0x000300c0, 0x00800040,
387 	0x3630, 0xff000fff, 0x00000100,
388 	0x360c, 0x000300c0, 0x00800040,
389 	0x16ec, 0x000000f0, 0x00000070,
390 	0x16f0, 0x00200000, 0x50100000,
391 	0x1c0c, 0x31000311, 0x00000011,
392 	mmMC_SEQ_PMG_PG_HWCNTL, 0x00073ffe, 0x000022a2,
393 	mmMC_XPB_P2P_BAR_CFG, 0x000007ff, 0x00000000,
394 	mmPA_CL_ENHANCE, 0xf000001f, 0x00000007,
395 	mmPA_SC_FORCE_EOV_MAX_CNTS, 0xffffffff, 0x00ffffff,
396 	mmPA_SC_LINE_STIPPLE_STATE, 0x0000ff0f, 0x00000000,
397 	mmPA_SC_MODE_CNTL_1, 0x07ffffff, 0x4e000000,
398 	mmPA_SC_RASTER_CONFIG, 0x3f3f3fff, 0x00000000,
399 	0x000c, 0xffffffff, 0x0040,
400 	0x000d, 0x00000040, 0x00004040,
401 	mmSPI_CONFIG_CNTL, 0x03e00000, 0x03600000,
402 	mmSX_DEBUG_1, 0x0000007f, 0x00000020,
403 	mmTA_CNTL_AUX, 0x00010000, 0x00010000,
404 	mmTCP_ADDR_CONFIG, 0x000003ff, 0x000000f1,
405 	mmTCP_CHAN_STEER_HI, 0xffffffff, 0x00000000,
406 	mmTCP_CHAN_STEER_LO, 0xffffffff, 0x00003210,
407 	mmVGT_GS_VERTEX_REUSE, 0x0000001f, 0x00000010,
408 	mmVM_L2_CG, 0x000c0fc0, 0x000c0400,
409 	mmVM_PRT_APERTURE0_LOW_ADDR, 0x0fffffff, 0xffffffff,
410 	mmVM_PRT_APERTURE1_LOW_ADDR, 0x0fffffff, 0x0fffffff,
411 	mmVM_PRT_APERTURE2_LOW_ADDR, 0x0fffffff, 0x0fffffff,
412 	mmVM_PRT_APERTURE3_LOW_ADDR, 0x0fffffff, 0x0fffffff,
413 };
414 
415 static const u32 hainan_golden_registers2[] =
416 {
417 	mmGB_ADDR_CONFIG, 0xffffffff, 0x2011003,
418 };
419 
420 static const u32 tahiti_mgcg_cgcg_init[] =
421 {
422 	mmRLC_CGTT_MGCG_OVERRIDE, 0xffffffff, 0xfffffffc,
423 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
424 	mmCB_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
425 	mmCGTT_BCI_CLK_CTRL, 0xffffffff, 0x00000100,
426 	mmCGTT_CP_CLK_CTRL, 0xffffffff, 0x00000100,
427 	mmCGTT_GDS_CLK_CTRL, 0xffffffff, 0x00000100,
428 	mmCGTT_IA_CLK_CTRL, 0xffffffff, 0x06000100,
429 	mmCGTT_PA_CLK_CTRL, 0xffffffff, 0x00000100,
430 	mmCGTT_PC_CLK_CTRL, 0xffffffff, 0x00000100,
431 	mmCGTT_RLC_CLK_CTRL, 0xffffffff, 0x00000100,
432 	mmCGTT_SC_CLK_CTRL, 0xffffffff, 0x00000100,
433 	mmCGTT_SPI_CLK_CTRL, 0xffffffff, 0x00000100,
434 	mmCGTT_SQ_CLK_CTRL, 0xffffffff, 0x00000100,
435 	mmCGTT_SQG_CLK_CTRL, 0xffffffff, 0x00000100,
436 	mmCGTT_SX_CLK_CTRL0, 0xffffffff, 0x00000100,
437 	mmCGTT_SX_CLK_CTRL1, 0xffffffff, 0x00000100,
438 	mmCGTT_SX_CLK_CTRL2, 0xffffffff, 0x00000100,
439 	mmCGTT_SX_CLK_CTRL3, 0xffffffff, 0x00000100,
440 	mmCGTT_TCI_CLK_CTRL, 0xffffffff, 0x00000100,
441 	mmCGTT_TCP_CLK_CTRL, 0xffffffff, 0x00000100,
442 	mmCGTT_VGT_CLK_CTRL, 0xffffffff, 0x06000100,
443 	mmDB_CGTT_CLK_CTRL_0, 0xffffffff, 0x00000100,
444 	mmTA_CGTT_CTRL, 0xffffffff, 0x00000100,
445 	mmTCA_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
446 	mmTCC_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
447 	mmTD_CGTT_CTRL, 0xffffffff, 0x00000100,
448 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
449 	0x2458, 0xffffffff, 0x00010000,
450 	0x2459, 0xffffffff, 0x00030002,
451 	0x245a, 0xffffffff, 0x00040007,
452 	0x245b, 0xffffffff, 0x00060005,
453 	0x245c, 0xffffffff, 0x00090008,
454 	0x245d, 0xffffffff, 0x00020001,
455 	0x245e, 0xffffffff, 0x00040003,
456 	0x245f, 0xffffffff, 0x00000007,
457 	0x2460, 0xffffffff, 0x00060005,
458 	0x2461, 0xffffffff, 0x00090008,
459 	0x2462, 0xffffffff, 0x00030002,
460 	0x2463, 0xffffffff, 0x00050004,
461 	0x2464, 0xffffffff, 0x00000008,
462 	0x2465, 0xffffffff, 0x00070006,
463 	0x2466, 0xffffffff, 0x000a0009,
464 	0x2467, 0xffffffff, 0x00040003,
465 	0x2468, 0xffffffff, 0x00060005,
466 	0x2469, 0xffffffff, 0x00000009,
467 	0x246a, 0xffffffff, 0x00080007,
468 	0x246b, 0xffffffff, 0x000b000a,
469 	0x246c, 0xffffffff, 0x00050004,
470 	0x246d, 0xffffffff, 0x00070006,
471 	0x246e, 0xffffffff, 0x0008000b,
472 	0x246f, 0xffffffff, 0x000a0009,
473 	0x2470, 0xffffffff, 0x000d000c,
474 	0x2471, 0xffffffff, 0x00060005,
475 	0x2472, 0xffffffff, 0x00080007,
476 	0x2473, 0xffffffff, 0x0000000b,
477 	0x2474, 0xffffffff, 0x000a0009,
478 	0x2475, 0xffffffff, 0x000d000c,
479 	0x2476, 0xffffffff, 0x00070006,
480 	0x2477, 0xffffffff, 0x00090008,
481 	0x2478, 0xffffffff, 0x0000000c,
482 	0x2479, 0xffffffff, 0x000b000a,
483 	0x247a, 0xffffffff, 0x000e000d,
484 	0x247b, 0xffffffff, 0x00080007,
485 	0x247c, 0xffffffff, 0x000a0009,
486 	0x247d, 0xffffffff, 0x0000000d,
487 	0x247e, 0xffffffff, 0x000c000b,
488 	0x247f, 0xffffffff, 0x000f000e,
489 	0x2480, 0xffffffff, 0x00090008,
490 	0x2481, 0xffffffff, 0x000b000a,
491 	0x2482, 0xffffffff, 0x000c000f,
492 	0x2483, 0xffffffff, 0x000e000d,
493 	0x2484, 0xffffffff, 0x00110010,
494 	0x2485, 0xffffffff, 0x000a0009,
495 	0x2486, 0xffffffff, 0x000c000b,
496 	0x2487, 0xffffffff, 0x0000000f,
497 	0x2488, 0xffffffff, 0x000e000d,
498 	0x2489, 0xffffffff, 0x00110010,
499 	0x248a, 0xffffffff, 0x000b000a,
500 	0x248b, 0xffffffff, 0x000d000c,
501 	0x248c, 0xffffffff, 0x00000010,
502 	0x248d, 0xffffffff, 0x000f000e,
503 	0x248e, 0xffffffff, 0x00120011,
504 	0x248f, 0xffffffff, 0x000c000b,
505 	0x2490, 0xffffffff, 0x000e000d,
506 	0x2491, 0xffffffff, 0x00000011,
507 	0x2492, 0xffffffff, 0x0010000f,
508 	0x2493, 0xffffffff, 0x00130012,
509 	0x2494, 0xffffffff, 0x000d000c,
510 	0x2495, 0xffffffff, 0x000f000e,
511 	0x2496, 0xffffffff, 0x00100013,
512 	0x2497, 0xffffffff, 0x00120011,
513 	0x2498, 0xffffffff, 0x00150014,
514 	0x2499, 0xffffffff, 0x000e000d,
515 	0x249a, 0xffffffff, 0x0010000f,
516 	0x249b, 0xffffffff, 0x00000013,
517 	0x249c, 0xffffffff, 0x00120011,
518 	0x249d, 0xffffffff, 0x00150014,
519 	0x249e, 0xffffffff, 0x000f000e,
520 	0x249f, 0xffffffff, 0x00110010,
521 	0x24a0, 0xffffffff, 0x00000014,
522 	0x24a1, 0xffffffff, 0x00130012,
523 	0x24a2, 0xffffffff, 0x00160015,
524 	0x24a3, 0xffffffff, 0x0010000f,
525 	0x24a4, 0xffffffff, 0x00120011,
526 	0x24a5, 0xffffffff, 0x00000015,
527 	0x24a6, 0xffffffff, 0x00140013,
528 	0x24a7, 0xffffffff, 0x00170016,
529 	mmCGTS_SM_CTRL_REG, 0xffffffff, 0x96940200,
530 	mmCP_RB_WPTR_POLL_CNTL, 0xffffffff, 0x00900100,
531 	mmRLC_GCPM_GENERAL_3, 0xffffffff, 0x00000080,
532 	mmRLC_CGCG_CGLS_CTRL, 0xffffffff, 0x0020003f,
533 	0x000c, 0xffffffff, 0x0000001c,
534 	0x000d, 0x000f0000, 0x000f0000,
535 	0x0583, 0xffffffff, 0x00000100,
536 	mmXDMA_CLOCK_GATING_CNTL, 0xffffffff, 0x00000100,
537 	mmXDMA_MEM_POWER_CNTL, 0x00000101, 0x00000000,
538 	mmMC_MEM_POWER_LS, 0xffffffff, 0x00000104,
539 	mmMC_CITF_MISC_WR_CG, 0x000c0000, 0x000c0000,
540 	mmMC_CITF_MISC_RD_CG, 0x000c0000, 0x000c0000,
541 	mmCGTT_DRM_CLK_CTRL0, 0xff000fff, 0x00000100,
542 	0x157a, 0x00000001, 0x00000001,
543 	mmHDP_MEM_POWER_LS, 0x00000001, 0x00000001,
544 	mmHDP_XDP_CGTT_BLK_CTRL, 0xc0000fff, 0x00000104,
545 	mmCP_MEM_SLP_CNTL, 0x00000001, 0x00000001,
546 	0x3430, 0xfffffff0, 0x00000100,
547 	0x3630, 0xfffffff0, 0x00000100,
548 };
549 static const u32 pitcairn_mgcg_cgcg_init[] =
550 {
551 	mmRLC_CGTT_MGCG_OVERRIDE, 0xffffffff, 0xfffffffc,
552 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
553 	mmCB_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
554 	mmCGTT_BCI_CLK_CTRL, 0xffffffff, 0x00000100,
555 	mmCGTT_CP_CLK_CTRL, 0xffffffff, 0x00000100,
556 	mmCGTT_GDS_CLK_CTRL, 0xffffffff, 0x00000100,
557 	mmCGTT_IA_CLK_CTRL, 0xffffffff, 0x06000100,
558 	mmCGTT_PA_CLK_CTRL, 0xffffffff, 0x00000100,
559 	mmCGTT_PC_CLK_CTRL, 0xffffffff, 0x00000100,
560 	mmCGTT_RLC_CLK_CTRL, 0xffffffff, 0x00000100,
561 	mmCGTT_SC_CLK_CTRL, 0xffffffff, 0x00000100,
562 	mmCGTT_SPI_CLK_CTRL, 0xffffffff, 0x00000100,
563 	mmCGTT_SQ_CLK_CTRL, 0xffffffff, 0x00000100,
564 	mmCGTT_SQG_CLK_CTRL, 0xffffffff, 0x00000100,
565 	mmCGTT_SX_CLK_CTRL0, 0xffffffff, 0x00000100,
566 	mmCGTT_SX_CLK_CTRL1, 0xffffffff, 0x00000100,
567 	mmCGTT_SX_CLK_CTRL2, 0xffffffff, 0x00000100,
568 	mmCGTT_SX_CLK_CTRL3, 0xffffffff, 0x00000100,
569 	mmCGTT_TCI_CLK_CTRL, 0xffffffff, 0x00000100,
570 	mmCGTT_TCP_CLK_CTRL, 0xffffffff, 0x00000100,
571 	mmCGTT_VGT_CLK_CTRL, 0xffffffff, 0x06000100,
572 	mmDB_CGTT_CLK_CTRL_0, 0xffffffff, 0x00000100,
573 	mmTA_CGTT_CTRL, 0xffffffff, 0x00000100,
574 	mmTCA_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
575 	mmTCC_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
576 	mmTD_CGTT_CTRL, 0xffffffff, 0x00000100,
577 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
578 	0x2458, 0xffffffff, 0x00010000,
579 	0x2459, 0xffffffff, 0x00030002,
580 	0x245a, 0xffffffff, 0x00040007,
581 	0x245b, 0xffffffff, 0x00060005,
582 	0x245c, 0xffffffff, 0x00090008,
583 	0x245d, 0xffffffff, 0x00020001,
584 	0x245e, 0xffffffff, 0x00040003,
585 	0x245f, 0xffffffff, 0x00000007,
586 	0x2460, 0xffffffff, 0x00060005,
587 	0x2461, 0xffffffff, 0x00090008,
588 	0x2462, 0xffffffff, 0x00030002,
589 	0x2463, 0xffffffff, 0x00050004,
590 	0x2464, 0xffffffff, 0x00000008,
591 	0x2465, 0xffffffff, 0x00070006,
592 	0x2466, 0xffffffff, 0x000a0009,
593 	0x2467, 0xffffffff, 0x00040003,
594 	0x2468, 0xffffffff, 0x00060005,
595 	0x2469, 0xffffffff, 0x00000009,
596 	0x246a, 0xffffffff, 0x00080007,
597 	0x246b, 0xffffffff, 0x000b000a,
598 	0x246c, 0xffffffff, 0x00050004,
599 	0x246d, 0xffffffff, 0x00070006,
600 	0x246e, 0xffffffff, 0x0008000b,
601 	0x246f, 0xffffffff, 0x000a0009,
602 	0x2470, 0xffffffff, 0x000d000c,
603 	0x2480, 0xffffffff, 0x00090008,
604 	0x2481, 0xffffffff, 0x000b000a,
605 	0x2482, 0xffffffff, 0x000c000f,
606 	0x2483, 0xffffffff, 0x000e000d,
607 	0x2484, 0xffffffff, 0x00110010,
608 	0x2485, 0xffffffff, 0x000a0009,
609 	0x2486, 0xffffffff, 0x000c000b,
610 	0x2487, 0xffffffff, 0x0000000f,
611 	0x2488, 0xffffffff, 0x000e000d,
612 	0x2489, 0xffffffff, 0x00110010,
613 	0x248a, 0xffffffff, 0x000b000a,
614 	0x248b, 0xffffffff, 0x000d000c,
615 	0x248c, 0xffffffff, 0x00000010,
616 	0x248d, 0xffffffff, 0x000f000e,
617 	0x248e, 0xffffffff, 0x00120011,
618 	0x248f, 0xffffffff, 0x000c000b,
619 	0x2490, 0xffffffff, 0x000e000d,
620 	0x2491, 0xffffffff, 0x00000011,
621 	0x2492, 0xffffffff, 0x0010000f,
622 	0x2493, 0xffffffff, 0x00130012,
623 	0x2494, 0xffffffff, 0x000d000c,
624 	0x2495, 0xffffffff, 0x000f000e,
625 	0x2496, 0xffffffff, 0x00100013,
626 	0x2497, 0xffffffff, 0x00120011,
627 	0x2498, 0xffffffff, 0x00150014,
628 	mmCGTS_SM_CTRL_REG, 0xffffffff, 0x96940200,
629 	mmCP_RB_WPTR_POLL_CNTL, 0xffffffff, 0x00900100,
630 	mmRLC_GCPM_GENERAL_3, 0xffffffff, 0x00000080,
631 	mmRLC_CGCG_CGLS_CTRL, 0xffffffff, 0x0020003f,
632 	0x000c, 0xffffffff, 0x0000001c,
633 	0x000d, 0x000f0000, 0x000f0000,
634 	0x0583, 0xffffffff, 0x00000100,
635 	mmXDMA_CLOCK_GATING_CNTL, 0xffffffff, 0x00000100,
636 	mmXDMA_MEM_POWER_CNTL, 0x00000101, 0x00000000,
637 	mmMC_MEM_POWER_LS, 0xffffffff, 0x00000104,
638 	mmCGTT_DRM_CLK_CTRL0, 0xff000fff, 0x00000100,
639 	0x157a, 0x00000001, 0x00000001,
640 	mmHDP_MEM_POWER_LS, 0x00000001, 0x00000001,
641 	mmHDP_XDP_CGTT_BLK_CTRL, 0xc0000fff, 0x00000104,
642 	mmCP_MEM_SLP_CNTL, 0x00000001, 0x00000001,
643 	0x3430, 0xfffffff0, 0x00000100,
644 	0x3630, 0xfffffff0, 0x00000100,
645 };
646 
647 static const u32 verde_mgcg_cgcg_init[] =
648 {
649 	mmRLC_CGTT_MGCG_OVERRIDE, 0xffffffff, 0xfffffffc,
650 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
651 	mmCB_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
652 	mmCGTT_BCI_CLK_CTRL, 0xffffffff, 0x00000100,
653 	mmCGTT_CP_CLK_CTRL, 0xffffffff, 0x00000100,
654 	mmCGTT_GDS_CLK_CTRL, 0xffffffff, 0x00000100,
655 	mmCGTT_IA_CLK_CTRL, 0xffffffff, 0x06000100,
656 	mmCGTT_PA_CLK_CTRL, 0xffffffff, 0x00000100,
657 	mmCGTT_PC_CLK_CTRL, 0xffffffff, 0x00000100,
658 	mmCGTT_RLC_CLK_CTRL, 0xffffffff, 0x00000100,
659 	mmCGTT_SC_CLK_CTRL, 0xffffffff, 0x00000100,
660 	mmCGTT_SPI_CLK_CTRL, 0xffffffff, 0x00000100,
661 	mmCGTT_SQ_CLK_CTRL, 0xffffffff, 0x00000100,
662 	mmCGTT_SQG_CLK_CTRL, 0xffffffff, 0x00000100,
663 	mmCGTT_SX_CLK_CTRL0, 0xffffffff, 0x00000100,
664 	mmCGTT_SX_CLK_CTRL1, 0xffffffff, 0x00000100,
665 	mmCGTT_SX_CLK_CTRL2, 0xffffffff, 0x00000100,
666 	mmCGTT_SX_CLK_CTRL3, 0xffffffff, 0x00000100,
667 	mmCGTT_TCI_CLK_CTRL, 0xffffffff, 0x00000100,
668 	mmCGTT_TCP_CLK_CTRL, 0xffffffff, 0x00000100,
669 	mmCGTT_VGT_CLK_CTRL, 0xffffffff, 0x06000100,
670 	mmDB_CGTT_CLK_CTRL_0, 0xffffffff, 0x00000100,
671 	mmTA_CGTT_CTRL, 0xffffffff, 0x00000100,
672 	mmTCA_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
673 	mmTCC_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
674 	mmTD_CGTT_CTRL, 0xffffffff, 0x00000100,
675 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
676 	0x2458, 0xffffffff, 0x00010000,
677 	0x2459, 0xffffffff, 0x00030002,
678 	0x245a, 0xffffffff, 0x00040007,
679 	0x245b, 0xffffffff, 0x00060005,
680 	0x245c, 0xffffffff, 0x00090008,
681 	0x245d, 0xffffffff, 0x00020001,
682 	0x245e, 0xffffffff, 0x00040003,
683 	0x245f, 0xffffffff, 0x00000007,
684 	0x2460, 0xffffffff, 0x00060005,
685 	0x2461, 0xffffffff, 0x00090008,
686 	0x2462, 0xffffffff, 0x00030002,
687 	0x2463, 0xffffffff, 0x00050004,
688 	0x2464, 0xffffffff, 0x00000008,
689 	0x2465, 0xffffffff, 0x00070006,
690 	0x2466, 0xffffffff, 0x000a0009,
691 	0x2467, 0xffffffff, 0x00040003,
692 	0x2468, 0xffffffff, 0x00060005,
693 	0x2469, 0xffffffff, 0x00000009,
694 	0x246a, 0xffffffff, 0x00080007,
695 	0x246b, 0xffffffff, 0x000b000a,
696 	0x246c, 0xffffffff, 0x00050004,
697 	0x246d, 0xffffffff, 0x00070006,
698 	0x246e, 0xffffffff, 0x0008000b,
699 	0x246f, 0xffffffff, 0x000a0009,
700 	0x2470, 0xffffffff, 0x000d000c,
701 	0x2480, 0xffffffff, 0x00090008,
702 	0x2481, 0xffffffff, 0x000b000a,
703 	0x2482, 0xffffffff, 0x000c000f,
704 	0x2483, 0xffffffff, 0x000e000d,
705 	0x2484, 0xffffffff, 0x00110010,
706 	0x2485, 0xffffffff, 0x000a0009,
707 	0x2486, 0xffffffff, 0x000c000b,
708 	0x2487, 0xffffffff, 0x0000000f,
709 	0x2488, 0xffffffff, 0x000e000d,
710 	0x2489, 0xffffffff, 0x00110010,
711 	0x248a, 0xffffffff, 0x000b000a,
712 	0x248b, 0xffffffff, 0x000d000c,
713 	0x248c, 0xffffffff, 0x00000010,
714 	0x248d, 0xffffffff, 0x000f000e,
715 	0x248e, 0xffffffff, 0x00120011,
716 	0x248f, 0xffffffff, 0x000c000b,
717 	0x2490, 0xffffffff, 0x000e000d,
718 	0x2491, 0xffffffff, 0x00000011,
719 	0x2492, 0xffffffff, 0x0010000f,
720 	0x2493, 0xffffffff, 0x00130012,
721 	0x2494, 0xffffffff, 0x000d000c,
722 	0x2495, 0xffffffff, 0x000f000e,
723 	0x2496, 0xffffffff, 0x00100013,
724 	0x2497, 0xffffffff, 0x00120011,
725 	0x2498, 0xffffffff, 0x00150014,
726 	mmCGTS_SM_CTRL_REG, 0xffffffff, 0x96940200,
727 	mmCP_RB_WPTR_POLL_CNTL, 0xffffffff, 0x00900100,
728 	mmRLC_GCPM_GENERAL_3, 0xffffffff, 0x00000080,
729 	mmRLC_CGCG_CGLS_CTRL, 0xffffffff, 0x0020003f,
730 	0x000c, 0xffffffff, 0x0000001c,
731 	0x000d, 0x000f0000, 0x000f0000,
732 	0x0583, 0xffffffff, 0x00000100,
733 	mmXDMA_CLOCK_GATING_CNTL, 0xffffffff, 0x00000100,
734 	mmXDMA_MEM_POWER_CNTL, 0x00000101, 0x00000000,
735 	mmMC_MEM_POWER_LS, 0xffffffff, 0x00000104,
736 	mmMC_CITF_MISC_WR_CG, 0x000c0000, 0x000c0000,
737 	mmMC_CITF_MISC_RD_CG, 0x000c0000, 0x000c0000,
738 	mmCGTT_DRM_CLK_CTRL0, 0xff000fff, 0x00000100,
739 	0x157a, 0x00000001, 0x00000001,
740 	mmHDP_MEM_POWER_LS, 0x00000001, 0x00000001,
741 	mmHDP_XDP_CGTT_BLK_CTRL, 0xc0000fff, 0x00000104,
742 	mmCP_MEM_SLP_CNTL, 0x00000001, 0x00000001,
743 	0x3430, 0xfffffff0, 0x00000100,
744 	0x3630, 0xfffffff0, 0x00000100,
745 };
746 
747 static const u32 oland_mgcg_cgcg_init[] =
748 {
749 	mmRLC_CGTT_MGCG_OVERRIDE, 0xffffffff, 0xfffffffc,
750 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
751 	mmCB_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
752 	mmCGTT_BCI_CLK_CTRL, 0xffffffff, 0x00000100,
753 	mmCGTT_CP_CLK_CTRL, 0xffffffff, 0x00000100,
754 	mmCGTT_GDS_CLK_CTRL, 0xffffffff, 0x00000100,
755 	mmCGTT_IA_CLK_CTRL, 0xffffffff, 0x06000100,
756 	mmCGTT_PA_CLK_CTRL, 0xffffffff, 0x00000100,
757 	mmCGTT_PC_CLK_CTRL, 0xffffffff, 0x00000100,
758 	mmCGTT_RLC_CLK_CTRL, 0xffffffff, 0x00000100,
759 	mmCGTT_SC_CLK_CTRL, 0xffffffff, 0x00000100,
760 	mmCGTT_SPI_CLK_CTRL, 0xffffffff, 0x00000100,
761 	mmCGTT_SQ_CLK_CTRL, 0xffffffff, 0x00000100,
762 	mmCGTT_SQG_CLK_CTRL, 0xffffffff, 0x00000100,
763 	mmCGTT_SX_CLK_CTRL0, 0xffffffff, 0x00000100,
764 	mmCGTT_SX_CLK_CTRL1, 0xffffffff, 0x00000100,
765 	mmCGTT_SX_CLK_CTRL2, 0xffffffff, 0x00000100,
766 	mmCGTT_SX_CLK_CTRL3, 0xffffffff, 0x00000100,
767 	mmCGTT_TCI_CLK_CTRL, 0xffffffff, 0x00000100,
768 	mmCGTT_TCP_CLK_CTRL, 0xffffffff, 0x00000100,
769 	mmCGTT_VGT_CLK_CTRL, 0xffffffff, 0x06000100,
770 	mmDB_CGTT_CLK_CTRL_0, 0xffffffff, 0x00000100,
771 	mmTA_CGTT_CTRL, 0xffffffff, 0x00000100,
772 	mmTCA_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
773 	mmTCC_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
774 	mmTD_CGTT_CTRL, 0xffffffff, 0x00000100,
775 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
776 	0x2458, 0xffffffff, 0x00010000,
777 	0x2459, 0xffffffff, 0x00030002,
778 	0x245a, 0xffffffff, 0x00040007,
779 	0x245b, 0xffffffff, 0x00060005,
780 	0x245c, 0xffffffff, 0x00090008,
781 	0x245d, 0xffffffff, 0x00020001,
782 	0x245e, 0xffffffff, 0x00040003,
783 	0x245f, 0xffffffff, 0x00000007,
784 	0x2460, 0xffffffff, 0x00060005,
785 	0x2461, 0xffffffff, 0x00090008,
786 	0x2462, 0xffffffff, 0x00030002,
787 	0x2463, 0xffffffff, 0x00050004,
788 	0x2464, 0xffffffff, 0x00000008,
789 	0x2465, 0xffffffff, 0x00070006,
790 	0x2466, 0xffffffff, 0x000a0009,
791 	0x2467, 0xffffffff, 0x00040003,
792 	0x2468, 0xffffffff, 0x00060005,
793 	0x2469, 0xffffffff, 0x00000009,
794 	0x246a, 0xffffffff, 0x00080007,
795 	0x246b, 0xffffffff, 0x000b000a,
796 	0x246c, 0xffffffff, 0x00050004,
797 	0x246d, 0xffffffff, 0x00070006,
798 	0x246e, 0xffffffff, 0x0008000b,
799 	0x246f, 0xffffffff, 0x000a0009,
800 	0x2470, 0xffffffff, 0x000d000c,
801 	0x2471, 0xffffffff, 0x00060005,
802 	0x2472, 0xffffffff, 0x00080007,
803 	0x2473, 0xffffffff, 0x0000000b,
804 	0x2474, 0xffffffff, 0x000a0009,
805 	0x2475, 0xffffffff, 0x000d000c,
806 	mmCGTS_SM_CTRL_REG, 0xffffffff, 0x96940200,
807 	mmCP_RB_WPTR_POLL_CNTL, 0xffffffff, 0x00900100,
808 	mmRLC_GCPM_GENERAL_3, 0xffffffff, 0x00000080,
809 	mmRLC_CGCG_CGLS_CTRL, 0xffffffff, 0x0020003f,
810 	0x000c, 0xffffffff, 0x0000001c,
811 	0x000d, 0x000f0000, 0x000f0000,
812 	0x0583, 0xffffffff, 0x00000100,
813 	mmXDMA_CLOCK_GATING_CNTL, 0xffffffff, 0x00000100,
814 	mmXDMA_MEM_POWER_CNTL, 0x00000101, 0x00000000,
815 	mmMC_MEM_POWER_LS, 0xffffffff, 0x00000104,
816 	mmMC_CITF_MISC_WR_CG, 0x000c0000, 0x000c0000,
817 	mmMC_CITF_MISC_RD_CG, 0x000c0000, 0x000c0000,
818 	mmCGTT_DRM_CLK_CTRL0, 0xff000fff, 0x00000100,
819 	0x157a, 0x00000001, 0x00000001,
820 	mmHDP_MEM_POWER_LS, 0x00000001, 0x00000001,
821 	mmHDP_XDP_CGTT_BLK_CTRL, 0xc0000fff, 0x00000104,
822 	mmCP_MEM_SLP_CNTL, 0x00000001, 0x00000001,
823 	0x3430, 0xfffffff0, 0x00000100,
824 	0x3630, 0xfffffff0, 0x00000100,
825 };
826 
827 static const u32 hainan_mgcg_cgcg_init[] =
828 {
829 	mmRLC_CGTT_MGCG_OVERRIDE, 0xffffffff, 0xfffffffc,
830 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
831 	mmCB_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
832 	mmCGTT_BCI_CLK_CTRL, 0xffffffff, 0x00000100,
833 	mmCGTT_CP_CLK_CTRL, 0xffffffff, 0x00000100,
834 	mmCGTT_GDS_CLK_CTRL, 0xffffffff, 0x00000100,
835 	mmCGTT_IA_CLK_CTRL, 0xffffffff, 0x06000100,
836 	mmCGTT_PA_CLK_CTRL, 0xffffffff, 0x00000100,
837 	mmCGTT_PC_CLK_CTRL, 0xffffffff, 0x00000100,
838 	mmCGTT_RLC_CLK_CTRL, 0xffffffff, 0x00000100,
839 	mmCGTT_SC_CLK_CTRL, 0xffffffff, 0x00000100,
840 	mmCGTT_SPI_CLK_CTRL, 0xffffffff, 0x00000100,
841 	mmCGTT_SQ_CLK_CTRL, 0xffffffff, 0x00000100,
842 	mmCGTT_SQG_CLK_CTRL, 0xffffffff, 0x00000100,
843 	mmCGTT_SX_CLK_CTRL0, 0xffffffff, 0x00000100,
844 	mmCGTT_SX_CLK_CTRL1, 0xffffffff, 0x00000100,
845 	mmCGTT_SX_CLK_CTRL2, 0xffffffff, 0x00000100,
846 	mmCGTT_SX_CLK_CTRL3, 0xffffffff, 0x00000100,
847 	mmCGTT_TCI_CLK_CTRL, 0xffffffff, 0x00000100,
848 	mmCGTT_TCP_CLK_CTRL, 0xffffffff, 0x00000100,
849 	mmCGTT_VGT_CLK_CTRL, 0xffffffff, 0x06000100,
850 	mmDB_CGTT_CLK_CTRL_0, 0xffffffff, 0x00000100,
851 	mmTA_CGTT_CTRL, 0xffffffff, 0x00000100,
852 	mmTCA_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
853 	mmTCC_CGTT_SCLK_CTRL, 0xffffffff, 0x00000100,
854 	mmTD_CGTT_CTRL, 0xffffffff, 0x00000100,
855 	mmGRBM_GFX_INDEX, 0xffffffff, 0xe0000000,
856 	0x2458, 0xffffffff, 0x00010000,
857 	0x2459, 0xffffffff, 0x00030002,
858 	0x245a, 0xffffffff, 0x00040007,
859 	0x245b, 0xffffffff, 0x00060005,
860 	0x245c, 0xffffffff, 0x00090008,
861 	0x245d, 0xffffffff, 0x00020001,
862 	0x245e, 0xffffffff, 0x00040003,
863 	0x245f, 0xffffffff, 0x00000007,
864 	0x2460, 0xffffffff, 0x00060005,
865 	0x2461, 0xffffffff, 0x00090008,
866 	0x2462, 0xffffffff, 0x00030002,
867 	0x2463, 0xffffffff, 0x00050004,
868 	0x2464, 0xffffffff, 0x00000008,
869 	0x2465, 0xffffffff, 0x00070006,
870 	0x2466, 0xffffffff, 0x000a0009,
871 	0x2467, 0xffffffff, 0x00040003,
872 	0x2468, 0xffffffff, 0x00060005,
873 	0x2469, 0xffffffff, 0x00000009,
874 	0x246a, 0xffffffff, 0x00080007,
875 	0x246b, 0xffffffff, 0x000b000a,
876 	0x246c, 0xffffffff, 0x00050004,
877 	0x246d, 0xffffffff, 0x00070006,
878 	0x246e, 0xffffffff, 0x0008000b,
879 	0x246f, 0xffffffff, 0x000a0009,
880 	0x2470, 0xffffffff, 0x000d000c,
881 	0x2471, 0xffffffff, 0x00060005,
882 	0x2472, 0xffffffff, 0x00080007,
883 	0x2473, 0xffffffff, 0x0000000b,
884 	0x2474, 0xffffffff, 0x000a0009,
885 	0x2475, 0xffffffff, 0x000d000c,
886 	mmCGTS_SM_CTRL_REG, 0xffffffff, 0x96940200,
887 	mmCP_RB_WPTR_POLL_CNTL, 0xffffffff, 0x00900100,
888 	mmRLC_GCPM_GENERAL_3, 0xffffffff, 0x00000080,
889 	mmRLC_CGCG_CGLS_CTRL, 0xffffffff, 0x0020003f,
890 	0x000c, 0xffffffff, 0x0000001c,
891 	0x000d, 0x000f0000, 0x000f0000,
892 	0x0583, 0xffffffff, 0x00000100,
893 	0x0409, 0xffffffff, 0x00000100,
894 	mmMC_MEM_POWER_LS, 0xffffffff, 0x00000104,
895 	mmMC_CITF_MISC_WR_CG, 0x000c0000, 0x000c0000,
896 	mmMC_CITF_MISC_RD_CG, 0x000c0000, 0x000c0000,
897 	mmHDP_MEM_POWER_LS, 0x00000001, 0x00000001,
898 	mmHDP_XDP_CGTT_BLK_CTRL, 0xc0000fff, 0x00000104,
899 	mmCP_MEM_SLP_CNTL, 0x00000001, 0x00000001,
900 	0x3430, 0xfffffff0, 0x00000100,
901 	0x3630, 0xfffffff0, 0x00000100,
902 };
903 
904 static u32 si_pcie_rreg(struct amdgpu_device *adev, u32 reg)
905 {
906 	unsigned long flags;
907 	u32 r;
908 
909 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
910 	WREG32(AMDGPU_PCIE_INDEX, reg);
911 	(void)RREG32(AMDGPU_PCIE_INDEX);
912 	r = RREG32(AMDGPU_PCIE_DATA);
913 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
914 	return r;
915 }
916 
917 static void si_pcie_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
918 {
919 	unsigned long flags;
920 
921 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
922 	WREG32(AMDGPU_PCIE_INDEX, reg);
923 	(void)RREG32(AMDGPU_PCIE_INDEX);
924 	WREG32(AMDGPU_PCIE_DATA, v);
925 	(void)RREG32(AMDGPU_PCIE_DATA);
926 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
927 }
928 
929 static u32 si_pciep_rreg(struct amdgpu_device *adev, u32 reg)
930 {
931 	unsigned long flags;
932 	u32 r;
933 
934 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
935 	WREG32(PCIE_PORT_INDEX, ((reg) & 0xff));
936 	(void)RREG32(PCIE_PORT_INDEX);
937 	r = RREG32(PCIE_PORT_DATA);
938 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
939 	return r;
940 }
941 
942 static void si_pciep_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
943 {
944 	unsigned long flags;
945 
946 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
947 	WREG32(PCIE_PORT_INDEX, ((reg) & 0xff));
948 	(void)RREG32(PCIE_PORT_INDEX);
949 	WREG32(PCIE_PORT_DATA, (v));
950 	(void)RREG32(PCIE_PORT_DATA);
951 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
952 }
953 
954 static u32 si_smc_rreg(struct amdgpu_device *adev, u32 reg)
955 {
956 	unsigned long flags;
957 	u32 r;
958 
959 	spin_lock_irqsave(&adev->smc_idx_lock, flags);
960 	WREG32(SMC_IND_INDEX_0, (reg));
961 	r = RREG32(SMC_IND_DATA_0);
962 	spin_unlock_irqrestore(&adev->smc_idx_lock, flags);
963 	return r;
964 }
965 
966 static void si_smc_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
967 {
968 	unsigned long flags;
969 
970 	spin_lock_irqsave(&adev->smc_idx_lock, flags);
971 	WREG32(SMC_IND_INDEX_0, (reg));
972 	WREG32(SMC_IND_DATA_0, (v));
973 	spin_unlock_irqrestore(&adev->smc_idx_lock, flags);
974 }
975 
976 static struct amdgpu_allowed_register_entry si_allowed_read_registers[] = {
977 	{GRBM_STATUS},
978 	{mmGRBM_STATUS2},
979 	{mmGRBM_STATUS_SE0},
980 	{mmGRBM_STATUS_SE1},
981 	{mmSRBM_STATUS},
982 	{mmSRBM_STATUS2},
983 	{DMA_STATUS_REG + DMA0_REGISTER_OFFSET},
984 	{DMA_STATUS_REG + DMA1_REGISTER_OFFSET},
985 	{mmCP_STAT},
986 	{mmCP_STALLED_STAT1},
987 	{mmCP_STALLED_STAT2},
988 	{mmCP_STALLED_STAT3},
989 	{GB_ADDR_CONFIG},
990 	{MC_ARB_RAMCFG},
991 	{GB_TILE_MODE0},
992 	{GB_TILE_MODE1},
993 	{GB_TILE_MODE2},
994 	{GB_TILE_MODE3},
995 	{GB_TILE_MODE4},
996 	{GB_TILE_MODE5},
997 	{GB_TILE_MODE6},
998 	{GB_TILE_MODE7},
999 	{GB_TILE_MODE8},
1000 	{GB_TILE_MODE9},
1001 	{GB_TILE_MODE10},
1002 	{GB_TILE_MODE11},
1003 	{GB_TILE_MODE12},
1004 	{GB_TILE_MODE13},
1005 	{GB_TILE_MODE14},
1006 	{GB_TILE_MODE15},
1007 	{GB_TILE_MODE16},
1008 	{GB_TILE_MODE17},
1009 	{GB_TILE_MODE18},
1010 	{GB_TILE_MODE19},
1011 	{GB_TILE_MODE20},
1012 	{GB_TILE_MODE21},
1013 	{GB_TILE_MODE22},
1014 	{GB_TILE_MODE23},
1015 	{GB_TILE_MODE24},
1016 	{GB_TILE_MODE25},
1017 	{GB_TILE_MODE26},
1018 	{GB_TILE_MODE27},
1019 	{GB_TILE_MODE28},
1020 	{GB_TILE_MODE29},
1021 	{GB_TILE_MODE30},
1022 	{GB_TILE_MODE31},
1023 	{CC_RB_BACKEND_DISABLE, true},
1024 	{GC_USER_RB_BACKEND_DISABLE, true},
1025 	{PA_SC_RASTER_CONFIG, true},
1026 };
1027 
1028 static uint32_t si_get_register_value(struct amdgpu_device *adev,
1029 				      bool indexed, u32 se_num,
1030 				      u32 sh_num, u32 reg_offset)
1031 {
1032 	if (indexed) {
1033 		uint32_t val;
1034 		unsigned se_idx = (se_num == 0xffffffff) ? 0 : se_num;
1035 		unsigned sh_idx = (sh_num == 0xffffffff) ? 0 : sh_num;
1036 
1037 		switch (reg_offset) {
1038 		case mmCC_RB_BACKEND_DISABLE:
1039 			return adev->gfx.config.rb_config[se_idx][sh_idx].rb_backend_disable;
1040 		case mmGC_USER_RB_BACKEND_DISABLE:
1041 			return adev->gfx.config.rb_config[se_idx][sh_idx].user_rb_backend_disable;
1042 		case mmPA_SC_RASTER_CONFIG:
1043 			return adev->gfx.config.rb_config[se_idx][sh_idx].raster_config;
1044 		}
1045 
1046 		mutex_lock(&adev->grbm_idx_mutex);
1047 		if (se_num != 0xffffffff || sh_num != 0xffffffff)
1048 			amdgpu_gfx_select_se_sh(adev, se_num, sh_num, 0xffffffff);
1049 
1050 		val = RREG32(reg_offset);
1051 
1052 		if (se_num != 0xffffffff || sh_num != 0xffffffff)
1053 			amdgpu_gfx_select_se_sh(adev, 0xffffffff, 0xffffffff, 0xffffffff);
1054 		mutex_unlock(&adev->grbm_idx_mutex);
1055 		return val;
1056 	} else {
1057 		unsigned idx;
1058 
1059 		switch (reg_offset) {
1060 		case mmGB_ADDR_CONFIG:
1061 			return adev->gfx.config.gb_addr_config;
1062 		case mmMC_ARB_RAMCFG:
1063 			return adev->gfx.config.mc_arb_ramcfg;
1064 		case mmGB_TILE_MODE0:
1065 		case mmGB_TILE_MODE1:
1066 		case mmGB_TILE_MODE2:
1067 		case mmGB_TILE_MODE3:
1068 		case mmGB_TILE_MODE4:
1069 		case mmGB_TILE_MODE5:
1070 		case mmGB_TILE_MODE6:
1071 		case mmGB_TILE_MODE7:
1072 		case mmGB_TILE_MODE8:
1073 		case mmGB_TILE_MODE9:
1074 		case mmGB_TILE_MODE10:
1075 		case mmGB_TILE_MODE11:
1076 		case mmGB_TILE_MODE12:
1077 		case mmGB_TILE_MODE13:
1078 		case mmGB_TILE_MODE14:
1079 		case mmGB_TILE_MODE15:
1080 		case mmGB_TILE_MODE16:
1081 		case mmGB_TILE_MODE17:
1082 		case mmGB_TILE_MODE18:
1083 		case mmGB_TILE_MODE19:
1084 		case mmGB_TILE_MODE20:
1085 		case mmGB_TILE_MODE21:
1086 		case mmGB_TILE_MODE22:
1087 		case mmGB_TILE_MODE23:
1088 		case mmGB_TILE_MODE24:
1089 		case mmGB_TILE_MODE25:
1090 		case mmGB_TILE_MODE26:
1091 		case mmGB_TILE_MODE27:
1092 		case mmGB_TILE_MODE28:
1093 		case mmGB_TILE_MODE29:
1094 		case mmGB_TILE_MODE30:
1095 		case mmGB_TILE_MODE31:
1096 			idx = (reg_offset - mmGB_TILE_MODE0);
1097 			return adev->gfx.config.tile_mode_array[idx];
1098 		default:
1099 			return RREG32(reg_offset);
1100 		}
1101 	}
1102 }
1103 static int si_read_register(struct amdgpu_device *adev, u32 se_num,
1104 			     u32 sh_num, u32 reg_offset, u32 *value)
1105 {
1106 	uint32_t i;
1107 
1108 	*value = 0;
1109 	for (i = 0; i < ARRAY_SIZE(si_allowed_read_registers); i++) {
1110 		bool indexed = si_allowed_read_registers[i].grbm_indexed;
1111 
1112 		if (reg_offset != si_allowed_read_registers[i].reg_offset)
1113 			continue;
1114 
1115 		*value = si_get_register_value(adev, indexed, se_num, sh_num,
1116 					       reg_offset);
1117 		return 0;
1118 	}
1119 	return -EINVAL;
1120 }
1121 
1122 static bool si_read_disabled_bios(struct amdgpu_device *adev)
1123 {
1124 	u32 bus_cntl;
1125 	u32 d1vga_control = 0;
1126 	u32 d2vga_control = 0;
1127 	u32 vga_render_control = 0;
1128 	u32 rom_cntl;
1129 	bool r;
1130 
1131 	bus_cntl = RREG32(R600_BUS_CNTL);
1132 	if (adev->mode_info.num_crtc) {
1133 		d1vga_control = RREG32(AVIVO_D1VGA_CONTROL);
1134 		d2vga_control = RREG32(AVIVO_D2VGA_CONTROL);
1135 		vga_render_control = RREG32(VGA_RENDER_CONTROL);
1136 	}
1137 	rom_cntl = RREG32(R600_ROM_CNTL);
1138 
1139 	/* enable the rom */
1140 	WREG32(R600_BUS_CNTL, (bus_cntl & ~R600_BIOS_ROM_DIS));
1141 	if (adev->mode_info.num_crtc) {
1142 		/* Disable VGA mode */
1143 		WREG32(AVIVO_D1VGA_CONTROL,
1144 		       (d1vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE |
1145 					  AVIVO_DVGA_CONTROL_TIMING_SELECT)));
1146 		WREG32(AVIVO_D2VGA_CONTROL,
1147 		       (d2vga_control & ~(AVIVO_DVGA_CONTROL_MODE_ENABLE |
1148 					  AVIVO_DVGA_CONTROL_TIMING_SELECT)));
1149 		WREG32(VGA_RENDER_CONTROL,
1150 		       (vga_render_control & C_000300_VGA_VSTATUS_CNTL));
1151 	}
1152 	WREG32(R600_ROM_CNTL, rom_cntl | R600_SCK_OVERWRITE);
1153 
1154 	r = amdgpu_read_bios(adev);
1155 
1156 	/* restore regs */
1157 	WREG32(R600_BUS_CNTL, bus_cntl);
1158 	if (adev->mode_info.num_crtc) {
1159 		WREG32(AVIVO_D1VGA_CONTROL, d1vga_control);
1160 		WREG32(AVIVO_D2VGA_CONTROL, d2vga_control);
1161 		WREG32(VGA_RENDER_CONTROL, vga_render_control);
1162 	}
1163 	WREG32(R600_ROM_CNTL, rom_cntl);
1164 	return r;
1165 }
1166 
1167 #define mmROM_INDEX 0x2A
1168 #define mmROM_DATA  0x2B
1169 
1170 static bool si_read_bios_from_rom(struct amdgpu_device *adev,
1171 				  u8 *bios, u32 length_bytes)
1172 {
1173 	u32 *dw_ptr;
1174 	u32 i, length_dw;
1175 
1176 	if (bios == NULL)
1177 		return false;
1178 	if (length_bytes == 0)
1179 		return false;
1180 	/* APU vbios image is part of sbios image */
1181 	if (adev->flags & AMD_IS_APU)
1182 		return false;
1183 
1184 	dw_ptr = (u32 *)bios;
1185 	length_dw = ALIGN(length_bytes, 4) / 4;
1186 	/* set rom index to 0 */
1187 	WREG32(mmROM_INDEX, 0);
1188 	for (i = 0; i < length_dw; i++)
1189 		dw_ptr[i] = RREG32(mmROM_DATA);
1190 
1191 	return true;
1192 }
1193 
1194 //xxx: not implemented
1195 static int si_asic_reset(struct amdgpu_device *adev)
1196 {
1197 	return 0;
1198 }
1199 
1200 static bool si_asic_supports_baco(struct amdgpu_device *adev)
1201 {
1202 	return false;
1203 }
1204 
1205 static enum amd_reset_method
1206 si_asic_reset_method(struct amdgpu_device *adev)
1207 {
1208 	return AMD_RESET_METHOD_LEGACY;
1209 }
1210 
1211 static u32 si_get_config_memsize(struct amdgpu_device *adev)
1212 {
1213 	return RREG32(mmCONFIG_MEMSIZE);
1214 }
1215 
1216 static void si_vga_set_state(struct amdgpu_device *adev, bool state)
1217 {
1218 	uint32_t temp;
1219 
1220 	temp = RREG32(CONFIG_CNTL);
1221 	if (state == false) {
1222 		temp &= ~(1<<0);
1223 		temp |= (1<<1);
1224 	} else {
1225 		temp &= ~(1<<1);
1226 	}
1227 	WREG32(CONFIG_CNTL, temp);
1228 }
1229 
1230 static u32 si_get_xclk(struct amdgpu_device *adev)
1231 {
1232         u32 reference_clock = adev->clock.spll.reference_freq;
1233 	u32 tmp;
1234 
1235 	tmp = RREG32(CG_CLKPIN_CNTL_2);
1236 	if (tmp & MUX_TCLK_TO_XCLK)
1237 		return TCLK;
1238 
1239 	tmp = RREG32(CG_CLKPIN_CNTL);
1240 	if (tmp & XTALIN_DIVIDE)
1241 		return reference_clock / 4;
1242 
1243 	return reference_clock;
1244 }
1245 
1246 //xxx:not implemented
1247 static int si_set_uvd_clocks(struct amdgpu_device *adev, u32 vclk, u32 dclk)
1248 {
1249 	return 0;
1250 }
1251 
1252 static void si_flush_hdp(struct amdgpu_device *adev, struct amdgpu_ring *ring)
1253 {
1254 	if (!ring || !ring->funcs->emit_wreg) {
1255 		WREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL, 1);
1256 		RREG32(mmHDP_MEM_COHERENCY_FLUSH_CNTL);
1257 	} else {
1258 		amdgpu_ring_emit_wreg(ring, mmHDP_MEM_COHERENCY_FLUSH_CNTL, 1);
1259 	}
1260 }
1261 
1262 static void si_invalidate_hdp(struct amdgpu_device *adev,
1263 			      struct amdgpu_ring *ring)
1264 {
1265 	if (!ring || !ring->funcs->emit_wreg) {
1266 		WREG32(mmHDP_DEBUG0, 1);
1267 		RREG32(mmHDP_DEBUG0);
1268 	} else {
1269 		amdgpu_ring_emit_wreg(ring, mmHDP_DEBUG0, 1);
1270 	}
1271 }
1272 
1273 static bool si_need_full_reset(struct amdgpu_device *adev)
1274 {
1275 	/* change this when we support soft reset */
1276 	return true;
1277 }
1278 
1279 static bool si_need_reset_on_init(struct amdgpu_device *adev)
1280 {
1281 	return false;
1282 }
1283 
1284 static int si_get_pcie_lanes(struct amdgpu_device *adev)
1285 {
1286 	u32 link_width_cntl;
1287 
1288 	if (adev->flags & AMD_IS_APU)
1289 		return 0;
1290 
1291 	link_width_cntl = RREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL);
1292 
1293 	switch ((link_width_cntl & LC_LINK_WIDTH_RD_MASK) >> LC_LINK_WIDTH_RD_SHIFT) {
1294 	case LC_LINK_WIDTH_X1:
1295 		return 1;
1296 	case LC_LINK_WIDTH_X2:
1297 		return 2;
1298 	case LC_LINK_WIDTH_X4:
1299 		return 4;
1300 	case LC_LINK_WIDTH_X8:
1301 		return 8;
1302 	case LC_LINK_WIDTH_X0:
1303 	case LC_LINK_WIDTH_X16:
1304 	default:
1305 		return 16;
1306 	}
1307 }
1308 
1309 static void si_set_pcie_lanes(struct amdgpu_device *adev, int lanes)
1310 {
1311 	u32 link_width_cntl, mask;
1312 
1313 	if (adev->flags & AMD_IS_APU)
1314 		return;
1315 
1316 	switch (lanes) {
1317 	case 0:
1318 		mask = LC_LINK_WIDTH_X0;
1319 		break;
1320 	case 1:
1321 		mask = LC_LINK_WIDTH_X1;
1322 		break;
1323 	case 2:
1324 		mask = LC_LINK_WIDTH_X2;
1325 		break;
1326 	case 4:
1327 		mask = LC_LINK_WIDTH_X4;
1328 		break;
1329 	case 8:
1330 		mask = LC_LINK_WIDTH_X8;
1331 		break;
1332 	case 16:
1333 		mask = LC_LINK_WIDTH_X16;
1334 		break;
1335 	default:
1336 		DRM_ERROR("invalid pcie lane request: %d\n", lanes);
1337 		return;
1338 	}
1339 
1340 	link_width_cntl = RREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL);
1341 	link_width_cntl &= ~LC_LINK_WIDTH_MASK;
1342 	link_width_cntl |= mask << LC_LINK_WIDTH_SHIFT;
1343 	link_width_cntl |= (LC_RECONFIG_NOW |
1344 			    LC_RECONFIG_ARC_MISSING_ESCAPE);
1345 
1346 	WREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL, link_width_cntl);
1347 }
1348 
1349 static void si_get_pcie_usage(struct amdgpu_device *adev, uint64_t *count0,
1350 			      uint64_t *count1)
1351 {
1352 	uint32_t perfctr = 0;
1353 	uint64_t cnt0_of, cnt1_of;
1354 	int tmp;
1355 
1356 	/* This reports 0 on APUs, so return to avoid writing/reading registers
1357 	 * that may or may not be different from their GPU counterparts
1358 	 */
1359 	if (adev->flags & AMD_IS_APU)
1360 		return;
1361 
1362 	/* Set the 2 events that we wish to watch, defined above */
1363 	/* Reg 40 is # received msgs, Reg 104 is # of posted requests sent */
1364 	perfctr = REG_SET_FIELD(perfctr, PCIE_PERF_CNTL_TXCLK, EVENT0_SEL, 40);
1365 	perfctr = REG_SET_FIELD(perfctr, PCIE_PERF_CNTL_TXCLK, EVENT1_SEL, 104);
1366 
1367 	/* Write to enable desired perf counters */
1368 	WREG32_PCIE(ixPCIE_PERF_CNTL_TXCLK, perfctr);
1369 	/* Zero out and enable the perf counters
1370 	 * Write 0x5:
1371 	 * Bit 0 = Start all counters(1)
1372 	 * Bit 2 = Global counter reset enable(1)
1373 	 */
1374 	WREG32_PCIE(ixPCIE_PERF_COUNT_CNTL, 0x00000005);
1375 
1376 	msleep(1000);
1377 
1378 	/* Load the shadow and disable the perf counters
1379 	 * Write 0x2:
1380 	 * Bit 0 = Stop counters(0)
1381 	 * Bit 1 = Load the shadow counters(1)
1382 	 */
1383 	WREG32_PCIE(ixPCIE_PERF_COUNT_CNTL, 0x00000002);
1384 
1385 	/* Read register values to get any >32bit overflow */
1386 	tmp = RREG32_PCIE(ixPCIE_PERF_CNTL_TXCLK);
1387 	cnt0_of = REG_GET_FIELD(tmp, PCIE_PERF_CNTL_TXCLK, COUNTER0_UPPER);
1388 	cnt1_of = REG_GET_FIELD(tmp, PCIE_PERF_CNTL_TXCLK, COUNTER1_UPPER);
1389 
1390 	/* Get the values and add the overflow */
1391 	*count0 = RREG32_PCIE(ixPCIE_PERF_COUNT0_TXCLK) | (cnt0_of << 32);
1392 	*count1 = RREG32_PCIE(ixPCIE_PERF_COUNT1_TXCLK) | (cnt1_of << 32);
1393 }
1394 
1395 static uint64_t si_get_pcie_replay_count(struct amdgpu_device *adev)
1396 {
1397 	uint64_t nak_r, nak_g;
1398 
1399 	/* Get the number of NAKs received and generated */
1400 	nak_r = RREG32_PCIE(ixPCIE_RX_NUM_NAK);
1401 	nak_g = RREG32_PCIE(ixPCIE_RX_NUM_NAK_GENERATED);
1402 
1403 	/* Add the total number of NAKs, i.e the number of replays */
1404 	return (nak_r + nak_g);
1405 }
1406 
1407 static const struct amdgpu_asic_funcs si_asic_funcs =
1408 {
1409 	.read_disabled_bios = &si_read_disabled_bios,
1410 	.read_bios_from_rom = &si_read_bios_from_rom,
1411 	.read_register = &si_read_register,
1412 	.reset = &si_asic_reset,
1413 	.reset_method = &si_asic_reset_method,
1414 	.set_vga_state = &si_vga_set_state,
1415 	.get_xclk = &si_get_xclk,
1416 	.set_uvd_clocks = &si_set_uvd_clocks,
1417 	.set_vce_clocks = NULL,
1418 	.get_pcie_lanes = &si_get_pcie_lanes,
1419 	.set_pcie_lanes = &si_set_pcie_lanes,
1420 	.get_config_memsize = &si_get_config_memsize,
1421 	.flush_hdp = &si_flush_hdp,
1422 	.invalidate_hdp = &si_invalidate_hdp,
1423 	.need_full_reset = &si_need_full_reset,
1424 	.get_pcie_usage = &si_get_pcie_usage,
1425 	.need_reset_on_init = &si_need_reset_on_init,
1426 	.get_pcie_replay_count = &si_get_pcie_replay_count,
1427 	.supports_baco = &si_asic_supports_baco,
1428 };
1429 
1430 static uint32_t si_get_rev_id(struct amdgpu_device *adev)
1431 {
1432 	return (RREG32(CC_DRM_ID_STRAPS) & CC_DRM_ID_STRAPS__ATI_REV_ID_MASK)
1433 		>> CC_DRM_ID_STRAPS__ATI_REV_ID__SHIFT;
1434 }
1435 
1436 static int si_common_early_init(void *handle)
1437 {
1438 	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
1439 
1440 	adev->smc_rreg = &si_smc_rreg;
1441 	adev->smc_wreg = &si_smc_wreg;
1442 	adev->pcie_rreg = &si_pcie_rreg;
1443 	adev->pcie_wreg = &si_pcie_wreg;
1444 	adev->pciep_rreg = &si_pciep_rreg;
1445 	adev->pciep_wreg = &si_pciep_wreg;
1446 	adev->uvd_ctx_rreg = NULL;
1447 	adev->uvd_ctx_wreg = NULL;
1448 	adev->didt_rreg = NULL;
1449 	adev->didt_wreg = NULL;
1450 
1451 	adev->asic_funcs = &si_asic_funcs;
1452 
1453 	adev->rev_id = si_get_rev_id(adev);
1454 	adev->external_rev_id = 0xFF;
1455 	switch (adev->asic_type) {
1456 	case CHIP_TAHITI:
1457 		adev->cg_flags =
1458 			AMD_CG_SUPPORT_GFX_MGCG |
1459 			AMD_CG_SUPPORT_GFX_MGLS |
1460 			/*AMD_CG_SUPPORT_GFX_CGCG |*/
1461 			AMD_CG_SUPPORT_GFX_CGLS |
1462 			AMD_CG_SUPPORT_GFX_CGTS |
1463 			AMD_CG_SUPPORT_GFX_CP_LS |
1464 			AMD_CG_SUPPORT_MC_MGCG |
1465 			AMD_CG_SUPPORT_SDMA_MGCG |
1466 			AMD_CG_SUPPORT_BIF_LS |
1467 			AMD_CG_SUPPORT_VCE_MGCG |
1468 			AMD_CG_SUPPORT_UVD_MGCG |
1469 			AMD_CG_SUPPORT_HDP_LS |
1470 			AMD_CG_SUPPORT_HDP_MGCG;
1471 		adev->pg_flags = 0;
1472 		adev->external_rev_id = (adev->rev_id == 0) ? 1 :
1473 					(adev->rev_id == 1) ? 5 : 6;
1474 		break;
1475 	case CHIP_PITCAIRN:
1476 		adev->cg_flags =
1477 			AMD_CG_SUPPORT_GFX_MGCG |
1478 			AMD_CG_SUPPORT_GFX_MGLS |
1479 			/*AMD_CG_SUPPORT_GFX_CGCG |*/
1480 			AMD_CG_SUPPORT_GFX_CGLS |
1481 			AMD_CG_SUPPORT_GFX_CGTS |
1482 			AMD_CG_SUPPORT_GFX_CP_LS |
1483 			AMD_CG_SUPPORT_GFX_RLC_LS |
1484 			AMD_CG_SUPPORT_MC_LS |
1485 			AMD_CG_SUPPORT_MC_MGCG |
1486 			AMD_CG_SUPPORT_SDMA_MGCG |
1487 			AMD_CG_SUPPORT_BIF_LS |
1488 			AMD_CG_SUPPORT_VCE_MGCG |
1489 			AMD_CG_SUPPORT_UVD_MGCG |
1490 			AMD_CG_SUPPORT_HDP_LS |
1491 			AMD_CG_SUPPORT_HDP_MGCG;
1492 		adev->pg_flags = 0;
1493 		adev->external_rev_id = adev->rev_id + 20;
1494 		break;
1495 
1496 	case CHIP_VERDE:
1497 		adev->cg_flags =
1498 			AMD_CG_SUPPORT_GFX_MGCG |
1499 			AMD_CG_SUPPORT_GFX_MGLS |
1500 			AMD_CG_SUPPORT_GFX_CGLS |
1501 			AMD_CG_SUPPORT_GFX_CGTS |
1502 			AMD_CG_SUPPORT_GFX_CGTS_LS |
1503 			AMD_CG_SUPPORT_GFX_CP_LS |
1504 			AMD_CG_SUPPORT_MC_LS |
1505 			AMD_CG_SUPPORT_MC_MGCG |
1506 			AMD_CG_SUPPORT_SDMA_MGCG |
1507 			AMD_CG_SUPPORT_SDMA_LS |
1508 			AMD_CG_SUPPORT_BIF_LS |
1509 			AMD_CG_SUPPORT_VCE_MGCG |
1510 			AMD_CG_SUPPORT_UVD_MGCG |
1511 			AMD_CG_SUPPORT_HDP_LS |
1512 			AMD_CG_SUPPORT_HDP_MGCG;
1513 		adev->pg_flags = 0;
1514 		//???
1515 		adev->external_rev_id = adev->rev_id + 40;
1516 		break;
1517 	case CHIP_OLAND:
1518 		adev->cg_flags =
1519 			AMD_CG_SUPPORT_GFX_MGCG |
1520 			AMD_CG_SUPPORT_GFX_MGLS |
1521 			/*AMD_CG_SUPPORT_GFX_CGCG |*/
1522 			AMD_CG_SUPPORT_GFX_CGLS |
1523 			AMD_CG_SUPPORT_GFX_CGTS |
1524 			AMD_CG_SUPPORT_GFX_CP_LS |
1525 			AMD_CG_SUPPORT_GFX_RLC_LS |
1526 			AMD_CG_SUPPORT_MC_LS |
1527 			AMD_CG_SUPPORT_MC_MGCG |
1528 			AMD_CG_SUPPORT_SDMA_MGCG |
1529 			AMD_CG_SUPPORT_BIF_LS |
1530 			AMD_CG_SUPPORT_UVD_MGCG |
1531 			AMD_CG_SUPPORT_HDP_LS |
1532 			AMD_CG_SUPPORT_HDP_MGCG;
1533 		adev->pg_flags = 0;
1534 		adev->external_rev_id = 60;
1535 		break;
1536 	case CHIP_HAINAN:
1537 		adev->cg_flags =
1538 			AMD_CG_SUPPORT_GFX_MGCG |
1539 			AMD_CG_SUPPORT_GFX_MGLS |
1540 			/*AMD_CG_SUPPORT_GFX_CGCG |*/
1541 			AMD_CG_SUPPORT_GFX_CGLS |
1542 			AMD_CG_SUPPORT_GFX_CGTS |
1543 			AMD_CG_SUPPORT_GFX_CP_LS |
1544 			AMD_CG_SUPPORT_GFX_RLC_LS |
1545 			AMD_CG_SUPPORT_MC_LS |
1546 			AMD_CG_SUPPORT_MC_MGCG |
1547 			AMD_CG_SUPPORT_SDMA_MGCG |
1548 			AMD_CG_SUPPORT_BIF_LS |
1549 			AMD_CG_SUPPORT_HDP_LS |
1550 			AMD_CG_SUPPORT_HDP_MGCG;
1551 		adev->pg_flags = 0;
1552 		adev->external_rev_id = 70;
1553 		break;
1554 
1555 	default:
1556 		return -EINVAL;
1557 	}
1558 
1559 	return 0;
1560 }
1561 
1562 static int si_common_sw_init(void *handle)
1563 {
1564 	return 0;
1565 }
1566 
1567 static int si_common_sw_fini(void *handle)
1568 {
1569 	return 0;
1570 }
1571 
1572 
1573 static void si_init_golden_registers(struct amdgpu_device *adev)
1574 {
1575 	switch (adev->asic_type) {
1576 	case CHIP_TAHITI:
1577 		amdgpu_device_program_register_sequence(adev,
1578 							tahiti_golden_registers,
1579 							ARRAY_SIZE(tahiti_golden_registers));
1580 		amdgpu_device_program_register_sequence(adev,
1581 							tahiti_golden_rlc_registers,
1582 							ARRAY_SIZE(tahiti_golden_rlc_registers));
1583 		amdgpu_device_program_register_sequence(adev,
1584 							tahiti_mgcg_cgcg_init,
1585 							ARRAY_SIZE(tahiti_mgcg_cgcg_init));
1586 		amdgpu_device_program_register_sequence(adev,
1587 							tahiti_golden_registers2,
1588 							ARRAY_SIZE(tahiti_golden_registers2));
1589 		break;
1590 	case CHIP_PITCAIRN:
1591 		amdgpu_device_program_register_sequence(adev,
1592 							pitcairn_golden_registers,
1593 							ARRAY_SIZE(pitcairn_golden_registers));
1594 		amdgpu_device_program_register_sequence(adev,
1595 							pitcairn_golden_rlc_registers,
1596 							ARRAY_SIZE(pitcairn_golden_rlc_registers));
1597 		amdgpu_device_program_register_sequence(adev,
1598 							pitcairn_mgcg_cgcg_init,
1599 							ARRAY_SIZE(pitcairn_mgcg_cgcg_init));
1600 		break;
1601 	case CHIP_VERDE:
1602 		amdgpu_device_program_register_sequence(adev,
1603 							verde_golden_registers,
1604 							ARRAY_SIZE(verde_golden_registers));
1605 		amdgpu_device_program_register_sequence(adev,
1606 							verde_golden_rlc_registers,
1607 							ARRAY_SIZE(verde_golden_rlc_registers));
1608 		amdgpu_device_program_register_sequence(adev,
1609 							verde_mgcg_cgcg_init,
1610 							ARRAY_SIZE(verde_mgcg_cgcg_init));
1611 		amdgpu_device_program_register_sequence(adev,
1612 							verde_pg_init,
1613 							ARRAY_SIZE(verde_pg_init));
1614 		break;
1615 	case CHIP_OLAND:
1616 		amdgpu_device_program_register_sequence(adev,
1617 							oland_golden_registers,
1618 							ARRAY_SIZE(oland_golden_registers));
1619 		amdgpu_device_program_register_sequence(adev,
1620 							oland_golden_rlc_registers,
1621 							ARRAY_SIZE(oland_golden_rlc_registers));
1622 		amdgpu_device_program_register_sequence(adev,
1623 							oland_mgcg_cgcg_init,
1624 							ARRAY_SIZE(oland_mgcg_cgcg_init));
1625 		break;
1626 	case CHIP_HAINAN:
1627 		amdgpu_device_program_register_sequence(adev,
1628 							hainan_golden_registers,
1629 							ARRAY_SIZE(hainan_golden_registers));
1630 		amdgpu_device_program_register_sequence(adev,
1631 							hainan_golden_registers2,
1632 							ARRAY_SIZE(hainan_golden_registers2));
1633 		amdgpu_device_program_register_sequence(adev,
1634 							hainan_mgcg_cgcg_init,
1635 							ARRAY_SIZE(hainan_mgcg_cgcg_init));
1636 		break;
1637 
1638 
1639 	default:
1640 		BUG();
1641 	}
1642 }
1643 
1644 static void si_pcie_gen3_enable(struct amdgpu_device *adev)
1645 {
1646 	struct pci_dev *root = adev->pdev->bus->self;
1647 	u32 speed_cntl, current_data_rate;
1648 	int i;
1649 	u16 tmp16;
1650 
1651 	if (pci_is_root_bus(adev->pdev->bus))
1652 		return;
1653 
1654 	if (amdgpu_pcie_gen2 == 0)
1655 		return;
1656 
1657 	if (adev->flags & AMD_IS_APU)
1658 		return;
1659 
1660 	if (!(adev->pm.pcie_gen_mask & (CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2 |
1661 					CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3)))
1662 		return;
1663 
1664 	speed_cntl = RREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL);
1665 	current_data_rate = (speed_cntl & LC_CURRENT_DATA_RATE_MASK) >>
1666 		LC_CURRENT_DATA_RATE_SHIFT;
1667 	if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3) {
1668 		if (current_data_rate == 2) {
1669 			DRM_INFO("PCIE gen 3 link speeds already enabled\n");
1670 			return;
1671 		}
1672 		DRM_INFO("enabling PCIE gen 3 link speeds, disable with amdgpu.pcie_gen2=0\n");
1673 	} else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2) {
1674 		if (current_data_rate == 1) {
1675 			DRM_INFO("PCIE gen 2 link speeds already enabled\n");
1676 			return;
1677 		}
1678 		DRM_INFO("enabling PCIE gen 2 link speeds, disable with amdgpu.pcie_gen2=0\n");
1679 	}
1680 
1681 	if (!pci_is_pcie(root) || !pci_is_pcie(adev->pdev))
1682 		return;
1683 
1684 	if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3) {
1685 		if (current_data_rate != 2) {
1686 			u16 bridge_cfg, gpu_cfg;
1687 			u16 bridge_cfg2, gpu_cfg2;
1688 			u32 max_lw, current_lw, tmp;
1689 
1690 			pcie_capability_read_word(root, PCI_EXP_LNKCTL,
1691 						  &bridge_cfg);
1692 			pcie_capability_read_word(adev->pdev, PCI_EXP_LNKCTL,
1693 						  &gpu_cfg);
1694 
1695 			tmp16 = bridge_cfg | PCI_EXP_LNKCTL_HAWD;
1696 			pcie_capability_write_word(root, PCI_EXP_LNKCTL, tmp16);
1697 
1698 			tmp16 = gpu_cfg | PCI_EXP_LNKCTL_HAWD;
1699 			pcie_capability_write_word(adev->pdev, PCI_EXP_LNKCTL,
1700 						   tmp16);
1701 
1702 			tmp = RREG32_PCIE(PCIE_LC_STATUS1);
1703 			max_lw = (tmp & LC_DETECTED_LINK_WIDTH_MASK) >> LC_DETECTED_LINK_WIDTH_SHIFT;
1704 			current_lw = (tmp & LC_OPERATING_LINK_WIDTH_MASK) >> LC_OPERATING_LINK_WIDTH_SHIFT;
1705 
1706 			if (current_lw < max_lw) {
1707 				tmp = RREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL);
1708 				if (tmp & LC_RENEGOTIATION_SUPPORT) {
1709 					tmp &= ~(LC_LINK_WIDTH_MASK | LC_UPCONFIGURE_DIS);
1710 					tmp |= (max_lw << LC_LINK_WIDTH_SHIFT);
1711 					tmp |= LC_UPCONFIGURE_SUPPORT | LC_RENEGOTIATE_EN | LC_RECONFIG_NOW;
1712 					WREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL, tmp);
1713 				}
1714 			}
1715 
1716 			for (i = 0; i < 10; i++) {
1717 				pcie_capability_read_word(adev->pdev,
1718 							  PCI_EXP_DEVSTA,
1719 							  &tmp16);
1720 				if (tmp16 & PCI_EXP_DEVSTA_TRPND)
1721 					break;
1722 
1723 				pcie_capability_read_word(root, PCI_EXP_LNKCTL,
1724 							  &bridge_cfg);
1725 				pcie_capability_read_word(adev->pdev,
1726 							  PCI_EXP_LNKCTL,
1727 							  &gpu_cfg);
1728 
1729 				pcie_capability_read_word(root, PCI_EXP_LNKCTL2,
1730 							  &bridge_cfg2);
1731 				pcie_capability_read_word(adev->pdev,
1732 							  PCI_EXP_LNKCTL2,
1733 							  &gpu_cfg2);
1734 
1735 				tmp = RREG32_PCIE_PORT(PCIE_LC_CNTL4);
1736 				tmp |= LC_SET_QUIESCE;
1737 				WREG32_PCIE_PORT(PCIE_LC_CNTL4, tmp);
1738 
1739 				tmp = RREG32_PCIE_PORT(PCIE_LC_CNTL4);
1740 				tmp |= LC_REDO_EQ;
1741 				WREG32_PCIE_PORT(PCIE_LC_CNTL4, tmp);
1742 
1743 				mdelay(100);
1744 
1745 				pcie_capability_read_word(root, PCI_EXP_LNKCTL,
1746 							  &tmp16);
1747 				tmp16 &= ~PCI_EXP_LNKCTL_HAWD;
1748 				tmp16 |= (bridge_cfg & PCI_EXP_LNKCTL_HAWD);
1749 				pcie_capability_write_word(root, PCI_EXP_LNKCTL,
1750 							   tmp16);
1751 
1752 				pcie_capability_read_word(adev->pdev,
1753 							  PCI_EXP_LNKCTL,
1754 							  &tmp16);
1755 				tmp16 &= ~PCI_EXP_LNKCTL_HAWD;
1756 				tmp16 |= (gpu_cfg & PCI_EXP_LNKCTL_HAWD);
1757 				pcie_capability_write_word(adev->pdev,
1758 							   PCI_EXP_LNKCTL,
1759 							   tmp16);
1760 
1761 				pcie_capability_read_word(root, PCI_EXP_LNKCTL2,
1762 							  &tmp16);
1763 				tmp16 &= ~(PCI_EXP_LNKCTL2_ENTER_COMP |
1764 					   PCI_EXP_LNKCTL2_TX_MARGIN);
1765 				tmp16 |= (bridge_cfg2 &
1766 					  (PCI_EXP_LNKCTL2_ENTER_COMP |
1767 					   PCI_EXP_LNKCTL2_TX_MARGIN));
1768 				pcie_capability_write_word(root,
1769 							   PCI_EXP_LNKCTL2,
1770 							   tmp16);
1771 
1772 				pcie_capability_read_word(adev->pdev,
1773 							  PCI_EXP_LNKCTL2,
1774 							  &tmp16);
1775 				tmp16 &= ~(PCI_EXP_LNKCTL2_ENTER_COMP |
1776 					   PCI_EXP_LNKCTL2_TX_MARGIN);
1777 				tmp16 |= (gpu_cfg2 &
1778 					  (PCI_EXP_LNKCTL2_ENTER_COMP |
1779 					   PCI_EXP_LNKCTL2_TX_MARGIN));
1780 				pcie_capability_write_word(adev->pdev,
1781 							   PCI_EXP_LNKCTL2,
1782 							   tmp16);
1783 
1784 				tmp = RREG32_PCIE_PORT(PCIE_LC_CNTL4);
1785 				tmp &= ~LC_SET_QUIESCE;
1786 				WREG32_PCIE_PORT(PCIE_LC_CNTL4, tmp);
1787 			}
1788 		}
1789 	}
1790 
1791 	speed_cntl |= LC_FORCE_EN_SW_SPEED_CHANGE | LC_FORCE_DIS_HW_SPEED_CHANGE;
1792 	speed_cntl &= ~LC_FORCE_DIS_SW_SPEED_CHANGE;
1793 	WREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL, speed_cntl);
1794 
1795 	pcie_capability_read_word(adev->pdev, PCI_EXP_LNKCTL2, &tmp16);
1796 	tmp16 &= ~PCI_EXP_LNKCTL2_TLS;
1797 
1798 	if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN3)
1799 		tmp16 |= PCI_EXP_LNKCTL2_TLS_8_0GT; /* gen3 */
1800 	else if (adev->pm.pcie_gen_mask & CAIL_PCIE_LINK_SPEED_SUPPORT_GEN2)
1801 		tmp16 |= PCI_EXP_LNKCTL2_TLS_5_0GT; /* gen2 */
1802 	else
1803 		tmp16 |= PCI_EXP_LNKCTL2_TLS_2_5GT; /* gen1 */
1804 	pcie_capability_write_word(adev->pdev, PCI_EXP_LNKCTL2, tmp16);
1805 
1806 	speed_cntl = RREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL);
1807 	speed_cntl |= LC_INITIATE_LINK_SPEED_CHANGE;
1808 	WREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL, speed_cntl);
1809 
1810 	for (i = 0; i < adev->usec_timeout; i++) {
1811 		speed_cntl = RREG32_PCIE_PORT(PCIE_LC_SPEED_CNTL);
1812 		if ((speed_cntl & LC_INITIATE_LINK_SPEED_CHANGE) == 0)
1813 			break;
1814 		udelay(1);
1815 	}
1816 }
1817 
1818 static inline u32 si_pif_phy0_rreg(struct amdgpu_device *adev, u32 reg)
1819 {
1820 	unsigned long flags;
1821 	u32 r;
1822 
1823 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1824 	WREG32(EVERGREEN_PIF_PHY0_INDEX, ((reg) & 0xffff));
1825 	r = RREG32(EVERGREEN_PIF_PHY0_DATA);
1826 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1827 	return r;
1828 }
1829 
1830 static inline void si_pif_phy0_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
1831 {
1832 	unsigned long flags;
1833 
1834 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1835 	WREG32(EVERGREEN_PIF_PHY0_INDEX, ((reg) & 0xffff));
1836 	WREG32(EVERGREEN_PIF_PHY0_DATA, (v));
1837 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1838 }
1839 
1840 static inline u32 si_pif_phy1_rreg(struct amdgpu_device *adev, u32 reg)
1841 {
1842 	unsigned long flags;
1843 	u32 r;
1844 
1845 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1846 	WREG32(EVERGREEN_PIF_PHY1_INDEX, ((reg) & 0xffff));
1847 	r = RREG32(EVERGREEN_PIF_PHY1_DATA);
1848 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1849 	return r;
1850 }
1851 
1852 static inline void si_pif_phy1_wreg(struct amdgpu_device *adev, u32 reg, u32 v)
1853 {
1854 	unsigned long flags;
1855 
1856 	spin_lock_irqsave(&adev->pcie_idx_lock, flags);
1857 	WREG32(EVERGREEN_PIF_PHY1_INDEX, ((reg) & 0xffff));
1858 	WREG32(EVERGREEN_PIF_PHY1_DATA, (v));
1859 	spin_unlock_irqrestore(&adev->pcie_idx_lock, flags);
1860 }
1861 static void si_program_aspm(struct amdgpu_device *adev)
1862 {
1863 	u32 data, orig;
1864 	bool disable_l0s = false, disable_l1 = false, disable_plloff_in_l1 = false;
1865 	bool disable_clkreq = false;
1866 
1867 	if (amdgpu_aspm == 0)
1868 		return;
1869 
1870 	if (adev->flags & AMD_IS_APU)
1871 		return;
1872 	orig = data = RREG32_PCIE_PORT(PCIE_LC_N_FTS_CNTL);
1873 	data &= ~LC_XMIT_N_FTS_MASK;
1874 	data |= LC_XMIT_N_FTS(0x24) | LC_XMIT_N_FTS_OVERRIDE_EN;
1875 	if (orig != data)
1876 		WREG32_PCIE_PORT(PCIE_LC_N_FTS_CNTL, data);
1877 
1878 	orig = data = RREG32_PCIE_PORT(PCIE_LC_CNTL3);
1879 	data |= LC_GO_TO_RECOVERY;
1880 	if (orig != data)
1881 		WREG32_PCIE_PORT(PCIE_LC_CNTL3, data);
1882 
1883 	orig = data = RREG32_PCIE(PCIE_P_CNTL);
1884 	data |= P_IGNORE_EDB_ERR;
1885 	if (orig != data)
1886 		WREG32_PCIE(PCIE_P_CNTL, data);
1887 
1888 	orig = data = RREG32_PCIE_PORT(PCIE_LC_CNTL);
1889 	data &= ~(LC_L0S_INACTIVITY_MASK | LC_L1_INACTIVITY_MASK);
1890 	data |= LC_PMI_TO_L1_DIS;
1891 	if (!disable_l0s)
1892 		data |= LC_L0S_INACTIVITY(7);
1893 
1894 	if (!disable_l1) {
1895 		data |= LC_L1_INACTIVITY(7);
1896 		data &= ~LC_PMI_TO_L1_DIS;
1897 		if (orig != data)
1898 			WREG32_PCIE_PORT(PCIE_LC_CNTL, data);
1899 
1900 		if (!disable_plloff_in_l1) {
1901 			bool clk_req_support;
1902 
1903 			orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_0);
1904 			data &= ~(PLL_POWER_STATE_IN_OFF_0_MASK | PLL_POWER_STATE_IN_TXS2_0_MASK);
1905 			data |= PLL_POWER_STATE_IN_OFF_0(7) | PLL_POWER_STATE_IN_TXS2_0(7);
1906 			if (orig != data)
1907 				si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_0, data);
1908 
1909 			orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_1);
1910 			data &= ~(PLL_POWER_STATE_IN_OFF_1_MASK | PLL_POWER_STATE_IN_TXS2_1_MASK);
1911 			data |= PLL_POWER_STATE_IN_OFF_1(7) | PLL_POWER_STATE_IN_TXS2_1(7);
1912 			if (orig != data)
1913 				si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_1, data);
1914 
1915 			orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_0);
1916 			data &= ~(PLL_POWER_STATE_IN_OFF_0_MASK | PLL_POWER_STATE_IN_TXS2_0_MASK);
1917 			data |= PLL_POWER_STATE_IN_OFF_0(7) | PLL_POWER_STATE_IN_TXS2_0(7);
1918 			if (orig != data)
1919 				si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_0, data);
1920 
1921 			orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_1);
1922 			data &= ~(PLL_POWER_STATE_IN_OFF_1_MASK | PLL_POWER_STATE_IN_TXS2_1_MASK);
1923 			data |= PLL_POWER_STATE_IN_OFF_1(7) | PLL_POWER_STATE_IN_TXS2_1(7);
1924 			if (orig != data)
1925 				si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_1, data);
1926 
1927 			if ((adev->asic_type != CHIP_OLAND) && (adev->asic_type != CHIP_HAINAN)) {
1928 				orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_0);
1929 				data &= ~PLL_RAMP_UP_TIME_0_MASK;
1930 				if (orig != data)
1931 					si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_0, data);
1932 
1933 				orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_1);
1934 				data &= ~PLL_RAMP_UP_TIME_1_MASK;
1935 				if (orig != data)
1936 					si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_1, data);
1937 
1938 				orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_2);
1939 				data &= ~PLL_RAMP_UP_TIME_2_MASK;
1940 				if (orig != data)
1941 					si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_2, data);
1942 
1943 				orig = data = si_pif_phy0_rreg(adev,PB0_PIF_PWRDOWN_3);
1944 				data &= ~PLL_RAMP_UP_TIME_3_MASK;
1945 				if (orig != data)
1946 					si_pif_phy0_wreg(adev,PB0_PIF_PWRDOWN_3, data);
1947 
1948 				orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_0);
1949 				data &= ~PLL_RAMP_UP_TIME_0_MASK;
1950 				if (orig != data)
1951 					si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_0, data);
1952 
1953 				orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_1);
1954 				data &= ~PLL_RAMP_UP_TIME_1_MASK;
1955 				if (orig != data)
1956 					si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_1, data);
1957 
1958 				orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_2);
1959 				data &= ~PLL_RAMP_UP_TIME_2_MASK;
1960 				if (orig != data)
1961 					si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_2, data);
1962 
1963 				orig = data = si_pif_phy1_rreg(adev,PB1_PIF_PWRDOWN_3);
1964 				data &= ~PLL_RAMP_UP_TIME_3_MASK;
1965 				if (orig != data)
1966 					si_pif_phy1_wreg(adev,PB1_PIF_PWRDOWN_3, data);
1967 			}
1968 			orig = data = RREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL);
1969 			data &= ~LC_DYN_LANES_PWR_STATE_MASK;
1970 			data |= LC_DYN_LANES_PWR_STATE(3);
1971 			if (orig != data)
1972 				WREG32_PCIE_PORT(PCIE_LC_LINK_WIDTH_CNTL, data);
1973 
1974 			orig = data = si_pif_phy0_rreg(adev,PB0_PIF_CNTL);
1975 			data &= ~LS2_EXIT_TIME_MASK;
1976 			if ((adev->asic_type == CHIP_OLAND) || (adev->asic_type == CHIP_HAINAN))
1977 				data |= LS2_EXIT_TIME(5);
1978 			if (orig != data)
1979 				si_pif_phy0_wreg(adev,PB0_PIF_CNTL, data);
1980 
1981 			orig = data = si_pif_phy1_rreg(adev,PB1_PIF_CNTL);
1982 			data &= ~LS2_EXIT_TIME_MASK;
1983 			if ((adev->asic_type == CHIP_OLAND) || (adev->asic_type == CHIP_HAINAN))
1984 				data |= LS2_EXIT_TIME(5);
1985 			if (orig != data)
1986 				si_pif_phy1_wreg(adev,PB1_PIF_CNTL, data);
1987 
1988 			if (!disable_clkreq &&
1989 			    !pci_is_root_bus(adev->pdev->bus)) {
1990 				struct pci_dev *root = adev->pdev->bus->self;
1991 				u32 lnkcap;
1992 
1993 				clk_req_support = false;
1994 				pcie_capability_read_dword(root, PCI_EXP_LNKCAP, &lnkcap);
1995 				if (lnkcap & PCI_EXP_LNKCAP_CLKPM)
1996 					clk_req_support = true;
1997 			} else {
1998 				clk_req_support = false;
1999 			}
2000 
2001 			if (clk_req_support) {
2002 				orig = data = RREG32_PCIE_PORT(PCIE_LC_CNTL2);
2003 				data |= LC_ALLOW_PDWN_IN_L1 | LC_ALLOW_PDWN_IN_L23;
2004 				if (orig != data)
2005 					WREG32_PCIE_PORT(PCIE_LC_CNTL2, data);
2006 
2007 				orig = data = RREG32(THM_CLK_CNTL);
2008 				data &= ~(CMON_CLK_SEL_MASK | TMON_CLK_SEL_MASK);
2009 				data |= CMON_CLK_SEL(1) | TMON_CLK_SEL(1);
2010 				if (orig != data)
2011 					WREG32(THM_CLK_CNTL, data);
2012 
2013 				orig = data = RREG32(MISC_CLK_CNTL);
2014 				data &= ~(DEEP_SLEEP_CLK_SEL_MASK | ZCLK_SEL_MASK);
2015 				data |= DEEP_SLEEP_CLK_SEL(1) | ZCLK_SEL(1);
2016 				if (orig != data)
2017 					WREG32(MISC_CLK_CNTL, data);
2018 
2019 				orig = data = RREG32(CG_CLKPIN_CNTL);
2020 				data &= ~BCLK_AS_XCLK;
2021 				if (orig != data)
2022 					WREG32(CG_CLKPIN_CNTL, data);
2023 
2024 				orig = data = RREG32(CG_CLKPIN_CNTL_2);
2025 				data &= ~FORCE_BIF_REFCLK_EN;
2026 				if (orig != data)
2027 					WREG32(CG_CLKPIN_CNTL_2, data);
2028 
2029 				orig = data = RREG32(MPLL_BYPASSCLK_SEL);
2030 				data &= ~MPLL_CLKOUT_SEL_MASK;
2031 				data |= MPLL_CLKOUT_SEL(4);
2032 				if (orig != data)
2033 					WREG32(MPLL_BYPASSCLK_SEL, data);
2034 
2035 				orig = data = RREG32(SPLL_CNTL_MODE);
2036 				data &= ~SPLL_REFCLK_SEL_MASK;
2037 				if (orig != data)
2038 					WREG32(SPLL_CNTL_MODE, data);
2039 			}
2040 		}
2041 	} else {
2042 		if (orig != data)
2043 			WREG32_PCIE_PORT(PCIE_LC_CNTL, data);
2044 	}
2045 
2046 	orig = data = RREG32_PCIE(PCIE_CNTL2);
2047 	data |= SLV_MEM_LS_EN | MST_MEM_LS_EN | REPLAY_MEM_LS_EN;
2048 	if (orig != data)
2049 		WREG32_PCIE(PCIE_CNTL2, data);
2050 
2051 	if (!disable_l0s) {
2052 		data = RREG32_PCIE_PORT(PCIE_LC_N_FTS_CNTL);
2053 		if((data & LC_N_FTS_MASK) == LC_N_FTS_MASK) {
2054 			data = RREG32_PCIE(PCIE_LC_STATUS1);
2055 			if ((data & LC_REVERSE_XMIT) && (data & LC_REVERSE_RCVR)) {
2056 				orig = data = RREG32_PCIE_PORT(PCIE_LC_CNTL);
2057 				data &= ~LC_L0S_INACTIVITY_MASK;
2058 				if (orig != data)
2059 					WREG32_PCIE_PORT(PCIE_LC_CNTL, data);
2060 			}
2061 		}
2062 	}
2063 }
2064 
2065 static void si_fix_pci_max_read_req_size(struct amdgpu_device *adev)
2066 {
2067 	int readrq;
2068 	u16 v;
2069 
2070 	readrq = pcie_get_readrq(adev->pdev);
2071 	v = ffs(readrq) - 8;
2072 	if ((v == 0) || (v == 6) || (v == 7))
2073 		pcie_set_readrq(adev->pdev, 512);
2074 }
2075 
2076 static int si_common_hw_init(void *handle)
2077 {
2078 	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
2079 
2080 	si_fix_pci_max_read_req_size(adev);
2081 	si_init_golden_registers(adev);
2082 	si_pcie_gen3_enable(adev);
2083 	si_program_aspm(adev);
2084 
2085 	return 0;
2086 }
2087 
2088 static int si_common_hw_fini(void *handle)
2089 {
2090 	return 0;
2091 }
2092 
2093 static int si_common_suspend(void *handle)
2094 {
2095 	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
2096 
2097 	return si_common_hw_fini(adev);
2098 }
2099 
2100 static int si_common_resume(void *handle)
2101 {
2102 	struct amdgpu_device *adev = (struct amdgpu_device *)handle;
2103 
2104 	return si_common_hw_init(adev);
2105 }
2106 
2107 static bool si_common_is_idle(void *handle)
2108 {
2109 	return true;
2110 }
2111 
2112 static int si_common_wait_for_idle(void *handle)
2113 {
2114 	return 0;
2115 }
2116 
2117 static int si_common_soft_reset(void *handle)
2118 {
2119 	return 0;
2120 }
2121 
2122 static int si_common_set_clockgating_state(void *handle,
2123 					    enum amd_clockgating_state state)
2124 {
2125 	return 0;
2126 }
2127 
2128 static int si_common_set_powergating_state(void *handle,
2129 					    enum amd_powergating_state state)
2130 {
2131 	return 0;
2132 }
2133 
2134 static const struct amd_ip_funcs si_common_ip_funcs = {
2135 	.name = "si_common",
2136 	.early_init = si_common_early_init,
2137 	.late_init = NULL,
2138 	.sw_init = si_common_sw_init,
2139 	.sw_fini = si_common_sw_fini,
2140 	.hw_init = si_common_hw_init,
2141 	.hw_fini = si_common_hw_fini,
2142 	.suspend = si_common_suspend,
2143 	.resume = si_common_resume,
2144 	.is_idle = si_common_is_idle,
2145 	.wait_for_idle = si_common_wait_for_idle,
2146 	.soft_reset = si_common_soft_reset,
2147 	.set_clockgating_state = si_common_set_clockgating_state,
2148 	.set_powergating_state = si_common_set_powergating_state,
2149 };
2150 
2151 static const struct amdgpu_ip_block_version si_common_ip_block =
2152 {
2153 	.type = AMD_IP_BLOCK_TYPE_COMMON,
2154 	.major = 1,
2155 	.minor = 0,
2156 	.rev = 0,
2157 	.funcs = &si_common_ip_funcs,
2158 };
2159 
2160 int si_set_ip_blocks(struct amdgpu_device *adev)
2161 {
2162 	switch (adev->asic_type) {
2163 	case CHIP_VERDE:
2164 	case CHIP_TAHITI:
2165 	case CHIP_PITCAIRN:
2166 		amdgpu_device_ip_block_add(adev, &si_common_ip_block);
2167 		amdgpu_device_ip_block_add(adev, &gmc_v6_0_ip_block);
2168 		amdgpu_device_ip_block_add(adev, &si_ih_ip_block);
2169 		amdgpu_device_ip_block_add(adev, &gfx_v6_0_ip_block);
2170 		amdgpu_device_ip_block_add(adev, &si_dma_ip_block);
2171 		amdgpu_device_ip_block_add(adev, &si_smu_ip_block);
2172 		if (adev->enable_virtual_display)
2173 			amdgpu_device_ip_block_add(adev, &dce_virtual_ip_block);
2174 		else
2175 			amdgpu_device_ip_block_add(adev, &dce_v6_0_ip_block);
2176 		/* amdgpu_device_ip_block_add(adev, &uvd_v3_1_ip_block); */
2177 		/* amdgpu_device_ip_block_add(adev, &vce_v1_0_ip_block); */
2178 		break;
2179 	case CHIP_OLAND:
2180 		amdgpu_device_ip_block_add(adev, &si_common_ip_block);
2181 		amdgpu_device_ip_block_add(adev, &gmc_v6_0_ip_block);
2182 		amdgpu_device_ip_block_add(adev, &si_ih_ip_block);
2183 		amdgpu_device_ip_block_add(adev, &gfx_v6_0_ip_block);
2184 		amdgpu_device_ip_block_add(adev, &si_dma_ip_block);
2185 		amdgpu_device_ip_block_add(adev, &si_smu_ip_block);
2186 		if (adev->enable_virtual_display)
2187 			amdgpu_device_ip_block_add(adev, &dce_virtual_ip_block);
2188 		else
2189 			amdgpu_device_ip_block_add(adev, &dce_v6_4_ip_block);
2190 
2191 		/* amdgpu_device_ip_block_add(adev, &uvd_v3_1_ip_block); */
2192 		/* amdgpu_device_ip_block_add(adev, &vce_v1_0_ip_block); */
2193 		break;
2194 	case CHIP_HAINAN:
2195 		amdgpu_device_ip_block_add(adev, &si_common_ip_block);
2196 		amdgpu_device_ip_block_add(adev, &gmc_v6_0_ip_block);
2197 		amdgpu_device_ip_block_add(adev, &si_ih_ip_block);
2198 		amdgpu_device_ip_block_add(adev, &gfx_v6_0_ip_block);
2199 		amdgpu_device_ip_block_add(adev, &si_dma_ip_block);
2200 		amdgpu_device_ip_block_add(adev, &si_smu_ip_block);
2201 		if (adev->enable_virtual_display)
2202 			amdgpu_device_ip_block_add(adev, &dce_virtual_ip_block);
2203 		break;
2204 	default:
2205 		BUG();
2206 	}
2207 	return 0;
2208 }
2209 
2210