mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 20:06:06 +00:00

In particular, it couldn't handle cases where lookup table constant expressions involved bitcasts. This does not seem to come up frequently in C++, but comes up reasonably often in Rust via `#[derive(Debug)]`. Originally reported by pcwalton. Reviewed By: nikic Differential Revision: https://reviews.llvm.org/D109565
43 lines
1.6 KiB
LLVM
43 lines
1.6 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --scrub-attributes
|
|
; RUN: opt -simplifycfg --switch-to-lookup -S < %s | FileCheck %s
|
|
target triple = "x86_64-unknown-linux-gnu"
|
|
|
|
@alloc0 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"A" }>, align 1
|
|
@alloc1 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"B" }>, align 1
|
|
@alloc2 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"C" }>, align 1
|
|
|
|
define { [0 x i8]*, i64 } @switch_to_lookup_bitcast(i8 %0) unnamed_addr {
|
|
; CHECK-LABEL: @switch_to_lookup_bitcast(
|
|
; CHECK-NEXT: start:
|
|
; CHECK-NEXT: [[SWITCH_GEP:%.*]] = getelementptr inbounds [3 x [0 x i8]*], [3 x [0 x i8]*]* @switch.table.switch_to_lookup_bitcast, i32 0, i8 [[TMP0:%.*]]
|
|
; CHECK-NEXT: [[SWITCH_LOAD:%.*]] = load [0 x i8]*, [0 x i8]** [[SWITCH_GEP]], align 8
|
|
; CHECK-NEXT: [[TMP1:%.*]] = insertvalue { [0 x i8]*, i64 } undef, [0 x i8]* [[SWITCH_LOAD]], 0
|
|
; CHECK-NEXT: [[TMP2:%.*]] = insertvalue { [0 x i8]*, i64 } [[TMP1]], i64 1, 1
|
|
; CHECK-NEXT: ret { [0 x i8]*, i64 } [[TMP2]]
|
|
;
|
|
start:
|
|
switch i8 %0, label %default [
|
|
i8 0, label %bb0
|
|
i8 1, label %bb1
|
|
i8 2, label %bb2
|
|
]
|
|
|
|
bb0:
|
|
br label %end
|
|
|
|
bb1:
|
|
br label %end
|
|
|
|
bb2:
|
|
br label %end
|
|
|
|
default:
|
|
unreachable
|
|
|
|
end:
|
|
%.sroa.0.0 = phi [0 x i8]* [ bitcast (<{ [1 x i8] }>* @alloc0 to [0 x i8]*), %bb0 ], [ bitcast (<{ [1 x i8] }>* @alloc1 to [0 x i8]*), %bb1 ], [ bitcast (<{ [1 x i8] }>* @alloc2 to [0 x i8]*), %bb2 ]
|
|
%1 = insertvalue { [0 x i8]*, i64 } undef, [0 x i8]* %.sroa.0.0, 0
|
|
%2 = insertvalue { [0 x i8]*, i64 } %1, i64 1, 1
|
|
ret { [0 x i8]*, i64 } %2
|
|
}
|