gpio-button-hotplug: add support for EV_SW

Signed-off-by: Luka Perkov <luka@openwrt.org>

SVN-Revision: 37130
master
Luka Perkov 12 years ago
parent c627ae768e
commit 6988613f7a
  1. 28
      package/kernel/gpio-button-hotplug/src/gpio-button-hotplug.c

@ -49,6 +49,7 @@ struct bh_priv {
struct bh_event { struct bh_event {
const char *name; const char *name;
unsigned int type;
char *action; char *action;
unsigned long seen; unsigned long seen;
@ -91,9 +92,7 @@ static struct bh_map button_map[] = {
BH_MAP(BTN_9, "BTN_9"), BH_MAP(BTN_9, "BTN_9"),
BH_MAP(KEY_RESTART, "reset"), BH_MAP(KEY_RESTART, "reset"),
BH_MAP(KEY_RFKILL, "rfkill"), BH_MAP(KEY_RFKILL, "rfkill"),
#ifdef KEY_WPS_BUTTON
BH_MAP(KEY_WPS_BUTTON, "wps"), BH_MAP(KEY_WPS_BUTTON, "wps"),
#endif /* KEY_WPS_BUTTON */
}; };
/* -------------------------------------------------------------------------*/ /* -------------------------------------------------------------------------*/
@ -140,7 +139,20 @@ static int button_hotplug_fill_event(struct bh_event *event)
if (ret) if (ret)
return ret; return ret;
ret = bh_event_add_var(event, 0, "SUBSYSTEM=%s", "button"); char *s;
switch (event->type) {
case EV_KEY:
s = "button";
break;
case EV_SW:
s = "switch";
break;
default:
s = "button";
break;
}
ret = bh_event_add_var(event, 0, "SUBSYSTEM=%s", s);
if (ret) if (ret)
return ret; return ret;
@ -190,8 +202,8 @@ static void button_hotplug_work(struct work_struct *work)
kfree(event); kfree(event);
} }
static int button_hotplug_create_event(const char *name, unsigned long seen, static int button_hotplug_create_event(const char *name, unsigned int type,
int pressed) unsigned long seen, int pressed)
{ {
struct bh_event *event; struct bh_event *event;
@ -203,6 +215,7 @@ static int button_hotplug_create_event(const char *name, unsigned long seen,
return -ENOMEM; return -ENOMEM;
event->name = name; event->name = name;
event->type = type;
event->seen = seen; event->seen = seen;
event->action = pressed ? "pressed" : "released"; event->action = pressed ? "pressed" : "released";
@ -225,6 +238,7 @@ static int button_get_index(unsigned int code)
return -1; return -1;
} }
static void button_hotplug_event(struct gpio_keys_button_data *data, static void button_hotplug_event(struct gpio_keys_button_data *data,
unsigned int type, unsigned int code, int value) unsigned int type, unsigned int code, int value)
{ {
@ -234,14 +248,14 @@ static void button_hotplug_event(struct gpio_keys_button_data *data,
BH_DBG("event type=%u, code=%u, value=%d\n", type, code, value); BH_DBG("event type=%u, code=%u, value=%d\n", type, code, value);
if (type != EV_KEY) if ((type != EV_KEY) && (type != EV_SW))
return; return;
btn = button_get_index(code); btn = button_get_index(code);
if (btn < 0) if (btn < 0)
return; return;
button_hotplug_create_event(button_map[btn].name, button_hotplug_create_event(button_map[btn].name, type,
(seen - priv->seen) / HZ, value); (seen - priv->seen) / HZ, value);
priv->seen = seen; priv->seen = seen;
} }

Loading…
Cancel
Save