10e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz#ifndef __HID_ROCCAT_KOVAPLUS_H
20e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz#define __HID_ROCCAT_KOVAPLUS_H
30e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
40e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz/*
50e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz * Copyright (c) 2010 Stefan Achatz <erazor_de@users.sourceforge.net>
60e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz */
70e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
80e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz/*
90e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz * This program is free software; you can redistribute it and/or modify it
100e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz * under the terms of the GNU General Public License as published by the Free
110e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz * Software Foundation; either version 2 of the License, or (at your option)
120e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz * any later version.
130e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz */
140e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
150e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz#include <linux/types.h>
160e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
170e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_control {
180e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_CONTROL */
190e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t value;
200e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t request;
210e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
220e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
230e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_control_requests {
240e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* read after write; value = 1 */
250e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_STATUS = 0x0,
260e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* write; value = profile number range 0-4 */
270e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_PROFILE_SETTINGS = 0x10,
280e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* write; value = profile number range 0-4 */
290e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_PROFILE_BUTTONS = 0x20,
300e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
310e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
320e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_control_values {
330e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_STATUS_OVERLOAD = 0, /* supposed */
340e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_STATUS_OK = 1,
350e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_CONTROL_REQUEST_STATUS_WAIT = 3, /* supposed */
360e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
370e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
380e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_actual_profile {
390e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_ACTUAL_PROFILE */
400e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t size; /* always 3 */
410e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t actual_profile; /* Range 0-4! */
420e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
430e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
440e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_profile_settings {
450e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_PROFILE_SETTINGS */
460e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t size; /* 16 */
470e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t profile_index; /* range 0-4 */
480e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t unknown1;
490e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t sensitivity_x; /* range 1-10 */
500e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t sensitivity_y; /* range 1-10 */
510e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t cpi_levels_enabled;
520e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t cpi_startup_level; /* range 1-4 */
530e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data[8];
540e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
550e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
560e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_profile_buttons {
570e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_PROFILE_BUTTONS */
580e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t size; /* 23 */
590e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t profile_index; /* range 0-4 */
600e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data[20];
610e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
620e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
630e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_info {
640e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_INFO */
650e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t size; /* 6 */
660e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t firmware_version;
670e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t unknown[3];
680e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
690e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
700e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz/* writes 1 on plugin */
710e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_a {
720e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t command; /* KOVAPLUS_COMMAND_A */
730e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t size; /* 3 */
740e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t unknown;
750e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
760e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
770e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_commands {
780e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_CONTROL = 0x4,
790e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_ACTUAL_PROFILE = 0x5,
800e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_PROFILE_SETTINGS = 0x6,
810e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_PROFILE_BUTTONS = 0x7,
820e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_INFO = 0x9,
830e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_COMMAND_A = 0xa,
840e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
850e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
860e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_mouse_report_numbers {
870e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_NUMBER_MOUSE = 1,
880e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_NUMBER_AUDIO = 2,
890e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_NUMBER_BUTTON = 3,
900e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_NUMBER_KBD = 4,
910e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
920e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
930e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_mouse_report_button {
940e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t report_number; /* KOVAPLUS_MOUSE_REPORT_NUMBER_BUTTON */
950e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t unknown1;
960e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t type;
970e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data1;
980e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data2;
990e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
1000e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
1010e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_mouse_report_button_types {
1020e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = profile_number range 1-5; no release event */
1030e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_PROFILE_1 = 0x20,
1040e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = profile_number range 1-5; no release event */
1050e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_PROFILE_2 = 0x30,
1060e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = button_number range 1-18; data2 = action */
1070e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_MACRO = 0x40,
1080e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = button_number range 1-18; data2 = action */
1090e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_SHORTCUT = 0x50,
1100e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = button_number range 1-18; data2 = action */
1110e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_QUICKLAUNCH = 0x60,
1120e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = button_number range 1-18; data2 = action */
1130e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_TIMER = 0x80,
1140e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = 1 = 400, 2 = 800, 4 = 1600, 7 = 3200; no release event */
1150e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_CPI = 0xb0,
1160e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 + data2 = sense range 1-10; no release event */
1170e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_SENSITIVITY = 0xc0,
1180e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	/* data1 = type as in profile_buttons; data2 = action */
1190e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_TYPE_MULTIMEDIA = 0xf0,
1200e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
1210e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
1220e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzenum kovaplus_mouse_report_button_actions {
1230e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_ACTION_PRESS = 0,
1240e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	KOVAPLUS_MOUSE_REPORT_BUTTON_ACTION_RELEASE = 1,
1250e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
1260e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
1270e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_roccat_report {
1280e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t type;
1290e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t profile;
1300e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t button;
1310e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data1;
1320e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	uint8_t data2;
1330e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz} __packed;
1340e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
1350e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatzstruct kovaplus_device {
1360e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int actual_profile;
1370e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int actual_cpi;
1380e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int actual_x_sensitivity;
1390e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int actual_y_sensitivity;
1400e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int roccat_claimed;
1410e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	int chrdev_minor;
1420e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	struct mutex kovaplus_lock;
1430e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	struct kovaplus_info info;
1440e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	struct kovaplus_profile_settings profile_settings[5];
1450e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz	struct kovaplus_profile_buttons profile_buttons[5];
1460e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz};
1470e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz
1480e70f97f257edcef4daa92ab9371a9aac0c851edStefan Achatz#endif
149