Commit af87b3d0 authored by David Herrmann's avatar David Herrmann Committed by Gustavo Padovan

Bluetooth: hidp: don't send boot-protocol messages as HID-reports

If a device is registered as HID device, it is always in Report-Mode.
Therefore, we must not send Boot-Protocol messages on
hidinput_input_event() callbacks. This confuses devices and may cause
disconnects on protocol errors.

We disable the hidinput_input_event() callback for now. We can implement
it properly later, but lets first fix the current code by disabling it.
Signed-off-by: default avatarDavid Herrmann <dh.herrmann@gmail.com>
Acked-by: default avatarMarcel Holtmann <marcel@holtmann.org>
Signed-off-by: default avatarGustavo Padovan <gustavo.padovan@collabora.co.uk>
parent 41edc0c0
...@@ -143,13 +143,15 @@ static int hidp_send_intr_message(struct hidp_session *session, ...@@ -143,13 +143,15 @@ static int hidp_send_intr_message(struct hidp_session *session,
&session->intr_transmit, hdr, data, size); &session->intr_transmit, hdr, data, size);
} }
static int hidp_queue_event(struct hidp_session *session, struct input_dev *dev, static int hidp_input_event(struct input_dev *dev, unsigned int type,
unsigned int type, unsigned int code, int value) unsigned int code, int value)
{ {
struct hidp_session *session = input_get_drvdata(dev);
unsigned char newleds; unsigned char newleds;
unsigned char hdr, data[2]; unsigned char hdr, data[2];
BT_DBG("session %p type %d code %d value %d", session, type, code, value); BT_DBG("session %p type %d code %d value %d",
session, type, code, value);
if (type != EV_LED) if (type != EV_LED)
return -1; return -1;
...@@ -172,21 +174,6 @@ static int hidp_queue_event(struct hidp_session *session, struct input_dev *dev, ...@@ -172,21 +174,6 @@ static int hidp_queue_event(struct hidp_session *session, struct input_dev *dev,
return hidp_send_intr_message(session, hdr, data, 2); return hidp_send_intr_message(session, hdr, data, 2);
} }
static int hidp_hidinput_event(struct input_dev *dev, unsigned int type, unsigned int code, int value)
{
struct hid_device *hid = input_get_drvdata(dev);
struct hidp_session *session = hid->driver_data;
return hidp_queue_event(session, dev, type, code, value);
}
static int hidp_input_event(struct input_dev *dev, unsigned int type, unsigned int code, int value)
{
struct hidp_session *session = input_get_drvdata(dev);
return hidp_queue_event(session, dev, type, code, value);
}
static void hidp_input_report(struct hidp_session *session, struct sk_buff *skb) static void hidp_input_report(struct hidp_session *session, struct sk_buff *skb)
{ {
struct input_dev *dev = session->input; struct input_dev *dev = session->input;
...@@ -732,7 +719,6 @@ static struct hid_ll_driver hidp_hid_driver = { ...@@ -732,7 +719,6 @@ static struct hid_ll_driver hidp_hid_driver = {
.stop = hidp_stop, .stop = hidp_stop,
.open = hidp_open, .open = hidp_open,
.close = hidp_close, .close = hidp_close,
.hidinput_input_event = hidp_hidinput_event,
}; };
/* This function sets up the hid device. It does not add it /* This function sets up the hid device. It does not add it
......
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