diff options
author | Lukas Larsson <[email protected]> | 2016-04-26 15:56:21 +0200 |
---|---|---|
committer | Lukas Larsson <[email protected]> | 2016-04-26 15:59:23 +0200 |
commit | c922f2729dcf2bc5ef571f9d77efea75029469de (patch) | |
tree | 77415645134d927b064bf1c6f5dc3aa7b356a490 /erts/emulator/beam/bif.c | |
parent | 76cf34c49631845a21ffdd6d317d7fc944ab9b7b (diff) | |
download | otp-c922f2729dcf2bc5ef571f9d77efea75029469de.tar.gz otp-c922f2729dcf2bc5ef571f9d77efea75029469de.tar.bz2 otp-c922f2729dcf2bc5ef571f9d77efea75029469de.zip |
Yield after setting sensitive for save_calls
Diffstat (limited to 'erts/emulator/beam/bif.c')
-rw-r--r-- | erts/emulator/beam/bif.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/erts/emulator/beam/bif.c b/erts/emulator/beam/bif.c index ed5b2983dd..c38d031ab8 100644 --- a/erts/emulator/beam/bif.c +++ b/erts/emulator/beam/bif.c @@ -1736,7 +1736,9 @@ BIF_RETTYPE process_flag_2(BIF_ALIST_2) ERTS_TRACE_FLAGS(BIF_P) &= ~F_SENSITIVE; } erts_smp_proc_unlock(BIF_P, ERTS_PROC_LOCKS_ALL_MINOR); - BIF_RET(old_value); + /* make sure to bump all reds so that we get + rescheduled immediately so setting takes effect */ + BIF_RET2(old_value, CONTEXT_REDS); } else if (BIF_ARG_1 == am_monitor_nodes) { /* |