diff options
Diffstat (limited to 'drivers/gpu')
-rw-r--r-- | drivers/gpu/drm/nouveau/nv50_pm.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/drivers/gpu/drm/nouveau/nv50_pm.c b/drivers/gpu/drm/nouveau/nv50_pm.c index 7dbb305d7e63..8a2810011bda 100644 --- a/drivers/gpu/drm/nouveau/nv50_pm.c +++ b/drivers/gpu/drm/nouveau/nv50_pm.c | |||
@@ -47,6 +47,21 @@ nv50_pm_clock_get(struct drm_device *dev, u32 id) | |||
47 | 47 | ||
48 | reg0 = nv_rd32(dev, pll.reg + 0); | 48 | reg0 = nv_rd32(dev, pll.reg + 0); |
49 | reg1 = nv_rd32(dev, pll.reg + 4); | 49 | reg1 = nv_rd32(dev, pll.reg + 4); |
50 | |||
51 | if ((reg0 & 0x80000000) == 0) { | ||
52 | if (id == PLL_SHADER) { | ||
53 | NV_DEBUG(dev, "Shader PLL is disabled. " | ||
54 | "Shader clock is twice the core\n"); | ||
55 | ret = nv50_pm_clock_get(dev, PLL_CORE); | ||
56 | if (ret > 0) | ||
57 | return ret << 1; | ||
58 | } else if (id == PLL_MEMORY) { | ||
59 | NV_DEBUG(dev, "Memory PLL is disabled. " | ||
60 | "Memory clock is equal to the ref_clk\n"); | ||
61 | return pll.refclk; | ||
62 | } | ||
63 | } | ||
64 | |||
50 | P = (reg0 & 0x00070000) >> 16; | 65 | P = (reg0 & 0x00070000) >> 16; |
51 | N = (reg1 & 0x0000ff00) >> 8; | 66 | N = (reg1 & 0x0000ff00) >> 8; |
52 | M = (reg1 & 0x000000ff); | 67 | M = (reg1 & 0x000000ff); |