aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2009-06-10 01:26:26 -0400
committerTakashi Iwai <tiwai@suse.de>2009-06-10 01:26:26 -0400
commitd3e3743694cbfd64450b3468e11b40ba8c6f4369 (patch)
tree625a71167bb1c7195aafff8ab333ba86d04e9fba
parentd108728ea24a766335ae22f10bfaf41f248fb70e (diff)
parent5fdc18d938c99399b73fe894bc24cb9400a1a2ee (diff)
Merge branch 'topic/core-id-check' into for-linus
* topic/core-id-check: ALSA: Core - clean up snd_card_set_id* calls and remove possible id collision ALSA: Fix double locking of card list in snd_card_register()
-rw-r--r--sound/core/init.c41
1 files changed, 21 insertions, 20 deletions
diff --git a/sound/core/init.c b/sound/core/init.c
index 6557dd85e191..d5d40d78c409 100644
--- a/sound/core/init.c
+++ b/sound/core/init.c
@@ -153,7 +153,7 @@ int snd_card_create(int idx, const char *xid,
153 if (!card) 153 if (!card)
154 return -ENOMEM; 154 return -ENOMEM;
155 if (xid) 155 if (xid)
156 snd_card_set_id(card, xid); 156 strlcpy(card->id, xid, sizeof(card->id));
157 err = 0; 157 err = 0;
158 mutex_lock(&snd_card_mutex); 158 mutex_lock(&snd_card_mutex);
159 if (idx < 0) { 159 if (idx < 0) {
@@ -476,23 +476,12 @@ int snd_card_free(struct snd_card *card)
476 476
477EXPORT_SYMBOL(snd_card_free); 477EXPORT_SYMBOL(snd_card_free);
478 478
479/** 479static void snd_card_set_id_no_lock(struct snd_card *card, const char *nid)
480 * snd_card_set_id - set card identification name
481 * @card: soundcard structure
482 * @nid: new identification string
483 *
484 * This function sets the card identification and checks for name
485 * collisions.
486 */
487void snd_card_set_id(struct snd_card *card, const char *nid)
488{ 480{
489 int i, len, idx_flag = 0, loops = SNDRV_CARDS; 481 int i, len, idx_flag = 0, loops = SNDRV_CARDS;
490 const char *spos, *src; 482 const char *spos, *src;
491 char *id; 483 char *id;
492 484
493 /* check if user specified own card->id */
494 if (card->id[0] != '\0')
495 return;
496 if (nid == NULL) { 485 if (nid == NULL) {
497 id = card->shortname; 486 id = card->shortname;
498 spos = src = id; 487 spos = src = id;
@@ -529,14 +518,10 @@ void snd_card_set_id(struct snd_card *card, const char *nid)
529 } 518 }
530 if (!snd_info_check_reserved_words(id)) 519 if (!snd_info_check_reserved_words(id))
531 goto __change; 520 goto __change;
532 mutex_lock(&snd_card_mutex);
533 for (i = 0; i < snd_ecards_limit; i++) { 521 for (i = 0; i < snd_ecards_limit; i++) {
534 if (snd_cards[i] && !strcmp(snd_cards[i]->id, id)) { 522 if (snd_cards[i] && !strcmp(snd_cards[i]->id, id))
535 mutex_unlock(&snd_card_mutex);
536 goto __change; 523 goto __change;
537 }
538 } 524 }
539 mutex_unlock(&snd_card_mutex);
540 break; 525 break;
541 526
542 __change: 527 __change:
@@ -561,6 +546,23 @@ void snd_card_set_id(struct snd_card *card, const char *nid)
561 } 546 }
562} 547}
563 548
549/**
550 * snd_card_set_id - set card identification name
551 * @card: soundcard structure
552 * @nid: new identification string
553 *
554 * This function sets the card identification and checks for name
555 * collisions.
556 */
557void snd_card_set_id(struct snd_card *card, const char *nid)
558{
559 /* check if user specified own card->id */
560 if (card->id[0] != '\0')
561 return;
562 mutex_lock(&snd_card_mutex);
563 snd_card_set_id_no_lock(card, nid);
564 mutex_unlock(&snd_card_mutex);
565}
564EXPORT_SYMBOL(snd_card_set_id); 566EXPORT_SYMBOL(snd_card_set_id);
565 567
566#ifndef CONFIG_SYSFS_DEPRECATED 568#ifndef CONFIG_SYSFS_DEPRECATED
@@ -656,8 +658,7 @@ int snd_card_register(struct snd_card *card)
656 mutex_unlock(&snd_card_mutex); 658 mutex_unlock(&snd_card_mutex);
657 return 0; 659 return 0;
658 } 660 }
659 if (card->id[0] == '\0') 661 snd_card_set_id_no_lock(card, card->id[0] == '\0' ? NULL : card->id);
660 snd_card_set_id(card, NULL);
661 snd_cards[card->number] = card; 662 snd_cards[card->number] = card;
662 mutex_unlock(&snd_card_mutex); 663 mutex_unlock(&snd_card_mutex);
663 init_info_for_card(card); 664 init_info_for_card(card);