diff options
Diffstat (limited to 'sys/dev/pci/azalia.c')
-rw-r--r-- | sys/dev/pci/azalia.c | 47 |
1 files changed, 11 insertions, 36 deletions
diff --git a/sys/dev/pci/azalia.c b/sys/dev/pci/azalia.c index 76317902d9c..24a9aa90aec 100644 --- a/sys/dev/pci/azalia.c +++ b/sys/dev/pci/azalia.c @@ -1,4 +1,4 @@ -/* $OpenBSD: azalia.c,v 1.89 2008/12/23 00:03:16 jakemsr Exp $ */ +/* $OpenBSD: azalia.c,v 1.90 2008/12/23 00:20:03 jakemsr Exp $ */ /* $NetBSD: azalia.c,v 1.20 2006/05/07 08:31:44 kent Exp $ */ /*- @@ -2166,8 +2166,6 @@ azalia_widget_init_connection(widget_t *this, const codec_t *codec) int err; boolean_t longform; int length, i; - nid_t *connections; - int nconnections, nconn; this->selected = -1; if ((this->widgetcap & COP_AWCAP_CONNLIST) == 0) @@ -2181,9 +2179,10 @@ azalia_widget_init_connection(widget_t *this, const codec_t *codec) length = COP_CLL_LENGTH(result); if (length == 0) return 0; - nconnections = length; - connections = malloc(sizeof(nid_t) * (length + 3), M_DEVBUF, M_NOWAIT); - if (connections == NULL) { + this->nconnections = length; + this->connections = malloc(sizeof(nid_t) * (length + 3), + M_DEVBUF, M_NOWAIT); + if (this->connections == NULL) { printf("%s: out of memory\n", XNAME(codec->az)); return ENOMEM; } @@ -2193,8 +2192,8 @@ azalia_widget_init_connection(widget_t *this, const codec_t *codec) CORB_GET_CONNECTION_LIST_ENTRY, i, &result); if (err) return err; - connections[i++] = CORB_CLE_LONG_0(result); - connections[i++] = CORB_CLE_LONG_1(result); + this->connections[i++] = CORB_CLE_LONG_0(result); + this->connections[i++] = CORB_CLE_LONG_1(result); } } else { for (i = 0; i < length;) { @@ -2202,36 +2201,12 @@ azalia_widget_init_connection(widget_t *this, const codec_t *codec) CORB_GET_CONNECTION_LIST_ENTRY, i, &result); if (err) return err; - connections[i++] = CORB_CLE_SHORT_0(result); - connections[i++] = CORB_CLE_SHORT_1(result); - connections[i++] = CORB_CLE_SHORT_2(result); - connections[i++] = CORB_CLE_SHORT_3(result); + this->connections[i++] = CORB_CLE_SHORT_0(result); + this->connections[i++] = CORB_CLE_SHORT_1(result); + this->connections[i++] = CORB_CLE_SHORT_2(result); + this->connections[i++] = CORB_CLE_SHORT_3(result); } } - - /* don't add invalid widgets to the connection list */ - nconn = 0; - for (i = 0; i < nconnections; i++) { - if (VALID_WIDGET_NID(connections[i], codec)) - nconn++; - else - DPRINTF(("%s: nid %2.2x invalid connection: %2.2x\n", - XNAME(codec->az), this->nid, connections[i])); - } - this->nconnections = nconn; - this->connections = malloc(sizeof(nid_t) * this->nconnections, - M_DEVBUF, M_NOWAIT); - if (this->connections == NULL) { - printf("%s: out of memory\n", XNAME(codec->az)); - return ENOMEM; - } - nconn = 0; - for (i = 0; i < nconnections && nconn < this->nconnections; i++) { - if (VALID_WIDGET_NID(connections[i], codec)) - this->connections[nconn++] = connections[i]; - } - free(connections, M_DEVBUF); - if (length > 0) { err = codec->comresp(codec, this->nid, CORB_GET_CONNECTION_SELECT_CONTROL, 0, &result); |