Skip to content

Commit

Permalink
ALSA: usb-audio: clean up find_audio_control_unit()
Browse files Browse the repository at this point in the history
Use a struct to parse the audio units, and return usable descriptors
for all types. There's no need to limit the result set, except for some
kind of sanity check.

Signed-off-by: Daniel Mack <daniel@caiaq.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
  • Loading branch information
Daniel Mack authored and Takashi Iwai committed May 31, 2010
1 parent 2e0281d commit 67e1daa
Showing 1 changed file with 10 additions and 8 deletions.
18 changes: 10 additions & 8 deletions sound/usb/mixer.c
Original file line number Diff line number Diff line change
Expand Up @@ -165,22 +165,24 @@ static int check_mapped_selector_name(struct mixer_build *state, int unitid,

/*
* find an audio control unit with the given unit id
* this doesn't return any clock related units, so they need to be handled elsewhere
*/
static void *find_audio_control_unit(struct mixer_build *state, unsigned char unit)
{
unsigned char *p;
/* we just parse the header */
struct uac_feature_unit_descriptor *hdr = NULL;

p = NULL;
while ((p = snd_usb_find_desc(state->buffer, state->buflen, p,
USB_DT_CS_INTERFACE)) != NULL) {
if (p[0] >= 4 && p[2] >= UAC_INPUT_TERMINAL && p[2] <= UAC2_EXTENSION_UNIT_V2 && p[3] == unit)
return p;
while ((hdr = snd_usb_find_desc(state->buffer, state->buflen, hdr,
USB_DT_CS_INTERFACE)) != NULL) {
if (hdr->bLength >= 4 &&
hdr->bDescriptorSubtype >= UAC_INPUT_TERMINAL &&
hdr->bDescriptorSubtype <= UAC2_SAMPLE_RATE_CONVERTER &&
hdr->bUnitID == unit)
return hdr;
}

return NULL;
}


/*
* copy a string with the given id
*/
Expand Down

0 comments on commit 67e1daa

Please sign in to comment.