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

    <tr>
        <th>Summary</th>
        <td>
            opt generates wrong code with "-passes=globalopt,bdce,flattencfg"
        </td>
    </tr>

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

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

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

<pre>
    *******************************************************************************
OS and Platform:
Ubuntu 20.04.4 LTS
*******************************************************************************
clang version 17.0.4
Target: x86_64-unknown-linux-gnu
Thread model: posix
InstalledDir: /home/cuisk/ctc/llvm-releases/llvm-17.0.4/build/bin
Found candidate GCC installation: /usr/lib/gcc/x86_64-linux-gnu/8
Found candidate GCC installation: /usr/lib/gcc/x86_64-linux-gnu/9
Selected GCC installation: /usr/lib/gcc/x86_64-linux-gnu/9
Candidate multilib: .;@m64
Candidate multilib: 32;@m32
Candidate multilib: x32;@mx32
Selected multilib: .;@m64
*******************************************************************************
Command Lines:
```shell
opt -passes=globalopt,bdce,flattencfg b.ll -o a.opt.bc
clang a.opt.bc -o a.out
 ./a.out
2
opt b.ll -o a0.opt.bc
clang a0.opt.bc -o a0.out
./a0.out 
1
```
*******************************************************************************
Source Code:
```llvm
; ModuleID = 'a.c'
source_filename = "a.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"

@.str = private unnamed_addr constant [4 x i8] c"%d\0A\00", align 1
@a = dso_local global i32 0, align 4
@c = dso_local global i32 0, align 4
@b = internal global i16 0, align 2

; Function Attrs: nounwind uwtable
define dso_local i32 @main() #0 {
  %1 = call i32 @e()
  %2 = load i32, ptr @a, align 4, !tbaa !5
  %3 = call i32 (ptr, ...) @printf(ptr noundef @.str, i32 noundef %2)
  ret i32 0
}

declare i32 @printf(ptr noundef, ...) #1

; Function Attrs: nounwind uwtable
define internal i32 @e() #0 {
  %1 = alloca i32, align 4
  %2 = alloca i16, align 2
  call void @llvm.lifetime.start.p0(i64 2, ptr %2) #3
  store i16 4, ptr %2, align 2, !tbaa !9
  %3 = load i16, ptr %2, align 2, !tbaa !9
  %4 = zext i16 %3 to i32
  %5 = call i32 @d(i8 noundef signext 0, i32 noundef %4)
  call void @llvm.lifetime.end.p0(i64 2, ptr %2) #3
  %6 = load i32, ptr %1, align 4
  ret i32 %6
}

; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
declare void @llvm.lifetime.start.p0(i64 immarg, ptr nocapture) #2

; Function Attrs: nounwind uwtable
define internal i32 @d(i8 noundef signext %0, i32 noundef %1) #0 {
  %3 = alloca i32, align 4
  %4 = alloca i8, align 1
  %5 = alloca i32, align 4
  %6 = alloca i32, align 4
  store i8 %0, ptr %4, align 1, !tbaa !11
  store i32 %1, ptr %5, align 4, !tbaa !5
  call void @llvm.lifetime.start.p0(i64 4, ptr %6) #3
  store i32 0, ptr %6, align 4, !tbaa !5
  %7 = load i16, ptr @b, align 2, !tbaa !9
 %8 = zext i16 %7 to i32
  %9 = load i32, ptr %5, align 4, !tbaa !5
 %10 = and i32 %9, 0
  %11 = icmp ne i32 %10, 0
  br i1 %11, label %13, label %12

12:                                               ; preds = %2
  br label %13

13: ; preds = %12, %2
  %14 = phi i1 [ true, %2 ], [ true, %12 ]
  %15 = zext i1 %14 to i32
  %16 = and i32 %8, %15
  %17 = icmp ne i32 %16, 0
  br i1 %17, label %18, label %19

18: ; preds = %13
  br label %19

19: ; preds = %18, %13
  %20 = phi i1 [ false, %13 ], [ true, %18 ]
  %21 = zext i1 %20 to i32
  %22 = trunc i32 %21 to i16
  %23 = call signext i16 @safe_add_func_int16_t_s_s(i16 noundef signext %22, i16 noundef signext 1)
  %24 = load i32, ptr @c, align 4, !tbaa !5
  %25 = trunc i32 %24 to i16
  %26 = call signext i16 @safe_add_func_int16_t_s_s(i16 noundef signext %23, i16 noundef signext %25)
  %27 = load i32, ptr %6, align 4, !tbaa !5
  %28 = call zeroext i16 @safe_rshift_func_uint16_t_u_u(i16 noundef zeroext %26, i32 noundef %27)
  %29 = zext i16 %28 to i32
  store i32 %29, ptr @a, align 4, !tbaa !5
  call void @llvm.lifetime.end.p0(i64 4, ptr %6) #3
  %30 = load i32, ptr %3, align 4
  ret i32 %30
}

; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
declare void @llvm.lifetime.end.p0(i64 immarg, ptr nocapture) #2

; Function Attrs: nounwind uwtable
define internal zeroext i16 @safe_rshift_func_uint16_t_u_u(i16 noundef zeroext %0, i32 noundef %1) #0 {
  %3 = alloca i16, align 2
  %4 = alloca i32, align 4
  store i16 %0, ptr %3, align 2, !tbaa !9
  store i32 %1, ptr %4, align 4, !tbaa !5
  %5 = load i32, ptr %4, align 4, !tbaa !5
  %6 = icmp uge i32 %5, 32
  br i1 %6, label %7, label %10

7: ; preds = %2
  %8 = load i16, ptr %3, align 2, !tbaa !9
  %9 = zext i16 %8 to i32
  br label %15

10: ; preds = %2
  %11 = load i16, ptr %3, align 2, !tbaa !9
  %12 = zext i16 %11 to i32
  %13 = load i32, ptr %4, align 4, !tbaa !5
  %14 = ashr i32 %12, %13
  br label %15

15: ; preds = %10, %7
  %16 = phi i32 [ %9, %7 ], [ %14, %10 ]
  %17 = trunc i32 %16 to i16
  ret i16 %17
}

; Function Attrs: nounwind uwtable
define internal signext i16 @safe_add_func_int16_t_s_s(i16 noundef signext %0, i16 noundef signext %1) #0 {
  %3 = alloca i16, align 2
  %4 = alloca i16, align 2
 store i16 %0, ptr %3, align 2, !tbaa !9
  store i16 %1, ptr %4, align 2, !tbaa !9
  %5 = load i16, ptr %3, align 2, !tbaa !9
  %6 = sext i16 %5 to i32
  %7 = load i16, ptr %4, align 2, !tbaa !9
  %8 = sext i16 %7 to i32
  %9 = add nsw i32 %6, %8
  %10 = trunc i32 %9 to i16
  ret i16 %10
}

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 = { nocallback nofree nosync nounwind willreturn memory(argmem: readwrite) }
attributes #3 = { 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 17.0.4"}
!5 = !{!6, !6, i64 0}
!6 = !{!"int", !7, i64 0}
!7 = !{!"omnipotent char", !8, i64 0}
!8 = !{!"Simple C/C++ TBAA"}
!9 = !{!10, !10, i64 0}
!10 = !{!"short", !7, i64 0}
!11 = !{!7, !7, i64 0}
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzsWltv2zry_zTMC2GDpK5-yEPs_P1HgS72AOk-B7RE2dxSpEBRidtPvyApybrZdU-DngXOFoUtiTPDmd9c6YjWNT9Kxh5BtAXR8wNtzEnpxy39rr5SHDwcVP7tEZCnv9F_9AzQ0z9fIJU5_ENQUyhdgqB9_q9DI00DCVqjcB3Cz19e_PO_Xu3fDlEmqDzCN6ZrriTEyRqtQ7_yheojMyB4guc0fo3DVSO_SvUuV4LL5rw6yqalO2lGc1iqnAlLXaman_3SJ1kbKgTLn7m2S4DsT6pkgOyzhtdf7bfJANkL8VauNBOM1qzu7ltdyP7QcJHbby692L1qZA4zKnOeU8Pg_-92kPutqOFKtls1tbay-AGQ_TGz-7SGXAwg-_TjRW68yBcmWGZY_hGydr1iZSMMt0zBE1yDYAtCVMbhLaqAtGQBuUV27unOHWFvwa1N__o4_u05s1NlaevKZy5Z3RcVECP_vz4xIfwzVRm4qmhtwzp4Pgp1oEJVBpDdIc8YILtCUGOYzIojPKyFgCsF6VpVZn3IhvnZPWvXG-MX4RqQ_eCeXHbtpaElcWgoD10EOHnuHvoHeGLb39bnL6rRGYM7lbO5x229ah8FW_gPlTeCfXqGIHiGgCR0nQGS-PXaiXktuGCSlqwlIY6k9Z5xdRfm1FBBvzlXeCK2sh2MrSqSIBA82Xx9Coi9xeNbexWH7mPFu4sitUyYpCuZ2ou444nD1Qsm6XR_o3klegWvtoCOq_0M0bo22nFVmr_ZItNIa2n-SvNcw0zZQigNBNE2hGfIUxA9Q2c8iXIQ7dCT_UDuwQ5SwY8S4l44dZLzWr0KlVEBfUZBHhCILvRhT5_9JP3B0XNpmJYDchwPyccWB1u4b2RmCzt8MkbbggClauQ7lzls3g09COZpc1ZwyQbqWD1sLaVcAuuBDQQkQBAk2za_ISARdjplVPT0zBMPaIijEYrmlsaqWlkvhIgOrSQ7CAg2B0rtdzTgDyZ7kLQy2tKv12unVogqzaUp_IqzL2cFbP1tKS1f_5hEZKCgZqaF3EOWPA8RzFkmqGadcUv7DDUhAf5F_Hv3juG8jj0V1l0dsqOYGaDfUeF4FirQQ_umeG43tOViLXjBDC_ZujZUm3WFAEl5HMKL9zyIVq2gE1MbZZHCsffmheyy4djJm5mTfZB4JX-OP3T839nZOA2cRKMcLBeiaBatuTUs7WPDnVTOxifUJGjCQdDcQIzJ_E68AIni5dQgEV5wZheplm8xWK-Fm9X2QLOvUKpCMwalqr_J7BKH71wIzUyjJSxZqfQ3QFKqjyWzJR3aAfpdc8N6-7ukuCtkeFlSfexMs8pUptGsBeNXy9U0Xa74E5BoyaX4SmYFd2VWOKJKZy1hEHI_EhX_mKrNrrS3pY2UcLjvOD8wnjD74MED7uiOEnx_eRjmfXylPHTd7UJ2Tw9IlstDiA4_Lg-AROmsOiTz6rC5lox3gGRhRd6JMu-A3lhiNKzYvmTzrKygvPgDjegOGnLsqe1zQQ9MuNtgfDtKHWyHJfhz_2y6VZrldTtHRWSgwnDb4T6BOyBOOXGLfTTEE_sEqU7cGRRtodEN6wghiJ7d9fg59gsDKdHQd63cme9wPAU_7QQOwwgniw6IrzggGSOejm83I2DSZWCCRUzHrJtl1t6CYccgaApqQUXdoxdcgzWdwErwFFaC5rASPz0Y3cisQ4tgR4fjId1gRutqrku0ENW0YHa8fi0amb1yaXD8al7r19rWDBwvlWo_Xi8t4slkGV4bLbP7ygqJFuwLF-yLP9S-4Jp9TqWJjcm1snRn6STpRffvTKup7ro-8cJ49ZtO_-a1mejfsTo0lmbqZKL3ZlZzSTqJsFFbIpufPBrcO4Td7Eq226NrCAe3p7Bg-czw3zGGjSD4TUPYx4TXn5_UFk83s0nt1njlAxUtx8DV88fV8Sq8L0WjawF4J3986WrNsVfEjS0BmbW1eNTGJj0ODWMhWWxMQ2TTa8e2e2DrZ65hkZjWiFHfjEZ9E_1QvXbg-vP6YTJTEOOF8SP4RQ-2sxKtT7qPIzLr_zewiJZnCNTKSOazkhsh7FbRth9W_aR9mSCcZp0aaDqZJfPmieNJ83TlsgUu-alyeU_B-fVejG604o8sOktUH1FzWmiXI-5WZEe_mBk-iOpBYkTzvLhybLtbyXS2ydVzG81zKOv3yy8kPmrTYcCiecBubsTrcnunxmh-aAyr29iwqZZsZxELASEllyvBjlSs3lhmlF6989ycACEgeAaEIGAHbEKkWhlNq4rL46qkAwI_wTua2tDs66rSynhJh6YomF7V_DvrydOW1v9Kvsqqpl86p_EqDsfrBaN2Cqh7IkC2WaneANnZq3PqL4pzrf1VWZ79Re1OHP6C-KtzmnTSG8lGex-ZZJpnbrnDcowi7lH8HxokIIOY-rih8dpuwTyCpxWaYDdblu5vR-tC0GPXYbCtjKRrM7j7BarL6eAiqZXBcybNmDmcb4cGFDZRO7mAkPfsRPVr5-h2UgyH--AJc3ph_uPTDn5mb0wMeMmQl0x4kyHv_93mDa7zdk3sCmc4BgQQsvjmAxkxRWOmtuD5bzvzoyFxPNuBS9OqA4j_oWPGlMyYVCl5pYx1oXXDRUC6KCCdCXjhZSUY3AGyt2kCyBZ-2T49TUzbjPku4YUWtxmFi9-nPin9Q_tGkdJRXaHu_pr6kD8G-SbY0Af2iONNmhKcJJuH02N6YGkaJqjY0CJhhzCIaEQKnGxSdthEtHjgjwSRAGOEURzFeLOOaMKyAmWIBUEWByEIESspF2uXKEofH3hdN-wxQRuEHtzgV7uXqAiR7B26RWti9PygH91bKYfmWNuDIK9NfZFiuBHsUVUGutJDbd6_ayWPMFM5g-_cnGyhuvNVAEDIQ6PF48mYyr1fQPaA7I_cnJrDOlNl-4ZM96JMpdW_WWYA2Tt9a0D2zp7_BAAA__-thQUz">