• R/O
  • HTTP
  • SSH
  • HTTPS

Commit

Tags
No Tags

Frequently used words (click to add to your profile)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

system/corennnnn


Commit MetaInfo

Revisionf0738997eac7c562371a05ef7f21ba95e0553ad4 (tree)
Time2016-09-07 15:06:40
AuthorChih-Wei Huang <cwhuang@linu...>
CommiterChih-Wei Huang

Log Message

Revert "adb: sockets: fix race condition between input_thread and fdevent callback"

This reverts commit 3e872c4ce7d83fee2673694644559f6fa9bdcbe0.

Change Summary

Incremental Difference

--- a/adb/adb.h
+++ b/adb/adb.h
@@ -85,13 +85,6 @@ struct asocket {
8585 ** but packets are still queued for delivery
8686 */
8787 int closing;
88- /* flag: set when this socket is running.
89- */
90- int running;
91- /* flag: force close this socket. if this socket is running, other
92- ** thread set this flag to request close it.
93- */
94- int force_close;
9588
9689 /* flag: quit adbd when both ends close the
9790 ** local service socket
--- a/adb/sockets.cpp
+++ b/adb/sockets.cpp
@@ -53,13 +53,16 @@ static asocket local_socket_closing_list = {
5353 .prev = &local_socket_closing_list,
5454 };
5555
56-static asocket *
57-find_socket_in_list(asocket *list, unsigned local_id, unsigned peer_id)
56+// Parse the global list of sockets to find one with id |local_id|.
57+// If |peer_id| is not 0, also check that it is connected to a peer
58+// with id |peer_id|. Returns an asocket handle on success, NULL on failure.
59+asocket *find_local_socket(unsigned local_id, unsigned peer_id)
5860 {
5961 asocket *s;
6062 asocket *result = NULL;
6163
62- for (s = list->next; s != list; s = s->next) {
64+ adb_mutex_lock(&socket_list_lock);
65+ for (s = local_socket_list.next; s != &local_socket_list; s = s->next) {
6366 if (s->id != local_id)
6467 continue;
6568 if (peer_id == 0 || (s->peer && s->peer->id == peer_id)) {
@@ -67,21 +70,8 @@ find_socket_in_list(asocket *list, unsigned local_id, unsigned peer_id)
6770 }
6871 break;
6972 }
70-
71- return result;
72-}
73-
74-
75-// Parse the global list of sockets to find one with id |local_id|.
76-// If |peer_id| is not 0, also check that it is connected to a peer
77-// with id |peer_id|. Returns an asocket handle on success, NULL on failure.
78-asocket *find_local_socket(unsigned local_id, unsigned peer_id)
79-{
80- asocket *result = NULL;
81-
82- adb_mutex_lock(&socket_list_lock);
83- result = find_socket_in_list(&local_socket_list, local_id, peer_id);
8473 adb_mutex_unlock(&socket_list_lock);
74+
8575 return result;
8676 }
8777
@@ -123,14 +113,10 @@ void remove_socket(asocket *s)
123113 }
124114 }
125115
126-// Note: after return, all sockets refer to transport @t should be closed.
127-// (Because the atransport is going to removed.)
128-// force_close && running flag are to implement this.
129116 void close_all_sockets(atransport *t)
130117 {
131118 asocket *s;
132119
133- D("close all sockets of transport %p\n", t);
134120 /* this is a little gross, but since s->close() *will* modify
135121 ** the list out from under you, your options are limited.
136122 */
@@ -138,17 +124,7 @@ void close_all_sockets(atransport *t)
138124 restart:
139125 for(s = local_socket_list.next; s != &local_socket_list; s = s->next){
140126 if(s->transport == t || (s->peer && s->peer->transport == t)) {
141- // set force_close flag since transport is going to be removed.
142- // we need ensure the socket is closed after we return.
143- s->force_close = 1;
144- // avoid race condition with pending fdevent
145- if (s->running) {
146- // unlock to give a chance to close socket after running
147- adb_mutex_unlock(&socket_list_lock);
148- adb_sleep_ms(10); // sleep to relax cpu
149- adb_mutex_lock(&socket_list_lock);
150- } else
151- local_socket_close_locked(s);
127+ local_socket_close_locked(s);
152128 goto restart;
153129 }
154130 }
@@ -217,18 +193,8 @@ static void local_socket_ready(asocket *s)
217193
218194 static void local_socket_close(asocket *s)
219195 {
220- unsigned local_id = s->id;
221- unsigned peer_id = s->peer ? s->peer->id : 0;
222- asocket *sk;
223-
224196 adb_mutex_lock(&socket_list_lock);
225- // we may race with close_all_sockets (called by input-thread),
226- // so need to check if socket already destoried.
227- sk = find_socket_in_list(&local_socket_list, local_id, peer_id);
228- if (!sk)
229- sk = find_socket_in_list(&local_socket_closing_list, local_id, peer_id);
230- if (sk)
231- local_socket_close_locked(s);
197+ local_socket_close_locked(s);
232198 adb_mutex_unlock(&socket_list_lock);
233199 }
234200
@@ -284,10 +250,9 @@ static void local_socket_close_locked(asocket *s)
284250 }
285251
286252 /* If we are already closing, or if there are no
287- ** pending packets, or need force close it, then
288- ** destroy immediately.
253+ ** pending packets, destroy immediately
289254 */
290- if (s->closing || s->force_close || s->pkt_first == NULL) {
255+ if (s->closing || s->pkt_first == NULL) {
291256 int id = s->id;
292257 local_socket_destroy(s);
293258 D("LS(%d): closed\n", id);
@@ -307,12 +272,8 @@ static void local_socket_close_locked(asocket *s)
307272 static void local_socket_event_func(int fd, unsigned ev, void* _s)
308273 {
309274 asocket* s = reinterpret_cast<asocket*>(_s);
310- s->running = 1;
311275 D("LS(%d): event_func(fd=%d(==%d), ev=%04x)\n", s->id, s->fd, fd, ev);
312276
313- if (s->force_close)
314- goto out;
315-
316277 /* put the FDE_WRITE processing before the FDE_READ
317278 ** in order to simplify the code.
318279 */
@@ -326,7 +287,7 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
326287 ** be processed in the next iteration loop
327288 */
328289 if (errno == EAGAIN) {
329- goto out;
290+ return;
330291 }
331292 } else if (r > 0) {
332293 p->ptr += r;
@@ -335,7 +296,6 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
335296 }
336297
337298 D(" closing after write because r=%d and errno is %d\n", r, errno);
338- s->running = 0;
339299 s->close(s);
340300 return;
341301 }
@@ -354,7 +314,6 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
354314 */
355315 if (s->closing) {
356316 D(" closing because 'closing' is set after write\n");
357- s->running = 0;
358317 s->close(s);
359318 return;
360319 }
@@ -413,7 +372,7 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
413372 ** this handler function will be called again
414373 ** to process FDE_WRITE events.
415374 */
416- goto out;
375+ return;
417376 }
418377
419378 if (r > 0) {
@@ -428,9 +387,7 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
428387 if ((s->fde.force_eof && !r) || is_eof) {
429388 D(" closing because is_eof=%d r=%d s->fde.force_eof=%d\n",
430389 is_eof, r, s->fde.force_eof);
431- s->running = 0;
432390 s->close(s);
433- return;
434391 }
435392 }
436393
@@ -441,13 +398,7 @@ static void local_socket_event_func(int fd, unsigned ev, void* _s)
441398 */
442399 D("LS(%d): FDE_ERROR (fd=%d)\n", s->id, s->fd);
443400
444- goto out;
445- }
446-out:
447- s->running = 0;
448- if (s->force_close) {
449- D("LS(%d): force closing (fd=%d)\n", s->id, s->fd);
450- s->close(s);
401+ return;
451402 }
452403 }
453404
@@ -455,7 +406,6 @@ asocket *create_local_socket(int fd)
455406 {
456407 asocket *s = reinterpret_cast<asocket*>(calloc(1, sizeof(asocket)));
457408 if (s == NULL) fatal("cannot allocate socket");
458- memset(s, 0, sizeof(asocket));
459409 s->fd = fd;
460410 s->enqueue = local_socket_enqueue;
461411 s->ready = local_socket_ready;
@@ -601,7 +551,6 @@ asocket *create_remote_socket(unsigned id, atransport *t)
601551 adisconnect* dis = &reinterpret_cast<aremotesocket*>(s)->disconnect;
602552
603553 if (s == NULL) fatal("cannot allocate socket");
604- memset(s, 0, sizeof(asocket));
605554 s->id = id;
606555 s->enqueue = remote_socket_enqueue;
607556 s->ready = remote_socket_ready;
@@ -934,7 +883,6 @@ static asocket *create_smart_socket(void)
934883 D("Creating smart socket \n");
935884 asocket *s = reinterpret_cast<asocket*>(calloc(1, sizeof(asocket)));
936885 if (s == NULL) fatal("cannot allocate socket");
937- memset(s, 0, sizeof(asocket));
938886 s->enqueue = smart_socket_enqueue;
939887 s->ready = smart_socket_ready;
940888 s->shutdown = NULL;