<table border="1" cellspacing="0" cellpadding="8">
    <tr>
        <th>Issue</th>
        <td>
            <a href=https://github.com/llvm/llvm-project/issues/64566>64566</a>
        </td>
    </tr>

    <tr>
        <th>Summary</th>
        <td>
            Dead Code Elimination Regression at -O2 (trunk vs. llvmorg-16.0.6)
        </td>
    </tr>

    <tr>
      <th>Labels</th>
      <td>
            new issue
      </td>
    </tr>

    <tr>
      <th>Assignees</th>
      <td>
      </td>
    </tr>

    <tr>
      <th>Reporter</th>
      <td>
          SvenjaScherrer
      </td>
    </tr>
</table>

<pre>
    ```c
static int b, c, d;
static int e[][1] = {{}, {}, {}, {}, {}, 4, 6, 9};
static short f = 5;
static char g = 194;
static int *j = &e[7][0];
void bar18_(void);
void foo(void);
void bar20_(void);
static short(a)(short k) { return k; }
static void i();
static void h(short k) {
  if (a(0)) {
 c++;
    e[c];
    --f;
  }
  i(&d, k, g);
}
static void i(int *, int l, unsigned n) {
o:
  *j = 0;
  if (!(n >= 4294967234 && n <= 4294967234))
    bar20_();
  if (l)
    bar18_();
  {
 int p;
    if (!(n >= 4294967234 && n <= 4294967234))
 foo();
    n = 0;
    for (; n <= 5; n++) {
      int q;
      if (0 == f)
        goto o;
      if (*j)
        break;
    }
 }
}
int main() {
  char m = b = 8;
  for (; b; b--)
 h(b);
  a(m);
}
```

`clang-84e89c9e0640 (trunk) -O2` cannot eliminate the call to foo but `clang-llvmorg-16.0.6 -O2` can.

-----------------------------------------------------------------------

`clang-84e89c9e0640de4cb946d126723d2038b74e2ea0 -O2 case.c -S -emit-llvm -o case.ll`
<details ><summary>Emitted IR</summary><p>

```ll
; ModuleID = 'case.c'
source_filename = "case.c"
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"

@b = internal unnamed_addr global i32 0, align 4
@e.0 = internal unnamed_addr global i1 false, align 16

; Function Attrs: nounwind uwtable
define dso_local i32 @main() local_unnamed_addr #0 {
  store i32 8, ptr @b, align 4, !tbaa !5
  br label %1

1:                                                ; preds = %0, %16
  %2 = phi i32 [ 8, %0 ], [ %18, %16 ]
  %3 = and i32 %2, 65535
  %4 = icmp eq i32 %3, 0
  store i1 true, ptr @e.0, align 16
 br i1 %4, label %8, label %5

5: ; preds = %1
  tail call void @bar18_() #2
  %6 = load i1, ptr @e.0, align 16
  %7 = freeze i1 %6
  br i1 %7, label %8, label %9

8:                                                ; preds = %1, %5
  br label %9

9: ; preds = %8, %5
  %10 = phi i1 [ true, %8 ], [ false, %5 ]
  %11 = phi i32 [ 0, %8 ], [ 3, %5 ]
  switch i32 %11, label %12 [
    i32 3, label %16
    i32 0, label %16
  ]

12: ; preds = %9
  br i1 %10, label %16, label %13

13: ; preds = %12
  store i1 true, ptr @e.0, align 16
  tail call void @bar20_() #2
  br i1 %4, label %15, label %14

14:                                               ; preds = %13
  tail call void @bar18_() #2
  br label %15

15: ; preds = %14, %13
  tail call void @foo() #2
  br label %16

16: ; preds = %15, %9, %9, %12
  %17 = load i32, ptr @b, align 4, !tbaa !5
  %18 = add nsw i32 %17, -1
  store i32 %18, ptr @b, align 4, !tbaa !5
  %19 = icmp eq i32 %18, 0
  br i1 %19, label %20, label %1, !llvm.loop !9

20:                                               ; preds = %16
  ret i32 0
}

declare void @bar20_() local_unnamed_addr #1

declare void @bar18_() local_unnamed_addr #1

declare void @foo() local_unnamed_addr #1

attributes #0 = { nounwind uwtable "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cmov,+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
attributes #1 = { "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cmov,+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
attributes #2 = { nounwind }

!llvm.module.flags = !{!0, !1, !2, !3}
!llvm.ident = !{!4}

!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"PIE Level", i32 2}
!3 = !{i32 7, !"uwtable", i32 2}
!4 = !{!"clang version 18.0.0 (git@github.com:llvm/llvm-project.git 84e89c9e0640de4cb946d126723d2038b74e2ea0)"}
!5 = !{!6, !6, i64 0}
!6 = !{!"int", !7, i64 0}
!7 = !{!"omnipotent char", !8, i64 0}
!8 = !{!"Simple C/C++ TBAA"}
!9 = distinct !{!9, !10}
!10 = !{!"llvm.loop.mustprogress"}
```


