Commit 74ca11c2 authored by Bastien Nocera's avatar Bastien Nocera Committed by Dmitry Torokhov

Input: uvc - the button on the camera is KEY_CAMERA

Cameras should generate KEY_CAMERA, not BTN_0. Also call input_sync()
on the device once the button has been pressed.
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarDmitry Torokhov <dtor@mail.ru>
parent 3c0340b7
...@@ -47,8 +47,8 @@ static int uvc_input_init(struct uvc_device *dev) ...@@ -47,8 +47,8 @@ static int uvc_input_init(struct uvc_device *dev)
usb_to_input_id(udev, &input->id); usb_to_input_id(udev, &input->id);
input->dev.parent = &dev->intf->dev; input->dev.parent = &dev->intf->dev;
set_bit(EV_KEY, input->evbit); __set_bit(EV_KEY, input->evbit);
set_bit(BTN_0, input->keybit); __set_bit(KEY_CAMERA, input->keybit);
if ((ret = input_register_device(input)) < 0) if ((ret = input_register_device(input)) < 0)
goto error; goto error;
...@@ -71,8 +71,10 @@ static void uvc_input_cleanup(struct uvc_device *dev) ...@@ -71,8 +71,10 @@ static void uvc_input_cleanup(struct uvc_device *dev)
static void uvc_input_report_key(struct uvc_device *dev, unsigned int code, static void uvc_input_report_key(struct uvc_device *dev, unsigned int code,
int value) int value)
{ {
if (dev->input) if (dev->input) {
input_report_key(dev->input, code, value); input_report_key(dev->input, code, value);
input_sync(dev->input);
}
} }
#else #else
...@@ -97,7 +99,7 @@ static void uvc_event_streaming(struct uvc_device *dev, __u8 *data, int len) ...@@ -97,7 +99,7 @@ static void uvc_event_streaming(struct uvc_device *dev, __u8 *data, int len)
return; return;
uvc_trace(UVC_TRACE_STATUS, "Button (intf %u) %s len %d\n", uvc_trace(UVC_TRACE_STATUS, "Button (intf %u) %s len %d\n",
data[1], data[3] ? "pressed" : "released", len); data[1], data[3] ? "pressed" : "released", len);
uvc_input_report_key(dev, BTN_0, data[3]); uvc_input_report_key(dev, KEY_CAMERA, data[3]);
} else { } else {
uvc_trace(UVC_TRACE_STATUS, "Stream %u error event %02x %02x " uvc_trace(UVC_TRACE_STATUS, "Stream %u error event %02x %02x "
"len %d.\n", data[1], data[2], data[3], len); "len %d.\n", data[1], data[2], data[3], len);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment