blob: ea7b23d13bfdf47cb9b0f5b80c654a31cf863570 [file] [log] [blame]
Thomas Gleixner1a59d1b82019-05-27 08:55:05 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Jiri Kosinac080d892007-01-25 11:43:31 +01002#ifndef __HID_DEBUG_H
3#define __HID_DEBUG_H
4
Linus Torvalds1da177e2005-04-16 15:20:36 -07005/*
Jiri Kosinaa635f9d2009-06-12 15:20:55 +02006 * Copyright (c) 2007-2009 Jiri Kosina
Linus Torvalds1da177e2005-04-16 15:20:36 -07007 */
8
9/*
Linus Torvalds1da177e2005-04-16 15:20:36 -070010 */
11
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020012#ifdef CONFIG_DEBUG_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
Vladis Dronov13054ab2019-01-29 11:58:35 +010014#include <linux/kfifo.h>
15
Benjamin Tissoiresa5f04b92013-04-17 19:38:13 +020016#define HID_DEBUG_BUFSIZE 512
Vladis Dronov13054ab2019-01-29 11:58:35 +010017#define HID_DEBUG_FIFOSIZE 512
Benjamin Tissoiresa5f04b92013-04-17 19:38:13 +020018
Jiri Kosinacd667ce2009-06-12 15:20:57 +020019void hid_dump_input(struct hid_device *, struct hid_usage *, __s32);
Benjamin Tissoiresa5f04b92013-04-17 19:38:13 +020020void hid_dump_report(struct hid_device *, int , u8 *, int);
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020021void hid_dump_device(struct hid_device *, struct seq_file *);
22void hid_dump_field(struct hid_field *, int, struct seq_file *);
Jiri Kosinacd667ce2009-06-12 15:20:57 +020023char *hid_resolv_usage(unsigned, struct seq_file *);
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020024void hid_debug_register(struct hid_device *, const char *);
25void hid_debug_unregister(struct hid_device *);
26void hid_debug_init(void);
27void hid_debug_exit(void);
Jiri Kosinacd667ce2009-06-12 15:20:57 +020028void hid_debug_event(struct hid_device *, char *);
29
Jiri Kosinacd667ce2009-06-12 15:20:57 +020030struct hid_debug_list {
Vladis Dronov13054ab2019-01-29 11:58:35 +010031 DECLARE_KFIFO_PTR(hid_debug_fifo, char);
Jiri Kosinacd667ce2009-06-12 15:20:57 +020032 struct fasync_struct *fasync;
33 struct hid_device *hdev;
34 struct list_head node;
35 struct mutex read_mutex;
36};
Linus Torvalds1da177e2005-04-16 15:20:36 -070037
Jiri Kosinac080d892007-01-25 11:43:31 +010038#else
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
Jiri Kosina38b7f492009-06-26 10:48:34 +020040#define hid_dump_input(a,b,c) do { } while (0)
Benjamin Tissoiresa5f04b92013-04-17 19:38:13 +020041#define hid_dump_report(a,b,c,d) do { } while (0)
Jiri Kosina38b7f492009-06-26 10:48:34 +020042#define hid_dump_device(a,b) do { } while (0)
43#define hid_dump_field(a,b,c) do { } while (0)
44#define hid_resolv_usage(a,b) do { } while (0)
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020045#define hid_debug_register(a, b) do { } while (0)
46#define hid_debug_unregister(a) do { } while (0)
47#define hid_debug_init() do { } while (0)
48#define hid_debug_exit() do { } while (0)
Jiri Kosinacd667ce2009-06-12 15:20:57 +020049#define hid_debug_event(a,b) do { } while (0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
Jiri Kosinaa635f9d2009-06-12 15:20:55 +020051#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
Jiri Kosinac080d892007-01-25 11:43:31 +010053#endif