diff options
Diffstat (limited to 'drivers/media/rc/rc-main.c')
| -rw-r--r-- | drivers/media/rc/rc-main.c | 26 |
1 files changed, 15 insertions, 11 deletions
diff --git a/drivers/media/rc/rc-main.c b/drivers/media/rc/rc-main.c index 2424946740e6..d84533699668 100644 --- a/drivers/media/rc/rc-main.c +++ b/drivers/media/rc/rc-main.c | |||
| @@ -1663,6 +1663,7 @@ static int rc_setup_rx_device(struct rc_dev *dev) | |||
| 1663 | { | 1663 | { |
| 1664 | int rc; | 1664 | int rc; |
| 1665 | struct rc_map *rc_map; | 1665 | struct rc_map *rc_map; |
| 1666 | u64 rc_type; | ||
| 1666 | 1667 | ||
| 1667 | if (!dev->map_name) | 1668 | if (!dev->map_name) |
| 1668 | return -EINVAL; | 1669 | return -EINVAL; |
| @@ -1677,15 +1678,18 @@ static int rc_setup_rx_device(struct rc_dev *dev) | |||
| 1677 | if (rc) | 1678 | if (rc) |
| 1678 | return rc; | 1679 | return rc; |
| 1679 | 1680 | ||
| 1680 | if (dev->change_protocol) { | 1681 | rc_type = BIT_ULL(rc_map->rc_type); |
| 1681 | u64 rc_type = (1ll << rc_map->rc_type); | ||
| 1682 | 1682 | ||
| 1683 | if (dev->change_protocol) { | ||
| 1683 | rc = dev->change_protocol(dev, &rc_type); | 1684 | rc = dev->change_protocol(dev, &rc_type); |
| 1684 | if (rc < 0) | 1685 | if (rc < 0) |
| 1685 | goto out_table; | 1686 | goto out_table; |
| 1686 | dev->enabled_protocols = rc_type; | 1687 | dev->enabled_protocols = rc_type; |
| 1687 | } | 1688 | } |
| 1688 | 1689 | ||
| 1690 | if (dev->driver_type == RC_DRIVER_IR_RAW) | ||
| 1691 | ir_raw_load_modules(&rc_type); | ||
| 1692 | |||
| 1689 | set_bit(EV_KEY, dev->input_dev->evbit); | 1693 | set_bit(EV_KEY, dev->input_dev->evbit); |
| 1690 | set_bit(EV_REP, dev->input_dev->evbit); | 1694 | set_bit(EV_REP, dev->input_dev->evbit); |
| 1691 | set_bit(EV_MSC, dev->input_dev->evbit); | 1695 | set_bit(EV_MSC, dev->input_dev->evbit); |
| @@ -1777,12 +1781,6 @@ int rc_register_device(struct rc_dev *dev) | |||
| 1777 | dev->input_name ?: "Unspecified device", path ?: "N/A"); | 1781 | dev->input_name ?: "Unspecified device", path ?: "N/A"); |
| 1778 | kfree(path); | 1782 | kfree(path); |
| 1779 | 1783 | ||
| 1780 | if (dev->driver_type != RC_DRIVER_IR_RAW_TX) { | ||
| 1781 | rc = rc_setup_rx_device(dev); | ||
| 1782 | if (rc) | ||
| 1783 | goto out_dev; | ||
| 1784 | } | ||
| 1785 | |||
| 1786 | if (dev->driver_type == RC_DRIVER_IR_RAW || | 1784 | if (dev->driver_type == RC_DRIVER_IR_RAW || |
| 1787 | dev->driver_type == RC_DRIVER_IR_RAW_TX) { | 1785 | dev->driver_type == RC_DRIVER_IR_RAW_TX) { |
| 1788 | if (!raw_init) { | 1786 | if (!raw_init) { |
| @@ -1791,7 +1789,13 @@ int rc_register_device(struct rc_dev *dev) | |||
| 1791 | } | 1789 | } |
| 1792 | rc = ir_raw_event_register(dev); | 1790 | rc = ir_raw_event_register(dev); |
| 1793 | if (rc < 0) | 1791 | if (rc < 0) |
| 1794 | goto out_rx; | 1792 | goto out_dev; |
| 1793 | } | ||
| 1794 | |||
| 1795 | if (dev->driver_type != RC_DRIVER_IR_RAW_TX) { | ||
| 1796 | rc = rc_setup_rx_device(dev); | ||
| 1797 | if (rc) | ||
| 1798 | goto out_raw; | ||
| 1795 | } | 1799 | } |
| 1796 | 1800 | ||
| 1797 | /* Allow the RC sysfs nodes to be accessible */ | 1801 | /* Allow the RC sysfs nodes to be accessible */ |
| @@ -1803,8 +1807,8 @@ int rc_register_device(struct rc_dev *dev) | |||
| 1803 | 1807 | ||
| 1804 | return 0; | 1808 | return 0; |
| 1805 | 1809 | ||
| 1806 | out_rx: | 1810 | out_raw: |
| 1807 | rc_free_rx_device(dev); | 1811 | ir_raw_event_unregister(dev); |
| 1808 | out_dev: | 1812 | out_dev: |
| 1809 | device_del(&dev->dev); | 1813 | device_del(&dev->dev); |
| 1810 | out_unlock: | 1814 | out_unlock: |
