aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen/MachineCopyPropagation.cpp
diff options
context:
space:
mode:
authorFangrui Song <i@maskray.me>2021-08-24 20:14:02 -0700
committerFangrui Song <i@maskray.me>2021-08-24 20:14:03 -0700
commit9ab9a9595b1bbcf360de619f7c9c17f4340caa52 (patch)
tree1aa4849cd6c56c63a3932a60f88668ef52648e62 /llvm/lib/CodeGen/MachineCopyPropagation.cpp
parentcd4d6d718b2e51ed830a28d01d765da2a220afd3 (diff)
downloadllvm-9ab9a9595b1bbcf360de619f7c9c17f4340caa52.zip
llvm-9ab9a9595b1bbcf360de619f7c9c17f4340caa52.tar.gz
llvm-9ab9a9595b1bbcf360de619f7c9c17f4340caa52.tar.bz2
[InstrProfiling] Keep profd non-private for non-renamable comdat functions
The NS==0 condition used by D103717 missed a corner case: if the current copy does not have a hash suffix (e.g. weak_odr), a copy with value profiling (with a different CFG) may exist. This is super rare, but is possible with pre-inlining PGO instrumentation (which can make a weak_odr function inlines its callees differently, sometimes with value profiling while sometimes without). If the current copy with private profd is prevailing, the non-prevailing copy may get an undefined symbol if a caller inlining the non-prevailing function references its profd. If the other copy with non-private profd is prevailing, the current copy may cause a "relocation to discarded section" linker error. The fix is straightforward: just keep non-private profd in such a `DataReferencedByCode` case. With this change, a stage 2 (`-DLLVM_TARGETS_TO_BUILD=X86 -DLLVM_BUILD_INSTRUMENTED=IR`) clang is 0.08% larger (172431496/172286720-1). `stat -c %s **/*.o | awk '{s+=$1}END{print s}' is 0.026% larger. The majority of D103717's benefits remains. Reviewed By: xur Differential Revision: https://reviews.llvm.org/D108432
Diffstat (limited to 'llvm/lib/CodeGen/MachineCopyPropagation.cpp')
0 files changed, 0 insertions, 0 deletions