diff options
-rw-r--r-- | sys/dev/pci/azalia.c | 137 |
1 files changed, 77 insertions, 60 deletions
diff --git a/sys/dev/pci/azalia.c b/sys/dev/pci/azalia.c index a38095d970d..50662c9cf7e 100644 --- a/sys/dev/pci/azalia.c +++ b/sys/dev/pci/azalia.c @@ -1,4 +1,4 @@ -/* $OpenBSD: azalia.c,v 1.80 2008/12/21 20:17:16 jakemsr Exp $ */ +/* $OpenBSD: azalia.c,v 1.81 2008/12/21 20:32:46 jakemsr Exp $ */ /* $NetBSD: azalia.c,v 1.20 2006/05/07 08:31:44 kent Exp $ */ /*- @@ -245,6 +245,7 @@ int azalia_widget_init_connection(widget_t *, const codec_t *); int azalia_widget_check_conn(codec_t *, int, int); int azalia_widget_sole_conn(codec_t *, nid_t); #ifdef AZALIA_DEBUG +int azalia_widget_dump_info(const widget_t *, const codec_t *); int azalia_widget_print_audio(const widget_t *, const char *); int azalia_widget_print_pin(const widget_t *); #endif @@ -1284,10 +1285,15 @@ azalia_codec_init(codec_t *this) err = azalia_widget_init(&this->w[i], this, i); if (err) return err; + err = azalia_widget_init_connection(&this->w[i], this); + if (err) + return err; +#ifdef AZALIA_DEBUG + err = azalia_widget_dump_info(&this->w[i], this); + if (err) + return err; +#endif } - err = azalia_widget_label_widgets(this); - if (err) - return err; /* Find widgets without any enabled inputs and disable them. * Must be done after all widgets are initialized and * their connections created. @@ -1302,6 +1308,9 @@ azalia_codec_init(codec_t *this) err = this->init_dacgroup(this); if (err) return err; + err = azalia_widget_label_widgets(this); + if (err) + return err; #ifdef AZALIA_DEBUG for (i = 0; i < this->dacs.ngroups; i++) { DPRINTF(("%s: dacgroup[%d]:", __func__, i)); @@ -1318,7 +1327,6 @@ azalia_codec_init(codec_t *this) DPRINTF(("\n")); } #endif - err = azalia_codec_construct_format(this, 0, 0); if (err) return err; @@ -1755,7 +1763,6 @@ azalia_widget_label_widgets(codec_t *codec) bzero(&types, sizeof(types)); FOR_EACH_WIDGET(codec, i) { - DPRINTF(("%s: ", XNAME(codec->az))); w = &codec->w[i]; if (w->type == COP_AWTYPE_PIN_COMPLEX) { pins[w->d.pin.device]++; @@ -1789,35 +1796,6 @@ azalia_widget_label_widgets(codec_t *codec) } if (codec->init_widget != NULL) codec->init_widget(codec, w, w->nid); -#ifdef AZALIA_DEBUG - DPRINTF(("%s%2.2x wcap=%b\n", w->type == COP_AWTYPE_PIN_COMPLEX ? - pin_colors[w->d.pin.color] : wtypes[w->type], - w->nid, w->widgetcap, WIDGETCAP_BITS)); - if (w->widgetcap & COP_AWCAP_FORMATOV) - azalia_widget_print_audio(w, "\t"); - if (w->type == COP_AWTYPE_PIN_COMPLEX) - azalia_widget_print_pin(w); - - if (w->type == COP_AWTYPE_VOLUME_KNOB) - DPRINTF(("\tdelta=%d steps=%d\n", - !!(w->d.volume.cap & COP_VKCAP_DELTA), - COP_VKCAP_NUMSTEPS(w->d.volume.cap))); - - if ((w->widgetcap & COP_AWCAP_INAMP) && (w->widgetcap & COP_AWCAP_AMPOV)) - DPRINTF(("\tinamp: mute=%u size=%u steps=%u offset=%u\n", - (w->inamp_cap & COP_AMPCAP_MUTE) != 0, - COP_AMPCAP_STEPSIZE(w->inamp_cap), - COP_AMPCAP_NUMSTEPS(w->inamp_cap), - COP_AMPCAP_OFFSET(w->inamp_cap))); - - if ((w->widgetcap & COP_AWCAP_OUTAMP) && (w->widgetcap & COP_AWCAP_AMPOV)) - DPRINTF(("\toutamp: mute=%u size=%u steps=%u offset=%u\n", - (w->outamp_cap & COP_AMPCAP_MUTE) != 0, - COP_AMPCAP_STEPSIZE(w->outamp_cap), - COP_AMPCAP_NUMSTEPS(w->outamp_cap), - COP_AMPCAP_OFFSET(w->outamp_cap))); -#endif - azalia_widget_init_connection(w, codec); } return 0; } @@ -1995,38 +1973,83 @@ azalia_widget_init_pin(widget_t *this, const codec_t *codec) #ifdef AZALIA_DEBUG int +azalia_widget_dump_info(const widget_t *w, const codec_t *codec) +{ + int i; + + printf("%s: ", XNAME(codec->az)); + printf("%s%2.2x wcap=%b\n", w->type == COP_AWTYPE_PIN_COMPLEX ? + pin_colors[w->d.pin.color] : wtypes[w->type], + w->nid, w->widgetcap, WIDGETCAP_BITS); + if (w->widgetcap & COP_AWCAP_FORMATOV) + azalia_widget_print_audio(w, "\t"); + if (w->type == COP_AWTYPE_PIN_COMPLEX) + azalia_widget_print_pin(w); + + if (w->type == COP_AWTYPE_VOLUME_KNOB) + printf("\tdelta=%d steps=%d\n", + !!(w->d.volume.cap & COP_VKCAP_DELTA), + COP_VKCAP_NUMSTEPS(w->d.volume.cap)); + + if ((w->widgetcap & COP_AWCAP_INAMP) && + (w->widgetcap & COP_AWCAP_AMPOV)) + printf("\tinamp: mute=%u size=%u steps=%u offset=%u\n", + (w->inamp_cap & COP_AMPCAP_MUTE) != 0, + COP_AMPCAP_STEPSIZE(w->inamp_cap), + COP_AMPCAP_NUMSTEPS(w->inamp_cap), + COP_AMPCAP_OFFSET(w->inamp_cap)); + + if ((w->widgetcap & COP_AWCAP_OUTAMP) && + (w->widgetcap & COP_AWCAP_AMPOV)) + printf("\toutamp: mute=%u size=%u steps=%u offset=%u\n", + (w->outamp_cap & COP_AMPCAP_MUTE) != 0, + COP_AMPCAP_STEPSIZE(w->outamp_cap), + COP_AMPCAP_NUMSTEPS(w->outamp_cap), + COP_AMPCAP_OFFSET(w->outamp_cap)); + + if (w->nconnections > 0) { + printf("\tconnections=0x%x", w->connections[0]); + for (i = 1; i < w->nconnections; i++) + printf(",0x%x", w->connections[i]); + printf("; selected=0x%x\n", w->connections[w->selected]); + } + + return 0; +} + +int azalia_widget_print_pin(const widget_t *this) { - DPRINTF(("\tcap=%b\n", this->d.pin.cap, PINCAP_BITS)); - DPRINTF(("\t[%2.2d/%2.2d] ", CORB_CD_ASSOCIATION(this->d.pin.config), - CORB_CD_SEQUENCE(this->d.pin.config))); - DPRINTF(("color=%s ", pin_colors[CORB_CD_COLOR(this->d.pin.config)])); - DPRINTF(("device=%s ", pin_devices[CORB_CD_DEVICE(this->d.pin.config)])); - DPRINTF(("conn=%s ", pin_conn[CORB_CD_PORT(this->d.pin.config)])); - DPRINTF(("conntype=%s\n", pin_conntype[CORB_CD_CONNECTION(this->d.pin.config)])); - DPRINTF(("\tlocation=%s ", pin_geo[CORB_CD_LOC_GEO(this->d.pin.config)])); - DPRINTF(("chassis=%s ", pin_chass[CORB_CD_LOC_CHASS(this->d.pin.config)])); - DPRINTF(("special=")); + printf("\tcap=%b\n", this->d.pin.cap, PINCAP_BITS); + printf("\t[%2.2d/%2.2d] ", CORB_CD_ASSOCIATION(this->d.pin.config), + CORB_CD_SEQUENCE(this->d.pin.config)); + printf("color=%s ", pin_colors[CORB_CD_COLOR(this->d.pin.config)]); + printf("device=%s ", pin_devices[CORB_CD_DEVICE(this->d.pin.config)]); + printf("conn=%s ", pin_conn[CORB_CD_PORT(this->d.pin.config)]); + printf("conntype=%s\n", pin_conntype[CORB_CD_CONNECTION(this->d.pin.config)]); + printf("\tlocation=%s ", pin_geo[CORB_CD_LOC_GEO(this->d.pin.config)]); + printf("chassis=%s ", pin_chass[CORB_CD_LOC_CHASS(this->d.pin.config)]); + printf("special="); if (CORB_CD_LOC_GEO(this->d.pin.config) == CORB_CD_LOC_SPEC0) { if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_EXTERNAL) - DPRINTF(("rear-panel")); + printf("rear-panel"); else if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_INTERNAL) - DPRINTF(("riser")); + printf("riser"); else if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_LOC_OTHER) - DPRINTF(("mobile-lid-internal")); + printf("mobile-lid-internal"); } else if (CORB_CD_LOC_GEO(this->d.pin.config) == CORB_CD_LOC_SPEC1) { if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_EXTERNAL) - DPRINTF(("drive-bay")); + printf("drive-bay"); else if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_INTERNAL) - DPRINTF(("hdmi")); + printf("hdmi"); else if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_LOC_OTHER) - DPRINTF(("mobile-lid-external")); + printf("mobile-lid-external"); } else if (CORB_CD_LOC_GEO(this->d.pin.config) == CORB_CD_LOC_SPEC2) { if (CORB_CD_LOC_CHASS(this->d.pin.config) == CORB_CD_INTERNAL) - DPRINTF(("atapi")); + printf("atapi"); } else - DPRINTF(("none")); - DPRINTF(("\n")); + printf("none"); + printf("\n"); return 0; } @@ -2081,17 +2104,11 @@ azalia_widget_init_connection(widget_t *this, const codec_t *codec) } } if (length > 0) { - DPRINTF(("\tconnections=0x%x", this->connections[0])); - for (i = 1; i < length; i++) { - DPRINTF((",0x%x", this->connections[i])); - } - err = codec->comresp(codec, this->nid, CORB_GET_CONNECTION_SELECT_CONTROL, 0, &result); if (err) return err; this->selected = CORB_CSC_INDEX(result); - DPRINTF(("; selected=0x%x\n", this->connections[result])); } return 0; } |