blob: 45e9fcb8d8777884e0ecf0c428b3c8015d189f9f [file] [log] [blame]
Jiri Kosina86166b72007-05-14 09:57:40 +02001#ifndef _HIDRAW_H
2#define _HIDRAW_H
3
4/*
5 * Copyright (c) 2007 Jiri Kosina
6 */
7
8/*
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms and conditions of the GNU General Public License,
11 * version 2, as published by the Free Software Foundation.
12 *
13 * You should have received a copy of the GNU General Public License along with
14 * this program; if not, write to the Free Software Foundation, Inc.,
15 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
16 */
17
Jiri Kosina57d292b2007-10-15 15:17:41 +020018#include <linux/hid.h>
Mike Frysinger0dd91542008-04-08 10:20:36 +020019#include <linux/types.h>
Jiri Kosina57d292b2007-10-15 15:17:41 +020020
Jiri Kosina86166b72007-05-14 09:57:40 +020021struct hidraw_report_descriptor {
22 __u32 size;
Jiri Kosina57d292b2007-10-15 15:17:41 +020023 __u8 value[HID_MAX_DESCRIPTOR_SIZE];
Jiri Kosina86166b72007-05-14 09:57:40 +020024};
25
26struct hidraw_devinfo {
27 __u32 bustype;
28 __s16 vendor;
29 __s16 product;
30};
31
32/* ioctl interface */
33#define HIDIOCGRDESCSIZE _IOR('H', 0x01, int)
34#define HIDIOCGRDESC _IOR('H', 0x02, struct hidraw_report_descriptor)
35#define HIDIOCGRAWINFO _IOR('H', 0x03, struct hidraw_devinfo)
Jiri Kosina9188e792008-11-12 16:14:08 +010036#define HIDIOCGRAWNAME(len) _IOC(_IOC_READ, 'H', 0x04, len)
37#define HIDIOCGRAWPHYS(len) _IOC(_IOC_READ, 'H', 0x05, len)
Alan Ottb4dbde92011-01-18 03:04:39 -050038/* The first byte of SFEATURE and GFEATURE is the report number */
39#define HIDIOCSFEATURE(len) _IOC(_IOC_WRITE|_IOC_READ, 'H', 0x06, len)
40#define HIDIOCGFEATURE(len) _IOC(_IOC_WRITE|_IOC_READ, 'H', 0x07, len)
Jiri Kosina86166b72007-05-14 09:57:40 +020041
42#define HIDRAW_FIRST_MINOR 0
43#define HIDRAW_MAX_DEVICES 64
44/* number of reports to buffer */
45#define HIDRAW_BUFFER_SIZE 64
46
47
48/* kernel-only API declarations */
49#ifdef __KERNEL__
50
Jiri Kosina86166b72007-05-14 09:57:40 +020051struct hidraw {
52 unsigned int minor;
53 int exist;
54 int open;
55 wait_queue_head_t wait;
56 struct hid_device *hid;
57 struct device *dev;
58 struct list_head list;
59};
60
61struct hidraw_report {
62 __u8 *value;
63 int len;
64};
65
66struct hidraw_list {
67 struct hidraw_report buffer[HIDRAW_BUFFER_SIZE];
68 int head;
69 int tail;
70 struct fasync_struct *fasync;
71 struct hidraw *hidraw;
72 struct list_head node;
73 struct mutex read_mutex;
74};
75
76#ifdef CONFIG_HIDRAW
77int hidraw_init(void);
78void hidraw_exit(void);
Jiri Kosinab6787242012-04-27 00:56:08 +020079int hidraw_report_event(struct hid_device *, u8 *, int);
Jiri Kosina86166b72007-05-14 09:57:40 +020080int hidraw_connect(struct hid_device *);
81void hidraw_disconnect(struct hid_device *);
82#else
83static inline int hidraw_init(void) { return 0; }
84static inline void hidraw_exit(void) { }
Jiri Kosinad6d7c872012-04-30 10:39:17 +020085static inline int hidraw_report_event(struct hid_device *hid, u8 *data, int len) { return 0; }
Jiri Kosina86166b72007-05-14 09:57:40 +020086static inline int hidraw_connect(struct hid_device *hid) { return -1; }
87static inline void hidraw_disconnect(struct hid_device *hid) { }
88#endif
89
90#endif
91
92#endif