summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDima Zavin <dima@android.com>2011-08-30 20:59:45 +0200
committerDima Zavin <dima@android.com>2011-09-02 23:55:20 +0200
commitbc29063bf4e2312133d91e211dfe9c86ee811489 (patch)
tree7bc5a29a8f1201e3af7ab25846398722e8b05dc3
parentminui: graphics: add interface for framebuffer blank/unblank (diff)
downloadandroid_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar.gz
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar.bz2
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar.lz
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar.xz
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.tar.zst
android_bootable_recovery-bc29063bf4e2312133d91e211dfe9c86ee811489.zip
-rw-r--r--minui/events.c49
-rw-r--r--minui/minui.h15
-rw-r--r--ui.c132
3 files changed, 121 insertions, 75 deletions
diff --git a/minui/events.c b/minui/events.c
index 3aed2a860..eca3bc73b 100644
--- a/minui/events.c
+++ b/minui/events.c
@@ -26,10 +26,18 @@
#define MAX_DEVICES 16
+struct fd_info {
+ ev_callback cb;
+ void *data;
+};
+
static struct pollfd ev_fds[MAX_DEVICES];
+static struct fd_info ev_fdinfo[MAX_DEVICES];
+
static unsigned ev_count = 0;
+static unsigned ev_dev_count = 0;
-int ev_init(void)
+int ev_init(ev_callback input_cb, void *data)
{
DIR *dir;
struct dirent *de;
@@ -45,6 +53,8 @@ int ev_init(void)
ev_fds[ev_count].fd = fd;
ev_fds[ev_count].events = POLLIN;
+ ev_fdinfo[ev_count].cb = input_cb;
+ ev_fdinfo[ev_count].data = data;
ev_count++;
if(ev_count == MAX_DEVICES) break;
}
@@ -60,23 +70,36 @@ void ev_exit(void)
}
}
-int ev_get(struct input_event *ev, unsigned dont_wait)
+int ev_wait(int timeout)
{
int r;
+
+ r = poll(ev_fds, ev_count, timeout);
+ if (r <= 0)
+ return -1;
+ return 0;
+}
+
+void ev_dispatch(void)
+{
unsigned n;
+ int ret;
- do {
- r = poll(ev_fds, ev_count, dont_wait ? 0 : -1);
+ for (n = 0; n < ev_count; n++) {
+ ev_callback cb = ev_fdinfo[n].cb;
+ if (cb && (ev_fds[n].revents & ev_fds[n].events))
+ cb(ev_fds[n].fd, ev_fds[n].revents, ev_fdinfo[n].data);
+ }
+}
- if(r > 0) {
- for(n = 0; n < ev_count; n++) {
- if(ev_fds[n].revents & POLLIN) {
- r = read(ev_fds[n].fd, ev, sizeof(*ev));
- if(r == sizeof(*ev)) return 0;
- }
- }
- }
- } while(dont_wait == 0);
+int ev_get_input(int fd, short revents, struct input_event *ev)
+{
+ int r;
+ if (revents & POLLIN) {
+ r = read(fd, ev, sizeof(*ev));
+ if (r == sizeof(*ev))
+ return 0;
+ }
return -1;
}
diff --git a/minui/minui.h b/minui/minui.h
index 2284a3374..5a4168c46 100644
--- a/minui/minui.h
+++ b/minui/minui.h
@@ -45,9 +45,20 @@ unsigned int gr_get_height(gr_surface surface);
// see http://www.mjmwired.net/kernel/Documentation/input/ for info.
struct input_event;
-int ev_init(void);
+typedef int (*ev_callback)(int fd, short revents, void *data);
+
+int ev_init(ev_callback input_cb, void *data);
void ev_exit(void);
-int ev_get(struct input_event *ev, unsigned dont_wait);
+
+/* timeout has the same semantics as for poll
+ * 0 : don't block
+ * < 0 : block forever
+ * > 0 : block for 'timeout' milliseconds
+ */
+int ev_wait(int timeout);
+
+int ev_get_input(int fd, short revents, struct input_event *ev);
+void ev_dispatch(void);
// Resources
diff --git a/ui.c b/ui.c
index 4e41bc907..d08f7d31a 100644
--- a/ui.c
+++ b/ui.c
@@ -295,71 +295,83 @@ static void *progress_thread(void *cookie)
return NULL;
}
-// Reads input events, handles special hot keys, and adds to the key queue.
-static void *input_thread(void *cookie)
+static int rel_sum = 0;
+
+static int input_callback(int fd, short revents, void *data)
{
- int rel_sum = 0;
+ struct input_event ev;
+ int ret;
int fake_key = 0;
- for (;;) {
- // wait for the next key event
- struct input_event ev;
- do {
- ev_get(&ev, 0);
-
- if (ev.type == EV_SYN) {
- continue;
- } else if (ev.type == EV_REL) {
- if (ev.code == REL_Y) {
- // accumulate the up or down motion reported by
- // the trackball. When it exceeds a threshold
- // (positive or negative), fake an up/down
- // key event.
- rel_sum += ev.value;
- if (rel_sum > 3) {
- fake_key = 1;
- ev.type = EV_KEY;
- ev.code = KEY_DOWN;
- ev.value = 1;
- rel_sum = 0;
- } else if (rel_sum < -3) {
- fake_key = 1;
- ev.type = EV_KEY;
- ev.code = KEY_UP;
- ev.value = 1;
- rel_sum = 0;
- }
- }
- } else {
+
+ ret = ev_get_input(fd, revents, &ev);
+ if (ret)
+ return -1;
+
+ if (ev.type == EV_SYN) {
+ return 0;
+ } else if (ev.type == EV_REL) {
+ if (ev.code == REL_Y) {
+ // accumulate the up or down motion reported by
+ // the trackball. When it exceeds a threshold
+ // (positive or negative), fake an up/down
+ // key event.
+ rel_sum += ev.value;
+ if (rel_sum > 3) {
+ fake_key = 1;
+ ev.type = EV_KEY;
+ ev.code = KEY_DOWN;
+ ev.value = 1;
+ rel_sum = 0;
+ } else if (rel_sum < -3) {
+ fake_key = 1;
+ ev.type = EV_KEY;
+ ev.code = KEY_UP;
+ ev.value = 1;
rel_sum = 0;
}
- } while (ev.type != EV_KEY || ev.code > KEY_MAX);
-
- pthread_mutex_lock(&key_queue_mutex);
- if (!fake_key) {
- // our "fake" keys only report a key-down event (no
- // key-up), so don't record them in the key_pressed
- // table.
- key_pressed[ev.code] = ev.value;
- }
- fake_key = 0;
- const int queue_max = sizeof(key_queue) / sizeof(key_queue[0]);
- if (ev.value > 0 && key_queue_len < queue_max) {
- key_queue[key_queue_len++] = ev.code;
- pthread_cond_signal(&key_queue_cond);
- }
- pthread_mutex_unlock(&key_queue_mutex);
-
- if (ev.value > 0 && device_toggle_display(key_pressed, ev.code)) {
- pthread_mutex_lock(&gUpdateMutex);
- show_text = !show_text;
- if (show_text) show_text_ever = 1;
- update_screen_locked();
- pthread_mutex_unlock(&gUpdateMutex);
}
+ } else {
+ rel_sum = 0;
+ }
- if (ev.value > 0 && device_reboot_now(key_pressed, ev.code)) {
- android_reboot(ANDROID_RB_RESTART, 0, 0);
- }
+ if (ev.type != EV_KEY || ev.code > KEY_MAX)
+ return 0;
+
+ pthread_mutex_lock(&key_queue_mutex);
+ if (!fake_key) {
+ // our "fake" keys only report a key-down event (no
+ // key-up), so don't record them in the key_pressed
+ // table.
+ key_pressed[ev.code] = ev.value;
+ }
+ const int queue_max = sizeof(key_queue) / sizeof(key_queue[0]);
+ if (ev.value > 0 && key_queue_len < queue_max) {
+ key_queue[key_queue_len++] = ev.code;
+ pthread_cond_signal(&key_queue_cond);
+ }
+ pthread_mutex_unlock(&key_queue_mutex);
+
+ if (ev.value > 0 && device_toggle_display(key_pressed, ev.code)) {
+ pthread_mutex_lock(&gUpdateMutex);
+ show_text = !show_text;
+ if (show_text) show_text_ever = 1;
+ update_screen_locked();
+ pthread_mutex_unlock(&gUpdateMutex);
+ }
+
+ if (ev.value > 0 && device_reboot_now(key_pressed, ev.code)) {
+ android_reboot(ANDROID_RB_RESTART, 0, 0);
+ }
+
+ return 0;
+}
+
+// Reads input events, handles special hot keys, and adds to the key queue.
+static void *input_thread(void *cookie)
+{
+ for (;;) {
+ if (!ev_wait(-1))
+ ev_dispatch();
}
return NULL;
}
@@ -367,7 +379,7 @@ static void *input_thread(void *cookie)
void ui_init(void)
{
gr_init();
- ev_init();
+ ev_init(input_callback, NULL);
text_col = text_row = 0;
text_rows = gr_fb_height() / CHAR_HEIGHT;