summaryrefslogtreecommitdiff
path: root/sys/dev/pci/azalia_codec.c
diff options
context:
space:
mode:
authorDeanna Phillips <deanna@cvs.openbsd.org>2007-07-23 02:03:43 +0000
committerDeanna Phillips <deanna@cvs.openbsd.org>2007-07-23 02:03:43 +0000
commitbcc609107f724e0c79ac8f84ea1045004e235ffa (patch)
tree1d1cd35ae029559e26778d376ab017fd7d2a55a9 /sys/dev/pci/azalia_codec.c
parentb4375cec7e9617f93861387f019e62e5ebaf3c00 (diff)
We will never make a mixer item out of the pin control operation, so
move it out of azalia_generic_mixer_set into its own function, azalia_generic_mixer_pinctrl. From kent@netbsd. In azalia_stac9200_mixer_init, let the unsolicited event handler make the initial headphone vs speaker choice. Removes some duplicate code. These changes only affect STAC9200. Tested by krw@ on a Latitude D620.
Diffstat (limited to 'sys/dev/pci/azalia_codec.c')
-rw-r--r--sys/dev/pci/azalia_codec.c93
1 files changed, 23 insertions, 70 deletions
diff --git a/sys/dev/pci/azalia_codec.c b/sys/dev/pci/azalia_codec.c
index 67007d0e8e4..c3306d450f9 100644
--- a/sys/dev/pci/azalia_codec.c
+++ b/sys/dev/pci/azalia_codec.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: azalia_codec.c,v 1.22 2007/07/07 16:33:38 deanna Exp $ */
+/* $OpenBSD: azalia_codec.c,v 1.23 2007/07/23 02:03:42 deanna Exp $ */
/* $NetBSD: azalia_codec.c,v 1.8 2006/05/10 11:17:27 kent Exp $ */
/*-
@@ -77,6 +77,7 @@ int azalia_generic_mixer_delete(codec_t *);
int azalia_generic_mixer_ensure_capacity(codec_t *, size_t);
int azalia_generic_mixer_get(const codec_t *, nid_t, int, mixer_ctrl_t *);
int azalia_generic_mixer_set(codec_t *, nid_t, int, const mixer_ctrl_t *);
+int azalia_generic_mixer_pinctrl(codec_t *, nid_t, uint32_t);
u_char azalia_generic_mixer_from_device_value
(const codec_t *, nid_t, int, uint32_t );
uint32_t azalia_generic_mixer_to_device_value
@@ -1221,28 +1222,6 @@ azalia_generic_mixer_set(codec_t *this, nid_t nid, int target, const mixer_ctrl_
return err;
}
- /*
- * pin control: enable/disable. for bidirectional pins, set
- * direction with MI_TARGET_PINDIR after enabling.
- */
-
- else if (target == MI_TARGET_PINCTRL) {
- if (mc->un.ord >= 2)
- return EINVAL;
- err = this->comresp(this, nid,
- CORB_GET_PIN_WIDGET_CONTROL, 0, &result);
- if (err)
- return err;
- if (mc->un.ord == 0) /* disable */
- result &= ~(CORB_PWC_OUTPUT | CORB_PWC_INPUT);
- else
- result |= CORB_PWC_OUTPUT | CORB_PWC_INPUT;
- err = this->comresp(this, nid,
- CORB_SET_PIN_WIDGET_CONTROL, result, &result);
- if (err)
- return err;
- }
-
/* pin headphone-boost */
else if (target == MI_TARGET_PINBOOST) {
if (mc->un.ord >= 2)
@@ -1305,6 +1284,21 @@ azalia_generic_mixer_set(codec_t *this, nid_t nid, int target, const mixer_ctrl_
return 0;
}
+int
+azalia_generic_mixer_pinctrl(codec_t *this, nid_t nid, uint32_t value)
+{
+ int err;
+ uint32_t result;
+
+ err = this->comresp(this, nid, CORB_GET_PIN_WIDGET_CONTROL, 0, &result);
+ if (err)
+ return err;
+ result &= ~(CORB_PWC_OUTPUT | CORB_PWC_INPUT);
+ result |= value & (CORB_PWC_OUTPUT | CORB_PWC_INPUT);
+ return this->comresp(this, nid,
+ CORB_SET_PIN_WIDGET_CONTROL, result, NULL);
+}
+
u_char
azalia_generic_mixer_from_device_value(const codec_t *this, nid_t nid, int target,
uint32_t dv)
@@ -2362,8 +2356,6 @@ int
azalia_stac9200_mixer_init(codec_t *this)
{
mixer_ctrl_t mc;
- int err;
- uint32_t value;
this->nmixers = sizeof(stac9200_mixer_items) / sizeof(mixer_item_t);
this->mixers = malloc(sizeof(mixer_item_t) * this->nmixers,
@@ -2401,31 +2393,8 @@ azalia_stac9200_mixer_init(codec_t *this)
CORB_SET_UNSOLICITED_RESPONSE,
CORB_UNSOL_ENABLE | STAC9200_EVENT_HP, NULL);
- /* make initial hp vs speaker choice */
+ azalia_stac9200_unsol_event(this, STAC9200_EVENT_HP);
- err = this->comresp(this, STAC9200_NID_HP,
- CORB_GET_PIN_SENSE, 0, &value);
- if (err)
- return err;
- if (value & CORB_PS_PRESENCE) {
- mc.un.ord = 0;
- azalia_generic_mixer_set(this, STAC9200_NID_SPEAKER,
- MI_TARGET_PINCTRL, &mc);
- mc.un.ord = 1;
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINCTRL, &mc);
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINDIR, &mc);
- } else {
- mc.un.ord = 0;
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINCTRL, &mc);
- mc.un.ord = 1;
- azalia_generic_mixer_set(this, STAC9200_NID_SPEAKER,
- MI_TARGET_PINCTRL, &mc);
- azalia_generic_mixer_set(this, STAC9200_NID_SPEAKER,
- MI_TARGET_PINDIR, &mc);
- }
return 0;
}
int
@@ -2433,37 +2402,21 @@ azalia_stac9200_unsol_event(codec_t *this, int tag)
{
int err;
uint32_t value;
- mixer_ctrl_t mc;
switch (tag) {
case STAC9200_EVENT_HP:
err = this->comresp(this, STAC9200_NID_HP,
CORB_GET_PIN_SENSE, 0, &value);
if (err)
- return err;
+ break;
if (value & CORB_PS_PRESENCE) {
DPRINTF(("%s: headphone inserted\n", __func__));
- mc.un.ord = 0; /* disable */
- azalia_generic_mixer_set(this,
- STAC9200_NID_SPEAKER,
- MI_TARGET_PINCTRL, &mc);
- mc.un.ord = 1; /* enable and direction output */
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINCTRL, &mc);
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINDIR, &mc);
+ azalia_generic_mixer_pinctrl(this,
+ STAC9200_NID_SPEAKER, 0);
} else {
DPRINTF(("%s: headphone pulled\n", __func__));
- mc.un.ord = 0;
- azalia_generic_mixer_set(this, STAC9200_NID_HP,
- MI_TARGET_PINCTRL, &mc);
- mc.un.ord = 1;
- azalia_generic_mixer_set(this,
- STAC9200_NID_SPEAKER,
- MI_TARGET_PINCTRL, &mc);
- azalia_generic_mixer_set(this,
- STAC9200_NID_SPEAKER,
- MI_TARGET_PINDIR, &mc);
+ azalia_generic_mixer_pinctrl(this,
+ STAC9200_NID_SPEAKER, CORB_PWC_OUTPUT);
}
break;
default: