mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30039 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			114 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			TableGen
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			TableGen
		
	
	
	
	
	
| //===- SparcInstrFormats.td - Sparc Instruction Formats ----*- tablegen -*-===//
 | |
| // 
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file was developed by the LLVM research group and is distributed under
 | |
| // the University of Illinois Open Source License. See LICENSE.TXT for details.
 | |
| // 
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| class InstSP<dag ops, string asmstr, list<dag> pattern> : Instruction {
 | |
|   field bits<32> Inst;
 | |
| 
 | |
|   let Namespace = "SP";
 | |
| 
 | |
|   bits<2> op;
 | |
|   let Inst{31-30} = op;               // Top two bits are the 'op' field
 | |
|   
 | |
|   dag OperandList = ops;
 | |
|   let AsmString   = asmstr;
 | |
|   let Pattern = pattern;
 | |
| }
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // Format #2 instruction classes in the Sparc
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // Format 2 instructions
 | |
| class F2<dag ops, string asmstr, list<dag> pattern>
 | |
|    : InstSP<ops, asmstr, pattern> {
 | |
|   bits<3>  op2;
 | |
|   bits<22> imm22;
 | |
|   let op          = 0;    // op = 0
 | |
|   let Inst{24-22} = op2;
 | |
|   let Inst{21-0}  = imm22;
 | |
| }
 | |
| 
 | |
| // Specific F2 classes: SparcV8 manual, page 44
 | |
| //
 | |
| class F2_1<bits<3> op2Val, dag ops, string asmstr, list<dag> pattern>
 | |
|    : F2<ops, asmstr, pattern> {
 | |
|   bits<5>  rd;
 | |
| 
 | |
|   let op2         = op2Val;
 | |
| 
 | |
|   let Inst{29-25} = rd;
 | |
| }
 | |
| 
 | |
| class F2_2<bits<4> condVal, bits<3> op2Val, dag ops, string asmstr, 
 | |
|            list<dag> pattern> : F2<ops, asmstr, pattern> {
 | |
|   bits<4>   cond;
 | |
|   bit       annul = 0;     // currently unused
 | |
| 
 | |
|   let cond        = condVal;
 | |
|   let op2         = op2Val;
 | |
| 
 | |
|   let Inst{29}    = annul;
 | |
|   let Inst{28-25} = cond;
 | |
| }
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // Format #3 instruction classes in the Sparc
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| class F3<dag ops, string asmstr, list<dag> pattern>
 | |
|     : InstSP<ops, asmstr, pattern> {
 | |
|   bits<5> rd;
 | |
|   bits<6> op3;
 | |
|   bits<5> rs1;
 | |
|   let op{1} = 1;   // Op = 2 or 3
 | |
|   let Inst{29-25} = rd;
 | |
|   let Inst{24-19} = op3;
 | |
|   let Inst{18-14} = rs1;
 | |
| }
 | |
| 
 | |
| // Specific F3 classes: SparcV8 manual, page 44
 | |
| //
 | |
| class F3_1<bits<2> opVal, bits<6> op3val, dag ops,
 | |
|            string asmstr, list<dag> pattern> : F3<ops, asmstr, pattern> {
 | |
|   bits<8> asi = 0; // asi not currently used
 | |
|   bits<5> rs2;
 | |
| 
 | |
|   let op         = opVal;
 | |
|   let op3        = op3val;
 | |
| 
 | |
|   let Inst{13}   = 0;     // i field = 0
 | |
|   let Inst{12-5} = asi;   // address space identifier
 | |
|   let Inst{4-0}  = rs2;
 | |
| }
 | |
| 
 | |
| class F3_2<bits<2> opVal, bits<6> op3val, dag ops, 
 | |
|            string asmstr, list<dag> pattern> : F3<ops, asmstr, pattern> {
 | |
|   bits<13> simm13;
 | |
| 
 | |
|   let op         = opVal;
 | |
|   let op3        = op3val;
 | |
| 
 | |
|   let Inst{13}   = 1;     // i field = 1
 | |
|   let Inst{12-0} = simm13;
 | |
| }
 | |
| 
 | |
| // floating-point
 | |
| class F3_3<bits<2> opVal, bits<6> op3val, bits<9> opfval, dag ops,
 | |
|            string asmstr, list<dag> pattern> : F3<ops, asmstr, pattern> {
 | |
|   bits<5> rs2;
 | |
| 
 | |
|   let op         = opVal;
 | |
|   let op3        = op3val;
 | |
| 
 | |
|   let Inst{13-5} = opfval;   // fp opcode
 | |
|   let Inst{4-0}  = rs2;
 | |
| }
 | |
| 
 | |
| 
 |