Skip to content

Commit 8033120

Browse files
Dan Carpentermchehab
authored andcommitted
media: atomisp2: array underflow in imx_enum_frame_size()
The code looks in imx_enum_frame_size() looks like this: 2066 int index = fse->index; 2067 struct imx_device *dev = to_imx_sensor(sd); 2068 2069 mutex_lock(&dev->input_lock); 2070 if (index >= dev->entries_curr_table) { 2071 mutex_unlock(&dev->input_lock); 2072 return -EINVAL; 2073 } 2074 2075 fse->min_width = dev->curr_res_table[index].width; "fse->index" is a u32 that comes from the user. We want negative values of "index" to be -EINVAL so we don't read before the start of the dev->curr_res_table[] array. I've made "entries_curr_table" unsigned long to fix this. I thought about making it unsigned int, but because of struct alignment, it doesn't use more memory either way. Fixes: a49d253 ("staging/atomisp: Add support for the Intel IPU v2") Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
1 parent 115b7ac commit 8033120

File tree

3 files changed

+3
-3
lines changed

3 files changed

+3
-3
lines changed

drivers/staging/media/atomisp/i2c/imx/imx.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -480,7 +480,7 @@ struct imx_device {
480480
struct imx_vcm *vcm_driver;
481481
struct imx_otp *otp_driver;
482482
const struct imx_resolution *curr_res_table;
483-
int entries_curr_table;
483+
unsigned long entries_curr_table;
484484
const struct firmware *fw;
485485
struct imx_reg_addr *reg_addr;
486486
const struct imx_reg *param_hold;

drivers/staging/media/atomisp/i2c/ov8858.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -266,7 +266,7 @@ struct ov8858_device {
266266
const struct ov8858_reg *regs;
267267
struct ov8858_vcm *vcm_driver;
268268
const struct ov8858_resolution *curr_res_table;
269-
int entries_curr_table;
269+
unsigned long entries_curr_table;
270270

271271
struct v4l2_ctrl_handler ctrl_handler;
272272
struct v4l2_ctrl *run_mode;

drivers/staging/media/atomisp/i2c/ov8858_btns.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -266,7 +266,7 @@ struct ov8858_device {
266266
const struct ov8858_reg *regs;
267267
struct ov8858_vcm *vcm_driver;
268268
const struct ov8858_resolution *curr_res_table;
269-
int entries_curr_table;
269+
unsigned long entries_curr_table;
270270

271271
struct v4l2_ctrl_handler ctrl_handler;
272272
struct v4l2_ctrl *run_mode;

0 commit comments

Comments
 (0)