xref: /openbmc/linux/sound/core/control.c (revision 3805e6a1)
1 /*
2  *  Routines for driver control interface
3  *  Copyright (c) by Jaroslav Kysela <perex@perex.cz>
4  *
5  *
6  *   This program is free software; you can redistribute it and/or modify
7  *   it under the terms of the GNU General Public License as published by
8  *   the Free Software Foundation; either version 2 of the License, or
9  *   (at your option) any later version.
10  *
11  *   This program is distributed in the hope that it will be useful,
12  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
13  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  *   GNU General Public License for more details.
15  *
16  *   You should have received a copy of the GNU General Public License
17  *   along with this program; if not, write to the Free Software
18  *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19  *
20  */
21 
22 #include <linux/threads.h>
23 #include <linux/interrupt.h>
24 #include <linux/module.h>
25 #include <linux/slab.h>
26 #include <linux/vmalloc.h>
27 #include <linux/time.h>
28 #include <sound/core.h>
29 #include <sound/minors.h>
30 #include <sound/info.h>
31 #include <sound/control.h>
32 
33 /* max number of user-defined controls */
34 #define MAX_USER_CONTROLS	32
35 #define MAX_CONTROL_COUNT	1028
36 
37 struct snd_kctl_ioctl {
38 	struct list_head list;		/* list of all ioctls */
39 	snd_kctl_ioctl_func_t fioctl;
40 };
41 
42 static DECLARE_RWSEM(snd_ioctl_rwsem);
43 static LIST_HEAD(snd_control_ioctls);
44 #ifdef CONFIG_COMPAT
45 static LIST_HEAD(snd_control_compat_ioctls);
46 #endif
47 
48 static int snd_ctl_open(struct inode *inode, struct file *file)
49 {
50 	unsigned long flags;
51 	struct snd_card *card;
52 	struct snd_ctl_file *ctl;
53 	int i, err;
54 
55 	err = nonseekable_open(inode, file);
56 	if (err < 0)
57 		return err;
58 
59 	card = snd_lookup_minor_data(iminor(inode), SNDRV_DEVICE_TYPE_CONTROL);
60 	if (!card) {
61 		err = -ENODEV;
62 		goto __error1;
63 	}
64 	err = snd_card_file_add(card, file);
65 	if (err < 0) {
66 		err = -ENODEV;
67 		goto __error1;
68 	}
69 	if (!try_module_get(card->module)) {
70 		err = -EFAULT;
71 		goto __error2;
72 	}
73 	ctl = kzalloc(sizeof(*ctl), GFP_KERNEL);
74 	if (ctl == NULL) {
75 		err = -ENOMEM;
76 		goto __error;
77 	}
78 	INIT_LIST_HEAD(&ctl->events);
79 	init_waitqueue_head(&ctl->change_sleep);
80 	spin_lock_init(&ctl->read_lock);
81 	ctl->card = card;
82 	for (i = 0; i < SND_CTL_SUBDEV_ITEMS; i++)
83 		ctl->preferred_subdevice[i] = -1;
84 	ctl->pid = get_pid(task_pid(current));
85 	file->private_data = ctl;
86 	write_lock_irqsave(&card->ctl_files_rwlock, flags);
87 	list_add_tail(&ctl->list, &card->ctl_files);
88 	write_unlock_irqrestore(&card->ctl_files_rwlock, flags);
89 	snd_card_unref(card);
90 	return 0;
91 
92       __error:
93 	module_put(card->module);
94       __error2:
95 	snd_card_file_remove(card, file);
96       __error1:
97 	if (card)
98 		snd_card_unref(card);
99       	return err;
100 }
101 
102 static void snd_ctl_empty_read_queue(struct snd_ctl_file * ctl)
103 {
104 	unsigned long flags;
105 	struct snd_kctl_event *cread;
106 
107 	spin_lock_irqsave(&ctl->read_lock, flags);
108 	while (!list_empty(&ctl->events)) {
109 		cread = snd_kctl_event(ctl->events.next);
110 		list_del(&cread->list);
111 		kfree(cread);
112 	}
113 	spin_unlock_irqrestore(&ctl->read_lock, flags);
114 }
115 
116 static int snd_ctl_release(struct inode *inode, struct file *file)
117 {
118 	unsigned long flags;
119 	struct snd_card *card;
120 	struct snd_ctl_file *ctl;
121 	struct snd_kcontrol *control;
122 	unsigned int idx;
123 
124 	ctl = file->private_data;
125 	file->private_data = NULL;
126 	card = ctl->card;
127 	write_lock_irqsave(&card->ctl_files_rwlock, flags);
128 	list_del(&ctl->list);
129 	write_unlock_irqrestore(&card->ctl_files_rwlock, flags);
130 	down_write(&card->controls_rwsem);
131 	list_for_each_entry(control, &card->controls, list)
132 		for (idx = 0; idx < control->count; idx++)
133 			if (control->vd[idx].owner == ctl)
134 				control->vd[idx].owner = NULL;
135 	up_write(&card->controls_rwsem);
136 	snd_ctl_empty_read_queue(ctl);
137 	put_pid(ctl->pid);
138 	kfree(ctl);
139 	module_put(card->module);
140 	snd_card_file_remove(card, file);
141 	return 0;
142 }
143 
144 /**
145  * snd_ctl_notify - Send notification to user-space for a control change
146  * @card: the card to send notification
147  * @mask: the event mask, SNDRV_CTL_EVENT_*
148  * @id: the ctl element id to send notification
149  *
150  * This function adds an event record with the given id and mask, appends
151  * to the list and wakes up the user-space for notification.  This can be
152  * called in the atomic context.
153  */
154 void snd_ctl_notify(struct snd_card *card, unsigned int mask,
155 		    struct snd_ctl_elem_id *id)
156 {
157 	unsigned long flags;
158 	struct snd_ctl_file *ctl;
159 	struct snd_kctl_event *ev;
160 
161 	if (snd_BUG_ON(!card || !id))
162 		return;
163 	read_lock(&card->ctl_files_rwlock);
164 #if IS_ENABLED(CONFIG_SND_MIXER_OSS)
165 	card->mixer_oss_change_count++;
166 #endif
167 	list_for_each_entry(ctl, &card->ctl_files, list) {
168 		if (!ctl->subscribed)
169 			continue;
170 		spin_lock_irqsave(&ctl->read_lock, flags);
171 		list_for_each_entry(ev, &ctl->events, list) {
172 			if (ev->id.numid == id->numid) {
173 				ev->mask |= mask;
174 				goto _found;
175 			}
176 		}
177 		ev = kzalloc(sizeof(*ev), GFP_ATOMIC);
178 		if (ev) {
179 			ev->id = *id;
180 			ev->mask = mask;
181 			list_add_tail(&ev->list, &ctl->events);
182 		} else {
183 			dev_err(card->dev, "No memory available to allocate event\n");
184 		}
185 	_found:
186 		wake_up(&ctl->change_sleep);
187 		spin_unlock_irqrestore(&ctl->read_lock, flags);
188 		kill_fasync(&ctl->fasync, SIGIO, POLL_IN);
189 	}
190 	read_unlock(&card->ctl_files_rwlock);
191 }
192 EXPORT_SYMBOL(snd_ctl_notify);
193 
194 /**
195  * snd_ctl_new - create a new control instance with some elements
196  * @kctl: the pointer to store new control instance
197  * @count: the number of elements in this control
198  * @access: the default access flags for elements in this control
199  * @file: given when locking these elements
200  *
201  * Allocates a memory object for a new control instance. The instance has
202  * elements as many as the given number (@count). Each element has given
203  * access permissions (@access). Each element is locked when @file is given.
204  *
205  * Return: 0 on success, error code on failure
206  */
207 static int snd_ctl_new(struct snd_kcontrol **kctl, unsigned int count,
208 		       unsigned int access, struct snd_ctl_file *file)
209 {
210 	unsigned int size;
211 	unsigned int idx;
212 
213 	if (count == 0 || count > MAX_CONTROL_COUNT)
214 		return -EINVAL;
215 
216 	size  = sizeof(struct snd_kcontrol);
217 	size += sizeof(struct snd_kcontrol_volatile) * count;
218 
219 	*kctl = kzalloc(size, GFP_KERNEL);
220 	if (!*kctl)
221 		return -ENOMEM;
222 
223 	for (idx = 0; idx < count; idx++) {
224 		(*kctl)->vd[idx].access = access;
225 		(*kctl)->vd[idx].owner = file;
226 	}
227 	(*kctl)->count = count;
228 
229 	return 0;
230 }
231 
232 /**
233  * snd_ctl_new1 - create a control instance from the template
234  * @ncontrol: the initialization record
235  * @private_data: the private data to set
236  *
237  * Allocates a new struct snd_kcontrol instance and initialize from the given
238  * template.  When the access field of ncontrol is 0, it's assumed as
239  * READWRITE access. When the count field is 0, it's assumes as one.
240  *
241  * Return: The pointer of the newly generated instance, or %NULL on failure.
242  */
243 struct snd_kcontrol *snd_ctl_new1(const struct snd_kcontrol_new *ncontrol,
244 				  void *private_data)
245 {
246 	struct snd_kcontrol *kctl;
247 	unsigned int count;
248 	unsigned int access;
249 	int err;
250 
251 	if (snd_BUG_ON(!ncontrol || !ncontrol->info))
252 		return NULL;
253 
254 	count = ncontrol->count;
255 	if (count == 0)
256 		count = 1;
257 
258 	access = ncontrol->access;
259 	if (access == 0)
260 		access = SNDRV_CTL_ELEM_ACCESS_READWRITE;
261 	access &= (SNDRV_CTL_ELEM_ACCESS_READWRITE |
262 		   SNDRV_CTL_ELEM_ACCESS_VOLATILE |
263 		   SNDRV_CTL_ELEM_ACCESS_INACTIVE |
264 		   SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE |
265 		   SNDRV_CTL_ELEM_ACCESS_TLV_COMMAND |
266 		   SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK);
267 
268 	err = snd_ctl_new(&kctl, count, access, NULL);
269 	if (err < 0)
270 		return NULL;
271 
272 	/* The 'numid' member is decided when calling snd_ctl_add(). */
273 	kctl->id.iface = ncontrol->iface;
274 	kctl->id.device = ncontrol->device;
275 	kctl->id.subdevice = ncontrol->subdevice;
276 	if (ncontrol->name) {
277 		strlcpy(kctl->id.name, ncontrol->name, sizeof(kctl->id.name));
278 		if (strcmp(ncontrol->name, kctl->id.name) != 0)
279 			pr_warn("ALSA: Control name '%s' truncated to '%s'\n",
280 				ncontrol->name, kctl->id.name);
281 	}
282 	kctl->id.index = ncontrol->index;
283 
284 	kctl->info = ncontrol->info;
285 	kctl->get = ncontrol->get;
286 	kctl->put = ncontrol->put;
287 	kctl->tlv.p = ncontrol->tlv.p;
288 
289 	kctl->private_value = ncontrol->private_value;
290 	kctl->private_data = private_data;
291 
292 	return kctl;
293 }
294 EXPORT_SYMBOL(snd_ctl_new1);
295 
296 /**
297  * snd_ctl_free_one - release the control instance
298  * @kcontrol: the control instance
299  *
300  * Releases the control instance created via snd_ctl_new()
301  * or snd_ctl_new1().
302  * Don't call this after the control was added to the card.
303  */
304 void snd_ctl_free_one(struct snd_kcontrol *kcontrol)
305 {
306 	if (kcontrol) {
307 		if (kcontrol->private_free)
308 			kcontrol->private_free(kcontrol);
309 		kfree(kcontrol);
310 	}
311 }
312 EXPORT_SYMBOL(snd_ctl_free_one);
313 
314 static bool snd_ctl_remove_numid_conflict(struct snd_card *card,
315 					  unsigned int count)
316 {
317 	struct snd_kcontrol *kctl;
318 
319 	/* Make sure that the ids assigned to the control do not wrap around */
320 	if (card->last_numid >= UINT_MAX - count)
321 		card->last_numid = 0;
322 
323 	list_for_each_entry(kctl, &card->controls, list) {
324 		if (kctl->id.numid < card->last_numid + 1 + count &&
325 		    kctl->id.numid + kctl->count > card->last_numid + 1) {
326 		    	card->last_numid = kctl->id.numid + kctl->count - 1;
327 			return true;
328 		}
329 	}
330 	return false;
331 }
332 
333 static int snd_ctl_find_hole(struct snd_card *card, unsigned int count)
334 {
335 	unsigned int iter = 100000;
336 
337 	while (snd_ctl_remove_numid_conflict(card, count)) {
338 		if (--iter == 0) {
339 			/* this situation is very unlikely */
340 			dev_err(card->dev, "unable to allocate new control numid\n");
341 			return -ENOMEM;
342 		}
343 	}
344 	return 0;
345 }
346 
347 /**
348  * snd_ctl_add - add the control instance to the card
349  * @card: the card instance
350  * @kcontrol: the control instance to add
351  *
352  * Adds the control instance created via snd_ctl_new() or
353  * snd_ctl_new1() to the given card. Assigns also an unique
354  * numid used for fast search.
355  *
356  * It frees automatically the control which cannot be added.
357  *
358  * Return: Zero if successful, or a negative error code on failure.
359  *
360  */
361 int snd_ctl_add(struct snd_card *card, struct snd_kcontrol *kcontrol)
362 {
363 	struct snd_ctl_elem_id id;
364 	unsigned int idx;
365 	unsigned int count;
366 	int err = -EINVAL;
367 
368 	if (! kcontrol)
369 		return err;
370 	if (snd_BUG_ON(!card || !kcontrol->info))
371 		goto error;
372 	id = kcontrol->id;
373 	if (id.index > UINT_MAX - kcontrol->count)
374 		goto error;
375 
376 	down_write(&card->controls_rwsem);
377 	if (snd_ctl_find_id(card, &id)) {
378 		up_write(&card->controls_rwsem);
379 		dev_err(card->dev, "control %i:%i:%i:%s:%i is already present\n",
380 					id.iface,
381 					id.device,
382 					id.subdevice,
383 					id.name,
384 					id.index);
385 		err = -EBUSY;
386 		goto error;
387 	}
388 	if (snd_ctl_find_hole(card, kcontrol->count) < 0) {
389 		up_write(&card->controls_rwsem);
390 		err = -ENOMEM;
391 		goto error;
392 	}
393 	list_add_tail(&kcontrol->list, &card->controls);
394 	card->controls_count += kcontrol->count;
395 	kcontrol->id.numid = card->last_numid + 1;
396 	card->last_numid += kcontrol->count;
397 	id = kcontrol->id;
398 	count = kcontrol->count;
399 	up_write(&card->controls_rwsem);
400 	for (idx = 0; idx < count; idx++, id.index++, id.numid++)
401 		snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_ADD, &id);
402 	return 0;
403 
404  error:
405 	snd_ctl_free_one(kcontrol);
406 	return err;
407 }
408 EXPORT_SYMBOL(snd_ctl_add);
409 
410 /**
411  * snd_ctl_replace - replace the control instance of the card
412  * @card: the card instance
413  * @kcontrol: the control instance to replace
414  * @add_on_replace: add the control if not already added
415  *
416  * Replaces the given control.  If the given control does not exist
417  * and the add_on_replace flag is set, the control is added.  If the
418  * control exists, it is destroyed first.
419  *
420  * It frees automatically the control which cannot be added or replaced.
421  *
422  * Return: Zero if successful, or a negative error code on failure.
423  */
424 int snd_ctl_replace(struct snd_card *card, struct snd_kcontrol *kcontrol,
425 		    bool add_on_replace)
426 {
427 	struct snd_ctl_elem_id id;
428 	unsigned int count;
429 	unsigned int idx;
430 	struct snd_kcontrol *old;
431 	int ret;
432 
433 	if (!kcontrol)
434 		return -EINVAL;
435 	if (snd_BUG_ON(!card || !kcontrol->info)) {
436 		ret = -EINVAL;
437 		goto error;
438 	}
439 	id = kcontrol->id;
440 	down_write(&card->controls_rwsem);
441 	old = snd_ctl_find_id(card, &id);
442 	if (!old) {
443 		if (add_on_replace)
444 			goto add;
445 		up_write(&card->controls_rwsem);
446 		ret = -EINVAL;
447 		goto error;
448 	}
449 	ret = snd_ctl_remove(card, old);
450 	if (ret < 0) {
451 		up_write(&card->controls_rwsem);
452 		goto error;
453 	}
454 add:
455 	if (snd_ctl_find_hole(card, kcontrol->count) < 0) {
456 		up_write(&card->controls_rwsem);
457 		ret = -ENOMEM;
458 		goto error;
459 	}
460 	list_add_tail(&kcontrol->list, &card->controls);
461 	card->controls_count += kcontrol->count;
462 	kcontrol->id.numid = card->last_numid + 1;
463 	card->last_numid += kcontrol->count;
464 	id = kcontrol->id;
465 	count = kcontrol->count;
466 	up_write(&card->controls_rwsem);
467 	for (idx = 0; idx < count; idx++, id.index++, id.numid++)
468 		snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_ADD, &id);
469 	return 0;
470 
471 error:
472 	snd_ctl_free_one(kcontrol);
473 	return ret;
474 }
475 EXPORT_SYMBOL(snd_ctl_replace);
476 
477 /**
478  * snd_ctl_remove - remove the control from the card and release it
479  * @card: the card instance
480  * @kcontrol: the control instance to remove
481  *
482  * Removes the control from the card and then releases the instance.
483  * You don't need to call snd_ctl_free_one(). You must be in
484  * the write lock - down_write(&card->controls_rwsem).
485  *
486  * Return: 0 if successful, or a negative error code on failure.
487  */
488 int snd_ctl_remove(struct snd_card *card, struct snd_kcontrol *kcontrol)
489 {
490 	struct snd_ctl_elem_id id;
491 	unsigned int idx;
492 
493 	if (snd_BUG_ON(!card || !kcontrol))
494 		return -EINVAL;
495 	list_del(&kcontrol->list);
496 	card->controls_count -= kcontrol->count;
497 	id = kcontrol->id;
498 	for (idx = 0; idx < kcontrol->count; idx++, id.index++, id.numid++)
499 		snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_REMOVE, &id);
500 	snd_ctl_free_one(kcontrol);
501 	return 0;
502 }
503 EXPORT_SYMBOL(snd_ctl_remove);
504 
505 /**
506  * snd_ctl_remove_id - remove the control of the given id and release it
507  * @card: the card instance
508  * @id: the control id to remove
509  *
510  * Finds the control instance with the given id, removes it from the
511  * card list and releases it.
512  *
513  * Return: 0 if successful, or a negative error code on failure.
514  */
515 int snd_ctl_remove_id(struct snd_card *card, struct snd_ctl_elem_id *id)
516 {
517 	struct snd_kcontrol *kctl;
518 	int ret;
519 
520 	down_write(&card->controls_rwsem);
521 	kctl = snd_ctl_find_id(card, id);
522 	if (kctl == NULL) {
523 		up_write(&card->controls_rwsem);
524 		return -ENOENT;
525 	}
526 	ret = snd_ctl_remove(card, kctl);
527 	up_write(&card->controls_rwsem);
528 	return ret;
529 }
530 EXPORT_SYMBOL(snd_ctl_remove_id);
531 
532 /**
533  * snd_ctl_remove_user_ctl - remove and release the unlocked user control
534  * @file: active control handle
535  * @id: the control id to remove
536  *
537  * Finds the control instance with the given id, removes it from the
538  * card list and releases it.
539  *
540  * Return: 0 if successful, or a negative error code on failure.
541  */
542 static int snd_ctl_remove_user_ctl(struct snd_ctl_file * file,
543 				   struct snd_ctl_elem_id *id)
544 {
545 	struct snd_card *card = file->card;
546 	struct snd_kcontrol *kctl;
547 	int idx, ret;
548 
549 	down_write(&card->controls_rwsem);
550 	kctl = snd_ctl_find_id(card, id);
551 	if (kctl == NULL) {
552 		ret = -ENOENT;
553 		goto error;
554 	}
555 	if (!(kctl->vd[0].access & SNDRV_CTL_ELEM_ACCESS_USER)) {
556 		ret = -EINVAL;
557 		goto error;
558 	}
559 	for (idx = 0; idx < kctl->count; idx++)
560 		if (kctl->vd[idx].owner != NULL && kctl->vd[idx].owner != file) {
561 			ret = -EBUSY;
562 			goto error;
563 		}
564 	ret = snd_ctl_remove(card, kctl);
565 	if (ret < 0)
566 		goto error;
567 	card->user_ctl_count--;
568 error:
569 	up_write(&card->controls_rwsem);
570 	return ret;
571 }
572 
573 /**
574  * snd_ctl_activate_id - activate/inactivate the control of the given id
575  * @card: the card instance
576  * @id: the control id to activate/inactivate
577  * @active: non-zero to activate
578  *
579  * Finds the control instance with the given id, and activate or
580  * inactivate the control together with notification, if changed.
581  * The given ID data is filled with full information.
582  *
583  * Return: 0 if unchanged, 1 if changed, or a negative error code on failure.
584  */
585 int snd_ctl_activate_id(struct snd_card *card, struct snd_ctl_elem_id *id,
586 			int active)
587 {
588 	struct snd_kcontrol *kctl;
589 	struct snd_kcontrol_volatile *vd;
590 	unsigned int index_offset;
591 	int ret;
592 
593 	down_write(&card->controls_rwsem);
594 	kctl = snd_ctl_find_id(card, id);
595 	if (kctl == NULL) {
596 		ret = -ENOENT;
597 		goto unlock;
598 	}
599 	index_offset = snd_ctl_get_ioff(kctl, id);
600 	vd = &kctl->vd[index_offset];
601 	ret = 0;
602 	if (active) {
603 		if (!(vd->access & SNDRV_CTL_ELEM_ACCESS_INACTIVE))
604 			goto unlock;
605 		vd->access &= ~SNDRV_CTL_ELEM_ACCESS_INACTIVE;
606 	} else {
607 		if (vd->access & SNDRV_CTL_ELEM_ACCESS_INACTIVE)
608 			goto unlock;
609 		vd->access |= SNDRV_CTL_ELEM_ACCESS_INACTIVE;
610 	}
611 	snd_ctl_build_ioff(id, kctl, index_offset);
612 	ret = 1;
613  unlock:
614 	up_write(&card->controls_rwsem);
615 	if (ret > 0)
616 		snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_INFO, id);
617 	return ret;
618 }
619 EXPORT_SYMBOL_GPL(snd_ctl_activate_id);
620 
621 /**
622  * snd_ctl_rename_id - replace the id of a control on the card
623  * @card: the card instance
624  * @src_id: the old id
625  * @dst_id: the new id
626  *
627  * Finds the control with the old id from the card, and replaces the
628  * id with the new one.
629  *
630  * Return: Zero if successful, or a negative error code on failure.
631  */
632 int snd_ctl_rename_id(struct snd_card *card, struct snd_ctl_elem_id *src_id,
633 		      struct snd_ctl_elem_id *dst_id)
634 {
635 	struct snd_kcontrol *kctl;
636 
637 	down_write(&card->controls_rwsem);
638 	kctl = snd_ctl_find_id(card, src_id);
639 	if (kctl == NULL) {
640 		up_write(&card->controls_rwsem);
641 		return -ENOENT;
642 	}
643 	kctl->id = *dst_id;
644 	kctl->id.numid = card->last_numid + 1;
645 	card->last_numid += kctl->count;
646 	up_write(&card->controls_rwsem);
647 	return 0;
648 }
649 EXPORT_SYMBOL(snd_ctl_rename_id);
650 
651 /**
652  * snd_ctl_find_numid - find the control instance with the given number-id
653  * @card: the card instance
654  * @numid: the number-id to search
655  *
656  * Finds the control instance with the given number-id from the card.
657  *
658  * The caller must down card->controls_rwsem before calling this function
659  * (if the race condition can happen).
660  *
661  * Return: The pointer of the instance if found, or %NULL if not.
662  *
663  */
664 struct snd_kcontrol *snd_ctl_find_numid(struct snd_card *card, unsigned int numid)
665 {
666 	struct snd_kcontrol *kctl;
667 
668 	if (snd_BUG_ON(!card || !numid))
669 		return NULL;
670 	list_for_each_entry(kctl, &card->controls, list) {
671 		if (kctl->id.numid <= numid && kctl->id.numid + kctl->count > numid)
672 			return kctl;
673 	}
674 	return NULL;
675 }
676 EXPORT_SYMBOL(snd_ctl_find_numid);
677 
678 /**
679  * snd_ctl_find_id - find the control instance with the given id
680  * @card: the card instance
681  * @id: the id to search
682  *
683  * Finds the control instance with the given id from the card.
684  *
685  * The caller must down card->controls_rwsem before calling this function
686  * (if the race condition can happen).
687  *
688  * Return: The pointer of the instance if found, or %NULL if not.
689  *
690  */
691 struct snd_kcontrol *snd_ctl_find_id(struct snd_card *card,
692 				     struct snd_ctl_elem_id *id)
693 {
694 	struct snd_kcontrol *kctl;
695 
696 	if (snd_BUG_ON(!card || !id))
697 		return NULL;
698 	if (id->numid != 0)
699 		return snd_ctl_find_numid(card, id->numid);
700 	list_for_each_entry(kctl, &card->controls, list) {
701 		if (kctl->id.iface != id->iface)
702 			continue;
703 		if (kctl->id.device != id->device)
704 			continue;
705 		if (kctl->id.subdevice != id->subdevice)
706 			continue;
707 		if (strncmp(kctl->id.name, id->name, sizeof(kctl->id.name)))
708 			continue;
709 		if (kctl->id.index > id->index)
710 			continue;
711 		if (kctl->id.index + kctl->count <= id->index)
712 			continue;
713 		return kctl;
714 	}
715 	return NULL;
716 }
717 EXPORT_SYMBOL(snd_ctl_find_id);
718 
719 static int snd_ctl_card_info(struct snd_card *card, struct snd_ctl_file * ctl,
720 			     unsigned int cmd, void __user *arg)
721 {
722 	struct snd_ctl_card_info *info;
723 
724 	info = kzalloc(sizeof(*info), GFP_KERNEL);
725 	if (! info)
726 		return -ENOMEM;
727 	down_read(&snd_ioctl_rwsem);
728 	info->card = card->number;
729 	strlcpy(info->id, card->id, sizeof(info->id));
730 	strlcpy(info->driver, card->driver, sizeof(info->driver));
731 	strlcpy(info->name, card->shortname, sizeof(info->name));
732 	strlcpy(info->longname, card->longname, sizeof(info->longname));
733 	strlcpy(info->mixername, card->mixername, sizeof(info->mixername));
734 	strlcpy(info->components, card->components, sizeof(info->components));
735 	up_read(&snd_ioctl_rwsem);
736 	if (copy_to_user(arg, info, sizeof(struct snd_ctl_card_info))) {
737 		kfree(info);
738 		return -EFAULT;
739 	}
740 	kfree(info);
741 	return 0;
742 }
743 
744 static int snd_ctl_elem_list(struct snd_card *card,
745 			     struct snd_ctl_elem_list __user *_list)
746 {
747 	struct list_head *plist;
748 	struct snd_ctl_elem_list list;
749 	struct snd_kcontrol *kctl;
750 	struct snd_ctl_elem_id *dst, *id;
751 	unsigned int offset, space, jidx;
752 
753 	if (copy_from_user(&list, _list, sizeof(list)))
754 		return -EFAULT;
755 	offset = list.offset;
756 	space = list.space;
757 	/* try limit maximum space */
758 	if (space > 16384)
759 		return -ENOMEM;
760 	if (space > 0) {
761 		/* allocate temporary buffer for atomic operation */
762 		dst = vmalloc(space * sizeof(struct snd_ctl_elem_id));
763 		if (dst == NULL)
764 			return -ENOMEM;
765 		down_read(&card->controls_rwsem);
766 		list.count = card->controls_count;
767 		plist = card->controls.next;
768 		while (plist != &card->controls) {
769 			if (offset == 0)
770 				break;
771 			kctl = snd_kcontrol(plist);
772 			if (offset < kctl->count)
773 				break;
774 			offset -= kctl->count;
775 			plist = plist->next;
776 		}
777 		list.used = 0;
778 		id = dst;
779 		while (space > 0 && plist != &card->controls) {
780 			kctl = snd_kcontrol(plist);
781 			for (jidx = offset; space > 0 && jidx < kctl->count; jidx++) {
782 				snd_ctl_build_ioff(id, kctl, jidx);
783 				id++;
784 				space--;
785 				list.used++;
786 			}
787 			plist = plist->next;
788 			offset = 0;
789 		}
790 		up_read(&card->controls_rwsem);
791 		if (list.used > 0 &&
792 		    copy_to_user(list.pids, dst,
793 				 list.used * sizeof(struct snd_ctl_elem_id))) {
794 			vfree(dst);
795 			return -EFAULT;
796 		}
797 		vfree(dst);
798 	} else {
799 		down_read(&card->controls_rwsem);
800 		list.count = card->controls_count;
801 		up_read(&card->controls_rwsem);
802 	}
803 	if (copy_to_user(_list, &list, sizeof(list)))
804 		return -EFAULT;
805 	return 0;
806 }
807 
808 static bool validate_element_member_dimension(struct snd_ctl_elem_info *info)
809 {
810 	unsigned int members;
811 	unsigned int i;
812 
813 	if (info->dimen.d[0] == 0)
814 		return true;
815 
816 	members = 1;
817 	for (i = 0; i < ARRAY_SIZE(info->dimen.d); ++i) {
818 		if (info->dimen.d[i] == 0)
819 			break;
820 		members *= info->dimen.d[i];
821 
822 		/*
823 		 * info->count should be validated in advance, to guarantee
824 		 * calculation soundness.
825 		 */
826 		if (members > info->count)
827 			return false;
828 	}
829 
830 	for (++i; i < ARRAY_SIZE(info->dimen.d); ++i) {
831 		if (info->dimen.d[i] > 0)
832 			return false;
833 	}
834 
835 	return members == info->count;
836 }
837 
838 static int snd_ctl_elem_info(struct snd_ctl_file *ctl,
839 			     struct snd_ctl_elem_info *info)
840 {
841 	struct snd_card *card = ctl->card;
842 	struct snd_kcontrol *kctl;
843 	struct snd_kcontrol_volatile *vd;
844 	unsigned int index_offset;
845 	int result;
846 
847 	down_read(&card->controls_rwsem);
848 	kctl = snd_ctl_find_id(card, &info->id);
849 	if (kctl == NULL) {
850 		up_read(&card->controls_rwsem);
851 		return -ENOENT;
852 	}
853 #ifdef CONFIG_SND_DEBUG
854 	info->access = 0;
855 #endif
856 	result = kctl->info(kctl, info);
857 	if (result >= 0) {
858 		snd_BUG_ON(info->access);
859 		index_offset = snd_ctl_get_ioff(kctl, &info->id);
860 		vd = &kctl->vd[index_offset];
861 		snd_ctl_build_ioff(&info->id, kctl, index_offset);
862 		info->access = vd->access;
863 		if (vd->owner) {
864 			info->access |= SNDRV_CTL_ELEM_ACCESS_LOCK;
865 			if (vd->owner == ctl)
866 				info->access |= SNDRV_CTL_ELEM_ACCESS_OWNER;
867 			info->owner = pid_vnr(vd->owner->pid);
868 		} else {
869 			info->owner = -1;
870 		}
871 	}
872 	up_read(&card->controls_rwsem);
873 	return result;
874 }
875 
876 static int snd_ctl_elem_info_user(struct snd_ctl_file *ctl,
877 				  struct snd_ctl_elem_info __user *_info)
878 {
879 	struct snd_ctl_elem_info info;
880 	int result;
881 
882 	if (copy_from_user(&info, _info, sizeof(info)))
883 		return -EFAULT;
884 	snd_power_lock(ctl->card);
885 	result = snd_power_wait(ctl->card, SNDRV_CTL_POWER_D0);
886 	if (result >= 0)
887 		result = snd_ctl_elem_info(ctl, &info);
888 	snd_power_unlock(ctl->card);
889 	if (result >= 0)
890 		if (copy_to_user(_info, &info, sizeof(info)))
891 			return -EFAULT;
892 	return result;
893 }
894 
895 static int snd_ctl_elem_read(struct snd_card *card,
896 			     struct snd_ctl_elem_value *control)
897 {
898 	struct snd_kcontrol *kctl;
899 	struct snd_kcontrol_volatile *vd;
900 	unsigned int index_offset;
901 	int result;
902 
903 	down_read(&card->controls_rwsem);
904 	kctl = snd_ctl_find_id(card, &control->id);
905 	if (kctl == NULL) {
906 		result = -ENOENT;
907 	} else {
908 		index_offset = snd_ctl_get_ioff(kctl, &control->id);
909 		vd = &kctl->vd[index_offset];
910 		if ((vd->access & SNDRV_CTL_ELEM_ACCESS_READ) &&
911 		    kctl->get != NULL) {
912 			snd_ctl_build_ioff(&control->id, kctl, index_offset);
913 			result = kctl->get(kctl, control);
914 		} else
915 			result = -EPERM;
916 	}
917 	up_read(&card->controls_rwsem);
918 	return result;
919 }
920 
921 static int snd_ctl_elem_read_user(struct snd_card *card,
922 				  struct snd_ctl_elem_value __user *_control)
923 {
924 	struct snd_ctl_elem_value *control;
925 	int result;
926 
927 	control = memdup_user(_control, sizeof(*control));
928 	if (IS_ERR(control))
929 		return PTR_ERR(control);
930 
931 	snd_power_lock(card);
932 	result = snd_power_wait(card, SNDRV_CTL_POWER_D0);
933 	if (result >= 0)
934 		result = snd_ctl_elem_read(card, control);
935 	snd_power_unlock(card);
936 	if (result >= 0)
937 		if (copy_to_user(_control, control, sizeof(*control)))
938 			result = -EFAULT;
939 	kfree(control);
940 	return result;
941 }
942 
943 static int snd_ctl_elem_write(struct snd_card *card, struct snd_ctl_file *file,
944 			      struct snd_ctl_elem_value *control)
945 {
946 	struct snd_kcontrol *kctl;
947 	struct snd_kcontrol_volatile *vd;
948 	unsigned int index_offset;
949 	int result;
950 
951 	down_read(&card->controls_rwsem);
952 	kctl = snd_ctl_find_id(card, &control->id);
953 	if (kctl == NULL) {
954 		result = -ENOENT;
955 	} else {
956 		index_offset = snd_ctl_get_ioff(kctl, &control->id);
957 		vd = &kctl->vd[index_offset];
958 		if (!(vd->access & SNDRV_CTL_ELEM_ACCESS_WRITE) ||
959 		    kctl->put == NULL ||
960 		    (file && vd->owner && vd->owner != file)) {
961 			result = -EPERM;
962 		} else {
963 			snd_ctl_build_ioff(&control->id, kctl, index_offset);
964 			result = kctl->put(kctl, control);
965 		}
966 		if (result > 0) {
967 			struct snd_ctl_elem_id id = control->id;
968 			up_read(&card->controls_rwsem);
969 			snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_VALUE, &id);
970 			return 0;
971 		}
972 	}
973 	up_read(&card->controls_rwsem);
974 	return result;
975 }
976 
977 static int snd_ctl_elem_write_user(struct snd_ctl_file *file,
978 				   struct snd_ctl_elem_value __user *_control)
979 {
980 	struct snd_ctl_elem_value *control;
981 	struct snd_card *card;
982 	int result;
983 
984 	control = memdup_user(_control, sizeof(*control));
985 	if (IS_ERR(control))
986 		return PTR_ERR(control);
987 
988 	card = file->card;
989 	snd_power_lock(card);
990 	result = snd_power_wait(card, SNDRV_CTL_POWER_D0);
991 	if (result >= 0)
992 		result = snd_ctl_elem_write(card, file, control);
993 	snd_power_unlock(card);
994 	if (result >= 0)
995 		if (copy_to_user(_control, control, sizeof(*control)))
996 			result = -EFAULT;
997 	kfree(control);
998 	return result;
999 }
1000 
1001 static int snd_ctl_elem_lock(struct snd_ctl_file *file,
1002 			     struct snd_ctl_elem_id __user *_id)
1003 {
1004 	struct snd_card *card = file->card;
1005 	struct snd_ctl_elem_id id;
1006 	struct snd_kcontrol *kctl;
1007 	struct snd_kcontrol_volatile *vd;
1008 	int result;
1009 
1010 	if (copy_from_user(&id, _id, sizeof(id)))
1011 		return -EFAULT;
1012 	down_write(&card->controls_rwsem);
1013 	kctl = snd_ctl_find_id(card, &id);
1014 	if (kctl == NULL) {
1015 		result = -ENOENT;
1016 	} else {
1017 		vd = &kctl->vd[snd_ctl_get_ioff(kctl, &id)];
1018 		if (vd->owner != NULL)
1019 			result = -EBUSY;
1020 		else {
1021 			vd->owner = file;
1022 			result = 0;
1023 		}
1024 	}
1025 	up_write(&card->controls_rwsem);
1026 	return result;
1027 }
1028 
1029 static int snd_ctl_elem_unlock(struct snd_ctl_file *file,
1030 			       struct snd_ctl_elem_id __user *_id)
1031 {
1032 	struct snd_card *card = file->card;
1033 	struct snd_ctl_elem_id id;
1034 	struct snd_kcontrol *kctl;
1035 	struct snd_kcontrol_volatile *vd;
1036 	int result;
1037 
1038 	if (copy_from_user(&id, _id, sizeof(id)))
1039 		return -EFAULT;
1040 	down_write(&card->controls_rwsem);
1041 	kctl = snd_ctl_find_id(card, &id);
1042 	if (kctl == NULL) {
1043 		result = -ENOENT;
1044 	} else {
1045 		vd = &kctl->vd[snd_ctl_get_ioff(kctl, &id)];
1046 		if (vd->owner == NULL)
1047 			result = -EINVAL;
1048 		else if (vd->owner != file)
1049 			result = -EPERM;
1050 		else {
1051 			vd->owner = NULL;
1052 			result = 0;
1053 		}
1054 	}
1055 	up_write(&card->controls_rwsem);
1056 	return result;
1057 }
1058 
1059 struct user_element {
1060 	struct snd_ctl_elem_info info;
1061 	struct snd_card *card;
1062 	char *elem_data;		/* element data */
1063 	unsigned long elem_data_size;	/* size of element data in bytes */
1064 	void *tlv_data;			/* TLV data */
1065 	unsigned long tlv_data_size;	/* TLV data size */
1066 	void *priv_data;		/* private data (like strings for enumerated type) */
1067 };
1068 
1069 static int snd_ctl_elem_user_info(struct snd_kcontrol *kcontrol,
1070 				  struct snd_ctl_elem_info *uinfo)
1071 {
1072 	struct user_element *ue = kcontrol->private_data;
1073 	unsigned int offset;
1074 
1075 	offset = snd_ctl_get_ioff(kcontrol, &uinfo->id);
1076 	*uinfo = ue->info;
1077 	snd_ctl_build_ioff(&uinfo->id, kcontrol, offset);
1078 
1079 	return 0;
1080 }
1081 
1082 static int snd_ctl_elem_user_enum_info(struct snd_kcontrol *kcontrol,
1083 				       struct snd_ctl_elem_info *uinfo)
1084 {
1085 	struct user_element *ue = kcontrol->private_data;
1086 	const char *names;
1087 	unsigned int item;
1088 	unsigned int offset;
1089 
1090 	item = uinfo->value.enumerated.item;
1091 
1092 	offset = snd_ctl_get_ioff(kcontrol, &uinfo->id);
1093 	*uinfo = ue->info;
1094 	snd_ctl_build_ioff(&uinfo->id, kcontrol, offset);
1095 
1096 	item = min(item, uinfo->value.enumerated.items - 1);
1097 	uinfo->value.enumerated.item = item;
1098 
1099 	names = ue->priv_data;
1100 	for (; item > 0; --item)
1101 		names += strlen(names) + 1;
1102 	strcpy(uinfo->value.enumerated.name, names);
1103 
1104 	return 0;
1105 }
1106 
1107 static int snd_ctl_elem_user_get(struct snd_kcontrol *kcontrol,
1108 				 struct snd_ctl_elem_value *ucontrol)
1109 {
1110 	struct user_element *ue = kcontrol->private_data;
1111 	unsigned int size = ue->elem_data_size;
1112 	char *src = ue->elem_data +
1113 			snd_ctl_get_ioff(kcontrol, &ucontrol->id) * size;
1114 
1115 	mutex_lock(&ue->card->user_ctl_lock);
1116 	memcpy(&ucontrol->value, src, size);
1117 	mutex_unlock(&ue->card->user_ctl_lock);
1118 	return 0;
1119 }
1120 
1121 static int snd_ctl_elem_user_put(struct snd_kcontrol *kcontrol,
1122 				 struct snd_ctl_elem_value *ucontrol)
1123 {
1124 	int change;
1125 	struct user_element *ue = kcontrol->private_data;
1126 	unsigned int size = ue->elem_data_size;
1127 	char *dst = ue->elem_data +
1128 			snd_ctl_get_ioff(kcontrol, &ucontrol->id) * size;
1129 
1130 	mutex_lock(&ue->card->user_ctl_lock);
1131 	change = memcmp(&ucontrol->value, dst, size) != 0;
1132 	if (change)
1133 		memcpy(dst, &ucontrol->value, size);
1134 	mutex_unlock(&ue->card->user_ctl_lock);
1135 	return change;
1136 }
1137 
1138 static int snd_ctl_elem_user_tlv(struct snd_kcontrol *kcontrol,
1139 				 int op_flag,
1140 				 unsigned int size,
1141 				 unsigned int __user *tlv)
1142 {
1143 	struct user_element *ue = kcontrol->private_data;
1144 	int change = 0;
1145 	void *new_data;
1146 
1147 	if (op_flag == SNDRV_CTL_TLV_OP_WRITE) {
1148 		if (size > 1024 * 128)	/* sane value */
1149 			return -EINVAL;
1150 
1151 		new_data = memdup_user(tlv, size);
1152 		if (IS_ERR(new_data))
1153 			return PTR_ERR(new_data);
1154 		mutex_lock(&ue->card->user_ctl_lock);
1155 		change = ue->tlv_data_size != size;
1156 		if (!change)
1157 			change = memcmp(ue->tlv_data, new_data, size);
1158 		kfree(ue->tlv_data);
1159 		ue->tlv_data = new_data;
1160 		ue->tlv_data_size = size;
1161 		mutex_unlock(&ue->card->user_ctl_lock);
1162 	} else {
1163 		int ret = 0;
1164 
1165 		mutex_lock(&ue->card->user_ctl_lock);
1166 		if (!ue->tlv_data_size || !ue->tlv_data) {
1167 			ret = -ENXIO;
1168 			goto err_unlock;
1169 		}
1170 		if (size < ue->tlv_data_size) {
1171 			ret = -ENOSPC;
1172 			goto err_unlock;
1173 		}
1174 		if (copy_to_user(tlv, ue->tlv_data, ue->tlv_data_size))
1175 			ret = -EFAULT;
1176 err_unlock:
1177 		mutex_unlock(&ue->card->user_ctl_lock);
1178 		if (ret)
1179 			return ret;
1180 	}
1181 	return change;
1182 }
1183 
1184 static int snd_ctl_elem_init_enum_names(struct user_element *ue)
1185 {
1186 	char *names, *p;
1187 	size_t buf_len, name_len;
1188 	unsigned int i;
1189 	const uintptr_t user_ptrval = ue->info.value.enumerated.names_ptr;
1190 
1191 	if (ue->info.value.enumerated.names_length > 64 * 1024)
1192 		return -EINVAL;
1193 
1194 	names = memdup_user((const void __user *)user_ptrval,
1195 		ue->info.value.enumerated.names_length);
1196 	if (IS_ERR(names))
1197 		return PTR_ERR(names);
1198 
1199 	/* check that there are enough valid names */
1200 	buf_len = ue->info.value.enumerated.names_length;
1201 	p = names;
1202 	for (i = 0; i < ue->info.value.enumerated.items; ++i) {
1203 		name_len = strnlen(p, buf_len);
1204 		if (name_len == 0 || name_len >= 64 || name_len == buf_len) {
1205 			kfree(names);
1206 			return -EINVAL;
1207 		}
1208 		p += name_len + 1;
1209 		buf_len -= name_len + 1;
1210 	}
1211 
1212 	ue->priv_data = names;
1213 	ue->info.value.enumerated.names_ptr = 0;
1214 
1215 	return 0;
1216 }
1217 
1218 static void snd_ctl_elem_user_free(struct snd_kcontrol *kcontrol)
1219 {
1220 	struct user_element *ue = kcontrol->private_data;
1221 
1222 	kfree(ue->tlv_data);
1223 	kfree(ue->priv_data);
1224 	kfree(ue);
1225 }
1226 
1227 static int snd_ctl_elem_add(struct snd_ctl_file *file,
1228 			    struct snd_ctl_elem_info *info, int replace)
1229 {
1230 	/* The capacity of struct snd_ctl_elem_value.value.*/
1231 	static const unsigned int value_sizes[] = {
1232 		[SNDRV_CTL_ELEM_TYPE_BOOLEAN]	= sizeof(long),
1233 		[SNDRV_CTL_ELEM_TYPE_INTEGER]	= sizeof(long),
1234 		[SNDRV_CTL_ELEM_TYPE_ENUMERATED] = sizeof(unsigned int),
1235 		[SNDRV_CTL_ELEM_TYPE_BYTES]	= sizeof(unsigned char),
1236 		[SNDRV_CTL_ELEM_TYPE_IEC958]	= sizeof(struct snd_aes_iec958),
1237 		[SNDRV_CTL_ELEM_TYPE_INTEGER64] = sizeof(long long),
1238 	};
1239 	static const unsigned int max_value_counts[] = {
1240 		[SNDRV_CTL_ELEM_TYPE_BOOLEAN]	= 128,
1241 		[SNDRV_CTL_ELEM_TYPE_INTEGER]	= 128,
1242 		[SNDRV_CTL_ELEM_TYPE_ENUMERATED] = 128,
1243 		[SNDRV_CTL_ELEM_TYPE_BYTES]	= 512,
1244 		[SNDRV_CTL_ELEM_TYPE_IEC958]	= 1,
1245 		[SNDRV_CTL_ELEM_TYPE_INTEGER64] = 64,
1246 	};
1247 	struct snd_card *card = file->card;
1248 	struct snd_kcontrol *kctl;
1249 	unsigned int count;
1250 	unsigned int access;
1251 	long private_size;
1252 	struct user_element *ue;
1253 	unsigned int offset;
1254 	int err;
1255 
1256 	if (!*info->id.name)
1257 		return -EINVAL;
1258 	if (strnlen(info->id.name, sizeof(info->id.name)) >= sizeof(info->id.name))
1259 		return -EINVAL;
1260 
1261 	/* Delete a control to replace them if needed. */
1262 	if (replace) {
1263 		info->id.numid = 0;
1264 		err = snd_ctl_remove_user_ctl(file, &info->id);
1265 		if (err)
1266 			return err;
1267 	}
1268 
1269 	/*
1270 	 * The number of userspace controls are counted control by control,
1271 	 * not element by element.
1272 	 */
1273 	if (card->user_ctl_count + 1 > MAX_USER_CONTROLS)
1274 		return -ENOMEM;
1275 
1276 	/* Check the number of elements for this userspace control. */
1277 	count = info->owner;
1278 	if (count == 0)
1279 		count = 1;
1280 
1281 	/* Arrange access permissions if needed. */
1282 	access = info->access;
1283 	if (access == 0)
1284 		access = SNDRV_CTL_ELEM_ACCESS_READWRITE;
1285 	access &= (SNDRV_CTL_ELEM_ACCESS_READWRITE |
1286 		   SNDRV_CTL_ELEM_ACCESS_INACTIVE |
1287 		   SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE);
1288 	if (access & SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE)
1289 		access |= SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK;
1290 	access |= SNDRV_CTL_ELEM_ACCESS_USER;
1291 
1292 	/*
1293 	 * Check information and calculate the size of data specific to
1294 	 * this userspace control.
1295 	 */
1296 	if (info->type < SNDRV_CTL_ELEM_TYPE_BOOLEAN ||
1297 	    info->type > SNDRV_CTL_ELEM_TYPE_INTEGER64)
1298 		return -EINVAL;
1299 	if (info->type == SNDRV_CTL_ELEM_TYPE_ENUMERATED &&
1300 	    info->value.enumerated.items == 0)
1301 		return -EINVAL;
1302 	if (info->count < 1 ||
1303 	    info->count > max_value_counts[info->type])
1304 		return -EINVAL;
1305 	if (!validate_element_member_dimension(info))
1306 		return -EINVAL;
1307 	private_size = value_sizes[info->type] * info->count;
1308 
1309 	/*
1310 	 * Keep memory object for this userspace control. After passing this
1311 	 * code block, the instance should be freed by snd_ctl_free_one().
1312 	 *
1313 	 * Note that these elements in this control are locked.
1314 	 */
1315 	err = snd_ctl_new(&kctl, count, access, file);
1316 	if (err < 0)
1317 		return err;
1318 	memcpy(&kctl->id, &info->id, sizeof(kctl->id));
1319 	kctl->private_data = kzalloc(sizeof(struct user_element) + private_size * count,
1320 				     GFP_KERNEL);
1321 	if (kctl->private_data == NULL) {
1322 		kfree(kctl);
1323 		return -ENOMEM;
1324 	}
1325 	kctl->private_free = snd_ctl_elem_user_free;
1326 
1327 	/* Set private data for this userspace control. */
1328 	ue = (struct user_element *)kctl->private_data;
1329 	ue->card = card;
1330 	ue->info = *info;
1331 	ue->info.access = 0;
1332 	ue->elem_data = (char *)ue + sizeof(*ue);
1333 	ue->elem_data_size = private_size;
1334 	if (ue->info.type == SNDRV_CTL_ELEM_TYPE_ENUMERATED) {
1335 		err = snd_ctl_elem_init_enum_names(ue);
1336 		if (err < 0) {
1337 			snd_ctl_free_one(kctl);
1338 			return err;
1339 		}
1340 	}
1341 
1342 	/* Set callback functions. */
1343 	if (info->type == SNDRV_CTL_ELEM_TYPE_ENUMERATED)
1344 		kctl->info = snd_ctl_elem_user_enum_info;
1345 	else
1346 		kctl->info = snd_ctl_elem_user_info;
1347 	if (access & SNDRV_CTL_ELEM_ACCESS_READ)
1348 		kctl->get = snd_ctl_elem_user_get;
1349 	if (access & SNDRV_CTL_ELEM_ACCESS_WRITE)
1350 		kctl->put = snd_ctl_elem_user_put;
1351 	if (access & SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE)
1352 		kctl->tlv.c = snd_ctl_elem_user_tlv;
1353 
1354 	/* This function manage to free the instance on failure. */
1355 	err = snd_ctl_add(card, kctl);
1356 	if (err < 0)
1357 		return err;
1358 	offset = snd_ctl_get_ioff(kctl, &info->id);
1359 	snd_ctl_build_ioff(&info->id, kctl, offset);
1360 	/*
1361 	 * Here we cannot fill any field for the number of elements added by
1362 	 * this operation because there're no specific fields. The usage of
1363 	 * 'owner' field for this purpose may cause any bugs to userspace
1364 	 * applications because the field originally means PID of a process
1365 	 * which locks the element.
1366 	 */
1367 
1368 	down_write(&card->controls_rwsem);
1369 	card->user_ctl_count++;
1370 	up_write(&card->controls_rwsem);
1371 
1372 	return 0;
1373 }
1374 
1375 static int snd_ctl_elem_add_user(struct snd_ctl_file *file,
1376 				 struct snd_ctl_elem_info __user *_info, int replace)
1377 {
1378 	struct snd_ctl_elem_info info;
1379 	int err;
1380 
1381 	if (copy_from_user(&info, _info, sizeof(info)))
1382 		return -EFAULT;
1383 	err = snd_ctl_elem_add(file, &info, replace);
1384 	if (err < 0)
1385 		return err;
1386 	if (copy_to_user(_info, &info, sizeof(info))) {
1387 		snd_ctl_remove_user_ctl(file, &info.id);
1388 		return -EFAULT;
1389 	}
1390 
1391 	return 0;
1392 }
1393 
1394 static int snd_ctl_elem_remove(struct snd_ctl_file *file,
1395 			       struct snd_ctl_elem_id __user *_id)
1396 {
1397 	struct snd_ctl_elem_id id;
1398 
1399 	if (copy_from_user(&id, _id, sizeof(id)))
1400 		return -EFAULT;
1401 	return snd_ctl_remove_user_ctl(file, &id);
1402 }
1403 
1404 static int snd_ctl_subscribe_events(struct snd_ctl_file *file, int __user *ptr)
1405 {
1406 	int subscribe;
1407 	if (get_user(subscribe, ptr))
1408 		return -EFAULT;
1409 	if (subscribe < 0) {
1410 		subscribe = file->subscribed;
1411 		if (put_user(subscribe, ptr))
1412 			return -EFAULT;
1413 		return 0;
1414 	}
1415 	if (subscribe) {
1416 		file->subscribed = 1;
1417 		return 0;
1418 	} else if (file->subscribed) {
1419 		snd_ctl_empty_read_queue(file);
1420 		file->subscribed = 0;
1421 	}
1422 	return 0;
1423 }
1424 
1425 static int snd_ctl_tlv_ioctl(struct snd_ctl_file *file,
1426                              struct snd_ctl_tlv __user *_tlv,
1427                              int op_flag)
1428 {
1429 	struct snd_card *card = file->card;
1430 	struct snd_ctl_tlv tlv;
1431 	struct snd_kcontrol *kctl;
1432 	struct snd_kcontrol_volatile *vd;
1433 	unsigned int len;
1434 	int err = 0;
1435 
1436 	if (copy_from_user(&tlv, _tlv, sizeof(tlv)))
1437 		return -EFAULT;
1438 	if (tlv.length < sizeof(unsigned int) * 2)
1439 		return -EINVAL;
1440 	if (!tlv.numid)
1441 		return -EINVAL;
1442 	down_read(&card->controls_rwsem);
1443 	kctl = snd_ctl_find_numid(card, tlv.numid);
1444 	if (kctl == NULL) {
1445 		err = -ENOENT;
1446 		goto __kctl_end;
1447 	}
1448 	if (kctl->tlv.p == NULL) {
1449 		err = -ENXIO;
1450 		goto __kctl_end;
1451 	}
1452 	vd = &kctl->vd[tlv.numid - kctl->id.numid];
1453 	if ((op_flag == SNDRV_CTL_TLV_OP_READ &&
1454 	     (vd->access & SNDRV_CTL_ELEM_ACCESS_TLV_READ) == 0) ||
1455 	    (op_flag == SNDRV_CTL_TLV_OP_WRITE &&
1456 	     (vd->access & SNDRV_CTL_ELEM_ACCESS_TLV_WRITE) == 0) ||
1457 	    (op_flag == SNDRV_CTL_TLV_OP_CMD &&
1458 	     (vd->access & SNDRV_CTL_ELEM_ACCESS_TLV_COMMAND) == 0)) {
1459 	    	err = -ENXIO;
1460 	    	goto __kctl_end;
1461 	}
1462 	if (vd->access & SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK) {
1463 		if (vd->owner != NULL && vd->owner != file) {
1464 			err = -EPERM;
1465 			goto __kctl_end;
1466 		}
1467 		err = kctl->tlv.c(kctl, op_flag, tlv.length, _tlv->tlv);
1468 		if (err > 0) {
1469 			struct snd_ctl_elem_id id = kctl->id;
1470 			up_read(&card->controls_rwsem);
1471 			snd_ctl_notify(card, SNDRV_CTL_EVENT_MASK_TLV, &id);
1472 			return 0;
1473 		}
1474 	} else {
1475 		if (op_flag != SNDRV_CTL_TLV_OP_READ) {
1476 			err = -ENXIO;
1477 			goto __kctl_end;
1478 		}
1479 		len = kctl->tlv.p[1] + 2 * sizeof(unsigned int);
1480 		if (tlv.length < len) {
1481 			err = -ENOMEM;
1482 			goto __kctl_end;
1483 		}
1484 		if (copy_to_user(_tlv->tlv, kctl->tlv.p, len))
1485 			err = -EFAULT;
1486 	}
1487       __kctl_end:
1488 	up_read(&card->controls_rwsem);
1489 	return err;
1490 }
1491 
1492 static long snd_ctl_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
1493 {
1494 	struct snd_ctl_file *ctl;
1495 	struct snd_card *card;
1496 	struct snd_kctl_ioctl *p;
1497 	void __user *argp = (void __user *)arg;
1498 	int __user *ip = argp;
1499 	int err;
1500 
1501 	ctl = file->private_data;
1502 	card = ctl->card;
1503 	if (snd_BUG_ON(!card))
1504 		return -ENXIO;
1505 	switch (cmd) {
1506 	case SNDRV_CTL_IOCTL_PVERSION:
1507 		return put_user(SNDRV_CTL_VERSION, ip) ? -EFAULT : 0;
1508 	case SNDRV_CTL_IOCTL_CARD_INFO:
1509 		return snd_ctl_card_info(card, ctl, cmd, argp);
1510 	case SNDRV_CTL_IOCTL_ELEM_LIST:
1511 		return snd_ctl_elem_list(card, argp);
1512 	case SNDRV_CTL_IOCTL_ELEM_INFO:
1513 		return snd_ctl_elem_info_user(ctl, argp);
1514 	case SNDRV_CTL_IOCTL_ELEM_READ:
1515 		return snd_ctl_elem_read_user(card, argp);
1516 	case SNDRV_CTL_IOCTL_ELEM_WRITE:
1517 		return snd_ctl_elem_write_user(ctl, argp);
1518 	case SNDRV_CTL_IOCTL_ELEM_LOCK:
1519 		return snd_ctl_elem_lock(ctl, argp);
1520 	case SNDRV_CTL_IOCTL_ELEM_UNLOCK:
1521 		return snd_ctl_elem_unlock(ctl, argp);
1522 	case SNDRV_CTL_IOCTL_ELEM_ADD:
1523 		return snd_ctl_elem_add_user(ctl, argp, 0);
1524 	case SNDRV_CTL_IOCTL_ELEM_REPLACE:
1525 		return snd_ctl_elem_add_user(ctl, argp, 1);
1526 	case SNDRV_CTL_IOCTL_ELEM_REMOVE:
1527 		return snd_ctl_elem_remove(ctl, argp);
1528 	case SNDRV_CTL_IOCTL_SUBSCRIBE_EVENTS:
1529 		return snd_ctl_subscribe_events(ctl, ip);
1530 	case SNDRV_CTL_IOCTL_TLV_READ:
1531 		return snd_ctl_tlv_ioctl(ctl, argp, SNDRV_CTL_TLV_OP_READ);
1532 	case SNDRV_CTL_IOCTL_TLV_WRITE:
1533 		return snd_ctl_tlv_ioctl(ctl, argp, SNDRV_CTL_TLV_OP_WRITE);
1534 	case SNDRV_CTL_IOCTL_TLV_COMMAND:
1535 		return snd_ctl_tlv_ioctl(ctl, argp, SNDRV_CTL_TLV_OP_CMD);
1536 	case SNDRV_CTL_IOCTL_POWER:
1537 		return -ENOPROTOOPT;
1538 	case SNDRV_CTL_IOCTL_POWER_STATE:
1539 #ifdef CONFIG_PM
1540 		return put_user(card->power_state, ip) ? -EFAULT : 0;
1541 #else
1542 		return put_user(SNDRV_CTL_POWER_D0, ip) ? -EFAULT : 0;
1543 #endif
1544 	}
1545 	down_read(&snd_ioctl_rwsem);
1546 	list_for_each_entry(p, &snd_control_ioctls, list) {
1547 		err = p->fioctl(card, ctl, cmd, arg);
1548 		if (err != -ENOIOCTLCMD) {
1549 			up_read(&snd_ioctl_rwsem);
1550 			return err;
1551 		}
1552 	}
1553 	up_read(&snd_ioctl_rwsem);
1554 	dev_dbg(card->dev, "unknown ioctl = 0x%x\n", cmd);
1555 	return -ENOTTY;
1556 }
1557 
1558 static ssize_t snd_ctl_read(struct file *file, char __user *buffer,
1559 			    size_t count, loff_t * offset)
1560 {
1561 	struct snd_ctl_file *ctl;
1562 	int err = 0;
1563 	ssize_t result = 0;
1564 
1565 	ctl = file->private_data;
1566 	if (snd_BUG_ON(!ctl || !ctl->card))
1567 		return -ENXIO;
1568 	if (!ctl->subscribed)
1569 		return -EBADFD;
1570 	if (count < sizeof(struct snd_ctl_event))
1571 		return -EINVAL;
1572 	spin_lock_irq(&ctl->read_lock);
1573 	while (count >= sizeof(struct snd_ctl_event)) {
1574 		struct snd_ctl_event ev;
1575 		struct snd_kctl_event *kev;
1576 		while (list_empty(&ctl->events)) {
1577 			wait_queue_t wait;
1578 			if ((file->f_flags & O_NONBLOCK) != 0 || result > 0) {
1579 				err = -EAGAIN;
1580 				goto __end_lock;
1581 			}
1582 			init_waitqueue_entry(&wait, current);
1583 			add_wait_queue(&ctl->change_sleep, &wait);
1584 			set_current_state(TASK_INTERRUPTIBLE);
1585 			spin_unlock_irq(&ctl->read_lock);
1586 			schedule();
1587 			remove_wait_queue(&ctl->change_sleep, &wait);
1588 			if (ctl->card->shutdown)
1589 				return -ENODEV;
1590 			if (signal_pending(current))
1591 				return -ERESTARTSYS;
1592 			spin_lock_irq(&ctl->read_lock);
1593 		}
1594 		kev = snd_kctl_event(ctl->events.next);
1595 		ev.type = SNDRV_CTL_EVENT_ELEM;
1596 		ev.data.elem.mask = kev->mask;
1597 		ev.data.elem.id = kev->id;
1598 		list_del(&kev->list);
1599 		spin_unlock_irq(&ctl->read_lock);
1600 		kfree(kev);
1601 		if (copy_to_user(buffer, &ev, sizeof(struct snd_ctl_event))) {
1602 			err = -EFAULT;
1603 			goto __end;
1604 		}
1605 		spin_lock_irq(&ctl->read_lock);
1606 		buffer += sizeof(struct snd_ctl_event);
1607 		count -= sizeof(struct snd_ctl_event);
1608 		result += sizeof(struct snd_ctl_event);
1609 	}
1610       __end_lock:
1611 	spin_unlock_irq(&ctl->read_lock);
1612       __end:
1613       	return result > 0 ? result : err;
1614 }
1615 
1616 static unsigned int snd_ctl_poll(struct file *file, poll_table * wait)
1617 {
1618 	unsigned int mask;
1619 	struct snd_ctl_file *ctl;
1620 
1621 	ctl = file->private_data;
1622 	if (!ctl->subscribed)
1623 		return 0;
1624 	poll_wait(file, &ctl->change_sleep, wait);
1625 
1626 	mask = 0;
1627 	if (!list_empty(&ctl->events))
1628 		mask |= POLLIN | POLLRDNORM;
1629 
1630 	return mask;
1631 }
1632 
1633 /*
1634  * register the device-specific control-ioctls.
1635  * called from each device manager like pcm.c, hwdep.c, etc.
1636  */
1637 static int _snd_ctl_register_ioctl(snd_kctl_ioctl_func_t fcn, struct list_head *lists)
1638 {
1639 	struct snd_kctl_ioctl *pn;
1640 
1641 	pn = kzalloc(sizeof(struct snd_kctl_ioctl), GFP_KERNEL);
1642 	if (pn == NULL)
1643 		return -ENOMEM;
1644 	pn->fioctl = fcn;
1645 	down_write(&snd_ioctl_rwsem);
1646 	list_add_tail(&pn->list, lists);
1647 	up_write(&snd_ioctl_rwsem);
1648 	return 0;
1649 }
1650 
1651 /**
1652  * snd_ctl_register_ioctl - register the device-specific control-ioctls
1653  * @fcn: ioctl callback function
1654  *
1655  * called from each device manager like pcm.c, hwdep.c, etc.
1656  */
1657 int snd_ctl_register_ioctl(snd_kctl_ioctl_func_t fcn)
1658 {
1659 	return _snd_ctl_register_ioctl(fcn, &snd_control_ioctls);
1660 }
1661 EXPORT_SYMBOL(snd_ctl_register_ioctl);
1662 
1663 #ifdef CONFIG_COMPAT
1664 /**
1665  * snd_ctl_register_ioctl_compat - register the device-specific 32bit compat
1666  * control-ioctls
1667  * @fcn: ioctl callback function
1668  */
1669 int snd_ctl_register_ioctl_compat(snd_kctl_ioctl_func_t fcn)
1670 {
1671 	return _snd_ctl_register_ioctl(fcn, &snd_control_compat_ioctls);
1672 }
1673 EXPORT_SYMBOL(snd_ctl_register_ioctl_compat);
1674 #endif
1675 
1676 /*
1677  * de-register the device-specific control-ioctls.
1678  */
1679 static int _snd_ctl_unregister_ioctl(snd_kctl_ioctl_func_t fcn,
1680 				     struct list_head *lists)
1681 {
1682 	struct snd_kctl_ioctl *p;
1683 
1684 	if (snd_BUG_ON(!fcn))
1685 		return -EINVAL;
1686 	down_write(&snd_ioctl_rwsem);
1687 	list_for_each_entry(p, lists, list) {
1688 		if (p->fioctl == fcn) {
1689 			list_del(&p->list);
1690 			up_write(&snd_ioctl_rwsem);
1691 			kfree(p);
1692 			return 0;
1693 		}
1694 	}
1695 	up_write(&snd_ioctl_rwsem);
1696 	snd_BUG();
1697 	return -EINVAL;
1698 }
1699 
1700 /**
1701  * snd_ctl_unregister_ioctl - de-register the device-specific control-ioctls
1702  * @fcn: ioctl callback function to unregister
1703  */
1704 int snd_ctl_unregister_ioctl(snd_kctl_ioctl_func_t fcn)
1705 {
1706 	return _snd_ctl_unregister_ioctl(fcn, &snd_control_ioctls);
1707 }
1708 EXPORT_SYMBOL(snd_ctl_unregister_ioctl);
1709 
1710 #ifdef CONFIG_COMPAT
1711 /**
1712  * snd_ctl_unregister_ioctl - de-register the device-specific compat 32bit
1713  * control-ioctls
1714  * @fcn: ioctl callback function to unregister
1715  */
1716 int snd_ctl_unregister_ioctl_compat(snd_kctl_ioctl_func_t fcn)
1717 {
1718 	return _snd_ctl_unregister_ioctl(fcn, &snd_control_compat_ioctls);
1719 }
1720 EXPORT_SYMBOL(snd_ctl_unregister_ioctl_compat);
1721 #endif
1722 
1723 static int snd_ctl_fasync(int fd, struct file * file, int on)
1724 {
1725 	struct snd_ctl_file *ctl;
1726 
1727 	ctl = file->private_data;
1728 	return fasync_helper(fd, file, on, &ctl->fasync);
1729 }
1730 
1731 /* return the preferred subdevice number if already assigned;
1732  * otherwise return -1
1733  */
1734 int snd_ctl_get_preferred_subdevice(struct snd_card *card, int type)
1735 {
1736 	struct snd_ctl_file *kctl;
1737 	int subdevice = -1;
1738 
1739 	read_lock(&card->ctl_files_rwlock);
1740 	list_for_each_entry(kctl, &card->ctl_files, list) {
1741 		if (kctl->pid == task_pid(current)) {
1742 			subdevice = kctl->preferred_subdevice[type];
1743 			if (subdevice != -1)
1744 				break;
1745 		}
1746 	}
1747 	read_unlock(&card->ctl_files_rwlock);
1748 	return subdevice;
1749 }
1750 EXPORT_SYMBOL_GPL(snd_ctl_get_preferred_subdevice);
1751 
1752 /*
1753  * ioctl32 compat
1754  */
1755 #ifdef CONFIG_COMPAT
1756 #include "control_compat.c"
1757 #else
1758 #define snd_ctl_ioctl_compat	NULL
1759 #endif
1760 
1761 /*
1762  *  INIT PART
1763  */
1764 
1765 static const struct file_operations snd_ctl_f_ops =
1766 {
1767 	.owner =	THIS_MODULE,
1768 	.read =		snd_ctl_read,
1769 	.open =		snd_ctl_open,
1770 	.release =	snd_ctl_release,
1771 	.llseek =	no_llseek,
1772 	.poll =		snd_ctl_poll,
1773 	.unlocked_ioctl =	snd_ctl_ioctl,
1774 	.compat_ioctl =	snd_ctl_ioctl_compat,
1775 	.fasync =	snd_ctl_fasync,
1776 };
1777 
1778 /*
1779  * registration of the control device
1780  */
1781 static int snd_ctl_dev_register(struct snd_device *device)
1782 {
1783 	struct snd_card *card = device->device_data;
1784 
1785 	return snd_register_device(SNDRV_DEVICE_TYPE_CONTROL, card, -1,
1786 				   &snd_ctl_f_ops, card, &card->ctl_dev);
1787 }
1788 
1789 /*
1790  * disconnection of the control device
1791  */
1792 static int snd_ctl_dev_disconnect(struct snd_device *device)
1793 {
1794 	struct snd_card *card = device->device_data;
1795 	struct snd_ctl_file *ctl;
1796 
1797 	read_lock(&card->ctl_files_rwlock);
1798 	list_for_each_entry(ctl, &card->ctl_files, list) {
1799 		wake_up(&ctl->change_sleep);
1800 		kill_fasync(&ctl->fasync, SIGIO, POLL_ERR);
1801 	}
1802 	read_unlock(&card->ctl_files_rwlock);
1803 
1804 	return snd_unregister_device(&card->ctl_dev);
1805 }
1806 
1807 /*
1808  * free all controls
1809  */
1810 static int snd_ctl_dev_free(struct snd_device *device)
1811 {
1812 	struct snd_card *card = device->device_data;
1813 	struct snd_kcontrol *control;
1814 
1815 	down_write(&card->controls_rwsem);
1816 	while (!list_empty(&card->controls)) {
1817 		control = snd_kcontrol(card->controls.next);
1818 		snd_ctl_remove(card, control);
1819 	}
1820 	up_write(&card->controls_rwsem);
1821 	put_device(&card->ctl_dev);
1822 	return 0;
1823 }
1824 
1825 /*
1826  * create control core:
1827  * called from init.c
1828  */
1829 int snd_ctl_create(struct snd_card *card)
1830 {
1831 	static struct snd_device_ops ops = {
1832 		.dev_free = snd_ctl_dev_free,
1833 		.dev_register =	snd_ctl_dev_register,
1834 		.dev_disconnect = snd_ctl_dev_disconnect,
1835 	};
1836 	int err;
1837 
1838 	if (snd_BUG_ON(!card))
1839 		return -ENXIO;
1840 	if (snd_BUG_ON(card->number < 0 || card->number >= SNDRV_CARDS))
1841 		return -ENXIO;
1842 
1843 	snd_device_initialize(&card->ctl_dev, card);
1844 	dev_set_name(&card->ctl_dev, "controlC%d", card->number);
1845 
1846 	err = snd_device_new(card, SNDRV_DEV_CONTROL, card, &ops);
1847 	if (err < 0)
1848 		put_device(&card->ctl_dev);
1849 	return err;
1850 }
1851 
1852 /*
1853  * Frequently used control callbacks/helpers
1854  */
1855 
1856 /**
1857  * snd_ctl_boolean_mono_info - Helper function for a standard boolean info
1858  * callback with a mono channel
1859  * @kcontrol: the kcontrol instance
1860  * @uinfo: info to store
1861  *
1862  * This is a function that can be used as info callback for a standard
1863  * boolean control with a single mono channel.
1864  */
1865 int snd_ctl_boolean_mono_info(struct snd_kcontrol *kcontrol,
1866 			      struct snd_ctl_elem_info *uinfo)
1867 {
1868 	uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1869 	uinfo->count = 1;
1870 	uinfo->value.integer.min = 0;
1871 	uinfo->value.integer.max = 1;
1872 	return 0;
1873 }
1874 EXPORT_SYMBOL(snd_ctl_boolean_mono_info);
1875 
1876 /**
1877  * snd_ctl_boolean_stereo_info - Helper function for a standard boolean info
1878  * callback with stereo two channels
1879  * @kcontrol: the kcontrol instance
1880  * @uinfo: info to store
1881  *
1882  * This is a function that can be used as info callback for a standard
1883  * boolean control with stereo two channels.
1884  */
1885 int snd_ctl_boolean_stereo_info(struct snd_kcontrol *kcontrol,
1886 				struct snd_ctl_elem_info *uinfo)
1887 {
1888 	uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1889 	uinfo->count = 2;
1890 	uinfo->value.integer.min = 0;
1891 	uinfo->value.integer.max = 1;
1892 	return 0;
1893 }
1894 EXPORT_SYMBOL(snd_ctl_boolean_stereo_info);
1895 
1896 /**
1897  * snd_ctl_enum_info - fills the info structure for an enumerated control
1898  * @info: the structure to be filled
1899  * @channels: the number of the control's channels; often one
1900  * @items: the number of control values; also the size of @names
1901  * @names: an array containing the names of all control values
1902  *
1903  * Sets all required fields in @info to their appropriate values.
1904  * If the control's accessibility is not the default (readable and writable),
1905  * the caller has to fill @info->access.
1906  *
1907  * Return: Zero.
1908  */
1909 int snd_ctl_enum_info(struct snd_ctl_elem_info *info, unsigned int channels,
1910 		      unsigned int items, const char *const names[])
1911 {
1912 	info->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1913 	info->count = channels;
1914 	info->value.enumerated.items = items;
1915 	if (!items)
1916 		return 0;
1917 	if (info->value.enumerated.item >= items)
1918 		info->value.enumerated.item = items - 1;
1919 	WARN(strlen(names[info->value.enumerated.item]) >= sizeof(info->value.enumerated.name),
1920 	     "ALSA: too long item name '%s'\n",
1921 	     names[info->value.enumerated.item]);
1922 	strlcpy(info->value.enumerated.name,
1923 		names[info->value.enumerated.item],
1924 		sizeof(info->value.enumerated.name));
1925 	return 0;
1926 }
1927 EXPORT_SYMBOL(snd_ctl_enum_info);
1928