mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-27 14:34:58 +00:00
Implemented shl, shl, & load instructions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@161 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
71496b3b50
commit
027dcc5b22
@ -19,10 +19,10 @@ public:
|
||||
assert(Ty->isPointerType() && "Can't allocate a non pointer type!");
|
||||
|
||||
if (ArraySize) {
|
||||
// Make sure they didn't try to specify a size for !(unsized array) type...
|
||||
// Make sure they didn't try to specify a size for !(unsized array) type
|
||||
assert((getType()->getValueType()->isArrayType() &&
|
||||
((const ArrayType*)getType()->getValueType())->isUnsized()) &&
|
||||
"Trying to allocate something other than unsized array, with size!");
|
||||
"Trying to allocate something other than unsized array, with size!");
|
||||
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use(ArraySize, this));
|
||||
@ -37,10 +37,11 @@ public:
|
||||
virtual Instruction *clone() const = 0;
|
||||
};
|
||||
|
||||
|
||||
class MallocInst : public AllocationInst {
|
||||
public:
|
||||
MallocInst(const Type *Ty, Value *ArraySize = 0, const string &Name = "")
|
||||
: AllocationInst(Ty, ArraySize, Instruction::Malloc, Name) {}
|
||||
: AllocationInst(Ty, ArraySize, Malloc, Name) {}
|
||||
|
||||
virtual Instruction *clone() const {
|
||||
return new MallocInst(getType(), Operands.size() ? Operands[1] : 0);
|
||||
@ -49,10 +50,11 @@ public:
|
||||
virtual const char *getOpcodeName() const { return "malloc"; }
|
||||
};
|
||||
|
||||
|
||||
class AllocaInst : public AllocationInst {
|
||||
public:
|
||||
AllocaInst(const Type *Ty, Value *ArraySize = 0, const string &Name = "")
|
||||
: AllocationInst(Ty, ArraySize, Instruction::Alloca, Name) {}
|
||||
: AllocationInst(Ty, ArraySize, Alloca, Name) {}
|
||||
|
||||
virtual Instruction *clone() const {
|
||||
return new AllocaInst(getType(), Operands.size() ? Operands[1] : 0);
|
||||
@ -62,20 +64,41 @@ public:
|
||||
};
|
||||
|
||||
|
||||
|
||||
class FreeInst : public Instruction {
|
||||
public:
|
||||
FreeInst(Value *Ptr, const string &Name = "")
|
||||
: Instruction(Type::VoidTy, Instruction::Free, Name) {
|
||||
: Instruction(Type::VoidTy, Free, Name) {
|
||||
assert(Ptr->getType()->isPointerType() && "Can't free nonpointer!");
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use(Ptr, this));
|
||||
}
|
||||
inline ~FreeInst() {}
|
||||
|
||||
virtual Instruction *clone() const { return new FreeInst(Operands[0]); }
|
||||
|
||||
virtual const char *getOpcodeName() const { return "free"; }
|
||||
};
|
||||
|
||||
|
||||
class LoadInst : public Instruction {
|
||||
LoadInst(const LoadInst &LI) : Instruction(LI.getType(), Load) {
|
||||
Operands.reserve(LI.Operands.size());
|
||||
for (unsigned i = 0, E = LI.Operands.size(); i != E; ++i)
|
||||
Operands.push_back(Use(LI.Operands[i], this));
|
||||
}
|
||||
public:
|
||||
LoadInst(Value *Ptr, const vector<ConstPoolVal*> &Idx,
|
||||
const string &Name = "");
|
||||
virtual Instruction *clone() const { return new LoadInst(*this); }
|
||||
virtual const char *getOpcodeName() const { return "load"; }
|
||||
|
||||
// getIndexedType - Returns the type of the element that would be loaded with
|
||||
// a load instruction with the specified parameters.
|
||||
//
|
||||
// A null type is returned if the indices are invalid for the specified
|
||||
// pointer type.
|
||||
//
|
||||
static const Type *getIndexedType(const Type *Ptr,
|
||||
const vector<ConstPoolVal*> &);
|
||||
};
|
||||
|
||||
#endif // LLVM_IMEMORY_H
|
||||
|
@ -12,30 +12,6 @@
|
||||
#include "llvm/Method.h"
|
||||
#include <vector>
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// CastInst Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// CastInst - This function represents a cast from Operand[0] to the type of
|
||||
// the instruction (i->getType()).
|
||||
//
|
||||
class CastInst : public Instruction {
|
||||
CastInst(const CastInst &CI) : Instruction(CI.getType(), Cast) {
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use((Value*)CI.getOperand(0), this));
|
||||
}
|
||||
public:
|
||||
CastInst(Value *S, const Type *Ty, const string &Name = "")
|
||||
: Instruction(Ty, Cast, Name) {
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use(S, this));
|
||||
}
|
||||
|
||||
virtual Instruction *clone() const { return new CastInst(*this); }
|
||||
virtual const char *getOpcodeName() const { return "cast"; }
|
||||
};
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// PHINode Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
@ -80,6 +56,30 @@ public:
|
||||
};
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// CastInst Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// CastInst - This class represents a cast from Operand[0] to the type of
|
||||
// the instruction (i->getType()).
|
||||
//
|
||||
class CastInst : public Instruction {
|
||||
CastInst(const CastInst &CI) : Instruction(CI.getType(), Cast) {
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use(Operands[0], this));
|
||||
}
|
||||
public:
|
||||
CastInst(Value *S, const Type *Ty, const string &Name = "")
|
||||
: Instruction(Ty, Cast, Name) {
|
||||
Operands.reserve(1);
|
||||
Operands.push_back(Use(S, this));
|
||||
}
|
||||
|
||||
virtual Instruction *clone() const { return new CastInst(*this); }
|
||||
virtual const char *getOpcodeName() const { return "cast"; }
|
||||
};
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// MethodArgument Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
@ -127,4 +127,32 @@ public:
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// ShiftInst Class
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
// ShiftInst - This class represents left and right shift instructions.
|
||||
//
|
||||
class ShiftInst : public Instruction {
|
||||
ShiftInst(const ShiftInst &CI) : Instruction(CI.getType(), CI.getOpcode()) {
|
||||
Operands.reserve(2);
|
||||
Operands.push_back(Use(Operands[0], this));
|
||||
Operands.push_back(Use(Operands[1], this));
|
||||
}
|
||||
public:
|
||||
ShiftInst(OtherOps Opcode, Value *S, Value *SA, const string &Name = "")
|
||||
: Instruction(S->getType(), Opcode, Name) {
|
||||
assert((Opcode == Shl || Opcode == Shr) && "ShiftInst Opcode invalid!");
|
||||
Operands.reserve(2);
|
||||
Operands.push_back(Use(S, this));
|
||||
Operands.push_back(Use(SA, this));
|
||||
}
|
||||
|
||||
virtual Instruction *clone() const { return new ShiftInst(*this); }
|
||||
virtual const char *getOpcodeName() const {
|
||||
return getOpcode() == Shl ? "shl" : "shr";
|
||||
}
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -308,26 +308,26 @@ static void yy_fatal_error YY_PROTO(( yyconst char msg[] ));
|
||||
*yy_cp = '\0'; \
|
||||
yy_c_buf_p = yy_cp;
|
||||
|
||||
#define YY_NUM_RULES 59
|
||||
#define YY_END_OF_BUFFER 60
|
||||
static yyconst short int yy_acclist[114] =
|
||||
#define YY_NUM_RULES 61
|
||||
#define YY_END_OF_BUFFER 62
|
||||
static yyconst short int yy_acclist[116] =
|
||||
{ 0,
|
||||
60, 58, 59, 57, 58, 59, 57, 59, 58, 59,
|
||||
58, 59, 58, 59, 8, 58, 59, 53, 58, 59,
|
||||
1, 58, 59, 58, 59, 58, 59, 58, 59, 58,
|
||||
59, 58, 59, 58, 59, 58, 59, 58, 59, 58,
|
||||
59, 58, 59, 58, 59, 58, 59, 58, 59, 58,
|
||||
59, 58, 59, 58, 59, 58, 59, 51, 50, 55,
|
||||
54, 53, 1, 9, 41, 28, 52, 50, 56, 29,
|
||||
32, 3, 16, 31, 24, 25, 33, 40, 30, 11,
|
||||
26, 27, 45, 46, 18, 4, 22, 17, 10, 2,
|
||||
5, 20, 23, 12, 35, 39, 37, 38, 36, 34,
|
||||
62, 60, 61, 59, 60, 61, 59, 61, 60, 61,
|
||||
60, 61, 60, 61, 8, 60, 61, 55, 60, 61,
|
||||
1, 60, 61, 60, 61, 60, 61, 60, 61, 60,
|
||||
61, 60, 61, 60, 61, 60, 61, 60, 61, 60,
|
||||
61, 60, 61, 60, 61, 60, 61, 60, 61, 60,
|
||||
61, 60, 61, 60, 61, 60, 61, 53, 52, 57,
|
||||
56, 55, 1, 9, 43, 36, 54, 52, 58, 25,
|
||||
28, 3, 16, 27, 24, 37, 29, 42, 40, 41,
|
||||
26, 11, 38, 39, 47, 48, 18, 4, 22, 17,
|
||||
10, 2, 5, 20, 23, 12, 31, 35, 33, 34,
|
||||
|
||||
14, 47, 13, 19, 44, 21, 43, 42, 15, 6,
|
||||
48, 49, 7
|
||||
32, 30, 14, 49, 13, 19, 46, 21, 45, 44,
|
||||
15, 6, 50, 51, 7
|
||||
} ;
|
||||
|
||||
static yyconst short int yy_accept[200] =
|
||||
static yyconst short int yy_accept[202] =
|
||||
{ 0,
|
||||
1, 1, 1, 2, 4, 7, 9, 11, 13, 15,
|
||||
18, 21, 24, 26, 28, 30, 32, 34, 36, 38,
|
||||
@ -340,17 +340,18 @@ static yyconst short int yy_accept[200] =
|
||||
70, 71, 71, 71, 71, 71, 71, 71, 72, 72,
|
||||
73, 73, 73, 73, 73, 73, 74, 74, 74, 74,
|
||||
|
||||
74, 75, 76, 77, 77, 78, 79, 79, 79, 79,
|
||||
79, 80, 80, 80, 80, 80, 80, 80, 80, 80,
|
||||
80, 80, 81, 82, 83, 83, 83, 83, 83, 84,
|
||||
84, 84, 84, 85, 86, 86, 86, 86, 86, 86,
|
||||
86, 86, 86, 86, 86, 87, 88, 88, 89, 89,
|
||||
89, 90, 90, 91, 91, 91, 92, 93, 93, 93,
|
||||
94, 94, 94, 95, 96, 97, 98, 99, 100, 101,
|
||||
102, 103, 103, 104, 105, 105, 106, 106, 107, 107,
|
||||
107, 108, 108, 109, 110, 111, 111, 111, 111, 112,
|
||||
112, 113, 113, 113, 113, 113, 113, 114, 114
|
||||
74, 75, 76, 77, 77, 78, 79, 79, 79, 80,
|
||||
80, 81, 81, 82, 82, 82, 82, 82, 82, 82,
|
||||
82, 82, 82, 82, 83, 84, 85, 85, 85, 85,
|
||||
85, 86, 86, 86, 86, 87, 88, 88, 88, 88,
|
||||
88, 88, 88, 88, 88, 88, 88, 89, 90, 90,
|
||||
91, 91, 91, 92, 92, 93, 93, 93, 94, 95,
|
||||
95, 95, 96, 96, 96, 97, 98, 99, 100, 101,
|
||||
102, 103, 104, 105, 105, 106, 107, 107, 108, 108,
|
||||
109, 109, 109, 110, 110, 111, 112, 113, 113, 113,
|
||||
113, 114, 114, 115, 115, 115, 115, 115, 115, 116,
|
||||
|
||||
116
|
||||
} ;
|
||||
|
||||
static yyconst int yy_ec[256] =
|
||||
@ -393,61 +394,61 @@ static yyconst int yy_meta[33] =
|
||||
4, 4
|
||||
} ;
|
||||
|
||||
static yyconst short int yy_base[204] =
|
||||
static yyconst short int yy_base[206] =
|
||||
{ 0,
|
||||
0, 0, 391, 392, 392, 392, 0, 381, 26, 381,
|
||||
0, 0, 395, 396, 396, 396, 0, 385, 26, 385,
|
||||
27, 0, 28, 40, 29, 35, 34, 42, 30, 38,
|
||||
56, 60, 52, 55, 61, 81, 65, 104, 63, 384,
|
||||
378, 392, 0, 378, 377, 376, 69, 0, 32, 72,
|
||||
374, 78, 71, 373, 91, 89, 73, 76, 92, 95,
|
||||
56, 60, 52, 55, 61, 81, 65, 104, 63, 388,
|
||||
382, 396, 0, 382, 381, 380, 69, 0, 32, 72,
|
||||
378, 78, 71, 377, 91, 89, 73, 76, 92, 95,
|
||||
98, 99, 108, 110, 111, 113, 118, 117, 121, 119,
|
||||
123, 124, 129, 126, 134, 136, 137, 139, 135, 372,
|
||||
140, 144, 146, 152, 147, 154, 156, 392, 0, 372,
|
||||
370, 157, 158, 162, 164, 155, 167, 369, 176, 368,
|
||||
170, 180, 177, 184, 181, 367, 187, 185, 186, 189,
|
||||
123, 124, 129, 126, 134, 140, 136, 139, 135, 376,
|
||||
144, 137, 146, 147, 156, 158, 155, 396, 0, 376,
|
||||
374, 159, 161, 163, 166, 162, 168, 373, 172, 372,
|
||||
176, 178, 182, 183, 184, 371, 185, 187, 189, 193,
|
||||
|
||||
366, 365, 364, 195, 363, 362, 196, 216, 197, 201,
|
||||
361, 198, 199, 203, 204, 206, 207, 212, 208, 228,
|
||||
221, 360, 359, 358, 231, 219, 235, 236, 357, 237,
|
||||
238, 239, 356, 355, 240, 242, 243, 245, 251, 253,
|
||||
256, 246, 258, 263, 354, 353, 260, 352, 268, 269,
|
||||
351, 271, 350, 274, 275, 349, 348, 277, 278, 347,
|
||||
280, 279, 346, 345, 344, 339, 334, 329, 324, 323,
|
||||
321, 287, 320, 319, 282, 317, 288, 315, 289, 292,
|
||||
314, 293, 312, 248, 211, 297, 295, 305, 210, 299,
|
||||
172, 307, 303, 306, 311, 313, 74, 392, 335, 338,
|
||||
370, 369, 368, 196, 367, 366, 186, 206, 365, 198,
|
||||
364, 199, 363, 201, 202, 207, 209, 210, 211, 218,
|
||||
221, 223, 222, 362, 361, 360, 231, 225, 234, 230,
|
||||
359, 237, 238, 239, 358, 357, 241, 242, 245, 243,
|
||||
248, 256, 257, 246, 258, 266, 356, 355, 268, 354,
|
||||
253, 260, 353, 269, 352, 272, 273, 351, 350, 276,
|
||||
278, 349, 280, 281, 348, 347, 346, 345, 344, 339,
|
||||
334, 329, 323, 283, 322, 321, 285, 319, 288, 317,
|
||||
286, 293, 316, 291, 315, 314, 312, 295, 296, 298,
|
||||
311, 301, 200, 305, 306, 308, 310, 313, 74, 396,
|
||||
|
||||
341, 346, 53
|
||||
335, 338, 341, 346, 53
|
||||
} ;
|
||||
|
||||
static yyconst short int yy_def[204] =
|
||||
static yyconst short int yy_def[206] =
|
||||
{ 0,
|
||||
198, 1, 198, 198, 198, 198, 199, 200, 201, 198,
|
||||
200, 202, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 199,
|
||||
200, 198, 203, 198, 198, 198, 200, 202, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 198, 203, 198,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 1, 200, 200, 200, 200, 201, 202, 203, 200,
|
||||
202, 204, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 201,
|
||||
202, 200, 205, 200, 200, 200, 202, 204, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 200, 205, 200,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 0, 198, 198,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 202,
|
||||
202, 202, 202, 202, 202, 202, 202, 202, 202, 0,
|
||||
|
||||
198, 198, 198
|
||||
200, 200, 200, 200, 200
|
||||
} ;
|
||||
|
||||
static yyconst short int yy_nxt[425] =
|
||||
static yyconst short int yy_nxt[429] =
|
||||
{ 0,
|
||||
4, 5, 6, 7, 8, 9, 10, 11, 4, 12,
|
||||
13, 14, 15, 16, 17, 18, 19, 8, 20, 21,
|
||||
@ -465,88 +466,88 @@ static yyconst short int yy_nxt[425] =
|
||||
92, 32, 74, 75, 97, 32, 32, 32, 98, 32,
|
||||
76, 32, 32, 95, 32, 94, 100, 32, 96, 99,
|
||||
101, 103, 32, 32, 32, 32, 102, 32, 32, 105,
|
||||
111, 104, 32, 112, 32, 32, 106, 107, 109, 110,
|
||||
32, 108, 32, 32, 32, 32, 32, 114, 113, 117,
|
||||
32, 118, 32, 116, 119, 32, 121, 115, 32, 120,
|
||||
32, 122, 124, 123, 32, 32, 125, 126, 32, 32,
|
||||
128, 129, 32, 32, 32, 32, 127, 32, 133, 130,
|
||||
113, 104, 32, 114, 32, 32, 106, 107, 112, 109,
|
||||
116, 108, 110, 32, 32, 111, 32, 32, 118, 32,
|
||||
32, 32, 115, 121, 32, 120, 32, 117, 119, 123,
|
||||
32, 122, 124, 128, 32, 125, 32, 127, 130, 126,
|
||||
32, 32, 32, 32, 32, 32, 131, 32, 132, 134,
|
||||
|
||||
131, 132, 134, 32, 32, 32, 32, 32, 135, 32,
|
||||
136, 32, 32, 145, 32, 32, 32, 146, 32, 32,
|
||||
32, 151, 142, 137, 32, 144, 143, 32, 149, 32,
|
||||
138, 147, 139, 148, 150, 140, 32, 141, 155, 32,
|
||||
152, 154, 153, 32, 32, 32, 32, 32, 32, 156,
|
||||
32, 32, 159, 32, 32, 158, 32, 163, 160, 32,
|
||||
162, 32, 161, 157, 32, 165, 32, 167, 32, 164,
|
||||
169, 32, 171, 170, 173, 172, 32, 32, 166, 32,
|
||||
168, 176, 32, 32, 174, 32, 32, 32, 32, 178,
|
||||
32, 179, 181, 182, 175, 32, 32, 32, 180, 177,
|
||||
135, 32, 129, 133, 32, 136, 32, 32, 32, 32,
|
||||
32, 138, 137, 139, 32, 32, 147, 32, 32, 32,
|
||||
140, 148, 141, 144, 145, 142, 32, 143, 146, 32,
|
||||
32, 32, 151, 32, 153, 154, 149, 150, 32, 32,
|
||||
152, 156, 32, 155, 157, 32, 32, 32, 158, 32,
|
||||
32, 32, 161, 32, 32, 160, 32, 159, 162, 165,
|
||||
164, 32, 167, 163, 32, 32, 32, 166, 32, 176,
|
||||
169, 171, 173, 172, 32, 168, 32, 32, 174, 178,
|
||||
32, 32, 175, 170, 32, 177, 32, 180, 32, 32,
|
||||
181, 32, 183, 32, 32, 184, 32, 179, 182, 32,
|
||||
|
||||
32, 32, 185, 32, 183, 32, 187, 32, 186, 184,
|
||||
189, 32, 188, 32, 32, 32, 190, 193, 191, 32,
|
||||
32, 32, 32, 32, 195, 32, 192, 32, 32, 32,
|
||||
194, 32, 32, 196, 197, 30, 30, 32, 30, 30,
|
||||
185, 32, 187, 32, 32, 188, 32, 189, 191, 32,
|
||||
190, 193, 186, 32, 32, 195, 32, 192, 32, 32,
|
||||
32, 32, 32, 32, 32, 32, 197, 32, 194, 32,
|
||||
32, 32, 198, 196, 199, 30, 30, 32, 30, 30,
|
||||
30, 31, 32, 31, 33, 33, 38, 32, 38, 38,
|
||||
38, 38, 32, 32, 32, 32, 32, 32, 32, 32,
|
||||
32, 32, 32, 32, 32, 32, 32, 32, 32, 32,
|
||||
32, 32, 32, 32, 32, 32, 32, 32, 32, 80,
|
||||
32, 32, 32, 36, 35, 80, 32, 78, 36, 32,
|
||||
198, 3, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
32, 32, 32, 32, 32, 32, 32, 32, 32, 32,
|
||||
32, 32, 32, 80, 32, 32, 32, 36, 35, 80,
|
||||
32, 78, 36, 32, 200, 3, 200, 200, 200, 200,
|
||||
|
||||
198, 198, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
198, 198, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
198, 198, 198, 198
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200
|
||||
} ;
|
||||
|
||||
static yyconst short int yy_chk[425] =
|
||||
static yyconst short int yy_chk[429] =
|
||||
{ 0,
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
|
||||
1, 1, 9, 9, 11, 11, 13, 15, 19, 15,
|
||||
39, 13, 17, 16, 19, 39, 20, 13, 14, 16,
|
||||
18, 14, 18, 16, 14, 17, 203, 16, 20, 20,
|
||||
18, 14, 18, 16, 14, 17, 205, 16, 20, 20,
|
||||
23, 18, 14, 24, 21, 14, 21, 18, 22, 25,
|
||||
22, 29, 24, 27, 23, 25, 37, 37, 21, 43,
|
||||
40, 47, 197, 24, 48, 29, 42, 27, 22, 26,
|
||||
40, 47, 199, 24, 48, 29, 42, 27, 22, 26,
|
||||
27, 40, 26, 43, 42, 26, 27, 46, 26, 45,
|
||||
|
||||
49, 46, 47, 50, 48, 49, 51, 52, 26, 26,
|
||||
45, 26, 28, 52, 50, 28, 53, 45, 54, 55,
|
||||
51, 56, 28, 28, 56, 58, 57, 60, 57, 59,
|
||||
28, 61, 62, 54, 64, 53, 58, 63, 55, 57,
|
||||
59, 61, 65, 69, 66, 67, 60, 68, 71, 63,
|
||||
68, 62, 72, 69, 73, 75, 63, 64, 66, 67,
|
||||
74, 65, 76, 86, 77, 82, 83, 72, 71, 75,
|
||||
84, 76, 85, 74, 77, 87, 83, 73, 91, 82,
|
||||
191, 84, 86, 85, 89, 93, 87, 89, 92, 95,
|
||||
92, 93, 94, 98, 99, 97, 91, 100, 98, 94,
|
||||
59, 61, 65, 69, 67, 72, 60, 68, 66, 63,
|
||||
68, 62, 71, 69, 73, 74, 63, 64, 67, 66,
|
||||
72, 65, 66, 77, 75, 66, 76, 82, 74, 83,
|
||||
86, 84, 71, 77, 85, 76, 87, 73, 75, 83,
|
||||
89, 82, 84, 89, 91, 85, 92, 87, 92, 86,
|
||||
93, 94, 95, 97, 107, 98, 93, 99, 94, 97,
|
||||
|
||||
95, 97, 99, 104, 107, 109, 112, 113, 100, 110,
|
||||
104, 114, 115, 113, 116, 117, 119, 114, 189, 185,
|
||||
118, 119, 109, 107, 108, 112, 110, 126, 117, 121,
|
||||
108, 115, 108, 116, 118, 108, 120, 108, 126, 125,
|
||||
120, 125, 121, 127, 128, 130, 131, 132, 135, 127,
|
||||
136, 137, 131, 138, 142, 130, 184, 137, 132, 139,
|
||||
136, 140, 135, 128, 141, 139, 143, 140, 147, 138,
|
||||
141, 144, 143, 142, 147, 144, 149, 150, 139, 152,
|
||||
140, 152, 154, 155, 149, 158, 159, 162, 161, 155,
|
||||
175, 158, 161, 162, 150, 172, 177, 179, 159, 154,
|
||||
98, 100, 91, 95, 104, 99, 110, 112, 193, 114,
|
||||
115, 104, 100, 107, 108, 116, 115, 117, 118, 119,
|
||||
108, 116, 108, 110, 112, 108, 120, 108, 114, 121,
|
||||
123, 122, 119, 128, 121, 122, 117, 118, 130, 127,
|
||||
120, 127, 129, 123, 128, 132, 133, 134, 129, 137,
|
||||
138, 140, 133, 139, 144, 132, 141, 130, 134, 139,
|
||||
138, 151, 141, 137, 142, 143, 145, 140, 152, 151,
|
||||
142, 143, 145, 144, 146, 141, 149, 154, 146, 154,
|
||||
156, 157, 149, 142, 160, 152, 161, 157, 163, 164,
|
||||
160, 174, 163, 177, 181, 164, 179, 156, 161, 184,
|
||||
|
||||
180, 182, 177, 187, 172, 186, 180, 190, 179, 175,
|
||||
186, 193, 182, 188, 194, 192, 187, 192, 188, 195,
|
||||
183, 196, 181, 178, 194, 176, 190, 174, 173, 171,
|
||||
193, 170, 169, 195, 196, 199, 199, 168, 199, 199,
|
||||
199, 200, 167, 200, 201, 201, 202, 166, 202, 202,
|
||||
202, 202, 165, 164, 163, 160, 157, 156, 153, 151,
|
||||
148, 146, 145, 134, 133, 129, 124, 123, 122, 111,
|
||||
106, 105, 103, 102, 101, 96, 90, 88, 81, 80,
|
||||
70, 44, 41, 36, 35, 34, 31, 30, 10, 8,
|
||||
3, 198, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
174, 182, 179, 188, 189, 181, 190, 182, 188, 192,
|
||||
184, 190, 177, 194, 195, 194, 196, 189, 197, 191,
|
||||
187, 198, 186, 185, 183, 180, 196, 178, 192, 176,
|
||||
175, 173, 197, 195, 198, 201, 201, 172, 201, 201,
|
||||
201, 202, 171, 202, 203, 203, 204, 170, 204, 204,
|
||||
204, 204, 169, 168, 167, 166, 165, 162, 159, 158,
|
||||
155, 153, 150, 148, 147, 136, 135, 131, 126, 125,
|
||||
124, 113, 111, 109, 106, 105, 103, 102, 101, 96,
|
||||
90, 88, 81, 80, 70, 44, 41, 36, 35, 34,
|
||||
31, 30, 10, 8, 3, 200, 200, 200, 200, 200,
|
||||
|
||||
198, 198, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
198, 198, 198, 198, 198, 198, 198, 198, 198, 198,
|
||||
198, 198, 198, 198
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200, 200, 200,
|
||||
200, 200, 200, 200, 200, 200, 200, 200
|
||||
} ;
|
||||
|
||||
static yy_state_type yy_state_buf[YY_BUF_SIZE + 2], *yy_state_ptr;
|
||||
@ -614,7 +615,7 @@ uint64_t atoull(const char *Buffer) {
|
||||
* are preceeded by a '%' character. These represent unnamed variable slots.
|
||||
*/
|
||||
/* E[PN]Integer: match positive and negative literal integer values */
|
||||
#line 618 "Lexer.cpp"
|
||||
#line 619 "Lexer.cpp"
|
||||
|
||||
/* Macros after this point can all be overridden by user definitions in
|
||||
* section 1.
|
||||
@ -768,7 +769,7 @@ YY_DECL
|
||||
#line 83 "Lexer.l"
|
||||
|
||||
|
||||
#line 772 "Lexer.cpp"
|
||||
#line 773 "Lexer.cpp"
|
||||
|
||||
if ( yy_init )
|
||||
{
|
||||
@ -816,14 +817,14 @@ yy_match:
|
||||
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
|
||||
{
|
||||
yy_current_state = (int) yy_def[yy_current_state];
|
||||
if ( yy_current_state >= 199 )
|
||||
if ( yy_current_state >= 201 )
|
||||
yy_c = yy_meta[(unsigned int) yy_c];
|
||||
}
|
||||
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
|
||||
*yy_state_ptr++ = yy_current_state;
|
||||
++yy_cp;
|
||||
}
|
||||
while ( yy_current_state != 198 );
|
||||
while ( yy_current_state != 200 );
|
||||
|
||||
yy_find_action:
|
||||
yy_current_state = *--yy_state_ptr;
|
||||
@ -975,165 +976,175 @@ YY_RULE_SETUP
|
||||
YY_BREAK
|
||||
case 24:
|
||||
YY_RULE_SETUP
|
||||
#line 114 "Lexer.l"
|
||||
#line 115 "Lexer.l"
|
||||
{ RET_TOK(UnaryOpVal, Not, NOT); }
|
||||
YY_BREAK
|
||||
case 25:
|
||||
YY_RULE_SETUP
|
||||
#line 116 "Lexer.l"
|
||||
{ return PHI; }
|
||||
#line 117 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Add, ADD); }
|
||||
YY_BREAK
|
||||
case 26:
|
||||
YY_RULE_SETUP
|
||||
#line 117 "Lexer.l"
|
||||
{ return CALL; }
|
||||
#line 118 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Sub, SUB); }
|
||||
YY_BREAK
|
||||
case 27:
|
||||
YY_RULE_SETUP
|
||||
#line 118 "Lexer.l"
|
||||
{ return CAST; }
|
||||
#line 119 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Mul, MUL); }
|
||||
YY_BREAK
|
||||
case 28:
|
||||
YY_RULE_SETUP
|
||||
#line 119 "Lexer.l"
|
||||
{ return TO; }
|
||||
#line 120 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Div, DIV); }
|
||||
YY_BREAK
|
||||
case 29:
|
||||
YY_RULE_SETUP
|
||||
#line 120 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Add, ADD); }
|
||||
#line 121 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Rem, REM); }
|
||||
YY_BREAK
|
||||
case 30:
|
||||
YY_RULE_SETUP
|
||||
#line 121 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Sub, SUB); }
|
||||
#line 122 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetNE, SETNE); }
|
||||
YY_BREAK
|
||||
case 31:
|
||||
YY_RULE_SETUP
|
||||
#line 122 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Mul, MUL); }
|
||||
#line 123 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetEQ, SETEQ); }
|
||||
YY_BREAK
|
||||
case 32:
|
||||
YY_RULE_SETUP
|
||||
#line 123 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Div, DIV); }
|
||||
#line 124 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetLT, SETLT); }
|
||||
YY_BREAK
|
||||
case 33:
|
||||
YY_RULE_SETUP
|
||||
#line 124 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, Rem, REM); }
|
||||
#line 125 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetGT, SETGT); }
|
||||
YY_BREAK
|
||||
case 34:
|
||||
YY_RULE_SETUP
|
||||
#line 125 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetNE, SETNE); }
|
||||
#line 126 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetLE, SETLE); }
|
||||
YY_BREAK
|
||||
case 35:
|
||||
YY_RULE_SETUP
|
||||
#line 126 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetEQ, SETEQ); }
|
||||
#line 127 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetGE, SETGE); }
|
||||
YY_BREAK
|
||||
case 36:
|
||||
YY_RULE_SETUP
|
||||
#line 127 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetLT, SETLT); }
|
||||
#line 129 "Lexer.l"
|
||||
{ return TO; }
|
||||
YY_BREAK
|
||||
case 37:
|
||||
YY_RULE_SETUP
|
||||
#line 128 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetGT, SETGT); }
|
||||
#line 130 "Lexer.l"
|
||||
{ RET_TOK(OtherOpVal, PHINode, PHI); }
|
||||
YY_BREAK
|
||||
case 38:
|
||||
YY_RULE_SETUP
|
||||
#line 129 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetLE, SETLE); }
|
||||
#line 131 "Lexer.l"
|
||||
{ RET_TOK(OtherOpVal, Call, CALL); }
|
||||
YY_BREAK
|
||||
case 39:
|
||||
YY_RULE_SETUP
|
||||
#line 130 "Lexer.l"
|
||||
{ RET_TOK(BinaryOpVal, SetGE, SETGE); }
|
||||
#line 132 "Lexer.l"
|
||||
{ RET_TOK(OtherOpVal, Cast, CAST); }
|
||||
YY_BREAK
|
||||
case 40:
|
||||
YY_RULE_SETUP
|
||||
#line 132 "Lexer.l"
|
||||
{ RET_TOK(TermOpVal, Ret, RET); }
|
||||
#line 133 "Lexer.l"
|
||||
{ RET_TOK(OtherOpVal, Shl, SHL); }
|
||||
YY_BREAK
|
||||
case 41:
|
||||
YY_RULE_SETUP
|
||||
#line 133 "Lexer.l"
|
||||
{ RET_TOK(TermOpVal, Br, BR); }
|
||||
#line 134 "Lexer.l"
|
||||
{ RET_TOK(OtherOpVal, Shr, SHR); }
|
||||
YY_BREAK
|
||||
case 42:
|
||||
YY_RULE_SETUP
|
||||
#line 134 "Lexer.l"
|
||||
{ RET_TOK(TermOpVal, Switch, SWITCH); }
|
||||
#line 136 "Lexer.l"
|
||||
{ RET_TOK(TermOpVal, Ret, RET); }
|
||||
YY_BREAK
|
||||
case 43:
|
||||
YY_RULE_SETUP
|
||||
#line 137 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Malloc, MALLOC); }
|
||||
{ RET_TOK(TermOpVal, Br, BR); }
|
||||
YY_BREAK
|
||||
case 44:
|
||||
YY_RULE_SETUP
|
||||
#line 138 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Alloca, ALLOCA); }
|
||||
{ RET_TOK(TermOpVal, Switch, SWITCH); }
|
||||
YY_BREAK
|
||||
case 45:
|
||||
YY_RULE_SETUP
|
||||
#line 139 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Free, FREE); }
|
||||
#line 141 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Malloc, MALLOC); }
|
||||
YY_BREAK
|
||||
case 46:
|
||||
YY_RULE_SETUP
|
||||
#line 140 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Load, LOAD); }
|
||||
#line 142 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Alloca, ALLOCA); }
|
||||
YY_BREAK
|
||||
case 47:
|
||||
YY_RULE_SETUP
|
||||
#line 141 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Store, STORE); }
|
||||
#line 143 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Free, FREE); }
|
||||
YY_BREAK
|
||||
case 48:
|
||||
YY_RULE_SETUP
|
||||
#line 142 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, GetField, GETFIELD); }
|
||||
#line 144 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Load, LOAD); }
|
||||
YY_BREAK
|
||||
case 49:
|
||||
YY_RULE_SETUP
|
||||
#line 143 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, PutField, PUTFIELD); }
|
||||
#line 145 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, Store, STORE); }
|
||||
YY_BREAK
|
||||
case 50:
|
||||
YY_RULE_SETUP
|
||||
#line 146 "Lexer.l"
|
||||
{ llvmAsmlval.StrVal = strdup(yytext+1); return VAR_ID; }
|
||||
{ RET_TOK(MemOpVal, GetField, GETFIELD); }
|
||||
YY_BREAK
|
||||
case 51:
|
||||
YY_RULE_SETUP
|
||||
#line 147 "Lexer.l"
|
||||
{ RET_TOK(MemOpVal, PutField, PUTFIELD); }
|
||||
YY_BREAK
|
||||
case 52:
|
||||
YY_RULE_SETUP
|
||||
#line 150 "Lexer.l"
|
||||
{ llvmAsmlval.StrVal = strdup(yytext+1); return VAR_ID; }
|
||||
YY_BREAK
|
||||
case 53:
|
||||
YY_RULE_SETUP
|
||||
#line 151 "Lexer.l"
|
||||
{
|
||||
yytext[strlen(yytext)-1] = 0; // nuke colon
|
||||
llvmAsmlval.StrVal = strdup(yytext);
|
||||
return LABELSTR;
|
||||
}
|
||||
YY_BREAK
|
||||
case 52:
|
||||
case 54:
|
||||
YY_RULE_SETUP
|
||||
#line 153 "Lexer.l"
|
||||
#line 157 "Lexer.l"
|
||||
{
|
||||
yytext[strlen(yytext)-1] = 0; // nuke end quote
|
||||
llvmAsmlval.StrVal = strdup(yytext+1); // Nuke start quote
|
||||
return STRINGCONSTANT;
|
||||
}
|
||||
YY_BREAK
|
||||
case 53:
|
||||
case 55:
|
||||
YY_RULE_SETUP
|
||||
#line 160 "Lexer.l"
|
||||
#line 164 "Lexer.l"
|
||||
{ llvmAsmlval.UInt64Val = atoull(yytext); return EUINT64VAL; }
|
||||
YY_BREAK
|
||||
case 54:
|
||||
case 56:
|
||||
YY_RULE_SETUP
|
||||
#line 161 "Lexer.l"
|
||||
#line 165 "Lexer.l"
|
||||
{
|
||||
uint64_t Val = atoull(yytext+1);
|
||||
// +1: we have bigger negative range
|
||||
@ -1143,14 +1154,14 @@ YY_RULE_SETUP
|
||||
return ESINT64VAL;
|
||||
}
|
||||
YY_BREAK
|
||||
case 55:
|
||||
case 57:
|
||||
YY_RULE_SETUP
|
||||
#line 171 "Lexer.l"
|
||||
#line 175 "Lexer.l"
|
||||
{ llvmAsmlval.UIntVal = atoull(yytext+1); return UINTVAL; }
|
||||
YY_BREAK
|
||||
case 56:
|
||||
case 58:
|
||||
YY_RULE_SETUP
|
||||
#line 172 "Lexer.l"
|
||||
#line 176 "Lexer.l"
|
||||
{
|
||||
uint64_t Val = atoull(yytext+2);
|
||||
// +1: we have bigger negative range
|
||||
@ -1160,22 +1171,22 @@ YY_RULE_SETUP
|
||||
return SINTVAL;
|
||||
}
|
||||
YY_BREAK
|
||||
case 57:
|
||||
YY_RULE_SETUP
|
||||
#line 182 "Lexer.l"
|
||||
{ /* Ignore whitespace */ }
|
||||
YY_BREAK
|
||||
case 58:
|
||||
YY_RULE_SETUP
|
||||
#line 183 "Lexer.l"
|
||||
{ /*printf("'%s'", yytext);*/ return yytext[0]; }
|
||||
YY_BREAK
|
||||
case 59:
|
||||
YY_RULE_SETUP
|
||||
#line 185 "Lexer.l"
|
||||
#line 186 "Lexer.l"
|
||||
{ /* Ignore whitespace */ }
|
||||
YY_BREAK
|
||||
case 60:
|
||||
YY_RULE_SETUP
|
||||
#line 187 "Lexer.l"
|
||||
{ /*printf("'%s'", yytext);*/ return yytext[0]; }
|
||||
YY_BREAK
|
||||
case 61:
|
||||
YY_RULE_SETUP
|
||||
#line 189 "Lexer.l"
|
||||
YY_FATAL_ERROR( "flex scanner jammed" );
|
||||
YY_BREAK
|
||||
#line 1180 "Lexer.cpp"
|
||||
#line 1191 "Lexer.cpp"
|
||||
case YY_STATE_EOF(INITIAL):
|
||||
yyterminate();
|
||||
|
||||
@ -1464,7 +1475,7 @@ static yy_state_type yy_get_previous_state()
|
||||
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
|
||||
{
|
||||
yy_current_state = (int) yy_def[yy_current_state];
|
||||
if ( yy_current_state >= 199 )
|
||||
if ( yy_current_state >= 201 )
|
||||
yy_c = yy_meta[(unsigned int) yy_c];
|
||||
}
|
||||
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
|
||||
@ -1494,11 +1505,11 @@ yy_state_type yy_current_state;
|
||||
while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state )
|
||||
{
|
||||
yy_current_state = (int) yy_def[yy_current_state];
|
||||
if ( yy_current_state >= 199 )
|
||||
if ( yy_current_state >= 201 )
|
||||
yy_c = yy_meta[(unsigned int) yy_c];
|
||||
}
|
||||
yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c];
|
||||
yy_is_jam = (yy_current_state == 198);
|
||||
yy_is_jam = (yy_current_state == 200);
|
||||
if ( ! yy_is_jam )
|
||||
*yy_state_ptr++ = yy_current_state;
|
||||
|
||||
@ -2059,5 +2070,5 @@ int main()
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
#line 185 "Lexer.l"
|
||||
#line 189 "Lexer.l"
|
||||
|
||||
|
@ -111,12 +111,9 @@ type { llvmAsmlval.TypeVal = Type::TypeTy ; return TYPE; }
|
||||
|
||||
label { llvmAsmlval.TypeVal = Type::LabelTy ; return LABEL; }
|
||||
|
||||
|
||||
not { RET_TOK(UnaryOpVal, Not, NOT); }
|
||||
|
||||
phi { return PHI; }
|
||||
call { return CALL; }
|
||||
cast { return CAST; }
|
||||
to { return TO; }
|
||||
add { RET_TOK(BinaryOpVal, Add, ADD); }
|
||||
sub { RET_TOK(BinaryOpVal, Sub, SUB); }
|
||||
mul { RET_TOK(BinaryOpVal, Mul, MUL); }
|
||||
@ -129,6 +126,13 @@ setgt { RET_TOK(BinaryOpVal, SetGT, SETGT); }
|
||||
setle { RET_TOK(BinaryOpVal, SetLE, SETLE); }
|
||||
setge { RET_TOK(BinaryOpVal, SetGE, SETGE); }
|
||||
|
||||
to { return TO; }
|
||||
phi { RET_TOK(OtherOpVal, PHINode, PHI); }
|
||||
call { RET_TOK(OtherOpVal, Call, CALL); }
|
||||
cast { RET_TOK(OtherOpVal, Cast, CAST); }
|
||||
shl { RET_TOK(OtherOpVal, Shl, SHL); }
|
||||
shr { RET_TOK(OtherOpVal, Shr, SHR); }
|
||||
|
||||
ret { RET_TOK(TermOpVal, Ret, RET); }
|
||||
br { RET_TOK(TermOpVal, Br, BR); }
|
||||
switch { RET_TOK(TermOpVal, Switch, SWITCH); }
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -27,6 +27,7 @@ typedef union {
|
||||
Instruction::BinaryOps BinaryOpVal;
|
||||
Instruction::TermOps TermOpVal;
|
||||
Instruction::MemoryOps MemOpVal;
|
||||
Instruction::OtherOps OtherOpVal;
|
||||
} YYSTYPE;
|
||||
#define ESINT64VAL 257
|
||||
#define EUINT64VAL 258
|
||||
@ -57,31 +58,33 @@ typedef union {
|
||||
#define END 283
|
||||
#define DECLARE 284
|
||||
#define TO 285
|
||||
#define PHI 286
|
||||
#define CALL 287
|
||||
#define CAST 288
|
||||
#define RET 289
|
||||
#define BR 290
|
||||
#define SWITCH 291
|
||||
#define NOT 292
|
||||
#define ADD 293
|
||||
#define SUB 294
|
||||
#define MUL 295
|
||||
#define DIV 296
|
||||
#define REM 297
|
||||
#define SETLE 298
|
||||
#define SETGE 299
|
||||
#define SETLT 300
|
||||
#define SETGT 301
|
||||
#define SETEQ 302
|
||||
#define SETNE 303
|
||||
#define MALLOC 304
|
||||
#define ALLOCA 305
|
||||
#define FREE 306
|
||||
#define LOAD 307
|
||||
#define STORE 308
|
||||
#define GETFIELD 309
|
||||
#define PUTFIELD 310
|
||||
#define RET 286
|
||||
#define BR 287
|
||||
#define SWITCH 288
|
||||
#define NOT 289
|
||||
#define ADD 290
|
||||
#define SUB 291
|
||||
#define MUL 292
|
||||
#define DIV 293
|
||||
#define REM 294
|
||||
#define SETLE 295
|
||||
#define SETGE 296
|
||||
#define SETLT 297
|
||||
#define SETGT 298
|
||||
#define SETEQ 299
|
||||
#define SETNE 300
|
||||
#define MALLOC 301
|
||||
#define ALLOCA 302
|
||||
#define FREE 303
|
||||
#define LOAD 304
|
||||
#define STORE 305
|
||||
#define GETFIELD 306
|
||||
#define PUTFIELD 307
|
||||
#define PHI 308
|
||||
#define CALL 309
|
||||
#define CAST 310
|
||||
#define SHL 311
|
||||
#define SHR 312
|
||||
|
||||
|
||||
extern YYSTYPE llvmAsmlval;
|
||||
|
@ -363,6 +363,7 @@ Module *RunVMAsmParser(const ToolCommandLine &Opts, FILE *F) {
|
||||
Instruction::BinaryOps BinaryOpVal;
|
||||
Instruction::TermOps TermOpVal;
|
||||
Instruction::MemoryOps MemOpVal;
|
||||
Instruction::OtherOps OtherOpVal;
|
||||
}
|
||||
|
||||
%type <ModuleVal> Module MethodList
|
||||
@ -371,7 +372,7 @@ Module *RunVMAsmParser(const ToolCommandLine &Opts, FILE *F) {
|
||||
%type <TermInstVal> BBTerminatorInst
|
||||
%type <InstVal> Inst InstVal MemoryInst
|
||||
%type <ConstVal> ConstVal
|
||||
%type <ConstVector> ConstVector
|
||||
%type <ConstVector> ConstVector UByteList
|
||||
%type <MethodArgList> ArgList ArgListH
|
||||
%type <MethArgVal> ArgVal
|
||||
%type <PHIList> PHIList
|
||||
@ -404,7 +405,6 @@ Module *RunVMAsmParser(const ToolCommandLine &Opts, FILE *F) {
|
||||
|
||||
|
||||
%token IMPLEMENTATION TRUE FALSE BEGINTOK END DECLARE TO
|
||||
%token PHI CALL CAST
|
||||
|
||||
// Basic Block Terminating Operators
|
||||
%token <TermOpVal> RET BR SWITCH
|
||||
@ -416,13 +416,15 @@ Module *RunVMAsmParser(const ToolCommandLine &Opts, FILE *F) {
|
||||
// Binary Operators
|
||||
%type <BinaryOpVal> BinaryOps // all the binary operators
|
||||
%token <BinaryOpVal> ADD SUB MUL DIV REM
|
||||
|
||||
// Binary Comarators
|
||||
%token <BinaryOpVal> SETLE SETGE SETLT SETGT SETEQ SETNE
|
||||
%token <BinaryOpVal> SETLE SETGE SETLT SETGT SETEQ SETNE // Binary Comarators
|
||||
|
||||
// Memory Instructions
|
||||
%token <MemoryOpVal> MALLOC ALLOCA FREE LOAD STORE GETFIELD PUTFIELD
|
||||
|
||||
// Other Operators
|
||||
%type <OtherOpVal> ShiftOps
|
||||
%token <OtherOpVal> PHI CALL CAST SHL SHR
|
||||
|
||||
%start Module
|
||||
%%
|
||||
|
||||
@ -461,6 +463,7 @@ TypesV : Types | VOID
|
||||
UnaryOps : NOT
|
||||
BinaryOps : ADD | SUB | MUL | DIV | REM
|
||||
BinaryOps : SETLE | SETGE | SETLT | SETGT | SETEQ | SETNE
|
||||
ShiftOps : SHL | SHR
|
||||
|
||||
// Valueine some types that allow classification if we only want a particular
|
||||
// thing...
|
||||
@ -872,6 +875,10 @@ InstVal : BinaryOps Types ValueRef ',' ValueRef {
|
||||
if ($$ == 0)
|
||||
ThrowException("unary operator returned null!");
|
||||
}
|
||||
| ShiftOps Types ValueRef ',' Types ValueRef {
|
||||
if ($5 != Type::UByteTy) ThrowException("Shift amount must be ubyte!");
|
||||
$$ = new ShiftInst($1, getVal($2, $3), getVal($5, $6));
|
||||
}
|
||||
| CAST Types ValueRef TO Types {
|
||||
$$ = new CastInst(getVal($2, $3), $5);
|
||||
}
|
||||
@ -927,6 +934,13 @@ InstVal : BinaryOps Types ValueRef ',' ValueRef {
|
||||
$$ = $1;
|
||||
}
|
||||
|
||||
// UByteList - List of ubyte values for load and store instructions
|
||||
UByteList : ',' ConstVector {
|
||||
$$ = $2;
|
||||
} | /* empty */ {
|
||||
$$ = new vector<ConstPoolVal*>();
|
||||
}
|
||||
|
||||
MemoryInst : MALLOC Types {
|
||||
const Type *Ty = PointerType::getPointerType($2);
|
||||
addConstValToConstantPool(new ConstPoolType(Ty));
|
||||
@ -961,6 +975,16 @@ MemoryInst : MALLOC Types {
|
||||
$$ = new FreeInst(getVal($2, $3));
|
||||
}
|
||||
|
||||
| LOAD Types ValueRef UByteList {
|
||||
if (!$2->isPointerType())
|
||||
ThrowException("Can't load from nonpointer type: " + $2->getName());
|
||||
if (LoadInst::getIndexedType($2, *$4) == 0)
|
||||
ThrowException("Invalid indices for load instruction!");
|
||||
|
||||
$$ = new LoadInst(getVal($2, $3), *$4);
|
||||
delete $4; // Free the vector...
|
||||
}
|
||||
|
||||
%%
|
||||
int yyerror(const char *ErrorMsg) {
|
||||
ThrowException(string("Parse error: ") + ErrorMsg);
|
||||
|
@ -105,10 +105,15 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf,
|
||||
getValue(Raw.Ty, Raw.Arg1),
|
||||
getValue(Raw.Ty, Raw.Arg2));
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Cast) {
|
||||
}
|
||||
|
||||
Value *V;
|
||||
switch (Raw.Opcode) {
|
||||
case Instruction::Cast:
|
||||
Res = new CastInst(getValue(Raw.Ty, Raw.Arg1), getType(Raw.Arg2));
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::PHINode) {
|
||||
|
||||
case Instruction::PHINode: {
|
||||
PHINode *PN = new PHINode(Raw.Ty);
|
||||
switch (Raw.NumOperands) {
|
||||
case 0:
|
||||
@ -137,13 +142,23 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf,
|
||||
}
|
||||
Res = PN;
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Ret) {
|
||||
}
|
||||
|
||||
case Instruction::Shl:
|
||||
case Instruction::Shr:
|
||||
Res = new ShiftInst((Instruction::OtherOps)Raw.Opcode,
|
||||
getValue(Raw.Ty, Raw.Arg1),
|
||||
getValue(Type::UByteTy, Raw.Arg2));
|
||||
return false;
|
||||
case Instruction::Ret:
|
||||
if (Raw.NumOperands == 0) {
|
||||
Res = new ReturnInst(); return false;
|
||||
} else if (Raw.NumOperands == 1) {
|
||||
Res = new ReturnInst(getValue(Raw.Ty, Raw.Arg1)); return false;
|
||||
}
|
||||
} else if (Raw.Opcode == Instruction::Br) {
|
||||
break;
|
||||
|
||||
case Instruction::Br:
|
||||
if (Raw.NumOperands == 1) {
|
||||
Res = new BranchInst((BasicBlock*)getValue(Type::LabelTy, Raw.Arg1));
|
||||
return false;
|
||||
@ -153,7 +168,9 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf,
|
||||
getValue(Type::BoolTy , Raw.Arg3));
|
||||
return false;
|
||||
}
|
||||
} else if (Raw.Opcode == Instruction::Switch) {
|
||||
break;
|
||||
|
||||
case Instruction::Switch: {
|
||||
SwitchInst *I =
|
||||
new SwitchInst(getValue(Raw.Ty, Raw.Arg1),
|
||||
(BasicBlock*)getValue(Type::LabelTy, Raw.Arg2));
|
||||
@ -173,7 +190,9 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf,
|
||||
|
||||
delete Raw.VarArgs;
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Call) {
|
||||
}
|
||||
|
||||
case Instruction::Call: {
|
||||
Method *M = (Method*)getValue(Raw.Ty, Raw.Arg1);
|
||||
if (M == 0) return true;
|
||||
|
||||
@ -204,22 +223,58 @@ bool BytecodeParser::ParseInstruction(const uchar *&Buf, const uchar *EndBuf,
|
||||
|
||||
Res = new CallInst(M, Params);
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Malloc) {
|
||||
}
|
||||
case Instruction::Malloc:
|
||||
if (Raw.NumOperands > 2) return true;
|
||||
Value *Sz = Raw.NumOperands ? getValue(Type::UIntTy, Raw.Arg1) : 0;
|
||||
Res = new MallocInst(Raw.Ty, Sz);
|
||||
V = Raw.NumOperands ? getValue(Type::UIntTy, Raw.Arg1) : 0;
|
||||
Res = new MallocInst(Raw.Ty, V);
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Alloca) {
|
||||
|
||||
case Instruction::Alloca:
|
||||
if (Raw.NumOperands > 2) return true;
|
||||
Value *Sz = Raw.NumOperands ? getValue(Type::UIntTy, Raw.Arg1) : 0;
|
||||
Res = new AllocaInst(Raw.Ty, Sz);
|
||||
V = Raw.NumOperands ? getValue(Type::UIntTy, Raw.Arg1) : 0;
|
||||
Res = new AllocaInst(Raw.Ty, V);
|
||||
return false;
|
||||
} else if (Raw.Opcode == Instruction::Free) {
|
||||
Value *Val = getValue(Raw.Ty, Raw.Arg1);
|
||||
if (!Val->getType()->isPointerType()) return true;
|
||||
Res = new FreeInst(Val);
|
||||
|
||||
case Instruction::Free:
|
||||
V = getValue(Raw.Ty, Raw.Arg1);
|
||||
if (!V->getType()->isPointerType()) return true;
|
||||
Res = new FreeInst(V);
|
||||
return false;
|
||||
|
||||
case Instruction::Load: {
|
||||
vector<ConstPoolVal*> Idx;
|
||||
switch (Raw.NumOperands) {
|
||||
case 0: cerr << "Invalid load encountered!\n"; return true;
|
||||
case 1: break;
|
||||
case 2: V = getValue(Type::UByteTy, Raw.Arg2);
|
||||
if (!V->isConstant()) return true;
|
||||
Idx.push_back(V->castConstant());
|
||||
break;
|
||||
case 3: V = getValue(Type::UByteTy, Raw.Arg2);
|
||||
if (!V->isConstant()) return true;
|
||||
Idx.push_back(V->castConstant());
|
||||
V = getValue(Type::UByteTy, Raw.Arg3);
|
||||
if (!V->isConstant()) return true;
|
||||
Idx.push_back(V->castConstant());
|
||||
break;
|
||||
default:
|
||||
V = getValue(Type::UByteTy, Raw.Arg2);
|
||||
if (!V->isConstant()) return true;
|
||||
Idx.push_back(V->castConstant());
|
||||
vector<unsigned> &args = *Raw.VarArgs;
|
||||
for (unsigned i = 0, E = args.size(); i != E; ++i) {
|
||||
V = getValue(Type::UByteTy, args[i]);
|
||||
if (!V->isConstant()) return true;
|
||||
Idx.push_back(V->castConstant());
|
||||
}
|
||||
delete Raw.VarArgs;
|
||||
break;
|
||||
}
|
||||
Res = new LoadInst(getValue(Raw.Ty, Raw.Arg1), Idx);
|
||||
return false;
|
||||
}
|
||||
} // end switch(Raw.Opcode)
|
||||
|
||||
cerr << "Unrecognized instruction! " << Raw.Opcode
|
||||
<< " ADDR = 0x" << (void*)Buf << endl;
|
||||
|
47
lib/VMCore/iMemory.cpp
Normal file
47
lib/VMCore/iMemory.cpp
Normal file
@ -0,0 +1,47 @@
|
||||
//===-- iMemory.cpp - Implement Memory instructions --------------*- C++ -*--=//
|
||||
//
|
||||
// This file implements the various memory related classes defined in iMemory.h
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "llvm/iMemory.h"
|
||||
#include "llvm/ConstPoolVals.h"
|
||||
|
||||
const Type *LoadInst::getIndexedType(const Type *Ptr,
|
||||
const vector<ConstPoolVal*> &Idx) {
|
||||
if (!Ptr->isPointerType()) return 0; // Type isn't a pointer type!
|
||||
|
||||
// Get the type pointed to...
|
||||
Ptr = ((const PointerType*)Ptr)->getValueType();
|
||||
|
||||
if (Ptr->isStructType()) {
|
||||
unsigned CurIDX = 0;
|
||||
while (Ptr->isStructType()) {
|
||||
if (Idx.size() == CurIDX) return 0; // Can't load a whole structure!
|
||||
if (Idx[CurIDX]->getType() != Type::UByteTy) return 0; // Illegal idx
|
||||
unsigned NextIdx = ((ConstPoolUInt*)Idx[CurIDX++])->getValue();
|
||||
|
||||
const StructType *ST = (const StructType *)Ptr;
|
||||
Ptr = ST->getElementTypes()[NextIdx];
|
||||
}
|
||||
return Ptr;
|
||||
} else if (Ptr->isArrayType()) {
|
||||
assert(0 && "Loading from arrays not implemented yet!");
|
||||
} else {
|
||||
return (Idx.size() == 0) ? Ptr : 0; // Load directly through ptr
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const vector<ConstPoolVal*> &Idx,
|
||||
const string &Name = "")
|
||||
: Instruction(getIndexedType(Ptr->getType(), Idx), Load, Name) {
|
||||
assert(getIndexedType(Ptr->getType(), Idx) && "Load operands invalid!");
|
||||
assert(Ptr->getType()->isPointerType() && "Can't free nonpointer!");
|
||||
Operands.reserve(1+Idx.size());
|
||||
Operands.push_back(Use(Ptr, this));
|
||||
|
||||
for (unsigned i = 0, E = Idx.size(); i != E; ++i)
|
||||
Operands.push_back(Use(Idx[i], this));
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user