From: Jia-Ju Bai Date: Tue, 12 Dec 2017 13:47:38 +0000 (-0500) Subject: media: bdisp: Fix a possible sleep-in-atomic bug in bdisp_hw_save_request X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=df8ab4c6010b3b4eafb6732fcb268487fb654220;p=openwrt%2Fstaging%2Fblogic.git media: bdisp: Fix a possible sleep-in-atomic bug in bdisp_hw_save_request The driver may sleep under a spinlock. The function call path is: bdisp_device_run (acquire the spinlock) bdisp_hw_update bdisp_hw_save_request devm_kzalloc(GFP_KERNEL) --> may sleep To fix it, GFP_KERNEL is replaced with GFP_ATOMIC. This bug is found by my static analysis tool(DSAC) and checked by my code review. Signed-off-by: Jia-Ju Bai Reviewed-by: Fabien Dessenne Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab --- diff --git a/drivers/media/platform/sti/bdisp/bdisp-hw.c b/drivers/media/platform/sti/bdisp/bdisp-hw.c index e7836b307d21..a5eb592e12c0 100644 --- a/drivers/media/platform/sti/bdisp/bdisp-hw.c +++ b/drivers/media/platform/sti/bdisp/bdisp-hw.c @@ -1064,7 +1064,7 @@ static void bdisp_hw_save_request(struct bdisp_ctx *ctx) if (!copy_node[i]) { copy_node[i] = devm_kzalloc(ctx->bdisp_dev->dev, sizeof(*copy_node[i]), - GFP_KERNEL); + GFP_ATOMIC); if (!copy_node[i]) return; }