mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
Add a bunch of new node types, including a new Void dummy register class
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7870 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
673537e5c0
commit
b6ef5c860c
@ -86,6 +86,10 @@ class RegisterClass<ValueType regType, int alignment, list<Register> regList> {
|
|||||||
// Methods - This member can be used to insert arbitrary code into a generated
|
// Methods - This member can be used to insert arbitrary code into a generated
|
||||||
// register class. The normal usage of this is to overload virtual methods.
|
// register class. The normal usage of this is to overload virtual methods.
|
||||||
code Methods = [{}];
|
code Methods = [{}];
|
||||||
|
|
||||||
|
// isDummyClass - If this is set to true, this register class is not really
|
||||||
|
// part of the target, it is just used for other purposes.
|
||||||
|
bit isDummyClass = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -156,6 +160,7 @@ class Target {
|
|||||||
// DAG node definitions used by the instruction selector...
|
// DAG node definitions used by the instruction selector...
|
||||||
//
|
//
|
||||||
class DagNodeValType;
|
class DagNodeValType;
|
||||||
|
def DNVT_any : DagNodeValType; // No constraint on tree node
|
||||||
def DNVT_void : DagNodeValType; // Tree node always returns void
|
def DNVT_void : DagNodeValType; // Tree node always returns void
|
||||||
def DNVT_val : DagNodeValType; // A non-void type
|
def DNVT_val : DagNodeValType; // A non-void type
|
||||||
def DNVT_arg0 : DagNodeValType; // Tree node returns same type as Arg0
|
def DNVT_arg0 : DagNodeValType; // Tree node returns same type as Arg0
|
||||||
@ -177,7 +182,14 @@ class BuiltinDagNode<DagNodeValType Ret, list<DagNodeValType> Args,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Magic nodes...
|
// Magic nodes...
|
||||||
def set : DagNode<DNVT_void, [DNVT_val, DNVT_arg0]>;
|
def Void : RegisterClass<isVoid,0,[]> { let isDummyClass = 1; }
|
||||||
|
def set : DagNode<DNVT_void, [DNVT_val, DNVT_arg0]>;
|
||||||
|
def chain : BuiltinDagNode<DNVT_void, [DNVT_void, DNVT_void], "ChainNode">;
|
||||||
|
def blockchain : BuiltinDagNode<DNVT_void, [DNVT_void, DNVT_void],
|
||||||
|
"BlockChainNode">;
|
||||||
|
def ChainExpander : Expander<(chain Void, Void), []>;
|
||||||
|
def BlockChainExpander : Expander<(blockchain Void, Void), []>;
|
||||||
|
|
||||||
|
|
||||||
// Terminals...
|
// Terminals...
|
||||||
def imm : BuiltinDagNode<DNVT_val, [], "Constant">;
|
def imm : BuiltinDagNode<DNVT_val, [], "Constant">;
|
||||||
@ -214,6 +226,9 @@ def br : BuiltinDagNode<DNVT_void, [DNVT_ptr], "Br">;
|
|||||||
def brcond : BuiltinDagNode<DNVT_void, [DNVT_i8, DNVT_ptr, DNVT_ptr],
|
def brcond : BuiltinDagNode<DNVT_void, [DNVT_i8, DNVT_ptr, DNVT_ptr],
|
||||||
"BrCond">;
|
"BrCond">;
|
||||||
|
|
||||||
|
def unspec1 : BuiltinDagNode<DNVT_any , [DNVT_val], "Unspec1">;
|
||||||
|
def unspec2 : BuiltinDagNode<DNVT_any , [DNVT_val, DNVT_val], "Unspec2">;
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// DAG nonterminals definitions used by the instruction selector...
|
// DAG nonterminals definitions used by the instruction selector...
|
||||||
//
|
//
|
||||||
|
Loading…
x
Reference in New Issue
Block a user