mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-03 22:01:56 +00:00
Eliminate the restriction that the array size in an alloca must be i32.
This will help reduce the amount of casting required on 64-bit targets. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104911 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5ddb087f7f
commit
f75a7d3fbf
docs
lib
test/CodeGen/X86
@ -4239,7 +4239,7 @@ Instruction</a> </div>
|
||||
|
||||
<h5>Syntax:</h5>
|
||||
<pre>
|
||||
<result> = alloca <type>[, i32 <NumElements>][, align <alignment>] <i>; yields {type*}:result</i>
|
||||
<result> = alloca <type>[, <ty> <NumElements>][, align <alignment>] <i>; yields {type*}:result</i>
|
||||
</pre>
|
||||
|
||||
<h5>Overview:</h5>
|
||||
|
@ -3791,8 +3791,8 @@ int LLParser::ParseAlloc(Instruction *&Inst, PerFunctionState &PFS,
|
||||
}
|
||||
}
|
||||
|
||||
if (Size && !Size->getType()->isIntegerTy(32))
|
||||
return Error(SizeLoc, "element count must be i32");
|
||||
if (Size && !Size->getType()->isIntegerTy())
|
||||
return Error(SizeLoc, "element count must have integer type");
|
||||
|
||||
if (isAlloca) {
|
||||
Inst = new AllocaInst(Ty, Size, Alignment);
|
||||
@ -3801,6 +3801,8 @@ int LLParser::ParseAlloc(Instruction *&Inst, PerFunctionState &PFS,
|
||||
|
||||
// Autoupgrade old malloc instruction to malloc call.
|
||||
// FIXME: Remove in LLVM 3.0.
|
||||
if (Size && !Size->getType()->isIntegerTy(32))
|
||||
return Error(SizeLoc, "element count must be i32");
|
||||
const Type *IntPtrTy = Type::getInt32Ty(Context);
|
||||
Constant *AllocSize = ConstantExpr::getSizeOf(Ty);
|
||||
AllocSize = ConstantExpr::getTruncOrBitCast(AllocSize, IntPtrTy);
|
||||
|
@ -2643,12 +2643,13 @@ void SelectionDAGBuilder::visitAlloca(const AllocaInst &I) {
|
||||
|
||||
SDValue AllocSize = getValue(I.getArraySize());
|
||||
|
||||
AllocSize = DAG.getNode(ISD::MUL, getCurDebugLoc(), AllocSize.getValueType(),
|
||||
AllocSize,
|
||||
DAG.getConstant(TySize, AllocSize.getValueType()));
|
||||
|
||||
EVT IntPtr = TLI.getPointerTy();
|
||||
AllocSize = DAG.getZExtOrTrunc(AllocSize, getCurDebugLoc(), IntPtr);
|
||||
if (AllocSize.getValueType() != IntPtr)
|
||||
AllocSize = DAG.getZExtOrTrunc(AllocSize, getCurDebugLoc(), IntPtr);
|
||||
|
||||
AllocSize = DAG.getNode(ISD::MUL, getCurDebugLoc(), IntPtr,
|
||||
AllocSize,
|
||||
DAG.getConstant(TySize, IntPtr));
|
||||
|
||||
// Handle alignment. If the requested alignment is less than or equal to
|
||||
// the stack alignment, ignore it. If the size is greater than or equal to
|
||||
|
@ -828,8 +828,8 @@ static Value *getAISize(LLVMContext &Context, Value *Amt) {
|
||||
else {
|
||||
assert(!isa<BasicBlock>(Amt) &&
|
||||
"Passed basic block into allocation size parameter! Use other ctor");
|
||||
assert(Amt->getType()->isIntegerTy(32) &&
|
||||
"Allocation array size is not a 32-bit integer!");
|
||||
assert(Amt->getType()->isIntegerTy() &&
|
||||
"Allocation array size is not an integer!");
|
||||
}
|
||||
return Amt;
|
||||
}
|
||||
|
@ -1371,8 +1371,8 @@ void Verifier::visitAllocaInst(AllocaInst &AI) {
|
||||
&AI);
|
||||
Assert1(PTy->getElementType()->isSized(), "Cannot allocate unsized type",
|
||||
&AI);
|
||||
Assert1(AI.getArraySize()->getType()->isIntegerTy(32),
|
||||
"Alloca array size must be i32", &AI);
|
||||
Assert1(AI.getArraySize()->getType()->isIntegerTy(),
|
||||
"Alloca array size must have integer type", &AI);
|
||||
visitInstruction(AI);
|
||||
}
|
||||
|
||||
|
15
test/CodeGen/X86/alloca-align-rounding-32.ll
Normal file
15
test/CodeGen/X86/alloca-align-rounding-32.ll
Normal file
@ -0,0 +1,15 @@
|
||||
; RUN: llc < %s -march=x86 -mtriple=i686-apple-darwin | grep and | count 1
|
||||
|
||||
declare void @bar(<2 x i64>* %n)
|
||||
|
||||
define void @foo(i32 %h) {
|
||||
%p = alloca <2 x i64>, i32 %h
|
||||
call void @bar(<2 x i64>* %p)
|
||||
ret void
|
||||
}
|
||||
|
||||
define void @foo2(i32 %h) {
|
||||
%p = alloca <2 x i64>, i32 %h, align 32
|
||||
call void @bar(<2 x i64>* %p)
|
||||
ret void
|
||||
}
|
@ -1,16 +1,15 @@
|
||||
; RUN: llc < %s -march=x86 -mtriple=i686-apple-darwin | grep and | count 1
|
||||
; RUN: llc < %s -march=x86-64 -mtriple=i686-pc-linux | grep and | count 1
|
||||
|
||||
declare void @bar(<2 x i64>* %n)
|
||||
|
||||
define void @foo(i32 %h) {
|
||||
%p = alloca <2 x i64>, i32 %h
|
||||
define void @foo(i64 %h) {
|
||||
%p = alloca <2 x i64>, i64 %h
|
||||
call void @bar(<2 x i64>* %p)
|
||||
ret void
|
||||
}
|
||||
|
||||
define void @foo2(i32 %h) {
|
||||
%p = alloca <2 x i64>, i32 %h, align 32
|
||||
define void @foo2(i64 %h) {
|
||||
%p = alloca <2 x i64>, i64 %h, align 32
|
||||
call void @bar(<2 x i64>* %p)
|
||||
ret void
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user