[sanitizer] Improve FreeBSD ASLR detection
[llvm-project.git] / llvm / test / Transforms / SimplifyCFG / X86 / switch-to-lookup-bitcast.ll
blob9a567f38a24b41fc26b2b2dea07534bdeef4ec34
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --scrub-attributes
2 ; RUN: opt -simplifycfg --switch-to-lookup -S < %s | FileCheck %s
3 target triple = "x86_64-unknown-linux-gnu"
5 @alloc0 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"A" }>, align 1
6 @alloc1 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"B" }>, align 1
7 @alloc2 = private unnamed_addr constant <{ [1 x i8] }> <{ [1 x i8] c"C" }>, align 1
9 define { [0 x i8]*, i64 } @switch_to_lookup_bitcast(i8 %0) unnamed_addr {
10 ; CHECK-LABEL: @switch_to_lookup_bitcast(
11 ; CHECK-NEXT:  start:
12 ; 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:%.*]]
13 ; CHECK-NEXT:    [[SWITCH_LOAD:%.*]] = load [0 x i8]*, [0 x i8]** [[SWITCH_GEP]], align 8
14 ; CHECK-NEXT:    [[TMP1:%.*]] = insertvalue { [0 x i8]*, i64 } undef, [0 x i8]* [[SWITCH_LOAD]], 0
15 ; CHECK-NEXT:    [[TMP2:%.*]] = insertvalue { [0 x i8]*, i64 } [[TMP1]], i64 1, 1
16 ; CHECK-NEXT:    ret { [0 x i8]*, i64 } [[TMP2]]
18 start:
19   switch i8 %0, label %default [
20   i8 0, label %bb0
21   i8 1, label %bb1
22   i8 2, label %bb2
23   ]
25 bb0:
26   br label %end
28 bb1:
29   br label %end
31 bb2:
32   br label %end
34 default:
35   unreachable
37 end:
38   %.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 ]
39   %1 = insertvalue { [0 x i8]*, i64 } undef, [0 x i8]* %.sroa.0.0, 0
40   %2 = insertvalue { [0 x i8]*, i64 } %1, i64 1, 1
41   ret { [0 x i8]*, i64 } %2