mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-08 03:30:22 +00:00
2e73e851d8
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51744 91177308-0d34-0410-b5e6-96231b3b80d8
101 lines
2.1 KiB
TableGen
101 lines
2.1 KiB
TableGen
//===- Tools.td - Common definitions for LLVMCC -----------*- tablegen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains common definitions used in llvmcc tool description files.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
class Tool<list<dag> l> {
|
|
list<dag> properties = l;
|
|
}
|
|
|
|
// Special Tool instance - the root node of the compilation graph.
|
|
|
|
def root : Tool<[]>;
|
|
|
|
// Possible Tool properties
|
|
|
|
def in_language;
|
|
def out_language;
|
|
def output_suffix;
|
|
def cmd_line;
|
|
def join;
|
|
def sink;
|
|
|
|
// Possible option types
|
|
|
|
def switch_option;
|
|
def parameter_option;
|
|
def parameter_list_option;
|
|
def prefix_option;
|
|
def prefix_list_option;
|
|
|
|
// Possible option properties
|
|
|
|
def append_cmd;
|
|
def forward;
|
|
def stop_compilation;
|
|
def unpack_values;
|
|
def help;
|
|
def required;
|
|
|
|
// Marker for an empty DAG.
|
|
def empty;
|
|
|
|
// The 'case' construct.
|
|
def case;
|
|
|
|
// Primitive tests.
|
|
def switch_on;
|
|
def parameter_equals;
|
|
def element_in_list;
|
|
def input_languages_contain;
|
|
def not_empty;
|
|
// TOTHINK: remove?
|
|
def default;
|
|
|
|
// Boolean operators.
|
|
def and;
|
|
def or;
|
|
|
|
// Increase/decrease the edge weight.
|
|
def inc_weight;
|
|
def dec_weight;
|
|
|
|
// Map from suffixes to language names
|
|
|
|
class LangToSuffixes<string str, list<string> lst> {
|
|
string lang = str;
|
|
list<string> suffixes = lst;
|
|
}
|
|
|
|
class LanguageMap<list<LangToSuffixes> lst> {
|
|
list<LangToSuffixes> map = lst;
|
|
}
|
|
|
|
// Compilation graph
|
|
|
|
class EdgeBase<Tool t1, Tool t2, dag d> {
|
|
Tool a = t1;
|
|
Tool b = t2;
|
|
dag weight = d;
|
|
}
|
|
|
|
class Edge<Tool t1, Tool t2> : EdgeBase<t1, t2, (empty)>;
|
|
|
|
// Edge and SimpleEdge are synonyms.
|
|
class SimpleEdge<Tool t1, Tool t2> : EdgeBase<t1, t2, (empty)>;
|
|
|
|
// Optionally enabled edge.
|
|
class OptionalEdge<Tool t1, Tool t2, dag props> : EdgeBase<t1, t2, props>;
|
|
|
|
class CompilationGraph<list<EdgeBase> lst> {
|
|
list<EdgeBase> edges = lst;
|
|
}
|