am 294539df: am 3e941347: am 6f6b21b4: am 4733d3a6: Merge "Bluetooth event loop dispatches dbus data on wakeup"

* commit '294539df2c05eb62c417e25b2e1c8a71474b09e6':
  Bluetooth event loop dispatches dbus data on wakeup
This commit is contained in:
Jaikumar Ganesh
2011-08-18 12:13:30 -07:00
committed by Android Git Automerger

View File

@@ -507,6 +507,7 @@ static void tearDownEventLoop(native_data_t *nat) {
#define EVENT_LOOP_EXIT 1
#define EVENT_LOOP_ADD 2
#define EVENT_LOOP_REMOVE 3
#define EVENT_LOOP_WAKEUP 4
dbus_bool_t dbusAddWatch(DBusWatch *watch, void *data) {
native_data_t *nat = (native_data_t *)data;
@@ -551,6 +552,13 @@ void dbusToggleWatch(DBusWatch *watch, void *data) {
}
}
void dbusWakeup(void *data) {
native_data_t *nat = (native_data_t *)data;
char control = EVENT_LOOP_WAKEUP;
write(nat->controlFdW, &control, sizeof(char));
}
static void handleWatchAdd(native_data_t *nat) {
DBusWatch *watch;
int newFD;
@@ -634,6 +642,7 @@ static void *eventLoopMain(void *ptr) {
dbus_connection_set_watch_functions(nat->conn, dbusAddWatch,
dbusRemoveWatch, dbusToggleWatch, ptr, NULL);
dbus_connection_set_wakeup_main_function(nat->conn, dbusWakeup, ptr, NULL);
nat->running = true;
@@ -669,6 +678,11 @@ static void *eventLoopMain(void *ptr) {
handleWatchRemove(nat);
break;
}
case EVENT_LOOP_WAKEUP:
{
// noop
break;
}
}
}
} else {