radeon_clocks.c 25 KB

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