mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Allow binary and for tblgen math.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214851 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -928,7 +928,7 @@ public: | ||||
| /// | ||||
| class BinOpInit : public OpInit { | ||||
| public: | ||||
|   enum BinaryOp { ADD, SHL, SRA, SRL, LISTCONCAT, STRCONCAT, CONCAT, EQ }; | ||||
|   enum BinaryOp { ADD, AND, SHL, SRA, SRL, LISTCONCAT, STRCONCAT, CONCAT, EQ }; | ||||
|  | ||||
| private: | ||||
|   BinaryOp Opc; | ||||
|   | ||||
| @@ -952,6 +952,7 @@ Init *BinOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) const { | ||||
|     break; | ||||
|   } | ||||
|   case ADD: | ||||
|   case AND: | ||||
|   case SHL: | ||||
|   case SRA: | ||||
|   case SRL: { | ||||
| @@ -965,6 +966,7 @@ Init *BinOpInit::Fold(Record *CurRec, MultiClass *CurMultiClass) const { | ||||
|       switch (getOpcode()) { | ||||
|       default: llvm_unreachable("Bad opcode!"); | ||||
|       case ADD: Result = LHSv +  RHSv; break; | ||||
|       case AND: Result = LHSv &  RHSv; break; | ||||
|       case SHL: Result = LHSv << RHSv; break; | ||||
|       case SRA: Result = LHSv >> RHSv; break; | ||||
|       case SRL: Result = (uint64_t)LHSv >> (uint64_t)RHSv; break; | ||||
| @@ -991,6 +993,7 @@ std::string BinOpInit::getAsString() const { | ||||
|   switch (Opc) { | ||||
|   case CONCAT: Result = "!con"; break; | ||||
|   case ADD: Result = "!add"; break; | ||||
|   case AND: Result = "!and"; break; | ||||
|   case SHL: Result = "!shl"; break; | ||||
|   case SRA: Result = "!sra"; break; | ||||
|   case SRL: Result = "!srl"; break; | ||||
|   | ||||
| @@ -471,6 +471,7 @@ tgtok::TokKind TGLexer::LexExclaim() { | ||||
|     .Case("tail", tgtok::XTail) | ||||
|     .Case("con", tgtok::XConcat) | ||||
|     .Case("add", tgtok::XADD) | ||||
|     .Case("and", tgtok::XAND) | ||||
|     .Case("shl", tgtok::XSHL) | ||||
|     .Case("sra", tgtok::XSRA) | ||||
|     .Case("srl", tgtok::XSRL) | ||||
|   | ||||
| @@ -47,8 +47,8 @@ namespace tgtok { | ||||
|     MultiClass, String, | ||||
|      | ||||
|     // !keywords. | ||||
|     XConcat, XADD, XSRA, XSRL, XSHL, XListConcat, XStrConcat, XCast, XSubst, | ||||
|     XForEach, XHead, XTail, XEmpty, XIf, XEq, | ||||
|     XConcat, XADD, XAND, XSRA, XSRL, XSHL, XListConcat, XStrConcat, XCast, | ||||
|     XSubst, XForEach, XHead, XTail, XEmpty, XIf, XEq, | ||||
|  | ||||
|     // Integer value. | ||||
|     IntVal, | ||||
|   | ||||
| @@ -911,6 +911,7 @@ Init *TGParser::ParseOperation(Record *CurRec, RecTy *ItemType) { | ||||
|  | ||||
|   case tgtok::XConcat: | ||||
|   case tgtok::XADD: | ||||
|   case tgtok::XAND: | ||||
|   case tgtok::XSRA: | ||||
|   case tgtok::XSRL: | ||||
|   case tgtok::XSHL: | ||||
| @@ -928,6 +929,7 @@ Init *TGParser::ParseOperation(Record *CurRec, RecTy *ItemType) { | ||||
|     default: llvm_unreachable("Unhandled code!"); | ||||
|     case tgtok::XConcat: Code = BinOpInit::CONCAT;Type = DagRecTy::get(); break; | ||||
|     case tgtok::XADD:    Code = BinOpInit::ADD;   Type = IntRecTy::get(); break; | ||||
|     case tgtok::XAND:    Code = BinOpInit::AND;   Type = IntRecTy::get(); break; | ||||
|     case tgtok::XSRA:    Code = BinOpInit::SRA;   Type = IntRecTy::get(); break; | ||||
|     case tgtok::XSRL:    Code = BinOpInit::SRL;   Type = IntRecTy::get(); break; | ||||
|     case tgtok::XSHL:    Code = BinOpInit::SHL;   Type = IntRecTy::get(); break; | ||||
| @@ -1446,6 +1448,7 @@ Init *TGParser::ParseSimpleValue(Record *CurRec, RecTy *ItemType, | ||||
|   case tgtok::XCast:  // Value ::= !unop '(' Value ')' | ||||
|   case tgtok::XConcat: | ||||
|   case tgtok::XADD: | ||||
|   case tgtok::XAND: | ||||
|   case tgtok::XSRA: | ||||
|   case tgtok::XSRL: | ||||
|   case tgtok::XSHL: | ||||
|   | ||||
| @@ -15,6 +15,12 @@ class Int<int value> { | ||||
|   int Value = value; | ||||
| } | ||||
|  | ||||
| // CHECK: def v0 | ||||
| // CHECK: Value = 0 | ||||
|  | ||||
| // CHECK: def v1 | ||||
| // CHECK: Value = 1 | ||||
|  | ||||
| def v1024   : Int<1024>; | ||||
| // CHECK: def v1024 | ||||
| // CHECK: Value = 1024 | ||||
| @@ -27,3 +33,5 @@ def v2048   : Int<!add(v1024.Value, v1024.Value)>; | ||||
| // CHECK: def v2048 | ||||
| // CHECK: Value = 2048 | ||||
|  | ||||
| def v0 : Int<!and(v1024.Value, v2048.Value)>; | ||||
| def v1 : Int<!and(v1025.Value, 1)>; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user