summaryrefslogtreecommitdiff
path: root/src/print_volume.c
diff options
context:
space:
mode:
authorBaptiste Daroussin <bapt@FreeBSD.org>2013-03-19 18:32:08 +0100
committerMichael Stapelberg <michael@stapelberg.de>2013-03-19 19:53:26 +0100
commitf30ec89b79143d5d90f7fbe9c5aaf73ef6847e30 (patch)
tree38b3f5e92e7748b824c1fc6c8077b70156a5c274 /src/print_volume.c
parent7f83d0a1976ebdba7f8671ba74b472ad5b4839b1 (diff)
Support mixer_idx with OSS
make mixer_idx load the default mixer
Diffstat (limited to 'src/print_volume.c')
-rw-r--r--src/print_volume.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/src/print_volume.c b/src/print_volume.c
index 1b03e5e..6a87b1e 100644
--- a/src/print_volume.c
+++ b/src/print_volume.c
@@ -175,12 +175,22 @@ void print_volume(yajl_gen json_gen, char *buffer, const char *fmt, const char *
}
#endif
#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__DragonFly__)
- char mixerpath[] = "/dev/mixer";
+ char *mixerpath;
+ char defaultmixer[] = "/dev/mixer";
int mixfd, vol, devmask = 0;
pbval = 1;
+ if (mixer_idx > 0)
+ asprintf(&mixerpath, "/dev/mixer%d", mixer_idx);
+ else
+ mixerpath = defaultmixer;
+
if ((mixfd = open(mixerpath, O_RDWR)) < 0)
return;
+
+ if (mixer_idx > 0)
+ free(mixerpath);
+
if (ioctl(mixfd, SOUND_MIXER_READ_DEVMASK, &devmask) == -1)
return;
if (ioctl(mixfd, MIXER_READ(0),&vol) == -1)