~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/hid_bpf.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/hid_bpf.h (Architecture mips) and /include/linux/hid_bpf.h (Architecture sparc64)


  1 /* SPDX-License-Identifier: GPL-2.0+ */             1 /* SPDX-License-Identifier: GPL-2.0+ */
  2                                                     2 
  3 #ifndef __HID_BPF_H                                 3 #ifndef __HID_BPF_H
  4 #define __HID_BPF_H                                 4 #define __HID_BPF_H
  5                                                     5 
  6 #include <linux/bpf.h>                              6 #include <linux/bpf.h>
  7 #include <linux/mutex.h>                            7 #include <linux/mutex.h>
  8 #include <linux/srcu.h>                             8 #include <linux/srcu.h>
  9 #include <uapi/linux/hid.h>                         9 #include <uapi/linux/hid.h>
 10                                                    10 
 11 struct hid_device;                                 11 struct hid_device;
 12                                                    12 
 13 /*                                                 13 /*
 14  * The following is the user facing HID BPF AP     14  * The following is the user facing HID BPF API.
 15  *                                                 15  *
 16  * Extra care should be taken when editing thi     16  * Extra care should be taken when editing this part, as
 17  * it might break existing out of the tree bpf     17  * it might break existing out of the tree bpf programs.
 18  */                                                18  */
 19                                                    19 
 20 /**                                                20 /**
 21  * struct hid_bpf_ctx - User accessible data f     21  * struct hid_bpf_ctx - User accessible data for all HID programs
 22  *                                                 22  *
 23  * ``data`` is not directly accessible from th     23  * ``data`` is not directly accessible from the context. We need to issue
 24  * a call to hid_bpf_get_data() in order to ge     24  * a call to hid_bpf_get_data() in order to get a pointer to that field.
 25  *                                                 25  *
 26  * @hid: the &struct hid_device representing t     26  * @hid: the &struct hid_device representing the device itself
 27  * @allocated_size: Allocated size of data.        27  * @allocated_size: Allocated size of data.
 28  *                                                 28  *
 29  *                  This is how much memory is     29  *                  This is how much memory is available and can be requested
 30  *                  by the HID program.            30  *                  by the HID program.
 31  *                  Note that for ``HID_BPF_RD     31  *                  Note that for ``HID_BPF_RDESC_FIXUP``, that memory is set to
 32  *                  ``4096`` (4 KB)                32  *                  ``4096`` (4 KB)
 33  * @size: Valid data in the data field.            33  * @size: Valid data in the data field.
 34  *                                                 34  *
 35  *        Programs can get the available valid     35  *        Programs can get the available valid size in data by fetching this field.
 36  *        Programs can also change this value      36  *        Programs can also change this value by returning a positive number in the
 37  *        program.                                 37  *        program.
 38  *        To discard the event, return a negat     38  *        To discard the event, return a negative error code.
 39  *                                                 39  *
 40  *        ``size`` must always be less or equa     40  *        ``size`` must always be less or equal than ``allocated_size`` (it is enforced
 41  *        once all BPF programs have been run)     41  *        once all BPF programs have been run).
 42  * @retval: Return value of the previous progr     42  * @retval: Return value of the previous program.
 43  *                                                 43  *
 44  * ``hid`` and ``allocated_size`` are read-onl     44  * ``hid`` and ``allocated_size`` are read-only, ``size`` and ``retval`` are read-write.
 45  */                                                45  */
 46 struct hid_bpf_ctx {                               46 struct hid_bpf_ctx {
 47         struct hid_device *hid;                    47         struct hid_device *hid;
 48         __u32 allocated_size;                      48         __u32 allocated_size;
 49         union {                                    49         union {
 50                 __s32 retval;                      50                 __s32 retval;
 51                 __s32 size;                        51                 __s32 size;
 52         };                                         52         };
 53 };                                                 53 };
 54                                                    54 
 55 /*                                                 55 /*
 56  * Below is HID internal                           56  * Below is HID internal
 57  */                                                57  */
 58                                                    58 
 59 #define HID_BPF_MAX_PROGS_PER_DEV 64               59 #define HID_BPF_MAX_PROGS_PER_DEV 64
 60 #define HID_BPF_FLAG_MASK (((HID_BPF_FLAG_MAX      60 #define HID_BPF_FLAG_MASK (((HID_BPF_FLAG_MAX - 1) << 1) - 1)
 61                                                    61 
 62                                                    62 
 63 struct hid_report_enum;                            63 struct hid_report_enum;
 64                                                    64 
 65 struct hid_ops {                                   65 struct hid_ops {
 66         struct hid_report *(*hid_get_report)(s     66         struct hid_report *(*hid_get_report)(struct hid_report_enum *report_enum, const u8 *data);
 67         int (*hid_hw_raw_request)(struct hid_d     67         int (*hid_hw_raw_request)(struct hid_device *hdev,
 68                                   unsigned cha     68                                   unsigned char reportnum, __u8 *buf,
 69                                   size_t len,      69                                   size_t len, enum hid_report_type rtype,
 70                                   enum hid_cla     70                                   enum hid_class_request reqtype,
 71                                   u64 source,      71                                   u64 source, bool from_bpf);
 72         int (*hid_hw_output_report)(struct hid     72         int (*hid_hw_output_report)(struct hid_device *hdev, __u8 *buf, size_t len,
 73                                     u64 source     73                                     u64 source, bool from_bpf);
 74         int (*hid_input_report)(struct hid_dev     74         int (*hid_input_report)(struct hid_device *hid, enum hid_report_type type,
 75                                 u8 *data, u32      75                                 u8 *data, u32 size, int interrupt, u64 source, bool from_bpf,
 76                                 bool lock_alre     76                                 bool lock_already_taken);
 77         struct module *owner;                      77         struct module *owner;
 78         const struct bus_type *bus_type;           78         const struct bus_type *bus_type;
 79 };                                                 79 };
 80                                                    80 
 81 extern struct hid_ops *hid_ops;                    81 extern struct hid_ops *hid_ops;
 82                                                    82 
 83 /**                                                83 /**
 84  * struct hid_bpf_ops - A BPF struct_ops of ca     84  * struct hid_bpf_ops - A BPF struct_ops of callbacks allowing to attach HID-BPF
 85  *                      programs to a HID devi     85  *                      programs to a HID device
 86  * @hid_id: the HID uniq ID to attach to. This     86  * @hid_id: the HID uniq ID to attach to. This is writeable before ``load()``, and
 87  *          cannot be changed after                87  *          cannot be changed after
 88  * @flags: flags used while attaching the stru     88  * @flags: flags used while attaching the struct_ops to the device. Currently only
 89  *         available value is %0 or ``BPF_F_BE     89  *         available value is %0 or ``BPF_F_BEFORE``.
 90  *         Writeable only before ``load()``        90  *         Writeable only before ``load()``
 91  */                                                91  */
 92 struct hid_bpf_ops {                               92 struct hid_bpf_ops {
 93         /* hid_id needs to stay first so we ca     93         /* hid_id needs to stay first so we can easily change it
 94          * from userspace.                         94          * from userspace.
 95          */                                        95          */
 96         int                     hid_id;            96         int                     hid_id;
 97         u32                     flags;             97         u32                     flags;
 98                                                    98 
 99         /* private: do not show up in the docs     99         /* private: do not show up in the docs */
100         struct list_head        list;             100         struct list_head        list;
101                                                   101 
102         /* public: rest should show up in the     102         /* public: rest should show up in the docs */
103                                                   103 
104         /**                                       104         /**
105          * @hid_device_event: called whenever     105          * @hid_device_event: called whenever an event is coming in from the device
106          *                                        106          *
107          * It has the following arguments:        107          * It has the following arguments:
108          *                                        108          *
109          * ``ctx``: The HID-BPF context as &st    109          * ``ctx``: The HID-BPF context as &struct hid_bpf_ctx
110          *                                        110          *
111          * Return: %0 on success and keep proc    111          * Return: %0 on success and keep processing; a positive
112          * value to change the incoming size b    112          * value to change the incoming size buffer; a negative
113          * error code to interrupt the process    113          * error code to interrupt the processing of this event
114          *                                        114          *
115          * Context: Interrupt context.            115          * Context: Interrupt context.
116          */                                       116          */
117         int (*hid_device_event)(struct hid_bpf    117         int (*hid_device_event)(struct hid_bpf_ctx *ctx, enum hid_report_type report_type,
118                                 u64 source);      118                                 u64 source);
119                                                   119 
120         /**                                       120         /**
121          * @hid_rdesc_fixup: called when the p    121          * @hid_rdesc_fixup: called when the probe function parses the report descriptor
122          * of the HID device                      122          * of the HID device
123          *                                        123          *
124          * It has the following arguments:        124          * It has the following arguments:
125          *                                        125          *
126          * ``ctx``: The HID-BPF context as &st    126          * ``ctx``: The HID-BPF context as &struct hid_bpf_ctx
127          *                                        127          *
128          * Return: %0 on success and keep proc    128          * Return: %0 on success and keep processing; a positive
129          * value to change the incoming size b    129          * value to change the incoming size buffer; a negative
130          * error code to interrupt the process    130          * error code to interrupt the processing of this device
131          */                                       131          */
132         int (*hid_rdesc_fixup)(struct hid_bpf_    132         int (*hid_rdesc_fixup)(struct hid_bpf_ctx *ctx);
133                                                   133 
134         /**                                       134         /**
135          * @hid_hw_request: called whenever a     135          * @hid_hw_request: called whenever a hid_hw_raw_request() call is emitted
136          * on the HID device                      136          * on the HID device
137          *                                        137          *
138          * It has the following arguments:        138          * It has the following arguments:
139          *                                        139          *
140          * ``ctx``: The HID-BPF context as &st    140          * ``ctx``: The HID-BPF context as &struct hid_bpf_ctx
141          *                                        141          *
142          * ``reportnum``: the report number, a    142          * ``reportnum``: the report number, as in hid_hw_raw_request()
143          *                                        143          *
144          * ``rtype``: the report type (``HID_I    144          * ``rtype``: the report type (``HID_INPUT_REPORT``, ``HID_FEATURE_REPORT``,
145          * ``HID_OUTPUT_REPORT``)                 145          * ``HID_OUTPUT_REPORT``)
146          *                                        146          *
147          * ``reqtype``: the request               147          * ``reqtype``: the request
148          *                                        148          *
149          * ``source``: a u64 referring to a un    149          * ``source``: a u64 referring to a uniq but identifiable source. If %0, the
150          * kernel itself emitted that call. Fo    150          * kernel itself emitted that call. For hidraw, ``source`` is set
151          * to the associated ``struct file *``    151          * to the associated ``struct file *``.
152          *                                        152          *
153          * Return: %0 to keep processing the r    153          * Return: %0 to keep processing the request by hid-core; any other value
154          * stops hid-core from processing that    154          * stops hid-core from processing that event. A positive value should be
155          * returned with the number of bytes r    155          * returned with the number of bytes returned in the incoming buffer; a
156          * negative error code interrupts the     156          * negative error code interrupts the processing of this call.
157          */                                       157          */
158         int (*hid_hw_request)(struct hid_bpf_c    158         int (*hid_hw_request)(struct hid_bpf_ctx *ctx, unsigned char reportnum,
159                                enum hid_report    159                                enum hid_report_type rtype, enum hid_class_request reqtype,
160                                u64 source);       160                                u64 source);
161                                                   161 
162         /**                                       162         /**
163          * @hid_hw_output_report: called whene    163          * @hid_hw_output_report: called whenever a hid_hw_output_report() call is emitted
164          * on the HID device                      164          * on the HID device
165          *                                        165          *
166          * It has the following arguments:        166          * It has the following arguments:
167          *                                        167          *
168          * ``ctx``: The HID-BPF context as &st    168          * ``ctx``: The HID-BPF context as &struct hid_bpf_ctx
169          *                                        169          *
170          * ``source``: a u64 referring to a un    170          * ``source``: a u64 referring to a uniq but identifiable source. If %0, the
171          * kernel itself emitted that call. Fo    171          * kernel itself emitted that call. For hidraw, ``source`` is set
172          * to the associated ``struct file *``    172          * to the associated ``struct file *``.
173          *                                        173          *
174          * Return: %0 to keep processing the r    174          * Return: %0 to keep processing the request by hid-core; any other value
175          * stops hid-core from processing that    175          * stops hid-core from processing that event. A positive value should be
176          * returned with the number of bytes w    176          * returned with the number of bytes written to the device; a negative error
177          * code interrupts the processing of t    177          * code interrupts the processing of this call.
178          */                                       178          */
179         int (*hid_hw_output_report)(struct hid    179         int (*hid_hw_output_report)(struct hid_bpf_ctx *ctx, u64 source);
180                                                   180 
181                                                   181 
182         /* private: do not show up in the docs    182         /* private: do not show up in the docs */
183         struct hid_device *hdev;                  183         struct hid_device *hdev;
184 };                                                184 };
185                                                   185 
186 /* stored in each device */                       186 /* stored in each device */
187 struct hid_bpf {                                  187 struct hid_bpf {
188         u8 *device_data;                /* all    188         u8 *device_data;                /* allocated when a bpf program of type
189                                          * SEC    189                                          * SEC(f.../hid_bpf_device_event) has been attached
190                                          * to     190                                          * to this HID device
191                                          */       191                                          */
192         u32 allocated_data;                       192         u32 allocated_data;
193         bool destroyed;                 /* pre    193         bool destroyed;                 /* prevents the assignment of any progs */
194                                                   194 
195         struct hid_bpf_ops *rdesc_ops;            195         struct hid_bpf_ops *rdesc_ops;
196         struct list_head prog_list;               196         struct list_head prog_list;
197         struct mutex prog_list_lock;    /* pro    197         struct mutex prog_list_lock;    /* protects prog_list update */
198         struct srcu_struct srcu;        /* pro    198         struct srcu_struct srcu;        /* protects prog_list read-only access */
199 };                                                199 };
200                                                   200 
201 #ifdef CONFIG_HID_BPF                             201 #ifdef CONFIG_HID_BPF
202 u8 *dispatch_hid_bpf_device_event(struct hid_d    202 u8 *dispatch_hid_bpf_device_event(struct hid_device *hid, enum hid_report_type type, u8 *data,
203                                   u32 *size, i    203                                   u32 *size, int interrupt, u64 source, bool from_bpf);
204 int dispatch_hid_bpf_raw_requests(struct hid_d    204 int dispatch_hid_bpf_raw_requests(struct hid_device *hdev,
205                                   unsigned cha    205                                   unsigned char reportnum, __u8 *buf,
206                                   u32 size, en    206                                   u32 size, enum hid_report_type rtype,
207                                   enum hid_cla    207                                   enum hid_class_request reqtype,
208                                   u64 source,     208                                   u64 source, bool from_bpf);
209 int dispatch_hid_bpf_output_report(struct hid_    209 int dispatch_hid_bpf_output_report(struct hid_device *hdev, __u8 *buf, u32 size,
210                                    u64 source,    210                                    u64 source, bool from_bpf);
211 int hid_bpf_connect_device(struct hid_device *    211 int hid_bpf_connect_device(struct hid_device *hdev);
212 void hid_bpf_disconnect_device(struct hid_devi    212 void hid_bpf_disconnect_device(struct hid_device *hdev);
213 void hid_bpf_destroy_device(struct hid_device     213 void hid_bpf_destroy_device(struct hid_device *hid);
214 int hid_bpf_device_init(struct hid_device *hid    214 int hid_bpf_device_init(struct hid_device *hid);
215 u8 *call_hid_bpf_rdesc_fixup(struct hid_device    215 u8 *call_hid_bpf_rdesc_fixup(struct hid_device *hdev, const u8 *rdesc, unsigned int *size);
216 #else /* CONFIG_HID_BPF */                        216 #else /* CONFIG_HID_BPF */
217 static inline u8 *dispatch_hid_bpf_device_even    217 static inline u8 *dispatch_hid_bpf_device_event(struct hid_device *hid, enum hid_report_type type,
218                                                   218                                                 u8 *data, u32 *size, int interrupt,
219                                                   219                                                 u64 source, bool from_bpf) { return data; }
220 static inline int dispatch_hid_bpf_raw_request    220 static inline int dispatch_hid_bpf_raw_requests(struct hid_device *hdev,
221                                                   221                                                 unsigned char reportnum, u8 *buf,
222                                                   222                                                 u32 size, enum hid_report_type rtype,
223                                                   223                                                 enum hid_class_request reqtype,
224                                                   224                                                 u64 source, bool from_bpf) { return 0; }
225 static inline int dispatch_hid_bpf_output_repo    225 static inline int dispatch_hid_bpf_output_report(struct hid_device *hdev, __u8 *buf, u32 size,
226                                                   226                                                  u64 source, bool from_bpf) { return 0; }
227 static inline int hid_bpf_connect_device(struc    227 static inline int hid_bpf_connect_device(struct hid_device *hdev) { return 0; }
228 static inline void hid_bpf_disconnect_device(s    228 static inline void hid_bpf_disconnect_device(struct hid_device *hdev) {}
229 static inline void hid_bpf_destroy_device(stru    229 static inline void hid_bpf_destroy_device(struct hid_device *hid) {}
230 static inline int hid_bpf_device_init(struct h    230 static inline int hid_bpf_device_init(struct hid_device *hid) { return 0; }
231 /*                                                231 /*
232  * This specialized allocator has to be a macr    232  * This specialized allocator has to be a macro for its allocations to be
233  * accounted separately (to have a separate al    233  * accounted separately (to have a separate alloc_tag). The typecast is
234  * intentional to enforce typesafety.             234  * intentional to enforce typesafety.
235  */                                               235  */
236 #define call_hid_bpf_rdesc_fixup(_hdev, _rdesc    236 #define call_hid_bpf_rdesc_fixup(_hdev, _rdesc, _size)  \
237                 ((u8 *)kmemdup(_rdesc, *(_size    237                 ((u8 *)kmemdup(_rdesc, *(_size), GFP_KERNEL))
238                                                   238 
239 #endif /* CONFIG_HID_BPF */                       239 #endif /* CONFIG_HID_BPF */
240                                                   240 
241 #endif /* __HID_BPF_H */                          241 #endif /* __HID_BPF_H */
242                                                   242 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php