提交 733aca90 编写于 作者: J Jaejoong Kim 提交者: Jiri Kosina

HID: hiddev: reallocate hiddev's minor number

We need to store the minor number each drivers. In case of hidraw, the
minor number is stored stores in struct hidraw. But hiddev's minor is
located in struct hid_device.

The hid-core driver announces a kernel message which driver is loaded when
HID device connected, but hiddev's minor number is always zero. To proper
display hiddev's minor number, we need to store the minor number asked from
usb core and do some refactoring work (move from hiddev.c to hiddev.h) to
access hiddev in hid-core.

[jkosina@suse.cz: rebase on top of newer codebase]
Reviewed-by: NBenjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: NJaejoong Kim <climbbb.kim@gmail.com>
Signed-off-by: NJiri Kosina <jkosina@suse.cz>
上级 42cb6b35
...@@ -1695,7 +1695,7 @@ int hid_connect(struct hid_device *hdev, unsigned int connect_mask) ...@@ -1695,7 +1695,7 @@ int hid_connect(struct hid_device *hdev, unsigned int connect_mask)
len += sprintf(buf + len, "input"); len += sprintf(buf + len, "input");
if (hdev->claimed & HID_CLAIMED_HIDDEV) if (hdev->claimed & HID_CLAIMED_HIDDEV)
len += sprintf(buf + len, "%shiddev%d", len ? "," : "", len += sprintf(buf + len, "%shiddev%d", len ? "," : "",
hdev->minor); ((struct hiddev *)hdev->hiddev)->minor);
if (hdev->claimed & HID_CLAIMED_HIDRAW) if (hdev->claimed & HID_CLAIMED_HIDRAW)
len += sprintf(buf + len, "%shidraw%d", len ? "," : "", len += sprintf(buf + len, "%shidraw%d", len ? "," : "",
((struct hidraw *)hdev->hidraw)->minor); ((struct hidraw *)hdev->hidraw)->minor);
......
...@@ -46,17 +46,6 @@ ...@@ -46,17 +46,6 @@
#endif #endif
#define HIDDEV_BUFFER_SIZE 2048 #define HIDDEV_BUFFER_SIZE 2048
struct hiddev {
int exist;
int open;
struct mutex existancelock;
wait_queue_head_t wait;
struct hid_device *hid;
struct list_head list;
spinlock_t list_lock;
bool initialized;
};
struct hiddev_list { struct hiddev_list {
struct hiddev_usage_ref buffer[HIDDEV_BUFFER_SIZE]; struct hiddev_usage_ref buffer[HIDDEV_BUFFER_SIZE];
int head; int head;
...@@ -923,6 +912,8 @@ int hiddev_connect(struct hid_device *hid, unsigned int force) ...@@ -923,6 +912,8 @@ int hiddev_connect(struct hid_device *hid, unsigned int force)
*/ */
hiddev->initialized = hid->quirks & HID_QUIRK_NO_INIT_REPORTS; hiddev->initialized = hid->quirks & HID_QUIRK_NO_INIT_REPORTS;
hiddev->minor = usbhid->intf->minor;
return 0; return 0;
} }
......
...@@ -541,7 +541,6 @@ struct hid_device { /* device report descriptor */ ...@@ -541,7 +541,6 @@ struct hid_device { /* device report descriptor */
struct list_head inputs; /* The list of inputs */ struct list_head inputs; /* The list of inputs */
void *hiddev; /* The hiddev structure */ void *hiddev; /* The hiddev structure */
void *hidraw; void *hidraw;
int minor; /* Hiddev minor number */
int open; /* is the device open by anyone? */ int open; /* is the device open by anyone? */
char name[128]; /* Device name */ char name[128]; /* Device name */
......
...@@ -32,6 +32,18 @@ ...@@ -32,6 +32,18 @@
* In-kernel definitions. * In-kernel definitions.
*/ */
struct hiddev {
int minor;
int exist;
int open;
struct mutex existancelock;
wait_queue_head_t wait;
struct hid_device *hid;
struct list_head list;
spinlock_t list_lock;
bool initialized;
};
struct hid_device; struct hid_device;
struct hid_usage; struct hid_usage;
struct hid_field; struct hid_field;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册