blob: ec08ac1ad68780ca599ff9bc12ffe3d9c2601c10 [file] [log] [blame]
Jiri Kosinac080d892007-01-25 11:43:31 +01001#ifndef __HID_DEBUG_H
2#define __HID_DEBUG_H
3
Linus Torvalds1da177e2005-04-16 15:20:36 -07004/*
Jiri Kosinaa635f9d2009-06-12 15:20:55 +02005 * Copyright (c) 2007-2009 Jiri Kosina
Linus Torvalds1da177e2005-04-16 15:20:36 -07006 */
7
8/*
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 *
Linus Torvalds1da177e2005-04-16 15:20:36 -070023 */
24
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020025#ifdef CONFIG_DEBUG_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -070026
Jiri Kosinacd667ce2009-06-12 15:20:57 +020027void hid_dump_input(struct hid_device *, struct hid_usage *, __s32);
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020028void hid_dump_device(struct hid_device *, struct seq_file *);
29void hid_dump_field(struct hid_field *, int, struct seq_file *);
Jiri Kosinacd667ce2009-06-12 15:20:57 +020030char *hid_resolv_usage(unsigned, struct seq_file *);
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020031void hid_debug_register(struct hid_device *, const char *);
32void hid_debug_unregister(struct hid_device *);
33void hid_debug_init(void);
34void hid_debug_exit(void);
Jiri Kosinacd667ce2009-06-12 15:20:57 +020035void hid_debug_event(struct hid_device *, char *);
36
37#define HID_DEBUG_BUFSIZE 512
38
39struct hid_debug_list {
40 char *hid_debug_buf;
41 int head;
42 int tail;
43 struct fasync_struct *fasync;
44 struct hid_device *hdev;
45 struct list_head node;
46 struct mutex read_mutex;
47};
Linus Torvalds1da177e2005-04-16 15:20:36 -070048
Jiri Kosinac080d892007-01-25 11:43:31 +010049#else
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020051#define hid_dump_input(a,b) do { } while (0)
52#define hid_dump_device(c) do { } while (0)
53#define hid_dump_field(a,b) do { } while (0)
54#define hid_resolv_usage(a) do { } while (0)
55#define hid_resolv_event(a,b) do { } while (0)
56#define hid_debug_register(a, b) do { } while (0)
57#define hid_debug_unregister(a) do { } while (0)
58#define hid_debug_init() do { } while (0)
59#define hid_debug_exit() do { } while (0)
Jiri Kosinacd667ce2009-06-12 15:20:57 +020060#define hid_debug_event(a,b) do { } while (0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020062#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
Jiri Kosinac080d892007-01-25 11:43:31 +010064#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070065