Skip to content

Commit aedaa07

Browse files
stephan-yichao-zhaoteresajohnson
authored andcommitted
Reduce dropTriviallyDeadConstantArrays cumulative time percentage from 17% to 4%
The history of dropTriviallyDeadConstantArrays is like this. Because the appending linkage uses too much memory (http://lists.llvm.org/pipermail/llvm-commits/Week-of-Mon-20150105/251381.html), dropTriviallyDeadConstantArrays was introduced (https://reviews.llvm.org/rG81f385b0c6ea37dd7195a65be162c75bbdef29d2) to release unused constant arrays. Recently, dropTriviallyDeadConstantArrays was improved (https://reviews.llvm.org/rG81f385b0c6ea37dd7195a65be162c75bbdef29d2) to reduce its quadratic cost. Our recent LTO profiling shows that when a target is large, 15-20% of time cost is from the SetVector::insert called by dropTriviallyDeadConstantArrays. A large application has hundreds or thousands of modules; each module calls dropTriviallyDeadConstantArrays once for cleaning up tens of thousands of ConstantArrays a module has. In those ConstantArrays, usually around 5 can be deleted; a very very few deleted ConstantArrays reference other ConstantArrays: less than 10 out of millions. Given this, the cost of SetVector::insert is mainly from the construction of WorkList from ArrayConstants. This motivated the fix that iterates ArrayConstants directly, and uses WorkList only when necessary. Our evaluation shows that 1) The cumulative time percentage of dropTriviallyDeadConstantArrays is reduced from 15-17% to 4-6%. 2) For targets with LTO time > 20min, the time reduction is about 20%. 3) No observable performance impact for build without using LTO. {F12506218} {F12506221} Reviewed By: mehdi_amini, tejohnson, jdoerfert Differential Revision: https://reviews.llvm.org/D85379
1 parent 3110e7b commit aedaa07

File tree

1 file changed

+9
-2
lines changed

1 file changed

+9
-2
lines changed

llvm/lib/IR/LLVMContextImpl.cpp

Lines changed: 9 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -129,8 +129,15 @@ LLVMContextImpl::~LLVMContextImpl() {
129129
}
130130

131131
void LLVMContextImpl::dropTriviallyDeadConstantArrays() {
132-
SmallSetVector<ConstantArray *, 4> WorkList(ArrayConstants.begin(),
133-
ArrayConstants.end());
132+
SmallSetVector<ConstantArray *, 4> WorkList;
133+
134+
// When ArrayConstants are of substantial size and only a few in them are
135+
// dead, starting WorkList with all elements of ArrayConstants can be
136+
// wasteful. Instead, starting WorkList with only elements that have empty
137+
// uses.
138+
for (ConstantArray *C : ArrayConstants)
139+
if (C->use_empty())
140+
WorkList.insert(C);
134141

135142
while (!WorkList.empty()) {
136143
ConstantArray *C = WorkList.pop_back_val();

0 commit comments

Comments
 (0)