radeon_clocks.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833
  1. /*
  2. * Copyright 2008 Advanced Micro Devices, Inc.
  3. * Copyright 2008 Red Hat Inc.
  4. * Copyright 2009 Jerome Glisse.
  5. *
  6. * Permission is hereby granted, free of charge, to any person obtaining a
  7. * copy of this software and associated documentation files (the "Software"),
  8. * to deal in the Software without restriction, including without limitation
  9. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  10. * and/or sell copies of the Software, and to permit persons to whom the
  11. * Software is furnished to do so, subject to the following conditions:
  12. *
  13. * The above copyright notice and this permission notice shall be included in
  14. * all copies or substantial portions of the Software.
  15. *
  16. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  17. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  18. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  19. * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
  20. * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
  21. * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
  22. * OTHER DEALINGS IN THE SOFTWARE.
  23. *
  24. * Authors: Dave Airlie
  25. * Alex Deucher
  26. * Jerome Glisse
  27. */
  28. #include "drmP.h"
  29. #include "radeon_drm.h"
  30. #include "radeon_reg.h"
  31. #include "radeon.h"
  32. #include "atom.h"
  33. /* 10 khz */
  34. static uint32_t radeon_legacy_get_engine_clock(struct radeon_device *rdev)
  35. {
  36. struct radeon_pll *spll = &rdev->clock.spll;
  37. uint32_t fb_div, ref_div, post_div, sclk;
  38. fb_div = RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV);
  39. fb_div = (fb_div >> RADEON_SPLL_FB_DIV_SHIFT) & RADEON_SPLL_FB_DIV_MASK;
  40. fb_div <<= 1;
  41. fb_div *= spll->reference_freq;
  42. ref_div =
  43. RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV) & RADEON_M_SPLL_REF_DIV_MASK;
  44. sclk = fb_div / ref_div;
  45. post_div = RREG32_PLL(RADEON_SCLK_CNTL) & RADEON_SCLK_SRC_SEL_MASK;
  46. if (post_div == 2)
  47. sclk >>= 1;
  48. else if (post_div == 3)
  49. sclk >>= 2;
  50. else if (post_div == 4)
  51. sclk >>= 4;
  52. return sclk;
  53. }
  54. /* 10 khz */
  55. static uint32_t radeon_legacy_get_memory_clock(struct radeon_device *rdev)
  56. {
  57. struct radeon_pll *mpll = &rdev->clock.mpll;
  58. uint32_t fb_div, ref_div, post_div, mclk;
  59. fb_div = RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV);
  60. fb_div = (fb_div >> RADEON_MPLL_FB_DIV_SHIFT) & RADEON_MPLL_FB_DIV_MASK;
  61. fb_div <<= 1;
  62. fb_div *= mpll->reference_freq;
  63. ref_div =
  64. RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV) & RADEON_M_SPLL_REF_DIV_MASK;
  65. mclk = fb_div / ref_div;
  66. post_div = RREG32_PLL(RADEON_MCLK_CNTL) & 0x7;
  67. if (post_div == 2)
  68. mclk >>= 1;
  69. else if (post_div == 3)
  70. mclk >>= 2;
  71. else if (post_div == 4)
  72. mclk >>= 4;
  73. return mclk;
  74. }
  75. void radeon_get_clock_info(struct drm_device *dev)
  76. {
  77. struct radeon_device *rdev = dev->dev_private;
  78. struct radeon_pll *p1pll = &rdev->clock.p1pll;
  79. struct radeon_pll *p2pll = &rdev->clock.p2pll;
  80. struct radeon_pll *spll = &rdev->clock.spll;
  81. struct radeon_pll *mpll = &rdev->clock.mpll;
  82. int ret;
  83. if (rdev->is_atom_bios)
  84. ret = radeon_atom_get_clock_info(dev);
  85. else
  86. ret = radeon_combios_get_clock_info(dev);
  87. if (ret) {
  88. if (p1pll->reference_div < 2)
  89. p1pll->reference_div = 12;
  90. if (p2pll->reference_div < 2)
  91. p2pll->reference_div = 12;
  92. if (spll->reference_div < 2)
  93. spll->reference_div =
  94. RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV) &
  95. RADEON_M_SPLL_REF_DIV_MASK;
  96. if (mpll->reference_div < 2)
  97. mpll->reference_div = spll->reference_div;
  98. } else {
  99. if (ASIC_IS_AVIVO(rdev)) {
  100. /* TODO FALLBACK */
  101. } else {
  102. DRM_INFO("Using generic clock info\n");
  103. if (rdev->flags & RADEON_IS_IGP) {
  104. p1pll->reference_freq = 1432;
  105. p2pll->reference_freq = 1432;
  106. spll->reference_freq = 1432;
  107. mpll->reference_freq = 1432;
  108. } else {
  109. p1pll->reference_freq = 2700;
  110. p2pll->reference_freq = 2700;
  111. spll->reference_freq = 2700;
  112. mpll->reference_freq = 2700;
  113. }
  114. p1pll->reference_div =
  115. RREG32_PLL(RADEON_PPLL_REF_DIV) & 0x3ff;
  116. if (p1pll->reference_div < 2)
  117. p1pll->reference_div = 12;
  118. p2pll->reference_div = p1pll->reference_div;
  119. if (rdev->family >= CHIP_R420) {
  120. p1pll->pll_in_min = 100;
  121. p1pll->pll_in_max = 1350;
  122. p1pll->pll_out_min = 20000;
  123. p1pll->pll_out_max = 50000;
  124. p2pll->pll_in_min = 100;
  125. p2pll->pll_in_max = 1350;
  126. p2pll->pll_out_min = 20000;
  127. p2pll->pll_out_max = 50000;
  128. } else {
  129. p1pll->pll_in_min = 40;
  130. p1pll->pll_in_max = 500;
  131. p1pll->pll_out_min = 12500;
  132. p1pll->pll_out_max = 35000;
  133. p2pll->pll_in_min = 40;
  134. p2pll->pll_in_max = 500;
  135. p2pll->pll_out_min = 12500;
  136. p2pll->pll_out_max = 35000;
  137. }
  138. spll->reference_div =
  139. RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV) &
  140. RADEON_M_SPLL_REF_DIV_MASK;
  141. mpll->reference_div = spll->reference_div;
  142. rdev->clock.default_sclk =
  143. radeon_legacy_get_engine_clock(rdev);
  144. rdev->clock.default_mclk =
  145. radeon_legacy_get_memory_clock(rdev);
  146. }
  147. }
  148. /* pixel clocks */
  149. if (ASIC_IS_AVIVO(rdev)) {
  150. p1pll->min_post_div = 2;
  151. p1pll->max_post_div = 0x7f;
  152. p1pll->min_frac_feedback_div = 0;
  153. p1pll->max_frac_feedback_div = 9;
  154. p2pll->min_post_div = 2;
  155. p2pll->max_post_div = 0x7f;
  156. p2pll->min_frac_feedback_div = 0;
  157. p2pll->max_frac_feedback_div = 9;
  158. } else {
  159. p1pll->min_post_div = 1;
  160. p1pll->max_post_div = 16;
  161. p1pll->min_frac_feedback_div = 0;
  162. p1pll->max_frac_feedback_div = 0;
  163. p2pll->min_post_div = 1;
  164. p2pll->max_post_div = 12;
  165. p2pll->min_frac_feedback_div = 0;
  166. p2pll->max_frac_feedback_div = 0;
  167. }
  168. p1pll->min_ref_div = 2;
  169. p1pll->max_ref_div = 0x3ff;
  170. p1pll->min_feedback_div = 4;
  171. p1pll->max_feedback_div = 0x7ff;
  172. p1pll->best_vco = 0;
  173. p2pll->min_ref_div = 2;
  174. p2pll->max_ref_div = 0x3ff;
  175. p2pll->min_feedback_div = 4;
  176. p2pll->max_feedback_div = 0x7ff;
  177. p2pll->best_vco = 0;
  178. /* system clock */
  179. spll->min_post_div = 1;
  180. spll->max_post_div = 1;
  181. spll->min_ref_div = 2;
  182. spll->max_ref_div = 0xff;
  183. spll->min_feedback_div = 4;
  184. spll->max_feedback_div = 0xff;
  185. spll->best_vco = 0;
  186. /* memory clock */
  187. mpll->min_post_div = 1;
  188. mpll->max_post_div = 1;
  189. mpll->min_ref_div = 2;
  190. mpll->max_ref_div = 0xff;
  191. mpll->min_feedback_div = 4;
  192. mpll->max_feedback_div = 0xff;
  193. mpll->best_vco = 0;
  194. }
  195. /* 10 khz */
  196. static uint32_t calc_eng_mem_clock(struct radeon_device *rdev,
  197. uint32_t req_clock,
  198. int *fb_div, int *post_div)
  199. {
  200. struct radeon_pll *spll = &rdev->clock.spll;
  201. int ref_div = spll->reference_div;
  202. if (!ref_div)
  203. ref_div =
  204. RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV) &
  205. RADEON_M_SPLL_REF_DIV_MASK;
  206. if (req_clock < 15000) {
  207. *post_div = 8;
  208. req_clock *= 8;
  209. } else if (req_clock < 30000) {
  210. *post_div = 4;
  211. req_clock *= 4;
  212. } else if (req_clock < 60000) {
  213. *post_div = 2;
  214. req_clock *= 2;
  215. } else
  216. *post_div = 1;
  217. req_clock *= ref_div;
  218. req_clock += spll->reference_freq;
  219. req_clock /= (2 * spll->reference_freq);
  220. *fb_div = req_clock & 0xff;
  221. req_clock = (req_clock & 0xffff) << 1;
  222. req_clock *= spll->reference_freq;
  223. req_clock /= ref_div;
  224. req_clock /= *post_div;
  225. return req_clock;
  226. }
  227. /* 10 khz */
  228. void radeon_legacy_set_engine_clock(struct radeon_device *rdev,
  229. uint32_t eng_clock)
  230. {
  231. uint32_t tmp;
  232. int fb_div, post_div;
  233. /* XXX: wait for idle */
  234. eng_clock = calc_eng_mem_clock(rdev, eng_clock, &fb_div, &post_div);
  235. tmp = RREG32_PLL(RADEON_CLK_PIN_CNTL);
  236. tmp &= ~RADEON_DONT_USE_XTALIN;
  237. WREG32_PLL(RADEON_CLK_PIN_CNTL, tmp);
  238. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  239. tmp &= ~RADEON_SCLK_SRC_SEL_MASK;
  240. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  241. udelay(10);
  242. tmp = RREG32_PLL(RADEON_SPLL_CNTL);
  243. tmp |= RADEON_SPLL_SLEEP;
  244. WREG32_PLL(RADEON_SPLL_CNTL, tmp);
  245. udelay(2);
  246. tmp = RREG32_PLL(RADEON_SPLL_CNTL);
  247. tmp |= RADEON_SPLL_RESET;
  248. WREG32_PLL(RADEON_SPLL_CNTL, tmp);
  249. udelay(200);
  250. tmp = RREG32_PLL(RADEON_M_SPLL_REF_FB_DIV);
  251. tmp &= ~(RADEON_SPLL_FB_DIV_MASK << RADEON_SPLL_FB_DIV_SHIFT);
  252. tmp |= (fb_div & RADEON_SPLL_FB_DIV_MASK) << RADEON_SPLL_FB_DIV_SHIFT;
  253. WREG32_PLL(RADEON_M_SPLL_REF_FB_DIV, tmp);
  254. /* XXX: verify on different asics */
  255. tmp = RREG32_PLL(RADEON_SPLL_CNTL);
  256. tmp &= ~RADEON_SPLL_PVG_MASK;
  257. if ((eng_clock * post_div) >= 90000)
  258. tmp |= (0x7 << RADEON_SPLL_PVG_SHIFT);
  259. else
  260. tmp |= (0x4 << RADEON_SPLL_PVG_SHIFT);
  261. WREG32_PLL(RADEON_SPLL_CNTL, tmp);
  262. tmp = RREG32_PLL(RADEON_SPLL_CNTL);
  263. tmp &= ~RADEON_SPLL_SLEEP;
  264. WREG32_PLL(RADEON_SPLL_CNTL, tmp);
  265. udelay(2);
  266. tmp = RREG32_PLL(RADEON_SPLL_CNTL);
  267. tmp &= ~RADEON_SPLL_RESET;
  268. WREG32_PLL(RADEON_SPLL_CNTL, tmp);
  269. udelay(200);
  270. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  271. tmp &= ~RADEON_SCLK_SRC_SEL_MASK;
  272. switch (post_div) {
  273. case 1:
  274. default:
  275. tmp |= 1;
  276. break;
  277. case 2:
  278. tmp |= 2;
  279. break;
  280. case 4:
  281. tmp |= 3;
  282. break;
  283. case 8:
  284. tmp |= 4;
  285. break;
  286. }
  287. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  288. udelay(20);
  289. tmp = RREG32_PLL(RADEON_CLK_PIN_CNTL);
  290. tmp |= RADEON_DONT_USE_XTALIN;
  291. WREG32_PLL(RADEON_CLK_PIN_CNTL, tmp);
  292. udelay(10);
  293. }
  294. void radeon_legacy_set_clock_gating(struct radeon_device *rdev, int enable)
  295. {
  296. uint32_t tmp;
  297. if (enable) {
  298. if (rdev->flags & RADEON_SINGLE_CRTC) {
  299. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  300. if ((RREG32(RADEON_CONFIG_CNTL) &
  301. RADEON_CFG_ATI_REV_ID_MASK) >
  302. RADEON_CFG_ATI_REV_A13) {
  303. tmp &=
  304. ~(RADEON_SCLK_FORCE_CP |
  305. RADEON_SCLK_FORCE_RB);
  306. }
  307. tmp &=
  308. ~(RADEON_SCLK_FORCE_HDP | RADEON_SCLK_FORCE_DISP1 |
  309. RADEON_SCLK_FORCE_TOP | RADEON_SCLK_FORCE_SE |
  310. RADEON_SCLK_FORCE_IDCT | RADEON_SCLK_FORCE_RE |
  311. RADEON_SCLK_FORCE_PB | RADEON_SCLK_FORCE_TAM |
  312. RADEON_SCLK_FORCE_TDM);
  313. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  314. } else if (ASIC_IS_R300(rdev)) {
  315. if ((rdev->family == CHIP_RS400) ||
  316. (rdev->family == CHIP_RS480)) {
  317. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  318. tmp &=
  319. ~(RADEON_SCLK_FORCE_DISP2 |
  320. RADEON_SCLK_FORCE_CP |
  321. RADEON_SCLK_FORCE_HDP |
  322. RADEON_SCLK_FORCE_DISP1 |
  323. RADEON_SCLK_FORCE_TOP |
  324. RADEON_SCLK_FORCE_E2 | R300_SCLK_FORCE_VAP
  325. | RADEON_SCLK_FORCE_IDCT |
  326. RADEON_SCLK_FORCE_VIP | R300_SCLK_FORCE_SR
  327. | R300_SCLK_FORCE_PX | R300_SCLK_FORCE_TX
  328. | R300_SCLK_FORCE_US |
  329. RADEON_SCLK_FORCE_TV_SCLK |
  330. R300_SCLK_FORCE_SU |
  331. RADEON_SCLK_FORCE_OV0);
  332. tmp |= RADEON_DYN_STOP_LAT_MASK;
  333. tmp |=
  334. RADEON_SCLK_FORCE_TOP |
  335. RADEON_SCLK_FORCE_VIP;
  336. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  337. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  338. tmp &= ~RADEON_SCLK_MORE_FORCEON;
  339. tmp |= RADEON_SCLK_MORE_MAX_DYN_STOP_LAT;
  340. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  341. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  342. tmp |= (RADEON_PIXCLK_ALWAYS_ONb |
  343. RADEON_PIXCLK_DAC_ALWAYS_ONb);
  344. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  345. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  346. tmp |= (RADEON_PIX2CLK_ALWAYS_ONb |
  347. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  348. RADEON_DISP_TVOUT_PIXCLK_TV_ALWAYS_ONb |
  349. R300_DVOCLK_ALWAYS_ONb |
  350. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  351. RADEON_PIXCLK_GV_ALWAYS_ONb |
  352. R300_PIXCLK_DVO_ALWAYS_ONb |
  353. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  354. RADEON_PIXCLK_TMDS_ALWAYS_ONb |
  355. R300_PIXCLK_TRANS_ALWAYS_ONb |
  356. R300_PIXCLK_TVO_ALWAYS_ONb |
  357. R300_P2G2CLK_ALWAYS_ONb |
  358. R300_P2G2CLK_ALWAYS_ONb);
  359. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  360. } else if (rdev->family >= CHIP_RV350) {
  361. tmp = RREG32_PLL(R300_SCLK_CNTL2);
  362. tmp &= ~(R300_SCLK_FORCE_TCL |
  363. R300_SCLK_FORCE_GA |
  364. R300_SCLK_FORCE_CBA);
  365. tmp |= (R300_SCLK_TCL_MAX_DYN_STOP_LAT |
  366. R300_SCLK_GA_MAX_DYN_STOP_LAT |
  367. R300_SCLK_CBA_MAX_DYN_STOP_LAT);
  368. WREG32_PLL(R300_SCLK_CNTL2, tmp);
  369. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  370. tmp &=
  371. ~(RADEON_SCLK_FORCE_DISP2 |
  372. RADEON_SCLK_FORCE_CP |
  373. RADEON_SCLK_FORCE_HDP |
  374. RADEON_SCLK_FORCE_DISP1 |
  375. RADEON_SCLK_FORCE_TOP |
  376. RADEON_SCLK_FORCE_E2 | R300_SCLK_FORCE_VAP
  377. | RADEON_SCLK_FORCE_IDCT |
  378. RADEON_SCLK_FORCE_VIP | R300_SCLK_FORCE_SR
  379. | R300_SCLK_FORCE_PX | R300_SCLK_FORCE_TX
  380. | R300_SCLK_FORCE_US |
  381. RADEON_SCLK_FORCE_TV_SCLK |
  382. R300_SCLK_FORCE_SU |
  383. RADEON_SCLK_FORCE_OV0);
  384. tmp |= RADEON_DYN_STOP_LAT_MASK;
  385. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  386. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  387. tmp &= ~RADEON_SCLK_MORE_FORCEON;
  388. tmp |= RADEON_SCLK_MORE_MAX_DYN_STOP_LAT;
  389. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  390. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  391. tmp |= (RADEON_PIXCLK_ALWAYS_ONb |
  392. RADEON_PIXCLK_DAC_ALWAYS_ONb);
  393. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  394. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  395. tmp |= (RADEON_PIX2CLK_ALWAYS_ONb |
  396. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  397. RADEON_DISP_TVOUT_PIXCLK_TV_ALWAYS_ONb |
  398. R300_DVOCLK_ALWAYS_ONb |
  399. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  400. RADEON_PIXCLK_GV_ALWAYS_ONb |
  401. R300_PIXCLK_DVO_ALWAYS_ONb |
  402. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  403. RADEON_PIXCLK_TMDS_ALWAYS_ONb |
  404. R300_PIXCLK_TRANS_ALWAYS_ONb |
  405. R300_PIXCLK_TVO_ALWAYS_ONb |
  406. R300_P2G2CLK_ALWAYS_ONb |
  407. R300_P2G2CLK_ALWAYS_ONb);
  408. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  409. tmp = RREG32_PLL(RADEON_MCLK_MISC);
  410. tmp |= (RADEON_MC_MCLK_DYN_ENABLE |
  411. RADEON_IO_MCLK_DYN_ENABLE);
  412. WREG32_PLL(RADEON_MCLK_MISC, tmp);
  413. tmp = RREG32_PLL(RADEON_MCLK_CNTL);
  414. tmp |= (RADEON_FORCEON_MCLKA |
  415. RADEON_FORCEON_MCLKB);
  416. tmp &= ~(RADEON_FORCEON_YCLKA |
  417. RADEON_FORCEON_YCLKB |
  418. RADEON_FORCEON_MC);
  419. /* Some releases of vbios have set DISABLE_MC_MCLKA
  420. and DISABLE_MC_MCLKB bits in the vbios table. Setting these
  421. bits will cause H/W hang when reading video memory with dynamic clocking
  422. enabled. */
  423. if ((tmp & R300_DISABLE_MC_MCLKA) &&
  424. (tmp & R300_DISABLE_MC_MCLKB)) {
  425. /* If both bits are set, then check the active channels */
  426. tmp = RREG32_PLL(RADEON_MCLK_CNTL);
  427. if (rdev->mc.vram_width == 64) {
  428. if (RREG32(RADEON_MEM_CNTL) &
  429. R300_MEM_USE_CD_CH_ONLY)
  430. tmp &=
  431. ~R300_DISABLE_MC_MCLKB;
  432. else
  433. tmp &=
  434. ~R300_DISABLE_MC_MCLKA;
  435. } else {
  436. tmp &= ~(R300_DISABLE_MC_MCLKA |
  437. R300_DISABLE_MC_MCLKB);
  438. }
  439. }
  440. WREG32_PLL(RADEON_MCLK_CNTL, tmp);
  441. } else {
  442. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  443. tmp &= ~(R300_SCLK_FORCE_VAP);
  444. tmp |= RADEON_SCLK_FORCE_CP;
  445. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  446. udelay(15000);
  447. tmp = RREG32_PLL(R300_SCLK_CNTL2);
  448. tmp &= ~(R300_SCLK_FORCE_TCL |
  449. R300_SCLK_FORCE_GA |
  450. R300_SCLK_FORCE_CBA);
  451. WREG32_PLL(R300_SCLK_CNTL2, tmp);
  452. }
  453. } else {
  454. tmp = RREG32_PLL(RADEON_CLK_PWRMGT_CNTL);
  455. tmp &= ~(RADEON_ACTIVE_HILO_LAT_MASK |
  456. RADEON_DISP_DYN_STOP_LAT_MASK |
  457. RADEON_DYN_STOP_MODE_MASK);
  458. tmp |= (RADEON_ENGIN_DYNCLK_MODE |
  459. (0x01 << RADEON_ACTIVE_HILO_LAT_SHIFT));
  460. WREG32_PLL(RADEON_CLK_PWRMGT_CNTL, tmp);
  461. udelay(15000);
  462. tmp = RREG32_PLL(RADEON_CLK_PIN_CNTL);
  463. tmp |= RADEON_SCLK_DYN_START_CNTL;
  464. WREG32_PLL(RADEON_CLK_PIN_CNTL, tmp);
  465. udelay(15000);
  466. /* When DRI is enabled, setting DYN_STOP_LAT to zero can cause some R200
  467. to lockup randomly, leave them as set by BIOS.
  468. */
  469. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  470. /*tmp &= RADEON_SCLK_SRC_SEL_MASK; */
  471. tmp &= ~RADEON_SCLK_FORCEON_MASK;
  472. /*RAGE_6::A11 A12 A12N1 A13, RV250::A11 A12, R300 */
  473. if (((rdev->family == CHIP_RV250) &&
  474. ((RREG32(RADEON_CONFIG_CNTL) &
  475. RADEON_CFG_ATI_REV_ID_MASK) <
  476. RADEON_CFG_ATI_REV_A13))
  477. || ((rdev->family == CHIP_RV100)
  478. &&
  479. ((RREG32(RADEON_CONFIG_CNTL) &
  480. RADEON_CFG_ATI_REV_ID_MASK) <=
  481. RADEON_CFG_ATI_REV_A13))) {
  482. tmp |= RADEON_SCLK_FORCE_CP;
  483. tmp |= RADEON_SCLK_FORCE_VIP;
  484. }
  485. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  486. if ((rdev->family == CHIP_RV200) ||
  487. (rdev->family == CHIP_RV250) ||
  488. (rdev->family == CHIP_RV280)) {
  489. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  490. tmp &= ~RADEON_SCLK_MORE_FORCEON;
  491. /* RV200::A11 A12 RV250::A11 A12 */
  492. if (((rdev->family == CHIP_RV200) ||
  493. (rdev->family == CHIP_RV250)) &&
  494. ((RREG32(RADEON_CONFIG_CNTL) &
  495. RADEON_CFG_ATI_REV_ID_MASK) <
  496. RADEON_CFG_ATI_REV_A13)) {
  497. tmp |= RADEON_SCLK_MORE_FORCEON;
  498. }
  499. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  500. udelay(15000);
  501. }
  502. /* RV200::A11 A12, RV250::A11 A12 */
  503. if (((rdev->family == CHIP_RV200) ||
  504. (rdev->family == CHIP_RV250)) &&
  505. ((RREG32(RADEON_CONFIG_CNTL) &
  506. RADEON_CFG_ATI_REV_ID_MASK) <
  507. RADEON_CFG_ATI_REV_A13)) {
  508. tmp = RREG32_PLL(RADEON_PLL_PWRMGT_CNTL);
  509. tmp |= RADEON_TCL_BYPASS_DISABLE;
  510. WREG32_PLL(RADEON_PLL_PWRMGT_CNTL, tmp);
  511. }
  512. udelay(15000);
  513. /*enable dynamic mode for display clocks (PIXCLK and PIX2CLK) */
  514. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  515. tmp |= (RADEON_PIX2CLK_ALWAYS_ONb |
  516. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  517. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  518. RADEON_PIXCLK_GV_ALWAYS_ONb |
  519. RADEON_PIXCLK_DIG_TMDS_ALWAYS_ONb |
  520. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  521. RADEON_PIXCLK_TMDS_ALWAYS_ONb);
  522. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  523. udelay(15000);
  524. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  525. tmp |= (RADEON_PIXCLK_ALWAYS_ONb |
  526. RADEON_PIXCLK_DAC_ALWAYS_ONb);
  527. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  528. udelay(15000);
  529. }
  530. } else {
  531. /* Turn everything OFF (ForceON to everything) */
  532. if (rdev->flags & RADEON_SINGLE_CRTC) {
  533. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  534. tmp |= (RADEON_SCLK_FORCE_CP | RADEON_SCLK_FORCE_HDP |
  535. RADEON_SCLK_FORCE_DISP1 | RADEON_SCLK_FORCE_TOP
  536. | RADEON_SCLK_FORCE_E2 | RADEON_SCLK_FORCE_SE |
  537. RADEON_SCLK_FORCE_IDCT | RADEON_SCLK_FORCE_VIP |
  538. RADEON_SCLK_FORCE_RE | RADEON_SCLK_FORCE_PB |
  539. RADEON_SCLK_FORCE_TAM | RADEON_SCLK_FORCE_TDM |
  540. RADEON_SCLK_FORCE_RB);
  541. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  542. } else if ((rdev->family == CHIP_RS400) ||
  543. (rdev->family == CHIP_RS480)) {
  544. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  545. tmp |= (RADEON_SCLK_FORCE_DISP2 | RADEON_SCLK_FORCE_CP |
  546. RADEON_SCLK_FORCE_HDP | RADEON_SCLK_FORCE_DISP1
  547. | RADEON_SCLK_FORCE_TOP | RADEON_SCLK_FORCE_E2 |
  548. R300_SCLK_FORCE_VAP | RADEON_SCLK_FORCE_IDCT |
  549. RADEON_SCLK_FORCE_VIP | R300_SCLK_FORCE_SR |
  550. R300_SCLK_FORCE_PX | R300_SCLK_FORCE_TX |
  551. R300_SCLK_FORCE_US | RADEON_SCLK_FORCE_TV_SCLK |
  552. R300_SCLK_FORCE_SU | RADEON_SCLK_FORCE_OV0);
  553. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  554. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  555. tmp |= RADEON_SCLK_MORE_FORCEON;
  556. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  557. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  558. tmp &= ~(RADEON_PIXCLK_ALWAYS_ONb |
  559. RADEON_PIXCLK_DAC_ALWAYS_ONb |
  560. R300_DISP_DAC_PIXCLK_DAC_BLANK_OFF);
  561. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  562. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  563. tmp &= ~(RADEON_PIX2CLK_ALWAYS_ONb |
  564. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  565. RADEON_DISP_TVOUT_PIXCLK_TV_ALWAYS_ONb |
  566. R300_DVOCLK_ALWAYS_ONb |
  567. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  568. RADEON_PIXCLK_GV_ALWAYS_ONb |
  569. R300_PIXCLK_DVO_ALWAYS_ONb |
  570. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  571. RADEON_PIXCLK_TMDS_ALWAYS_ONb |
  572. R300_PIXCLK_TRANS_ALWAYS_ONb |
  573. R300_PIXCLK_TVO_ALWAYS_ONb |
  574. R300_P2G2CLK_ALWAYS_ONb |
  575. R300_P2G2CLK_ALWAYS_ONb |
  576. R300_DISP_DAC_PIXCLK_DAC2_BLANK_OFF);
  577. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  578. } else if (rdev->family >= CHIP_RV350) {
  579. /* for RV350/M10, no delays are required. */
  580. tmp = RREG32_PLL(R300_SCLK_CNTL2);
  581. tmp |= (R300_SCLK_FORCE_TCL |
  582. R300_SCLK_FORCE_GA | R300_SCLK_FORCE_CBA);
  583. WREG32_PLL(R300_SCLK_CNTL2, tmp);
  584. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  585. tmp |= (RADEON_SCLK_FORCE_DISP2 | RADEON_SCLK_FORCE_CP |
  586. RADEON_SCLK_FORCE_HDP | RADEON_SCLK_FORCE_DISP1
  587. | RADEON_SCLK_FORCE_TOP | RADEON_SCLK_FORCE_E2 |
  588. R300_SCLK_FORCE_VAP | RADEON_SCLK_FORCE_IDCT |
  589. RADEON_SCLK_FORCE_VIP | R300_SCLK_FORCE_SR |
  590. R300_SCLK_FORCE_PX | R300_SCLK_FORCE_TX |
  591. R300_SCLK_FORCE_US | RADEON_SCLK_FORCE_TV_SCLK |
  592. R300_SCLK_FORCE_SU | RADEON_SCLK_FORCE_OV0);
  593. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  594. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  595. tmp |= RADEON_SCLK_MORE_FORCEON;
  596. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  597. tmp = RREG32_PLL(RADEON_MCLK_CNTL);
  598. tmp |= (RADEON_FORCEON_MCLKA |
  599. RADEON_FORCEON_MCLKB |
  600. RADEON_FORCEON_YCLKA |
  601. RADEON_FORCEON_YCLKB | RADEON_FORCEON_MC);
  602. WREG32_PLL(RADEON_MCLK_CNTL, tmp);
  603. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  604. tmp &= ~(RADEON_PIXCLK_ALWAYS_ONb |
  605. RADEON_PIXCLK_DAC_ALWAYS_ONb |
  606. R300_DISP_DAC_PIXCLK_DAC_BLANK_OFF);
  607. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  608. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  609. tmp &= ~(RADEON_PIX2CLK_ALWAYS_ONb |
  610. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  611. RADEON_DISP_TVOUT_PIXCLK_TV_ALWAYS_ONb |
  612. R300_DVOCLK_ALWAYS_ONb |
  613. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  614. RADEON_PIXCLK_GV_ALWAYS_ONb |
  615. R300_PIXCLK_DVO_ALWAYS_ONb |
  616. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  617. RADEON_PIXCLK_TMDS_ALWAYS_ONb |
  618. R300_PIXCLK_TRANS_ALWAYS_ONb |
  619. R300_PIXCLK_TVO_ALWAYS_ONb |
  620. R300_P2G2CLK_ALWAYS_ONb |
  621. R300_P2G2CLK_ALWAYS_ONb |
  622. R300_DISP_DAC_PIXCLK_DAC2_BLANK_OFF);
  623. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  624. } else {
  625. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  626. tmp |= (RADEON_SCLK_FORCE_CP | RADEON_SCLK_FORCE_E2);
  627. tmp |= RADEON_SCLK_FORCE_SE;
  628. if (rdev->flags & RADEON_SINGLE_CRTC) {
  629. tmp |= (RADEON_SCLK_FORCE_RB |
  630. RADEON_SCLK_FORCE_TDM |
  631. RADEON_SCLK_FORCE_TAM |
  632. RADEON_SCLK_FORCE_PB |
  633. RADEON_SCLK_FORCE_RE |
  634. RADEON_SCLK_FORCE_VIP |
  635. RADEON_SCLK_FORCE_IDCT |
  636. RADEON_SCLK_FORCE_TOP |
  637. RADEON_SCLK_FORCE_DISP1 |
  638. RADEON_SCLK_FORCE_DISP2 |
  639. RADEON_SCLK_FORCE_HDP);
  640. } else if ((rdev->family == CHIP_R300) ||
  641. (rdev->family == CHIP_R350)) {
  642. tmp |= (RADEON_SCLK_FORCE_HDP |
  643. RADEON_SCLK_FORCE_DISP1 |
  644. RADEON_SCLK_FORCE_DISP2 |
  645. RADEON_SCLK_FORCE_TOP |
  646. RADEON_SCLK_FORCE_IDCT |
  647. RADEON_SCLK_FORCE_VIP);
  648. }
  649. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  650. udelay(16000);
  651. if ((rdev->family == CHIP_R300) ||
  652. (rdev->family == CHIP_R350)) {
  653. tmp = RREG32_PLL(R300_SCLK_CNTL2);
  654. tmp |= (R300_SCLK_FORCE_TCL |
  655. R300_SCLK_FORCE_GA |
  656. R300_SCLK_FORCE_CBA);
  657. WREG32_PLL(R300_SCLK_CNTL2, tmp);
  658. udelay(16000);
  659. }
  660. if (rdev->flags & RADEON_IS_IGP) {
  661. tmp = RREG32_PLL(RADEON_MCLK_CNTL);
  662. tmp &= ~(RADEON_FORCEON_MCLKA |
  663. RADEON_FORCEON_YCLKA);
  664. WREG32_PLL(RADEON_MCLK_CNTL, tmp);
  665. udelay(16000);
  666. }
  667. if ((rdev->family == CHIP_RV200) ||
  668. (rdev->family == CHIP_RV250) ||
  669. (rdev->family == CHIP_RV280)) {
  670. tmp = RREG32_PLL(RADEON_SCLK_MORE_CNTL);
  671. tmp |= RADEON_SCLK_MORE_FORCEON;
  672. WREG32_PLL(RADEON_SCLK_MORE_CNTL, tmp);
  673. udelay(16000);
  674. }
  675. tmp = RREG32_PLL(RADEON_PIXCLKS_CNTL);
  676. tmp &= ~(RADEON_PIX2CLK_ALWAYS_ONb |
  677. RADEON_PIX2CLK_DAC_ALWAYS_ONb |
  678. RADEON_PIXCLK_BLEND_ALWAYS_ONb |
  679. RADEON_PIXCLK_GV_ALWAYS_ONb |
  680. RADEON_PIXCLK_DIG_TMDS_ALWAYS_ONb |
  681. RADEON_PIXCLK_LVDS_ALWAYS_ONb |
  682. RADEON_PIXCLK_TMDS_ALWAYS_ONb);
  683. WREG32_PLL(RADEON_PIXCLKS_CNTL, tmp);
  684. udelay(16000);
  685. tmp = RREG32_PLL(RADEON_VCLK_ECP_CNTL);
  686. tmp &= ~(RADEON_PIXCLK_ALWAYS_ONb |
  687. RADEON_PIXCLK_DAC_ALWAYS_ONb);
  688. WREG32_PLL(RADEON_VCLK_ECP_CNTL, tmp);
  689. }
  690. }
  691. }
  692. static void radeon_apply_clock_quirks(struct radeon_device *rdev)
  693. {
  694. uint32_t tmp;
  695. /* XXX make sure engine is idle */
  696. if (rdev->family < CHIP_RS600) {
  697. tmp = RREG32_PLL(RADEON_SCLK_CNTL);
  698. if (ASIC_IS_R300(rdev) || ASIC_IS_RV100(rdev))
  699. tmp |= RADEON_SCLK_FORCE_CP | RADEON_SCLK_FORCE_VIP;
  700. if ((rdev->family == CHIP_RV250)
  701. || (rdev->family == CHIP_RV280))
  702. tmp |=
  703. RADEON_SCLK_FORCE_DISP1 | RADEON_SCLK_FORCE_DISP2;
  704. if ((rdev->family == CHIP_RV350)
  705. || (rdev->family == CHIP_RV380))
  706. tmp |= R300_SCLK_FORCE_VAP;
  707. if (rdev->family == CHIP_R420)
  708. tmp |= R300_SCLK_FORCE_PX | R300_SCLK_FORCE_TX;
  709. WREG32_PLL(RADEON_SCLK_CNTL, tmp);
  710. } else if (rdev->family < CHIP_R600) {
  711. tmp = RREG32_PLL(AVIVO_CP_DYN_CNTL);
  712. tmp |= AVIVO_CP_FORCEON;
  713. WREG32_PLL(AVIVO_CP_DYN_CNTL, tmp);
  714. tmp = RREG32_PLL(AVIVO_E2_DYN_CNTL);
  715. tmp |= AVIVO_E2_FORCEON;
  716. WREG32_PLL(AVIVO_E2_DYN_CNTL, tmp);
  717. tmp = RREG32_PLL(AVIVO_IDCT_DYN_CNTL);
  718. tmp |= AVIVO_IDCT_FORCEON;
  719. WREG32_PLL(AVIVO_IDCT_DYN_CNTL, tmp);
  720. }
  721. }
  722. int radeon_static_clocks_init(struct drm_device *dev)
  723. {
  724. struct radeon_device *rdev = dev->dev_private;
  725. /* XXX make sure engine is idle */
  726. if (radeon_dynclks != -1) {
  727. if (radeon_dynclks)
  728. radeon_set_clock_gating(rdev, 1);
  729. }
  730. radeon_apply_clock_quirks(rdev);
  731. return 0;
  732. }