Home | History | Annotate | Line # | Download | only in gas
as.c revision 1.1.1.8
      1      1.1     skrll /* as.c - GAS main program.
      2  1.1.1.8  christos    Copyright (C) 1987-2020 Free Software Foundation, Inc.
      3      1.1     skrll 
      4      1.1     skrll    This file is part of GAS, the GNU Assembler.
      5      1.1     skrll 
      6      1.1     skrll    GAS is free software; you can redistribute it and/or modify
      7      1.1     skrll    it under the terms of the GNU General Public License as published by
      8      1.1     skrll    the Free Software Foundation; either version 3, or (at your option)
      9      1.1     skrll    any later version.
     10      1.1     skrll 
     11      1.1     skrll    GAS is distributed in the hope that it will be useful, but WITHOUT
     12      1.1     skrll    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
     13      1.1     skrll    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
     14      1.1     skrll    License for more details.
     15      1.1     skrll 
     16      1.1     skrll    You should have received a copy of the GNU General Public License
     17      1.1     skrll    along with GAS; see the file COPYING.  If not, write to the Free
     18      1.1     skrll    Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
     19      1.1     skrll    02110-1301, USA.  */
     20      1.1     skrll 
     21      1.1     skrll /* Main program for AS; a 32-bit assembler of GNU.
     22      1.1     skrll    Understands command arguments.
     23      1.1     skrll    Has a few routines that don't fit in other modules because they
     24      1.1     skrll    are shared.
     25  1.1.1.4  christos 
     26      1.1     skrll   			bugs
     27  1.1.1.4  christos 
     28      1.1     skrll    : initialisers
     29      1.1     skrll   	Since no-one else says they will support them in future: I
     30      1.1     skrll    don't support them now.  */
     31      1.1     skrll 
     32      1.1     skrll #define COMMON
     33      1.1     skrll 
     34  1.1.1.6  christos /* Disable code to set FAKE_LABEL_NAME in obj-multi.h, to avoid circular
     35  1.1.1.6  christos    reference.  */
     36  1.1.1.6  christos #define INITIALIZING_EMULS
     37  1.1.1.6  christos 
     38      1.1     skrll #include "as.h"
     39      1.1     skrll #include "subsegs.h"
     40      1.1     skrll #include "output-file.h"
     41      1.1     skrll #include "sb.h"
     42      1.1     skrll #include "macro.h"
     43      1.1     skrll #include "dwarf2dbg.h"
     44      1.1     skrll #include "dw2gencfi.h"
     45      1.1     skrll #include "bfdver.h"
     46  1.1.1.6  christos #include "write.h"
     47      1.1     skrll 
     48      1.1     skrll #ifdef HAVE_ITBL_CPU
     49      1.1     skrll #include "itbl-ops.h"
     50      1.1     skrll #else
     51      1.1     skrll #define itbl_init()
     52      1.1     skrll #endif
     53      1.1     skrll 
     54      1.1     skrll #ifdef USING_CGEN
     55      1.1     skrll /* Perform any cgen specific initialisation for gas.  */
     56      1.1     skrll extern void gas_cgen_begin (void);
     57      1.1     skrll #endif
     58      1.1     skrll 
     59      1.1     skrll /* We build a list of defsyms as we read the options, and then define
     60      1.1     skrll    them after we have initialized everything.  */
     61      1.1     skrll struct defsym_list
     62      1.1     skrll {
     63      1.1     skrll   struct defsym_list *next;
     64      1.1     skrll   char *name;
     65      1.1     skrll   valueT value;
     66      1.1     skrll };
     67      1.1     skrll 
     68      1.1     skrll 
     69      1.1     skrll /* True if a listing is wanted.  */
     70      1.1     skrll int listing;
     71      1.1     skrll 
     72      1.1     skrll /* Type of debugging to generate.  */
     73      1.1     skrll enum debug_info_type debug_type = DEBUG_UNSPECIFIED;
     74      1.1     skrll int use_gnu_debug_info_extensions = 0;
     75      1.1     skrll 
     76      1.1     skrll #ifndef MD_DEBUG_FORMAT_SELECTOR
     77      1.1     skrll #define MD_DEBUG_FORMAT_SELECTOR NULL
     78      1.1     skrll #endif
     79      1.1     skrll static enum debug_info_type (*md_debug_format_selector) (int *) = MD_DEBUG_FORMAT_SELECTOR;
     80      1.1     skrll 
     81      1.1     skrll /* Maximum level of macro nesting.  */
     82      1.1     skrll int max_macro_nest = 100;
     83      1.1     skrll 
     84      1.1     skrll /* argv[0]  */
     85      1.1     skrll static char * myname;
     86      1.1     skrll 
     87      1.1     skrll /* The default obstack chunk size.  If we set this to zero, the
     88      1.1     skrll    obstack code will use whatever will fit in a 4096 byte block.  */
     89      1.1     skrll int chunksize = 0;
     90      1.1     skrll 
     91      1.1     skrll /* To monitor memory allocation more effectively, make this non-zero.
     92      1.1     skrll    Then the chunk sizes for gas and bfd will be reduced.  */
     93      1.1     skrll int debug_memory = 0;
     94      1.1     skrll 
     95      1.1     skrll /* Enable verbose mode.  */
     96      1.1     skrll int verbose = 0;
     97      1.1     skrll 
     98  1.1.1.8  christos /* Which version of DWARF CIE to produce.  This default value of -1
     99  1.1.1.8  christos    indicates that this value has not been set yet, a default value is
    100  1.1.1.8  christos    provided in dwarf2_init.  A different value can also be supplied by the
    101  1.1.1.8  christos    command line flag --gdwarf-cie-version, or by a target in
    102  1.1.1.8  christos    MD_AFTER_PARSE_ARGS.  */
    103  1.1.1.8  christos int flag_dwarf_cie_version = -1;
    104  1.1.1.8  christos 
    105  1.1.1.5  christos #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
    106  1.1.1.5  christos int flag_use_elf_stt_common = DEFAULT_GENERATE_ELF_STT_COMMON;
    107  1.1.1.7  christos bfd_boolean flag_generate_build_notes = DEFAULT_GENERATE_BUILD_NOTES;
    108  1.1.1.5  christos #endif
    109  1.1.1.5  christos 
    110  1.1.1.2  christos /* Keep the output file.  */
    111  1.1.1.4  christos static int keep_it = 0;
    112  1.1.1.2  christos 
    113      1.1     skrll segT reg_section;
    114      1.1     skrll segT expr_section;
    115      1.1     skrll segT text_section;
    116      1.1     skrll segT data_section;
    117      1.1     skrll segT bss_section;
    118      1.1     skrll 
    119      1.1     skrll /* Name of listing file.  */
    120      1.1     skrll static char *listing_filename = NULL;
    121      1.1     skrll 
    122      1.1     skrll static struct defsym_list *defsyms;
    123      1.1     skrll 
    124      1.1     skrll #ifdef HAVE_ITBL_CPU
    125      1.1     skrll /* Keep a record of the itbl files we read in.  */
    126      1.1     skrll struct itbl_file_list
    127      1.1     skrll {
    128      1.1     skrll   struct itbl_file_list *next;
    129      1.1     skrll   char *name;
    130      1.1     skrll };
    131      1.1     skrll static struct itbl_file_list *itbl_files;
    132      1.1     skrll #endif
    133      1.1     skrll 
    134      1.1     skrll static long start_time;
    135      1.1     skrll 
    136      1.1     skrll static int flag_macro_alternate;
    137      1.1     skrll 
    138      1.1     skrll 
    139      1.1     skrll #ifdef USE_EMULATIONS
    141      1.1     skrll #define EMULATION_ENVIRON "AS_EMULATION"
    142      1.1     skrll 
    143      1.1     skrll extern struct emulation mipsbelf, mipslelf, mipself;
    144      1.1     skrll extern struct emulation i386coff, i386elf, i386aout;
    145      1.1     skrll extern struct emulation crisaout, criself;
    146      1.1     skrll 
    147      1.1     skrll static struct emulation *const emulations[] = { EMULATIONS };
    148      1.1     skrll static const int n_emulations = sizeof (emulations) / sizeof (emulations[0]);
    149      1.1     skrll 
    150      1.1     skrll static void
    151      1.1     skrll select_emulation_mode (int argc, char **argv)
    152      1.1     skrll {
    153  1.1.1.5  christos   int i;
    154  1.1.1.5  christos   char *p;
    155      1.1     skrll   const char *em = NULL;
    156      1.1     skrll 
    157      1.1     skrll   for (i = 1; i < argc; i++)
    158      1.1     skrll     if (!strncmp ("--em", argv[i], 4))
    159      1.1     skrll       break;
    160      1.1     skrll 
    161      1.1     skrll   if (i == argc)
    162      1.1     skrll     goto do_default;
    163      1.1     skrll 
    164      1.1     skrll   p = strchr (argv[i], '=');
    165      1.1     skrll   if (p)
    166      1.1     skrll     p++;
    167      1.1     skrll   else
    168      1.1     skrll     p = argv[i + 1];
    169      1.1     skrll 
    170      1.1     skrll   if (!p || !*p)
    171      1.1     skrll     as_fatal (_("missing emulation mode name"));
    172      1.1     skrll   em = p;
    173      1.1     skrll 
    174      1.1     skrll  do_default:
    175      1.1     skrll   if (em == 0)
    176      1.1     skrll     em = getenv (EMULATION_ENVIRON);
    177      1.1     skrll   if (em == 0)
    178      1.1     skrll     em = DEFAULT_EMULATION;
    179      1.1     skrll 
    180      1.1     skrll   if (em)
    181      1.1     skrll     {
    182      1.1     skrll       for (i = 0; i < n_emulations; i++)
    183      1.1     skrll 	if (!strcmp (emulations[i]->name, em))
    184      1.1     skrll 	  break;
    185      1.1     skrll       if (i == n_emulations)
    186      1.1     skrll 	as_fatal (_("unrecognized emulation name `%s'"), em);
    187      1.1     skrll       this_emulation = emulations[i];
    188      1.1     skrll     }
    189      1.1     skrll   else
    190      1.1     skrll     this_emulation = emulations[0];
    191      1.1     skrll 
    192      1.1     skrll   this_emulation->init ();
    193      1.1     skrll }
    194      1.1     skrll 
    195      1.1     skrll const char *
    196      1.1     skrll default_emul_bfd_name (void)
    197      1.1     skrll {
    198      1.1     skrll   abort ();
    199      1.1     skrll   return NULL;
    200      1.1     skrll }
    201      1.1     skrll 
    202      1.1     skrll void
    203      1.1     skrll common_emul_init (void)
    204      1.1     skrll {
    205      1.1     skrll   this_format = this_emulation->format;
    206      1.1     skrll 
    207      1.1     skrll   if (this_emulation->leading_underscore == 2)
    208      1.1     skrll     this_emulation->leading_underscore = this_format->dfl_leading_underscore;
    209      1.1     skrll 
    210      1.1     skrll   if (this_emulation->default_endian != 2)
    211      1.1     skrll     target_big_endian = this_emulation->default_endian;
    212      1.1     skrll 
    213      1.1     skrll   if (this_emulation->fake_label_name == 0)
    214      1.1     skrll     {
    215  1.1.1.6  christos       if (this_emulation->leading_underscore)
    216      1.1     skrll 	this_emulation->fake_label_name = FAKE_LABEL_NAME;
    217      1.1     skrll       else
    218  1.1.1.6  christos 	/* What other parameters should we test?  */
    219      1.1     skrll 	this_emulation->fake_label_name = "." FAKE_LABEL_NAME;
    220      1.1     skrll     }
    221      1.1     skrll }
    222      1.1     skrll #endif
    223      1.1     skrll 
    224      1.1     skrll void
    225      1.1     skrll print_version_id (void)
    226      1.1     skrll {
    227      1.1     skrll   static int printed;
    228      1.1     skrll 
    229      1.1     skrll   if (printed)
    230      1.1     skrll     return;
    231      1.1     skrll   printed = 1;
    232      1.1     skrll 
    233      1.1     skrll   fprintf (stderr, _("GNU assembler version %s (%s) using BFD version %s\n"),
    234      1.1     skrll 	   VERSION, TARGET_ALIAS, BFD_VERSION_STRING);
    235      1.1     skrll }
    236  1.1.1.4  christos 
    237  1.1.1.4  christos #ifdef DEFAULT_FLAG_COMPRESS_DEBUG
    238  1.1.1.4  christos enum compressed_debug_section_type flag_compress_debug
    239  1.1.1.4  christos   = COMPRESS_DEBUG_GABI_ZLIB;
    240  1.1.1.4  christos #endif
    241      1.1     skrll 
    242      1.1     skrll static void
    243      1.1     skrll show_usage (FILE * stream)
    244      1.1     skrll {
    245      1.1     skrll   fprintf (stream, _("Usage: %s [option...] [asmfile...]\n"), myname);
    246      1.1     skrll 
    247      1.1     skrll   fprintf (stream, _("\
    248      1.1     skrll Options:\n\
    249      1.1     skrll   -a[sub-option...]	  turn on listings\n\
    250      1.1     skrll                       	  Sub-options [default hls]:\n\
    251      1.1     skrll                       	  c      omit false conditionals\n\
    252      1.1     skrll                       	  d      omit debugging directives\n\
    253      1.1     skrll                       	  g      include general info\n\
    254      1.1     skrll                       	  h      include high-level source\n\
    255      1.1     skrll                       	  l      include assembly\n\
    256      1.1     skrll                       	  m      include macro expansions\n\
    257      1.1     skrll                       	  n      omit forms processing\n\
    258      1.1     skrll                       	  s      include symbols\n\
    259      1.1     skrll                       	  =FILE  list to FILE (must be last sub-option)\n"));
    260      1.1     skrll 
    261      1.1     skrll   fprintf (stream, _("\
    262  1.1.1.4  christos   --alternate             initially turn on alternate macro syntax\n"));
    263  1.1.1.2  christos #ifdef DEFAULT_FLAG_COMPRESS_DEBUG
    264  1.1.1.4  christos   fprintf (stream, _("\
    265  1.1.1.4  christos   --compress-debug-sections[={none|zlib|zlib-gnu|zlib-gabi}]\n\
    266  1.1.1.2  christos                           compress DWARF debug sections using zlib [default]\n"));
    267  1.1.1.2  christos   fprintf (stream, _("\
    268  1.1.1.2  christos   --nocompress-debug-sections\n\
    269  1.1.1.4  christos                           don't compress DWARF debug sections\n"));
    270  1.1.1.4  christos #else
    271  1.1.1.4  christos   fprintf (stream, _("\
    272  1.1.1.4  christos   --compress-debug-sections[={none|zlib|zlib-gnu|zlib-gabi}]\n\
    273  1.1.1.4  christos                           compress DWARF debug sections using zlib\n"));
    274  1.1.1.4  christos   fprintf (stream, _("\
    275  1.1.1.4  christos   --nocompress-debug-sections\n\
    276  1.1.1.4  christos                           don't compress DWARF debug sections [default]\n"));
    277      1.1     skrll #endif
    278      1.1     skrll   fprintf (stream, _("\
    279      1.1     skrll   -D                      produce assembler debugging messages\n"));
    280  1.1.1.2  christos   fprintf (stream, _("\
    281  1.1.1.2  christos   --debug-prefix-map OLD=NEW\n\
    282      1.1     skrll                           map OLD to NEW in debug information\n"));
    283      1.1     skrll   fprintf (stream, _("\
    284      1.1     skrll   --defsym SYM=VAL        define symbol SYM to given value\n"));
    285      1.1     skrll #ifdef USE_EMULATIONS
    286      1.1     skrll   {
    287  1.1.1.5  christos     int i;
    288      1.1     skrll     const char *def_em;
    289      1.1     skrll 
    290      1.1     skrll     fprintf (stream, "\
    291      1.1     skrll   --em=[");
    292      1.1     skrll     for (i = 0; i < n_emulations - 1; i++)
    293      1.1     skrll       fprintf (stream, "%s | ", emulations[i]->name);
    294      1.1     skrll     fprintf (stream, "%s]\n", emulations[i]->name);
    295      1.1     skrll 
    296      1.1     skrll     def_em = getenv (EMULATION_ENVIRON);
    297      1.1     skrll     if (!def_em)
    298      1.1     skrll       def_em = DEFAULT_EMULATION;
    299      1.1     skrll     fprintf (stream, _("\
    300      1.1     skrll                           emulate output (default %s)\n"), def_em);
    301      1.1     skrll   }
    302      1.1     skrll #endif
    303      1.1     skrll #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
    304      1.1     skrll   fprintf (stream, _("\
    305      1.1     skrll   --execstack             require executable stack for this object\n"));
    306      1.1     skrll   fprintf (stream, _("\
    307  1.1.1.2  christos   --noexecstack           don't require executable stack for this object\n"));
    308  1.1.1.2  christos   fprintf (stream, _("\
    309  1.1.1.2  christos   --size-check=[error|warning]\n\
    310  1.1.1.4  christos 			  ELF .size directive check (default --size-check=error)\n"));
    311  1.1.1.8  christos   fprintf (stream, _("\
    312  1.1.1.8  christos   --elf-stt-common=[no|yes] "));
    313  1.1.1.8  christos   if (DEFAULT_GENERATE_ELF_STT_COMMON)
    314  1.1.1.8  christos     fprintf (stream, _("(default: yes)\n"));
    315  1.1.1.8  christos   else
    316  1.1.1.8  christos     fprintf (stream, _("(default: no)\n"));
    317  1.1.1.5  christos   fprintf (stream, _("\
    318  1.1.1.5  christos                           generate ELF common symbols with STT_COMMON type\n"));
    319  1.1.1.4  christos   fprintf (stream, _("\
    320  1.1.1.7  christos   --sectname-subst        enable section name substitution sequences\n"));
    321  1.1.1.7  christos 
    322  1.1.1.7  christos   fprintf (stream, _("\
    323  1.1.1.7  christos   --generate-missing-build-notes=[no|yes] "));
    324  1.1.1.7  christos #if DEFAULT_GENERATE_BUILD_NOTES
    325  1.1.1.7  christos   fprintf (stream, _("(default: yes)\n"));
    326  1.1.1.7  christos #else
    327      1.1     skrll   fprintf (stream, _("(default: no)\n"));
    328      1.1     skrll #endif
    329  1.1.1.7  christos   fprintf (stream, _("\
    330  1.1.1.7  christos                           generate GNU Build notes if none are present in the input\n"));
    331  1.1.1.7  christos #endif /* OBJ_ELF */
    332  1.1.1.7  christos 
    333      1.1     skrll   fprintf (stream, _("\
    334      1.1     skrll   -f                      skip whitespace and comment preprocessing\n"));
    335      1.1     skrll   fprintf (stream, _("\
    336      1.1     skrll   -g --gen-debug          generate debugging information\n"));
    337      1.1     skrll   fprintf (stream, _("\
    338      1.1     skrll   --gstabs                generate STABS debugging information\n"));
    339      1.1     skrll   fprintf (stream, _("\
    340      1.1     skrll   --gstabs+               generate STABS debug info with GNU extensions\n"));
    341      1.1     skrll   fprintf (stream, _("\
    342      1.1     skrll   --gdwarf-2              generate DWARF2 debugging information\n"));
    343  1.1.1.4  christos   fprintf (stream, _("\
    344  1.1.1.4  christos   --gdwarf-sections       generate per-function section names for DWARF line information\n"));
    345      1.1     skrll   fprintf (stream, _("\
    346      1.1     skrll   --hash-size=<value>     set the hash table size close to <value>\n"));
    347      1.1     skrll   fprintf (stream, _("\
    348      1.1     skrll   --help                  show this message and exit\n"));
    349      1.1     skrll   fprintf (stream, _("\
    350      1.1     skrll   --target-help           show target specific options\n"));
    351      1.1     skrll   fprintf (stream, _("\
    352      1.1     skrll   -I DIR                  add DIR to search list for .include directives\n"));
    353      1.1     skrll   fprintf (stream, _("\
    354      1.1     skrll   -J                      don't warn about signed overflow\n"));
    355      1.1     skrll   fprintf (stream, _("\
    356      1.1     skrll   -K                      warn when differences altered for long displacements\n"));
    357      1.1     skrll   fprintf (stream, _("\
    358      1.1     skrll   -L,--keep-locals        keep local symbols (e.g. starting with `L')\n"));
    359      1.1     skrll   fprintf (stream, _("\
    360      1.1     skrll   -M,--mri                assemble in MRI compatibility mode\n"));
    361      1.1     skrll   fprintf (stream, _("\
    362      1.1     skrll   --MD FILE               write dependency information in FILE (default none)\n"));
    363      1.1     skrll   fprintf (stream, _("\
    364      1.1     skrll   -nocpp                  ignored\n"));
    365  1.1.1.5  christos   fprintf (stream, _("\
    366  1.1.1.5  christos   -no-pad-sections        do not pad the end of sections to alignment boundaries\n"));
    367      1.1     skrll   fprintf (stream, _("\
    368      1.1     skrll   -o OBJFILE              name the object-file output OBJFILE (default a.out)\n"));
    369      1.1     skrll   fprintf (stream, _("\
    370      1.1     skrll   -R                      fold data section into text section\n"));
    371      1.1     skrll   fprintf (stream, _("\
    372      1.1     skrll   --reduce-memory-overheads \n\
    373      1.1     skrll                           prefer smaller memory use at the cost of longer\n\
    374      1.1     skrll                           assembly times\n"));
    375      1.1     skrll   fprintf (stream, _("\
    376      1.1     skrll   --statistics            print various measured statistics from execution\n"));
    377      1.1     skrll   fprintf (stream, _("\
    378      1.1     skrll   --strip-local-absolute  strip local absolute symbols\n"));
    379      1.1     skrll   fprintf (stream, _("\
    380      1.1     skrll   --traditional-format    Use same format as native assembler when possible\n"));
    381      1.1     skrll   fprintf (stream, _("\
    382      1.1     skrll   --version               print assembler version number and exit\n"));
    383      1.1     skrll   fprintf (stream, _("\
    384      1.1     skrll   -W  --no-warn           suppress warnings\n"));
    385      1.1     skrll   fprintf (stream, _("\
    386      1.1     skrll   --warn                  don't suppress warnings\n"));
    387      1.1     skrll   fprintf (stream, _("\
    388      1.1     skrll   --fatal-warnings        treat warnings as errors\n"));
    389      1.1     skrll #ifdef HAVE_ITBL_CPU
    390      1.1     skrll   fprintf (stream, _("\
    391      1.1     skrll   --itbl INSTTBL          extend instruction set to include instructions\n\
    392      1.1     skrll                           matching the specifications defined in file INSTTBL\n"));
    393      1.1     skrll #endif
    394      1.1     skrll   fprintf (stream, _("\
    395      1.1     skrll   -w                      ignored\n"));
    396      1.1     skrll   fprintf (stream, _("\
    397      1.1     skrll   -X                      ignored\n"));
    398      1.1     skrll   fprintf (stream, _("\
    399      1.1     skrll   -Z                      generate object file even after errors\n"));
    400      1.1     skrll   fprintf (stream, _("\
    401      1.1     skrll   --listing-lhs-width     set the width in words of the output data column of\n\
    402      1.1     skrll                           the listing\n"));
    403      1.1     skrll   fprintf (stream, _("\
    404      1.1     skrll   --listing-lhs-width2    set the width in words of the continuation lines\n\
    405      1.1     skrll                           of the output data column; ignored if smaller than\n\
    406      1.1     skrll                           the width of the first line\n"));
    407      1.1     skrll   fprintf (stream, _("\
    408      1.1     skrll   --listing-rhs-width     set the max width in characters of the lines from\n\
    409      1.1     skrll                           the source file\n"));
    410      1.1     skrll   fprintf (stream, _("\
    411      1.1     skrll   --listing-cont-lines    set the maximum number of continuation lines used\n\
    412      1.1     skrll                           for the output data column of the listing\n"));
    413  1.1.1.4  christos   fprintf (stream, _("\
    414      1.1     skrll   @FILE                   read options from FILE\n"));
    415      1.1     skrll 
    416      1.1     skrll   md_show_usage (stream);
    417      1.1     skrll 
    418      1.1     skrll   fputc ('\n', stream);
    419      1.1     skrll 
    420      1.1     skrll   if (REPORT_BUGS_TO[0] && stream == stdout)
    421      1.1     skrll     fprintf (stream, _("Report bugs to %s\n"), REPORT_BUGS_TO);
    422      1.1     skrll }
    423      1.1     skrll 
    424      1.1     skrll /* Since it is easy to do here we interpret the special arg "-"
    425      1.1     skrll    to mean "use stdin" and we set that argv[] pointing to "".
    426      1.1     skrll    After we have munged argv[], the only things left are source file
    427      1.1     skrll    name(s) and ""(s) denoting stdin. These file names are used
    428      1.1     skrll    (perhaps more than once) later.
    429      1.1     skrll 
    430      1.1     skrll    check for new machine-dep cmdline options in
    431      1.1     skrll    md_parse_option definitions in config/tc-*.c.  */
    432      1.1     skrll 
    433      1.1     skrll static void
    434      1.1     skrll parse_args (int * pargc, char *** pargv)
    435      1.1     skrll {
    436      1.1     skrll   int old_argc;
    437      1.1     skrll   int new_argc;
    438      1.1     skrll   char ** old_argv;
    439      1.1     skrll   char ** new_argv;
    440      1.1     skrll   /* Starting the short option string with '-' is for programs that
    441      1.1     skrll      expect options and other ARGV-elements in any order and that care about
    442      1.1     skrll      the ordering of the two.  We describe each non-option ARGV-element
    443      1.1     skrll      as if it were the argument of an option with character code 1.  */
    444      1.1     skrll   char *shortopts;
    445      1.1     skrll   extern const char *md_shortopts;
    446      1.1     skrll   static const char std_shortopts[] =
    447      1.1     skrll   {
    448      1.1     skrll     '-', 'J',
    449      1.1     skrll #ifndef WORKING_DOT_WORD
    450      1.1     skrll     /* -K is not meaningful if .word is not being hacked.  */
    451      1.1     skrll     'K',
    452      1.1     skrll #endif
    453      1.1     skrll     'L', 'M', 'R', 'W', 'Z', 'a', ':', ':', 'D', 'f', 'g', ':',':', 'I', ':', 'o', ':',
    454      1.1     skrll #ifndef VMS
    455      1.1     skrll     /* -v takes an argument on VMS, so we don't make it a generic
    456      1.1     skrll        option.  */
    457      1.1     skrll     'v',
    458      1.1     skrll #endif
    459      1.1     skrll     'w', 'X',
    460      1.1     skrll #ifdef HAVE_ITBL_CPU
    461      1.1     skrll     /* New option for extending instruction set (see also --itbl below).  */
    462      1.1     skrll     't', ':',
    463      1.1     skrll #endif
    464      1.1     skrll     '\0'
    465      1.1     skrll   };
    466      1.1     skrll   struct option *longopts;
    467      1.1     skrll   extern struct option md_longopts[];
    468      1.1     skrll   extern size_t md_longopts_size;
    469      1.1     skrll   /* Codes used for the long options with no short synonyms.  */
    470      1.1     skrll   enum option_values
    471      1.1     skrll     {
    472      1.1     skrll       OPTION_HELP = OPTION_STD_BASE,
    473      1.1     skrll       OPTION_NOCPP,
    474      1.1     skrll       OPTION_STATISTICS,
    475      1.1     skrll       OPTION_VERSION,
    476      1.1     skrll       OPTION_DUMPCONFIG,
    477      1.1     skrll       OPTION_VERBOSE,
    478      1.1     skrll       OPTION_EMULATION,
    479      1.1     skrll       OPTION_DEBUG_PREFIX_MAP,
    480      1.1     skrll       OPTION_DEFSYM,
    481      1.1     skrll       OPTION_LISTING_LHS_WIDTH,
    482      1.1     skrll       OPTION_LISTING_LHS_WIDTH2,
    483      1.1     skrll       OPTION_LISTING_RHS_WIDTH,
    484      1.1     skrll       OPTION_LISTING_CONT_LINES,
    485      1.1     skrll       OPTION_DEPFILE,
    486      1.1     skrll       OPTION_GSTABS,
    487      1.1     skrll       OPTION_GSTABS_PLUS,
    488  1.1.1.4  christos       OPTION_GDWARF2,
    489  1.1.1.8  christos       OPTION_GDWARF_SECTIONS,
    490      1.1     skrll       OPTION_GDWARF_CIE_VERSION,
    491      1.1     skrll       OPTION_STRIP_LOCAL_ABSOLUTE,
    492      1.1     skrll       OPTION_TRADITIONAL_FORMAT,
    493      1.1     skrll       OPTION_WARN,
    494      1.1     skrll       OPTION_TARGET_HELP,
    495      1.1     skrll       OPTION_EXECSTACK,
    496  1.1.1.2  christos       OPTION_NOEXECSTACK,
    497  1.1.1.5  christos       OPTION_SIZE_CHECK,
    498  1.1.1.7  christos       OPTION_ELF_STT_COMMON,
    499  1.1.1.4  christos       OPTION_ELF_BUILD_NOTES,
    500      1.1     skrll       OPTION_SECTNAME_SUBST,
    501      1.1     skrll       OPTION_ALTERNATE,
    502      1.1     skrll       OPTION_AL,
    503      1.1     skrll       OPTION_HASH_TABLE_SIZE,
    504  1.1.1.2  christos       OPTION_REDUCE_MEMORY_OVERHEADS,
    505  1.1.1.2  christos       OPTION_WARN_FATAL,
    506  1.1.1.5  christos       OPTION_COMPRESS_DEBUG,
    507  1.1.1.5  christos       OPTION_NOCOMPRESS_DEBUG,
    508      1.1     skrll       OPTION_NO_PAD_SECTIONS /* = STD_BASE + 40 */
    509      1.1     skrll     /* When you add options here, check that they do
    510      1.1     skrll        not collide with OPTION_MD_BASE.  See as.h.  */
    511  1.1.1.4  christos     };
    512      1.1     skrll 
    513      1.1     skrll   static const struct option std_longopts[] =
    514      1.1     skrll   {
    515  1.1.1.3  christos     /* Note: commas are placed at the start of the line rather than
    516      1.1     skrll        the end of the preceding line so that it is simpler to
    517      1.1     skrll        selectively add and remove lines from this list.  */
    518      1.1     skrll     {"alternate", no_argument, NULL, OPTION_ALTERNATE}
    519      1.1     skrll     /* The entry for "a" is here to prevent getopt_long_only() from
    520      1.1     skrll        considering that -a is an abbreviation for --alternate.  This is
    521      1.1     skrll        necessary because -a=<FILE> is a valid switch but getopt would
    522      1.1     skrll        normally reject it since --alternate does not take an argument.  */
    523      1.1     skrll     ,{"a", optional_argument, NULL, 'a'}
    524      1.1     skrll     /* Handle -al=<FILE>.  */
    525  1.1.1.4  christos     ,{"al", optional_argument, NULL, OPTION_AL}
    526  1.1.1.2  christos     ,{"compress-debug-sections", optional_argument, NULL, OPTION_COMPRESS_DEBUG}
    527      1.1     skrll     ,{"nocompress-debug-sections", no_argument, NULL, OPTION_NOCOMPRESS_DEBUG}
    528      1.1     skrll     ,{"debug-prefix-map", required_argument, NULL, OPTION_DEBUG_PREFIX_MAP}
    529      1.1     skrll     ,{"defsym", required_argument, NULL, OPTION_DEFSYM}
    530      1.1     skrll     ,{"dump-config", no_argument, NULL, OPTION_DUMPCONFIG}
    531      1.1     skrll     ,{"emulation", required_argument, NULL, OPTION_EMULATION}
    532      1.1     skrll #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
    533      1.1     skrll     ,{"execstack", no_argument, NULL, OPTION_EXECSTACK}
    534  1.1.1.2  christos     ,{"noexecstack", no_argument, NULL, OPTION_NOEXECSTACK}
    535  1.1.1.5  christos     ,{"size-check", required_argument, NULL, OPTION_SIZE_CHECK}
    536  1.1.1.4  christos     ,{"elf-stt-common", required_argument, NULL, OPTION_ELF_STT_COMMON}
    537  1.1.1.7  christos     ,{"sectname-subst", no_argument, NULL, OPTION_SECTNAME_SUBST}
    538      1.1     skrll     ,{"generate-missing-build-notes", required_argument, NULL, OPTION_ELF_BUILD_NOTES}
    539      1.1     skrll #endif
    540      1.1     skrll     ,{"fatal-warnings", no_argument, NULL, OPTION_WARN_FATAL}
    541      1.1     skrll     ,{"gdwarf-2", no_argument, NULL, OPTION_GDWARF2}
    542      1.1     skrll     /* GCC uses --gdwarf-2 but GAS uses to use --gdwarf2,
    543      1.1     skrll        so we keep it here for backwards compatibility.  */
    544  1.1.1.4  christos     ,{"gdwarf2", no_argument, NULL, OPTION_GDWARF2}
    545  1.1.1.8  christos     ,{"gdwarf-sections", no_argument, NULL, OPTION_GDWARF_SECTIONS}
    546      1.1     skrll     ,{"gdwarf-cie-version", required_argument, NULL, OPTION_GDWARF_CIE_VERSION}
    547      1.1     skrll     ,{"gen-debug", no_argument, NULL, 'g'}
    548      1.1     skrll     ,{"gstabs", no_argument, NULL, OPTION_GSTABS}
    549      1.1     skrll     ,{"gstabs+", no_argument, NULL, OPTION_GSTABS_PLUS}
    550      1.1     skrll     ,{"hash-size", required_argument, NULL, OPTION_HASH_TABLE_SIZE}
    551      1.1     skrll     ,{"help", no_argument, NULL, OPTION_HELP}
    552      1.1     skrll #ifdef HAVE_ITBL_CPU
    553      1.1     skrll     /* New option for extending instruction set (see also -t above).
    554      1.1     skrll        The "-t file" or "--itbl file" option extends the basic set of
    555      1.1     skrll        valid instructions by reading "file", a text file containing a
    556      1.1     skrll        list of instruction formats.  The additional opcodes and their
    557      1.1     skrll        formats are added to the built-in set of instructions, and
    558      1.1     skrll        mnemonics for new registers may also be defined.  */
    559      1.1     skrll     ,{"itbl", required_argument, NULL, 't'}
    560      1.1     skrll #endif
    561      1.1     skrll     /* getopt allows abbreviations, so we do this to stop it from
    562      1.1     skrll        treating -k as an abbreviation for --keep-locals.  Some
    563      1.1     skrll        ports use -k to enable PIC assembly.  */
    564      1.1     skrll     ,{"keep-locals", no_argument, NULL, 'L'}
    565      1.1     skrll     ,{"keep-locals", no_argument, NULL, 'L'}
    566      1.1     skrll     ,{"listing-lhs-width", required_argument, NULL, OPTION_LISTING_LHS_WIDTH}
    567      1.1     skrll     ,{"listing-lhs-width2", required_argument, NULL, OPTION_LISTING_LHS_WIDTH2}
    568      1.1     skrll     ,{"listing-rhs-width", required_argument, NULL, OPTION_LISTING_RHS_WIDTH}
    569      1.1     skrll     ,{"listing-cont-lines", required_argument, NULL, OPTION_LISTING_CONT_LINES}
    570      1.1     skrll     ,{"MD", required_argument, NULL, OPTION_DEPFILE}
    571      1.1     skrll     ,{"mri", no_argument, NULL, 'M'}
    572  1.1.1.5  christos     ,{"nocpp", no_argument, NULL, OPTION_NOCPP}
    573      1.1     skrll     ,{"no-pad-sections", no_argument, NULL, OPTION_NO_PAD_SECTIONS}
    574      1.1     skrll     ,{"no-warn", no_argument, NULL, 'W'}
    575      1.1     skrll     ,{"reduce-memory-overheads", no_argument, NULL, OPTION_REDUCE_MEMORY_OVERHEADS}
    576      1.1     skrll     ,{"statistics", no_argument, NULL, OPTION_STATISTICS}
    577      1.1     skrll     ,{"strip-local-absolute", no_argument, NULL, OPTION_STRIP_LOCAL_ABSOLUTE}
    578      1.1     skrll     ,{"version", no_argument, NULL, OPTION_VERSION}
    579      1.1     skrll     ,{"verbose", no_argument, NULL, OPTION_VERBOSE}
    580      1.1     skrll     ,{"target-help", no_argument, NULL, OPTION_TARGET_HELP}
    581      1.1     skrll     ,{"traditional-format", no_argument, NULL, OPTION_TRADITIONAL_FORMAT}
    582      1.1     skrll     ,{"warn", no_argument, NULL, OPTION_WARN}
    583      1.1     skrll   };
    584      1.1     skrll 
    585      1.1     skrll   /* Construct the option lists from the standard list and the target
    586      1.1     skrll      dependent list.  Include space for an extra NULL option and
    587      1.1     skrll      always NULL terminate.  */
    588  1.1.1.2  christos   shortopts = concat (std_shortopts, md_shortopts, (char *) NULL);
    589  1.1.1.2  christos   longopts = (struct option *) xmalloc (sizeof (std_longopts)
    590      1.1     skrll                                         + md_longopts_size + sizeof (struct option));
    591      1.1     skrll   memcpy (longopts, std_longopts, sizeof (std_longopts));
    592      1.1     skrll   memcpy (((char *) longopts) + sizeof (std_longopts), md_longopts, md_longopts_size);
    593      1.1     skrll   memset (((char *) longopts) + sizeof (std_longopts) + md_longopts_size,
    594      1.1     skrll 	  0, sizeof (struct option));
    595      1.1     skrll 
    596      1.1     skrll   /* Make a local copy of the old argv.  */
    597      1.1     skrll   old_argc = *pargc;
    598      1.1     skrll   old_argv = *pargv;
    599      1.1     skrll 
    600  1.1.1.5  christos   /* Initialize a new argv that contains no options.  */
    601      1.1     skrll   new_argv = XNEWVEC (char *, old_argc + 1);
    602      1.1     skrll   new_argv[0] = old_argv[0];
    603      1.1     skrll   new_argc = 1;
    604      1.1     skrll   new_argv[new_argc] = NULL;
    605      1.1     skrll 
    606      1.1     skrll   while (1)
    607      1.1     skrll     {
    608      1.1     skrll       /* getopt_long_only is like getopt_long, but '-' as well as '--' can
    609      1.1     skrll 	 indicate a long option.  */
    610      1.1     skrll       int longind;
    611      1.1     skrll       int optc = getopt_long_only (old_argc, old_argv, shortopts, longopts,
    612      1.1     skrll 				   &longind);
    613      1.1     skrll 
    614      1.1     skrll       if (optc == -1)
    615      1.1     skrll 	break;
    616      1.1     skrll 
    617      1.1     skrll       switch (optc)
    618      1.1     skrll 	{
    619      1.1     skrll 	default:
    620      1.1     skrll 	  /* md_parse_option should return 1 if it recognizes optc,
    621      1.1     skrll 	     0 if not.  */
    622      1.1     skrll 	  if (md_parse_option (optc, optarg) != 0)
    623      1.1     skrll 	    break;
    624      1.1     skrll 	  /* `-v' isn't included in the general short_opts list, so check for
    625      1.1     skrll 	     it explicitly here before deciding we've gotten a bad argument.  */
    626      1.1     skrll 	  if (optc == 'v')
    627      1.1     skrll 	    {
    628      1.1     skrll #ifdef VMS
    629      1.1     skrll 	      /* Telling getopt to treat -v's value as optional can result
    630      1.1     skrll 		 in it picking up a following filename argument here.  The
    631      1.1     skrll 		 VMS code in md_parse_option can return 0 in that case,
    632      1.1     skrll 		 but it has no way of pushing the filename argument back.  */
    633      1.1     skrll 	      if (optarg && *optarg)
    634      1.1     skrll 		new_argv[new_argc++] = optarg, new_argv[new_argc] = NULL;
    635      1.1     skrll 	      else
    636      1.1     skrll #else
    637      1.1     skrll 	      case 'v':
    638      1.1     skrll #endif
    639      1.1     skrll 	      case OPTION_VERBOSE:
    640      1.1     skrll 		print_version_id ();
    641      1.1     skrll 		verbose = 1;
    642      1.1     skrll 	      break;
    643      1.1     skrll 	    }
    644      1.1     skrll 	  else
    645      1.1     skrll 	    as_bad (_("unrecognized option -%c%s"), optc, optarg ? optarg : "");
    646      1.1     skrll 	  /* Fall through.  */
    647      1.1     skrll 
    648      1.1     skrll 	case '?':
    649      1.1     skrll 	  exit (EXIT_FAILURE);
    650      1.1     skrll 
    651      1.1     skrll 	case 1:			/* File name.  */
    652  1.1.1.5  christos 	  if (!strcmp (optarg, "-"))
    653      1.1     skrll 	    optarg = (char *) "";
    654      1.1     skrll 	  new_argv[new_argc++] = optarg;
    655      1.1     skrll 	  new_argv[new_argc] = NULL;
    656      1.1     skrll 	  break;
    657      1.1     skrll 
    658      1.1     skrll 	case OPTION_TARGET_HELP:
    659      1.1     skrll 	  md_show_usage (stdout);
    660      1.1     skrll 	  exit (EXIT_SUCCESS);
    661      1.1     skrll 
    662      1.1     skrll 	case OPTION_HELP:
    663      1.1     skrll 	  show_usage (stdout);
    664      1.1     skrll 	  exit (EXIT_SUCCESS);
    665      1.1     skrll 
    666      1.1     skrll 	case OPTION_NOCPP:
    667      1.1     skrll 	  break;
    668  1.1.1.5  christos 
    669  1.1.1.5  christos 	case OPTION_NO_PAD_SECTIONS:
    670  1.1.1.5  christos 	  do_not_pad_sections_to_alignment = 1;
    671  1.1.1.5  christos 	  break;
    672      1.1     skrll 
    673      1.1     skrll 	case OPTION_STATISTICS:
    674      1.1     skrll 	  flag_print_statistics = 1;
    675      1.1     skrll 	  break;
    676      1.1     skrll 
    677      1.1     skrll 	case OPTION_STRIP_LOCAL_ABSOLUTE:
    678      1.1     skrll 	  flag_strip_local_absolute = 1;
    679      1.1     skrll 	  break;
    680      1.1     skrll 
    681      1.1     skrll 	case OPTION_TRADITIONAL_FORMAT:
    682      1.1     skrll 	  flag_traditional_format = 1;
    683      1.1     skrll 	  break;
    684      1.1     skrll 
    685      1.1     skrll 	case OPTION_VERSION:
    686      1.1     skrll 	  /* This output is intended to follow the GNU standards document.  */
    687  1.1.1.8  christos 	  printf (_("GNU assembler %s\n"), BFD_VERSION_STRING);
    688      1.1     skrll 	  printf (_("Copyright (C) 2020 Free Software Foundation, Inc.\n"));
    689      1.1     skrll 	  printf (_("\
    690      1.1     skrll This program is free software; you may redistribute it under the terms of\n\
    691      1.1     skrll the GNU General Public License version 3 or later.\n\
    692  1.1.1.5  christos This program has absolutely no warranty.\n"));
    693  1.1.1.5  christos #ifdef TARGET_WITH_CPU
    694  1.1.1.5  christos 	  printf (_("This assembler was configured for a target of `%s' "
    695  1.1.1.5  christos 		    "and default,\ncpu type `%s'.\n"),
    696  1.1.1.5  christos 		  TARGET_ALIAS, TARGET_WITH_CPU);
    697      1.1     skrll #else
    698      1.1     skrll 	  printf (_("This assembler was configured for a target of `%s'.\n"),
    699  1.1.1.5  christos 		  TARGET_ALIAS);
    700      1.1     skrll #endif
    701      1.1     skrll 	  exit (EXIT_SUCCESS);
    702      1.1     skrll 
    703      1.1     skrll 	case OPTION_EMULATION:
    704      1.1     skrll #ifdef USE_EMULATIONS
    705      1.1     skrll 	  if (strcmp (optarg, this_emulation->name))
    706      1.1     skrll 	    as_fatal (_("multiple emulation names specified"));
    707      1.1     skrll #else
    708      1.1     skrll 	  as_fatal (_("emulations not handled in this configuration"));
    709      1.1     skrll #endif
    710      1.1     skrll 	  break;
    711      1.1     skrll 
    712      1.1     skrll 	case OPTION_DUMPCONFIG:
    713      1.1     skrll 	  fprintf (stderr, _("alias = %s\n"), TARGET_ALIAS);
    714      1.1     skrll 	  fprintf (stderr, _("canonical = %s\n"), TARGET_CANONICAL);
    715      1.1     skrll 	  fprintf (stderr, _("cpu-type = %s\n"), TARGET_CPU);
    716      1.1     skrll #ifdef TARGET_OBJ_FORMAT
    717      1.1     skrll 	  fprintf (stderr, _("format = %s\n"), TARGET_OBJ_FORMAT);
    718      1.1     skrll #endif
    719      1.1     skrll #ifdef TARGET_FORMAT
    720      1.1     skrll 	  fprintf (stderr, _("bfd-target = %s\n"), TARGET_FORMAT);
    721      1.1     skrll #endif
    722      1.1     skrll 	  exit (EXIT_SUCCESS);
    723  1.1.1.2  christos 
    724  1.1.1.4  christos 	case OPTION_COMPRESS_DEBUG:
    725  1.1.1.4  christos 	  if (optarg)
    726  1.1.1.4  christos 	    {
    727  1.1.1.4  christos #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
    728  1.1.1.4  christos 	      if (strcasecmp (optarg, "none") == 0)
    729  1.1.1.4  christos 		flag_compress_debug = COMPRESS_DEBUG_NONE;
    730  1.1.1.4  christos 	      else if (strcasecmp (optarg, "zlib") == 0)
    731  1.1.1.4  christos 		flag_compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
    732  1.1.1.4  christos 	      else if (strcasecmp (optarg, "zlib-gnu") == 0)
    733  1.1.1.4  christos 		flag_compress_debug = COMPRESS_DEBUG_GNU_ZLIB;
    734  1.1.1.4  christos 	      else if (strcasecmp (optarg, "zlib-gabi") == 0)
    735  1.1.1.4  christos 		flag_compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
    736  1.1.1.4  christos 	      else
    737  1.1.1.4  christos 		as_fatal (_("Invalid --compress-debug-sections option: `%s'"),
    738  1.1.1.2  christos 			  optarg);
    739  1.1.1.4  christos #else
    740  1.1.1.4  christos 	      as_fatal (_("--compress-debug-sections=%s is unsupported"),
    741  1.1.1.4  christos 			optarg);
    742  1.1.1.4  christos #endif
    743  1.1.1.4  christos 	    }
    744  1.1.1.4  christos 	  else
    745  1.1.1.2  christos 	    flag_compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
    746  1.1.1.2  christos 	  break;
    747  1.1.1.2  christos 
    748  1.1.1.4  christos 	case OPTION_NOCOMPRESS_DEBUG:
    749  1.1.1.2  christos 	  flag_compress_debug = COMPRESS_DEBUG_NONE;
    750  1.1.1.2  christos 	  break;
    751      1.1     skrll 
    752      1.1     skrll 	case OPTION_DEBUG_PREFIX_MAP:
    753      1.1     skrll 	  add_debug_prefix_map (optarg);
    754      1.1     skrll 	  break;
    755      1.1     skrll 
    756      1.1     skrll 	case OPTION_DEFSYM:
    757      1.1     skrll 	  {
    758      1.1     skrll 	    char *s;
    759      1.1     skrll 	    valueT i;
    760      1.1     skrll 	    struct defsym_list *n;
    761      1.1     skrll 
    762      1.1     skrll 	    for (s = optarg; *s != '\0' && *s != '='; s++)
    763      1.1     skrll 	      ;
    764      1.1     skrll 	    if (*s == '\0')
    765      1.1     skrll 	      as_fatal (_("bad defsym; format is --defsym name=value"));
    766      1.1     skrll 	    *s++ = '\0';
    767  1.1.1.5  christos 	    i = bfd_scan_vma (s, (const char **) NULL, 0);
    768      1.1     skrll 	    n = XNEW (struct defsym_list);
    769      1.1     skrll 	    n->next = defsyms;
    770      1.1     skrll 	    n->name = optarg;
    771      1.1     skrll 	    n->value = i;
    772      1.1     skrll 	    defsyms = n;
    773      1.1     skrll 	  }
    774      1.1     skrll 	  break;
    775      1.1     skrll 
    776      1.1     skrll #ifdef HAVE_ITBL_CPU
    777      1.1     skrll 	case 't':
    778      1.1     skrll 	  {
    779      1.1     skrll 	    /* optarg is the name of the file containing the instruction
    780      1.1     skrll 	       formats, opcodes, register names, etc.  */
    781      1.1     skrll 	    struct itbl_file_list *n;
    782      1.1     skrll 
    783      1.1     skrll 	    if (optarg == NULL)
    784      1.1     skrll 	      {
    785      1.1     skrll 		as_warn (_("no file name following -t option"));
    786      1.1     skrll 		break;
    787      1.1     skrll 	      }
    788  1.1.1.5  christos 
    789      1.1     skrll 	    n = XNEW (struct itbl_file_list);
    790      1.1     skrll 	    n->next = itbl_files;
    791      1.1     skrll 	    n->name = optarg;
    792      1.1     skrll 	    itbl_files = n;
    793      1.1     skrll 
    794      1.1     skrll 	    /* Parse the file and add the new instructions to our internal
    795      1.1     skrll 	       table.  If multiple instruction tables are specified, the
    796      1.1     skrll 	       information from this table gets appended onto the existing
    797      1.1     skrll 	       internal table.  */
    798      1.1     skrll 	    itbl_files->name = xstrdup (optarg);
    799      1.1     skrll 	    if (itbl_parse (itbl_files->name) != 0)
    800      1.1     skrll 	      as_fatal (_("failed to read instruction table %s\n"),
    801      1.1     skrll 			itbl_files->name);
    802      1.1     skrll 	  }
    803      1.1     skrll 	  break;
    804      1.1     skrll #endif
    805      1.1     skrll 
    806      1.1     skrll 	case OPTION_DEPFILE:
    807      1.1     skrll 	  start_dependencies (optarg);
    808      1.1     skrll 	  break;
    809      1.1     skrll 
    810      1.1     skrll 	case 'g':
    811      1.1     skrll 	  /* Some backends, eg Alpha and Mips, use the -g switch for their
    812      1.1     skrll 	     own purposes.  So we check here for an explicit -g and allow
    813      1.1     skrll 	     the backend to decide if it wants to process it.  */
    814      1.1     skrll 	  if (   old_argv[optind - 1][1] == 'g'
    815      1.1     skrll 	      && md_parse_option (optc, optarg))
    816      1.1     skrll 	    continue;
    817      1.1     skrll 
    818      1.1     skrll 	  if (md_debug_format_selector)
    819      1.1     skrll 	    debug_type = md_debug_format_selector (& use_gnu_debug_info_extensions);
    820      1.1     skrll 	  else if (IS_ELF)
    821      1.1     skrll 	    debug_type = DEBUG_DWARF2;
    822      1.1     skrll 	  else
    823      1.1     skrll 	    debug_type = DEBUG_STABS;
    824      1.1     skrll 	  break;
    825      1.1     skrll 
    826      1.1     skrll 	case OPTION_GSTABS_PLUS:
    827      1.1     skrll 	  use_gnu_debug_info_extensions = 1;
    828      1.1     skrll 	  /* Fall through.  */
    829      1.1     skrll 	case OPTION_GSTABS:
    830      1.1     skrll 	  debug_type = DEBUG_STABS;
    831      1.1     skrll 	  break;
    832      1.1     skrll 
    833      1.1     skrll 	case OPTION_GDWARF2:
    834      1.1     skrll 	  debug_type = DEBUG_DWARF2;
    835      1.1     skrll 	  break;
    836  1.1.1.4  christos 
    837  1.1.1.4  christos 	case OPTION_GDWARF_SECTIONS:
    838  1.1.1.4  christos 	  flag_dwarf_sections = TRUE;
    839  1.1.1.4  christos 	  break;
    840  1.1.1.8  christos 
    841  1.1.1.8  christos         case OPTION_GDWARF_CIE_VERSION:
    842  1.1.1.8  christos 	  flag_dwarf_cie_version = atoi (optarg);
    843  1.1.1.8  christos           /* The available CIE versions are 1 (DWARF 2), 3 (DWARF 3), and 4
    844  1.1.1.8  christos              (DWARF 4 and 5).  */
    845  1.1.1.8  christos 	  if (flag_dwarf_cie_version < 1
    846  1.1.1.8  christos               || flag_dwarf_cie_version == 2
    847  1.1.1.8  christos               || flag_dwarf_cie_version > 4)
    848  1.1.1.8  christos             as_fatal (_("Invalid --gdwarf-cie-version `%s'"), optarg);
    849  1.1.1.8  christos 	  break;
    850      1.1     skrll 
    851      1.1     skrll 	case 'J':
    852      1.1     skrll 	  flag_signed_overflow_ok = 1;
    853      1.1     skrll 	  break;
    854      1.1     skrll 
    855      1.1     skrll #ifndef WORKING_DOT_WORD
    856      1.1     skrll 	case 'K':
    857      1.1     skrll 	  flag_warn_displacement = 1;
    858      1.1     skrll 	  break;
    859      1.1     skrll #endif
    860      1.1     skrll 	case 'L':
    861      1.1     skrll 	  flag_keep_locals = 1;
    862      1.1     skrll 	  break;
    863      1.1     skrll 
    864      1.1     skrll 	case OPTION_LISTING_LHS_WIDTH:
    865      1.1     skrll 	  listing_lhs_width = atoi (optarg);
    866      1.1     skrll 	  if (listing_lhs_width_second < listing_lhs_width)
    867      1.1     skrll 	    listing_lhs_width_second = listing_lhs_width;
    868      1.1     skrll 	  break;
    869      1.1     skrll 	case OPTION_LISTING_LHS_WIDTH2:
    870      1.1     skrll 	  {
    871      1.1     skrll 	    int tmp = atoi (optarg);
    872      1.1     skrll 
    873      1.1     skrll 	    if (tmp > listing_lhs_width)
    874      1.1     skrll 	      listing_lhs_width_second = tmp;
    875      1.1     skrll 	  }
    876      1.1     skrll 	  break;
    877      1.1     skrll 	case OPTION_LISTING_RHS_WIDTH:
    878      1.1     skrll 	  listing_rhs_width = atoi (optarg);
    879      1.1     skrll 	  break;
    880      1.1     skrll 	case OPTION_LISTING_CONT_LINES:
    881      1.1     skrll 	  listing_lhs_cont_lines = atoi (optarg);
    882      1.1     skrll 	  break;
    883      1.1     skrll 
    884      1.1     skrll 	case 'M':
    885      1.1     skrll 	  flag_mri = 1;
    886      1.1     skrll #ifdef TC_M68K
    887      1.1     skrll 	  flag_m68k_mri = 1;
    888      1.1     skrll #endif
    889      1.1     skrll 	  break;
    890      1.1     skrll 
    891      1.1     skrll 	case 'R':
    892      1.1     skrll 	  flag_readonly_data_in_text = 1;
    893      1.1     skrll 	  break;
    894      1.1     skrll 
    895      1.1     skrll 	case 'W':
    896      1.1     skrll 	  flag_no_warnings = 1;
    897      1.1     skrll 	  break;
    898      1.1     skrll 
    899      1.1     skrll 	case OPTION_WARN:
    900      1.1     skrll 	  flag_no_warnings = 0;
    901      1.1     skrll 	  flag_fatal_warnings = 0;
    902      1.1     skrll 	  break;
    903      1.1     skrll 
    904      1.1     skrll 	case OPTION_WARN_FATAL:
    905      1.1     skrll 	  flag_no_warnings = 0;
    906      1.1     skrll 	  flag_fatal_warnings = 1;
    907      1.1     skrll 	  break;
    908      1.1     skrll 
    909      1.1     skrll #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
    910      1.1     skrll 	case OPTION_EXECSTACK:
    911      1.1     skrll 	  flag_execstack = 1;
    912      1.1     skrll 	  flag_noexecstack = 0;
    913      1.1     skrll 	  break;
    914      1.1     skrll 
    915      1.1     skrll 	case OPTION_NOEXECSTACK:
    916      1.1     skrll 	  flag_noexecstack = 1;
    917      1.1     skrll 	  flag_execstack = 0;
    918  1.1.1.2  christos 	  break;
    919  1.1.1.2  christos 
    920  1.1.1.2  christos 	case OPTION_SIZE_CHECK:
    921  1.1.1.5  christos 	  if (strcasecmp (optarg, "error") == 0)
    922  1.1.1.2  christos 	    flag_allow_nonconst_size = FALSE;
    923  1.1.1.5  christos 	  else if (strcasecmp (optarg, "warning") == 0)
    924  1.1.1.2  christos 	    flag_allow_nonconst_size = TRUE;
    925  1.1.1.2  christos 	  else
    926  1.1.1.2  christos 	    as_fatal (_("Invalid --size-check= option: `%s'"), optarg);
    927  1.1.1.4  christos 	  break;
    928  1.1.1.5  christos 
    929  1.1.1.5  christos 	case OPTION_ELF_STT_COMMON:
    930  1.1.1.5  christos 	  if (strcasecmp (optarg, "no") == 0)
    931  1.1.1.5  christos 	    flag_use_elf_stt_common = 0;
    932  1.1.1.5  christos 	  else if (strcasecmp (optarg, "yes") == 0)
    933  1.1.1.5  christos 	    flag_use_elf_stt_common = 1;
    934  1.1.1.5  christos 	  else
    935  1.1.1.5  christos 	    as_fatal (_("Invalid --elf-stt-common= option: `%s'"),
    936  1.1.1.5  christos 		      optarg);
    937  1.1.1.5  christos 	  break;
    938  1.1.1.4  christos 
    939  1.1.1.4  christos 	case OPTION_SECTNAME_SUBST:
    940  1.1.1.4  christos 	  flag_sectname_subst = 1;
    941  1.1.1.7  christos 	  break;
    942  1.1.1.7  christos 
    943  1.1.1.7  christos 	case OPTION_ELF_BUILD_NOTES:
    944  1.1.1.7  christos 	  if (strcasecmp (optarg, "no") == 0)
    945  1.1.1.7  christos 	    flag_generate_build_notes = FALSE;
    946  1.1.1.7  christos 	  else if (strcasecmp (optarg, "yes") == 0)
    947  1.1.1.7  christos 	    flag_generate_build_notes = TRUE;
    948  1.1.1.7  christos 	  else
    949  1.1.1.7  christos 	    as_fatal (_("Invalid --generate-missing-build-notes option: `%s'"),
    950  1.1.1.7  christos 		      optarg);
    951  1.1.1.7  christos 	  break;
    952  1.1.1.7  christos 
    953  1.1.1.7  christos #endif /* OBJ_ELF */
    954      1.1     skrll 
    955      1.1     skrll 	case 'Z':
    956      1.1     skrll 	  flag_always_generate_output = 1;
    957      1.1     skrll 	  break;
    958      1.1     skrll 
    959      1.1     skrll  	case OPTION_AL:
    960      1.1     skrll 	  listing |= LISTING_LISTING;
    961      1.1     skrll 	  if (optarg)
    962      1.1     skrll 	    listing_filename = xstrdup (optarg);
    963      1.1     skrll 	  break;
    964      1.1     skrll 
    965      1.1     skrll  	case OPTION_ALTERNATE:
    966      1.1     skrll  	  optarg = old_argv [optind - 1];
    967      1.1     skrll  	  while (* optarg == '-')
    968      1.1     skrll  	    optarg ++;
    969      1.1     skrll 
    970      1.1     skrll  	  if (strcmp (optarg, "alternate") == 0)
    971      1.1     skrll  	    {
    972      1.1     skrll  	      flag_macro_alternate = 1;
    973      1.1     skrll  	      break;
    974      1.1     skrll  	    }
    975      1.1     skrll  	  optarg ++;
    976      1.1     skrll  	  /* Fall through.  */
    977      1.1     skrll 
    978      1.1     skrll 	case 'a':
    979      1.1     skrll 	  if (optarg)
    980      1.1     skrll 	    {
    981      1.1     skrll 	      if (optarg != old_argv[optind] && optarg[-1] == '=')
    982      1.1     skrll 		--optarg;
    983      1.1     skrll 
    984      1.1     skrll 	      if (md_parse_option (optc, optarg) != 0)
    985      1.1     skrll 		break;
    986      1.1     skrll 
    987      1.1     skrll 	      while (*optarg)
    988      1.1     skrll 		{
    989      1.1     skrll 		  switch (*optarg)
    990      1.1     skrll 		    {
    991      1.1     skrll 		    case 'c':
    992      1.1     skrll 		      listing |= LISTING_NOCOND;
    993      1.1     skrll 		      break;
    994      1.1     skrll 		    case 'd':
    995      1.1     skrll 		      listing |= LISTING_NODEBUG;
    996      1.1     skrll 		      break;
    997      1.1     skrll 		    case 'g':
    998      1.1     skrll 		      listing |= LISTING_GENERAL;
    999      1.1     skrll 		      break;
   1000      1.1     skrll 		    case 'h':
   1001      1.1     skrll 		      listing |= LISTING_HLL;
   1002      1.1     skrll 		      break;
   1003      1.1     skrll 		    case 'l':
   1004      1.1     skrll 		      listing |= LISTING_LISTING;
   1005      1.1     skrll 		      break;
   1006      1.1     skrll 		    case 'm':
   1007      1.1     skrll 		      listing |= LISTING_MACEXP;
   1008      1.1     skrll 		      break;
   1009      1.1     skrll 		    case 'n':
   1010      1.1     skrll 		      listing |= LISTING_NOFORM;
   1011      1.1     skrll 		      break;
   1012      1.1     skrll 		    case 's':
   1013      1.1     skrll 		      listing |= LISTING_SYMBOLS;
   1014      1.1     skrll 		      break;
   1015      1.1     skrll 		    case '=':
   1016      1.1     skrll 		      listing_filename = xstrdup (optarg + 1);
   1017      1.1     skrll 		      optarg += strlen (listing_filename);
   1018      1.1     skrll 		      break;
   1019      1.1     skrll 		    default:
   1020      1.1     skrll 		      as_fatal (_("invalid listing option `%c'"), *optarg);
   1021      1.1     skrll 		      break;
   1022      1.1     skrll 		    }
   1023      1.1     skrll 		  optarg++;
   1024      1.1     skrll 		}
   1025      1.1     skrll 	    }
   1026      1.1     skrll 	  if (!listing)
   1027      1.1     skrll 	    listing = LISTING_DEFAULT;
   1028      1.1     skrll 	  break;
   1029      1.1     skrll 
   1030      1.1     skrll 	case 'D':
   1031      1.1     skrll 	  /* DEBUG is implemented: it debugs different
   1032      1.1     skrll 	     things from other people's assemblers.  */
   1033      1.1     skrll 	  flag_debug = 1;
   1034      1.1     skrll 	  break;
   1035      1.1     skrll 
   1036      1.1     skrll 	case 'f':
   1037      1.1     skrll 	  flag_no_comments = 1;
   1038      1.1     skrll 	  break;
   1039      1.1     skrll 
   1040      1.1     skrll 	case 'I':
   1041      1.1     skrll 	  {			/* Include file directory.  */
   1042      1.1     skrll 	    char *temp = xstrdup (optarg);
   1043      1.1     skrll 
   1044      1.1     skrll 	    add_include_dir (temp);
   1045      1.1     skrll 	    break;
   1046      1.1     skrll 	  }
   1047      1.1     skrll 
   1048      1.1     skrll 	case 'o':
   1049      1.1     skrll 	  out_file_name = xstrdup (optarg);
   1050      1.1     skrll 	  break;
   1051      1.1     skrll 
   1052      1.1     skrll 	case 'w':
   1053      1.1     skrll 	  break;
   1054      1.1     skrll 
   1055      1.1     skrll 	case 'X':
   1056      1.1     skrll 	  /* -X means treat warnings as errors.  */
   1057      1.1     skrll 	  break;
   1058      1.1     skrll 
   1059      1.1     skrll 	case OPTION_REDUCE_MEMORY_OVERHEADS:
   1060      1.1     skrll 	  /* The only change we make at the moment is to reduce
   1061      1.1     skrll 	     the size of the hash tables that we use.  */
   1062      1.1     skrll 	  set_gas_hash_table_size (4051);
   1063      1.1     skrll 	  break;
   1064      1.1     skrll 
   1065      1.1     skrll 	case OPTION_HASH_TABLE_SIZE:
   1066      1.1     skrll 	  {
   1067      1.1     skrll 	    unsigned long new_size;
   1068      1.1     skrll 
   1069      1.1     skrll             new_size = strtoul (optarg, NULL, 0);
   1070      1.1     skrll             if (new_size)
   1071      1.1     skrll               set_gas_hash_table_size (new_size);
   1072      1.1     skrll             else
   1073      1.1     skrll               as_fatal (_("--hash-size needs a numeric argument"));
   1074      1.1     skrll 	    break;
   1075      1.1     skrll 	  }
   1076      1.1     skrll 	}
   1077      1.1     skrll     }
   1078      1.1     skrll 
   1079      1.1     skrll   free (shortopts);
   1080      1.1     skrll   free (longopts);
   1081      1.1     skrll 
   1082      1.1     skrll   *pargc = new_argc;
   1083      1.1     skrll   *pargv = new_argv;
   1084      1.1     skrll 
   1085      1.1     skrll #ifdef md_after_parse_args
   1086      1.1     skrll   md_after_parse_args ();
   1087      1.1     skrll #endif
   1088      1.1     skrll }
   1089      1.1     skrll 
   1090      1.1     skrll static void
   1091      1.1     skrll dump_statistics (void)
   1092      1.1     skrll {
   1093      1.1     skrll   long run_time = get_run_time () - start_time;
   1094      1.1     skrll 
   1095      1.1     skrll   fprintf (stderr, _("%s: total time in assembly: %ld.%06ld\n"),
   1096      1.1     skrll 	   myname, run_time / 1000000, run_time % 1000000);
   1097      1.1     skrll 
   1098      1.1     skrll   subsegs_print_statistics (stderr);
   1099      1.1     skrll   write_print_statistics (stderr);
   1100      1.1     skrll   symbol_print_statistics (stderr);
   1101      1.1     skrll   read_print_statistics (stderr);
   1102      1.1     skrll 
   1103      1.1     skrll #ifdef tc_print_statistics
   1104      1.1     skrll   tc_print_statistics (stderr);
   1105      1.1     skrll #endif
   1106      1.1     skrll 
   1107      1.1     skrll #ifdef obj_print_statistics
   1108      1.1     skrll   obj_print_statistics (stderr);
   1109      1.1     skrll #endif
   1110      1.1     skrll }
   1111      1.1     skrll 
   1112      1.1     skrll static void
   1113      1.1     skrll close_output_file (void)
   1114      1.1     skrll {
   1115  1.1.1.2  christos   output_file_close (out_file_name);
   1116  1.1.1.2  christos   if (!keep_it)
   1117      1.1     skrll     unlink_if_ordinary (out_file_name);
   1118      1.1     skrll }
   1119      1.1     skrll 
   1120      1.1     skrll /* The interface between the macro code and gas expression handling.  */
   1121  1.1.1.3  christos 
   1122  1.1.1.3  christos static size_t
   1123      1.1     skrll macro_expr (const char *emsg, size_t idx, sb *in, offsetT *val)
   1124      1.1     skrll {
   1125      1.1     skrll   expressionS ex;
   1126      1.1     skrll 
   1127      1.1     skrll   sb_terminate (in);
   1128  1.1.1.8  christos 
   1129      1.1     skrll   temp_ilp (in->ptr + idx);
   1130      1.1     skrll   expression_and_evaluate (&ex);
   1131  1.1.1.8  christos   idx = input_line_pointer - in->ptr;
   1132      1.1     skrll   restore_ilp ();
   1133      1.1     skrll 
   1134      1.1     skrll   if (ex.X_op != O_constant)
   1135      1.1     skrll     as_bad ("%s", emsg);
   1136  1.1.1.3  christos 
   1137      1.1     skrll   *val = ex.X_add_number;
   1138      1.1     skrll 
   1139      1.1     skrll   return idx;
   1140      1.1     skrll }
   1141      1.1     skrll 
   1142      1.1     skrll /* Here to attempt 1 pass over each input file.
   1144      1.1     skrll    We scan argv[*] looking for filenames or exactly "" which is
   1145      1.1     skrll    shorthand for stdin. Any argv that is NULL is not a file-name.
   1146      1.1     skrll    We set need_pass_2 TRUE if, after this, we still have unresolved
   1147      1.1     skrll    expressions of the form (unknown value)+-(unknown value).
   1148      1.1     skrll 
   1149      1.1     skrll    Note the un*x semantics: there is only 1 logical input file, but it
   1150      1.1     skrll    may be a catenation of many 'physical' input files.  */
   1151      1.1     skrll 
   1152      1.1     skrll static void
   1153      1.1     skrll perform_an_assembly_pass (int argc, char ** argv)
   1154  1.1.1.3  christos {
   1155      1.1     skrll   int saw_a_file = 0;
   1156  1.1.1.3  christos #ifndef OBJ_MACH_O
   1157      1.1     skrll   flagword applicable;
   1158      1.1     skrll #endif
   1159      1.1     skrll 
   1160  1.1.1.3  christos   need_pass_2 = 0;
   1161      1.1     skrll 
   1162      1.1     skrll #ifndef OBJ_MACH_O
   1163      1.1     skrll   /* Create the standard sections, and those the assembler uses
   1164      1.1     skrll      internally.  */
   1165      1.1     skrll   text_section = subseg_new (TEXT_SECTION_NAME, 0);
   1166      1.1     skrll   data_section = subseg_new (DATA_SECTION_NAME, 0);
   1167      1.1     skrll   bss_section = subseg_new (BSS_SECTION_NAME, 0);
   1168      1.1     skrll   /* @@ FIXME -- we're setting the RELOC flag so that sections are assumed
   1169  1.1.1.8  christos      to have relocs, otherwise we don't find out in time.  */
   1170      1.1     skrll   applicable = bfd_applicable_section_flags (stdoutput);
   1171      1.1     skrll   bfd_set_section_flags (text_section,
   1172  1.1.1.8  christos 			 applicable & (SEC_ALLOC | SEC_LOAD | SEC_RELOC
   1173      1.1     skrll 				       | SEC_CODE | SEC_READONLY));
   1174      1.1     skrll   bfd_set_section_flags (data_section,
   1175  1.1.1.8  christos 			 applicable & (SEC_ALLOC | SEC_LOAD | SEC_RELOC
   1176      1.1     skrll 				       | SEC_DATA));
   1177  1.1.1.3  christos   bfd_set_section_flags (bss_section, applicable & SEC_ALLOC);
   1178      1.1     skrll   seg_info (bss_section)->bss = 1;
   1179      1.1     skrll #endif
   1180      1.1     skrll   subseg_new (BFD_ABS_SECTION_NAME, 0);
   1181      1.1     skrll   subseg_new (BFD_UND_SECTION_NAME, 0);
   1182      1.1     skrll   reg_section = subseg_new ("*GAS `reg' section*", 0);
   1183  1.1.1.3  christos   expr_section = subseg_new ("*GAS `expr' section*", 0);
   1184      1.1     skrll 
   1185  1.1.1.3  christos #ifndef OBJ_MACH_O
   1186      1.1     skrll   subseg_set (text_section, 0);
   1187      1.1     skrll #endif
   1188      1.1     skrll 
   1189      1.1     skrll   /* This may add symbol table entries, which requires having an open BFD,
   1190      1.1     skrll      and sections already created.  */
   1191      1.1     skrll   md_begin ();
   1192      1.1     skrll 
   1193      1.1     skrll #ifdef USING_CGEN
   1194      1.1     skrll   gas_cgen_begin ();
   1195      1.1     skrll #endif
   1196      1.1     skrll #ifdef obj_begin
   1197      1.1     skrll   obj_begin ();
   1198      1.1     skrll #endif
   1199      1.1     skrll 
   1200      1.1     skrll   /* Skip argv[0].  */
   1201      1.1     skrll   argv++;
   1202      1.1     skrll   argc--;
   1203      1.1     skrll 
   1204      1.1     skrll   while (argc--)
   1205      1.1     skrll     {
   1206      1.1     skrll       if (*argv)
   1207      1.1     skrll 	{			/* Is it a file-name argument?  */
   1208      1.1     skrll 	  PROGRESS (1);
   1209      1.1     skrll 	  saw_a_file++;
   1210      1.1     skrll 	  /* argv->"" if stdin desired, else->filename.  */
   1211      1.1     skrll 	  read_a_source_file (*argv);
   1212      1.1     skrll 	}
   1213      1.1     skrll       argv++;			/* Completed that argv.  */
   1214      1.1     skrll     }
   1215      1.1     skrll   if (!saw_a_file)
   1216      1.1     skrll     read_a_source_file ("");
   1217      1.1     skrll }
   1218      1.1     skrll 
   1219      1.1     skrll 
   1221      1.1     skrll int
   1222  1.1.1.7  christos main (int argc, char ** argv)
   1223      1.1     skrll {
   1224      1.1     skrll   char ** argv_orig = argv;
   1225      1.1     skrll   struct stat sob;
   1226      1.1     skrll 
   1227  1.1.1.6  christos   int macro_strip_at;
   1228      1.1     skrll 
   1229      1.1     skrll   start_time = get_run_time ();
   1230      1.1     skrll   signal_init ();
   1231      1.1     skrll 
   1232      1.1     skrll #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
   1233      1.1     skrll   setlocale (LC_MESSAGES, "");
   1234      1.1     skrll #endif
   1235      1.1     skrll #if defined (HAVE_SETLOCALE)
   1236      1.1     skrll   setlocale (LC_CTYPE, "");
   1237      1.1     skrll #endif
   1238      1.1     skrll   bindtextdomain (PACKAGE, LOCALEDIR);
   1239      1.1     skrll   textdomain (PACKAGE);
   1240      1.1     skrll 
   1241      1.1     skrll   if (debug_memory)
   1242      1.1     skrll     chunksize = 64;
   1243      1.1     skrll 
   1244      1.1     skrll #ifdef HOST_SPECIAL_INIT
   1245      1.1     skrll   HOST_SPECIAL_INIT (argc, argv);
   1246      1.1     skrll #endif
   1247      1.1     skrll 
   1248      1.1     skrll   myname = argv[0];
   1249      1.1     skrll   xmalloc_set_program_name (myname);
   1250      1.1     skrll 
   1251      1.1     skrll   expandargv (&argc, &argv);
   1252      1.1     skrll 
   1253      1.1     skrll   START_PROGRESS (myname, 0);
   1254      1.1     skrll 
   1255      1.1     skrll #ifndef OBJ_DEFAULT_OUTPUT_FILE_NAME
   1256      1.1     skrll #define OBJ_DEFAULT_OUTPUT_FILE_NAME "a.out"
   1257      1.1     skrll #endif
   1258      1.1     skrll 
   1259  1.1.1.8  christos   out_file_name = OBJ_DEFAULT_OUTPUT_FILE_NAME;
   1260  1.1.1.8  christos 
   1261      1.1     skrll   hex_init ();
   1262      1.1     skrll   if (bfd_init () != BFD_INIT_MAGIC)
   1263      1.1     skrll     as_fatal (_("libbfd ABI mismatch"));
   1264      1.1     skrll   bfd_set_error_program_name (myname);
   1265      1.1     skrll 
   1266      1.1     skrll #ifdef USE_EMULATIONS
   1267      1.1     skrll   select_emulation_mode (argc, argv);
   1268      1.1     skrll #endif
   1269      1.1     skrll 
   1270      1.1     skrll   PROGRESS (1);
   1271  1.1.1.7  christos   /* Call parse_args before any of the init/begin functions
   1272  1.1.1.7  christos      so that switches like --hash-size can be honored.  */
   1273  1.1.1.7  christos   parse_args (&argc, &argv);
   1274  1.1.1.7  christos 
   1275  1.1.1.7  christos   if (argc > 1 && stat (out_file_name, &sob) == 0)
   1276  1.1.1.7  christos     {
   1277  1.1.1.7  christos       int i;
   1278  1.1.1.7  christos 
   1279  1.1.1.7  christos       for (i = 1; i < argc; ++i)
   1280  1.1.1.8  christos 	{
   1281  1.1.1.8  christos 	  struct stat sib;
   1282  1.1.1.8  christos 
   1283  1.1.1.8  christos 	  /* Check that the input file and output file are different.  */
   1284  1.1.1.8  christos 	  if (stat (argv[i], &sib) == 0
   1285  1.1.1.8  christos 	      && sib.st_ino == sob.st_ino
   1286  1.1.1.8  christos 	      /* POSIX emulating systems may support stat() but if the
   1287  1.1.1.8  christos 		 underlying file system does not support a file serial number
   1288  1.1.1.8  christos 		 of some kind then they will return 0 for the inode.  So
   1289  1.1.1.8  christos 		 two files with an inode of 0 may not actually be the same.
   1290  1.1.1.8  christos 		 On real POSIX systems no ordinary file will ever have an
   1291  1.1.1.8  christos 		 inode of 0.  */
   1292  1.1.1.8  christos 	      && sib.st_ino != 0
   1293  1.1.1.8  christos 	      /* Different files may have the same inode number if they
   1294  1.1.1.7  christos 		 reside on different devices, so check the st_dev field as
   1295  1.1.1.8  christos 		 well.  */
   1296  1.1.1.8  christos 	      && sib.st_dev == sob.st_dev)
   1297  1.1.1.8  christos 	    {
   1298  1.1.1.8  christos 	      const char *saved_out_file_name = out_file_name;
   1299  1.1.1.8  christos 
   1300  1.1.1.8  christos 	      /* Don't let as_fatal remove the output file!  */
   1301  1.1.1.7  christos 	      out_file_name = NULL;
   1302  1.1.1.7  christos 	      as_fatal (_("The input '%s' and output '%s' files are the same"),
   1303  1.1.1.7  christos 			argv[i], saved_out_file_name);
   1304  1.1.1.7  christos 	    }
   1305      1.1     skrll 	}
   1306      1.1     skrll     }
   1307      1.1     skrll 
   1308      1.1     skrll   symbol_begin ();
   1309      1.1     skrll   frag_init ();
   1310      1.1     skrll   subsegs_begin ();
   1311      1.1     skrll   read_begin ();
   1312      1.1     skrll   input_scrub_begin ();
   1313      1.1     skrll   expr_begin ();
   1314      1.1     skrll 
   1315      1.1     skrll   /* It has to be called after dump_statistics ().  */
   1316      1.1     skrll   xatexit (close_output_file);
   1317      1.1     skrll 
   1318      1.1     skrll   if (flag_print_statistics)
   1319      1.1     skrll     xatexit (dump_statistics);
   1320      1.1     skrll 
   1321      1.1     skrll   macro_strip_at = 0;
   1322      1.1     skrll #ifdef TC_I960
   1323      1.1     skrll   macro_strip_at = flag_mri;
   1324      1.1     skrll #endif
   1325      1.1     skrll 
   1326      1.1     skrll   macro_init (flag_macro_alternate, flag_mri, macro_strip_at, macro_expr);
   1327      1.1     skrll 
   1328  1.1.1.2  christos   PROGRESS (1);
   1329  1.1.1.2  christos 
   1330  1.1.1.2  christos   output_file_create (out_file_name);
   1331      1.1     skrll   gas_assert (stdoutput != 0);
   1332      1.1     skrll 
   1333      1.1     skrll   dot_symbol_init ();
   1334      1.1     skrll 
   1335      1.1     skrll #ifdef tc_init_after_args
   1336      1.1     skrll   tc_init_after_args ();
   1337      1.1     skrll #endif
   1338  1.1.1.2  christos 
   1339  1.1.1.2  christos   itbl_init ();
   1340  1.1.1.3  christos 
   1341  1.1.1.3  christos   dwarf2_init ();
   1342  1.1.1.3  christos 
   1343      1.1     skrll   local_symbol_make (".gasversion.", absolute_section,
   1344      1.1     skrll 		     BFD_VERSION / 10000UL, &predefined_address_frag);
   1345      1.1     skrll 
   1346      1.1     skrll   /* Now that we have fully initialized, and have created the output
   1347      1.1     skrll      file, define any symbols requested by --defsym command line
   1348      1.1     skrll      arguments.  */
   1349      1.1     skrll   while (defsyms != NULL)
   1350      1.1     skrll     {
   1351      1.1     skrll       symbolS *sym;
   1352      1.1     skrll       struct defsym_list *next;
   1353      1.1     skrll 
   1354      1.1     skrll       sym = symbol_new (defsyms->name, absolute_section, defsyms->value,
   1355      1.1     skrll 			&zero_address_frag);
   1356      1.1     skrll       /* Make symbols defined on the command line volatile, so that they
   1357      1.1     skrll 	 can be redefined inside a source file.  This makes this assembler's
   1358      1.1     skrll 	 behaviour compatible with earlier versions, but it may not be
   1359      1.1     skrll 	 completely intuitive.  */
   1360      1.1     skrll       S_SET_VOLATILE (sym);
   1361      1.1     skrll       symbol_table_insert (sym);
   1362      1.1     skrll       next = defsyms->next;
   1363      1.1     skrll       free (defsyms);
   1364      1.1     skrll       defsyms = next;
   1365      1.1     skrll     }
   1366      1.1     skrll 
   1367      1.1     skrll   PROGRESS (1);
   1368      1.1     skrll 
   1369      1.1     skrll   /* Assemble it.  */
   1370      1.1     skrll   perform_an_assembly_pass (argc, argv);
   1371      1.1     skrll 
   1372      1.1     skrll   cond_finish_check (-1);
   1373      1.1     skrll 
   1374      1.1     skrll #ifdef md_end
   1375      1.1     skrll   md_end ();
   1376      1.1     skrll #endif
   1377      1.1     skrll 
   1378      1.1     skrll #if defined OBJ_ELF || defined OBJ_MAYBE_ELF
   1379      1.1     skrll   if ((flag_execstack || flag_noexecstack)
   1380      1.1     skrll       && OUTPUT_FLAVOR == bfd_target_elf_flavour)
   1381      1.1     skrll     {
   1382  1.1.1.8  christos       segT gnustack;
   1383      1.1     skrll 
   1384  1.1.1.4  christos       gnustack = subseg_new (".note.GNU-stack", 0);
   1385      1.1     skrll       bfd_set_section_flags (gnustack,
   1386      1.1     skrll 			     SEC_READONLY | (flag_execstack ? SEC_CODE : 0));
   1387      1.1     skrll 
   1388      1.1     skrll     }
   1389      1.1     skrll #endif
   1390      1.1     skrll 
   1391      1.1     skrll   /* If we've been collecting dwarf2 .debug_line info, either for
   1392  1.1.1.4  christos      assembly debugging or on behalf of the compiler, emit it now.  */
   1393      1.1     skrll   dwarf2_finish ();
   1394      1.1     skrll 
   1395      1.1     skrll   /* If we constructed dwarf2 .eh_frame info, either via .cfi
   1396  1.1.1.4  christos      directives from the user or by the backend, emit it now.  */
   1397  1.1.1.4  christos   cfi_finish ();
   1398  1.1.1.4  christos 
   1399  1.1.1.4  christos   keep_it = 0;
   1400  1.1.1.4  christos   if (seen_at_least_1_file ())
   1401  1.1.1.4  christos     {
   1402  1.1.1.4  christos       int n_warns, n_errs;
   1403  1.1.1.4  christos       char warn_msg[50];
   1404      1.1     skrll       char err_msg[50];
   1405  1.1.1.4  christos 
   1406  1.1.1.4  christos       write_object_file ();
   1407      1.1     skrll 
   1408  1.1.1.6  christos       n_warns = had_warnings ();
   1409  1.1.1.6  christos       n_errs = had_errors ();
   1410  1.1.1.6  christos 
   1411  1.1.1.6  christos       sprintf (warn_msg,
   1412  1.1.1.4  christos 	       ngettext ("%d warning", "%d warnings", n_warns), n_warns);
   1413  1.1.1.4  christos       sprintf (err_msg,
   1414  1.1.1.4  christos 	       ngettext ("%d error", "%d errors", n_errs), n_errs);
   1415  1.1.1.4  christos       if (flag_fatal_warnings && n_warns != 0)
   1416  1.1.1.4  christos 	{
   1417  1.1.1.4  christos 	  if (n_errs == 0)
   1418  1.1.1.4  christos 	    as_bad (_("%s, treating warnings as errors"), warn_msg);
   1419  1.1.1.4  christos 	  n_errs += n_warns;
   1420  1.1.1.4  christos 	}
   1421  1.1.1.4  christos 
   1422  1.1.1.4  christos       if (n_errs == 0)
   1423  1.1.1.4  christos 	keep_it = 1;
   1424  1.1.1.4  christos       else if (flag_always_generate_output)
   1425  1.1.1.4  christos 	{
   1426  1.1.1.4  christos 	  /* The -Z flag indicates that an object file should be generated,
   1427  1.1.1.4  christos 	     regardless of warnings and errors.  */
   1428  1.1.1.4  christos 	  keep_it = 1;
   1429  1.1.1.4  christos 	  fprintf (stderr, _("%s, %s, generating bad object file\n"),
   1430      1.1     skrll 		   err_msg, warn_msg);
   1431      1.1     skrll 	}
   1432      1.1     skrll     }
   1433      1.1     skrll 
   1434      1.1     skrll   fflush (stderr);
   1435      1.1     skrll 
   1436      1.1     skrll #ifndef NO_LISTING
   1437      1.1     skrll   listing_print (listing_filename, argv_orig);
   1438      1.1     skrll #endif
   1439      1.1     skrll 
   1440      1.1     skrll   input_scrub_end ();
   1441      1.1     skrll 
   1442      1.1     skrll   END_PROGRESS (myname);
   1443  1.1.1.4  christos 
   1444      1.1     skrll   /* Use xexit instead of return, because under VMS environments they
   1445      1.1     skrll      may not place the same interpretation on the value given.  */
   1446      1.1     skrll   if (had_errors () != 0)
   1447      1.1     skrll     xexit (EXIT_FAILURE);
   1448      1.1     skrll 
   1449      1.1     skrll   /* Only generate dependency file if assembler was successful.  */
   1450      1.1     skrll   print_dependencies ();
   1451                    
   1452                      xexit (EXIT_SUCCESS);
   1453                    }
   1454