You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			91 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			TableGen
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			TableGen
		
	
	
	
	
	
| //===-- RISCV.td - Describe the RISCV Target Machine -------*- tablegen -*-===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| include "llvm/Target/Target.td"
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // RISC-V subtarget features and instruction predicates.
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| def FeatureStdExtM
 | |
|     : SubtargetFeature<"m", "HasStdExtM", "true",
 | |
|                        "'M' (Integer Multiplication and Division)">;
 | |
| def HasStdExtM : Predicate<"Subtarget->hasStdExtM()">,
 | |
|                            AssemblerPredicate<"FeatureStdExtM">;
 | |
| 
 | |
| def FeatureStdExtA
 | |
|     : SubtargetFeature<"a", "HasStdExtA", "true",
 | |
|                        "'A' (Atomic Instructions)">;
 | |
| def HasStdExtA : Predicate<"Subtarget->hasStdExtA()">,
 | |
|                            AssemblerPredicate<"FeatureStdExtA">;
 | |
| 
 | |
| def FeatureStdExtF
 | |
|     : SubtargetFeature<"f", "HasStdExtF", "true",
 | |
|                        "'F' (Single-Precision Floating-Point)">;
 | |
| def HasStdExtF : Predicate<"Subtarget->hasStdExtF()">,
 | |
|                            AssemblerPredicate<"FeatureStdExtF">;
 | |
| 
 | |
| def FeatureStdExtD
 | |
|     : SubtargetFeature<"d", "HasStdExtD", "true",
 | |
|                        "'D' (Double-Precision Floating-Point)",
 | |
|                        [FeatureStdExtF]>;
 | |
| def HasStdExtD : Predicate<"Subtarget->hasStdExtD()">,
 | |
|                            AssemblerPredicate<"FeatureStdExtD">;
 | |
| 
 | |
| def FeatureStdExtC
 | |
|     : SubtargetFeature<"c", "HasStdExtC", "true",
 | |
|                        "'C' (Compressed Instructions)">;
 | |
| def HasStdExtC : Predicate<"Subtarget->hasStdExtC()">,
 | |
|                            AssemblerPredicate<"FeatureStdExtC">;
 | |
| 
 | |
| 
 | |
| def Feature64Bit
 | |
|     : SubtargetFeature<"64bit", "HasRV64", "true", "Implements RV64">;
 | |
| def IsRV64 : Predicate<"Subtarget->is64Bit()">,
 | |
|                        AssemblerPredicate<"Feature64Bit">;
 | |
| def IsRV32 : Predicate<"!Subtarget->is64Bit()">,
 | |
|                        AssemblerPredicate<"!Feature64Bit">;
 | |
| 
 | |
| def RV64           : HwMode<"+64bit">;
 | |
| def RV32           : HwMode<"-64bit">;
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // Registers, calling conventions, instruction descriptions.
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| include "RISCVRegisterInfo.td"
 | |
| include "RISCVCallingConv.td"
 | |
| include "RISCVInstrInfo.td"
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // RISC-V processors supported.
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| def : ProcessorModel<"generic-rv32", NoSchedModel, []>;
 | |
| 
 | |
| def : ProcessorModel<"generic-rv64", NoSchedModel, [Feature64Bit]>;
 | |
| 
 | |
| //===----------------------------------------------------------------------===//
 | |
| // Define the RISC-V target.
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| def RISCVInstrInfo : InstrInfo {
 | |
|   let guessInstructionProperties = 0;
 | |
| }
 | |
| 
 | |
| def RISCVAsmParser : AsmParser {
 | |
|   let ShouldEmitMatchRegisterAltName = 1;
 | |
|   let AllowDuplicateRegisterNames = 1;
 | |
| }
 | |
| 
 | |
| def RISCV : Target {
 | |
|   let InstructionSet = RISCVInstrInfo;
 | |
|   let AssemblyParsers = [RISCVAsmParser];
 | |
| }
 |