diff options
Diffstat (limited to 'drivers/media/radio')
-rw-r--r-- | drivers/media/radio/radio-mr800.c | 78 |
1 files changed, 26 insertions, 52 deletions
diff --git a/drivers/media/radio/radio-mr800.c b/drivers/media/radio/radio-mr800.c index ac2107378942..5506fac5fd49 100644 --- a/drivers/media/radio/radio-mr800.c +++ b/drivers/media/radio/radio-mr800.c | |||
@@ -186,8 +186,10 @@ static int amradio_set_mute(struct amradio_device *radio, char argument) | |||
186 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), | 186 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), |
187 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); | 187 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); |
188 | 188 | ||
189 | if (retval < 0 || size != BUFFER_LENGTH) | 189 | if (retval < 0 || size != BUFFER_LENGTH) { |
190 | amradio_dev_warn(&radio->videodev.dev, "set mute failed\n"); | ||
190 | return retval; | 191 | return retval; |
192 | } | ||
191 | 193 | ||
192 | radio->muted = argument; | 194 | radio->muted = argument; |
193 | 195 | ||
@@ -216,7 +218,7 @@ static int amradio_setfreq(struct amradio_device *radio, int freq) | |||
216 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); | 218 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); |
217 | 219 | ||
218 | if (retval < 0 || size != BUFFER_LENGTH) | 220 | if (retval < 0 || size != BUFFER_LENGTH) |
219 | return retval; | 221 | goto out_err; |
220 | 222 | ||
221 | /* frequency is calculated from freq_send and placed in first 2 bytes */ | 223 | /* frequency is calculated from freq_send and placed in first 2 bytes */ |
222 | radio->buffer[0] = (freq_send >> 8) & 0xff; | 224 | radio->buffer[0] = (freq_send >> 8) & 0xff; |
@@ -230,6 +232,14 @@ static int amradio_setfreq(struct amradio_device *radio, int freq) | |||
230 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), | 232 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), |
231 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); | 233 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); |
232 | 234 | ||
235 | if (retval < 0 || size != BUFFER_LENGTH) | ||
236 | goto out_err; | ||
237 | |||
238 | goto out; | ||
239 | |||
240 | out_err: | ||
241 | amradio_dev_warn(&radio->videodev.dev, "set frequency failed\n"); | ||
242 | out: | ||
233 | return retval; | 243 | return retval; |
234 | } | 244 | } |
235 | 245 | ||
@@ -252,8 +262,10 @@ static int amradio_set_stereo(struct amradio_device *radio, char argument) | |||
252 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), | 262 | retval = usb_bulk_msg(radio->usbdev, usb_sndintpipe(radio->usbdev, 2), |
253 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); | 263 | (void *) (radio->buffer), BUFFER_LENGTH, &size, USB_TIMEOUT); |
254 | 264 | ||
255 | if (retval < 0 || size != BUFFER_LENGTH) | 265 | if (retval < 0 || size != BUFFER_LENGTH) { |
266 | amradio_dev_warn(&radio->videodev.dev, "set stereo failed\n"); | ||
256 | return retval; | 267 | return retval; |
268 | } | ||
257 | 269 | ||
258 | if (argument == WANT_STEREO) | 270 | if (argument == WANT_STEREO) |
259 | radio->stereo = 1; | 271 | radio->stereo = 1; |
@@ -314,9 +326,6 @@ static int vidioc_g_tuner(struct file *file, void *priv, | |||
314 | * amradio_set_stereo shouldn't be here | 326 | * amradio_set_stereo shouldn't be here |
315 | */ | 327 | */ |
316 | retval = amradio_set_stereo(radio, WANT_STEREO); | 328 | retval = amradio_set_stereo(radio, WANT_STEREO); |
317 | if (retval < 0) | ||
318 | amradio_dev_warn(&radio->videodev.dev, | ||
319 | "set stereo failed\n"); | ||
320 | 329 | ||
321 | strcpy(v->name, "FM"); | 330 | strcpy(v->name, "FM"); |
322 | v->type = V4L2_TUNER_RADIO; | 331 | v->type = V4L2_TUNER_RADIO; |
@@ -348,15 +357,9 @@ static int vidioc_s_tuner(struct file *file, void *priv, | |||
348 | switch (v->audmode) { | 357 | switch (v->audmode) { |
349 | case V4L2_TUNER_MODE_MONO: | 358 | case V4L2_TUNER_MODE_MONO: |
350 | retval = amradio_set_stereo(radio, WANT_MONO); | 359 | retval = amradio_set_stereo(radio, WANT_MONO); |
351 | if (retval < 0) | ||
352 | amradio_dev_warn(&radio->videodev.dev, | ||
353 | "set mono failed\n"); | ||
354 | break; | 360 | break; |
355 | case V4L2_TUNER_MODE_STEREO: | 361 | case V4L2_TUNER_MODE_STEREO: |
356 | retval = amradio_set_stereo(radio, WANT_STEREO); | 362 | retval = amradio_set_stereo(radio, WANT_STEREO); |
357 | if (retval < 0) | ||
358 | amradio_dev_warn(&radio->videodev.dev, | ||
359 | "set stereo failed\n"); | ||
360 | break; | 363 | break; |
361 | } | 364 | } |
362 | 365 | ||
@@ -373,9 +376,6 @@ static int vidioc_s_frequency(struct file *file, void *priv, | |||
373 | radio->curfreq = f->frequency; | 376 | radio->curfreq = f->frequency; |
374 | 377 | ||
375 | retval = amradio_setfreq(radio, radio->curfreq); | 378 | retval = amradio_setfreq(radio, radio->curfreq); |
376 | if (retval < 0) | ||
377 | amradio_dev_warn(&radio->videodev.dev, | ||
378 | "set frequency failed\n"); | ||
379 | 379 | ||
380 | return retval; | 380 | return retval; |
381 | } | 381 | } |
@@ -428,19 +428,11 @@ static int vidioc_s_ctrl(struct file *file, void *priv, | |||
428 | 428 | ||
429 | switch (ctrl->id) { | 429 | switch (ctrl->id) { |
430 | case V4L2_CID_AUDIO_MUTE: | 430 | case V4L2_CID_AUDIO_MUTE: |
431 | if (ctrl->value) { | 431 | if (ctrl->value) |
432 | retval = amradio_set_mute(radio, AMRADIO_STOP); | 432 | retval = amradio_set_mute(radio, AMRADIO_STOP); |
433 | if (retval < 0) { | 433 | else |
434 | amradio_dev_warn(&radio->videodev.dev, | ||
435 | "amradio_stop failed\n"); | ||
436 | } | ||
437 | } else { | ||
438 | retval = amradio_set_mute(radio, AMRADIO_START); | 434 | retval = amradio_set_mute(radio, AMRADIO_START); |
439 | if (retval < 0) { | 435 | |
440 | amradio_dev_warn(&radio->videodev.dev, | ||
441 | "amradio_start failed\n"); | ||
442 | } | ||
443 | } | ||
444 | break; | 436 | break; |
445 | } | 437 | } |
446 | 438 | ||
@@ -488,16 +480,12 @@ static int usb_amradio_init(struct amradio_device *radio) | |||
488 | int retval; | 480 | int retval; |
489 | 481 | ||
490 | retval = amradio_set_mute(radio, AMRADIO_STOP); | 482 | retval = amradio_set_mute(radio, AMRADIO_STOP); |
491 | if (retval < 0) { | 483 | if (retval) |
492 | amradio_dev_warn(&radio->videodev.dev, "amradio_stop failed\n"); | ||
493 | goto out_err; | 484 | goto out_err; |
494 | } | ||
495 | 485 | ||
496 | retval = amradio_set_stereo(radio, WANT_STEREO); | 486 | retval = amradio_set_stereo(radio, WANT_STEREO); |
497 | if (retval < 0) { | 487 | if (retval) |
498 | amradio_dev_warn(&radio->videodev.dev, "set stereo failed\n"); | ||
499 | goto out_err; | 488 | goto out_err; |
500 | } | ||
501 | 489 | ||
502 | radio->initialized = 1; | 490 | radio->initialized = 1; |
503 | goto out; | 491 | goto out; |
@@ -570,14 +558,11 @@ unlock: | |||
570 | static int usb_amradio_suspend(struct usb_interface *intf, pm_message_t message) | 558 | static int usb_amradio_suspend(struct usb_interface *intf, pm_message_t message) |
571 | { | 559 | { |
572 | struct amradio_device *radio = usb_get_intfdata(intf); | 560 | struct amradio_device *radio = usb_get_intfdata(intf); |
573 | int retval; | ||
574 | 561 | ||
575 | mutex_lock(&radio->lock); | 562 | mutex_lock(&radio->lock); |
576 | 563 | ||
577 | if (!radio->muted && radio->initialized) { | 564 | if (!radio->muted && radio->initialized) { |
578 | retval = amradio_set_mute(radio, AMRADIO_STOP); | 565 | amradio_set_mute(radio, AMRADIO_STOP); |
579 | if (retval < 0) | ||
580 | dev_warn(&intf->dev, "amradio_stop failed\n"); | ||
581 | radio->muted = 0; | 566 | radio->muted = 0; |
582 | } | 567 | } |
583 | 568 | ||
@@ -591,7 +576,6 @@ static int usb_amradio_suspend(struct usb_interface *intf, pm_message_t message) | |||
591 | static int usb_amradio_resume(struct usb_interface *intf) | 576 | static int usb_amradio_resume(struct usb_interface *intf) |
592 | { | 577 | { |
593 | struct amradio_device *radio = usb_get_intfdata(intf); | 578 | struct amradio_device *radio = usb_get_intfdata(intf); |
594 | int retval; | ||
595 | 579 | ||
596 | mutex_lock(&radio->lock); | 580 | mutex_lock(&radio->lock); |
597 | 581 | ||
@@ -599,24 +583,14 @@ static int usb_amradio_resume(struct usb_interface *intf) | |||
599 | goto unlock; | 583 | goto unlock; |
600 | 584 | ||
601 | if (radio->stereo) | 585 | if (radio->stereo) |
602 | retval = amradio_set_stereo(radio, WANT_STEREO); | 586 | amradio_set_stereo(radio, WANT_STEREO); |
603 | else | 587 | else |
604 | retval = amradio_set_stereo(radio, WANT_MONO); | 588 | amradio_set_stereo(radio, WANT_MONO); |
605 | 589 | ||
606 | if (retval < 0) | 590 | amradio_setfreq(radio, radio->curfreq); |
607 | amradio_dev_warn(&radio->videodev.dev, "set stereo failed\n"); | ||
608 | 591 | ||
609 | retval = amradio_setfreq(radio, radio->curfreq); | 592 | if (!radio->muted) |
610 | if (retval < 0) | 593 | amradio_set_mute(radio, AMRADIO_START); |
611 | amradio_dev_warn(&radio->videodev.dev, | ||
612 | "set frequency failed\n"); | ||
613 | |||
614 | if (!radio->muted) { | ||
615 | retval = amradio_set_mute(radio, AMRADIO_START); | ||
616 | if (retval < 0) | ||
617 | dev_warn(&radio->videodev.dev, | ||
618 | "amradio_start failed\n"); | ||
619 | } | ||
620 | 594 | ||
621 | unlock: | 595 | unlock: |
622 | dev_info(&intf->dev, "coming out of suspend..\n"); | 596 | dev_info(&intf->dev, "coming out of suspend..\n"); |