blob: cd67f4ca5599c50842c774b0a635ccf847a19343 [file] [log] [blame]
Thomas Gleixnera32dd672019-05-29 07:18:11 -07001/* SPDX-License-Identifier: GPL-2.0-only */
Jiri Kosina86166b72007-05-14 09:57:40 +02002/*
3 * Copyright (c) 2007 Jiri Kosina
4 */
David Howells607ca462012-10-13 10:46:48 +01005#ifndef _HIDRAW_H
6#define _HIDRAW_H
Jiri Kosina86166b72007-05-14 09:57:40 +02007
David Howells607ca462012-10-13 10:46:48 +01008#include <uapi/linux/hidraw.h>
Jiri Kosina57d292b2007-10-15 15:17:41 +02009
Jiri Kosina86166b72007-05-14 09:57:40 +020010
Jiri Kosina86166b72007-05-14 09:57:40 +020011struct hidraw {
12 unsigned int minor;
13 int exist;
14 int open;
15 wait_queue_head_t wait;
16 struct hid_device *hid;
17 struct device *dev;
Yonghua Zheng277fe442013-08-26 23:38:35 +080018 spinlock_t list_lock;
Jiri Kosina86166b72007-05-14 09:57:40 +020019 struct list_head list;
20};
21
22struct hidraw_report {
23 __u8 *value;
24 int len;
25};
26
27struct hidraw_list {
28 struct hidraw_report buffer[HIDRAW_BUFFER_SIZE];
29 int head;
30 int tail;
31 struct fasync_struct *fasync;
32 struct hidraw *hidraw;
33 struct list_head node;
34 struct mutex read_mutex;
35};
36
37#ifdef CONFIG_HIDRAW
38int hidraw_init(void);
39void hidraw_exit(void);
Jiri Kosinab6787242012-04-27 00:56:08 +020040int hidraw_report_event(struct hid_device *, u8 *, int);
Jiri Kosina86166b72007-05-14 09:57:40 +020041int hidraw_connect(struct hid_device *);
42void hidraw_disconnect(struct hid_device *);
43#else
44static inline int hidraw_init(void) { return 0; }
45static inline void hidraw_exit(void) { }
Jiri Kosinad6d7c872012-04-30 10:39:17 +020046static inline int hidraw_report_event(struct hid_device *hid, u8 *data, int len) { return 0; }
Jiri Kosina86166b72007-05-14 09:57:40 +020047static inline int hidraw_connect(struct hid_device *hid) { return -1; }
48static inline void hidraw_disconnect(struct hid_device *hid) { }
49#endif
50
51#endif