Commit e1444e9b authored by Christophe JAILLET's avatar Christophe JAILLET Committed by Mauro Carvalho Chehab

media: cx88: Fix some error handling path in 'cx8800_initdev()'

A call to 'pci_disable_device()' is missing in the error handling path.
In some cases, a call to 'free_irq()' may also be missing.

Reorder the error handling path, add some new labels and fix the 2 issues
mentionned above.

This way, the error handling path in more in line with 'cx8800_finidev()'
(i.e. the remove function)
Signed-off-by: default avatarChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 2eca8e4c
...@@ -1277,7 +1277,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev, ...@@ -1277,7 +1277,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev,
core = cx88_core_get(dev->pci); core = cx88_core_get(dev->pci);
if (!core) { if (!core) {
err = -EINVAL; err = -EINVAL;
goto fail_free; goto fail_disable;
} }
dev->core = core; dev->core = core;
...@@ -1323,7 +1323,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev, ...@@ -1323,7 +1323,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev,
cc->step, cc->default_value); cc->step, cc->default_value);
if (!vc) { if (!vc) {
err = core->audio_hdl.error; err = core->audio_hdl.error;
goto fail_core; goto fail_irq;
} }
vc->priv = (void *)cc; vc->priv = (void *)cc;
} }
...@@ -1337,7 +1337,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev, ...@@ -1337,7 +1337,7 @@ static int cx8800_initdev(struct pci_dev *pci_dev,
cc->step, cc->default_value); cc->step, cc->default_value);
if (!vc) { if (!vc) {
err = core->video_hdl.error; err = core->video_hdl.error;
goto fail_core; goto fail_irq;
} }
vc->priv = (void *)cc; vc->priv = (void *)cc;
if (vc->id == V4L2_CID_CHROMA_AGC) if (vc->id == V4L2_CID_CHROMA_AGC)
...@@ -1509,11 +1509,14 @@ static int cx8800_initdev(struct pci_dev *pci_dev, ...@@ -1509,11 +1509,14 @@ static int cx8800_initdev(struct pci_dev *pci_dev,
fail_unreg: fail_unreg:
cx8800_unregister_video(dev); cx8800_unregister_video(dev);
free_irq(pci_dev->irq, dev);
mutex_unlock(&core->lock); mutex_unlock(&core->lock);
fail_irq:
free_irq(pci_dev->irq, dev);
fail_core: fail_core:
core->v4ldev = NULL; core->v4ldev = NULL;
cx88_core_put(core, dev->pci); cx88_core_put(core, dev->pci);
fail_disable:
pci_disable_device(pci_dev);
fail_free: fail_free:
kfree(dev); kfree(dev);
return err; return err;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment