summaryrefslogtreecommitdiff
path: root/libcutils/socket_local_server_unix.cpp
diff options
context:
space:
mode:
authorChristopher Ferris <cferris@google.com>2015-05-28 16:10:33 -0700
committerChristopher Ferris <cferris@google.com>2015-06-01 13:51:51 -0700
commit2d09171758b7d98c77f27e439a4caf35dd84c311 (patch)
tree817d634ba99dec2616cdefbe4bee442cedc55439 /libcutils/socket_local_server_unix.cpp
parenta684d9dad58eaac4d4833321ae92e7327057f18b (diff)
Modify the code to avoid potential deadlocks.
If the signal to dump a thread is never delivered, then it's possible for a deadlock. The signal handler is responsible for unlocking and deleting the ThreadEntry created for the pid/tid combination. This means if the signal is lost, the ThreadEntry gets stuck locked and never deleted. If a second attempt to get a backtrace of this thread occurs, there is a deadlock. Also, decrease the timeout from 10 seconds to 5 seconds. The original 10 seconds was because the unwind was actually done in the signal handler. Now the signal handler does nothing but copy the ucontext structure and let the caller do the unwind. Bug: 21086132 Change-Id: Idc735dbf6147ec879d35bd4f034c5d227e26a98d
Diffstat (limited to 'libcutils/socket_local_server_unix.cpp')
0 files changed, 0 insertions, 0 deletions