|
|
1.1 root 1: @c Copyright (C) 1988, 1989, 1992 Free Software Foundation, Inc.
2: @c This is part of the GCC manual.
3: @c For copying conditions, see the file gcc.texi.
4:
5: @node RTL
6: @chapter RTL Representation
7: @cindex RTL representation
8: @cindex representation of RTL
9: @cindex Register Transfer Language (RTL)
10:
11: Most of the work of the compiler is done on an intermediate representation
12: called register transfer language. In this language, the instructions to be
13: output are described, pretty much one by one, in an algebraic form that
14: describes what the instruction does.
15:
16: RTL is inspired by Lisp lists. It has both an internal form, made up of
17: structures that point at other structures, and a textual form that is used
18: in the machine description and in printed debugging dumps. The textual
19: form uses nested parentheses to indicate the pointers in the internal form.
20:
21: @menu
22: * RTL Objects:: Expressions vs vectors vs strings vs integers.
23: * Accessors:: Macros to access expression operands or vector elts.
24: * Flags:: Other flags in an RTL expression.
25: * Machine Modes:: Describing the size and format of a datum.
26: * Constants:: Expressions with constant values.
27: * Regs and Memory:: Expressions representing register contents or memory.
28: * Arithmetic:: Expressions representing arithmetic on other expressions.
29: * Comparisons:: Expressions representing comparison of expressions.
30: * Bit Fields:: Expressions representing bitfields in memory or reg.
31: * Conversions:: Extending, truncating, floating or fixing.
32: * RTL Declarations:: Declaring volatility, constancy, etc.
33: * Side Effects:: Expressions for storing in registers, etc.
34: * Incdec:: Embedded side-effects for autoincrement addressing.
35: * Assembler:: Representing @code{asm} with operands.
36: * Insns:: Expression types for entire insns.
37: * Calls:: RTL representation of function call insns.
38: * Sharing:: Some expressions are unique; others *must* be copied.
39: * Reading RTL:: Reading textual RTL from a file.
40: @end menu
41:
42: @node RTL Objects, Accessors, RTL, RTL
43: @section RTL Object Types
44: @cindex RTL object types
45:
46: @cindex RTL integers
47: @cindex RTL strings
48: @cindex RTL vectors
49: @cindex RTL expression
50: @cindex RTX (See RTL)
51: RTL uses five kinds of objects: expressions, integers, wide integers,
52: strings and vectors. Expressions are the most important ones. An RTL
53: expression (``RTX'', for short) is a C structure, but it is usually
54: referred to with a pointer; a type that is given the typedef name
55: @code{rtx}.
56:
57: An integer is simply an @code{int}; their written form uses decimal digits.
58: A wide integer is an integral object whose type is @code{HOST_WIDE_INT}
59: (@pxref{Config}); their written form uses decimal digits.
60:
61: A string is a sequence of characters. In core it is represented as a
62: @code{char *} in usual C fashion, and it is written in C syntax as well.
63: However, strings in RTL may never be null. If you write an empty string in
64: a machine description, it is represented in core as a null pointer rather
65: than as a pointer to a null character. In certain contexts, these null
66: pointers instead of strings are valid. Within RTL code, strings are most
67: commonly found inside @code{symbol_ref} expressions, but they appear in
68: other contexts in the RTL expressions that make up machine descriptions.
69:
70: A vector contains an arbitrary number of pointers to expressions. The
71: number of elements in the vector is explicitly present in the vector.
72: The written form of a vector consists of square brackets
73: (@samp{[@dots{}]}) surrounding the elements, in sequence and with
74: whitespace separating them. Vectors of length zero are not created;
75: null pointers are used instead.
76:
77: @cindex expression codes
78: @cindex codes, RTL expression
79: @findex GET_CODE
80: @findex PUT_CODE
81: Expressions are classified by @dfn{expression codes} (also called RTX
82: codes). The expression code is a name defined in @file{rtl.def}, which is
83: also (in upper case) a C enumeration constant. The possible expression
84: codes and their meanings are machine-independent. The code of an RTX can
85: be extracted with the macro @code{GET_CODE (@var{x})} and altered with
86: @code{PUT_CODE (@var{x}, @var{newcode})}.
87:
88: The expression code determines how many operands the expression contains,
89: and what kinds of objects they are. In RTL, unlike Lisp, you cannot tell
90: by looking at an operand what kind of object it is. Instead, you must know
91: from its context---from the expression code of the containing expression.
92: For example, in an expression of code @code{subreg}, the first operand is
93: to be regarded as an expression and the second operand as an integer. In
94: an expression of code @code{plus}, there are two operands, both of which
95: are to be regarded as expressions. In a @code{symbol_ref} expression,
96: there is one operand, which is to be regarded as a string.
97:
98: Expressions are written as parentheses containing the name of the
99: expression type, its flags and machine mode if any, and then the operands
100: of the expression (separated by spaces).
101:
102: Expression code names in the @samp{md} file are written in lower case,
103: but when they appear in C code they are written in upper case. In this
104: manual, they are shown as follows: @code{const_int}.
105:
106: @cindex (nil)
107: @cindex nil
108: In a few contexts a null pointer is valid where an expression is normally
109: wanted. The written form of this is @code{(nil)}.
110:
111: @node Accessors, Flags, RTL Objects, RTL
112: @section Access to Operands
113: @cindex accessors
114: @cindex access to operands
115: @cindex operand access
116:
117: @cindex RTL format
118: For each expression type @file{rtl.def} specifies the number of
119: contained objects and their kinds, with four possibilities: @samp{e} for
120: expression (actually a pointer to an expression), @samp{i} for integer,
121: @samp{w} for wide integer, @samp{s} for string, and @samp{E} for vector
122: of expressions. The sequence of letters for an expression code is
123: called its @dfn{format}. Thus, the format of @code{subreg} is
124: @samp{ei}.@refill
125:
126: @cindex RTL format characters
127: A few other format characters are used occasionally:
128:
129: @table @code
130: @item u
131: @samp{u} is equivalent to @samp{e} except that it is printed differently
132: in debugging dumps. It is used for pointers to insns.
133:
134: @item n
135: @samp{n} is equivalent to @samp{i} except that it is printed differently
136: in debugging dumps. It is used for the line number or code number of a
137: @code{note} insn.
138:
139: @item S
140: @samp{S} indicates a string which is optional. In the RTL objects in
141: core, @samp{S} is equivalent to @samp{s}, but when the object is read,
142: from an @samp{md} file, the string value of this operand may be omitted.
143: An omitted string is taken to be the null string.
144:
145: @item V
146: @samp{V} indicates a vector which is optional. In the RTL objects in
147: core, @samp{V} is equivalent to @samp{E}, but when the object is read
148: from an @samp{md} file, the vector value of this operand may be omitted.
149: An omitted vector is effectively the same as a vector of no elements.
150:
151: @item 0
152: @samp{0} means a slot whose contents do not fit any normal category.
153: @samp{0} slots are not printed at all in dumps, and are often used in
154: special ways by small parts of the compiler.
155: @end table
156:
157: There are macros to get the number of operands, the format, and the
158: class of an expression code:
159:
160: @table @code
161: @findex GET_RTX_LENGTH
162: @item GET_RTX_LENGTH (@var{code})
163: Number of operands of an RTX of code @var{code}.
164:
165: @findex GET_RTX_FORMAT
166: @item GET_RTX_FORMAT (@var{code})
167: The format of an RTX of code @var{code}, as a C string.
168:
169: @findex GET_RTX_CLASS
170: @cindex classes of RTX codes
171: @item GET_RTX_CLASS (@var{code})
172: A single character representing the type of RTX operation that code
173: @var{code} performs.
174:
175: The following classes are defined:
176:
177: @table @code
178: @item o
179: An RTX code that represents an actual object, such as @code{reg} or
180: @code{mem}. @code{subreg} is not in this class.
181:
182: @item <
183: An RTX code for a comparison. The codes in this class are
184: @code{NE}, @code{EQ}, @code{LE}, @code{LT}, @code{GE}, @code{GT},
185: @code{LEU}, @code{LTU}, @code{GEU}, @code{GTU}.@refill
186:
187: @item 1
188: An RTX code for a unary arithmetic operation, such as @code{neg}.
189:
190: @item c
191: An RTX code for a commutative binary operation, other than @code{NE}
192: and @code{EQ} (which have class @samp{<}).
193:
194: @item 2
195: An RTX code for a noncommutative binary operation, such as @code{MINUS}.
196:
197: @item b
198: An RTX code for a bitfield operation, either @code{ZERO_EXTRACT} or
199: @code{SIGN_EXTRACT}.
200:
201: @item 3
202: An RTX code for other three input operations, such as @code{IF_THEN_ELSE}.
203:
204: @item i
205: An RTX code for a machine insn (@code{INSN}, @code{JUMP_INSN}, and
206: @code{CALL_INSN}).@refill
207:
208: @item m
209: An RTX code for something that matches in insns, such as @code{MATCH_DUP}.
210:
211: @item x
212: All other RTX codes.
213: @end table
214: @end table
215:
216: @findex XEXP
217: @findex XINT
218: @findex XWINT
219: @findex XSTR
220: Operands of expressions are accessed using the macros @code{XEXP},
221: @code{XINT}, @code{XWINT} and @code{XSTR}. Each of these macros takes
222: two arguments: an expression-pointer (RTX) and an operand number
223: (counting from zero). Thus,@refill
224:
225: @example
226: XEXP (@var{x}, 2)
227: @end example
228:
229: @noindent
230: accesses operand 2 of expression @var{x}, as an expression.
231:
232: @example
233: XINT (@var{x}, 2)
234: @end example
235:
236: @noindent
237: accesses the same operand as an integer. @code{XSTR}, used in the same
238: fashion, would access it as a string.
239:
240: Any operand can be accessed as an integer, as an expression or as a string.
241: You must choose the correct method of access for the kind of value actually
242: stored in the operand. You would do this based on the expression code of
243: the containing expression. That is also how you would know how many
244: operands there are.
245:
246: For example, if @var{x} is a @code{subreg} expression, you know that it has
247: two operands which can be correctly accessed as @code{XEXP (@var{x}, 0)}
248: and @code{XINT (@var{x}, 1)}. If you did @code{XINT (@var{x}, 0)}, you
249: would get the address of the expression operand but cast as an integer;
250: that might occasionally be useful, but it would be cleaner to write
251: @code{(int) XEXP (@var{x}, 0)}. @code{XEXP (@var{x}, 1)} would also
252: compile without error, and would return the second, integer operand cast as
253: an expression pointer, which would probably result in a crash when
254: accessed. Nothing stops you from writing @code{XEXP (@var{x}, 28)} either,
255: but this will access memory past the end of the expression with
256: unpredictable results.@refill
257:
258: Access to operands which are vectors is more complicated. You can use the
259: macro @code{XVEC} to get the vector-pointer itself, or the macros
260: @code{XVECEXP} and @code{XVECLEN} to access the elements and length of a
261: vector.
262:
263: @table @code
264: @findex XVEC
265: @item XVEC (@var{exp}, @var{idx})
266: Access the vector-pointer which is operand number @var{idx} in @var{exp}.
267:
268: @findex XVECLEN
269: @item XVECLEN (@var{exp}, @var{idx})
270: Access the length (number of elements) in the vector which is
271: in operand number @var{idx} in @var{exp}. This value is an @code{int}.
272:
273: @findex XVECEXP
274: @item XVECEXP (@var{exp}, @var{idx}, @var{eltnum})
275: Access element number @var{eltnum} in the vector which is
276: in operand number @var{idx} in @var{exp}. This value is an RTX.
277:
278: It is up to you to make sure that @var{eltnum} is not negative
279: and is less than @code{XVECLEN (@var{exp}, @var{idx})}.
280: @end table
281:
282: All the macros defined in this section expand into lvalues and therefore
283: can be used to assign the operands, lengths and vector elements as well as
284: to access them.
285:
286: @node Flags, Machine Modes, Accessors, RTL
287: @section Flags in an RTL Expression
288: @cindex flags in RTL expression
289:
290: RTL expressions contain several flags (one-bit bitfields) that are used
291: in certain types of expression. Most often they are accessed with the
292: following macros:
293:
294: @table @code
295: @findex MEM_VOLATILE_P
296: @cindex @code{mem} and @samp{/v}
297: @cindex @code{volatil}, in @code{mem}
298: @cindex @samp{/v} in RTL dump
299: @item MEM_VOLATILE_P (@var{x})
300: In @code{mem} expressions, nonzero for volatile memory references.
301: Stored in the @code{volatil} field and printed as @samp{/v}.
302:
303: @findex MEM_IN_STRUCT_P
304: @cindex @code{mem} and @samp{/s}
305: @cindex @code{in_struct}, in @code{mem}
306: @cindex @samp{/s} in RTL dump
307: @item MEM_IN_STRUCT_P (@var{x})
308: In @code{mem} expressions, nonzero for reference to an entire
309: structure, union or array, or to a component of one. Zero for
310: references to a scalar variable or through a pointer to a scalar.
311: Stored in the @code{in_struct} field and printed as @samp{/s}.
312:
313: @findex REG_LOOP_TEST_P
314: @cindex @code{reg} and @samp{/s}
315: @cindex @code{in_struct}, in @code{reg}
316: @item REG_LOOP_TEST_P
317: In @code{reg} expressions, nonzero if this register's entire life is
318: contained in the exit test code for some loop. Stored in the
319: @code{in_struct} field and printed as @samp{/s}.
320:
321: @findex REG_USERVAR_P
322: @cindex @code{reg} and @samp{/v}
323: @cindex @code{volatil}, in @code{reg}
324: @item REG_USERVAR_P (@var{x})
325: In a @code{reg}, nonzero if it corresponds to a variable present in
326: the user's source code. Zero for temporaries generated internally by
327: the compiler. Stored in the @code{volatil} field and printed as
328: @samp{/v}.
329:
330: @cindex @samp{/i} in RTL dump
331: @findex REG_FUNCTION_VALUE_P
332: @cindex @code{reg} and @samp{/i}
333: @cindex @code{integrated}, in @code{reg}
334: @item REG_FUNCTION_VALUE_P (@var{x})
335: Nonzero in a @code{reg} if it is the place in which this function's
336: value is going to be returned. (This happens only in a hard
337: register.) Stored in the @code{integrated} field and printed as
338: @samp{/i}.
339:
340: The same hard register may be used also for collecting the values of
341: functions called by this one, but @code{REG_FUNCTION_VALUE_P} is zero
342: in this kind of use.
343:
344: @findex SUBREG_PROMOTED_VAR_P
345: @cindex @code{subreg} and @samp{/s}
346: @cindex @code{in_struct}, in @code{subreg}
347: @item SUBREG_PROMOTED_VAR_P
348: Nonzero in a @code{subreg} if it was made when accessing an object that
349: was promoted to a wider mode in accord with the @code{PROMOTED_MODE} machine
350: description macro (@pxref{Storage Layout}). In this case, the mode of
351: the @code{subreg} is the declared mode of the object and the mode of
352: @code{SUBREG_REG} is the mode of the register that holds the object.
353: Promoted variables are always either sign- or zero-extended to the wider
354: mode on every assignment. Stored in the @code{in_struct} field and
355: printed as @samp{/s}.
356:
357: @findex SUBREG_PROMOTED_UNSIGNED_P
358: @cindex @code{subreg} and @samp{/u}
359: @cindex @code{unchanging}, in @code{subreg}
360: @item SUBREG_PROMOTED_UNSIGNED_P
361: Nonzero in a @code{subreg} that has @code{SUBREG_PROMOTED_VAR_P} nonzero
362: if the object being referenced is kept zero-extended and zero if it
363: is kept sign-extended. Stored in the @code{unchanging} field and
364: printed as @samp{/u}.
365:
366: @findex RTX_UNCHANGING_P
367: @cindex @code{reg} and @samp{/u}
368: @cindex @code{mem} and @samp{/u}
369: @cindex @code{unchanging}, in @code{reg} and @code{mem}
370: @cindex @samp{/u} in RTL dump
371: @item RTX_UNCHANGING_P (@var{x})
372: Nonzero in a @code{reg} or @code{mem} if the value is not changed.
373: (This flag is not set for memory references via pointers to constants.
374: Such pointers only guarantee that the object will not be changed
375: explicitly by the current function. The object might be changed by
376: other functions or by aliasing.) Stored in the
377: @code{unchanging} field and printed as @samp{/u}.
378:
379: @findex RTX_INTEGRATED_P
380: @cindex @code{integrated}, in @code{insn}
381: @item RTX_INTEGRATED_P (@var{insn})
382: Nonzero in an insn if it resulted from an in-line function call.
383: Stored in the @code{integrated} field and printed as @samp{/i}. This
384: may be deleted; nothing currently depends on it.
385:
386: @findex SYMBOL_REF_USED
387: @cindex @code{used}, in @code{symbol_ref}
388: @item SYMBOL_REF_USED (@var{x})
389: In a @code{symbol_ref}, indicates that @var{x} has been used. This is
390: normally only used to ensure that @var{x} is only declared external
391: once. Stored in the @code{used} field.
392:
393: @findex SYMBOL_REF_FLAG
394: @cindex @code{symbol_ref} and @samp{/v}
395: @cindex @code{volatil}, in @code{symbol_ref}
396: @item SYMBOL_REF_FLAG (@var{x})
397: In a @code{symbol_ref}, this is used as a flag for machine-specific purposes.
398: Stored in the @code{volatil} field and printed as @samp{/v}.
399:
400: @findex LABEL_OUTSIDE_LOOP_P
401: @cindex @code{label_ref} and @samp{/s}
402: @cindex @code{in_struct}, in @code{label_ref}
403: @item LABEL_OUTSIDE_LOOP_P
404: In @code{label_ref} expressions, nonzero if this is a reference to a
405: label that is outside the innermost loop containing the reference to the
406: label. Stored in the @code{in_struct} field and printed as @samp{/s}.
407:
408: @findex INSN_DELETED_P
409: @cindex @code{volatil}, in @code{insn}
410: @item INSN_DELETED_P (@var{insn})
411: In an insn, nonzero if the insn has been deleted. Stored in the
412: @code{volatil} field and printed as @samp{/v}.
413:
414: @findex INSN_ANNULLED_BRANCH_P
415: @cindex @code{insn} and @samp{/u}
416: @cindex @code{unchanging}, in @code{insn}
417: @item INSN_ANNULLED_BRANCH_P (@var{insn})
418: In an @code{insn} in the delay slot of a branch insn, indicates that an
419: annulling branch should be used. See the discussion under
420: @code{sequence} below. Stored in the @code{unchanging} field and printed
421: as @samp{/u}.
422:
423: @findex INSN_FROM_TARGET_P
424: @cindex @code{insn} and @samp{/s}
425: @cindex @code{in_struct}, in @code{insn}
426: @cindex @samp{/s} in RTL dump
427: @item INSN_FROM_TARGET_P (@var{insn})
428: In an @code{insn} in a delay slot of a branch, indicates that the insn
429: is from the target of the branch. If the branch insn has
430: @code{INSN_ANNULLED_BRANCH_P} set, this insn should only be executed if
431: the branch is taken. For annulled branches with this bit clear, the
432: insn should be executed only if the branch is not taken. Stored in the
433: @code{in_struct} field and printed as @samp{/s}.
434:
435: @findex CONSTANT_POOL_ADDRESS_P
436: @cindex @code{symbol_ref} and @samp{/u}
437: @cindex @code{unchanging}, in @code{symbol_ref}
438: @item CONSTANT_POOL_ADDRESS_P (@var{x})
439: Nonzero in a @code{symbol_ref} if it refers to part of the current
440: function's ``constants pool''. These are addresses close to the
441: beginning of the function, and GNU CC assumes they can be addressed
442: directly (perhaps with the help of base registers). Stored in the
443: @code{unchanging} field and printed as @samp{/u}.
444:
445: @findex CONST_CALL_P
446: @cindex @code{call_insn} and @samp{/u}
447: @cindex @code{unchanging}, in @code{call_insn}
448: @item CONST_CALL_P (@var{x})
449: In a @code{call_insn}, indicates that the insn represents a call to a const
450: function. Stored in the @code{unchanging} field and printed as @samp{/u}.
451:
452: @findex LABEL_PRESERVE_P
453: @cindex @code{code_label} and @samp{/i}
454: @cindex @code{in_struct}, in @code{code_label}
455: @item LABEL_PRESERVE_P (@var{x})
456: In a @code{code_label}, indicates that the label can never be deleted.
457: Labels referenced by a non-local goto will have this bit set. Stored
458: in the @code{in_struct} field and printed as @samp{/s}.
459:
460: @findex SCHED_GROUP_P
461: @cindex @code{insn} and @samp{/i}
462: @cindex @code{in_struct}, in @code{insn}
463: @item SCHED_GROUP_P (@var{insn})
464: During instruction scheduling, in an insn, indicates that the previous insn
465: must be scheduled together with this insn. This is used to ensure that
466: certain groups of instructions will not be split up by the instruction
467: scheduling pass, for example, @code{use} insns before a @code{call_insn} may
468: not be separated from the @code{call_insn}. Stored in the @code{in_struct}
469: field and printed as @samp{/s}.
470: @end table
471:
472: These are the fields which the above macros refer to:
473:
474: @table @code
475: @findex used
476: @item used
477: Normally, this flag is used only momentarily, at the end of RTL
478: generation for a function, to count the number of times an expression
479: appears in insns. Expressions that appear more than once are copied,
480: according to the rules for shared structure (@pxref{Sharing}).
481:
482: In a @code{symbol_ref}, it indicates that an external declaration for
483: the symbol has already been written.
484:
485: In a @code{reg}, it is used by the leaf register renumbering code to ensure
486: that each register is only renumbered once.
487:
488: @findex volatil
489: @item volatil
490: This flag is used in @code{mem}, @code{symbol_ref} and @code{reg}
491: expressions and in insns. In RTL dump files, it is printed as
492: @samp{/v}.
493:
494: @cindex volatile memory references
495: In a @code{mem} expression, it is 1 if the memory reference is volatile.
496: Volatile memory references may not be deleted, reordered or combined.
497:
498: In a @code{symbol_ref} expression, it is used for machine-specific
499: purposes.
500:
501: In a @code{reg} expression, it is 1 if the value is a user-level variable.
502: 0 indicates an internal compiler temporary.
503:
504: In an insn, 1 means the insn has been deleted.
505:
506: @findex in_struct
507: @item in_struct
508: In @code{mem} expressions, it is 1 if the memory datum referred to is
509: all or part of a structure or array; 0 if it is (or might be) a scalar
510: variable. A reference through a C pointer has 0 because the pointer
511: might point to a scalar variable. This information allows the compiler
512: to determine something about possible cases of aliasing.
513:
514: In an insn in the delay slot of a branch, 1 means that this insn is from
515: the target of the branch.
516:
517: During instruction scheduling, in an insn, 1 means that this insn must be
518: scheduled as part of a group together with the previous insn.
519:
520: In @code{reg} expressions, it is 1 if the register has its entire life
521: contained within the test expression of some loop.
522:
523: In @code{subreg} expressions, 1 means that the @code{subreg} is accessing
524: an object that has had its mode promoted from a wider mode.
525:
526: In @code{label_ref} expressions, 1 means that the referenced label is
527: outside the innermost loop containing the insn in which the @code{label_ref}
528: was found.
529:
530: In @code{code_label} expressions, it is 1 if the label may never be deleted.
531: This is used for labels which are the target of non-local gotos.
532:
533: In an RTL dump, this flag is represented as @samp{/s}.
534:
535: @findex unchanging
536: @item unchanging
537: In @code{reg} and @code{mem} expressions, 1 means
538: that the value of the expression never changes.
539:
540: In @code{subreg} expressions, it is 1 if the @code{subreg} references an
541: unsigned object whose mode has been promoted to a wider mode.
542:
543: In an insn, 1 means that this is an annulling branch.
544:
545: In a @code{symbol_ref} expression, 1 means that this symbol addresses
546: something in the per-function constants pool.
547:
548: In a @code{call_insn}, 1 means that this instruction is a call to a
549: const function.
550:
551: In an RTL dump, this flag is represented as @samp{/u}.
552:
553: @findex integrated
554: @item integrated
555: In some kinds of expressions, including insns, this flag means the
556: rtl was produced by procedure integration.
557:
558: In a @code{reg} expression, this flag indicates the register
559: containing the value to be returned by the current function. On
560: machines that pass parameters in registers, the same register number
561: may be used for parameters as well, but this flag is not set on such
562: uses.
563: @end table
564:
565: @node Machine Modes, Constants, Flags, RTL
566: @section Machine Modes
567: @cindex machine modes
568:
569: @findex enum machine_mode
570: A machine mode describes a size of data object and the representation used
571: for it. In the C code, machine modes are represented by an enumeration
572: type, @code{enum machine_mode}, defined in @file{machmode.def}. Each RTL
573: expression has room for a machine mode and so do certain kinds of tree
574: expressions (declarations and types, to be precise).
575:
576: In debugging dumps and machine descriptions, the machine mode of an RTL
577: expression is written after the expression code with a colon to separate
578: them. The letters @samp{mode} which appear at the end of each machine mode
579: name are omitted. For example, @code{(reg:SI 38)} is a @code{reg}
580: expression with machine mode @code{SImode}. If the mode is
581: @code{VOIDmode}, it is not written at all.
582:
583: Here is a table of machine modes. The term ``byte'' below refers to an
584: object of @code{BITS_PER_UNIT} bits (@pxref{Storage Layout}).
585:
586: @table @code
587: @findex QImode
588: @item QImode
589: ``Quarter-Integer'' mode represents a single byte treated as an integer.
590:
591: @findex HImode
592: @item HImode
593: ``Half-Integer'' mode represents a two-byte integer.
594:
595: @findex PSImode
596: @item PSImode
597: ``Partial Single Integer'' mode represents an integer which occupies
598: four bytes but which doesn't really use all four. On some machines,
599: this is the right mode to use for pointers.
600:
601: @findex SImode
602: @item SImode
603: ``Single Integer'' mode represents a four-byte integer.
604:
605: @findex PDImode
606: @item PDImode
607: ``Partial Double Integer'' mode represents an integer which occupies
608: eight bytes but which doesn't really use all eight. On some machines,
609: this is the right mode to use for certain pointers.
610:
611: @findex DImode
612: @item DImode
613: ``Double Integer'' mode represents an eight-byte integer.
614:
615: @findex TImode
616: @item TImode
617: ``Tetra Integer'' (?) mode represents a sixteen-byte integer.
618:
619: @findex SFmode
620: @item SFmode
621: ``Single Floating'' mode represents a single-precision (four byte) floating
622: point number.
623:
624: @findex DFmode
625: @item DFmode
626: ``Double Floating'' mode represents a double-precision (eight byte) floating
627: point number.
628:
629: @findex XFmode
630: @item XFmode
631: ``Extended Floating'' mode represents a triple-precision (twelve byte)
632: floating point number. This mode is used for IEEE extended floating
633: point.
634:
635: @findex TFmode
636: @item TFmode
637: ``Tetra Floating'' mode represents a quadruple-precision (sixteen byte)
638: floating point number.
639:
640: @findex CCmode
641: @item CCmode
642: ``Condition Code'' mode represents the value of a condition code, which
643: is a machine-specific set of bits used to represent the result of a
644: comparison operation. Other machine-specific modes may also be used for
645: the condition code. These modes are not used on machines that use
646: @code{cc0} (see @pxref{Condition Code}).
647:
648: @findex BLKmode
649: @item BLKmode
650: ``Block'' mode represents values that are aggregates to which none of
651: the other modes apply. In RTL, only memory references can have this mode,
652: and only if they appear in string-move or vector instructions. On machines
653: which have no such instructions, @code{BLKmode} will not appear in RTL.
654:
655: @findex VOIDmode
656: @item VOIDmode
657: Void mode means the absence of a mode or an unspecified mode.
658: For example, RTL expressions of code @code{const_int} have mode
659: @code{VOIDmode} because they can be taken to have whatever mode the context
660: requires. In debugging dumps of RTL, @code{VOIDmode} is expressed by
661: the absence of any mode.
662:
663: @findex SCmode
664: @findex DCmode
665: @findex XCmode
666: @findex TCmode
667: @item SCmode, DCmode, XCmode, TCmode
668: These modes stand for a complex number represented as a pair of floating
669: point values. The floating point values are in @code{SFmode},
670: @code{DFmode}, @code{XFmode}, and @code{TFmode}, respectively.
671:
672: @findex CQImode
673: @findex CHImode
674: @findex CSImode
675: @findex CDImode
676: @findex CTImode
677: @findex COImode
678: @item CQImode, CHImode, CSImode, CDImode, CTImode, COImode
679: These modes stand for a complex number represented as a pair of integer
680: values. The integer values are in @code{QImode}, @code{HImode},
681: @code{SImode}, @code{DImode}, @code{TImode}, and @code{OImode},
682: respectively.
683: @end table
684:
685: The machine description defines @code{Pmode} as a C macro which expands
686: into the machine mode used for addresses. Normally this is the mode
687: whose size is @code{BITS_PER_WORD}, @code{SImode} on 32-bit machines.
688:
689: The only modes which a machine description @i{must} support are
690: @code{QImode}, and the modes corresponding to @code{BITS_PER_WORD},
691: @code{FLOAT_TYPE_SIZE} and @code{DOUBLE_TYPE_SIZE}.
692: The compiler will attempt to use @code{DImode} for 8-byte structures and
693: unions, but this can be prevented by overriding the definition of
694: @code{MAX_FIXED_MODE_SIZE}. Alternatively, you can have the compiler
695: use @code{TImode} for 16-byte structures and unions. Likewise, you can
696: arrange for the C type @code{short int} to avoid using @code{HImode}.
697:
698: @cindex mode classes
699: Very few explicit references to machine modes remain in the compiler and
700: these few references will soon be removed. Instead, the machine modes
701: are divided into mode classes. These are represented by the enumeration
702: type @code{enum mode_class} defined in @file{machmode.h}. The possible
703: mode classes are:
704:
705: @table @code
706: @findex MODE_INT
707: @item MODE_INT
708: Integer modes. By default these are @code{QImode}, @code{HImode},
709: @code{SImode}, @code{DImode}, and @code{TImode}.
710:
711: @findex MODE_PARTIAL_INT
712: @item MODE_PARTIAL_INT
713: The ``partial integer'' modes, @code{PSImode} and @code{PDImode}.
714:
715: @findex MODE_FLOAT
716: @item MODE_FLOAT
717: floating point modes. By default these are @code{SFmode}, @code{DFmode},
718: @code{XFmode} and @code{TFmode}.
719:
720: @findex MODE_COMPLEX_INT
721: @item MODE_COMPLEX_INT
722: Complex integer modes. (These are not currently implemented).
723:
724: @findex MODE_COMPLEX_FLOAT
725: @item MODE_COMPLEX_FLOAT
726: Complex floating point modes. By default these are @code{SCmode},
727: @code{DCmode}, @code{XCmode}, and @code{TCmode}.
728:
729: @findex MODE_FUNCTION
730: @item MODE_FUNCTION
731: Algol or Pascal function variables including a static chain.
732: (These are not currently implemented).
733:
734: @findex MODE_CC
735: @item MODE_CC
736: Modes representing condition code values. These are @code{CCmode} plus
737: any modes listed in the @code{EXTRA_CC_MODES} macro. @xref{Jump Patterns},
738: also see @ref{Condition Code}.
739:
740: @findex MODE_RANDOM
741: @item MODE_RANDOM
742: This is a catchall mode class for modes which don't fit into the above
743: classes. Currently @code{VOIDmode} and @code{BLKmode} are in
744: @code{MODE_RANDOM}.
745: @end table
746:
747: Here are some C macros that relate to machine modes:
748:
749: @table @code
750: @findex GET_MODE
751: @item GET_MODE (@var{x})
752: Returns the machine mode of the RTX @var{x}.
753:
754: @findex PUT_MODE
755: @item PUT_MODE (@var{x}, @var{newmode})
756: Alters the machine mode of the RTX @var{x} to be @var{newmode}.
757:
758: @findex NUM_MACHINE_MODES
759: @item NUM_MACHINE_MODES
760: Stands for the number of machine modes available on the target
761: machine. This is one greater than the largest numeric value of any
762: machine mode.
763:
764: @findex GET_MODE_NAME
765: @item GET_MODE_NAME (@var{m})
766: Returns the name of mode @var{m} as a string.
767:
768: @findex GET_MODE_CLASS
769: @item GET_MODE_CLASS (@var{m})
770: Returns the mode class of mode @var{m}.
771:
772: @findex GET_MODE_WIDER_MODE
773: @item GET_MODE_WIDER_MODE (@var{m})
774: Returns the next wider natural mode. For example, the expression
775: @code{GET_MODE_WIDER_MODE (QImode)} returns @code{HImode}.
776:
777: @findex GET_MODE_SIZE
778: @item GET_MODE_SIZE (@var{m})
779: Returns the size in bytes of a datum of mode @var{m}.
780:
781: @findex GET_MODE_BITSIZE
782: @item GET_MODE_BITSIZE (@var{m})
783: Returns the size in bits of a datum of mode @var{m}.
784:
785: @findex GET_MODE_MASK
786: @item GET_MODE_MASK (@var{m})
787: Returns a bitmask containing 1 for all bits in a word that fit within
788: mode @var{m}. This macro can only be used for modes whose bitsize is
789: less than or equal to @code{HOST_BITS_PER_INT}.
790:
791: @findex GET_MODE_ALIGNMENT
792: @item GET_MODE_ALIGNMENT (@var{m)})
793: Return the required alignment, in bits, for an object of mode @var{m}.
794:
795: @findex GET_MODE_UNIT_SIZE
796: @item GET_MODE_UNIT_SIZE (@var{m})
797: Returns the size in bytes of the subunits of a datum of mode @var{m}.
798: This is the same as @code{GET_MODE_SIZE} except in the case of complex
799: modes. For them, the unit size is the size of the real or imaginary
800: part.
801:
802: @findex GET_MODE_NUNITS
803: @item GET_MODE_NUNITS (@var{m})
804: Returns the number of units contained in a mode, i.e.,
805: @code{GET_MODE_SIZE} divided by @code{GET_MODE_UNIT_SIZE}.
806:
807: @findex GET_CLASS_NARROWEST_MODE
808: @item GET_CLASS_NARROWEST_MODE (@var{c})
809: Returns the narrowest mode in mode class @var{c}.
810: @end table
811:
812: @findex byte_mode
813: @findex word_mode
814: The global variables @code{byte_mode} and @code{word_mode} contain modes
815: whose classes are @code{MODE_INT} and whose bitsizes are either
816: @code{BITS_PER_UNIT} or @code{BITS_PER_WORD}, respectively. On 32-bit
817: machines, these are @code{QImode} and @code{SImode}, respectively.
818:
819: @node Constants, Regs and Memory, Machine Modes, RTL
820: @section Constant Expression Types
821: @cindex RTL constants
822: @cindex RTL constant expression types
823:
824: The simplest RTL expressions are those that represent constant values.
825:
826: @table @code
827: @findex const_int
828: @item (const_int @var{i})
829: This type of expression represents the integer value @var{i}. @var{i}
830: is customarily accessed with the macro @code{INTVAL} as in
831: @code{INTVAL (@var{exp})}, which is equivalent to @code{XWINT (@var{exp}, 0)}.
832:
833: @findex const0_rtx
834: @findex const1_rtx
835: @findex const2_rtx
836: @findex constm1_rtx
837: There is only one expression object for the integer value zero; it is
838: the value of the variable @code{const0_rtx}. Likewise, the only
839: expression for integer value one is found in @code{const1_rtx}, the only
840: expression for integer value two is found in @code{const2_rtx}, and the
841: only expression for integer value negative one is found in
842: @code{constm1_rtx}. Any attempt to create an expression of code
843: @code{const_int} and value zero, one, two or negative one will return
844: @code{const0_rtx}, @code{const1_rtx}, @code{const2_rtx} or
845: @code{constm1_rtx} as appropriate.@refill
846:
847: @findex const_true_rtx
848: Similarly, there is only one object for the integer whose value is
849: @code{STORE_FLAG_VALUE}. It is found in @code{const_true_rtx}. If
850: @code{STORE_FLAG_VALUE} is one, @code{const_true_rtx} and
851: @code{const1_rtx} will point to the same object. If
852: @code{STORE_FLAG_VALUE} is -1, @code{const_true_rtx} and
853: @code{constm1_rtx} will point to the same object.@refill
854:
855: @findex const_double
856: @item (const_double:@var{m} @var{addr} @var{i0} @var{i1} @dots{})
857: Represents either a floating-point constant of mode @var{m} or an
858: integer constant too large to fit into @code{HOST_BITS_PER_WIDE_INT}
859: bits but small enough to fit within twice that number of bits (GNU CC
860: does not provide a mechanism to represent even larger constants). In
861: the latter case, @var{m} will be @code{VOIDmode}.
862:
863: @findex CONST_DOUBLE_MEM
864: @findex CONST_DOUBLE_CHAIN
865: @var{addr} is used to contain the @code{mem} expression that corresponds
866: to the location in memory that at which the constant can be found. If
867: it has not been allocated a memory location, but is on the chain of all
868: @code{const_double} expressions in this compilation (maintained using an
869: undisplayed field), @var{addr} contains @code{const0_rtx}. If it is not
870: on the chain, @var{addr} contains @code{cc0_rtx}. @var{addr} is
871: customarily accessed with the macro @code{CONST_DOUBLE_MEM} and the
872: chain field via @code{CONST_DOUBLE_CHAIN}.@refill
873:
874: @findex CONST_DOUBLE_LOW
875: If @var{m} is @code{VOIDmode}, the bits of the value are stored in
876: @var{i0} and @var{i1}. @var{i0} is customarily accessed with the macro
877: @code{CONST_DOUBLE_LOW} and @var{i1} with @code{CONST_DOUBLE_HIGH}.
878:
879: If the constant is floating point (regardless of its precision), then
880: the number of integers used to store the value depends on the size of
881: @code{REAL_VALUE_TYPE} (@pxref{Cross-compilation}). The integers
882: represent a floating point number, but not precisely in the target
883: machine's or host machine's floating point format. To convert them to
884: the precise bit pattern used by the target machine, use the macro
885: @code{REAL_VALUE_TO_TARGET_DOUBLE} and friends (@pxref{Data Output}).
886:
887: @findex CONST0_RTX
888: @findex CONST1_RTX
889: @findex CONST2_RTX
890: The macro @code{CONST0_RTX (@var{mode})} refers to an expression with
891: value 0 in mode @var{mode}. If mode @var{mode} is of mode class
892: @code{MODE_INT}, it returns @code{const0_rtx}. Otherwise, it returns a
893: @code{CONST_DOUBLE} expression in mode @var{mode}. Similarly, the macro
894: @code{CONST1_RTX (@var{mode})} refers to an expression with value 1 in
895: mode @var{mode} and similarly for @code{CONST2_RTX}.
896:
897: @findex const_string
898: @item (const_string @var{str})
899: Represents a constant string with value @var{str}. Currently this is
900: used only for insn attributes (@pxref{Insn Attributes}) since constant
901: strings in C are placed in memory.
902:
903: @findex symbol_ref
904: @item (symbol_ref:@var{mode} @var{symbol})
905: Represents the value of an assembler label for data. @var{symbol} is
906: a string that describes the name of the assembler label. If it starts
907: with a @samp{*}, the label is the rest of @var{symbol} not including
908: the @samp{*}. Otherwise, the label is @var{symbol}, usually prefixed
909: with @samp{_}.
910:
911: The @code{symbol_ref} contains a mode, which is usually @code{Pmode}.
912: Usually that is the only mode for which a symbol is directly valid.
913:
914: @findex label_ref
915: @item (label_ref @var{label})
916: Represents the value of an assembler label for code. It contains one
917: operand, an expression, which must be a @code{code_label} that appears
918: in the instruction sequence to identify the place where the label
919: should go.
920:
921: The reason for using a distinct expression type for code label
922: references is so that jump optimization can distinguish them.
923:
924: @item (const:@var{m} @var{exp})
925: Represents a constant that is the result of an assembly-time
926: arithmetic computation. The operand, @var{exp}, is an expression that
927: contains only constants (@code{const_int}, @code{symbol_ref} and
928: @code{label_ref} expressions) combined with @code{plus} and
929: @code{minus}. However, not all combinations are valid, since the
930: assembler cannot do arbitrary arithmetic on relocatable symbols.
931:
932: @var{m} should be @code{Pmode}.
933:
934: @findex high
935: @item (high:@var{m} @var{exp})
936: Represents the high-order bits of @var{exp}, usually a
937: @code{symbol_ref}. The number of bits is machine-dependent and is
938: normally the number of bits specified in an instruction that initializes
939: the high order bits of a register. It is used with @code{lo_sum} to
940: represent the typical two-instruction sequence used in RISC machines to
941: reference a global memory location.
942:
943: @var{m} should be @code{Pmode}.
944: @end table
945:
946: @node Regs and Memory, Arithmetic, Constants, RTL
947: @section Registers and Memory
948: @cindex RTL register expressions
949: @cindex RTL memory expressions
950:
951: Here are the RTL expression types for describing access to machine
952: registers and to main memory.
953:
954: @table @code
955: @findex reg
956: @cindex hard registers
957: @cindex pseudo registers
958: @item (reg:@var{m} @var{n})
959: For small values of the integer @var{n} (those that are less than
960: @code{FIRST_PSEUDO_REGISTER}), this stands for a reference to machine
961: register number @var{n}: a @dfn{hard register}. For larger values of
962: @var{n}, it stands for a temporary value or @dfn{pseudo register}.
963: The compiler's strategy is to generate code assuming an unlimited
964: number of such pseudo registers, and later convert them into hard
965: registers or into memory references.
966:
967: @var{m} is the machine mode of the reference. It is necessary because
968: machines can generally refer to each register in more than one mode.
969: For example, a register may contain a full word but there may be
970: instructions to refer to it as a half word or as a single byte, as
971: well as instructions to refer to it as a floating point number of
972: various precisions.
973:
974: Even for a register that the machine can access in only one mode,
975: the mode must always be specified.
976:
977: The symbol @code{FIRST_PSEUDO_REGISTER} is defined by the machine
978: description, since the number of hard registers on the machine is an
979: invariant characteristic of the machine. Note, however, that not
980: all of the machine registers must be general registers. All the
981: machine registers that can be used for storage of data are given
982: hard register numbers, even those that can be used only in certain
983: instructions or can hold only certain types of data.
984:
985: A hard register may be accessed in various modes throughout one
986: function, but each pseudo register is given a natural mode
987: and is accessed only in that mode. When it is necessary to describe
988: an access to a pseudo register using a nonnatural mode, a @code{subreg}
989: expression is used.
990:
991: A @code{reg} expression with a machine mode that specifies more than
992: one word of data may actually stand for several consecutive registers.
993: If in addition the register number specifies a hardware register, then
994: it actually represents several consecutive hardware registers starting
995: with the specified one.
996:
997: Each pseudo register number used in a function's RTL code is
998: represented by a unique @code{reg} expression.
999:
1000: @findex FIRST_VIRTUAL_REGISTER
1001: @findex LAST_VIRTUAL_REGISTER
1002: Some pseudo register numbers, those within the range of
1003: @code{FIRST_VIRTUAL_REGISTER} to @code{LAST_VIRTUAL_REGISTER} only
1004: appear during the RTL generation phase and are eliminated before the
1005: optimization phases. These represent locations in the stack frame that
1006: cannot be determined until RTL generation for the function has been
1007: completed. The following virtual register numbers are defined:
1008:
1009: @table @code
1010: @findex VIRTUAL_INCOMING_ARGS_REGNUM
1011: @item VIRTUAL_INCOMING_ARGS_REGNUM
1012: This points to the first word of the incoming arguments passed on the
1013: stack. Normally these arguments are placed there by the caller, but the
1014: callee may have pushed some arguments that were previously passed in
1015: registers.
1016:
1017: @cindex @code{FIRST_PARM_OFFSET} and virtual registers
1018: @cindex @code{ARG_POINTER_REGNUM} and virtual registers
1019: When RTL generation is complete, this virtual register is replaced
1020: by the sum of the register given by @code{ARG_POINTER_REGNUM} and the
1021: value of @code{FIRST_PARM_OFFSET}.
1022:
1023: @findex VIRTUAL_STACK_VARS_REGNUM
1024: @cindex @code{FRAME_GROWS_DOWNWARD} and virtual registers
1025: @item VIRTUAL_STACK_VARS_REGNUM
1026: If @code{FRAME_GROWS_DOWNWARD} is defined, this points to immediately
1027: above the first variable on the stack. Otherwise, it points to the
1028: first variable on the stack.
1029:
1030: @cindex @code{STARTING_FRAME_OFFSET} and virtual registers
1031: @cindex @code{FRAME_POINTER_REGNUM} and virtual registers
1032: @code{VIRTUAL_STACK_VARS_REGNUM} is replaced with the sum of the
1033: register given by @code{FRAME_POINTER_REGNUM} and the value
1034: @code{STARTING_FRAME_OFFSET}.
1035:
1036: @findex VIRTUAL_STACK_DYNAMIC_REGNUM
1037: @item VIRTUAL_STACK_DYNAMIC_REGNUM
1038: This points to the location of dynamically allocated memory on the stack
1039: immediately after the stack pointer has been adjusted by the amount of
1040: memory desired.
1041:
1042: @cindex @code{STACK_DYNAMIC_OFFSET} and virtual registers
1043: @cindex @code{STACK_POINTER_REGNUM} and virtual registers
1044: This virtual register is replaced by the sum of the register given by
1045: @code{STACK_POINTER_REGNUM} and the value @code{STACK_DYNAMIC_OFFSET}.
1046:
1047: @findex VIRTUAL_OUTGOING_ARGS_REGNUM
1048: @item VIRTUAL_OUTGOING_ARGS_REGNUM
1049: This points to the location in the stack at which outgoing arguments
1050: should be written when the stack is pre-pushed (arguments pushed using
1051: push insns should always use @code{STACK_POINTER_REGNUM}).
1052:
1053: @cindex @code{STACK_POINTER_OFFSET} and virtual registers
1054: This virtual register is replaced by the sum of the register given by
1055: @code{STACK_POINTER_REGNUM} and the value @code{STACK_POINTER_OFFSET}.
1056: @end table
1057:
1058: @findex subreg
1059: @item (subreg:@var{m} @var{reg} @var{wordnum})
1060: @code{subreg} expressions are used to refer to a register in a machine
1061: mode other than its natural one, or to refer to one register of
1062: a multi-word @code{reg} that actually refers to several registers.
1063:
1064: Each pseudo-register has a natural mode. If it is necessary to
1065: operate on it in a different mode---for example, to perform a fullword
1066: move instruction on a pseudo-register that contains a single
1067: byte---the pseudo-register must be enclosed in a @code{subreg}. In
1068: such a case, @var{wordnum} is zero.
1069:
1070: Usually @var{m} is at least as narrow as the mode of @var{reg}, in which
1071: case it is restricting consideration to only the bits of @var{reg} that
1072: are in @var{m}.
1073:
1074: Sometimes @var{m} is wider than the mode of @var{reg}. These
1075: @code{subreg} expressions are often called @dfn{paradoxical}. They are
1076: used in cases where we want to refer to an object in a wider mode but do
1077: not care what value the additional bits have. The reload pass ensures
1078: that paradoxical references are only made to hard registers.
1079:
1080: The other use of @code{subreg} is to extract the individual registers of
1081: a multi-register value. Machine modes such as @code{DImode} and
1082: @code{TImode} can indicate values longer than a word, values which
1083: usually require two or more consecutive registers. To access one of the
1084: registers, use a @code{subreg} with mode @code{SImode} and a
1085: @var{wordnum} that says which register.
1086:
1087: Storing in a non-paradoxical @code{subreg} has undefined results for
1088: bits belonging to the same word as the @code{subreg}. This laxity makes
1089: it easier to generate efficient code for such instructions. To
1090: represent an instruction that preserves all the bits outside of those in
1091: the @code{subreg}, use @code{strict_low_part} around the @code{subreg}.
1092:
1093: @cindex @code{WORDS_BIG_ENDIAN}, effect on @code{subreg}
1094: The compilation parameter @code{WORDS_BIG_ENDIAN}, if set to 1, says
1095: that word number zero is the most significant part; otherwise, it is
1096: the least significant part.
1097:
1098: @cindex combiner pass
1099: @cindex reload pass
1100: @cindex @code{subreg}, special reload handling
1101: Between the combiner pass and the reload pass, it is possible to have a
1102: paradoxical @code{subreg} which contains a @code{mem} instead of a
1103: @code{reg} as its first operand. After the reload pass, it is also
1104: possible to have a non-paradoxical @code{subreg} which contains a
1105: @code{mem}; this usually occurs when the @code{mem} is a stack slot
1106: which replaced a pseudo register.
1107:
1108: Note that it is not valid to access a @code{DFmode} value in @code{SFmode}
1109: using a @code{subreg}. On some machines the most significant part of a
1110: @code{DFmode} value does not have the same format as a single-precision
1111: floating value.
1112:
1113: It is also not valid to access a single word of a multi-word value in a
1114: hard register when less registers can hold the value than would be
1115: expected from its size. For example, some 32-bit machines have
1116: floating-point registers that can hold an entire @code{DFmode} value.
1117: If register 10 were such a register @code{(subreg:SI (reg:DF 10) 1)}
1118: would be invalid because there is no way to convert that reference to
1119: a single machine register. The reload pass prevents @code{subreg}
1120: expressions such as these from being formed.
1121:
1122: @findex SUBREG_REG
1123: @findex SUBREG_WORD
1124: The first operand of a @code{subreg} expression is customarily accessed
1125: with the @code{SUBREG_REG} macro and the second operand is customarily
1126: accessed with the @code{SUBREG_WORD} macro.
1127:
1128: @findex scratch
1129: @cindex scratch operands
1130: @item (scratch:@var{m})
1131: This represents a scratch register that will be required for the
1132: execution of a single instruction and not used subsequently. It is
1133: converted into a @code{reg} by either the local register allocator or
1134: the reload pass.
1135:
1136: @code{scratch} is usually present inside a @code{clobber} operation
1137: (@pxref{Side Effects}).
1138:
1139: @findex cc0
1140: @cindex condition code register
1141: @item (cc0)
1142: This refers to the machine's condition code register. It has no
1143: operands and may not have a machine mode. There are two ways to use it:
1144:
1145: @itemize @bullet
1146: @item
1147: To stand for a complete set of condition code flags. This is best on
1148: most machines, where each comparison sets the entire series of flags.
1149:
1150: With this technique, @code{(cc0)} may be validly used in only two
1151: contexts: as the destination of an assignment (in test and compare
1152: instructions) and in comparison operators comparing against zero
1153: (@code{const_int} with value zero; that is to say, @code{const0_rtx}).
1154:
1155: @item
1156: To stand for a single flag that is the result of a single condition.
1157: This is useful on machines that have only a single flag bit, and in
1158: which comparison instructions must specify the condition to test.
1159:
1160: With this technique, @code{(cc0)} may be validly used in only two
1161: contexts: as the destination of an assignment (in test and compare
1162: instructions) where the source is a comparison operator, and as the
1163: first operand of @code{if_then_else} (in a conditional branch).
1164: @end itemize
1165:
1166: @findex cc0_rtx
1167: There is only one expression object of code @code{cc0}; it is the
1168: value of the variable @code{cc0_rtx}. Any attempt to create an
1169: expression of code @code{cc0} will return @code{cc0_rtx}.
1170:
1171: Instructions can set the condition code implicitly. On many machines,
1172: nearly all instructions set the condition code based on the value that
1173: they compute or store. It is not necessary to record these actions
1174: explicitly in the RTL because the machine description includes a
1175: prescription for recognizing the instructions that do so (by means of
1176: the macro @code{NOTICE_UPDATE_CC}). @xref{Condition Code}. Only
1177: instructions whose sole purpose is to set the condition code, and
1178: instructions that use the condition code, need mention @code{(cc0)}.
1179:
1180: On some machines, the condition code register is given a register number
1181: and a @code{reg} is used instead of @code{(cc0)}. This is usually the
1182: preferable approach if only a small subset of instructions modify the
1183: condition code. Other machines store condition codes in general
1184: registers; in such cases a pseudo register should be used.
1185:
1186: Some machines, such as the Sparc and RS/6000, have two sets of
1187: arithmetic instructions, one that sets and one that does not set the
1188: condition code. This is best handled by normally generating the
1189: instruction that does not set the condition code, and making a pattern
1190: that both performs the arithmetic and sets the condition code register
1191: (which would not be @code{(cc0)} in this case). For examples, search
1192: for @samp{addcc} and @samp{andcc} in @file{sparc.md}.
1193:
1194: @findex pc
1195: @item (pc)
1196: @cindex program counter
1197: This represents the machine's program counter. It has no operands and
1198: may not have a machine mode. @code{(pc)} may be validly used only in
1199: certain specific contexts in jump instructions.
1200:
1201: @findex pc_rtx
1202: There is only one expression object of code @code{pc}; it is the value
1203: of the variable @code{pc_rtx}. Any attempt to create an expression of
1204: code @code{pc} will return @code{pc_rtx}.
1205:
1206: All instructions that do not jump alter the program counter implicitly
1207: by incrementing it, but there is no need to mention this in the RTL.
1208:
1209: @findex mem
1210: @item (mem:@var{m} @var{addr})
1211: This RTX represents a reference to main memory at an address
1212: represented by the expression @var{addr}. @var{m} specifies how large
1213: a unit of memory is accessed.
1214: @end table
1215:
1216: @node Arithmetic, Comparisons, Regs and Memory, RTL
1217: @section RTL Expressions for Arithmetic
1218: @cindex arithmetic, in RTL
1219: @cindex math, in RTL
1220: @cindex RTL expressions for arithmetic
1221:
1222: Unless otherwise specified, all the operands of arithmetic expressions
1223: must be valid for mode @var{m}. An operand is valid for mode @var{m}
1224: if it has mode @var{m}, or if it is a @code{const_int} or
1225: @code{const_double} and @var{m} is a mode of class @code{MODE_INT}.
1226:
1227: For commutative binary operations, constants should be placed in the
1228: second operand.
1229:
1230: @table @code
1231: @findex plus
1232: @cindex RTL addition
1233: @cindex RTL sum
1234: @item (plus:@var{m} @var{x} @var{y})
1235: Represents the sum of the values represented by @var{x} and @var{y}
1236: carried out in machine mode @var{m}.
1237:
1238: @findex lo_sum
1239: @item (lo_sum:@var{m} @var{x} @var{y})
1240: Like @code{plus}, except that it represents that sum of @var{x} and the
1241: low-order bits of @var{y}. The number of low order bits is
1242: machine-dependent but is normally the number of bits in a @code{Pmode}
1243: item minus the number of bits set by the @code{high} code
1244: (@pxref{Constants}).
1245:
1246: @var{m} should be @code{Pmode}.
1247:
1248: @findex minus
1249: @cindex RTL subtraction
1250: @cindex RTL difference
1251: @item (minus:@var{m} @var{x} @var{y})
1252: Like @code{plus} but represents subtraction.
1253:
1254: @findex compare
1255: @cindex RTL comparison
1256: @item (compare:@var{m} @var{x} @var{y})
1257: Represents the result of subtracting @var{y} from @var{x} for purposes
1258: of comparison. The result is computed without overflow, as if with
1259: infinite precision.
1260:
1261: Of course, machines can't really subtract with infinite precision.
1262: However, they can pretend to do so when only the sign of the
1263: result will be used, which is the case when the result is stored
1264: in the condition code. And that is the only way this kind of expression
1265: may validly be used: as a value to be stored in the condition codes.
1266:
1267: The mode @var{m} is not related to the modes of @var{x} and @var{y},
1268: but instead is the mode of the condition code value. If @code{(cc0)}
1269: is used, it is @code{VOIDmode}. Otherwise it is some mode in class
1270: @code{MODE_CC}, often @code{CCmode}. @xref{Condition Code}.
1271:
1272: Normally, @var{x} and @var{y} must have the same mode. Otherwise,
1273: @code{compare} is valid only if the mode of @var{x} is in class
1274: @code{MODE_INT} and @var{y} is a @code{const_int} or
1275: @code{const_double} with mode @code{VOIDmode}. The mode of @var{x}
1276: determines what mode the comparison is to be done in; thus it must not
1277: be @code{VOIDmode}.
1278:
1279: If one of the operands is a constant, it should be placed in the
1280: second operand and the comparison code adjusted as appropriate.
1281:
1282: A @code{compare} specifying two @code{VOIDmode} constants is not valid
1283: since there is no way to know in what mode the comparison is to be
1284: performed; the comparison must either be folded during the compilation
1285: or the first operand must be loaded into a register while its mode is
1286: still known.
1287:
1288: @findex neg
1289: @item (neg:@var{m} @var{x})
1290: Represents the negation (subtraction from zero) of the value represented
1291: by @var{x}, carried out in mode @var{m}.
1292:
1293: @findex mult
1294: @cindex multiplication
1295: @cindex product
1296: @item (mult:@var{m} @var{x} @var{y})
1297: Represents the signed product of the values represented by @var{x} and
1298: @var{y} carried out in machine mode @var{m}.
1299:
1300: Some machines support a multiplication that generates a product wider
1301: than the operands. Write the pattern for this as
1302:
1303: @example
1304: (mult:@var{m} (sign_extend:@var{m} @var{x}) (sign_extend:@var{m} @var{y}))
1305: @end example
1306:
1307: where @var{m} is wider than the modes of @var{x} and @var{y}, which need
1308: not be the same.
1309:
1310: Write patterns for unsigned widening multiplication similarly using
1311: @code{zero_extend}.
1312:
1313: @findex div
1314: @cindex division
1315: @cindex signed division
1316: @cindex quotient
1317: @item (div:@var{m} @var{x} @var{y})
1318: Represents the quotient in signed division of @var{x} by @var{y},
1319: carried out in machine mode @var{m}. If @var{m} is a floating point
1320: mode, it represents the exact quotient; otherwise, the integerized
1321: quotient.
1322:
1323: Some machines have division instructions in which the operands and
1324: quotient widths are not all the same; you should represent
1325: such instructions using @code{truncate} and @code{sign_extend} as in,
1326:
1327: @example
1328: (truncate:@var{m1} (div:@var{m2} @var{x} (sign_extend:@var{m2} @var{y})))
1329: @end example
1330:
1331: @findex udiv
1332: @cindex unsigned division
1333: @cindex division
1334: @item (udiv:@var{m} @var{x} @var{y})
1335: Like @code{div} but represents unsigned division.
1336:
1337: @findex mod
1338: @findex umod
1339: @cindex remainder
1340: @cindex division
1341: @item (mod:@var{m} @var{x} @var{y})
1342: @itemx (umod:@var{m} @var{x} @var{y})
1343: Like @code{div} and @code{udiv} but represent the remainder instead of
1344: the quotient.
1345:
1346: @findex smin
1347: @findex smax
1348: @cindex signed minimum
1349: @cindex signed maximum
1350: @item (smin:@var{m} @var{x} @var{y})
1351: @itemx (smax:@var{m} @var{x} @var{y})
1352: Represents the smaller (for @code{smin}) or larger (for @code{smax}) of
1353: @var{x} and @var{y}, interpreted as signed integers in mode @var{m}.
1354:
1355: @findex umin
1356: @findex umax
1357: @cindex unsigned minimum and maximum
1358: @item (umin:@var{m} @var{x} @var{y})
1359: @itemx (umax:@var{m} @var{x} @var{y})
1360: Like @code{smin} and @code{smax}, but the values are interpreted as unsigned
1361: integers.
1362:
1363: @findex not
1364: @cindex complement, bitwise
1365: @cindex bitwise complement
1366: @item (not:@var{m} @var{x})
1367: Represents the bitwise complement of the value represented by @var{x},
1368: carried out in mode @var{m}, which must be a fixed-point machine mode.
1369:
1370: @findex and
1371: @cindex logical-and, bitwise
1372: @cindex bitwise logical-and
1373: @item (and:@var{m} @var{x} @var{y})
1374: Represents the bitwise logical-and of the values represented by
1375: @var{x} and @var{y}, carried out in machine mode @var{m}, which must be
1376: a fixed-point machine mode.
1377:
1378: @findex ior
1379: @cindex inclusive-or, bitwise
1380: @cindex bitwise inclusive-or
1381: @item (ior:@var{m} @var{x} @var{y})
1382: Represents the bitwise inclusive-or of the values represented by @var{x}
1383: and @var{y}, carried out in machine mode @var{m}, which must be a
1384: fixed-point mode.
1385:
1386: @findex xor
1387: @cindex exclusive-or, bitwise
1388: @cindex bitwise exclusive-or
1389: @item (xor:@var{m} @var{x} @var{y})
1390: Represents the bitwise exclusive-or of the values represented by @var{x}
1391: and @var{y}, carried out in machine mode @var{m}, which must be a
1392: fixed-point mode.
1393:
1394: @findex ashift
1395: @cindex left shift
1396: @cindex shift
1397: @cindex arithmetic shift
1398: @item (ashift:@var{m} @var{x} @var{c})
1399: Represents the result of arithmetically shifting @var{x} left by @var{c}
1400: places. @var{x} have mode @var{m}, a fixed-point machine mode. @var{c}
1401: be a fixed-point mode or be a constant with mode @code{VOIDmode}; which
1402: mode is determined by the mode called for in the machine description
1403: entry for the left-shift instruction. For example, on the Vax, the mode
1404: of @var{c} is @code{QImode} regardless of @var{m}.
1405:
1406: @findex lshift
1407: @cindex left shift
1408: @cindex logical shift
1409: @item (lshift:@var{m} @var{x} @var{c})
1410: Like @code{ashift} but for logical left shift. @code{ashift} and
1411: @code{lshift} are identical operations; we customarily use @code{ashift}
1412: for both.
1413:
1414: @findex lshiftrt
1415: @cindex right shift
1416: @findex ashiftrt
1417: @item (lshiftrt:@var{m} @var{x} @var{c})
1418: @itemx (ashiftrt:@var{m} @var{x} @var{c})
1419: Like @code{lshift} and @code{ashift} but for right shift. Unlike
1420: the case for left shift, these two operations are distinct.
1421:
1422: @findex rotate
1423: @cindex rotate
1424: @cindex left rotate
1425: @findex rotatert
1426: @cindex right rotate
1427: @item (rotate:@var{m} @var{x} @var{c})
1428: @itemx (rotatert:@var{m} @var{x} @var{c})
1429: Similar but represent left and right rotate. If @var{c} is a constant,
1430: use @code{rotate}.
1431:
1432: @findex abs
1433: @cindex absolute value
1434: @item (abs:@var{m} @var{x})
1435: Represents the absolute value of @var{x}, computed in mode @var{m}.
1436:
1437: @findex sqrt
1438: @cindex square root
1439: @item (sqrt:@var{m} @var{x})
1440: Represents the square root of @var{x}, computed in mode @var{m}.
1441: Most often @var{m} will be a floating point mode.
1442:
1443: @findex ffs
1444: @item (ffs:@var{m} @var{x})
1445: Represents one plus the index of the least significant 1-bit in
1446: @var{x}, represented as an integer of mode @var{m}. (The value is
1447: zero if @var{x} is zero.) The mode of @var{x} need not be @var{m};
1448: depending on the target machine, various mode combinations may be
1449: valid.
1450: @end table
1451:
1452: @node Comparisons, Bit Fields, Arithmetic, RTL
1453: @section Comparison Operations
1454: @cindex RTL comparison operations
1455:
1456: Comparison operators test a relation on two operands and are considered
1457: to represent a machine-dependent nonzero value described by, but not
1458: necessarily equal to, @code{STORE_FLAG_VALUE} (@pxref{Misc})
1459: if the relation holds, or zero if it does not. The mode of the
1460: comparison operation is independent of the mode of the data being
1461: compared. If the comparison operation is being tested (e.g., the first
1462: operand of an @code{if_then_else}), the mode must be @code{VOIDmode}.
1463: If the comparison operation is producing data to be stored in some
1464: variable, the mode must be in class @code{MODE_INT}. All comparison
1465: operations producing data must use the same mode, which is
1466: machine-specific.
1467:
1468: @cindex condition codes
1469: There are two ways that comparison operations may be used. The
1470: comparison operators may be used to compare the condition codes
1471: @code{(cc0)} against zero, as in @code{(eq (cc0) (const_int 0))}. Such
1472: a construct actually refers to the result of the preceding instruction
1473: in which the condition codes were set. The instructing setting the
1474: condition code must be adjacent to the instruction using the condition
1475: code; only @code{note} insns may separate them.
1476:
1477: Alternatively, a comparison operation may directly compare two data
1478: objects. The mode of the comparison is determined by the operands; they
1479: must both be valid for a common machine mode. A comparison with both
1480: operands constant would be invalid as the machine mode could not be
1481: deduced from it, but such a comparison should never exist in RTL due to
1482: constant folding.
1483:
1484: In the example above, if @code{(cc0)} were last set to
1485: @code{(compare @var{x} @var{y})}, the comparison operation is
1486: identical to @code{(eq @var{x} @var{y})}. Usually only one style
1487: of comparisons is supported on a particular machine, but the combine
1488: pass will try to merge the operations to produce the @code{eq} shown
1489: in case it exists in the context of the particular insn involved.
1490:
1491: Inequality comparisons come in two flavors, signed and unsigned. Thus,
1492: there are distinct expression codes @code{gt} and @code{gtu} for signed and
1493: unsigned greater-than. These can produce different results for the same
1494: pair of integer values: for example, 1 is signed greater-than -1 but not
1495: unsigned greater-than, because -1 when regarded as unsigned is actually
1496: @code{0xffffffff} which is greater than 1.
1497:
1498: The signed comparisons are also used for floating point values. Floating
1499: point comparisons are distinguished by the machine modes of the operands.
1500:
1501: @table @code
1502: @findex eq
1503: @cindex equal
1504: @item (eq:@var{m} @var{x} @var{y})
1505: 1 if the values represented by @var{x} and @var{y} are equal,
1506: otherwise 0.
1507:
1508: @findex ne
1509: @cindex not equal
1510: @item (ne:@var{m} @var{x} @var{y})
1511: 1 if the values represented by @var{x} and @var{y} are not equal,
1512: otherwise 0.
1513:
1514: @findex gt
1515: @cindex greater than
1516: @item (gt:@var{m} @var{x} @var{y})
1517: 1 if the @var{x} is greater than @var{y}. If they are fixed-point,
1518: the comparison is done in a signed sense.
1519:
1520: @findex gtu
1521: @cindex greater than
1522: @cindex unsigned greater than
1523: @item (gtu:@var{m} @var{x} @var{y})
1524: Like @code{gt} but does unsigned comparison, on fixed-point numbers only.
1525:
1526: @findex lt
1527: @cindex less than
1528: @findex ltu
1529: @cindex unsigned less than
1530: @item (lt:@var{m} @var{x} @var{y})
1531: @itemx (ltu:@var{m} @var{x} @var{y})
1532: Like @code{gt} and @code{gtu} but test for ``less than''.
1533:
1534: @findex ge
1535: @cindex greater than
1536: @findex geu
1537: @cindex unsigned greater than
1538: @item (ge:@var{m} @var{x} @var{y})
1539: @itemx (geu:@var{m} @var{x} @var{y})
1540: Like @code{gt} and @code{gtu} but test for ``greater than or equal''.
1541:
1542: @findex le
1543: @cindex less than or equal
1544: @findex leu
1545: @cindex unsigned less than
1546: @item (le:@var{m} @var{x} @var{y})
1547: @itemx (leu:@var{m} @var{x} @var{y})
1548: Like @code{gt} and @code{gtu} but test for ``less than or equal''.
1549:
1550: @findex if_then_else
1551: @item (if_then_else @var{cond} @var{then} @var{else})
1552: This is not a comparison operation but is listed here because it is
1553: always used in conjunction with a comparison operation. To be
1554: precise, @var{cond} is a comparison expression. This expression
1555: represents a choice, according to @var{cond}, between the value
1556: represented by @var{then} and the one represented by @var{else}.
1557:
1558: On most machines, @code{if_then_else} expressions are valid only
1559: to express conditional jumps.
1560:
1561: @findex cond
1562: @item (cond [@var{test1} @var{value1} @var{test2} @var{value2} @dots{}] @var{default})
1563: Similar to @code{if_then_else}, but more general. Each of @var{test1},
1564: @var{test2}, @dots{} is performed in turn. The result of this expression is
1565: the @var{value} corresponding to the first non-zero test, or @var{default} if
1566: none of the tests are non-zero expressions.
1567:
1568: This is currently not valid for instruction patterns and is supported only
1569: for insn attributes. @xref{Insn Attributes}.
1570: @end table
1571:
1572: @node Bit Fields, Conversions, Comparisons, RTL
1573: @section Bit Fields
1574: @cindex bit fields
1575:
1576: Special expression codes exist to represent bitfield instructions.
1577: These types of expressions are lvalues in RTL; they may appear
1578: on the left side of an assignment, indicating insertion of a value
1579: into the specified bit field.
1580:
1581: @table @code
1582: @findex sign_extract
1583: @cindex @code{BITS_BIG_ENDIAN}, effect on @code{sign_extract}
1584: @item (sign_extract:@var{m} @var{loc} @var{size} @var{pos})
1585: This represents a reference to a sign-extended bit field contained or
1586: starting in @var{loc} (a memory or register reference). The bit field
1587: is @var{size} bits wide and starts at bit @var{pos}. The compilation
1588: option @code{BITS_BIG_ENDIAN} says which end of the memory unit
1589: @var{pos} counts from.
1590:
1591: If @var{loc} is in memory, its mode must be a single-byte integer mode.
1592: If @var{loc} is in a register, the mode to use is specified by the
1593: operand of the @code{insv} or @code{extv} pattern
1594: (@pxref{Standard Names}) and is usually a full-word integer mode.
1595:
1596: The mode of @var{pos} is machine-specific and is also specified
1597: in the @code{insv} or @code{extv} pattern.
1598:
1599: The mode @var{m} is the same as the mode that would be used for
1600: @var{loc} if it were a register.
1601:
1602: @findex zero_extract
1603: @item (zero_extract:@var{m} @var{loc} @var{size} @var{pos})
1604: Like @code{sign_extract} but refers to an unsigned or zero-extended
1605: bit field. The same sequence of bits are extracted, but they
1606: are filled to an entire word with zeros instead of by sign-extension.
1607: @end table
1608:
1609: @node Conversions, RTL Declarations, Bit Fields, RTL
1610: @section Conversions
1611: @cindex conversions
1612: @cindex machine mode conversions
1613:
1614: All conversions between machine modes must be represented by
1615: explicit conversion operations. For example, an expression
1616: which is the sum of a byte and a full word cannot be written as
1617: @code{(plus:SI (reg:QI 34) (reg:SI 80))} because the @code{plus}
1618: operation requires two operands of the same machine mode.
1619: Therefore, the byte-sized operand is enclosed in a conversion
1620: operation, as in
1621:
1622: @example
1623: (plus:SI (sign_extend:SI (reg:QI 34)) (reg:SI 80))
1624: @end example
1625:
1626: The conversion operation is not a mere placeholder, because there
1627: may be more than one way of converting from a given starting mode
1628: to the desired final mode. The conversion operation code says how
1629: to do it.
1630:
1631: For all conversion operations, @var{x} must not be @code{VOIDmode}
1632: because the mode in which to do the conversion would not be known.
1633: The conversion must either be done at compile-time or @var{x}
1634: must be placed into a register.
1635:
1636: @table @code
1637: @findex sign_extend
1638: @item (sign_extend:@var{m} @var{x})
1639: Represents the result of sign-extending the value @var{x}
1640: to machine mode @var{m}. @var{m} must be a fixed-point mode
1641: and @var{x} a fixed-point value of a mode narrower than @var{m}.
1642:
1643: @findex zero_extend
1644: @item (zero_extend:@var{m} @var{x})
1645: Represents the result of zero-extending the value @var{x}
1646: to machine mode @var{m}. @var{m} must be a fixed-point mode
1647: and @var{x} a fixed-point value of a mode narrower than @var{m}.
1648:
1649: @findex float_extend
1650: @item (float_extend:@var{m} @var{x})
1651: Represents the result of extending the value @var{x}
1652: to machine mode @var{m}. @var{m} must be a floating point mode
1653: and @var{x} a floating point value of a mode narrower than @var{m}.
1654:
1655: @findex truncate
1656: @item (truncate:@var{m} @var{x})
1657: Represents the result of truncating the value @var{x}
1658: to machine mode @var{m}. @var{m} must be a fixed-point mode
1659: and @var{x} a fixed-point value of a mode wider than @var{m}.
1660:
1661: @findex float_truncate
1662: @item (float_truncate:@var{m} @var{x})
1663: Represents the result of truncating the value @var{x}
1664: to machine mode @var{m}. @var{m} must be a floating point mode
1665: and @var{x} a floating point value of a mode wider than @var{m}.
1666:
1667: @findex float
1668: @item (float:@var{m} @var{x})
1669: Represents the result of converting fixed point value @var{x},
1670: regarded as signed, to floating point mode @var{m}.
1671:
1672: @findex unsigned_float
1673: @item (unsigned_float:@var{m} @var{x})
1674: Represents the result of converting fixed point value @var{x},
1675: regarded as unsigned, to floating point mode @var{m}.
1676:
1677: @findex fix
1678: @item (fix:@var{m} @var{x})
1679: When @var{m} is a fixed point mode, represents the result of
1680: converting floating point value @var{x} to mode @var{m}, regarded as
1681: signed. How rounding is done is not specified, so this operation may
1682: be used validly in compiling C code only for integer-valued operands.
1683:
1684: @findex unsigned_fix
1685: @item (unsigned_fix:@var{m} @var{x})
1686: Represents the result of converting floating point value @var{x} to
1687: fixed point mode @var{m}, regarded as unsigned. How rounding is done
1688: is not specified.
1689:
1690: @findex fix
1691: @item (fix:@var{m} @var{x})
1692: When @var{m} is a floating point mode, represents the result of
1693: converting floating point value @var{x} (valid for mode @var{m}) to an
1694: integer, still represented in floating point mode @var{m}, by rounding
1695: towards zero.
1696: @end table
1697:
1698: @node RTL Declarations, Side Effects, Conversions, RTL
1699: @section Declarations
1700: @cindex RTL declarations
1701: @cindex declarations, RTL
1702:
1703: Declaration expression codes do not represent arithmetic operations
1704: but rather state assertions about their operands.
1705:
1706: @table @code
1707: @findex strict_low_part
1708: @cindex @code{subreg}, in @code{strict_low_part}
1709: @item (strict_low_part (subreg:@var{m} (reg:@var{n} @var{r}) 0))
1710: This expression code is used in only one context: as the destination operand of a
1711: @code{set} expression. In addition, the operand of this expression
1712: must be a non-paradoxical @code{subreg} expression.
1713:
1714: The presence of @code{strict_low_part} says that the part of the
1715: register which is meaningful in mode @var{n}, but is not part of
1716: mode @var{m}, is not to be altered. Normally, an assignment to such
1717: a subreg is allowed to have undefined effects on the rest of the
1718: register when @var{m} is less than a word.
1719: @end table
1720:
1721: @node Side Effects, Incdec, RTL Declarations, RTL
1722: @section Side Effect Expressions
1723: @cindex RTL side effect expressions
1724:
1725: The expression codes described so far represent values, not actions.
1726: But machine instructions never produce values; they are meaningful
1727: only for their side effects on the state of the machine. Special
1728: expression codes are used to represent side effects.
1729:
1730: The body of an instruction is always one of these side effect codes;
1731: the codes described above, which represent values, appear only as
1732: the operands of these.
1733:
1734: @table @code
1735: @findex set
1736: @item (set @var{lval} @var{x})
1737: Represents the action of storing the value of @var{x} into the place
1738: represented by @var{lval}. @var{lval} must be an expression
1739: representing a place that can be stored in: @code{reg} (or
1740: @code{subreg} or @code{strict_low_part}), @code{mem}, @code{pc} or
1741: @code{cc0}.@refill
1742:
1743: If @var{lval} is a @code{reg}, @code{subreg} or @code{mem}, it has a
1744: machine mode; then @var{x} must be valid for that mode.@refill
1745:
1746: If @var{lval} is a @code{reg} whose machine mode is less than the full
1747: width of the register, then it means that the part of the register
1748: specified by the machine mode is given the specified value and the
1749: rest of the register receives an undefined value. Likewise, if
1750: @var{lval} is a @code{subreg} whose machine mode is narrower than
1751: the mode of the register, the rest of the register can be changed in
1752: an undefined way.
1753:
1754: If @var{lval} is a @code{strict_low_part} of a @code{subreg}, then the
1755: part of the register specified by the machine mode of the
1756: @code{subreg} is given the value @var{x} and the rest of the register
1757: is not changed.@refill
1758:
1759: If @var{lval} is @code{(cc0)}, it has no machine mode, and @var{x} may
1760: be either a @code{compare} expression or a value that may have any mode.
1761: The latter case represents a ``test'' instruction. The expression
1762: @code{(set (cc0) (reg:@var{m} @var{n}))} is equivalent to
1763: @code{(set (cc0) (compare (reg:@var{m} @var{n}) (const_int 0)))}.
1764: Use the former expression to save space during the compilation.
1765:
1766: @cindex jump instructions and @code{set}
1767: @cindex @code{if_then_else} usage
1768: If @var{lval} is @code{(pc)}, we have a jump instruction, and the
1769: possibilities for @var{x} are very limited. It may be a
1770: @code{label_ref} expression (unconditional jump). It may be an
1771: @code{if_then_else} (conditional jump), in which case either the
1772: second or the third operand must be @code{(pc)} (for the case which
1773: does not jump) and the other of the two must be a @code{label_ref}
1774: (for the case which does jump). @var{x} may also be a @code{mem} or
1775: @code{(plus:SI (pc) @var{y})}, where @var{y} may be a @code{reg} or a
1776: @code{mem}; these unusual patterns are used to represent jumps through
1777: branch tables.@refill
1778:
1779: If @var{lval} is neither @code{(cc0)} nor @code{(pc)}, the mode of
1780: @var{lval} must not be @code{VOIDmode} and the mode of @var{x} must be
1781: valid for the mode of @var{lval}.
1782:
1783: @findex SET_DEST
1784: @findex SET_SRC
1785: @var{lval} is customarily accessed with the @code{SET_DEST} macro and
1786: @var{x} with the @code{SET_SRC} macro.
1787:
1788: @findex return
1789: @item (return)
1790: As the sole expression in a pattern, represents a return from the
1791: current function, on machines where this can be done with one
1792: instruction, such as Vaxes. On machines where a multi-instruction
1793: ``epilogue'' must be executed in order to return from the function,
1794: returning is done by jumping to a label which precedes the epilogue, and
1795: the @code{return} expression code is never used.
1796:
1797: Inside an @code{if_then_else} expression, represents the value to be
1798: placed in @code{pc} to return to the caller.
1799:
1800: Note that an insn pattern of @code{(return)} is logically equivalent to
1801: @code{(set (pc) (return))}, but the latter form is never used.
1802:
1803: @findex call
1804: @item (call @var{function} @var{nargs})
1805: Represents a function call. @var{function} is a @code{mem} expression
1806: whose address is the address of the function to be called.
1807: @var{nargs} is an expression which can be used for two purposes: on
1808: some machines it represents the number of bytes of stack argument; on
1809: others, it represents the number of argument registers.
1810:
1811: Each machine has a standard machine mode which @var{function} must
1812: have. The machine description defines macro @code{FUNCTION_MODE} to
1813: expand into the requisite mode name. The purpose of this mode is to
1814: specify what kind of addressing is allowed, on machines where the
1815: allowed kinds of addressing depend on the machine mode being
1816: addressed.
1817:
1818: @findex clobber
1819: @item (clobber @var{x})
1820: Represents the storing or possible storing of an unpredictable,
1821: undescribed value into @var{x}, which must be a @code{reg},
1822: @code{scratch} or @code{mem} expression.
1823:
1824: One place this is used is in string instructions that store standard
1825: values into particular hard registers. It may not be worth the
1826: trouble to describe the values that are stored, but it is essential to
1827: inform the compiler that the registers will be altered, lest it
1828: attempt to keep data in them across the string instruction.
1829:
1830: If @var{x} is @code{(mem:BLK (const_int 0))}, it means that all memory
1831: locations must be presumed clobbered.
1832:
1833: Note that the machine description classifies certain hard registers as
1834: ``call-clobbered''. All function call instructions are assumed by
1835: default to clobber these registers, so there is no need to use
1836: @code{clobber} expressions to indicate this fact. Also, each function
1837: call is assumed to have the potential to alter any memory location,
1838: unless the function is declared @code{const}.
1839:
1840: If the last group of expressions in a @code{parallel} are each a
1841: @code{clobber} expression whose arguments are @code{reg} or
1842: @code{match_scratch} (@pxref{RTL Template}) expressions, the combiner
1843: phase can add the appropriate @code{clobber} expressions to an insn it
1844: has constructed when doing so will cause a pattern to be matched.
1845:
1846: This feature can be used, for example, on a machine that whose multiply
1847: and add instructions don't use an MQ register but which has an
1848: add-accumulate instruction that does clobber the MQ register. Similarly,
1849: a combined instruction might require a temporary register while the
1850: constituent instructions might not.
1851:
1852: When a @code{clobber} expression for a register appears inside a
1853: @code{parallel} with other side effects, the register allocator
1854: guarantees that the register is unoccupied both before and after that
1855: insn. However, the reload phase may allocate a register used for one of
1856: the inputs unless the @samp{&} constraint is specified for the selected
1857: alternative (@pxref{Modifiers}). You can clobber either a specific hard
1858: register, a pseudo register, or a @code{scratch} expression; in the
1859: latter two cases, GNU CC will allocate a hard register that is available
1860: there for use as a temporary.
1861:
1862: For instructions that require a temporary register, you should use
1863: @code{scratch} instead of a pseudo-register because this will allow the
1864: combiner phase to add the @code{clobber} when required. You do this by
1865: coding (@code{clobber} (@code{match_scratch} @dots{})). If you do
1866: clobber a pseudo register, use one which appears nowhere else---generate
1867: a new one each time. Otherwise, you may confuse CSE.
1868:
1869: There is one other known use for clobbering a pseudo register in a
1870: @code{parallel}: when one of the input operands of the insn is also
1871: clobbered by the insn. In this case, using the same pseudo register in
1872: the clobber and elsewhere in the insn produces the expected results.
1873:
1874: @findex use
1875: @item (use @var{x})
1876: Represents the use of the value of @var{x}. It indicates that the
1877: value in @var{x} at this point in the program is needed, even though
1878: it may not be apparent why this is so. Therefore, the compiler will
1879: not attempt to delete previous instructions whose only effect is to
1880: store a value in @var{x}. @var{x} must be a @code{reg} expression.
1881:
1882: During the delayed branch scheduling phase, @var{x} may be an insn.
1883: This indicates that @var{x} previously was located at this place in the
1884: code and its data dependencies need to be taken into account. These
1885: @code{use} insns will be deleted before the delayed branch scheduling
1886: phase exits.
1887:
1888: @findex parallel
1889: @item (parallel [@var{x0} @var{x1} @dots{}])
1890: Represents several side effects performed in parallel. The square
1891: brackets stand for a vector; the operand of @code{parallel} is a
1892: vector of expressions. @var{x0}, @var{x1} and so on are individual
1893: side effect expressions---expressions of code @code{set}, @code{call},
1894: @code{return}, @code{clobber} or @code{use}.@refill
1895:
1896: ``In parallel'' means that first all the values used in the individual
1897: side-effects are computed, and second all the actual side-effects are
1898: performed. For example,
1899:
1900: @example
1901: (parallel [(set (reg:SI 1) (mem:SI (reg:SI 1)))
1902: (set (mem:SI (reg:SI 1)) (reg:SI 1))])
1903: @end example
1904:
1905: @noindent
1906: says unambiguously that the values of hard register 1 and the memory
1907: location addressed by it are interchanged. In both places where
1908: @code{(reg:SI 1)} appears as a memory address it refers to the value
1909: in register 1 @emph{before} the execution of the insn.
1910:
1911: It follows that it is @emph{incorrect} to use @code{parallel} and
1912: expect the result of one @code{set} to be available for the next one.
1913: For example, people sometimes attempt to represent a jump-if-zero
1914: instruction this way:
1915:
1916: @example
1917: (parallel [(set (cc0) (reg:SI 34))
1918: (set (pc) (if_then_else
1919: (eq (cc0) (const_int 0))
1920: (label_ref @dots{})
1921: (pc)))])
1922: @end example
1923:
1924: @noindent
1925: But this is incorrect, because it says that the jump condition depends
1926: on the condition code value @emph{before} this instruction, not on the
1927: new value that is set by this instruction.
1928:
1929: @cindex peephole optimization, RTL representation
1930: Peephole optimization, which takes place together with final assembly
1931: code output, can produce insns whose patterns consist of a @code{parallel}
1932: whose elements are the operands needed to output the resulting
1933: assembler code---often @code{reg}, @code{mem} or constant expressions.
1934: This would not be well-formed RTL at any other stage in compilation,
1935: but it is ok then because no further optimization remains to be done.
1936: However, the definition of the macro @code{NOTICE_UPDATE_CC}, if
1937: any, must deal with such insns if you define any peephole optimizations.
1938:
1939: @findex sequence
1940: @item (sequence [@var{insns} @dots{}])
1941: Represents a sequence of insns. Each of the @var{insns} that appears
1942: in the vector is suitable for appearing in the chain of insns, so it
1943: must be an @code{insn}, @code{jump_insn}, @code{call_insn},
1944: @code{code_label}, @code{barrier} or @code{note}.
1945:
1946: A @code{sequence} RTX is never placed in an actual insn during RTL
1947: generation. It represents the sequence of insns that result from a
1948: @code{define_expand} @emph{before} those insns are passed to
1949: @code{emit_insn} to insert them in the chain of insns. When actually
1950: inserted, the individual sub-insns are separated out and the
1951: @code{sequence} is forgotten.
1952:
1953: After delay-slot scheduling is completed, an insn and all the insns that
1954: reside in its delay slots are grouped together into a @code{sequence}.
1955: The insn requiring the delay slot is the first insn in the vector;
1956: subsequent insns are to be placed in the delay slot.
1957:
1958: @code{INSN_ANNULLED_BRANCH_P} is set on an insn in a delay slot to
1959: indicate that a branch insn should be used that will conditionally annul
1960: the effect of the insns in the delay slots. In such a case,
1961: @code{INSN_FROM_TARGET_P} indicates that the insn is from the target of
1962: the branch and should be executed only if the branch is taken; otherwise
1963: the insn should be executed only if the branch is not taken.
1964: @xref{Delay Slots}.
1965: @end table
1966:
1967: These expression codes appear in place of a side effect, as the body of
1968: an insn, though strictly speaking they do not always describe side
1969: effects as such:
1970:
1971: @table @code
1972: @findex asm_input
1973: @item (asm_input @var{s})
1974: Represents literal assembler code as described by the string @var{s}.
1975:
1976: @findex unspec
1977: @findex unspec_volatile
1978: @item (unspec [@var{operands} @dots{}] @var{index})
1979: @itemx (unspec_volatile [@var{operands} @dots{}] @var{index})
1980: Represents a machine-specific operation on @var{operands}. @var{index}
1981: selects between multiple machine-specific operations.
1982: @code{unspec_volatile} is used for volatile operations and operations
1983: that may trap; @code{unspec} is used for other operations.
1984:
1985: These codes may appear inside a @code{pattern} of an
1986: insn, inside a @code{parallel}, or inside an expression.
1987:
1988: @findex addr_vec
1989: @item (addr_vec:@var{m} [@var{lr0} @var{lr1} @dots{}])
1990: Represents a table of jump addresses. The vector elements @var{lr0},
1991: etc., are @code{label_ref} expressions. The mode @var{m} specifies
1992: how much space is given to each address; normally @var{m} would be
1993: @code{Pmode}.
1994:
1995: @findex addr_diff_vec
1996: @item (addr_diff_vec:@var{m} @var{base} [@var{lr0} @var{lr1} @dots{}])
1997: Represents a table of jump addresses expressed as offsets from
1998: @var{base}. The vector elements @var{lr0}, etc., are @code{label_ref}
1999: expressions and so is @var{base}. The mode @var{m} specifies how much
2000: space is given to each address-difference.@refill
2001: @end table
2002:
2003: @node Incdec, Assembler, Side Effects, RTL
2004: @section Embedded Side-Effects on Addresses
2005: @cindex RTL preincrement
2006: @cindex RTL postincrement
2007: @cindex RTL predecrement
2008: @cindex RTL postdecrement
2009:
2010: Four special side-effect expression codes appear as memory addresses.
2011:
2012: @table @code
2013: @findex pre_dec
2014: @item (pre_dec:@var{m} @var{x})
2015: Represents the side effect of decrementing @var{x} by a standard
2016: amount and represents also the value that @var{x} has after being
2017: decremented. @var{x} must be a @code{reg} or @code{mem}, but most
2018: machines allow only a @code{reg}. @var{m} must be the machine mode
2019: for pointers on the machine in use. The amount @var{x} is decremented
2020: by is the length in bytes of the machine mode of the containing memory
2021: reference of which this expression serves as the address. Here is an
2022: example of its use:@refill
2023:
2024: @example
2025: (mem:DF (pre_dec:SI (reg:SI 39)))
2026: @end example
2027:
2028: @noindent
2029: This says to decrement pseudo register 39 by the length of a @code{DFmode}
2030: value and use the result to address a @code{DFmode} value.
2031:
2032: @findex pre_inc
2033: @item (pre_inc:@var{m} @var{x})
2034: Similar, but specifies incrementing @var{x} instead of decrementing it.
2035:
2036: @findex post_dec
2037: @item (post_dec:@var{m} @var{x})
2038: Represents the same side effect as @code{pre_dec} but a different
2039: value. The value represented here is the value @var{x} has @i{before}
2040: being decremented.
2041:
2042: @findex post_inc
2043: @item (post_inc:@var{m} @var{x})
2044: Similar, but specifies incrementing @var{x} instead of decrementing it.
2045: @end table
2046:
2047: These embedded side effect expressions must be used with care. Instruction
2048: patterns may not use them. Until the @samp{flow} pass of the compiler,
2049: they may occur only to represent pushes onto the stack. The @samp{flow}
2050: pass finds cases where registers are incremented or decremented in one
2051: instruction and used as an address shortly before or after; these cases are
2052: then transformed to use pre- or post-increment or -decrement.
2053:
2054: If a register used as the operand of these expressions is used in
2055: another address in an insn, the original value of the register is used.
2056: Uses of the register outside of an address are not permitted within the
2057: same insn as a use in an embedded side effect expression because such
2058: insns behave differently on different machines and hence must be treated
2059: as ambiguous and disallowed.
2060:
2061: An instruction that can be represented with an embedded side effect
2062: could also be represented using @code{parallel} containing an additional
2063: @code{set} to describe how the address register is altered. This is not
2064: done because machines that allow these operations at all typically
2065: allow them wherever a memory address is called for. Describing them as
2066: additional parallel stores would require doubling the number of entries
2067: in the machine description.
2068:
2069: @node Assembler, Insns, Incdec, RTL
2070: @section Assembler Instructions as Expressions
2071: @cindex assembler instructions in RTL
2072:
2073: @cindex @code{asm_operands}, usage
2074: The RTX code @code{asm_operands} represents a value produced by a
2075: user-specified assembler instruction. It is used to represent
2076: an @code{asm} statement with arguments. An @code{asm} statement with
2077: a single output operand, like this:
2078:
2079: @smallexample
2080: asm ("foo %1,%2,%0" : "=a" (outputvar) : "g" (x + y), "di" (*z));
2081: @end smallexample
2082:
2083: @noindent
2084: is represented using a single @code{asm_operands} RTX which represents
2085: the value that is stored in @code{outputvar}:
2086:
2087: @smallexample
2088: (set @var{rtx-for-outputvar}
2089: (asm_operands "foo %1,%2,%0" "a" 0
2090: [@var{rtx-for-addition-result} @var{rtx-for-*z}]
2091: [(asm_input:@var{m1} "g")
2092: (asm_input:@var{m2} "di")]))
2093: @end smallexample
2094:
2095: @noindent
2096: Here the operands of the @code{asm_operands} RTX are the assembler
2097: template string, the output-operand's constraint, the index-number of the
2098: output operand among the output operands specified, a vector of input
2099: operand RTX's, and a vector of input-operand modes and constraints. The
2100: mode @var{m1} is the mode of the sum @code{x+y}; @var{m2} is that of
2101: @code{*z}.
2102:
2103: When an @code{asm} statement has multiple output values, its insn has
2104: several such @code{set} RTX's inside of a @code{parallel}. Each @code{set}
2105: contains a @code{asm_operands}; all of these share the same assembler
2106: template and vectors, but each contains the constraint for the respective
2107: output operand. They are also distinguished by the output-operand index
2108: number, which is 0, 1, @dots{} for successive output operands.
2109:
2110: @node Insns, Calls, Assembler, RTL
2111: @section Insns
2112: @cindex insns
2113:
2114: The RTL representation of the code for a function is a doubly-linked
2115: chain of objects called @dfn{insns}. Insns are expressions with
2116: special codes that are used for no other purpose. Some insns are
2117: actual instructions; others represent dispatch tables for @code{switch}
2118: statements; others represent labels to jump to or various sorts of
2119: declarative information.
2120:
2121: In addition to its own specific data, each insn must have a unique
2122: id-number that distinguishes it from all other insns in the current
2123: function (after delayed branch scheduling, copies of an insn with the
2124: same id-number may be present in multiple places in a function, but
2125: these copies will always be identical and will only appear inside a
2126: @code{sequence}), and chain pointers to the preceding and following
2127: insns. These three fields occupy the same position in every insn,
2128: independent of the expression code of the insn. They could be accessed
2129: with @code{XEXP} and @code{XINT}, but instead three special macros are
2130: always used:
2131:
2132: @table @code
2133: @findex INSN_UID
2134: @item INSN_UID (@var{i})
2135: Accesses the unique id of insn @var{i}.
2136:
2137: @findex PREV_INSN
2138: @item PREV_INSN (@var{i})
2139: Accesses the chain pointer to the insn preceding @var{i}.
2140: If @var{i} is the first insn, this is a null pointer.
2141:
2142: @findex NEXT_INSN
2143: @item NEXT_INSN (@var{i})
2144: Accesses the chain pointer to the insn following @var{i}.
2145: If @var{i} is the last insn, this is a null pointer.
2146: @end table
2147:
2148: @findex get_insns
2149: @findex get_last_insn
2150: The first insn in the chain is obtained by calling @code{get_insns}; the
2151: last insn is the result of calling @code{get_last_insn}. Within the
2152: chain delimited by these insns, the @code{NEXT_INSN} and
2153: @code{PREV_INSN} pointers must always correspond: if @var{insn} is not
2154: the first insn,
2155:
2156: @example
2157: NEXT_INSN (PREV_INSN (@var{insn})) == @var{insn}
2158: @end example
2159:
2160: @noindent
2161: is always true and if @var{insn} is not the last insn,
2162:
2163: @example
2164: PREV_INSN (NEXT_INSN (@var{insn})) == @var{insn}
2165: @end example
2166:
2167: @noindent
2168: is always true.
2169:
2170: After delay slot scheduling, some of the insns in the chain might be
2171: @code{sequence} expressions, which contain a vector of insns. The value
2172: of @code{NEXT_INSN} in all but the last of these insns is the next insn
2173: in the vector; the value of @code{NEXT_INSN} of the last insn in the vector
2174: is the same as the value of @code{NEXT_INSN} for the @code{sequence} in
2175: which it is contained. Similar rules apply for @code{PREV_INSN}.
2176:
2177: This means that the above invariants are not necessarily true for insns
2178: inside @code{sequence} expressions. Specifically, if @var{insn} is the
2179: first insn in a @code{sequence}, @code{NEXT_INSN (PREV_INSN (@var{insn}))}
2180: is the insn containing the @code{sequence} expression, as is the value
2181: of @code{PREV_INSN (NEXT_INSN (@var{insn}))} is @var{insn} is the last
2182: insn in the @code{sequence} expression. You can use these expressions
2183: to find the containing @code{sequence} expression.@refill
2184:
2185: Every insn has one of the following six expression codes:
2186:
2187: @table @code
2188: @findex insn
2189: @item insn
2190: The expression code @code{insn} is used for instructions that do not jump
2191: and do not do function calls. @code{sequence} expressions are always
2192: contained in insns with code @code{insn} even if one of those insns
2193: should jump or do function calls.
2194:
2195: Insns with code @code{insn} have four additional fields beyond the three
2196: mandatory ones listed above. These four are described in a table below.
2197:
2198: @findex jump_insn
2199: @item jump_insn
2200: The expression code @code{jump_insn} is used for instructions that may
2201: jump (or, more generally, may contain @code{label_ref} expressions). If
2202: there is an instruction to return from the current function, it is
2203: recorded as a @code{jump_insn}.
2204:
2205: @findex JUMP_LABEL
2206: @code{jump_insn} insns have the same extra fields as @code{insn} insns,
2207: accessed in the same way and in addition contains a field
2208: @code{JUMP_LABEL} which is defined once jump optimization has completed.
2209:
2210: For simple conditional and unconditional jumps, this field contains the
2211: @code{code_label} to which this insn will (possibly conditionally)
2212: branch. In a more complex jump, @code{JUMP_LABEL} records one of the
2213: labels that the insn refers to; the only way to find the others
2214: is to scan the entire body of the insn.
2215:
2216: Return insns count as jumps, but since they do not refer to any labels,
2217: they have zero in the @code{JUMP_LABEL} field.
2218:
2219: @findex call_insn
2220: @item call_insn
2221: The expression code @code{call_insn} is used for instructions that may do
2222: function calls. It is important to distinguish these instructions because
2223: they imply that certain registers and memory locations may be altered
2224: unpredictably.
2225:
2226: A @code{call_insn} insn may be preceded by insns that contain a single
2227: @code{use} expression and be followed by insns the contain a single
2228: @code{clobber} expression. If so, these @code{use} and @code{clobber}
2229: expressions are treated as being part of the function call.
2230: There must not even be a @code{note} between the @code{call_insn} and
2231: the @code{use} or @code{clobber} insns for this special treatment to
2232: take place. This is somewhat of a kludge and will be removed in a later
2233: version of GNU CC.
2234:
2235: @code{call_insn} insns have the same extra fields as @code{insn} insns,
2236: accessed in the same way.
2237:
2238: @findex code_label
2239: @findex CODE_LABEL_NUMBER
2240: @item code_label
2241: A @code{code_label} insn represents a label that a jump insn can jump
2242: to. It contains two special fields of data in addition to the three
2243: standard ones. @code{CODE_LABEL_NUMBER} is used to hold the @dfn{label
2244: number}, a number that identifies this label uniquely among all the
2245: labels in the compilation (not just in the current function).
2246: Ultimately, the label is represented in the assembler output as an
2247: assembler label, usually of the form @samp{L@var{n}} where @var{n} is
2248: the label number.
2249:
2250: When a @code{code_label} appears in an RTL expression, it normally
2251: appears within a @code{label_ref} which represents the address of
2252: the label, as a number.
2253:
2254: @findex LABEL_NUSES
2255: The field @code{LABEL_NUSES} is only defined once the jump optimization
2256: phase is completed and contains the number of times this label is
2257: referenced in the current function.
2258:
2259: @findex barrier
2260: @item barrier
2261: Barriers are placed in the instruction stream when control cannot flow
2262: past them. They are placed after unconditional jump instructions to
2263: indicate that the jumps are unconditional and after calls to
2264: @code{volatile} functions, which do not return (e.g., @code{exit}).
2265: They contain no information beyond the three standard fields.
2266:
2267: @findex note
2268: @findex NOTE_LINE_NUMBER
2269: @findex NOTE_SOURCE_FILE
2270: @item note
2271: @code{note} insns are used to represent additional debugging and
2272: declarative information. They contain two nonstandard fields, an
2273: integer which is accessed with the macro @code{NOTE_LINE_NUMBER} and a
2274: string accessed with @code{NOTE_SOURCE_FILE}.
2275:
2276: If @code{NOTE_LINE_NUMBER} is positive, the note represents the
2277: position of a source line and @code{NOTE_SOURCE_FILE} is the source file name
2278: that the line came from. These notes control generation of line
2279: number data in the assembler output.
2280:
2281: Otherwise, @code{NOTE_LINE_NUMBER} is not really a line number but a
2282: code with one of the following values (and @code{NOTE_SOURCE_FILE}
2283: must contain a null pointer):
2284:
2285: @table @code
2286: @findex NOTE_INSN_DELETED
2287: @item NOTE_INSN_DELETED
2288: Such a note is completely ignorable. Some passes of the compiler
2289: delete insns by altering them into notes of this kind.
2290:
2291: @findex NOTE_INSN_BLOCK_BEG
2292: @findex NOTE_INSN_BLOCK_END
2293: @item NOTE_INSN_BLOCK_BEG
2294: @itemx NOTE_INSN_BLOCK_END
2295: These types of notes indicate the position of the beginning and end
2296: of a level of scoping of variable names. They control the output
2297: of debugging information.
2298:
2299: @findex NOTE_INSN_LOOP_BEG
2300: @findex NOTE_INSN_LOOP_END
2301: @item NOTE_INSN_LOOP_BEG
2302: @itemx NOTE_INSN_LOOP_END
2303: These types of notes indicate the position of the beginning and end
2304: of a @code{while} or @code{for} loop. They enable the loop optimizer
2305: to find loops quickly.
2306:
2307: @findex NOTE_INSN_LOOP_CONT
2308: @item NOTE_INSN_LOOP_CONT
2309: Appears at the place in a loop that @code{continue} statements jump to.
2310:
2311: @findex NOTE_INSN_LOOP_VTOP
2312: @item NOTE_INSN_LOOP_VTOP
2313: This note indicates the place in a loop where the exit test begins for
2314: those loops in which the exit test has been duplicated. This position
2315: becomes another virtual start of the loop when considering loop
2316: invariants.
2317:
2318: @findex NOTE_INSN_FUNCTION_END
2319: @item NOTE_INSN_FUNCTION_END
2320: Appears near the end of the function body, just before the label that
2321: @code{return} statements jump to (on machine where a single instruction
2322: does not suffice for returning). This note may be deleted by jump
2323: optimization.
2324:
2325: @findex NOTE_INSN_SETJMP
2326: @item NOTE_INSN_SETJMP
2327: Appears following each call to @code{setjmp} or a related function.
2328: @end table
2329:
2330: These codes are printed symbolically when they appear in debugging dumps.
2331: @end table
2332:
2333: @cindex @code{HImode}, in @code{insn}
2334: @cindex @code{QImode}, in @code{insn}
2335: The machine mode of an insn is normally @code{VOIDmode}, but some
2336: phases use the mode for various purposes; for example, the reload pass
2337: sets it to @code{HImode} if the insn needs reloading but not register
2338: elimination and @code{QImode} if both are required. The common
2339: subexpression elimination pass sets the mode of an insn to @code{QImode}
2340: when it is the first insn in a block that has already been processed.
2341:
2342: Here is a table of the extra fields of @code{insn}, @code{jump_insn}
2343: and @code{call_insn} insns:
2344:
2345: @table @code
2346: @findex PATTERN
2347: @item PATTERN (@var{i})
2348: An expression for the side effect performed by this insn. This must be
2349: one of the following codes: @code{set}, @code{call}, @code{use},
2350: @code{clobber}, @code{return}, @code{asm_input}, @code{asm_output},
2351: @code{addr_vec}, @code{addr_diff_vec}, @code{trap_if}, @code{unspec},
2352: @code{unspec_volatile}, @code{parallel}, or @code{sequence}. If it is a @code{parallel},
2353: each element of the @code{parallel} must be one these codes, except that
2354: @code{parallel} expressions cannot be nested and @code{addr_vec} and
2355: @code{addr_diff_vec} are not permitted inside a @code{parallel} expression.
2356:
2357: @findex INSN_CODE
2358: @item INSN_CODE (@var{i})
2359: An integer that says which pattern in the machine description matches
2360: this insn, or -1 if the matching has not yet been attempted.
2361:
2362: Such matching is never attempted and this field remains -1 on an insn
2363: whose pattern consists of a single @code{use}, @code{clobber},
2364: @code{asm_input}, @code{addr_vec} or @code{addr_diff_vec} expression.
2365:
2366: @findex asm_noperands
2367: Matching is also never attempted on insns that result from an @code{asm}
2368: statement. These contain at least one @code{asm_operands} expression.
2369: The function @code{asm_noperands} returns a non-negative value for
2370: such insns.
2371:
2372: In the debugging output, this field is printed as a number followed by
2373: a symbolic representation that locates the pattern in the @file{md}
2374: file as some small positive or negative offset from a named pattern.
2375:
2376: @findex LOG_LINKS
2377: @item LOG_LINKS (@var{i})
2378: A list (chain of @code{insn_list} expressions) giving information about
2379: dependencies between instructions within a basic block. Neither a jump
2380: nor a label may come between the related insns.
2381:
2382: @findex REG_NOTES
2383: @item REG_NOTES (@var{i})
2384: A list (chain of @code{expr_list} and @code{insn_list} expressions)
2385: giving miscellaneous information about the insn. It is often information
2386: pertaining to the registers used in this insn.
2387: @end table
2388:
2389: The @code{LOG_LINKS} field of an insn is a chain of @code{insn_list}
2390: expressions. Each of these has two operands: the first is an insn,
2391: and the second is another @code{insn_list} expression (the next one in
2392: the chain). The last @code{insn_list} in the chain has a null pointer
2393: as second operand. The significant thing about the chain is which
2394: insns appear in it (as first operands of @code{insn_list}
2395: expressions). Their order is not significant.
2396:
2397: This list is originally set up by the flow analysis pass; it is a null
2398: pointer until then. Flow only adds links for those data dependencies
2399: which can be used for instruction combination. For each insn, the flow
2400: analysis pass adds a link to insns which store into registers values
2401: that are used for the first time in this insn. The instruction
2402: scheduling pass adds extra links so that every dependence will be
2403: represented. Links represent data dependencies, antidependencies and
2404: output dependencies; the machine mode of the link distinguishes these
2405: three types: antidependencies have mode @code{REG_DEP_ANTI}, output
2406: dependencies have mode @code{REG_DEP_OUTPUT}, and data dependencies have
2407: mode @code{VOIDmode}.
2408:
2409: The @code{REG_NOTES} field of an insn is a chain similar to the
2410: @code{LOG_LINKS} field but it includes @code{expr_list} expressions in
2411: addition to @code{insn_list} expressions. There are several kinds
2412: of register notes, which are distinguished by the machine mode, which
2413: in a register note is really understood as being an @code{enum reg_note}.
2414: The first operand @var{op} of the note is data whose meaning depends on
2415: the kind of note.
2416:
2417: @findex REG_NOTE_KIND
2418: @findex PUT_REG_NOTE_KIND
2419: The macro @code{REG_NOTE_KIND (@var{x})} returns the kind of
2420: register note. Its counterpart, the macro @code{PUT_REG_NOTE_KIND
2421: (@var{x}, @var{newkind})} sets the register note type of @var{x} to be
2422: @var{newkind}.
2423:
2424: Register notes are of three classes: They may say something about an
2425: input to an insn, they may say something about an output of an insn, or
2426: they may create a linkage between two insns. There are also a set
2427: of values that are only used in @code{LOG_LINKS}.
2428:
2429: These register notes annotate inputs to an insn:
2430:
2431: @table @code
2432: @findex REG_DEAD
2433: @item REG_DEAD
2434: The value in @var{op} dies in this insn; that is to say, altering the
2435: value immediately after this insn would not affect the future behavior
2436: of the program.
2437:
2438: This does not necessarily mean that the register @var{op} has no useful
2439: value after this insn since it may also be an output of the insn. In
2440: such a case, however, a @code{REG_DEAD} note would be redundant and is
2441: usually not present until after the reload pass, but no code relies on
2442: this fact.
2443:
2444: @findex REG_INC
2445: @item REG_INC
2446: The register @var{op} is incremented (or decremented; at this level
2447: there is no distinction) by an embedded side effect inside this insn.
2448: This means it appears in a @code{post_inc}, @code{pre_inc},
2449: @code{post_dec} or @code{pre_dec} expression.
2450:
2451: @findex REG_NONNEG
2452: @item REG_NONNEG
2453: The register @var{op} is known to have a nonnegative value when this
2454: insn is reached. This is used so that decrement and branch until zero
2455: instructions, such as the m68k dbra, can be matched.
2456:
2457: The @code{REG_NONNEG} note is added to insns only if the machine
2458: description has a @samp{decrement_and_branch_until_zero} pattern.
2459:
2460: @findex REG_NO_CONFLICT
2461: @item REG_NO_CONFLICT
2462: This insn does not cause a conflict between @var{op} and the item
2463: being set by this insn even though it might appear that it does.
2464: In other words, if the destination register and @var{op} could
2465: otherwise be assigned the same register, this insn does not
2466: prevent that assignment.
2467:
2468: Insns with this note are usually part of a block that begins with a
2469: @code{clobber} insn specifying a multi-word pseudo register (which will
2470: be the output of the block), a group of insns that each set one word of
2471: the value and have the @code{REG_NO_CONFLICT} note attached, and a final
2472: insn that copies the output to itself with an attached @code{REG_EQUAL}
2473: note giving the expression being computed. This block is encapsulated
2474: with @code{REG_LIBCALL} and @code{REG_RETVAL} notes on the first and
2475: last insns, respectively.
2476:
2477: @findex REG_LABEL
2478: @item REG_LABEL
2479: This insn uses @var{op}, a @code{code_label}, but is not a
2480: @code{jump_insn}. The presence of this note allows jump optimization to
2481: be aware that @var{op} is, in fact, being used.
2482: @end table
2483:
2484: The following notes describe attributes of outputs of an insn:
2485:
2486: @table @code
2487: @findex REG_EQUIV
2488: @findex REG_EQUAL
2489: @item REG_EQUIV
2490: @itemx REG_EQUAL
2491: This note is only valid on an insn that sets only one register and
2492: indicates that that register will be equal to @var{op} at run time; the
2493: scope of this equivalence differs between the two types of notes. The
2494: value which the insn explicitly copies into the register may look
2495: different from @var{op}, but they will be equal at run time. If the
2496: output of the single @code{set} is a @code{strict_low_part} expression,
2497: the note refers to the register that is contained in @code{SUBREG_REG}
2498: of the @code{subreg} expression.
2499:
2500: For @code{REG_EQUIV}, the register is equivalent to @var{op} throughout
2501: the entire function, and could validly be replaced in all its
2502: occurrences by @var{op}. (``Validly'' here refers to the data flow of
2503: the program; simple replacement may make some insns invalid.) For
2504: example, when a constant is loaded into a register that is never
2505: assigned any other value, this kind of note is used.
2506:
2507: When a parameter is copied into a pseudo-register at entry to a function,
2508: a note of this kind records that the register is equivalent to the stack
2509: slot where the parameter was passed. Although in this case the register
2510: may be set by other insns, it is still valid to replace the register
2511: by the stack slot throughout the function.
2512:
2513: In the case of @code{REG_EQUAL}, the register that is set by this insn
2514: will be equal to @var{op} at run time at the end of this insn but not
2515: necessarily elsewhere in the function. In this case, @var{op}
2516: is typically an arithmetic expression. For example, when a sequence of
2517: insns such as a library call is used to perform an arithmetic operation,
2518: this kind of note is attached to the insn that produces or copies the
2519: final value.
2520:
2521: These two notes are used in different ways by the compiler passes.
2522: @code{REG_EQUAL} is used by passes prior to register allocation (such as
2523: common subexpression elimination and loop optimization) to tell them how
2524: to think of that value. @code{REG_EQUIV} notes are used by register
2525: allocation to indicate that there is an available substitute expression
2526: (either a constant or a @code{mem} expression for the location of a
2527: parameter on the stack) that may be used in place of a register if
2528: insufficient registers are available.
2529:
2530: Except for stack homes for parameters, which are indicated by a
2531: @code{REG_EQUIV} note and are not useful to the early optimization
2532: passes and pseudo registers that are equivalent to a memory location
2533: throughout there entire life, which is not detected until later in
2534: the compilation, all equivalences are initially indicated by an attached
2535: @code{REG_EQUAL} note. In the early stages of register allocation, a
2536: @code{REG_EQUAL} note is changed into a @code{REG_EQUIV} note if
2537: @var{op} is a constant and the insn represents the only set of its
2538: destination register.
2539:
2540: Thus, compiler passes prior to register allocation need only check for
2541: @code{REG_EQUAL} notes and passes subsequent to register allocation
2542: need only check for @code{REG_EQUIV} notes.
2543:
2544: @findex REG_UNUSED
2545: @item REG_UNUSED
2546: The register @var{op} being set by this insn will not be used in a
2547: subsequent insn. This differs from a @code{REG_DEAD} note, which
2548: indicates that the value in an input will not be used subsequently.
2549: These two notes are independent; both may be present for the same
2550: register.
2551:
2552: @findex REG_WAS_0
2553: @item REG_WAS_0
2554: The single output of this insn contained zero before this insn.
2555: @var{op} is the insn that set it to zero. You can rely on this note if
2556: it is present and @var{op} has not been deleted or turned into a @code{note};
2557: its absence implies nothing.
2558: @end table
2559:
2560: These notes describe linkages between insns. They occur in pairs: one
2561: insn has one of a pair of notes that points to a second insn, which has
2562: the inverse note pointing back to the first insn.
2563:
2564: @table @code
2565: @findex REG_RETVAL
2566: @item REG_RETVAL
2567: This insn copies the value of a multi-insn sequence (for example, a
2568: library call), and @var{op} is the first insn of the sequence (for a
2569: library call, the first insn that was generated to set up the arguments
2570: for the library call).
2571:
2572: Loop optimization uses this note to treat such a sequence as a single
2573: operation for code motion purposes and flow analysis uses this note to
2574: delete such sequences whose results are dead.
2575:
2576: A @code{REG_EQUAL} note will also usually be attached to this insn to
2577: provide the expression being computed by the sequence.
2578:
2579: @findex REG_LIBCALL
2580: @item REG_LIBCALL
2581: This is the inverse of @code{REG_RETVAL}: it is placed on the first
2582: insn of a multi-insn sequence, and it points to the last one.
2583:
2584: @findex REG_CC_SETTER
2585: @findex REG_CC_USER
2586: @item REG_CC_SETTER
2587: @itemx REG_CC_USER
2588: On machines that use @code{cc0}, the insns which set and use @code{cc0}
2589: set and use @code{cc0} are adjacent. However, when branch delay slot
2590: filling is done, this may no longer be true. In this case a
2591: @code{REG_CC_USER} note will be placed on the insn setting @code{cc0} to
2592: point to the insn using @code{cc0} and a @code{REG_CC_SETTER} note will
2593: be placed on the insn using @code{cc0} to point to the insn setting
2594: @code{cc0}.@refill
2595: @end table
2596:
2597: These values are only used in the @code{LOG_LINKS} field, and indicate
2598: the type of dependency that each link represents. Links which indicate
2599: a data dependence (a read after write dependence) do not use any code,
2600: they simply have mode @code{VOIDmode}, and are printed without any
2601: descriptive text.
2602:
2603: @table @code
2604: @findex REG_DEP_ANTI
2605: @item REG_DEP_ANTI
2606: This indicates an anti dependence (a write after read dependence).
2607:
2608: @findex REG_DEP_OUTPUT
2609: @item REG_DEP_OUTPUT
2610: This indicates an output dependence (a write after write dependence).
2611: @end table
2612:
2613: For convenience, the machine mode in an @code{insn_list} or
2614: @code{expr_list} is printed using these symbolic codes in debugging dumps.
2615:
2616: @findex insn_list
2617: @findex expr_list
2618: The only difference between the expression codes @code{insn_list} and
2619: @code{expr_list} is that the first operand of an @code{insn_list} is
2620: assumed to be an insn and is printed in debugging dumps as the insn's
2621: unique id; the first operand of an @code{expr_list} is printed in the
2622: ordinary way as an expression.
2623:
2624: @node Calls, Sharing, Insns, RTL
2625: @section RTL Representation of Function-Call Insns
2626: @cindex calling functions in RTL
2627: @cindex RTL function-call insns
2628: @cindex function-call insns
2629:
2630: Insns that call subroutines have the RTL expression code @code{call_insn}.
2631: These insns must satisfy special rules, and their bodies must use a special
2632: RTL expression code, @code{call}.
2633:
2634: @cindex @code{call} usage
2635: A @code{call} expression has two operands, as follows:
2636:
2637: @example
2638: (call (mem:@var{fm} @var{addr}) @var{nbytes})
2639: @end example
2640:
2641: @noindent
2642: Here @var{nbytes} is an operand that represents the number of bytes of
2643: argument data being passed to the subroutine, @var{fm} is a machine mode
2644: (which must equal as the definition of the @code{FUNCTION_MODE} macro in
2645: the machine description) and @var{addr} represents the address of the
2646: subroutine.
2647:
2648: For a subroutine that returns no value, the @code{call} expression as
2649: shown above is the entire body of the insn, except that the insn might
2650: also contain @code{use} or @code{clobber} expressions.
2651:
2652: @cindex @code{BLKmode}, and function return values
2653: For a subroutine that returns a value whose mode is not @code{BLKmode},
2654: the value is returned in a hard register. If this register's number is
2655: @var{r}, then the body of the call insn looks like this:
2656:
2657: @example
2658: (set (reg:@var{m} @var{r})
2659: (call (mem:@var{fm} @var{addr}) @var{nbytes}))
2660: @end example
2661:
2662: @noindent
2663: This RTL expression makes it clear (to the optimizer passes) that the
2664: appropriate register receives a useful value in this insn.
2665:
2666: When a subroutine returns a @code{BLKmode} value, it is handled by
2667: passing to the subroutine the address of a place to store the value.
2668: So the call insn itself does not ``return'' any value, and it has the
2669: same RTL form as a call that returns nothing.
2670:
2671: On some machines, the call instruction itself clobbers some register,
2672: for example to contain the return address. @code{call_insn} insns
2673: on these machines should have a body which is a @code{parallel}
2674: that contains both the @code{call} expression and @code{clobber}
2675: expressions that indicate which registers are destroyed. Similarly,
2676: if the call instruction requires some register other than the stack
2677: pointer that is not explicitly mentioned it its RTL, a @code{use}
2678: subexpression should mention that register.
2679:
2680: Functions that are called are assumed to modify all registers listed in
2681: the configuration macro @code{CALL_USED_REGISTERS} (@pxref{Register
2682: Basics}) and, with the exception of @code{const} functions and library
2683: calls, to modify all of memory.
2684:
2685: Insns containing just @code{use} expressions directly precede the
2686: @code{call_insn} insn to indicate which registers contain inputs to the
2687: function. Similarly, if registers other than those in
2688: @code{CALL_USED_REGISTERS} are clobbered by the called function, insns
2689: containing a single @code{clobber} follow immediately after the call to
2690: indicate which registers.
2691:
2692: @node Sharing
2693: @section Structure Sharing Assumptions
2694: @cindex sharing of RTL components
2695: @cindex RTL structure sharing assumptions
2696:
2697: The compiler assumes that certain kinds of RTL expressions are unique;
2698: there do not exist two distinct objects representing the same value.
2699: In other cases, it makes an opposite assumption: that no RTL expression
2700: object of a certain kind appears in more than one place in the
2701: containing structure.
2702:
2703: These assumptions refer to a single function; except for the RTL
2704: objects that describe global variables and external functions,
2705: and a few standard objects such as small integer constants,
2706: no RTL objects are common to two functions.
2707:
2708: @itemize @bullet
2709: @cindex @code{reg}, RTL sharing
2710: @item
2711: Each pseudo-register has only a single @code{reg} object to represent it,
2712: and therefore only a single machine mode.
2713:
2714: @cindex symbolic label
2715: @cindex @code{symbol_ref}, RTL sharing
2716: @item
2717: For any symbolic label, there is only one @code{symbol_ref} object
2718: referring to it.
2719:
2720: @cindex @code{const_int}, RTL sharing
2721: @item
2722: There is only one @code{const_int} expression with value 0, only
2723: one with value 1, and only one with value @minus{}1.
2724: Some other integer values are also stored uniquely.
2725:
2726: @cindex @code{pc}, RTL sharing
2727: @item
2728: There is only one @code{pc} expression.
2729:
2730: @cindex @code{cc0}, RTL sharing
2731: @item
2732: There is only one @code{cc0} expression.
2733:
2734: @cindex @code{const_double}, RTL sharing
2735: @item
2736: There is only one @code{const_double} expression with value 0 for
2737: each floating point mode. Likewise for values 1 and 2.
2738:
2739: @cindex @code{label_ref}, RTL sharing
2740: @cindex @code{scratch}, RTL sharing
2741: @item
2742: No @code{label_ref} or @code{scratch} appears in more than one place in
2743: the RTL structure; in other words, it is safe to do a tree-walk of all
2744: the insns in the function and assume that each time a @code{label_ref}
2745: or @code{scratch} is seen it is distinct from all others that are seen.
2746:
2747: @cindex @code{mem}, RTL sharing
2748: @item
2749: Only one @code{mem} object is normally created for each static
2750: variable or stack slot, so these objects are frequently shared in all
2751: the places they appear. However, separate but equal objects for these
2752: variables are occasionally made.
2753:
2754: @cindex @code{asm_operands}, RTL sharing
2755: @item
2756: When a single @code{asm} statement has multiple output operands, a
2757: distinct @code{asm_operands} expression is made for each output operand.
2758: However, these all share the vector which contains the sequence of input
2759: operands. This sharing is used later on to test whether two
2760: @code{asm_operands} expressions come from the same statement, so all
2761: optimizations must carefully preserve the sharing if they copy the
2762: vector at all.
2763:
2764: @item
2765: No RTL object appears in more than one place in the RTL structure
2766: except as described above. Many passes of the compiler rely on this
2767: by assuming that they can modify RTL objects in place without unwanted
2768: side-effects on other insns.
2769:
2770: @findex unshare_all_rtl
2771: @item
2772: During initial RTL generation, shared structure is freely introduced.
2773: After all the RTL for a function has been generated, all shared
2774: structure is copied by @code{unshare_all_rtl} in @file{emit-rtl.c},
2775: after which the above rules are guaranteed to be followed.
2776:
2777: @findex copy_rtx_if_shared
2778: @item
2779: During the combiner pass, shared structure within an insn can exist
2780: temporarily. However, the shared structure is copied before the
2781: combiner is finished with the insn. This is done by calling
2782: @code{copy_rtx_if_shared}, which is a subroutine of
2783: @code{unshare_all_rtl}.
2784: @end itemize
2785:
2786: @node Reading RTL
2787: @section Reading RTL
2788:
2789: To read an RTL object from a file, call @code{read_rtx}. It takes one
2790: argument, a stdio stream, and returns a single RTL object.
2791:
2792: Reading RTL from a file is very slow. This is no currently not a
2793: problem because reading RTL occurs only as part of building the
2794: compiler.
2795:
2796: People frequently have the idea of using RTL stored as text in a file as
2797: an interface between a language front end and the bulk of GNU CC. This
2798: idea is not feasible.
2799:
2800: GNU CC was designed to use RTL internally only. Correct RTL for a given
2801: program is very dependent on the particular target machine. And the RTL
2802: does not contain all the information about the program.
2803:
2804: The proper way to interface GNU CC to a new language front end is with
2805: the ``tree'' data structure. There is no manual for this data
2806: structure, but it is described in the files @file{tree.h} and
2807: @file{tree.def}.
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.