xref: /OK3568_Linux_fs/kernel/drivers/hid/hid-roccat-koneplus.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */
2*4882a593Smuzhiyun #ifndef __HID_ROCCAT_KONEPLUS_H
3*4882a593Smuzhiyun #define __HID_ROCCAT_KONEPLUS_H
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun /*
6*4882a593Smuzhiyun  * Copyright (c) 2010 Stefan Achatz <erazor_de@users.sourceforge.net>
7*4882a593Smuzhiyun  */
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun /*
10*4882a593Smuzhiyun  */
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun #include <linux/types.h>
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun enum {
15*4882a593Smuzhiyun 	KONEPLUS_SIZE_ACTUAL_PROFILE = 0x03,
16*4882a593Smuzhiyun 	KONEPLUS_SIZE_CONTROL = 0x03,
17*4882a593Smuzhiyun 	KONEPLUS_SIZE_FIRMWARE_WRITE = 0x0402,
18*4882a593Smuzhiyun 	KONEPLUS_SIZE_INFO = 0x06,
19*4882a593Smuzhiyun 	KONEPLUS_SIZE_MACRO = 0x0822,
20*4882a593Smuzhiyun 	KONEPLUS_SIZE_PROFILE_SETTINGS = 0x2b,
21*4882a593Smuzhiyun 	KONEPLUS_SIZE_PROFILE_BUTTONS = 0x4d,
22*4882a593Smuzhiyun 	KONEPLUS_SIZE_SENSOR = 0x06,
23*4882a593Smuzhiyun 	KONEPLUS_SIZE_TALK = 0x10,
24*4882a593Smuzhiyun 	KONEPLUS_SIZE_TCU = 0x04,
25*4882a593Smuzhiyun 	KONEPLUS_SIZE_TCU_IMAGE = 0x0404,
26*4882a593Smuzhiyun };
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun enum koneplus_control_requests {
29*4882a593Smuzhiyun 	KONEPLUS_CONTROL_REQUEST_PROFILE_SETTINGS = 0x80,
30*4882a593Smuzhiyun 	KONEPLUS_CONTROL_REQUEST_PROFILE_BUTTONS = 0x90,
31*4882a593Smuzhiyun };
32*4882a593Smuzhiyun 
33*4882a593Smuzhiyun struct koneplus_actual_profile {
34*4882a593Smuzhiyun 	uint8_t command; /* KONEPLUS_COMMAND_ACTUAL_PROFILE */
35*4882a593Smuzhiyun 	uint8_t size; /* always 3 */
36*4882a593Smuzhiyun 	uint8_t actual_profile; /* Range 0-4! */
37*4882a593Smuzhiyun } __attribute__ ((__packed__));
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun struct koneplus_info {
40*4882a593Smuzhiyun 	uint8_t command; /* KONEPLUS_COMMAND_INFO */
41*4882a593Smuzhiyun 	uint8_t size; /* always 6 */
42*4882a593Smuzhiyun 	uint8_t firmware_version;
43*4882a593Smuzhiyun 	uint8_t unknown[3];
44*4882a593Smuzhiyun } __attribute__ ((__packed__));
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun enum koneplus_commands {
47*4882a593Smuzhiyun 	KONEPLUS_COMMAND_ACTUAL_PROFILE = 0x5,
48*4882a593Smuzhiyun 	KONEPLUS_COMMAND_CONTROL = 0x4,
49*4882a593Smuzhiyun 	KONEPLUS_COMMAND_PROFILE_SETTINGS = 0x6,
50*4882a593Smuzhiyun 	KONEPLUS_COMMAND_PROFILE_BUTTONS = 0x7,
51*4882a593Smuzhiyun 	KONEPLUS_COMMAND_MACRO = 0x8,
52*4882a593Smuzhiyun 	KONEPLUS_COMMAND_INFO = 0x9,
53*4882a593Smuzhiyun 	KONEPLUS_COMMAND_TCU = 0xc,
54*4882a593Smuzhiyun 	KONEPLUS_COMMAND_TCU_IMAGE = 0xc,
55*4882a593Smuzhiyun 	KONEPLUS_COMMAND_E = 0xe,
56*4882a593Smuzhiyun 	KONEPLUS_COMMAND_SENSOR = 0xf,
57*4882a593Smuzhiyun 	KONEPLUS_COMMAND_TALK = 0x10,
58*4882a593Smuzhiyun 	KONEPLUS_COMMAND_FIRMWARE_WRITE = 0x1b,
59*4882a593Smuzhiyun 	KONEPLUS_COMMAND_FIRMWARE_WRITE_CONTROL = 0x1c,
60*4882a593Smuzhiyun };
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun enum koneplus_mouse_report_numbers {
63*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_NUMBER_HID = 1,
64*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_NUMBER_AUDIO = 2,
65*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_NUMBER_BUTTON = 3,
66*4882a593Smuzhiyun };
67*4882a593Smuzhiyun 
68*4882a593Smuzhiyun struct koneplus_mouse_report_button {
69*4882a593Smuzhiyun 	uint8_t report_number; /* always KONEPLUS_MOUSE_REPORT_NUMBER_BUTTON */
70*4882a593Smuzhiyun 	uint8_t zero1;
71*4882a593Smuzhiyun 	uint8_t type;
72*4882a593Smuzhiyun 	uint8_t data1;
73*4882a593Smuzhiyun 	uint8_t data2;
74*4882a593Smuzhiyun 	uint8_t zero2;
75*4882a593Smuzhiyun 	uint8_t unknown[2];
76*4882a593Smuzhiyun } __attribute__ ((__packed__));
77*4882a593Smuzhiyun 
78*4882a593Smuzhiyun enum koneplus_mouse_report_button_types {
79*4882a593Smuzhiyun 	/* data1 = new profile range 1-5 */
80*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_PROFILE = 0x20,
81*4882a593Smuzhiyun 
82*4882a593Smuzhiyun 	/* data1 = button number range 1-24; data2 = action */
83*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_QUICKLAUNCH = 0x60,
84*4882a593Smuzhiyun 
85*4882a593Smuzhiyun 	/* data1 = button number range 1-24; data2 = action */
86*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_TIMER = 0x80,
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun 	/* data1 = setting number range 1-5 */
89*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_CPI = 0xb0,
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun 	/* data1 and data2 = range 0x1-0xb */
92*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_SENSITIVITY = 0xc0,
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun 	/* data1 = 22 = next track...
95*4882a593Smuzhiyun 	 * data2 = action
96*4882a593Smuzhiyun 	 */
97*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_TYPE_MULTIMEDIA = 0xf0,
98*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_TALK = 0xff,
99*4882a593Smuzhiyun };
100*4882a593Smuzhiyun 
101*4882a593Smuzhiyun enum koneplus_mouse_report_button_action {
102*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_ACTION_PRESS = 0,
103*4882a593Smuzhiyun 	KONEPLUS_MOUSE_REPORT_BUTTON_ACTION_RELEASE = 1,
104*4882a593Smuzhiyun };
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun struct koneplus_roccat_report {
107*4882a593Smuzhiyun 	uint8_t type;
108*4882a593Smuzhiyun 	uint8_t data1;
109*4882a593Smuzhiyun 	uint8_t data2;
110*4882a593Smuzhiyun 	uint8_t profile;
111*4882a593Smuzhiyun } __attribute__ ((__packed__));
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun struct koneplus_device {
114*4882a593Smuzhiyun 	int actual_profile;
115*4882a593Smuzhiyun 
116*4882a593Smuzhiyun 	int roccat_claimed;
117*4882a593Smuzhiyun 	int chrdev_minor;
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun 	struct mutex koneplus_lock;
120*4882a593Smuzhiyun };
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun #endif
123