xref: /aosp_15_r20/prebuilts/build-tools/sysroots/i686-unknown-linux-musl/include/linux/counter.h (revision cda5da8d549138a6648c5ee6d7a49cf8f4a657be)
1*cda5da8dSAndroid Build Coastguard Worker /*
2*cda5da8dSAndroid Build Coastguard Worker  * This file is auto-generated. Modifications will be lost.
3*cda5da8dSAndroid Build Coastguard Worker  *
4*cda5da8dSAndroid Build Coastguard Worker  * See https://android.googlesource.com/platform/bionic/+/master/libc/kernel/
5*cda5da8dSAndroid Build Coastguard Worker  * for more information.
6*cda5da8dSAndroid Build Coastguard Worker  */
7*cda5da8dSAndroid Build Coastguard Worker #ifndef _UAPI_COUNTER_H_
8*cda5da8dSAndroid Build Coastguard Worker #define _UAPI_COUNTER_H_
9*cda5da8dSAndroid Build Coastguard Worker #include <linux/ioctl.h>
10*cda5da8dSAndroid Build Coastguard Worker #include <linux/types.h>
11*cda5da8dSAndroid Build Coastguard Worker enum counter_component_type {
12*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_NONE,
13*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_SIGNAL,
14*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_COUNT,
15*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_FUNCTION,
16*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_SYNAPSE_ACTION,
17*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COMPONENT_EXTENSION,
18*cda5da8dSAndroid Build Coastguard Worker };
19*cda5da8dSAndroid Build Coastguard Worker enum counter_scope {
20*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SCOPE_DEVICE,
21*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SCOPE_SIGNAL,
22*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SCOPE_COUNT,
23*cda5da8dSAndroid Build Coastguard Worker };
24*cda5da8dSAndroid Build Coastguard Worker struct counter_component {
25*cda5da8dSAndroid Build Coastguard Worker   __u8 type;
26*cda5da8dSAndroid Build Coastguard Worker   __u8 scope;
27*cda5da8dSAndroid Build Coastguard Worker   __u8 parent;
28*cda5da8dSAndroid Build Coastguard Worker   __u8 id;
29*cda5da8dSAndroid Build Coastguard Worker };
30*cda5da8dSAndroid Build Coastguard Worker enum counter_event_type {
31*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_OVERFLOW,
32*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_UNDERFLOW,
33*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_OVERFLOW_UNDERFLOW,
34*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_THRESHOLD,
35*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_INDEX,
36*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_CHANGE_OF_STATE,
37*cda5da8dSAndroid Build Coastguard Worker   COUNTER_EVENT_CAPTURE,
38*cda5da8dSAndroid Build Coastguard Worker };
39*cda5da8dSAndroid Build Coastguard Worker struct counter_watch {
40*cda5da8dSAndroid Build Coastguard Worker   struct counter_component component;
41*cda5da8dSAndroid Build Coastguard Worker   __u8 event;
42*cda5da8dSAndroid Build Coastguard Worker   __u8 channel;
43*cda5da8dSAndroid Build Coastguard Worker };
44*cda5da8dSAndroid Build Coastguard Worker #define COUNTER_ADD_WATCH_IOCTL _IOW(0x3E, 0x00, struct counter_watch)
45*cda5da8dSAndroid Build Coastguard Worker #define COUNTER_ENABLE_EVENTS_IOCTL _IO(0x3E, 0x01)
46*cda5da8dSAndroid Build Coastguard Worker #define COUNTER_DISABLE_EVENTS_IOCTL _IO(0x3E, 0x02)
47*cda5da8dSAndroid Build Coastguard Worker struct counter_event {
48*cda5da8dSAndroid Build Coastguard Worker   __aligned_u64 timestamp;
49*cda5da8dSAndroid Build Coastguard Worker   __aligned_u64 value;
50*cda5da8dSAndroid Build Coastguard Worker   struct counter_watch watch;
51*cda5da8dSAndroid Build Coastguard Worker   __u8 status;
52*cda5da8dSAndroid Build Coastguard Worker };
53*cda5da8dSAndroid Build Coastguard Worker enum counter_count_direction {
54*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_DIRECTION_FORWARD,
55*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_DIRECTION_BACKWARD,
56*cda5da8dSAndroid Build Coastguard Worker };
57*cda5da8dSAndroid Build Coastguard Worker enum counter_count_mode {
58*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_NORMAL,
59*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_RANGE_LIMIT,
60*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_NON_RECYCLE,
61*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_MODULO_N,
62*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_INTERRUPT_ON_TERMINAL_COUNT,
63*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_HARDWARE_RETRIGGERABLE_ONESHOT,
64*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_RATE_GENERATOR,
65*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_SQUARE_WAVE_MODE,
66*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_SOFTWARE_TRIGGERED_STROBE,
67*cda5da8dSAndroid Build Coastguard Worker   COUNTER_COUNT_MODE_HARDWARE_TRIGGERED_STROBE,
68*cda5da8dSAndroid Build Coastguard Worker };
69*cda5da8dSAndroid Build Coastguard Worker enum counter_function {
70*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_INCREASE,
71*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_DECREASE,
72*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_PULSE_DIRECTION,
73*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_QUADRATURE_X1_A,
74*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_QUADRATURE_X1_B,
75*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_QUADRATURE_X2_A,
76*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_QUADRATURE_X2_B,
77*cda5da8dSAndroid Build Coastguard Worker   COUNTER_FUNCTION_QUADRATURE_X4,
78*cda5da8dSAndroid Build Coastguard Worker };
79*cda5da8dSAndroid Build Coastguard Worker enum counter_signal_level {
80*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SIGNAL_LEVEL_LOW,
81*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SIGNAL_LEVEL_HIGH,
82*cda5da8dSAndroid Build Coastguard Worker };
83*cda5da8dSAndroid Build Coastguard Worker enum counter_synapse_action {
84*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SYNAPSE_ACTION_NONE,
85*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SYNAPSE_ACTION_RISING_EDGE,
86*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SYNAPSE_ACTION_FALLING_EDGE,
87*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SYNAPSE_ACTION_BOTH_EDGES,
88*cda5da8dSAndroid Build Coastguard Worker };
89*cda5da8dSAndroid Build Coastguard Worker enum counter_signal_polarity {
90*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SIGNAL_POLARITY_POSITIVE,
91*cda5da8dSAndroid Build Coastguard Worker   COUNTER_SIGNAL_POLARITY_NEGATIVE,
92*cda5da8dSAndroid Build Coastguard Worker };
93*cda5da8dSAndroid Build Coastguard Worker #endif
94