summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSaleem Abdulrasool <compnerd@compnerd.org>2014-11-24 20:14:29 +0000
committerSaleem Abdulrasool <compnerd@compnerd.org>2014-11-24 20:14:29 +0000
commitaca550fdb56231631eb9d7da11e70772f230a8e1 (patch)
tree10fbb709e46e33c49536c325d87448cb99d05bd7
parent76ecafd5238d84063053f9f754c2df18c57c4fe2 (diff)
downloadbcm5719-llvm-aca550fdb56231631eb9d7da11e70772f230a8e1.tar.gz
bcm5719-llvm-aca550fdb56231631eb9d7da11e70772f230a8e1.zip
CodeGen: make i686-windows-itanium more similar to msvc
The itanium environment follows the system calling convention for structures. Pass small aggregates via registers. llvm-svn: 222680
-rw-r--r--clang/lib/CodeGen/TargetInfo.cpp1
-rw-r--r--clang/test/CodeGen/windows-struct-abi.c19
2 files changed, 18 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/TargetInfo.cpp b/clang/lib/CodeGen/TargetInfo.cpp
index 3ad8bd950c6..422feef84e6 100644
--- a/clang/lib/CodeGen/TargetInfo.cpp
+++ b/clang/lib/CodeGen/TargetInfo.cpp
@@ -1307,6 +1307,7 @@ bool X86_32TargetCodeGenInfo::isStructReturnInRegABI(
case llvm::Triple::UnknownEnvironment:
case llvm::Triple::Cygnus:
case llvm::Triple::GNU:
+ case llvm::Triple::Itanium:
case llvm::Triple::MSVC:
return true;
default:
diff --git a/clang/test/CodeGen/windows-struct-abi.c b/clang/test/CodeGen/windows-struct-abi.c
index ec4bab6b47d..4b4a6f1b5db 100644
--- a/clang/test/CodeGen/windows-struct-abi.c
+++ b/clang/test/CodeGen/windows-struct-abi.c
@@ -6,7 +6,7 @@ struct f1 {
struct f1 return_f1(void) { while (1); }
-// CHECK: define void @return_f1(%struct.f1* noalias sret %agg.result)
+// CHECK: define i32 @return_f1()
void receive_f1(struct f1 a0) { }
@@ -19,9 +19,24 @@ struct f2 {
struct f2 return_f2(void) { while (1); }
-// CHECK: define void @return_f2(%struct.f2* noalias sret %agg.result)
+// CHECK: define i64 @return_f2()
void receive_f2(struct f2 a0) { }
// CHECK: define void @receive_f2(%struct.f2* byval align 4 %a0)
+struct f4 {
+ float f;
+ float g;
+ float h;
+ float i;
+};
+
+struct f4 return_f4(void) { while (1); }
+
+// CHECK: define void @return_f4(%struct.f4* noalias sret %agg.result)
+
+void receive_f4(struct f4 a0) { }
+
+// CHECK: define void @receive_f4(%struct.f4* byval align 4 %a0)
+
OpenPOWER on IntegriCloud