[clang] [lld] [llvm] [LTO] enable `ObjCARCContractPass` only on optimized build (PR #101114)

Mikael Holmén via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 15 04:11:49 PDT 2024


mikaelholmen wrote:

> @mikaelholmen I can't reproduce this on commit [e40915b](https://github.com/llvm/llvm-project/commit/e40915b7407eda4b370658da5c9606e310b55d19) with `-DLLVM_USE_SANITIZER=Undefined`. Kindly let me know how to reproduce this.
> 
> Looking from the code, I suspect that it's caused by uninitialized bool (
> 
> https://github.com/llvm/llvm-project/blob/539bf499615dbbfe98deaac1021f351eaad330ea/llvm/lib/Transforms/ObjCARC/ObjCARCContract.cpp#L553
> )

I think the problem is that the
```
Changed = CFGChanged = false; 
```
initialization done in
```
bool ObjCARCContract::run(Function &F, AAResults *A, DominatorTree *D) {
  if (!Run)
    return false;

  if (!EnableARCOpts)
    return false;

  Changed = CFGChanged = false;
```
is skipped if we bail out early due to "!Run" or "!EnableARCOpts".
But the pass always asks
```
  bool CFGChanged = OCAC.hasCFGChanged();
```
afterwards anyway.

https://github.com/llvm/llvm-project/pull/101114


More information about the llvm-commits mailing list