aboutsummaryrefslogtreecommitdiffstats
path: root/erts/emulator/beam/erl_process_lock.h
diff options
context:
space:
mode:
authorBjörn Gustavsson <[email protected]>2017-05-29 14:41:14 +0200
committerBjörn Gustavsson <[email protected]>2017-05-29 14:50:39 +0200
commit23f132d9ab776ab94c29f1faed76c9fde8f4a73f (patch)
tree321f24cb0a753e15927460f784ea4b28042a02db /erts/emulator/beam/erl_process_lock.h
parent6ebe1a85f0ae97b383a9c1fa838b4e9f9a808e21 (diff)
downloadotp-23f132d9ab776ab94c29f1faed76c9fde8f4a73f.tar.gz
otp-23f132d9ab776ab94c29f1faed76c9fde8f4a73f.tar.bz2
otp-23f132d9ab776ab94c29f1faed76c9fde8f4a73f.zip
Make sure that asynchronous replies are not lost
If an synchronous GC was requested by calling: erlang:garbage_collect(Pid, [{async,Ref}]) the reply message could in certain circumstances be lost. The problem is in cleanup_sys_tasks() in erl_process.c. If there were at least one dirty task, only the first dirty task would be cleaned up. All other systems tasks would not be cleaned up (that is, no replies would be sent to other processes waiting for the tasks to finish).
Diffstat (limited to 'erts/emulator/beam/erl_process_lock.h')
0 files changed, 0 insertions, 0 deletions