aboutsummaryrefslogtreecommitdiffstats
path: root/sound/core/sound.c
diff options
context:
space:
mode:
authorClemens Ladisch <clemens@ladisch.de>2005-11-20 08:03:48 -0500
committerJaroslav Kysela <perex@suse.cz>2006-01-03 06:29:14 -0500
commit2af677fc884fc6dc79e65c99050ea607ac8bab9b (patch)
tree4291d36c2f116d5887b88da5f0213b68933a1201 /sound/core/sound.c
parenta106cd3d9e88c8761bd0eac2ce402cc82bd11fea (diff)
[ALSA] dynamic minors (1/6): store device type in struct snd_minor
Instead of a comment string, store the device type in the snd_minor structure. This makes snd_minor more flexible, and has the nice side effect that we don't need anymore to create a separate snd_minor template for registering a device but can pass the file_operations directly to snd_register_device(). Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Diffstat (limited to 'sound/core/sound.c')
-rw-r--r--sound/core/sound.c38
1 files changed, 31 insertions, 7 deletions
diff --git a/sound/core/sound.c b/sound/core/sound.c
index fb236a6b9c34..798c24c2de20 100644
--- a/sound/core/sound.c
+++ b/sound/core/sound.c
@@ -195,7 +195,7 @@ static int snd_kernel_minor(int type, struct snd_card *card, int dev)
195 * @type: the device type, SNDRV_DEVICE_TYPE_XXX 195 * @type: the device type, SNDRV_DEVICE_TYPE_XXX
196 * @card: the card instance 196 * @card: the card instance
197 * @dev: the device index 197 * @dev: the device index
198 * @reg: the struct snd_minor record 198 * @f_ops: the file operations
199 * @name: the device file name 199 * @name: the device file name
200 * 200 *
201 * Registers an ALSA device file for the given card. 201 * Registers an ALSA device file for the given card.
@@ -203,7 +203,8 @@ static int snd_kernel_minor(int type, struct snd_card *card, int dev)
203 * 203 *
204 * Retrurns zero if successful, or a negative error code on failure. 204 * Retrurns zero if successful, or a negative error code on failure.
205 */ 205 */
206int snd_register_device(int type, struct snd_card *card, int dev, struct snd_minor * reg, const char *name) 206int snd_register_device(int type, struct snd_card *card, int dev,
207 struct file_operations *f_ops, const char *name)
207{ 208{
208 int minor = snd_kernel_minor(type, card, dev); 209 int minor = snd_kernel_minor(type, card, dev);
209 struct snd_minor *preg; 210 struct snd_minor *preg;
@@ -212,12 +213,13 @@ int snd_register_device(int type, struct snd_card *card, int dev, struct snd_min
212 if (minor < 0) 213 if (minor < 0)
213 return minor; 214 return minor;
214 snd_assert(name, return -EINVAL); 215 snd_assert(name, return -EINVAL);
215 preg = kmalloc(sizeof(struct snd_minor) + strlen(name) + 1, GFP_KERNEL); 216 preg = kzalloc(sizeof(struct snd_minor) + strlen(name) + 1, GFP_KERNEL);
216 if (preg == NULL) 217 if (preg == NULL)
217 return -ENOMEM; 218 return -ENOMEM;
218 *preg = *reg;
219 preg->number = minor; 219 preg->number = minor;
220 preg->type = type;
220 preg->device = dev; 221 preg->device = dev;
222 preg->f_ops = f_ops;
221 strcpy(preg->name, name); 223 strcpy(preg->name, name);
222 down(&sound_mutex); 224 down(&sound_mutex);
223 if (snd_minor_search(minor)) { 225 if (snd_minor_search(minor)) {
@@ -276,6 +278,28 @@ int snd_unregister_device(int type, struct snd_card *card, int dev)
276 278
277static struct snd_info_entry *snd_minor_info_entry = NULL; 279static struct snd_info_entry *snd_minor_info_entry = NULL;
278 280
281static const char *snd_device_type_name(int type)
282{
283 switch (type) {
284 case SNDRV_DEVICE_TYPE_CONTROL:
285 return "control";
286 case SNDRV_DEVICE_TYPE_HWDEP:
287 return "hardware dependent";
288 case SNDRV_DEVICE_TYPE_RAWMIDI:
289 return "raw midi";
290 case SNDRV_DEVICE_TYPE_PCM_PLAYBACK:
291 return "digital audio playback";
292 case SNDRV_DEVICE_TYPE_PCM_CAPTURE:
293 return "digital audio capture";
294 case SNDRV_DEVICE_TYPE_SEQUENCER:
295 return "sequencer";
296 case SNDRV_DEVICE_TYPE_TIMER:
297 return "timer";
298 default:
299 return "?";
300 }
301}
302
279static void snd_minor_info_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer) 303static void snd_minor_info_read(struct snd_info_entry *entry, struct snd_info_buffer *buffer)
280{ 304{
281 int card, device; 305 int card, device;
@@ -288,11 +312,11 @@ static void snd_minor_info_read(struct snd_info_entry *entry, struct snd_info_bu
288 mptr = list_entry(list, struct snd_minor, list); 312 mptr = list_entry(list, struct snd_minor, list);
289 if (SNDRV_MINOR_DEVICE(mptr->number) != SNDRV_MINOR_GLOBAL) { 313 if (SNDRV_MINOR_DEVICE(mptr->number) != SNDRV_MINOR_GLOBAL) {
290 if ((device = mptr->device) >= 0) 314 if ((device = mptr->device) >= 0)
291 snd_iprintf(buffer, "%3i: [%i-%2i]: %s\n", mptr->number, card, device, mptr->comment); 315 snd_iprintf(buffer, "%3i: [%i-%2i]: %s\n", mptr->number, card, device, snd_device_type_name(mptr->type));
292 else 316 else
293 snd_iprintf(buffer, "%3i: [%i] : %s\n", mptr->number, card, mptr->comment); 317 snd_iprintf(buffer, "%3i: [%i] : %s\n", mptr->number, card, snd_device_type_name(mptr->type));
294 } else { 318 } else {
295 snd_iprintf(buffer, "%3i: : %s\n", mptr->number, mptr->comment); 319 snd_iprintf(buffer, "%3i: : %s\n", mptr->number, snd_device_type_name(mptr->type));
296 } 320 }
297 } 321 }
298 } 322 }