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