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: |