summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRickard Green <rickard@erlang.org>2023-01-30 14:22:38 +0100
committerRickard Green <rickard@erlang.org>2023-01-30 14:22:38 +0100
commit9a375419bf616b90b84bb0328ea0559105f70a4e (patch)
treebba6d97a6714c5d3bef1fa3cda7325cea59d8b24
parent3002f55f409f44122d3a45ac53bfd453e9aa2cb2 (diff)
downloaderlang-9a375419bf616b90b84bb0328ea0559105f70a4e.tar.gz
[erts] Fix process_info(Pid, status)
-rw-r--r--erts/emulator/beam/erl_bif_info.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/erts/emulator/beam/erl_bif_info.c b/erts/emulator/beam/erl_bif_info.c
index 41c0fb82fa..c58b9a53a1 100644
--- a/erts/emulator/beam/erl_bif_info.c
+++ b/erts/emulator/beam/erl_bif_info.c
@@ -1434,10 +1434,15 @@ process_info_aux(Process *c_p,
break;
case ERTS_PI_IX_STATUS: {
- erts_aint32_t state = erts_atomic32_read_nob(&rp->state);
+ erts_aint32_t state;
+ if (!rp_locks)
+ state = erts_atomic32_read_mb(&rp->state);
+ else
+ state = erts_atomic32_read_nob(&rp->state);
res = erts_process_state2status(state);
- if (res == am_running && (state & ERTS_PSFLG_RUNNING_SYS)) {
- ASSERT(c_p == rp);
+ if (res == am_running
+ && c_p == rp
+ && (state & ERTS_PSFLG_RUNNING_SYS)) {
ASSERT(flags & ERTS_PI_FLAG_REQUEST_FOR_OTHER);
if (!(state & (ERTS_PSFLG_SYS_TASKS
| ERTS_PSFLG_ACTIVE