</p></details>

-----------------------------------------------------------------------

`clang-af2ed9f794c422923414d162dd1f48d986e2d6e3 -O2 case.c -S -emit-llvm -o case.ll`
<details ><summary>Emitted IR</summary><p>

```ll
; ModuleID = 'case.c'
source_filename = "case.c"
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-unknown-linux-gnu"

@b = internal unnamed_addr global i32 0, align 4

; Function Attrs: nounwind uwtable
define dso_local i32 @main() local_unnamed_addr #0 {
  store i32 8, ptr @b, align 4, !tbaa !5
  br label %1

1: ; preds = %0, %6
  %2 = phi i32 [ 8, %0 ], [ %8, %6 ]
  %3 = and i32 %2, 65535
  %4 = icmp eq i32 %3, 0
  br i1 %4, label %6, label %5

5:                                                ; preds = %1
 tail call void @bar18_() #2
  br label %6

6: ; preds = %1, %5
  %7 = load i32, ptr @b, align 4, !tbaa !5
  %8 = add nsw i32 %7, -1
  store i32 %8, ptr @b, align 4, !tbaa !5
  %9 = icmp eq i32 %8, 0
  br i1 %9, label %10, label %1, !llvm.loop !9

10:                                               ; preds = %6
  ret i32 0
}

declare void @bar18_() local_unnamed_addr #1

attributes #0 = { nounwind uwtable "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
attributes #1 = { "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
attributes #2 = { nounwind }

!llvm.module.flags = !{!0, !1, !2, !3}
!llvm.ident = !{!4}

!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"PIE Level", i32 2}
!3 = !{i32 7, !"uwtable", i32 2}
!4 = !{!"clang version 16.0.6 (git@github.com:llvm/llvm-project.git 7cbf1a2591520c2491aa35339f227775f4d3adf6)"}
!5 = !{!6, !6, i64 0}
!6 = !{!"int", !7, i64 0}
!7 = !{!"omnipotent char", !8, i64 0}
!8 = !{!"Simple C/C++ TBAA"}
!9 = distinct !{!9, !10}
!10 = !{!"llvm.loop.mustprogress"}
```


</p></details>

-----------------------------------------------------------------------

Bisects to 72121a20cda4dc91d0ef5548f93046e71c5ec6f6
Committed by: @fhahn

