Blame view

drivers/hid/hid-sunplus.c 2.05 KB
90231e7ea   Jiri Slaby   HID: move sunplus...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
  /*
   *  HID driver for some sunplus "special" devices
   *
   *  Copyright (c) 1999 Andreas Gal
   *  Copyright (c) 2000-2005 Vojtech Pavlik <vojtech@suse.cz>
   *  Copyright (c) 2005 Michael Haboustak <mike-@cinci.rr.com> for Concept2, Inc
   *  Copyright (c) 2006-2007 Jiri Kosina
   *  Copyright (c) 2007 Paul Walmsley
   *  Copyright (c) 2008 Jiri Slaby
   */
  
  /*
   * This program is free software; you can redistribute it and/or modify it
   * under the terms of the GNU General Public License as published by the Free
   * Software Foundation; either version 2 of the License, or (at your option)
   * any later version.
   */
  
  #include <linux/device.h>
  #include <linux/hid.h>
  #include <linux/module.h>
  
  #include "hid-ids.h"
73e4008dd   Nikolai Kondrashov   HID: allow resizi...
24
25
  static __u8 *sp_report_fixup(struct hid_device *hdev, __u8 *rdesc,
  		unsigned int *rsize)
90231e7ea   Jiri Slaby   HID: move sunplus...
26
  {
73e4008dd   Nikolai Kondrashov   HID: allow resizi...
27
  	if (*rsize >= 107 && rdesc[104] == 0x26 && rdesc[105] == 0x80 &&
90231e7ea   Jiri Slaby   HID: move sunplus...
28
  			rdesc[106] == 0x03) {
4291ee305   Joe Perches   HID: Add and use ...
29
30
  		hid_info(hdev, "fixing up Sunplus Wireless Desktop report descriptor
  ");
90231e7ea   Jiri Slaby   HID: move sunplus...
31
32
33
  		rdesc[105] = rdesc[110] = 0x03;
  		rdesc[106] = rdesc[111] = 0x21;
  	}
73e4008dd   Nikolai Kondrashov   HID: allow resizi...
34
  	return rdesc;
90231e7ea   Jiri Slaby   HID: move sunplus...
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
  }
  
  #define sp_map_key_clear(c)	hid_map_usage_clear(hi, usage, bit, max, \
  		EV_KEY, (c))
  static int sp_input_mapping(struct hid_device *hdev, struct hid_input *hi,
  		struct hid_field *field, struct hid_usage *usage,
  		unsigned long **bit, int *max)
  {
  	if ((usage->hid & HID_USAGE_PAGE) != HID_UP_CONSUMER)
  		return 0;
  
  	switch (usage->hid & HID_USAGE) {
  	case 0x2003: sp_map_key_clear(KEY_ZOOMIN);		break;
  	case 0x2103: sp_map_key_clear(KEY_ZOOMOUT);	break;
  	default:
  		return 0;
  	}
  	return 1;
  }
  
  static const struct hid_device_id sp_devices[] = {
  	{ HID_USB_DEVICE(USB_VENDOR_ID_SUNPLUS, USB_DEVICE_ID_SUNPLUS_WDESKTOP) },
  	{ }
  };
  MODULE_DEVICE_TABLE(hid, sp_devices);
  
  static struct hid_driver sp_driver = {
  	.name = "sunplus",
  	.id_table = sp_devices,
  	.report_fixup = sp_report_fixup,
  	.input_mapping = sp_input_mapping,
  };
a24f423bd   Peter Huewe   HID: adding __ini...
67
  static int __init sp_init(void)
90231e7ea   Jiri Slaby   HID: move sunplus...
68
69
70
  {
  	return hid_register_driver(&sp_driver);
  }
a24f423bd   Peter Huewe   HID: adding __ini...
71
  static void __exit sp_exit(void)
90231e7ea   Jiri Slaby   HID: move sunplus...
72
73
74
75
76
77
78
  {
  	hid_unregister_driver(&sp_driver);
  }
  
  module_init(sp_init);
  module_exit(sp_exit);
  MODULE_LICENSE("GPL");