Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 328513
b: refs/heads/master
c: c0bb1f9
h: refs/heads/master
i:
  328511: 8ddfb18
v: v3
  • Loading branch information
Dmitry Torokhov committed Aug 22, 2012
1 parent 370067c commit 99aa3e4
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 18 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 80c99bcd28617bd534b6f9489857235ee613c797
refs/heads/master: c0bb1f975ca06b17d595937c5e91578b36047039
43 changes: 26 additions & 17 deletions trunk/drivers/input/input.c
Original file line number Diff line number Diff line change
Expand Up @@ -844,18 +844,10 @@ int input_set_keycode(struct input_dev *dev,
}
EXPORT_SYMBOL(input_set_keycode);

#define MATCH_BIT(bit, max) \
for (i = 0; i < BITS_TO_LONGS(max); i++) \
if ((id->bit[i] & dev->bit[i]) != id->bit[i]) \
break; \
if (i != BITS_TO_LONGS(max)) \
continue;

static const struct input_device_id *input_match_device(struct input_handler *handler,
struct input_dev *dev)
{
const struct input_device_id *id;
int i;

for (id = handler->id_table; id->flags || id->driver_info; id++) {

Expand All @@ -875,15 +867,32 @@ static const struct input_device_id *input_match_device(struct input_handler *ha
if (id->version != dev->id.version)
continue;

MATCH_BIT(evbit, EV_MAX);
MATCH_BIT(keybit, KEY_MAX);
MATCH_BIT(relbit, REL_MAX);
MATCH_BIT(absbit, ABS_MAX);
MATCH_BIT(mscbit, MSC_MAX);
MATCH_BIT(ledbit, LED_MAX);
MATCH_BIT(sndbit, SND_MAX);
MATCH_BIT(ffbit, FF_MAX);
MATCH_BIT(swbit, SW_MAX);
if (!bitmap_subset(id->evbit, dev->evbit, EV_MAX))
continue;

if (!bitmap_subset(id->keybit, dev->keybit, KEY_MAX))
continue;

if (!bitmap_subset(id->relbit, dev->relbit, REL_MAX))
continue;

if (!bitmap_subset(id->absbit, dev->absbit, ABS_MAX))
continue;

if (!bitmap_subset(id->mscbit, dev->mscbit, MSC_MAX))
continue;

if (!bitmap_subset(id->ledbit, dev->ledbit, LED_MAX))
continue;

if (!bitmap_subset(id->sndbit, dev->sndbit, SND_MAX))
continue;

if (!bitmap_subset(id->ffbit, dev->ffbit, FF_MAX))
continue;

if (!bitmap_subset(id->swbit, dev->swbit, SW_MAX))
continue;

if (!handler->match || handler->match(handler, dev))
return id;
Expand Down

0 comments on commit 99aa3e4

Please sign in to comment.