Index: test/Transforms/NaCl/rewrite-agg-arg.ll |
diff --git a/test/Transforms/NaCl/rewrite-agg-arg.ll b/test/Transforms/NaCl/rewrite-agg-arg.ll |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4fc39cb1e0fc34bcf638526ebb7c441930592f43 |
--- /dev/null |
+++ b/test/Transforms/NaCl/rewrite-agg-arg.ll |
@@ -0,0 +1,82 @@ |
+; RUN: opt -S -rewrite-aggregate-arguments %s | FileCheck %s |
+ |
+target datalayout = "e-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-p:32:32:32-v128:32:32" |
+ |
+%struct = type { i8, i32 } |
+ |
+; CHECK-LABEL: void @arrayarg([2 x i32]* nocapture nonnull dereferenceable(8) %a) |
+define void @arrayarg([2 x i32] %a) { |
+; CHECK-NEXT: agg-arg-loads: |
+; CHECK-NEXT: %a.load = load [2 x i32], [2 x i32]* %a |
+ |
+; CHECK: %a.load.call-store = alloca [2 x i32] |
+; CHECK-NEXT: store [2 x i32] %a.load, [2 x i32]* %a.load.call-store |
+ call void @arrayarg([2 x i32] %a) |
+; CHECK: call void %.fty-cast([2 x i32]* nocapture nonnull dereferenceable(8) %a.load.call-store) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @structarg(%struct* nocapture nonnull dereferenceable(8) %a) |
+define void @structarg(%struct %a) { |
+; CHECK-NEXT: agg-arg-loads: |
+; CHECK-NEXT: %a.load = load %struct, %struct* %a |
+ |
+; CHECK: %a.load.call-store = alloca %struct |
+; CHECK-NEXT: store %struct %a.load, %struct* %a.load.call-store |
+ call void @structarg(%struct %a) |
+; CHECK: call void %.fty-cast(%struct* nocapture nonnull dereferenceable(8) %a.load.call-store) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @vectorarg(<4 x i32>* nocapture nonnull dereferenceable(16) %a) |
+define void @vectorarg(<4 x i32> %a) { |
+; CHECK-NEXT: agg-arg-loads: |
+; CHECK-NEXT: %a.load = load <4 x i32>, <4 x i32>* %a |
+ |
+; CHECK: %a.load.call-store = alloca <4 x i32> |
+; CHECK-NEXT: store <4 x i32> %a.load, <4 x i32>* %a.load.call-store |
+ call void @vectorarg(<4 x i32> %a) |
+; CHECK: call void %.fty-cast(<4 x i32>* nocapture nonnull dereferenceable(16) %a.load.call-store) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @multipleargs(i32 %a, %struct* nocapture nonnull dereferenceable(8) %b) |
+define void @multipleargs(i32 %a, %struct %b) { |
+; CHECK-NEXT: agg-arg-loads: |
+; CHECK-NEXT: %b.load = load %struct, %struct* %b |
+ |
+; CHECK: %b.load.call-store = alloca %struct |
+; CHECK-NEXT: store %struct %b.load, %struct* %b.load.call-store |
+ call void @multipleargs(i32 %a, %struct %b) |
+; CHECK: call void %.fty-cast(i32 %a, %struct* nocapture nonnull dereferenceable(8) %b.load.call-store) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @multiplecalls() |
+define void @multiplecalls() { |
+; CHECK-NEXT: %.call-store = alloca <4 x i32> |
+; CHECK-NEXT: store <4 x i32> undef, <4 x i32>* %.call-store |
+ call void @vectorarg(<4 x i32> undef) |
+; CHECK: call void %.fty-cast(<4 x i32>* nocapture nonnull dereferenceable(16) %.call-store) |
+ |
+; CHECK-NEXT: %.call-store1 = alloca %struct |
+; CHECK-NEXT: store %struct undef, %struct* %.call-store1 |
+ call void @multipleargs(i32 0, %struct undef) |
+; CHECK: call void %.fty-cast2(i32 0, %struct* nocapture nonnull dereferenceable(8) %.call-store1) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @indirectcall(void (%struct)* %f) |
+define void @indirectcall(void (%struct)* %f) { |
+; CHECK-NEXT: %.call-store = alloca %struct |
+; CHECK-NEXT: store %struct undef, %struct* %.call-store |
+; CHECK-NEXT: %f.fty-cast = bitcast void (%struct)* %f to void (%struct*)* |
+ call void %f(%struct undef) |
+; CHECK-NEXT: call void %f.fty-cast(%struct* nocapture nonnull dereferenceable(8) %.call-store) |
+ ret void |
+} |
+ |
+; CHECK-LABEL: void @argattrs(i8* nonnull, %struct* nocapture nonnull dereferenceable(8)) |
+define void @argattrs(i8* nonnull, %struct) { |
+ ret void |
+} |