alsa-lib/src/mixer/mixer.c

131 lines
3.2 KiB
C
Raw Normal View History

1998-08-13 15:42:56 +00:00
/*
* Mixer Interface - main file
* Copyright (c) 1998/1999/2000 by Jaroslav Kysela <perex@suse.cz>
2001-02-09 11:20:31 +00:00
* Copyright (c) 2001 by Abramo Bagnara <abramo@alsa-project.org>
1998-08-13 15:42:56 +00:00
*
*
* This library is free software; you can redistribute it and/or modify
* it under the terms of the GNU Library General Public License as
* published by the Free Software Foundation; either version 2 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 Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#include "mixer_local.h"
1998-08-13 15:42:56 +00:00
2001-02-09 11:20:31 +00:00
int snd_mixer_open(snd_mixer_t **mixerp, char *name)
1998-08-13 15:42:56 +00:00
{
2001-02-09 11:20:31 +00:00
snd_mixer_t *mixer;
snd_ctl_t *ctl;
int err;
2001-02-09 11:20:31 +00:00
assert(mixerp);
if ((err = snd_ctl_open(&ctl, name)) < 0)
return err;
2001-02-09 11:20:31 +00:00
mixer = calloc(1, sizeof(snd_mixer_t));
if (mixer == NULL) {
snd_ctl_close(ctl);
2000-08-17 21:50:34 +00:00
return -ENOMEM;
}
2001-02-09 11:20:31 +00:00
mixer->ctl = ctl;
INIT_LIST_HEAD(&mixer->elems);
*mixerp = mixer;
1998-11-27 14:57:39 +00:00
return 0;
1998-08-13 15:42:56 +00:00
}
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *snd_mixer_elem_add(snd_mixer_t *mixer)
1998-08-13 15:42:56 +00:00
{
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *elem;
elem = calloc(1, sizeof(*elem));
if (!elem)
return NULL;
elem->mixer = mixer;
list_add_tail(&elem->list, &mixer->elems);
mixer->count++;
return elem;
1998-08-13 15:42:56 +00:00
}
2001-02-09 11:20:31 +00:00
void snd_mixer_elem_remove(snd_mixer_elem_t *elem)
1998-08-13 15:42:56 +00:00
{
2001-02-09 11:20:31 +00:00
snd_mixer_t *mixer = elem->mixer;
if (elem->private_free)
elem->private_free(elem);
if (elem->callback)
elem->callback(elem, SND_CTL_EVENT_REMOVE);
list_del(&elem->list);
free(elem);
mixer->count--;
1998-08-13 15:42:56 +00:00
}
2001-02-09 11:20:31 +00:00
void snd_mixer_free(snd_mixer_t *mixer)
{
2001-02-09 11:20:31 +00:00
while (!list_empty(&mixer->elems))
snd_mixer_elem_remove(list_entry(mixer->elems.next, snd_mixer_elem_t, list));
}
2000-01-18 08:45:02 +00:00
2001-02-09 11:20:31 +00:00
int snd_mixer_close(snd_mixer_t *mixer)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
assert(mixer);
snd_mixer_free(mixer);
return snd_ctl_close(mixer->ctl);
2000-01-18 08:45:02 +00:00
}
2001-02-09 11:20:31 +00:00
int snd_mixer_poll_descriptor(snd_mixer_t *mixer)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
if (mixer == NULL || mixer->ctl == NULL)
return -EIO;
return snd_ctl_poll_descriptor(mixer->ctl);
2000-01-18 08:45:02 +00:00
}
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *snd_mixer_first_elem(snd_mixer_t *mixer)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
assert(mixer);
if (list_empty(&mixer->elems))
return NULL;
return list_entry(mixer->elems.next, snd_mixer_elem_t, list);
}
2000-01-18 08:45:02 +00:00
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *snd_mixer_last_elem(snd_mixer_t *mixer)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
assert(mixer);
if (list_empty(&mixer->elems))
return NULL;
return list_entry(mixer->elems.prev, snd_mixer_elem_t, list);
2000-01-18 08:45:02 +00:00
}
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *snd_mixer_elem_next(snd_mixer_elem_t *elem)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
assert(elem);
if (elem->list.next == &elem->mixer->elems)
return NULL;
return list_entry(elem->list.next, snd_mixer_elem_t, list);
2000-01-18 08:45:02 +00:00
}
2001-02-09 11:20:31 +00:00
snd_mixer_elem_t *snd_mixer_elem_prev(snd_mixer_elem_t *elem)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
assert(elem);
if (elem->list.prev == &elem->mixer->elems)
return NULL;
return list_entry(elem->list.prev, snd_mixer_elem_t, list);
}
2000-01-18 08:45:02 +00:00
2001-02-09 11:20:31 +00:00
int snd_mixer_events(snd_mixer_t *mixer)
2000-01-18 08:45:02 +00:00
{
2001-02-09 11:20:31 +00:00
return snd_hctl_events(mixer->ctl);
2000-01-18 08:45:02 +00:00
}
2001-02-09 11:20:31 +00:00