ALSA: core: Don't refer to snd_cards array directly
authorTakashi Iwai <tiwai@suse.de>
Tue, 16 Apr 2019 16:18:47 +0000 (18:18 +0200)
committerTakashi Iwai <tiwai@suse.de>
Wed, 17 Apr 2019 05:16:15 +0000 (07:16 +0200)
commitf4fa968950aef7efb98a0899bb0132405e2edaf1
tree2053bcf32985ef7539b02f10246bf67c4543903a
parentc989954938761a2939a21fcbc768af182de6be58
ALSA: core: Don't refer to snd_cards array directly

The snd_cards[] array holds the card pointers that have been currently
registered, and it's exported for the external modules that may need
to refer a card object.  But accessing to this array can be racy
against the driver probe or removal, as the card registration or free
may happen concurrently.

This patch gets rid of the direct access to snd_cards[] array and
provides a helper function to give the card object from the index
number with a refcount management.  Then the caller can access to the
given card object safely, and releases it via snd_card_unref().

While we're at it, add a proper comment to snd_card_unref() and make
it an inlined function for type-safety, too.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
include/sound/core.h
sound/core/init.c
sound/core/oss/mixer_oss.c
sound/core/sound.c
sound/last.c