Message ID | 20200903080547.v3.1.I56cf27cd59f4013bd074dc622c8b8248b034a4cc@changeid (mailing list archive) |
---|---|
State | Accepted |
Commit | 231331b2dbd71487159a0400d9ffd967eb0d0e08 |
Headers | show |
Series | [v3] rpmsg: Avoid double-free in mtk_rpmsg_register_device | expand |
Hello: This patch was applied to andersson/remoteproc.git (refs/heads/for-next). On Thu, 3 Sep 2020 08:05:58 +0800 you wrote: > If rpmsg_register_device fails, it will call > mtk_rpmsg_release_device which already frees mdev. > > Fixes: 7017996951fd ("rpmsg: add rpmsg support for mt8183 SCP.") > Signed-off-by: Nicolas Boichat <drinkcat@chromium.org> > Reviewed-by: Mathieu Poirier <mathieu.poirier@linaro.org> > > [...] Here is a summary with links: - [v3] rpmsg: Avoid double-free in mtk_rpmsg_register_device https://git.kernel.org/andersson/remoteproc/c/231331b2dbd71487159a0400d9ffd967eb0d0e08 You are awesome, thank you!
diff --git a/drivers/rpmsg/mtk_rpmsg.c b/drivers/rpmsg/mtk_rpmsg.c index 83f2b8804ee9..96a17ec29140 100644 --- a/drivers/rpmsg/mtk_rpmsg.c +++ b/drivers/rpmsg/mtk_rpmsg.c @@ -200,7 +200,6 @@ static int mtk_rpmsg_register_device(struct mtk_rpmsg_rproc_subdev *mtk_subdev, struct rpmsg_device *rpdev; struct mtk_rpmsg_device *mdev; struct platform_device *pdev = mtk_subdev->pdev; - int ret; mdev = kzalloc(sizeof(*mdev), GFP_KERNEL); if (!mdev) @@ -219,13 +218,7 @@ static int mtk_rpmsg_register_device(struct mtk_rpmsg_rproc_subdev *mtk_subdev, rpdev->dev.parent = &pdev->dev; rpdev->dev.release = mtk_rpmsg_release_device; - ret = rpmsg_register_device(rpdev); - if (ret) { - kfree(mdev); - return ret; - } - - return 0; + return rpmsg_register_device(rpdev); } static void mtk_register_device_work_function(struct work_struct *register_work)