Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(9)

Side by Side Diff: test/Transforms/MinSFI/sandbox-indirect-calls.ll

Issue 939073008: Rebased PNaCl localmods in LLVM to 223109 (Closed)
Patch Set: undo localmod Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 ; RUN: opt %s -minsfi-sandbox-indirect-calls -S | FileCheck %s
2
3 !llvm.module.flags = !{!0}
4 !0 = metadata !{i32 1, metadata !"Debug Info Version", i32 2}
5
6 target datalayout = "p:32:32:32"
7 target triple = "le32-unknown-nacl"
8
9 declare void @fn_v_v()
10 declare void @fn_v_i_not_addr_taken(i32)
11 declare void @fn_v_i_1(i32)
12 declare i32 @fn_i_i_not_addr_taken(i32)
13 declare i32 @fn_i_ii(i32, i32)
14 declare void @fn_v_i_2(i32)
15
16 declare void @foo_2ptr(i32, i32)
17
18 ; CHECK-DAG: [[TAB_V_V:@__sfi_function_table[0-9]*]] = internal constant [8 x v oid ()*] [void ()* null, void ()* @fn_v_v, void ()* null, void ()* null, void ()* null, void ()* null, void ()* null, void ()* null]
19 ; CHECK-DAG: [[TAB_V_I:@__sfi_function_table[0-9]*]] = internal constant [8 x v oid (i32)*] [void (i32)* null, void (i32)* null, void (i32)* @fn_v_i _1, void (i32)* null, void (i32)* @fn_v_i_2, void (i32)* null, void (i32)* null, void (i32)* null]
20 ; CHECK-DAG: [[TAB_I_II:@__sfi_function_table[0-9]*]] = internal constant [8 x i 32 (i32, i32)*] [i32 (i32, i32)* null, i32 (i32, i32)* null, i32 (i32, i32)* nul l, i32 (i32, i32)* @fn_i_ii, i32 (i32, i32)* null, i32 (i32, i32)* null, i32 ( i32, i32)* null, i32 (i32, i32)* null]
21
22 @test_global_inits =
23 internal constant i32 ptrtoint (void (i32)* @fn_v_i_2 to i32)
24
25 ; CHECK-DAG: @test_global_inits = internal constant i32 4
26
27 define void @test_direct_calls_not_replaced() {
28 call void @fn_v_i_not_addr_taken(i32 5)
29 call i32 @fn_i_i_not_addr_taken(i32 7)
30 ret void
31 }
32
33 ; CHECK-LABEL: define void @test_direct_calls_not_replaced() {
34 ; CHECK-NEXT: call void @fn_v_i_not_addr_taken(i32 5)
35 ; CHECK-NEXT: call i32 @fn_i_i_not_addr_taken(i32 7)
36 ; CHECK-NEXT: ret void
37 ; CHECK-NEXT: }
38
39 define void @test_ptr_consts_replaced() {
40 call void @foo_2ptr(i32 ptrtoint (void (i32)* @fn_v_i_1 to i32),
41 i32 ptrtoint (void ()* @fn_v_v to i32))
42 ret void
43 }
44
45 ; CHECK-LABEL: define void @test_ptr_consts_replaced() {
46 ; CHECK-NEXT: call void @foo_2ptr(i32 2, i32 1)
47 ; CHECK-NEXT: ret void
48 ; CHECK-NEXT: }
49
50 define void @test_ptr_insts_replaced() {
51 %ptr1 = ptrtoint void (i32)* @fn_v_i_2 to i32
52 %ptr2 = ptrtoint i32 (i32, i32)* @fn_i_ii to i32
53 call void @foo_2ptr(i32 %ptr1, i32 %ptr2)
54 ret void
55 }
56
57 ; CHECK-LABEL: define void @test_ptr_insts_replaced() {
58 ; CHECK-NEXT: call void @foo_2ptr(i32 4, i32 3)
59 ; CHECK-NEXT: ret void
60 ; CHECK-NEXT: }
61
62 define void @test_indirect_calls(i32 %index_v_i, i32 %index_i_ii) {
63 %fn_v_i = inttoptr i32 %index_v_i to void (i32)*, !dbg !1
64 call void %fn_v_i(i32 7), !dbg !2
65 call void %fn_v_i(i32 9), !dbg !3
66 %fn_i_ii = inttoptr i32 %index_i_ii to i32 (i32, i32)*, !dbg !4
67 call i32 %fn_i_ii(i32 11, i32 13), !dbg !5
68 ret void
69 }
70
71 ; CHECK-LABEL: define void @test_indirect_calls(i32 %index_v_i, i32 %index_i_ii) {
72 ; CHECK-NEXT: %1 = and i32 %index_v_i, 7
73 ; CHECK-NEXT: %2 = getelementptr [8 x void (i32)*]* [[TAB_V_I]], i32 0, i32 % 1
74 ; CHECK-NEXT: %3 = load void (i32)** %2, !dbg !1
75 ; CHECK-NEXT: call void %3(i32 7), !dbg !2
76 ; CHECK-NEXT: %4 = and i32 %index_v_i, 7
77 ; CHECK-NEXT: %5 = getelementptr [8 x void (i32)*]* [[TAB_V_I]], i32 0, i32 % 4
78 ; CHECK-NEXT: %6 = load void (i32)** %5, !dbg !1
79 ; CHECK-NEXT: call void %6(i32 9), !dbg !3
80 ; CHECK-NEXT: %7 = and i32 %index_i_ii, 7
81 ; CHECK-NEXT: %8 = getelementptr [8 x i32 (i32, i32)*]* [[TAB_I_II]], i32 0, i32 %7
82 ; CHECK-NEXT: %9 = load i32 (i32, i32)** %8, !dbg !4
83 ; CHECK-NEXT: call i32 %9(i32 11, i32 13), !dbg !5
84 ; CHECK-NEXT: ret void
85 ; CHECK-NEXT: }
86
87 define float @test_call_without_a_table(i32 %index) {
88 %fn = inttoptr i32 %index to float (float)*
89 %ret = call float %fn(float 0.000000e+00)
90 ret float %ret
91 }
92
93 ; CHECK-LABEL: define float @test_call_without_a_table(i32 %index) {
94 ; CHECK-NEXT: call void @llvm.trap()
95 ; CHECK-NEXT: %ret = call float null(float 0.000000e+00)
96 ; CHECK-NEXT: ret float %ret
97 ; CHECK-NEXT: }
98
99 !1 = metadata !{i32 138, i32 0, metadata !1, null}
100 !2 = metadata !{i32 142, i32 0, metadata !2, null}
101 !3 = metadata !{i32 144, i32 0, metadata !3, null}
102 !4 = metadata !{i32 144, i32 0, metadata !4, null}
103 !5 = metadata !{i32 144, i32 0, metadata !5, null}
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698