Skip to content

Commit

Permalink
JIT: Fix invalid memory barrier removal optimization
Browse files Browse the repository at this point in the history
The ARM32/ARM64 backends have an optimization where they optimize out
the latter of two subsequent memory barriers if no memory store/load has
been seen between them. This optimization should not be allowed to
remove memory barriers when a call has been seen.

Fix #91732
  • Loading branch information
jakobbotsch authored and github-actions committed Sep 11, 2023
1 parent 49b266d commit 181b78c
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 0 deletions.
1 change: 1 addition & 0 deletions src/coreclr/jit/emitarm.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4850,6 +4850,7 @@ void emitter::emitIns_Call(EmitCallType callType,

dispIns(id);
appendToCurIG(id);
emitLastMemBarrier = nullptr; // Cannot optimize away future memory barriers
}

/*****************************************************************************
Expand Down
1 change: 1 addition & 0 deletions src/coreclr/jit/emitarm64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8886,6 +8886,7 @@ void emitter::emitIns_Call(EmitCallType callType,

dispIns(id);
appendToCurIG(id);
emitLastMemBarrier = nullptr; // Cannot optimize away future memory barriers
}

/*****************************************************************************
Expand Down

0 comments on commit 181b78c

Please sign in to comment.