summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosh Gao <jmgao@google.com>2017-04-14 22:09:45 +0200
committerandroid-build-merger <android-build-merger@google.com>2017-04-14 22:09:45 +0200
commit572b7ba1bcb8d315b80dd58564a6a4800a59b953 (patch)
tree88f2dc925ba46e43d26486d1ff9ea22d6303e811
parentMerge "Protect filename_cache with lock in ota fault" am: 1b28a27c33 (diff)
parentMerge "minadbd: switch adb_thread_create to std::thread." (diff)
downloadandroid_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar.gz
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar.bz2
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar.lz
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar.xz
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.tar.zst
android_bootable_recovery-572b7ba1bcb8d315b80dd58564a6a4800a59b953.zip
-rw-r--r--minadbd/minadbd_services.cpp30
1 files changed, 3 insertions, 27 deletions
diff --git a/minadbd/minadbd_services.cpp b/minadbd/minadbd_services.cpp
index 426d982eb..a6aa321ca 100644
--- a/minadbd/minadbd_services.cpp
+++ b/minadbd/minadbd_services.cpp
@@ -21,25 +21,13 @@
#include <string.h>
#include <unistd.h>
+#include <thread>
+
#include "adb.h"
#include "fdevent.h"
#include "fuse_adb_provider.h"
#include "sysdeps.h"
-typedef struct stinfo stinfo;
-
-struct stinfo {
- void (*func)(int fd, void *cookie);
- int fd;
- void *cookie;
-};
-
-void service_bootstrap_func(void* x) {
- stinfo* sti = reinterpret_cast<stinfo*>(x);
- sti->func(sti->fd, sti->cookie);
- free(sti);
-}
-
static void sideload_host_service(int sfd, void* data) {
char* args = reinterpret_cast<char*>(data);
int file_size;
@@ -66,19 +54,7 @@ static int create_service_thread(void (*func)(int, void *), void *cookie) {
return -1;
}
- stinfo* sti = static_cast<stinfo*>(malloc(sizeof(stinfo)));
- if(sti == 0) fatal("cannot allocate stinfo");
- sti->func = func;
- sti->cookie = cookie;
- sti->fd = s[1];
-
- if (!adb_thread_create(service_bootstrap_func, sti)) {
- free(sti);
- adb_close(s[0]);
- adb_close(s[1]);
- printf("cannot create service thread\n");
- return -1;
- }
+ std::thread([s, func, cookie]() { func(s[1], cookie); }).detach();
VLOG(SERVICES) << "service thread started, " << s[0] << ":" << s[1];
return s[0];