linux/drivers/hid/hid-roccat-pyra.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0-or-later */
   2#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/*
  10 */
  11
  12#include <linux/types.h>
  13
  14enum {
  15        PYRA_SIZE_CONTROL = 0x03,
  16        PYRA_SIZE_INFO = 0x06,
  17        PYRA_SIZE_PROFILE_SETTINGS = 0x0d,
  18        PYRA_SIZE_PROFILE_BUTTONS = 0x13,
  19        PYRA_SIZE_SETTINGS = 0x03,
  20};
  21
  22enum pyra_control_requests {
  23        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! */
  31} __attribute__ ((__packed__));
  32
  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 */
  46} __attribute__ ((__packed__));
  47
  48struct 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 */
  55} __attribute__ ((__packed__));
  56
  57enum pyra_commands {
  58        PYRA_COMMAND_CONTROL = 0x4,
  59        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
  66enum 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;
  78} __attribute__ ((__packed__));
  79
  80struct pyra_mouse_event_audio {
  81        uint8_t report_number; /* always 2 */
  82        uint8_t type;
  83        uint8_t unused; /* always 0 */
  84} __attribute__ ((__packed__));
  85
  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;
 138} __attribute__ ((__packed__));
 139
 140struct pyra_device {
 141        int actual_profile;
 142        int actual_cpi;
 143        int roccat_claimed;
 144        int chrdev_minor;
 145        struct mutex pyra_lock;
 146        struct pyra_profile_settings profile_settings[5];
 147};
 148
 149#endif
 150