]> Git Repo - binutils.git/blob - gas/expr.h
Add support for COFF secidx relocations
[binutils.git] / gas / expr.h
1 /* expr.h -> header file for expr.c
2    Copyright (C) 1987-2022 Free Software Foundation, Inc.
3
4    This file is part of GAS, the GNU Assembler.
5
6    GAS is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3, or (at your option)
9    any later version.
10
11    GAS is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with GAS; see the file COPYING.  If not, write to the Free
18    Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
19    02110-1301, USA.  */
20
21 /* By popular demand, we define a struct to represent an expression.
22    This will no doubt mutate as expressions become baroque.
23
24    Currently, we support expressions like "foo OP bar + 42".  In other
25    words we permit a (possibly undefined) symbol, a (possibly
26    undefined) symbol and the operation used to combine the symbols,
27    and an (absolute) augend.  RMS says this is so we can have 1-pass
28    assembly for any compiler emissions, and a 'case' statement might
29    emit 'undefined1 - undefined2'.
30
31    The type of an expression used to be stored as a segment.  That got
32    confusing because it overloaded the concept of a segment.  I added
33    an operator field, instead.  */
34
35 /* This is the type of an expression.  The operator types are also
36    used while parsing an expression.
37
38    NOTE: This enumeration must match the op_rank array in expr.c.  */
39
40 typedef enum
41 {
42   /* An illegal expression.  */
43   O_illegal,
44   /* A nonexistent expression.  */
45   O_absent,
46   /* X_add_number (a constant expression).  */
47   O_constant,
48   /* X_add_symbol + X_add_number.  */
49   O_symbol,
50   /* X_add_symbol + X_add_number - the base address of the image.  */
51   O_symbol_rva,
52   /* The section index of X_add_symbol.  */
53   O_secidx,
54   /* A register (X_add_number is register number).  */
55   O_register,
56   /* A big value.  If X_add_number is negative or 0, the value is in
57      generic_floating_point_number.  Otherwise the value is in
58      generic_bignum, and X_add_number is the number of LITTLENUMs in
59      the value.  */
60   O_big,
61   /* (- X_add_symbol) + X_add_number.  */
62   O_uminus,
63   /* (~ X_add_symbol) + X_add_number.  */
64   O_bit_not,
65   /* (! X_add_symbol) + X_add_number.  */
66   O_logical_not,
67   /* (X_add_symbol * X_op_symbol) + X_add_number.  */
68   O_multiply,
69   /* (X_add_symbol / X_op_symbol) + X_add_number.  */
70   O_divide,
71   /* (X_add_symbol % X_op_symbol) + X_add_number.  */
72   O_modulus,
73   /* (X_add_symbol << X_op_symbol) + X_add_number.  */
74   O_left_shift,
75   /* (X_add_symbol >> X_op_symbol) + X_add_number.  */
76   O_right_shift,
77   /* (X_add_symbol | X_op_symbol) + X_add_number.  */
78   O_bit_inclusive_or,
79   /* (X_add_symbol |~ X_op_symbol) + X_add_number.  */
80   O_bit_or_not,
81   /* (X_add_symbol ^ X_op_symbol) + X_add_number.  */
82   O_bit_exclusive_or,
83   /* (X_add_symbol & X_op_symbol) + X_add_number.  */
84   O_bit_and,
85   /* (X_add_symbol + X_op_symbol) + X_add_number.  */
86   O_add,
87   /* (X_add_symbol - X_op_symbol) + X_add_number.  */
88   O_subtract,
89   /* (X_add_symbol == X_op_symbol) + X_add_number.  */
90   O_eq,
91   /* (X_add_symbol != X_op_symbol) + X_add_number.  */
92   O_ne,
93   /* (X_add_symbol < X_op_symbol) + X_add_number.  */
94   O_lt,
95   /* (X_add_symbol <= X_op_symbol) + X_add_number.  */
96   O_le,
97   /* (X_add_symbol >= X_op_symbol) + X_add_number.  */
98   O_ge,
99   /* (X_add_symbol > X_op_symbol) + X_add_number.  */
100   O_gt,
101   /* (X_add_symbol && X_op_symbol) + X_add_number.  */
102   O_logical_and,
103   /* (X_add_symbol || X_op_symbol) + X_add_number.  */
104   O_logical_or,
105   /* X_op_symbol [ X_add_symbol ] */
106   O_index,
107   /* machine dependent operators */
108   O_md1,  O_md2,  O_md3,  O_md4,  O_md5,  O_md6,  O_md7,  O_md8,
109   O_md9,  O_md10, O_md11, O_md12, O_md13, O_md14, O_md15, O_md16,
110   O_md17, O_md18, O_md19, O_md20, O_md21, O_md22, O_md23, O_md24,
111   O_md25, O_md26, O_md27, O_md28, O_md29, O_md30, O_md31, O_md32,
112   /* this must be the largest value */
113   O_max
114 } operatorT;
115
116 typedef struct expressionS
117 {
118   /* The main symbol.  */
119   symbolS *X_add_symbol;
120   /* The second symbol, if needed.  */
121   symbolS *X_op_symbol;
122   /* A number to add.  */
123   offsetT X_add_number;
124
125   /* The type of the expression.  We can't assume that an arbitrary
126      compiler can handle a bitfield of enum type.  FIXME: We could
127      check this using autoconf.  */
128 #ifdef __GNUC__
129   operatorT X_op : 8;
130 #else
131   unsigned char X_op;
132 #endif
133
134   /* Non-zero if X_add_number should be regarded as unsigned.  This is
135      only valid for O_constant expressions.  It is only used when an
136      O_constant must be extended into a bignum (i.e., it is not used
137      when performing arithmetic on these values).
138      FIXME: This field is not set very reliably.  */
139   unsigned int X_unsigned : 1;
140   /* This is used to implement "word size + 1 bit" arithmetic, so that e.g.
141      expressions used with .sleb128 directives can use the full range available
142      for an unsigned word, but can also properly represent all values of a
143      signed word.  */
144   unsigned int X_extrabit : 1;
145
146   /* 7 additional bits can be defined if needed.  */
147
148   /* Machine dependent field */
149   unsigned short X_md;
150 } expressionS;
151
152 enum expr_mode
153 {
154   expr_evaluate,
155   expr_normal,
156   expr_defer
157 };
158
159 /* "result" should be type (expressionS *).  */
160 #define expression(result) expr (0, result, expr_normal)
161 #define expression_and_evaluate(result) expr (0, result, expr_evaluate)
162 #define deferred_expression(result) expr (0, result, expr_defer)
163
164 /* If an expression is O_big, look here for its value. These common
165    data may be clobbered whenever expr() is called.  */
166 /* Flonums returned here.  Big enough to hold most precise flonum.  */
167 extern FLONUM_TYPE generic_floating_point_number;
168 /* Bignums returned here.  */
169 extern LITTLENUM_TYPE generic_bignum[];
170 /* Number of littlenums in above.  */
171 #define SIZE_OF_LARGE_NUMBER (20)
172
173 typedef char operator_rankT;
174
175 extern char get_symbol_name (char **);
176 extern char restore_line_pointer (char);
177 extern void expr_begin (void);
178 extern void expr_set_precedence (void);
179 extern void expr_set_rank (operatorT, operator_rankT);
180 extern void add_to_result (expressionS *, offsetT, int);
181 extern void subtract_from_result (expressionS *, offsetT, int);
182 extern segT expr (int, expressionS *, enum expr_mode);
183 extern unsigned int get_single_number (void);
184 extern symbolS *make_expr_symbol (expressionS * expressionP);
185 extern int expr_symbol_where (symbolS *, const char **, unsigned int *);
186 extern void current_location (expressionS *);
187 extern symbolS *expr_build_uconstant (offsetT);
188 extern symbolS *expr_build_dot (void);
189 extern uint32_t generic_bignum_to_int32 (void);
190 extern uint64_t generic_bignum_to_int64 (void);
191 extern int resolve_expression (expressionS *);
192
193 extern bool literal_prefix_dollar_hex;
This page took 0.034375 seconds and 4 git commands to generate.