mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 19:08:57 +09:00
UPSTREAM: video: fbdev: pxa3xx-gcu: Fix integer overflow in pxa3xx_gcu_write
[ Upstream commit a09d2d00af ]
In pxa3xx_gcu_write, a count parameter of type size_t is passed to words of
type int. Then, copy_from_user() may cause a heap overflow because it is used
as the third argument of copy_from_user().
Bug: 245928838
Signed-off-by: Hyunwoo Kim <imv4bel@gmail.com>
Signed-off-by: Helge Deller <deller@gmx.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Lee Jones <joneslee@google.com>
Change-Id: I9e21917a52e2cb78cc640a77a6eba21838aa8655
This commit is contained in:
committed by
Treehugger Robot
parent
34055de440
commit
3d129ea9b5
@@ -381,7 +381,7 @@ pxa3xx_gcu_write(struct file *file, const char *buff,
|
|||||||
struct pxa3xx_gcu_batch *buffer;
|
struct pxa3xx_gcu_batch *buffer;
|
||||||
struct pxa3xx_gcu_priv *priv = to_pxa3xx_gcu_priv(file);
|
struct pxa3xx_gcu_priv *priv = to_pxa3xx_gcu_priv(file);
|
||||||
|
|
||||||
int words = count / 4;
|
size_t words = count / 4;
|
||||||
|
|
||||||
/* Does not need to be atomic. There's a lock in user space,
|
/* Does not need to be atomic. There's a lock in user space,
|
||||||
* but anyhow, this is just for statistics. */
|
* but anyhow, this is just for statistics. */
|
||||||
|
|||||||
Reference in New Issue
Block a user