diff options
author | Sean Young <sean@mess.org> | 2017-02-22 16:48:01 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@s-opensource.com> | 2017-03-03 05:06:58 -0500 |
commit | 413808685dd7c9b54bbc5af79da2eaddd0fc3cb2 (patch) | |
tree | 4a800a337305f672984ead0b274e74c6f94bc644 | |
parent | c1305a40722f3e02f3d971acc22f5991aff239a6 (diff) |
[media] rc: raw decoder for keymap protocol is not loaded on register
When the protocol is set via the sysfs protocols attribute, the
decoder is loaded. However, when it is not when a device is first
plugged in or registered.
Fixes: acc1c3c ("[media] media: rc: load decoder modules on-demand")
Signed-off-by: Sean Young <sean@mess.org>
Cc: <stable@vger.kernel.org> # v4.5+
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
-rw-r--r-- | drivers/media/rc/rc-main.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/media/rc/rc-main.c b/drivers/media/rc/rc-main.c index 2424946740e6..a158b321b40a 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); |