diff options
author | Emil Velikov <eeydev@nottingham.ac.uk> | 2010-09-26 15:26:02 -0400 |
---|---|---|
committer | Ben Skeggs <bskeggs@redhat.com> | 2010-10-04 19:59:34 -0400 |
commit | eadc69cc9054594ff7860d407f855536af13af99 (patch) | |
tree | 1076b2a26039a15a0ee29ec6f9c686bda6c51631 /drivers/gpu/drm/nouveau | |
parent | 8af29ccd7917ab448ea7b5cf581fa7b2b4ea3cba (diff) |
drm/nouveau: don't use the default pll limits in table v2.1 on nv50+ cards
This fixes issues bug 30370 and prevents another possible divide by zero on
the original nv50 cards, by returning -ENOENT
Signed-off-by: Emil Velikov <eeydev@nottingham.ac.uk>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/nouveau')
-rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_bios.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_bios.c b/drivers/gpu/drm/nouveau/nouveau_bios.c index c66d4567a2e..53f4eba65cb 100644 --- a/drivers/gpu/drm/nouveau/nouveau_bios.c +++ b/drivers/gpu/drm/nouveau/nouveau_bios.c | |||
@@ -4890,6 +4890,12 @@ int get_pll_limits(struct drm_device *dev, uint32_t limit_match, struct pll_lims | |||
4890 | break; | 4890 | break; |
4891 | } | 4891 | } |
4892 | 4892 | ||
4893 | if ((dev_priv->card_type >= NV_50) && (pllindex == 0)) { | ||
4894 | NV_ERROR(dev, "Register 0x%08x not found in PLL " | ||
4895 | "limits table", pll_lim->reg); | ||
4896 | return -ENOENT; | ||
4897 | } | ||
4898 | |||
4893 | pll_rec = &bios->data[plloffs + recordlen * pllindex]; | 4899 | pll_rec = &bios->data[plloffs + recordlen * pllindex]; |
4894 | 4900 | ||
4895 | BIOSLOG(bios, "Loading PLL limits for reg 0x%08x\n", | 4901 | BIOSLOG(bios, "Loading PLL limits for reg 0x%08x\n", |