From: Jinjie Ruan <ruanjinjie@xxxxxxxxxx> commit d2842dec577900031826dc44e9bf0c66416d7173 upstream. In set_frame_rate(), select a rate in rate_0 or rate_1 by checking sd->frame_rate >= r->fps in a loop, but the loop condition terminates when the index reaches zero, which fails to check the last elememt in rate_0 or rate_1. Check for >= 0 so that the last one in rate_0 or rate_1 is also checked. Fixes: 189d92af707e ("V4L/DVB (13422): gspca - ov534: ov772x changes from Richard Kaswy.") Cc: stable@xxxxxxxxxxxxxxx Signed-off-by: Jinjie Ruan <ruanjinjie@xxxxxxxxxx> Signed-off-by: Sakari Ailus <sakari.ailus@xxxxxxxxxxxxxxx> Signed-off-by: Hans Verkuil <hverkuil@xxxxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- drivers/media/usb/gspca/ov534.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/media/usb/gspca/ov534.c +++ b/drivers/media/usb/gspca/ov534.c @@ -847,7 +847,7 @@ static void set_frame_rate(struct gspca_ r = rate_1; i = ARRAY_SIZE(rate_1); } - while (--i > 0) { + while (--i >= 0) { if (sd->frame_rate >= r->fps) break; r++; Patches currently in stable-queue which might be from ruanjinjie@xxxxxxxxxx are queue-6.12/kunit-string-stream-fix-a-uaf-bug-in-kunit_init_suite.patch queue-6.12/media-amphion-fix-pm_runtime_set_suspended-with-runtime-pm-enabled.patch queue-6.12/media-gspca-ov534-ov772x-fix-off-by-one-error-in-set_frame_rate.patch queue-6.12/media-venus-fix-pm_runtime_set_suspended-with-runtime-pm-enabled.patch queue-6.12/media-i2c-dw9768-fix-pm_runtime_set_suspended-with-runtime-pm-enabled.patch