mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-30 17:33:24 +00:00
Added an instruction and constant expression for the extractelement
operation. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25176 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
eb7116bb08
commit
49b78a5696
@ -521,6 +521,8 @@ protected:
|
||||
Constant *C1, Constant *C2, Constant *C3);
|
||||
static Constant *getGetElementPtrTy(const Type *Ty, Constant *C,
|
||||
const std::vector<Value*> &IdxList);
|
||||
static Constant *getExtractElementTy(const Type *Ty, Constant *Val,
|
||||
Constant *Idx);
|
||||
|
||||
public:
|
||||
// Static methods to construct a ConstantExpr of different kinds. Note that
|
||||
@ -588,6 +590,10 @@ public:
|
||||
static Constant *getGetElementPtr(Constant *C,
|
||||
const std::vector<Value*> &IdxList);
|
||||
|
||||
/// Extractelement form.
|
||||
///
|
||||
static Constant *getExtractElement(Constant *Val, Constant *Idx);
|
||||
|
||||
/// isNullValue - Return true if this is the value that would be returned by
|
||||
/// getNullValue.
|
||||
virtual bool isNullValue() const { return false; }
|
||||
|
@ -135,7 +135,8 @@ HANDLE_OTHER_INST(34, Select , SelectInst ) // select instruction
|
||||
HANDLE_OTHER_INST(35, UserOp1, Instruction) // May be used internally in a pass
|
||||
HANDLE_OTHER_INST(36, UserOp2, Instruction)
|
||||
HANDLE_OTHER_INST(37, VAArg , VAArgInst ) // vaarg instruction
|
||||
LAST_OTHER_INST(37)
|
||||
HANDLE_OTHER_INST(38, ExtractElement, ExtractElementInst) // extract packed element
|
||||
LAST_OTHER_INST(38)
|
||||
|
||||
#undef FIRST_TERM_INST
|
||||
#undef HANDLE_TERM_INST
|
||||
|
@ -717,6 +717,52 @@ public:
|
||||
}
|
||||
};
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// ExtractElementInst Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
/// ExtractElementInst - This instruction extracts a single (scalar)
|
||||
/// element from a PackedType value
|
||||
///
|
||||
class ExtractElementInst : public Instruction {
|
||||
Use Ops[2];
|
||||
ExtractElementInst(const ExtractElementInst &EI) :
|
||||
Instruction(EI.getType(), ExtractElement, Ops, 2) {
|
||||
Ops[0].init(EI.Ops[0], this);
|
||||
Ops[1].init(EI.Ops[1], this);
|
||||
}
|
||||
|
||||
public:
|
||||
ExtractElementInst(Value *Val, Value *Index,
|
||||
const std::string &Name = "", Instruction *InsertBefore = 0);
|
||||
ExtractElementInst(Value *Val, Value *Index,
|
||||
const std::string &Name, BasicBlock *InsertAtEnd);
|
||||
|
||||
virtual ExtractElementInst *clone() const;
|
||||
|
||||
virtual bool mayWriteToMemory() const { return false; }
|
||||
|
||||
/// Transparently provide more efficient getOperand methods.
|
||||
Value *getOperand(unsigned i) const {
|
||||
assert(i < 2 && "getOperand() out of range!");
|
||||
return Ops[i];
|
||||
}
|
||||
void setOperand(unsigned i, Value *Val) {
|
||||
assert(i < 2 && "setOperand() out of range!");
|
||||
Ops[i] = Val;
|
||||
}
|
||||
unsigned getNumOperands() const { return 2; }
|
||||
|
||||
// Methods for support type inquiry through isa, cast, and dyn_cast:
|
||||
static inline bool classof(const ExtractElementInst *) { return true; }
|
||||
static inline bool classof(const Instruction *I) {
|
||||
return I->getOpcode() == Instruction::ExtractElement;
|
||||
}
|
||||
static inline bool classof(const Value *V) {
|
||||
return isa<Instruction>(V) && classof(cast<Instruction>(V));
|
||||
}
|
||||
};
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// PHINode Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
@ -175,6 +175,7 @@ public:
|
||||
RetTy visitCallInst(CallInst &I) { DELEGATE(Instruction); }
|
||||
RetTy visitShiftInst(ShiftInst &I) { DELEGATE(Instruction); }
|
||||
RetTy visitVAArgInst(VAArgInst &I) { DELEGATE(Instruction); }
|
||||
RetTy visitExtractElementInst(ExtractElementInst &I) { DELEGATE(Instruction); }
|
||||
|
||||
// Next level propagators... if the user does not overload a specific
|
||||
// instruction type, they can overload one of these to get the whole class
|
||||
|
Loading…
Reference in New Issue
Block a user