Browse Source

ALSA: cmipci: Use common error handling code in snd_cmipci_probe()

Add a jump target so that a bit of exception handling can be better reused
at the end of this function.

This issue was detected by using the Coccinelle software.

Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Markus Elfring 8 years ago
parent
commit
e17a85eccf
1 changed files with 11 additions and 8 deletions
  1. 11 8
      sound/pci/cmipci.c

+ 11 - 8
sound/pci/cmipci.c

@@ -3295,20 +3295,23 @@ static int snd_cmipci_probe(struct pci_dev *pci,
 		break;
 		break;
 	}
 	}
 
 
-	if ((err = snd_cmipci_create(card, pci, dev, &cm)) < 0) {
-		snd_card_free(card);
-		return err;
-	}
+	err = snd_cmipci_create(card, pci, dev, &cm);
+	if (err < 0)
+		goto free_card;
+
 	card->private_data = cm;
 	card->private_data = cm;
 
 
-	if ((err = snd_card_register(card)) < 0) {
-		snd_card_free(card);
-		return err;
-	}
+	err = snd_card_register(card);
+	if (err < 0)
+		goto free_card;
+
 	pci_set_drvdata(pci, card);
 	pci_set_drvdata(pci, card);
 	dev++;
 	dev++;
 	return 0;
 	return 0;
 
 
+free_card:
+	snd_card_free(card);
+	return err;
 }
 }
 
 
 static void snd_cmipci_remove(struct pci_dev *pci)
 static void snd_cmipci_remove(struct pci_dev *pci)