AsmParser turns 'not' instructions into 'xor' instructions now.

llvm-svn: 3309
This commit is contained in:
Chris Lattner 2002-08-14 17:12:33 +00:00
parent 31408f7a80
commit db3b202be8
2 changed files with 17 additions and 25 deletions

View File

@ -1,8 +1,8 @@
/*===-- Lexer.l - Scanner for llvm assembly files ----------------*- C++ -*--=// /*===-- Lexer.l - Scanner for llvm assembly files --------------*- C++ -*--===//
// //
// This file implements the flex scanner for LLVM assembly languages files. // This file implements the flex scanner for LLVM assembly languages files.
// //
//===------------------------------------------------------------------------=*/ //===----------------------------------------------------------------------===*/
%option prefix="llvmAsm" %option prefix="llvmAsm"
%option yylineno %option yylineno
@ -162,6 +162,7 @@ string { return STRING; }
null { return NULL_TOK; } null { return NULL_TOK; }
to { return TO; } to { return TO; }
except { return EXCEPT; } except { return EXCEPT; }
not { return NOT; } /* Deprecated, turned into XOR */
void { llvmAsmlval.PrimType = Type::VoidTy ; return VOID; } void { llvmAsmlval.PrimType = Type::VoidTy ; return VOID; }
bool { llvmAsmlval.PrimType = Type::BoolTy ; return BOOL; } bool { llvmAsmlval.PrimType = Type::BoolTy ; return BOOL; }
@ -179,9 +180,6 @@ type { llvmAsmlval.PrimType = Type::TypeTy ; return TYPE; }
label { llvmAsmlval.PrimType = Type::LabelTy ; return LABEL; } label { llvmAsmlval.PrimType = Type::LabelTy ; return LABEL; }
opaque { return OPAQUE; } opaque { return OPAQUE; }
not { RET_TOK(UnaryOpVal, Not, NOT); }
add { RET_TOK(BinaryOpVal, Add, ADD); } add { RET_TOK(BinaryOpVal, Add, ADD); }
sub { RET_TOK(BinaryOpVal, Sub, SUB); } sub { RET_TOK(BinaryOpVal, Sub, SUB); }
mul { RET_TOK(BinaryOpVal, Mul, MUL); } mul { RET_TOK(BinaryOpVal, Mul, MUL); }

View File

