diff options
author | Josh Gao <jmgao@google.com> | 2017-04-14 22:22:48 +0200 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2017-04-14 22:22:48 +0200 |
commit | 7fa75c551e127ea91b6a43a5584d46f0254f0879 (patch) | |
tree | 101d8b06f688de68eaa5f726fb4e8f70f265fe0c | |
parent | Add the missing LOCAL_CFLAGS for librecovery. am: 25dbe1717e (diff) | |
parent | Merge "minadbd: switch adb_thread_create to std::thread." am: d3d91e5595 am: 0836159ce1 (diff) | |
download | android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar.gz android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar.bz2 android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar.lz android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar.xz android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.tar.zst android_bootable_recovery-7fa75c551e127ea91b6a43a5584d46f0254f0879.zip |
Diffstat (limited to '')
-rw-r--r-- | minadbd/minadbd_services.cpp | 30 |
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]; |