Clean up CLOEXEC in debuggerd.
Change-Id: I1cd75f6a8f98e99f4a4fedfc706103ce34035765
(cherry picked from commit 17ba68d0cd
)
This commit is contained in:
parent
aa41756851
commit
1a69e2811e
1 changed files with 6 additions and 9 deletions
|
@ -710,10 +710,9 @@ static int do_server() {
|
|||
act.sa_flags = SA_NOCLDWAIT;
|
||||
sigaction(SIGCHLD, &act, 0);
|
||||
|
||||
int s = socket_local_server(SOCKET_NAME, ANDROID_SOCKET_NAMESPACE_ABSTRACT, SOCK_STREAM);
|
||||
if (s < 0)
|
||||
return 1;
|
||||
fcntl(s, F_SETFD, FD_CLOEXEC);
|
||||
int s = socket_local_server(SOCKET_NAME, ANDROID_SOCKET_NAMESPACE_ABSTRACT,
|
||||
SOCK_STREAM | SOCK_CLOEXEC);
|
||||
if (s == -1) return 1;
|
||||
|
||||
ALOGI("debuggerd: starting\n");
|
||||
|
||||
|
@ -723,14 +722,12 @@ static int do_server() {
|
|||
socklen_t alen = sizeof(ss);
|
||||
|
||||
ALOGV("waiting for connection\n");
|
||||
int fd = accept(s, addrp, &alen);
|
||||
if (fd < 0) {
|
||||
ALOGV("accept failed: %s\n", strerror(errno));
|
||||
int fd = accept4(s, addrp, &alen, SOCK_CLOEXEC);
|
||||
if (fd == -1) {
|
||||
ALOGE("accept failed: %s\n", strerror(errno));
|
||||
continue;
|
||||
}
|
||||
|
||||
fcntl(fd, F_SETFD, FD_CLOEXEC);
|
||||
|
||||
handle_request(fd);
|
||||
}
|
||||
return 0;
|
||||
|
|
Loading…
Reference in a new issue