diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2011-09-26 15:15:27 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2011-09-27 03:21:48 -0400 |
commit | 17d900c4a1b50bc191b3ca58cbd78acc04a1c5b3 (patch) | |
tree | 7640521988e285f1afa0e3dd44aa73a5333ccb38 /sound/usb | |
parent | 6b69a0e520a0dc6579901098d0810bcd2e1ea60b (diff) |
ALSA: usb-audio: increase control transfer timeout
There are certain devices that are reportedly so slow that they need
more than 100 ms to handle control transfers. Therefore, increase the
timeout in mixer(_quirks).c to 1000 ms.
The timeout parameter of snd_usb_ctl_msg() is now constant, so we can
drop it.
Reported-by: Felipe Balbi <balbi@ti.com>
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/usb')
-rw-r--r-- | sound/usb/clock.c | 12 | ||||
-rw-r--r-- | sound/usb/format.c | 4 | ||||
-rw-r--r-- | sound/usb/helper.c | 4 | ||||
-rw-r--r-- | sound/usb/helper.h | 2 | ||||
-rw-r--r-- | sound/usb/mixer.c | 6 | ||||
-rw-r--r-- | sound/usb/mixer_quirks.c | 10 | ||||
-rw-r--r-- | sound/usb/pcm.c | 4 | ||||
-rw-r--r-- | sound/usb/quirks.c | 8 |
8 files changed, 25 insertions, 25 deletions
diff --git a/sound/usb/clock.c b/sound/usb/clock.c index 075195e8661a..379baad3d5ad 100644 --- a/sound/usb/clock.c +++ b/sound/usb/clock.c | |||
@@ -91,7 +91,7 @@ static int uac_clock_selector_get_val(struct snd_usb_audio *chip, int selector_i | |||
91 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, | 91 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, |
92 | UAC2_CX_CLOCK_SELECTOR << 8, | 92 | UAC2_CX_CLOCK_SELECTOR << 8, |
93 | snd_usb_ctrl_intf(chip) | (selector_id << 8), | 93 | snd_usb_ctrl_intf(chip) | (selector_id << 8), |
94 | &buf, sizeof(buf), 1000); | 94 | &buf, sizeof(buf)); |
95 | 95 | ||
96 | if (ret < 0) | 96 | if (ret < 0) |
97 | return ret; | 97 | return ret; |
@@ -118,7 +118,7 @@ static bool uac_clock_source_is_valid(struct snd_usb_audio *chip, int source_id) | |||
118 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, | 118 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, |
119 | UAC2_CS_CONTROL_CLOCK_VALID << 8, | 119 | UAC2_CS_CONTROL_CLOCK_VALID << 8, |
120 | snd_usb_ctrl_intf(chip) | (source_id << 8), | 120 | snd_usb_ctrl_intf(chip) | (source_id << 8), |
121 | &data, sizeof(data), 1000); | 121 | &data, sizeof(data)); |
122 | 122 | ||
123 | if (err < 0) { | 123 | if (err < 0) { |
124 | snd_printk(KERN_WARNING "%s(): cannot get clock validity for id %d\n", | 124 | snd_printk(KERN_WARNING "%s(): cannot get clock validity for id %d\n", |
@@ -222,7 +222,7 @@ static int set_sample_rate_v1(struct snd_usb_audio *chip, int iface, | |||
222 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC_SET_CUR, | 222 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC_SET_CUR, |
223 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_OUT, | 223 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_OUT, |
224 | UAC_EP_CS_ATTR_SAMPLE_RATE << 8, ep, | 224 | UAC_EP_CS_ATTR_SAMPLE_RATE << 8, ep, |
225 | data, sizeof(data), 1000)) < 0) { | 225 | data, sizeof(data))) < 0) { |
226 | snd_printk(KERN_ERR "%d:%d:%d: cannot set freq %d to ep %#x\n", | 226 | snd_printk(KERN_ERR "%d:%d:%d: cannot set freq %d to ep %#x\n", |
227 | dev->devnum, iface, fmt->altsetting, rate, ep); | 227 | dev->devnum, iface, fmt->altsetting, rate, ep); |
228 | return err; | 228 | return err; |
@@ -231,7 +231,7 @@ static int set_sample_rate_v1(struct snd_usb_audio *chip, int iface, | |||
231 | if ((err = snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), UAC_GET_CUR, | 231 | if ((err = snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), UAC_GET_CUR, |
232 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_IN, | 232 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_IN, |
233 | UAC_EP_CS_ATTR_SAMPLE_RATE << 8, ep, | 233 | UAC_EP_CS_ATTR_SAMPLE_RATE << 8, ep, |
234 | data, sizeof(data), 1000)) < 0) { | 234 | data, sizeof(data))) < 0) { |
235 | snd_printk(KERN_WARNING "%d:%d:%d: cannot get freq at ep %#x\n", | 235 | snd_printk(KERN_WARNING "%d:%d:%d: cannot get freq at ep %#x\n", |
236 | dev->devnum, iface, fmt->altsetting, ep); | 236 | dev->devnum, iface, fmt->altsetting, ep); |
237 | return 0; /* some devices don't support reading */ | 237 | return 0; /* some devices don't support reading */ |
@@ -273,7 +273,7 @@ static int set_sample_rate_v2(struct snd_usb_audio *chip, int iface, | |||
273 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_OUT, | 273 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_OUT, |
274 | UAC2_CS_CONTROL_SAM_FREQ << 8, | 274 | UAC2_CS_CONTROL_SAM_FREQ << 8, |
275 | snd_usb_ctrl_intf(chip) | (clock << 8), | 275 | snd_usb_ctrl_intf(chip) | (clock << 8), |
276 | data, sizeof(data), 1000)) < 0) { | 276 | data, sizeof(data))) < 0) { |
277 | snd_printk(KERN_ERR "%d:%d:%d: cannot set freq %d (v2)\n", | 277 | snd_printk(KERN_ERR "%d:%d:%d: cannot set freq %d (v2)\n", |
278 | dev->devnum, iface, fmt->altsetting, rate); | 278 | dev->devnum, iface, fmt->altsetting, rate); |
279 | return err; | 279 | return err; |
@@ -283,7 +283,7 @@ static int set_sample_rate_v2(struct snd_usb_audio *chip, int iface, | |||
283 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, | 283 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, |
284 | UAC2_CS_CONTROL_SAM_FREQ << 8, | 284 | UAC2_CS_CONTROL_SAM_FREQ << 8, |
285 | snd_usb_ctrl_intf(chip) | (clock << 8), | 285 | snd_usb_ctrl_intf(chip) | (clock << 8), |
286 | data, sizeof(data), 1000)) < 0) { | 286 | data, sizeof(data))) < 0) { |
287 | snd_printk(KERN_WARNING "%d:%d:%d: cannot get freq (v2)\n", | 287 | snd_printk(KERN_WARNING "%d:%d:%d: cannot get freq (v2)\n", |
288 | dev->devnum, iface, fmt->altsetting); | 288 | dev->devnum, iface, fmt->altsetting); |
289 | return err; | 289 | return err; |
diff --git a/sound/usb/format.c b/sound/usb/format.c index 8d042dce0d16..89421d176570 100644 --- a/sound/usb/format.c +++ b/sound/usb/format.c | |||
@@ -286,7 +286,7 @@ static int parse_audio_format_rates_v2(struct snd_usb_audio *chip, | |||
286 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, | 286 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, |
287 | UAC2_CS_CONTROL_SAM_FREQ << 8, | 287 | UAC2_CS_CONTROL_SAM_FREQ << 8, |
288 | snd_usb_ctrl_intf(chip) | (clock << 8), | 288 | snd_usb_ctrl_intf(chip) | (clock << 8), |
289 | tmp, sizeof(tmp), 1000); | 289 | tmp, sizeof(tmp)); |
290 | 290 | ||
291 | if (ret < 0) { | 291 | if (ret < 0) { |
292 | snd_printk(KERN_ERR "%s(): unable to retrieve number of sample rates (clock %d)\n", | 292 | snd_printk(KERN_ERR "%s(): unable to retrieve number of sample rates (clock %d)\n", |
@@ -307,7 +307,7 @@ static int parse_audio_format_rates_v2(struct snd_usb_audio *chip, | |||
307 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, | 307 | USB_TYPE_CLASS | USB_RECIP_INTERFACE | USB_DIR_IN, |
308 | UAC2_CS_CONTROL_SAM_FREQ << 8, | 308 | UAC2_CS_CONTROL_SAM_FREQ << 8, |
309 | snd_usb_ctrl_intf(chip) | (clock << 8), | 309 | snd_usb_ctrl_intf(chip) | (clock << 8), |
310 | data, data_size, 1000); | 310 | data, data_size); |
311 | 311 | ||
312 | if (ret < 0) { | 312 | if (ret < 0) { |
313 | snd_printk(KERN_ERR "%s(): unable to retrieve sample rate range (clock %d)\n", | 313 | snd_printk(KERN_ERR "%s(): unable to retrieve sample rate range (clock %d)\n", |
diff --git a/sound/usb/helper.c b/sound/usb/helper.c index f280c1903c25..9eed8f40b179 100644 --- a/sound/usb/helper.c +++ b/sound/usb/helper.c | |||
@@ -81,7 +81,7 @@ void *snd_usb_find_csint_desc(void *buffer, int buflen, void *after, u8 dsubtype | |||
81 | */ | 81 | */ |
82 | int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe, __u8 request, | 82 | int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe, __u8 request, |
83 | __u8 requesttype, __u16 value, __u16 index, void *data, | 83 | __u8 requesttype, __u16 value, __u16 index, void *data, |
84 | __u16 size, int timeout) | 84 | __u16 size) |
85 | { | 85 | { |
86 | int err; | 86 | int err; |
87 | void *buf = NULL; | 87 | void *buf = NULL; |
@@ -92,7 +92,7 @@ int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe, __u8 request, | |||
92 | return -ENOMEM; | 92 | return -ENOMEM; |
93 | } | 93 | } |
94 | err = usb_control_msg(dev, pipe, request, requesttype, | 94 | err = usb_control_msg(dev, pipe, request, requesttype, |
95 | value, index, buf, size, timeout); | 95 | value, index, buf, size, 1000); |
96 | if (size > 0) { | 96 | if (size > 0) { |
97 | memcpy(data, buf, size); | 97 | memcpy(data, buf, size); |
98 | kfree(buf); | 98 | kfree(buf); |
diff --git a/sound/usb/helper.h b/sound/usb/helper.h index 09bd943c43bf..805c300dd004 100644 --- a/sound/usb/helper.h +++ b/sound/usb/helper.h | |||
@@ -8,7 +8,7 @@ void *snd_usb_find_csint_desc(void *descstart, int desclen, void *after, u8 dsub | |||
8 | 8 | ||
9 | int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe, | 9 | int snd_usb_ctl_msg(struct usb_device *dev, unsigned int pipe, |
10 | __u8 request, __u8 requesttype, __u16 value, __u16 index, | 10 | __u8 request, __u8 requesttype, __u16 value, __u16 index, |
11 | void *data, __u16 size, int timeout); | 11 | void *data, __u16 size); |
12 | 12 | ||
13 | unsigned char snd_usb_parse_datainterval(struct snd_usb_audio *chip, | 13 | unsigned char snd_usb_parse_datainterval(struct snd_usb_audio *chip, |
14 | struct usb_host_interface *alts); | 14 | struct usb_host_interface *alts); |
diff --git a/sound/usb/mixer.c b/sound/usb/mixer.c index 78a5abda6793..b13b7ac5bad9 100644 --- a/sound/usb/mixer.c +++ b/sound/usb/mixer.c | |||
@@ -296,7 +296,7 @@ static int get_ctl_value_v1(struct usb_mixer_elem_info *cval, int request, int v | |||
296 | if (snd_usb_ctl_msg(chip->dev, usb_rcvctrlpipe(chip->dev, 0), request, | 296 | if (snd_usb_ctl_msg(chip->dev, usb_rcvctrlpipe(chip->dev, 0), request, |
297 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, | 297 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, |
298 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), | 298 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), |
299 | buf, val_len, 100) >= val_len) { | 299 | buf, val_len) >= val_len) { |
300 | *value_ret = convert_signed_value(cval, snd_usb_combine_bytes(buf, val_len)); | 300 | *value_ret = convert_signed_value(cval, snd_usb_combine_bytes(buf, val_len)); |
301 | snd_usb_autosuspend(cval->mixer->chip); | 301 | snd_usb_autosuspend(cval->mixer->chip); |
302 | return 0; | 302 | return 0; |
@@ -333,7 +333,7 @@ static int get_ctl_value_v2(struct usb_mixer_elem_info *cval, int request, int v | |||
333 | ret = snd_usb_ctl_msg(chip->dev, usb_rcvctrlpipe(chip->dev, 0), bRequest, | 333 | ret = snd_usb_ctl_msg(chip->dev, usb_rcvctrlpipe(chip->dev, 0), bRequest, |
334 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, | 334 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_IN, |
335 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), | 335 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), |
336 | buf, size, 1000); | 336 | buf, size); |
337 | snd_usb_autosuspend(chip); | 337 | snd_usb_autosuspend(chip); |
338 | 338 | ||
339 | if (ret < 0) { | 339 | if (ret < 0) { |
@@ -445,7 +445,7 @@ int snd_usb_mixer_set_ctl_value(struct usb_mixer_elem_info *cval, | |||
445 | usb_sndctrlpipe(chip->dev, 0), request, | 445 | usb_sndctrlpipe(chip->dev, 0), request, |
446 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_OUT, | 446 | USB_RECIP_INTERFACE | USB_TYPE_CLASS | USB_DIR_OUT, |
447 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), | 447 | validx, snd_usb_ctrl_intf(chip) | (cval->id << 8), |
448 | buf, val_len, 100) >= 0) { | 448 | buf, val_len) >= 0) { |
449 | snd_usb_autosuspend(chip); | 449 | snd_usb_autosuspend(chip); |
450 | return 0; | 450 | return 0; |
451 | } | 451 | } |
diff --git a/sound/usb/mixer_quirks.c b/sound/usb/mixer_quirks.c index 3d0f4873112b..ab125ee0b0f0 100644 --- a/sound/usb/mixer_quirks.c +++ b/sound/usb/mixer_quirks.c | |||
@@ -190,18 +190,18 @@ static int snd_audigy2nx_led_put(struct snd_kcontrol *kcontrol, struct snd_ctl_e | |||
190 | err = snd_usb_ctl_msg(mixer->chip->dev, | 190 | err = snd_usb_ctl_msg(mixer->chip->dev, |
191 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, | 191 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, |
192 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 192 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
193 | !value, 0, NULL, 0, 100); | 193 | !value, 0, NULL, 0); |
194 | /* USB X-Fi S51 Pro */ | 194 | /* USB X-Fi S51 Pro */ |
195 | if (mixer->chip->usb_id == USB_ID(0x041e, 0x30df)) | 195 | if (mixer->chip->usb_id == USB_ID(0x041e, 0x30df)) |
196 | err = snd_usb_ctl_msg(mixer->chip->dev, | 196 | err = snd_usb_ctl_msg(mixer->chip->dev, |
197 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, | 197 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, |
198 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 198 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
199 | !value, 0, NULL, 0, 100); | 199 | !value, 0, NULL, 0); |
200 | else | 200 | else |
201 | err = snd_usb_ctl_msg(mixer->chip->dev, | 201 | err = snd_usb_ctl_msg(mixer->chip->dev, |
202 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, | 202 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x24, |
203 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 203 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
204 | value, index + 2, NULL, 0, 100); | 204 | value, index + 2, NULL, 0); |
205 | if (err < 0) | 205 | if (err < 0) |
206 | return err; | 206 | return err; |
207 | mixer->audigy2nx_leds[index] = value; | 207 | mixer->audigy2nx_leds[index] = value; |
@@ -299,7 +299,7 @@ static void snd_audigy2nx_proc_read(struct snd_info_entry *entry, | |||
299 | usb_rcvctrlpipe(mixer->chip->dev, 0), | 299 | usb_rcvctrlpipe(mixer->chip->dev, 0), |
300 | UAC_GET_MEM, USB_DIR_IN | USB_TYPE_CLASS | | 300 | UAC_GET_MEM, USB_DIR_IN | USB_TYPE_CLASS | |
301 | USB_RECIP_INTERFACE, 0, | 301 | USB_RECIP_INTERFACE, 0, |
302 | jacks[i].unitid << 8, buf, 3, 100); | 302 | jacks[i].unitid << 8, buf, 3); |
303 | if (err == 3 && (buf[0] == 3 || buf[0] == 6)) | 303 | if (err == 3 && (buf[0] == 3 || buf[0] == 6)) |
304 | snd_iprintf(buffer, "%02x %02x\n", buf[1], buf[2]); | 304 | snd_iprintf(buffer, "%02x %02x\n", buf[1], buf[2]); |
305 | else | 305 | else |
@@ -332,7 +332,7 @@ static int snd_xonar_u1_switch_put(struct snd_kcontrol *kcontrol, | |||
332 | err = snd_usb_ctl_msg(mixer->chip->dev, | 332 | err = snd_usb_ctl_msg(mixer->chip->dev, |
333 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x08, | 333 | usb_sndctrlpipe(mixer->chip->dev, 0), 0x08, |
334 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 334 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
335 | 50, 0, &new_status, 1, 100); | 335 | 50, 0, &new_status, 1); |
336 | if (err < 0) | 336 | if (err < 0) |
337 | return err; | 337 | return err; |
338 | mixer->xonar_u1_status = new_status; | 338 | mixer->xonar_u1_status = new_status; |
diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c index b5bc870878db..0220b0f335b9 100644 --- a/sound/usb/pcm.c +++ b/sound/usb/pcm.c | |||
@@ -152,7 +152,7 @@ static int init_pitch_v1(struct snd_usb_audio *chip, int iface, | |||
152 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC_SET_CUR, | 152 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC_SET_CUR, |
153 | USB_TYPE_CLASS|USB_RECIP_ENDPOINT|USB_DIR_OUT, | 153 | USB_TYPE_CLASS|USB_RECIP_ENDPOINT|USB_DIR_OUT, |
154 | UAC_EP_CS_ATTR_PITCH_CONTROL << 8, ep, | 154 | UAC_EP_CS_ATTR_PITCH_CONTROL << 8, ep, |
155 | data, sizeof(data), 1000)) < 0) { | 155 | data, sizeof(data))) < 0) { |
156 | snd_printk(KERN_ERR "%d:%d:%d: cannot set enable PITCH\n", | 156 | snd_printk(KERN_ERR "%d:%d:%d: cannot set enable PITCH\n", |
157 | dev->devnum, iface, ep); | 157 | dev->devnum, iface, ep); |
158 | return err; | 158 | return err; |
@@ -176,7 +176,7 @@ static int init_pitch_v2(struct snd_usb_audio *chip, int iface, | |||
176 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC2_CS_CUR, | 176 | if ((err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), UAC2_CS_CUR, |
177 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_OUT, | 177 | USB_TYPE_CLASS | USB_RECIP_ENDPOINT | USB_DIR_OUT, |
178 | UAC2_EP_CS_PITCH << 8, 0, | 178 | UAC2_EP_CS_PITCH << 8, 0, |
179 | data, sizeof(data), 1000)) < 0) { | 179 | data, sizeof(data))) < 0) { |
180 | snd_printk(KERN_ERR "%d:%d:%d: cannot set enable PITCH (v2)\n", | 180 | snd_printk(KERN_ERR "%d:%d:%d: cannot set enable PITCH (v2)\n", |
181 | dev->devnum, iface, fmt->altsetting); | 181 | dev->devnum, iface, fmt->altsetting); |
182 | return err; | 182 | return err; |
diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c index 556edea28b90..2e5bc7344026 100644 --- a/sound/usb/quirks.c +++ b/sound/usb/quirks.c | |||
@@ -340,7 +340,7 @@ static int snd_usb_extigy_boot_quirk(struct usb_device *dev, struct usb_interfac | |||
340 | snd_printdd("sending Extigy boot sequence...\n"); | 340 | snd_printdd("sending Extigy boot sequence...\n"); |
341 | /* Send message to force it to reconnect with full interface. */ | 341 | /* Send message to force it to reconnect with full interface. */ |
342 | err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev,0), | 342 | err = snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev,0), |
343 | 0x10, 0x43, 0x0001, 0x000a, NULL, 0, 1000); | 343 | 0x10, 0x43, 0x0001, 0x000a, NULL, 0); |
344 | if (err < 0) snd_printdd("error sending boot message: %d\n", err); | 344 | if (err < 0) snd_printdd("error sending boot message: %d\n", err); |
345 | err = usb_get_descriptor(dev, USB_DT_DEVICE, 0, | 345 | err = usb_get_descriptor(dev, USB_DT_DEVICE, 0, |
346 | &dev->descriptor, sizeof(dev->descriptor)); | 346 | &dev->descriptor, sizeof(dev->descriptor)); |
@@ -361,11 +361,11 @@ static int snd_usb_audigy2nx_boot_quirk(struct usb_device *dev) | |||
361 | 361 | ||
362 | snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), 0x2a, | 362 | snd_usb_ctl_msg(dev, usb_rcvctrlpipe(dev, 0), 0x2a, |
363 | USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 363 | USB_DIR_IN | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
364 | 0, 0, &buf, 1, 1000); | 364 | 0, 0, &buf, 1); |
365 | if (buf == 0) { | 365 | if (buf == 0) { |
366 | snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), 0x29, | 366 | snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), 0x29, |
367 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, | 367 | USB_DIR_OUT | USB_TYPE_VENDOR | USB_RECIP_OTHER, |
368 | 1, 2000, NULL, 0, 1000); | 368 | 1, 2000, NULL, 0); |
369 | return -ENODEV; | 369 | return -ENODEV; |
370 | } | 370 | } |
371 | return 0; | 371 | return 0; |
@@ -408,7 +408,7 @@ static int snd_usb_cm106_write_int_reg(struct usb_device *dev, int reg, u16 valu | |||
408 | buf[3] = reg; | 408 | buf[3] = reg; |
409 | return snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), USB_REQ_SET_CONFIGURATION, | 409 | return snd_usb_ctl_msg(dev, usb_sndctrlpipe(dev, 0), USB_REQ_SET_CONFIGURATION, |
410 | USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_ENDPOINT, | 410 | USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_ENDPOINT, |
411 | 0, 0, &buf, 4, 1000); | 411 | 0, 0, &buf, 4); |
412 | } | 412 | } |
413 | 413 | ||
414 | static int snd_usb_cm106_boot_quirk(struct usb_device *dev) | 414 | static int snd_usb_cm106_boot_quirk(struct usb_device *dev) |