| 1 | /* frags.h - Header file for the frag concept. | 
|---|
| 2 | Copyright 1987, 1992, 1993, 1994, 1995, 1997, 1998, 1999, 2000, 2001 | 
|---|
| 3 | Free Software Foundation, Inc. | 
|---|
| 4 |  | 
|---|
| 5 | This file is part of GAS, the GNU Assembler. | 
|---|
| 6 |  | 
|---|
| 7 | GAS is free software; you can redistribute it and/or modify | 
|---|
| 8 | it under the terms of the GNU General Public License as published by | 
|---|
| 9 | the Free Software Foundation; either version 2, or (at your option) | 
|---|
| 10 | any later version. | 
|---|
| 11 |  | 
|---|
| 12 | GAS is distributed in the hope that it will be useful, | 
|---|
| 13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 15 | GNU General Public License for more details. | 
|---|
| 16 |  | 
|---|
| 17 | You should have received a copy of the GNU General Public License | 
|---|
| 18 | along with GAS; see the file COPYING.  If not, write to the Free | 
|---|
| 19 | Software Foundation, 59 Temple Place - Suite 330, Boston, MA | 
|---|
| 20 | 02111-1307, USA.  */ | 
|---|
| 21 |  | 
|---|
| 22 | #ifndef FRAGS_H | 
|---|
| 23 | #define FRAGS_H | 
|---|
| 24 |  | 
|---|
| 25 | #ifdef ANSI_PROTOTYPES | 
|---|
| 26 | struct obstack; | 
|---|
| 27 | #endif | 
|---|
| 28 |  | 
|---|
| 29 | /* A code fragment (frag) is some known number of chars, followed by some | 
|---|
| 30 | unknown number of chars. Typically the unknown number of chars is an | 
|---|
| 31 | instruction address whose size is yet unknown. We always know the greatest | 
|---|
| 32 | possible size the unknown number of chars may become, and reserve that | 
|---|
| 33 | much room at the end of the frag. | 
|---|
| 34 | Once created, frags do not change address during assembly. | 
|---|
| 35 | We chain the frags in (a) forward-linked list(s). The object-file address | 
|---|
| 36 | of the 1st char of a frag is generally not known until after relax(). | 
|---|
| 37 | Many things at assembly time describe an address by {object-file-address | 
|---|
| 38 | of a particular frag}+offset. | 
|---|
| 39 |  | 
|---|
| 40 | BUG: it may be smarter to have a single pointer off to various different | 
|---|
| 41 | notes for different frag kinds.  See how code pans.  */ | 
|---|
| 42 |  | 
|---|
| 43 | struct frag { | 
|---|
| 44 | /* Object file address (as an octet offset).  */ | 
|---|
| 45 | addressT fr_address; | 
|---|
| 46 | /* When relaxing multiple times, remember the address the frag had | 
|---|
| 47 | in the last relax pass.  */ | 
|---|
| 48 | addressT last_fr_address; | 
|---|
| 49 |  | 
|---|
| 50 | /* (Fixed) number of octets we know we have.  May be 0.  */ | 
|---|
| 51 | offsetT fr_fix; | 
|---|
| 52 | /* May be used for (Variable) number of octets after above. | 
|---|
| 53 | The generic frag handling code no longer makes any use of fr_var.  */ | 
|---|
| 54 | offsetT fr_var; | 
|---|
| 55 | /* For variable-length tail.  */ | 
|---|
| 56 | offsetT fr_offset; | 
|---|
| 57 | /* For variable-length tail.  */ | 
|---|
| 58 | symbolS *fr_symbol; | 
|---|
| 59 | /* Points to opcode low addr byte, for relaxation.  */ | 
|---|
| 60 | char *fr_opcode; | 
|---|
| 61 |  | 
|---|
| 62 | /* Chain forward; ascending address order.  Rooted in frch_root.  */ | 
|---|
| 63 | struct frag *fr_next; | 
|---|
| 64 |  | 
|---|
| 65 | /* Where the frag was created, or where it became a variant frag.  */ | 
|---|
| 66 | char *fr_file; | 
|---|
| 67 | unsigned int fr_line; | 
|---|
| 68 |  | 
|---|
| 69 | #ifndef NO_LISTING | 
|---|
| 70 | struct list_info_struct *line; | 
|---|
| 71 | #endif | 
|---|
| 72 |  | 
|---|
| 73 | /* Flipped each relax pass so we can easily determine whether | 
|---|
| 74 | fr_address has been adjusted.  */ | 
|---|
| 75 | unsigned int relax_marker:1; | 
|---|
| 76 |  | 
|---|
| 77 | /* What state is my tail in? */ | 
|---|
| 78 | relax_stateT fr_type; | 
|---|
| 79 | relax_substateT fr_subtype; | 
|---|
| 80 |  | 
|---|
| 81 | #ifdef USING_CGEN | 
|---|
| 82 | /* Don't include this unless using CGEN to keep frag size down.  */ | 
|---|
| 83 | struct { | 
|---|
| 84 | /* CGEN_INSN entry for this instruction.  */ | 
|---|
| 85 | const struct cgen_insn *insn; | 
|---|
| 86 | /* Index into operand table.  */ | 
|---|
| 87 | int opindex; | 
|---|
| 88 | /* Target specific data, usually reloc number.  */ | 
|---|
| 89 | int opinfo; | 
|---|
| 90 | } fr_cgen; | 
|---|
| 91 | #endif | 
|---|
| 92 |  | 
|---|
| 93 | #ifdef TC_FRAG_TYPE | 
|---|
| 94 | TC_FRAG_TYPE tc_frag_data; | 
|---|
| 95 | #endif | 
|---|
| 96 |  | 
|---|
| 97 | /* Data begins here.  */ | 
|---|
| 98 | char fr_literal[1]; | 
|---|
| 99 | }; | 
|---|
| 100 |  | 
|---|
| 101 | #define SIZEOF_STRUCT_FRAG \ | 
|---|
| 102 | ((char *) zero_address_frag.fr_literal - (char *) &zero_address_frag) | 
|---|
| 103 | /* We want to say fr_literal[0] above.  */ | 
|---|
| 104 |  | 
|---|
| 105 | /* Current frag we are building.  This frag is incomplete.  It is, | 
|---|
| 106 | however, included in frchain_now.  The fr_fix field is bogus; | 
|---|
| 107 | instead, use frag_now_fix ().  */ | 
|---|
| 108 | COMMON fragS *frag_now; | 
|---|
| 109 | extern addressT frag_now_fix PARAMS ((void)); | 
|---|
| 110 | extern addressT frag_now_fix_octets PARAMS ((void)); | 
|---|
| 111 |  | 
|---|
| 112 | /* For foreign-segment symbol fixups.  */ | 
|---|
| 113 | COMMON fragS zero_address_frag; | 
|---|
| 114 | /* For local common (N_BSS segment) fixups.  */ | 
|---|
| 115 | COMMON fragS bss_address_frag; | 
|---|
| 116 |  | 
|---|
| 117 | #if 0 | 
|---|
| 118 | /* A macro to speed up appending exactly 1 char to current frag.  */ | 
|---|
| 119 | /* JF changed < 1 to <= 1 to avoid a race conditon.  */ | 
|---|
| 120 | #define FRAG_APPEND_1_CHAR(datum)                       \ | 
|---|
| 121 | {                                                       \ | 
|---|
| 122 | if (obstack_room (&frags) <= 1)                       \ | 
|---|
| 123 | {                                                   \ | 
|---|
| 124 | frag_wane (frag_now);                             \ | 
|---|
| 125 | frag_new (0);                                     \ | 
|---|
| 126 | }                                                   \ | 
|---|
| 127 | obstack_1grow (&frags, datum);                        \ | 
|---|
| 128 | } | 
|---|
| 129 | #else | 
|---|
| 130 | extern void frag_append_1_char PARAMS ((int)); | 
|---|
| 131 | #define FRAG_APPEND_1_CHAR(X) frag_append_1_char (X) | 
|---|
| 132 | #endif | 
|---|
| 133 |  | 
|---|
| 134 | void frag_init PARAMS ((void)); | 
|---|
| 135 | fragS *frag_alloc PARAMS ((struct obstack *)); | 
|---|
| 136 | void frag_grow PARAMS ((unsigned int nchars)); | 
|---|
| 137 | char *frag_more PARAMS ((int nchars)); | 
|---|
| 138 | void frag_align PARAMS ((int alignment, int fill_character, int max)); | 
|---|
| 139 | void frag_align_pattern PARAMS ((int alignment, | 
|---|
| 140 | const char *fill_pattern, | 
|---|
| 141 | int n_fill, | 
|---|
| 142 | int max)); | 
|---|
| 143 | void frag_align_code PARAMS ((int alignment, int max)); | 
|---|
| 144 | void frag_new PARAMS ((int old_frags_var_max_size)); | 
|---|
| 145 | void frag_wane PARAMS ((fragS * fragP)); | 
|---|
| 146 |  | 
|---|
| 147 | char *frag_variant PARAMS ((relax_stateT type, | 
|---|
| 148 | int max_chars, | 
|---|
| 149 | int var, | 
|---|
| 150 | relax_substateT subtype, | 
|---|
| 151 | symbolS * symbol, | 
|---|
| 152 | offsetT offset, | 
|---|
| 153 | char *opcode)); | 
|---|
| 154 |  | 
|---|
| 155 | char *frag_var PARAMS ((relax_stateT type, | 
|---|
| 156 | int max_chars, | 
|---|
| 157 | int var, | 
|---|
| 158 | relax_substateT subtype, | 
|---|
| 159 | symbolS * symbol, | 
|---|
| 160 | offsetT offset, | 
|---|
| 161 | char *opcode)); | 
|---|
| 162 |  | 
|---|
| 163 | #endif /* FRAGS_H */ | 
|---|