X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/bd8895a87731c72190ea2012f36583f796d4181a..b0b15b7ced28b3c6ddfcd4b0a7e46ee6432a243c:/lib/mixer-oss.c diff --git a/lib/mixer-oss.c b/lib/mixer-oss.c index 7ab73a2..158b6f6 100644 --- a/lib/mixer-oss.c +++ b/lib/mixer-oss.c @@ -1,6 +1,6 @@ /* * This file is part of DisOrder - * Copyright (C) 2004, 2007 Richard Kettlewell + * Copyright (C) 2004, 2007, 2008 Richard Kettlewell * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -17,26 +17,29 @@ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA */ +/** @file lib/mixer-oss.c + * @brief OSS mixer support + * + * Mono output devices aren't explicitly supported (but may work + * nonetheless). + */ -#include -#include "types.h" +#include "common.h" + +#if HAVE_SYS_SOUNDCARD_H -#include -#include #include #include -#include #include #include #include +#include #include "configuration.h" #include "mixer.h" #include "log.h" #include "syscalls.h" - -#if HAVE_SYS_SOUNDCARD_H -#include +#include "mem.h" /* documentation does not match implementation! */ #ifndef SOUND_MIXER_READ @@ -46,8 +49,10 @@ # define SOUND_MIXER_WRITE(x) MIXER_WRITE(x) #endif +/** @brief Channel names */ static const char *channels[] = SOUND_DEVICE_NAMES; +/** @brief Convert channel name to number */ static int mixer_channel(const char *c) { unsigned n; @@ -61,35 +66,24 @@ static int mixer_channel(const char *c) { } } -static int oss_validate_channel(const char *c) { - if(mixer_channel(c) != -1) - return 1; - else - return 0; -} - -static int oss_validate_device(const char *d) { - struct stat sb; - - if(stat(d, &sb) < 0) { - error(errno, "%s", d); - return 0; - } - if(!S_ISCHR(sb.st_mode)) { - error(0, "%s: not a character device", d); - return 0; - } - return 1; -} - +/** @brief Open the OSS mixer device and return its fd */ static int oss_do_open(void) { int fd; - if((fd = open(config->mixer, O_RDWR, 0)) < 0) - error(errno, "error opening %s", config->mixer); + if((fd = open(config->mixer, O_RDWR, 0)) < 0) { + static char *reported; + + if(!reported || strcmp(reported, config->mixer)) { + if(reported) + xfree(reported); + reported = xstrdup(config->mixer); + error(errno, "error opening %s", config->mixer); + } + } return fd; } +/** @brief Get the OSS mixer setting */ static int oss_do_get(int *left, int *right, int fd, int ch) { int r; @@ -103,6 +97,7 @@ static int oss_do_get(int *left, int *right, int fd, int ch) { return 0; } +/** @brief Get OSS volume */ static int oss_get(int *left, int *right) { int ch, fd; @@ -121,6 +116,7 @@ static int oss_get(int *left, int *right) { return -1; } +/** @brief Set OSS volume */ static int oss_set(int *left, int *right) { int ch, fd, r; @@ -146,10 +142,9 @@ static int oss_set(int *left, int *right) { return -1; } +/** @brief OSS mixer vtable */ const struct mixer mixer_oss = { BACKEND_OSS, - oss_validate_device, - oss_validate_channel, oss_get, oss_set, "/dev/mixer",