mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
Codegen support for arbitrary vector getelementptrs.
llvm-svn: 167830
This commit is contained in:
parent
834534bbe1
commit
7c55936d5f
@ -3137,12 +3137,12 @@ void SelectionDAGBuilder::visitGetElementPtr(const User &I) {
|
||||
OI != E; ++OI) {
|
||||
const Value *Idx = *OI;
|
||||
if (StructType *StTy = dyn_cast<StructType>(Ty)) {
|
||||
unsigned Field = cast<ConstantInt>(Idx)->getZExtValue();
|
||||
unsigned Field = cast<Constant>(Idx)->getUniqueInteger().getZExtValue();
|
||||
if (Field) {
|
||||
// N = N + Offset
|
||||
uint64_t Offset = TD->getStructLayout(StTy)->getElementOffset(Field);
|
||||
N = DAG.getNode(ISD::ADD, getCurDebugLoc(), N.getValueType(), N,
|
||||
DAG.getIntPtrConstant(Offset));
|
||||
DAG.getConstant(Offset, N.getValueType()));
|
||||
}
|
||||
|
||||
Ty = StTy->getElementType(Field);
|
||||
@ -3187,7 +3187,7 @@ void SelectionDAGBuilder::visitGetElementPtr(const User &I) {
|
||||
N.getValueType(), IdxN,
|
||||
DAG.getConstant(Amt, IdxN.getValueType()));
|
||||
} else {
|
||||
SDValue Scale = DAG.getConstant(ElementSize, TLI.getPointerTy());
|
||||
SDValue Scale = DAG.getConstant(ElementSize, IdxN.getValueType());
|
||||
IdxN = DAG.getNode(ISD::MUL, getCurDebugLoc(),
|
||||
N.getValueType(), IdxN, Scale);
|
||||
}
|
||||
|
@ -152,3 +152,8 @@ define void @splat_i4(%i4* %P, %i4* %Q, i32 %X) {
|
||||
store %i4 %R, %i4* %P
|
||||
ret void
|
||||
}
|
||||
|
||||
define <2 x i32*> @vector_gep(<2 x [3 x {i32, i32}]*> %a) {
|
||||
%w = getelementptr <2 x [3 x {i32, i32}]*> %a, <2 x i32> <i32 1, i32 2>, <2 x i32> <i32 2, i32 3>, <2 x i32> <i32 1, i32 1>
|
||||
ret <2 x i32*> %w
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user