提交 761c5a69 编写于 作者: M Marcin Slusarz 提交者: Ben Skeggs

drm/nouveau: fix i2ctable bounds checking

i2c_entries seems to be the number of i2c entries,
so with index equal to this number, we could read
invalid data from i2ctable. Fix it.
Signed-off-by: NMarcin Slusarz <marcin.slusarz@gmail.com>
Signed-off-by: NFrancisco Jerez <currojerez@riseup.net>
Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
上级 b762b8ce
...@@ -4984,7 +4984,8 @@ read_dcb_i2c_entry(struct drm_device *dev, int dcb_version, uint8_t *i2ctable, i ...@@ -4984,7 +4984,8 @@ read_dcb_i2c_entry(struct drm_device *dev, int dcb_version, uint8_t *i2ctable, i
else else
NV_WARN(dev, NV_WARN(dev,
"DCB I2C table has more entries than indexable " "DCB I2C table has more entries than indexable "
"(%d entries, max index 15)\n", i2ctable[2]); "(%d entries, max %d)\n", i2ctable[2],
DCB_MAX_NUM_I2C_ENTRIES);
entry_len = i2ctable[3]; entry_len = i2ctable[3];
/* [4] is i2c_default_indices, read in parse_dcb_table() */ /* [4] is i2c_default_indices, read in parse_dcb_table() */
} }
...@@ -5000,8 +5001,8 @@ read_dcb_i2c_entry(struct drm_device *dev, int dcb_version, uint8_t *i2ctable, i ...@@ -5000,8 +5001,8 @@ read_dcb_i2c_entry(struct drm_device *dev, int dcb_version, uint8_t *i2ctable, i
if (index == 0xf) if (index == 0xf)
return 0; return 0;
if (index > i2c_entries) { if (index >= i2c_entries) {
NV_ERROR(dev, "DCB I2C index too big (%d > %d)\n", NV_ERROR(dev, "DCB I2C index too big (%d >= %d)\n",
index, i2ctable[2]); index, i2ctable[2]);
return -ENOENT; return -ENOENT;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册