Kodi Development  20.0
for Binary and Script based Add-Ons
peripheral.h
1 /*
2  * Copyright (C) 2014-2018 Team Kodi
3  * This file is part of Kodi - https://kodi.tv
4  *
5  * SPDX-License-Identifier: GPL-2.0-or-later
6  * See LICENSES/README.md for more information.
7  */
8 
9 #ifndef C_API_ADDONINSTANCE_PERIPHERAL_H
10 #define C_API_ADDONINSTANCE_PERIPHERAL_H
11 
12 #include "../addon_base.h"
13 
14 /* indicates a joystick has no preference for port number */
15 #define NO_PORT_REQUESTED (-1)
16 
17 /* joystick's driver button/hat/axis index is unknown */
18 #define DRIVER_INDEX_UNKNOWN (-1)
19 
20 #ifdef __cplusplus
21 extern "C"
22 {
23 #endif /* __cplusplus */
24 
25  //============================================================================
35  typedef enum PERIPHERAL_ERROR
36  {
39 
42 
45 
48 
51 
54 
59  //----------------------------------------------------------------------------
60 
61  // @name Peripheral types
62  //{
63 
64  //============================================================================
70  typedef enum PERIPHERAL_TYPE
71  {
74 
77 
82  //----------------------------------------------------------------------------
83 
87  typedef struct PERIPHERAL_INFO
88  {
90  char* name;
91  uint16_t vendor_id;
92  uint16_t product_id;
93  unsigned int index;
94  } ATTRIBUTE_PACKED PERIPHERAL_INFO;
95 
99  typedef struct PERIPHERAL_CAPABILITIES
100  {
102  bool provides_joystick_rumble;
103  bool provides_joystick_power_off;
105  } ATTRIBUTE_PACKED PERIPHERAL_CAPABILITIES;
106 
107  //}
108 
109  // @name Event types
110  //{
111 
112  //============================================================================
119  {
122 
125 
128 
131 
136  //----------------------------------------------------------------------------
137 
138  //============================================================================
145  {
148 
153  //----------------------------------------------------------------------------
154 
155  //============================================================================
161  typedef enum JOYSTICK_STATE_HAT
162  {
165 
168 
171 
174 
177 
180 
183 
186 
191  //----------------------------------------------------------------------------
192 
193  //============================================================================
201  typedef float JOYSTICK_STATE_AXIS;
202  //----------------------------------------------------------------------------
203 
204  //============================================================================
207  typedef float JOYSTICK_STATE_MOTOR;
208  //----------------------------------------------------------------------------
209 
213  typedef struct PERIPHERAL_EVENT
214  {
216  unsigned int peripheral_index;
217 
220 
222  unsigned int driver_index;
223 
224  JOYSTICK_STATE_BUTTON driver_button_state;
225  JOYSTICK_STATE_HAT driver_hat_state;
226  JOYSTICK_STATE_AXIS driver_axis_state;
227  JOYSTICK_STATE_MOTOR motor_state;
228  } ATTRIBUTE_PACKED PERIPHERAL_EVENT;
229 
230  //}
231 
232  // @name Joystick types
233  //{
234 
238  typedef struct JOYSTICK_INFO
239  {
241  char* provider;
243  unsigned int button_count;
244  unsigned int hat_count;
245  unsigned int axis_count;
246  unsigned int motor_count;
248  } ATTRIBUTE_PACKED JOYSTICK_INFO;
249 
250  //============================================================================
264  {
267 
270 
273 
276 
279 
282 
285 
290  //----------------------------------------------------------------------------
291 
295  typedef struct JOYSTICK_DRIVER_BUTTON
296  {
297  int index;
298  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_BUTTON;
299 
300  //============================================================================
307  {
310 
313 
316 
319 
324  //----------------------------------------------------------------------------
325 
329  typedef struct JOYSTICK_DRIVER_HAT
330  {
331  int index;
333  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_HAT;
334 
335  //============================================================================
342  {
345 
348 
353  //----------------------------------------------------------------------------
354 
359  {
360  int index;
361  int center;
363  unsigned int range;
364  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_SEMIAXIS;
365 
369  typedef struct JOYSTICK_DRIVER_MOTOR
370  {
371  int index;
372  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_MOTOR;
373 
377  typedef struct JOYSTICK_DRIVER_KEY
378  {
379  char keycode[16];
380  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_KEY;
381 
382  //============================================================================
389  {
392 
395 
398 
401 
404 
407 
410 
413 
416 
421  //----------------------------------------------------------------------------
422 
427  {
429  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_MOUSE_BUTTON;
430 
431  //============================================================================
438  {
441 
444 
447 
450 
455  //----------------------------------------------------------------------------
456 
461  {
463  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_RELPOINTER;
464 
469  {
471  union
472  {
473  struct JOYSTICK_DRIVER_BUTTON button;
474  struct JOYSTICK_DRIVER_HAT hat;
475  struct JOYSTICK_DRIVER_SEMIAXIS semiaxis;
476  struct JOYSTICK_DRIVER_MOTOR motor;
477  struct JOYSTICK_DRIVER_KEY key;
478  struct JOYSTICK_DRIVER_MOUSE_BUTTON mouse;
479  struct JOYSTICK_DRIVER_RELPOINTER relpointer;
480  };
481  } ATTRIBUTE_PACKED JOYSTICK_DRIVER_PRIMITIVE;
482 
483  //============================================================================
494  {
497 
500 
503 
506 
509 
512 
515 
518 
521 
526  //----------------------------------------------------------------------------
527 
528  //============================================================================
536  {
539 
548 
555 
558 
563 
568 
571 
574 
583 
588  //----------------------------------------------------------------------------
589 
593  typedef struct JOYSTICK_FEATURE
594  {
595  char* name;
598  } ATTRIBUTE_PACKED JOYSTICK_FEATURE;
599  //}
600 
601  typedef struct AddonProps_Peripheral
602  {
603  const char* user_path;
604  const char* addon_path;
605  } ATTRIBUTE_PACKED AddonProps_Peripheral;
606 
608 
610  {
611  KODI_HANDLE kodiInstance;
612  void (*trigger_scan)(void* kodiInstance);
613  void (*refresh_button_maps)(void* kodiInstance,
614  const char* device_name,
615  const char* controller_id);
616  unsigned int (*feature_count)(void* kodiInstance,
617  const char* controller_id,
618  JOYSTICK_FEATURE_TYPE type);
619  JOYSTICK_FEATURE_TYPE(*feature_type)
620  (void* kodiInstance, const char* controller_id, const char* feature_name);
622 
624 
626  {
627  KODI_HANDLE addonInstance;
628 
629  void(__cdecl* get_capabilities)(const struct AddonInstance_Peripheral* addonInstance,
630  struct PERIPHERAL_CAPABILITIES* capabilities);
631  PERIPHERAL_ERROR(__cdecl* perform_device_scan)
632  (const struct AddonInstance_Peripheral* addonInstance,
633  unsigned int* peripheral_count,
634  struct PERIPHERAL_INFO** scan_results);
635  void(__cdecl* free_scan_results)(const struct AddonInstance_Peripheral* addonInstance,
636  unsigned int peripheral_count,
637  struct PERIPHERAL_INFO* scan_results);
638  PERIPHERAL_ERROR(__cdecl* get_events)
639  (const struct AddonInstance_Peripheral* addonInstance,
640  unsigned int* event_count,
641  struct PERIPHERAL_EVENT** events);
642  void(__cdecl* free_events)(const struct AddonInstance_Peripheral* addonInstance,
643  unsigned int event_count,
644  struct PERIPHERAL_EVENT* events);
645  bool(__cdecl* send_event)(const struct AddonInstance_Peripheral* addonInstance,
646  const struct PERIPHERAL_EVENT* event);
647 
650  PERIPHERAL_ERROR(__cdecl* get_joystick_info)
651  (const struct AddonInstance_Peripheral* addonInstance,
652  unsigned int index,
653  struct JOYSTICK_INFO* info);
654  void(__cdecl* free_joystick_info)(const struct AddonInstance_Peripheral* addonInstance,
655  struct JOYSTICK_INFO* info);
656  PERIPHERAL_ERROR(__cdecl* get_features)
657  (const struct AddonInstance_Peripheral* addonInstance,
658  const struct JOYSTICK_INFO* joystick,
659  const char* controller_id,
660  unsigned int* feature_count,
661  struct JOYSTICK_FEATURE** features);
662  void(__cdecl* free_features)(const struct AddonInstance_Peripheral* addonInstance,
663  unsigned int feature_count,
664  struct JOYSTICK_FEATURE* features);
665  PERIPHERAL_ERROR(__cdecl* map_features)
666  (const struct AddonInstance_Peripheral* addonInstance,
667  const struct JOYSTICK_INFO* joystick,
668  const char* controller_id,
669  unsigned int feature_count,
670  const struct JOYSTICK_FEATURE* features);
671  PERIPHERAL_ERROR(__cdecl* get_ignored_primitives)
672  (const struct AddonInstance_Peripheral* addonInstance,
673  const struct JOYSTICK_INFO* joystick,
674  unsigned int* feature_count,
675  struct JOYSTICK_DRIVER_PRIMITIVE** primitives);
676  void(__cdecl* free_primitives)(const struct AddonInstance_Peripheral* addonInstance,
677  unsigned int,
678  struct JOYSTICK_DRIVER_PRIMITIVE* primitives);
679  PERIPHERAL_ERROR(__cdecl* set_ignored_primitives)
680  (const struct AddonInstance_Peripheral* addonInstance,
681  const struct JOYSTICK_INFO* joystick,
682  unsigned int primitive_count,
683  const struct JOYSTICK_DRIVER_PRIMITIVE* primitives);
684  void(__cdecl* save_button_map)(const struct AddonInstance_Peripheral* addonInstance,
685  const struct JOYSTICK_INFO* joystick);
686  void(__cdecl* revert_button_map)(const struct AddonInstance_Peripheral* addonInstance,
687  const struct JOYSTICK_INFO* joystick);
688  void(__cdecl* reset_button_map)(const struct AddonInstance_Peripheral* addonInstance,
689  const struct JOYSTICK_INFO* joystick,
690  const char* controller_id);
691  void(__cdecl* power_off_joystick)(const struct AddonInstance_Peripheral* addonInstance,
692  unsigned int index);
695 
697  {
698  struct AddonProps_Peripheral* props;
699  struct AddonToKodiFuncTable_Peripheral* toKodi;
700  struct KodiToAddonFuncTable_Peripheral* toAddon;
702 
703 #ifdef __cplusplus
704 } /* extern "C" */
705 #endif /* __cplusplus */
706 
707 #endif /* !C_API_ADDONINSTANCE_PERIPHERAL_H */
JOYSTICK_STATE_BUTTON
Definition: peripheral.h:145
@ JOYSTICK_STATE_BUTTON_UNPRESSED
button is released
Definition: peripheral.h:147
@ JOYSTICK_STATE_BUTTON_PRESSED
button is pressed
Definition: peripheral.h:150
JOYSTICK_STATE_HAT
Definition: peripheral.h:162
@ JOYSTICK_STATE_HAT_DOWN
only down is pressed
Definition: peripheral.h:176
@ JOYSTICK_STATE_HAT_RIGHT
only right is pressed
Definition: peripheral.h:170
@ JOYSTICK_STATE_HAT_RIGHT_DOWN
right and down is pressed
Definition: peripheral.h:188
@ JOYSTICK_STATE_HAT_UNPRESSED
no directions are pressed
Definition: peripheral.h:164
@ JOYSTICK_STATE_HAT_LEFT
only left is pressed
Definition: peripheral.h:167
@ JOYSTICK_STATE_HAT_UP
only up is pressed
Definition: peripheral.h:173
@ JOYSTICK_STATE_HAT_LEFT_UP
left and up is pressed
Definition: peripheral.h:179
@ JOYSTICK_STATE_HAT_LEFT_DOWN
left and down is pressed
Definition: peripheral.h:182
@ JOYSTICK_STATE_HAT_RIGHT_UP
right and up is pressed
Definition: peripheral.h:185
PERIPHERAL_EVENT_TYPE
Definition: peripheral.h:119
@ PERIPHERAL_EVENT_TYPE_SET_MOTOR
set the state for joystick rumble motor
Definition: peripheral.h:133
@ PERIPHERAL_EVENT_TYPE_DRIVER_HAT
state changed for joystick driver hat
Definition: peripheral.h:127
@ PERIPHERAL_EVENT_TYPE_NONE
unknown event
Definition: peripheral.h:121
@ PERIPHERAL_EVENT_TYPE_DRIVER_AXIS
state changed for joystick driver axis
Definition: peripheral.h:130
@ PERIPHERAL_EVENT_TYPE_DRIVER_BUTTON
state changed for joystick driver button
Definition: peripheral.h:124
float JOYSTICK_STATE_AXIS
Axis value in the closed interval [-1.0, 1.0].
Definition: peripheral.h:201
float JOYSTICK_STATE_MOTOR
Motor value in the closed interval [0.0, 1.0].
Definition: peripheral.h:207
PERIPHERAL_ERROR
Definition: peripheral.h:36
@ PERIPHERAL_ERROR_NOT_CONNECTED
-5 : No peripherals are connected
Definition: peripheral.h:53
@ PERIPHERAL_ERROR_FAILED
-2 : The command failed
Definition: peripheral.h:44
@ PERIPHERAL_ERROR_INVALID_PARAMETERS
-3 : The parameters of the method are invalid for this operation
Definition: peripheral.h:47
@ PERIPHERAL_ERROR_UNKNOWN
-1 : An unknown error occurred
Definition: peripheral.h:41
@ PERIPHERAL_NO_ERROR
0 : No error occurred
Definition: peripheral.h:38
@ PERIPHERAL_ERROR_NOT_IMPLEMENTED
-4 : The method that the frontend called is not implemented
Definition: peripheral.h:50
@ PERIPHERAL_ERROR_CONNECTION_FAILED
-6 : Peripherals are connected, but command was interrupted
Definition: peripheral.h:56
JOYSTICK_DRIVER_HAT_DIRECTION
Definition: peripheral.h:307
@ JOYSTICK_DRIVER_HAT_RIGHT
Driver hat right.
Definition: peripheral.h:315
@ JOYSTICK_DRIVER_HAT_DOWN
Driver hat down.
Definition: peripheral.h:321
@ JOYSTICK_DRIVER_HAT_UNKNOWN
Driver hat unknown.
Definition: peripheral.h:309
@ JOYSTICK_DRIVER_HAT_UP
Driver hat up.
Definition: peripheral.h:318
@ JOYSTICK_DRIVER_HAT_LEFT
Driver hat left.
Definition: peripheral.h:312
JOYSTICK_DRIVER_MOUSE_INDEX
Definition: peripheral.h:389
@ JOYSTICK_DRIVER_MOUSE_INDEX_WHEEL_DOWN
Mouse index wheel down.
Definition: peripheral.h:412
@ JOYSTICK_DRIVER_MOUSE_INDEX_LEFT
Mouse index left.
Definition: peripheral.h:394
@ JOYSTICK_DRIVER_MOUSE_INDEX_BUTTON4
Mouse index button 4.
Definition: peripheral.h:403
@ JOYSTICK_DRIVER_MOUSE_INDEX_UNKNOWN
Mouse index unknown.
Definition: peripheral.h:391
@ JOYSTICK_DRIVER_MOUSE_INDEX_HORIZ_WHEEL_LEFT
Mouse index horizontal wheel left.
Definition: peripheral.h:415
@ JOYSTICK_DRIVER_MOUSE_INDEX_MIDDLE
Mouse index middle.
Definition: peripheral.h:400
@ JOYSTICK_DRIVER_MOUSE_INDEX_WHEEL_UP
Mouse index wheel up.
Definition: peripheral.h:409
@ JOYSTICK_DRIVER_MOUSE_INDEX_RIGHT
Mouse index right.
Definition: peripheral.h:397
@ JOYSTICK_DRIVER_MOUSE_INDEX_HORIZ_WHEEL_RIGHT
Mouse index horizontal wheel right.
Definition: peripheral.h:418
@ JOYSTICK_DRIVER_MOUSE_INDEX_BUTTON5
Mouse index button 5.
Definition: peripheral.h:406
JOYSTICK_DRIVER_PRIMITIVE_TYPE
Definition: peripheral.h:264
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_MOTOR
Driver input primitive type motor.
Definition: peripheral.h:278
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_MOUSE_BUTTON
Driver input primitive type mouse button.
Definition: peripheral.h:284
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_UNKNOWN
Driver input primitive type unknown.
Definition: peripheral.h:266
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_RELPOINTER_DIRECTION
Driver input primitive type relative pointer direction.
Definition: peripheral.h:287
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_HAT_DIRECTION
Driver input primitive type hat direction.
Definition: peripheral.h:272
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_BUTTON
Driver input primitive type button.
Definition: peripheral.h:269
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_SEMIAXIS
Driver input primitive type semiaxis.
Definition: peripheral.h:275
@ JOYSTICK_DRIVER_PRIMITIVE_TYPE_KEY
Driver input primitive type key.
Definition: peripheral.h:281
JOYSTICK_DRIVER_RELPOINTER_DIRECTION
Definition: peripheral.h:438
@ JOYSTICK_DRIVER_RELPOINTER_RIGHT
Relative pointer direction right.
Definition: peripheral.h:446
@ JOYSTICK_DRIVER_RELPOINTER_LEFT
Relative pointer direction left.
Definition: peripheral.h:443
@ JOYSTICK_DRIVER_RELPOINTER_UP
Relative pointer direction up.
Definition: peripheral.h:449
@ JOYSTICK_DRIVER_RELPOINTER_UNKNOWN
Relative pointer direction unknown.
Definition: peripheral.h:440
@ JOYSTICK_DRIVER_RELPOINTER_DOWN
Relative pointer direction down.
Definition: peripheral.h:452
JOYSTICK_DRIVER_SEMIAXIS_DIRECTION
Definition: peripheral.h:342
@ JOYSTICK_DRIVER_SEMIAXIS_NEGATIVE
negative half of the axis
Definition: peripheral.h:344
@ JOYSTICK_DRIVER_SEMIAXIS_UNKNOWN
unknown direction
Definition: peripheral.h:347
@ JOYSTICK_DRIVER_SEMIAXIS_POSITIVE
positive half of the axis
Definition: peripheral.h:350
JOYSTICK_FEATURE_PRIMITIVE
Definition: peripheral.h:536
@ JOYSTICK_THROTTLE_UP
Throttle up.
Definition: peripheral.h:565
@ JOYSTICK_WHEEL_LEFT
Wheel left.
Definition: peripheral.h:560
@ JOYSTICK_RELPOINTER_DOWN
Relative pointer direction down.
Definition: peripheral.h:578
@ JOYSTICK_RELPOINTER_UP
Relative pointer direction up.
Definition: peripheral.h:576
@ JOYSTICK_SCALAR_PRIMITIVE
Scalar feature (a button, hat direction or semiaxis)
Definition: peripheral.h:538
@ JOYSTICK_ACCELEROMETER_POSITIVE_X
Accelerometer X.
Definition: peripheral.h:550
@ JOYSTICK_ACCELEROMETER_POSITIVE_Y
Accelerometer Y.
Definition: peripheral.h:552
@ JOYSTICK_ANALOG_STICK_DOWN
Analog stick down.
Definition: peripheral.h:543
@ JOYSTICK_THROTTLE_DOWN
Throttle down.
Definition: peripheral.h:567
@ JOYSTICK_KEY_PRIMITIVE
Key.
Definition: peripheral.h:570
@ JOYSTICK_ANALOG_STICK_UP
Analog stick up.
Definition: peripheral.h:541
@ JOYSTICK_RELPOINTER_LEFT
Relative pointer direction left.
Definition: peripheral.h:582
@ JOYSTICK_WHEEL_RIGHT
Wheel right.
Definition: peripheral.h:562
@ JOYSTICK_PRIMITIVE_MAX
Maximum number of primitives.
Definition: peripheral.h:585
@ JOYSTICK_MOTOR_PRIMITIVE
Motor.
Definition: peripheral.h:557
@ JOYSTICK_MOUSE_BUTTON
Mouse button.
Definition: peripheral.h:573
@ JOYSTICK_RELPOINTER_RIGHT
Relative pointer direction right.
Definition: peripheral.h:580
@ JOYSTICK_ANALOG_STICK_LEFT
Analog stick left.
Definition: peripheral.h:547
@ JOYSTICK_ANALOG_STICK_RIGHT
Analog stick right.
Definition: peripheral.h:545
@ JOYSTICK_ACCELEROMETER_POSITIVE_Z
Accelerometer Z.
Definition: peripheral.h:554
JOYSTICK_FEATURE_TYPE
Definition: peripheral.h:494
@ JOYSTICK_FEATURE_TYPE_ANALOG_STICK
Type analog stick.
Definition: peripheral.h:502
@ JOYSTICK_FEATURE_TYPE_RELPOINTER
Type relative pointer.
Definition: peripheral.h:511
@ JOYSTICK_FEATURE_TYPE_ACCELEROMETER
Type accelerometer.
Definition: peripheral.h:505
@ JOYSTICK_FEATURE_TYPE_WHEEL
Type wheel.
Definition: peripheral.h:517
@ JOYSTICK_FEATURE_TYPE_UNKNOWN
Unknown type.
Definition: peripheral.h:496
@ JOYSTICK_FEATURE_TYPE_MOTOR
Type motor.
Definition: peripheral.h:508
@ JOYSTICK_FEATURE_TYPE_ABSPOINTER
Type absolut pointer.
Definition: peripheral.h:514
@ JOYSTICK_FEATURE_TYPE_KEY
Type key.
Definition: peripheral.h:523
@ JOYSTICK_FEATURE_TYPE_THROTTLE
Type throttle.
Definition: peripheral.h:520
@ JOYSTICK_FEATURE_TYPE_SCALAR
Type scalar.
Definition: peripheral.h:499
PERIPHERAL_TYPE
Definition: peripheral.h:71
@ PERIPHERAL_TYPE_UNKNOWN
Type declared as unknown.
Definition: peripheral.h:73
@ PERIPHERAL_TYPE_JOYSTICK
Type declared as joystick.
Definition: peripheral.h:76
@ PERIPHERAL_TYPE_KEYBOARD
Type declared as keyboard.
Definition: peripheral.h:79
Definition: peripheral.h:697
Definition: peripheral.h:602
const char * addon_path
path to this add-on
Definition: peripheral.h:604
const char * user_path
path to the user profile
Definition: peripheral.h:603
Definition: peripheral.h:610
Button primitive.
Definition: peripheral.h:296
Hat direction primitive.
Definition: peripheral.h:330
Keyboard key primitive.
Definition: peripheral.h:378
Motor primitive.
Definition: peripheral.h:370
Mouse button primitive.
Definition: peripheral.h:427
Driver primitive struct.
Definition: peripheral.h:469
Relative pointer direction primitive.
Definition: peripheral.h:461
Semiaxis primitive.
Definition: peripheral.h:359
Mapping between higher-level controller feature and its driver primitives.
Definition: peripheral.h:594
Info specific to joystick peripherals.
Definition: peripheral.h:239
unsigned int motor_count
number of motors reported by the driver
Definition: peripheral.h:246
unsigned int axis_count
number of axes reported by the driver
Definition: peripheral.h:245
char * provider
name of the driver or interface providing the joystick
Definition: peripheral.h:241
unsigned int button_count
number of buttons reported by the driver
Definition: peripheral.h:243
bool supports_poweroff
whether the joystick supports being powered off
Definition: peripheral.h:247
unsigned int hat_count
number of hats reported by the driver
Definition: peripheral.h:244
PERIPHERAL_INFO peripheral
peripheral info for this joystick
Definition: peripheral.h:240
int requested_port
requested port number (such as for 360 controllers), or NO_PORT_REQUESTED
Definition: peripheral.h:242
Definition: peripheral.h:626
Peripheral add-on capabilities.
Definition: peripheral.h:100
bool provides_joysticks
Definition: peripheral.h:101
bool provides_buttonmaps
Definition: peripheral.h:104
Event information.
Definition: peripheral.h:214
unsigned int peripheral_index
Index of the peripheral handling/receiving the event.
Definition: peripheral.h:216
unsigned int driver_index
The index of the event source.
Definition: peripheral.h:222
PERIPHERAL_EVENT_TYPE type
Type of the event used to determine which enum field to access below.
Definition: peripheral.h:219
Information shared between peripherals.
Definition: peripheral.h:88
uint16_t product_id
Definition: peripheral.h:92
unsigned int index
Definition: peripheral.h:93
char * name
Definition: peripheral.h:90
uint16_t vendor_id
Definition: peripheral.h:91
PERIPHERAL_TYPE type
Definition: peripheral.h:89