[yaml2obj/obj2yaml] - Add support for .stack_sizes sections.
[llvm-complete.git] / docs / CommandGuide / tblgen.rst
blob372d1b2a73086ff0938a0a4441259a6f2fab7a1c
1 tblgen - Target Description To C++ Code Generator
2 =================================================
4 .. program:: tblgen
6 SYNOPSIS
7 --------
9 :program:`tblgen` [*options*] [*filename*]
11 DESCRIPTION
12 -----------
14 :program:`tblgen` translates from target description (``.td``) files into C++
15 code that can be included in the definition of an LLVM target library.  Most
16 users of LLVM will not need to use this program.  It is only for assisting with
17 writing an LLVM target backend.
19 The input and output of :program:`tblgen` is beyond the scope of this short
20 introduction; please see the :doc:`introduction to TableGen
21 <../TableGen/index>`.
23 The *filename* argument specifies the name of a Target Description (``.td``)
24 file to read as input.
26 OPTIONS
27 -------
29 .. program:: tblgen
31 .. option:: -help
33  Print a summary of command line options.
35 .. option:: -o filename
37  Specify the output file name.  If ``filename`` is ``-``, then
38  :program:`tblgen` sends its output to standard output.
40 .. option:: -I directory
42  Specify where to find other target description files for inclusion.  The
43  ``directory`` value should be a full or partial path to a directory that
44  contains target description files.
46 .. option:: -asmparsernum N
48  Make -gen-asm-parser emit assembly writer number ``N``.
50 .. option:: -asmwriternum N
52  Make -gen-asm-writer emit assembly writer number ``N``.
54 .. option:: -class className
56  Print the enumeration list for this class.
58 .. option:: -print-records
60  Print all records to standard output (default).
62 .. option:: -dump-json
64  Print a JSON representation of all records, suitable for further
65  automated processing.
67 .. option:: -print-enums
69  Print enumeration values for a class.
71 .. option:: -print-sets
73  Print expanded sets for testing DAG exprs.
75 .. option:: -gen-emitter
77  Generate machine code emitter.
79 .. option:: -gen-register-info
81  Generate registers and register classes info.
83 .. option:: -gen-instr-info
85  Generate instruction descriptions.
87 .. option:: -gen-asm-writer
89  Generate the assembly writer.
91 .. option:: -gen-disassembler
93  Generate disassembler.
95 .. option:: -gen-pseudo-lowering
97  Generate pseudo instruction lowering.
99 .. option:: -gen-dag-isel
101  Generate a DAG (Directed Acycle Graph) instruction selector.
103 .. option:: -gen-asm-matcher
105  Generate assembly instruction matcher.
107 .. option:: -gen-dfa-packetizer
109  Generate DFA Packetizer for VLIW targets.
111 .. option:: -gen-fast-isel
113  Generate a "fast" instruction selector.
115 .. option:: -gen-subtarget
117  Generate subtarget enumerations.
119 .. option:: -gen-intrinsic-enums
121  Generate intrinsic enums.
123 .. option:: -gen-intrinsic-impl
125  Generate intrinsic implementation.
127 .. option:: -gen-tgt-intrinsic
129  Generate target intrinsic information.
131 .. option:: -gen-enhanced-disassembly-info
133  Generate enhanced disassembly info.
135 .. option:: -gen-exegesis
137  Generate llvm-exegesis tables.
139 .. option:: -version
141  Show the version number of this program.
143 EXIT STATUS
144 -----------
146 If :program:`tblgen` succeeds, it will exit with 0.  Otherwise, if an error
147 occurs, it will exit with a non-zero value.