提交 211eba9e 编写于 作者: C Colin Ian King 提交者: Mauro Carvalho Chehab

[media] VPU: mediatek: fix null pointer dereference on pdev

pdev is being null checked, however, prior to that it is being
dereferenced by platform_get_drvdata.  Move the assignments of
vpu and run to after the pdev null check to avoid a potential
null pointer dereference.
Signed-off-by: NColin Ian King <colin.king@canonical.com>
Reviewed-by: NTiffany Lin <tiffany.lin@mediatek.com>
Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@s-opensource.com>
上级 67712beb
...@@ -534,9 +534,9 @@ static int load_requested_vpu(struct mtk_vpu *vpu, ...@@ -534,9 +534,9 @@ static int load_requested_vpu(struct mtk_vpu *vpu,
int vpu_load_firmware(struct platform_device *pdev) int vpu_load_firmware(struct platform_device *pdev)
{ {
struct mtk_vpu *vpu = platform_get_drvdata(pdev); struct mtk_vpu *vpu;
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct vpu_run *run = &vpu->run; struct vpu_run *run;
const struct firmware *vpu_fw = NULL; const struct firmware *vpu_fw = NULL;
int ret; int ret;
...@@ -545,6 +545,9 @@ int vpu_load_firmware(struct platform_device *pdev) ...@@ -545,6 +545,9 @@ int vpu_load_firmware(struct platform_device *pdev)
return -EINVAL; return -EINVAL;
} }
vpu = platform_get_drvdata(pdev);
run = &vpu->run;
mutex_lock(&vpu->vpu_mutex); mutex_lock(&vpu->vpu_mutex);
if (vpu->fw_loaded) { if (vpu->fw_loaded) {
mutex_unlock(&vpu->vpu_mutex); mutex_unlock(&vpu->vpu_mutex);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册