| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py |
| ; RUN: opt -S -passes=simplifycfg -simplifycfg-require-and-preserve-domtree=1 < %s | FileCheck %s |
| |
| ; We're sign extending an 8-bit value. |
| ; The switch condition must be in the range [-128, 127], so any cases outside of that range must be dead. |
| ; Only the first case has a non-zero weight, but that gets eliminated. Note |
| ; that this shouldn't have been the case in the first place, but the test here |
| ; ensures that all-zero branch weights are not attached causing problems downstream. |
| |
| define i1 @repeated_signbits(i8 %condition) { |
| ; CHECK-LABEL: @repeated_signbits( |
| ; CHECK-NEXT: entry: |
| ; CHECK-NEXT: [[SEXT:%.*]] = sext i8 [[CONDITION:%.*]] to i32 |
| ; CHECK-NEXT: switch i32 [[SEXT]], label [[DEFAULT:%.*]] [ |
| ; CHECK-NEXT: i32 0, label [[COMMON_RET:%.*]] |
| ; CHECK-NEXT: i32 127, label [[COMMON_RET]] |
| ; CHECK-NEXT: i32 -128, label [[COMMON_RET]] |
| ; CHECK-NEXT: i32 -1, label [[COMMON_RET]] |
| ; CHECK-NEXT: ] |
| ; CHECK: common.ret: |
| ; CHECK-NEXT: [[COMMON_RET_OP:%.*]] = phi i1 [ false, [[DEFAULT]] ], [ true, [[ENTRY:%.*]] ], [ true, [[ENTRY]] ], [ true, [[ENTRY]] ], [ true, [[ENTRY]] ] |
| ; CHECK-NEXT: ret i1 [[COMMON_RET_OP]] |
| ; CHECK: default: |
| ; CHECK-NEXT: br label [[COMMON_RET]] |
| ; |
| entry: |
| %sext = sext i8 %condition to i32 |
| switch i32 %sext, label %default [ |
| i32 -2147483648, label %a |
| i32 -129, label %a |
| i32 -128, label %a |
| i32 -1, label %a |
| i32 0, label %a |
| i32 127, label %a |
| i32 128, label %a |
| i32 2147483647, label %a |
| ], !prof !1 |
| |
| a: |
| ret i1 1 |
| |
| default: |
| ret i1 0 |
| } |
| |
| !1 = !{!"branch_weights", i32 0, i32 1, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0} |
| |