summaryrefslogtreecommitdiff
path: root/sys/dev/ic/ac97.c
diff options
context:
space:
mode:
authorConstantine Sapuntzakis <csapuntz@cvs.openbsd.org>1999-09-21 16:06:29 +0000
committerConstantine Sapuntzakis <csapuntz@cvs.openbsd.org>1999-09-21 16:06:29 +0000
commit7f01c9d6df9ead7cf08e5b2dbc317ada575b5350 (patch)
treedbd168f135b9c5f511ea40d4c05340ff79bc5ed8 /sys/dev/ic/ac97.c
parent4ecdc1954f4fbdcb4552591930031f4e3396fbe8 (diff)
Add get_portnum_by_name to ac97 vtbl.
get_portnum_by_name returns the mixer port # given a (class, device, qualifier) tuple.
Diffstat (limited to 'sys/dev/ic/ac97.c')
-rw-r--r--sys/dev/ic/ac97.c36
1 files changed, 30 insertions, 6 deletions
diff --git a/sys/dev/ic/ac97.c b/sys/dev/ic/ac97.c
index 77762814f33..b8ed4d88a72 100644
--- a/sys/dev/ic/ac97.c
+++ b/sys/dev/ic/ac97.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ac97.c,v 1.1 1999/09/19 06:45:12 csapuntz Exp $ */
+/* $OpenBSD: ac97.c,v 1.2 1999/09/21 16:06:27 csapuntz Exp $ */
/*
* Copyright (c) 1999 Constantine Sapuntzakis
@@ -279,11 +279,14 @@ struct ac97_softc {
int ac97_mixer_get_port __P((struct ac97_codec_if *self, mixer_ctrl_t *cp));
int ac97_mixer_set_port __P((struct ac97_codec_if *self, mixer_ctrl_t *));
int ac97_query_devinfo __P((struct ac97_codec_if *self, mixer_devinfo_t *));
+int ac97_get_portnum_by_name __P((struct ac97_codec_if *, char *, char *,
+ char *));
struct ac97_codec_if_vtbl ac97civ = {
ac97_mixer_get_port,
ac97_mixer_set_port,
- ac97_query_devinfo
+ ac97_query_devinfo,
+ ac97_get_portnum_by_name
};
static struct ac97_codecid {
@@ -607,8 +610,9 @@ ac97_mixer_set_port(codec_if, cp)
struct audio_mixer_value *value = si->info;
u_int16_t l, r;
- if (cp->un.value.num_channels !=
- value->num_channels) return (EINVAL);
+ if ((cp->un.value.num_channels <= 0) ||
+ (cp->un.value.num_channels > value->num_channels))
+ return (EINVAL);
if (cp->un.value.num_channels == 1) {
l = r = cp->un.value.level[AUDIO_MIXER_LEVEL_MONO];
@@ -646,6 +650,25 @@ ac97_mixer_set_port(codec_if, cp)
}
int
+ac97_get_portnum_by_name(codec_if, class, device, qualifier)
+ struct ac97_codec_if *codec_if;
+ char *class, *device, *qualifier;
+{
+ struct ac97_softc *as = (struct ac97_softc *)codec_if;
+ int idx;
+
+ for (idx = 0; idx < as->num_source_info; idx++) {
+ struct ac97_source_info *si = &as->source_info[idx];
+ if (ac97_str_equal(class, si->class) &&
+ ac97_str_equal(device, si->device) &&
+ ac97_str_equal(qualifier, si->qualifier))
+ return (idx);
+ }
+
+ return (-1);
+}
+
+int
ac97_mixer_get_port(codec_if, cp)
struct ac97_codec_if *codec_if;
mixer_ctrl_t *cp;
@@ -680,8 +703,9 @@ ac97_mixer_get_port(codec_if, cp)
struct audio_mixer_value *value = si->info;
u_int16_t l, r;
- if (cp->un.value.num_channels !=
- value->num_channels) return (EINVAL);
+ if ((cp->un.value.num_channels <= 0) ||
+ (cp->un.value.num_channels > value->num_channels))
+ return (EINVAL);
if (value->num_channels == 1) {
l = r = (val >> si->ofs) & mask;