@ -22,7 +22,6 @@ using std::pair;
using std::map; using std::map;
using std::pair; using std::pair;
using std::make_pair; using std::make_pair;
using std::cerr;
using std::string; using std::string;
int yyerror(const char *ErrorMsg); // Forward declarations to prevent "implicit int yyerror(const char *ErrorMsg); // Forward declarations to prevent "implicit
@ -37,7 +36,7 @@ string CurFilename;
// //
//#define DEBUG_UPREFS 1 //#define DEBUG_UPREFS 1
#ifdef DEBUG_UPREFS #ifdef DEBUG_UPREFS
#define UR_OUT(X) cerr << X #define UR_OUT(X) std::cerr << X
#else #else
#define UR_OUT(X) #define UR_OUT(X)
#endif #endif
@ -494,7 +493,7 @@ static bool setValueName(Value *V, char *NameStr) {
// is defined the same as the old one... // is defined the same as the old one...
if (const Type *Ty = dyn_cast<const Type>(Existing)) { if (const Type *Ty = dyn_cast<const Type>(Existing)) {
if (Ty == cast<const Type>(V)) return true; // Yes, it's equal. if (Ty == cast<const Type>(V)) return true; // Yes, it's equal.
// cerr << "Type: " << Ty->getDescription() << " != " // std::cerr << "Type: " << Ty->getDescription() << " != "
// << cast<const Type>(V)->getDescription() << "!\n"; // << cast<const Type>(V)->getDescription() << "!\n";
} else if (GlobalVariable *EGV = dyn_cast<GlobalVariable>(Existing)) { } else if (GlobalVariable *EGV = dyn_cast<GlobalVariable>(Existing)) {
// We are allowed to redefine a global variable in two circumstances: // We are allowed to redefine a global variable in two circumstances:
@ -621,7 +620,6 @@ Module *RunVMAsmParser(const string &Filename, FILE *F) {
char *StrVal; // This memory is strdup'd! char *StrVal; // This memory is strdup'd!
ValID ValIDVal; // strdup'd memory maybe! ValID ValIDVal; // strdup'd memory maybe!
Instruction::UnaryOps UnaryOpVal;
Instruction::BinaryOps BinaryOpVal; Instruction::BinaryOps BinaryOpVal;
Instruction::TermOps TermOpVal; Instruction::TermOps TermOpVal;
Instruction::MemoryOps MemOpVal; Instruction::MemoryOps MemOpVal;
@ -672,15 +670,11 @@ Module *RunVMAsmParser(const string &Filename, FILE *F) {
%token IMPLEMENTATION TRUE FALSE BEGINTOK ENDTOK DECLARE GLOBAL CONSTANT UNINIT %token IMPLEMENTATION TRUE FALSE BEGINTOK ENDTOK DECLARE GLOBAL CONSTANT UNINIT
%token TO EXCEPT DOTDOTDOT STRING NULL_TOK CONST INTERNAL OPAQUE %token TO EXCEPT DOTDOTDOT STRING NULL_TOK CONST INTERNAL OPAQUE NOT
// Basic Block Terminating Operators // Basic Block Terminating Operators
%token <TermOpVal> RET BR SWITCH %token <TermOpVal> RET BR SWITCH
// Unary Operators
%type <UnaryOpVal> UnaryOps // all the unary operators
%token <UnaryOpVal> NOT
// Binary Operators // Binary Operators
%type <BinaryOpVal> BinaryOps // all the binary operators %type <BinaryOpVal> BinaryOps // all the binary operators
%token <BinaryOpVal> ADD SUB MUL DIV REM AND OR XOR %token <BinaryOpVal> ADD SUB MUL DIV REM AND OR XOR
@ -717,7 +711,6 @@ EINT64VAL : EUINT64VAL {
// Operations that are notably excluded from this list include: // Operations that are notably excluded from this list include:
// RET, BR, & SWITCH because they end basic blocks and are treated specially. // RET, BR, & SWITCH because they end basic blocks and are treated specially.
// //
UnaryOps : NOT;
BinaryOps : ADD | SUB | MUL | DIV | REM | AND | OR | XOR; BinaryOps : ADD | SUB | MUL | DIV | REM | AND | OR | XOR;
BinaryOps : SETLE | SETGE | SETLT | SETGT | SETEQ | SETNE; BinaryOps : SETLE | SETGE | SETLT | SETGT | SETEQ | SETNE;
ShiftOps : SHL | SHR; ShiftOps : SHL | SHR;
@ -970,7 +963,6 @@ ConstVal: Types '[' ConstVector ']' { // Nonempty unsized arr
// FIXME: ConstExpr::get never return null! Do checking here in the parser. // FIXME: ConstExpr::get never return null! Do checking here in the parser.
ConstExpr: Types CAST ConstVal { ConstExpr: Types CAST ConstVal {
$$ = ConstantExpr::get(Instruction::Cast, $3, $1->get()); $$ = ConstantExpr::get(Instruction::Cast, $3, $1->get());
if ($$ == 0) ThrowException("constant expression builder returned null!");
delete $1; delete $1;
} }
| Types GETELEMENTPTR '(' ConstVal IndexList ')' { | Types GETELEMENTPTR '(' ConstVal IndexList ')' {
@ -996,10 +988,6 @@ ConstExpr: Types CAST ConstVal {
$$ = ConstantExpr::getGetElementPtr($4, IdxVec); $$ = ConstantExpr::getGetElementPtr($4, IdxVec);
delete $1; delete $1;
} }
| Types UnaryOps ConstVal {
$$ = ConstantExpr::get($2, $3, $1->get());
delete $1;
}
| Types BinaryOps ConstVal ',' ConstVal { | Types BinaryOps ConstVal ',' ConstVal {
if ($3->getType() != $5->getType()) if ($3->getType() != $5->getType())
ThrowException("Binary operator types must match!"); ThrowException("Binary operator types must match!");
@ -1016,8 +1004,7 @@ ConstExpr: Types CAST ConstVal {
$$ = ConstantExpr::get($2, $3, $5); $$ = ConstantExpr::get($2, $3, $5);
delete $1; delete $1;
} };
;
ConstVal : SIntType EINT64VAL { // integral constants ConstVal : SIntType EINT64VAL { // integral constants
@ -1510,10 +1497,17 @@ InstVal : BinaryOps Types ValueRef ',' ValueRef {
ThrowException("binary operator returned null!"); ThrowException("binary operator returned null!");
delete $2; delete $2;
} }
| UnaryOps ResolvedVal { | NOT ResolvedVal {
$$ = UnaryOperator::create($1, $2); std::cerr << "WARNING: Use of eliminated 'not' instruction:"
<< " Replacing with 'xor'.\n";
Value *Ones = ConstantIntegral::getAllOnesValue($2->getType());
if (Ones == 0)
ThrowException("Expected integral type for not instruction!");
$$ = BinaryOperator::create(Instruction::Xor, $2, Ones);
if ($$ == 0) if ($$ == 0)
ThrowException("unary operator returned null!"); ThrowException("Could not create a xor instruction!");
} }
| ShiftOps ResolvedVal ',' ResolvedVal { | ShiftOps ResolvedVal ',' ResolvedVal {
if ($4->getType() != Type::UByteTy) if ($4->getType() != Type::UByteTy)