[all-commits] [llvm/llvm-project] 29fada: [EarlyCSE] Don't eagerly optimize MemoryUses
Nikita Popov via All-commits
all-commits at lists.llvm.org
Wed Mar 23 08:47:51 PDT 2022
Branch: refs/heads/main
Home: https://github.com/llvm/llvm-project
Commit: 29fada4a3d3db309f11f7fa7a0c61cd4021e9947
https://github.com/llvm/llvm-project/commit/29fada4a3d3db309f11f7fa7a0c61cd4021e9947
Author: Nikita Popov <npopov at redhat.com>
Date: 2022-03-23 (Wed, 23 Mar 2022)
Changed paths:
M llvm/lib/Transforms/Scalar/EarlyCSE.cpp
Log Message:
-----------
[EarlyCSE] Don't eagerly optimize MemoryUses
EarlyCSE currently optimizes all MemoryUses upfront. However,
EarlyCSE only actually queries the clobbering memory access for
a subset of uses, namely those where a CSE candidate has already
been identified. Delaying use optimization to the clobber query
improves compile-time in practice.
This change is not NFC because EarlyCSE has a limit on the number
of clobber queries (EarlyCSEMssaOptCap), in which case it falls
back to the defining access. The defining access for uses will now
no longer coincide with the optimized access.
If there are performance regressions from this change, we should
be able to address them by raising this limit.
Differential Revision: https://reviews.llvm.org/D121987
More information about the All-commits
mailing list