/drivers/gpu/drm/amd/amdgpu/gfx_v7_0.c

https://gitlab.com/sunny256/linux · C · 5337 lines · 4318 code · 571 blank · 448 comment · 469 complexity · dc27c900df68462b7f5d7e405e2ffaf8 MD5 · raw file

Large files are truncated click here to view the full file

  1. /*
  2. * Copyright 2014 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. #include <linux/firmware.h>
  24. #include <drm/drmP.h>
  25. #include "amdgpu.h"
  26. #include "amdgpu_ih.h"
  27. #include "amdgpu_gfx.h"
  28. #include "cikd.h"
  29. #include "cik.h"
  30. #include "cik_structs.h"
  31. #include "atom.h"
  32. #include "amdgpu_ucode.h"
  33. #include "clearstate_ci.h"
  34. #include "dce/dce_8_0_d.h"
  35. #include "dce/dce_8_0_sh_mask.h"
  36. #include "bif/bif_4_1_d.h"
  37. #include "bif/bif_4_1_sh_mask.h"
  38. #include "gca/gfx_7_0_d.h"
  39. #include "gca/gfx_7_2_enum.h"
  40. #include "gca/gfx_7_2_sh_mask.h"
  41. #include "gmc/gmc_7_0_d.h"
  42. #include "gmc/gmc_7_0_sh_mask.h"
  43. #include "oss/oss_2_0_d.h"
  44. #include "oss/oss_2_0_sh_mask.h"
  45. #define GFX7_NUM_GFX_RINGS 1
  46. #define GFX7_MEC_HPD_SIZE 2048
  47. static void gfx_v7_0_set_ring_funcs(struct amdgpu_device *adev);
  48. static void gfx_v7_0_set_irq_funcs(struct amdgpu_device *adev);
  49. static void gfx_v7_0_set_gds_init(struct amdgpu_device *adev);
  50. MODULE_FIRMWARE("radeon/bonaire_pfp.bin");
  51. MODULE_FIRMWARE("radeon/bonaire_me.bin");
  52. MODULE_FIRMWARE("radeon/bonaire_ce.bin");
  53. MODULE_FIRMWARE("radeon/bonaire_rlc.bin");
  54. MODULE_FIRMWARE("radeon/bonaire_mec.bin");
  55. MODULE_FIRMWARE("radeon/hawaii_pfp.bin");
  56. MODULE_FIRMWARE("radeon/hawaii_me.bin");
  57. MODULE_FIRMWARE("radeon/hawaii_ce.bin");
  58. MODULE_FIRMWARE("radeon/hawaii_rlc.bin");
  59. MODULE_FIRMWARE("radeon/hawaii_mec.bin");
  60. MODULE_FIRMWARE("radeon/kaveri_pfp.bin");
  61. MODULE_FIRMWARE("radeon/kaveri_me.bin");
  62. MODULE_FIRMWARE("radeon/kaveri_ce.bin");
  63. MODULE_FIRMWARE("radeon/kaveri_rlc.bin");
  64. MODULE_FIRMWARE("radeon/kaveri_mec.bin");
  65. MODULE_FIRMWARE("radeon/kaveri_mec2.bin");
  66. MODULE_FIRMWARE("radeon/kabini_pfp.bin");
  67. MODULE_FIRMWARE("radeon/kabini_me.bin");
  68. MODULE_FIRMWARE("radeon/kabini_ce.bin");
  69. MODULE_FIRMWARE("radeon/kabini_rlc.bin");
  70. MODULE_FIRMWARE("radeon/kabini_mec.bin");
  71. MODULE_FIRMWARE("radeon/mullins_pfp.bin");
  72. MODULE_FIRMWARE("radeon/mullins_me.bin");
  73. MODULE_FIRMWARE("radeon/mullins_ce.bin");
  74. MODULE_FIRMWARE("radeon/mullins_rlc.bin");
  75. MODULE_FIRMWARE("radeon/mullins_mec.bin");
  76. static const struct amdgpu_gds_reg_offset amdgpu_gds_reg_offset[] =
  77. {
  78. {mmGDS_VMID0_BASE, mmGDS_VMID0_SIZE, mmGDS_GWS_VMID0, mmGDS_OA_VMID0},
  79. {mmGDS_VMID1_BASE, mmGDS_VMID1_SIZE, mmGDS_GWS_VMID1, mmGDS_OA_VMID1},
  80. {mmGDS_VMID2_BASE, mmGDS_VMID2_SIZE, mmGDS_GWS_VMID2, mmGDS_OA_VMID2},
  81. {mmGDS_VMID3_BASE, mmGDS_VMID3_SIZE, mmGDS_GWS_VMID3, mmGDS_OA_VMID3},
  82. {mmGDS_VMID4_BASE, mmGDS_VMID4_SIZE, mmGDS_GWS_VMID4, mmGDS_OA_VMID4},
  83. {mmGDS_VMID5_BASE, mmGDS_VMID5_SIZE, mmGDS_GWS_VMID5, mmGDS_OA_VMID5},
  84. {mmGDS_VMID6_BASE, mmGDS_VMID6_SIZE, mmGDS_GWS_VMID6, mmGDS_OA_VMID6},
  85. {mmGDS_VMID7_BASE, mmGDS_VMID7_SIZE, mmGDS_GWS_VMID7, mmGDS_OA_VMID7},
  86. {mmGDS_VMID8_BASE, mmGDS_VMID8_SIZE, mmGDS_GWS_VMID8, mmGDS_OA_VMID8},
  87. {mmGDS_VMID9_BASE, mmGDS_VMID9_SIZE, mmGDS_GWS_VMID9, mmGDS_OA_VMID9},
  88. {mmGDS_VMID10_BASE, mmGDS_VMID10_SIZE, mmGDS_GWS_VMID10, mmGDS_OA_VMID10},
  89. {mmGDS_VMID11_BASE, mmGDS_VMID11_SIZE, mmGDS_GWS_VMID11, mmGDS_OA_VMID11},
  90. {mmGDS_VMID12_BASE, mmGDS_VMID12_SIZE, mmGDS_GWS_VMID12, mmGDS_OA_VMID12},
  91. {mmGDS_VMID13_BASE, mmGDS_VMID13_SIZE, mmGDS_GWS_VMID13, mmGDS_OA_VMID13},
  92. {mmGDS_VMID14_BASE, mmGDS_VMID14_SIZE, mmGDS_GWS_VMID14, mmGDS_OA_VMID14},
  93. {mmGDS_VMID15_BASE, mmGDS_VMID15_SIZE, mmGDS_GWS_VMID15, mmGDS_OA_VMID15}
  94. };
  95. static const u32 spectre_rlc_save_restore_register_list[] =
  96. {
  97. (0x0e00 << 16) | (0xc12c >> 2),
  98. 0x00000000,
  99. (0x0e00 << 16) | (0xc140 >> 2),
  100. 0x00000000,
  101. (0x0e00 << 16) | (0xc150 >> 2),
  102. 0x00000000,
  103. (0x0e00 << 16) | (0xc15c >> 2),
  104. 0x00000000,
  105. (0x0e00 << 16) | (0xc168 >> 2),
  106. 0x00000000,
  107. (0x0e00 << 16) | (0xc170 >> 2),
  108. 0x00000000,
  109. (0x0e00 << 16) | (0xc178 >> 2),
  110. 0x00000000,
  111. (0x0e00 << 16) | (0xc204 >> 2),
  112. 0x00000000,
  113. (0x0e00 << 16) | (0xc2b4 >> 2),
  114. 0x00000000,
  115. (0x0e00 << 16) | (0xc2b8 >> 2),
  116. 0x00000000,
  117. (0x0e00 << 16) | (0xc2bc >> 2),
  118. 0x00000000,
  119. (0x0e00 << 16) | (0xc2c0 >> 2),
  120. 0x00000000,
  121. (0x0e00 << 16) | (0x8228 >> 2),
  122. 0x00000000,
  123. (0x0e00 << 16) | (0x829c >> 2),
  124. 0x00000000,
  125. (0x0e00 << 16) | (0x869c >> 2),
  126. 0x00000000,
  127. (0x0600 << 16) | (0x98f4 >> 2),
  128. 0x00000000,
  129. (0x0e00 << 16) | (0x98f8 >> 2),
  130. 0x00000000,
  131. (0x0e00 << 16) | (0x9900 >> 2),
  132. 0x00000000,
  133. (0x0e00 << 16) | (0xc260 >> 2),
  134. 0x00000000,
  135. (0x0e00 << 16) | (0x90e8 >> 2),
  136. 0x00000000,
  137. (0x0e00 << 16) | (0x3c000 >> 2),
  138. 0x00000000,
  139. (0x0e00 << 16) | (0x3c00c >> 2),
  140. 0x00000000,
  141. (0x0e00 << 16) | (0x8c1c >> 2),
  142. 0x00000000,
  143. (0x0e00 << 16) | (0x9700 >> 2),
  144. 0x00000000,
  145. (0x0e00 << 16) | (0xcd20 >> 2),
  146. 0x00000000,
  147. (0x4e00 << 16) | (0xcd20 >> 2),
  148. 0x00000000,
  149. (0x5e00 << 16) | (0xcd20 >> 2),
  150. 0x00000000,
  151. (0x6e00 << 16) | (0xcd20 >> 2),
  152. 0x00000000,
  153. (0x7e00 << 16) | (0xcd20 >> 2),
  154. 0x00000000,
  155. (0x8e00 << 16) | (0xcd20 >> 2),
  156. 0x00000000,
  157. (0x9e00 << 16) | (0xcd20 >> 2),
  158. 0x00000000,
  159. (0xae00 << 16) | (0xcd20 >> 2),
  160. 0x00000000,
  161. (0xbe00 << 16) | (0xcd20 >> 2),
  162. 0x00000000,
  163. (0x0e00 << 16) | (0x89bc >> 2),
  164. 0x00000000,
  165. (0x0e00 << 16) | (0x8900 >> 2),
  166. 0x00000000,
  167. 0x3,
  168. (0x0e00 << 16) | (0xc130 >> 2),
  169. 0x00000000,
  170. (0x0e00 << 16) | (0xc134 >> 2),
  171. 0x00000000,
  172. (0x0e00 << 16) | (0xc1fc >> 2),
  173. 0x00000000,
  174. (0x0e00 << 16) | (0xc208 >> 2),
  175. 0x00000000,
  176. (0x0e00 << 16) | (0xc264 >> 2),
  177. 0x00000000,
  178. (0x0e00 << 16) | (0xc268 >> 2),
  179. 0x00000000,
  180. (0x0e00 << 16) | (0xc26c >> 2),
  181. 0x00000000,
  182. (0x0e00 << 16) | (0xc270 >> 2),
  183. 0x00000000,
  184. (0x0e00 << 16) | (0xc274 >> 2),
  185. 0x00000000,
  186. (0x0e00 << 16) | (0xc278 >> 2),
  187. 0x00000000,
  188. (0x0e00 << 16) | (0xc27c >> 2),
  189. 0x00000000,
  190. (0x0e00 << 16) | (0xc280 >> 2),
  191. 0x00000000,
  192. (0x0e00 << 16) | (0xc284 >> 2),
  193. 0x00000000,
  194. (0x0e00 << 16) | (0xc288 >> 2),
  195. 0x00000000,
  196. (0x0e00 << 16) | (0xc28c >> 2),
  197. 0x00000000,
  198. (0x0e00 << 16) | (0xc290 >> 2),
  199. 0x00000000,
  200. (0x0e00 << 16) | (0xc294 >> 2),
  201. 0x00000000,
  202. (0x0e00 << 16) | (0xc298 >> 2),
  203. 0x00000000,
  204. (0x0e00 << 16) | (0xc29c >> 2),
  205. 0x00000000,
  206. (0x0e00 << 16) | (0xc2a0 >> 2),
  207. 0x00000000,
  208. (0x0e00 << 16) | (0xc2a4 >> 2),
  209. 0x00000000,
  210. (0x0e00 << 16) | (0xc2a8 >> 2),
  211. 0x00000000,
  212. (0x0e00 << 16) | (0xc2ac >> 2),
  213. 0x00000000,
  214. (0x0e00 << 16) | (0xc2b0 >> 2),
  215. 0x00000000,
  216. (0x0e00 << 16) | (0x301d0 >> 2),
  217. 0x00000000,
  218. (0x0e00 << 16) | (0x30238 >> 2),
  219. 0x00000000,
  220. (0x0e00 << 16) | (0x30250 >> 2),
  221. 0x00000000,
  222. (0x0e00 << 16) | (0x30254 >> 2),
  223. 0x00000000,
  224. (0x0e00 << 16) | (0x30258 >> 2),
  225. 0x00000000,
  226. (0x0e00 << 16) | (0x3025c >> 2),
  227. 0x00000000,
  228. (0x4e00 << 16) | (0xc900 >> 2),
  229. 0x00000000,
  230. (0x5e00 << 16) | (0xc900 >> 2),
  231. 0x00000000,
  232. (0x6e00 << 16) | (0xc900 >> 2),
  233. 0x00000000,
  234. (0x7e00 << 16) | (0xc900 >> 2),
  235. 0x00000000,
  236. (0x8e00 << 16) | (0xc900 >> 2),
  237. 0x00000000,
  238. (0x9e00 << 16) | (0xc900 >> 2),
  239. 0x00000000,
  240. (0xae00 << 16) | (0xc900 >> 2),
  241. 0x00000000,
  242. (0xbe00 << 16) | (0xc900 >> 2),
  243. 0x00000000,
  244. (0x4e00 << 16) | (0xc904 >> 2),
  245. 0x00000000,
  246. (0x5e00 << 16) | (0xc904 >> 2),
  247. 0x00000000,
  248. (0x6e00 << 16) | (0xc904 >> 2),
  249. 0x00000000,
  250. (0x7e00 << 16) | (0xc904 >> 2),
  251. 0x00000000,
  252. (0x8e00 << 16) | (0xc904 >> 2),
  253. 0x00000000,
  254. (0x9e00 << 16) | (0xc904 >> 2),
  255. 0x00000000,
  256. (0xae00 << 16) | (0xc904 >> 2),
  257. 0x00000000,
  258. (0xbe00 << 16) | (0xc904 >> 2),
  259. 0x00000000,
  260. (0x4e00 << 16) | (0xc908 >> 2),
  261. 0x00000000,
  262. (0x5e00 << 16) | (0xc908 >> 2),
  263. 0x00000000,
  264. (0x6e00 << 16) | (0xc908 >> 2),
  265. 0x00000000,
  266. (0x7e00 << 16) | (0xc908 >> 2),
  267. 0x00000000,
  268. (0x8e00 << 16) | (0xc908 >> 2),
  269. 0x00000000,
  270. (0x9e00 << 16) | (0xc908 >> 2),
  271. 0x00000000,
  272. (0xae00 << 16) | (0xc908 >> 2),
  273. 0x00000000,
  274. (0xbe00 << 16) | (0xc908 >> 2),
  275. 0x00000000,
  276. (0x4e00 << 16) | (0xc90c >> 2),
  277. 0x00000000,
  278. (0x5e00 << 16) | (0xc90c >> 2),
  279. 0x00000000,
  280. (0x6e00 << 16) | (0xc90c >> 2),
  281. 0x00000000,
  282. (0x7e00 << 16) | (0xc90c >> 2),
  283. 0x00000000,
  284. (0x8e00 << 16) | (0xc90c >> 2),
  285. 0x00000000,
  286. (0x9e00 << 16) | (0xc90c >> 2),
  287. 0x00000000,
  288. (0xae00 << 16) | (0xc90c >> 2),
  289. 0x00000000,
  290. (0xbe00 << 16) | (0xc90c >> 2),
  291. 0x00000000,
  292. (0x4e00 << 16) | (0xc910 >> 2),
  293. 0x00000000,
  294. (0x5e00 << 16) | (0xc910 >> 2),
  295. 0x00000000,
  296. (0x6e00 << 16) | (0xc910 >> 2),
  297. 0x00000000,
  298. (0x7e00 << 16) | (0xc910 >> 2),
  299. 0x00000000,
  300. (0x8e00 << 16) | (0xc910 >> 2),
  301. 0x00000000,
  302. (0x9e00 << 16) | (0xc910 >> 2),
  303. 0x00000000,
  304. (0xae00 << 16) | (0xc910 >> 2),
  305. 0x00000000,
  306. (0xbe00 << 16) | (0xc910 >> 2),
  307. 0x00000000,
  308. (0x0e00 << 16) | (0xc99c >> 2),
  309. 0x00000000,
  310. (0x0e00 << 16) | (0x9834 >> 2),
  311. 0x00000000,
  312. (0x0000 << 16) | (0x30f00 >> 2),
  313. 0x00000000,
  314. (0x0001 << 16) | (0x30f00 >> 2),
  315. 0x00000000,
  316. (0x0000 << 16) | (0x30f04 >> 2),
  317. 0x00000000,
  318. (0x0001 << 16) | (0x30f04 >> 2),
  319. 0x00000000,
  320. (0x0000 << 16) | (0x30f08 >> 2),
  321. 0x00000000,
  322. (0x0001 << 16) | (0x30f08 >> 2),
  323. 0x00000000,
  324. (0x0000 << 16) | (0x30f0c >> 2),
  325. 0x00000000,
  326. (0x0001 << 16) | (0x30f0c >> 2),
  327. 0x00000000,
  328. (0x0600 << 16) | (0x9b7c >> 2),
  329. 0x00000000,
  330. (0x0e00 << 16) | (0x8a14 >> 2),
  331. 0x00000000,
  332. (0x0e00 << 16) | (0x8a18 >> 2),
  333. 0x00000000,
  334. (0x0600 << 16) | (0x30a00 >> 2),
  335. 0x00000000,
  336. (0x0e00 << 16) | (0x8bf0 >> 2),
  337. 0x00000000,
  338. (0x0e00 << 16) | (0x8bcc >> 2),
  339. 0x00000000,
  340. (0x0e00 << 16) | (0x8b24 >> 2),
  341. 0x00000000,
  342. (0x0e00 << 16) | (0x30a04 >> 2),
  343. 0x00000000,
  344. (0x0600 << 16) | (0x30a10 >> 2),
  345. 0x00000000,
  346. (0x0600 << 16) | (0x30a14 >> 2),
  347. 0x00000000,
  348. (0x0600 << 16) | (0x30a18 >> 2),
  349. 0x00000000,
  350. (0x0600 << 16) | (0x30a2c >> 2),
  351. 0x00000000,
  352. (0x0e00 << 16) | (0xc700 >> 2),
  353. 0x00000000,
  354. (0x0e00 << 16) | (0xc704 >> 2),
  355. 0x00000000,
  356. (0x0e00 << 16) | (0xc708 >> 2),
  357. 0x00000000,
  358. (0x0e00 << 16) | (0xc768 >> 2),
  359. 0x00000000,
  360. (0x0400 << 16) | (0xc770 >> 2),
  361. 0x00000000,
  362. (0x0400 << 16) | (0xc774 >> 2),
  363. 0x00000000,
  364. (0x0400 << 16) | (0xc778 >> 2),
  365. 0x00000000,
  366. (0x0400 << 16) | (0xc77c >> 2),
  367. 0x00000000,
  368. (0x0400 << 16) | (0xc780 >> 2),
  369. 0x00000000,
  370. (0x0400 << 16) | (0xc784 >> 2),
  371. 0x00000000,
  372. (0x0400 << 16) | (0xc788 >> 2),
  373. 0x00000000,
  374. (0x0400 << 16) | (0xc78c >> 2),
  375. 0x00000000,
  376. (0x0400 << 16) | (0xc798 >> 2),
  377. 0x00000000,
  378. (0x0400 << 16) | (0xc79c >> 2),
  379. 0x00000000,
  380. (0x0400 << 16) | (0xc7a0 >> 2),
  381. 0x00000000,
  382. (0x0400 << 16) | (0xc7a4 >> 2),
  383. 0x00000000,
  384. (0x0400 << 16) | (0xc7a8 >> 2),
  385. 0x00000000,
  386. (0x0400 << 16) | (0xc7ac >> 2),
  387. 0x00000000,
  388. (0x0400 << 16) | (0xc7b0 >> 2),
  389. 0x00000000,
  390. (0x0400 << 16) | (0xc7b4 >> 2),
  391. 0x00000000,
  392. (0x0e00 << 16) | (0x9100 >> 2),
  393. 0x00000000,
  394. (0x0e00 << 16) | (0x3c010 >> 2),
  395. 0x00000000,
  396. (0x0e00 << 16) | (0x92a8 >> 2),
  397. 0x00000000,
  398. (0x0e00 << 16) | (0x92ac >> 2),
  399. 0x00000000,
  400. (0x0e00 << 16) | (0x92b4 >> 2),
  401. 0x00000000,
  402. (0x0e00 << 16) | (0x92b8 >> 2),
  403. 0x00000000,
  404. (0x0e00 << 16) | (0x92bc >> 2),
  405. 0x00000000,
  406. (0x0e00 << 16) | (0x92c0 >> 2),
  407. 0x00000000,
  408. (0x0e00 << 16) | (0x92c4 >> 2),
  409. 0x00000000,
  410. (0x0e00 << 16) | (0x92c8 >> 2),
  411. 0x00000000,
  412. (0x0e00 << 16) | (0x92cc >> 2),
  413. 0x00000000,
  414. (0x0e00 << 16) | (0x92d0 >> 2),
  415. 0x00000000,
  416. (0x0e00 << 16) | (0x8c00 >> 2),
  417. 0x00000000,
  418. (0x0e00 << 16) | (0x8c04 >> 2),
  419. 0x00000000,
  420. (0x0e00 << 16) | (0x8c20 >> 2),
  421. 0x00000000,
  422. (0x0e00 << 16) | (0x8c38 >> 2),
  423. 0x00000000,
  424. (0x0e00 << 16) | (0x8c3c >> 2),
  425. 0x00000000,
  426. (0x0e00 << 16) | (0xae00 >> 2),
  427. 0x00000000,
  428. (0x0e00 << 16) | (0x9604 >> 2),
  429. 0x00000000,
  430. (0x0e00 << 16) | (0xac08 >> 2),
  431. 0x00000000,
  432. (0x0e00 << 16) | (0xac0c >> 2),
  433. 0x00000000,
  434. (0x0e00 << 16) | (0xac10 >> 2),
  435. 0x00000000,
  436. (0x0e00 << 16) | (0xac14 >> 2),
  437. 0x00000000,
  438. (0x0e00 << 16) | (0xac58 >> 2),
  439. 0x00000000,
  440. (0x0e00 << 16) | (0xac68 >> 2),
  441. 0x00000000,
  442. (0x0e00 << 16) | (0xac6c >> 2),
  443. 0x00000000,
  444. (0x0e00 << 16) | (0xac70 >> 2),
  445. 0x00000000,
  446. (0x0e00 << 16) | (0xac74 >> 2),
  447. 0x00000000,
  448. (0x0e00 << 16) | (0xac78 >> 2),
  449. 0x00000000,
  450. (0x0e00 << 16) | (0xac7c >> 2),
  451. 0x00000000,
  452. (0x0e00 << 16) | (0xac80 >> 2),
  453. 0x00000000,
  454. (0x0e00 << 16) | (0xac84 >> 2),
  455. 0x00000000,
  456. (0x0e00 << 16) | (0xac88 >> 2),
  457. 0x00000000,
  458. (0x0e00 << 16) | (0xac8c >> 2),
  459. 0x00000000,
  460. (0x0e00 << 16) | (0x970c >> 2),
  461. 0x00000000,
  462. (0x0e00 << 16) | (0x9714 >> 2),
  463. 0x00000000,
  464. (0x0e00 << 16) | (0x9718 >> 2),
  465. 0x00000000,
  466. (0x0e00 << 16) | (0x971c >> 2),
  467. 0x00000000,
  468. (0x0e00 << 16) | (0x31068 >> 2),
  469. 0x00000000,
  470. (0x4e00 << 16) | (0x31068 >> 2),
  471. 0x00000000,
  472. (0x5e00 << 16) | (0x31068 >> 2),
  473. 0x00000000,
  474. (0x6e00 << 16) | (0x31068 >> 2),
  475. 0x00000000,
  476. (0x7e00 << 16) | (0x31068 >> 2),
  477. 0x00000000,
  478. (0x8e00 << 16) | (0x31068 >> 2),
  479. 0x00000000,
  480. (0x9e00 << 16) | (0x31068 >> 2),
  481. 0x00000000,
  482. (0xae00 << 16) | (0x31068 >> 2),
  483. 0x00000000,
  484. (0xbe00 << 16) | (0x31068 >> 2),
  485. 0x00000000,
  486. (0x0e00 << 16) | (0xcd10 >> 2),
  487. 0x00000000,
  488. (0x0e00 << 16) | (0xcd14 >> 2),
  489. 0x00000000,
  490. (0x0e00 << 16) | (0x88b0 >> 2),
  491. 0x00000000,
  492. (0x0e00 << 16) | (0x88b4 >> 2),
  493. 0x00000000,
  494. (0x0e00 << 16) | (0x88b8 >> 2),
  495. 0x00000000,
  496. (0x0e00 << 16) | (0x88bc >> 2),
  497. 0x00000000,
  498. (0x0400 << 16) | (0x89c0 >> 2),
  499. 0x00000000,
  500. (0x0e00 << 16) | (0x88c4 >> 2),
  501. 0x00000000,
  502. (0x0e00 << 16) | (0x88c8 >> 2),
  503. 0x00000000,
  504. (0x0e00 << 16) | (0x88d0 >> 2),
  505. 0x00000000,
  506. (0x0e00 << 16) | (0x88d4 >> 2),
  507. 0x00000000,
  508. (0x0e00 << 16) | (0x88d8 >> 2),
  509. 0x00000000,
  510. (0x0e00 << 16) | (0x8980 >> 2),
  511. 0x00000000,
  512. (0x0e00 << 16) | (0x30938 >> 2),
  513. 0x00000000,
  514. (0x0e00 << 16) | (0x3093c >> 2),
  515. 0x00000000,
  516. (0x0e00 << 16) | (0x30940 >> 2),
  517. 0x00000000,
  518. (0x0e00 << 16) | (0x89a0 >> 2),
  519. 0x00000000,
  520. (0x0e00 << 16) | (0x30900 >> 2),
  521. 0x00000000,
  522. (0x0e00 << 16) | (0x30904 >> 2),
  523. 0x00000000,
  524. (0x0e00 << 16) | (0x89b4 >> 2),
  525. 0x00000000,
  526. (0x0e00 << 16) | (0x3c210 >> 2),
  527. 0x00000000,
  528. (0x0e00 << 16) | (0x3c214 >> 2),
  529. 0x00000000,
  530. (0x0e00 << 16) | (0x3c218 >> 2),
  531. 0x00000000,
  532. (0x0e00 << 16) | (0x8904 >> 2),
  533. 0x00000000,
  534. 0x5,
  535. (0x0e00 << 16) | (0x8c28 >> 2),
  536. (0x0e00 << 16) | (0x8c2c >> 2),
  537. (0x0e00 << 16) | (0x8c30 >> 2),
  538. (0x0e00 << 16) | (0x8c34 >> 2),
  539. (0x0e00 << 16) | (0x9600 >> 2),
  540. };
  541. static const u32 kalindi_rlc_save_restore_register_list[] =
  542. {
  543. (0x0e00 << 16) | (0xc12c >> 2),
  544. 0x00000000,
  545. (0x0e00 << 16) | (0xc140 >> 2),
  546. 0x00000000,
  547. (0x0e00 << 16) | (0xc150 >> 2),
  548. 0x00000000,
  549. (0x0e00 << 16) | (0xc15c >> 2),
  550. 0x00000000,
  551. (0x0e00 << 16) | (0xc168 >> 2),
  552. 0x00000000,
  553. (0x0e00 << 16) | (0xc170 >> 2),
  554. 0x00000000,
  555. (0x0e00 << 16) | (0xc204 >> 2),
  556. 0x00000000,
  557. (0x0e00 << 16) | (0xc2b4 >> 2),
  558. 0x00000000,
  559. (0x0e00 << 16) | (0xc2b8 >> 2),
  560. 0x00000000,
  561. (0x0e00 << 16) | (0xc2bc >> 2),
  562. 0x00000000,
  563. (0x0e00 << 16) | (0xc2c0 >> 2),
  564. 0x00000000,
  565. (0x0e00 << 16) | (0x8228 >> 2),
  566. 0x00000000,
  567. (0x0e00 << 16) | (0x829c >> 2),
  568. 0x00000000,
  569. (0x0e00 << 16) | (0x869c >> 2),
  570. 0x00000000,
  571. (0x0600 << 16) | (0x98f4 >> 2),
  572. 0x00000000,
  573. (0x0e00 << 16) | (0x98f8 >> 2),
  574. 0x00000000,
  575. (0x0e00 << 16) | (0x9900 >> 2),
  576. 0x00000000,
  577. (0x0e00 << 16) | (0xc260 >> 2),
  578. 0x00000000,
  579. (0x0e00 << 16) | (0x90e8 >> 2),
  580. 0x00000000,
  581. (0x0e00 << 16) | (0x3c000 >> 2),
  582. 0x00000000,
  583. (0x0e00 << 16) | (0x3c00c >> 2),
  584. 0x00000000,
  585. (0x0e00 << 16) | (0x8c1c >> 2),
  586. 0x00000000,
  587. (0x0e00 << 16) | (0x9700 >> 2),
  588. 0x00000000,
  589. (0x0e00 << 16) | (0xcd20 >> 2),
  590. 0x00000000,
  591. (0x4e00 << 16) | (0xcd20 >> 2),
  592. 0x00000000,
  593. (0x5e00 << 16) | (0xcd20 >> 2),
  594. 0x00000000,
  595. (0x6e00 << 16) | (0xcd20 >> 2),
  596. 0x00000000,
  597. (0x7e00 << 16) | (0xcd20 >> 2),
  598. 0x00000000,
  599. (0x0e00 << 16) | (0x89bc >> 2),
  600. 0x00000000,
  601. (0x0e00 << 16) | (0x8900 >> 2),
  602. 0x00000000,
  603. 0x3,
  604. (0x0e00 << 16) | (0xc130 >> 2),
  605. 0x00000000,
  606. (0x0e00 << 16) | (0xc134 >> 2),
  607. 0x00000000,
  608. (0x0e00 << 16) | (0xc1fc >> 2),
  609. 0x00000000,
  610. (0x0e00 << 16) | (0xc208 >> 2),
  611. 0x00000000,
  612. (0x0e00 << 16) | (0xc264 >> 2),
  613. 0x00000000,
  614. (0x0e00 << 16) | (0xc268 >> 2),
  615. 0x00000000,
  616. (0x0e00 << 16) | (0xc26c >> 2),
  617. 0x00000000,
  618. (0x0e00 << 16) | (0xc270 >> 2),
  619. 0x00000000,
  620. (0x0e00 << 16) | (0xc274 >> 2),
  621. 0x00000000,
  622. (0x0e00 << 16) | (0xc28c >> 2),
  623. 0x00000000,
  624. (0x0e00 << 16) | (0xc290 >> 2),
  625. 0x00000000,
  626. (0x0e00 << 16) | (0xc294 >> 2),
  627. 0x00000000,
  628. (0x0e00 << 16) | (0xc298 >> 2),
  629. 0x00000000,
  630. (0x0e00 << 16) | (0xc2a0 >> 2),
  631. 0x00000000,
  632. (0x0e00 << 16) | (0xc2a4 >> 2),
  633. 0x00000000,
  634. (0x0e00 << 16) | (0xc2a8 >> 2),
  635. 0x00000000,
  636. (0x0e00 << 16) | (0xc2ac >> 2),
  637. 0x00000000,
  638. (0x0e00 << 16) | (0x301d0 >> 2),
  639. 0x00000000,
  640. (0x0e00 << 16) | (0x30238 >> 2),
  641. 0x00000000,
  642. (0x0e00 << 16) | (0x30250 >> 2),
  643. 0x00000000,
  644. (0x0e00 << 16) | (0x30254 >> 2),
  645. 0x00000000,
  646. (0x0e00 << 16) | (0x30258 >> 2),
  647. 0x00000000,
  648. (0x0e00 << 16) | (0x3025c >> 2),
  649. 0x00000000,
  650. (0x4e00 << 16) | (0xc900 >> 2),
  651. 0x00000000,
  652. (0x5e00 << 16) | (0xc900 >> 2),
  653. 0x00000000,
  654. (0x6e00 << 16) | (0xc900 >> 2),
  655. 0x00000000,
  656. (0x7e00 << 16) | (0xc900 >> 2),
  657. 0x00000000,
  658. (0x4e00 << 16) | (0xc904 >> 2),
  659. 0x00000000,
  660. (0x5e00 << 16) | (0xc904 >> 2),
  661. 0x00000000,
  662. (0x6e00 << 16) | (0xc904 >> 2),
  663. 0x00000000,
  664. (0x7e00 << 16) | (0xc904 >> 2),
  665. 0x00000000,
  666. (0x4e00 << 16) | (0xc908 >> 2),
  667. 0x00000000,
  668. (0x5e00 << 16) | (0xc908 >> 2),
  669. 0x00000000,
  670. (0x6e00 << 16) | (0xc908 >> 2),
  671. 0x00000000,
  672. (0x7e00 << 16) | (0xc908 >> 2),
  673. 0x00000000,
  674. (0x4e00 << 16) | (0xc90c >> 2),
  675. 0x00000000,
  676. (0x5e00 << 16) | (0xc90c >> 2),
  677. 0x00000000,
  678. (0x6e00 << 16) | (0xc90c >> 2),
  679. 0x00000000,
  680. (0x7e00 << 16) | (0xc90c >> 2),
  681. 0x00000000,
  682. (0x4e00 << 16) | (0xc910 >> 2),
  683. 0x00000000,
  684. (0x5e00 << 16) | (0xc910 >> 2),
  685. 0x00000000,
  686. (0x6e00 << 16) | (0xc910 >> 2),
  687. 0x00000000,
  688. (0x7e00 << 16) | (0xc910 >> 2),
  689. 0x00000000,
  690. (0x0e00 << 16) | (0xc99c >> 2),
  691. 0x00000000,
  692. (0x0e00 << 16) | (0x9834 >> 2),
  693. 0x00000000,
  694. (0x0000 << 16) | (0x30f00 >> 2),
  695. 0x00000000,
  696. (0x0000 << 16) | (0x30f04 >> 2),
  697. 0x00000000,
  698. (0x0000 << 16) | (0x30f08 >> 2),
  699. 0x00000000,
  700. (0x0000 << 16) | (0x30f0c >> 2),
  701. 0x00000000,
  702. (0x0600 << 16) | (0x9b7c >> 2),
  703. 0x00000000,
  704. (0x0e00 << 16) | (0x8a14 >> 2),
  705. 0x00000000,
  706. (0x0e00 << 16) | (0x8a18 >> 2),
  707. 0x00000000,
  708. (0x0600 << 16) | (0x30a00 >> 2),
  709. 0x00000000,
  710. (0x0e00 << 16) | (0x8bf0 >> 2),
  711. 0x00000000,
  712. (0x0e00 << 16) | (0x8bcc >> 2),
  713. 0x00000000,
  714. (0x0e00 << 16) | (0x8b24 >> 2),
  715. 0x00000000,
  716. (0x0e00 << 16) | (0x30a04 >> 2),
  717. 0x00000000,
  718. (0x0600 << 16) | (0x30a10 >> 2),
  719. 0x00000000,
  720. (0x0600 << 16) | (0x30a14 >> 2),
  721. 0x00000000,
  722. (0x0600 << 16) | (0x30a18 >> 2),
  723. 0x00000000,
  724. (0x0600 << 16) | (0x30a2c >> 2),
  725. 0x00000000,
  726. (0x0e00 << 16) | (0xc700 >> 2),
  727. 0x00000000,
  728. (0x0e00 << 16) | (0xc704 >> 2),
  729. 0x00000000,
  730. (0x0e00 << 16) | (0xc708 >> 2),
  731. 0x00000000,
  732. (0x0e00 << 16) | (0xc768 >> 2),
  733. 0x00000000,
  734. (0x0400 << 16) | (0xc770 >> 2),
  735. 0x00000000,
  736. (0x0400 << 16) | (0xc774 >> 2),
  737. 0x00000000,
  738. (0x0400 << 16) | (0xc798 >> 2),
  739. 0x00000000,
  740. (0x0400 << 16) | (0xc79c >> 2),
  741. 0x00000000,
  742. (0x0e00 << 16) | (0x9100 >> 2),
  743. 0x00000000,
  744. (0x0e00 << 16) | (0x3c010 >> 2),
  745. 0x00000000,
  746. (0x0e00 << 16) | (0x8c00 >> 2),
  747. 0x00000000,
  748. (0x0e00 << 16) | (0x8c04 >> 2),
  749. 0x00000000,
  750. (0x0e00 << 16) | (0x8c20 >> 2),
  751. 0x00000000,
  752. (0x0e00 << 16) | (0x8c38 >> 2),
  753. 0x00000000,
  754. (0x0e00 << 16) | (0x8c3c >> 2),
  755. 0x00000000,
  756. (0x0e00 << 16) | (0xae00 >> 2),
  757. 0x00000000,
  758. (0x0e00 << 16) | (0x9604 >> 2),
  759. 0x00000000,
  760. (0x0e00 << 16) | (0xac08 >> 2),
  761. 0x00000000,
  762. (0x0e00 << 16) | (0xac0c >> 2),
  763. 0x00000000,
  764. (0x0e00 << 16) | (0xac10 >> 2),
  765. 0x00000000,
  766. (0x0e00 << 16) | (0xac14 >> 2),
  767. 0x00000000,
  768. (0x0e00 << 16) | (0xac58 >> 2),
  769. 0x00000000,
  770. (0x0e00 << 16) | (0xac68 >> 2),
  771. 0x00000000,
  772. (0x0e00 << 16) | (0xac6c >> 2),
  773. 0x00000000,
  774. (0x0e00 << 16) | (0xac70 >> 2),
  775. 0x00000000,
  776. (0x0e00 << 16) | (0xac74 >> 2),
  777. 0x00000000,
  778. (0x0e00 << 16) | (0xac78 >> 2),
  779. 0x00000000,
  780. (0x0e00 << 16) | (0xac7c >> 2),
  781. 0x00000000,
  782. (0x0e00 << 16) | (0xac80 >> 2),
  783. 0x00000000,
  784. (0x0e00 << 16) | (0xac84 >> 2),
  785. 0x00000000,
  786. (0x0e00 << 16) | (0xac88 >> 2),
  787. 0x00000000,
  788. (0x0e00 << 16) | (0xac8c >> 2),
  789. 0x00000000,
  790. (0x0e00 << 16) | (0x970c >> 2),
  791. 0x00000000,
  792. (0x0e00 << 16) | (0x9714 >> 2),
  793. 0x00000000,
  794. (0x0e00 << 16) | (0x9718 >> 2),
  795. 0x00000000,
  796. (0x0e00 << 16) | (0x971c >> 2),
  797. 0x00000000,
  798. (0x0e00 << 16) | (0x31068 >> 2),
  799. 0x00000000,
  800. (0x4e00 << 16) | (0x31068 >> 2),
  801. 0x00000000,
  802. (0x5e00 << 16) | (0x31068 >> 2),
  803. 0x00000000,
  804. (0x6e00 << 16) | (0x31068 >> 2),
  805. 0x00000000,
  806. (0x7e00 << 16) | (0x31068 >> 2),
  807. 0x00000000,
  808. (0x0e00 << 16) | (0xcd10 >> 2),
  809. 0x00000000,
  810. (0x0e00 << 16) | (0xcd14 >> 2),
  811. 0x00000000,
  812. (0x0e00 << 16) | (0x88b0 >> 2),
  813. 0x00000000,
  814. (0x0e00 << 16) | (0x88b4 >> 2),
  815. 0x00000000,
  816. (0x0e00 << 16) | (0x88b8 >> 2),
  817. 0x00000000,
  818. (0x0e00 << 16) | (0x88bc >> 2),
  819. 0x00000000,
  820. (0x0400 << 16) | (0x89c0 >> 2),
  821. 0x00000000,
  822. (0x0e00 << 16) | (0x88c4 >> 2),
  823. 0x00000000,
  824. (0x0e00 << 16) | (0x88c8 >> 2),
  825. 0x00000000,
  826. (0x0e00 << 16) | (0x88d0 >> 2),
  827. 0x00000000,
  828. (0x0e00 << 16) | (0x88d4 >> 2),
  829. 0x00000000,
  830. (0x0e00 << 16) | (0x88d8 >> 2),
  831. 0x00000000,
  832. (0x0e00 << 16) | (0x8980 >> 2),
  833. 0x00000000,
  834. (0x0e00 << 16) | (0x30938 >> 2),
  835. 0x00000000,
  836. (0x0e00 << 16) | (0x3093c >> 2),
  837. 0x00000000,
  838. (0x0e00 << 16) | (0x30940 >> 2),
  839. 0x00000000,
  840. (0x0e00 << 16) | (0x89a0 >> 2),
  841. 0x00000000,
  842. (0x0e00 << 16) | (0x30900 >> 2),
  843. 0x00000000,
  844. (0x0e00 << 16) | (0x30904 >> 2),
  845. 0x00000000,
  846. (0x0e00 << 16) | (0x89b4 >> 2),
  847. 0x00000000,
  848. (0x0e00 << 16) | (0x3e1fc >> 2),
  849. 0x00000000,
  850. (0x0e00 << 16) | (0x3c210 >> 2),
  851. 0x00000000,
  852. (0x0e00 << 16) | (0x3c214 >> 2),
  853. 0x00000000,
  854. (0x0e00 << 16) | (0x3c218 >> 2),
  855. 0x00000000,
  856. (0x0e00 << 16) | (0x8904 >> 2),
  857. 0x00000000,
  858. 0x5,
  859. (0x0e00 << 16) | (0x8c28 >> 2),
  860. (0x0e00 << 16) | (0x8c2c >> 2),
  861. (0x0e00 << 16) | (0x8c30 >> 2),
  862. (0x0e00 << 16) | (0x8c34 >> 2),
  863. (0x0e00 << 16) | (0x9600 >> 2),
  864. };
  865. static u32 gfx_v7_0_get_csb_size(struct amdgpu_device *adev);
  866. static void gfx_v7_0_get_csb_buffer(struct amdgpu_device *adev, volatile u32 *buffer);
  867. static void gfx_v7_0_init_cp_pg_table(struct amdgpu_device *adev);
  868. static void gfx_v7_0_init_pg(struct amdgpu_device *adev);
  869. static void gfx_v7_0_get_cu_info(struct amdgpu_device *adev);
  870. /*
  871. * Core functions
  872. */
  873. /**
  874. * gfx_v7_0_init_microcode - load ucode images from disk
  875. *
  876. * @adev: amdgpu_device pointer
  877. *
  878. * Use the firmware interface to load the ucode images into
  879. * the driver (not loaded into hw).
  880. * Returns 0 on success, error on failure.
  881. */
  882. static int gfx_v7_0_init_microcode(struct amdgpu_device *adev)
  883. {
  884. const char *chip_name;
  885. char fw_name[30];
  886. int err;
  887. DRM_DEBUG("\n");
  888. switch (adev->asic_type) {
  889. case CHIP_BONAIRE:
  890. chip_name = "bonaire";
  891. break;
  892. case CHIP_HAWAII:
  893. chip_name = "hawaii";
  894. break;
  895. case CHIP_KAVERI:
  896. chip_name = "kaveri";
  897. break;
  898. case CHIP_KABINI:
  899. chip_name = "kabini";
  900. break;
  901. case CHIP_MULLINS:
  902. chip_name = "mullins";
  903. break;
  904. default: BUG();
  905. }
  906. snprintf(fw_name, sizeof(fw_name), "radeon/%s_pfp.bin", chip_name);
  907. err = request_firmware(&adev->gfx.pfp_fw, fw_name, adev->dev);
  908. if (err)
  909. goto out;
  910. err = amdgpu_ucode_validate(adev->gfx.pfp_fw);
  911. if (err)
  912. goto out;
  913. snprintf(fw_name, sizeof(fw_name), "radeon/%s_me.bin", chip_name);
  914. err = request_firmware(&adev->gfx.me_fw, fw_name, adev->dev);
  915. if (err)
  916. goto out;
  917. err = amdgpu_ucode_validate(adev->gfx.me_fw);
  918. if (err)
  919. goto out;
  920. snprintf(fw_name, sizeof(fw_name), "radeon/%s_ce.bin", chip_name);
  921. err = request_firmware(&adev->gfx.ce_fw, fw_name, adev->dev);
  922. if (err)
  923. goto out;
  924. err = amdgpu_ucode_validate(adev->gfx.ce_fw);
  925. if (err)
  926. goto out;
  927. snprintf(fw_name, sizeof(fw_name), "radeon/%s_mec.bin", chip_name);
  928. err = request_firmware(&adev->gfx.mec_fw, fw_name, adev->dev);
  929. if (err)
  930. goto out;
  931. err = amdgpu_ucode_validate(adev->gfx.mec_fw);
  932. if (err)
  933. goto out;
  934. if (adev->asic_type == CHIP_KAVERI) {
  935. snprintf(fw_name, sizeof(fw_name), "radeon/%s_mec2.bin", chip_name);
  936. err = request_firmware(&adev->gfx.mec2_fw, fw_name, adev->dev);
  937. if (err)
  938. goto out;
  939. err = amdgpu_ucode_validate(adev->gfx.mec2_fw);
  940. if (err)
  941. goto out;
  942. }
  943. snprintf(fw_name, sizeof(fw_name), "radeon/%s_rlc.bin", chip_name);
  944. err = request_firmware(&adev->gfx.rlc_fw, fw_name, adev->dev);
  945. if (err)
  946. goto out;
  947. err = amdgpu_ucode_validate(adev->gfx.rlc_fw);
  948. out:
  949. if (err) {
  950. pr_err("gfx7: Failed to load firmware \"%s\"\n", fw_name);
  951. release_firmware(adev->gfx.pfp_fw);
  952. adev->gfx.pfp_fw = NULL;
  953. release_firmware(adev->gfx.me_fw);
  954. adev->gfx.me_fw = NULL;
  955. release_firmware(adev->gfx.ce_fw);
  956. adev->gfx.ce_fw = NULL;
  957. release_firmware(adev->gfx.mec_fw);
  958. adev->gfx.mec_fw = NULL;
  959. release_firmware(adev->gfx.mec2_fw);
  960. adev->gfx.mec2_fw = NULL;
  961. release_firmware(adev->gfx.rlc_fw);
  962. adev->gfx.rlc_fw = NULL;
  963. }
  964. return err;
  965. }
  966. static void gfx_v7_0_free_microcode(struct amdgpu_device *adev)
  967. {
  968. release_firmware(adev->gfx.pfp_fw);
  969. adev->gfx.pfp_fw = NULL;
  970. release_firmware(adev->gfx.me_fw);
  971. adev->gfx.me_fw = NULL;
  972. release_firmware(adev->gfx.ce_fw);
  973. adev->gfx.ce_fw = NULL;
  974. release_firmware(adev->gfx.mec_fw);
  975. adev->gfx.mec_fw = NULL;
  976. release_firmware(adev->gfx.mec2_fw);
  977. adev->gfx.mec2_fw = NULL;
  978. release_firmware(adev->gfx.rlc_fw);
  979. adev->gfx.rlc_fw = NULL;
  980. }
  981. /**
  982. * gfx_v7_0_tiling_mode_table_init - init the hw tiling table
  983. *
  984. * @adev: amdgpu_device pointer
  985. *
  986. * Starting with SI, the tiling setup is done globally in a
  987. * set of 32 tiling modes. Rather than selecting each set of
  988. * parameters per surface as on older asics, we just select
  989. * which index in the tiling table we want to use, and the
  990. * surface uses those parameters (CIK).
  991. */
  992. static void gfx_v7_0_tiling_mode_table_init(struct amdgpu_device *adev)
  993. {
  994. const u32 num_tile_mode_states =
  995. ARRAY_SIZE(adev->gfx.config.tile_mode_array);
  996. const u32 num_secondary_tile_mode_states =
  997. ARRAY_SIZE(adev->gfx.config.macrotile_mode_array);
  998. u32 reg_offset, split_equal_to_row_size;
  999. uint32_t *tile, *macrotile;
  1000. tile = adev->gfx.config.tile_mode_array;
  1001. macrotile = adev->gfx.config.macrotile_mode_array;
  1002. switch (adev->gfx.config.mem_row_size_in_kb) {
  1003. case 1:
  1004. split_equal_to_row_size = ADDR_SURF_TILE_SPLIT_1KB;
  1005. break;
  1006. case 2:
  1007. default:
  1008. split_equal_to_row_size = ADDR_SURF_TILE_SPLIT_2KB;
  1009. break;
  1010. case 4:
  1011. split_equal_to_row_size = ADDR_SURF_TILE_SPLIT_4KB;
  1012. break;
  1013. }
  1014. for (reg_offset = 0; reg_offset < num_tile_mode_states; reg_offset++)
  1015. tile[reg_offset] = 0;
  1016. for (reg_offset = 0; reg_offset < num_secondary_tile_mode_states; reg_offset++)
  1017. macrotile[reg_offset] = 0;
  1018. switch (adev->asic_type) {
  1019. case CHIP_BONAIRE:
  1020. tile[0] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1021. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1022. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_64B) |
  1023. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1024. tile[1] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1025. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1026. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_128B) |
  1027. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1028. tile[2] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1029. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1030. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_256B) |
  1031. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1032. tile[3] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1033. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1034. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_512B) |
  1035. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1036. tile[4] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1037. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1038. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1039. TILE_SPLIT(split_equal_to_row_size));
  1040. tile[5] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1041. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1042. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1043. tile[6] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1044. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1045. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1046. TILE_SPLIT(split_equal_to_row_size));
  1047. tile[7] = (TILE_SPLIT(split_equal_to_row_size));
  1048. tile[8] = (ARRAY_MODE(ARRAY_LINEAR_ALIGNED) |
  1049. PIPE_CONFIG(ADDR_SURF_P4_16x16));
  1050. tile[9] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1051. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1052. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING));
  1053. tile[10] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1054. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1055. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1056. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1057. tile[11] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1058. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1059. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1060. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1061. tile[12] = (TILE_SPLIT(split_equal_to_row_size));
  1062. tile[13] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1063. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1064. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING));
  1065. tile[14] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1066. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1067. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1068. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1069. tile[15] = (ARRAY_MODE(ARRAY_3D_TILED_THIN1) |
  1070. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1071. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1072. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1073. tile[16] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1074. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1075. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1076. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1077. tile[17] = (TILE_SPLIT(split_equal_to_row_size));
  1078. tile[18] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1079. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1080. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1081. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1082. tile[19] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1083. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1084. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING));
  1085. tile[20] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1086. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1087. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1088. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1089. tile[21] = (ARRAY_MODE(ARRAY_3D_TILED_THICK) |
  1090. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1091. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1092. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1093. tile[22] = (ARRAY_MODE(ARRAY_PRT_TILED_THICK) |
  1094. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1095. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1096. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1097. tile[23] = (TILE_SPLIT(split_equal_to_row_size));
  1098. tile[24] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1099. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1100. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1101. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1102. tile[25] = (ARRAY_MODE(ARRAY_2D_TILED_XTHICK) |
  1103. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1104. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1105. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1106. tile[26] = (ARRAY_MODE(ARRAY_3D_TILED_XTHICK) |
  1107. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1108. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1109. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1110. tile[27] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1111. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1112. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING));
  1113. tile[28] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1114. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1115. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1116. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1117. tile[29] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1118. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1119. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1120. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1121. tile[30] = (TILE_SPLIT(split_equal_to_row_size));
  1122. macrotile[0] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1123. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1124. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1125. NUM_BANKS(ADDR_SURF_16_BANK));
  1126. macrotile[1] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1127. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1128. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1129. NUM_BANKS(ADDR_SURF_16_BANK));
  1130. macrotile[2] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1131. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1132. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1133. NUM_BANKS(ADDR_SURF_16_BANK));
  1134. macrotile[3] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1135. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1136. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1137. NUM_BANKS(ADDR_SURF_16_BANK));
  1138. macrotile[4] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1139. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1140. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1141. NUM_BANKS(ADDR_SURF_16_BANK));
  1142. macrotile[5] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1143. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1144. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1145. NUM_BANKS(ADDR_SURF_8_BANK));
  1146. macrotile[6] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1147. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1148. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1149. NUM_BANKS(ADDR_SURF_4_BANK));
  1150. macrotile[8] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_2) |
  1151. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_8) |
  1152. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1153. NUM_BANKS(ADDR_SURF_16_BANK));
  1154. macrotile[9] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_2) |
  1155. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1156. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1157. NUM_BANKS(ADDR_SURF_16_BANK));
  1158. macrotile[10] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1159. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1160. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1161. NUM_BANKS(ADDR_SURF_16_BANK));
  1162. macrotile[11] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1163. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1164. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1165. NUM_BANKS(ADDR_SURF_16_BANK));
  1166. macrotile[12] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1167. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1168. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1169. NUM_BANKS(ADDR_SURF_16_BANK));
  1170. macrotile[13] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1171. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1172. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1173. NUM_BANKS(ADDR_SURF_8_BANK));
  1174. macrotile[14] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1175. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1176. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1177. NUM_BANKS(ADDR_SURF_4_BANK));
  1178. for (reg_offset = 0; reg_offset < num_tile_mode_states; reg_offset++)
  1179. WREG32(mmGB_TILE_MODE0 + reg_offset, tile[reg_offset]);
  1180. for (reg_offset = 0; reg_offset < num_secondary_tile_mode_states; reg_offset++)
  1181. if (reg_offset != 7)
  1182. WREG32(mmGB_MACROTILE_MODE0 + reg_offset, macrotile[reg_offset]);
  1183. break;
  1184. case CHIP_HAWAII:
  1185. tile[0] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1186. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1187. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_64B) |
  1188. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1189. tile[1] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1190. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1191. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_128B) |
  1192. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1193. tile[2] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1194. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1195. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_256B) |
  1196. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1197. tile[3] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1198. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1199. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_512B) |
  1200. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1201. tile[4] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1202. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1203. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1204. TILE_SPLIT(split_equal_to_row_size));
  1205. tile[5] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1206. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1207. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1208. TILE_SPLIT(split_equal_to_row_size));
  1209. tile[6] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1210. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1211. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1212. TILE_SPLIT(split_equal_to_row_size));
  1213. tile[7] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1214. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1215. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1216. TILE_SPLIT(split_equal_to_row_size));
  1217. tile[8] = (ARRAY_MODE(ARRAY_LINEAR_ALIGNED) |
  1218. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16));
  1219. tile[9] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1220. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1221. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING));
  1222. tile[10] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1223. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1224. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1225. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1226. tile[11] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1227. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1228. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1229. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1230. tile[12] = (ARRAY_MODE(ARRAY_PRT_2D_TILED_THIN1) |
  1231. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1232. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1233. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1234. tile[13] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1235. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1236. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING));
  1237. tile[14] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1238. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1239. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1240. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1241. tile[15] = (ARRAY_MODE(ARRAY_3D_TILED_THIN1) |
  1242. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1243. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1244. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1245. tile[16] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1246. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1247. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1248. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1249. tile[17] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1250. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1251. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1252. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1253. tile[18] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1254. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1255. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1256. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1257. tile[19] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1258. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1259. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING));
  1260. tile[20] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1261. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1262. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1263. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1264. tile[21] = (ARRAY_MODE(ARRAY_3D_TILED_THICK) |
  1265. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1266. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1267. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1268. tile[22] = (ARRAY_MODE(ARRAY_PRT_TILED_THICK) |
  1269. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1270. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1271. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1272. tile[23] = (ARRAY_MODE(ARRAY_PRT_TILED_THICK) |
  1273. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1274. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1275. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1276. tile[24] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1277. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1278. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1279. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1280. tile[25] = (ARRAY_MODE(ARRAY_2D_TILED_XTHICK) |
  1281. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1282. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1283. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1284. tile[26] = (ARRAY_MODE(ARRAY_3D_TILED_XTHICK) |
  1285. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1286. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1287. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1288. tile[27] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1289. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1290. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING));
  1291. tile[28] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1292. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1293. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1294. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1295. tile[29] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1296. PIPE_CONFIG(ADDR_SURF_P16_32x32_16x16) |
  1297. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1298. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1299. tile[30] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1300. PIPE_CONFIG(ADDR_SURF_P4_16x16) |
  1301. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1302. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1303. macrotile[0] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1304. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1305. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1306. NUM_BANKS(ADDR_SURF_16_BANK));
  1307. macrotile[1] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1308. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1309. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1310. NUM_BANKS(ADDR_SURF_16_BANK));
  1311. macrotile[2] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1312. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1313. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1314. NUM_BANKS(ADDR_SURF_16_BANK));
  1315. macrotile[3] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1316. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1317. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1318. NUM_BANKS(ADDR_SURF_16_BANK));
  1319. macrotile[4] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1320. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1321. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1322. NUM_BANKS(ADDR_SURF_8_BANK));
  1323. macrotile[5] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1324. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1325. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1326. NUM_BANKS(ADDR_SURF_4_BANK));
  1327. macrotile[6] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1328. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1329. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1330. NUM_BANKS(ADDR_SURF_4_BANK));
  1331. macrotile[8] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1332. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1333. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1334. NUM_BANKS(ADDR_SURF_16_BANK));
  1335. macrotile[9] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1336. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1337. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1338. NUM_BANKS(ADDR_SURF_16_BANK));
  1339. macrotile[10] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1340. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1341. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1342. NUM_BANKS(ADDR_SURF_16_BANK));
  1343. macrotile[11] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1344. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1345. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1346. NUM_BANKS(ADDR_SURF_8_BANK));
  1347. macrotile[12] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1348. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1349. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1350. NUM_BANKS(ADDR_SURF_16_BANK));
  1351. macrotile[13] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1352. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1353. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1354. NUM_BANKS(ADDR_SURF_8_BANK));
  1355. macrotile[14] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1356. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1357. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_1) |
  1358. NUM_BANKS(ADDR_SURF_4_BANK));
  1359. for (reg_offset = 0; reg_offset < num_tile_mode_states; reg_offset++)
  1360. WREG32(mmGB_TILE_MODE0 + reg_offset, tile[reg_offset]);
  1361. for (reg_offset = 0; reg_offset < num_secondary_tile_mode_states; reg_offset++)
  1362. if (reg_offset != 7)
  1363. WREG32(mmGB_MACROTILE_MODE0 + reg_offset, macrotile[reg_offset]);
  1364. break;
  1365. case CHIP_KABINI:
  1366. case CHIP_KAVERI:
  1367. case CHIP_MULLINS:
  1368. default:
  1369. tile[0] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1370. PIPE_CONFIG(ADDR_SURF_P2) |
  1371. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_64B) |
  1372. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1373. tile[1] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1374. PIPE_CONFIG(ADDR_SURF_P2) |
  1375. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_128B) |
  1376. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1377. tile[2] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1378. PIPE_CONFIG(ADDR_SURF_P2) |
  1379. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_256B) |
  1380. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1381. tile[3] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1382. PIPE_CONFIG(ADDR_SURF_P2) |
  1383. TILE_SPLIT(ADDR_SURF_TILE_SPLIT_512B) |
  1384. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1385. tile[4] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1386. PIPE_CONFIG(ADDR_SURF_P2) |
  1387. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1388. TILE_SPLIT(split_equal_to_row_size));
  1389. tile[5] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1390. PIPE_CONFIG(ADDR_SURF_P2) |
  1391. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING));
  1392. tile[6] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1393. PIPE_CONFIG(ADDR_SURF_P2) |
  1394. MICRO_TILE_MODE_NEW(ADDR_SURF_DEPTH_MICRO_TILING) |
  1395. TILE_SPLIT(split_equal_to_row_size));
  1396. tile[7] = (TILE_SPLIT(split_equal_to_row_size));
  1397. tile[8] = (ARRAY_MODE(ARRAY_LINEAR_ALIGNED) |
  1398. PIPE_CONFIG(ADDR_SURF_P2));
  1399. tile[9] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1400. PIPE_CONFIG(ADDR_SURF_P2) |
  1401. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING));
  1402. tile[10] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1403. PIPE_CONFIG(ADDR_SURF_P2) |
  1404. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1405. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1406. tile[11] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1407. PIPE_CONFIG(ADDR_SURF_P2) |
  1408. MICRO_TILE_MODE_NEW(ADDR_SURF_DISPLAY_MICRO_TILING) |
  1409. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1410. tile[12] = (TILE_SPLIT(split_equal_to_row_size));
  1411. tile[13] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1412. PIPE_CONFIG(ADDR_SURF_P2) |
  1413. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING));
  1414. tile[14] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1415. PIPE_CONFIG(ADDR_SURF_P2) |
  1416. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1417. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1418. tile[15] = (ARRAY_MODE(ARRAY_3D_TILED_THIN1) |
  1419. PIPE_CONFIG(ADDR_SURF_P2) |
  1420. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1421. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1422. tile[16] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1423. PIPE_CONFIG(ADDR_SURF_P2) |
  1424. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1425. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1426. tile[17] = (TILE_SPLIT(split_equal_to_row_size));
  1427. tile[18] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1428. PIPE_CONFIG(ADDR_SURF_P2) |
  1429. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1430. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1431. tile[19] = (ARRAY_MODE(ARRAY_1D_TILED_THICK) |
  1432. PIPE_CONFIG(ADDR_SURF_P2) |
  1433. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING));
  1434. tile[20] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1435. PIPE_CONFIG(ADDR_SURF_P2) |
  1436. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1437. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1438. tile[21] = (ARRAY_MODE(ARRAY_3D_TILED_THICK) |
  1439. PIPE_CONFIG(ADDR_SURF_P2) |
  1440. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1441. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1442. tile[22] = (ARRAY_MODE(ARRAY_PRT_TILED_THICK) |
  1443. PIPE_CONFIG(ADDR_SURF_P2) |
  1444. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1445. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1446. tile[23] = (TILE_SPLIT(split_equal_to_row_size));
  1447. tile[24] = (ARRAY_MODE(ARRAY_2D_TILED_THICK) |
  1448. PIPE_CONFIG(ADDR_SURF_P2) |
  1449. MICRO_TILE_MODE_NEW(ADDR_SURF_THIN_MICRO_TILING) |
  1450. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1451. tile[25] = (ARRAY_MODE(ARRAY_2D_TILED_XTHICK) |
  1452. PIPE_CONFIG(ADDR_SURF_P2) |
  1453. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1454. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1455. tile[26] = (ARRAY_MODE(ARRAY_3D_TILED_XTHICK) |
  1456. PIPE_CONFIG(ADDR_SURF_P2) |
  1457. MICRO_TILE_MODE_NEW(ADDR_SURF_THICK_MICRO_TILING) |
  1458. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_1));
  1459. tile[27] = (ARRAY_MODE(ARRAY_1D_TILED_THIN1) |
  1460. PIPE_CONFIG(ADDR_SURF_P2) |
  1461. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING));
  1462. tile[28] = (ARRAY_MODE(ARRAY_2D_TILED_THIN1) |
  1463. PIPE_CONFIG(ADDR_SURF_P2) |
  1464. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1465. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_2));
  1466. tile[29] = (ARRAY_MODE(ARRAY_PRT_TILED_THIN1) |
  1467. PIPE_CONFIG(ADDR_SURF_P2) |
  1468. MICRO_TILE_MODE_NEW(ADDR_SURF_ROTATED_MICRO_TILING) |
  1469. SAMPLE_SPLIT(ADDR_SURF_SAMPLE_SPLIT_8));
  1470. tile[30] = (TILE_SPLIT(split_equal_to_row_size));
  1471. macrotile[0] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1472. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_4) |
  1473. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1474. NUM_BANKS(ADDR_SURF_8_BANK));
  1475. macrotile[1] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1476. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1477. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1478. NUM_BANKS(ADDR_SURF_8_BANK));
  1479. macrotile[2] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1480. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_2) |
  1481. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1482. NUM_BANKS(ADDR_SURF_8_BANK));
  1483. macrotile[3] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1484. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1485. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1486. NUM_BANKS(ADDR_SURF_8_BANK));
  1487. macrotile[4] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1488. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1489. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1490. NUM_BANKS(ADDR_SURF_8_BANK));
  1491. macrotile[5] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1492. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1493. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1494. NUM_BANKS(ADDR_SURF_8_BANK));
  1495. macrotile[6] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_1) |
  1496. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_1) |
  1497. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_2) |
  1498. NUM_BANKS(ADDR_SURF_8_BANK));
  1499. macrotile[8] = (BANK_WIDTH(ADDR_SURF_BANK_WIDTH_4) |
  1500. BANK_HEIGHT(ADDR_SURF_BANK_HEIGHT_8) |
  1501. MACRO_TILE_ASPECT(ADDR_SURF_MACRO_ASPECT_4) |
  1502. NUM_BANKS(ADDR_SURF_16_BANK));
  1503. macrotile[9] = (BANK_WIDTH(ADDR_SURF_