[media] pms: Fix a bad usage of the stack
As warned by smatch: drivers/media/parport/pms.c:632:21: warning: Variable length array is used. The pms driver is doing something really bad: it is using the stack to read data into a buffer whose size is given by the user by the read() syscall. Replace it by a dynamically allocated buffer. Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
This commit is contained in:
parent
5a9ff85dc1
commit
64e01cbd9d
1 changed files with 6 additions and 1 deletions
|
@ -629,11 +629,15 @@ static int pms_capture(struct pms *dev, char __user *buf, int rgb555, int count)
|
||||||
{
|
{
|
||||||
int y;
|
int y;
|
||||||
int dw = 2 * dev->width;
|
int dw = 2 * dev->width;
|
||||||
char tmp[dw + 32]; /* using a temp buffer is faster than direct */
|
char *tmp; /* using a temp buffer is faster than direct */
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
int len = 0;
|
int len = 0;
|
||||||
unsigned char r8 = 0x5; /* value for reg8 */
|
unsigned char r8 = 0x5; /* value for reg8 */
|
||||||
|
|
||||||
|
tmp = kmalloc(dw + 32, GFP_KERNEL);
|
||||||
|
if (!tmp)
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (rgb555)
|
if (rgb555)
|
||||||
r8 |= 0x20; /* else use untranslated rgb = 565 */
|
r8 |= 0x20; /* else use untranslated rgb = 565 */
|
||||||
mvv_write(dev, 0x08, r8); /* capture rgb555/565, init DRAM, PC enable */
|
mvv_write(dev, 0x08, r8); /* capture rgb555/565, init DRAM, PC enable */
|
||||||
|
@ -664,6 +668,7 @@ static int pms_capture(struct pms *dev, char __user *buf, int rgb555, int count)
|
||||||
len += dt;
|
len += dt;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
kfree(tmp);
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue