summaryrefslogtreecommitdiffstats
path: root/alsa-lib/src/control/control.c
diff options
context:
space:
mode:
Diffstat (limited to 'alsa-lib/src/control/control.c')
-rw-r--r--alsa-lib/src/control/control.c2585
1 files changed, 0 insertions, 2585 deletions
diff --git a/alsa-lib/src/control/control.c b/alsa-lib/src/control/control.c
deleted file mode 100644
index c090797..0000000
--- a/alsa-lib/src/control/control.c
+++ /dev/null
@@ -1,2585 +0,0 @@
-/**
- * \file control/control.c
- * \brief CTL interface - primitive controls
- * \author Abramo Bagnara <abramo@alsa-project.org>
- * \date 2000
- *
- * CTL interface is designed to access primitive controls.
- * See \ref control page for more details.
- */
-/*
- * Control Interface - main file
- * Copyright (c) 2000 by Abramo Bagnara <abramo@alsa-project.org>
- *
- *
- * This library is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as
- * published by the Free Software Foundation; either version 2.1 of
- * the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *
- */
-
-/*! \page control Control interface
-
-<P>Control interface is designed to access primitive controls. There is
-also interface notifying about control and structure changes.
-
-\section control_general_overview General overview
-
-The primitive controls can be integer, boolean, enumerators, bytes
-and IEC958 structure.
-
-*/
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <stdarg.h>
-#include <unistd.h>
-#include <string.h>
-#include <fcntl.h>
-#include <signal.h>
-#include <sys/poll.h>
-#include "control_local.h"
-
-/**
- * \brief get identifier of CTL handle
- * \param ctl CTL handle
- * \return ascii identifier of CTL handle
- *
- * Returns the ASCII identifier of given CTL handle. It's the same
- * identifier specified in snd_ctl_open().
- */
-const char *snd_ctl_name(snd_ctl_t *ctl)
-{
- assert(ctl);
- return ctl->name;
-}
-
-/**
- * \brief get type of CTL handle
- * \param ctl CTL handle
- * \return type of CTL handle
- *
- * Returns the type #snd_ctl_type_t of given CTL handle.
- */
-snd_ctl_type_t snd_ctl_type(snd_ctl_t *ctl)
-{
- assert(ctl);
- return ctl->type;
-}
-
-/**
- * \brief close CTL handle
- * \param ctl CTL handle
- * \return 0 on success otherwise a negative error code
- *
- * Closes the specified CTL handle and frees all associated
- * resources.
- */
-int snd_ctl_close(snd_ctl_t *ctl)
-{
- int err;
- while (!list_empty(&ctl->async_handlers)) {
- snd_async_handler_t *h = list_entry(&ctl->async_handlers.next, snd_async_handler_t, hlist);
- snd_async_del_handler(h);
- }
- err = ctl->ops->close(ctl);
- free(ctl->name);
- if (ctl->dl_handle)
- snd_dlclose(ctl->dl_handle);
- free(ctl);
- return err;
-}
-
-/**
- * \brief set nonblock mode
- * \param ctl CTL handle
- * \param nonblock 0 = block, 1 = nonblock mode
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_nonblock(snd_ctl_t *ctl, int nonblock)
-{
- int err;
- assert(ctl);
- err = ctl->ops->nonblock(ctl, nonblock);
- if (err < 0)
- return err;
- ctl->nonblock = nonblock;
- return 0;
-}
-
-#ifndef DOC_HIDDEN
-int snd_ctl_new(snd_ctl_t **ctlp, snd_ctl_type_t type, const char *name)
-{
- snd_ctl_t *ctl;
- ctl = calloc(1, sizeof(*ctl));
- if (!ctl)
- return -ENOMEM;
- ctl->type = type;
- if (name)
- ctl->name = strdup(name);
- INIT_LIST_HEAD(&ctl->async_handlers);
- *ctlp = ctl;
- return 0;
-}
-
-
-/**
- * \brief set async mode
- * \param ctl CTL handle
- * \param sig Signal to raise: < 0 disable, 0 default (SIGIO)
- * \param pid Process ID to signal: 0 current
- * \return 0 on success otherwise a negative error code
- *
- * A signal is raised when a change happens.
- */
-int snd_ctl_async(snd_ctl_t *ctl, int sig, pid_t pid)
-{
- assert(ctl);
- if (sig == 0)
- sig = SIGIO;
- if (pid == 0)
- pid = getpid();
- return ctl->ops->async(ctl, sig, pid);
-}
-#endif
-
-/**
- * \brief get count of poll descriptors for CTL handle
- * \param ctl CTL handle
- * \return count of poll descriptors
- */
-int snd_ctl_poll_descriptors_count(snd_ctl_t *ctl)
-{
- assert(ctl);
- if (ctl->ops->poll_descriptors_count)
- return ctl->ops->poll_descriptors_count(ctl);
- if (ctl->poll_fd < 0)
- return 0;
- return 1;
-}
-
-/**
- * \brief get poll descriptors
- * \param ctl CTL handle
- * \param pfds array of poll descriptors
- * \param space space in the poll descriptor array
- * \return count of filled descriptors
- */
-int snd_ctl_poll_descriptors(snd_ctl_t *ctl, struct pollfd *pfds, unsigned int space)
-{
- assert(ctl && pfds);
- if (ctl->ops->poll_descriptors)
- return ctl->ops->poll_descriptors(ctl, pfds, space);
- if (ctl->poll_fd < 0)
- return 0;
- if (space > 0) {
- pfds->fd = ctl->poll_fd;
- pfds->events = POLLIN|POLLERR|POLLNVAL;
- return 1;
- }
- return 0;
-}
-
-/**
- * \brief get returned events from poll descriptors
- * \param ctl CTL handle
- * \param pfds array of poll descriptors
- * \param nfds count of poll descriptors
- * \param revents returned events
- * \return zero if success, otherwise a negative error code
- */
-int snd_ctl_poll_descriptors_revents(snd_ctl_t *ctl, struct pollfd *pfds, unsigned int nfds, unsigned short *revents)
-{
- assert(ctl && pfds && revents);
- if (ctl->ops->poll_revents)
- return ctl->ops->poll_revents(ctl, pfds, nfds, revents);
- if (nfds == 1) {
- *revents = pfds->revents;
- return 0;
- }
- return -EINVAL;
-}
-
-/**
- * \brief Ask to be informed about events (poll, #snd_ctl_async, #snd_ctl_read)
- * \param ctl CTL handle
- * \param subscribe 0 = unsubscribe, 1 = subscribe
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_subscribe_events(snd_ctl_t *ctl, int subscribe)
-{
- assert(ctl);
- return ctl->ops->subscribe_events(ctl, subscribe);
-}
-
-
-/**
- * \brief Get card related information
- * \param ctl CTL handle
- * \param info Card info pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_card_info(snd_ctl_t *ctl, snd_ctl_card_info_t *info)
-{
- assert(ctl && info);
- return ctl->ops->card_info(ctl, info);
-}
-
-/**
- * \brief Get a list of element identifiers
- * \param ctl CTL handle
- * \param list CTL element identifiers list pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_list(snd_ctl_t *ctl, snd_ctl_elem_list_t *list)
-{
- assert(ctl && list);
- assert(list->space == 0 || list->pids);
- return ctl->ops->element_list(ctl, list);
-}
-
-/**
- * \brief Get CTL element information
- * \param ctl CTL handle
- * \param info CTL element id/information pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_info(snd_ctl_t *ctl, snd_ctl_elem_info_t *info)
-{
- assert(ctl && info && (info->id.name[0] || info->id.numid));
- return ctl->ops->element_info(ctl, info);
-}
-
-/**
- * \brief Create and add an user INTEGER CTL element
- * \param ctl CTL handle
- * \param id CTL element id to add
- * \param count number of elements
- * \param min minimum value
- * \param max maximum value
- * \param step value step
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_add_integer(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- unsigned int count, long min, long max, long step)
-{
- snd_ctl_elem_info_t *info;
- snd_ctl_elem_value_t *val;
- unsigned int i;
- int err;
-
- assert(ctl && id && id->name[0]);
- snd_ctl_elem_info_alloca(&info);
- info->id = *id;
- info->type = SND_CTL_ELEM_TYPE_INTEGER;
- info->access = SNDRV_CTL_ELEM_ACCESS_READWRITE |
- SNDRV_CTL_ELEM_ACCESS_TLV_READWRITE;
- info->count = count;
- info->value.integer.min = min;
- info->value.integer.max = max;
- info->value.integer.step = step;
- err = ctl->ops->element_add(ctl, info);
- if (err < 0)
- return err;
- snd_ctl_elem_value_alloca(&val);
- val->id = *id;
- for (i = 0; i < count; i++)
- val->value.integer.value[i] = min;
- err = ctl->ops->element_write(ctl, val);
- return err;
-}
-
-/**
- * \brief Create and add an user INTEGER64 CTL element
- * \param ctl CTL handle
- * \param id CTL element id to add
- * \param count number of elements
- * \param min minimum value
- * \param max maximum value
- * \param step value step
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_add_integer64(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- unsigned int count, long long min, long long max,
- long long step)
-{
- snd_ctl_elem_info_t *info;
- snd_ctl_elem_value_t *val;
- unsigned int i;
- int err;
-
- assert(ctl && id && id->name[0]);
- snd_ctl_elem_info_alloca(&info);
- info->id = *id;
- info->type = SND_CTL_ELEM_TYPE_INTEGER64;
- info->count = count;
- info->value.integer64.min = min;
- info->value.integer64.max = max;
- info->value.integer64.step = step;
- err = ctl->ops->element_add(ctl, info);
- if (err < 0)
- return err;
- snd_ctl_elem_value_alloca(&val);
- val->id = *id;
- for (i = 0; i < count; i++)
- val->value.integer64.value[i] = min;
- err = ctl->ops->element_write(ctl, val);
- return err;
-}
-
-/**
- * \brief Create and add an user BOOLEAN CTL element
- * \param ctl CTL handle
- * \param id CTL element id to add
- * \param count number of elements
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_add_boolean(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- unsigned int count)
-{
- snd_ctl_elem_info_t *info;
-
- assert(ctl && id && id->name[0]);
- snd_ctl_elem_info_alloca(&info);
- info->id = *id;
- info->type = SND_CTL_ELEM_TYPE_BOOLEAN;
- info->count = count;
- info->value.integer.min = 0;
- info->value.integer.max = 1;
- return ctl->ops->element_add(ctl, info);
-}
-
-/**
- * \brief Create and add an user IEC958 CTL element
- * \param ctl CTL handle
- * \param id CTL element info to add
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_add_iec958(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id)
-{
- snd_ctl_elem_info_t *info;
-
- assert(ctl && id && id->name[0]);
- snd_ctl_elem_info_alloca(&info);
- info->id = *id;
- info->type = SND_CTL_ELEM_TYPE_IEC958;
- info->count = 1;
- return ctl->ops->element_add(ctl, info);
-}
-
-/**
- * \brief Remove an user CTL element
- * \param ctl CTL handle
- * \param id CTL element identification
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_remove(snd_ctl_t *ctl, snd_ctl_elem_id_t *id)
-{
- assert(ctl && id && (id->name[0] || id->numid));
- return ctl->ops->element_remove(ctl, id);
-}
-
-/**
- * \brief Get CTL element value
- * \param ctl CTL handle
- * \param control CTL element id/value pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_read(snd_ctl_t *ctl, snd_ctl_elem_value_t *control)
-{
- assert(ctl && control && (control->id.name[0] || control->id.numid));
- return ctl->ops->element_read(ctl, control);
-}
-
-/**
- * \brief Set CTL element value
- * \param ctl CTL handle
- * \param control CTL element id/value pointer
- * \retval 0 on success
- * \retval >0 on success when value was changed
- * \retval <0 a negative error code
- */
-int snd_ctl_elem_write(snd_ctl_t *ctl, snd_ctl_elem_value_t *control)
-{
- assert(ctl && control && (control->id.name[0] || control->id.numid));
- return ctl->ops->element_write(ctl, control);
-}
-
-static int snd_ctl_tlv_do(snd_ctl_t *ctl, int op_flag,
- const snd_ctl_elem_id_t *id,
- unsigned int *tlv, unsigned int tlv_size)
-{
- snd_ctl_elem_info_t *info = NULL;
- int err;
-
- if (id->numid == 0) {
- info = calloc(1, sizeof(*info));
- if (info == NULL)
- return -ENOMEM;
- info->id = *id;
- id = &info->id;
- err = snd_ctl_elem_info(ctl, info);
- if (err < 0)
- goto __err;
- if (id->numid == 0) {
- err = -ENOENT;
- goto __err;
- }
- }
- err = ctl->ops->element_tlv(ctl, op_flag, id->numid, tlv, tlv_size);
- __err:
- if (info)
- free(info);
- return err;
-}
-
-
-
-/**
- * \brief Get CTL element TLV value
- * \param ctl CTL handle
- * \param id CTL element id pointer
- * \param tlv TLV array pointer to store
- * \param tlv_size TLV array size in bytes
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_tlv_read(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- unsigned int *tlv, unsigned int tlv_size)
-{
- int err;
- assert(ctl && id && (id->name[0] || id->numid) && tlv);
- if (tlv_size < 2 * sizeof(int))
- return -EINVAL;
- /* 1.0.12 driver doesn't return the error even if the user TLV
- * is empty. So, initialize TLV here with an invalid type
- * and compare the returned value after ioctl for checking
- * the validity of TLV.
- */
- tlv[0] = -1;
- tlv[1] = 0;
- err = snd_ctl_tlv_do(ctl, 0, id, tlv, tlv_size);
- if (err >= 0 && tlv[0] == (unsigned int)-1)
- err = -ENXIO;
- return err;
-}
-
-/**
- * \brief Set CTL element TLV value
- * \param ctl CTL handle
- * \param id CTL element id pointer
- * \param tlv TLV array pointer to store
- * \retval 0 on success
- * \retval >0 on success when value was changed
- * \retval <0 a negative error code
- */
-int snd_ctl_elem_tlv_write(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- const unsigned int *tlv)
-{
- assert(ctl && id && (id->name[0] || id->numid) && tlv);
- return snd_ctl_tlv_do(ctl, 1, id, (unsigned int *)tlv, tlv[1] + 2 * sizeof(unsigned int));
-}
-
-/**
- * \brief Process CTL element TLV command
- * \param ctl CTL handle
- * \param id CTL element id pointer
- * \param tlv TLV array pointer to process
- * \retval 0 on success
- * \retval >0 on success when value was changed
- * \retval <0 a negative error code
- */
-int snd_ctl_elem_tlv_command(snd_ctl_t *ctl, const snd_ctl_elem_id_t *id,
- const unsigned int *tlv)
-{
- assert(ctl && id && (id->name[0] || id->numid) && tlv);
- return snd_ctl_tlv_do(ctl, -1, id, (unsigned int *)tlv, tlv[1] + 2 * sizeof(unsigned int));
-}
-
-/**
- * \brief Lock CTL element
- * \param ctl CTL handle
- * \param id CTL element id pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_lock(snd_ctl_t *ctl, snd_ctl_elem_id_t *id)
-{
- assert(ctl && id);
- return ctl->ops->element_lock(ctl, id);
-}
-
-/**
- * \brief Unlock CTL element
- * \param ctl CTL handle
- * \param id CTL element id pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_unlock(snd_ctl_t *ctl, snd_ctl_elem_id_t *id)
-{
- assert(ctl && id);
- return ctl->ops->element_unlock(ctl, id);
-}
-
-/**
- * \brief Get next hardware dependent device number
- * \param ctl CTL handle
- * \param device current device on entry and next device on return
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_hwdep_next_device(snd_ctl_t *ctl, int *device)
-{
- assert(ctl && device);
- return ctl->ops->hwdep_next_device(ctl, device);
-}
-
-/**
- * \brief Get info about a hardware dependent device
- * \param ctl CTL handle
- * \param info Hardware dependent device id/info pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_hwdep_info(snd_ctl_t *ctl, snd_hwdep_info_t * info)
-{
- assert(ctl && info);
- return ctl->ops->hwdep_info(ctl, info);
-}
-
-/**
- * \brief Get next PCM device number
- * \param ctl CTL handle
- * \param device current device on entry and next device on return
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_pcm_next_device(snd_ctl_t *ctl, int * device)
-{
- assert(ctl && device);
- return ctl->ops->pcm_next_device(ctl, device);
-}
-
-/**
- * \brief Get info about a PCM device
- * \param ctl CTL handle
- * \param info PCM device id/info pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_pcm_info(snd_ctl_t *ctl, snd_pcm_info_t * info)
-{
- assert(ctl && info);
- return ctl->ops->pcm_info(ctl, info);
-}
-
-/**
- * \brief Set preferred PCM subdevice number of successive PCM open
- * \param ctl CTL handle
- * \param subdev Preferred PCM subdevice number
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_pcm_prefer_subdevice(snd_ctl_t *ctl, int subdev)
-{
- assert(ctl);
- return ctl->ops->pcm_prefer_subdevice(ctl, subdev);
-}
-
-/**
- * \brief Get next RawMidi device number
- * \param ctl CTL handle
- * \param device current device on entry and next device on return
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_rawmidi_next_device(snd_ctl_t *ctl, int * device)
-{
- assert(ctl && device);
- return ctl->ops->rawmidi_next_device(ctl, device);
-}
-
-/**
- * \brief Get info about a RawMidi device
- * \param ctl CTL handle
- * \param info RawMidi device id/info pointer
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_rawmidi_info(snd_ctl_t *ctl, snd_rawmidi_info_t * info)
-{
- assert(ctl && info);
- return ctl->ops->rawmidi_info(ctl, info);
-}
-
-/**
- * \brief Set preferred RawMidi subdevice number of successive RawMidi open
- * \param ctl CTL handle
- * \param subdev Preferred RawMidi subdevice number
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_rawmidi_prefer_subdevice(snd_ctl_t *ctl, int subdev)
-{
- assert(ctl);
- return ctl->ops->rawmidi_prefer_subdevice(ctl, subdev);
-}
-
-/**
- * \brief Set Power State to given SND_CTL_POWER_* value and do the power management
- * \param ctl CTL handle
- * \param state Desired Power State
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_set_power_state(snd_ctl_t *ctl, unsigned int state)
-{
- assert(ctl);
- if (ctl->ops->set_power_state)
- return ctl->ops->set_power_state(ctl, state);
- return -ENXIO;
-}
-
-/**
- * \brief Get actual Power State
- * \param ctl CTL handle
- * \param state Destination value
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_get_power_state(snd_ctl_t *ctl, unsigned int *state)
-{
- assert(ctl);
- if (ctl->ops->get_power_state)
- return ctl->ops->get_power_state(ctl, state);
- return -ENXIO;
-}
-
-/**
- * \brief Read an event
- * \param ctl CTL handle
- * \param event Event pointer
- * \return number of events read otherwise a negative error code on failure
- */
-int snd_ctl_read(snd_ctl_t *ctl, snd_ctl_event_t *event)
-{
- assert(ctl && event);
- return (ctl->ops->read)(ctl, event);
-}
-
-/**
- * \brief Wait for a CTL to become ready (i.e. at least one event pending)
- * \param ctl CTL handle
- * \param timeout maximum time in milliseconds to wait
- * \return 0 otherwise a negative error code on failure
- */
-int snd_ctl_wait(snd_ctl_t *ctl, int timeout)
-{
- struct pollfd *pfd;
- unsigned short *revents;
- int i, npfds, pollio, err, err_poll;
-
- npfds = snd_ctl_poll_descriptors_count(ctl);
- if (npfds <= 0 || npfds >= 16) {
- SNDERR("Invalid poll_fds %d\n", npfds);
- return -EIO;
- }
- pfd = alloca(sizeof(*pfd) * npfds);
- revents = alloca(sizeof(*revents) * npfds);
- err = snd_ctl_poll_descriptors(ctl, pfd, npfds);
- if (err < 0)
- return err;
- if (err != npfds) {
- SNDMSG("invalid poll descriptors %d\n", err);
- return -EIO;
- }
- do {
- err_poll = poll(pfd, npfds, timeout);
- if (err_poll < 0)
- return -errno;
- if (! err_poll)
- break;
- err = snd_ctl_poll_descriptors_revents(ctl, pfd, npfds, revents);
- if (err < 0)
- return err;
- pollio = 0;
- for (i = 0; i < npfds; i++) {
- if (revents[i] & (POLLERR | POLLNVAL))
- return -EIO;
- if ((revents[i] & (POLLIN | POLLOUT)) == 0)
- continue;
- pollio++;
- }
- } while (! pollio);
-
- return err_poll > 0 ? 1 : 0;
-}
-
-/**
- * \brief Add an async handler for a CTL
- * \param handler Returned handler handle
- * \param ctl CTL handle
- * \param callback Callback function
- * \param private_data Callback private data
- * \return 0 otherwise a negative error code on failure
- */
-int snd_async_add_ctl_handler(snd_async_handler_t **handler, snd_ctl_t *ctl,
- snd_async_callback_t callback, void *private_data)
-{
- int err;
- int was_empty;
- snd_async_handler_t *h;
- err = snd_async_add_handler(&h, _snd_ctl_async_descriptor(ctl),
- callback, private_data);
- if (err < 0)
- return err;
- h->type = SND_ASYNC_HANDLER_CTL;
- h->u.ctl = ctl;
- was_empty = list_empty(&ctl->async_handlers);
- list_add_tail(&h->hlist, &ctl->async_handlers);
- if (was_empty) {
- err = snd_ctl_async(ctl, snd_async_handler_get_signo(h), getpid());
- if (err < 0) {
- snd_async_del_handler(h);
- return err;
- }
- }
- *handler = h;
- return 0;
-}
-
-/**
- * \brief Return CTL handle related to an async handler
- * \param handler Async handler handle
- * \return CTL handle
- */
-snd_ctl_t *snd_async_handler_get_ctl(snd_async_handler_t *handler)
-{
- assert(handler->type == SND_ASYNC_HANDLER_CTL);
- return handler->u.ctl;
-}
-
-static const char *const build_in_ctls[] = {
- "hw", "shm", NULL
-};
-
-static int snd_ctl_open_conf(snd_ctl_t **ctlp, const char *name,
- snd_config_t *ctl_root, snd_config_t *ctl_conf, int mode)
-{
- const char *str;
- char *buf = NULL, *buf1 = NULL;
- int err;
- snd_config_t *conf, *type_conf = NULL;
- snd_config_iterator_t i, next;
- const char *lib = NULL, *open_name = NULL;
- const char *id;
- int (*open_func)(snd_ctl_t **, const char *, snd_config_t *, snd_config_t *, int) = NULL;
-#ifndef PIC
- extern void *snd_control_open_symbols(void);
-#endif
- void *h = NULL;
- if (snd_config_get_type(ctl_conf) != SND_CONFIG_TYPE_COMPOUND) {
- if (name)
- SNDERR("Invalid type for CTL %s definition", name);
- else
- SNDERR("Invalid type for CTL definition");
- return -EINVAL;
- }
- err = snd_config_search(ctl_conf, "type", &conf);
- if (err < 0) {
- SNDERR("type is not defined");
- return err;
- }
- err = snd_config_get_id(conf, &id);
- if (err < 0) {
- SNDERR("unable to get id");
- return err;
- }
- err = snd_config_get_string(conf, &str);
- if (err < 0) {
- SNDERR("Invalid type for %s", id);
- return err;
- }
- err = snd_config_search_definition(ctl_root, "ctl_type", str, &type_conf);
- if (err >= 0) {
- if (snd_config_get_type(type_conf) != SND_CONFIG_TYPE_COMPOUND) {
- SNDERR("Invalid type for CTL type %s definition", str);
- goto _err;
- }
- snd_config_for_each(i, next, type_conf) {
- snd_config_t *n = snd_config_iterator_entry(i);
- const char *id;
- if (snd_config_get_id(n, &id) < 0)
- continue;
- if (strcmp(id, "comment") == 0)
- continue;
- if (strcmp(id, "lib") == 0) {
- err = snd_config_get_string(n, &lib);
- if (err < 0) {
- SNDERR("Invalid type for %s", id);
- goto _err;
- }
- continue;
- }
- if (strcmp(id, "open") == 0) {
- err = snd_config_get_string(n, &open_name);
- if (err < 0) {
- SNDERR("Invalid type for %s", id);
- goto _err;
- }
- continue;
- }
- SNDERR("Unknown field %s", id);
- err = -EINVAL;
- goto _err;
- }
- }
- if (!open_name) {
- buf = malloc(strlen(str) + 32);
- if (buf == NULL) {
- err = -ENOMEM;
- goto _err;
- }
- open_name = buf;
- sprintf(buf, "_snd_ctl_%s_open", str);
- }
- if (!lib) {
- const char *const *build_in = build_in_ctls;
- while (*build_in) {
- if (!strcmp(*build_in, str))
- break;
- build_in++;
- }
- if (*build_in == NULL) {
- buf1 = malloc(strlen(str) + sizeof(ALSA_PLUGIN_DIR) + 32);
- if (buf1 == NULL) {
- err = -ENOMEM;
- goto _err;
- }
- lib = buf1;
- sprintf(buf1, "%s/libasound_module_ctl_%s.so", ALSA_PLUGIN_DIR, str);
- }
- }
-#ifndef PIC
- snd_control_open_symbols();
-#endif
- open_func = snd_dlobj_cache_lookup(open_name);
- if (open_func) {
- err = 0;
- goto _err;
- }
- h = snd_dlopen(lib, RTLD_NOW);
- if (h)
- open_func = snd_dlsym(h, open_name, SND_DLSYM_VERSION(SND_CONTROL_DLSYM_VERSION));
- err = 0;
- if (!h) {
- SNDERR("Cannot open shared library %s", lib);
- err = -ENOENT;
- } else if (!open_func) {
- SNDERR("symbol %s is not defined inside %s", open_name, lib);
- snd_dlclose(h);
- err = -ENXIO;
- }
- _err:
- if (type_conf)
- snd_config_delete(type_conf);
- if (err >= 0) {
- err = open_func(ctlp, name, ctl_root, ctl_conf, mode);
- if (err >= 0) {
- if (h /*&& (mode & SND_CTL_KEEP_ALIVE)*/) {
- snd_dlobj_cache_add(open_name, h, open_func);
- h = NULL;
- }
- (*ctlp)->dl_handle = h;
- err = 0;
- } else {
- if (h)
- snd_dlclose(h);
- }
- }
- free(buf);
- free(buf1);
- return err;
-}
-
-static int snd_ctl_open_noupdate(snd_ctl_t **ctlp, snd_config_t *root, const char *name, int mode)
-{
- int err;
- snd_config_t *ctl_conf;
- err = snd_config_search_definition(root, "ctl", name, &ctl_conf);
- if (err < 0) {
- SNDERR("Invalid CTL %s", name);
- return err;
- }
- err = snd_ctl_open_conf(ctlp, name, root, ctl_conf, mode);
- snd_config_delete(ctl_conf);
- return err;
-}
-
-/**
- * \brief Opens a CTL
- * \param ctlp Returned CTL handle
- * \param name ASCII identifier of the CTL handle
- * \param mode Open mode (see #SND_CTL_NONBLOCK, #SND_CTL_ASYNC)
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_open(snd_ctl_t **ctlp, const char *name, int mode)
-{
- int err;
- assert(ctlp && name);
- err = snd_config_update();
- if (err < 0)
- return err;
- return snd_ctl_open_noupdate(ctlp, snd_config, name, mode);
-}
-
-/**
- * \brief Opens a CTL using local configuration
- * \param ctlp Returned CTL handle
- * \param name ASCII identifier of the CTL handle
- * \param mode Open mode (see #SND_CTL_NONBLOCK, #SND_CTL_ASYNC)
- * \param lconf Local configuration
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_open_lconf(snd_ctl_t **ctlp, const char *name,
- int mode, snd_config_t *lconf)
-{
- assert(ctlp && name && lconf);
- return snd_ctl_open_noupdate(ctlp, lconf, name, mode);
-}
-
-#ifndef DOC_HIDDEN
-#define TYPE(v) [SND_CTL_ELEM_TYPE_##v] = #v
-#define IFACE(v) [SND_CTL_ELEM_IFACE_##v] = #v
-#define IFACE1(v, n) [SND_CTL_ELEM_IFACE_##v] = #n
-#define EVENT(v) [SND_CTL_EVENT_##v] = #v
-
-static const char *const snd_ctl_elem_type_names[] = {
- TYPE(NONE),
- TYPE(BOOLEAN),
- TYPE(INTEGER),
- TYPE(ENUMERATED),
- TYPE(BYTES),
- TYPE(IEC958),
- TYPE(INTEGER64),
-};
-
-static const char *const snd_ctl_elem_iface_names[] = {
- IFACE(CARD),
- IFACE(HWDEP),
- IFACE(MIXER),
- IFACE(PCM),
- IFACE(RAWMIDI),
- IFACE(TIMER),
- IFACE(SEQUENCER),
-};
-
-static const char *const snd_ctl_event_type_names[] = {
- EVENT(ELEM),
-};
-#endif
-
-/**
- * \brief get name of a CTL element type
- * \param type CTL element type
- * \return ascii name of CTL element type
- */
-const char *snd_ctl_elem_type_name(snd_ctl_elem_type_t type)
-{
- assert(type <= SND_CTL_ELEM_TYPE_LAST);
- return snd_ctl_elem_type_names[type];
-}
-
-/**
- * \brief get name of a CTL element related interface
- * \param iface CTL element related interface
- * \return ascii name of CTL element related interface
- */
-const char *snd_ctl_elem_iface_name(snd_ctl_elem_iface_t iface)
-{
- assert(iface <= SND_CTL_ELEM_IFACE_LAST);
- return snd_ctl_elem_iface_names[iface];
-}
-
-/**
- * \brief get name of a CTL event type
- * \param type CTL event type
- * \return ascii name of CTL event type
- */
-const char *snd_ctl_event_type_name(snd_ctl_event_type_t type)
-{
- assert(type <= SND_CTL_EVENT_LAST);
- return snd_ctl_event_type_names[type];
-}
-
-/**
- * \brief allocate space for CTL element identifiers list
- * \param obj CTL element identifiers list
- * \param entries Entries to allocate
- * \return 0 on success otherwise a negative error code
- */
-int snd_ctl_elem_list_alloc_space(snd_ctl_elem_list_t *obj, unsigned int entries)
-{
- free(obj->pids);
- obj->pids = calloc(entries, sizeof(*obj->pids));
- if (!obj->pids) {
- obj->space = 0;
- return -ENOMEM;
- }
- obj->space = entries;
- return 0;
-}
-
-/**
- * \brief free previously allocated space for CTL element identifiers list
- * \param obj CTL element identifiers list
- */
-void snd_ctl_elem_list_free_space(snd_ctl_elem_list_t *obj)
-{
- free(obj->pids);
- obj->pids = NULL;
- obj->space = 0;
-}
-
-/**
- * \brief Get event mask for an element related event
- * \param obj CTL event
- * \return event mask for element related event
- */
-unsigned int snd_ctl_event_elem_get_mask(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.mask;
-}
-
-/**
- * \brief Get CTL element identifier for an element related event
- * \param obj CTL event
- * \param ptr Pointer to returned CTL element identifier
- */
-void snd_ctl_event_elem_get_id(const snd_ctl_event_t *obj, snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- *ptr = obj->data.elem.id;
-}
-
-/**
- * \brief Get element numeric identifier for an element related event
- * \param obj CTL event
- * \return element numeric identifier
- */
-unsigned int snd_ctl_event_elem_get_numid(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.id.numid;
-}
-
-/**
- * \brief Get interface part of CTL element identifier for an element related event
- * \param obj CTL event
- * \return interface part of element identifier
- */
-snd_ctl_elem_iface_t snd_ctl_event_elem_get_interface(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.id.iface;
-}
-
-/**
- * \brief Get device part of CTL element identifier for an element related event
- * \param obj CTL event
- * \return device part of element identifier
- */
-unsigned int snd_ctl_event_elem_get_device(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.id.device;
-}
-
-/**
- * \brief Get subdevice part of CTL element identifier for an element related event
- * \param obj CTL event
- * \return subdevice part of element identifier
- */
-unsigned int snd_ctl_event_elem_get_subdevice(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.id.subdevice;
-}
-
-/**
- * \brief Get name part of CTL element identifier for an element related event
- * \param obj CTL event
- * \return name part of element identifier
- */
-const char *snd_ctl_event_elem_get_name(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return (const char *)obj->data.elem.id.name;
-}
-
-/**
- * \brief Get index part of CTL element identifier for an element related event
- * \param obj CTL event
- * \return index part of element identifier
- */
-unsigned int snd_ctl_event_elem_get_index(const snd_ctl_event_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_EVENT_ELEM);
- return obj->data.elem.id.index;
-}
-
-#ifndef DOC_HIDDEN
-int _snd_ctl_poll_descriptor(snd_ctl_t *ctl)
-{
- assert(ctl);
- return ctl->poll_fd;
-}
-#endif
-
-/**
- * \brief get size of #snd_ctl_elem_id_t
- * \return size in bytes
- */
-size_t snd_ctl_elem_id_sizeof()
-{
- return sizeof(snd_ctl_elem_id_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_elem_id_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_elem_id_malloc(snd_ctl_elem_id_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_elem_id_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_elem_id_t
- * \param obj pointer to object to free
- */
-void snd_ctl_elem_id_free(snd_ctl_elem_id_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_elem_id_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_elem_id_clear(snd_ctl_elem_id_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_elem_id_t));
-}
-
-/**
- * \brief copy one #snd_ctl_elem_id_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_elem_id_copy(snd_ctl_elem_id_t *dst, const snd_ctl_elem_id_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Get numeric identifier from a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element numeric identifier
- */
-unsigned int snd_ctl_elem_id_get_numid(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return obj->numid;
-}
-
-/**
- * \brief Get interface part of a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element related interface
- */
-snd_ctl_elem_iface_t snd_ctl_elem_id_get_interface(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return obj->iface;
-}
-
-/**
- * \brief Get device part of a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element related device
- */
-unsigned int snd_ctl_elem_id_get_device(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return obj->device;
-}
-
-/**
- * \brief Get subdevice part of a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element related subdevice
- */
-unsigned int snd_ctl_elem_id_get_subdevice(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return obj->subdevice;
-}
-
-/**
- * \brief Get name part of a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element name
- */
-const char *snd_ctl_elem_id_get_name(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return (const char *)obj->name;
-}
-
-/**
- * \brief Get index part of a CTL element identifier
- * \param obj CTL element identifier
- * \return CTL element index
- */
-unsigned int snd_ctl_elem_id_get_index(const snd_ctl_elem_id_t *obj)
-{
- assert(obj);
- return obj->index;
-}
-
-/**
- * \brief Set numeric identifier for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element numeric identifier
- */
-void snd_ctl_elem_id_set_numid(snd_ctl_elem_id_t *obj, unsigned int val)
-{
- assert(obj);
- obj->numid = val;
-}
-
-/**
- * \brief Set interface part for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element related interface
- */
-void snd_ctl_elem_id_set_interface(snd_ctl_elem_id_t *obj, snd_ctl_elem_iface_t val)
-{
- assert(obj);
- obj->iface = val;
-}
-
-/**
- * \brief Set device part for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element related device
- */
-void snd_ctl_elem_id_set_device(snd_ctl_elem_id_t *obj, unsigned int val)
-{
- assert(obj);
- obj->device = val;
-}
-
-/**
- * \brief Set subdevice part for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element related subdevice
- */
-void snd_ctl_elem_id_set_subdevice(snd_ctl_elem_id_t *obj, unsigned int val)
-{
- assert(obj);
- obj->subdevice = val;
-}
-
-/**
- * \brief Set name part for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element name
- */
-void snd_ctl_elem_id_set_name(snd_ctl_elem_id_t *obj, const char *val)
-{
- assert(obj);
- strncpy((char *)obj->name, val, sizeof(obj->name));
-}
-
-/**
- * \brief Set index part for a CTL element identifier
- * \param obj CTL element identifier
- * \param val CTL element index
- */
-void snd_ctl_elem_id_set_index(snd_ctl_elem_id_t *obj, unsigned int val)
-{
- assert(obj);
- obj->index = val;
-}
-
-/**
- * \brief get size of #snd_ctl_card_info_t
- * \return size in bytes
- */
-size_t snd_ctl_card_info_sizeof()
-{
- return sizeof(snd_ctl_card_info_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_card_info_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_card_info_malloc(snd_ctl_card_info_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_card_info_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_card_info_t
- * \param obj pointer to object to free
- */
-void snd_ctl_card_info_free(snd_ctl_card_info_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_card_info_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_card_info_clear(snd_ctl_card_info_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_card_info_t));
-}
-
-/**
- * \brief copy one #snd_ctl_card_info_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_card_info_copy(snd_ctl_card_info_t *dst, const snd_ctl_card_info_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Get card number from a CTL card info
- * \param obj CTL card info
- * \return card number
- */
-int snd_ctl_card_info_get_card(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return obj->card;
-}
-
-/**
- * \brief Get card identifier from a CTL card info
- * \param obj CTL card info
- * \return card identifier
- */
-const char *snd_ctl_card_info_get_id(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->id;
-}
-
-/**
- * \brief Get card driver name from a CTL card info
- * \param obj CTL card info
- * \return card driver name
- */
-const char *snd_ctl_card_info_get_driver(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->driver;
-}
-
-/**
- * \brief Get card name from a CTL card info
- * \param obj CTL card info
- * \return card name
- */
-const char *snd_ctl_card_info_get_name(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->name;
-}
-
-/**
- * \brief Get card long name from a CTL card info
- * \param obj CTL card info
- * \return card long name
- */
-const char *snd_ctl_card_info_get_longname(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->longname;
-}
-
-/**
- * \brief Get card mixer name from a CTL card info
- * \param obj CTL card info
- * \return card mixer name
- */
-const char *snd_ctl_card_info_get_mixername(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->mixername;
-}
-
-/**
- * \brief Get card component list from a CTL card info
- * \param obj CTL card info
- * \return card mixer identifier
- */
-const char *snd_ctl_card_info_get_components(const snd_ctl_card_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->components;
-}
-
-/**
- * \brief get size of #snd_ctl_event_t
- * \return size in bytes
- */
-size_t snd_ctl_event_sizeof()
-{
- return sizeof(snd_ctl_event_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_event_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_event_malloc(snd_ctl_event_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_event_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_event_t
- * \param obj pointer to object to free
- */
-void snd_ctl_event_free(snd_ctl_event_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_event_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_event_clear(snd_ctl_event_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_event_t));
-}
-
-/**
- * \brief copy one #snd_ctl_event_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_event_copy(snd_ctl_event_t *dst, const snd_ctl_event_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Get type of a CTL event
- * \param obj CTL event
- * \return CTL event type
- */
-snd_ctl_event_type_t snd_ctl_event_get_type(const snd_ctl_event_t *obj)
-{
- assert(obj);
- return obj->type;
-}
-
-/**
- * \brief get size of #snd_ctl_elem_list_t
- * \return size in bytes
- */
-size_t snd_ctl_elem_list_sizeof()
-{
- return sizeof(snd_ctl_elem_list_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_elem_list_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_elem_list_malloc(snd_ctl_elem_list_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_elem_list_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_elem_list_t
- * \param obj pointer to object to free
- */
-void snd_ctl_elem_list_free(snd_ctl_elem_list_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_elem_list_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_elem_list_clear(snd_ctl_elem_list_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_elem_list_t));
-}
-
-/**
- * \brief copy one #snd_ctl_elem_list_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_elem_list_copy(snd_ctl_elem_list_t *dst, const snd_ctl_elem_list_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Set index of first wanted CTL element identifier in a CTL element identifiers list
- * \param obj CTL element identifiers list
- * \param val index of CTL element to put at position 0 of list
- */
-void snd_ctl_elem_list_set_offset(snd_ctl_elem_list_t *obj, unsigned int val)
-{
- assert(obj);
- obj->offset = val;
-}
-
-/**
- * \brief Get number of used entries in CTL element identifiers list
- * \param obj CTL element identifier list
- * \return number of used entries
- */
-unsigned int snd_ctl_elem_list_get_used(const snd_ctl_elem_list_t *obj)
-{
- assert(obj);
- return obj->used;
-}
-
-/**
- * \brief Get total count of elements present in CTL device (information present in every filled CTL element identifiers list)
- * \param obj CTL element identifier list
- * \return total number of elements
- */
-unsigned int snd_ctl_elem_list_get_count(const snd_ctl_elem_list_t *obj)
-{
- assert(obj);
- return obj->count;
-}
-
-/**
- * \brief Get CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \param ptr Pointer to returned CTL element identifier
- */
-void snd_ctl_elem_list_get_id(const snd_ctl_elem_list_t *obj, unsigned int idx, snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- assert(idx < obj->used);
- *ptr = obj->pids[idx];
-}
-
-/**
- * \brief Get CTL element numeric identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element numeric identifier
- */
-unsigned int snd_ctl_elem_list_get_numid(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return obj->pids[idx].numid;
-}
-
-/**
- * \brief Get interface part of CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element related interface
- */
-snd_ctl_elem_iface_t snd_ctl_elem_list_get_interface(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return obj->pids[idx].iface;
-}
-
-/**
- * \brief Get device part of CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element related device
- */
-unsigned int snd_ctl_elem_list_get_device(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return obj->pids[idx].device;
-}
-
-/**
- * \brief Get subdevice part of CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element related subdevice
- */
-unsigned int snd_ctl_elem_list_get_subdevice(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return obj->pids[idx].subdevice;
-}
-
-/**
- * \brief Get name part of CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element name
- */
-const char *snd_ctl_elem_list_get_name(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return (const char *)obj->pids[idx].name;
-}
-
-/**
- * \brief Get index part of CTL element identifier for an entry of a CTL element identifiers list
- * \param obj CTL element identifier list
- * \param idx Index of entry
- * \return CTL element index
- */
-unsigned int snd_ctl_elem_list_get_index(const snd_ctl_elem_list_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < obj->used);
- return obj->pids[idx].index;
-}
-
-/**
- * \brief get size of #snd_ctl_elem_info_t
- * \return size in bytes
- */
-size_t snd_ctl_elem_info_sizeof()
-{
- return sizeof(snd_ctl_elem_info_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_elem_info_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_elem_info_malloc(snd_ctl_elem_info_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_elem_info_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_elem_info_t
- * \param obj pointer to object to free
- */
-void snd_ctl_elem_info_free(snd_ctl_elem_info_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_elem_info_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_elem_info_clear(snd_ctl_elem_info_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_elem_info_t));
-}
-
-/**
- * \brief copy one #snd_ctl_elem_info_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_elem_info_copy(snd_ctl_elem_info_t *dst, const snd_ctl_elem_info_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Get type from a CTL element id/info
- * \param obj CTL element id/info
- * \return CTL element content type
- */
-snd_ctl_elem_type_t snd_ctl_elem_info_get_type(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->type;
-}
-
-/**
- * \brief Get info about readability from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element is not readable, 1 if element is readable
- */
-int snd_ctl_elem_info_is_readable(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_READ);
-}
-
-/**
- * \brief Get info about writability from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element is not writable, 1 if element is not writable
- */
-int snd_ctl_elem_info_is_writable(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_WRITE);
-}
-
-/**
- * \brief Get info about notification feasibility from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if all element value changes are notified to subscribed applications, 1 otherwise
- */
-int snd_ctl_elem_info_is_volatile(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_VOLATILE);
-}
-
-/**
- * \brief Get info about status from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element value is not active, 1 if is active
- */
-int snd_ctl_elem_info_is_inactive(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_INACTIVE);
-}
-
-/**
- * \brief Get info whether an element is locked
- * \param obj CTL element id/info
- * \return 0 if element value is currently changeable, 1 if it's locked by another application
- */
-int snd_ctl_elem_info_is_locked(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_LOCK);
-}
-
-/**
- * \brief Get info if I own an element
- * \param obj CTL element id/info
- * \return 0 if element value is currently changeable, 1 if it's locked by another application
- */
-int snd_ctl_elem_info_is_owner(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_OWNER);
-}
-
-/**
- * \brief Get info if it's a user element
- * \param obj CTL element id/info
- * \return 0 if element value is a system element, 1 if it's a user-created element
- */
-int snd_ctl_elem_info_is_user(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_USER);
-}
-
-/**
- * \brief Get info about TLV readability from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element's TLV is not readable, 1 if element's TLV is readable
- */
-int snd_ctl_elem_info_is_tlv_readable(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_TLV_READ);
-}
-
-/**
- * \brief Get info about TLV writeability from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element's TLV is not writable, 1 if element's TLV is writable
- */
-int snd_ctl_elem_info_is_tlv_writable(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_TLV_WRITE);
-}
-
-/**
- * \brief Get info about TLV command possibility from a CTL element id/info
- * \param obj CTL element id/info
- * \return 0 if element's TLV command is not possible, 1 if element's TLV command is supported
- */
-int snd_ctl_elem_info_is_tlv_commandable(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return !!(obj->access & SNDRV_CTL_ELEM_ACCESS_TLV_COMMAND);
-}
-
-/**
- * \brief (DEPRECATED) Get info about values passing policy from a CTL element value
- * \param obj CTL element id/info
- * \return 0 if element value need to be passed by contents, 1 if need to be passed with a pointer
- */
-int snd_ctl_elem_info_is_indirect(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return 0;
-}
-link_warning(snd_ctl_elem_info_is_indirect, "Warning: snd_ctl_elem_info_is_indirect is deprecated, do not use it");
-
-/**
- * \brief Get owner of a locked element
- * \param obj CTL element id/info
- * \return value entries count
- */
-pid_t snd_ctl_elem_info_get_owner(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->owner;
-}
-
-/**
- * \brief Get number of value entries from a CTL element id/info
- * \param obj CTL element id/info
- * \return value entries count
- */
-unsigned int snd_ctl_elem_info_get_count(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->count;
-}
-
-/**
- * \brief Get minimum value from a #SND_CTL_ELEM_TYPE_INTEGER CTL element id/info
- * \param obj CTL element id/info
- * \return Minimum value
- */
-long snd_ctl_elem_info_get_min(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER);
- return obj->value.integer.min;
-}
-
-/**
- * \brief Get maximum value from a #SND_CTL_ELEM_TYPE_INTEGER CTL element id/info
- * \param obj CTL element id/info
- * \return Maximum value
- */
-long snd_ctl_elem_info_get_max(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER);
- return obj->value.integer.max;
-}
-
-/**
- * \brief Get value step from a #SND_CTL_ELEM_TYPE_INTEGER CTL element id/info
- * \param obj CTL element id/info
- * \return Step
- */
-long snd_ctl_elem_info_get_step(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER);
- return obj->value.integer.step;
-}
-
-/**
- * \brief Get minimum value from a #SND_CTL_ELEM_TYPE_INTEGER64 CTL element id/info
- * \param obj CTL element id/info
- * \return Minimum value
- */
-long long snd_ctl_elem_info_get_min64(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER64);
- return obj->value.integer64.min;
-}
-
-/**
- * \brief Get maximum value from a #SND_CTL_ELEM_TYPE_INTEGER64 CTL element id/info
- * \param obj CTL element id/info
- * \return Maximum value
- */
-long long snd_ctl_elem_info_get_max64(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER64);
- return obj->value.integer64.max;
-}
-
-/**
- * \brief Get value step from a #SND_CTL_ELEM_TYPE_INTEGER64 CTL element id/info
- * \param obj CTL element id/info
- * \return Step
- */
-long long snd_ctl_elem_info_get_step64(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_INTEGER64);
- return obj->value.integer64.step;
-}
-
-/**
- * \brief Get number of items available from a #SND_CTL_ELEM_TYPE_ENUMERATED CTL element id/info
- * \param obj CTL element id/info
- * \return items count
- */
-unsigned int snd_ctl_elem_info_get_items(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_ENUMERATED);
- return obj->value.enumerated.items;
-}
-
-/**
- * \brief Select item in a #SND_CTL_ELEM_TYPE_ENUMERATED CTL element id/info
- * \param obj CTL element id/info
- * \param val item number
- */
-void snd_ctl_elem_info_set_item(snd_ctl_elem_info_t *obj, unsigned int val)
-{
- assert(obj);
- obj->value.enumerated.item = val;
-}
-
-/**
- * \brief Get name for selected item in a #SND_CTL_ELEM_TYPE_ENUMERATED CTL element id/info
- * \param obj CTL element id/info
- * \return name of chosen item
- */
-const char *snd_ctl_elem_info_get_item_name(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- assert(obj->type == SND_CTL_ELEM_TYPE_ENUMERATED);
- return obj->value.enumerated.name;
-}
-
-/**
- * \brief Get count of dimensions for given element
- * \param obj CTL element id/info
- * \return zero value if no dimensions are defined, otherwise positive value with count of dimensions
- */
-#ifndef DOXYGEN
-int INTERNAL(snd_ctl_elem_info_get_dimensions)(const snd_ctl_elem_info_t *obj)
-#else
-int snd_ctl_elem_info_get_dimensions(const snd_ctl_elem_info_t *obj)
-#endif
-{
- int i;
-
- assert(obj);
- for (i = 3; i >= 0; i--)
- if (obj->dimen.d[i])
- break;
- return i + 1;
-}
-use_default_symbol_version(__snd_ctl_elem_info_get_dimensions, snd_ctl_elem_info_get_dimensions, ALSA_0.9.3);
-
-/**
- * \brief Get specified of dimension width for given element
- * \param obj CTL element id/info
- * \param idx The dimension index
- * \return zero value if no dimension width is defined, otherwise positive value with with of specified dimension
- */
-#ifndef DOXYGEN
-int INTERNAL(snd_ctl_elem_info_get_dimension)(const snd_ctl_elem_info_t *obj, unsigned int idx)
-#else
-int snd_ctl_elem_info_get_dimension(const snd_ctl_elem_info_t *obj, unsigned int idx)
-#endif
-{
- assert(obj);
- if (idx >= 3)
- return 0;
- return obj->dimen.d[idx];
-}
-use_default_symbol_version(__snd_ctl_elem_info_get_dimension, snd_ctl_elem_info_get_dimension, ALSA_0.9.3);
-
-/**
- * \brief Get CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param ptr Pointer to returned CTL element identifier
- */
-void snd_ctl_elem_info_get_id(const snd_ctl_elem_info_t *obj, snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- *ptr = obj->id;
-}
-
-/**
- * \brief Get element numeric identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return element numeric identifier
- */
-unsigned int snd_ctl_elem_info_get_numid(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->id.numid;
-}
-
-/**
- * \brief Get interface part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return interface part of element identifier
- */
-snd_ctl_elem_iface_t snd_ctl_elem_info_get_interface(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->id.iface;
-}
-
-/**
- * \brief Get device part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return device part of element identifier
- */
-unsigned int snd_ctl_elem_info_get_device(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->id.device;
-}
-
-/**
- * \brief Get subdevice part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return subdevice part of element identifier
- */
-unsigned int snd_ctl_elem_info_get_subdevice(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->id.subdevice;
-}
-
-/**
- * \brief Get name part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return name part of element identifier
- */
-const char *snd_ctl_elem_info_get_name(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return (const char *)obj->id.name;
-}
-
-/**
- * \brief Get index part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \return index part of element identifier
- */
-unsigned int snd_ctl_elem_info_get_index(const snd_ctl_elem_info_t *obj)
-{
- assert(obj);
- return obj->id.index;
-}
-
-/**
- * \brief Set CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param ptr CTL element identifier
- */
-void snd_ctl_elem_info_set_id(snd_ctl_elem_info_t *obj, const snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- obj->id = *ptr;
-}
-
-/**
- * \brief Set element numeric identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val element numeric identifier
- */
-void snd_ctl_elem_info_set_numid(snd_ctl_elem_info_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.numid = val;
-}
-
-/**
- * \brief Set interface part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val interface part of element identifier
- */
-void snd_ctl_elem_info_set_interface(snd_ctl_elem_info_t *obj, snd_ctl_elem_iface_t val)
-{
- assert(obj);
- obj->id.iface = val;
-}
-
-/**
- * \brief Set device part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val device part of element identifier
- */
-void snd_ctl_elem_info_set_device(snd_ctl_elem_info_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.device = val;
-}
-
-/**
- * \brief Set subdevice part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val subdevice part of element identifier
- */
-void snd_ctl_elem_info_set_subdevice(snd_ctl_elem_info_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.subdevice = val;
-}
-
-/**
- * \brief Set name part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val name part of element identifier
- */
-void snd_ctl_elem_info_set_name(snd_ctl_elem_info_t *obj, const char *val)
-{
- assert(obj);
- strncpy((char *)obj->id.name, val, sizeof(obj->id.name));
-}
-
-/**
- * \brief Set index part of CTL element identifier of a CTL element id/info
- * \param obj CTL element id/info
- * \param val index part of element identifier
- */
-void snd_ctl_elem_info_set_index(snd_ctl_elem_info_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.index = val;
-}
-
-/**
- * \brief get size of #snd_ctl_elem_value_t
- * \return size in bytes
- */
-size_t snd_ctl_elem_value_sizeof()
-{
- return sizeof(snd_ctl_elem_value_t);
-}
-
-/**
- * \brief allocate an invalid #snd_ctl_elem_value_t using standard malloc
- * \param ptr returned pointer
- * \return 0 on success otherwise negative error code
- */
-int snd_ctl_elem_value_malloc(snd_ctl_elem_value_t **ptr)
-{
- assert(ptr);
- *ptr = calloc(1, sizeof(snd_ctl_elem_value_t));
- if (!*ptr)
- return -ENOMEM;
- return 0;
-}
-
-/**
- * \brief frees a previously allocated #snd_ctl_elem_value_t
- * \param obj pointer to object to free
- */
-void snd_ctl_elem_value_free(snd_ctl_elem_value_t *obj)
-{
- free(obj);
-}
-
-/**
- * \brief clear given #snd_ctl_elem_value_t object
- * \param obj pointer to object to clear
- */
-void snd_ctl_elem_value_clear(snd_ctl_elem_value_t *obj)
-{
- memset(obj, 0, sizeof(snd_ctl_elem_value_t));
-}
-
-/**
- * \brief copy one #snd_ctl_elem_value_t to another
- * \param dst pointer to destination
- * \param src pointer to source
- */
-void snd_ctl_elem_value_copy(snd_ctl_elem_value_t *dst, const snd_ctl_elem_value_t *src)
-{
- assert(dst && src);
- *dst = *src;
-}
-
-/**
- * \brief Get CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param ptr Pointer to returned CTL element identifier
- */
-void snd_ctl_elem_value_get_id(const snd_ctl_elem_value_t *obj, snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- *ptr = obj->id;
-}
-
-/**
- * \brief Get element numeric identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return element numeric identifier
- */
-unsigned int snd_ctl_elem_value_get_numid(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->id.numid;
-}
-
-/**
- * \brief Get interface part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return interface part of element identifier
- */
-snd_ctl_elem_iface_t snd_ctl_elem_value_get_interface(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->id.iface;
-}
-
-/**
- * \brief Get device part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return device part of element identifier
- */
-unsigned int snd_ctl_elem_value_get_device(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->id.device;
-}
-
-/**
- * \brief Get subdevice part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return subdevice part of element identifier
- */
-unsigned int snd_ctl_elem_value_get_subdevice(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->id.subdevice;
-}
-
-/**
- * \brief Get name part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return name part of element identifier
- */
-const char *snd_ctl_elem_value_get_name(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return (const char *)obj->id.name;
-}
-
-/**
- * \brief Get index part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \return index part of element identifier
- */
-unsigned int snd_ctl_elem_value_get_index(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->id.index;
-}
-
-/**
- * \brief Set CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param ptr CTL element identifier
- */
-void snd_ctl_elem_value_set_id(snd_ctl_elem_value_t *obj, const snd_ctl_elem_id_t *ptr)
-{
- assert(obj && ptr);
- obj->id = *ptr;
-}
-
-/**
- * \brief Set element numeric identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val element numeric identifier
- */
-void snd_ctl_elem_value_set_numid(snd_ctl_elem_value_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.numid = val;
-}
-
-/**
- * \brief Set interface part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val interface part of element identifier
- */
-void snd_ctl_elem_value_set_interface(snd_ctl_elem_value_t *obj, snd_ctl_elem_iface_t val)
-{
- assert(obj);
- obj->id.iface = val;
-}
-
-/**
- * \brief Set device part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val device part of element identifier
- */
-void snd_ctl_elem_value_set_device(snd_ctl_elem_value_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.device = val;
-}
-
-/**
- * \brief Set subdevice part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val subdevice part of element identifier
- */
-void snd_ctl_elem_value_set_subdevice(snd_ctl_elem_value_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.subdevice = val;
-}
-
-/**
- * \brief Set name part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val name part of element identifier
- */
-void snd_ctl_elem_value_set_name(snd_ctl_elem_value_t *obj, const char *val)
-{
- assert(obj);
- strncpy((char *)obj->id.name, val, sizeof(obj->id.name));
-}
-
-/**
- * \brief Set index part of CTL element identifier of a CTL element id/value
- * \param obj CTL element id/value
- * \param val index part of element identifier
- */
-void snd_ctl_elem_value_set_index(snd_ctl_elem_value_t *obj, unsigned int val)
-{
- assert(obj);
- obj->id.index = val;
-}
-
-/**
- * \brief Get value for an entry of a #SND_CTL_ELEM_TYPE_BOOLEAN CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \return value for the entry
- */
-int snd_ctl_elem_value_get_boolean(const snd_ctl_elem_value_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < sizeof(obj->value.integer.value) / sizeof(obj->value.integer.value[0]));
- return obj->value.integer.value[idx];
-}
-
-/**
- * \brief Get value for an entry of a #SND_CTL_ELEM_TYPE_INTEGER CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \return value for the entry
- */
-long snd_ctl_elem_value_get_integer(const snd_ctl_elem_value_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < sizeof(obj->value.integer.value) / sizeof(obj->value.integer.value[0]));
- return obj->value.integer.value[idx];
-}
-
-/**
- * \brief Get value for an entry of a #SND_CTL_ELEM_TYPE_INTEGER64 CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \return value for the entry
- */
-long long snd_ctl_elem_value_get_integer64(const snd_ctl_elem_value_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < sizeof(obj->value.integer64.value) / sizeof(obj->value.integer64.value[0]));
- return obj->value.integer64.value[idx];
-}
-
-/**
- * \brief Get value for an entry of a #SND_CTL_ELEM_TYPE_ENUMERATED CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \return value for the entry
- */
-unsigned int snd_ctl_elem_value_get_enumerated(const snd_ctl_elem_value_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < sizeof(obj->value.enumerated.item) / sizeof(obj->value.enumerated.item[0]));
- return obj->value.enumerated.item[idx];
-}
-
-/**
- * \brief Get value for an entry of a #SND_CTL_ELEM_TYPE_BYTES CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \return value for the entry
- */
-unsigned char snd_ctl_elem_value_get_byte(const snd_ctl_elem_value_t *obj, unsigned int idx)
-{
- assert(obj);
- assert(idx < sizeof(obj->value.bytes.data));
- return obj->value.bytes.data[idx];
-}
-
-/**
- * \brief Set value for an entry of a #SND_CTL_ELEM_TYPE_BOOLEAN CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \param val value for the entry
- */
-void snd_ctl_elem_value_set_boolean(snd_ctl_elem_value_t *obj, unsigned int idx, long val)
-{
- assert(obj);
- obj->value.integer.value[idx] = val;
-}
-
-/**
- * \brief Set value for an entry of a #SND_CTL_ELEM_TYPE_INTEGER CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \param val value for the entry
- */
-void snd_ctl_elem_value_set_integer(snd_ctl_elem_value_t *obj, unsigned int idx, long val)
-{
- assert(obj);
- obj->value.integer.value[idx] = val;
-}
-
-/**
- * \brief Set value for an entry of a #SND_CTL_ELEM_TYPE_INTEGER64 CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \param val value for the entry
- */
-void snd_ctl_elem_value_set_integer64(snd_ctl_elem_value_t *obj, unsigned int idx, long long val)
-{
- assert(obj);
- obj->value.integer64.value[idx] = val;
-}
-
-/**
- * \brief Set value for an entry of a #SND_CTL_ELEM_TYPE_ENUMERATED CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \param val value for the entry
- */
-void snd_ctl_elem_value_set_enumerated(snd_ctl_elem_value_t *obj, unsigned int idx, unsigned int val)
-{
- assert(obj);
- obj->value.enumerated.item[idx] = val;
-}
-
-/**
- * \brief Set value for an entry of a #SND_CTL_ELEM_TYPE_BYTES CTL element id/value
- * \param obj CTL element id/value
- * \param idx Entry index
- * \param val value for the entry
- */
-void snd_ctl_elem_value_set_byte(snd_ctl_elem_value_t *obj, unsigned int idx, unsigned char val)
-{
- assert(obj);
- obj->value.bytes.data[idx] = val;
-}
-
-/**
- * \brief Set CTL element #SND_CTL_ELEM_TYPE_BYTES value
- * \param obj CTL handle
- * \param data Bytes value
- * \param size Size in bytes
- */
-void snd_ctl_elem_set_bytes(snd_ctl_elem_value_t *obj, void *data, size_t size)
-{
- assert(obj);
- if (size >= sizeof(obj->value.bytes.data)) {
- assert(0);
- return;
- }
- memcpy(obj->value.bytes.data, data, size);
-}
-
-/**
- * \brief Get value for a #SND_CTL_ELEM_TYPE_BYTES CTL element id/value
- * \param obj CTL element id/value
- * \return Pointer to CTL element value
- */
-const void * snd_ctl_elem_value_get_bytes(const snd_ctl_elem_value_t *obj)
-{
- assert(obj);
- return obj->value.bytes.data;
-}
-
-/**
- * \brief Get value for a #SND_CTL_ELEM_TYPE_IEC958 CTL element id/value
- * \param obj CTL element id/value
- * \param ptr Pointer to returned CTL element value
- */
-void snd_ctl_elem_value_get_iec958(const snd_ctl_elem_value_t *obj, snd_aes_iec958_t *ptr)
-{
- assert(obj && ptr);
- memcpy(ptr, &obj->value.iec958, sizeof(*ptr));
-}
-
-/**
- * \brief Set value for a #SND_CTL_ELEM_TYPE_IEC958 CTL element id/value
- * \param obj CTL element id/value
- * \param ptr Pointer to CTL element value
- */
-void snd_ctl_elem_value_set_iec958(snd_ctl_elem_value_t *obj, const snd_aes_iec958_t *ptr)
-{
- assert(obj && ptr);
- memcpy(&obj->value.iec958, ptr, sizeof(obj->value.iec958));
-}
-