diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2005-11-20 08:06:59 -0500 |
---|---|---|
committer | Jaroslav Kysela <perex@suse.cz> | 2006-01-03 06:29:17 -0500 |
commit | f87135f56cb266e031f5ec081dfbde7e43f55e80 (patch) | |
tree | c048abae6bb04df53f5d8d7dcffbf2c28bc638ff /sound/core/control.c | |
parent | 6983b7240cd229787c3ee00e663ea94ea649d96a (diff) |
[ALSA] dynamic minors (3/6): store device-specific object pointers dynamically
Instead of storing the pointers to the device-specific structures in an
array, put them into the struct snd_minor, and look them up dynamically.
This makes the device type modules independent of the minor number
encoding.
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Diffstat (limited to 'sound/core/control.c')
-rw-r--r-- | sound/core/control.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/sound/core/control.c b/sound/core/control.c index 23561e74712b..abd62f943726 100644 --- a/sound/core/control.c +++ b/sound/core/control.c | |||
@@ -47,13 +47,12 @@ static LIST_HEAD(snd_control_compat_ioctls); | |||
47 | 47 | ||
48 | static int snd_ctl_open(struct inode *inode, struct file *file) | 48 | static int snd_ctl_open(struct inode *inode, struct file *file) |
49 | { | 49 | { |
50 | int cardnum = SNDRV_MINOR_CARD(iminor(inode)); | ||
51 | unsigned long flags; | 50 | unsigned long flags; |
52 | struct snd_card *card; | 51 | struct snd_card *card; |
53 | struct snd_ctl_file *ctl; | 52 | struct snd_ctl_file *ctl; |
54 | int err; | 53 | int err; |
55 | 54 | ||
56 | card = snd_cards[cardnum]; | 55 | card = snd_lookup_minor_data(iminor(inode), SNDRV_DEVICE_TYPE_CONTROL); |
57 | if (!card) { | 56 | if (!card) { |
58 | err = -ENODEV; | 57 | err = -ENODEV; |
59 | goto __error1; | 58 | goto __error1; |
@@ -1277,8 +1276,8 @@ static int snd_ctl_dev_register(struct snd_device *device) | |||
1277 | cardnum = card->number; | 1276 | cardnum = card->number; |
1278 | snd_assert(cardnum >= 0 && cardnum < SNDRV_CARDS, return -ENXIO); | 1277 | snd_assert(cardnum >= 0 && cardnum < SNDRV_CARDS, return -ENXIO); |
1279 | sprintf(name, "controlC%i", cardnum); | 1278 | sprintf(name, "controlC%i", cardnum); |
1280 | if ((err = snd_register_device(SNDRV_DEVICE_TYPE_CONTROL, | 1279 | if ((err = snd_register_device(SNDRV_DEVICE_TYPE_CONTROL, card, -1, |
1281 | card, -1, &snd_ctl_f_ops, name)) < 0) | 1280 | &snd_ctl_f_ops, card, name)) < 0) |
1282 | return err; | 1281 | return err; |
1283 | return 0; | 1282 | return 0; |
1284 | } | 1283 | } |