@@ -38,27 +38,13 @@ int f1(int n, ...) {
38
38
// AFTER: [[CMP0:%.*]] = cir.cmp(ge, [[GR_OFFS]], [[ZERO]]) : !s32i, !cir.bool
39
39
// AFTER-NEXT: cir.brcond [[CMP0]] [[BB_ON_STACK:\^bb.*]], [[BB_MAY_REG:\^bb.*]]
40
40
41
- // This BB is where different path converges. BLK_ARG is the arg addr which
42
- // could come from IN_REG block where arg is passed in register, and saved in callee
43
- // stack's argument saving area.
44
- // Or from ON_STACK block which means arg is passed in from caller's stack area.
45
- // AFTER-NEXT: [[BB_END:\^bb.*]]([[BLK_ARG:%.*]]: !cir.ptr<!void>): // 2 preds: [[BB_IN_REG:\^bb.*]], [[BB_ON_STACK]]
46
- // AFTER-NEXT: [[TMP0:%.*]] = cir.cast(bitcast, [[BLK_ARG]] : !cir.ptr<!void>), !cir.ptr<!s32i>
47
- // AFTER-NEXT: [[TMP1:%.*]] = cir.load [[TMP0]] : !cir.ptr<!s32i>, !s32i
48
- // AFTER: cir.store [[TMP1]], [[RESP]] : !s32i, !cir.ptr<!s32i>
49
- // AFTER: cir.va.end [[VARLIST]] : !cir.ptr<!ty_22__va_list22>
50
- // AFTER: [[RES:%.*]] = cir.load [[RESP]] : !cir.ptr<!s32i>, !s32i
51
- // AFTER: cir.store [[RES]], [[RETP]] : !s32i, !cir.ptr<!s32i>
52
- // AFTER: [[RETV:%.*]] = cir.load [[RETP]] : !cir.ptr<!s32i>, !s32i
53
- // AFTER: cir.return [[RETV]] : !s32i
54
-
55
41
// This BB calculates to see if it is possible to pass arg in register.
56
42
// AFTER: [[BB_MAY_REG]]:
57
43
// AFTER-NEXT: [[EIGHT:%.*]] = cir.const #cir.int<8> : !s32i
58
44
// AFTER-NEXT: [[NEW_REG_OFFS:%.*]] = cir.binop(add, [[GR_OFFS]], [[EIGHT]]) : !s32i
59
45
// AFTER-NEXT: cir.store [[NEW_REG_OFFS]], [[GR_OFFS_P]] : !s32i, !cir.ptr<!s32i>
60
46
// AFTER-NEXT: [[CMP1:%.*]] = cir.cmp(le, [[NEW_REG_OFFS]], [[ZERO]]) : !s32i, !cir.bool
61
- // AFTER-NEXT: cir.brcond [[CMP1]] [[BB_IN_REG]], [[BB_ON_STACK]]
47
+ // AFTER-NEXT: cir.brcond [[CMP1]] [[BB_IN_REG:\^bb.* ]], [[BB_ON_STACK]]
62
48
63
49
// arg is passed in register.
64
50
// AFTER: [[BB_IN_REG]]:
@@ -67,7 +53,7 @@ int f1(int n, ...) {
67
53
// AFTER-NEXT: [[TMP2:%.*]] = cir.cast(bitcast, [[GR_TOP]] : !cir.ptr<!void>), !cir.ptr<i8>
68
54
// AFTER-NEXT: [[TMP3:%.*]] = cir.ptr_stride([[TMP2]] : !cir.ptr<i8>, [[GR_OFFS]] : !s32i), !cir.ptr<i8>
69
55
// AFTER-NEXT: [[IN_REG_OUTPUT:%.*]] = cir.cast(bitcast, [[TMP3]] : !cir.ptr<i8>), !cir.ptr<!void>
70
- // AFTER-NEXT: cir.br [[BB_END]]([[IN_REG_OUTPUT]] : !cir.ptr<!void>)
56
+ // AFTER-NEXT: cir.br [[BB_END:\^bb.* ]]([[IN_REG_OUTPUT]] : !cir.ptr<!void>)
71
57
72
58
// arg is passed in stack.
73
59
// AFTER: [[BB_ON_STACK]]:
@@ -80,6 +66,20 @@ int f1(int n, ...) {
80
66
// AFTER-NEXT: cir.store [[NEW_STACK_V]], [[STACK_P]] : !cir.ptr<!void>, !cir.ptr<!cir.ptr<!void>>
81
67
// AFTER-NEXT: cir.br [[BB_END]]([[STACK_V]] : !cir.ptr<!void>)
82
68
69
+ // This BB is where different path converges. BLK_ARG is the arg addr which
70
+ // could come from IN_REG block where arg is passed in register, and saved in callee
71
+ // stack's argument saving area.
72
+ // Or from ON_STACK block which means arg is passed in from caller's stack area.
73
+ // AFTER-NEXT: [[BB_END]]([[BLK_ARG:%.*]]: !cir.ptr<!void>): // 2 preds: [[BB_IN_REG]], [[BB_ON_STACK]]
74
+ // AFTER-NEXT: [[TMP0:%.*]] = cir.cast(bitcast, [[BLK_ARG]] : !cir.ptr<!void>), !cir.ptr<!s32i>
75
+ // AFTER-NEXT: [[TMP1:%.*]] = cir.load [[TMP0]] : !cir.ptr<!s32i>, !s32i
76
+ // AFTER: cir.store [[TMP1]], [[RESP]] : !s32i, !cir.ptr<!s32i>
77
+ // AFTER: cir.va.end [[VARLIST]] : !cir.ptr<!ty_22__va_list22>
78
+ // AFTER: [[RES:%.*]] = cir.load [[RESP]] : !cir.ptr<!s32i>, !s32i
79
+ // AFTER: cir.store [[RES]], [[RETP]] : !s32i, !cir.ptr<!s32i>
80
+ // AFTER: [[RETV:%.*]] = cir.load [[RETP]] : !cir.ptr<!s32i>, !s32i
81
+ // AFTER: cir.return [[RETV]] : !s32i
82
+
83
83
// LLVM: %struct.__va_list = type { ptr, ptr, ptr, i32, i32 }
84
84
// LLVM: define i32 @f1(i32 %0, ...)
85
85
// LLVM: [[ARGN:%.*]] = alloca i32, i64 1, align 4,
@@ -91,32 +91,32 @@ int f1(int n, ...) {
91
91
// LLVM-NEXT: [[CMP0:%.*]] = icmp sge i32 [[GR_OFFS]], 0,
92
92
// LLVM-NEXT: br i1 [[CMP0]], label %[[BB_ON_STACK:.*]], label %[[BB_MAY_REG:.*]],
93
93
94
- // LLVM: [[BB_END:.*]]: ; preds = %[[BB_ON_STACK]], %[[BB_IN_REG:.*]]
95
- // LLVM-NEXT: [[PHIP:%.*]] = phi ptr [ [[IN_REG_OUTPUT:%.*]], %[[BB_IN_REG]] ], [ [[STACK_V:%.*]], %[[BB_ON_STACK]] ]
96
- // LLVM-NEXT: [[PHIV:%.*]] = load i32, ptr [[PHIP]], align 4,
97
- // LLVM-NEXT: store i32 [[PHIV]], ptr [[RESP]], align 4,
98
- // LLVM: call void @llvm.va_end.p0(ptr [[VARLIST]]),
99
- // LLVM: [[RES:%.*]] = load i32, ptr [[RESP]], align 4,
100
- // LLVM: store i32 [[RES]], ptr [[RETP]], align 4,
101
- // LLVM: [[RETV:%.*]] = load i32, ptr [[RETP]], align 4,
102
- // LLVM-NEXT: ret i32 [[RETV]],
103
-
104
94
// LLVM: [[BB_MAY_REG]]: ;
105
95
// LLVM: [[NEW_REG_OFFS:%.*]] = add i32 [[GR_OFFS]], 8,
106
96
// LLVM: store i32 [[NEW_REG_OFFS]], ptr [[GR_OFFS_P]], align 4,
107
97
// LLVM-NEXT: [[CMP1:%.*]] = icmp sle i32 [[NEW_REG_OFFS]], 0,
108
- // LLVM-NEXT: br i1 [[CMP1]], label %[[BB_IN_REG]], label %[[BB_ON_STACK]],
98
+ // LLVM-NEXT: br i1 [[CMP1]], label %[[BB_IN_REG:.* ]], label %[[BB_ON_STACK]],
109
99
110
100
// LLVM: [[BB_IN_REG]]: ;
111
101
// LLVM-NEXT: [[GR_TOP_P:%.*]] = getelementptr %struct.__va_list, ptr [[VARLIST]], i32 0, i32 1,
112
102
// LLVM-NEXT: [[GR_TOP:%.*]] = load ptr, ptr [[GR_TOP_P]], align 8,
113
103
// LLVM-NEXT: [[EXT64_GR_OFFS:%.*]] = sext i32 [[GR_OFFS]] to i64,
114
- // LLVM-NEXT: [[IN_REG_OUTPUT]] = getelementptr i8, ptr [[GR_TOP]], i64 [[EXT64_GR_OFFS]],
115
- // LLVM-NEXT: br label %[[BB_END]],
104
+ // LLVM-NEXT: [[IN_REG_OUTPUT:%.* ]] = getelementptr i8, ptr [[GR_TOP]], i64 [[EXT64_GR_OFFS]],
105
+ // LLVM-NEXT: br label %[[BB_END:.* ]],
116
106
117
107
// LLVM: [[BB_ON_STACK]]: ;
118
108
// LLVM-NEXT: [[STACK_P:%.*]] = getelementptr %struct.__va_list, ptr [[VARLIST]], i32 0, i32 0,
119
- // LLVM-NEXT: [[STACK_V]] = load ptr, ptr [[STACK_P]], align 8,
109
+ // LLVM-NEXT: [[STACK_V:%.* ]] = load ptr, ptr [[STACK_P]], align 8,
120
110
// LLVM-NEXT: [[NEW_STACK_V:%.*]] = getelementptr i8, ptr [[STACK_V]], i32 8,
121
111
// LLVM-NEXT: store ptr [[NEW_STACK_V]], ptr [[STACK_P]], align 8,
122
112
// LLVM-NEXT: br label %[[BB_END]],
113
+
114
+ // LLVM: [[BB_END]]: ; preds = %[[BB_ON_STACK]], %[[BB_IN_REG]]
115
+ // LLVM-NEXT: [[PHIP:%.*]] = phi ptr [ [[IN_REG_OUTPUT]], %[[BB_IN_REG]] ], [ [[STACK_V]], %[[BB_ON_STACK]] ]
116
+ // LLVM-NEXT: [[PHIV:%.*]] = load i32, ptr [[PHIP]], align 4,
117
+ // LLVM-NEXT: store i32 [[PHIV]], ptr [[RESP]], align 4,
118
+ // LLVM: call void @llvm.va_end.p0(ptr [[VARLIST]]),
119
+ // LLVM: [[RES:%.*]] = load i32, ptr [[RESP]], align 4,
120
+ // LLVM: store i32 [[RES]], ptr [[RETP]], align 4,
121
+ // LLVM: [[RETV:%.*]] = load i32, ptr [[RETP]], align 4,
122
+ // LLVM-NEXT: ret i32 [[RETV]],
0 commit comments