Commit 42158660 authored by Zhao Yakui's avatar Zhao Yakui Committed by Eric Anholt

drm/i915: Restore the DPLL calculation logic for 9xx platform

The DPLL calculation logic for 9xx platform is changed in:
commit 652c393a
Author: Jesse Barnes <jbarnes@virtuousgeek.org>
Date:   Mon Aug 17 13:31:43 2009 -0700

    drm/i915: add dynamic clock frequency control

Maybe we will get the different M/N/P combination with that by using the
previous dpll calculation logic.

So restore the DPLL calculation logic for 9xx platform.
Signed-off-by: default avatarZhao Yakui <yakui.zhao@intel.com>
Reviewed-by: default avatarJesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: default avatarEric Anholt <eric@anholt.net>
parent d1fcea6a
...@@ -706,16 +706,17 @@ intel_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc, ...@@ -706,16 +706,17 @@ intel_find_best_PLL(const intel_limit_t *limit, struct drm_crtc *crtc,
memset (best_clock, 0, sizeof (*best_clock)); memset (best_clock, 0, sizeof (*best_clock));
for (clock.p1 = limit->p1.max; clock.p1 >= limit->p1.min; clock.p1--) { for (clock.m1 = limit->m1.min; clock.m1 <= limit->m1.max;
for (clock.m1 = limit->m1.min; clock.m1 <= limit->m1.max; clock.m1++) {
clock.m1++) { for (clock.m2 = limit->m2.min;
for (clock.m2 = limit->m2.min; clock.m2 <= limit->m2.max; clock.m2++) {
clock.m2 <= limit->m2.max; clock.m2++) { /* m1 is always 0 in IGD */
/* m1 is always 0 in IGD */ if (clock.m2 >= clock.m1 && !IS_IGD(dev))
if (clock.m2 >= clock.m1 && !IS_IGD(dev)) break;
break; for (clock.n = limit->n.min;
for (clock.n = limit->n.min; clock.n <= limit->n.max; clock.n++) {
clock.n <= limit->n.max; clock.n++) { for (clock.p1 = limit->p1.min;
clock.p1 <= limit->p1.max; clock.p1++) {
int this_err; int this_err;
intel_clock(dev, refclk, &clock); intel_clock(dev, refclk, &clock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment