<div dir="ltr">Ping, we need to move this out of CGCall.cpp.</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Sat, Aug 16, 2014 at 1:15 AM, James Molloy <span dir="ltr"><<a href="mailto:James.Molloy@arm.com" target="_blank">James.Molloy@arm.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word;color:rgb(0,0,0);font-size:14px;font-family:Calibri,sans-serif">
<div>Forwarding to Oliver, as this was his commit! :)</div>
<div><br>
</div>
<span>
<div style="font-family:Calibri;font-size:11pt;text-align:left;color:black;BORDER-BOTTOM:medium none;BORDER-LEFT:medium none;PADDING-BOTTOM:0in;PADDING-LEFT:0in;PADDING-RIGHT:0in;BORDER-TOP:#b5c4df 1pt solid;BORDER-RIGHT:medium none;PADDING-TOP:3pt">
<span style="font-weight:bold">From: </span>Dan Gohman <<a href="mailto:dan433584@gmail.com" target="_blank">dan433584@gmail.com</a>><br>
<span style="font-weight:bold">Date: </span>Sat, 16 Aug 2014 00:48:24 +0100<br>
<span style="font-weight:bold">To: </span>Reid Kleckner <<a href="mailto:rnk@google.com" target="_blank">rnk@google.com</a>><br>
<span style="font-weight:bold">Cc: </span>Admin <<a href="mailto:james.molloy@arm.com" target="_blank">james.molloy@arm.com</a>>, John McCall <<a href="mailto:rjmccall@apple.com" target="_blank">rjmccall@apple.com</a>>, "<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a>"
<<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a>><br>
<span style="font-weight:bold">Subject: </span>Re: r208425 - Reapply r208417 (olista01 'ARM: HFAs must be passed in consecutive registers'). Bots are now pacified.<br>
</div><div><div class="h5">
<div><br>
</div>
<div dir="ltr">
<div>It's true that there's no LangRef guarantee, implied or otherwise, about FCA's being passed by constituent elements in codegen. It's implemented by target-independent code though, so it's not something you'll want to change without reason.<br>
<br>
</div>
Dan<br>
<div>
<div>
<div class="gmail_extra"><br>
<div class="gmail_quote">On Fri, Aug 15, 2014 at 3:29 PM, Reid Kleckner <span dir="ltr">
<<a href="mailto:rnk@google.com" target="_blank">rnk@google.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div dir="ltr">CGCall.cpp is not the right place to do target specific lowering. Please move this logic to lib/CodeGen/TargetInfo.cpp.
<div><br>
</div>
<div>Furthermore, how does AAPCS treat structure arguments? Some time ago Dan Gohman told me that FCAs are defined to be passed exactly as if their constituent elements were passed as separate arguments. If you're not doing that, you've changed the semantics
of FCAs dramatically. I can't actually find this guarantee in LangRef, so maybe that change is OK, but I want to know about it. :)</div>
<div class="gmail_extra"><br>
<br>
<div class="gmail_quote">On Fri, May 9, 2014 at 9:21 AM, James Molloy <span dir="ltr">
<<a href="mailto:james.molloy@arm.com" target="_blank">james.molloy@arm.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Author: jamesm<br>
Date: Fri May 9 11:21:39 2014<br>
New Revision: 208425<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=208425&view=rev" target="_blank">
http://llvm.org/viewvc/llvm-project?rev=208425&view=rev</a><br>
Log:<br>
Reapply r208417 (olista01 'ARM: HFAs must be passed in consecutive registers'). Bots are now pacified.<br>
<br>
Modified:<br>
cfe/trunk/lib/CodeGen/CGCall.cpp<br>
cfe/trunk/lib/CodeGen/TargetInfo.cpp<br>
cfe/trunk/test/CodeGen/arm-aapcs-vfp.c<br>
cfe/trunk/test/CodeGen/arm-homogenous.c<br>
<br>
Modified: cfe/trunk/lib/CodeGen/CGCall.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGCall.cpp?rev=208425&r1=208424&r2=208425&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGCall.cpp?rev=208425&r1=208424&r2=208425&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/lib/CodeGen/CGCall.cpp (original)<br>
+++ cfe/trunk/lib/CodeGen/CGCall.cpp Fri May 9 11:21:39 2014<br>
@@ -158,6 +158,23 @@ static CallingConv getCallingConventionF<br>
return CC_C;<br>
}<br>
<br>
+static bool isAAPCSVFP(const CGFunctionInfo &FI, const TargetInfo &Target) {<br>
+ switch (FI.getEffectiveCallingConvention()) {<br>
+ case llvm::CallingConv::C:<br>
+ switch (Target.getTriple().getEnvironment()) {<br>
+ case llvm::Triple::EABIHF:<br>
+ case llvm::Triple::GNUEABIHF:<br>
+ return true;<br>
+ default:<br>
+ return false;<br>
+ }<br>
+ case llvm::CallingConv::ARM_AAPCS_VFP:<br>
+ return true;<br>
+ default:<br>
+ return false;<br>
+ }<br>
+}<br>
+<br>
/// Arrange the argument and result information for a call to an<br>
/// unknown C++ non-static member function of the given abstract type.<br>
/// (Zero value of RD means we don't have any meaningful "this" argument type,<br>
@@ -995,8 +1012,11 @@ CodeGenTypes::GetFunctionType(const CGFu<br>
// If the coerce-to type is a first class aggregate, flatten it. Either<br>
// way is semantically identical, but fast-isel and the optimizer<br>
// generally likes scalar values better than FCAs.<br>
+ // We cannot do this for functions using the AAPCS calling convention,<br>
+ // as structures are treated differently by that calling convention.<br>
llvm::Type *argType = argAI.getCoerceToType();<br>
- if (llvm::StructType *st = dyn_cast<llvm::StructType>(argType)) {<br>
+ llvm::StructType *st = dyn_cast<llvm::StructType>(argType);<br>
+ if (st && !isAAPCSVFP(FI, getTarget())) {<br>
for (unsigned i = 0, e = st->getNumElements(); i != e; ++i)<br>
argTypes.push_back(st->getElementType(i));<br>
} else {<br>
@@ -1199,14 +1219,15 @@ void CodeGenModule::ConstructAttributeLi<br>
else if (ParamType->isUnsignedIntegerOrEnumerationType())<br>
Attrs.addAttribute(llvm::Attribute::ZExt);<br>
// FALL THROUGH<br>
- case ABIArgInfo::Direct:<br>
+ case ABIArgInfo::Direct: {<br>
if (AI.getInReg())<br>
Attrs.addAttribute(llvm::Attribute::InReg);<br>
<br>
// FIXME: handle sseregparm someday...<br>
<br>
- if (llvm::StructType *STy =<br>
- dyn_cast<llvm::StructType>(AI.getCoerceToType())) {<br>
+ llvm::StructType *STy =<br>
+ dyn_cast<llvm::StructType>(AI.getCoerceToType());<br>
+ if (!isAAPCSVFP(FI, getTarget()) && STy) {<br>
unsigned Extra = STy->getNumElements()-1; // 1 will be added below.<br>
if (Attrs.hasAttributes())<br>
for (unsigned I = 0; I < Extra; ++I)<br>
@@ -1215,7 +1236,7 @@ void CodeGenModule::ConstructAttributeLi<br>
Index += Extra;<br>
}<br>
break;<br>
-<br>
+ }<br>
case ABIArgInfo::Indirect:<br>
if (AI.getInReg())<br>
Attrs.addAttribute(llvm::Attribute::InReg);<br>
@@ -1474,8 +1495,10 @@ void CodeGenFunction::EmitFunctionProlog<br>
// If the coerce-to type is a first class aggregate, we flatten it and<br>
// pass the elements. Either way is semantically identical, but fast-isel<br>
// and the optimizer generally likes scalar values better than FCAs.<br>
+ // We cannot do this for functions using the AAPCS calling convention,<br>
+ // as structures are treated differently by that calling convention.<br>
llvm::StructType *STy = dyn_cast<llvm::StructType>(ArgI.getCoerceToType());<br>
- if (STy && STy->getNumElements() > 1) {<br>
+ if (!isAAPCSVFP(FI, getTarget()) && STy && STy->getNumElements() > 1) {<br>
uint64_t SrcSize = CGM.getDataLayout().getTypeAllocSize(STy);<br>
llvm::Type *DstTy =<br>
cast<llvm::PointerType>(Ptr->getType())->getElementType();<br>
@@ -2735,8 +2758,11 @@ RValue CodeGenFunction::EmitCall(const C<br>
// If the coerce-to type is a first class aggregate, we flatten it and<br>
// pass the elements. Either way is semantically identical, but fast-isel<br>
// and the optimizer generally likes scalar values better than FCAs.<br>
- if (llvm::StructType *STy =<br>
- dyn_cast<llvm::StructType>(ArgInfo.getCoerceToType())) {<br>
+ // We cannot do this for functions using the AAPCS calling convention,<br>
+ // as structures are treated differently by that calling convention.<br>
+ llvm::StructType *STy =<br>
+ dyn_cast<llvm::StructType>(ArgInfo.getCoerceToType());<br>
+ if (STy && !isAAPCSVFP(CallInfo, getTarget())) {<br>
llvm::Type *SrcTy =<br>
cast<llvm::PointerType>(SrcPtr->getType())->getElementType();<br>
uint64_t SrcSize = CGM.getDataLayout().getTypeAllocSize(SrcTy);<br>
<br>
Modified: cfe/trunk/lib/CodeGen/TargetInfo.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/TargetInfo.cpp?rev=208425&r1=208424&r2=208425&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/TargetInfo.cpp?rev=208425&r1=208424&r2=208425&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/lib/CodeGen/TargetInfo.cpp (original)<br>
+++ cfe/trunk/lib/CodeGen/TargetInfo.cpp Fri May 9 11:21:39 2014<br>
@@ -3796,7 +3796,7 @@ public:<br>
<br>
private:<br>
ABIArgInfo classifyReturnType(QualType RetTy, bool isVariadic) const;<br>
- ABIArgInfo classifyArgumentType(QualType RetTy, bool &IsHA, bool isVariadic,<br>
+ ABIArgInfo classifyArgumentType(QualType RetTy, bool isVariadic,<br>
bool &IsCPRC) const;<br>
bool isIllegalVectorType(QualType Ty) const;<br>
<br>
@@ -3901,22 +3901,10 @@ void ARMABIInfo::computeInfo(CGFunctionI<br>
for (auto &I : FI.arguments()) {<br>
unsigned PreAllocationVFPs = AllocatedVFPs;<br>
unsigned PreAllocationGPRs = AllocatedGPRs;<br>
- bool IsHA = false;<br>
bool IsCPRC = false;<br>
// 6.1.2.3 There is one VFP co-processor register class using registers<br>
// s0-s15 (d0-d7) for passing arguments.<br>
- I.info = classifyArgumentType(I.type, IsHA, FI.isVariadic(), IsCPRC);<br>
- assert((IsCPRC || !IsHA) && "Homogeneous aggregates must be CPRCs");<br>
- // If we do not have enough VFP registers for the HA, any VFP registers<br>
- // that are unallocated are marked as unavailable. To achieve this, we add<br>
- // padding of (NumVFPs - PreAllocationVFP) floats.<br>
- // Note that IsHA will only be set when using the AAPCS-VFP calling convention,<br>
- // and the callee is not variadic.<br>
- if (IsHA && AllocatedVFPs > NumVFPs && PreAllocationVFPs < NumVFPs) {<br>
- llvm::Type *PaddingTy = llvm::ArrayType::get(<br>
- llvm::Type::getFloatTy(getVMContext()), NumVFPs - PreAllocationVFPs);<br>
- I.info = ABIArgInfo::getExpandWithPadding(false, PaddingTy);<br>
- }<br>
+ I.info = classifyArgumentType(I.type, FI.isVariadic(), IsCPRC);<br>
<br>
// If we have allocated some arguments onto the stack (due to running<br>
// out of VFP registers), we cannot split an argument between GPRs and<br>
@@ -3930,6 +3918,7 @@ void ARMABIInfo::computeInfo(CGFunctionI<br>
llvm::Type::getInt32Ty(getVMContext()), NumGPRs - PreAllocationGPRs);<br>
I.info = ABIArgInfo::getDirect(nullptr /* type */, 0 /* offset */,<br>
PaddingTy);<br>
+<br>
}<br>
}<br>
<br>
@@ -4113,8 +4102,7 @@ void ARMABIInfo::resetAllocatedRegs(void<br>
VFPRegs[i] = 0;<br>
}<br>
<br>
-ABIArgInfo ARMABIInfo::classifyArgumentType(QualType Ty, bool &IsHA,<br>
- bool isVariadic,<br>
+ABIArgInfo ARMABIInfo::classifyArgumentType(QualType Ty, bool isVariadic,<br>
bool &IsCPRC) const {<br>
// We update number of allocated VFPs according to<br>
// 6.1.2.1 The following argument types are VFP CPRCs:<br>
@@ -4226,9 +4214,8 @@ ABIArgInfo ARMABIInfo::classifyArgumentT<br>
Base->isSpecificBuiltinType(BuiltinType::LongDouble));<br>
markAllocatedVFPs(2, Members * 2);<br>
}<br>
- IsHA = true;<br>
IsCPRC = true;<br>
- return ABIArgInfo::getExpand();<br>
+ return ABIArgInfo::getDirect();<br>
}<br>
}<br>
<br>
@@ -4242,7 +4229,7 @@ ABIArgInfo ARMABIInfo::classifyArgumentT<br>
getABIKind() == ARMABIInfo::AAPCS)<br>
ABIAlign = std::min(std::max(TyAlign, (uint64_t)4), (uint64_t)8);<br>
if (getContext().getTypeSizeInChars(Ty) > CharUnits::fromQuantity(64)) {<br>
- // Update Allocated GPRs<br>
+ // Update Allocated GPRs<br>
markAllocatedGPRs(1, 1);<br>
return ABIArgInfo::getIndirect(TyAlign, /*ByVal=*/true,<br>
/*Realign=*/TyAlign > ABIAlign);<br>
<br>
Modified: cfe/trunk/test/CodeGen/arm-aapcs-vfp.c<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/arm-aapcs-vfp.c?rev=208425&r1=208424&r2=208425&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/arm-aapcs-vfp.c?rev=208425&r1=208424&r2=208425&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/CodeGen/arm-aapcs-vfp.c (original)<br>
+++ cfe/trunk/test/CodeGen/arm-aapcs-vfp.c Fri May 9 11:21:39 2014<br>
@@ -27,14 +27,14 @@ struct homogeneous_struct {<br>
float f3;<br>
float f4;<br>
};<br>
-// CHECK: define arm_aapcs_vfpcc %struct.homogeneous_struct @test_struct(float %{{.*}}, float %{{.*}}, float %{{.*}}, float %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc %struct.homogeneous_struct @test_struct(%struct.homogeneous_struct %{{.*}})<br>
// CHECK64: define %struct.homogeneous_struct @test_struct(float %{{.*}}, float %{{.*}}, float %{{.*}}, float %{{.*}})<br>
extern struct homogeneous_struct struct_callee(struct homogeneous_struct);<br>
struct homogeneous_struct test_struct(struct homogeneous_struct arg) {<br>
return struct_callee(arg);<br>
}<br>
<br>
-// CHECK: define arm_aapcs_vfpcc void @test_struct_variadic(%struct.homogeneous_struct* {{.*}}, [4 x i32] %{{.*}}, ...)<br>
+// CHECK: define arm_aapcs_vfpcc void @test_struct_variadic(%struct.homogeneous_struct* {{.*}}, ...)<br>
struct homogeneous_struct test_struct_variadic(struct homogeneous_struct arg, ...) {<br>
return struct_callee(arg);<br>
}<br>
@@ -42,7 +42,7 @@ struct homogeneous_struct test_struct_va<br>
struct nested_array {<br>
double d[4];<br>
};<br>
-// CHECK: define arm_aapcs_vfpcc void @test_array(double %{{.*}}, double %{{.*}}, double %{{.*}}, double %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_array(%struct.nested_array %{{.*}})<br>
// CHECK64: define void @test_array(double %{{.*}}, double %{{.*}}, double %{{.*}}, double %{{.*}})<br>
extern void array_callee(struct nested_array);<br>
void test_array(struct nested_array arg) {<br>
@@ -50,7 +50,7 @@ void test_array(struct nested_array arg)<br>
}<br>
<br>
extern void complex_callee(__complex__ double);<br>
-// CHECK: define arm_aapcs_vfpcc void @test_complex(double %{{.*}}, double %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_complex({ double, double } %{{.*}})<br>
// CHECK64: define void @test_complex(double %{{.*}}, double %{{.*}})<br>
void test_complex(__complex__ double cd) {<br>
complex_callee(cd);<br>
@@ -58,7 +58,7 @@ void test_complex(__complex__ double cd)<br>
<br>
// Long double is the same as double on AAPCS, it should be homogeneous.<br>
extern void complex_long_callee(__complex__ long double);<br>
-// CHECK: define arm_aapcs_vfpcc void @test_complex_long(double %{{.*}}, double %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_complex_long({ double, double } %{{.*}})<br>
void test_complex_long(__complex__ long double cd) {<br>
complex_callee(cd);<br>
}<br>
@@ -72,7 +72,7 @@ struct big_struct {<br>
float f3;<br>
float f4;<br>
};<br>
-// CHECK: define arm_aapcs_vfpcc void @test_big([5 x i32] %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_big({ [5 x i32] } %{{.*}})<br>
// CHECK64: define void @test_big(%struct.big_struct* %{{.*}})<br>
// CHECK64: call void @llvm.memcpy<br>
// CHECK64: call void @big_callee(%struct.big_struct*<br>
@@ -88,7 +88,7 @@ struct heterogeneous_struct {<br>
float f1;<br>
int i2;<br>
};<br>
-// CHECK: define arm_aapcs_vfpcc void @test_hetero([2 x i32] %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_hetero({ [2 x i32] } %{{.*}})<br>
// CHECK64: define void @test_hetero(i64 %{{.*}})<br>
extern void hetero_callee(struct heterogeneous_struct);<br>
void test_hetero(struct heterogeneous_struct arg) {<br>
@@ -96,7 +96,7 @@ void test_hetero(struct heterogeneous_st<br>
}<br>
<br>
// Neon multi-vector types are homogeneous aggregates.<br>
-// CHECK: define arm_aapcs_vfpcc <16 x i8> @f0(<16 x i8> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc <16 x i8> @f0(%struct.int8x16x4_t %{{.*}})<br>
// CHECK64: define <16 x i8> @f0(<16 x i8> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}})<br>
int8x16_t f0(int8x16x4_t v4) {<br>
return vaddq_s8(v4.val[0], v4.val[3]);<br>
@@ -110,7 +110,7 @@ struct neon_struct {<br>
int32x2_t v3;<br>
int16x4_t v4;<br>
};<br>
-// CHECK: define arm_aapcs_vfpcc void @test_neon(<8 x i8> %{{.*}}, <8 x i8> %{{.*}}, <2 x i32> %{{.*}}, <4 x i16> %{{.*}})<br>
+// CHECK: define arm_aapcs_vfpcc void @test_neon(%struct.neon_struct %{{.*}})<br>
// CHECK64: define void @test_neon(<8 x i8> %{{.*}}, <8 x i8> %{{.*}}, <2 x i32> %{{.*}}, <4 x i16> %{{.*}})<br>
extern void neon_callee(struct neon_struct);<br>
void test_neon(struct neon_struct arg) {<br>
@@ -125,12 +125,12 @@ typedef struct { long long x; int y; } s<br>
// CHECK: define arm_aapcs_vfpcc void @test_vfp_stack_gpr_split_1(double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, i32 %j, i64 %k, i32 %l)<br>
void test_vfp_stack_gpr_split_1(double a, double b, double c, double d, double e, double f, double g, double h, double i, int j, long long k, int l) {}<br>
<br>
-// CHECK: define arm_aapcs_vfpcc void @test_vfp_stack_gpr_split_2(double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, i32 %j, [3 x i32], i64 %k.coerce0, i32 %k.coerce1)<br>
+// CHECK: define arm_aapcs_vfpcc void @test_vfp_stack_gpr_split_2(double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, i32 %j, [3 x i32], %struct.struct_long_long_int %k.coerce)<br>
void test_vfp_stack_gpr_split_2(double a, double b, double c, double d, double e, double f, double g, double h, double i, int j, struct_long_long_int k) {}<br>
<br>
-// CHECK: define arm_aapcs_vfpcc void @test_vfp_stack_gpr_split_3(%struct.struct_long_long_int* noalias sret %agg.result, double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, [3 x i32], i64 %k.coerce0, i32 %k.coerce1)<br>
+// CHECK: define arm_aapcs_vfpcc void @test_vfp_stack_gpr_split_3(%struct.struct_long_long_int* noalias sret %agg.result, double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, [3 x i32], %struct.struct_long_long_int
%k.coerce)<br>
struct_long_long_int test_vfp_stack_gpr_split_3(double a, double b, double c, double d, double e, double f, double g, double h, double i, struct_long_long_int k) {}<br>
<br>
typedef struct { int a; int b:4; int c; } struct_int_bitfield_int;<br>
-// CHECK: define arm_aapcs_vfpcc void @test_test_vfp_stack_gpr_split_bitfield(double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, i32 %j, i32 %k, [2 x i32], i32 %l.coerce0, i8 %l.coerce1, i32 %l.coerce2)<br>
+// CHECK: define arm_aapcs_vfpcc void @test_test_vfp_stack_gpr_split_bitfield(double %a, double %b, double %c, double %d, double %e, double %f, double %g, double %h, double %i, i32 %j, i32 %k, [2 x i32], %struct.struct_int_bitfield_int %l.coerce)<br>
void test_test_vfp_stack_gpr_split_bitfield(double a, double b, double c, double d, double e, double f, double g, double h, double i, int j, int k, struct_int_bitfield_int l) {}<br>
<br>
Modified: cfe/trunk/test/CodeGen/arm-homogenous.c<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/arm-homogenous.c?rev=208425&r1=208424&r2=208425&view=diff" target="_blank">
http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/arm-homogenous.c?rev=208425&r1=208424&r2=208425&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/CodeGen/arm-homogenous.c (original)<br>
+++ cfe/trunk/test/CodeGen/arm-homogenous.c Fri May 9 11:21:39 2014<br>
@@ -22,7 +22,7 @@ extern union_with_first_floats returns_u<br>
void test_union_with_first_floats(void) {<br>
takes_union_with_first_floats(g_u_f);<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_first_floats([4 x i32])<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_first_floats({ [4 x i32] })<br>
<br>
void test_return_union_with_first_floats(void) {<br>
g_u_f = returns_union_with_first_floats();<br>
@@ -42,7 +42,7 @@ extern union_with_non_first_floats retur<br>
void test_union_with_non_first_floats(void) {<br>
takes_union_with_non_first_floats(g_u_nf_f);<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_non_first_floats([4 x i32])<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_non_first_floats({ [4 x i32] })<br>
<br>
void test_return_union_with_non_first_floats(void) {<br>
g_u_nf_f = returns_union_with_non_first_floats();<br>
@@ -62,7 +62,7 @@ extern struct_with_union_with_first_floa<br>
void test_struct_with_union_with_first_floats(void) {<br>
takes_struct_with_union_with_first_floats(g_s_f);<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_union_with_first_floats([5 x i32])<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_union_with_first_floats({ [5 x i32] })<br>
<br>
void test_return_struct_with_union_with_first_floats(void) {<br>
g_s_f = returns_struct_with_union_with_first_floats();<br>
@@ -82,7 +82,7 @@ extern struct_with_union_with_non_first_<br>
void test_struct_with_union_with_non_first_floats(void) {<br>
takes_struct_with_union_with_non_first_floats(g_s_nf_f);<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_union_with_non_first_floats([5 x i32])<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_union_with_non_first_floats({ [5 x i32] })<br>
<br>
void test_return_struct_with_union_with_non_first_floats(void) {<br>
g_s_nf_f = returns_struct_with_union_with_non_first_floats();<br>
@@ -108,9 +108,9 @@ extern struct_with_fundamental_elems ret<br>
<br>
void test_struct_with_fundamental_elems(void) {<br>
takes_struct_with_fundamental_elems(g_s);<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_fundamental_elems(float {{.*}}, float {{.*}}, float{{.*}}, float {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_fundamental_elems(%struct.struct_with_fundamental_elems {{.*}})<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_fundamental_elems(float, float, float, float)<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_fundamental_elems(%struct.struct_with_fundamental_elems)<br>
<br>
void test_return_struct_with_fundamental_elems(void) {<br>
g_s = returns_struct_with_fundamental_elems();<br>
@@ -129,9 +129,9 @@ extern struct_with_array returns_struct_<br>
<br>
void test_struct_with_array(void) {<br>
takes_struct_with_array(g_s_a);<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_array(float {{.*}}, float {{.*}}, float {{.*}}, float {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_array(%struct.struct_with_array {{.*}})<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_array(float, float, float, float)<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_struct_with_array(%struct.struct_with_array)<br>
<br>
void test_return_struct_with_array(void) {<br>
g_s_a = returns_struct_with_array();<br>
@@ -151,9 +151,9 @@ extern union_with_struct_with_fundamenta<br>
<br>
void test_union_with_struct_with_fundamental_elems(void) {<br>
takes_union_with_struct_with_fundamental_elems(g_u_s_fe);<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_union_with_struct_with_fundamental_elems(float {{.*}}, float {{.*}}, float {{.*}}, float {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_union_with_struct_with_fundamental_elems(%union.union_with_struct_with_fundamental_elems {{.*}})<br>
}<br>
-// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_struct_with_fundamental_elems(float, float, float, float)<br>
+// CHECK: declare arm_aapcs_vfpcc void @takes_union_with_struct_with_fundamental_elems(%union.union_with_struct_with_fundamental_elems)<br>
<br>
void test_return_union_with_struct_with_fundamental_elems(void) {<br>
g_u_s_fe = returns_union_with_struct_with_fundamental_elems();<br>
@@ -174,7 +174,7 @@ struct_of_four_doubles g_s4d;<br>
<br>
void test_struct_of_four_doubles(void) {<br>
// CHECK: test_struct_of_four_doubles<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_struct_of_four_doubles(double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, [6 x float] undef, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_struct_of_four_doubles(double {{.*}}, %struct.struct_of_four_doubles {{.*}}, %struct.struct_of_four_doubles {{.*}}, double {{.*}})<br>
// CHECK64: test_struct_of_four_doubles<br>
// CHECK64: call void @takes_struct_of_four_doubles(double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, [3 x float] undef, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}})<br>
// CHECK64-AAPCS: test_struct_of_four_doubles<br>
@@ -186,14 +186,14 @@ extern void takes_struct_of_four_doubles<br>
<br>
void test_struct_of_four_doubles_variadic(void) {<br>
// CHECK: test_struct_of_four_doubles_variadic<br>
-// CHECK: call arm_aapcs_vfpcc void (double, [4 x i64], [4 x i64], double, ...)* @takes_struct_of_four_doubles_variadic(double {{.*}}, [4 x i64] {{.*}}, [4 x i64] {{.*}}, double {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void (double, { [4 x i64] }, { [4 x i64] }, double, ...)* @takes_struct_of_four_doubles_variadic(double {{.*}}, { [4 x i64] } {{.*}}, { [4 x i64] } {{.*}}, double {{.*}})<br>
takes_struct_of_four_doubles_variadic(3.0, g_s4d, g_s4d, 4.0);<br>
}<br>
<br>
extern void takes_struct_with_backfill(float f1, double a, float f2, struct_of_four_doubles b, struct_of_four_doubles c, double d);<br>
void test_struct_with_backfill(void) {<br>
// CHECK: test_struct_with_backfill<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_backfill(float {{.*}}, double {{.*}}, float {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, [4 x float] undef, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}}, double {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_struct_with_backfill(float {{.*}}, double {{.*}}, float {{.*}}, %struct.struct_of_four_doubles {{.*}}, %struct.struct_of_four_doubles {{.*}}, double {{.*}})<br>
takes_struct_with_backfill(3.0, 3.1, 3.2, g_s4d, g_s4d, 4.0);<br>
}<br>
<br>
@@ -210,7 +210,7 @@ struct_of_vecs g_vec;<br>
<br>
void test_struct_of_vecs(void) {<br>
// CHECK: test_struct_of_vecs<br>
-// CHECK: call arm_aapcs_vfpcc void @takes_struct_of_vecs(double {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, [6 x float] undef, <8 x i8> {{.*}}, <4 x i16> {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, double {{.*}})<br>
+// CHECK: call arm_aapcs_vfpcc void @takes_struct_of_vecs(double {{.*}}, %struct.struct_of_vecs {{.*}}, %struct.struct_of_vecs {{.*}}, double {{.*}})<br>
// CHECK64: test_struct_of_vecs<br>
// CHECK64: call void @takes_struct_of_vecs(double {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, [3 x float] undef, <8 x i8> {{.*}}, <4 x i16> {{.*}}, <8 x i8> {{.*}}, <4 x i16> {{.*}}, double {{.*}})<br>
// CHECK64-AAPCS: test_struct_of_vecs<br>
<br>
<br>
_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu" target="_blank">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
</blockquote>
</div>
<br>
</div>
</div>
</blockquote>
</div>
<br>
</div>
</div>
</div>
</div>
</div></div></span><br>
<font face="Arial" color="Black">-- IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents
to any other person, use it for any purpose, or store or copy the information in any medium. Thank you.<br>
<br>
ARM Limited, Registered office 110 Fulbourn Road, Cambridge CB1 9NJ, Registered in England & Wales, Company No: 2557590<br>
ARM Holdings plc, Registered office 110 Fulbourn Road, Cambridge CB1 9NJ, Registered in England & Wales, Company No: 2548782<br>
</font>
</div>
</blockquote></div><br></div>