Skip to content

Commit bd14c18

Browse files
jhovoldgregkh
authored andcommitted
cx231xx-audio: fix init error path
commit fff1abc4d54e469140a699612b4db8d6397bfcba upstream. Make sure to release the snd_card also on a late allocation error. Fixes: e0d3baf ("V4L/DVB (10954): Add cx231xx USB driver") Cc: Sri Deevi <Srinivasa.Deevi@conexant.com> Signed-off-by: Johan Hovold <johan@kernel.org> Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent f7c778f commit bd14c18

1 file changed

Lines changed: 14 additions & 11 deletions

File tree

drivers/media/usb/cx231xx/cx231xx-audio.c

Lines changed: 14 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -671,10 +671,8 @@ static int cx231xx_audio_init(struct cx231xx *dev)
671671

672672
spin_lock_init(&adev->slock);
673673
err = snd_pcm_new(card, "Cx231xx Audio", 0, 0, 1, &pcm);
674-
if (err < 0) {
675-
snd_card_free(card);
676-
return err;
677-
}
674+
if (err < 0)
675+
goto err_free_card;
678676

679677
snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE,
680678
&snd_cx231xx_pcm_capture);
@@ -688,10 +686,9 @@ static int cx231xx_audio_init(struct cx231xx *dev)
688686
INIT_WORK(&dev->wq_trigger, audio_trigger);
689687

690688
err = snd_card_register(card);
691-
if (err < 0) {
692-
snd_card_free(card);
693-
return err;
694-
}
689+
if (err < 0)
690+
goto err_free_card;
691+
695692
adev->sndcard = card;
696693
adev->udev = dev->udev;
697694

@@ -710,9 +707,10 @@ static int cx231xx_audio_init(struct cx231xx *dev)
710707
"audio EndPoint Addr 0x%x, Alternate settings: %i\n",
711708
adev->end_point_addr, adev->num_alt);
712709
adev->alt_max_pkt_size = kmalloc(32 * adev->num_alt, GFP_KERNEL);
713-
714-
if (adev->alt_max_pkt_size == NULL)
715-
return -ENOMEM;
710+
if (!adev->alt_max_pkt_size) {
711+
err = -ENOMEM;
712+
goto err_free_card;
713+
}
716714

717715
for (i = 0; i < adev->num_alt; i++) {
718716
u16 tmp =
@@ -726,6 +724,11 @@ static int cx231xx_audio_init(struct cx231xx *dev)
726724
}
727725

728726
return 0;
727+
728+
err_free_card:
729+
snd_card_free(card);
730+
731+
return err;
729732
}
730733

731734
static int cx231xx_audio_fini(struct cx231xx *dev)

0 commit comments

Comments
 (0)