diff options
-rw-r--r-- | drivers/media/video/saa7134/saa7134-input.c | 49 | ||||
-rw-r--r-- | drivers/media/video/saa7134/saa7134.h | 4 |
2 files changed, 21 insertions, 32 deletions
diff --git a/drivers/media/video/saa7134/saa7134-input.c b/drivers/media/video/saa7134/saa7134-input.c index 10dc9ad2eae9..d75c307981bc 100644 --- a/drivers/media/video/saa7134/saa7134-input.c +++ b/drivers/media/video/saa7134/saa7134-input.c | |||
@@ -407,17 +407,16 @@ static int __saa7134_ir_start(void *priv) | |||
407 | struct saa7134_dev *dev = priv; | 407 | struct saa7134_dev *dev = priv; |
408 | struct saa7134_card_ir *ir; | 408 | struct saa7134_card_ir *ir; |
409 | 409 | ||
410 | if (!dev) | 410 | if (!dev || !dev->remote) |
411 | return -EINVAL; | 411 | return -EINVAL; |
412 | 412 | ||
413 | ir = dev->remote; | 413 | ir = dev->remote; |
414 | if (!ir) | ||
415 | return -EINVAL; | ||
416 | |||
417 | if (ir->running) | 414 | if (ir->running) |
418 | return 0; | 415 | return 0; |
419 | 416 | ||
420 | ir->running = true; | 417 | ir->running = true; |
418 | ir->active = false; | ||
419 | |||
421 | if (ir->polling) { | 420 | if (ir->polling) { |
422 | setup_timer(&ir->timer, saa7134_input_timer, | 421 | setup_timer(&ir->timer, saa7134_input_timer, |
423 | (unsigned long)dev); | 422 | (unsigned long)dev); |
@@ -425,10 +424,8 @@ static int __saa7134_ir_start(void *priv) | |||
425 | add_timer(&ir->timer); | 424 | add_timer(&ir->timer); |
426 | } else if (ir->raw_decode) { | 425 | } else if (ir->raw_decode) { |
427 | /* set timer_end for code completion */ | 426 | /* set timer_end for code completion */ |
428 | init_timer(&ir->timer_end); | 427 | setup_timer(&ir->timer_end, ir_raw_decode_timer_end, |
429 | ir->timer_end.function = ir_raw_decode_timer_end; | 428 | (unsigned long)dev); |
430 | ir->timer_end.data = (unsigned long)dev; | ||
431 | ir->active = false; | ||
432 | } | 429 | } |
433 | 430 | ||
434 | return 0; | 431 | return 0; |
@@ -439,22 +436,19 @@ static void __saa7134_ir_stop(void *priv) | |||
439 | struct saa7134_dev *dev = priv; | 436 | struct saa7134_dev *dev = priv; |
440 | struct saa7134_card_ir *ir; | 437 | struct saa7134_card_ir *ir; |
441 | 438 | ||
442 | if (!dev) | 439 | if (!dev || !dev->remote) |
443 | return; | 440 | return; |
444 | 441 | ||
445 | ir = dev->remote; | 442 | ir = dev->remote; |
446 | if (!ir) | ||
447 | return; | ||
448 | |||
449 | if (!ir->running) | 443 | if (!ir->running) |
450 | return; | 444 | return; |
451 | if (dev->remote->polling) | 445 | |
452 | del_timer_sync(&dev->remote->timer); | 446 | if (ir->polling) |
453 | else if (ir->raw_decode) { | 447 | del_timer_sync(&ir->timer); |
448 | else if (ir->raw_decode) | ||
454 | del_timer_sync(&ir->timer_end); | 449 | del_timer_sync(&ir->timer_end); |
455 | ir->active = false; | ||
456 | } | ||
457 | 450 | ||
451 | ir->active = false; | ||
458 | ir->running = false; | 452 | ir->running = false; |
459 | 453 | ||
460 | return; | 454 | return; |
@@ -499,8 +493,8 @@ int saa7134_input_init1(struct saa7134_dev *dev) | |||
499 | u32 mask_keycode = 0; | 493 | u32 mask_keycode = 0; |
500 | u32 mask_keydown = 0; | 494 | u32 mask_keydown = 0; |
501 | u32 mask_keyup = 0; | 495 | u32 mask_keyup = 0; |
502 | int polling = 0; | 496 | unsigned polling = 0; |
503 | int raw_decode = 0; | 497 | bool raw_decode = false; |
504 | int err; | 498 | int err; |
505 | 499 | ||
506 | if (dev->has_remote != SAA7134_REMOTE_GPIO) | 500 | if (dev->has_remote != SAA7134_REMOTE_GPIO) |
@@ -565,14 +559,14 @@ int saa7134_input_init1(struct saa7134_dev *dev) | |||
565 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ | 559 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ |
566 | mask_keyup = 0x0040000; | 560 | mask_keyup = 0x0040000; |
567 | mask_keycode = 0xffff; | 561 | mask_keycode = 0xffff; |
568 | raw_decode = 1; | 562 | raw_decode = true; |
569 | break; | 563 | break; |
570 | case SAA7134_BOARD_AVERMEDIA_M733A: | 564 | case SAA7134_BOARD_AVERMEDIA_M733A: |
571 | ir_codes = RC_MAP_AVERMEDIA_M733A_RM_K6; | 565 | ir_codes = RC_MAP_AVERMEDIA_M733A_RM_K6; |
572 | mask_keydown = 0x0040000; | 566 | mask_keydown = 0x0040000; |
573 | mask_keyup = 0x0040000; | 567 | mask_keyup = 0x0040000; |
574 | mask_keycode = 0xffff; | 568 | mask_keycode = 0xffff; |
575 | raw_decode = 1; | 569 | raw_decode = true; |
576 | break; | 570 | break; |
577 | case SAA7134_BOARD_AVERMEDIA_777: | 571 | case SAA7134_BOARD_AVERMEDIA_777: |
578 | case SAA7134_BOARD_AVERMEDIA_A16AR: | 572 | case SAA7134_BOARD_AVERMEDIA_A16AR: |
@@ -679,7 +673,7 @@ int saa7134_input_init1(struct saa7134_dev *dev) | |||
679 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ | 673 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ |
680 | mask_keyup = 0x0040000; | 674 | mask_keyup = 0x0040000; |
681 | mask_keycode = 0xffff; | 675 | mask_keycode = 0xffff; |
682 | raw_decode = 1; | 676 | raw_decode = true; |
683 | break; | 677 | break; |
684 | case SAA7134_BOARD_ENCORE_ENLTV: | 678 | case SAA7134_BOARD_ENCORE_ENLTV: |
685 | case SAA7134_BOARD_ENCORE_ENLTV_FM: | 679 | case SAA7134_BOARD_ENCORE_ENLTV_FM: |
@@ -693,7 +687,7 @@ int saa7134_input_init1(struct saa7134_dev *dev) | |||
693 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ | 687 | mask_keydown = 0x0040000; /* Enable GPIO18 line on both edges */ |
694 | mask_keyup = 0x0040000; | 688 | mask_keyup = 0x0040000; |
695 | mask_keycode = 0xffff; | 689 | mask_keycode = 0xffff; |
696 | raw_decode = 1; | 690 | raw_decode = true; |
697 | break; | 691 | break; |
698 | case SAA7134_BOARD_10MOONSTVMASTER3: | 692 | case SAA7134_BOARD_10MOONSTVMASTER3: |
699 | ir_codes = RC_MAP_ENCORE_ENLTV; | 693 | ir_codes = RC_MAP_ENCORE_ENLTV; |
@@ -746,8 +740,6 @@ int saa7134_input_init1(struct saa7134_dev *dev) | |||
746 | ir->dev = rc; | 740 | ir->dev = rc; |
747 | dev->remote = ir; | 741 | dev->remote = ir; |
748 | 742 | ||
749 | ir->running = false; | ||
750 | |||
751 | /* init hardware-specific stuff */ | 743 | /* init hardware-specific stuff */ |
752 | ir->mask_keycode = mask_keycode; | 744 | ir->mask_keycode = mask_keycode; |
753 | ir->mask_keydown = mask_keydown; | 745 | ir->mask_keydown = mask_keydown; |
@@ -809,14 +801,12 @@ void saa7134_input_fini(struct saa7134_dev *dev) | |||
809 | void saa7134_probe_i2c_ir(struct saa7134_dev *dev) | 801 | void saa7134_probe_i2c_ir(struct saa7134_dev *dev) |
810 | { | 802 | { |
811 | struct i2c_board_info info; | 803 | struct i2c_board_info info; |
812 | |||
813 | struct i2c_msg msg_msi = { | 804 | struct i2c_msg msg_msi = { |
814 | .addr = 0x50, | 805 | .addr = 0x50, |
815 | .flags = I2C_M_RD, | 806 | .flags = I2C_M_RD, |
816 | .len = 0, | 807 | .len = 0, |
817 | .buf = NULL, | 808 | .buf = NULL, |
818 | }; | 809 | }; |
819 | |||
820 | int rc; | 810 | int rc; |
821 | 811 | ||
822 | if (disable_ir) { | 812 | if (disable_ir) { |
@@ -916,8 +906,8 @@ void saa7134_probe_i2c_ir(struct saa7134_dev *dev) | |||
916 | 906 | ||
917 | static int saa7134_raw_decode_irq(struct saa7134_dev *dev) | 907 | static int saa7134_raw_decode_irq(struct saa7134_dev *dev) |
918 | { | 908 | { |
919 | struct saa7134_card_ir *ir = dev->remote; | 909 | struct saa7134_card_ir *ir = dev->remote; |
920 | unsigned long timeout; | 910 | unsigned long timeout; |
921 | int space; | 911 | int space; |
922 | 912 | ||
923 | /* Generate initial event */ | 913 | /* Generate initial event */ |
@@ -926,7 +916,6 @@ static int saa7134_raw_decode_irq(struct saa7134_dev *dev) | |||
926 | space = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2) & ir->mask_keydown; | 916 | space = saa_readl(SAA7134_GPIO_GPSTATUS0 >> 2) & ir->mask_keydown; |
927 | ir_raw_event_store_edge(dev->remote->dev, space ? IR_SPACE : IR_PULSE); | 917 | ir_raw_event_store_edge(dev->remote->dev, space ? IR_SPACE : IR_PULSE); |
928 | 918 | ||
929 | |||
930 | /* | 919 | /* |
931 | * Wait 15 ms from the start of the first IR event before processing | 920 | * Wait 15 ms from the start of the first IR event before processing |
932 | * the event. This time is enough for NEC protocol. May need adjustments | 921 | * the event. This time is enough for NEC protocol. May need adjustments |
diff --git a/drivers/media/video/saa7134/saa7134.h b/drivers/media/video/saa7134/saa7134.h index 1923f3ca0eab..f93951acec41 100644 --- a/drivers/media/video/saa7134/saa7134.h +++ b/drivers/media/video/saa7134/saa7134.h | |||
@@ -124,7 +124,7 @@ struct saa7134_card_ir { | |||
124 | 124 | ||
125 | char name[32]; | 125 | char name[32]; |
126 | char phys[32]; | 126 | char phys[32]; |
127 | int users; | 127 | unsigned users; |
128 | 128 | ||
129 | u32 polling; | 129 | u32 polling; |
130 | u32 last_gpio; | 130 | u32 last_gpio; |
@@ -551,7 +551,7 @@ struct saa7134_dev { | |||
551 | 551 | ||
552 | /* infrared remote */ | 552 | /* infrared remote */ |
553 | int has_remote; | 553 | int has_remote; |
554 | struct saa7134_card_ir *remote; | 554 | struct saa7134_card_ir *remote; |
555 | 555 | ||
556 | /* pci i/o */ | 556 | /* pci i/o */ |
557 | char name[32]; | 557 | char name[32]; |