From: David Herrmann <dh.herrmann@googlemail.com>
To: linux-input@vger.kernel.org
Cc: jkosina@suse.cz, David Herrmann <dh.herrmann@googlemail.com>
Subject: [PATCH 01/16] HID: uhid: introduce user-space I/O driver support for HID
Date: Sun, 10 Jun 2012 15:16:13 +0200 [thread overview]
Message-ID: <1339334188-21766-2-git-send-email-dh.herrmann@googlemail.com> (raw)
In-Reply-To: <1339334188-21766-1-git-send-email-dh.herrmann@googlemail.com>
This adds a dummy driver that will support user-space I/O drivers for the
HID subsystem. This allows to write transport-level drivers like USB-HID
and Bluetooth-HID in user-space.
Low-Energy Bluetooth needs this to feed HID data that is parsed in
user-space back into the kernel.
Signed-off-by: David Herrmann <dh.herrmann@googlemail.com>
---
drivers/hid/Kconfig | 21 ++++++++++++
drivers/hid/Makefile | 1 +
drivers/hid/uhid.c | 88 ++++++++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 110 insertions(+)
create mode 100644 drivers/hid/uhid.c
diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig
index ca7e76c..89bd6b4 100644
--- a/drivers/hid/Kconfig
+++ b/drivers/hid/Kconfig
@@ -59,6 +59,27 @@ config HIDRAW
If unsure, say Y.
+config UHID
+ tristate "User-space I/O driver support for HID subsystem"
+ depends on HID
+ default n
+ ---help---
+ Say Y here if you want to provide HID I/O Drivers from user-space.
+ This allows to write I/O drivers in user-space and feed the data from
+ the device into the kernel. The kernel parses the HID reports, loads the
+ corresponding HID Device Driver or provides input devices on top of your
+ user-space device.
+
+ This driver cannot be used to parse HID-reports in user-space and write
+ special HID-drivers. You should use hidraw for that.
+ Instead, this driver allows to write the transport-layer driver in
+ user-space like USB-HID and Bluetooth-HID do in kernel-space.
+
+ If unsure, say N.
+
+ To compile this driver as a module, choose M here: the
+ module will be called uhid.
+
source "drivers/hid/usbhid/Kconfig"
menu "Special HID drivers"
diff --git a/drivers/hid/Makefile b/drivers/hid/Makefile
index 05913c5..dedc932 100644
--- a/drivers/hid/Makefile
+++ b/drivers/hid/Makefile
@@ -8,6 +8,7 @@ ifdef CONFIG_DEBUG_FS
endif
obj-$(CONFIG_HID) += hid.o
+obj-$(CONFIG_UHID) += uhid.o
obj-$(CONFIG_HID_GENERIC) += hid-generic.o
diff --git a/drivers/hid/uhid.c b/drivers/hid/uhid.c
new file mode 100644
index 0000000..5b02d6c
--- /dev/null
+++ b/drivers/hid/uhid.c
@@ -0,0 +1,88 @@
+/*
+ * User-space I/O driver support for HID subsystem
+ * Copyright (c) 2012 David Herrmann
+ */
+
+/*
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the Free
+ * Software Foundation; either version 2 of the License, or (at your option)
+ * any later version.
+ */
+
+#include <linux/atomic.h>
+#include <linux/device.h>
+#include <linux/fs.h>
+#include <linux/hid.h>
+#include <linux/input.h>
+#include <linux/miscdevice.h>
+#include <linux/module.h>
+#include <linux/mutex.h>
+#include <linux/poll.h>
+#include <linux/sched.h>
+#include <linux/spinlock.h>
+#include <linux/uhid.h>
+#include <linux/wait.h>
+
+#define UHID_NAME "uhid"
+
+static struct miscdevice uhid_misc;
+
+static int uhid_char_open(struct inode *inode, struct file *file)
+{
+ return 0;
+}
+
+static int uhid_char_release(struct inode *inode, struct file *file)
+{
+ return 0;
+}
+
+static ssize_t uhid_char_read(struct file *file, char __user *buffer,
+ size_t count, loff_t *ppos)
+{
+ return 0;
+}
+
+static ssize_t uhid_char_write(struct file *file, const char __user *buffer,
+ size_t count, loff_t *ppos)
+{
+ return 0;
+}
+
+static unsigned int uhid_char_poll(struct file *file, poll_table *wait)
+{
+ return 0;
+}
+
+static const struct file_operations uhid_fops = {
+ .owner = THIS_MODULE,
+ .open = uhid_char_open,
+ .release = uhid_char_release,
+ .read = uhid_char_read,
+ .write = uhid_char_write,
+ .poll = uhid_char_poll,
+ .llseek = no_llseek,
+};
+
+static struct miscdevice uhid_misc = {
+ .fops = &uhid_fops,
+ .minor = MISC_DYNAMIC_MINOR,
+ .name = UHID_NAME,
+};
+
+static int __init uhid_init(void)
+{
+ return misc_register(&uhid_misc);
+}
+
+static void __exit uhid_exit(void)
+{
+ misc_deregister(&uhid_misc);
+}
+
+module_init(uhid_init);
+module_exit(uhid_exit);
+MODULE_LICENSE("GPL");
+MODULE_AUTHOR("David Herrmann <dh.herrmann@gmail.com>");
+MODULE_DESCRIPTION("User-space I/O driver support for HID subsystem");
--
1.7.10.4
next prev parent reply other threads:[~2012-06-10 13:16 UTC|newest]
Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-06-10 13:16 [PATCH 00/16] HID: uhid: User-space HID I/O driver David Herrmann
2012-06-10 13:16 ` David Herrmann [this message]
2012-06-10 13:16 ` [PATCH 02/16] HID: uhid: add internal message buffer David Herrmann
2012-06-10 13:16 ` [PATCH 03/16] HID: uhid: allow poll()'ing on uhid devices David Herrmann
2012-06-10 13:16 ` [PATCH 04/16] HID: uhid: implement read() " David Herrmann
2012-06-10 13:16 ` [PATCH 05/16] HID: uhid: implement write() " David Herrmann
2012-06-10 13:16 ` [PATCH 06/16] HID: uhid: add UHID_CREATE and UHID_DESTROY events David Herrmann
2012-06-10 13:16 ` [PATCH 07/16] HID: uhid: allow feeding input data into uhid devices David Herrmann
2012-06-10 13:16 ` [PATCH 08/16] HID: uhid: forward hid report-descriptor to hid core David Herrmann
2012-06-10 13:16 ` [PATCH 09/16] HID: uhid: add UHID_START and UHID_STOP events David Herrmann
2012-06-10 13:16 ` [PATCH 10/16] HID: uhid: forward open/close events to user-space David Herrmann
2012-06-10 13:16 ` [PATCH 11/16] HID: uhid: forward output request " David Herrmann
2012-06-10 13:16 ` [PATCH 12/16] HID: uhid: forward raw output reports " David Herrmann
2012-06-10 13:16 ` [PATCH 13/16] HID: uhid: implement feature requests David Herrmann
2012-06-10 13:16 ` [PATCH 14/16] HID: uhid: add documentation David Herrmann
2012-06-10 13:16 ` [PATCH 15/16] HID: uhid: add example program David Herrmann
2012-06-10 13:16 ` [PATCH 16/16] MAINTAINERS: add UHID entry David Herrmann
2012-06-11 14:46 ` [PATCH 00/16] HID: uhid: User-space HID I/O driver Joao Paulo Rechi Vita
2012-06-11 17:56 ` David Herrmann
[not found] ` <CAAngNMa3GMqrgZUrx=XqaRWfK2MaFMewK6OEQU_=4oPj1FOMNw@mail.gmail.com>
2012-06-14 22:05 ` Joao Paulo Rechi Vita
2012-06-16 12:44 ` David Herrmann
2012-06-18 11:46 ` Jiri Kosina
2012-07-02 21:05 ` Joao Paulo Rechi Vita
2012-07-02 21:19 ` David Herrmann
2012-07-03 2:15 ` Jiri Kosina
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1339334188-21766-2-git-send-email-dh.herrmann@googlemail.com \
--to=dh.herrmann@googlemail.com \
--cc=jkosina@suse.cz \
--cc=linux-input@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).