* [HID Patchsets for Samsung driver v2 0/6] HID Support for Samsung driver [not found] <CGME20240108091950epcas5p41633efaf7b62db312982aa2f94a26db3@epcas5p4.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S [not found] ` <CGME20240108091954epcas5p39f9ca04b57adf01a7c964593b7be87d2@epcas5p3.samsung.com> ` (5 more replies) 0 siblings, 6 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Dear All, I hope this email finds you well. As per your review comments give by Mr. Benjamin Tissoires in our last converstaion over mail. We refactored series with : 1. hid_is_usb() check being moved 2. fix the checkpatch complain 3+ Added bluetooth device support As of today, Opensource kernel Samsung driver only supports USB HID devices and do not have support for Bluetooth HID devices. Samsung would like to improve the samsung driver and extend it's support for bluetooth devices as well. Summary of changes in Samsung driver: 1. Add support for below bluetooth devices Samsung wireless Keyboard Samsung wireless GamePad Samsung Wireless Action Mouse Samsung Wireless Book Cover Samsung Wireless Universal Keyboard Samsung Wireless HOGP Keyboard 2. Add support for Special key processing on each of the above devices. Patch Series Overview: -------------------------------------- [Patch 1/6] HID Samsung : Broaden device compatibility in samsung driver. hid_is_usb() check being moved. [Patch 2/6] HID: Samsung : Fix the checkpatch complain. Warning found by checkpatch.pl script. [Patch 3/6] HID: Samsung : Add Samsung wireless keyboard support. [Patch 4/6] HID: Samsung : Add Samsung wireless gamepad support. [Patch 5/6] HID: Samsung : Add Samsung wireless action mouse support. [Patch 6/6] HID: Samsung : Add Samsung wireless bookcover and universal keyboard support. All these changes have been verified and tested thoroughly in android devices. Please accept our changes. Thanks for your time and consideration Best regards Sandeep C S Sandeep C S (6): HID Samsung : Broaden device compatibility in samsung driver. HID: Samsung : Fix the checkpatch complain. HID: Samsung : Add Samsung wireless keyboard support. HID: Samsung : Add Samsung wireless gamepad support. HID: Samsung : Add Samsung wireless action mouse support. HID: Samsung : Add Samsung wireless bookcover and universal keyboard support. drivers/hid/hid-ids.h | 7 + drivers/hid/hid-samsung.c | 440 +++++++++++++++++++++++++++++++++++--- 2 files changed, 423 insertions(+), 24 deletions(-) -- 2.34.1 ^ permalink raw reply [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108091954epcas5p39f9ca04b57adf01a7c964593b7be87d2@epcas5p3.samsung.com>]
* [HID Patchsets for Samsung driver v2 1/6] HID Samsung : Broaden device compatibility in samsung driver. [not found] ` <CGME20240108091954epcas5p39f9ca04b57adf01a7c964593b7be87d2@epcas5p3.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 0 siblings, 0 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel The USB validation check has been moved wherever its required. Earlier Samsung driver only handles USB HID devices and returns an error if it encounters a Bluetooth type of HID device. This changes improves driver compatibility and extends its support for a wide range of devices. Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-samsung.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index cf5992e97094..885657531607 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -128,7 +128,7 @@ static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { - if (USB_DEVICE_ID_SAMSUNG_IR_REMOTE == hdev->product) + if (USB_DEVICE_ID_SAMSUNG_IR_REMOTE == hdev->product && hid_is_usb(hdev)) rdesc = samsung_irda_report_fixup(hdev, rdesc, rsize); return rdesc; } @@ -139,7 +139,7 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, { int ret = 0; - if (USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE == hdev->product) + if (USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE == hdev->product && hid_is_usb(hdev)) ret = samsung_kbd_mouse_input_mapping(hdev, hi, field, usage, bit, max); @@ -152,9 +152,6 @@ static int samsung_probe(struct hid_device *hdev, int ret; unsigned int cmask = HID_CONNECT_DEFAULT; - if (!hid_is_usb(hdev)) - return -EINVAL; - ret = hid_parse(hdev); if (ret) { hid_err(hdev, "parse failed\n"); @@ -162,6 +159,10 @@ static int samsung_probe(struct hid_device *hdev, } if (USB_DEVICE_ID_SAMSUNG_IR_REMOTE == hdev->product) { + if (!hid_is_usb(hdev)) { + ret = -EINVAL; + goto err_free; + } if (hdev->rsize == 184) { /* disable hidinput, force hiddev */ cmask = (cmask & ~HID_CONNECT_HIDINPUT) | -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108091959epcas5p2559b779424e2fb7c7e268d1b24612b4f@epcas5p2.samsung.com>]
* [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. [not found] ` <CGME20240108091959epcas5p2559b779424e2fb7c7e268d1b24612b4f@epcas5p2.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 2024-01-08 10:21 ` Joe Perches 0 siblings, 1 reply; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Warning found by checkpatch.pl script. Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-samsung.c | 61 +++++++++++++++++++++++++-------------- 1 file changed, 40 insertions(+), 21 deletions(-) diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index 885657531607..33cc92337394 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -67,20 +67,17 @@ static __u8 *samsung_irda_report_fixup(struct hid_device *hdev, __u8 *rdesc, rdesc[178] = 0x08; rdesc[180] = 0x06; rdesc[182] = 0x42; - } else - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && + } else if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && rdesc[194] == 0x25 && rdesc[195] == 0x12) { samsung_irda_dev_trace(hdev, 203); rdesc[193] = 0x1; rdesc[195] = 0xf; - } else - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && + } else if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && rdesc[126] == 0x25 && rdesc[127] == 0x11) { samsung_irda_dev_trace(hdev, 135); rdesc[125] = 0x1; rdesc[127] = 0xe; - } else - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && + } else if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && rdesc[162] == 0x25 && rdesc[163] == 0x01) { samsung_irda_dev_trace(hdev, 171); rdesc[161] = 0x1; @@ -99,7 +96,7 @@ static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, struct usb_interface *intf = to_usb_interface(hdev->dev.parent); unsigned short ifnum = intf->cur_altsetting->desc.bInterfaceNumber; - if (1 != ifnum || HID_UP_CONSUMER != (usage->hid & HID_USAGE_PAGE)) + if (ifnum != 1 || HID_UP_CONSUMER != (usage->hid & HID_USAGE_PAGE)) return 0; dbg_hid("samsung wireless keyboard/mouse input mapping event [0x%x]\n", @@ -107,17 +104,39 @@ static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, switch (usage->hid & HID_USAGE) { /* report 2 */ - case 0x183: samsung_kbd_mouse_map_key_clear(KEY_MEDIA); break; - case 0x195: samsung_kbd_mouse_map_key_clear(KEY_EMAIL); break; - case 0x196: samsung_kbd_mouse_map_key_clear(KEY_CALC); break; - case 0x197: samsung_kbd_mouse_map_key_clear(KEY_COMPUTER); break; - case 0x22b: samsung_kbd_mouse_map_key_clear(KEY_SEARCH); break; - case 0x22c: samsung_kbd_mouse_map_key_clear(KEY_WWW); break; - case 0x22d: samsung_kbd_mouse_map_key_clear(KEY_BACK); break; - case 0x22e: samsung_kbd_mouse_map_key_clear(KEY_FORWARD); break; - case 0x22f: samsung_kbd_mouse_map_key_clear(KEY_FAVORITES); break; - case 0x230: samsung_kbd_mouse_map_key_clear(KEY_REFRESH); break; - case 0x231: samsung_kbd_mouse_map_key_clear(KEY_STOP); break; + case 0x183: + samsung_kbd_mouse_map_key_clear(KEY_MEDIA); + break; + case 0x195: + samsung_kbd_mouse_map_key_clear(KEY_EMAIL); + break; + case 0x196: + samsung_kbd_mouse_map_key_clear(KEY_CALC); + break; + case 0x197: + samsung_kbd_mouse_map_key_clear(KEY_COMPUTER); + break; + case 0x22b: + samsung_kbd_mouse_map_key_clear(KEY_SEARCH); + break; + case 0x22c: + samsung_kbd_mouse_map_key_clear(KEY_WWW); + break; + case 0x22d: + samsung_kbd_mouse_map_key_clear(KEY_BACK); + break; + case 0x22e: + samsung_kbd_mouse_map_key_clear(KEY_FORWARD); + break; + case 0x22f: + samsung_kbd_mouse_map_key_clear(KEY_FAVORITES); + break; + case 0x230: + samsung_kbd_mouse_map_key_clear(KEY_REFRESH); + break; + case 0x231: + samsung_kbd_mouse_map_key_clear(KEY_STOP); + break; default: return 0; } @@ -128,7 +147,7 @@ static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { - if (USB_DEVICE_ID_SAMSUNG_IR_REMOTE == hdev->product && hid_is_usb(hdev)) + if (hdev->product == USB_DEVICE_ID_SAMSUNG_IR_REMOTE && hid_is_usb(hdev)) rdesc = samsung_irda_report_fixup(hdev, rdesc, rsize); return rdesc; } @@ -139,7 +158,7 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, { int ret = 0; - if (USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE == hdev->product && hid_is_usb(hdev)) + if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE && hid_is_usb(hdev)) ret = samsung_kbd_mouse_input_mapping(hdev, hi, field, usage, bit, max); @@ -158,7 +177,7 @@ static int samsung_probe(struct hid_device *hdev, goto err_free; } - if (USB_DEVICE_ID_SAMSUNG_IR_REMOTE == hdev->product) { + if (hdev->product == USB_DEVICE_ID_SAMSUNG_IR_REMOTE) { if (!hid_is_usb(hdev)) { ret = -EINVAL; goto err_free; -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain Sandeep C S @ 2024-01-08 10:21 ` Joe Perches 2024-01-08 10:44 ` sandeep.cs 0 siblings, 1 reply; 12+ messages in thread From: Joe Perches @ 2024-01-08 10:21 UTC (permalink / raw) To: Sandeep C S, Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, linux-input, linux-kernel On Mon, 2024-01-08 at 14:49 +0530, Sandeep C S wrote: > Warning found by checkpatch.pl script. [] > diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c [] > @@ -67,20 +67,17 @@ static __u8 *samsung_irda_report_fixup(struct hid_device *hdev, __u8 *rdesc, > rdesc[178] = 0x08; > rdesc[180] = 0x06; > rdesc[182] = 0x42; > - } else > - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && > + } else if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && > rdesc[194] == 0x25 && rdesc[195] == 0x12) { > samsung_irda_dev_trace(hdev, 203); > rdesc[193] = 0x1; > rdesc[195] = 0xf; > - } else > - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && > + } else if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && > rdesc[126] == 0x25 && rdesc[127] == 0x11) { > samsung_irda_dev_trace(hdev, 135); > rdesc[125] = 0x1; > rdesc[127] = 0xe; > - } else > - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && > + } else if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && > rdesc[162] == 0x25 && rdesc[163] == 0x01) { > samsung_irda_dev_trace(hdev, 171); > rdesc[161] = 0x1; For this block, I think a rewrite using memcmp would be clearer. Something like: --- drivers/hid/hid-samsung.c | 34 +++++++++++++++------------------- 1 file changed, 15 insertions(+), 19 deletions(-) diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index cf5992e970940..cd84fb5e68f69 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -58,33 +58,29 @@ static inline void samsung_irda_dev_trace(struct hid_device *hdev, static __u8 *samsung_irda_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { - if (*rsize == 184 && rdesc[175] == 0x25 && rdesc[176] == 0x40 && - rdesc[177] == 0x75 && rdesc[178] == 0x30 && - rdesc[179] == 0x95 && rdesc[180] == 0x01 && - rdesc[182] == 0x40) { + if (*rsize == 184 && + !memcmp(&rdesc[175], "\x25\x40\x75\x30\x95\x01", 6) && + rdesc[182] == 0x40) { samsung_irda_dev_trace(hdev, 184); rdesc[176] = 0xff; rdesc[178] = 0x08; rdesc[180] = 0x06; rdesc[182] = 0x42; - } else - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && - rdesc[194] == 0x25 && rdesc[195] == 0x12) { + } else if (*rsize == 203 && + !memcmp(&rdesc[192], "\x15\x00\x25\x12", 4)) { samsung_irda_dev_trace(hdev, 203); - rdesc[193] = 0x1; - rdesc[195] = 0xf; - } else - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && - rdesc[126] == 0x25 && rdesc[127] == 0x11) { + rdesc[193] = 0x01; + rdesc[195] = 0x0f; + } else if (*rsize == 135 && + !memcmp(&rdesc[124], "\x15\x00\x25\x11", 4)) { samsung_irda_dev_trace(hdev, 135); - rdesc[125] = 0x1; - rdesc[127] = 0xe; - } else - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && - rdesc[162] == 0x25 && rdesc[163] == 0x01) { + rdesc[125] = 0x01; + rdesc[127] = 0x0e; + } else if (*rsize == 171 && + !memcmp(&rdesc[160], "\x15\x00\x25\x01", 4)) { samsung_irda_dev_trace(hdev, 171); - rdesc[161] = 0x1; - rdesc[163] = 0x3; + rdesc[161] = 0x01; + rdesc[163] = 0x03; } return rdesc; } ^ permalink raw reply related [flat|nested] 12+ messages in thread
* RE: [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. 2024-01-08 10:21 ` Joe Perches @ 2024-01-08 10:44 ` sandeep.cs 2024-01-09 2:34 ` Joe Perches 2024-01-23 9:49 ` Jiri Kosina 0 siblings, 2 replies; 12+ messages in thread From: sandeep.cs @ 2024-01-08 10:44 UTC (permalink / raw) To: 'Joe Perches', 'Jiri Kosina', 'Benjamin Tissoires' Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, linux-input, linux-kernel >On Mon, 2024-01-08 at 14:49 +0530, Sandeep C S wrote: >> Warning found by checkpatch.pl script. >[] >> diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c >[] >> @@ -67,20 +67,17 @@ static __u8 *samsung_irda_report_fixup(struct >hid_device *hdev, __u8 *rdesc, >> rdesc[178] = 0x08; >> rdesc[180] = 0x06; >> rdesc[182] = 0x42; >> - } else >> - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && >> + } else if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 >> +&& >> rdesc[194] == 0x25 && rdesc[195] == 0x12) { >> samsung_irda_dev_trace(hdev, 203); >> rdesc[193] = 0x1; >> rdesc[195] = 0xf; >> - } else >> - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && >> + } else if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 >> +&& >> rdesc[126] == 0x25 && rdesc[127] == 0x11) { >> samsung_irda_dev_trace(hdev, 135); >> rdesc[125] = 0x1; >> rdesc[127] = 0xe; >> - } else >> - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && >> + } else if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 >> +&& >> rdesc[162] == 0x25 && rdesc[163] == 0x01) { >> samsung_irda_dev_trace(hdev, 171); >> rdesc[161] = 0x1; > >For this block, I think a rewrite using memcmp would be clearer. >Something like: Okay . Thanks for your valuable feedback. We will promptly address your suggestions and enhance our code accordingly. And also please review other patch set as well. Thank you >--- > drivers/hid/hid-samsung.c | 34 +++++++++++++++------------------- > 1 file changed, 15 insertions(+), 19 deletions(-) > >diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index >cf5992e970940..cd84fb5e68f69 100644 >--- a/drivers/hid/hid-samsung.c >+++ b/drivers/hid/hid-samsung.c >@@ -58,33 +58,29 @@ static inline void samsung_irda_dev_trace(struct >hid_device *hdev, static __u8 *samsung_irda_report_fixup(struct hid_device >*hdev, __u8 *rdesc, > unsigned int *rsize) > { >- if (*rsize == 184 && rdesc[175] == 0x25 && rdesc[176] == 0x40 && >- rdesc[177] == 0x75 && rdesc[178] == 0x30 && >- rdesc[179] == 0x95 && rdesc[180] == 0x01 && >- rdesc[182] == 0x40) { >+ if (*rsize == 184 && >+ !memcmp(&rdesc[175], "\x25\x40\x75\x30\x95\x01", 6) && >+ rdesc[182] == 0x40) { > samsung_irda_dev_trace(hdev, 184); > rdesc[176] = 0xff; > rdesc[178] = 0x08; > rdesc[180] = 0x06; > rdesc[182] = 0x42; >- } else >- if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && >- rdesc[194] == 0x25 && rdesc[195] == 0x12) { >+ } else if (*rsize == 203 && >+ !memcmp(&rdesc[192], "\x15\x00\x25\x12", 4)) { > samsung_irda_dev_trace(hdev, 203); >- rdesc[193] = 0x1; >- rdesc[195] = 0xf; >- } else >- if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && >- rdesc[126] == 0x25 && rdesc[127] == 0x11) { >+ rdesc[193] = 0x01; >+ rdesc[195] = 0x0f; >+ } else if (*rsize == 135 && >+ !memcmp(&rdesc[124], "\x15\x00\x25\x11", 4)) { > samsung_irda_dev_trace(hdev, 135); >- rdesc[125] = 0x1; >- rdesc[127] = 0xe; >- } else >- if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && >- rdesc[162] == 0x25 && rdesc[163] == 0x01) { >+ rdesc[125] = 0x01; >+ rdesc[127] = 0x0e; >+ } else if (*rsize == 171 && >+ !memcmp(&rdesc[160], "\x15\x00\x25\x01", 4)) { > samsung_irda_dev_trace(hdev, 171); >- rdesc[161] = 0x1; >- rdesc[163] = 0x3; >+ rdesc[161] = 0x01; >+ rdesc[163] = 0x03; > } > return rdesc; > } ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. 2024-01-08 10:44 ` sandeep.cs @ 2024-01-09 2:34 ` Joe Perches 2024-01-23 9:49 ` Jiri Kosina 1 sibling, 0 replies; 12+ messages in thread From: Joe Perches @ 2024-01-09 2:34 UTC (permalink / raw) To: sandeep.cs, 'Jiri Kosina', 'Benjamin Tissoires' Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, linux-input, linux-kernel On Mon, 2024-01-08 at 16:14 +0530, sandeep.cs wrote: > > On Mon, 2024-01-08 at 14:49 +0530, Sandeep C S wrote: Generally, it's better to refactor code that checkpatch bleats about than merely shutting up the warning. > > For this block, I think a rewrite using memcmp would be clearer. > > Something like: > Okay . Thanks for your valuable feedback. We will promptly address your > suggestions and enhance our code accordingly. > And also please review other patch set as well. Another way to write the input_mapping function is using a static const struct and a for loop like: static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, unsigned long **bit, int *max) { struct usb_interface *intf = to_usb_interface(hdev->dev.parent); unsigned short ifnum = intf->cur_altsetting->desc.bInterfaceNumber; static const struct { unsigned hid; __u16 map; } samsung_hid_key_map[] = { {0x183, KEY_MEDIA}, {0x195, KEY_EMAIL}, {0x196, KEY_CALC}, {0x197, KEY_COMPUTER}, {0x22b, KEY_SEARCH}, {0x22c, KEY_WWW}, {0x22d, KEY_BACK}, {0x22e, KEY_FORWARD}, {0x22f, KEY_FAVORITES}, {0x230, KEY_REFRESH}, {0x231, KEY_STOP}, }; int i; unsigned hid; if (1 != ifnum || HID_UP_CONSUMER != (usage->hid & HID_USAGE_PAGE)) return 0; hid = usage->hid & HID_USAGE; dbg_hid("samsung wireless keyboard/mouse input mapping event [0x%x]\n", hid); for (i = 0; i < ARRAY_SIZE(samsung_hid_key_map); i++) { if (hid == samsung_hid_key_map[i].hid) { hid_map_usage_clear(hi, usage, bit, max, EV_KEY, samsung_hid_key_map[i].map); return 1; } } return 0; } ^ permalink raw reply [flat|nested] 12+ messages in thread
* RE: [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. 2024-01-08 10:44 ` sandeep.cs 2024-01-09 2:34 ` Joe Perches @ 2024-01-23 9:49 ` Jiri Kosina 2024-01-23 10:04 ` sandeep.cs 1 sibling, 1 reply; 12+ messages in thread From: Jiri Kosina @ 2024-01-23 9:49 UTC (permalink / raw) To: sandeep.cs Cc: 'Joe Perches', 'Benjamin Tissoires', gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, linux-input, linux-kernel On Mon, 8 Jan 2024, sandeep.cs wrote: > >> - } else > >> - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && > >> + } else if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 > >> +&& > >> rdesc[194] == 0x25 && rdesc[195] == 0x12) { > >> samsung_irda_dev_trace(hdev, 203); > >> rdesc[193] = 0x1; > >> rdesc[195] = 0xf; > >> - } else > >> - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && > >> + } else if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 > >> +&& > >> rdesc[126] == 0x25 && rdesc[127] == 0x11) { > >> samsung_irda_dev_trace(hdev, 135); > >> rdesc[125] = 0x1; > >> rdesc[127] = 0xe; > >> - } else > >> - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && > >> + } else if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 > >> +&& > >> rdesc[162] == 0x25 && rdesc[163] == 0x01) { > >> samsung_irda_dev_trace(hdev, 171); > >> rdesc[161] = 0x1; > > > >For this block, I think a rewrite using memcmp would be clearer. > >Something like: > Okay . Thanks for your valuable feedback. We will promptly address your > suggestions and enhance our code accordingly. I agree with Joe's suggestion here; are you planning to send v2 of the series? The rest of the set looks good to me. Thanks, -- Jiri Kosina SUSE Labs ^ permalink raw reply [flat|nested] 12+ messages in thread
* RE: [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain. 2024-01-23 9:49 ` Jiri Kosina @ 2024-01-23 10:04 ` sandeep.cs 0 siblings, 0 replies; 12+ messages in thread From: sandeep.cs @ 2024-01-23 10:04 UTC (permalink / raw) To: 'Jiri Kosina' Cc: 'Joe Perches', 'Benjamin Tissoires', gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, linux-input, linux-kernel >> >> - } else >> >> - if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == 0x0 && >> >> + } else if (*rsize == 203 && rdesc[192] == 0x15 && rdesc[193] == >> >> +0x0 && >> >> rdesc[194] == 0x25 && rdesc[195] == 0x12) { >> >> samsung_irda_dev_trace(hdev, 203); >> >> rdesc[193] = 0x1; >> >> rdesc[195] = 0xf; >> >> - } else >> >> - if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == 0x0 && >> >> + } else if (*rsize == 135 && rdesc[124] == 0x15 && rdesc[125] == >> >> +0x0 && >> >> rdesc[126] == 0x25 && rdesc[127] == 0x11) { >> >> samsung_irda_dev_trace(hdev, 135); >> >> rdesc[125] = 0x1; >> >> rdesc[127] = 0xe; >> >> - } else >> >> - if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == 0x0 && >> >> + } else if (*rsize == 171 && rdesc[160] == 0x15 && rdesc[161] == >> >> +0x0 && >> >> rdesc[162] == 0x25 && rdesc[163] == 0x01) { >> >> samsung_irda_dev_trace(hdev, 171); >> >> rdesc[161] = 0x1; >> > >> >For this block, I think a rewrite using memcmp would be clearer. >> >Something like: >> Okay . Thanks for your valuable feedback. We will promptly address >> your suggestions and enhance our code accordingly. > >I agree with Joe's suggestion here; are you planning to send v2 of the series? > >The rest of the set looks good to me. > >Thanks, > >-- >Jiri Kosina >SUSE Labs Hello Jiri , Yes, I am planning to send the v2 of the series. I will include review comments and share it with you soon. Thank & Regards Sandeep C S ^ permalink raw reply [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108092004epcas5p1c7069a6ede85066817d8ce5a79da75ad@epcas5p1.samsung.com>]
* [HID Patchsets for Samsung driver v2 3/6] HID: Samsung : Add Samsung wireless keyboard support. [not found] ` <CGME20240108092004epcas5p1c7069a6ede85066817d8ce5a79da75ad@epcas5p1.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 0 siblings, 0 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Add Support for samsung wireless keyboard with input mapping events. Device 7021 (Samsung wireless keyboard) Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-ids.h | 2 + drivers/hid/hid-samsung.c | 108 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 110 insertions(+) diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index 72046039d1be..2f526dc8983a 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h @@ -1139,8 +1139,10 @@ #define USB_DEVICE_ID_SAITEK_X65 0x0b6a #define USB_VENDOR_ID_SAMSUNG 0x0419 +#define USB_VENDOR_ID_SAMSUNG_ELECTRONICS 0x04e8 #define USB_DEVICE_ID_SAMSUNG_IR_REMOTE 0x0001 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE 0x0600 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD 0x7021 #define USB_VENDOR_ID_SEMICO 0x1a2c #define USB_DEVICE_ID_SEMICO_USB_KEYKOARD 0x0023 diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index 33cc92337394..611acd7ffd6d 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -144,6 +144,110 @@ static int samsung_kbd_mouse_input_mapping(struct hid_device *hdev, return 1; } +static int samsung_kbd_input_mapping(struct hid_device *hdev, + struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, + unsigned long **bit, int *max) +{ + if (!(HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE) || + HID_UP_KEYBOARD == (usage->hid & HID_USAGE_PAGE))) + return 0; + + dbg_hid("samsung wireless keyboard input mapping event [0x%x]\n", + usage->hid & HID_USAGE); + + if (HID_UP_KEYBOARD == (usage->hid & HID_USAGE_PAGE)) { + set_bit(EV_REP, hi->input->evbit); + switch (usage->hid & HID_USAGE) { + /* Only for UK keyboard */ + /* key found */ +#ifdef CONFIG_HID_KK_UPGRADE + case 0x32: + samsung_kbd_mouse_map_key_clear(KEY_KBDILLUMTOGGLE); + break; + case 0x64: + samsung_kbd_mouse_map_key_clear(KEY_BACKSLASH); + break; +#else + case 0x32: + samsung_kbd_mouse_map_key_clear(KEY_BACKSLASH); + break; + case 0x64: + samsung_kbd_mouse_map_key_clear(KEY_102ND); + break; +#endif + /* Only for BR keyboard */ + case 0x87: + samsung_kbd_mouse_map_key_clear(KEY_RO); + break; + default: + return 0; + } + } + + if (HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE)) { + switch (usage->hid & HID_USAGE) { + /* report 2 */ + /* MENU */ + case 0x040: + samsung_kbd_mouse_map_key_clear(KEY_MENU); + break; + case 0x18a: + samsung_kbd_mouse_map_key_clear(KEY_MAIL); + break; + case 0x196: + samsung_kbd_mouse_map_key_clear(KEY_WWW); + break; + case 0x19e: + samsung_kbd_mouse_map_key_clear(KEY_SCREENLOCK); + break; + case 0x221: + samsung_kbd_mouse_map_key_clear(KEY_SEARCH); + break; + case 0x223: + samsung_kbd_mouse_map_key_clear(KEY_HOMEPAGE); + break; + /* Smtart Voice Key */ + case 0x300: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY13); + break; + /* RECENTAPPS */ + case 0x301: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY1); + break; + /* APPLICATION */ + case 0x302: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY2); + break; + /* Voice search */ + case 0x305: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY4); + break; + /* QPANEL on/off */ + case 0x306: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY5); + break; + /* SIP on/off */ + case 0x307: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY3); + break; + /* LANG */ + case 0x308: + samsung_kbd_mouse_map_key_clear(KEY_LANGUAGE); + break; + case 0x30a: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSDOWN); + break; + case 0x30b: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSUP); + break; + default: + return 0; + } + } + + return 1; +} + static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { @@ -161,6 +265,9 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE && hid_is_usb(hdev)) ret = samsung_kbd_mouse_input_mapping(hdev, hi, field, usage, bit, max); + else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) + ret = samsung_kbd_input_mapping(hdev, + hi, field, usage, bit, max); return ret; } @@ -203,6 +310,7 @@ static int samsung_probe(struct hid_device *hdev, static const struct hid_device_id samsung_devices[] = { { HID_USB_DEVICE(USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_IR_REMOTE) }, { HID_USB_DEVICE(USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE) }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) }, { } }; MODULE_DEVICE_TABLE(hid, samsung_devices); -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108092009epcas5p15c5be87fa427a5c4426c55c86c5ce3bc@epcas5p1.samsung.com>]
* [HID Patchsets for Samsung driver v2 4/6] HID: Samsung : Add Samsung wireless gamepad support. [not found] ` <CGME20240108092009epcas5p15c5be87fa427a5c4426c55c86c5ce3bc@epcas5p1.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 0 siblings, 0 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Add support for samsung wireless gamepad with input mapping events. Device a000 (Samsung wireless gamepad) Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-ids.h | 1 + drivers/hid/hid-samsung.c | 95 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index 2f526dc8983a..2851dc25f949 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h @@ -1143,6 +1143,7 @@ #define USB_DEVICE_ID_SAMSUNG_IR_REMOTE 0x0001 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE 0x0600 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD 0x7021 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD 0xa000 #define USB_VENDOR_ID_SEMICO 0x1a2c #define USB_DEVICE_ID_SEMICO_USB_KEYKOARD 0x0023 diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index 611acd7ffd6d..6b08acd3c4fd 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -248,6 +248,97 @@ static int samsung_kbd_input_mapping(struct hid_device *hdev, return 1; } +static int samsung_gamepad_input_mapping(struct hid_device *hdev, + struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, + unsigned long **bit, int *max) +{ + if (!(HID_UP_BUTTON == (usage->hid & HID_USAGE_PAGE) || + HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE))) + return 0; + + dbg_hid("samsung wireless gamepad input mapping event [0x%x], %ld, %ld, [0x%x]\n", + usage->hid & HID_USAGE, hi->input->evbit[0], hi->input->absbit[0], usage->hid & HID_USAGE_PAGE); + + if (HID_UP_BUTTON == (usage->hid & HID_USAGE_PAGE)) { + switch (usage->hid & HID_USAGE) { + case 0x01: + samsung_kbd_mouse_map_key_clear(BTN_A); + break; + case 0x02: + samsung_kbd_mouse_map_key_clear(BTN_B); + break; + case 0x03: + samsung_kbd_mouse_map_key_clear(BTN_C); + break; + case 0x04: + samsung_kbd_mouse_map_key_clear(BTN_X); + break; + case 0x05: + samsung_kbd_mouse_map_key_clear(BTN_Y); + break; + case 0x06: + samsung_kbd_mouse_map_key_clear(BTN_Z); + break; + case 0x07: + samsung_kbd_mouse_map_key_clear(BTN_TL); + break; + case 0x08: + samsung_kbd_mouse_map_key_clear(BTN_TR); + break; + case 0x09: + samsung_kbd_mouse_map_key_clear(BTN_TL2); + break; + case 0x0a: + samsung_kbd_mouse_map_key_clear(BTN_TR2); + break; + case 0x0b: + samsung_kbd_mouse_map_key_clear(BTN_SELECT); + break; + case 0x0c: + samsung_kbd_mouse_map_key_clear(BTN_START); + break; + case 0x0d: + samsung_kbd_mouse_map_key_clear(BTN_MODE); + break; + case 0x0e: + samsung_kbd_mouse_map_key_clear(BTN_THUMBL); + break; + case 0x0f: + samsung_kbd_mouse_map_key_clear(BTN_THUMBR); + break; + case 0x10: + samsung_kbd_mouse_map_key_clear(0x13f); + break; + default: + return 0; + } + } + + if (HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE)) { + switch (usage->hid & HID_USAGE) { + case 0x040: + samsung_kbd_mouse_map_key_clear(KEY_MENU); + break; + case 0x223: + samsung_kbd_mouse_map_key_clear(KEY_HOMEPAGE); + break; + case 0x224: + samsung_kbd_mouse_map_key_clear(KEY_BACK); + break; + + /* Screen Capture */ + case 0x303: + samsung_kbd_mouse_map_key_clear(KEY_SYSRQ); + break; + + default: + return 0; + } + } + + return 1; +} + static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { @@ -268,6 +359,9 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) ret = samsung_kbd_input_mapping(hdev, hi, field, usage, bit, max); + else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD) + ret = samsung_gamepad_input_mapping(hdev, + hi, field, usage, bit, max); return ret; } @@ -311,6 +405,7 @@ static const struct hid_device_id samsung_devices[] = { { HID_USB_DEVICE(USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_IR_REMOTE) }, { HID_USB_DEVICE(USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE) }, { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD) }, { } }; MODULE_DEVICE_TABLE(hid, samsung_devices); -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108092017epcas5p24c1c263149a0a8bf3204c86925e3cfd9@epcas5p2.samsung.com>]
* [HID Patchsets for Samsung driver v2 5/6] HID: Samsung : Add Samsung wireless action mouse support. [not found] ` <CGME20240108092017epcas5p24c1c263149a0a8bf3204c86925e3cfd9@epcas5p2.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 0 siblings, 0 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Add support for samsung wireless action mouse with input mapping events. Device a004 (Samsung wireless action mouse) Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-ids.h | 1 + drivers/hid/hid-samsung.c | 27 +++++++++++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index 2851dc25f949..b1208d04712c 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h @@ -1144,6 +1144,7 @@ #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE 0x0600 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD 0x7021 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD 0xa000 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE 0xa004 #define USB_VENDOR_ID_SEMICO 0x1a2c #define USB_DEVICE_ID_SEMICO_USB_KEYKOARD 0x0023 diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index 6b08acd3c4fd..36ab9540e064 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -339,6 +339,29 @@ static int samsung_gamepad_input_mapping(struct hid_device *hdev, return 1; } +static int samsung_actionmouse_input_mapping(struct hid_device *hdev, + struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, + unsigned long **bit, int *max) +{ + + dbg_hid("samsung wireless actionmouse input mapping event [0x%x], [0x%x], %ld, %ld, [0x%x]\n", + usage->hid, usage->hid & HID_USAGE, hi->input->evbit[0], hi->input->absbit[0], + usage->hid & HID_USAGE_PAGE); + + if (((usage->hid & HID_USAGE_PAGE) != HID_UP_CONSUMER) && ((usage->hid & HID_USAGE_PAGE) != HID_UP_BUTTON)) + return 0; + + switch (usage->hid & HID_USAGE) { + case 0x301: + samsung_kbd_mouse_map_key_clear(254); + break; + default: + return 0; + } + + return 1; +} + static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { @@ -362,6 +385,9 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD) ret = samsung_gamepad_input_mapping(hdev, hi, field, usage, bit, max); + else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE) + ret = samsung_actionmouse_input_mapping(hdev, + hi, field, usage, bit, max); return ret; } @@ -406,6 +432,7 @@ static const struct hid_device_id samsung_devices[] = { { HID_USB_DEVICE(USB_VENDOR_ID_SAMSUNG, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD_MOUSE) }, { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) }, { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD) }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE) }, { } }; MODULE_DEVICE_TABLE(hid, samsung_devices); -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
[parent not found: <CGME20240108092025epcas5p39e2ecb3b12b4fba9e41f0694f430ec1d@epcas5p3.samsung.com>]
* [HID Patchsets for Samsung driver v2 6/6] HID: Samsung : Add Samsung wireless bookcover and universal keyboard support. [not found] ` <CGME20240108092025epcas5p39e2ecb3b12b4fba9e41f0694f430ec1d@epcas5p3.samsung.com> @ 2024-01-08 9:19 ` Sandeep C S 0 siblings, 0 replies; 12+ messages in thread From: Sandeep C S @ 2024-01-08 9:19 UTC (permalink / raw) To: Jiri Kosina, Benjamin Tissoires Cc: gaudium.lee, ih0923.kim, suhyun_.kim, jitender.s21, junwan.cho, sandeep.cs, linux-input, linux-kernel Add support for samsung wireless bookcover and universal keyboard with input mapping events. Device a005 (Samsung wireless bookcover keyboard) Device a006 (Samsung wireless universal keyboard) Device a064 (Samsung wireless multi hogp keyboard) Signed-off-by: Sandeep C S <sandeep.cs@samsung.com> Signed-off-by: Junwan Cho <junwan.cho@samsung.com> Signed-off-by: Jitender Sajwan <jitender.s21@samsung.com> --- drivers/hid/hid-ids.h | 3 + drivers/hid/hid-samsung.c | 142 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 145 insertions(+) diff --git a/drivers/hid/hid-ids.h b/drivers/hid/hid-ids.h index b1208d04712c..c03137ada8f5 100644 --- a/drivers/hid/hid-ids.h +++ b/drivers/hid/hid-ids.h @@ -1145,6 +1145,9 @@ #define USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD 0x7021 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD 0xa000 #define USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE 0xa004 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_BOOKCOVER 0xa005 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_UNIVERSAL_KBD 0xa006 +#define USB_DEVICE_ID_SAMSUNG_WIRELESS_MULTI_HOGP_KBD 0xa064 #define USB_VENDOR_ID_SEMICO 0x1a2c #define USB_DEVICE_ID_SEMICO_USB_KEYKOARD 0x0023 diff --git a/drivers/hid/hid-samsung.c b/drivers/hid/hid-samsung.c index 36ab9540e064..ba1c71f25d78 100644 --- a/drivers/hid/hid-samsung.c +++ b/drivers/hid/hid-samsung.c @@ -362,6 +362,140 @@ static int samsung_actionmouse_input_mapping(struct hid_device *hdev, return 1; } +static int samsung_universal_kbd_input_mapping(struct hid_device *hdev, + struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, + unsigned long **bit, int *max) +{ + if (!(HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE) || + HID_UP_KEYBOARD == (usage->hid & HID_USAGE_PAGE))) + return 0; + + dbg_hid("samsung wireless keyboard input mapping event [0x%x]\n", + usage->hid & HID_USAGE); + + if (HID_UP_KEYBOARD == (usage->hid & HID_USAGE_PAGE)) { + set_bit(EV_REP, hi->input->evbit); + switch (usage->hid & HID_USAGE) { + /* Only for UK keyboard */ + /* key found */ +#ifdef CONFIG_HID_KK_UPGRADE + case 0x32: + samsung_kbd_mouse_map_key_clear(KEY_KBDILLUMTOGGLE); + break; + case 0x64: + samsung_kbd_mouse_map_key_clear(KEY_BACKSLASH); + break; +#else + case 0x32: + samsung_kbd_mouse_map_key_clear(KEY_BACKSLASH); + break; + case 0x64: + samsung_kbd_mouse_map_key_clear(KEY_102ND); + break; +#endif + /* Only for BR keyboard */ + case 0x87: + samsung_kbd_mouse_map_key_clear(KEY_RO); + break; + default: + return 0; + } + } + + if (HID_UP_CONSUMER == (usage->hid & HID_USAGE_PAGE)) { + switch (usage->hid & HID_USAGE) { + /* report 2 */ + /* MENU */ + case 0x040: + samsung_kbd_mouse_map_key_clear(KEY_MENU); + break; + case 0x18a: + samsung_kbd_mouse_map_key_clear(KEY_MAIL); + break; + case 0x196: + samsung_kbd_mouse_map_key_clear(KEY_WWW); + break; + case 0x19e: + samsung_kbd_mouse_map_key_clear(KEY_SCREENLOCK); + break; + case 0x221: + samsung_kbd_mouse_map_key_clear(KEY_SEARCH); + break; + case 0x223: + samsung_kbd_mouse_map_key_clear(KEY_HOMEPAGE); + break; + /* RECENTAPPS */ + case 0x301: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY1); + break; + /* APPLICATION */ + case 0x302: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY2); + break; + /* Voice search */ + case 0x305: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY4); + break; + /* QPANEL on/off */ + case 0x306: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY5); + break; + /* SIP on/off */ + case 0x307: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY3); + break; + /* LANG */ + case 0x308: + samsung_kbd_mouse_map_key_clear(KEY_LANGUAGE); + break; + case 0x30a: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSDOWN); + break; + case 0x070: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSDOWN); + break; + case 0x30b: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSUP); + break; + case 0x06f: + samsung_kbd_mouse_map_key_clear(KEY_BRIGHTNESSUP); + break; + /* S-Finder */ + case 0x304: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY7); + break; + /* Screen Capture */ + case 0x303: + samsung_kbd_mouse_map_key_clear(KEY_SYSRQ); + break; + /* Multi Window */ + case 0x309: + samsung_kbd_mouse_map_key_clear(BTN_TRIGGER_HAPPY9); + break; + /* HotKey App 1 */ + case 0x071: + samsung_kbd_mouse_map_key_clear(0x2f5); + break; + /* HotKey App 2 */ + case 0x072: + samsung_kbd_mouse_map_key_clear(0x2f6); + break; + /* HotKey App 3 */ + case 0x073: + samsung_kbd_mouse_map_key_clear(0x2f7); + break; + /* Dex */ + case 0x06e: + samsung_kbd_mouse_map_key_clear(0x2bd); + break; + default: + return 0; + } + } + + return 1; +} + static __u8 *samsung_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) { @@ -388,6 +522,12 @@ static int samsung_input_mapping(struct hid_device *hdev, struct hid_input *hi, else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE) ret = samsung_actionmouse_input_mapping(hdev, hi, field, usage, bit, max); + else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_UNIVERSAL_KBD) + ret = samsung_universal_kbd_input_mapping(hdev, + hi, field, usage, bit, max); + else if (hdev->product == USB_DEVICE_ID_SAMSUNG_WIRELESS_MULTI_HOGP_KBD) + ret = samsung_universal_kbd_input_mapping(hdev, + hi, field, usage, bit, max); return ret; } @@ -433,6 +573,8 @@ static const struct hid_device_id samsung_devices[] = { { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_KBD) }, { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_GAMEPAD) }, { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_ACTIONMOUSE) }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_UNIVERSAL_KBD) }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_SAMSUNG_ELECTRONICS, USB_DEVICE_ID_SAMSUNG_WIRELESS_MULTI_HOGP_KBD) }, { } }; MODULE_DEVICE_TABLE(hid, samsung_devices); -- 2.34.1 ^ permalink raw reply related [flat|nested] 12+ messages in thread
end of thread, other threads:[~2024-01-23 10:04 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- [not found] <CGME20240108091950epcas5p41633efaf7b62db312982aa2f94a26db3@epcas5p4.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 0/6] HID Support for Samsung driver Sandeep C S [not found] ` <CGME20240108091954epcas5p39f9ca04b57adf01a7c964593b7be87d2@epcas5p3.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 1/6] HID Samsung : Broaden device compatibility in samsung driver Sandeep C S [not found] ` <CGME20240108091959epcas5p2559b779424e2fb7c7e268d1b24612b4f@epcas5p2.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 2/6] HID: Samsung : Fix the checkpatch complain Sandeep C S 2024-01-08 10:21 ` Joe Perches 2024-01-08 10:44 ` sandeep.cs 2024-01-09 2:34 ` Joe Perches 2024-01-23 9:49 ` Jiri Kosina 2024-01-23 10:04 ` sandeep.cs [not found] ` <CGME20240108092004epcas5p1c7069a6ede85066817d8ce5a79da75ad@epcas5p1.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 3/6] HID: Samsung : Add Samsung wireless keyboard support Sandeep C S [not found] ` <CGME20240108092009epcas5p15c5be87fa427a5c4426c55c86c5ce3bc@epcas5p1.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 4/6] HID: Samsung : Add Samsung wireless gamepad support Sandeep C S [not found] ` <CGME20240108092017epcas5p24c1c263149a0a8bf3204c86925e3cfd9@epcas5p2.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 5/6] HID: Samsung : Add Samsung wireless action mouse support Sandeep C S [not found] ` <CGME20240108092025epcas5p39e2ecb3b12b4fba9e41f0694f430ec1d@epcas5p3.samsung.com> 2024-01-08 9:19 ` [HID Patchsets for Samsung driver v2 6/6] HID: Samsung : Add Samsung wireless bookcover and universal keyboard support Sandeep C S
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).