blob: 7fc61006e8b06f35b28cd5f3fe19d98a98719965 [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +02002#ifndef __HID_ROCCAT_PYRA_H
3#define __HID_ROCCAT_PYRA_H
4
5/*
6 * Copyright (c) 2010 Stefan Achatz <erazor_de@users.sourceforge.net>
7 */
8
9/*
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020010 */
11
12#include <linux/types.h>
13
Stefan Achatzbe343802012-11-11 06:20:58 +010014enum {
Stefan Achatzecbfe7a2012-11-11 06:21:10 +010015 PYRA_SIZE_CONTROL = 0x03,
Stefan Achatzbe343802012-11-11 06:20:58 +010016 PYRA_SIZE_INFO = 0x06,
17 PYRA_SIZE_PROFILE_SETTINGS = 0x0d,
18 PYRA_SIZE_PROFILE_BUTTONS = 0x13,
19 PYRA_SIZE_SETTINGS = 0x03,
20};
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020021
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020022enum pyra_control_requests {
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020023 PYRA_CONTROL_REQUEST_PROFILE_SETTINGS = 0x10,
24 PYRA_CONTROL_REQUEST_PROFILE_BUTTONS = 0x20
25};
26
27struct pyra_settings {
28 uint8_t command; /* PYRA_COMMAND_SETTINGS */
29 uint8_t size; /* always 3 */
30 uint8_t startup_profile; /* Range 0-4! */
Jiri Kosina4d043102010-12-09 14:29:34 +010031} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020032
33struct pyra_profile_settings {
34 uint8_t command; /* PYRA_COMMAND_PROFILE_SETTINGS */
35 uint8_t size; /* always 0xd */
36 uint8_t number; /* Range 0-4 */
37 uint8_t xysync;
38 uint8_t x_sensitivity; /* 0x1-0xa */
39 uint8_t y_sensitivity;
40 uint8_t x_cpi; /* unused */
41 uint8_t y_cpi; /* this value is for x and y */
42 uint8_t lightswitch; /* 0 = off, 1 = on */
43 uint8_t light_effect;
44 uint8_t handedness;
45 uint16_t checksum; /* byte sum */
Jiri Kosina4d043102010-12-09 14:29:34 +010046} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020047
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020048struct pyra_info {
49 uint8_t command; /* PYRA_COMMAND_INFO */
50 uint8_t size; /* always 6 */
51 uint8_t firmware_version;
52 uint8_t unknown1; /* always 0 */
53 uint8_t unknown2; /* always 1 */
54 uint8_t unknown3; /* always 0 */
Jiri Kosina4d043102010-12-09 14:29:34 +010055} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020056
57enum pyra_commands {
Stefan Achatzecbfe7a2012-11-11 06:21:10 +010058 PYRA_COMMAND_CONTROL = 0x4,
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020059 PYRA_COMMAND_SETTINGS = 0x5,
60 PYRA_COMMAND_PROFILE_SETTINGS = 0x6,
61 PYRA_COMMAND_PROFILE_BUTTONS = 0x7,
62 PYRA_COMMAND_INFO = 0x9,
63 PYRA_COMMAND_B = 0xb
64};
65
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020066enum pyra_mouse_report_numbers {
67 PYRA_MOUSE_REPORT_NUMBER_HID = 1,
68 PYRA_MOUSE_REPORT_NUMBER_AUDIO = 2,
69 PYRA_MOUSE_REPORT_NUMBER_BUTTON = 3,
70};
71
72struct pyra_mouse_event_button {
73 uint8_t report_number; /* always 3 */
74 uint8_t unknown; /* always 0 */
75 uint8_t type;
76 uint8_t data1;
77 uint8_t data2;
Jiri Kosina4d043102010-12-09 14:29:34 +010078} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020079
80struct pyra_mouse_event_audio {
81 uint8_t report_number; /* always 2 */
82 uint8_t type;
83 uint8_t unused; /* always 0 */
Jiri Kosina4d043102010-12-09 14:29:34 +010084} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +020085
86/* hid audio controls */
87enum pyra_mouse_event_audio_types {
88 PYRA_MOUSE_EVENT_AUDIO_TYPE_MUTE = 0xe2,
89 PYRA_MOUSE_EVENT_AUDIO_TYPE_VOLUME_UP = 0xe9,
90 PYRA_MOUSE_EVENT_AUDIO_TYPE_VOLUME_DOWN = 0xea,
91};
92
93enum pyra_mouse_event_button_types {
94 /*
95 * Mouse sends tilt events on report_number 1 and 3
96 * Tilt events are sent repeatedly with 0.94s between first and second
97 * event and 0.22s on subsequent
98 */
99 PYRA_MOUSE_EVENT_BUTTON_TYPE_TILT = 0x10,
100
101 /*
102 * These are sent sequentially
103 * data1 contains new profile number in range 1-5
104 */
105 PYRA_MOUSE_EVENT_BUTTON_TYPE_PROFILE_1 = 0x20,
106 PYRA_MOUSE_EVENT_BUTTON_TYPE_PROFILE_2 = 0x30,
107
108 /*
109 * data1 = button_number (rmp index)
110 * data2 = pressed/released
111 */
112 PYRA_MOUSE_EVENT_BUTTON_TYPE_MACRO = 0x40,
113 PYRA_MOUSE_EVENT_BUTTON_TYPE_SHORTCUT = 0x50,
114
115 /*
116 * data1 = button_number (rmp index)
117 */
118 PYRA_MOUSE_EVENT_BUTTON_TYPE_QUICKLAUNCH = 0x60,
119
120 /* data1 = new cpi */
121 PYRA_MOUSE_EVENT_BUTTON_TYPE_CPI = 0xb0,
122
123 /* data1 and data2 = new sensitivity */
124 PYRA_MOUSE_EVENT_BUTTON_TYPE_SENSITIVITY = 0xc0,
125
126 PYRA_MOUSE_EVENT_BUTTON_TYPE_MULTIMEDIA = 0xf0,
127};
128
129enum {
130 PYRA_MOUSE_EVENT_BUTTON_PRESS = 0,
131 PYRA_MOUSE_EVENT_BUTTON_RELEASE = 1,
132};
133
134struct pyra_roccat_report {
135 uint8_t type;
136 uint8_t value;
137 uint8_t key;
Jiri Kosina4d043102010-12-09 14:29:34 +0100138} __attribute__ ((__packed__));
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +0200139
140struct pyra_device {
141 int actual_profile;
142 int actual_cpi;
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +0200143 int roccat_claimed;
144 int chrdev_minor;
145 struct mutex pyra_lock;
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +0200146 struct pyra_profile_settings profile_settings[5];
Stefan Achatzcb7cf3d2010-08-29 12:30:18 +0200147};
148
149#endif