</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzsGktvpDj61zgXi5JfvA45pJKONNKudjW998iAqfI0mBowSXp-_eqzgcL16O5kei6tRCUwfO-X7c9EDoPeGaVuUbxF8cONHO2-628_Pyvzh_xc7lXfq_6m6Kqvtygh_lci8oDI3WCl1SXWxuICsXtcwqVCfHsGVp45ircUxQ8Y8QeM0q37PQDRj44EXBK45PDmRNKw73qLa8c-PgWWe9njnYPRXFxSErG7P7xqLAGFU68xgduM_tzpCheyp9kTYhk8IZaH0LrrroEK2TNyiXBtAGKZBBjLvD1fEMvBBbhXduwN_oL4FoP1a0rHXiOWXeDqYPszfh4HY11jLzIjTuwaWCK2hR9fsLGLZbn2CbyMonr1vGiHJ52SCmL2BS67tYZXzZjiAQQwbGAwGpepFTaBkh3id4vgOYRkpY03EDGKWGYw4p8AQbBc5EnKuIBwI5ZgAN2HIO-Po5VL_NY2zAKaU1SfIyHq0bVg1iHw4U_S0-dfKBY7qtAtGNdd7yTy7ZFp7J6msIeJ4nQ0Fv8ZMJn1JiAAONSBH-Bv19kOdxepIGBn-EWv5JcA_ZhQy2gZgEqt1MYbvVbYlXzrDC_cNVsxXRlfuEsUHRWBailCF0KBtBdzd5kWp8f5ZdlIs4syobK8zBVJBAGBth-NK8HoPwwlBJfSmM5i1ehWG2kVtnuFS9k02HYQS1yMFi_cmua57fpdRJMN2SQrHpu18Ojn_H3XnkqJsshFUlEGeVgxwrMiFYopSUA3XMpBbUocfcaRarV16uOo8--b5ugzfl8pK3Uz-Ly_H8a2lf1XxD99arW1qsK__Q4Zyh6PEMTvD3ALtfS_ppkZb_G_u2ps1G_TssNSrxRi6TT1dGNfqqdaN8rIVk1YbMZiHsvKfqcsrqSVjfzaQUw8nopaxO9UdGApQfyOM3eBRxo-wigR7hLpeVBnQERZFpkMBslMk4joM4WMDuXbXh-aRcfXLHlKRDSaL6Z7MVGjzfga7cy4UE1XQXz-a2NVb2SDRwOmVk-yqnq8a7pCNlhzhgnMs7LRO4PFQqs25AeoKa5lM6gjA5oEOvAtfhxNaXVn8J21_YD4HTbdaF60qfD4YmXRKI9bqVobhauhe2q6clINCbKqcvf-KVAEMU7W1T_YrleONAOlDrYHHsXaQthbMGoLKeEez5RFjxtZqAYjFtO1ERBR_MY_MPzQq2qYghYTLzae_QOrVswc9LDX3tZ465UGdAxrLYzjrSPLFnoHOfLgjoc0lefBYuZ2S3HM4xWW8LEs2wNWf86YHDDJiecotv2oVr5TG3IeXvCWpo4zABfHZcFTvHZjDG488wudxcM84GdAtx2AoK0WU4gzW9mTOPqmkxXW9LvKAkXqKOpeqb_UpHqyCr1_k37DmHxtTPYzcoJOMb2YgoG4_KLvslN64EmOOUVd9szhBIJ1Vi2FCxxOkorSs8wkl3jwS_TDi7blfk4ySgMvUsdttf3hzHM5YiQhlFyBLhKnKmUXfZSfxZieMQweecCUX05a9r6iuZzky-YySPIrBUbj8FEE6oq3p-W5cfwdJRlMnkHZ0yt1L-YJ7Rvilk3tdVnBcuMW0guy4klWfnKn6ymFpqs5hbM3rh5ujvZTcVVhM7ws-e_mlIieL1DLtP5GMfmludxzIufZngf5wk6Sf5IDO7RN03UHeAhmHkZ-RkotBdArOxX1yW562gKUjezV5eK4vPjT79Af0_Ud9Mf8-wFiaW2vi9GqYdqU-OOOs90ObOFabaJG7WQTPavSdn30oiu7hw0cf0AMggRBZaaLbC8PB212UStXCH62cTiDleWX6NB31nMqxrpWfTTov9SCnk24fjsZlYdxAb1mSZSIEF4racdeDQsSYtuy7Z4Ru4fRa-YH9evQ-1HbvvrB4FYUP2B-9JqlM_fRqED2ThnV69KB50QIvUgXL354g3F2nlMnBTSXcuuan03dyN1chBQ2yYxOyzidK59Nd37kNPHQlTI2JBbn4sgKAwp75osYe4FO_Gl2Pbt3hS_WcugJcXYk_u9v9_hf6lk1K1q2pmUntOma9tO3afl12rkluUIpQodAxwj9MX5W_QA9Ds02ZOM6_p22SJCdtvux2JQdtIvgVsQe4QYp-ocq7WanLf7R5tod-ATqxKE6yWSHu-tEYLJGTs5018ZOhiLm16kzovSMqGuNPnQWkgMCfGSQXWSQnTH4rFvoZqGtv_dHTvh_27u7E9P8KlfpwWpT2iODfE7gQEqQh17MsqZt2nGwh77b9WoYAikXj3DmownEHg_-vAGxx-mc4uTg4Z88cZE1U1Vep7koBWM544KKiiasqmgtsirPEsWqRPGPE5df48TlFzsvuXoA8r7zj_n9P3b6caXdSr5znvG3d8aT_He2WkH3c6X5uXBI8Hc7nYuNzrf6nHe0ORe7nCtNTtjjnDb43-1x6M_ocd7f4rypRfnFu4yP3uKjo_joKIKOwn_ze1tHkZZFTSWLcxozUjKRUyl5zHleM5amaVyLisuqTj46il-_o9jqQZV2wLbDKaOMSkbKSoqqzGlFVB3HIqtzTkSiUlrGqkzqaSm779qpJyi-uq2FIPVe7o2H3lS3vMp5Lm_ULU1ymhDCk_Rmf1uLRHGSkiSpWFpmORWS1lSmNBMlEYTc6FtGGCcZyWkS5yzdqILHlGUpL6taiTJHgqhW6mbjHN71uxs9DKO6TUScJDduYR_cPy4xZtQLdkCIQvxw09-6WijG3YAEafRghyMXq22jbh-UrPB9Vyn8afr6DmX2u3LBhKG0rqeav9rj52GDwy_wiOU3Y9_c7q09wA4dsUfEHleV6UvypDIRe3SqDog9OlP-HwAA__8MqYNw">