aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/nouveau/nouveau_bios.c
diff options
context:
space:
mode:
authorMarcin Slusarz <marcin.slusarz@gmail.com>2010-02-17 13:04:00 -0500
committerBen Skeggs <bskeggs@redhat.com>2010-02-25 00:09:07 -0500
commitdf31ef4dbd48eca2772d8d88b12ee5eb5117c86e (patch)
treea557c4b12dbac70cac62609f8bab24986e165869 /drivers/gpu/drm/nouveau/nouveau_bios.c
parenta1606a9596e54da90ad6209071b357a4c1b0fa82 (diff)
drm/nouveau: fix pramdac_table range checking
get_tmds_index_reg reads some value from stack when mlv happens to be equal to size of pramdac_table array. Fix it. Reported-by: Dan Carpenter <error27@gmail.com> Signed-off-by: Marcin Slusarz <marcin.slusarz@gmail.com> Signed-off-by: Francisco Jerez <currojerez@riseup.net> Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/nouveau/nouveau_bios.c')
-rw-r--r--drivers/gpu/drm/nouveau/nouveau_bios.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_bios.c b/drivers/gpu/drm/nouveau/nouveau_bios.c
index 0e9cd1d49130..c1cee919b3cf 100644
--- a/drivers/gpu/drm/nouveau/nouveau_bios.c
+++ b/drivers/gpu/drm/nouveau/nouveau_bios.c
@@ -762,7 +762,7 @@ static uint32_t get_tmds_index_reg(struct drm_device *dev, uint8_t mlv)
762 dacoffset ^= 8; 762 dacoffset ^= 8;
763 return 0x6808b0 + dacoffset; 763 return 0x6808b0 + dacoffset;
764 } else { 764 } else {
765 if (mlv > ARRAY_SIZE(pramdac_table)) { 765 if (mlv >= ARRAY_SIZE(pramdac_table)) {
766 NV_ERROR(dev, "Magic Lookup Value too big (%02X)\n", 766 NV_ERROR(dev, "Magic Lookup Value too big (%02X)\n",
767 mlv); 767 mlv);
768 return 0; 768 return 0;