home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / gcc-2.7.2.1-diffs.gz / gcc-2.7.2.1-diffs
Text File  |  1996-10-13  |  3MB  |  67,556 lines

  1. This file contains patches that transform the baseline version into
  2. the amiga version.  Assuming that you have unarchived the baseline
  3. version in the current directory, just run the command:
  4.  
  5.     patch -p1 -E -b .pbak <diff-file
  6.  
  7. where 'diff-file' is this patch file.  After running patch you should
  8. remove all the generated *.pbak files, and look for any *.rej files
  9. that indicate a problem patching the baseline source.
  10.  
  11. diff -rup --new-file baseline/fsf/gcc/ChangeLog amiga/fsf/gcc/ChangeLog
  12. --- baseline/fsf/gcc/ChangeLog    Wed Jul 24 14:31:12 1996
  13. +++ amiga/fsf/gcc/ChangeLog    Sat Oct  5 13:36:13 1996
  14. @@ -1,3 +1,61 @@
  15. +Sat Oct  5 13:35:23 1996  Fred Fish  <fnf@ninemoons.com>
  16. +
  17. +    * Makefile.in (install-common): Arranged to install cpp as
  18. +    $(bindir)/cpp for the sake of some programs that really want
  19. +    to use cpp directly and where "gcc -E" does not work.
  20. +
  21. +Tue Oct  1 08:50:59 1996  Fred Fish  <fnf@ninemoons.com>
  22. +
  23. +    * config/m68k/amigaos.h: Undef PCC_STATIC_STRUCT_RETURN
  24. +
  25. +Tue Sep 17 19:33:11 1996  Kamil Iskra  <iskra@student.uci.agh.edu.pl>
  26. +
  27. +    * config/m68k/amigaos.c (amiga_restore_a4): New function.
  28. +    * config/m68k/amigaos.h (PROLOGUE_EXTRA_SAVE,
  29. +    EPILOGUE_EXTRA_RESTORE, SUBTARGET_INITIAL_FP_OFFSET): Use it.
  30. +
  31. +    * config/m68k/amigaos.c (amigaos_use_return_insn): New
  32. +    function, to fix yet another problem with a4 restoring in
  33. +    functions without a frame pointer.
  34. +    * config/m68k/amigaos.h (USE_RETURN_INSN): Define.
  35. +
  36. +    * reload1.c: Undo last change.
  37. +
  38. +Sun Sep 15 13:14:50 1996  Kamil Iskra  <iskra@student.uci.agh.edu.pl>
  39. +
  40. +    * config/m68k/m68k.c (output_function_prologue): Add support
  41. +    for '-flarge-baserel' to stack checking/extension.
  42. +
  43. +Fri Sep 13 21:48:22 1996  Kamil Iskra  <iskra@student.uci.agh.edu.pl>
  44. +
  45. +    * config/m68k/m68k.h (INITIAL_FRAME_POINTER_OFFSET): Add
  46. +    support for SUBTARGET_INITIAL_FP_OFFSET.
  47. +    * config/m68k/amigaos.h (SUBTARGET_INITIAL_FP_OFFSET): Define
  48. +    to fix problems with a4 restoring without a frame pointer.
  49. +    * reload1.c: include "tree.h".
  50. +
  51. +Fri Sep  6 18:36:38 1996   Daniel Verite  <daniel@brainstorm.eu.org>
  52. +
  53. +        * config/m68k/amigaos.h (CONDITIONAL_REGISTER_USAGE): add
  54. +        the base register to `call_used_regs' when large-baserel is used.
  55. +
  56. +Wed Sep  4 11:42:40 1996  Kamil Iskra  <iskra@student.uci.agh.edu.pl>
  57. +
  58. +        * config/m68k/amigaos.h (SUBTARGET_SWITCHES): Rename
  59. +        -mnostackcheck and -mnostackextend to -mno-stackcheck and
  60. +        -mno-stackextend.
  61. +
  62. +Thu Aug 22 20:48:39 1996  Fred Fish  <fnf@ninemoons.com>
  63. +
  64. +    * config/m68k/amigaos.h:  Remove flag_omit_frame_pointer kludge
  65. +    since it interferes with debugging.
  66. +
  67. +Sun Aug 11 19:27:07 1996  Kamil Iskra <iskra@student.uci.agh.edu.pl>
  68. +
  69. +    * config/m68k/xm-amigaos.h: Fix handling of O_CASE.
  70. +    * explow.c (allocate_dynamic_stack_space): Remove two warnings.
  71. +    * toplev.c (main): Remove a warning.
  72. +
  73.  Sat Jun 29 12:33:39 1996  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
  74.  
  75.      * Version 2.7.2.1 released.
  76. diff -rup --new-file baseline/fsf/gcc/ChangeLog.4 amiga/fsf/gcc/ChangeLog.4
  77. --- baseline/fsf/gcc/ChangeLog.4    Thu Mar  5 11:59:12 1992
  78. +++ amiga/fsf/gcc/ChangeLog.4    Sat Sep 28 00:00:00 1996
  79. @@ -1106,7 +1106,7 @@ Mon Dec 30 01:44:21 1991  Richard Stallm
  80.      * protoize.c (do_processing): Fix setting syscalls_absolute_filename.
  81.  
  82.      * configure (m68k-*-sysv4*, m68k-*-amix*): New alternatives.
  83. -    * config.sub (*-commodore): Default OS to Amigados.
  84. +    * config.sub (*-commodore): Default OS to AmigaOS
  85.      (-amix*): Allow this as input.
  86.      (amiga): New abbreviation.
  87.  
  88. diff -rup --new-file baseline/fsf/gcc/ChangeLog.7 amiga/fsf/gcc/ChangeLog.7
  89. --- baseline/fsf/gcc/ChangeLog.7    Mon Jul 26 14:49:20 1993
  90. +++ amiga/fsf/gcc/ChangeLog.7    Sat Sep 28 00:00:00 1996
  91. @@ -9486,7 +9486,7 @@ Fri Nov 20 05:24:16 1992  Jim Blandy  (j
  92.      New manufacturers recognized not to be operating systems: High
  93.      Level Hardware (highlevel, defaults to using BSD), Gould
  94.      (gould, defaults to System V), Commodore (cbm, defaults to
  95. -    amigados), National Semiconductor (ns, defaults to Genix), and
  96. +    amigaos), National Semiconductor (ns, defaults to Genix), and
  97.      Masscomp (masscomp, defaults to RTU).
  98.      Recognize the NS1600 (ns16k) and the Clipper (clipper) as
  99.      processors.
  100. diff -rup --new-file baseline/fsf/gcc/INSTALL amiga/fsf/gcc/INSTALL
  101. --- baseline/fsf/gcc/INSTALL    Tue Jul  2 04:19:38 1996
  102. +++ amiga/fsf/gcc/INSTALL    Sat Sep 28 00:00:00 1996
  103. @@ -452,7 +452,7 @@ is equivalent to `vax-dec-ultrix4.2'.
  104.  
  105.     Here is a list of system types:
  106.  
  107. -     386bsd, aix, acis, amigados, aos, aout, bosx, bsd, clix, coff,
  108. +     386bsd, aix, acis, amigaos, aos, aout, bosx, bsd, clix, coff,
  109.       ctix, cxux, dgux, dynix, ebmon, ecoff, elf, esix, freebsd, hms,
  110.       genix, gnu, gnu/linux, hiux, hpux, iris, irix, isc, luna, lynxos,
  111.       mach, minix, msdos, mvs, netbsd, newsos, nindy, ns, osf, osfrose,
  112. diff -rup --new-file baseline/fsf/gcc/Makefile.in amiga/fsf/gcc/Makefile.in
  113. --- baseline/fsf/gcc/Makefile.in    Sun Nov 26 12:44:25 1995
  114. +++ amiga/fsf/gcc/Makefile.in    Sat Oct  5 13:36:24 1996
  115. @@ -66,10 +66,12 @@ OLDAR_FLAGS = qc
  116.  AR_FLAGS = rc
  117.  SHELL = /bin/sh
  118.  # on sysV, define this as cp.
  119. -INSTALL = install -c
  120. +INSTALL = cp
  121.  # These permit overriding just for certain files.
  122.  INSTALL_PROGRAM = $(INSTALL)
  123.  INSTALL_DATA = $(INSTALL)
  124. +LN_S = ln -s
  125. +LN = ln
  126.  MAKEINFO = makeinfo
  127.  TEXI2DVI = texi2dvi
  128.  # For GNUmake: let us decide what gets passed to recursive makes.
  129. @@ -99,7 +101,7 @@ CCLIBFLAGS = -O
  130.  OLDAR = ar
  131.  
  132.  # Target to use when installing include directory.  Either
  133. -# install-headers-tar or install-headers-cpio.
  134. +# install-headers-tar or install-headers-cpio or install-headers-cp
  135.  INSTALL_HEADERS_DIR = install-headers-tar
  136.  
  137.  # Header files that are made available under the same name
  138. @@ -181,12 +183,15 @@ mainversion=`sed -e 's/.*\"\([0-9]*\.[0-
  139.  srcdir = .
  140.  # Common prefix for installation directories.
  141.  # NOTE: This directory must exist when you start installation.
  142. -prefix = /usr/local
  143. +prefix = /ade
  144.  # Directory in which to put localized header files. On the systems with
  145.  # gcc as the native cc, `local_prefix' may not be `prefix' which is
  146.  # `/usr'.
  147. +# Similar considerations apply for toolkits located on non-writable storage,
  148. +# such as CD-ROM, where we need a completely separate place to put local
  149. +# include files.
  150.  # NOTE: local_prefix *should not* default from prefix.
  151. -local_prefix = /usr/local
  152. +local_prefix = /ade
  153.  # Directory in which to put host dependent programs and libraries
  154.  exec_prefix = $(prefix)
  155.  # Directory in which to put the executable for the command `gcc'
  156. @@ -204,6 +209,8 @@ includedir = $(local_prefix)/include
  157.  assertdir = $(tooldir)/include
  158.  # where the info files go
  159.  infodir = $(prefix)/info
  160. +# where the guide files go
  161. +guidedir = $(prefix)/guide
  162.  # Extension (if any) to put in installed man-page filename.
  163.  manext = .1
  164.  objext = .o
  165. @@ -285,6 +292,10 @@ EXTRA_OBJS =
  166.  # the gcc driver.
  167.  EXTRA_GCC_OBJS =
  168.  
  169. +# List of extra object files that should be compiled and linked with
  170. +# the preprocessor (cpp).
  171. +EXTRA_CPP_OBJS =
  172. +
  173.  # List of additional header files to install.
  174.  # Often this is edited directly by `configure'.
  175.  EXTRA_HEADERS =
  176. @@ -366,7 +377,8 @@ GCC_INSTALL_NAME = `t='$(program_transfo
  177.  GCC_CROSS_NAME = `t='$(program_transform_cross_name)'; echo gcc | sed $$t`
  178.  
  179.  # Choose the real default target.
  180. -ALL=all.internal
  181. +# ADE hack: Always build doc files when making everything else.
  182. +ALL=all.internal doc
  183.  
  184.  # Choose the real install target.
  185.  INSTALL_TARGET=install-normal
  186. @@ -922,6 +934,8 @@ libgcc.a: $(LIBGCC1) $(LIBGCC2)
  187.      -(cd tmpcopy; chmod +w * > /dev/null 2>&1)
  188.      (cd tmpcopy; $(AR) x ../$(LIBGCC2))
  189.      (cd tmpcopy; $(AR) $(AR_FLAGS) ../tmplibgcc.a *$(objext))
  190. +# Makes sure that the lock on tmpcopy has time to disappear.
  191. +    sleep 2
  192.      rm -rf tmpcopy
  193.      -if $(RANLIB_TEST) ; then $(RANLIB) tmplibgcc.a; else true; fi
  194.  # Actually build it in tmplibgcc.a, then rename at end,
  195. @@ -997,7 +1011,7 @@ libobjc.a: cc1obj stmp-int-hdrs libgcc2.
  196.        GCC_FOR_TARGET="$${thisdir1}/xgcc -B$${thisdir1}/" \
  197.        GCC_CFLAGS="$(GCC_CFLAGS)"
  198.      -rm -f libobjc.a
  199. -    ln objc/libobjc.a . >/dev/null 2>&1 || cp objc/libobjc.a .
  200. +    $(LN) objc/libobjc.a . >/dev/null 2>&1 || cp objc/libobjc.a .
  201.      -if $(RANLIB_TEST) ; then $(RANLIB) libobjc.a; else true; fi
  202.  
  203.  # This is used by objc/Makefile if the user runs that directly.
  204. @@ -1049,28 +1063,30 @@ stamp-crtS:    crtstuff.c $(GCC_PASSES) $(C
  205.  
  206.  # C language specific files.
  207.  
  208. -c-parse.o : $(srcdir)/c-parse.c $(CONFIG_H) $(TREE_H) c-lex.h \
  209. -    $(srcdir)/c-parse.h c-tree.h input.h flags.h
  210. -    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c $(srcdir)/c-parse.c
  211. -$(srcdir)/c-parse.h: $(srcdir)/c-parse.c
  212. -$(srcdir)/c-parse.c: $(srcdir)/c-parse.y
  213. -    cd $(srcdir); $(BISON) $(BISONFLAGS) -d c-parse.y -o c-parse.c
  214. -$(srcdir)/c-parse.y: c-parse.in
  215. +c-parse.o : c-parse.c $(CONFIG_H) $(TREE_H) c-lex.h \
  216. +    c-parse.h c-tree.h input.h flags.h
  217. +    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c c-parse.c
  218. +c-parse.h: c-parse.c
  219. +c-parse.c: c-parse.y
  220. +    $(BISON) $(BISONFLAGS) -d c-parse.y -o c-parse.c
  221. +c-parse.y: c-parse.in
  222. +    echo '/*WARNING: This file is automatically generated!*/' >tmp-c-parse.y
  223.      sed -e "/^ifobjc$$/,/^end ifobjc$$/d" \
  224.        -e "/^ifc$$/d" -e "/^end ifc$$/d" \
  225. -      $(srcdir)/c-parse.in >tmp-c-parse.y
  226. -    $(srcdir)/move-if-change tmp-c-parse.y $(srcdir)/c-parse.y
  227. +      $(srcdir)/c-parse.in >>tmp-c-parse.y
  228. +    $(srcdir)/move-if-change tmp-c-parse.y c-parse.y
  229.  
  230. -$(srcdir)/c-gperf.h: c-parse.gperf
  231. +c-gperf.h: c-parse.gperf
  232. +    echo '/*WARNING: This file is automatically generated!*/' >tmp-gperf.h
  233.      gperf -p -j1 -i 1 -g -o -t -G -N is_reserved_word -k1,3,$$ \
  234. -       $(srcdir)/c-parse.gperf >tmp-gperf.h
  235. -     $(srcdir)/move-if-change tmp-gperf.h $(srcdir)/c-gperf.h
  236. +       $(srcdir)/c-parse.gperf >>tmp-gperf.h
  237. +    $(srcdir)/move-if-change tmp-gperf.h c-gperf.h
  238.  
  239.  c-decl.o : c-decl.c $(CONFIG_H) $(TREE_H) c-tree.h c-lex.h flags.h output.h
  240.  c-typeck.o : c-typeck.c $(CONFIG_H) $(TREE_H) c-tree.h flags.h output.h
  241.  c-lang.o : c-lang.c $(CONFIG_H) $(TREE_H)
  242. -c-lex.o : c-lex.c $(CONFIG_H) $(TREE_H) c-lex.h c-tree.h $(srcdir)/c-parse.h \
  243. -    input.h flags.h $(srcdir)/c-gperf.h c-pragma.h
  244. +c-lex.o : c-lex.c $(CONFIG_H) $(TREE_H) c-lex.h c-tree.h c-parse.h \
  245. +    input.h flags.h c-gperf.h c-pragma.h
  246.  c-aux-info.o : c-aux-info.c  $(CONFIG_H) $(TREE_H) c-tree.h flags.h
  247.  c-convert.o : c-convert.c $(CONFIG_H) $(TREE_H) flags.h
  248.  c-pragma.o: c-pragma.c $(CONFIG_H) $(TREE_H) c-pragma.h
  249. @@ -1079,7 +1095,7 @@ c-iterate.o: c-iterate.c $(CONFIG_H) $(T
  250.  # To make a configuration always use collect2, set USE_COLLECT2 to ld.
  251.  ld: collect2
  252.      rm -f ld$(exeext)
  253. -    ln collect2$(exeext) ld$(exeext) > /dev/null 2>&1 \
  254. +    $(LN) collect2$(exeext) ld$(exeext) > /dev/null 2>&1 \
  255.         || cp collect2$(exeext) ld$(exeext)
  256.  
  257.  collect2 : collect2.o cplus-dem.o underscore.o version.o $(LIBDEPS)
  258. @@ -1112,19 +1128,20 @@ stamp-under: $(GCC_PASSES)
  259.  
  260.  # Objective C language specific files.
  261.  
  262. -objc-parse.o : $(srcdir)/objc-parse.c $(CONFIG_H) $(TREE_H) c-lex.h \
  263. +objc-parse.o : objc-parse.c $(CONFIG_H) $(TREE_H) c-lex.h \
  264.     c-tree.h input.h flags.h objc-act.h
  265. -    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c $(srcdir)/objc-parse.c
  266. -$(srcdir)/objc-parse.c : $(srcdir)/objc-parse.y
  267. -    cd $(srcdir); $(BISON) $(BISONFLAGS) objc-parse.y -o objc-parse.c
  268. -$(srcdir)/objc-parse.y: $(srcdir)/c-parse.in
  269. +    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c objc-parse.c
  270. +objc-parse.c : objc-parse.y
  271. +    $(BISON) $(BISONFLAGS) objc-parse.y -o objc-parse.c
  272. +objc-parse.y: c-parse.in
  273. +    echo '/*WARNING: This file is automatically generated!*/' >tmp-objc-prs.y
  274.      sed -e "/^ifc$$/,/^end ifc$$/d" \
  275.        -e "/^ifobjc$$/d" -e "/^end ifobjc$$/d" \
  276. -      $(srcdir)/c-parse.in >tmp-objc-prs.y
  277. -    $(srcdir)/move-if-change tmp-objc-prs.y $(srcdir)/objc-parse.y
  278. +      $(srcdir)/c-parse.in >>tmp-objc-prs.y
  279. +    $(srcdir)/move-if-change tmp-objc-prs.y objc-parse.y
  280.  
  281.  objc-act.o : objc-act.c $(CONFIG_H) $(TREE_H) $(RTL_H) c-tree.h c-lex.h \
  282. -   flags.h objc-act.h input.h function.h $(srcdir)/c-parse.h
  283. +   flags.h objc-act.h input.h function.h c-parse.h
  284.  
  285.  # A file used by all variants of C.
  286.  
  287. @@ -1550,9 +1567,9 @@ bi-opname: bi-opname.o $(BI_OBJ) $(HOST_
  288.      $(HOST_CC) $(HOST_CFLAGS) $(HOST_LDFLAGS) -o $@ \
  289.       bi-opname.o $(BI_OBJ) $(HOST_LIBS)
  290.  
  291. -$(srcdir)/bi-parser.h: $(srcdir)/bi-parser.c
  292. -$(srcdir)/bi-parser.c: $(srcdir)/bi-parser.y
  293. -    cd $(srcdir); $(BISON) $(BISONFLAGS) -d bi-parser.y -o bi-parser.c
  294. +bi-parser.h: bi-parser.c
  295. +bi-parser.c: bi-parser.y
  296. +    $(BISON) $(BISONFLAGS) -d $(srcdir)/bi-parser.y -o bi-parser.c
  297.  
  298.  bi-parser.o: $(srcdir)/bi-parser.c bi-defs.h $(build_xm_file)
  299.      $(HOST_CC) -c $(HOST_CFLAGS) $(HOST_CPPFLAGS) $(INCLUDES) \
  300. @@ -1606,15 +1623,15 @@ bytecode.maintainer-clean: bytecode.clea
  301.  # Making the preprocessor
  302.  cpp: $(CCCP)
  303.      -rm -f cpp$(exeext)
  304. -    ln $(CCCP)$(exeext) cpp$(exeext) > /dev/null 2>&1 \
  305. +    $(LN) $(CCCP)$(exeext) cpp$(exeext) > /dev/null 2>&1 \
  306.       || cp $(CCCP)$(exeext) cpp$(exeext)
  307. -cccp: cccp.o cexp.o version.o $(LIBDEPS)
  308. +cccp: cccp.o cexp.o version.o $(EXTRA_CPP_OBJS) $(LIBDEPS)
  309.      $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ cccp.o cexp.o \
  310. -      version.o $(LIBS)
  311. -cexp.o: $(srcdir)/cexp.c $(CONFIG_H)
  312. -    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c $(srcdir)/cexp.c
  313. -$(srcdir)/cexp.c: $(srcdir)/cexp.y
  314. -    cd $(srcdir); $(BISON) -o cexp.c cexp.y
  315. +      version.o $(EXTRA_CPP_OBJS) $(LIBS)
  316. +cexp.o: cexp.c $(CONFIG_H)
  317. +    $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c cexp.c
  318. +cexp.c: cexp.y
  319. +    $(BISON) $(BISONFLAGS) $(srcdir)/cexp.y -o cexp.c
  320.  
  321.  cccp.o: cccp.c $(CONFIG_H) pcp.h version.c config.status
  322.  # The reason we use $(libdir)/g++-include rather than using libsubdir
  323. @@ -1622,6 +1639,7 @@ cccp.o: cccp.c $(CONFIG_H) pcp.h version
  324.      $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
  325.        -DGCC_INCLUDE_DIR=\"$(libsubdir)/include\" \
  326.        -DGPLUSPLUS_INCLUDE_DIR=\"$(gxx_include_dir)\" \
  327. +      -DGPLUSPLUS_INCLUDE_DIR_SPECIFIC=\"$(libsubdir)/g++-include\" \
  328.        -DLOCAL_INCLUDE_DIR=\"$(includedir)\" \
  329.        -DCROSS_INCLUDE_DIR=\"$(libsubdir)/sys-include\" \
  330.        -DTOOL_INCLUDE_DIR=\"$(tooldir)/include\" \
  331. @@ -1864,30 +1882,38 @@ stmp-fixproto: fixhdr.ready fixproto stm
  332.  
  333.  # Remake the info files.
  334.  
  335. -doc: info
  336. -info: $(srcdir)/cpp.info $(srcdir)/gcc.info lang.info
  337. +doc: info guide
  338. +info: cpp.info gcc.info lang.info
  339. +guide: cpp.guide gcc.guide lang.guide
  340.  
  341. -$(srcdir)/cpp.info: cpp.texi
  342. -    cd $(srcdir); $(MAKEINFO) cpp.texi
  343. +cpp.info: cpp.texi
  344. +    $(MAKEINFO) -I$(srcdir) $(srcdir)/cpp.texi --output=$@
  345.  
  346. -$(srcdir)/gcc.info: gcc.texi extend.texi install.texi invoke.texi \
  347. +cpp.guide: cpp.texi
  348. +    $(MAKEINFO) -I$(srcdir) $(srcdir)/cpp.texi --output=$@ --amiga-39 --no-split
  349. +
  350. +gcc.info: gcc.texi extend.texi install.texi invoke.texi \
  351.          md.texi rtl.texi tm.texi 
  352. -    cd $(srcdir); $(MAKEINFO) gcc.texi
  353. +    $(MAKEINFO) -I$(srcdir) $(srcdir)/gcc.texi --output=$@
  354.  
  355. -dvi: $(srcdir)/gcc.dvi $(srcdir)/cpp.dvi lang.dvi
  356. +gcc.guide: gcc.texi extend.texi install.texi invoke.texi \
  357. +        md.texi rtl.texi tm.texi 
  358. +    $(MAKEINFO) -I$(srcdir) $(srcdir)/gcc.texi --output=$@ --amiga-39 --no-split
  359. +
  360. +dvi: gcc.dvi cpp.dvi lang.dvi
  361.  
  362.  # This works with GNU Make's default rule.
  363. -$(srcdir)/gcc.dvi: gcc.texi extend.texi install.texi invoke.texi \
  364. +gcc.dvi: gcc.texi extend.texi install.texi invoke.texi \
  365.          md.texi rtl.texi tm.texi 
  366.      $(TEXI2DVI) $<
  367.  
  368.  # This works with GNU Make's default rule.
  369. -$(srcdir)/cpp.dvi: cpp.texi
  370. +cpp.dvi: cpp.texi
  371.      $(TEXI2DVI) $<
  372.  
  373. -$(srcdir)/INSTALL: install1.texi install.texi
  374. -    $(MAKEINFO) -D INSTALLONLY --no-header --no-split \
  375. -      `echo $(srcdir)/install1.texi | sed 's,^\./,,'`
  376. +INSTALL: install1.texi install.texi
  377. +    $(MAKEINFO) -I$(srcdir) -D INSTALLONLY --no-header --no-split \
  378. +      $(srcdir)/install1.texi --output=$@
  379.  
  380.  # Deletion of files made during compilation.
  381.  # There are four levels of this:
  382. @@ -1979,6 +2005,7 @@ distclean: clean bytecode.distclean lang
  383.      -rm -f Makefile specs.h options.h *.oaux
  384.      -rm -fr stage1 stage2 stage3 stage4
  385.      -rm -f */stage1 */stage2 */stage3 */stage4 */include
  386. +    -rm -f cp-parse.output
  387.      -rm -f objc-parse.output
  388.      -rm -f c-parse.output
  389.      -rm -f *.asm
  390. @@ -1999,9 +2026,11 @@ extraclean: distclean lang.extraclean
  391.      -rm -f */*.dvi */*.oaux */*.d */*.[zZ] */*.gz
  392.      -rm -f */*.tar */*.xtar */*diff */*.diff.* */*.tar.* */*.xtar.* */*diffs
  393.      -rm -f */*lose */*.s */*.s[0-9] */*.i
  394. +    -rm -f *.guide
  395.  
  396.  # Get rid of every file that's generated from some other file.
  397.  # Most of these files ARE PRESENT in the GCC distribution.
  398. +# ADE note: These files have been removed from the ADE source tree.
  399.  maintainer-clean: distclean bytecode.maintainer-clean lang.maintainer-clean
  400.      -rm -f c-parse.y c-gperf.h objc-parse.y
  401.      -rm -f objc-parse.c objc-parse.output
  402. @@ -2022,7 +2051,7 @@ install: $(INSTALL_TARGET) ; @true
  403.  # Install the driver last so that the window when things are
  404.  # broken is small.
  405.  install-normal: install-common $(INSTALL_HEADERS) $(INSTALL_LIBGCC) \
  406. -    install-libobjc install-man install-info lang.install-normal install-driver
  407. +    install-libobjc install-man install-info install-guide lang.install-normal install-driver
  408.  
  409.  # Do nothing while making gcc with a cross-compiler. The person who
  410.  # makes gcc for the target machine has to know how to put a complete
  411. @@ -2105,6 +2134,7 @@ install-common: native install-dir $(EXT
  412.      fi
  413.      -rm -f $(libsubdir)/cpp$(exeext)
  414.      $(INSTALL_PROGRAM) cpp$(exeext) $(libsubdir)/cpp$(exeext)
  415. +    $(INSTALL_PROGRAM) cpp$(exeext) $(bindir)/cpp$(exeext)
  416.  
  417.  # Install the driver program as $(target)-gcc
  418.  # and also as either gcc (if native) or $(tooldir)/bin/gcc.
  419. @@ -2120,7 +2150,7 @@ install-driver: xgcc
  420.        rm -f $(bindir)/$(GCC_INSTALL_NAME)$(exeext); \
  421.        $(INSTALL_PROGRAM) xgcc$(exeext) $(bindir)/$(GCC_INSTALL_NAME)$(exeext); \
  422.        rm -f $(bindir)/$(target)-gcc-1$(exeext); \
  423. -      ln $(bindir)/$(GCC_INSTALL_NAME)$(exeext) $(bindir)/$(target)-gcc-1$(exeext) \
  424. +      $(LN) $(bindir)/$(GCC_INSTALL_NAME)$(exeext) $(bindir)/$(target)-gcc-1$(exeext) \
  425.          > /dev/null 2>&1 \
  426.          || cp $(bindir)/$(GCC_INSTALL_NAME)$(exeext) $(bindir)/$(target)-gcc-1$(exeext); \
  427.        mv $(bindir)/$(target)-gcc-1$(exeext) $(bindir)/$(target)-gcc$(exeext); \
  428. @@ -2129,10 +2159,17 @@ install-driver: xgcc
  429.  # Install the info files.
  430.  install-info: doc install-dir lang.install-info
  431.      -rm -f $(infodir)/cpp.info* $(infodir)/gcc.info*
  432. -    cd $(srcdir); for f in cpp.info* gcc.info*; \
  433. +    for f in cpp.info* gcc.info*; \
  434.      do $(INSTALL_DATA) $$f $(infodir)/$$f; done
  435.      -chmod a-x $(infodir)/cpp.info* $(infodir)/gcc.info*
  436.  
  437. +# Install the guide files.
  438. +install-guide: doc install-dir lang.install-info
  439. +    -rm -f $(guidedir)/cpp.guide $(guidedir)/gcc.guide
  440. +    for f in cpp.guide gcc.guide; \
  441. +    do $(INSTALL_DATA) $$f $(guidedir)/$$f; done
  442. +    -chmod a-x $(guidedir)/cpp.guide $(guidedir)/gcc.guide
  443. +
  444.  # Install the man pages.
  445.  install-man: install-dir $(srcdir)/gcc.1 $(srcdir)/cccp.1 lang.install-man
  446.      -if [ -f gcc-cross ] ; then \
  447. @@ -2191,7 +2228,7 @@ install-headers: install-include-dir $(I
  448.          dest=`ls -ld $(libsubdir)/include/$$i | sed -n 's/.*-> //p'`; \
  449.          if expr "$$dest" : "$$dir.*" > /dev/null; then \
  450.            rm -f $(libsubdir)/include/$$i; \
  451. -          ln -s `echo $$i | sed "s|/[^/]*|/..|g" | sed 's|/..$$||'``echo "$$dest" | sed "s|$$dir||"` $(libsubdir)/include/$$i; \
  452. +          $(LN_S) `echo $$i | sed "s|/[^/]*|/..|g" | sed 's|/..$$||'``echo "$$dest" | sed "s|$$dir||"` $(libsubdir)/include/$$i; \
  453.          fi; \
  454.        done; \
  455.      fi
  456. @@ -2214,6 +2251,10 @@ install-headers-tar: stmp-headers $(STMP
  457.  install-headers-cpio: stmp-headers $(STMP_FIXPROTO) install-include-dir
  458.      (cd include; find . -print) | (cd include; cpio -pdum $(libsubdir)/include)
  459.  
  460. +# Install the include directory using simple recursive copy.
  461. +install-headers-cp: stmp-headers install-include-dir
  462. +    cd include; cp -r . $(libsubdir)/include
  463. +
  464.  # Put assert.h where it won't override GNU libc's assert.h.
  465.  # It goes in a dir that is searched after GNU libc's headers;
  466.  # thus, the following conditionals are no longer needed.
  467. @@ -2260,12 +2301,7 @@ uninstall: lang.uninstall
  468.  
  469.  # Update the tags table.
  470.  TAGS: force
  471. -    cd $(srcdir);                            \
  472. -    mkdir temp;                            \
  473. -    mv -f c-parse.[ch] objc-parse.c cexp.c =*.[chy] temp;        \
  474. -    etags *.y *.h *.c;                        \
  475. -    mv temp/* .;                            \
  476. -    rmdir temp
  477. +    objdir=`pwd`; cd $(srcdir); etags *.y *.h *.c -o $$objdir/TAGS;
  478.  
  479.  # Create the distribution tar file.
  480.  #dist: gcc-$(version).tar.gz
  481. @@ -2285,9 +2321,9 @@ gcc.xtar: distdir
  482.  
  483.  # This target exists to do the initial work before the language specific
  484.  # stuff gets done.
  485. -distdir-start: doc $(srcdir)/INSTALL $(srcdir)/c-parse.y $(srcdir)/c-gperf.h \
  486. -  $(srcdir)/objc-parse.y $(srcdir)/c-parse.c $(srcdir)/objc-parse.c \
  487. -  $(srcdir)/cexp.c
  488. +distdir-start: doc $(srcdir)/INSTALL c-parse.y c-gperf.h \
  489. +  objc-parse.y c-parse.c objc-parse.c \
  490. +  cexp.c
  491.      @if grep -s "for version ${mainversion}" gcc.texi > /dev/null; \
  492.      then true; \
  493.      else echo "You must update the version number in \`gcc.texi'"; sleep 10;\
  494. @@ -2306,7 +2342,7 @@ distdir-start: doc $(srcdir)/INSTALL $(s
  495.      mkdir tmp/ginclude
  496.      mkdir tmp/objc
  497.      for file in *[0-9a-zA-Z+]; do \
  498. -      ln $$file tmp > /dev/null 2>&1 || cp $$file tmp; \
  499. +      $(LN) $$file tmp > /dev/null 2>&1 || cp $$file tmp; \
  500.      done
  501.      cd config; \
  502.      for file in *[0-9a-zA-Z+]; do \
  503. @@ -2314,25 +2350,25 @@ distdir-start: doc $(srcdir)/INSTALL $(s
  504.          mkdir ../tmp/config/$$file; \
  505.          cd $$file; \
  506.          for subfile in *[0-9a-zA-Z+]; do \
  507. -          ln $$subfile ../../tmp/config/$$file >/dev/null 2>&1 \
  508. +          $(LN) $$subfile ../../tmp/config/$$file >/dev/null 2>&1 \
  509.            || cp $$subfile ../../tmp/config/$$file; \
  510.          done; \
  511.          cd ..; \
  512.        else \
  513. -        ln $$file ../tmp/config >/dev/null 2>&1 \
  514. +        $(LN) $$file ../tmp/config >/dev/null 2>&1 \
  515.          || cp $$file ../tmp/config; \
  516.        fi; \
  517.      done
  518.      cd ginclude; \
  519.      for file in *[0-9a-zA-Z+]; do \
  520. -      ln $$file ../tmp/ginclude >/dev/null 2>&1 \
  521. +      $(LN) $$file ../tmp/ginclude >/dev/null 2>&1 \
  522.         || cp $$file ../tmp/ginclude; \
  523.      done
  524.      cd objc; \
  525.      for file in *[0-9a-zA-Z+]; do \
  526. -      ln $$file ../tmp/objc >/dev/null 2>&1 || cp $$file ../tmp/objc; \
  527. +      $(LN) $$file ../tmp/objc >/dev/null 2>&1 || cp $$file ../tmp/objc; \
  528.      done
  529. -    ln .gdbinit tmp
  530. +    $(LN) .gdbinit tmp
  531.  
  532.  # Finish making `distdir', after the languages have done their thing.
  533.  distdir-finish:
  534. @@ -2457,9 +2493,9 @@ stage1-start:
  535.      -mv $(STAGESTUFF) stage1
  536.  # Copy as/ld if they exist to stage dir, so that running xgcc from the stage
  537.  # dir will work properly.
  538. -    -if [ -f as$(exeext) ] ; then ln -s ../as$(exeext) stage1 || cp as$(exeext) stage1 ; else true ; fi
  539. -    -if [ -f ld$(exeext) ] ; then ln -s ../ld$(exeext) stage1 || cp ld$(exeext) stage1 ; else true ; fi
  540. -    -if [ -f collect-ld$(exeext) ] ; then ln -s ../collect-ld$(exeext) stage1 || cp collect-ld$(exeext) stage1 ; else true ; fi
  541. +    -if [ -f as$(exeext) ] ; then $(LN_S) ../as$(exeext) stage1 || cp as$(exeext) stage1 ; else true ; fi
  542. +    -if [ -f ld$(exeext) ] ; then $(LN_S) ../ld$(exeext) stage1 || cp ld$(exeext) stage1 ; else true ; fi
  543. +    -if [ -f collect-ld$(exeext) ] ; then $(LN_S) ../collect-ld$(exeext) stage1 || cp collect-ld$(exeext) stage1 ; else true ; fi
  544.      -rm -f stage1/libgcc.a
  545.      -cp libgcc.a stage1
  546.      -if $(RANLIB_TEST) ; then $(RANLIB) stage1/libgcc.a; else true; fi
  547. @@ -2474,9 +2510,9 @@ stage2-start:
  548.      -mv $(STAGESTUFF) stage2
  549.  # Copy as/ld if they exist to stage dir, so that running xgcc from the stage
  550.  # dir will work properly.
  551. -    -if [ -f as$(exeext) ] ; then ln -s ../as$(exeext) stage2 || cp as$(exeext) stage2 ; else true ; fi
  552. -    -if [ -f ld$(exeext) ] ; then ln -s ../ld$(exeext) stage2 || cp ld$(exeext) stage2 ; else true ; fi
  553. -    -if [ -f collect-ld ] ; then ln -s ../collect-ld$(exeext) stage2 || cp collect-ld$(exeext) stage2 ; else true ; fi
  554. +    -if [ -f as$(exeext) ] ; then $(LN_S) ../as$(exeext) stage2 || cp as$(exeext) stage2 ; else true ; fi
  555. +    -if [ -f ld$(exeext) ] ; then $(LN_S) ../ld$(exeext) stage2 || cp ld$(exeext) stage2 ; else true ; fi
  556. +    -if [ -f collect-ld ] ; then $(LN_S) ../collect-ld$(exeext) stage2 || cp collect-ld$(exeext) stage2 ; else true ; fi
  557.      -rm -f stage2/libgcc.a
  558.      -cp libgcc.a stage2
  559.      -if $(RANLIB_TEST) ; then $(RANLIB) stage2/libgcc.a; else true; fi
  560. @@ -2491,9 +2527,9 @@ stage3-start:
  561.      -mv $(STAGESTUFF) stage3
  562.  # Copy as/ld if they exist to stage dir, so that running xgcc from the stage
  563.  # dir will work properly.
  564. -    -if [ -f as$(exeext) ] ; then ln -s ../as$(exeext) stage3 || cp as$(exeext) stage3 ; else true ; fi
  565. -    -if [ -f ld$(exeext) ] ; then ln -s ../ld$(exeext) stage3 || cp ld$(exeext) stage3 ; else true ; fi
  566. -    -if [ -f collect-ld$(exeext) ] ; then ln -s ../collect-ld$(exeext) stage3 || cp collect-ld$(exeext) stage3 ; else true ; fi
  567. +    -if [ -f as$(exeext) ] ; then $(LN_S) ../as$(exeext) stage3 || cp as$(exeext) stage3 ; else true ; fi
  568. +    -if [ -f ld$(exeext) ] ; then $(LN_S) ../ld$(exeext) stage3 || cp ld$(exeext) stage3 ; else true ; fi
  569. +    -if [ -f collect-ld$(exeext) ] ; then $(LN_S) ../collect-ld$(exeext) stage3 || cp collect-ld$(exeext) stage3 ; else true ; fi
  570.      -rm -f stage3/libgcc.a
  571.      -cp libgcc.a stage3
  572.      -if $(RANLIB_TEST) ; then $(RANLIB) stage3/libgcc.a; else true; fi
  573. @@ -2508,9 +2544,9 @@ stage4-start:
  574.      -mv $(STAGESTUFF) stage4
  575.  # Copy as/ld if they exist to stage dir, so that running xgcc from the stage
  576.  # dir will work properly.
  577. -    -if [ -f as$(exeext) ] ; then ln -s ../as$(exeext) stage4 || cp as$(exeext) stage4 ; else true ; fi
  578. -    -if [ -f ld$(exeext) ] ; then ln -s ../ld$(exeext) stage4 || cp ld$(exeext) stage4 ; else true ; fi
  579. -    -if [ -f collect-ld$(exeext) ] ; then ln -s ../collect-ld$(exeext) stage4 || cp collect-ld$(exeext) stage4 ; else true ; fi
  580. +    -if [ -f as$(exeext) ] ; then $(LN_S) ../as$(exeext) stage4 || cp as$(exeext) stage4 ; else true ; fi
  581. +    -if [ -f ld$(exeext) ] ; then $(LN_S) ../ld$(exeext) stage4 || cp ld$(exeext) stage4 ; else true ; fi
  582. +    -if [ -f collect-ld$(exeext) ] ; then $(LN_S) ../collect-ld$(exeext) stage4 || cp collect-ld$(exeext) stage4 ; else true ; fi
  583.      -rm -f stage4/libgcc.a
  584.      -cp libgcc.a stage4
  585.      -if $(RANLIB_TEST) ; then $(RANLIB) stage4/libgcc.a; else true; fi
  586. diff -rup --new-file baseline/fsf/gcc/Product-Info amiga/fsf/gcc/Product-Info
  587. --- baseline/fsf/gcc/Product-Info    Wed Dec 31 17:00:00 1969
  588. +++ amiga/fsf/gcc/Product-Info    Sat Sep 28 00:00:00 1996
  589. @@ -0,0 +1,22 @@
  590. +.name
  591. +gcc
  592. +.fullname
  593. +GNU C/C++/Objective-C compiler
  594. +.type
  595. +Compiler
  596. +.short
  597. +GNU C/C++/Obj-C compilers.
  598. +.description
  599. +The GNU C, C++, and Objective C compilers.  Includes all support for
  600. +compiling C, C++ and Objective C, including a run-time library for
  601. +Objective C.
  602. +.version
  603. +2.7.2.1
  604. +.author
  605. +Free Software Foundation
  606. +.requirements
  607. +Amiga binaries require ixemul.library.
  608. +.distribution
  609. +GNU Public License
  610. +.described-by
  611. +Fred Fish (fnf@amigalib.com)
  612. diff -rup --new-file baseline/fsf/gcc/TAGS amiga/fsf/gcc/TAGS
  613. --- baseline/fsf/gcc/TAGS    Thu Jun 15 19:33:50 1995
  614. +++ amiga/fsf/gcc/TAGS    Wed Dec 31 17:00:00 1969
  615. @@ -1,6918 +0,0 @@
  616. -
  617. -bi-parser.y,254
  618. -%token <string> DEFOP STRING52,1194
  619. -top:60,1343
  620. -defs:65,1380
  621. -def:71,1442
  622. -variations:76,1548
  623. -variation:82,1638
  624. -opt_string:93,2062
  625. -list:98,2130
  626. -items:105,2209
  627. -item:112,2309
  628. -makenode 120,2382
  629. -makevar 132,2557
  630. -makedef 149,2916
  631. -yyerror 164,3185
  632. -
  633. -c-parse.y,2549
  634. -%token 130,4637
  635. -%token INTERFACE IMPLEMENTATION END SELECTOR DEFS ENCODE160,5501
  636. -program:231,7813
  637. -extdefs:250,8294
  638. -extdef:255,8385
  639. -datadef:268,8702
  640. -fndef:300,9830
  641. -identifier:357,11831
  642. -unop:362,11871
  643. -expr:378,12126
  644. -exprlist:382,12190
  645. -nonnull_exprlist:388,12261
  646. -unary_expr:395,12435
  647. -cast_expr:455,14395
  648. -expr_no_commas:491,15330
  649. -primary:532,17022
  650. -string:700,22162
  651. -xdecls:707,22231
  652. -lineno_datadecl:720,22613
  653. -datadecls:725,22678
  654. -datadecl:732,22777
  655. -lineno_decl:754,23601
  656. -decls:759,23658
  657. -setspecs:770,23973
  658. -setattrs:780,24239
  659. -decl:784,24331
  660. -typed_declspecs:815,25553
  661. -reserved_declspecs:822,25743
  662. -declmods:837,26234
  663. -typed_typespecs:859,26921
  664. -reserved_typespecquals:866,27130
  665. -typespec:876,27440
  666. -typespecqual_reserved:890,27788
  667. -initdecls:895,27849
  668. -notype_initdecls:900,27898
  669. -maybeasm:905,27968
  670. -initdcl:914,28118
  671. -notype_initdcl:930,28648
  672. -maybe_attribute:947,29341
  673. -attributes:954,29434
  674. -attribute:961,29534
  675. -attribute_list:966,29611
  676. -attrib:973,29718
  677. -any_word:989,30187
  678. -init:998,30301
  679. -initlist_maybe_comma:1018,30807
  680. -initlist1:1025,30951
  681. -initelt:1032,31080
  682. -nested_function:1060,31840
  683. -notype_nested_function:1083,32500
  684. -declarator:1109,33267
  685. -after_type_declarator:1116,33399
  686. -parm_declarator:1140,34360
  687. -notype_declarator:1160,35076
  688. -structsp:1179,35728
  689. -maybecomma:1218,37018
  690. -maybecomma_warn:1223,37056
  691. -component_decl_list:1229,37164
  692. -component_decl_list2:1237,37352
  693. -component_decl:1255,38022
  694. -components:1282,38857
  695. -component_declarator:1288,38965
  696. -enumlist:1306,39751
  697. -enumerator:1315,39873
  698. -typename:1322,40019
  699. -absdcl:1329,40161
  700. -nonempty_type_quals:1335,40250
  701. -type_quals:1342,40412
  702. -absdcl1:1349,40531
  703. -stmts:1377,41549
  704. -xstmts:1383,41631
  705. -errstmt:1388,41665
  706. -pushlevel:1391,41689
  707. -maybe_label_decls:1402,41958
  708. -label_decls:1409,42084
  709. -label_decl:1414,42141
  710. -compstmt_or_error:1428,42530
  711. -compstmt:1434,42588
  712. -simple_if:1463,43630
  713. -if_prefix:1471,43813
  714. -do_stmt_start:1484,44224
  715. -save_filename:1496,44534
  716. -save_lineno:1500,44580
  717. -lineno_labeled_stmt:1504,44616
  718. -lineno_stmt_or_label:1514,44788
  719. -stmt_or_label:1519,44863
  720. -stmt:1532,45171
  721. -all_iter_stmt:1732,52306
  722. -all_iter_stmt_simple:1737,52381
  723. -label:1794,54012
  724. -maybe_type_qual:1874,56536
  725. -xexpr:1882,56697
  726. -asm_operands:1890,56880
  727. -nonnull_asm_operands:1895,56956
  728. -asm_operand:1901,57066
  729. -asm_clobbers:1906,57143
  730. -parmlist:1915,57440
  731. -parmlist_1:1925,57611
  732. -parmlist_2:1943,58162
  733. -parms:1961,58754
  734. -parm:1970,58932
  735. -parmlist_or_identifiers:2022,60971
  736. -parmlist_or_identifiers_1:2032,61172
  737. -identifiers:2043,61469
  738. -identifiers_or_typenames:2051,61690
  739. -
  740. -cexp.y,965
  741. -#define NULL 52,1497
  742. -#define GENERIC_PTR 57,1607
  743. -#define GENERIC_PTR 59,1640
  744. -#define HOST_BITS_PER_WIDE_INT 68,1827
  745. -#define HOST_WIDE_INT 69,1877
  746. -#define HOST_BITS_PER_WIDE_INT 71,1910
  747. -#define HOST_WIDE_INT 72,1959
  748. -#define NULL_PTR 78,2018
  749. -#define CHAR_TYPE_SIZE 106,2663
  750. -#define INT_TYPE_SIZE 110,2730
  751. -#define LONG_TYPE_SIZE 114,2797
  752. -#define WCHAR_TYPE_SIZE 118,2866
  753. -#define MAX_CHAR_TYPE_SIZE 122,2939
  754. -#define MAX_INT_TYPE_SIZE 126,3015
  755. -#define MAX_LONG_TYPE_SIZE 130,3090
  756. -#define MAX_WCHAR_TYPE_SIZE 134,3168
  757. -#define possible_sum_sign(139,3365
  758. -start 176,4006
  759. -exp1    181,4110
  760. -exp    189,4285
  761. -exp    218,5075
  762. -keywords 352,8951
  763. -parse_number 387,9958
  764. -struct token token483,12154
  765. -yylex 505,12483
  766. -parse_escape 786,18846
  767. -yyerror 882,20735
  768. -integer_overflow 891,20849
  769. -left_shift 898,20983
  770. -right_shift 914,21385
  771. -parse_c_expression 934,21933
  772. -main 964,22684
  773. -initialize_random_junk 999,23461
  774. -error 1029,24117
  775. -warning 1034,24165
  776. -lookup 1040,24235
  777. -
  778. -objc-parse.y,3622
  779. -%token 108,3147
  780. -%token INTERFACE IMPLEMENTATION END SELECTOR DEFS ENCODE138,4011
  781. -program:230,7129
  782. -extdefs:249,7610
  783. -extdef:254,7701
  784. -datadef:268,8029
  785. -fndef:300,9157
  786. -identifier:357,11158
  787. -unop:364,11232
  788. -expr:380,11487
  789. -exprlist:384,11551
  790. -nonnull_exprlist:390,11622
  791. -unary_expr:397,11796
  792. -cast_expr:457,13756
  793. -expr_no_commas:493,14691
  794. -primary:534,16383
  795. -string:789,24101
  796. -objc_string:797,24259
  797. -xdecls:803,24347
  798. -lineno_datadecl:816,24729
  799. -datadecls:821,24794
  800. -datadecl:828,24893
  801. -lineno_decl:850,25717
  802. -decls:855,25774
  803. -setspecs:866,26089
  804. -setattrs:876,26355
  805. -decl:880,26447
  806. -typed_declspecs:911,27669
  807. -reserved_declspecs:918,27859
  808. -declmods:933,28350
  809. -typed_typespecs:955,29037
  810. -reserved_typespecquals:962,29246
  811. -typespec:972,29556
  812. -typespecqual_reserved:990,30037
  813. -initdecls:995,30098
  814. -notype_initdecls:1000,30147
  815. -maybeasm:1005,30217
  816. -initdcl:1014,30367
  817. -notype_initdcl:1030,30897
  818. -maybe_attribute:1047,31590
  819. -attributes:1054,31683
  820. -attribute:1061,31783
  821. -attribute_list:1066,31860
  822. -attrib:1073,31967
  823. -any_word:1089,32436
  824. -init:1098,32550
  825. -initlist_maybe_comma:1118,33056
  826. -initlist1:1125,33200
  827. -initelt:1132,33329
  828. -nested_function:1151,33839
  829. -notype_nested_function:1174,34499
  830. -declarator:1200,35266
  831. -after_type_declarator:1207,35398
  832. -parm_declarator:1232,36373
  833. -notype_declarator:1252,37089
  834. -structsp:1271,37741
  835. -maybecomma:1310,39031
  836. -maybecomma_warn:1315,39069
  837. -component_decl_list:1321,39177
  838. -component_decl_list2:1329,39365
  839. -component_decl:1361,40364
  840. -components:1388,41199
  841. -component_declarator:1394,41307
  842. -enumlist:1412,42093
  843. -enumerator:1421,42215
  844. -typename:1428,42361
  845. -absdcl:1435,42503
  846. -nonempty_type_quals:1441,42592
  847. -type_quals:1448,42754
  848. -absdcl1:1455,42873
  849. -stmts:1483,43891
  850. -xstmts:1489,43973
  851. -errstmt:1494,44007
  852. -pushlevel:1497,44031
  853. -maybe_label_decls:1510,44354
  854. -label_decls:1517,44480
  855. -label_decl:1522,44537
  856. -compstmt_or_error:1536,44926
  857. -compstmt:1542,44984
  858. -simple_if:1571,46026
  859. -if_prefix:1579,46209
  860. -do_stmt_start:1592,46620
  861. -save_filename:1604,46930
  862. -save_lineno:1608,46976
  863. -lineno_labeled_stmt:1612,47012
  864. -lineno_stmt_or_label:1622,47184
  865. -stmt_or_label:1627,47259
  866. -stmt:1640,47567
  867. -all_iter_stmt:1840,54702
  868. -all_iter_stmt_simple:1845,54777
  869. -label:1902,56408
  870. -maybe_type_qual:1982,58932
  871. -xexpr:1990,59093
  872. -asm_operands:1998,59276
  873. -nonnull_asm_operands:2003,59352
  874. -asm_operand:2009,59462
  875. -asm_clobbers:2014,59539
  876. -parmlist:2023,59836
  877. -parmlist_1:2033,60007
  878. -parmlist_2:2051,60558
  879. -parms:2069,61150
  880. -parm:2078,61328
  881. -parmlist_or_identifiers:2130,63367
  882. -parmlist_or_identifiers_1:2140,63568
  883. -identifiers:2151,63865
  884. -identifiers_or_typenames:2159,64086
  885. -objcdef:2168,64307
  886. -identifier_list:2188,64721
  887. -classdecl:2195,64890
  888. -aliasdecl:2201,64968
  889. -classdef:2207,65056
  890. -protocoldef:2330,68232
  891. -protocolrefs:2345,68564
  892. -ivar_decl_list:2359,68758
  893. -visibility_spec:2364,68858
  894. -ivar_decls:2370,68991
  895. -ivar_decl:2393,69676
  896. -ivars:2410,70199
  897. -ivar_declarator:2417,70295
  898. -methoddef:2440,70844
  899. -methodprotolist:2496,72076
  900. -methodprotolist2:2501,72159
  901. -semi_or_error:2508,72338
  902. -methodproto:2513,72373
  903. -methoddecl:2535,72693
  904. -optarglist:2560,73288
  905. -myxdecls:2568,73478
  906. -mydecls:2573,73518
  907. -mydecl:2580,73586
  908. -myparms:2592,73922
  909. -myparm:2602,74149
  910. -optparmlist:2620,74655
  911. -unaryselector:2642,74946
  912. -keywordselector:2646,74977
  913. -selector:2655,75080
  914. -reservedwords:2662,75160
  915. -keyworddecl:2685,76148
  916. -messageargs:2707,76520
  917. -keywordarglist:2712,76574
  918. -keywordexpr:2721,76673
  919. -keywordarg:2733,76945
  920. -receiver:2744,77101
  921. -objcmessageexpr:2752,77179
  922. -selectorarg:2763,77347
  923. -keywordnamelist:2768,77402
  924. -keywordname:2776,77504
  925. -objcselectorexpr:2787,77651
  926. -objcprotocolexpr:2794,77726
  927. -objcencodeexpr:2803,77857
  928. -
  929. -assert.h,168
  930. -#define assert(7,136
  931. -#define assert(12,195
  932. -#define __assert(15,300
  933. -#define assert(32,701
  934. -#define __assert(35,807
  935. -#define assert(43,1049
  936. -#define __assert(46,1154
  937. -
  938. -basic-block.h,182
  939. -#define REGSET_ELT_BITS 24,863
  940. -#define REGSET_ELT_TYPE 30,1111
  941. -typedef REGSET_ELT_TYPE *regset;regset35,1256
  942. -#define REG_BLOCK_UNKNOWN 67,2251
  943. -#define REG_BLOCK_GLOBAL 68,2280
  944. -
  945. -bc-emit.h,199
  946. -struct bc_symbc_sym4,140
  947. -struct bc_segsymbc_segsym27,574
  948. -struct bc_segrelocbc_segreloc35,704
  949. -struct bc_segbc_seg48,914
  950. -struct bc_labelbc_label68,1310
  951. -struct bc_labelrefbc_labelref89,1779
  952. -
  953. -bc-optab.h,144
  954. -struct binary_operatorbinary_operator27,967
  955. -struct unary_operatorunary_operator55,2048
  956. -struct increment_operatorincrement_operator66,2308
  957. -
  958. -bc-typecd.h,263
  959. -#define TYPECODE_H22,819
  960. -enum typecodetypecode24,839
  961. -#define TYPECODE_INTEGER_P(34,1030
  962. -#define TYPECODE_UNSIGNED_P(37,1148
  963. -#define TYPECODE_SIGNED_P(41,1290
  964. -#define TYPECODE_FLOAT_P(45,1435
  965. -#define TYPECODE_ARITH_P(49,1590
  966. -#define NUM_TYPECODES 52,1691
  967. -
  968. -bi-defs.h,80
  969. -struct nodenode22,792
  970. -struct variationvariation28,845
  971. -struct defdef38,992
  972. -
  973. -bi-parser.h,68
  974. -} YYSTYPE;YYSTYPE7,103
  975. -#define    DEFOP    8,114
  976. -#define    STRING    9,132
  977. -
  978. -bi-run.h,435
  979. -#define MAXLITERALS 21,797
  980. -struct arityvecarityvec23,820
  981. -struct argtypeargtype31,923
  982. -struct callinfocallinfo37,1036
  983. -struct bytecodebytecode46,1346
  984. -#define INTERP_BPC 56,1680
  985. -#define INTERP_BPI 57,1722
  986. -#define min(62,1806
  987. -#define LM(70,1942
  988. -#define HM(71,1975
  989. -#define EXTEND(79,2250
  990. -#define BI_PARAMS(109,3416
  991. -#define SHIFT_IN_BITS(128,4147
  992. -#define OR_IN_BITS(136,4384
  993. -#define CALL(151,4991
  994. -#define PROCRET(159,5344
  995. -
  996. -bytecode.h,927
  997. -#define bc_emit_bytecode_DI_const(28,948
  998. -#define MACHINE_SEG_ALIGN 53,1777
  999. -#define INT_ALIGN 54,1805
  1000. -#define PTR_ALIGN 55,1825
  1001. -#define NAMES_HAVE_UNDERSCORES56,1845
  1002. -#define BC_NOP 57,1876
  1003. -#define BC_GLOBALIZE_LABEL(58,1897
  1004. -#define BC_OUTPUT_COMMON(59,1941
  1005. -#define BC_OUTPUT_LOCAL(60,1998
  1006. -#define BC_OUTPUT_ALIGN(61,2055
  1007. -#define BC_OUTPUT_LABEL(62,2099
  1008. -#define BC_OUTPUT_SKIP(63,2143
  1009. -#define BC_OUTPUT_LABELREF(64,2187
  1010. -#define BC_OUTPUT_FLOAT(65,2231
  1011. -#define BC_OUTPUT_DOUBLE(66,2275
  1012. -#define BC_OUTPUT_BYTE(67,2319
  1013. -#define BC_OUTPUT_FILE 68,2363
  1014. -#define BC_OUTPUT_ASCII 69,2402
  1015. -#define BC_OUTPUT_IDENT 70,2443
  1016. -#define BCXSTR(71,2484
  1017. -#define BC_WRITE_FILE(72,2523
  1018. -#define BC_WRITE_SEGSYM(73,2567
  1019. -#define BC_WRITE_RELOC_ENTRY(74,2611
  1020. -#define BC_START_BYTECODE_LINE(75,2669
  1021. -#define BC_WRITE_BYTECODE(76,2713
  1022. -#define BC_WRITE_RTL(77,2760
  1023. -#define BC_EMIT_TRAMPOLINE(78,2804
  1024. -#define VALIDATE_STACK 79,2858
  1025. -
  1026. -bytetypes.h,642
  1027. -typedef __signed__ char QItype;QItype5,98
  1028. -typedef unsigned char QUtype;QUtype6,130
  1029. -typedef __signed__ short int HItype;HItype7,160
  1030. -typedef unsigned short int HUtype;HUtype8,197
  1031. -typedef __signed__ long int SItype;SItype9,232
  1032. -typedef unsigned long int SUtype;SUtype10,268
  1033. -typedef __signed__ long long int DItype;DItype11,302
  1034. -typedef unsigned long long int DUtype;DUtype12,343
  1035. -typedef float SFtype;SFtype13,382
  1036. -typedef double DFtype;DFtype14,404
  1037. -typedef long double XFtype;XFtype15,427
  1038. -typedef char *Ptype;Ptype16,455
  1039. -typedef int Ttype;Ttype17,476
  1040. -typedef union stacktypestacktype20,497
  1041. -} stacktype;stacktype35,727
  1042. -
  1043. -c-gperf.h,222
  1044. -struct resword resword3,154
  1045. -#define TOTAL_KEYWORDS 5,214
  1046. -#define MIN_WORD_LENGTH 6,240
  1047. -#define MAX_WORD_LENGTH 7,266
  1048. -#define MIN_HASH_VALUE 8,293
  1049. -#define MAX_HASH_VALUE 9,319
  1050. -hash 16,445
  1051. -is_reserved_word 167,4856
  1052. -
  1053. -c-lex.h,79
  1054. -enum ridrid23,812
  1055. -#define NORID 59,1218
  1056. -#define RID_FIRST_MODIFIER 61,1244
  1057. -
  1058. -c-pragma.h,73
  1059. -#define HANDLE_PRAGMA_WEAK 24,923
  1060. -enum pragma_statepragma_state27,972
  1061. -
  1062. -c-tree.h,940
  1063. -#define _C_TREE_H22,834
  1064. -struct lang_identifierlang_identifier30,1133
  1065. -#define IDENTIFIER_GLOBAL_VALUE(42,1508
  1066. -#define IDENTIFIER_LOCAL_VALUE(46,1684
  1067. -#define IDENTIFIER_LABEL_VALUE(50,1875
  1068. -#define IDENTIFIER_LIMBO_VALUE(54,2077
  1069. -#define IDENTIFIER_IMPLICIT_DECL(58,2290
  1070. -#define IDENTIFIER_ERROR_LOCUS(62,2529
  1071. -#define C_TYPE_FIELDS_READONLY(74,3068
  1072. -#define C_TYPE_FIELDS_VOLATILE(77,3207
  1073. -#define C_TYPE_BEING_DEFINED(81,3386
  1074. -struct lang_typelang_type84,3513
  1075. -#define C_DECLARED_LABEL_FLAG(92,3684
  1076. -#define C_TYPE_VARIABLE_SIZE(96,3877
  1077. -#define C_DECL_VARIABLE_SIZE(97,3936
  1078. -#define C_EXP_ORIGINAL_CODE(101,4095
  1079. -#define C_MISSING_PROTOTYPE_WARNED(107,4356
  1080. -#define C_SET_EXP_ORIGINAL_CODE(111,4464
  1081. -#define C_TYPEDEF_EXPLICITLY_SIGNED(115,4624
  1082. -#define C_DECL_ANTICIPATED(120,4888
  1083. -#define TYPE_ACTUAL_ARG_TYPES(125,5120
  1084. -#define C_PROMOTING_INTEGER_TYPE_P(130,5368
  1085. -#define ITERATOR_P(139,5810
  1086. -#define ITERATOR_BOUND_P(143,5953
  1087. -
  1088. -conditions.h,447
  1089. -#define CC_STATUS_MDEP 48,2039
  1090. -#define CC_STATUS_MDEP_INIT 52,2102
  1091. -typedef struct {int flags; rtx value1, value2; CC_STATUS_MDEP mdep;} CC_STATUS;CC_STATUS55,2140
  1092. -#define CC_REVERSED 69,2645
  1093. -#define CC_NOT_POSITIVE 76,2982
  1094. -#define CC_NOT_NEGATIVE 84,3356
  1095. -#define CC_NO_OVERFLOW 88,3522
  1096. -#define CC_Z_IN_NOT_N 92,3659
  1097. -#define CC_Z_IN_N 96,3777
  1098. -#define CC_INVERTED 103,4109
  1099. -#define CC_NOT_SIGNED 107,4259
  1100. -#define CC_STATUS_INIT 112,4388
  1101. -
  1102. -config.h,0
  1103. -
  1104. -convert.h,0
  1105. -
  1106. -cpphash.h,190
  1107. -union hashval hashval5,139
  1108. -struct hashnode hashnode14,237
  1109. -typedef struct hashnode HASHNODE;HASHNODE26,730
  1110. -#define HASHSIZE 35,1149
  1111. -#define HASHSTEP(37,1207
  1112. -#define MAKE_POS(38,1249
  1113. -
  1114. -cpplib.h,1652
  1115. -#define PARAMS(76,2050
  1116. -#define PARAMS(78,2076
  1117. -typedef enum cpp_token (*parse_underflow_t)parse_underflow_t82,2126
  1118. -typedef int (*parse_cleanup_t)parse_cleanup_t83,2193
  1119. -struct parse_marker parse_marker88,2345
  1120. -#define IMPORT_HASH_SIZE 107,3042
  1121. -struct import_file import_file109,3071
  1122. -#define CPP_LINE_BASE(117,3235
  1123. -struct cpp_buffer cpp_buffer119,3295
  1124. -typedef struct assertion_hashnode ASSERTION_HASHNODE;ASSERTION_HASHNODE165,4772
  1125. -#define ASSERTION_HASHSIZE 166,4826
  1126. -#define CPP_STACK_MAX 171,5007
  1127. -struct cpp_reader cpp_reader174,5041
  1128. -#define CPP_BUF_PEEK(265,7672
  1129. -#define CPP_BUF_GET(267,7763
  1130. -#define CPP_FORWARD(269,7855
  1131. -#define CPP_WRITTEN(272,7973
  1132. -#define CPP_PWRITTEN(273,8041
  1133. -#define CPP_RESERVE(276,8165
  1134. -#define CPP_PUTS_Q(282,8392
  1135. -#define CPP_PUTS(285,8565
  1136. -#define CPP_PUTC_Q(287,8723
  1137. -#define CPP_PUTC(289,8856
  1138. -#define CPP_NUL_TERMINATE_Q(291,8983
  1139. -#define CPP_NUL_TERMINATE(292,9040
  1140. -#define CPP_ADJUST_WRITTEN(293,9118
  1141. -#define CPP_SET_WRITTEN(294,9186
  1142. -#define CPP_OPTIONS(296,9267
  1143. -#define CPP_BUFFER(297,9324
  1144. -#define CPP_PREV_BUFFER(299,9390
  1145. -#define CPP_NULL_BUFFER(300,9435
  1146. -#define CPP_PREV_BUFFER(302,9512
  1147. -#define CPP_NULL_BUFFER(303,9562
  1148. -struct cpp_options cpp_options307,9656
  1149. -#define CPP_TRADITIONAL(493,15032
  1150. -#define CPP_PEDANTIC(494,15098
  1151. -#define CPP_PRINT_DEPS(495,15158
  1152. -enum node_type node_type509,15755
  1153. -typedef struct macrodef MACRODEF;MACRODEF550,17306
  1154. -struct macrodefmacrodef551,17340
  1155. -typedef struct definition DEFINITION;DEFINITION579,18495
  1156. -struct definition definition580,18533
  1157. -struct if_stack if_stack614,19777
  1158. -typedef struct if_stack IF_STACK_FRAME;IF_STACK_FRAME624,20226
  1159. -
  1160. -dbxstclass.h,276
  1161. -#define C_GSYM    5,169
  1162. -#define C_LSYM    6,190
  1163. -#define C_PSYM    7,211
  1164. -#define C_RSYM    8,232
  1165. -#define C_RPSYM    9,253
  1166. -#define C_STSYM    10,275
  1167. -#define C_BCOMM    12,298
  1168. -#define C_ECOML    13,320
  1169. -#define C_ECOMM    14,342
  1170. -#define C_DECL    15,364
  1171. -#define C_ENTRY    16,385
  1172. -#define C_FUN    17,407
  1173. -
  1174. -defaults.h,325
  1175. -#define ASM_FORMAT_PRIVATE_NAME(31,1175
  1176. -#define ASM_STABD_OP 45,1624
  1177. -#define ASM_OUTPUT_ADDR_VEC_ELT(52,1835
  1178. -#define ASM_OUTPUT_ADDR_DIFF_ELT(63,2215
  1179. -#define ASM_OUTPUT_ASCII(75,2597
  1180. -#define ASM_IDENTIFY_LANGUAGE(119,4369
  1181. -#define ASM_OUTPUT_DEF(126,4553
  1182. -#define SUPPORTS_WEAK 139,4923
  1183. -#define SUPPORTS_WEAK 141,4953
  1184. -
  1185. -demangle.h,797
  1186. -#define DEMANGLE_H21,826
  1187. -#define PROTO(28,972
  1188. -#define PROTO(30,1003
  1189. -#define PARAMS(34,1041
  1190. -#define PTR 37,1091
  1191. -#define const40,1130
  1192. -#define PTR 42,1151
  1193. -#define DMGL_NO_OPTS    51,1302
  1194. -#define DMGL_PARAMS    52,1351
  1195. -#define DMGL_ANSI    53,1408
  1196. -#define DMGL_AUTO    55,1471
  1197. -#define DMGL_GNU    56,1498
  1198. -#define DMGL_LUCID    57,1524
  1199. -#define DMGL_ARM    58,1553
  1200. -#define DMGL_STYLE_MASK 60,1659
  1201. -extern enum demangling_stylesdemangling_styles70,2094
  1202. -#define AUTO_DEMANGLING_STYLE_STRING    81,2364
  1203. -#define GNU_DEMANGLING_STYLE_STRING    82,2408
  1204. -#define LUCID_DEMANGLING_STYLE_STRING    83,2450
  1205. -#define ARM_DEMANGLING_STYLE_STRING    84,2496
  1206. -#define CURRENT_DEMANGLING_STYLE 88,2599
  1207. -#define AUTO_DEMANGLING 89,2657
  1208. -#define GNU_DEMANGLING 90,2728
  1209. -#define LUCID_DEMANGLING 91,2797
  1210. -#define ARM_DEMANGLING 92,2870
  1211. -
  1212. -dwarf.h,959
  1213. -enum dwarf_tag dwarf_tag34,1295
  1214. -#define TAG_lo_user    79,2677
  1215. -#define TAG_hi_user    80,2746
  1216. -#define TAG_source_file 81,2813
  1217. -enum dwarf_form dwarf_form85,2919
  1218. -enum dwarf_attribute dwarf_attribute98,3151
  1219. -#define AT_lo_user    171,6208
  1220. -#define AT_hi_user    172,6275
  1221. -enum dwarf_location_atom dwarf_location_atom176,6380
  1222. -#define OP_LO_USER    186,6556
  1223. -#define OP_HI_USER    187,6622
  1224. -enum dwarf_fundamental_type dwarf_fundamental_type191,6729
  1225. -#define FT_lo_user    243,8318
  1226. -#define FT_hi_user    244,8386
  1227. -enum dwarf_type_modifier dwarf_type_modifier248,8492
  1228. -#define MOD_lo_user    255,8626
  1229. -#define MOD_hi_user    256,8693
  1230. -enum dwarf_array_dim_ordering dwarf_array_dim_ordering260,8799
  1231. -enum dwarf_subscr_data_formats dwarf_subscr_data_formats267,8928
  1232. -#define FMT_CODE(281,9202
  1233. -enum dwarf_source_language dwarf_source_language288,9406
  1234. -#define LANG_lo_user    301,9748
  1235. -#define LANG_hi_user    302,9822
  1236. -enum dwarf_macinfo_record_type dwarf_macinfo_record_type306,9948
  1237. -
  1238. -expr.h,886
  1239. -#define const24,863
  1240. -#define BRANCH_COST 30,949
  1241. -#define QUEUED_VAR(38,1181
  1242. -#define QUEUED_INSN(41,1347
  1243. -#define QUEUED_COPY(44,1505
  1244. -#define QUEUED_BODY(47,1642
  1245. -#define QUEUED_NEXT(49,1710
  1246. -enum expand_modifier expand_modifier56,2053
  1247. -#define NO_DEFER_POP 111,4017
  1248. -#define OK_DEFER_POP 112,4063
  1249. -struct args_sizeargs_size134,4938
  1250. -#define ADD_PARM_SIZE(143,5064
  1251. -#define SUB_PARM_SIZE(152,5336
  1252. -#define ARGS_SIZE_RTX(162,5719
  1253. -#define ARGS_SIZE_TREE(169,5991
  1254. -enum direction direction177,6286
  1255. -#define FUNCTION_ARG_PADDING(180,6386
  1256. -#define FUNCTION_ARG_BOUNDARY(195,6938
  1257. -#define MUST_PASS_IN_STACK(214,7713
  1258. -#define RETURN_IN_MEMORY(229,8298
  1259. -typedef struct optaboptab251,9121
  1260. -} * optab;optab258,9258
  1261. -#define GEN_FCN(268,9652
  1262. -#define GEN_FCN(270,9714
  1263. -enum optab_methodsoptab_methods337,12700
  1264. -typedef rtx (*rtxfun)rtxfun451,15250
  1265. -enum save_level save_level819,29799
  1266. -
  1267. -flags.h,91
  1268. -enum debug_info_typedebug_info_type24,903
  1269. -enum debug_info_leveldebug_info_level36,1348
  1270. -
  1271. -function.h,220
  1272. -#define tree 23,840
  1273. -#define rtx 26,883
  1274. -struct var_refs_queuevar_refs_queue29,909
  1275. -struct sequence_stacksequence_stack42,1255
  1276. -struct simple_obstack_stacksimple_obstack_stack54,1506
  1277. -struct functionfunction63,1733
  1278. -
  1279. -gbl-ctors.h,130
  1280. -#define ON_EXIT(39,1502
  1281. -#define ON_EXIT(43,1597
  1282. -typedef void (*func_ptr)func_ptr49,1712
  1283. -#define DO_GLOBAL_CTORS_BODY    78,2876
  1284. -
  1285. -getopt.h,125
  1286. -#define _GETOPT_H 19,797
  1287. -#define    no_argument    93,3221
  1288. -#define required_argument    94,3244
  1289. -#define optional_argument    95,3272
  1290. -
  1291. -glimits.h,710
  1292. -#define _LIMITS_H___5,95
  1293. -#define _MACH_MACHLIMITS_H_6,116
  1294. -#define CHAR_BIT 10,196
  1295. -#define MB_LEN_MAX 14,283
  1296. -#define SCHAR_MIN 19,389
  1297. -#define SCHAR_MAX 21,431
  1298. -#define UCHAR_MAX 25,538
  1299. -#define CHAR_MIN 30,655
  1300. -#define CHAR_MAX 32,690
  1301. -#define CHAR_MIN 35,733
  1302. -#define CHAR_MAX 37,773
  1303. -#define SHRT_MIN 42,883
  1304. -#define SHRT_MAX 44,925
  1305. -#define USHRT_MAX 48,1038
  1306. -#define __INT_MAX__ 52,1142
  1307. -#define INT_MIN 55,1195
  1308. -#define INT_MAX 57,1239
  1309. -#define UINT_MAX 61,1350
  1310. -#define __LONG_MAX__ 66,1492
  1311. -#define LONG_MIN 69,1548
  1312. -#define LONG_MAX 71,1595
  1313. -#define ULONG_MAX 75,1714
  1314. -#define __LONG_LONG_MAX__ 80,1930
  1315. -#define LONG_LONG_MIN 83,2006
  1316. -#define LONG_LONG_MAX 85,2068
  1317. -#define ULONG_LONG_MAX 89,2207
  1318. -
  1319. -gstab.h,101
  1320. -#define __GNU_STAB__5,65
  1321. -#define __define_stab(7,87
  1322. -enum __stab_debug_code__stab_debug_code9,141
  1323. -
  1324. -gsyms.h,177
  1325. -#define __GNU_SYMS__4,92
  1326. -enum sdb_storage_classsdb_storage_class6,114
  1327. -enum sdb_typesdb_type38,558
  1328. -enum sdb_type_classsdb_type_class59,829
  1329. -enum sdb_maskssdb_masks67,910
  1330. -
  1331. -gsyslimits.h,34
  1332. -#define _GCC_NEXT_LIMITS_H    6,214
  1333. -
  1334. -halfpic.h,442
  1335. -#define PROTO(26,924
  1336. -#define PROTO(28,955
  1337. -#define STDIO_PROTO(37,1085
  1338. -#define HALF_PIC_P(72,2729
  1339. -#define HALF_PIC_NUMBER_PTRS    73,2767
  1340. -#define HALF_PIC_NUMBER_REFS    74,2819
  1341. -#define HALF_PIC_ENCODE(76,2872
  1342. -#define HALF_PIC_DECLARE(77,2925
  1343. -#define HALF_PIC_EXTERNAL(78,2980
  1344. -#define HALF_PIC_INIT(79,3037
  1345. -#define HALF_PIC_FINISH(80,3079
  1346. -#define HALF_PIC_ADDRESS_P(81,3136
  1347. -#define HALF_PIC_PTR(82,3198
  1348. -#define    HALF_PIC_PREFIX    86,3297
  1349. -
  1350. -hard-reg-set.h,1234
  1351. -typedef unsigned HOST_WIDE_INT HARD_REG_ELT_TYPE;HARD_REG_ELT_TYPE39,1712
  1352. -#define HARD_REG_SET 43,1816
  1353. -#define HARD_REG_SET_LONGS 47,1863
  1354. -typedef HARD_REG_ELT_TYPE HARD_REG_SET[HARD_REG_SET50,1977
  1355. -#define HARD_CONST(57,2148
  1356. -#define SET_HARD_REG_BIT(88,3280
  1357. -#define CLEAR_HARD_REG_BIT(90,3354
  1358. -#define TEST_HARD_REG_BIT(92,3433
  1359. -#define CLEAR_HARD_REG_SET(95,3510
  1360. -#define SET_HARD_REG_SET(96,3565
  1361. -#define COPY_HARD_REG_SET(98,3621
  1362. -#define COMPL_HARD_REG_SET(99,3673
  1363. -#define IOR_HARD_REG_SET(101,3728
  1364. -#define IOR_COMPL_HARD_REG_SET(102,3780
  1365. -#define AND_HARD_REG_SET(103,3840
  1366. -#define AND_COMPL_HARD_REG_SET(104,3892
  1367. -#define GO_IF_HARD_REG_SUBSET(106,3953
  1368. -#define GO_IF_HARD_REG_EQUAL(108,4036
  1369. -#define UHOST_BITS_PER_WIDE_INT 112,4105
  1370. -#define SET_HARD_REG_BIT(114,4174
  1371. -#define CLEAR_HARD_REG_BIT(118,4316
  1372. -#define TEST_HARD_REG_BIT(122,4463
  1373. -#define CLEAR_HARD_REG_SET(126,4607
  1374. -#define SET_HARD_REG_SET(132,4809
  1375. -#define COPY_HARD_REG_SET(138,5010
  1376. -#define COMPL_HARD_REG_SET(144,5246
  1377. -#define AND_HARD_REG_SET(150,5485
  1378. -#define AND_COMPL_HARD_REG_SET(156,5721
  1379. -#define IOR_HARD_REG_SET(162,5965
  1380. -#define IOR_COMPL_HARD_REG_SET(168,6201
  1381. -#define GO_IF_HARD_REG_SUBSET(174,6445
  1382. -#define GO_IF_HARD_REG_EQUAL(181,6745
  1383. -
  1384. -hconfig.h,0
  1385. -
  1386. -input.h,37
  1387. -struct file_stackfile_stack35,1156
  1388. -
  1389. -integrate.h,41
  1390. -struct inline_remapinline_remap33,1346
  1391. -
  1392. -limitx.h,29
  1393. -#define _GCC_LIMITS_H_7,303
  1394. -
  1395. -limity.h,0
  1396. -
  1397. -longlong.h,3654
  1398. -#define SI_TYPE_SIZE 20,871
  1399. -#define __BITS4 23,903
  1400. -#define __ll_B 24,938
  1401. -#define __ll_lowpart(25,980
  1402. -#define __ll_highpart(26,1029
  1403. -#define __CLOBBER_CC83,3538
  1404. -#define __AND_CLOBBER_CC84,3559
  1405. -#define __CLOBBER_CC 86,3610
  1406. -#define __AND_CLOBBER_CC 87,3638
  1407. -#define add_ssaaaa(91,3740
  1408. -#define sub_ddmmss(100,4031
  1409. -#define umul_ppmm(109,4321
  1410. -#define udiv_qrnnd(121,4689
  1411. -#define count_leading_zeros(128,4920
  1412. -#define add_ssaaaa(135,5103
  1413. -#define sub_ddmmss(144,5398
  1414. -#define umul_ppmm(153,5691
  1415. -#define UMUL_TIME 173,6232
  1416. -#define UDIV_TIME 174,6253
  1417. -#define umul_ppmm(178,6323
  1418. -#define smul_ppmm(187,6624
  1419. -#define __umulsidi3(196,6921
  1420. -#define add_ssaaaa(206,7168
  1421. -#define sub_ddmmss(215,7454
  1422. -#define umul_ppmm(224,7738
  1423. -#define udiv_qrnnd(230,7936
  1424. -#define count_leading_zeros(237,8165
  1425. -#define add_ssaaaa(245,8349
  1426. -#define sub_ddmmss(254,8643
  1427. -#define umul_ppmm(264,8961
  1428. -#define UMUL_TIME 278,9359
  1429. -#define UMUL_TIME 280,9385
  1430. -#define UDIV_TIME 282,9413
  1431. -#define count_leading_zeros(283,9434
  1432. -#define add_ssaaaa(307,10268
  1433. -#define sub_ddmmss(316,10553
  1434. -#define umul_ppmm(325,10836
  1435. -#define udiv_qrnnd(331,11026
  1436. -#define count_leading_zeros(338,11251
  1437. -#define UMUL_TIME 345,11470
  1438. -#define UDIV_TIME 346,11491
  1439. -#define add_ssaaaa(353,11646
  1440. -#define sub_ddmmss(370,12162
  1441. -#define umul_ppmm(391,12731
  1442. -#define __umulsidi3(400,13034
  1443. -#define add_ssaaaa(410,13283
  1444. -#define sub_ddmmss(419,13573
  1445. -#define umul_ppmm(429,13929
  1446. -#define UMUL_TIME 435,14128
  1447. -#define udiv_qrnnd(436,14149
  1448. -#define UDIV_TIME 443,14383
  1449. -#define sdiv_qrnnd(444,14404
  1450. -#define count_leading_zeros(451,14638
  1451. -#define umul_ppmm(457,14878
  1452. -#define UMUL_TIME 489,15528
  1453. -#define UDIV_TIME 490,15550
  1454. -#define add_ssaaaa(495,15644
  1455. -#define sub_ddmmss(504,15948
  1456. -#define count_leading_zeros(513,16250
  1457. -#define umul_ppmm(522,16508
  1458. -#define udiv_qrnnd(534,16867
  1459. -#define UMUL_TIME 545,17234
  1460. -#define UDIV_TIME 546,17254
  1461. -#define UMUL_TIME 548,17281
  1462. -#define UDIV_TIME 549,17302
  1463. -#define umul_ppmm(554,17397
  1464. -#define UMUL_TIME 562,17607
  1465. -#define UDIV_TIME 563,17628
  1466. -#define umul_ppmm(567,17699
  1467. -#define __umulsidi3(576,17999
  1468. -#define udiv_qrnnd(583,18193
  1469. -#define add_ssaaaa(596,18635
  1470. -#define sub_ddmmss(621,19622
  1471. -#define count_leading_zeros(660,21167
  1472. -#define umul_ppmm(665,21333
  1473. -#define UMUL_TIME 674,21604
  1474. -#define smul_ppmm(675,21625
  1475. -#define SMUL_TIME 684,21893
  1476. -#define UDIV_TIME 685,21914
  1477. -#define umul_ppmm(687,21942
  1478. -#define UMUL_TIME 698,22309
  1479. -#define smul_ppmm(699,22329
  1480. -#define SMUL_TIME 705,22503
  1481. -#define sdiv_qrnnd(706,22523
  1482. -#define UDIV_TIME 710,22708
  1483. -#define add_ssaaaa(715,22803
  1484. -#define sub_ddmmss(724,23089
  1485. -#define umul_ppmm(734,23424
  1486. -#define add_ssaaaa(750,23870
  1487. -#define sub_ddmmss(759,24150
  1488. -#define umul_ppmm(768,24428
  1489. -#define UMUL_TIME 800,25006
  1490. -#define UDIV_TIME 801,25027
  1491. -#define count_leading_zeros(802,25049
  1492. -#define add_ssaaaa(819,25472
  1493. -#define sub_ddmmss(829,25793
  1494. -#define umul_ppmm(840,26139
  1495. -#define udiv_qrnnd(846,26341
  1496. -#define umul_ppmm(857,26781
  1497. -#define udiv_qrnnd(863,26983
  1498. -#define UDIV_TIME 909,28048
  1499. -#define count_leading_zeros(910,28069
  1500. -#define umul_ppmm(917,28349
  1501. -#define UMUL_TIME 963,29491
  1502. -#define udiv_qrnnd(966,29668
  1503. -#define UDIV_TIME 996,30488
  1504. -#define add_ssaaaa(1002,30661
  1505. -#define sub_ddmmss(1011,30947
  1506. -#define umul_ppmm(1020,31231
  1507. -#define sdiv_qrnnd(1036,31733
  1508. -#define add_ssaaaa(1053,32186
  1509. -#define sub_ddmmss(1063,32422
  1510. -#define umul_ppmm(1073,32657
  1511. -#define __umulsidi3(1099,33529
  1512. -#define __udiv_qrnnd_c(1106,33724
  1513. -#define udiv_qrnnd(1146,34980
  1514. -#define UDIV_NEEDS_NORMALIZATION 1156,35257
  1515. -#define udiv_qrnnd 1157,35292
  1516. -#define count_leading_zeros(1162,35403
  1517. -#define UDIV_NEEDS_NORMALIZATION 1185,36035
  1518. -
  1519. -loop.h,157
  1520. -#define INSN_LUID(24,947
  1521. -enum g_types g_types38,1535
  1522. -struct inductioninduction43,1696
  1523. -struct iv_class iv_class116,5351
  1524. -enum iv_mode iv_mode139,6522
  1525. -
  1526. -machmode.h,853
  1527. -#define PROTO(25,953
  1528. -#define PROTO(27,984
  1529. -#define MIN(43,1380
  1530. -#define MAX(44,1421
  1531. -#define HOST_BITS_PER_WIDE_INT 51,1608
  1532. -#define HOST_WIDE_INT 52,1658
  1533. -#define HOST_BITS_PER_WIDE_INT 54,1691
  1534. -#define HOST_WIDE_INT 55,1740
  1535. -#define HOST_PTR_PRINTF 63,1875
  1536. -#define DEF_MACHMODE(68,2015
  1537. -enum machine_mode machine_mode70,2079
  1538. -#define HAVE_MACHINE_MODES80,2213
  1539. -#define NUM_MACHINE_MODES 83,2267
  1540. -#define GET_MODE_NAME(89,2397
  1541. -enum mode_class mode_class91,2452
  1542. -#define GET_MODE_CLASS(98,2732
  1543. -#define INTEGRAL_MODE_P(101,2833
  1544. -#define FLOAT_MODE_P(107,3056
  1545. -#define GET_MODE_SIZE(114,3260
  1546. -#define GET_MODE_UNIT_SIZE(119,3420
  1547. -#define GET_MODE_NUNITS(123,3531
  1548. -#define GET_MODE_BITSIZE(129,3726
  1549. -#define GET_MODE_MASK(134,3888
  1550. -#define GET_MODE_WIDER_MODE(141,4177
  1551. -#define GET_MODE_ALIGNMENT(155,4737
  1552. -#define GET_CLASS_NARROWEST_MODE(162,4979
  1553. -
  1554. -objc-act.h,834
  1555. -#define KEYWORD_KEY_NAME(76,2575
  1556. -#define KEYWORD_ARG_NAME(77,2626
  1557. -#define METHOD_SEL_NAME(80,2729
  1558. -#define METHOD_SEL_ARGS(81,2779
  1559. -#define METHOD_ADD_ARGS(82,2834
  1560. -#define METHOD_DEFINITION(83,2886
  1561. -#define METHOD_ENCODING(84,2941
  1562. -#define CLASS_NAME(89,3135
  1563. -#define CLASS_SUPER_NAME(90,3182
  1564. -#define CLASS_IVARS(91,3238
  1565. -#define CLASS_RAW_IVARS(92,3302
  1566. -#define CLASS_NST_METHODS(93,3370
  1567. -#define CLASS_CLS_METHODS(94,3426
  1568. -#define CLASS_STATIC_TEMPLATE(95,3482
  1569. -#define CLASS_CATEGORY_LIST(96,3556
  1570. -#define CLASS_PROTOCOL_LIST(97,3628
  1571. -#define PROTOCOL_NAME(98,3700
  1572. -#define PROTOCOL_LIST(99,3750
  1573. -#define PROTOCOL_NST_METHODS(100,3816
  1574. -#define PROTOCOL_CLS_METHODS(101,3875
  1575. -#define PROTOCOL_FORWARD_DECL(102,3934
  1576. -#define TYPE_PROTOCOL_LIST(103,4008
  1577. -#define DEFTREECODE(107,4143
  1578. -enum objc_tree_code objc_tree_code108,4193
  1579. -
  1580. -obstack.h,1829
  1581. -#define __OBSTACK_H__104,4711
  1582. -#define __PTR_TO_INT(111,4940
  1583. -#define __INT_TO_PTR(115,5011
  1584. -#define __need_ptrdiff_t128,5562
  1585. -#define PTR_INT_TYPE 136,5665
  1586. -#define PTR_INT_TYPE 138,5702
  1587. -struct _obstack_chunk    _obstack_chunk141,5736
  1588. -struct obstack    obstack148,5964
  1589. -#define obstack_base(231,9354
  1590. -#define obstack_chunk_size(235,9467
  1591. -#define obstack_next_free(239,9581
  1592. -#define obstack_alignment_mask(243,9731
  1593. -#define obstack_init(245,9788
  1594. -#define obstack_begin(249,9920
  1595. -#define obstack_specify_allocation(253,10064
  1596. -#define obstack_specify_allocation_with_arg(257,10245
  1597. -#define obstack_chunkfun(261,10449
  1598. -#define obstack_freefun(264,10560
  1599. -#define obstack_1grow_fast(267,10649
  1600. -#define obstack_blank_fast(269,10716
  1601. -#define __extension__276,11045
  1602. -#define obstack_object_size(284,11277
  1603. -#define obstack_room(290,11482
  1604. -#define obstack_grow(295,11645
  1605. -#define obstack_grow0(308,12064
  1606. -#define obstack_1grow(322,12537
  1607. -#define obstack_ptr_grow(335,13003
  1608. -#define obstack_int_grow(344,13337
  1609. -#define obstack_ptr_grow_fast(353,13661
  1610. -#define obstack_int_grow_fast(354,13745
  1611. -#define obstack_blank(356,13825
  1612. -#define obstack_alloc(366,14151
  1613. -#define obstack_copy(372,14329
  1614. -#define obstack_copy0(378,14518
  1615. -#define obstack_finish(386,14807
  1616. -#define obstack_free(407,15538
  1617. -#define obstack_object_size(417,15887
  1618. -#define obstack_room(420,15993
  1619. -#define obstack_grow(429,16329
  1620. -#define obstack_grow0(437,16642
  1621. -#define obstack_1grow(446,16998
  1622. -#define obstack_ptr_grow(452,17202
  1623. -#define obstack_int_grow(458,17483
  1624. -#define obstack_ptr_grow_fast(464,17749
  1625. -#define obstack_int_grow_fast(465,17833
  1626. -#define obstack_blank(467,17913
  1627. -#define obstack_alloc(474,18163
  1628. -#define obstack_copy(477,18258
  1629. -#define obstack_copy0(480,18365
  1630. -#define obstack_finish(483,18474
  1631. -#define obstack_free(499,19097
  1632. -#define obstack_free(506,19434
  1633. -
  1634. -options.h,0
  1635. -
  1636. -output.h,0
  1637. -
  1638. -pcp.h,161
  1639. -typedef struct stringdef STRINGDEF;STRINGDEF24,872
  1640. -struct stringdefstringdef25,908
  1641. -typedef struct keydef KEYDEF;KEYDEF36,1270
  1642. -struct keydefkeydef37,1300
  1643. -
  1644. -real.h,3013
  1645. -#define REAL_H_INCLUDED22,834
  1646. -#define UNKNOWN_FLOAT_FORMAT 25,922
  1647. -#define IEEE_FLOAT_FORMAT 26,953
  1648. -#define VAX_FLOAT_FORMAT 27,981
  1649. -#define IBM_FLOAT_FORMAT 28,1008
  1650. -#define    TARGET_FLOAT_FORMAT    33,1141
  1651. -#define    HOST_FLOAT_FORMAT    37,1221
  1652. -#define REAL_INFINITY41,1318
  1653. -#define FLOAT_WORDS_BIG_ENDIAN 50,1609
  1654. -#define HOST_FLOAT_WORDS_BIG_ENDIAN 56,1791
  1655. -#define HOST_FLOAT_WORDS_BIG_ENDIAN 58,1835
  1656. -#define LONG_DOUBLE_TYPE_SIZE 67,2158
  1657. -#define REAL_ARITHMETIC71,2290
  1658. -#define REAL_IS_NOT_DOUBLE80,2583
  1659. -#define REAL_ARITHMETIC81,2610
  1660. -} realvaluetype;realvaluetype84,2726
  1661. -#define REAL_VALUE_TYPE 85,2743
  1662. -#define REAL_IS_NOT_DOUBLE91,2849
  1663. -#define REAL_ARITHMETIC92,2876
  1664. -} realvaluetype;realvaluetype95,2992
  1665. -#define REAL_VALUE_TYPE 96,3009
  1666. -#define REAL_IS_NOT_DOUBLE103,3236
  1667. -} realvaluetype;realvaluetype106,3354
  1668. -#define REAL_VALUE_TYPE 107,3371
  1669. -#define REAL_VALUE_TYPE 111,3525
  1670. -#define REAL_ARITHMETIC(126,4068
  1671. -#define REAL_VALUES_EQUAL(157,5579
  1672. -#define REAL_VALUES_LESS(159,5661
  1673. -#define REAL_VALUE_LDEXP(160,5721
  1674. -#define REAL_VALUE_RNDZINT(163,5808
  1675. -#define REAL_VALUE_UNSIGNED_RNDZINT(164,5852
  1676. -#define REAL_VALUE_TRUNCATE(166,5953
  1677. -#define REAL_VALUE_FIX(170,6128
  1678. -#define REAL_VALUE_UNSIGNED_FIX(173,6249
  1679. -#define REAL_VALUE_ATOF 175,6298
  1680. -#define REAL_VALUE_NEGATE 176,6333
  1681. -#define REAL_VALUE_MINUS_ZERO(178,6373
  1682. -#define REAL_VALUE_TO_INT 181,6469
  1683. -#define REAL_VALUE_FROM_INT(184,6582
  1684. -#define REAL_VALUE_FROM_UNSIGNED_INT(187,6690
  1685. -#define REAL_VALUE_TO_TARGET_LONG_DOUBLE(191,6860
  1686. -#define REAL_VALUE_TO_TARGET_LONG_DOUBLE(193,6944
  1687. -#define REAL_VALUE_TO_TARGET_DOUBLE(195,7029
  1688. -#define REAL_VALUE_TO_TARGET_SINGLE(198,7149
  1689. -#define REAL_VALUE_FROM_TARGET_DOUBLE(202,7347
  1690. -#define REAL_VALUE_FROM_TARGET_SINGLE(205,7491
  1691. -#define REAL_VALUE_TO_DECIMAL(208,7601
  1692. -#define    REAL_IS_NOT_DOUBLE227,8396
  1693. -  } realvaluetype;realvaluetype231,8525
  1694. -#define REAL_VALUE_TYPE 232,8544
  1695. -#define REAL_VALUE_TYPE 243,8894
  1696. -#define REAL_IS_NOT_DOUBLE245,8931
  1697. -#define REAL_VALUE_TO_TARGET_SINGLE(254,9244
  1698. -#define REAL_VALUE_TO_TARGET_DOUBLE(264,9607
  1699. -#define REAL_VALUE_TO_TARGET_LONG_DOUBLE(282,10226
  1700. -#define REAL_VALUES_EQUAL(287,10397
  1701. -#define REAL_VALUES_LESS(292,10531
  1702. -#define REAL_VALUE_RNDZINT(297,10673
  1703. -#define REAL_VALUE_UNSIGNED_RNDZINT(302,10843
  1704. -#define REAL_VALUE_FIX(307,11017
  1705. -#define REAL_VALUE_UNSIGNED_FIX(313,11178
  1706. -#define REAL_VALUE_LDEXP(318,11300
  1707. -#define REAL_VALUE_ATOF(327,11551
  1708. -#define REAL_VALUE_ATOF(330,11678
  1709. -#define REAL_VALUE_NEGATE(344,12090
  1710. -#define REAL_VALUE_TRUNCATE(355,12487
  1711. -#define REAL_VALUE_ISINF(362,12711
  1712. -#define REAL_VALUE_ISNAN(367,12850
  1713. -#define REAL_VALUE_NEGATIVE(372,12995
  1714. -#define REAL_VALUE_MINUS_ZERO(377,13147
  1715. -union real_extract real_extract390,13496
  1716. -#define CONST_DOUBLE_LOW(403,13982
  1717. -#define CONST_DOUBLE_HIGH(404,14023
  1718. -#define CONST_DOUBLE_CHAIN(407,14137
  1719. -#define CONST_DOUBLE_MEM(411,14342
  1720. -#define REAL_VALUE_FROM_CONST_DOUBLE(419,14596
  1721. -#define CONST_DOUBLE_FROM_REAL_VALUE(426,14836
  1722. -#define REAL_VALUE_TO_DECIMAL(435,15210
  1723. -
  1724. -recog.h,91
  1725. -#define PROTO(24,929
  1726. -#define PROTO(26,960
  1727. -#define const79,2426
  1728. -#define OUT_FCN(85,2500
  1729. -
  1730. -regs.h,236
  1731. -#define REG_BYTES(23,838
  1732. -#define REG_SIZE(29,1105
  1733. -#define PSEUDO_REGNO_SIZE(65,2306
  1734. -#define PSEUDO_REGNO_BYTES(71,2489
  1735. -#define PSEUDO_REGNO_MODE(76,2608
  1736. -#define REGNO_POINTER_FLAG(144,5208
  1737. -#define CALLER_SAVE_PROFITABLE(165,5897
  1738. -
  1739. -reload.h,197
  1740. -#define SECONDARY_INPUT_RELOAD_CLASS(26,949
  1741. -#define SECONDARY_OUTPUT_RELOAD_CLASS(28,1046
  1742. -#define HAVE_SECONDARY_RELOADS34,1308
  1743. -#define MAX_RELOADS 40,1461
  1744. -enum reload_typereload_type84,3338
  1745. -
  1746. -rtl.h,6063
  1747. -#define RTX_CODE    35,1123
  1748. -enum rtx_code rtx_code36,1154
  1749. -#define NUM_RTX_CODE 46,1452
  1750. -#define GET_RTX_LENGTH(50,1579
  1751. -#define GET_RTX_NAME(53,1661
  1752. -#define GET_RTX_FORMAT(56,1741
  1753. -#define GET_RTX_CLASS(59,1823
  1754. -typedef union rtunion_defrtunion_def63,1926
  1755. -} rtunion;rtunion71,2084
  1756. -typedef struct rtx_defrtx_def75,2128
  1757. -} *rtx;rtx147,5268
  1758. -#define PROTO(153,5389
  1759. -#define PROTO(155,5420
  1760. -#define PVPROTO(161,5489
  1761. -#define VPROTO(162,5517
  1762. -#define VA_START(163,5544
  1763. -#define PVPROTO(165,5602
  1764. -#define VPROTO(166,5628
  1765. -#define VA_START(167,5668
  1766. -#define STDIO_PROTO(173,5765
  1767. -#define STDIO_PROTO(175,5809
  1768. -#define NULL_RTX 179,5853
  1769. -#define NULL 184,5958
  1770. -#define GENERIC_PTR 189,6068
  1771. -#define GENERIC_PTR 191,6101
  1772. -#define NULL_PTR 196,6160
  1773. -#define GET_CODE(202,6285
  1774. -#define PUT_CODE(203,6340
  1775. -#define GET_CODE(205,6407
  1776. -#define PUT_CODE(206,6444
  1777. -#define GET_MODE(209,6503
  1778. -#define PUT_MODE(210,6540
  1779. -#define RTX_INTEGRATED_P(212,6592
  1780. -#define RTX_UNCHANGING_P(213,6642
  1781. -typedef struct rtvec_def{rtvec_def219,6851
  1782. -} *rtvec;rtvec222,6943
  1783. -#define NULL_RTVEC 224,6954
  1784. -#define GET_NUM_ELEM(226,6984
  1785. -#define PUT_NUM_ELEM(227,7033
  1786. -#define RTVEC_ELT(229,7104
  1787. -#define REG_P(233,7184
  1788. -#define CONSTANT_P(237,7279
  1789. -#define XEXP(244,7556
  1790. -#define XINT(245,7597
  1791. -#define XWINT(246,7640
  1792. -#define XSTR(247,7685
  1793. -#define XVEC(248,7728
  1794. -#define XVECLEN(249,7771
  1795. -#define XVECEXP(250,7827
  1796. -#define INSN_UID(256,8040
  1797. -#define PREV_INSN(259,8128
  1798. -#define NEXT_INSN(260,8173
  1799. -#define PATTERN(263,8247
  1800. -#define INSN_CODE(267,8413
  1801. -#define LOG_LINKS(274,8770
  1802. -#define INSN_DELETED_P(277,8852
  1803. -#define CONST_CALL_P(280,8948
  1804. -#define INSN_ANNULLED_BRANCH_P(284,9119
  1805. -#define INSN_FROM_TARGET_P(290,9476
  1806. -#define REG_NOTES(344,12915
  1807. -enum reg_note reg_note347,13015
  1808. -#define REG_NOTE_KIND(354,13373
  1809. -#define PUT_REG_NOTE_KIND(355,13435
  1810. -#define GET_REG_NOTE_NAME(360,13596
  1811. -#define CALL_INSN_FUNCTION_USAGE(369,14019
  1812. -#define CODE_LABEL_NUMBER(374,14249
  1813. -#define LINE_NUMBER 376,14305
  1814. -#define NOTE_SOURCE_FILE(384,14653
  1815. -#define NOTE_BLOCK_NUMBER(385,14708
  1816. -#define NOTE_LINE_NUMBER(389,14894
  1817. -#define NOTE_INSN_DELETED 406,15617
  1818. -#define NOTE_INSN_BLOCK_BEG 407,15646
  1819. -#define NOTE_INSN_BLOCK_END 408,15677
  1820. -#define NOTE_INSN_LOOP_BEG 409,15708
  1821. -#define NOTE_INSN_LOOP_END 410,15738
  1822. -#define NOTE_INSN_FUNCTION_END 416,16100
  1823. -#define NOTE_INSN_SETJMP 418,16213
  1824. -#define NOTE_INSN_LOOP_CONT 420,16307
  1825. -#define NOTE_INSN_LOOP_VTOP 422,16395
  1826. -#define NOTE_INSN_PROLOGUE_END 424,16496
  1827. -#define NOTE_INSN_EPILOGUE_BEG 426,16605
  1828. -#define NOTE_INSN_DELETED_LABEL 428,16713
  1829. -#define NOTE_INSN_FUNCTION_BEG 432,16908
  1830. -#define NOTE_DECL_NAME(436,17022
  1831. -#define NOTE_DECL_CODE(437,17074
  1832. -#define NOTE_DECL_RTL(438,17126
  1833. -#define NOTE_DECL_IDENTIFIER(439,17175
  1834. -#define NOTE_DECL_TYPE(440,17233
  1835. -#define GET_NOTE_INSN_NAME(446,17387
  1836. -#define LABEL_NAME(450,17558
  1837. -#define LABEL_NUSES(454,17737
  1838. -#define BYTECODE_LABEL(462,18047
  1839. -#define BYTECODE_BC_LABEL(465,18140
  1840. -#define JUMP_LABEL(470,18409
  1841. -#define LABEL_REFS(476,18671
  1842. -#define LABEL_NEXTREF(482,18882
  1843. -#define CONTAINING_INSN(487,19049
  1844. -#define REGNO(491,19158
  1845. -#define REG_FUNCTION_VALUE_P(496,19309
  1846. -#define REG_USERVAR_P(499,19440
  1847. -#define INTVAL(503,19543
  1848. -#define SUBREG_REG(508,19705
  1849. -#define SUBREG_WORD(509,19749
  1850. -#define SUBREG_PROMOTED_VAR_P(519,20117
  1851. -#define SUBREG_PROMOTED_UNSIGNED_P(520,20171
  1852. -#define ASM_OPERANDS_TEMPLATE(524,20290
  1853. -#define ASM_OPERANDS_OUTPUT_CONSTRAINT(525,20341
  1854. -#define ASM_OPERANDS_OUTPUT_IDX(526,20401
  1855. -#define ASM_OPERANDS_INPUT_VEC(527,20454
  1856. -#define ASM_OPERANDS_INPUT_CONSTRAINT_VEC(528,20506
  1857. -#define ASM_OPERANDS_INPUT(529,20569
  1858. -#define ASM_OPERANDS_INPUT_LENGTH(530,20628
  1859. -#define ASM_OPERANDS_INPUT_CONSTRAINT(531,20686
  1860. -#define ASM_OPERANDS_INPUT_MODE(532,20766
  1861. -#define ASM_OPERANDS_SOURCE_FILE(533,20841
  1862. -#define ASM_OPERANDS_SOURCE_LINE(534,20895
  1863. -#define MEM_VOLATILE_P(538,21036
  1864. -#define MEM_IN_STRUCT_P(541,21154
  1865. -#define LABEL_OUTSIDE_LOOP_P(545,21315
  1866. -#define LABEL_REF_NONLOCAL_P(549,21483
  1867. -#define LABEL_PRESERVE_P(552,21609
  1868. -#define REG_LOOP_TEST_P(555,21738
  1869. -#define SCHED_GROUP_P(559,21898
  1870. -#define LINK_COST_ZERO(568,22451
  1871. -#define LINK_COST_FREE(569,22489
  1872. -#define SET_DEST(573,22626
  1873. -#define SET_SRC(574,22668
  1874. -#define TRAP_CONDITION(577,22769
  1875. -#define CONSTANT_POOL_ADDRESS_P(580,22891
  1876. -#define SYMBOL_REF_FLAG(583,23008
  1877. -#define SYMBOL_REF_USED(586,23135
  1878. -#define FIRST_FUNCTION_INSN(612,24523
  1879. -#define FIRST_PARM_INSN(613,24576
  1880. -#define FIRST_LABELNO(614,24625
  1881. -#define LAST_LABELNO(615,24674
  1882. -#define MAX_PARMREG(616,24722
  1883. -#define MAX_REGNUM(617,24769
  1884. -#define FUNCTION_ARGS_SIZE(618,24815
  1885. -#define POPS_ARGS(619,24869
  1886. -#define STACK_SLOT_LIST(620,24914
  1887. -#define FORCED_LABELS(621,24964
  1888. -#define FUNCTION_FLAGS(622,25012
  1889. -#define OUTGOING_ARGS_SIZE(623,25063
  1890. -#define ORIGINAL_ARG_VECTOR(624,25118
  1891. -#define ORIGINAL_DECL_INITIAL(625,25174
  1892. -#define FUNCTION_FLAGS_CALLS_ALLOCA 632,25512
  1893. -#define FUNCTION_FLAGS_CALLS_SETJMP 633,25551
  1894. -#define FUNCTION_FLAGS_RETURNS_STRUCT 634,25590
  1895. -#define FUNCTION_FLAGS_RETURNS_PCC_STRUCT 635,25631
  1896. -#define FUNCTION_FLAGS_NEEDS_CONTEXT 636,25677
  1897. -#define FUNCTION_FLAGS_HAS_NONLOCAL_LABEL 637,25718
  1898. -#define FUNCTION_FLAGS_RETURNS_POINTER 638,25764
  1899. -#define FUNCTION_FLAGS_USES_CONST_POOL 639,25808
  1900. -#define FUNCTION_FLAGS_CALLS_LONGJMP 640,25852
  1901. -#define FUNCTION_FLAGS_USES_PIC_OFFSET_TABLE 641,25894
  1902. -#define FIND_REG_INC_NOTE(648,26249
  1903. -#define FIND_REG_INC_NOTE(650,26333
  1904. -#define AUTO_INC_DEC658,26712
  1905. -#define exact_log2(668,26979
  1906. -#define floor_log2(669,27039
  1907. -#define plus_constant(672,27107
  1908. -#define plus_constant_for_output(674,27179
  1909. -#define GEN_INT(680,27410
  1910. -#define CONST0_RTX(848,34922
  1911. -#define CONST1_RTX(852,35027
  1912. -#define CONST2_RTX(853,35086
  1913. -#define HARD_FRAME_POINTER_REGNUM 875,36080
  1914. -#define FIRST_VIRTUAL_REGISTER    884,36467
  1915. -#define VIRTUAL_INCOMING_ARGS_REGNUM    892,36736
  1916. -#define VIRTUAL_STACK_VARS_REGNUM    900,36998
  1917. -#define VIRTUAL_STACK_DYNAMIC_REGNUM    908,37267
  1918. -#define VIRTUAL_OUTGOING_ARGS_REGNUM    916,37556
  1919. -#define LAST_VIRTUAL_REGISTER    918,37625
  1920. -#define STORE_FLAG_VALUE 939,38315
  1921. -
  1922. -scan.h,419
  1923. -typedef struct sstringsstring20,808
  1924. -} sstring;sstring25,875
  1925. -#define INIT_SSTRING(27,887
  1926. -#define FREE_SSTRING(28,965
  1927. -#define SSTRING_PUT(29,1042
  1928. -#define SSTRING_LENGTH(32,1176
  1929. -#define MAKE_SSTRING_SPACE(33,1231
  1930. -#define _PARAMS(38,1411
  1931. -#define _PARAMS(40,1444
  1932. -struct fn_declfn_decl45,1506
  1933. -#define IDENTIFIER_TOKEN 65,2135
  1934. -#define CHAR_TOKEN 66,2164
  1935. -#define STRING_TOKEN 67,2187
  1936. -#define INT_TOKEN 68,2212
  1937. -
  1938. -specs.h,0
  1939. -
  1940. -stack.h,38
  1941. -struct stack_levelstack_level25,966
  1942. -
  1943. -sys-protos.h,160
  1944. -extern ENTRY                  TLgetentry(6,257
  1945. -extern ENTRY *                hsearch(538,30567
  1946. -extern ENTRY *                hsearch(ENTRY, ACTION)538,30567
  1947. -
  1948. -sys-types.h,5084
  1949. -enum clnt_stat clnt_stat1,0
  1950. -enum auth_stat auth_stat2,29
  1951. -struct timeval timeval65,959
  1952. -struct in_addr in_addr69,1034
  1953. -struct mallinfo mallinfo71,1076
  1954. -typedef int dev_t;dev_t93,1481
  1955. -typedef int pid_t;pid_t94,1500
  1956. -typedef int gid_t;gid_t95,1519
  1957. -typedef int off_t;off_t96,1538
  1958. -typedef int mode_t;mode_t97,1557
  1959. -typedef int uid_t;uid_t98,1577
  1960. -typedef int proc_t;proc_t100,1597
  1961. -typedef int time_t;time_t101,1617
  1962. -typedef int addr_t;addr_t102,1637
  1963. -typedef int caddr_t;caddr_t103,1657
  1964. -typedef int clock_t;clock_t104,1678
  1965. -typedef int div_t;div_t105,1699
  1966. -typedef int ldiv_t;ldiv_t106,1718
  1967. -typedef int dl_t;dl_t107,1738
  1968. -typedef int major_t;major_t108,1756
  1969. -typedef int minor_t;minor_t109,1777
  1970. -typedef int emcp_t;emcp_t110,1798
  1971. -typedef int fpclass_t;fpclass_t111,1818
  1972. -typedef int index_t;index_t112,1841
  1973. -typedef int ecb_t;ecb_t113,1862
  1974. -typedef int aioop_t;aioop_t114,1881
  1975. -typedef int evver_t;evver_t115,1902
  1976. -typedef int evcntlcmds_t;evcntlcmds_t116,1923
  1977. -typedef int idtype_t;idtype_t117,1949
  1978. -typedef int id_t;id_t118,1971
  1979. -typedef int procset_t;procset_t119,1989
  1980. -typedef int hostid_t;hostid_t120,2012
  1981. -typedef int evpollcmds_t;evpollcmds_t121,2034
  1982. -typedef int event_t;event_t122,2060
  1983. -typedef int hrtime_t;hrtime_t123,2081
  1984. -typedef int evqcntlcmds_t;evqcntlcmds_t124,2103
  1985. -typedef int sigset_t;sigset_t125,2130
  1986. -typedef int evsiginfo_t;evsiginfo_t126,2152
  1987. -typedef int evcontext_t;evcontext_t127,2177
  1988. -typedef int evta_t;evta_t128,2202
  1989. -typedef int speed_t;speed_t129,2222
  1990. -typedef int rlim_t;rlim_t130,2243
  1991. -typedef int cred_t;cred_t131,2263
  1992. -typedef int file_t;file_t132,2283
  1993. -typedef int vnode_t;vnode_t133,2303
  1994. -typedef int vfs_t;vfs_t134,2324
  1995. -typedef int fpos_t;fpos_t135,2343
  1996. -typedef int exhda_t;exhda_t136,2363
  1997. -typedef int ucontext_t;ucontext_t137,2384
  1998. -typedef int sess_t;sess_t138,2408
  1999. -typedef int hrtcmd_t;hrtcmd_t139,2428
  2000. -typedef int interval_t;interval_t140,2450
  2001. -typedef int key_t;key_t141,2474
  2002. -typedef int daddr_t;daddr_t142,2493
  2003. -typedef int stack_t;stack_t143,2514
  2004. -typedef int sigaction_t;sigaction_t144,2535
  2005. -typedef int siginfo_t;siginfo_t145,2560
  2006. -typedef int mblk_t;mblk_t146,2583
  2007. -typedef int paddr_t;paddr_t147,2603
  2008. -typedef int qband_t;qband_t148,2624
  2009. -typedef int queue_t;queue_t149,2645
  2010. -typedef int rf_resource_t;rf_resource_t150,2666
  2011. -typedef int sr_mount_t;sr_mount_t151,2693
  2012. -typedef int timer_t;timer_t152,2717
  2013. -typedef int fpregset_t;fpregset_t153,2738
  2014. -typedef int prstatus_t;prstatus_t154,2762
  2015. -typedef int vfssw_t;vfssw_t155,2786
  2016. -typedef int eucwidth_t;eucwidth_t156,2807
  2017. -typedef int page_t;page_t157,2831
  2018. -typedef int u_int;u_int159,2852
  2019. -typedef int u_short;u_short160,2871
  2020. -typedef int u_long;u_long161,2892
  2021. -typedef int u_char;u_char162,2912
  2022. -typedef int ushort;ushort164,2933
  2023. -typedef int ulong;ulong165,2953
  2024. -typedef int uint;uint166,2972
  2025. -typedef int __gnuc_va_list;__gnuc_va_list168,2991
  2026. -typedef int archdr;archdr170,3020
  2027. -typedef int AUTH;AUTH171,3040
  2028. -typedef int CLIENT;CLIENT172,3058
  2029. -typedef int DIR;DIR173,3078
  2030. -typedef int ENTRY;ENTRY174,3095
  2031. -typedef int Elf;Elf175,3114
  2032. -typedef int Elf32_Ehdr;Elf32_Ehdr176,3131
  2033. -typedef int Elf32_Phdr;Elf32_Phdr177,3155
  2034. -typedef int Elf32_Shdr;Elf32_Shdr178,3179
  2035. -typedef int Elf_Arhdr;Elf_Arhdr179,3203
  2036. -typedef int Elf_Arsym;Elf_Arsym180,3226
  2037. -typedef int Elf_Cmd;Elf_Cmd181,3249
  2038. -typedef int Elf_Data;Elf_Data182,3270
  2039. -typedef int Elf_Scn;Elf_Scn183,3292
  2040. -typedef int Elf_Type;Elf_Type184,3313
  2041. -typedef int Elf_Kind;Elf_Kind185,3335
  2042. -typedef int FIELD;FIELD186,3357
  2043. -typedef int FIELDTYPE;FIELDTYPE187,3376
  2044. -typedef int PTF_int;PTF_int188,3399
  2045. -typedef int PTF_void;PTF_void189,3420
  2046. -typedef int PTF_charP;PTF_charP190,3442
  2047. -typedef int FILE;FILE191,3465
  2048. -typedef int FORM;FORM192,3483
  2049. -typedef int ITEM;ITEM193,3501
  2050. -typedef int MENU;MENU194,3519
  2051. -typedef int OPTIONS;OPTIONS195,3537
  2052. -typedef int PANEL;PANEL196,3558
  2053. -typedef int FTP_void;FTP_void197,3577
  2054. -typedef int RPCBLIST;RPCBLIST198,3599
  2055. -typedef int SCREEN;SCREEN199,3621
  2056. -typedef int SVCXPRT;SVCXPRT200,3641
  2057. -typedef int TERMINAL;TERMINAL201,3662
  2058. -typedef int WINDOW;WINDOW202,3684
  2059. -typedef int bool;bool203,3704
  2060. -typedef int nl_catd;nl_catd204,3722
  2061. -typedef int nl_item;nl_item205,3743
  2062. -typedef int chtype;chtype206,3764
  2063. -typedef int datum;datum207,3784
  2064. -typedef int fp_rnd;fp_rnd208,3803
  2065. -typedef int spraycumul;spraycumul209,3823
  2066. -typedef int WORD;WORD210,3847
  2067. -typedef int VISIT;VISIT211,3865
  2068. -typedef int ACTION;ACTION212,3884
  2069. -typedef int *jmp_buf;jmp_buf214,3905
  2070. -typedef int *sigjmp_buf;sigjmp_buf215,3927
  2071. -typedef int xdrproc_t;xdrproc_t216,3952
  2072. -typedef int CALL;CALL217,3975
  2073. -typedef int bool_t;bool_t218,3993
  2074. -typedef int DBM;DBM219,4013
  2075. -typedef int des_block;des_block220,4030
  2076. -typedef int resultproc_t;resultproc_t221,4053
  2077. -#define mode_t 226,4093
  2078. -#define uid_t 227,4112
  2079. -#define gid_t 228,4130
  2080. -#define time_t 229,4148
  2081. -#define pid_t 230,4168
  2082. -#define signal_ret_t 231,4186
  2083. -#define wait_arg_t 232,4211
  2084. -#define signal_ret_t 236,4249
  2085. -#define wait_arg_t 237,4275
  2086. -
  2087. -tconfig.h,0
  2088. -
  2089. -tm.h,0
  2090. -
  2091. -tree.h,7960
  2092. -#define DEFTREECODE(29,907
  2093. -enum tree_code tree_code31,961
  2094. -#define NUM_TREE_CODES 41,1145
  2095. -#define TREE_CODE_CLASS(51,1611
  2096. -enum built_in_functionbuilt_in_function64,1940
  2097. -typedef union tree_node *tree;tree129,3615
  2098. -struct tree_commontree_common136,3819
  2099. -#define TREE_CODE(177,4856
  2100. -#define TREE_SET_CODE(178,4919
  2101. -#define TREE_TYPE(183,5205
  2102. -#define TREE_CHAIN(194,5672
  2103. -#define STRIP_NOPS(199,5840
  2104. -#define STRIP_TYPE_NOPS(209,6192
  2105. -#define INTEGRAL_TYPE_P(220,6570
  2106. -#define FLOAT_TYPE_P(227,6854
  2107. -#define AGGREGATE_TYPE_P(234,7087
  2108. -#define POINTER_TYPE_P(241,7357
  2109. -#define TREE_ADDRESSABLE(258,8272
  2110. -#define TREE_STATIC(263,8520
  2111. -#define TREE_NO_UNUSED_WARNING(267,8722
  2112. -#define TREE_VIA_VIRTUAL(271,8904
  2113. -#define TREE_CONSTANT_OVERFLOW(276,9188
  2114. -#define TREE_SYMBOL_REFERENCED(280,9362
  2115. -#define TREE_OVERFLOW(285,9653
  2116. -#define TREE_PUBLIC(292,9977
  2117. -#define TREE_VIA_PUBLIC(297,10215
  2118. -#define TREE_VIA_PRIVATE(300,10317
  2119. -#define TREE_VIA_PROTECTED(306,10573
  2120. -#define TREE_SIDE_EFFECTS(313,10958
  2121. -#define TREE_THIS_VOLATILE(325,11511
  2122. -#define TREE_READONLY(332,11865
  2123. -#define TREE_CONSTANT(338,12112
  2124. -#define TREE_PERMANENT(343,12330
  2125. -#define TREE_UNSIGNED(348,12579
  2126. -#define TREE_ASM_WRITTEN(357,13089
  2127. -#define TREE_USED(363,13368
  2128. -#define TREE_RAISES(367,13538
  2129. -#define TREE_PRIVATE(370,13625
  2130. -#define TREE_PROTECTED(373,13762
  2131. -#define TREE_LANG_FLAG_0(376,13904
  2132. -#define TREE_LANG_FLAG_1(377,13964
  2133. -#define TREE_LANG_FLAG_2(378,14024
  2134. -#define TREE_LANG_FLAG_3(379,14084
  2135. -#define TREE_LANG_FLAG_4(380,14144
  2136. -#define TREE_LANG_FLAG_5(381,14204
  2137. -#define TREE_LANG_FLAG_6(382,14264
  2138. -#define TREE_INT_CST_LOW(390,14674
  2139. -#define TREE_INT_CST_HIGH(391,14735
  2140. -#define INT_CST_LT(393,14799
  2141. -#define INT_CST_LT_UNSIGNED(399,15045
  2142. -struct tree_int_csttree_int_cst407,15416
  2143. -#define TREE_CST_RTL(418,15724
  2144. -#define TREE_REAL_CST(425,15963
  2145. -struct tree_real_csttree_real_cst429,16039
  2146. -#define TREE_STRING_LENGTH(438,16250
  2147. -#define TREE_STRING_POINTER(439,16307
  2148. -struct tree_stringtree_string441,16367
  2149. -#define TREE_REALPART(451,16587
  2150. -#define TREE_IMAGPART(452,16638
  2151. -struct tree_complextree_complex454,16690
  2152. -#define IDENTIFIER_LENGTH(465,16974
  2153. -#define IDENTIFIER_POINTER(466,17034
  2154. -struct tree_identifiertree_identifier468,17097
  2155. -#define TREE_PURPOSE(476,17229
  2156. -#define TREE_VALUE(477,17279
  2157. -struct tree_listtree_list479,17326
  2158. -#define TREE_VEC_LENGTH(487,17474
  2159. -#define TREE_VEC_ELT(488,17525
  2160. -#define TREE_VEC_END(489,17573
  2161. -struct tree_vectree_vec491,17640
  2162. -#define SAVE_EXPR_CONTEXT(501,17852
  2163. -#define SAVE_EXPR_RTL(502,17906
  2164. -#define RTL_EXPR_SEQUENCE(505,18010
  2165. -#define RTL_EXPR_RTL(506,18090
  2166. -#define CALL_EXPR_RTL(509,18194
  2167. -#define CONSTRUCTOR_ELTS(512,18301
  2168. -#define TREE_OPERAND(515,18393
  2169. -#define TREE_COMPLEXITY(516,18449
  2170. -struct tree_exptree_exp518,18505
  2171. -#define BLOCK_VARS(526,18646
  2172. -#define BLOCK_TYPE_TAGS(527,18692
  2173. -#define BLOCK_SUBBLOCKS(528,18748
  2174. -#define BLOCK_SUPERCONTEXT(529,18804
  2175. -#define BLOCK_CHAIN(532,18961
  2176. -#define BLOCK_ABSTRACT_ORIGIN(533,19005
  2177. -#define BLOCK_ABSTRACT(534,19073
  2178. -#define BLOCK_END_NOTE(535,19132
  2179. -#define BLOCK_HANDLER_BLOCK(539,19291
  2180. -struct tree_blocktree_block541,19361
  2181. -#define TYPE_UID(561,19882
  2182. -#define TYPE_SIZE(562,19924
  2183. -#define TYPE_MODE(563,19968
  2184. -#define TYPE_VALUES(564,20012
  2185. -#define TYPE_DOMAIN(565,20060
  2186. -#define TYPE_FIELDS(566,20108
  2187. -#define TYPE_METHODS(567,20156
  2188. -#define TYPE_VFIELD(568,20205
  2189. -#define TYPE_ARG_TYPES(569,20253
  2190. -#define TYPE_METHOD_BASETYPE(570,20304
  2191. -#define TYPE_OFFSET_BASETYPE(571,20361
  2192. -#define TYPE_POINTER_TO(572,20418
  2193. -#define TYPE_REFERENCE_TO(573,20474
  2194. -#define TYPE_MIN_VALUE(574,20534
  2195. -#define TYPE_MAX_VALUE(575,20585
  2196. -#define TYPE_PRECISION(576,20636
  2197. -#define TYPE_SYMTAB_ADDRESS(577,20690
  2198. -#define TYPE_SYMTAB_POINTER(578,20754
  2199. -#define TYPE_NAME(579,20818
  2200. -#define TYPE_NEXT_VARIANT(580,20862
  2201. -#define TYPE_MAIN_VARIANT(581,20922
  2202. -#define TYPE_BINFO(582,20982
  2203. -#define TYPE_NONCOPIED_PARTS(583,21028
  2204. -#define TYPE_CONTEXT(584,21094
  2205. -#define TYPE_OBSTACK(585,21144
  2206. -#define TYPE_LANG_SPECIFIC(586,21194
  2207. -#define TYPE_ATTRIBUTES(590,21342
  2208. -#define TYPE_ALIGN(594,21498
  2209. -#define TYPE_STUB_DECL(596,21545
  2210. -#define TYPE_NO_FORCE_BLK(601,21749
  2211. -#define TYPE_VOLATILE(604,21872
  2212. -#define TYPE_READONLY(607,21975
  2213. -#define TYPE_LANG_FLAG_0(610,22115
  2214. -#define TYPE_LANG_FLAG_1(611,22173
  2215. -#define TYPE_LANG_FLAG_2(612,22231
  2216. -#define TYPE_LANG_FLAG_3(613,22289
  2217. -#define TYPE_LANG_FLAG_4(614,22347
  2218. -#define TYPE_LANG_FLAG_5(615,22405
  2219. -#define TYPE_LANG_FLAG_6(616,22463
  2220. -#define TYPE_STRING_FLAG(621,22693
  2221. -#define TYPE_NEEDS_CONSTRUCTING(625,22863
  2222. -#define TYPE_TRANSPARENT_UNION(629,23083
  2223. -#define TYPE_PACKED(633,23258
  2224. -struct tree_typetree_type635,23312
  2225. -#define BINFO_TYPE(697,25320
  2226. -#define BINFO_OFFSET(705,25674
  2227. -#define TYPE_BINFO_OFFSET(706,25726
  2228. -#define BINFO_OFFSET_ZEROP(707,25791
  2229. -#define BINFO_VTABLE(713,26079
  2230. -#define TYPE_BINFO_VTABLE(714,26131
  2231. -#define BINFO_VIRTUALS(719,26382
  2232. -#define TYPE_BINFO_VIRTUALS(720,26436
  2233. -#define BINFO_BASETYPES(732,26974
  2234. -#define TYPE_BINFO_BASETYPES(733,27029
  2235. -#define BINFO_VPTR_FIELD(739,27292
  2236. -#define BINFO_BASETYPE(742,27416
  2237. -#define TYPE_BINFO_BASETYPE(743,27490
  2238. -#define BINFO_INHERITANCE_CHAIN(756,28277
  2239. -#define DECL_NAME(762,28508
  2240. -#define DECL_ASSEMBLER_NAME(767,28750
  2241. -#define DECL_SECTION_NAME(770,28957
  2242. -#define DECL_CONTEXT(776,29348
  2243. -#define DECL_FIELD_CONTEXT(777,29398
  2244. -#define DECL_MACHINE_ATTRIBUTES(780,29550
  2245. -#define DECL_FIELD_BITPOS(783,29749
  2246. -#define DECL_BIT_FIELD_TYPE(787,29996
  2247. -#define DECL_ARGUMENTS(791,30192
  2248. -#define DECL_RESULT(793,30308
  2249. -#define DECL_ARG_TYPE_AS_WRITTEN(795,30434
  2250. -#define DECL_INITIAL(801,30729
  2251. -#define DECL_ARG_TYPE(804,30913
  2252. -#define DECL_QUALIFIER(807,31122
  2253. -#define DECL_SOURCE_FILE(809,31253
  2254. -#define DECL_SOURCE_LINE(810,31308
  2255. -#define DECL_SIZE(813,31445
  2256. -#define DECL_ALIGN(815,31540
  2257. -#define DECL_MODE(819,31757
  2258. -#define DECL_RTL(825,32134
  2259. -#define DECL_INCOMING_RTL(828,32281
  2260. -#define DECL_SAVED_INSNS(830,32413
  2261. -#define DECL_FRAME_SIZE(833,32569
  2262. -#define DECL_FUNCTION_CODE(836,32723
  2263. -#define DECL_SET_FUNCTION_CODE(837,32784
  2264. -#define DECL_FIELD_SIZE(839,32930
  2265. -#define DECL_VINDEX(848,33433
  2266. -#define DECL_FCONTEXT(852,33688
  2267. -#define DECL_UID(855,33788
  2268. -#define DECL_ABSTRACT_ORIGIN(860,34045
  2269. -#define DECL_FROM_INLINE(865,34331
  2270. -#define DECL_IGNORED_P(869,34514
  2271. -#define DECL_ABSTRACT(877,34998
  2272. -#define DECL_IN_SYSTEM_HEADER(881,35162
  2273. -#define DECL_COMMON(886,35443
  2274. -#define DECL_LANG_SPECIFIC(889,35540
  2275. -#define DECL_EXTERNAL(894,35744
  2276. -#define TYPE_DECL_SUPPRESS_DEBUG(900,36004
  2277. -#define DECL_REGISTER(906,36290
  2278. -#define DECL_PACKED(908,36413
  2279. -#define DECL_NONLOCAL(917,36818
  2280. -#define DECL_INLINE(921,36972
  2281. -#define DECL_BUILT_IN_NONANSI(926,37212
  2282. -#define DECL_BIT_FIELD(930,37371
  2283. -#define DECL_TOO_LATE(933,37567
  2284. -#define DECL_BUILT_IN(935,37687
  2285. -#define DECL_IN_TEXT_SECTION(938,37829
  2286. -#define DECL_VIRTUAL_P(943,38075
  2287. -#define DECL_DEFER_OUTPUT(947,38247
  2288. -#define DECL_TRANSPARENT_UNION(952,38475
  2289. -#define DECL_STATIC_CONSTRUCTOR(956,38667
  2290. -#define DECL_STATIC_DESTRUCTOR(957,38737
  2291. -#define DECL_ARTIFICIAL(960,38886
  2292. -#define DECL_WEAK(963,39005
  2293. -#define DECL_LANG_FLAG_0(966,39107
  2294. -#define DECL_LANG_FLAG_1(967,39165
  2295. -#define DECL_LANG_FLAG_2(968,39223
  2296. -#define DECL_LANG_FLAG_3(969,39281
  2297. -#define DECL_LANG_FLAG_4(970,39339
  2298. -#define DECL_LANG_FLAG_5(971,39397
  2299. -#define DECL_LANG_FLAG_6(972,39455
  2300. -#define DECL_LANG_FLAG_7(973,39513
  2301. -struct tree_decltree_decl975,39572
  2302. -union tree_nodetree_node1051,41685
  2303. -#define PROTO(1070,42157
  2304. -#define PROTO(1072,42188
  2305. -#define PVPROTO(1078,42257
  2306. -#define VPROTO(1079,42285
  2307. -#define VA_START(1080,42322
  2308. -#define PVPROTO(1082,42381
  2309. -#define VPROTO(1083,42407
  2310. -#define VA_START(1084,42457
  2311. -#define STDIO_PROTO(1090,42555
  2312. -#define STDIO_PROTO(1092,42599
  2313. -#define NULL_TREE 1096,42643
  2314. -#define NULL 1101,42753
  2315. -#define GENERIC_PTR 1106,42863
  2316. -#define GENERIC_PTR 1108,42896
  2317. -#define NULL_PTR 1113,42955
  2318. -#define exact_log2(1121,43198
  2319. -#define floor_log2(1122,43258
  2320. -#define build_int_2(1168,44564
  2321. -
  2322. -typeclass.h,32
  2323. -enum type_classtype_class3,52
  2324. -
  2325. -xcoffout.h,680
  2326. -#define ASM_STABS_OP 4,86
  2327. -#define DBX_TYPE_DECL_STABS_CODE 8,176
  2328. -#define DBX_OUTPUT_STANDARD_TYPES(16,465
  2329. -#define DBX_TYPE_DEFINED(24,654
  2330. -#define DBX_STATIC_CONST_VAR_CODE 29,820
  2331. -#define DBX_STATIC_BLOCK_START(46,1657
  2332. -#define DBX_STATIC_BLOCK_END(59,2108
  2333. -#define DBX_REGPARM_STABS_CODE 67,2350
  2334. -#define DBX_REGPARM_STABS_LETTER 71,2454
  2335. -#define DBX_FINISH_SYMBOL(76,2593
  2336. -#define N_DECL 106,3760
  2337. -#define N_RPSYM 112,3966
  2338. -#define DBX_OUTPUT_MAIN_SOURCE_DIRECTORY(143,4886
  2339. -#define DBX_OUTPUT_MAIN_SOURCE_FILENAME(150,5283
  2340. -#define DBX_OUTPUT_MAIN_SOURCE_FILE_END(154,5443
  2341. -#define DBX_CONTIN_LENGTH 166,5814
  2342. -#define DBX_NO_XREFS171,6054
  2343. -#define DEBUG_SYMS_TEXT177,6240
  2344. -
  2345. -alloca.c,675
  2346. -#define ADDRESS_FUNCTION(58,1913
  2347. -#define ADDRESS_FUNCTION(60,1976
  2348. -typedef void *pointer;pointer64,2034
  2349. -typedef char *pointer;pointer66,2063
  2350. -#define    NULL    69,2094
  2351. -#define malloc 82,2558
  2352. -#define    STACK_DIRECTION    95,2957
  2353. -#define    STACK_DIR    100,3043
  2354. -#define    STACK_DIR    105,3214
  2355. -find_stack_direction 108,3255
  2356. -#define    ALIGN_SIZE    139,4045
  2357. -typedef union hdrhdr142,4087
  2358. -} header;header150,4293
  2359. -alloca 162,4744
  2360. -#define CRAY_STACK230,6222
  2361. -struct stack_control_headerstack_control_header233,6315
  2362. -struct stack_segment_linkagestack_segment_linkage248,6936
  2363. -struct stk_statstk_stat286,8034
  2364. -struct stk_trailerstk_trailer315,9457
  2365. -i00afunc 344,10115
  2366. -i00afunc 418,12063
  2367. -
  2368. -bc-emit.c,1349
  2369. -prsym 66,1767
  2370. -#define HASH_BITS 84,2034
  2371. -#define HASH_SIZE 85,2055
  2372. -hash 90,2141
  2373. -sym_lookup 107,2410
  2374. -bc_sym_write 131,2898
  2375. -seg_create 166,3512
  2376. -seg_align 182,3841
  2377. -seg_data 201,4269
  2378. -seg_skip 220,4665
  2379. -seg_defsym 240,5165
  2380. -seg_refsym 264,5649
  2381. -seg_concat 284,6152
  2382. -bc_seg_write 322,7051
  2383. -bc_initialize 401,8863
  2384. -bc_define_pointer 467,10845
  2385. -bc_begin_function 479,11008
  2386. -bc_align_bytecode 491,11230
  2387. -bc_emit_bytecode_const 500,11352
  2388. -bc_get_bytecode_label 513,11704
  2389. -bc_emit_bytecode_labeldef 528,12001
  2390. -bc_emit_bytecode_labelref 551,12469
  2391. -bc_emit_code_labelref 574,13040
  2392. -bc_end_function 594,13585
  2393. -bc_align_const 641,14668
  2394. -bc_emit_const 649,14774
  2395. -bc_emit_const_skip 658,14930
  2396. -bc_emit_const_labeldef 666,15066
  2397. -bc_emit_const_labelref 674,15208
  2398. -bc_align_data 683,15363
  2399. -bc_emit_data 691,15462
  2400. -bc_emit_data_skip 700,15614
  2401. -bc_emit_data_labeldef 708,15741
  2402. -bc_emit_data_labelref 716,15874
  2403. -bc_emit_common 727,16187
  2404. -bc_globalize_label 745,16454
  2405. -bc_text 757,16629
  2406. -bc_data 763,16671
  2407. -bc_align 769,16713
  2408. -bc_emit 779,16844
  2409. -bc_emit_skip 790,17012
  2410. -bc_emit_labeldef 800,17159
  2411. -bc_emit_labelref 810,17326
  2412. -bc_write_file 821,17520
  2413. -bc_gen_rtx 832,17680
  2414. -bc_print_rtl 851,18020
  2415. -bc_emit_bytecode 865,18324
  2416. -#define PRLIT(904,19353
  2417. -#define PRLIT(906,19426
  2418. -bc_emit_instruction VPROTO(913,19675
  2419. -bc_emit_trampoline 968,21065
  2420. -bc_xstrdup 985,21333
  2421. -
  2422. -bc-optab.c,757
  2423. -#define obstack_chunk_alloc 32,1001
  2424. -#define obstack_chunk_free 33,1037
  2425. -#define GET_TYPECODE_MODE(39,1179
  2426. -#define GET_TYPECODE_SIZE(50,1548
  2427. -#define BIG_ARBITRARY_NUMBER 52,1622
  2428. -static struct conversion_recipeconversion_recipe56,1761
  2429. -static struct conversion_infoconversion_info321,8848
  2430. -#define NUM_CONVERSIONS 390,11317
  2431. -struct conversion_listconversion_list393,11442
  2432. -conversion_reasonable_p 410,12108
  2433. -deduce_conversion 522,15499
  2434. -#define DEDUCE_CONVERSION(611,17996
  2435. -emit_typecode_conversion 619,18252
  2436. -bc_init_mode_to_code_map 632,18557
  2437. -preferred_typecode 655,19142
  2438. -bc_expand_conversion 673,19509
  2439. -bc_expand_truth_conversion 686,19847
  2440. -bc_expand_binary_operation 697,20090
  2441. -bc_expand_unary_operation 738,21403
  2442. -bc_expand_increment 774,22362
  2443. -
  2444. -bi-arity.c,45
  2445. -length 27,874
  2446. -main 38,976
  2447. -xmalloc 68,1620
  2448. -
  2449. -bi-lexer.c,72
  2450. -xmalloc 34,1060
  2451. -xrealloc 53,1430
  2452. -scan_string 78,2127
  2453. -yylex 125,3049
  2454. -
  2455. -bi-opcode.c,30
  2456. -main(26,883
  2457. -xmalloc 66,1769
  2458. -
  2459. -bi-opname.c,30
  2460. -main(26,887
  2461. -xmalloc 47,1307
  2462. -
  2463. -bi-parser.c,1170
  2464. -#define YYBISON 5,91
  2465. -#define    DEFOP    7,141
  2466. -#define    STRING    8,159
  2467. -} YYSTYPE;YYSTYPE39,631
  2468. -  struct yyltypeyyltype43,667
  2469. -  yyltype;yyltype52,824
  2470. -#define YYLTYPE 54,836
  2471. -#define const61,925
  2472. -#define    YYFINAL    67,956
  2473. -#define    YYFLAG    68,976
  2474. -#define    YYNTBASE    69,999
  2475. -#define YYTRANSLATE(71,1019
  2476. -#define    YYLAST    165,5216
  2477. -#define alloca 204,6751
  2478. -#define yyerrok    240,7876
  2479. -#define yyclearin    241,7911
  2480. -#define YYEMPTY    242,7948
  2481. -#define YYEOF    243,7968
  2482. -#define YYACCEPT    244,7985
  2483. -#define YYABORT 245,8012
  2484. -#define YYERROR    246,8039
  2485. -#define YYFAIL    251,8275
  2486. -#define YYRECOVERING(252,8305
  2487. -#define YYBACKUP(253,8345
  2488. -#define YYTERROR    265,8679
  2489. -#define YYERRCODE    266,8698
  2490. -#define YYLEX    269,8736
  2491. -#define YYLEX    274,8801
  2492. -#define YYLEX    276,8846
  2493. -#define YYINITDEPTH 305,9534
  2494. -#define YYMAXDEPTH 316,9763
  2495. -#define __yy_bcopy(325,9944
  2496. -__yy_bcopy 332,10194
  2497. -__yy_bcopy 350,10546
  2498. -#define YYPARSE_PARAM_DECL 372,11056
  2499. -#define YYPARSE_PARAM374,11110
  2500. -#define YYPARSE_PARAM_DECL375,11132
  2501. -yyparse(379,11171
  2502. -  if 728,19944
  2503. -  if 742,20197
  2504. -  if 765,20815
  2505. -  if 826,22217
  2506. -  if 855,23028
  2507. -  if 881,23511
  2508. -  else if 896,23787
  2509. -makevar 931,24282
  2510. -makedef 948,24641
  2511. -yyerror 963,24910
  2512. -
  2513. -bi-reverse.c,16
  2514. -reverse(26,871
  2515. -
  2516. -c-aux-info.c,353
  2517. -enum formals_style_enum formals_style_enum32,1121
  2518. -typedef enum formals_style_enum formals_style;formals_style37,1191
  2519. -concat 54,1620
  2520. -concat3 77,2012
  2521. -affix_data_type 117,3248
  2522. -gen_formal_list_for_type 162,4456
  2523. -deserves_ellipsis 246,7591
  2524. -gen_formal_list_for_func_def 282,9146
  2525. -gen_type 357,12748
  2526. -gen_decl 517,17581
  2527. -gen_aux_info_record 597,20653
  2528. -
  2529. -c-common.c,1281
  2530. -enum attrs attrs32,1029
  2531. -declare_function_name 44,1463
  2532. -declare_hidden_char_array 71,2189
  2533. -combine_strings 105,3280
  2534. -add_attribute 223,6502
  2535. -init_attributes 249,7165
  2536. -decl_attributes 274,8224
  2537. -#define T_I    654,19334
  2538. -#define T_L    655,19365
  2539. -#define T_LL    656,19401
  2540. -#define T_S    657,19443
  2541. -#define T_UI    658,19480
  2542. -#define T_UL    659,19513
  2543. -#define T_ULL    660,19551
  2544. -#define T_US    661,19595
  2545. -#define T_F    662,19634
  2546. -#define T_D    663,19663
  2547. -#define T_LD    664,19693
  2548. -#define T_C    665,19729
  2549. -#define T_V    666,19757
  2550. -#define T_W    667,19785
  2551. -#define T_ST 668,19814
  2552. -} format_char_info;format_char_info689,20570
  2553. -typedef struct function_format_info function_format_info721,21804
  2554. -} function_format_info;function_format_info728,22186
  2555. -init_function_format_info 742,22740
  2556. -record_function_format 765,23996
  2557. -check_function_format 806,25113
  2558. -check_format_info 832,25742
  2559. -constant_expression_warning 1301,39011
  2560. -overflow_warning 1318,39629
  2561. -unsigned_conversion_warning 1345,40469
  2562. -convert_and_check 1366,41299
  2563. -c_expand_expr_stmt 1398,42227
  2564. -check_case_value 1418,42834
  2565. -type_for_size 1446,43480
  2566. -type_for_mode 1486,44837
  2567. -min_precision 1539,46588
  2568. -binary_op_error 1570,47602
  2569. -shorten_compare 1645,49640
  2570. -truthvalue_conversion 1972,59548
  2571. -get_directive_line 2144,65511
  2572. -c_build_type_variant 2216,67236
  2573. -
  2574. -c-convert.c,17
  2575. -convert 59,2205
  2576. -
  2577. -c-decl.c,2557
  2578. -enum decl_contextdecl_context38,1373
  2579. -#define CHAR_TYPE_SIZE 47,1712
  2580. -#define SHORT_TYPE_SIZE 51,1781
  2581. -#define INT_TYPE_SIZE 55,1887
  2582. -#define LONG_TYPE_SIZE 59,1954
  2583. -#define LONG_LONG_TYPE_SIZE 63,2027
  2584. -#define WCHAR_UNSIGNED 67,2106
  2585. -#define FLOAT_TYPE_SIZE 71,2163
  2586. -#define DOUBLE_TYPE_SIZE 75,2234
  2587. -#define LONG_DOUBLE_TYPE_SIZE 79,2317
  2588. -#define SIZE_TYPE 89,2729
  2589. -#define PTRDIFF_TYPE 93,2796
  2590. -#define WCHAR_TYPE 97,2855
  2591. -struct binding_levelbinding_level308,9124
  2592. -#define NULL_BINDING_LEVEL 369,11374
  2593. -#define DOLLARS_IN_IDENTIFIERS 548,16354
  2594. -c_decode_option 557,16598
  2595. -print_lang_decl 739,22506
  2596. -print_lang_type 747,22603
  2597. -print_lang_identifier 755,22700
  2598. -finish_incomplete_decl 772,23381
  2599. -make_binding_level 793,23817
  2600. -global_bindings_p 802,24005
  2601. -keep_next_level 808,24092
  2602. -kept_level_p 816,24213
  2603. -declare_parm_level 832,24727
  2604. -in_parm_level_p 841,24894
  2605. -pushlevel 851,25104
  2606. -poplevel 909,26775
  2607. -delete_block 1139,34389
  2608. -insert_block 1163,35062
  2609. -set_block 1175,35306
  2610. -push_label_level 1182,35406
  2611. -pop_label_level 1210,36005
  2612. -pushtag 1271,37881
  2613. -duplicate_decls 1313,39147
  2614. -pushdecl 1878,59656
  2615. -pushdecl_top_level 2297,74863
  2616. -implicitly_declare 2313,75232
  2617. -redeclaration_error_message 2381,77534
  2618. -lookup_label 2442,79888
  2619. -shadow_label 2495,81336
  2620. -define_label 2529,82249
  2621. -getdecls 2566,83295
  2622. -gettags 2574,83434
  2623. -storedecls 2584,83704
  2624. -storetags 2593,83861
  2625. -lookup_tag 2610,84450
  2626. -pending_xref_error 2647,85471
  2627. -lookup_tag_reverse 2661,85870
  2628. -lookup_name 2684,86460
  2629. -lookup_name_current_level 2699,86795
  2630. -lookup_name_current_level_global 2721,87242
  2631. -init_decl_processing 2746,87859
  2632. -builtin_function 3281,108693
  2633. -shadow_tag 3321,110157
  2634. -shadow_tag_warned 3328,110247
  2635. -groktypename 3396,111729
  2636. -groktypename_in_parm_context 3409,112014
  2637. -start_decl 3439,113079
  2638. -finish_decl 3578,117582
  2639. -maybe_build_cleanup 3855,126877
  2640. -push_parm_decl 3868,127204
  2641. -clear_parm_order 3910,128411
  2642. -complete_array_type 3920,128688
  2643. -grokdeclarator 4020,131828
  2644. -grokparms 5021,164767
  2645. -get_parm_info 5128,168152
  2646. -parmlist_tags_warning 5223,171125
  2647. -xref_tag 5260,172161
  2648. -start_struct 5318,174111
  2649. -grokfield 5361,175376
  2650. -field_decl_cmp 5383,175900
  2651. -finish_struct 5396,176257
  2652. -layout_array_type 5718,185936
  2653. -start_enum 5733,186362
  2654. -finish_enum 5782,187811
  2655. -build_enumerator 5888,191355
  2656. -start_function 5966,193625
  2657. -c_mark_varargs 6132,199834
  2658. -store_parm_decls 6145,200183
  2659. -combine_parm_decls 6567,213859
  2660. -finish_function 6710,218112
  2661. -struct c_functionc_function6846,222472
  2662. -push_c_function_context 6864,222830
  2663. -pop_c_function_context 6889,223498
  2664. -copy_lang_decl 6928,224697
  2665. -
  2666. -c-iterate.c,632
  2667. -struct  ixpansionixpansion80,3152
  2668. -struct iter_stack_nodeiter_stack_node91,3431
  2669. -init_iterators 108,3892
  2670. -iterator_for_loop_start 117,4085
  2671. -iterator_for_loop_end 128,4322
  2672. -iterator_expand 148,4861
  2673. -expand_stmt_with_iterators_1 160,5096
  2674. -collect_iterators 189,6022
  2675. -iterator_loop_prologue 278,8088
  2676. -iterator_loop_epilogue 326,9660
  2677. -top_level_ixpansion_p 355,10590
  2678. -isn_append 364,10737
  2679. -#define ISN_ZERO(384,11015
  2680. -istack_sublevel_to_current 391,11250
  2681. -push_iterator_stack 409,11760
  2682. -pop_iterator_stack 425,12127
  2683. -add_ixpansion 441,12460
  2684. -delete_ixpansion 471,13350
  2685. -prdecl 522,14703
  2686. -pil 543,15040
  2687. -pixl 560,15362
  2688. -pis 583,15777
  2689. -
  2690. -c-lang.c,437
  2691. -lang_decode_option 31,993
  2692. -lang_init 38,1070
  2693. -lang_finish 47,1296
  2694. -lang_identify 52,1323
  2695. -print_lang_statistics 58,1364
  2696. -lookup_interface 65,1443
  2697. -is_class_name 72,1503
  2698. -maybe_objc_check_decl 79,1559
  2699. -maybe_objc_comptypes 85,1613
  2700. -maybe_objc_method_name 93,1719
  2701. -maybe_building_objc_message_expr 100,1786
  2702. -recognize_objc_keyword 106,1843
  2703. -build_objc_string 112,1891
  2704. -GNU_xref_begin 121,1990
  2705. -GNU_xref_end 127,2061
  2706. -finish_file 134,2198
  2707. -
  2708. -c-lex.c,595
  2709. -#define YYDEBUG 53,1414
  2710. -#define WCHAR_TYPE_SIZE 74,1966
  2711. -#define WCHAR_TYPE_SIZE    76,2010
  2712. -#define WCHAR_BYTES 81,2107
  2713. -make_pointer_declarator 110,3157
  2714. -forget_protocol_qualifiers 117,3295
  2715. -remember_protocol_qualifiers 128,3547
  2716. -init_lex 146,4050
  2717. -reinit_parse_for_function 220,6919
  2718. -yyprint 227,7035
  2719. -skip_white_space 270,7869
  2720. -position_after_white_space 326,8968
  2721. -extend_token_buffer 344,9393
  2722. -check_newline 361,9852
  2723. -handle_sysv_pragma 685,18053
  2724. -#define ENDFILE 719,18632
  2725. -readescape 725,18835
  2726. -yyerror 860,21662
  2727. -struct try_typetry_type888,22426
  2728. -yylex 908,22826
  2729. -set_yydebug 2013,50961
  2730. -
  2731. -c-pragma.c,29
  2732. -handle_pragma_token 43,1382
  2733. -
  2734. -c-typeck.c,2578
  2735. -require_complete_type 79,3206
  2736. -incomplete_type_error 98,3681
  2737. -qualify_type 161,5150
  2738. -common_type 178,5704
  2739. -comptypes 444,14082
  2740. -comp_target_types 550,17066
  2741. -function_types_compatible_p 577,17876
  2742. -type_lists_compatible_p 627,19287
  2743. -self_promoting_args_p 707,21672
  2744. -self_promoting_type_p 733,22152
  2745. -unsigned_type 748,22410
  2746. -signed_type 768,22981
  2747. -signed_or_unsigned_type 789,23577
  2748. -c_sizeof 812,24518
  2749. -c_sizeof_nowarn 848,25450
  2750. -c_size_in_bytes 871,25961
  2751. -c_alignof 900,26636
  2752. -c_alignof_expr 920,27171
  2753. -decl_constant_value 960,28319
  2754. -default_conversion 989,29440
  2755. -lookup_field 1120,33686
  2756. -build_component_ref 1212,35856
  2757. -build_indirect_ref 1296,38367
  2758. -build_array_ref 1353,40313
  2759. -build_function_call 1488,44645
  2760. -convert_arguments 1590,47991
  2761. -parser_build_binary_op 1768,54602
  2762. -build_binary_op 1879,58563
  2763. -pointer_int_sum 2599,82817
  2764. -pointer_diff 2680,85668
  2765. -build_unary_op 2724,87118
  2766. -convert_sequence 3095,97850
  2767. -lvalue_p 3123,98511
  2768. -lvalue_or_else 3156,99175
  2769. -unary_complex_lvalue 3173,99601
  2770. -pedantic_lvalue_warning 3203,100473
  2771. -readonly_warning 3215,100772
  2772. -mark_addressable 3255,101778
  2773. -build_conditional_expr 3331,103602
  2774. -build_compound_expr 3532,110190
  2775. -internal_build_compound_expr 3539,110302
  2776. -build_c_cast 3600,112527
  2777. -build_modify_expr 3766,117681
  2778. -convert_for_assignment 3940,123545
  2779. -warn_for_assignment 4190,132864
  2780. -initializer_constant_valid_p 4236,134209
  2781. -valid_compound_expr_initializer 4364,138595
  2782. -store_init_value 4389,139321
  2783. -struct spellingspelling4448,141068
  2784. -#define SPELLING_STRING 4458,141153
  2785. -#define SPELLING_MEMBER 4459,141179
  2786. -#define SPELLING_BOUNDS 4460,141205
  2787. -#define SPELLING_DEPTH(4469,141552
  2788. -#define RESTORE_SPELLING_DEPTH(4470,141604
  2789. -#define SAVE_SPELLING_DEPTH(4474,141747
  2790. -#define PUSH_SPELLING(4484,141980
  2791. -push_string 4509,142705
  2792. -push_member_name 4518,142875
  2793. -push_array_bounds 4530,143146
  2794. -spelling_length 4539,143321
  2795. -print_spelling 4558,143633
  2796. -get_spelling 4589,144246
  2797. -error_init 4624,145234
  2798. -pedwarn_init 4650,145974
  2799. -warning_init 4676,146716
  2800. -digest_init 4701,147427
  2801. -struct constructor_stackconstructor_stack5004,157816
  2802. -struct initializer_stackinitializer_stack5036,158538
  2803. -start_init 5058,159024
  2804. -finish_init 5126,160948
  2805. -really_start_incremental_init 5169,162396
  2806. -push_init_level 5269,165597
  2807. -check_init_type_bitfields 5421,170587
  2808. -pop_init_level 5455,171519
  2809. -set_init_index 5671,177877
  2810. -set_init_label 5715,179375
  2811. -output_init_element 5755,180543
  2812. -output_pending_init_elements 5942,186648
  2813. -process_init_element 6095,191272
  2814. -c_expand_asm_operands 6365,199601
  2815. -c_expand_return 6433,201883
  2816. -c_expand_start_case 6526,204489
  2817. -
  2818. -caller-save.c,297
  2819. -#define MAX_MOVE_MAX 33,1072
  2820. -#define MIN_UNITS_PER_WORD 37,1137
  2821. -init_caller_save 98,3407
  2822. -init_save_areas 214,6863
  2823. -setup_save_areas 249,8305
  2824. -save_call_clobbered_regs 349,11141
  2825. -set_reg_live 510,16620
  2826. -clear_reg_live 542,17403
  2827. -restore_referenced_regs 566,18081
  2828. -insert_save_restore 639,20512
  2829. -
  2830. -calls.c,360
  2831. -#define PUSH_ARGS_REVERSED    42,1323
  2832. -#define STACK_BYTES 48,1454
  2833. -struct arg_dataarg_data52,1572
  2834. -calls_function 144,5375
  2835. -calls_function_1 156,5580
  2836. -prepare_call_address 255,8045
  2837. -emit_call_1 342,11046
  2838. -expand_call 479,15270
  2839. -emit_library_call VPROTO(2218,73170
  2840. -emit_library_call_value VPROTO(2493,81499
  2841. -target_for_arg 2878,92962
  2842. -store_one_arg 2922,94455
  2843. -
  2844. -cccp.c,7149
  2845. -typedef unsigned char U_CHAR;U_CHAR25,1070
  2846. -#define NO_SHORTNAMES28,1114
  2847. -#define STANDARD_INCLUDE_DIR 44,1467
  2848. -#define LOCAL_INCLUDE_DIR 48,1545
  2849. -#define PTR_INT_TYPE 53,1693
  2850. -#define PTR_INT_TYPE 55,1730
  2851. -#define PATH_SEPARATOR 63,1878
  2852. -# define HAVE_STDLIB_H 84,2306
  2853. -# define HAVE_UNISTD_H 87,2362
  2854. -# define STDC_HEADERS 90,2417
  2855. -# define HAVE_FCNTL_H 96,2558
  2856. -# define bcmp(132,3100
  2857. -# define bcopy(135,3163
  2858. -# define bzero(138,3227
  2859. -#  define bcmp 147,3409
  2860. -my_bcmp 149,3443
  2861. -#  define bcopy 163,3658
  2862. -my_bcopy 165,3695
  2863. -#  define bzero 176,3874
  2864. -my_bzero 178,3911
  2865. -# define __attribute__(191,4216
  2866. -#  define PROTO(196,4332
  2867. -#  define PROTO(198,4366
  2868. -# define VA_START(204,4477
  2869. -# define PRINTF_ALIST(205,4533
  2870. -# define PRINTF_DCL(206,4575
  2871. -# define PRINTF_PROTO(207,4600
  2872. -# define VA_START(210,4715
  2873. -# define PRINTF_ALIST(211,4766
  2874. -# define PRINTF_DCL(212,4807
  2875. -# define PRINTF_PROTO(213,4850
  2876. -# define vfprintf(214,4927
  2877. -#define PRINTF_PROTO_1(224,5195
  2878. -#define PRINTF_PROTO_2(225,5249
  2879. -#define PRINTF_PROTO_3(226,5303
  2880. -#define O_RDONLY    235,5468
  2881. -#define O_WRONLY    236,5517
  2882. -#define read(237,5566
  2883. -#define write(238,5615
  2884. -#define open(239,5666
  2885. -#define fopen(240,5723
  2886. -#define freopen(241,5772
  2887. -#define strncat(242,5837
  2888. -#define fstat(243,5892
  2889. -typedef struct { unsigned :16, :16, :16; } vms_ino_t;vms_ino_t252,6184
  2890. -#define ino_t 253,6238
  2891. -#define INCLUDE_LEN_FUDGE 254,6262
  2892. -#define BSTRING    256,6350
  2893. -#define O_RDONLY 261,6469
  2894. -#define MIN(266,6518
  2895. -#define MAX(267,6559
  2896. -#define HOST_BITS_PER_WIDE_INT 274,6746
  2897. -#define HOST_WIDE_INT 275,6796
  2898. -#define HOST_BITS_PER_WIDE_INT 277,6829
  2899. -#define HOST_WIDE_INT 278,6878
  2900. -#define S_ISREG(284,6936
  2901. -#define S_ISDIR(288,7007
  2902. -#define NULL 294,7141
  2903. -#define GENERIC_PTR 299,7251
  2904. -#define GENERIC_PTR 301,7284
  2905. -#define NULL_PTR 306,7343
  2906. -#define INCLUDE_LEN_FUDGE 310,7411
  2907. -#define INPUT_STACK_MAX 503,12790
  2908. -static struct file_buf file_buf504,12818
  2909. -#define CHECK_DEPTH(534,13887
  2910. -typedef struct file_buf FILE_BUF;FILE_BUF545,14224
  2911. -#define OUTBUF_SIZE 551,14451
  2912. -#define check_expand(557,14623
  2913. -struct file_name_listfile_name_list561,14770
  2914. -static struct default_include default_include581,15466
  2915. -typedef struct macrodef MACRODEF;MACRODEF668,19039
  2916. -struct macrodefmacrodef669,19073
  2917. -enum sharp_token_type sharp_token_type676,19155
  2918. -typedef struct definition DEFINITION;DEFINITION707,20559
  2919. -struct definition definition708,20597
  2920. -union hashval hashval740,21837
  2921. -#define REST_EXTENSION_LENGTH    759,22549
  2922. -enum node_type node_type769,23069
  2923. -struct hashnode hashnode810,24630
  2924. -typedef struct hashnode HASHNODE;HASHNODE822,25123
  2925. -#define HASHSIZE 831,25542
  2926. -#define HASHSTEP(833,25600
  2927. -#define MAKE_POS(834,25642
  2928. -#define SIZE_TYPE 853,26238
  2929. -#define PTRDIFF_TYPE 859,26352
  2930. -#define WCHAR_TYPE 865,26456
  2931. -#define USER_LABEL_PREFIX 873,26615
  2932. -#define REGISTER_PREFIX 879,26724
  2933. -#define IMMEDIATE_PREFIX 885,26833
  2934. -struct tokenlist_list tokenlist_list893,27073
  2935. -struct assertion_hashnode assertion_hashnode898,27158
  2936. -typedef struct assertion_hashnode ASSERTION_HASHNODE;ASSERTION_HASHNODE911,27639
  2937. -#define ASSERTION_HASHSIZE 920,28069
  2938. -#define DO_PROTO 929,28380
  2939. -struct directive directive931,28458
  2940. -#define SKIP_WHITE_SPACE(1006,31077
  2941. -#define SKIP_ALL_WHITE_SPACE(1007,31152
  2942. -#define DOLLARS_IN_IDENTIFIERS 1023,31685
  2943. -struct if_stack if_stack1030,31836
  2944. -typedef struct if_stack IF_STACK_FRAME;IF_STACK_FRAME1040,32285
  2945. -static DEFINITION *collect_expansion 1111,34701
  2946. -enum file_change_code file_change_code1136,35886
  2947. -static void fatal PRINTF_PROTO_1(1190,37986
  2948. -safe_write 1239,39419
  2949. -main 1260,39730
  2950. -path_include 2344,70717
  2951. -index0 2396,72076
  2952. -trigraph_pcp 2427,72821
  2953. -newline_fix 2500,74487
  2954. -name_newline_fix 2533,75254
  2955. -get_lintcmd 2573,76300
  2956. -rescan 2654,79325
  2957. -expand_to_temp_buffer 3579,104304
  2958. -handle_directive 3662,106348
  2959. -timestamp 4058,116421
  2960. -special_symbol 4078,116826
  2961. -do_include 4256,120819
  2962. -redundant_include_p 4713,134299
  2963. -is_system_include 4737,135184
  2964. -struct file_name_mapfile_name_map4771,136240
  2965. -#define FILE_NAME_MAP_FILE 4778,136335
  2966. -read_filename_string 4784,136470
  2967. -read_name_map 4815,136999
  2968. -open_include_file 4904,139327
  2969. -finclude 4986,141682
  2970. -record_control_macro 5102,144556
  2971. -#define IMPORT_HASH_SIZE 5121,144979
  2972. -struct import_file import_file5123,145008
  2973. -import_hash 5137,145299
  2974. -lookup_import 5152,145639
  2975. -add_import 5196,146732
  2976. -check_precompiled 5227,147875
  2977. -check_preconditions 5283,149000
  2978. -pcfinclude 5342,150544
  2979. -pcstring_used 5457,154178
  2980. -write_output 5470,154443
  2981. -pass_thru_directive 5522,156166
  2982. -struct arglist arglist5556,157361
  2983. -create_definition 5567,157577
  2984. -do_define 5743,162400
  2985. -check_macro_name 5810,164380
  2986. -compare_defs 5832,164873
  2987. -     DEFINITION *d1,5833,164895
  2988. -comp_def_part 5875,166268
  2989. -collect_expansion 5918,167786
  2990. -do_assert 6207,175477
  2991. -do_unassert 6284,177501
  2992. -check_assertion 6384,179984
  2993. -compare_token_lists 6427,181030
  2994. -read_token_list 6450,181649
  2995. -free_token_list 6515,183189
  2996. -assertion_install 6536,183665
  2997. -assertion_lookup 6576,184694
  2998. -delete_assertion 6593,185026
  2999. -#define FNAME_HASHSIZE 6614,185490
  3000. -do_line 6617,185528
  3001. -do_undef 6769,189196
  3002. -do_error 6811,190334
  3003. -do_warning 6832,190871
  3004. -do_once 6850,191330
  3005. -do_ident 6877,191916
  3006. -do_pragma 6913,192939
  3007. -do_pragma 6962,194380
  3008. -do_sccs 6984,194941
  3009. -do_if 7010,195737
  3010. -do_elif 7029,196145
  3011. -eval_if_expression 7071,197317
  3012. -do_xifdef 7100,198007
  3013. -conditional_skip 7194,200782
  3014. -skip_if_group 7227,201561
  3015. -do_else 7511,208586
  3016. -do_endif 7556,209741
  3017. -validate_else 7618,211560
  3018. -skip_to_end_of_comment 7667,213013
  3019. -skip_quoted_string 7773,215664
  3020. -quote_string 7840,217385
  3021. -skip_paren_group 7879,218096
  3022. -output_line_directive 7932,219143
  3023. -struct argdata argdata8012,221606
  3024. -macroexpand 8030,222108
  3025. -macarg 8426,233877
  3026. -macarg1 8561,238143
  3027. -discard_comments 8661,240373
  3028. -change_newlines 8769,242811
  3029. -my_strerror 8822,243769
  3030. -error 8855,244621
  3031. -verror 8866,244767
  3032. -error_from_errno 8891,245214
  3033. -warning 8916,245644
  3034. -vwarning 8927,245794
  3035. -error_with_line 8957,246344
  3036. -verror_with_line 8972,246597
  3037. -vwarning_with_line 8996,247021
  3038. -pedwarn 9028,247591
  3039. -pedwarn_with_line 9043,247839
  3040. -pedwarn_with_file_and_line 9065,248337
  3041. -print_containing_files 9093,248992
  3042. -line_for_error 9143,250346
  3043. -grow_outbuf 9174,251061
  3044. -install 9217,252376
  3045. -lookup 9270,253544
  3046. -delete_macro 9310,254604
  3047. -hashf 9344,255306
  3048. -dump_single_macro 9360,255583
  3049. -dump_all_macros 9446,257748
  3050. -dump_defn_1 9467,258261
  3051. -dump_arg_n 9500,258996
  3052. -     DEFINITION *defn;9501,259026
  3053. -initialize_char_syntax 9520,259367
  3054. -initialize_builtins 9565,260403
  3055. -make_definition 9674,264534
  3056. -make_undef 9761,266589
  3057. -make_assertion 9790,267236
  3058. -append_include_chain 9849,268611
  3059. -deps_output 9882,269313
  3060. -fatal 9922,270221
  3061. -fancy_abort 9939,270595
  3062. -perror_with_name 9945,270660
  3063. -pfatal_with_name 9954,270827
  3064. -pipe_closed 9968,271012
  3065. -memory_full 9976,271164
  3066. -xmalloc 9983,271228
  3067. -xrealloc 9993,271389
  3068. -xcalloc 10004,271584
  3069. -savestring 10016,271820
  3070. -file_size_and_mode 10029,272103
  3071. -output_dots 10043,272413
  3072. -hack_vms_include_specification 10061,272733
  3073. -read 10227,278706
  3074. -write 10254,279228
  3075. -freopen 10285,280057
  3076. -fopen 10297,280382
  3077. -open 10315,280954
  3078. -strncat 10329,281389
  3079. -VMS_fstat 10365,282548
  3080. -VMS_stat 10385,282936
  3081. -
  3082. -collect2.c,2606
  3083. -#define COLLECT42,1374
  3084. -#define obstack_chunk_alloc 63,1705
  3085. -#define obstack_chunk_free 64,1741
  3086. -#define const67,1818
  3087. -#define vfork 71,1851
  3088. -#define PROTO(77,1989
  3089. -#define PROTO(79,2020
  3090. -#define R_OK 84,2071
  3091. -#define W_OK 85,2086
  3092. -#define X_OK 86,2101
  3093. -#define WIFSIGNALED(90,2144
  3094. -#define WTERMSIG(93,2235
  3095. -#define WIFEXITED(96,2293
  3096. -#define WEXITSTATUS(99,2361
  3097. -#define P_tmpdir 106,2552
  3098. -#define OBJECT_FORMAT_NONE132,3443
  3099. -#define MY_ISCOFF(158,3958
  3100. -#define USE_MMAP166,4077
  3101. -#define NM_FLAGS 185,4387
  3102. -#define NAME__MAIN 195,4740
  3103. -#define SYMBOL__MAIN 196,4768
  3104. -#define SCAN_LIBRARIES200,4856
  3105. -struct id id211,5025
  3106. -struct headhead218,5093
  3107. -enum pass pass227,5241
  3108. -struct prefix_listprefix_list281,7116
  3109. -struct path_prefixpath_prefix287,7265
  3110. -dup2 325,8719
  3111. -my_strerror 346,9053
  3112. -collect_exit 370,9365
  3113. -fatal_perror 398,9846
  3114. -fatal 412,10118
  3115. -error 424,10356
  3116. -fancy_abort 436,10667
  3117. -handler 443,10729
  3118. -xcalloc 461,11006
  3119. -xmalloc 473,11185
  3120. -xrealloc 485,11345
  3121. -file_exists 496,11540
  3122. -savestring 505,11677
  3123. -dump_file 516,11860
  3124. -is_ctor_dtor 576,13152
  3125. -choose_temp_base 634,14695
  3126. -putenv 670,15418
  3127. -#define PATH_SEPARATOR 715,16335
  3128. -is_in_prefix_list 742,17107
  3129. -find_a_file 778,17801
  3130. -add_prefix 830,18937
  3131. -prefix_from_env 866,19687
  3132. -prefix_from_string 877,19858
  3133. -main 915,20517
  3134. -collect_wait 1520,38119
  3135. -do_wait 1554,38671
  3136. -collect_execute 1569,38917
  3137. -fork_execute 1628,40070
  3138. -maybe_unlink 1639,40252
  3139. -add_to_list 1652,40431
  3140. -write_list 1687,41157
  3141. -write_list_with_asm 1700,41380
  3142. -write_c_file_stat 1717,41784
  3143. -write_c_file_glob 1814,44503
  3144. -write_c_file 1841,45375
  3145. -write_export_file 1854,45589
  3146. -scan_prog_file 1874,46271
  3147. -mapfile 2064,50505
  3148. -libselect 2088,50991
  3149. -libcompare 2095,51108
  3150. -locatelib 2124,51625
  3151. -scan_libraries 2216,53549
  3152. -scan_libraries 2291,55496
  3153. -#   define GCC_SYMBOLS(2439,58715
  3154. -#   define GCC_SYMENT    2440,58787
  3155. -#   define GCC_OK_SYMBOL(2441,58815
  3156. -#   define GCC_SYMINC(2442,58882
  3157. -#   define GCC_SYMZERO(2443,58911
  3158. -#   define GCC_CHECK_HDR(2444,58960
  3159. -#   define GCC_SYMBOLS(2446,59012
  3160. -#   define GCC_SYMENT    2447,59062
  3161. -#   define GCC_OK_SYMBOL(2448,59092
  3162. -#   define GCC_SYMINC(2452,59276
  3163. -#   define GCC_SYMZERO(2453,59318
  3164. -#   define GCC_CHECK_HDR(2454,59346
  3165. -scan_prog_file 2469,59903
  3166. -typedef union load_unionload_union2560,61888
  3167. -} load_union_t;load_union_t2573,62524
  3168. -typedef struct load_allload_all2577,62612
  3169. -} load_all_t;load_all_t2581,62725
  3170. -struct file_infofile_info2585,62814
  3171. -scan_prog_file 2618,64066
  3172. -add_func_table 2891,71639
  3173. -print_header 2971,74221
  3174. -print_load_command 3014,76097
  3175. -bad_header 3081,78126
  3176. -read_file 3106,78846
  3177. -end_file 3171,80375
  3178. -
  3179. -combine.c,1969
  3180. -#define gen_lowpart 102,4149
  3181. -#define REVERSIBLE_CC_MODE(128,4889
  3182. -#define INSN_CUID(143,5369
  3183. -struct undoundo321,12095
  3184. -#define MAX_UNDO 337,12573
  3185. -struct undobufundobuf339,12594
  3186. -#define SUBST(355,13041
  3187. -#define SUBST_INT(372,13637
  3188. -combine_instructions 453,17448
  3189. -init_reg_last_arrays 667,24118
  3190. -setup_incoming_promotions 685,24832
  3191. -set_nonzero_bits_and_sign_copies 718,25950
  3192. -can_combine_p 803,28760
  3193. -combinable_i3pat 1073,39199
  3194. -try_combine 1191,43003
  3195. -undo_all 2380,86661
  3196. -find_split_point 2410,87442
  3197. -subst 2779,100093
  3198. -simplify_rtx 2962,106427
  3199. -simplify_if_then_else 3916,140711
  3200. -simplify_set 4208,151379
  3201. -simplify_logical 4491,161317
  3202. -expand_compound_operation 4775,170938
  3203. -expand_field_assignment 4903,175175
  3204. -make_extraction 5030,179497
  3205. -extract_left_shift 5337,190606
  3206. -make_compound_operation 5397,192580
  3207. -get_pos_from_mask 5642,201191
  3208. -force_to_mode 5679,202298
  3209. -if_then_else_cond 6167,220108
  3210. -known_cond 6340,226227
  3211. -make_field_assignment 6428,228528
  3212. -apply_distributive_law 6540,233089
  3213. -simplify_and_const_int 6666,237416
  3214. -nonzero_bits 6777,241503
  3215. -num_sign_bit_copies 7149,253517
  3216. -extended_count 7450,264189
  3217. -merge_outer_ops 7487,265603
  3218. -simplify_shift_const 7615,268784
  3219. -recog_for_combine 8339,293391
  3220. -gen_lowpart_for_combine 8440,296456
  3221. -gen_rtx_combine VPROTO(8543,299996
  3222. -gen_binary 8612,301644
  3223. -gen_unary 8662,303017
  3224. -simplify_comparison 8687,303808
  3225. -reversible_comparison_p 9675,336617
  3226. -update_table_tick 9711,337612
  3227. -record_value_for_reg 9743,338550
  3228. -record_dead_and_set_regs_1 9836,341502
  3229. -record_dead_and_set_regs 9877,343099
  3230. -get_last_value_validate 9931,344711
  3231. -get_last_value 9979,346006
  3232. -use_crosses_set_p 10078,349248
  3233. -reg_dead_at_p_1 10138,350750
  3234. -reg_dead_at_p 10164,351528
  3235. -mark_used_regs_combine 10225,353133
  3236. -remove_death 10326,355646
  3237. -move_deaths 10350,356257
  3238. -reg_bitfield_target_p 10485,360351
  3239. -distribute_notes 10540,361889
  3240. -distribute_links 10935,374620
  3241. -dump_combine_stats 11023,377263
  3242. -dump_combine_total_stats 11033,377522
  3243. -
  3244. -convert.c,112
  3245. -convert_to_pointer 36,1227
  3246. -convert_to_real 80,2397
  3247. -convert_to_integer 118,3497
  3248. -convert_to_complex 414,13468
  3249. -
  3250. -cplus-dem.c,1620
  3251. -#define CURRENT_DEMANGLING_STYLE 34,1331
  3252. -mystrstr 40,1478
  3253. -#define CPLUS_MARKER 73,2669
  3254. -set_cplus_marker_for_demangling 81,2839
  3255. -struct work_stuffwork_stuff90,3038
  3256. -#define PRINT_ANSI_QUALIFIERS 102,3264
  3257. -#define PRINT_ARG_TYPES 103,3324
  3258. -static const struct optableoptable105,3387
  3259. -typedef struct string    string192,6815
  3260. -} string;string197,7059
  3261. -#define STRING_EMPTY(199,7070
  3262. -#define PREPEND_BLANK(200,7123
  3263. -#define APPEND_BLANK(202,7211
  3264. -#define ARM_VTABLE_STRING 205,7298
  3265. -#define ARM_VTABLE_STRLEN 206,7372
  3266. -consume_count 310,9839
  3267. -cplus_demangle_opname 325,10027
  3268. -cplus_mangle_opname 454,13051
  3269. -int cplus_match 475,13539
  3270. -cplus_demangle 516,14910
  3271. -mop_up 569,16414
  3272. -demangle_signature 631,17922
  3273. -demangle_method_args 819,22944
  3274. -demangle_template 842,23340
  3275. -arm_pt 1090,28437
  3276. -demangle_arm_pt 1112,28872
  3277. -demangle_class_name 1148,29636
  3278. -demangle_class 1202,30942
  3279. -demangle_prefix 1266,32623
  3280. -gnu_special 1454,37521
  3281. -arm_special 1613,41130
  3282. -demangle_qualified 1696,43242
  3283. -get_count 1846,46515
  3284. -do_type 1885,47058
  3285. -demangle_fund_type 2117,51346
  3286. -do_arg 2264,54155
  3287. -remember_type 2283,54474
  3288. -forget_types 2315,55170
  3289. -demangle_args 2374,56855
  3290. -demangle_function_name 2501,59421
  3291. -string_need 2653,63250
  3292. -string_delete 2680,63625
  3293. -string_init 2691,63760
  3294. -string_clear 2698,63839
  3295. -string_empty 2707,63910
  3296. -string_append 2716,63993
  3297. -string_appends 2730,64195
  3298. -string_appendn 2745,64392
  3299. -string_prepend 2759,64578
  3300. -string_prepends 2770,64738
  3301. -string_prependn 2780,64876
  3302. -demangle_it 2807,65395
  3303. -usage 2830,65776
  3304. -#define MBUF_SIZE 2842,66071
  3305. -main 2860,66516
  3306. -fatal 2971,68529
  3307. -xmalloc 2982,68670
  3308. -xrealloc 2992,68840
  3309. -
  3310. -cppalloc.c,73
  3311. -memory_full 28,1166
  3312. -xmalloc 34,1224
  3313. -xrealloc 45,1395
  3314. -xcalloc 56,1567
  3315. -
  3316. -cpperror.c,144
  3317. -cpp_print_containing_files 36,1325
  3318. -cpp_file_line_for_message 80,2290
  3319. -void cpp_message 92,2600
  3320. -fatal 107,2906
  3321. -cpp_pfatal_with_name 118,3077
  3322. -
  3323. -cppexp.c,1692
  3324. -struct arglist arglist41,1337
  3325. -#define NULL 51,1504
  3326. -#define GENERIC_PTR 56,1614
  3327. -#define GENERIC_PTR 58,1647
  3328. -#define NULL_PTR 63,1706
  3329. -#define CHAR_TYPE_SIZE 69,1797
  3330. -#define INT_TYPE_SIZE 73,1864
  3331. -#define LONG_TYPE_SIZE 77,1931
  3332. -#define WCHAR_TYPE_SIZE 81,2000
  3333. -#define MAX_CHAR_TYPE_SIZE 85,2073
  3334. -#define MAX_INT_TYPE_SIZE 89,2149
  3335. -#define MAX_LONG_TYPE_SIZE 93,2224
  3336. -#define MAX_WCHAR_TYPE_SIZE 97,2302
  3337. -#define possible_sum_sign(102,2499
  3338. -#define ERROR 108,2664
  3339. -#define OROR 109,2682
  3340. -#define ANDAND 110,2699
  3341. -#define EQUAL 111,2718
  3342. -#define NOTEQUAL 112,2736
  3343. -#define LEQ 113,2757
  3344. -#define GEQ 114,2773
  3345. -#define LSH 115,2789
  3346. -#define RSH 116,2805
  3347. -#define NAME 117,2821
  3348. -#define INT 118,2838
  3349. -#define CHAR 119,2854
  3350. -#define LEFT_OPERAND_REQUIRED 121,2872
  3351. -#define RIGHT_OPERAND_REQUIRED 122,2904
  3352. -#define HAVE_VALUE 123,2937
  3353. -#define HOST_BITS_PER_WIDE_INT 129,3058
  3354. -#define HOST_WIDE_INT 130,3108
  3355. -#define HOST_BITS_PER_WIDE_INT 132,3141
  3356. -#define HOST_WIDE_INT 133,3190
  3357. -struct operation operation138,3232
  3358. -parse_number 152,3699
  3359. -struct token token256,6106
  3360. -cpp_lex 278,6417
  3361. -cpp_parse_escape 486,11756
  3362. -integer_overflow 585,13750
  3363. -left_shift 593,13916
  3364. -right_shift 617,14332
  3365. -#define PAREN_INNER_PRIO 632,14695
  3366. -#define COMMA_PRIO 633,14722
  3367. -#define COND_PRIO 634,14743
  3368. -#define OROR_PRIO 635,14776
  3369. -#define ANDAND_PRIO 636,14808
  3370. -#define OR_PRIO 637,14842
  3371. -#define XOR_PRIO 638,14874
  3372. -#define AND_PRIO 639,14903
  3373. -#define EQUAL_PRIO 640,14933
  3374. -#define LESS_PRIO 641,14965
  3375. -#define SHIFT_PRIO 642,14998
  3376. -#define PLUS_PRIO 643,15031
  3377. -#define MUL_PRIO 644,15064
  3378. -#define UNARY_PRIO 645,15095
  3379. -#define PAREN_OUTER_PRIO 646,15127
  3380. -#define COMPARE(648,15168
  3381. -cpp_parse_expr 656,15411
  3382. -
  3383. -cpphash.c,172
  3384. -#define NULL 33,1291
  3385. -#define const37,1331
  3386. -#define volatile38,1345
  3387. -hashf 46,1487
  3388. -cpp_lookup 70,2038
  3389. -delete_macro 112,3167
  3390. -install 158,4422
  3391. -cpp_hash_cleanup 205,5348
  3392. -
  3393. -cpplib.c,4927
  3394. -#define NO_SHORTNAMES26,1106
  3395. -#define STANDARD_INCLUDE_DIR 42,1459
  3396. -#define LOCAL_INCLUDE_DIR 46,1537
  3397. -#define PTR_INT_TYPE 51,1685
  3398. -#define PTR_INT_TYPE 53,1722
  3399. -#define STDC_VALUE 61,1832
  3400. -#define PATH_SEPARATOR 66,1942
  3401. -#define O_RDONLY 95,2500
  3402. -#define MIN(100,2549
  3403. -#define MAX(101,2590
  3404. -#define HOST_BITS_PER_WIDE_INT 108,2777
  3405. -#define HOST_WIDE_INT 109,2827
  3406. -#define HOST_BITS_PER_WIDE_INT 111,2860
  3407. -#define HOST_WIDE_INT 112,2909
  3408. -#define S_ISREG(118,2967
  3409. -#define S_ISDIR(122,3038
  3410. -#define NULL 128,3172
  3411. -#define GENERIC_PTR 133,3282
  3412. -#define GENERIC_PTR 135,3315
  3413. -#define NULL_PTR 140,3374
  3414. -#define INCLUDE_LEN_FUDGE 144,3442
  3415. -#define SIZE_TYPE 164,4009
  3416. -#define PTRDIFF_TYPE 170,4123
  3417. -#define WCHAR_TYPE 176,4227
  3418. -#define CPP_WCHAR_TYPE(178,4259
  3419. -#define USER_LABEL_PREFIX 184,4429
  3420. -#define REGISTER_PREFIX 190,4538
  3421. -struct tokenlist_list tokenlist_list198,4777
  3422. -struct assertion_hashnode assertion_hashnode203,4862
  3423. -#define SKIP_WHITE_SPACE(216,5344
  3424. -#define SKIP_ALL_WHITE_SPACE(217,5419
  3425. -#define PEEKN(219,5495
  3426. -#define FORWARD(220,5609
  3427. -#define GETC(221,5666
  3428. -#define PEEKC(222,5714
  3429. -#define CPP_IS_MACRO_BUFFER(225,5906
  3430. -#define NEWLINE_FIX 234,6302
  3431. -#define NEWLINE_FIX1(238,6467
  3432. -struct cpp_pending cpp_pending246,6654
  3433. -enum file_change_code file_change_code303,8284
  3434. -struct file_name_listfile_name_list336,9156
  3435. -#define SELF_DIR_DUMMY 354,9797
  3436. -static struct default_include default_include360,10041
  3437. -struct directive directive404,11684
  3438. -initialize_char_syntax 454,13575
  3439. -quote_string 497,14639
  3440. -cpp_grow_buffer 533,15239
  3441. -cpp_define 553,15766
  3442. -make_assertion 607,16918
  3443. -append_include_chain 654,18002
  3444. -deps_output 690,18878
  3445. -path_include 731,20007
  3446. -init_parse_options 778,21056
  3447. -null_underflow 812,21862
  3448. -null_cleanup 819,21936
  3449. -macro_cleanup 827,22031
  3450. -file_cleanup 840,22327
  3451. -newline_fix 853,22504
  3452. -skip_comment 893,23447
  3453. -cpp_skip_hspace 954,24563
  3454. -copy_rest_of_line 992,25364
  3455. -skip_rest_of_line 1041,26255
  3456. -handle_directive 1053,26478
  3457. -pass_thru_directive 1176,30240
  3458. -struct arglist arglist1208,31384
  3459. -collect_expansion 1229,32086
  3460. -#define REST_EXTENSION_LENGTH    1508,40027
  3461. -create_definition 1513,40198
  3462. -check_macro_name 1688,45095
  3463. -compare_defs 1718,45851
  3464. -     DEFINITION *d1,1719,45873
  3465. -comp_def_part 1761,47249
  3466. -do_define 1795,48299
  3467. -#define ARG_BASE 1879,50989
  3468. -struct argdata argdata1881,51031
  3469. -cpp_push_buffer 1892,51242
  3470. -cpp_pop_buffer 1920,52021
  3471. -cpp_scan_buffer 1940,52467
  3472. -cpp_expand_to_buffer 1967,53139
  3473. -adjust_position 2014,53919
  3474. -update_position 2033,54240
  3475. -cpp_buf_line_and_col 2049,54704
  3476. -cpp_file_buffer 2072,55154
  3477. -count_newlines 2084,55386
  3478. -output_line_command 2107,55962
  3479. -macarg 2193,58254
  3480. -change_newlines 2253,59730
  3481. -timestamp 2292,60361
  3482. -special_symbol 2312,60787
  3483. -initialize_builtins 2502,65046
  3484. -unsafe_chars 2595,68742
  3485. -macroexpand 2645,70484
  3486. -push_macro_expansion 3049,81888
  3487. -get_directive_token 3087,83288
  3488. -do_include 3122,84181
  3489. -redundant_include_p 3542,97031
  3490. -is_system_include 3567,97965
  3491. -assertion_install 3601,98805
  3492. -assertion_lookup 3642,99886
  3493. -delete_assertion 3660,100259
  3494. -convert_string 3692,101101
  3495. -#define FNAME_HASHSIZE 3734,101870
  3496. -do_line 3737,101908
  3497. -do_undef 3869,105970
  3498. -do_error 3914,107213
  3499. -do_warning 3935,107751
  3500. -do_once 3953,108210
  3501. -do_ident 3982,108836
  3502. -do_pragma 4003,109466
  3503. -do_pragma 4055,111002
  3504. -do_sccs 4075,111540
  3505. -do_if 4099,112324
  3506. -do_elif 4115,112700
  3507. -eval_if_expression 4157,113983
  3508. -do_xifdef 4185,114660
  3509. -conditional_skip 4267,117003
  3510. -skip_if_group 4301,117831
  3511. -do_else 4466,122057
  3512. -do_endif 4509,123268
  3513. -validate_else 4583,125162
  3514. -cpp_get_token 4600,125540
  3515. -cpp_get_non_space_token 5243,141929
  3516. -parse_name 5260,142314
  3517. -import_hash 5292,142848
  3518. -lookup_import 5307,143188
  3519. -add_import 5352,144333
  3520. -struct file_name_mapfile_name_map5380,145336
  3521. -#define FILE_NAME_MAP_FILE 5387,145431
  3522. -read_filename_string 5393,145566
  3523. -struct file_name_map_listfile_name_map_list5422,146095
  3524. -read_name_map 5432,146311
  3525. -open_include_file 5513,148442
  3526. -finclude 5593,150789
  3527. -push_parse_file 5712,153484
  3528. -init_parse_file 6205,168038
  3529. -nreverse_pending 6225,168563
  3530. -push_pending 6240,168833
  3531. -cpp_handle_options 6259,169352
  3532. -cpp_finish 6723,182409
  3533. -cpp_cleanup 6755,183232
  3534. -do_assert 6821,184633
  3535. -do_unassert 6894,186810
  3536. -check_assertion 6988,189242
  3537. -compare_token_lists 7032,190352
  3538. -reverse_token_list 7049,190686
  3539. -read_token_list 7067,191158
  3540. -free_token_list 7147,192926
  3541. -file_size_and_mode 7162,193241
  3542. -safe_read 7181,193798
  3543. -savestring 7206,194173
  3544. -parse_set_mark 7217,194401
  3545. -parse_clear_mark 7230,194699
  3546. -parse_goto_mark 7244,195038
  3547. -parse_move_mark 7258,195441
  3548. -cpp_read_check_assertion 7269,195700
  3549. -cpp_print_file_and_line 7298,196513
  3550. -cpp_error 7313,196824
  3551. -cpp_warning 7326,197116
  3552. -cpp_pedwarn 7345,197541
  3553. -cpp_error_with_line 7357,197810
  3554. -cpp_warning_with_line 7375,198219
  3555. -cpp_pedwarn_with_line 7401,198758
  3556. -cpp_pedwarn_with_file_and_line 7417,199232
  3557. -my_strerror 7459,200161
  3558. -cpp_error_from_errno 7490,200991
  3559. -cpp_perror_with_name 7506,201326
  3560. -
  3561. -cppmain.c,35
  3562. -fancy_abort 39,1295
  3563. -main 46,1354
  3564. -
  3565. -crtstuff.c,394
  3566. -#define CTORS_SECTION_ASM_OP    75,3509
  3567. -#define DTORS_SECTION_ASM_OP    78,3600
  3568. -typedef void (*func_ptr)func_ptr84,3738
  3569. -#define STATIC 85,3771
  3570. -#define ON_EXIT(92,3866
  3571. -#define STATIC94,3895
  3572. -__do_global_dtors_aux 120,4791
  3573. -fini_dummy 129,4969
  3574. -void __do_global_ctors 148,5616
  3575. -__do_global_ctors_aux 178,6788
  3576. -__do_global_ctors_aux 232,8683
  3577. -init_dummy 241,8877
  3578. -__do_global_ctors_aux 290,10655
  3579. -
  3580. -cse.c,2248
  3581. -#define INSN_CUID(339,13731
  3582. -struct table_elttable_elt411,16366
  3583. -#define NBUCKETS 431,16905
  3584. -#define HASH(436,17075
  3585. -#define FIXED_REGNO_P(447,17594
  3586. -#define FIXED_REGNO_P(452,17777
  3587. -#define CHEAP_REGNO(462,18219
  3588. -#define CHEAP_REG(472,18711
  3589. -#define COST(476,18828
  3590. -#define REGNO_QTY_VALID_P(486,19121
  3591. -struct write_datawrite_data530,20753
  3592. -#define PATHLENGTH    540,21046
  3593. -struct cse_basic_block_data cse_basic_block_data544,21148
  3594. -#define FIXED_BASE_PLUS_P(570,22073
  3595. -#define NONZERO_BASE_PLUS_P(588,22867
  3596. -#define COSTS_N_INSNS(675,27094
  3597. -rtx_cost 678,27138
  3598. -new_basic_block 761,29251
  3599. -make_new_qty 800,30140
  3600. -make_regs_eqv 821,30543
  3601. -delete_reg_equiv 882,32746
  3602. -mention_regs 920,33550
  3603. -insert_regs 1002,35915
  3604. -free_element 1061,37473
  3605. -get_element 1071,37671
  3606. -remove_from_table 1089,38139
  3607. -lookup 1169,40232
  3608. -lookup_for_remove 1188,40730
  3609. -lookup_as_function 1219,41477
  3610. -#define CHEAPER(1263,42983
  3611. -insert 1266,43057
  3612. -merge_equiv_classes 1434,48320
  3613. -invalidate 1496,50216
  3614. -remove_invalid_refs 1608,53292
  3615. -rehash_using_reg 1630,53848
  3616. -invalidate_memory 1681,55280
  3617. -invalidate_for_call 1705,55840
  3618. -use_related_value 1761,57406
  3619. -canon_hash 1845,59847
  3620. -safe_hash 1997,63293
  3621. -exp_equiv_p 2027,64532
  3622. -refers_to_p 2181,68088
  3623. -set_nonvarying_address_components 2239,69361
  3624. -refers_to_mem_p 2355,72620
  3625. -cse_rtx_addr_varies_p 2418,74052
  3626. -canon_reg 2457,75550
  3627. -find_best_addr 2547,78349
  3628. -find_comparison_args 2763,85456
  3629. -simplify_unary_operation 2918,90192
  3630. -simplify_binary_operation 3342,101100
  3631. -simplify_plus_minus 4183,124447
  3632. -cse_gen_binary 4353,128664
  3633. -simplify_relational_operation 4398,130177
  3634. -simplify_ternary_operation 4615,136970
  3635. -fold_rtx 4694,139258
  3636. -equiv_constant 5624,168730
  3637. -gen_lowpart_if_possible 5670,170047
  3638. -record_jump_equiv 5716,171502
  3639. -record_jump_cond 5764,173079
  3640. -struct setset5986,179855
  3641. -cse_insn 6020,180981
  3642. -note_mem_written 7450,230481
  3643. -invalidate_from_clobbers 7502,232318
  3644. -cse_process_notes 7568,234161
  3645. -cse_around_loop 7652,236527
  3646. -invalidate_skipped_set 7721,239140
  3647. -invalidate_skipped_block 7754,240186
  3648. -cse_check_loop_start 7789,241118
  3649. -cse_set_around_loop 7820,242233
  3650. -cse_end_of_basic_block 7919,245888
  3651. -cse_main 8131,252658
  3652. -cse_basic_block 8309,258225
  3653. -count_reg_usage 8505,264641
  3654. -delete_dead_from_cse 8594,267049
  3655. -
  3656. -dbxout.c,1596
  3657. -#define ASM_STABS_OP 93,3531
  3658. -#define ASM_STABN_OP 97,3590
  3659. -#define DBX_TYPE_DECL_STABS_CODE 101,3661
  3660. -#define DBX_STATIC_CONST_VAR_CODE 105,3743
  3661. -#define DBX_REGPARM_STABS_CODE 109,3822
  3662. -#define DBX_REGPARM_STABS_LETTER 113,3901
  3663. -#define GDB_INV_REF_REGPARM_STABS_LETTER 118,4067
  3664. -#define DBX_MEMPARM_STABS_LETTER 122,4153
  3665. -#define FILE_NAME_JOINER 126,4223
  3666. -#define FORCE_TEXT 154,5084
  3667. -#define FORCE_TEXT156,5126
  3668. -#define N_CATCH 166,5411
  3669. -#define STAB_CODE_TYPE 171,5481
  3670. -#define STAB_CODE_TYPE 173,5533
  3671. -#define PARM_PASSED_IN_MEMORY(178,5624
  3672. -#define DEBUGGER_AUTO_OFFSET(184,5853
  3673. -#define DEBUGGER_ARG_OFFSET(191,6111
  3674. -enum typestatus typestatus206,6370
  3675. -#define CHARS(259,8324
  3676. -#define DBX_CONTIN_LENGTH 265,8495
  3677. -#define CONTIN 269,8558
  3678. -#define CONTIN272,8663
  3679. -abspath 302,9698
  3680. -dbxout_init 397,12324
  3681. -dbxout_typedefs 491,15626
  3682. -dbxout_source_file 511,16061
  3683. -dbxout_source_line 543,17026
  3684. -dbxout_finish 562,17480
  3685. -dbxout_continue 578,17946
  3686. -dbxout_type_fields 595,18357
  3687. -dbxout_type_method_1 696,21345
  3688. -dbxout_type_methods 740,22535
  3689. -dbxout_range_type 887,26833
  3690. -dbxout_type 927,28190
  3691. -print_int_cst_octal 1432,43262
  3692. -print_octal 1476,44555
  3693. -dbxout_type_name 1491,44911
  3694. -dbxout_symbol 1518,45579
  3695. -dbxout_symbol_location 1793,54031
  3696. -dbxout_symbol_name 2003,60928
  3697. -dbxout_prepare_symbol 2022,61517
  3698. -dbxout_finish_symbol 2033,61692
  3699. -dbxout_syms 2055,62180
  3700. -dbxout_parms 2078,62898
  3701. -dbxout_reg_parms 2299,70046
  3702. -dbxout_args 2329,71080
  3703. -dbxout_types 2346,71423
  3704. -dbxout_block 2377,72385
  3705. -dbxout_really_begin_function 2480,75405
  3706. -dbxout_begin_function 2492,75682
  3707. -dbxout_function 2507,76119
  3708. -
  3709. -doschk.c,264
  3710. -typedef struct ENTENT19,307
  3711. -} ENT;ENT26,413
  3712. -invalid_msg 38,645
  3713. -alloc_ent 52,856
  3714. -fill_ent 65,1075
  3715. -compare_ent_dosname 179,3141
  3716. -compare_ent_fullname 192,3388
  3717. -mpath 205,3646
  3718. -add_ent 221,4006
  3719. -handle_input 229,4076
  3720. -display_problems 238,4186
  3721. -main 331,6366
  3722. -
  3723. -dwarfout.c,8567
  3724. -#define DWARF_VERSION 40,1295
  3725. -#define inline 76,2297
  3726. -#define inline 78,2332
  3727. -#define ASM_COMMENT_START 83,2430
  3728. -#define PRINT_REG(88,2528
  3729. -#define TYPE_USED_FOR_FUNCTION(107,3435
  3730. -#define MAX_ARTIFICIAL_LABEL_BYTES    115,3667
  3731. -#define CHAR_TYPE_SIZE 123,3974
  3732. -#define SHORT_TYPE_SIZE 127,4043
  3733. -#define INT_TYPE_SIZE 131,4117
  3734. -#define LONG_TYPE_SIZE 135,4184
  3735. -#define LONG_LONG_TYPE_SIZE 139,4257
  3736. -#define WCHAR_TYPE_SIZE 143,4337
  3737. -#define WCHAR_UNSIGNED 147,4406
  3738. -#define FLOAT_TYPE_SIZE 151,4463
  3739. -#define DOUBLE_TYPE_SIZE 155,4534
  3740. -#define LONG_DOUBLE_TYPE_SIZE 159,4617
  3741. -struct filename_entry filename_entry164,4729
  3742. -typedef struct filename_entry filename_entry;filename_entry169,4791
  3743. -#define FT_ENTRIES_INCREMENT 189,5437
  3744. -#define NEXT_DIE_NUM 224,6569
  3745. -#define PENDING_SIBLINGS_INCREMENT 245,7290
  3746. -#define PENDING_TYPES_INCREMENT 271,8141
  3747. -#define FILE_ASM_OP    312,9804
  3748. -#define VERSION_ASM_OP    315,9863
  3749. -#define UNALIGNED_SHORT_ASM_OP    318,9936
  3750. -#define UNALIGNED_INT_ASM_OP    321,10012
  3751. -#define ASM_BYTE_OP    324,10077
  3752. -#define SET_ASM_OP    327,10132
  3753. -#define PUSHSECTION_ASM_OP    339,10695
  3754. -#define POPSECTION_ASM_OP    342,10766
  3755. -#define PUSHSECTION_FORMAT    351,11137
  3756. -#define DEBUG_SECTION    355,11207
  3757. -#define LINE_SECTION    358,11267
  3758. -#define SFNAMES_SECTION    361,11328
  3759. -#define SRCINFO_SECTION    364,11401
  3760. -#define MACINFO_SECTION    367,11474
  3761. -#define PUBNAMES_SECTION    370,11548
  3762. -#define ARANGES_SECTION    373,11622
  3763. -#define TEXT_SECTION    376,11692
  3764. -#define DATA_SECTION    379,11750
  3765. -#define DATA1_SECTION    382,11809
  3766. -#define RODATA_SECTION    385,11871
  3767. -#define RODATA1_SECTION    388,11936
  3768. -#define BSS_SECTION    391,11999
  3769. -#define TEXT_BEGIN_LABEL    413,13033
  3770. -#define TEXT_END_LABEL    416,13100
  3771. -#define DATA_BEGIN_LABEL    420,13169
  3772. -#define DATA_END_LABEL    423,13236
  3773. -#define DATA1_BEGIN_LABEL    427,13306
  3774. -#define DATA1_END_LABEL    430,13376
  3775. -#define RODATA_BEGIN_LABEL    434,13449
  3776. -#define RODATA_END_LABEL    437,13522
  3777. -#define RODATA1_BEGIN_LABEL    441,13597
  3778. -#define RODATA1_END_LABEL    444,13673
  3779. -#define BSS_BEGIN_LABEL    448,13746
  3780. -#define BSS_END_LABEL    451,13811
  3781. -#define LINE_BEGIN_LABEL    455,13878
  3782. -#define LINE_LAST_ENTRY_LABEL    458,13952
  3783. -#define LINE_END_LABEL    461,14027
  3784. -#define DEBUG_BEGIN_LABEL    465,14097
  3785. -#define SFNAMES_BEGIN_LABEL    468,14171
  3786. -#define SRCINFO_BEGIN_LABEL    471,14249
  3787. -#define MACINFO_BEGIN_LABEL    474,14327
  3788. -#define DIE_BEGIN_LABEL_FMT    478,14406
  3789. -#define DIE_END_LABEL_FMT    481,14476
  3790. -#define PUB_DIE_LABEL_FMT    484,14546
  3791. -#define INSN_LABEL_FMT    487,14611
  3792. -#define BLOCK_BEGIN_LABEL_FMT    490,14684
  3793. -#define BLOCK_END_LABEL_FMT    493,14758
  3794. -#define SS_BEGIN_LABEL_FMT    496,14831
  3795. -#define SS_END_LABEL_FMT    499,14899
  3796. -#define EE_BEGIN_LABEL_FMT    502,14969
  3797. -#define EE_END_LABEL_FMT    505,15037
  3798. -#define MT_BEGIN_LABEL_FMT    508,15107
  3799. -#define MT_END_LABEL_FMT    511,15175
  3800. -#define LOC_BEGIN_LABEL_FMT    514,15246
  3801. -#define LOC_END_LABEL_FMT    517,15316
  3802. -#define BOUND_BEGIN_LABEL_FMT    520,15390
  3803. -#define BOUND_END_LABEL_FMT    523,15470
  3804. -#define DERIV_BEGIN_LABEL_FMT    526,15552
  3805. -#define DERIV_END_LABEL_FMT    529,15626
  3806. -#define SL_BEGIN_LABEL_FMT    532,15699
  3807. -#define SL_END_LABEL_FMT    535,15768
  3808. -#define BODY_BEGIN_LABEL_FMT    538,15841
  3809. -#define BODY_END_LABEL_FMT    541,15913
  3810. -#define FUNC_END_LABEL_FMT    544,15985
  3811. -#define TYPE_NAME_FMT    547,16052
  3812. -#define DECL_NAME_FMT    550,16113
  3813. -#define LINE_CODE_LABEL_FMT    553,16180
  3814. -#define SFNAMES_ENTRY_LABEL_FMT    556,16257
  3815. -#define LINE_ENTRY_LABEL_FMT    559,16334
  3816. -#define ASM_OUTPUT_PUSH_SECTION(569,16643
  3817. -#define ASM_OUTPUT_POP_SECTION(574,16799
  3818. -#define ASM_OUTPUT_SOURCE_FILENAME(579,16929
  3819. -#define ASM_OUTPUT_DWARF_DELTA2(587,17151
  3820. -#define ASM_OUTPUT_DWARF_DELTA4(597,17455
  3821. -#define ASM_OUTPUT_DWARF_TAG(607,17754
  3822. -#define ASM_OUTPUT_DWARF_ATTRIBUTE(619,18124
  3823. -#define ASM_OUTPUT_DWARF_STACK_OP(631,18502
  3824. -#define ASM_OUTPUT_DWARF_FUND_TYPE(642,18854
  3825. -#define ASM_OUTPUT_DWARF_FMT_BYTE(654,19231
  3826. -#define ASM_OUTPUT_DWARF_TYPE_MODIFIER(665,19589
  3827. -#define ASM_OUTPUT_DWARF_ADDR(676,19942
  3828. -#define ASM_OUTPUT_DWARF_ADDR_CONST(684,20172
  3829. -#define ASM_OUTPUT_DWARF_REF(693,20427
  3830. -#define ASM_OUTPUT_DWARF_DATA1(701,20651
  3831. -#define ASM_OUTPUT_DWARF_DATA2(706,20790
  3832. -#define ASM_OUTPUT_DWARF_DATA4(711,20951
  3833. -#define ASM_OUTPUT_DWARF_DATA8(716,21110
  3834. -#define ASM_OUTPUT_DWARF_STRING(732,21645
  3835. -xstrdup 739,21836
  3836. -is_pseudo_reg 749,21973
  3837. -type_main_variant 758,22214
  3838. -is_tagged_type 780,22848
  3839. -dwarf_tag_name 790,23075
  3840. -dwarf_attr_name 840,25234
  3841. -dwarf_stack_op_name 918,28782
  3842. -dwarf_typemod_name 935,29188
  3843. -dwarf_fmt_byte_name 949,29518
  3844. -dwarf_fund_type_name 967,30025
  3845. -decl_ultimate_origin 1030,32496
  3846. -block_ultimate_origin 1059,33271
  3847. -output_unsigned_leb128 1084,33783
  3848. -output_signed_leb128 1106,34327
  3849. -is_body_block 1152,35727
  3850. -fundamental_type_code 1195,37167
  3851. -root_type 1319,41428
  3852. -write_modifier_bytes 1343,41954
  3853. -type_is_fundamental 1377,42922
  3854. -equate_decl_number_to_die_number 1426,44230
  3855. -equate_type_number_to_die_number 1458,45619
  3856. -output_reg_number 1477,46245
  3857. -output_mem_loc_descriptor 1509,47344
  3858. -output_loc_descriptor 1589,50070
  3859. -output_bound_representation 1623,50893
  3860. -output_enumeral_list 1712,53781
  3861. -ceiling 1729,54254
  3862. -field_type 1741,54648
  3863. -simple_type_align_in_bits 1760,55124
  3864. -simple_type_size_in_bits 1773,55600
  3865. -field_byte_offset 1797,56387
  3866. -sibling_attribute 1917,61465
  3867. -location_attribute 1931,61929
  3868. -data_member_location_attribute 1995,64861
  3869. -const_value_attribute 2020,65967
  3870. -location_or_const_value_attribute 2105,69528
  3871. -name_attribute 2244,75979
  3872. -fund_type_attribute 2255,76222
  3873. -mod_fund_type_attribute 2263,76414
  3874. -user_def_type_attribute 2283,77167
  3875. -mod_u_d_type_attribute 2294,77464
  3876. -ordering_attribute 2316,78321
  3877. -subscript_data_attribute 2328,78704
  3878. -byte_size_attribute 2430,82085
  3879. -bit_offset_attribute 2490,84084
  3880. -bit_size_attribute 2542,86026
  3881. -element_list_attribute 2559,86622
  3882. -stmt_list_attribute 2585,87602
  3883. -low_pc_attribute 2597,87932
  3884. -high_pc_attribute 2608,88221
  3885. -body_begin_attribute 2618,88487
  3886. -body_end_attribute 2628,88761
  3887. -language_attribute 2639,89088
  3888. -member_attribute 2647,89292
  3889. -string_length_attribute 2663,89696
  3890. -comp_dir_attribute 2679,90272
  3891. -sf_names_attribute 2687,90456
  3892. -src_info_attribute 2696,90725
  3893. -mac_info_attribute 2705,90994
  3894. -prototyped_attribute 2714,91263
  3895. -producer_attribute 2726,91563
  3896. -inline_attribute 2734,91750
  3897. -containing_type_attribute 2745,91964
  3898. -abstract_origin_attribute 2756,92277
  3899. -src_coords_attribute 2781,92829
  3900. -pure_or_virtual_attribute 2792,93173
  3901. -name_and_src_coords_attributes 2815,93884
  3902. -type_attribute 2851,95194
  3903. -type_tag 2899,97047
  3904. -dienum_push 2939,98458
  3905. -dienum_pop 2960,99020
  3906. -member_declared_type 2966,99073
  3907. -function_start_label 2979,99386
  3908. -output_array_type_die 3003,99861
  3909. -output_set_type_die 3030,100844
  3910. -output_entry_point_die 3045,101224
  3911. -output_inlined_enumeration_type_die 3072,101924
  3912. -output_inlined_structure_type_die 3086,102269
  3913. -output_inlined_union_type_die 3100,102606
  3914. -output_enumeration_type_die 3116,103074
  3915. -output_formal_parameter_die 3152,104428
  3916. -output_global_subroutine_die 3194,105491
  3917. -output_global_variable_die 3239,106788
  3918. -output_label_die 3266,107468
  3919. -output_lexical_block_die 3305,108553
  3920. -output_inlined_subroutine_die 3326,109114
  3921. -output_local_variable_die 3351,109892
  3922. -output_member_die 3375,110528
  3923. -output_pointer_type_die 3404,111359
  3924. -output_reference_type_die 3417,111669
  3925. -output_ptr_to_mbr_type_die 3431,111990
  3926. -output_compile_unit_die 3445,112368
  3927. -output_string_type_die 3492,113595
  3928. -output_structure_type_die 3507,113936
  3929. -output_local_subroutine_die 3535,114800
  3930. -output_subroutine_type_die 3579,116076
  3931. -output_typedef_die 3595,116484
  3932. -output_union_type_die 3617,117053
  3933. -output_unspecified_parameters_die 3645,117909
  3934. -output_padded_null_die 3671,118899
  3935. -output_die 3686,119472
  3936. -end_sibling_chain 3718,120362
  3937. -output_formal_types 3750,121391
  3938. -pend_type 3807,123417
  3939. -type_ok_for_scope 3864,126043
  3940. -output_pending_types_for_scope 3897,127451
  3941. -output_type 3933,128384
  3942. -output_tagged_type_instantiation 4178,136486
  3943. -output_block 4220,137499
  3944. -output_decls_for_scope 4310,140727
  3945. -output_decl 4350,141679
  3946. -dwarfout_file_scope_decl 4724,155540
  3947. -dwarfout_begin_block 4933,163558
  3948. -dwarfout_end_block 4947,163911
  3949. -dwarfout_label 4961,164286
  3950. -dwarfout_begin_function 4980,164826
  3951. -dwarfout_end_function 4993,165209
  3952. -dwarfout_end_epilogue 5007,165614
  3953. -shuffle_filename_entry 5019,165895
  3954. -generate_new_sfname_entry 5045,166494
  3955. -lookup_filename 5093,168810
  3956. -generate_srcinfo_entry 5144,170442
  3957. -dwarfout_line 5160,170998
  3958. -generate_macinfo_entry 5209,172589
  3959. -dwarfout_start_new_source_file 5221,172972
  3960. -dwarfout_resume_previous_source_file 5234,173382
  3961. -dwarfout_define 5250,173888
  3962. -dwarfout_undef 5273,174555
  3963. -dwarfout_init 5287,174912
  3964. -dwarfout_finish 5470,181403
  3965. -
  3966. -emit-rtl.c,2793
  3967. -#define MAX_SAVED_CONST_INT 172,6121
  3968. -#define SEQUENCE_RESULT_SIZE 238,8566
  3969. -gen_rtx VPROTO(286,9980
  3970. -gen_rtvec VPROTO(410,13505
  3971. -gen_rtvec_v 438,13919
  3972. -gen_reg_rtx 460,14369
  3973. -mark_reg_pointer 523,16403
  3974. -max_reg_num 532,16567
  3975. -max_label_num 540,16693
  3976. -get_first_label_num 550,16895
  3977. -gen_lowpart_common 567,17457
  3978. -gen_realpart 801,25883
  3979. -gen_imagpart 817,26288
  3980. -subreg_realpart_p 835,26791
  3981. -gen_lowpart 852,27248
  3982. -gen_highpart 884,28137
  3983. -subreg_lowpart_p 965,30779
  3984. -operand_subword 999,31909
  3985. -operand_subword_force 1227,39398
  3986. -reverse_comparison 1251,39884
  3987. -change_address 1286,40671
  3988. -gen_label_rtx 1320,41510
  3989. -gen_inline_header_rtx 1338,41935
  3990. -set_new_first_and_last_insn 1368,42985
  3991. -set_new_first_and_last_label_num 1379,43232
  3992. -save_emit_status 1391,43525
  3993. -restore_emit_status 1412,44161
  3994. -unshare_all_rtl 1442,45079
  3995. -copy_rtx_if_shared 1469,45980
  3996. -reset_used_flags 1590,48918
  3997. -make_safe_from 1651,50042
  3998. -get_insns 1689,50858
  3999. -get_last_insn 1697,50979
  4000. -set_last_insn 1705,51079
  4001. -get_last_insn_anywhere 1716,51265
  4002. -get_max_uid 1730,51570
  4003. -next_insn 1739,51712
  4004. -previous_insn 1757,52048
  4005. -next_nonnote_insn 1775,52430
  4006. -prev_nonnote_insn 1792,52723
  4007. -next_real_insn 1810,53042
  4008. -prev_real_insn 1829,53427
  4009. -next_active_insn 1848,53853
  4010. -prev_active_insn 1871,54408
  4011. -next_label 1892,54858
  4012. -prev_label 1908,55116
  4013. -link_cc0_insns 1926,55438
  4014. -next_cc0_user 1949,56187
  4015. -prev_cc0_setter 1972,56737
  4016. -try_split 1999,57444
  4017. -make_insn_raw 2077,59793
  4018. -make_jump_insn_raw 2096,60126
  4019. -make_call_insn_raw 2116,60497
  4020. -add_insn 2137,60941
  4021. -add_insn_after 2158,61404
  4022. -add_insn_before 2206,62573
  4023. -delete_insns_since 2252,63601
  4024. -reorder_insns 2273,64174
  4025. -find_line_note 2300,64880
  4026. -reorder_insns_with_line_notes 2319,65302
  4027. -emit_insn_before 2347,65989
  4028. -emit_jump_insn_before 2377,66626
  4029. -emit_call_insn_before 2397,67046
  4030. -emit_barrier_before 2418,67464
  4031. -emit_note_before 2432,67721
  4032. -emit_insn_after 2449,68086
  4033. -emit_insn_after_with_line_notes 2480,68744
  4034. -emit_jump_insn_after 2502,69312
  4035. -emit_barrier_after 2522,69688
  4036. -emit_label_after 2536,69928
  4037. -emit_note_after 2554,70331
  4038. -emit_line_note_after 2569,70663
  4039. -emit_insn 2598,71282
  4040. -emit_insns 2628,71825
  4041. -emit_insns_before 2648,72154
  4042. -emit_insns_after 2669,72529
  4043. -emit_jump_insn 2702,73170
  4044. -emit_call_insn 2719,73521
  4045. -emit_label 2736,73860
  4046. -emit_barrier 2754,74257
  4047. -emit_line_note 2768,74600
  4048. -emit_note 2796,75166
  4049. -emit_line_note_force 2828,75765
  4050. -force_next_line_note 2840,76039
  4051. -classify_insn 2849,76238
  4052. -emit 2887,77169
  4053. -start_sequence 2912,77700
  4054. -start_sequence_for_rtl_expr 2940,78318
  4055. -push_to_sequence 2952,78533
  4056. -push_topmost_sequence 2969,78840
  4057. -pop_topmost_sequence 2987,79241
  4058. -end_sequence 3007,79692
  4059. -in_sequence_p 3023,80028
  4060. -gen_sequence 3035,80283
  4061. -restore_reg_data 3089,81839
  4062. -restore_reg_data_1 3130,82688
  4063. -init_emit 3221,84648
  4064. -init_emit_once 3280,86578
  4065. -
  4066. -enquire.c,7662
  4067. -#define VERSION 5,119
  4068. -#define FILENAME 300,13879
  4069. -#define FILENAME 303,13994
  4070. -#define FILENAME 305,14026
  4071. -#define PASS 313,14219
  4072. -#define PASS0 314,14234
  4073. -#define PASS1 315,14250
  4074. -#define D_CHAR_BIT 319,14326
  4075. -#define D_CHAR_MAX 320,14380
  4076. -#define D_CHAR_MIN 321,14414
  4077. -#define D_SCHAR_MAX 322,14448
  4078. -#define D_SCHAR_MIN 323,14490
  4079. -#define D_UCHAR_MAX 324,14532
  4080. -#define D_INT_MAX 326,14599
  4081. -#define D_INT_MIN 327,14630
  4082. -#define D_UINT_MAX 328,14661
  4083. -#define D_FLT_ROUNDS 330,14725
  4084. -#define D_FLT_RADIX 331,14818
  4085. -#define D_MANT_DIG 332,14873
  4086. -#define D_DIG 333,14953
  4087. -#define D_MIN_EXP 334,15015
  4088. -#define D_MIN_10_EXP 335,15095
  4089. -#define D_MAX_EXP 336,15167
  4090. -#define D_MAX_10_EXP 337,15250
  4091. -#define D_MAX 338,15325
  4092. -#define D_EPSILON 339,15352
  4093. -#define D_MIN 340,15431
  4094. -#define Procedure 344,15553
  4095. -#define Procedure 346,15581
  4096. -#define STDC355,15822
  4097. -#define ARGS(371,16311
  4098. -#define NOARGS 372,16329
  4099. -#define Volatile 373,16351
  4100. -#define Long_double 374,16377
  4101. -#define stdc 375,16409
  4102. -#define U 376,16424
  4103. -#define ARGS(380,16464
  4104. -#define NOARGS 381,16483
  4105. -#define Volatile 382,16501
  4106. -#define Long_double 383,16525
  4107. -#define stdc 384,16552
  4108. -#define U 385,16567
  4109. -#define jmp_buf 399,16769
  4110. -#define Vprintf 422,17138
  4111. -#define Unexpected(423,17168
  4112. -#define fabs(424,17227
  4113. -    int setjmp(488,19170
  4114. -    Procedure signal(489,19211
  4115. -    Procedure overflow(493,19274
  4116. -#define ROUND_BITS    520,20159
  4117. -#define TO_NEAREST    521,20183
  4118. -#define TO_ZERO    522,20207
  4119. -#define TO_MINUS_INF    523,20229
  4120. -#define TO_PLUS_INF    524,20255
  4121. -#define EXT_BITS    527,20370
  4122. -#define ROUND_EXTENDED    528,20392
  4123. -#define ROUND_SINGLE    529,20420
  4124. -#define ROUND_DOUBLE    530,20446
  4125. -#define EXE_INEX1 533,20493
  4126. -#define EXE_INEX2 534,20518
  4127. -#define EXE_DZ    535,20543
  4128. -#define EXE_UNFL 536,20567
  4129. -#define EXE_OVFL 537,20592
  4130. -#define EXE_OPERR 538,20617
  4131. -#define EXE_SNAN 539,20642
  4132. -#define EXE_BSUN 540,20667
  4133. -printmode(544,20771
  4134. -int setmode(579,21970
  4135. -int setmode(596,22274
  4136. -Procedure farewell(602,22384
  4137. -Procedure croak(613,22756
  4138. -char *xmalloc(619,22985
  4139. -int maximum_int(630,23176
  4140. -int main(649,23563
  4141. -Procedure eek_a_bug(781,26482
  4142. -Procedure describe(787,26637
  4143. -Procedure i_define(794,26825
  4144. -Procedure u_define(822,27825
  4145. -Procedure f_define(836,28303
  4146. -int floor_log(877,29618
  4147. -int ceil_log(884,29760
  4148. -int exponent(890,29866
  4149. -char *fake_f_rep(925,30677
  4150. -char *f_rep(935,31026
  4151. -Procedure bitpattern(955,31535
  4152. -#define Order(969,31804
  4153. -Procedure endian(975,32050
  4154. -Procedure missing(998,32576
  4155. -Procedure fmissing(1003,32686
  4156. -int false(1009,32829
  4157. -#define Promoted(1011,32856
  4158. -#define is_signed(1012,32895
  4159. -#define sign_of(1013,32934
  4160. -#define Signed 1014,32979
  4161. -#define Unsigned 1015,32996
  4162. -#define sgn(1016,33015
  4163. -#define showtype(1018,33064
  4164. -char *type_of(1020,33168
  4165. -char *ftype_of(1038,33626
  4166. -Procedure typerr(1053,33910
  4167. -Procedure ftyperr(1061,34164
  4168. -int promotions(1066,34348
  4169. -#define checktype(1093,35130
  4170. -#define fchecktype(1095,35249
  4171. -Procedure check_defines(1097,35340
  4172. -#define SCHAR_MAX    1341,40389
  4173. -#define SCHAR_MIN    1344,40441
  4174. -#define UCHAR_MAX    1347,40493
  4175. -#define CHAR_BIT    1352,40565
  4176. -#define CHAR_MAX    1355,40615
  4177. -#define CHAR_MIN    1358,40665
  4178. -#define SCHAR_MAX    1361,40716
  4179. -#define SCHAR_MIN    1364,40768
  4180. -#define UCHAR_MAX    1367,40820
  4181. -int cprop(1370,40855
  4182. -int basic(1504,44158
  4183. -#define Number    1705,48820
  4184. -#define THING    1706,48841
  4185. -#define Thing    1707,48863
  4186. -#define thing    1708,48885
  4187. -#define Fname    1709,48907
  4188. -#define FPROP    1710,48927
  4189. -#define Store    1711,48947
  4190. -#define Sum    1712,48968
  4191. -#define Diff    1713,48985
  4192. -#define Mul    1714,49004
  4193. -#define Div    1715,49021
  4194. -#define ZERO    1716,49038
  4195. -#define HALF    1717,49055
  4196. -#define ONE    1718,49072
  4197. -#define TWO    1719,49088
  4198. -#define THREE    1720,49104
  4199. -#define FOUR    1721,49122
  4200. -#define Self    1722,49139
  4201. -#define F_check    1723,49158
  4202. -#define MARK    1724,49181
  4203. -#define Validate(1726,49212
  4204. -#define EPROP    1729,49291
  4205. -#define Integer    1731,49313
  4206. -#define INT    1732,49335
  4207. -#define IPROP    1733,49355
  4208. -#define Iname    1734,49375
  4209. -#define OK_UI 1736,49410
  4210. -#define IMARK    1738,49433
  4211. -#define UPROP    1740,49451
  4212. -#define Uname    1741,49472
  4213. -#define I_MAX    1745,49525
  4214. -#define I_MIN    1748,49572
  4215. -#define U_MAX    1751,49620
  4216. -#define F_RADIX    1755,49670
  4217. -#define F_MANT_DIG    1758,49724
  4218. -#define F_DIG    1761,49778
  4219. -#define F_ROUNDS    1764,49826
  4220. -#define F_EPSILON    1767,49880
  4221. -#define F_MIN_EXP    1770,49936
  4222. -#define F_MIN    1773,49988
  4223. -#define F_MIN_10_EXP    1776,50040
  4224. -#define F_MAX_EXP    1779,50102
  4225. -#define F_MAX    1782,50154
  4226. -#define F_MAX_10_EXP    1785,50206
  4227. -#define Number    1793,50304
  4228. -#define THING    1794,50326
  4229. -#define Thing    1795,50349
  4230. -#define thing    1796,50372
  4231. -#define Fname    1797,50395
  4232. -#define FPROP    1798,50415
  4233. -#define Store    1799,50435
  4234. -#define Sum    1800,50456
  4235. -#define Diff    1801,50473
  4236. -#define Mul    1802,50492
  4237. -#define Div    1803,50509
  4238. -#define ZERO    1804,50526
  4239. -#define HALF    1805,50543
  4240. -#define ONE    1806,50560
  4241. -#define TWO    1807,50576
  4242. -#define THREE    1808,50592
  4243. -#define FOUR    1809,50610
  4244. -#define Self    1810,50627
  4245. -#define F_check    1811,50646
  4246. -#define MARK    1812,50669
  4247. -#define Validate(1814,50699
  4248. -#define EPROP    1817,50778
  4249. -#define Integer    1819,50800
  4250. -#define INT    1820,50820
  4251. -#define IPROP    1821,50838
  4252. -#define Iname    1822,50858
  4253. -#define OK_UI    1823,50878
  4254. -#define IMARK    1824,50932
  4255. -#define UPROP    1826,50950
  4256. -#define Uname    1827,50971
  4257. -#define I_MAX    1831,51022
  4258. -#define I_MIN    1834,51067
  4259. -#define U_MAX    1837,51113
  4260. -#define F_MANT_DIG    1841,51165
  4261. -#define F_DIG    1844,51219
  4262. -#define F_EPSILON    1847,51268
  4263. -#define F_MIN_EXP    1850,51324
  4264. -#define F_MIN    1853,51376
  4265. -#define F_MIN_10_EXP    1856,51428
  4266. -#define F_MAX_EXP    1859,51490
  4267. -#define F_MAX    1862,51542
  4268. -#define F_MAX_10_EXP    1865,51594
  4269. -#define Number    1874,51704
  4270. -#define ZERO    1876,51732
  4271. -#define HALF    1877,51750
  4272. -#define ONE    1878,51768
  4273. -#define TWO    1879,51785
  4274. -#define THREE    1880,51802
  4275. -#define FOUR    1881,51821
  4276. -#define THING    1884,51847
  4277. -#define Thing    1885,51875
  4278. -#define thing    1886,51903
  4279. -#define Fname    1887,51931
  4280. -#define FPROP    1888,51952
  4281. -#define Store    1889,51973
  4282. -#define Sum    1890,51995
  4283. -#define Diff    1891,52013
  4284. -#define Mul    1892,52033
  4285. -#define Div    1893,52051
  4286. -#define Self    1894,52069
  4287. -#define F_check    1895,52089
  4288. -#define MARK    1896,52113
  4289. -#define Validate(1898,52144
  4290. -#define EPROP    1901,52224
  4291. -#define Integer    1903,52247
  4292. -#define INT    1904,52268
  4293. -#define IPROP    1905,52287
  4294. -#define Iname    1906,52307
  4295. -#define OK_UI    1908,52342
  4296. -#define IMARK    1910,52365
  4297. -#define UPROP    1912,52384
  4298. -#define Uname    1913,52405
  4299. -#define I_MAX    1917,52458
  4300. -#define I_MIN    1920,52504
  4301. -#define U_MAX    1923,52551
  4302. -#define F_MANT_DIG    1927,52604
  4303. -#define F_DIG    1930,52660
  4304. -#define F_EPSILON    1933,52711
  4305. -#define F_MIN_EXP    1936,52769
  4306. -#define F_MIN    1939,52823
  4307. -#define F_MIN_10_EXP    1942,52877
  4308. -#define F_MAX_EXP    1945,52941
  4309. -#define F_MAX    1948,52995
  4310. -#define F_MAX_10_EXP    1951,53049
  4311. -#define I_MAX    1958,53148
  4312. -#define I_MIN    1961,53191
  4313. -#define U_MAX    1964,53234
  4314. -#define F_RADIX    1968,53278
  4315. -#define F_MANT_DIG    1971,53329
  4316. -#define F_DIG    1974,53380
  4317. -#define F_ROUNDS    1977,53425
  4318. -#define F_EPSILON    1980,53476
  4319. -#define F_MIN_EXP    1983,53529
  4320. -#define F_MIN    1986,53578
  4321. -#define F_MIN_10_EXP    1989,53627
  4322. -#define F_MAX_EXP    1992,53686
  4323. -#define F_MAX    1995,53735
  4324. -#define F_MAX_10_EXP    1998,53784
  4325. -#define Validate(2002,53841
  4326. -Procedure IPROP(2007,53908
  4327. -Procedure UPROP 2087,55968
  4328. -#define ARGS1(2128,57002
  4329. -#define ARGS2(2129,57036
  4330. -#define ARGS1(2131,57095
  4331. -#define ARGS2(2132,57132
  4332. -Procedure Store ARGS2(2135,57199
  4333. -Number Sum ARGS2(2136,57255
  4334. -Number Diff ARGS2(2137,57335
  4335. -Number Mul ARGS2(2138,57415
  4336. -Number Div ARGS2(2139,57495
  4337. -Number Self ARGS1(2140,57575
  4338. -Procedure F_check(2144,57713
  4339. -Procedure Validate(2235,60543
  4340. -int FPROP(2267,61492
  4341. -Procedure EPROP(2734,76152
  4342. -int FPROP(2802,78136
  4343. -Procedure EPROP(2806,78229
  4344. -#define PASS 2816,78400
  4345. -#define PASS3 2817,78415
  4346. -#define PASS 2822,78465
  4347. -#define PASS2 2823,78480
  4348. -
  4349. -explow.c,786
  4350. -plus_constant_wide 40,1226
  4351. -plus_constant_for_output_wide 140,3855
  4352. -eliminate_constant_term 162,4461
  4353. -find_next_ref 202,5558
  4354. -expr_size 245,6450
  4355. -break_out_memory_refs 274,7401
  4356. -convert_memory_address 303,8276
  4357. -copy_all_regs 355,9782
  4358. -memory_address 385,10618
  4359. -memory_address_noforce 512,14636
  4360. -validize_mem 529,14991
  4361. -stabilize 546,15543
  4362. -copy_to_reg 575,16290
  4363. -copy_addr_to_reg 595,16709
  4364. -copy_to_mode_reg 605,16885
  4365. -force_reg 632,17651
  4366. -force_not_mem 664,18459
  4367. -copy_to_suggested_reg 680,18824
  4368. -promote_mode 702,19367
  4369. -adjust_stack 741,20227
  4370. -anti_adjust_stack 767,20800
  4371. -round_push 793,21376
  4372. -emit_stack_save 829,22542
  4373. -emit_stack_restore 919,24747
  4374. -allocate_dynamic_stack_space 980,26220
  4375. -hard_function_value 1144,32120
  4376. -hard_libcall_value 1176,32975
  4377. -rtx_to_tree_code 1188,33276
  4378. -
  4379. -expmed.c,896
  4380. -#define CEIL(44,1583
  4381. -#define SLOW_UNALIGNED_ACCESS 54,1929
  4382. -#define MAX_BITS_PER_WORD 62,2197
  4383. -init_expmed 77,2715
  4384. -negate_rtx 184,6094
  4385. -store_bit_field 221,7464
  4386. -store_fixed_bit_field 556,19294
  4387. -store_split_bit_field 724,24636
  4388. -extract_bit_field 860,29215
  4389. -extract_fixed_bit_field 1367,45469
  4390. -mask_rtx 1514,50479
  4391. -lshift_value 1553,51504
  4392. -extract_split_bit_field 1589,52514
  4393. -expand_inc 1690,55497
  4394. -expand_dec 1703,55761
  4395. -expand_shift 1721,56332
  4396. -enum alg_code alg_code1854,60494
  4397. -struct algorithmalgorithm1879,61444
  4398. -synth_mult 1898,62134
  4399. -expand_mult 2136,68657
  4400. -ceil_log2 2344,75121
  4401. -choose_multiplier 2368,75967
  4402. -invert_mod2n 2464,78631
  4403. -expand_mult_highpart_adjust 2501,79660
  4404. -expand_mult_highpart 2536,80793
  4405. -#define EXACT_POWER_OF_2_OR_ZERO_P(2672,85873
  4406. -expand_divmod 2675,85941
  4407. -make_tree 3680,118780
  4408. -expand_mult_add 3778,121439
  4409. -expand_and 3801,122133
  4410. -emit_store_flag 3842,123392
  4411. -
  4412. -expr.c,3123
  4413. -#define CEIL(45,1265
  4414. -#define PUSH_ARGS_REVERSED    56,1610
  4415. -#define STACK_PUSH_CODE 63,1733
  4416. -#define STACK_PUSH_CODE 65,1771
  4417. -#define STACK_BYTES 70,1878
  4418. -struct move_by_piecesmove_by_pieces116,3684
  4419. -#define MOVE_RATIO 207,7340
  4420. -#define MOVE_RATIO 211,7463
  4421. -#define SLOW_UNALIGNED_ACCESS 221,7730
  4422. -#define INCOMING_REGNO(226,7879
  4423. -#define OUTGOING_REGNO(229,7943
  4424. -bc_init_mode_to_opcode_maps 240,8317
  4425. -init_expr_once 262,8901
  4426. -init_expr 328,10711
  4427. -save_expr_status 344,11029
  4428. -restore_expr_status 369,11692
  4429. -enqueue_insn 393,12474
  4430. -protect_from_queue 417,13415
  4431. -queued_subexp_p 500,16001
  4432. -emit_queue 522,16393
  4433. -init_queue 533,16574
  4434. -convert_move 545,16883
  4435. -convert_to_mode 1285,35370
  4436. -convert_modes 1307,36053
  4437. -move_by_pieces 1390,39121
  4438. -move_by_pieces_ninsns 1503,42361
  4439. -move_by_pieces_1 1544,43471
  4440. -emit_block_move 1600,45165
  4441. -move_block_to_reg 1698,47983
  4442. -move_block_from_reg 1741,48945
  4443. -use_reg 1800,50276
  4444. -use_regs 1816,50684
  4445. -clear_storage 1834,51071
  4446. -emit_move_insn 1864,51775
  4447. -emit_move_insn_1 1904,52857
  4448. -push_block 2027,56870
  4449. -gen_push_operand 2067,57997
  4450. -emit_push_insn 2101,59358
  4451. -expand_assignment 2437,69814
  4452. -store_expr 2684,78108
  4453. -store_constructor 2956,87499
  4454. -store_field 3337,99456
  4455. -get_inner_unaligned_p 3468,104080
  4456. -get_inner_reference 3518,105788
  4457. -force_operand 3672,110571
  4458. -save_noncopied_parts 3747,113208
  4459. -init_noncopied_parts 3781,114319
  4460. -safe_from_p 3805,114985
  4461. -fixed_type_p 3961,119013
  4462. -expand_expr 4009,120969
  4463. -bc_expand_expr 6430,203362
  4464. -get_pointer_alignment 6947,215871
  4465. -string_constant 7011,217449
  4466. -c_strlen 7056,218612
  4467. -#define CALLED_AS_BUILT_IN(7120,220840
  4468. -expand_builtin 7124,220959
  4469. -apply_args_register_offset 7971,248338
  4470. -apply_args_size 7988,248749
  4471. -apply_result_size 8052,250547
  4472. -result_vector 8113,252296
  4473. -expand_builtin_apply_args 8145,253338
  4474. -expand_builtin_apply 8210,255299
  4475. -expand_builtin_return 8373,260691
  4476. -expand_increment 8427,262111
  4477. -preexpand_calls 8617,268942
  4478. -init_pending_stack_adjust 8684,270835
  4479. -clear_pending_stack_adjust 8693,271019
  4480. -do_pending_stack_adjust 8706,271352
  4481. -defer_cleanups_to 8720,271657
  4482. -expand_cleanups_to 8761,272646
  4483. -jumpifnot 8779,273175
  4484. -jumpif 8789,273354
  4485. -do_jump 8809,273977
  4486. -do_jump_by_parts_greater 9264,288077
  4487. -do_jump_by_parts_greater_rtx 9330,290224
  4488. -do_jump_by_parts_equality 9392,292115
  4489. -do_jump_by_parts_equality_rtx 9429,293295
  4490. -do_jump_for_compare 9461,294202
  4491. -compare 9535,296433
  4492. -compare_from_rtx 9564,297479
  4493. -do_store_flag 9646,300315
  4494. -do_tablejump 9891,308182
  4495. -bc_load_memory 9962,310934
  4496. -bc_store_memory 10002,311927
  4497. -bc_allocate_local 10051,313378
  4498. -bc_allocate_variable_array 10084,314134
  4499. -bc_load_externaddr 10105,314679
  4500. -bc_strdup 10119,314936
  4501. -bc_load_externaddr_id 10130,315116
  4502. -bc_load_localaddr 10148,315466
  4503. -bc_load_parmaddr 10158,315705
  4504. -bc_canonicalize_array_ref 10168,315909
  4505. -bc_expand_component_address 10205,316960
  4506. -bc_push_offset_and_size 10253,318198
  4507. -bc_expand_address 10268,318626
  4508. -bc_runtime_type_code 10389,321638
  4509. -bc_gen_constr_label 10422,322123
  4510. -bc_expand_constructor 10441,322716
  4511. -bc_store_field 10594,327191
  4512. -bc_store_bit_field 10635,328113
  4513. -bc_load_bit_field 10648,328363
  4514. -bc_adjust_stack 10665,328882
  4515. -
  4516. -final.c,1236
  4517. -#define    N_SLINE    86,2954
  4518. -#define    N_SOL 91,3040
  4519. -#define INT_TYPE_SIZE 95,3089
  4520. -#define CC_STATUS_INIT101,3289
  4521. -#define ASM_COMMENT_START 106,3388
  4522. -#define IS_ASM_LOGICAL_LINE_SEPARATOR(111,3539
  4523. -struct bb_list bb_list245,7755
  4524. -struct bb_str bb_str259,8364
  4525. -init_final 289,9361
  4526. -end_final 307,9741
  4527. -app_enable 507,16215
  4528. -app_disable 520,16433
  4529. -dbr_sequence_length 535,16746
  4530. -init_insn_lengths 559,17303
  4531. -get_attr_length 568,17498
  4532. -#define FIRST_INSN_ADDRESS 638,19271
  4533. -shorten_branches 642,19313
  4534. -asm_insn_count 832,24838
  4535. -final_start_function 863,25695
  4536. -profile_after_prologue 951,28253
  4537. -profile_function 968,28602
  4538. -final_end_function 1034,30169
  4539. -add_bb 1092,31610
  4540. -add_bb_string 1123,32405
  4541. -final 1180,33855
  4542. -final_scan_insn 1256,36041
  4543. -output_source_line 2020,57822
  4544. -alter_subreg 2081,59560
  4545. -walk_alter_subreg 2111,60344
  4546. -alter_cond 2145,61127
  4547. -output_operand_lossage 2294,63551
  4548. -output_asm_name 2322,64518
  4549. -output_asm_insn 2344,65091
  4550. -output_asm_label 2498,68793
  4551. -output_operand 2524,69618
  4552. -output_address 2545,70142
  4553. -output_addr_const 2557,70411
  4554. -asm_fprintf VPROTO(2705,73974
  4555. -split_double 2855,76624
  4556. -leaf_function_p 2977,79631
  4557. -only_leaf_regs_used 3023,81006
  4558. -leaf_renumber_regs 3040,81329
  4559. -leaf_renumber_regs_insn 3060,82009
  4560. -
  4561. -fix-header.c,1053
  4562. -#define O_RDONLY 80,3228
  4563. -#define const 84,3269
  4564. -enum special_filespecial_file125,4159
  4565. -typedef const char* namelist;namelist136,4346
  4566. -struct std_include_entry std_include_entry138,4377
  4567. -namelist_end 148,4521
  4568. -xfree 272,9144
  4569. -fancy_abort 283,9358
  4570. -#define obstack_chunk_alloc 288,9391
  4571. -#define obstack_chunk_free 289,9427
  4572. -lookup_std_proto 294,9569
  4573. -write_lbrac 327,10216
  4574. -struct partial_protopartial_proto346,10742
  4575. -#define REQUIRED(358,11020
  4576. -#define SET_REQUIRED(359,11082
  4577. -#define SET_SEEN(360,11147
  4578. -#define SEEN(361,11204
  4579. -recognized_macro 364,11264
  4580. -recognized_extern 403,12529
  4581. -recognized_function 425,13189
  4582. -check_macro_names 500,15289
  4583. -read_scan_file 513,15520
  4584. -write_rbrac 636,19142
  4585. -xstrdup 722,21602
  4586. -#define INF_GET(737,21863
  4587. -#define INF_UNGET(738,21938
  4588. -inf_skip_spaces 741,21988
  4589. -inf_read_upto 780,22552
  4590. -inf_scan_ident 798,22813
  4591. -check_protection 824,23340
  4592. -main 929,25486
  4593. -cpp_file_line_for_message 1149,30337
  4594. -cpp_print_containing_files 1163,30635
  4595. -void cpp_message 1169,30744
  4596. -fatal 1186,31088
  4597. -cpp_pfatal_with_name 1196,31275
  4598. -
  4599. -floatlib.c,701
  4600. -#define EXCESS    57,2432
  4601. -#define SIGNBIT    58,2452
  4602. -#define HIDDEN    59,2480
  4603. -#define SIGN(60,2506
  4604. -#define EXP(61,2540
  4605. -#define MANT(62,2579
  4606. -#define PACK(63,2625
  4607. -#define EXCESSD    66,2732
  4608. -#define HIDDEND    67,2754
  4609. -#define EXPD(68,2781
  4610. -#define SIGND(69,2829
  4611. -#define MANTD(70,2872
  4612. -union double_longdouble_long74,3033
  4613. -union float_longfloat_long90,3234
  4614. -__addsf3 98,3313
  4615. -__subsf3 187,4742
  4616. -__cmpsf2 207,5057
  4617. -__mulsf3 228,5377
  4618. -__divsf3 277,6301
  4619. -__floatsidf 343,7431
  4620. -__negsf2 383,8005
  4621. -__negdf2 397,8176
  4622. -__extendsfdf2 412,8392
  4623. -__truncdfsf2 437,8839
  4624. -__cmpdf2 474,9465
  4625. -__fixdfsi 499,9922
  4626. -long __fixunsdfsi 527,10417
  4627. -__adddf3 557,11021
  4628. -__subdf3 564,11128
  4629. -__muldf3 571,11235
  4630. -__divdf3 578,11340
  4631. -
  4632. -flow.c,737
  4633. -#define obstack_chunk_alloc 122,5091
  4634. -#define obstack_chunk_free 123,5127
  4635. -#define BLOCK_NUM(136,5483
  4636. -#define INSN_VOLATILE(146,5806
  4637. -flow_analysis 316,11798
  4638. -find_basic_blocks 403,14383
  4639. -uses_reg_or_mem 765,26305
  4640. -mark_label_ref 803,27192
  4641. -flow_delete_insn 859,28637
  4642. -life_analysis 877,29301
  4643. -allocate_for_life_analysis 1273,43063
  4644. -init_regset_vector 1320,44814
  4645. -propagate_block 1356,45959
  4646. -insn_dead_p 1705,57209
  4647. -libcall_dead_p 1813,60614
  4648. -regno_uninitialized 1868,62002
  4649. -regno_clobbered_at_setjmp 1884,62450
  4650. -mark_set_regs 1907,63223
  4651. -mark_set_1 1933,63817
  4652. -find_auto_inc 2145,71010
  4653. -mark_used_regs 2337,77286
  4654. -try_pre_increment_1 2681,86976
  4655. -try_pre_increment 2726,88499
  4656. -find_use_as_address 2814,91058
  4657. -dump_flow_info 2876,92563
  4658. -
  4659. -fold-const.c,1413
  4660. -#define BRANCH_COST 84,3656
  4661. -#define left_shift_overflows(88,3756
  4662. -#define overflow_sum_sign(95,4204
  4663. -#define LOWPART(101,4511
  4664. -#define HIGHPART(103,4607
  4665. -#define BASE 105,4690
  4666. -encode 112,4931
  4667. -decode 127,5310
  4668. -force_fit_type 146,5868
  4669. -add_double 227,8051
  4670. -neg_double 247,8578
  4671. -mul_double 272,9143
  4672. -lshift_double 329,10784
  4673. -rshift_double 365,11748
  4674. -lrotate_double 402,12818
  4675. -rrotate_double 424,13391
  4676. -div_and_round_double 451,14207
  4677. -real_value_truncate 711,21753
  4678. -target_isinf 723,22000
  4679. -target_isnan 763,22864
  4680. -target_negative 803,23721
  4681. -target_isinf 840,24484
  4682. -target_isnan 849,24660
  4683. -target_negative 858,24845
  4684. -split_tree 881,25635
  4685. -const_binop 963,28357
  4686. -size_int 1306,36790
  4687. -size_binop 1339,37659
  4688. -fold_convert 1373,38696
  4689. -non_lvalue 1512,42984
  4690. -pedantic_non_lvalue 1550,44026
  4691. -invert_tree_comparison 1564,44361
  4692. -swap_tree_comparison 1590,44863
  4693. -truth_value_p 1614,45282
  4694. -operand_equal_p 1632,45991
  4695. -operand_equal_for_comparison_p 1738,49191
  4696. -twoval_comparison_p 1793,50976
  4697. -eval_subst 1891,53709
  4698. -omit_one_operand 1973,55990
  4699. -pedantic_omit_one_operand 1987,56299
  4700. -invert_truthvalue 2005,56732
  4701. -distribute_bit_expr 2116,60338
  4702. -make_bit_field_ref 2165,61772
  4703. -optimize_bit_field_compare 2200,63037
  4704. -decode_field_reference 2389,69285
  4705. -all_ones_mask_p 2449,71024
  4706. -simple_operand_p 2473,71609
  4707. -range_test 2514,73158
  4708. -unextend 2627,76072
  4709. -fold_truthop 2677,77881
  4710. -strip_compound_expr 3018,90076
  4711. -fold 3059,91626
  4712. -
  4713. -function.c,2743
  4714. -#define NAME__MAIN 66,2438
  4715. -#define SYMBOL__MAIN 67,2466
  4716. -#define FLOOR_ROUND(73,2704
  4717. -#define CEIL_ROUND(77,2848
  4718. -#define NEED_SEPARATE_AP86,3286
  4719. -struct temp_slottemp_slot344,12354
  4720. -struct fixup_replacementfixup_replacement405,14295
  4721. -find_function_data 450,16092
  4722. -push_function_context_to 466,16528
  4723. -push_function_context 532,19093
  4724. -pop_function_context_from 541,19309
  4725. -void pop_function_context 620,22329
  4726. -get_frame_size 632,22674
  4727. -assign_stack_local 652,23157
  4728. -assign_outer_stack_local 721,25172
  4729. -assign_stack_temp 795,27358
  4730. -combine_temp_slots 902,30621
  4731. -find_temp_slot_from_address 959,32037
  4732. -update_temp_slot_address 986,32587
  4733. -mark_temp_addr_taken 1009,33141
  4734. -preserve_temp_slots 1036,33868
  4735. -preserve_rtl_expr_result 1102,35857
  4736. -free_temp_slots 1132,36735
  4737. -free_temps_for_rtl_expr 1147,37020
  4738. -push_temp_slots 1162,37273
  4739. -pop_temp_slots 1171,37415
  4740. -put_var_into_stack 1188,37790
  4741. -put_reg_into_stack 1275,40857
  4742. -fixup_var_refs 1336,42767
  4743. -find_fixup_replacement 1379,44150
  4744. -fixup_var_refs_insns 1406,44798
  4745. -fixup_var_refs_1 1588,50914
  4746. -fixup_memory_subreg 2074,66177
  4747. -walk_fixup_memory_subreg 2113,67508
  4748. -fixup_stack_1 2155,68630
  4749. -optimize_bit_field 2216,70296
  4750. -#define STACK_POINTER_OFFSET    2379,75692
  4751. -#define STACK_DYNAMIC_OFFSET(2398,76563
  4752. -#define STACK_DYNAMIC_OFFSET(2403,76707
  4753. -#define STACK_DYNAMIC_OFFSET(2408,76823
  4754. -instantiate_virtual_regs 2416,77023
  4755. -instantiate_decls 2463,78618
  4756. -instantiate_decls_1 2502,79972
  4757. -instantiate_decl 2524,80597
  4758. -instantiate_virtual_regs_1 2596,82821
  4759. -delete_handlers 2954,93740
  4760. -nonlocal_label_rtx_list 2997,94913
  4761. -use_variable 3013,95282
  4762. -use_variable_after 3032,95904
  4763. -max_parm_reg_num 3048,96455
  4764. -get_first_nonparm_insn 3056,96582
  4765. -get_first_block_beg 3067,96795
  4766. -aggregate_value_p 3087,97451
  4767. -assign_parms 3125,98685
  4768. -promoted_input_arg 3938,126356
  4769. -locate_and_pad_parm 3999,128451
  4770. -pad_to_arg_alignment 4106,131963
  4771. -pad_below 4137,132599
  4772. -round_down 4165,133399
  4773. -uninitialized_vars_warning 4180,133829
  4774. -setjmp_args_warning 4212,135002
  4775. -setjmp_protect 4228,135495
  4776. -setjmp_protect_args 4259,136511
  4777. -lookup_static_chain 4283,137123
  4778. -fix_lexical_addr 4311,137928
  4779. -trampoline_address 4397,140489
  4780. -round_trampoline_addr 4480,143086
  4781. -identify_blocks 4508,144078
  4782. -reorder_blocks 4555,145331
  4783. -blocks_nreverse 4602,146696
  4784. -all_blocks 4619,147057
  4785. -bc_build_calldesc 4642,147568
  4786. -init_function_start 4688,148935
  4787. -mark_varargs 4846,153416
  4788. -#define HAS_INIT_SECTION4855,153630
  4789. -expand_main_function 4859,153668
  4790. -bc_expand_function_start 4878,154101
  4791. -bc_expand_function_end 4927,155514
  4792. -expand_function_start 4961,156576
  4793. -expand_function_end 5192,164565
  4794. -record_insns 5428,171991
  4795. -contains 5453,172484
  4796. -thread_prologue_and_epilogue_insns 5483,173199
  4797. -reposition_prologue_and_epilogue_notes 5584,176104
  4798. -
  4799. -gcc.c,3659
  4800. -#define R_OK 59,1901
  4801. -#define W_OK 60,1916
  4802. -#define X_OK 61,1931
  4803. -#define WIFSIGNALED(65,1974
  4804. -#define WTERMSIG(68,2065
  4805. -#define WIFEXITED(71,2123
  4806. -#define WEXITSTATUS(74,2191
  4807. -#define PROTO(80,2355
  4808. -#define PROTO(82,2386
  4809. -#define PVPROTO(88,2455
  4810. -#define VPROTO(89,2483
  4811. -#define VA_START(90,2510
  4812. -#define PVPROTO(92,2568
  4813. -#define VPROTO(93,2594
  4814. -#define VA_START(94,2634
  4815. -#define NULL 101,2776
  4816. -#define O_RDONLY 106,2878
  4817. -#define GENERIC_PTR 111,2992
  4818. -#define GENERIC_PTR 113,3025
  4819. -#define NULL_PTR 118,3084
  4820. -#define vfork 122,3137
  4821. -#define P_tmpdir 129,3312
  4822. -#define S_ISREG(135,3407
  4823. -#define S_ISDIR(140,3519
  4824. -#define EXECUTABLE_SUFFIX 145,3662
  4825. -#define HAVE_OBJECT_SUFFIX150,3775
  4826. -#define OBJECT_SUFFIX 152,3808
  4827. -#define PATH_SEPARATOR 157,3924
  4828. -#define DIR_SEPARATOR 161,3981
  4829. -#define obstack_chunk_alloc 166,4070
  4830. -#define obstack_chunk_free 167,4106
  4831. -#define MIN_FATAL_STATUS 192,4540
  4832. -static 237,5704
  4833. -static 243,5873
  4834. -#define ASM_SPEC 447,15694
  4835. -#define ASM_FINAL_SPEC 453,15843
  4836. -#define CPP_SPEC 459,16007
  4837. -#define CC1_SPEC 465,16162
  4838. -#define CC1PLUS_SPEC 471,16317
  4839. -#define LINK_SPEC 477,16473
  4840. -#define LIB_SPEC 482,16590
  4841. -#define LIBGCC_SPEC 490,16896
  4842. -#define LIBGCC_SPEC 492,16946
  4843. -#define STARTFILE_SPEC 498,17101
  4844. -#define SWITCHES_NEED_SPACES 505,17361
  4845. -#define ENDFILE_SPEC 510,17498
  4846. -#define SIGNED_CHAR_SPEC 518,17741
  4847. -#define SIGNED_CHAR_SPEC 520,17812
  4848. -#define MULTILIB_SELECT 528,18082
  4849. -#define SWITCH_TAKES_ARG(549,18794
  4850. -#define DEFAULT_WORD_SWITCH_TAKES_ARG(558,19108
  4851. -#define WORD_SWITCH_TAKES_ARG(567,19523
  4852. -struct compilercompiler572,19672
  4853. -struct option_mapoption_map760,27486
  4854. -translate_options 856,30819
  4855. -my_strerror(1012,34478
  4856. -read_specs 1045,35169
  4857. -skip_whitespace 1154,38030
  4858. -struct spec_listspec_list1180,38589
  4859. -set_spec 1196,39080
  4860. -static struct temp_name temp_name1276,41310
  4861. -struct prefix_listprefix_list1299,41937
  4862. -struct path_prefixpath_prefix1308,42298
  4863. -#define STANDARD_EXEC_PREFIX 1350,43513
  4864. -#define STANDARD_STARTFILE_PREFIX 1360,43835
  4865. -#define TOOLDIR_BASE_PREFIX 1374,44327
  4866. -clear_args 1387,44689
  4867. -store_arg 1400,45073
  4868. -struct temp_filetemp_file1437,46163
  4869. -record_temp_file 1455,46734
  4870. -delete_if_ordinary 1494,47790
  4871. -delete_temp_files 1515,48218
  4872. -delete_failure_queue 1527,48469
  4873. -clear_failure_queue 1536,48644
  4874. -choose_temp_base_try 1545,48816
  4875. -choose_temp_base 1562,49068
  4876. -putenv 1610,50690
  4877. -build_search_list 1661,51848
  4878. -putenv_from_prefixes 1720,53506
  4879. -find_a_file 1732,53848
  4880. -add_prefix 1867,57205
  4881. -unused_prefix_warnings 1909,58141
  4882. -free_path_prefix 1930,58564
  4883. -#define STDIN_FILE_NO 1947,58892
  4884. -#define STDOUT_FILE_NO 1950,58944
  4885. -#define READ_PORT 1953,59018
  4886. -#define WRITE_PORT 1956,59087
  4887. -pexecute 1973,59606
  4888. -pexecute 2025,60683
  4889. -fix_argv 2122,62934
  4890. -#define FIX_ARGV(2155,63592
  4891. -#define FIX_ARGV(2159,63632
  4892. -pexecute 2164,63674
  4893. -execute 2182,64139
  4894. -struct switchstrswitchstr2340,68312
  4895. -struct infileinfile2352,68455
  4896. -process_command 2372,68808
  4897. -do_spec 3013,87661
  4898. -do_spec_1 3054,88736
  4899. -handle_braces 3857,107993
  4900. -check_live_switch 4041,112307
  4901. -give_switch 4117,114488
  4902. -find_file 4144,115170
  4903. -is_directory 4177,116054
  4904. -fatal_error 4221,117315
  4905. -main 4233,117562
  4906. -lookup_compiler 4616,128719
  4907. -xmalloc 4680,130432
  4908. -xrealloc 4690,130602
  4909. -concat 4703,130889
  4910. -concat3 4718,131143
  4911. -concat4 4725,131247
  4912. -concat6 4732,131373
  4913. -save_string 4739,131535
  4914. -pfatal_with_name 4751,131709
  4915. -perror_with_name 4764,131902
  4916. -perror_exec 4777,132095
  4917. -fancy_abort 4793,132467
  4918. -fatal VPROTO(4803,132594
  4919. -error VPROTO(4825,132933
  4920. -fatal 4848,133267
  4921. -error 4857,133401
  4922. -validate_all_switches 4869,133609
  4923. -validate_switches 4972,136042
  4924. -used_arg 5017,136869
  4925. -set_multilib_dir 5039,137501
  4926. -print_multilib_info 5122,139171
  4927. -
  4928. -gen-protos.c,91
  4929. -#define HASH_SIZE 25,916
  4930. -hashf 28,958
  4931. -fancy_abort 51,1394
  4932. -main 57,1430
  4933. -fatal 174,4010
  4934. -
  4935. -genattr.c,337
  4936. -#define obstack_chunk_alloc 31,1044
  4937. -#define obstack_chunk_free 32,1080
  4938. -struct rangerange43,1300
  4939. -struct function_unitfunction_unit52,1433
  4940. -extend_range 64,1869
  4941. -init_range 74,2055
  4942. -write_upcase 82,2159
  4943. -gen_attr 93,2343
  4944. -write_units 143,3725
  4945. -xmalloc 195,5799
  4946. -xrealloc 206,5964
  4947. -fatal 217,6158
  4948. -fancy_abort 230,6451
  4949. -main 236,6509
  4950. -
  4951. -genattrtab.c,3313
  4952. -#define obstack_chunk_alloc 125,5429
  4953. -#define obstack_chunk_free 126,5465
  4954. -#define MAX_DIGITS 138,5745
  4955. -struct insn_definsn_def147,6098
  4956. -struct insn_entinsn_ent161,6593
  4957. -struct attr_valueattr_value172,6920
  4958. -struct attr_descattr_desc183,7280
  4959. -#define NULL_ATTR 196,7841
  4960. -struct rangerange200,7913
  4961. -struct delay_descdelay_desc208,7995
  4962. -struct function_unit_opfunction_unit_op217,8235
  4963. -struct function_unitfunction_unit231,8810
  4964. -#define MAX_ATTRS_INDEX 253,9887
  4965. -struct dimension dimension294,11932
  4966. -enum operator operator318,12578
  4967. -#define SIMPLIFY_TEST_EXP(345,13344
  4968. -#define SIMPLIFY_ALTERNATIVE(351,13615
  4969. -#define oballoc(452,18484
  4970. -struct attr_hashattr_hash461,18765
  4971. -#define RTL_HASH_SIZE 479,19404
  4972. -#define RTL_HASH(484,19559
  4973. -attr_hash_add_rtx 489,19700
  4974. -attr_hash_add_string 506,20131
  4975. -attr_rtx VPROTO(532,20838
  4976. -attr_printf VPROTO(731,25721
  4977. -attr_printf 758,26184
  4978. -attr_eq 774,26530
  4979. -attr_numeral 782,26695
  4980. -attr_string 792,26907
  4981. -attr_equal_p 828,27974
  4982. -attr_copy_rtx 840,28250
  4983. -check_attr_test 933,30422
  4984. -check_attr_value 1080,34349
  4985. -convert_set_attr_alternative 1169,36672
  4986. -convert_set_attr 1210,37869
  4987. -check_defs 1245,38821
  4988. -convert_const_symbol_ref 1298,40172
  4989. -make_canonical 1351,41597
  4990. -copy_boolean 1429,43565
  4991. -get_attr_value 1448,44271
  4992. -expand_delays 1497,45773
  4993. -operate_exp 1588,48698
  4994. -expand_units 1789,54501
  4995. -simplify_knowing 2126,66013
  4996. -encode_units_mask 2144,66589
  4997. -fill_attr 2207,67962
  4998. -substitute_address 2252,69371
  4999. -make_length_attrs 2326,71546
  5000. -identity_fn 2376,73158
  5001. -zero_fn 2383,73220
  5002. -one_fn 2390,73297
  5003. -max_fn 2397,73373
  5004. -simplify_cond 2412,73809
  5005. -remove_insn_ent 2532,76895
  5006. -insert_insn_ent 2557,77360
  5007. -insert_right_side 2580,78047
  5008. -compute_alternative_mask 2646,79864
  5009. -make_alternative_compare 2676,80657
  5010. -evaluate_eq_attr 2702,81445
  5011. -simplify_and_tree 2805,84449
  5012. -simplify_or_tree 2924,87506
  5013. -simplify_test_exp 3001,89941
  5014. -optimize_attrs 3289,98598
  5015. -simplify_by_alternatives 3399,101740
  5016. -simplify_by_exploding 3436,102881
  5017. -find_and_mark_used_attributes 3584,107402
  5018. -unmark_used_attributes 3633,108550
  5019. -add_values_to_cover 3656,109063
  5020. -increment_current_value 3720,110739
  5021. -test_for_current_value 3740,111165
  5022. -simplify_with_current_value 3760,111696
  5023. -simplify_with_current_value_aux 3793,112385
  5024. -clear_struct_flag 3869,114430
  5025. -count_sub_rtxs 3923,115435
  5026. -gen_attr 3979,116403
  5027. -count_alternatives 4032,118005
  5028. -compares_alternatives_p 4070,118728
  5029. -contained_in_p 4102,119339
  5030. -gen_insn 4135,119942
  5031. -gen_delay 4179,121031
  5032. -gen_unit 4210,121796
  5033. -write_test_expr 4290,124422
  5034. -max_attr_value 4514,129627
  5035. -walk_attr_value 4563,130699
  5036. -write_attr_get 4627,131969
  5037. -eliminate_known_true 4684,133757
  5038. -write_attr_set 4715,134594
  5039. -write_attr_case 4812,137087
  5040. -write_attr_valueq 4888,138877
  5041. -write_attr_value 4908,139242
  5042. -write_upcase 4919,139435
  5043. -write_indent 4930,139615
  5044. -write_eligible_delay 4953,140341
  5045. -write_function_unit_info 5072,143925
  5046. -write_complex_function 5141,145903
  5047. -n_comma_elts 5233,148577
  5048. -next_comma_elt 5253,148958
  5049. -find_attr 5279,149459
  5050. -make_internal_attr 5317,150512
  5051. -find_most_used 5339,151010
  5052. -find_single_value 5360,151422
  5053. -make_numeric_value 5382,151775
  5054. -extend_range 5405,152098
  5055. -xrealloc 5415,152279
  5056. -xmalloc 5426,152467
  5057. -copy_rtx_unchanging 5437,152636
  5058. -fatal 5473,153283
  5059. -fancy_abort 5486,153579
  5060. -write_const_num_delay_slots 5495,153784
  5061. -main 5531,154571
  5062. -
  5063. -gencodes.c,176
  5064. -#define obstack_chunk_alloc 33,1065
  5065. -#define obstack_chunk_free 34,1101
  5066. -gen_insn 46,1284
  5067. -xmalloc 58,1619
  5068. -xrealloc 69,1784
  5069. -fatal 80,1977
  5070. -fancy_abort 93,2271
  5071. -main 99,2329
  5072. -
  5073. -genconfig.c,269
  5074. -#define obstack_chunk_alloc 32,986
  5075. -#define obstack_chunk_free 33,1022
  5076. -walk_insn_part 64,1980
  5077. -gen_insn 165,4423
  5078. -gen_expand 186,4989
  5079. -gen_split 213,5679
  5080. -gen_peephole 228,6088
  5081. -xmalloc 240,6333
  5082. -xrealloc 252,6499
  5083. -fatal 263,6692
  5084. -fancy_abort 276,6987
  5085. -main 282,7045
  5086. -
  5087. -genemit.c,458
  5088. -#define obstack_chunk_alloc 30,990
  5089. -#define obstack_chunk_free 31,1026
  5090. -struct clobber_patclobber_pat50,1497
  5091. -struct clobber_entclobber_ent60,1682
  5092. -max_operand_1 67,1793
  5093. -max_operand_vec 106,2741
  5094. -print_code 123,3012
  5095. -gen_exp 140,3354
  5096. -gen_insn 267,6018
  5097. -gen_expand 384,9241
  5098. -gen_split 510,13666
  5099. -output_add_clobbers 602,16799
  5100. -output_init_mov_optab 640,17780
  5101. -xmalloc 671,18592
  5102. -xrealloc 683,18758
  5103. -fatal 694,18951
  5104. -fancy_abort 707,19244
  5105. -main 713,19302
  5106. -
  5107. -genextract.c,328
  5108. -#define obstack_chunk_alloc 31,1025
  5109. -#define obstack_chunk_free 32,1061
  5110. -struct extractionextraction50,1789
  5111. -struct code_ptrcode_ptr63,2067
  5112. -gen_insn 111,3087
  5113. -walk_rtx 191,4922
  5114. -print_path 310,7493
  5115. -xmalloc 343,8186
  5116. -xrealloc 354,8351
  5117. -fatal 365,8544
  5118. -fancy_abort 378,8840
  5119. -copystr 384,8907
  5120. -mybzero 399,9084
  5121. -main 408,9205
  5122. -
  5123. -genflags.c,246
  5124. -#define obstack_chunk_alloc 33,1055
  5125. -#define obstack_chunk_free 34,1091
  5126. -num_operands 54,1549
  5127. -gen_proto 91,2200
  5128. -gen_nonproto 112,2557
  5129. -gen_insn 119,2663
  5130. -xmalloc 173,4053
  5131. -xrealloc 185,4219
  5132. -fatal 196,4412
  5133. -fancy_abort 209,4706
  5134. -main 215,4764
  5135. -
  5136. -genopinit.c,186
  5137. -#define obstack_chunk_alloc 31,991
  5138. -#define obstack_chunk_free 32,1027
  5139. -gen_insn 131,6657
  5140. -xmalloc 284,10010
  5141. -xrealloc 296,10176
  5142. -fatal 307,10369
  5143. -fancy_abort 320,10664
  5144. -main 326,10722
  5145. -
  5146. -genoutput.c,541
  5147. -#define MAX_MAX_OPERANDS 102,4342
  5148. -#define obstack_chunk_alloc 107,4443
  5149. -#define obstack_chunk_free 108,4479
  5150. -struct datadata135,5178
  5151. -output_prologue 176,6436
  5152. -output_epilogue 199,7111
  5153. -scan_operands 414,12675
  5154. -process_template 540,15986
  5155. -validate_insn_alternatives 614,17846
  5156. -gen_insn 639,18658
  5157. -gen_peephole 695,20280
  5158. -gen_expand 748,21861
  5159. -gen_split 809,23559
  5160. -xmalloc 862,24987
  5161. -xrealloc 873,25152
  5162. -mybzero 884,25345
  5163. -mybcopy 893,25473
  5164. -fatal 903,25636
  5165. -fancy_abort 916,25947
  5166. -error 922,26012
  5167. -main 933,26165
  5168. -n_occurrences 992,27222
  5169. -
  5170. -genpeep.c,275
  5171. -#define obstack_chunk_alloc 30,991
  5172. -#define obstack_chunk_free 31,1027
  5173. -struct linklink42,1401
  5174. -gen_peephole 70,1934
  5175. -match_rtx 154,4371
  5176. -print_path 355,9274
  5177. -print_code 375,9635
  5178. -xmalloc 389,9854
  5179. -xrealloc 400,10019
  5180. -fatal 411,10212
  5181. -fancy_abort 424,10505
  5182. -main 430,10563
  5183. -
  5184. -genrecog.c,869
  5185. -#define obstack_chunk_alloc 57,2360
  5186. -#define obstack_chunk_free 58,2396
  5187. -struct decision_head decision_head67,2662
  5188. -struct decisiondecision72,2805
  5189. -#define SUBROUTINE_THRESHOLD 105,4540
  5190. -enum routine_type routine_type112,4751
  5191. -static struct pred_tablepred_table138,5548
  5192. -#define NUM_KNOWN_PREDS 166,6651
  5193. -make_insn_sequence 206,8449
  5194. -add_to_sequence 293,10677
  5195. -not_both_true 568,18433
  5196. -position_merit 675,22183
  5197. -merge_trees 731,24132
  5198. -break_out_subroutines 953,31068
  5199. -write_subroutine 977,31647
  5200. -write_tree_1 1046,34064
  5201. -print_code 1467,46371
  5202. -same_codes 1481,46598
  5203. -clear_codes 1493,46783
  5204. -same_modes 1501,46898
  5205. -clear_modes 1513,47118
  5206. -write_tree 1529,47527
  5207. -change_state 1576,48864
  5208. -copystr 1605,49515
  5209. -mybzero 1620,49692
  5210. -mybcopy 1629,49820
  5211. -concat 1638,49969
  5212. -xrealloc 1657,50235
  5213. -xmalloc 1668,50423
  5214. -fatal 1679,50593
  5215. -fancy_abort 1693,50929
  5216. -main 1699,50987
  5217. -
  5218. -getopt.c,230
  5219. -#define _NO_PROTO26,1089
  5220. -#define const37,1306
  5221. -# define gettext(67,2391
  5222. -#define    my_index    172,6351
  5223. -my_index 181,6501
  5224. -exchange 227,7946
  5225. -_getopt_initialize 285,9469
  5226. -_getopt_internal 375,12954
  5227. -getopt 679,20759
  5228. -main 698,21141
  5229. -
  5230. -getopt1.c,105
  5231. -#define const29,1042
  5232. -#define NULL 55,1833
  5233. -getopt_long 59,1860
  5234. -getopt_long_only 75,2363
  5235. -main 93,2719
  5236. -
  5237. -getpwd.c,170
  5238. -#define getcwd(20,496
  5239. -#define GUESSPATHLEN 22,549
  5240. -#define GUESSPATHLEN 24,593
  5241. -#define GUESSPATHLEN 29,756
  5242. -getpwd 46,1169
  5243. -#define MAXPATHLEN 89,2014
  5244. -getpwd 93,2052
  5245. -
  5246. -global.c,818
  5247. -#define INT_BITS 104,3838
  5248. -#define INT_TYPE 105,3878
  5249. -#define CONFLICTP(123,4408
  5250. -#define SET_CONFLICT(127,4531
  5251. -#define REGBITP(197,6838
  5252. -#define SET_REGBIT(201,6978
  5253. -#define ALLOCNO_LIVE_P(210,7235
  5254. -#define SET_ALLOCNO_LIVE(213,7335
  5255. -#define CLEAR_ALLOCNO_LIVE(216,7438
  5256. -#define NUM_NO_CONFLICT_PAIRS 237,8598
  5257. -global_alloc 277,10009
  5258. -allocno_compare 587,20847
  5259. -global_conflicts 614,21761
  5260. -expand_preferences 781,26605
  5261. -prune_preferences 834,28434
  5262. -find_reg 904,30919
  5263. -retry_global_alloc 1203,40326
  5264. -record_one_conflict 1236,41349
  5265. -record_conflicts 1279,42652
  5266. -mark_reg_store 1317,43951
  5267. -mark_reg_clobber 1381,45534
  5268. -mark_reg_conflicts 1438,46923
  5269. -mark_reg_death 1477,47851
  5270. -mark_reg_live_nc 1513,48980
  5271. -set_preference 1535,49705
  5272. -mark_elimination 1627,52380
  5273. -dump_conflicts 1647,52993
  5274. -dump_global_regs 1695,54403
  5275. -
  5276. -gmon.c,133
  5277. -extern mcount(48,2015
  5278. -#define        SCALE_1_TO_1    66,2490
  5279. -#define    MSG 68,2522
  5280. -_mcleanup(147,4532
  5281. -mcount(187,5624
  5282. -moncontrol(312,8518
  5283. -
  5284. -halfpic.c,371
  5285. -#define obstack_chunk_alloc 40,1399
  5286. -#define obstack_chunk_free 41,1435
  5287. -struct all_refs all_refs59,1984
  5288. -#define MAX_HASH_TABLE 83,2863
  5289. -#define HASHBITS 86,2899
  5290. -half_pic_hash 89,2945
  5291. -half_pic_init 164,4486
  5292. -half_pic_finish 176,4712
  5293. -half_pic_encode 200,5138
  5294. -half_pic_declare 251,6217
  5295. -half_pic_external 275,6592
  5296. -half_pic_address_p 299,6961
  5297. -half_pic_ptr 366,8295
  5298. -
  5299. -integrate.c,955
  5300. -#define    obstack_chunk_alloc    39,1155
  5301. -#define    obstack_chunk_free    40,1191
  5302. -#define CEIL_ROUND(49,1415
  5303. -#define INTEGRATE_THRESHOLD(54,1634
  5304. -function_cannot_inline_p 83,2861
  5305. -initialize_for_inline 230,8621
  5306. -finish_inline 338,12608
  5307. -adjust_copied_decl_tree 352,12983
  5308. -save_for_inline_copying 389,14288
  5309. -copy_decl_list 622,22303
  5310. -copy_decl_tree 652,22925
  5311. -copy_decl_rtls 682,23761
  5312. -save_for_inline_nocopy 716,25094
  5313. -save_constants 800,27976
  5314. -note_modified_parmregs 874,29714
  5315. -copy_for_inline 899,30600
  5316. -#define FIXED_BASE_PLUS_P(1134,37539
  5317. -expand_inline_function 1154,38325
  5318. -integrate_parm_decls 1913,64732
  5319. -integrate_decl_tree 1958,66434
  5320. -copy_rtx_and_substitute 2024,68132
  5321. -try_constants 2424,81374
  5322. -subst_constants 2484,83330
  5323. -mark_stores 2747,91020
  5324. -restore_constants 2785,92208
  5325. -set_block_origin_self 2862,94477
  5326. -set_decl_origin_self 2901,95790
  5327. -set_block_abstract_flags 2925,96495
  5328. -set_decl_abstract_flags 2957,97386
  5329. -output_inline_function 2978,98011
  5330. -
  5331. -jump.c,1111
  5332. -jump_optimize 138,5389
  5333. -duplicate_loop_exit_test 2137,72652
  5334. -squeeze_notes 2316,77963
  5335. -find_cross_jump 2367,79565
  5336. -do_cross_jump 2533,84441
  5337. -get_label_before 2585,86022
  5338. -get_label_after 2608,86488
  5339. -jump_back_p 2631,87040
  5340. -can_reverse_comparison_p 2673,88233
  5341. -reverse_condition 2733,90187
  5342. -swap_condition 2778,90778
  5343. -unsigned_condition 2822,91397
  5344. -signed_condition 2855,91816
  5345. -comparison_dominates_p 2889,92277
  5346. -simplejump_p 2929,92920
  5347. -condjump_p 2942,93233
  5348. -condjump_in_parallel_p 2969,93934
  5349. -sets_cc0_p 3004,94845
  5350. -follow_jumps 3041,95781
  5351. -tension_vector_labels 3091,97189
  5352. -mark_jump_label 3130,98568
  5353. -delete_jump 3257,101958
  5354. -delete_computation 3280,102729
  5355. -delete_insn 3389,105748
  5356. -next_nondeleted_insn 3537,110323
  5357. -delete_for_peephole 3551,110674
  5358. -invert_jump 3590,111536
  5359. -invert_exp 3617,112269
  5360. -redirect_jump 3679,113924
  5361. -delete_from_jump_chain 3720,114958
  5362. -redirect_exp 3765,116126
  5363. -redirect_tablejump 3825,117699
  5364. -delete_labelref_insn 3855,118557
  5365. -rtx_renumbered_equal_p 3895,119333
  5366. -true_regnum 4066,123500
  5367. -mark_modified_reg 4131,125267
  5368. -thread_jumps 4157,125766
  5369. -rtx_equal_for_thread_p 4345,131574
  5370. -
  5371. -libgcc1-test.c,138
  5372. -main_without__main 12,373
  5373. -discard 68,1340
  5374. -ddiscard 72,1368
  5375. -foo 76,1400
  5376. -dfoo 85,1501
  5377. -extern void start(96,1802
  5378. -void _start(100,1897
  5379. -
  5380. -libgcc1.c,2157
  5381. -#define perform_mulsi3(57,2575
  5382. -#define perform_divsi3(61,2648
  5383. -#define perform_udivsi3(65,2722
  5384. -#define perform_modsi3(69,2796
  5385. -#define perform_umodsi3(73,2870
  5386. -#define perform_lshrsi3(77,2945
  5387. -#define perform_ashrsi3(81,3021
  5388. -#define perform_ashlsi3(85,3097
  5389. -#define perform_adddf3(89,3172
  5390. -#define perform_subdf3(93,3245
  5391. -#define perform_muldf3(97,3318
  5392. -#define perform_divdf3(101,3391
  5393. -#define perform_addsf3(105,3464
  5394. -#define perform_subsf3(109,3546
  5395. -#define perform_mulsf3(113,3628
  5396. -#define perform_divsf3(117,3710
  5397. -#define perform_negdf2(121,3792
  5398. -#define perform_negsf2(125,3859
  5399. -#define perform_fixdfsi(129,3936
  5400. -#define perform_fixsfsi(133,4022
  5401. -#define perform_floatsidf(137,4109
  5402. -#define perform_floatsisf(141,4190
  5403. -#define perform_extendsfdf2(145,4282
  5404. -#define perform_truncdfsf2(149,4358
  5405. -#define perform_eqdf2(158,4615
  5406. -#define perform_nedf2(162,4690
  5407. -#define perform_gtdf2(166,4762
  5408. -#define perform_gedf2(170,4833
  5409. -#define perform_ltdf2(174,4911
  5410. -#define perform_ledf2(178,4985
  5411. -#define perform_eqsf2(182,5063
  5412. -#define perform_nesf2(186,5138
  5413. -#define perform_gtsf2(190,5210
  5414. -#define perform_gesf2(194,5281
  5415. -#define perform_ltsf2(198,5359
  5416. -#define perform_lesf2(202,5433
  5417. -#define nongcc_SI_type 208,5573
  5418. -#define nongcc_word_type 213,5699
  5419. -#define FLOAT_VALUE_TYPE 222,5998
  5420. -#define INTIFY(226,6050
  5421. -#define FLOATIFY(230,6135
  5422. -#define FLOAT_ARG_TYPE 234,6205
  5423. -union flt_or_value flt_or_value237,6253
  5424. -union flt_or_int flt_or_int239,6307
  5425. -__mulsi3 244,6378
  5426. -__udivsi3 253,6489
  5427. -__divsi3 262,6610
  5428. -__umodsi3 271,6721
  5429. -__modsi3 280,6842
  5430. -__lshrsi3 289,6953
  5431. -__ashrsi3 298,7075
  5432. -__ashlsi3 307,7188
  5433. -__divdf3 316,7293
  5434. -__muldf3 325,7387
  5435. -__negdf2 334,7481
  5436. -__adddf3 343,7566
  5437. -__subdf3 352,7660
  5438. -__eqdf2 366,7941
  5439. -__nedf2 376,8074
  5440. -__gtdf2 386,8207
  5441. -__gedf2 396,8338
  5442. -__ltdf2 406,8471
  5443. -__ledf2 416,8602
  5444. -__fixdfsi 426,8736
  5445. -__fixsfsi 435,8832
  5446. -__floatsidf 445,8970
  5447. -__floatsisf 454,9082
  5448. -__addsf3 464,9221
  5449. -__negsf2 474,9384
  5450. -__subsf3 484,9527
  5451. -__eqsf2 494,9689
  5452. -__nesf2 505,9879
  5453. -__gtsf2 516,10069
  5454. -__gesf2 527,10257
  5455. -__ltsf2 538,10447
  5456. -__lesf2 549,10635
  5457. -__mulsf3 560,10826
  5458. -__divsf3 570,10989
  5459. -__truncdfsf2 580,11156
  5460. -__extendsfdf2 590,11283
  5461. -
  5462. -libgcc2.c,4264
  5463. -#define WEAK_ALIAS46,1718
  5464. -#define LIBGCC2_WORDS_BIG_ENDIAN 54,1939
  5465. -typedef unsigned int UQItype    __attribute__ ((mode (QI)QI66,2561
  5466. -typedef      int SItype    __attribute__ ((mode (SI)SI67,2619
  5467. -typedef unsigned int USItype    __attribute__ ((mode (SI)SI68,2669
  5468. -typedef         int DItype    __attribute__ ((mode (DI)DI69,2727
  5469. -typedef unsigned int UDItype    __attribute__ ((mode (DI)DI70,2777
  5470. -typedef     float SFtype    __attribute__ ((mode (SF)SF72,2836
  5471. -typedef        float DFtype    __attribute__ ((mode (DF)DF73,2887
  5472. -typedef        float XFtype    __attribute__ ((mode (XF)XF76,2971
  5473. -typedef        float TFtype    __attribute__ ((mode (TF)TF79,3062
  5474. -typedef int word_type __attribute__ ((mode (__word__)__word__82,3121
  5475. -#define char 90,3519
  5476. -#define short 91,3543
  5477. -#define int 92,3568
  5478. -#define long 93,3591
  5479. -#define unsigned 94,3615
  5480. -#define float 95,3643
  5481. -#define double 96,3668
  5482. -#define SI_TYPE_SIZE 98,3695
  5483. -  struct DIstruct DIstruct104,3881
  5484. -  struct DIstruct DIstruct106,3926
  5485. -} DIunion;DIunion117,4239
  5486. -__negdi2 139,4754
  5487. -__lshrdi3 156,4951
  5488. -__ashldi3 188,5439
  5489. -__ashrdi3 220,5925
  5490. -__ffsdi2 253,6480
  5491. -__muldi3 274,6800
  5492. -__udiv_w_sdiv 293,7103
  5493. -__udivmoddi4 405,9474
  5494. -__divdi3 628,13197
  5495. -__moddi3 656,13589
  5496. -__umoddi3 683,13963
  5497. -__udivdi3 697,14122
  5498. -__cmpdi2 706,14242
  5499. -__ucmpdi2 727,14589
  5500. -#define WORD_SIZE 747,15011
  5501. -#define HIGH_WORD_COEFF 748,15063
  5502. -__fixunstfdi 751,15124
  5503. -__fixtfdi 781,15843
  5504. -#define WORD_SIZE 791,16015
  5505. -#define HIGH_WORD_COEFF 792,16067
  5506. -__fixunsxfdi 795,16128
  5507. -__fixxfdi 825,16846
  5508. -#define WORD_SIZE 835,16979
  5509. -#define HIGH_WORD_COEFF 836,17031
  5510. -__fixunsdfdi 839,17092
  5511. -__fixdfdi 869,17771
  5512. -#define WORD_SIZE 879,17904
  5513. -#define HIGH_WORD_COEFF 880,17956
  5514. -__fixunssfdi 883,18017
  5515. -__fixsfdi 916,18942
  5516. -#define WORD_SIZE 925,19105
  5517. -#define HIGH_HALFWORD_COEFF 926,19157
  5518. -#define HIGH_WORD_COEFF 927,19220
  5519. -__floatdixf 930,19281
  5520. -#define WORD_SIZE 949,19620
  5521. -#define HIGH_HALFWORD_COEFF 950,19672
  5522. -#define HIGH_WORD_COEFF 951,19735
  5523. -__floatditf 954,19796
  5524. -#define WORD_SIZE 973,20095
  5525. -#define HIGH_HALFWORD_COEFF 974,20147
  5526. -#define HIGH_WORD_COEFF 975,20210
  5527. -__floatdidf 978,20271
  5528. -#define WORD_SIZE 997,20570
  5529. -#define HIGH_HALFWORD_COEFF 998,20622
  5530. -#define HIGH_WORD_COEFF 999,20685
  5531. -#define DI_SIZE 1000,20738
  5532. -#define UNKNOWN_FLOAT_FORMAT 1005,20898
  5533. -#define IEEE_FLOAT_FORMAT 1006,20929
  5534. -#define VAX_FLOAT_FORMAT 1007,20957
  5535. -#define IBM_FLOAT_FORMAT 1008,20984
  5536. -#define    HOST_FLOAT_FORMAT    1012,21114
  5537. -#define DF_SIZE 1016,21209
  5538. -#define SF_SIZE 1017,21228
  5539. -#define DF_SIZE 1021,21297
  5540. -#define SF_SIZE 1022,21316
  5541. -#define DF_SIZE 1026,21385
  5542. -#define SF_SIZE 1027,21404
  5543. -__floatdisf 1031,21438
  5544. -__fixunsxfsi 1080,22697
  5545. -__fixunsdfsi 1101,23044
  5546. -__fixunssfsi 1122,23391
  5547. -#define SItype 1132,23591
  5548. -#define USItype 1133,23617
  5549. -#define DItype 1134,23644
  5550. -#define UDItype 1135,23670
  5551. -#define SFtype 1136,23697
  5552. -#define DFtype 1137,23723
  5553. -__gcc_bcmp 1154,24017
  5554. -__builtin_saveregs 1380,30261
  5555. -__eprintf 1397,30564
  5556. -struct bbbb1414,30858
  5557. -#define ON_EXIT(1449,31595
  5558. -#define ON_EXIT(1453,31690
  5559. -/* __inline__ */ static int num_digits 1460,31841
  5560. -__bb_exit_func 1477,32095
  5561. -__bb_init_func 1590,34904
  5562. -typedef void (*vfp)vfp1621,35643
  5563. -void * __builtin_new 1626,35757
  5564. -void * __builtin_vec_new 1659,36461
  5565. -#define write(1685,37259
  5566. -typedef void (*vfp)vfp1689,37345
  5567. -set_new_handler 1695,37441
  5568. -#define MESSAGE 1705,37632
  5569. -__default_new_handler 1708,37691
  5570. -void __builtin_delete 1728,38338
  5571. -void __builtin_vec_delete 1750,38799
  5572. -#define INSN_CACHE_PLANE_SIZE 1781,39614
  5573. -__clear_cache 1784,39687
  5574. -__enable_execute_stack 1912,43059
  5575. -__enable_execute_stack 1948,43872
  5576. -__enable_execute_stack 1975,44421
  5577. -__enable_execute_stack 2011,45250
  5578. -#define NAME__MAIN 2033,45865
  5579. -#define SYMBOL__MAIN 2034,45893
  5580. -__do_global_dtors 2041,46066
  5581. -#define ON_EXIT(2057,46339
  5582. -__do_global_ctors 2068,46643
  5583. -SYMBOL__MAIN 2085,47181
  5584. -extern void _exit 2134,48569
  5585. -} exception_table;exception_table2162,49022
  5586. -struct exception_table_node exception_table_node2164,49042
  5587. -find_exception_table 2176,49304
  5588. -__find_first_exception_table_match(2215,50391
  5589. -__throw_type_match 2272,51839
  5590. -__register_exceptions 2284,52121
  5591. -__unwind_function(2314,52863
  5592. -__unwind_function(2339,53501
  5593. -__unwind_function(2357,53861
  5594. -#define write(2384,54553
  5595. -#define MESSAGE 2388,54639
  5596. -__pure_virtual 2391,54692
  5597. -
  5598. -local-alloc.c,825
  5599. -#define CLASS_LIKELY_SPILLED_P(77,3231
  5600. -alloc_qty 279,10816
  5601. -alloc_qty_for_scratch 306,11577
  5602. -local_alloc 394,13899
  5603. -validate_equiv_mem_from_store 540,19147
  5604. -validate_equiv_mem 559,19693
  5605. -memref_referenced_p 609,20982
  5606. -memref_used_between_p 672,22312
  5607. -optimize_reg_copy_1 700,23111
  5608. -optimize_reg_copy_2 874,28712
  5609. -update_equiv_regs 947,30771
  5610. -block_alloc 1123,37219
  5611. -qty_compare 1579,52430
  5612. -qty_compare_1 1598,53040
  5613. -qty_sugg_compare 1633,54266
  5614. -qty_sugg_compare_1 1662,55205
  5615. -combine_regs 1722,57321
  5616. -reg_meets_class_p 1893,63290
  5617. -reg_classes_overlap_p 1906,63659
  5618. -update_qty_class 1928,64166
  5619. -reg_is_set 1954,64888
  5620. -reg_is_born 1976,65592
  5621. -wipe_dead_reg 2013,66671
  5622. -find_free_reg 2067,68475
  5623. -mark_life 2218,73457
  5624. -post_mark_life 2237,73972
  5625. -no_conflict_p 2276,74911
  5626. -requires_inout 2315,75941
  5627. -dump_local_alloc 2368,77045
  5628. -
  5629. -loop.c,1721
  5630. -#define NUM_STORES 157,5378
  5631. -#define obstack_chunk_alloc 193,6629
  5632. -#define obstack_chunk_free 194,6665
  5633. -struct movablemovable202,6908
  5634. -init_loop 297,10376
  5635. -loop_optimize 323,11162
  5636. -scan_loop 452,15596
  5637. -record_excess_regs 978,35293
  5638. -libcall_other_reg 1031,36442
  5639. -reg_in_basic_block_p 1056,37037
  5640. -libcall_benefit 1103,38128
  5641. -skip_consec_insns 1127,38698
  5642. -ignore_some_movables 1155,39409
  5643. -force_movables 1187,40495
  5644. -combine_movables 1226,41667
  5645. -regs_match_p 1337,45363
  5646. -rtx_equal_for_loop_p 1366,46039
  5647. -add_label_notes 1478,48751
  5648. -move_movables 1523,50015
  5649. -replace_call_address 2000,64537
  5650. -count_nonfixed_reads 2060,65762
  5651. -constant_high_bytes 2113,66854
  5652. -prescan_loop 2152,67890
  5653. -find_and_verify_loops 2216,69269
  5654. -mark_loop_jump 2466,77155
  5655. -labels_in_range_p 2584,80225
  5656. -note_addr_stored 2601,80506
  5657. -invariant_p 2648,81766
  5658. -consec_sets_invariant_p 2773,85029
  5659. -all_sets_invariant_p 2847,86852
  5660. -find_single_use_in_loop 2877,87626
  5661. -count_loop_regs_set 2929,89389
  5662. -loop_reg_used_before_p 3046,93324
  5663. -strength_reduce 3154,97628
  5664. -valid_initial_value_p 4060,128905
  5665. -find_mem_givs 4098,129932
  5666. -record_biv 4186,132328
  5667. -record_giv 4281,135015
  5668. -check_final_value 4491,141358
  5669. -update_giv_derive 4633,145927
  5670. -basic_induction_var 4759,150876
  5671. -general_induction_var 4893,154839
  5672. -simplify_giv_expr 4999,157772
  5673. -consec_sets_giv 5262,165018
  5674. -express_from 5359,167761
  5675. -combine_givs_p 5398,168988
  5676. -combine_givs 5434,170087
  5677. -emit_iv_add_mult 5475,171440
  5678. -product_cheap_p 5508,172378
  5679. -check_dbra_loop 5595,175053
  5680. -maybe_eliminate_biv 5892,184987
  5681. -maybe_eliminate_biv_1 5944,186473
  5682. -last_use_this_basic_block 6248,195379
  5683. -record_initial 6267,195816
  5684. -update_reg_last_use 6294,196491
  5685. -get_condition 6341,198395
  5686. -get_condition_for_loop 6559,204511
  5687. -
  5688. -mips-tdump.c,1451
  5689. -#define CODE_MASK 49,1517
  5690. -#define MIPS_IS_STAB(50,1543
  5691. -#define MIPS_MARK_STAB(51,1609
  5692. -#define MIPS_UNMARK_STAB(52,1657
  5693. -typedef void *PTR_T;PTR_T56,1731
  5694. -typedef const void *CPTR_T;CPTR_T57,1752
  5695. -#define __proto(58,1780
  5696. -typedef void *PTR_T;PTR_T62,1878
  5697. -typedef void *CPTR_T;CPTR_T63,1899
  5698. -typedef char *PTR_T;PTR_T66,1928
  5699. -typedef char *CPTR_T;CPTR_T67,1970
  5700. -#define __proto(70,2000
  5701. -#define const71,2022
  5702. -#define uchar    74,2044
  5703. -#define ushort    75,2072
  5704. -#define uint    76,2102
  5705. -#define ulong    77,2128
  5706. -#define size_t    85,2373
  5707. -#define ptrdiff_t    86,2394
  5708. -#define stStaParam    93,2524
  5709. -#define btVoid    97,2601
  5710. -typedef enum sc sc100,2650
  5711. -} sc_t;sc_t125,4061
  5712. -typedef enum st st129,4107
  5713. -} st_t;st_t152,5140
  5714. -typedef enum tq tq156,5190
  5715. -} tq_t;tq_t164,5485
  5716. -typedef enum bt bt168,5531
  5717. -} bt_t;bt_t197,6792
  5718. -typedef enum lang lang201,6845
  5719. -} lang_t;lang_t211,7104
  5720. -typedef enum glevel glevel215,7162
  5721. -} glevel_t;glevel_t220,7275
  5722. -typedef struct scope scope224,7330
  5723. -} scope_t;scope_t229,7507
  5724. -#define __define_stab(285,9564
  5725. -read_seek 295,9807
  5726. -lang_to_string 329,10630
  5727. -sc_to_string(352,11106
  5728. -st_to_string(390,12172
  5729. -glevel_to_string 426,13121
  5730. -type_to_string 444,13419
  5731. -print_global_hdr 756,20662
  5732. -print_sym_hdr 811,22102
  5733. -print_symbol 885,24353
  5734. -print_aux 1054,28502
  5735. -emit_aggregate 1080,28942
  5736. -print_file_desc 1111,29617
  5737. -read_tfile __proto(1335,36141
  5738. -main 1435,38475
  5739. -fancy_abort 1561,41602
  5740. -fatal(1568,41688
  5741. -xmalloc 1578,41824
  5742. -
  5743. -mips-tfile.c,5248
  5744. -#define saber_stop(611,22337
  5745. -#define __LINE__ 615,22383
  5746. -typedef void *PTR_T;PTR_T619,22426
  5747. -typedef const void *CPTR_T;CPTR_T620,22447
  5748. -#define __proto(621,22475
  5749. -#define PVPROTO(623,22511
  5750. -#define VPROTO(624,22539
  5751. -#define VA_START(625,22576
  5752. -typedef void *PTR_T;PTR_T630,22713
  5753. -typedef void *CPTR_T;CPTR_T631,22734
  5754. -typedef char *PTR_T;PTR_T634,22763
  5755. -typedef char *CPTR_T;CPTR_T635,22805
  5756. -#define __proto(638,22835
  5757. -#define const639,22857
  5758. -#define PVPROTO(641,22886
  5759. -#define VPROTO(642,22912
  5760. -#define VA_START(643,22962
  5761. -#define Size_t    656,23515
  5762. -#define Size_t    658,23555
  5763. -#define Ptrdiff_t    660,23591
  5764. -main 694,24469
  5765. -#define STAB_CODE_TYPE 729,25218
  5766. -#define STAB_CODE_TYPE 731,25270
  5767. -#define HAS_STDLIB_H735,25324
  5768. -#define HAS_UNISTD_H736,25345
  5769. -#define MALLOC_CHECK753,25590
  5770. -#define IS_ASM_IDENT(757,25626
  5771. -typedef enum sc sc764,25804
  5772. -} sc_t;sc_t789,27209
  5773. -typedef enum st st793,27255
  5774. -} st_t;st_t815,28228
  5775. -typedef enum tq tq819,28278
  5776. -} tq_t;tq_t827,28573
  5777. -typedef enum bt bt831,28619
  5778. -} bt_t;bt_t866,29932
  5779. -enum coff_storage coff_storage871,29979
  5780. -typedef enum coff_type coff_type903,30494
  5781. -} coff_type_t;coff_type_t921,30774
  5782. -typedef enum coff_dt coff_dt924,30825
  5783. -} coff_dt_t;coff_dt_t930,30917
  5784. -#define N_BTMASK    932,30931
  5785. -#define N_TMASK    933,30988
  5786. -#define N_BT_SHIFT    934,31047
  5787. -#define N_TQ_SHIFT    935,31106
  5788. -#define    N_TQ    936,31163
  5789. -typedef enum hash_state hash_state939,31254
  5790. -} hash_state_t;hash_state_t943,31443
  5791. -enum alloc_type alloc_type947,31514
  5792. -#define WORD_ALIGN(961,32046
  5793. -#define DWORD_ALIGN(962,32123
  5794. -#define PAGE_SIZE 976,32720
  5795. -#define PAGE_USIZE 979,32779
  5796. -#define MAX_CLUSTER_PAGES 984,32927
  5797. -#define MAX_CLUSTER_PAGES 986,32962
  5798. -typedef struct vlinks vlinks992,33064
  5799. -} vlinks_t;vlinks_t997,33294
  5800. -typedef struct varray varray1001,33337
  5801. -} varray_t;varray_t1008,33719
  5802. -#define OBJECTS_PER_PAGE(1011,33753
  5803. -#define OBJECTS_PER_PAGE(1013,33818
  5804. -#define INIT_VARRAY(1016,33895
  5805. -typedef unsigned long symint_t;symint_t1026,34268
  5806. -typedef struct scope scope1030,34379
  5807. -} scope_t;scope_t1036,34627
  5808. -typedef struct forward forward1040,34712
  5809. -} forward_t;forward_t1046,35003
  5810. -typedef struct tag tag1051,35127
  5811. -} tag_t;tag_t1060,35625
  5812. -typedef struct thead thead1064,35682
  5813. -} thead_t;thead_t1068,35854
  5814. -typedef union small_free small_free1072,35949
  5815. -} small_free_t;small_free_t1077,36161
  5816. -#define SHASH_SIZE 1084,36288
  5817. -#define HASH_LEN_MAX 1087,36320
  5818. -typedef struct shash shash1089,36388
  5819. -} shash_t;shash_t1099,36824
  5820. -#define THASH_SIZE 1108,37103
  5821. -typedef struct thash thash1111,37134
  5822. -} thash_t;thash_t1115,37295
  5823. -typedef struct efdr efdr1120,37425
  5824. -} efdr_t;efdr_t1138,38217
  5825. -typedef union page page1199,40706
  5826. -} page_t;page_t1216,41464
  5827. -typedef struct alloc_info alloc_info1220,41552
  5828. -} alloc_info_t;alloc_info_t1228,41998
  5829. -typedef struct type_info type_info1231,42059
  5830. -} type_info_t;type_info_t1245,42791
  5831. -#define CHECK(1590,52536
  5832. -#define ORIG_LINENUM(1593,52658
  5833. -#define ORIG_DENSE(1594,52758
  5834. -#define ORIG_PROCS(1595,52854
  5835. -#define ORIG_FILES(1596,52950
  5836. -#define ORIG_LSYMS(1597,53046
  5837. -#define ORIG_LSTRS(1598,53147
  5838. -#define ORIG_ESYMS(1599,53248
  5839. -#define ORIG_ESTRS(1600,53347
  5840. -#define ORIG_OPT(1601,53446
  5841. -#define ORIG_AUX(1602,53544
  5842. -#define ORIG_RFDS(1603,53642
  5843. -#define STABS_SYMBOL 1636,55594
  5844. -#define STATIC 1645,55772
  5845. -#define    SEEK_SET 1779,59557
  5846. -#define    SEEK_CUR 1780,59609
  5847. -#define    SEEK_END 1781,59684
  5848. -typedef struct _pseudo_ops _pseudo_ops1790,59986
  5849. -} pseudo_ops_t;pseudo_ops_t1794,60178
  5850. -add_varray_page 1814,60815
  5851. -#define HASHBITS 1845,61582
  5852. -hash_string 1848,61620
  5853. -add_string 1884,62649
  5854. -add_local_symbol 1937,63950
  5855. -add_ext_symbol 2114,68928
  5856. -add_aux_sym_symint 2168,70445
  5857. -add_aux_sym_rndx 2188,70943
  5858. -add_aux_sym_tir 2211,71505
  5859. -get_tag 2373,76273
  5860. -add_unknown_tag 2424,77582
  5861. -add_procedure 2484,78978
  5862. -add_file 2549,80881
  5863. -add_bytes 2629,83326
  5864. -sc_to_string(2668,84239
  5865. -st_to_string(2706,85337
  5866. -read_line __proto(2743,86434
  5867. -parse_begin 2819,88044
  5868. -parse_bend 2869,89266
  5869. -parse_def 2927,90734
  5870. -parse_end 3503,104650
  5871. -parse_ent 3565,106224
  5872. -parse_file 3603,106987
  5873. -mark_stabs 3631,107588
  5874. -parse_stabs_common 3676,108736
  5875. -parse_stabs 3875,113286
  5876. -parse_stabn 3891,113612
  5877. -parse_input __proto(3902,113849
  5878. -update_headers __proto(3965,115343
  5879. -write_varray 4151,121006
  5880. -write_object __proto(4194,122165
  5881. -read_seek 4413,128175
  5882. -copy_object __proto(4482,129880
  5883. -main 4856,141597
  5884. -catch_signal 5075,147426
  5885. -pfatal_with_name 5090,147740
  5886. -out_of_bounds 5114,148302
  5887. -allocate_cluster 5139,149081
  5888. -allocate_cluster 5156,149413
  5889. -allocate_multiple_pages 5191,150214
  5890. -free_multiple_pages 5221,150783
  5891. -allocate_page __proto(5252,151433
  5892. -allocate_scope __proto(5274,151815
  5893. -free_scope 5313,152822
  5894. -allocate_vlinks __proto(5332,153186
  5895. -allocate_shash __proto(5365,154029
  5896. -allocate_thash __proto(5398,154855
  5897. -allocate_tag __proto(5431,155703
  5898. -free_tag 5470,156670
  5899. -allocate_forward __proto(5489,157025
  5900. -free_forward 5528,158072
  5901. -allocate_thead __proto(5547,158437
  5902. -free_thead 5586,159444
  5903. -fatal VPROTO(5610,159861
  5904. -error VPROTO(5640,160382
  5905. -fatal 5672,160926
  5906. -error 5680,161029
  5907. -fancy_abort 5694,161360
  5908. -botch 5704,161523
  5909. -xmalloc 5713,161643
  5910. -xcalloc 5729,161963
  5911. -xrealloc 5746,162355
  5912. -xfree 5762,162663
  5913. -local_index 5776,162923
  5914. -local_rindex 5792,163140
  5915. -
  5916. -objc-act.c,7403
  5917. -#define OBJC_GEN_METHOD_LABEL(57,2015
  5918. -#define OBJC_FORWARDING_STACK_OFFSET 72,2487
  5919. -#define OBJC_FORWARDING_MIN_OFFSET 76,2569
  5920. -#define DEFTREECODE(85,2851
  5921. -#define DEFTREECODE(97,3142
  5922. -#define DEFTREECODE(107,3368
  5923. -#define obstack_chunk_alloc 119,3569
  5924. -#define obstack_chunk_free 120,3605
  5925. -#define OBJC_VERSION    138,4134
  5926. -#define PROTOCOL_VERSION 139,4183
  5927. -#define OBJC_ENCODE_INLINE_DEFS 141,4211
  5928. -#define OBJC_ENCODE_DONT_INLINE_DEFS    142,4246
  5929. -typedef struct hashed_entry     *hash;hash195,6226
  5930. -typedef struct hashed_attribute  *attr;attr196,6262
  5931. -struct hashed_attributehashed_attribute198,6303
  5932. -struct hashed_entryhashed_entry203,6359
  5933. -enum string_sectionstring_section220,6873
  5934. -#define TYPE_ID    328,11612
  5935. -#define TAG_OBJECT    329,11635
  5936. -#define TAG_CLASS    330,11669
  5937. -#define TAG_SUPER    331,11701
  5938. -#define TAG_SELECTOR    332,11733
  5939. -#define UTAG_CLASS    334,11772
  5940. -#define UTAG_IVAR    335,11806
  5941. -#define UTAG_IVAR_LIST    336,11838
  5942. -#define UTAG_METHOD    337,11880
  5943. -#define UTAG_METHOD_LIST    338,11916
  5944. -#define UTAG_CATEGORY    339,11961
  5945. -#define UTAG_MODULE    340,12001
  5946. -#define UTAG_STATICS    341,12037
  5947. -#define UTAG_SYMTAB    342,12075
  5948. -#define UTAG_SUPER    343,12111
  5949. -#define UTAG_SELECTOR    344,12145
  5950. -#define UTAG_PROTOCOL    346,12186
  5951. -#define UTAG_PROTOCOL_LIST    347,12226
  5952. -#define UTAG_METHOD_PROTOTYPE    348,12275
  5953. -#define UTAG_METHOD_PROTOTYPE_LIST 349,12330
  5954. -#define STRING_OBJECT_CLASS_NAME 351,12397
  5955. -#define PROTOCOL_OBJECT_CLASS_NAME 352,12449
  5956. -#define TREE_STATIC_TEMPLATE(362,12700
  5957. -#define TYPED_OBJECT(363,12770
  5958. -#define IS_ID(379,13236
  5959. -#define IS_PROTOCOL_QUALIFIED_ID(381,13318
  5960. -#define IS_SUPER(383,13405
  5961. -struct imp_entryimp_entry425,14893
  5962. -#define BUFSIZE    456,15877
  5963. -lang_init 504,17145
  5964. -objc_fatal 552,18586
  5965. -finish_file 558,18657
  5966. -lang_finish 568,18822
  5967. -lang_identify 573,18849
  5968. -lang_decode_option 579,18892
  5969. -define_decl 609,19666
  5970. -maybe_objc_comptypes 631,20385
  5971. -lookup_method_in_protocol_list 641,20571
  5972. -lookup_protocol_in_reflist 674,21298
  5973. -objc_comptypes 713,22270
  5974. -objc_check_decl 857,26184
  5975. -maybe_objc_check_decl 872,26521
  5976. -get_static_reference 882,26707
  5977. -get_object_reference 918,27639
  5978. -lookup_and_install_protocols 967,29028
  5979. -create_builtin_decl 1004,29806
  5980. -synth_module_prologue 1034,30443
  5981. -my_build_string 1163,34093
  5982. -build_objc_string 1189,34773
  5983. -build_objc_string_object 1207,35292
  5984. -objc_add_static_instance 1261,36765
  5985. -build_constructor 1305,38068
  5986. -build_objc_symtab_template 1331,38601
  5987. -init_def_list 1383,39966
  5988. -init_objc_symtab 1415,40780
  5989. -forward_declare_categories 1460,41947
  5990. -generate_objc_symtab_decl 1483,42652
  5991. -init_module_descriptor 1514,43427
  5992. -build_module_descriptor 1565,44899
  5993. -generate_forward_declaration_to_string_table 1712,49597
  5994. -get_objc_string_decl 1728,50062
  5995. -generate_static_references 1753,50655
  5996. -generate_strings 1829,53376
  5997. -build_selector_reference_decl 1880,55381
  5998. -build_selector 1913,56026
  5999. -build_msg_pool_reference 1929,56530
  6000. -init_selector 1946,56951
  6001. -build_selector_translation_table 1955,57108
  6002. -get_proto_encoding 2026,59285
  6003. -build_typed_selector_reference 2054,59911
  6004. -build_selector_reference 2081,60481
  6005. -build_class_reference_decl 2111,61090
  6006. -add_class_reference 2145,61763
  6007. -get_class_reference 2174,62326
  6008. -add_objc_string 2220,63549
  6009. -build_objc_string_decl 2249,64200
  6010. -objc_declare_alias 2289,65206
  6011. -objc_declare_class 2305,65670
  6012. -is_class_name 2335,66309
  6013. -lookup_interface 2359,66711
  6014. -objc_copy_list 2373,66938
  6015. -build_ivar_chain 2408,68007
  6016. -build_private_template 2467,69452
  6017. -build_protocol_template 2510,70544
  6018. -build_descriptor_table_initializer 2573,72636
  6019. -build_method_prototype_list_template 2612,73442
  6020. -build_method_prototype_template 2648,74447
  6021. -forwarding_offset 2689,75816
  6022. -encode_method_prototype 2734,77232
  6023. -generate_descriptor_table 2805,79146
  6024. -generate_method_descriptors 2830,79806
  6025. -build_tmp_function_decl 2891,81550
  6026. -hack_method_prototype 2924,82628
  6027. -generate_protocol_references 2972,84112
  6028. -generate_protocols 2995,84653
  6029. -build_protocol_initializer 3095,87659
  6030. -build_category_template 3152,89316
  6031. -build_selector_template 3218,91488
  6032. -build_class_template 3265,92838
  6033. -synth_forward_declarations 3404,97591
  6034. -error_with_ivar 3435,98627
  6035. -#define USERTYPE(3450,98989
  6036. -check_ivars 3455,99126
  6037. -build_super_template 3514,100643
  6038. -build_ivar_template 3556,101877
  6039. -build_ivar_list_template 3602,103194
  6040. -build_method_list_template 3642,104250
  6041. -build_ivar_list_initializer 3689,105578
  6042. -generate_ivars_list 3745,106866
  6043. -generate_ivar_lists 3770,107536
  6044. -build_dispatch_table_initializer 3826,109223
  6045. -build_method_template 3870,110314
  6046. -generate_dispatch_table 3918,111882
  6047. -generate_dispatch_tables 3944,112622
  6048. -generate_protocol_list 4012,114504
  6049. -build_category_initializer 4098,117071
  6050. -build_shared_structure_initializer 4172,119053
  6051. -generate_category 4264,121528
  6052. -generate_shared_structures 4315,123056
  6053. -synth_id_with_class_suffix 4422,126172
  6054. -is_objc_type_qualifier 4461,127496
  6055. -adjust_type_for_id_default 4478,128077
  6056. -build_keyword_decl 4522,129246
  6057. -build_keyword_selector 4544,129776
  6058. -build_method_decl 4586,130764
  6059. -#define METHOD_DEF 4618,131648
  6060. -#define METHOD_REF 4619,131669
  6061. -get_arg_type_list 4629,132086
  6062. -check_duplicates 4672,133414
  6063. -receiver_is_class_object 4703,134228
  6064. -maybe_building_objc_message_expr 4749,135672
  6065. -build_message_expr 4762,136057
  6066. -build_objc_method_call 5050,144214
  6067. -build_protocol_reference 5152,147557
  6068. -build_protocol_expr 5187,148376
  6069. -build_selector_expr 5216,148883
  6070. -build_encode_expr 5238,149396
  6071. -build_ivar_reference 5259,149919
  6072. -#define HASH_ALLOC_LIST_SIZE    5281,150769
  6073. -#define ATTR_ALLOC_LIST_SIZE    5282,150802
  6074. -#define SIZEHASHTABLE 5283,150835
  6075. -#define HASHFUNCTION(5286,150884
  6076. -hash_init 5289,150958
  6077. -hash_enter 5309,151392
  6078. -hash_lookup 5335,152078
  6079. -hash_add_attr 5354,152388
  6080. -lookup_method 5378,152981
  6081. -lookup_instance_method_static 5399,153329
  6082. -lookup_class_method_static 5452,154488
  6083. -add_class_method 5509,155818
  6084. -add_instance_method 5555,157079
  6085. -add_class 5601,158358
  6086. -add_category 5611,158552
  6087. -add_instance_variable 5637,159321
  6088. -is_ivar 5688,160446
  6089. -is_private 5701,160742
  6090. -is_public 5718,161122
  6091. -get_class_ivars 5774,162579
  6092. -check_methods 5786,162788
  6093. -conforms_to_protocol 5821,163610
  6094. -check_methods_accessible 5852,164297
  6095. -check_protocols 5915,165921
  6096. -start_class 5973,167601
  6097. -continue_class 6133,172381
  6098. -finish_class 6199,174044
  6099. -add_protocol 6266,176231
  6100. -lookup_protocol 6276,176435
  6101. -start_protocol 6291,176657
  6102. -finish_protocol 6325,177398
  6103. -encode_type_qualifiers 6335,177591
  6104. -encode_pointer 6360,178388
  6105. -encode_array 6424,179961
  6106. -encode_aggregate 6451,180576
  6107. -encode_bitfield 6616,185093
  6108. -encode_type 6628,185366
  6109. -encode_field_decl 6705,187303
  6110. -expr_last 6727,188024
  6111. -maybe_objc_method_name 6743,188309
  6112. -start_method_def 6756,188591
  6113. -warn_with_method 6847,191397
  6114. -comp_method_with_proto 6867,191870
  6115. -comp_proto_with_proto 6893,192572
  6116. -really_start_method 6926,193715
  6117. -continue_method_def 7014,196779
  6118. -add_objc_decls 7036,197374
  6119. -get_super_receiver 7060,197988
  6120. -encode_method_def 7142,200362
  6121. -finish_method_def 7199,201813
  6122. -lang_report_error_function 7211,202128
  6123. -is_complex_decl 7226,202374
  6124. -adorn_decl 7240,202670
  6125. -gen_declarator 7341,204932
  6126. -gen_declspecs 7430,206717
  6127. -gen_declaration 7678,212329
  6128. -#define RAW_TYPESPEC(7765,214416
  6129. -gen_method_decl 7768,214505
  6130. -dump_interface 7831,215941
  6131. -init_objc 7881,217111
  6132. -finish_objc 7918,218220
  6133. -generate_classref_translation_entry 8051,222101
  6134. -handle_class_ref 8077,222861
  6135. -handle_impent 8124,224333
  6136. -objc_debug 8193,226455
  6137. -print_lang_statistics 8266,228140
  6138. -
  6139. -obstack.c,810
  6140. -#define POINTER 35,1483
  6141. -#define POINTER 37,1512
  6142. -struct fooalign fooalign41,1579
  6143. -#define DEFAULT_ALIGNMENT 42,1616
  6144. -union fooround fooround47,1924
  6145. -#define DEFAULT_ROUNDING 48,1960
  6146. -#define COPYING_UNIT 55,2265
  6147. -#define CALL_CHUNKFUN(69,2778
  6148. -#define CALL_FREEFUN(74,2921
  6149. -_obstack_begin 93,3519
  6150. -_obstack_begin_1 144,5053
  6151. -_obstack_newchunk 203,6912
  6152. -_obstack_allocated_p 277,9349
  6153. -_obstack_free 305,10208
  6154. -obstack_free 339,11199
  6155. -POINTER 384,12725
  6156. -POINTER 390,12826
  6157. -int (obstack_object_size)396,12937
  6158. -int (obstack_room)402,13048
  6159. -void (obstack_grow)408,13145
  6160. -void (obstack_grow0)416,13309
  6161. -void (obstack_1grow)424,13475
  6162. -void (obstack_blank)431,13610
  6163. -void (obstack_1grow_fast)438,13736
  6164. -void (obstack_blank_fast)445,13881
  6165. -POINTER 452,14017
  6166. -POINTER 458,14122
  6167. -POINTER 465,14258
  6168. -POINTER 473,14432
  6169. -
  6170. -optabs.c,1050
  6171. -add_equal_note 249,6453
  6172. -widen_operand 299,8210
  6173. -expand_binop 341,9623
  6174. -sign_expand_binop 1620,48262
  6175. -expand_twoval_binop 1682,50445
  6176. -expand_unop 1812,54363
  6177. -expand_abs 2084,61619
  6178. -expand_complex_abs 2168,64086
  6179. -emit_unop_insn 2363,69268
  6180. -emit_no_conflict_block 2429,71367
  6181. -emit_libcall_block 2554,75180
  6182. -emit_clr_insn 2623,77023
  6183. -emit_0_to_1_insn 2633,77176
  6184. -emit_cmp_insn 2654,77814
  6185. -can_compare_p 2860,84055
  6186. -emit_float_lib_cmp 2877,84437
  6187. -emit_indirect_jump 3054,87308
  6188. -emit_conditional_move 3082,88174
  6189. -can_conditionally_move_p 3196,91330
  6190. -gen_add2_insn 3217,91827
  6191. -have_add2_insn 3231,92236
  6192. -gen_sub2_insn 3240,92431
  6193. -have_sub2_insn 3254,92840
  6194. -gen_move_insn 3264,93085
  6195. -can_extend_p 3348,95579
  6196. -gen_extend_insn 3359,95897
  6197. -can_fix_p 3377,96521
  6198. -can_float_p 3395,97047
  6199. -expand_float 3409,97470
  6200. -ftruncify 3667,105053
  6201. -expand_fix 3675,105193
  6202. -init_optab 3886,111716
  6203. -init_libfuncs 3922,112891
  6204. -init_integral_libfuncs 3962,114081
  6205. -init_floating_libfuncs 3976,114532
  6206. -init_complex_libfuncs 3990,114985
  6207. -init_optabs 4002,115295
  6208. -ldexp(4309,127208
  6209. -
  6210. -print-rtl.c,142
  6211. -#define DEBUG_PRINT_REG(32,1022
  6212. -print_rtx 57,1745
  6213. -debug_rtx 226,5310
  6214. -debug_rtx_list 246,5869
  6215. -debug_rtx_find(274,6490
  6216. -print_rtl 299,6999
  6217. -
  6218. -print-tree.c,143
  6219. -#define HASH_SIZE 36,1108
  6220. -struct bucketbucket38,1130
  6221. -debug_tree 51,1373
  6222. -print_node_brief 67,1769
  6223. -indent_to 182,4461
  6224. -print_node 199,4804
  6225. -
  6226. -protoize.c,3882
  6227. -#define __STDC__ 26,1066
  6228. -#define VOLATILE 30,1186
  6229. -#define VOLATILE32,1218
  6230. -#define const36,1260
  6231. -#define volatile37,1274
  6232. -#define POSIX47,1584
  6233. -#define _POSIX_SOURCE57,1939
  6234. -#define getopt 80,2511
  6235. -#define my_access(108,3202
  6236. -#define my_stat(109,3258
  6237. -#define my_execvp(110,3308
  6238. -#define my_link(111,3373
  6239. -#define my_unlink(112,3438
  6240. -#define my_open(113,3484
  6241. -#define my_chmod(114,3549
  6242. -typedef void * pointer_type;pointer_type123,3810
  6243. -typedef const void * const_pointer_type;const_pointer_type124,3839
  6244. -typedef char * pointer_type;pointer_type126,3886
  6245. -typedef char * const_pointer_type;const_pointer_type127,3915
  6246. -#define R_OK 140,4109
  6247. -#define W_OK 141,4164
  6248. -#define X_OK 142,4220
  6249. -#define F_OK 143,4278
  6250. -#define O_RDONLY 146,4353
  6251. -#define O_WRONLY 150,4404
  6252. -#define WIFSIGNALED(154,4458
  6253. -#define WTERMSIG(157,4549
  6254. -#define WIFEXITED(160,4607
  6255. -#define WEXITSTATUS(163,4675
  6256. -typedef void voidfn voidfn170,4851
  6257. -#define fork 205,5733
  6258. -extern size_t   strlen 199,5575
  6259. -#define NONCONST214,5935
  6260. -#define STRINGIFY(219,6042
  6261. -#define STRINGIFY(221,6082
  6262. -#define STD_PROTO_DIR 227,6207
  6263. -struct unexpansion_struct unexpansion_struct259,7135
  6264. -typedef struct unexpansion_struct unexpansion;unexpansion263,7216
  6265. -#define HASH_TABLE_SIZE    281,7852
  6266. -#define STANDARD_INCLUDE_DIR 291,8113
  6267. -#define LOCAL_INCLUDE_DIR 295,8191
  6268. -struct default_include default_include298,8246
  6269. -struct string_liststring_list335,9606
  6270. -typedef struct hash_table_entry_struct hash_table_entry;hash_table_entry377,11324
  6271. -typedef struct def_dec_info_struct def_dec_info;def_dec_info381,11457
  6272. -typedef struct file_info_struct file_info;file_info382,11506
  6273. -typedef struct f_list_chain_item_struct f_list_chain_item;f_list_chain_item383,11549
  6274. -struct hash_table_entry_struct hash_table_entry_struct397,12404
  6275. -#define ddip 405,12636
  6276. -#define fip 406,12661
  6277. -typedef hash_table_entry hash_table[hash_table410,12745
  6278. -struct file_info_struct file_info_struct415,12938
  6279. -struct f_list_chain_item_struct f_list_chain_item_struct438,14056
  6280. -struct def_dec_info_struct def_dec_info_struct450,14636
  6281. -my_strerror(628,21283
  6282. -xmalloc 653,21684
  6283. -xrealloc 672,22061
  6284. -xfree 694,22576
  6285. -savestring 704,22733
  6286. -savestring2 716,22977
  6287. -fancy_abort 732,23399
  6288. -dupnstr 742,23591
  6289. -substr 757,23930
  6290. -safe_read 781,24378
  6291. -safe_write 809,24866
  6292. -save_pointers 835,25380
  6293. -restore_pointers 845,25629
  6294. -is_id_char 854,25823
  6295. -usage 864,26036
  6296. -in_system_include_dir 881,26544
  6297. -file_could_be_converted 902,27056
  6298. -file_normally_convertible 936,28099
  6299. -is_syscalls_file 988,29254
  6300. -needs_to_be_converted 1008,29984
  6301. -directory_specified_p 1047,30901
  6302. -file_excluded_p 1074,31436
  6303. -string_list_cons 1092,31865
  6304. -visit_each_hash_node 1114,32539
  6305. -add_symbol 1137,33214
  6306. -lookup 1154,33669
  6307. -free_def_dec 1187,34543
  6308. -unexpand_if_needed 1214,35096
  6309. -abspath 1297,37595
  6310. -shortpath 1404,40891
  6311. -find_file 1492,43306
  6312. -aux_info_corrupted 1533,44418
  6313. -check_aux_info 1544,44730
  6314. -find_corresponding_lparen 1556,45016
  6315. -referenced_file_is_newer 1583,45654
  6316. -save_def_or_dec 1631,47285
  6317. -munge_compile_params 2018,59605
  6318. -gen_aux_info_file 2091,61789
  6319. -process_aux_info_file 2191,64321
  6320. -rename_c_file 2491,72816
  6321. -reverse_def_dec_list 2539,74511
  6322. -find_extern_def 2581,75973
  6323. -find_static_definition 2744,82608
  6324. -connect_defs_and_decs 2794,84386
  6325. -identify_lineno 2919,90418
  6326. -declare_source_confusing 2934,90728
  6327. -check_source 2955,91382
  6328. -seek_to_line 2979,92370
  6329. -forward_to_next_token_char 2999,92873
  6330. -output_bytes 3012,93244
  6331. -output_string 3033,93844
  6332. -output_up_to 3059,94790
  6333. -other_variable_style_function 3079,95385
  6334. -edit_fn_declaration 3118,96414
  6335. -edit_formals_lists 3334,104522
  6336. -find_rightmost_formals_list 3444,107926
  6337. -add_local_decl 3562,112069
  6338. -add_global_decls 3670,116137
  6339. -edit_fn_definition 3761,119090
  6340. -do_cleaning 3905,123918
  6341. -careful_find_l_paren 4007,126970
  6342. -scan_for_missed_items 4046,128155
  6343. -edit_file 4161,132272
  6344. -do_processing 4469,141893
  6345. -main 4584,145680
  6346. -
  6347. -pself.c,10
  6348. -main(1,0
  6349. -
  6350. -pself1.c,0
  6351. -
  6352. -pself2.c,10
  6353. -main(1,0
  6354. -
  6355. -pself3.c,10
  6356. -main(1,0
  6357. -
  6358. -real.c,4186
  6359. -#define DEC 114,4896
  6360. -#define IBM 118,5006
  6361. -#define IEEE121,5098
  6362. -#define UNK 125,5234
  6363. -#define REAL_WORDS_BIG_ENDIAN 130,5313
  6364. -#define DEC 140,5737
  6365. -#define IBM 144,5845
  6366. -#define IEEE147,5935
  6367. -#define UNK 150,6005
  6368. -#define REAL_WORDS_BIG_ENDIAN 155,6084
  6369. -#define INFINITY162,6322
  6370. -#define NANS163,6339
  6371. -#define INFINITY169,6441
  6372. -#define EMUSHORT 177,6624
  6373. -#define EMUSHORT_SIZE 178,6646
  6374. -#define EMULONG_SIZE 179,6687
  6375. -#define EMUSHORT 182,6769
  6376. -#define EMUSHORT_SIZE 183,6792
  6377. -#define EMULONG_SIZE 184,6834
  6378. -#define EMUSHORT 187,6915
  6379. -#define EMUSHORT_SIZE 188,6936
  6380. -#define EMULONG_SIZE 189,6976
  6381. -#define EMUSHORT 192,7056
  6382. -#define EMUSHORT_SIZE 193,7078
  6383. -#define EMULONG_SIZE 194,7119
  6384. -#define EMU_NON_COMPILE197,7244
  6385. -#define EMULONG 204,7337
  6386. -#define EMULONG 207,7403
  6387. -#define EMULONG 210,7468
  6388. -#define EMULONG 213,7539
  6389. -#define EMU_NON_COMPILE216,7648
  6390. -#define EMU_NON_COMPILE225,7790
  6391. -#define NE 238,8188
  6392. -#define MAXDECEXP 239,8201
  6393. -#define MINDECEXP 240,8224
  6394. -#define GET_REAL(241,8248
  6395. -#define PUT_REAL(242,8307
  6396. -#define NE 245,8421
  6397. -#define MAXDECEXP 246,8435
  6398. -#define MINDECEXP 247,8458
  6399. -#define GET_REAL(248,8482
  6400. -#define PUT_REAL(249,8541
  6401. -#define NE 251,8606
  6402. -#define MAXDECEXP 252,8619
  6403. -#define MINDECEXP 253,8642
  6404. -#define GET_REAL(258,8778
  6405. -#define PUT_REAL(273,9201
  6406. -#define GET_REAL(291,9694
  6407. -#define PUT_REAL(292,9756
  6408. -#define NI 300,9949
  6409. -#define E 303,9999
  6410. -#define M 306,10050
  6411. -#define NBITS 309,10097
  6412. -#define NDEC 314,10204
  6413. -#define EXONE 317,10257
  6414. -endian 430,16478
  6415. -earith 536,18482
  6416. -etrunci 615,19856
  6417. -etruncui 638,20268
  6418. -ereal_atof 662,20763
  6419. -ereal_negate 699,21360
  6420. -efixi 716,21619
  6421. -efixui 739,22035
  6422. -ereal_from_int 761,22357
  6423. -ereal_from_uint 795,22971
  6424. -ereal_to_int 816,23345
  6425. -ereal_ldexp 860,24212
  6426. -target_isinf 885,24652
  6427. -target_isnan 901,24868
  6428. -target_negative 919,25146
  6429. -real_value_truncate 929,25343
  6430. -debug_real 986,26330
  6431. -etartdouble 1011,27036
  6432. -etarldouble 1027,27364
  6433. -etardouble 1042,27677
  6434. -etarsingle 1057,27939
  6435. -ereal_to_decimal 1075,28332
  6436. -ereal_cmp 1089,28573
  6437. -ereal_isneg 1102,28793
  6438. -#define DOMAIN    1271,35513
  6439. -#define SING    1272,35559
  6440. -#define OVERFLOW    1273,35602
  6441. -#define UNDERFLOW    1274,35648
  6442. -#define TLOSS    1275,35696
  6443. -#define PLOSS    1276,35743
  6444. -#define INVALID    1277,35792
  6445. -eclear 1359,38329
  6446. -emov 1371,38494
  6447. -eabs 1384,38664
  6448. -eneg 1394,38836
  6449. -eisneg 1404,39012
  6450. -eisinf 1417,39201
  6451. -eisnan 1435,39518
  6452. -einfin 1459,39935
  6453. -enan 1502,40597
  6454. -emovi 1517,40864
  6455. -emovo 1564,41692
  6456. -ecleaz 1603,42321
  6457. -ecleazs 1615,42512
  6458. -emovz 1628,42702
  6459. -einan 1644,43006
  6460. -eiisnan 1656,43167
  6461. -eiisneg 1675,43433
  6462. -eiinfin 1686,43621
  6463. -eiisinf 1697,43766
  6464. -ecmpm 1719,44118
  6465. -eshdn1 1743,44481
  6466. -eshup1 1767,44857
  6467. -eshdn8 1792,45208
  6468. -eshup8 1813,45546
  6469. -eshup6 1835,45891
  6470. -eshdn6 1853,46150
  6471. -eaddm 1871,46426
  6472. -esubm 1897,46893
  6473. -edivm 1931,47401
  6474. -emulm 2028,48882
  6475. -m16m 2080,49784
  6476. -edivm 2124,50626
  6477. -emulm 2189,51978
  6478. -emdnorm 2265,54003
  6479. -esub 2465,57491
  6480. -eadd 2497,58018
  6481. -eadd1 2530,58599
  6482. -ediv 2634,60549
  6483. -emul 2736,62421
  6484. -e53toe 2826,63962
  6485. -e64toe 2928,65802
  6486. -e113toe 3026,67627
  6487. -e24toe 3111,68881
  6488. -etoe113 3206,70570
  6489. -toe113 3239,71172
  6490. -etoe64 3297,72102
  6491. -toe64 3331,72731
  6492. -etoe53 3441,74457
  6493. -toe53 3451,74670
  6494. -etoe53 3462,74818
  6495. -toe53 3472,75016
  6496. -etoe53 3483,75184
  6497. -toe53 3517,75816
  6498. -etoe24 3612,77307
  6499. -toe24 3622,77503
  6500. -etoe24 3632,77675
  6501. -toe24 3666,78304
  6502. -ecmp 3763,79810
  6503. -eround 3825,80776
  6504. -ltoe 3835,80924
  6505. -ultoe 3877,82092
  6506. -eifrac 3917,83358
  6507. -euifrac 4000,85240
  6508. -eshift 4069,86704
  6509. -enormlz 4135,87528
  6510. -#define NTEN 4202,88631
  6511. -#define MAXP 4203,88647
  6512. -e24toasc 4306,92922
  6513. -e53toasc 4321,93204
  6514. -e64toasc 4336,93495
  6515. -e113toasc 4351,93790
  6516. -etoasc 4368,94134
  6517. -asctoe24 4684,100303
  6518. -asctoe53 4695,100461
  6519. -asctoe64 4710,100686
  6520. -asctoe113 4720,100840
  6521. -asctoe 4730,100983
  6522. -asctoeg 4741,101179
  6523. -efloor 5078,107177
  6524. -efrexp 5128,108071
  6525. -eldexp 5152,108509
  6526. -eremain 5174,108894
  6527. -eiremain 5210,109538
  6528. -#define NMSGS 5256,110711
  6529. -mtherr 5273,111025
  6530. -dectoe 5296,111591
  6531. -etodec 5336,112734
  6532. -todec 5358,113205
  6533. -ibmtoe 5404,113870
  6534. -etoibm 5448,115136
  6535. -toibm 5467,115541
  6536. -make_nan 5565,117305
  6537. -ereal_from_float 5624,118507
  6538. -ereal_from_double 5661,119564
  6539. -uditoe 5710,120985
  6540. -ditoe 5739,121649
  6541. -etoudi 5788,122647
  6542. -etodi 5871,123866
  6543. -esqrt 5973,125490
  6544. -significand_size 6082,127672
  6545. -
  6546. -recog.c,1337
  6547. -#define STACK_PUSH_CODE 37,1140
  6548. -#define STACK_PUSH_CODE 39,1178
  6549. -init_recog_no_volatile 75,2172
  6550. -init_recog 81,2227
  6551. -recog_memoized 96,2659
  6552. -check_asm_operands 108,2945
  6553. -#define MAX_CHANGE_LOCS    137,3630
  6554. -validate_change 165,4811
  6555. -apply_change_group 210,5844
  6556. -num_validated_changes 304,8599
  6557. -cancel_changes 312,8705
  6558. -validate_replace_rtx_1 332,9214
  6559. -validate_replace_rtx 512,15162
  6560. -next_insn_tests_no_inequality 525,15497
  6561. -next_insns_test_no_inequality 545,16048
  6562. -find_single_use_1 575,16855
  6563. -find_single_use 684,19914
  6564. -general_operand 750,21640
  6565. -address_operand 828,23818
  6566. -register_operand 850,24634
  6567. -scratch_operand 881,25609
  6568. -immediate_operand 897,26017
  6569. -const_int_operand 920,26662
  6570. -const_double_operand 931,26891
  6571. -nonimmediate_operand 950,27480
  6572. -nonmemory_operand 960,27712
  6573. -push_operand 1010,29297
  6574. -memory_address_p 1031,29646
  6575. -memory_operand 1049,30024
  6576. -indirect_operand 1074,30713
  6577. -comparison_operator 1113,32058
  6578. -asm_noperands 1126,32397
  6579. -decode_asm_operands 1204,35065
  6580. -find_constant_term_loc 1341,39205
  6581. -offsettable_memref_p 1395,40471
  6582. -offsettable_nonstrict_memref_p 1406,40729
  6583. -offsettable_address_p 1424,41281
  6584. -mode_dependent_address_p 1485,43186
  6585. -mode_independent_operand 1498,43418
  6586. -adj_offsettable_operand 1524,43966
  6587. -struct funny_matchfunny_match1592,46180
  6588. -constrain_operands 1598,46228
  6589. -reg_fits_class_p 1946,55174
  6590. -
  6591. -reg-stack.c,1095
  6592. -#define REG_STACK_SIZE 171,7224
  6593. -typedef struct stack_defstack_def182,7638
  6594. -} *stack;stack187,7823
  6595. -#define FP_MODE_REG(223,9018
  6596. -#define BLOCK_NUM(229,9227
  6597. -mark_regs_pat 253,9846
  6598. -straighten_stack 279,10386
  6599. -stack_regs_mentioned_p 297,10828
  6600. -reg_to_stack 335,11862
  6601. -record_label_references 471,15668
  6602. -get_true_reg 520,16822
  6603. -constrain_asm_operands 564,18185
  6604. -record_asm_reg_life 840,25085
  6605. -record_reg_life_pat 1056,31302
  6606. -get_asm_operand_lengths 1108,32562
  6607. -record_reg_life 1145,33867
  6608. -find_blocks 1263,37614
  6609. -uses_reg_or_mem 1372,40398
  6610. -stack_result 1405,41071
  6611. -stack_reg_life_analysis 1456,43036
  6612. -replace_reg 1605,47610
  6613. -remove_regno_note 1627,48088
  6614. -get_hard_regnum 1653,48719
  6615. -delete_insn_for_stacker 1674,49202
  6616. -emit_pop_insn 1690,49763
  6617. -emit_swap_insn 1732,51022
  6618. -move_for_stack_reg 1807,53271
  6619. -swap_rtx_condition 1947,57377
  6620. -compare_for_stack_reg 1983,58287
  6621. -subst_stack_regs_pat 2081,61124
  6622. -subst_asm_stack_regs 2330,68059
  6623. -subst_stack_regs 2616,76351
  6624. -change_stack 2722,79827
  6625. -goto_block_pat 2826,82850
  6626. -convert_regs 2944,85967
  6627. -print_blocks 3038,88809
  6628. -dump_stack_info 3075,89603
  6629. -
  6630. -regclass.c,691
  6631. -#define REGISTER_MOVE_COST(39,1302
  6632. -#define MEMORY_MOVE_COST(43,1370
  6633. -#define FORBIDDEN_INC_DEC_CLASSES52,1726
  6634. -#define N_REG_INTS 124,3971
  6635. -init_reg_sets 200,6419
  6636. -init_reg_sets_1 361,10888
  6637. -init_reg_modes 401,11824
  6638. -init_regs 424,12536
  6639. -choose_hard_reg_mode 438,12911
  6640. -fix_register 481,14153
  6641. -globalize_reg 511,14741
  6642. -struct costscosts544,15607
  6643. -reg_preferred_class 599,17471
  6644. -reg_alternate_class 608,17626
  6645. -regclass_init 620,17837
  6646. -regclass 631,18147
  6647. -record_reg_classes 1008,30536
  6648. -copy_cost 1404,41142
  6649. -record_address_regs 1467,43144
  6650. -auto_inc_dec_reg_p 1621,47751
  6651. -reg_scan 1688,49580
  6652. -reg_scan_mark_refs 1736,51117
  6653. -reg_class_subset_p 1859,54820
  6654. -reg_classes_intersect_p 1877,55175
  6655. -
  6656. -reload.c,1373
  6657. -#define REG_OK_STRICT88,3899
  6658. -#define REGISTER_MOVE_COST(103,4175
  6659. -struct replacementreplacement197,8087
  6660. -struct decompositiondecomposition212,8572
  6661. -#define MATCHES(266,10573
  6662. -#define MERGABLE_RELOADS(273,10862
  6663. -#define MERGE_TO_OTHER(283,11360
  6664. -push_secondary_reload 331,13513
  6665. -get_secondary_mem 602,23338
  6666. -clear_secondary_mem 674,25766
  6667. -push_reload 714,27368
  6668. -push_replacement 1349,50646
  6669. -transfer_replacements 1368,51052
  6670. -combine_reloads 1391,51824
  6671. -find_dummy_reload 1574,59148
  6672. -earlyclobber_operand_p 1716,63479
  6673. -hard_reg_set_here_p 1734,63887
  6674. -strict_memory_address_p 1768,64745
  6675. -operands_match_p 1795,65600
  6676. -n_occurrences 1921,69070
  6677. -decompose 1940,69609
  6678. -immune_p 2064,72608
  6679. -safe_from_earlyclobber 2110,73817
  6680. -find_reloads 2139,74859
  6681. -alternative_allows_memconst 3828,133277
  6682. -find_reloads_toplev 3863,134389
  6683. -make_memloc 4010,139234
  6684. -find_reloads_address 4062,141147
  6685. -subst_reg_equivs 4364,152074
  6686. -form_sum 4417,153254
  6687. -subst_indexed_address 4472,154932
  6688. -find_reloads_address_1 4539,157053
  6689. -find_reloads_address_part 4882,167563
  6690. -subst_reloads 4924,168899
  6691. -copy_replacements 4970,170330
  6692. -find_replacement 5011,171413
  6693. -refers_to_regno_for_reload_p 5058,172765
  6694. -reg_overlap_mentioned_for_reload_p 5180,176186
  6695. -refers_to_mem_for_reload_p 5227,177365
  6696. -find_equiv_reg 5278,178973
  6697. -find_inc_amount 5702,192474
  6698. -regno_clobbered_p 5747,193423
  6699. -debug_reload(5789,194378
  6700. -
  6701. -reload1.c,1472
  6702. -#define REGISTER_MOVE_COST(73,2884
  6703. -#define MEMORY_MOVE_COST(77,2952
  6704. -#define obstack_chunk_alloc 267,10769
  6705. -#define obstack_chunk_free 268,10805
  6706. -static struct elim_tableelim_table278,11214
  6707. -#define NUM_ELIMINABLE_REGS 308,12460
  6708. -struct hard_reg_n_uses hard_reg_n_uses332,13444
  6709. -init_reload 378,15621
  6710. -reload 445,17726
  6711. -possible_group_p 2032,72768
  6712. -count_possible_groups 2093,74599
  6713. -modes_equiv_for_class_p 2167,77194
  6714. -spill_failure 2186,77758
  6715. -new_spill_reg 2205,78470
  6716. -delete_dead_insn 2280,80988
  6717. -alter_reg 2308,81884
  6718. -mark_home_live 2425,85979
  6719. -mark_scratch_live 2440,86276
  6720. -set_label_offsets 2462,86847
  6721. -eliminate_regs 2640,92834
  6722. -eliminate_regs_in_insn 3170,110546
  6723. -mark_not_eliminable 3403,118891
  6724. -spill_hard_reg 3444,120243
  6725. -scan_paradoxical_subregs 3540,122838
  6726. -hard_reg_use_compare 3590,123916
  6727. -order_regs_for_reload 3605,124409
  6728. -compare_spill_regs 3716,127764
  6729. -reload_as_needed 3732,128283
  6730. -forget_old_reloads_1 4010,137456
  6731. -reload_reg_class_lower 4072,139292
  6732. -mark_reload_reg_in_use 4138,141863
  6733. -clear_reload_reg_in_use 4195,143132
  6734. -reload_reg_free_p 4251,144402
  6735. -reload_reg_free_before_p 4384,148830
  6736. -reload_reg_reaches_end_p 4495,152856
  6737. -reloads_conflict 4614,156810
  6738. -allocate_reload_reg 4705,159860
  6739. -choose_reload_regs 4902,166414
  6740. -merge_assigned_reloads 5564,190044
  6741. -emit_reload_insns 5640,192564
  6742. -gen_reload 6648,227108
  6743. -delete_output_reload 6850,234613
  6744. -inc_for_reload 6946,237613
  6745. -constraint_accepts_reg_p 7037,240432
  6746. -count_occurrences 7082,241507
  6747. -
  6748. -reorg.c,1768
  6749. -#define obstack_chunk_alloc 135,6284
  6750. -#define obstack_chunk_free 136,6320
  6751. -#define eligible_for_annul_true(139,6380
  6752. -#define eligible_for_annul_false(142,6476
  6753. -#define unfilled_slots_base    154,6875
  6754. -#define unfilled_slots_next    157,6957
  6755. -struct resourcesresources163,7150
  6756. -#define CLEAR_RESOURCE(173,7528
  6757. -struct target_infotarget_info191,8270
  6758. -#define TARGET_HASH_PRIME 200,8583
  6759. -mark_referenced_resources 274,11797
  6760. -mark_set_resources 495,18601
  6761. -stop_search_p 675,23328
  6762. -resource_conflicts_p 711,24110
  6763. -insn_references_resource_p 743,25042
  6764. -insn_sets_resource_p 761,25663
  6765. -find_end_label 777,26113
  6766. -emit_delay_sequence 854,28536
  6767. -add_to_delay_list 952,31666
  6768. -delete_from_delay_slot 986,32579
  6769. -delete_scheduled_jump 1040,34275
  6770. -#define NUM_REORG_FUNCTIONS 1087,35688
  6771. -#define MAX_DELAY_HISTOGRAM 1088,35718
  6772. -#define MAX_REORG_PASSES 1089,35748
  6773. -note_delay_statistics 1098,35989
  6774. -optimize_skip 1142,37395
  6775. -get_jump_flags 1222,40185
  6776. -rare_destination 1286,41989
  6777. -mostly_true_jump 1335,43315
  6778. -get_branch_condition 1436,46610
  6779. -condition_dominates_p 1479,47862
  6780. -redirect_with_delay_slots_safe_p 1507,48732
  6781. -redirect_with_delay_list_safe_p 1542,49794
  6782. -steal_delay_list_from_target 1593,51678
  6783. -steal_delay_list_from_fallthrough 1699,55342
  6784. -try_merge_delay_insns 1776,57368
  6785. -redundant_insn 1952,63456
  6786. -own_thread_p 2151,69463
  6787. -find_basic_block 2192,70554
  6788. -update_block 2233,71805
  6789. -reorg_redirect_jump 2258,72407
  6790. -update_reg_dead_notes 2282,73243
  6791. -update_reg_unused_notes 2315,74150
  6792. -update_live_status 2348,75063
  6793. -next_insn_no_annul 2381,75889
  6794. -mark_target_live_regs 2441,78226
  6795. -fill_simple_delay_slots 2799,90060
  6796. -fill_slots_from_thread 3273,105398
  6797. -fill_eager_delay_slots 3646,117195
  6798. -relax_delay_slots 3762,120514
  6799. -make_return_insns 4072,130675
  6800. -dbr_schedule 4192,134499
  6801. -
  6802. -rtl.c,494
  6803. -#define    obstack_chunk_alloc    29,929
  6804. -#define    obstack_chunk_free    30,965
  6805. -#define DEF_RTL_EXPR(52,1691
  6806. -#define DEF_MACHMODE(63,1977
  6807. -#define DEF_MACHMODE(79,2286
  6808. -#define DEF_MACHMODE(90,2558
  6809. -#define DEF_MACHMODE(101,2821
  6810. -#define DEF_MACHMODE(113,3164
  6811. -rtvec_alloc 187,5831
  6812. -rtx_alloc 209,6279
  6813. -rtx_free 249,7468
  6814. -copy_rtx 260,7673
  6815. -copy_most_rtx 358,9900
  6816. -dump_and_abort 448,11636
  6817. -read_skip_spaces 476,12355
  6818. -read_name 512,13028
  6819. -read_rtx 550,13828
  6820. -init_rtl 783,19300
  6821. -gcc_memset 843,21110
  6822. -
  6823. -rtlanal.c,1030
  6824. -rtx_unstable_p 40,1344
  6825. -rtx_varies_p 76,2220
  6826. -rtx_addr_can_trap_p 121,3279
  6827. -rtx_addr_varies_p 163,4526
  6828. -get_integer_term 191,5154
  6829. -get_related_value 211,5614
  6830. -reg_mentioned_p 231,6112
  6831. -no_labels_between_p 295,7414
  6832. -reg_used_between_p 309,7722
  6833. -reg_referenced_p 332,8402
  6834. -reg_referenced_between_p 390,9983
  6835. -reg_set_between_p 411,10546
  6836. -reg_set_p_1 432,10970
  6837. -reg_set_p 444,11208
  6838. -modified_between_p 481,12344
  6839. -modified_in_p 533,13469
  6840. -single_set 585,14518
  6841. -find_last_value 622,15451
  6842. -refers_to_regno_p 670,16627
  6843. -reg_overlap_mentioned_p 780,19856
  6844. -reg_set_last_1 832,21065
  6845. -reg_set_last 868,22066
  6846. -rtx_equal_p 925,23700
  6847. -note_stores 1035,26501
  6848. -dead_or_set_p 1092,28407
  6849. -dead_or_set_regno_p 1121,29027
  6850. -find_reg_note 1209,31483
  6851. -find_regno_note 1229,32061
  6852. -find_reg_fusage 1255,32801
  6853. -find_regno_fusage 1304,33967
  6854. -remove_note 1338,34749
  6855. -volatile_insn_p 1366,35401
  6856. -volatile_refs_p 1429,36549
  6857. -side_effects_p 1492,37663
  6858. -may_trap_p 1563,39044
  6859. -inequality_comparisons_p 1640,40705
  6860. -replace_rtx 1699,41715
  6861. -replace_regs 1738,42848
  6862. -
  6863. -scan-decls.c,86
  6864. -#define in_extern_C_brace 32,1159
  6865. -skip_to_closing_brace 39,1346
  6866. -scan_decls 78,2230
  6867. -
  6868. -scan.c,154
  6869. -make_sstring_space 27,911
  6870. -sstring_append 47,1339
  6871. -scan_ident 62,1611
  6872. -scan_string 84,1940
  6873. -skip_spaces 117,2435
  6874. -read_upto 155,2969
  6875. -get_token 174,3242
  6876. -
  6877. -sched.c,2310
  6878. -#define INSN_LUID(151,6956
  6879. -#define INSN_PRIORITY(155,7107
  6880. -#define INSN_COST(158,7195
  6881. -#define INSN_UNIT(163,7358
  6882. -#define INSN_BLOCKAGE(168,7572
  6883. -#define UNIT_BITS 169,7631
  6884. -#define BLOCKAGE_MASK 170,7651
  6885. -#define ENCODE_BLOCKAGE(171,7700
  6886. -#define UNIT_BLOCKED(175,7855
  6887. -#define BLOCKAGE_RANGE(176,7908
  6888. -#define MIN_BLOCKAGE_COST(181,8101
  6889. -#define MAX_BLOCKAGE_COST(182,8163
  6890. -#define DONE_PRIORITY    184,8238
  6891. -#define MAX_PRIORITY    185,8263
  6892. -#define TAIL_PRIORITY    186,8295
  6893. -#define LAUNCH_PRIORITY    187,8328
  6894. -#define DONE_PRIORITY_P(188,8363
  6895. -#define LOW_PRIORITY_P(189,8420
  6896. -#define INSN_REF_COUNT(193,8602
  6897. -#define LINE_NOTE(199,8849
  6898. -#define NEXT_Q(277,12541
  6899. -#define NEXT_Q_AFTER(278,12591
  6900. -#define INSN_TICK(284,12848
  6901. -struct sometimessometimes289,12999
  6902. -#define SIZE_FOR_MODE(348,15524
  6903. -canon_rtx 371,16581
  6904. -init_alias_analysis 399,17386
  6905. -rtx_equal_for_memref_p 447,18959
  6906. -find_symbolic_term 561,21881
  6907. -memrefs_conflict_p 614,23340
  6908. -read_dependence 807,28838
  6909. -true_dependence 817,29018
  6910. -anti_dependence 845,30153
  6911. -output_dependence 869,30993
  6912. -add_dependence 891,31780
  6913. -remove_dependence 960,33926
  6914. -schedule_insns 987,34354
  6915. -#define __inline993,34430
  6916. -find_insn_list 1079,37656
  6917. -insn_unit 1099,38156
  6918. -blockage_range 1135,39274
  6919. -clear_units 1172,40499
  6920. -prepare_unit 1182,40777
  6921. -actual_hazard_this_instance 1200,41153
  6922. -schedule_unit 1237,42344
  6923. -actual_hazard 1269,43220
  6924. -potential_hazard 1318,44584
  6925. -insn_cost 1363,45753
  6926. -priority 1425,47268
  6927. -free_pending_lists 1506,49736
  6928. -add_insn_mem_dependence 1580,51231
  6929. -flush_pending_lists 1614,51972
  6930. -sched_analyze_1 1659,53253
  6931. -sched_analyze_2 1797,57540
  6932. -sched_analyze_insn 2017,64064
  6933. -sched_analyze 2164,68539
  6934. -sched_note_set 2281,72213
  6935. -#define SCHED_SORT(2373,74512
  6936. -rank_for_schedule 2385,74955
  6937. -swap_sort 2434,76523
  6938. -queue_insn 2455,76884
  6939. -birthing_insn_p 2469,77191
  6940. -adjust_priority 2507,78076
  6941. -schedule_insn 2557,79373
  6942. -schedule_select 2616,81009
  6943. -create_reg_dead_note 2710,83301
  6944. -attach_deaths 2779,85465
  6945. -attach_deaths_insn 2971,91106
  6946. -unlink_notes 3025,92846
  6947. -new_sometimes_live 3066,94000
  6948. -finish_sometimes_live 3094,94850
  6949. -reemit_notes 3118,95551
  6950. -schedule_block 3144,96177
  6951. -regno_use_in 4055,124452
  6952. -split_hard_reg_notes 4089,125290
  6953. -new_insn_dead_notes 4138,126632
  6954. -update_n_sets 4239,129710
  6955. -update_flow_info 4271,130508
  6956. -schedule_insns 4666,141574
  6957. -
  6958. -sdbout.c,2033
  6959. -#define T_VOID 61,2218
  6960. -#define PARM_PASSED_IN_MEMORY(71,2448
  6961. -#define DEBUGGER_AUTO_OFFSET(77,2677
  6962. -#define DEBUGGER_ARG_OFFSET(84,2934
  6963. -#define CHAR_TYPE_SIZE 114,3673
  6964. -#define SHORT_TYPE_SIZE 118,3742
  6965. -#define INT_TYPE_SIZE 122,3848
  6966. -#define LONG_TYPE_SIZE 126,3915
  6967. -#define LONG_LONG_TYPE_SIZE 130,3988
  6968. -#define FLOAT_TYPE_SIZE 134,4068
  6969. -#define DOUBLE_TYPE_SIZE 138,4139
  6970. -#define LONG_DOUBLE_TYPE_SIZE 142,4222
  6971. -#define CONTIN148,4380
  6972. -#define SDB_DELIM    152,4456
  6973. -#define SDB_MAX_DIM 157,4568
  6974. -#define PUT_SDB_SCL(161,4618
  6975. -#define PUT_SDB_INT_VAL(165,4727
  6976. -#define PUT_SDB_VAL(169,4837
  6977. -#define PUT_SDB_DEF(176,5012
  6978. -#define PUT_SDB_PLAIN_DEF(183,5216
  6979. -#define PUT_SDB_ENDEF 187,5326
  6980. -#define PUT_SDB_TYPE(191,5411
  6981. -#define PUT_SDB_SIZE(195,5518
  6982. -#define PUT_SDB_START_DIM 199,5629
  6983. -#define PUT_SDB_NEXT_DIM(203,5722
  6984. -#define PUT_SDB_LAST_DIM(207,5815
  6985. -#define PUT_SDB_TAG(211,5915
  6986. -#define PUT_SDB_BLOCK_START(218,6120
  6987. -#define PUT_SDB_BLOCK_END(225,6346
  6988. -#define PUT_SDB_FUNCTION_START(232,6577
  6989. -#define PUT_SDB_FUNCTION_END(239,6809
  6990. -#define PUT_SDB_EPILOGUE_END(246,7039
  6991. -#define SDB_GENERATE_FAKE(255,7340
  6992. -#define KNOWN_TYPE_TAG(262,7560
  6993. -#define SET_KNOWN_TYPE_TAG(266,7678
  6994. -#define TAG_NAME(272,7900
  6995. -#define MAKE_LINE_SAFE(278,8133
  6996. -sdbout_init 284,8305
  6997. -tag_of_ru_type 311,8937
  6998. -gen_fake_label 327,9357
  6999. -#define PUSH_DERIVED_LEVEL(355,10331
  7000. -plain_type 370,10757
  7001. -template_name_p 401,11505
  7002. -sdbout_record_type_name 412,11676
  7003. -plain_type_1 462,13052
  7004. -sdbout_block 619,17338
  7005. -sdbout_syms 650,18016
  7006. -sdbout_symbol 665,18304
  7007. -sdbout_toplevel_data 910,25784
  7008. -sdbout_queue_anonymous_type 944,26435
  7009. -sdbout_dequeue_anonymous_types 951,26578
  7010. -sdbout_types 976,27072
  7011. -sdbout_type 990,27321
  7012. -sdbout_field_types 1005,27736
  7013. -sdbout_one_type 1024,28394
  7014. -sdbout_parms 1225,34073
  7015. -sdbout_reg_parms 1359,38745
  7016. -sdbout_begin_block 1424,41086
  7017. -sdbout_end_block 1464,42158
  7018. -sdbout_mark_begin_function 1484,42702
  7019. -sdbout_begin_function 1496,43038
  7020. -sdbout_end_function 1509,43370
  7021. -sdbout_end_epilogue 1527,43786
  7022. -sdbout_label 1537,44025
  7023. -
  7024. -stmt.c,3280
  7025. -#define obstack_chunk_alloc 61,2030
  7026. -#define obstack_chunk_free 62,2066
  7027. -struct case_nodecase_node167,6098
  7028. -typedef struct case_node case_node;case_node177,6488
  7029. -typedef struct case_node *case_node_ptr;case_node_ptr178,6524
  7030. -struct nestingnesting211,8079
  7031. -#define ALLOC_NESTING(340,12549
  7032. -#define POPSTACK(348,12863
  7033. -struct goto_fixupgoto_fixup375,13990
  7034. -struct label_chainlabel_chain426,15827
  7035. -init_stmt 484,18208
  7036. -init_stmt_for_function 493,18343
  7037. -save_stmt_status 515,18789
  7038. -restore_stmt_status 535,19365
  7039. -emit_nop 557,19979
  7040. -label_rtx 575,20314
  7041. -emit_jump 590,20592
  7042. -expand_computed_goto 602,20807
  7043. -expand_label 638,21792
  7044. -declare_nonlocal_label 670,22648
  7045. -expand_goto 690,23253
  7046. -expand_goto_internal 775,26276
  7047. -bc_expand_goto_internal 849,28556
  7048. -expand_fixup 933,31126
  7049. -bc_expand_fixup 1053,35286
  7050. -expand_fixups 1082,36026
  7051. -fixup_gotos 1102,36802
  7052. -bc_fixup_gotos 1286,43421
  7053. -expand_asm 1337,44830
  7054. -expand_asm_operands 1370,45864
  7055. -expand_expr_stmt 1650,54050
  7056. -warn_if_unused_value 1735,56644
  7057. -clear_last_expr 1830,59530
  7058. -expand_start_stmt_expr 1840,59754
  7059. -expand_end_stmt_expr 1873,60781
  7060. -expand_start_cond 1951,62976
  7061. -expand_start_elseif 1981,63883
  7062. -expand_start_else 1996,64343
  7063. -expand_elseif 2016,64848
  7064. -expand_end_cond 2027,65104
  7065. -bc_expand_start_cond 2053,65782
  7066. -bc_expand_end_cond 2075,66284
  7067. -bc_expand_start_else 2086,66516
  7068. -expand_start_loop 2110,67231
  7069. -expand_start_loop_continue_elsewhere 2146,68314
  7070. -expand_loop_continue_here 2160,68718
  7071. -bc_expand_end_loop 2175,69053
  7072. -expand_end_loop 2196,69531
  7073. -expand_continue_loop 2321,73829
  7074. -expand_exit_loop 2338,74256
  7075. -expand_exit_loop_if_false 2355,74712
  7076. -preserve_subexpressions_p 2400,75968
  7077. -expand_exit_something 2428,76720
  7078. -expand_null_return 2446,77104
  7079. -expand_value_return 2470,77600
  7080. -expand_null_return_1 2517,79086
  7081. -expand_return 2555,80069
  7082. -drop_through_at_end_p 2837,89974
  7083. -tail_recursion_args 2852,90448
  7084. -expand_start_bindings 2920,92424
  7085. -remember_end_note 2979,94395
  7086. -expand_end_bindings 2996,94927
  7087. -bc_expand_end_bindings 3248,103784
  7088. -expand_decl 3287,105270
  7089. -bc_expand_decl 3480,111591
  7090. -expand_decl_init 3522,112622
  7091. -bc_expand_variable_local_init 3581,114502
  7092. -bc_expand_decl_init 3612,115524
  7093. -expand_decl_cleanup 3667,117248
  7094. -expand_anon_union_decl 3694,117995
  7095. -expand_cleanups 3769,120339
  7096. -move_cleanups_up 3810,121669
  7097. -last_cleanup_this_contour 3822,121921
  7098. -any_pending_cleanups 3835,122236
  7099. -expand_start_case 3873,123290
  7100. -bc_expand_start_case 3918,124611
  7101. -expand_start_case_dummy 3946,125434
  7102. -expand_end_case_dummy 3968,126013
  7103. -case_index_expr_type 3977,126179
  7104. -pushcase 4000,127020
  7105. -pushcase_range 4112,130314
  7106. -bc_pushcase 4231,133983
  7107. -all_cases_count 4286,135657
  7108. -#define BITARRAY_TEST(4356,137352
  7109. -#define BITARRAY_SET(4359,137498
  7110. -mark_seen_cases 4372,137981
  7111. -check_for_full_enumeration_handling 4474,140744
  7112. -bc_check_for_full_enumeration_handling 4611,144770
  7113. -expand_end_case 4651,145981
  7114. -bc_expand_end_case 5042,158092
  7115. -bc_new_uid 5135,160911
  7116. -do_jump_if_equal 5145,161054
  7117. -estimate_case_costs 5189,162224
  7118. -group_case_nodes 5251,163979
  7119. -balance_case_nodes 5298,165414
  7120. -node_has_low_bound 5417,168447
  7121. -node_has_high_bound 5464,169928
  7122. -node_is_bounded 5505,171116
  7123. -emit_jump_if_reachable 5516,171385
  7124. -emit_case_nodes 5550,172894
  7125. -find_loop_tree_blocks 5835,182709
  7126. -unroll_block_trees 5847,183032
  7127. -
  7128. -stor-layout.c,528
  7129. -#define CEIL(29,936
  7130. -#define GET_MODE_ALIGNMENT(53,1583
  7131. -get_pending_sizes 72,2140
  7132. -variable_size 88,2544
  7133. -#define MAX_FIXED_MODE_SIZE 122,3553
  7134. -mode_for_size 131,3856
  7135. -smallest_mode_for_size 154,4474
  7136. -round_up 173,4949
  7137. -layout_decl 196,5765
  7138. -layout_record 288,8854
  7139. -layout_union 546,17602
  7140. -layout_type 648,21056
  7141. -make_signed_type 995,31847
  7142. -make_unsigned_type 1042,33102
  7143. -fixup_signed_type 1067,33683
  7144. -fixup_unsigned_type 1100,34677
  7145. -get_best_mode 1138,35988
  7146. -save_storage_status 1195,37741
  7147. -restore_storage_status 1208,38107
  7148. -
  7149. -stupid.c,175
  7150. -#define INSN_SUID(61,2456
  7151. -#define MARK_LIVE_AFTER(97,3468
  7152. -stupid_life_analysis 114,4220
  7153. -stupid_reg_compare 287,9465
  7154. -stupid_find_reg 323,10584
  7155. -stupid_mark_refs 412,13026
  7156. -
  7157. -toplev.c,2193
  7158. -vms_fopen 73,1990
  7159. -#define fopen 88,2507
  7160. -#define DEFAULT_GDB_EXTENSIONS 92,2580
  7161. -#define DEFAULT_PCC_STRUCT_RETURN 325,9288
  7162. -int 335,9609
  7163. -get_run_time 785,22001
  7164. -#define TIMEVAR(829,22814
  7165. -print_time 833,22936
  7166. -count_error 845,23172
  7167. -pfatal_with_name 872,23682
  7168. -fatal_io_error 881,23814
  7169. -fatal_insn 892,24046
  7170. -fatal_insn_not_found 941,25284
  7171. -decl_name 953,25583
  7172. -interim_eh 963,25752
  7173. -announce_function 983,26318
  7174. -default_print_error_function 1003,26784
  7175. -report_error_function 1037,27719
  7176. -vmessage 1068,28383
  7177. -v_message_with_file_and_line 1091,28844
  7178. -v_message_with_decl 1110,29209
  7179. -file_and_line_for_asm 1172,30485
  7180. -v_error_with_file_and_line 1209,31396
  7181. -error_with_file_and_line VPROTO(1221,31633
  7182. -v_error_with_decl 1247,32159
  7183. -error_with_decl VPROTO(1258,32369
  7184. -v_error_for_asm 1282,32832
  7185. -error_for_asm VPROTO(1297,33108
  7186. -verror 1319,33434
  7187. -error VPROTO(1327,33552
  7188. -vfatal 1347,33811
  7189. -fatal VPROTO(1356,33911
  7190. -v_warning_with_file_and_line 1376,34165
  7191. -warning_with_file_and_line VPROTO(1390,34425
  7192. -v_warning_with_decl 1416,34956
  7193. -warning_with_decl VPROTO(1429,35189
  7194. -v_warning_for_asm 1453,35657
  7195. -warning_for_asm VPROTO(1470,35968
  7196. -vwarning 1492,36299
  7197. -warning VPROTO(1500,36421
  7198. -vpedwarn 1521,36717
  7199. -pedwarn VPROTO(1532,36852
  7200. -v_pedwarn_with_decl 1550,37058
  7201. -pedwarn_with_decl VPROTO(1572,37744
  7202. -v_pedwarn_with_file_and_line 1592,38029
  7203. -pedwarn_with_file_and_line VPROTO(1605,38292
  7204. -vsorry 1629,38707
  7205. -sorry VPROTO(1643,38975
  7206. -v_really_sorry 1663,39241
  7207. -really_sorry VPROTO(1677,39517
  7208. -fancy_abort 1703,40045
  7209. -do_abort 1712,40237
  7210. -botch 1721,40378
  7211. -xmalloc 1729,40478
  7212. -xrealloc 1741,40715
  7213. -exact_log2_wide 1757,41064
  7214. -floor_log2_wide 1775,41448
  7215. -set_float_handler 1792,41782
  7216. -push_float_handler 1805,42190
  7217. -pop_float_handler 1823,42661
  7218. -float_signal 1835,42911
  7219. -pipe_closed 1852,43287
  7220. -strip_off_ending 1863,43520
  7221. -output_quoted_string 1897,44654
  7222. -output_file_directive 1916,44991
  7223. -output_lang_identify 1946,45651
  7224. -open_dump_file 1957,45966
  7225. -compile_file 1976,46426
  7226. -rest_of_decl_compilation 2572,63985
  7227. -rest_of_type_compilation 2638,66267
  7228. -rest_of_compilation 2659,66957
  7229. -main 3302,85703
  7230. -set_target_switch 3967,103114
  7231. -print_single_switch 4007,104028
  7232. -print_switch_values 4024,104351
  7233. -
  7234. -tree.c,4433
  7235. -#define obstack_chunk_alloc 49,1698
  7236. -#define obstack_chunk_free 50,1734
  7237. -struct obstack_stackobstack_stack125,4307
  7238. -struct momentary_levelmomentary_level157,5174
  7239. -#define DEFTREECODE(173,5665
  7240. -#define DEFTREECODE(184,5948
  7241. -#define DEFTREECODE(193,6168
  7242. -} tree_node_kind;tree_node_kind235,7018
  7243. -#define MAX_HASH_TABLE 261,7463
  7244. -#define TYPE_HASH(274,7858
  7245. -init_obstacks 283,8015
  7246. -gcc_obstack_init 310,8985
  7247. -save_tree_status 336,9782
  7248. -restore_tree_status 403,12162
  7249. -temporary_allocation 441,13593
  7250. -end_temporary_allocation 457,14152
  7251. -resume_temporary_allocation 468,14430
  7252. -saveable_allocation 481,14832
  7253. -push_obstacks 493,15257
  7254. -push_obstacks_nochange 515,15832
  7255. -pop_obstacks 532,16227
  7256. -allocation_temporary_p 549,16609
  7257. -permanent_allocation 562,16958
  7258. -preserve_data 596,18049
  7259. -preserve_initializer 603,18169
  7260. -rtl_in_current_obstack 626,18816
  7261. -rtl_in_saveable_obstack 635,19001
  7262. -oballoc 645,19223
  7263. -obfree 656,19481
  7264. -permalloc 666,19647
  7265. -perm_calloc 677,19907
  7266. -savealloc 690,20181
  7267. -print_obstack_name 699,20331
  7268. -debug_obstack 768,22294
  7269. -object_permanent_p 780,22572
  7270. -push_momentary 792,22908
  7271. -preserve_momentary 808,23392
  7272. -clear_momentary 817,23618
  7273. -pop_momentary 828,23922
  7274. -pop_momentary_nofree 843,24424
  7275. -suspend_momentary 855,24769
  7276. -resume_momentary 868,25126
  7277. -init_tree_codes 879,25350
  7278. -make_node 900,26186
  7279. -copy_node 1093,31746
  7280. -copy_list 1176,34157
  7281. -#define HASHBITS 1196,34482
  7282. -get_identifier 1203,34697
  7283. -start_identifier_warnings 1265,36513
  7284. -set_identifier_size 1276,36798
  7285. -build_int_2_wide 1290,37167
  7286. -build_real 1303,37456
  7287. -real_value_from_int_cst 1329,38132
  7288. -build_real_from_int_cst 1370,39476
  7289. -build_string 1414,40396
  7290. -build_complex 1434,41024
  7291. -make_tree_vec 1450,41481
  7292. -integer_zerop 1480,42158
  7293. -integer_onep 1497,42574
  7294. -integer_all_onesp 1514,43041
  7295. -integer_pow2p 1564,44492
  7296. -real_zerop 1592,45048
  7297. -real_onep 1607,45416
  7298. -real_twop 1622,45758
  7299. -really_constant_p 1637,46112
  7300. -value_member 1652,46502
  7301. -purpose_member 1668,46788
  7302. -binfo_member 1684,47076
  7303. -chain_member 1699,47321
  7304. -chain_member_value 1719,47751
  7305. -chain_member_purpose 1739,48202
  7306. -list_length 1757,48567
  7307. -chainon 1774,48898
  7308. -tree_last 1797,49346
  7309. -nreverse 1811,49623
  7310. -listify 1828,49933
  7311. -build_tree_list 1853,50406
  7312. -build_decl_list 1865,50630
  7313. -tree_cons 1881,51042
  7314. -decl_tree_cons 1911,51794
  7315. -perm_tree_cons 1925,52153
  7316. -temp_tree_cons 1940,52527
  7317. -saveable_tree_cons 1955,52910
  7318. -size_in_bytes 1974,53498
  7319. -int_size_in_bytes 1998,54024
  7320. -array_type_nelts 2023,54722
  7321. -staticp 2039,55182
  7322. -save_expr 2096,57060
  7323. -contains_placeholder_p 2144,58865
  7324. -substitute_in_expr 2195,60305
  7325. -substitute_in_type 2313,63181
  7326. -stabilize_reference 2457,67465
  7327. -stabilize_reference_1 2551,70324
  7328. -build VPROTO(2628,72738
  7329. -build1 2698,74398
  7330. -build_nt VPROTO(2752,75530
  7331. -build_parse_node VPROTO(2782,76046
  7332. -build_op_identifier 2816,76724
  7333. -build_decl 2833,77150
  7334. -build_block 2863,77973
  7335. -build_decl_attribute_variant 2879,78427
  7336. -build_type_attribute_variant 2892,78730
  7337. -valid_machine_attribute 2949,80388
  7338. -is_attribute_p 3048,83237
  7339. -lookup_attribute 3093,84257
  7340. -build_type_variant 3124,85115
  7341. -change_main_variant 3157,86021
  7342. -build_type_copy 3184,86775
  7343. -struct type_hashtype_hash3210,87424
  7344. -#define TYPE_HASH_SIZE 3224,88015
  7345. -type_hash_list 3232,88264
  7346. -type_hash_lookup 3246,88610
  7347. -type_hash_add 3279,89757
  7348. -type_hash_canon 3307,90694
  7349. -attribute_hash_list 3339,91456
  7350. -attribute_list_equal 3354,91826
  7351. -attribute_list_contained 3370,92393
  7352. -type_list_equal 3410,93352
  7353. -tree_int_cst_equal 3430,93871
  7354. -tree_int_cst_lt 3449,94353
  7355. -tree_int_cst_sgn 3465,94743
  7356. -simple_cst_list_equal 3482,95118
  7357. -simple_cst_equal 3504,95632
  7358. -build_pointer_type 3630,99366
  7359. -build_index_type 3663,100296
  7360. -build_range_type 3696,101410
  7361. -build_index_2_type 3725,102348
  7362. -index_type_equal 3737,102709
  7363. -build_array_type 3764,103548
  7364. -build_function_type 3815,105007
  7365. -build_reference_type 3844,105726
  7366. -build_method_type 3882,106773
  7367. -build_offset_type 3919,107757
  7368. -build_complex_type 3944,108317
  7369. -get_unwidened 3991,110065
  7370. -get_narrower 4081,113204
  7371. -type_precision 4167,115841
  7372. -int_fits_type_p 4180,116170
  7373. -decl_function_context 4199,116819
  7374. -decl_type_context 4234,117675
  7375. -print_obstack_statistics 4258,118221
  7376. -dump_tree_statistics 4276,118601
  7377. -#define FILE_FUNCTION_PREFIX_LEN 4303,119530
  7378. -#define FILE_FUNCTION_FORMAT 4306,119593
  7379. -#define FILE_FUNCTION_FORMAT 4309,119693
  7380. -#define FILE_FUNCTION_FORMAT 4311,119766
  7381. -get_file_function_name 4321,120067
  7382. -get_set_constructor_bits 4376,121710
  7383. -get_set_constructor_bytes 4432,123386
  7384. -
  7385. -unprotoize.c,0
  7386. -
  7387. -unroll.c,773
  7388. -#define NUM_FACTORS 140,6708
  7389. -struct _factor _factor142,6731
  7390. -enum unroll_types unroll_types147,6903
  7391. -#define MAX_UNROLLED_INSNS 163,7262
  7392. -unroll_loop 225,9938
  7393. -precondition_loop_p 1188,43675
  7394. -init_reg_map 1320,47916
  7395. -calculate_giv_inc 1346,48776
  7396. -initial_reg_note_copy 1447,51859
  7397. -final_reg_note_copy 1475,52464
  7398. -copy_loop_body 1490,52871
  7399. -emit_unrolled_add 2014,69764
  7400. -back_branch_in_range_p 2035,70458
  7401. -fold_rtx_mult_add 2078,71665
  7402. -biv_total_increment 2127,73076
  7403. -iteration_info 2162,74238
  7404. -approx_final_value 2258,77822
  7405. -find_splittable_regs 2331,80381
  7406. -verify_addresses 2489,86081
  7407. -find_splittable_givs 2517,86916
  7408. -reg_dead_after_loop 2910,100820
  7409. -final_biv_value 2970,102364
  7410. -final_giv_value 3045,104767
  7411. -loop_iterations 3164,108670
  7412. -remap_split_bivs 3407,116804
  7413. -
  7414. -varasm.c,3014
  7415. -#define ASM_STABS_OP 55,1613
  7416. -#define STRIP_NAME_ENCODING(62,1831
  7417. -#define obstack_chunk_alloc 77,2287
  7418. -struct weak_symsweak_syms105,2951
  7419. -static enum in_section in_section150,4546
  7420. -static enum in_section in_section153,4659
  7421. -#define IN_NAMED_SECTION(158,4822
  7422. -text_section 173,5244
  7423. -data_section 189,5495
  7424. -readonly_data_section 217,6016
  7425. -in_text_section 229,6227
  7426. -named_section 239,6440
  7427. -function_section 272,7347
  7428. -make_function_rtl 287,7705
  7429. -bc_make_decl_rtl 341,9286
  7430. -strip_reg_name 379,10444
  7431. -decode_reg_name 400,11082
  7432. -make_decl_rtl 460,12479
  7433. -make_var_volatile 627,18402
  7434. -assemble_constant_align 639,18619
  7435. -assemble_asm 658,19073
  7436. -#define ASM_OUTPUT_CONSTRUCTOR(681,19689
  7437. -#define ASM_OUTPUT_DESTRUCTOR(684,19769
  7438. -assemble_destructor 697,20109
  7439. -assemble_constructor 717,20631
  7440. -assemble_gc_entry 738,21236
  7441. -assemble_start_function 760,21890
  7442. -assemble_end_function 840,23925
  7443. -assemble_zeros 852,24158
  7444. -assemble_align 905,25264
  7445. -assemble_string 915,25491
  7446. -bc_output_ascii 950,26047
  7447. -assemble_variable 969,26710
  7448. -contains_pointers_p 1402,40112
  7449. -bc_output_constructor 1439,40980
  7450. -bc_output_data_constructor 1468,41489
  7451. -assemble_external 1490,42049
  7452. -assemble_external_libcall 1516,42648
  7453. -assemble_global 1535,43021
  7454. -assemble_label 1544,43152
  7455. -assemble_name 1560,43640
  7456. -assemble_static_space 1595,44426
  7457. -assemble_trampoline_template 1644,45681
  7458. -assemble_integer 1684,46734
  7459. -assemble_real 1775,48583
  7460. -immed_double_const 1857,50620
  7461. -immed_real_const_1 1965,54524
  7462. -immed_real_const 2041,57195
  7463. -clear_const_double_mem 2052,57541
  7464. -struct addr_constaddr_const2075,58132
  7465. -decode_addr_const 2082,58204
  7466. -struct constant_descriptorconstant_descriptor2161,60156
  7467. -#define HASHBITS 2168,60260
  7468. -#define MAX_HASH_TABLE 2169,60280
  7469. -const_hash 2175,60444
  7470. -compare_constant 2266,63268
  7471. -compare_constant_1 2283,63863
  7472. -record_constant 2421,67519
  7473. -record_constant_1 2442,68216
  7474. -struct deferred_constantdeferred_constant2565,71498
  7475. -defer_addressed_constants 2582,71872
  7476. -output_deferred_addressed_constants 2591,72047
  7477. -copy_constant 2615,72579
  7478. -output_constant_def 2682,74503
  7479. -output_constant_def_contents 2790,77627
  7480. -#define MAX_RTX_HASH_TABLE 2853,79337
  7481. -struct pool_constantpool_constant2861,79695
  7482. -struct pool_sympool_sym2884,80198
  7483. -#define SYMHASH(2896,80446
  7484. -init_const_rtx_hash_table 2902,80616
  7485. -save_varasm_status 2922,81221
  7486. -restore_varasm_status 2933,81477
  7487. -enum kind kind2943,81732
  7488. -struct rtx_constrtx_const2945,81768
  7489. -decode_rtx_const 2965,82175
  7490. -simplify_subtraction 3042,83906
  7491. -const_hash_rtx 3058,84283
  7492. -compare_constant_rtx 3081,84790
  7493. -record_constant_rtx 3107,85408
  7494. -force_const_mem 3133,86230
  7495. -find_pool_constant 3277,90898
  7496. -get_pool_constant 3293,91226
  7497. -get_pool_mode 3302,91371
  7498. -get_pool_offset 3311,91517
  7499. -get_pool_size 3320,91656
  7500. -output_constant_pool 3328,91760
  7501. -output_addressed_constants 3408,93987
  7502. -output_constant 3479,96128
  7503. -bc_assemble_integer 3599,99260
  7504. -output_constructor 3699,101893
  7505. -handle_pragma_weak 3963,109846
  7506. -declare_weak 3995,110582
  7507. -weak_finish 4009,110939
  7508. -assemble_alias 4026,111228
  7509. -
  7510. -version.c,0
  7511. -
  7512. -xcoffout.c,690
  7513. -#define N_CATCH 49,1512
  7514. -#define ABS_OR_RELATIVE_LINENO(82,2365
  7515. -#define ASM_OUTPUT_SOURCE_LINE(86,2556
  7516. -#define ASM_OUTPUT_LFB(92,2750
  7517. -#define ASM_OUTPUT_LFE(104,3102
  7518. -#define ASM_OUTPUT_LBB(110,3257
  7519. -#define ASM_OUTPUT_LBE(113,3372
  7520. -assign_type_number 122,3690
  7521. -xcoff_output_standard_types 142,4132
  7522. -#define UNKNOWN_STAB(173,5408
  7523. -stab_to_sclass 182,5627
  7524. -xcoffout_output_first_source_line 323,7902
  7525. -xcoffout_source_file 336,8279
  7526. -xcoffout_source_line 369,9143
  7527. -xcoffout_block 390,9665
  7528. -xcoffout_begin_block 434,10968
  7529. -xcoffout_end_block 455,11446
  7530. -xcoffout_declare_function 468,11689
  7531. -xcoffout_begin_function 501,12561
  7532. -xcoffout_end_function 512,12784
  7533. -xcoffout_end_epilogue 523,13018
  7534. diff -rup --new-file baseline/fsf/gcc/ada/lang-options.h amiga/fsf/gcc/ada/lang-options.h
  7535. --- baseline/fsf/gcc/ada/lang-options.h    Wed Dec 31 17:00:00 1969
  7536. +++ amiga/fsf/gcc/ada/lang-options.h    Sat Sep 28 00:00:00 1996
  7537. @@ -0,0 +1,27 @@
  7538. +/* Definitions for switches for Gnu ADA.
  7539. +   Copyright (C) 1995 Free Software Foundation, Inc.
  7540. +   Contributed by Fred Fish (fnf@amigalib.com)
  7541. +
  7542. +This file is part of GNU ADA.
  7543. +
  7544. +GNU ADA is free software; you can redistribute it and/or modify
  7545. +it under the terms of the GNU General Public License as published by
  7546. +the Free Software Foundation; either version 2, or (at your option)
  7547. +any later version.
  7548. +
  7549. +GNU ADA is distributed in the hope that it will be useful,
  7550. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  7551. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  7552. +GNU General Public License for more details.
  7553. +
  7554. +You should have received a copy of the GNU General Public License
  7555. +along with GNU ADA; see the file COPYING.  If not, write to
  7556. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  7557. +
  7558. +*/
  7559. +
  7560. +/* This is the contribution to the `lang_options' array in gcc.c for
  7561. +   GNAT and is temporary.  */
  7562. +
  7563. +  "-gnat",
  7564. +  "-I",
  7565. diff -rup --new-file baseline/fsf/gcc/ada/lang-specs.h amiga/fsf/gcc/ada/lang-specs.h
  7566. --- baseline/fsf/gcc/ada/lang-specs.h    Wed Dec 31 17:00:00 1969
  7567. +++ amiga/fsf/gcc/ada/lang-specs.h    Sat Sep 28 00:00:00 1996
  7568. @@ -0,0 +1,57 @@
  7569. +/* Definitions for specs for Gnu ADA
  7570. +   Copyright (C) 1995 Free Software Foundation, Inc.
  7571. +   Contributed by Fred Fish (fnf@amigalib.com)
  7572. +
  7573. +This file is part of GNU ADA.
  7574. +
  7575. +GNU ADA is free software; you can redistribute it and/or modify
  7576. +it under the terms of the GNU General Public License as published by
  7577. +the Free Software Foundation; either version 2, or (at your option)
  7578. +any later version.
  7579. +
  7580. +GNU ADA is distributed in the hope that it will be useful,
  7581. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  7582. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  7583. +GNU General Public License for more details.
  7584. +
  7585. +You should have received a copy of the GNU General Public License
  7586. +along with GNU ADA; see the file COPYING.  If not, write to
  7587. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  7588. +
  7589. +*/
  7590. +
  7591. +/* Definitions for specs for C++.
  7592. +   Copyright (C) 1995 Free Software Foundation, Inc.
  7593. +
  7594. +This file is part of GNU CC.
  7595. +
  7596. +GNU CC is free software; you can redistribute it and/or modify
  7597. +it under the terms of the GNU General Public License as published by
  7598. +the Free Software Foundation; either version 2, or (at your option)
  7599. +any later version.
  7600. +
  7601. +GNU CC is distributed in the hope that it will be useful,
  7602. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  7603. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  7604. +GNU General Public License for more details.
  7605. +
  7606. +You should have received a copy of the GNU General Public License
  7607. +along with GNU CC; see the file COPYING.  If not, write to
  7608. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  7609. +
  7610. +/* This is the contribution to the `default_compilers' array in gcc.c for
  7611. +   ADA.  */
  7612. +
  7613. +  {".ads", "@ada"},
  7614. +  {".adb", "@ada"},
  7615. +  {".ada", "@ada"},
  7616. +  {"@ada",
  7617. +   "%{!M:%{!MM:%{!E:gnat1 %{I*} %{k8:-gnatk8} %{w:-gnatws} %{!Q:-quiet}\
  7618. +               -dumpbase %{.adb:%b.adb}%{.ads:%b.ads}\
  7619. +                          %{g*} %{O*} %{W*} %{w} %{p} %{pg:-p} %{f*}\
  7620. +              %{d*}\
  7621. +              %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
  7622. +              %i %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
  7623. +            %{!S:%{!gnatc:%{!gnats:as %{R} %{j} %{J} %{h} %{d2} %a %Y\
  7624. +                          %{c:%W{o*}%{!o*:-o %w%b.o}}\
  7625. +                          %{!c:-o %d%w%u.o} %{!pipe:%g.s} %A\n}}}}}} "},
  7626. diff -rup --new-file baseline/fsf/gcc/amigacpp.c amiga/fsf/gcc/amigacpp.c
  7627. --- baseline/fsf/gcc/amigacpp.c    Wed Dec 31 17:00:00 1969
  7628. +++ amiga/fsf/gcc/amigacpp.c    Sat Sep 28 00:00:00 1996
  7629. @@ -0,0 +1,189 @@
  7630. +/* Supplimentary functions that get compiled and linked to cpp on an
  7631. +   Amiga host.
  7632. +   Copyright (C) 1996 Free Software Foundation, Inc.
  7633. +
  7634. +This file is part of GNU CC.
  7635. +
  7636. +GNU CC is free software; you can redistribute it and/or modify
  7637. +it under the terms of the GNU General Public License as published by
  7638. +the Free Software Foundation; either version 2, or (at your option)
  7639. +any later version.
  7640. +
  7641. +GNU CC is distributed in the hope that it will be useful,
  7642. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  7643. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  7644. +GNU General Public License for more details.
  7645. +
  7646. +You should have received a copy of the GNU General Public License
  7647. +along with GNU CC; see the file COPYING.  If not, write to
  7648. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
  7649. +
  7650. +#include <stdio.h>
  7651. +#include <sys/types.h>
  7652. +#include <sys/stat.h>
  7653. +#include <fcntl.h>
  7654. +#include <errno.h>
  7655. +
  7656. +#if HAVE_STDLIB_H
  7657. +# include <stdlib.h>
  7658. +#else
  7659. +char *getenv ();
  7660. +#endif
  7661. +
  7662. +#if STDC_HEADERS
  7663. +# include <string.h>
  7664. +#else
  7665. +char *strrchr();
  7666. +#endif
  7667. +
  7668. +#include <proto/exec.h>
  7669. +#include <proto/dos.h>
  7670. +
  7671. +static int amiga_priority = -1;     /* Flag indicating process priority */
  7672. +struct Task *amiga_task;
  7673. +BPTR __amiga_filehandle (int fd); /* Semi-private function of IXEmul. */
  7674. +
  7675. +/* Improved version of open() that also checks if casing of FILENAME is
  7676. +   correct. */
  7677. +
  7678. +#ifndef O_CASE    /* Use this until ixemul.library implements O_CASE */
  7679. +
  7680. +int
  7681. +amiga_open_case_sensitive (filename, flags, mode)
  7682. +     char *filename;
  7683. +     int flags;
  7684. +     mode_t mode;
  7685. +{
  7686. +  int fd;
  7687. +  BPTR fh;
  7688. +  char fibbuf[sizeof (struct FileInfoBlock) + 3], *basename;
  7689. +  struct FileInfoBlock *fib;
  7690. +
  7691. +  fd = open (filename, flags, mode);
  7692. +  if (fd != -1)
  7693. +    {
  7694. +      /* Ensure that casing of the filename is correct. */
  7695. +
  7696. +      fh = __amiga_filehandle (fd);
  7697. +      /* Align fib to longword. */
  7698. +      fib = (struct FileInfoBlock*) ((ULONG) (fibbuf + 3) & 0xFFFFFFFC);
  7699. +      if (!(basename=strrchr(filename, '/')))
  7700. +    basename=filename;
  7701. +      else
  7702. +    basename++; /* Skip '/'. */
  7703. +
  7704. +      /* The last condition below is to prevent incorrect handling of links. */
  7705. +      if (fh && ExamineFH (fh, fib) && strcmp (fib -> fib_FileName, basename)
  7706. +          && strcasecmp (fib -> fib_FileName, basename) == 0)
  7707. +    {
  7708. +      close (fd);
  7709. +      errno = ENOENT;
  7710. +      fd = -1;
  7711. +    }
  7712. +    }
  7713. +  return (fd);
  7714. +}
  7715. +
  7716. +#endif    /* #ifndef O_CASE */
  7717. +
  7718. +/* This function returns whether the LEN characters long filename FNAME 
  7719. +   is an absolute path specification. */
  7720. +
  7721. +int
  7722. +amiga_abs_filename (fname, len)
  7723. +     char *fname;
  7724. +     int len;
  7725. +{
  7726. +  /* we're using ixemul.library, which treats `/foo' as `foo:', so 
  7727. +     fname[0] is to be considered absolute as well */
  7728. +
  7729. +  if (fname[0] == '/')
  7730. +    {
  7731. +      return (1);
  7732. +    }
  7733. +
  7734. +  /* else do an index() on fname, but one which is limited to len characters */
  7735. +
  7736. +  while (*fname && *fname != ':' && len) 
  7737. +    {
  7738. +      fname++;
  7739. +      len--;
  7740. +    }
  7741. +
  7742. +  return (*fname == ':');
  7743. +}
  7744. +
  7745. +void
  7746. +amiga_get_default_priority ()
  7747. +{
  7748. +  char *envstr;
  7749. +  int i;
  7750. +
  7751. +  if (envstr = getenv ("GCCPRIORITY"))
  7752. +    {
  7753. +      if (((i = atoi (envstr)) > -20) && (i < 20))
  7754. +    {
  7755. +      amiga_priority = i;
  7756. +    }
  7757. +    }
  7758. +}
  7759. +
  7760. +/* Set the priority to whatever is currently in the amiga_priority variable. */
  7761. +
  7762. +void
  7763. +amiga_set_priority ()
  7764. +{
  7765. +  Forbid ();
  7766. +  amiga_task = FindTask (NULL);
  7767. +  Permit ();
  7768. +  SetTaskPri (amiga_task, amiga_priority);
  7769. +}
  7770. +
  7771. +/* Parse the --priority option and stash the value away for future use. */
  7772. +
  7773. +int
  7774. +amiga_parse_priority (argc, argv, ip)
  7775. +     int argc;
  7776. +     char **argv;
  7777. +     int *ip;
  7778. +{
  7779. +  if (strcmp (argv[*ip], "-priority") != 0)
  7780. +    {
  7781. +      return (0);
  7782. +    }
  7783. +  else
  7784. +    {
  7785. +      if (*ip + 1 == argc)
  7786. +    {
  7787. +      fatal ("Priority missing after -P option");
  7788. +    }
  7789. +      (*ip)++;
  7790. +      if ((amiga_priority = atoi (argv[*ip])) < -25)
  7791. +    {
  7792. +      amiga_priority = -25;
  7793. +    }
  7794. +      else if (amiga_priority > 25)
  7795. +    {
  7796. +      amiga_priority = 25;
  7797. +    }
  7798. +      return (1);
  7799. +    }
  7800. +}
  7801. +
  7802. +/* This function is called with the name of each symbol found in a
  7803. +   #if, #ifdef, #ifndef, or #if defined directive.  Presently it just
  7804. +   warns users not to test for obsolete "amigados" or "__amigados__" */
  7805. +
  7806. +void
  7807. +amiga_cpp_symname_hook (char *symname, int symlength)
  7808. +{
  7809. +  if (symlength == 8 && strncmp(symname, "amigados", symlength) == 0 ||
  7810. +      symlength == 12 && strncmp(symname, "__amigados__", symlength) == 0)
  7811. +    {
  7812. +      char save = *(symname + symlength);
  7813. +      *(symname + symlength) = '\000';
  7814. +      warning ("change test for '%s' to use '__amigaos__' instead", symname);
  7815. +      warning ("this symbol will not be predefined in a future release");
  7816. +      *(symname + symlength) = save;
  7817. +    }  
  7818. +}
  7819. diff -rup --new-file baseline/fsf/gcc/c-decl.c amiga/fsf/gcc/c-decl.c
  7820. --- baseline/fsf/gcc/c-decl.c    Fri Oct 27 02:44:43 1995
  7821. +++ amiga/fsf/gcc/c-decl.c    Sat Sep 28 00:00:00 1996
  7822. @@ -3883,8 +3883,10 @@ maybe_build_cleanup (decl)
  7823.     record the given order of parms in `parm_order'.  */
  7824.  
  7825.  void
  7826. -push_parm_decl (parm)
  7827. -     tree parm;
  7828. +/* Amiga-specific support for explicit register specification for parameters.
  7829. +   KI 1.04.1996 */
  7830. +push_parm_decl (parm, asmspec)
  7831. +     tree parm, asmspec;
  7832.  {
  7833.    tree decl;
  7834.    int old_immediate_size_expand = immediate_size_expand;
  7835. @@ -3908,6 +3910,75 @@ push_parm_decl (parm)
  7836.      pedwarn_with_decl (decl, "ANSI C forbids parameter `%s' shadowing typedef");
  7837.      }
  7838.  #endif
  7839. +
  7840. +  /* Amiga-specific support for explicit register specification for
  7841. +     parameters. KI 7.04.1996 */
  7842. +  if (asmspec)
  7843. +#ifdef TARGET_AMIGAOS
  7844. +    {
  7845. +      char *regname=TREE_STRING_POINTER(asmspec);
  7846. +      int regnum;
  7847. +      if ((regnum=decode_reg_name(regname))>=0)
  7848. +    {
  7849. +      tree type=TREE_TYPE(decl);
  7850. +      if (HARD_REGNO_MODE_OK(regnum, TYPE_MODE(type)))
  7851. +        {
  7852. +          tree t;
  7853. +          /* Build tree for __attribute__ ((asm(regnum))). */
  7854. +#if 0
  7855. +          /* This doesn't work well because of a bug in
  7856. +         attribute_list_contained(), which passes list of arguments to
  7857. +         simple_cst_equal() instead of passing every argument
  7858. +         separately. */
  7859. +          tree attrs=tree_cons(get_identifier("asm"), tree_cons(NULL_TREE,
  7860. +             build_int_2_wide(regnum, 0), NULL_TREE), NULL_TREE);
  7861. +#else
  7862. +          tree attrs=tree_cons(get_identifier("asm"),
  7863. +             build_int_2_wide(regnum, 0), NULL_TREE);
  7864. +#endif
  7865. +#if 0
  7866. +          /* build_type_attribute_variant() would seem to be more
  7867. +         appropriate here. However, that function does not support
  7868. +         attributes for parameters properly. It modifies
  7869. +         TYPE_MAIN_VARIANT of a new type. As a result, comptypes()
  7870. +         thinks that types of parameters in prototype and definition
  7871. +         are different and issues error messages. See also comment
  7872. +         below. */
  7873. +          type=build_type_attribute_variant(type, attrs);
  7874. +#else
  7875. +          /* First check whether such a type already exists - if yes, use
  7876. +         that one. This is very important, since otherwise
  7877. +         common_type() would think that it sees two different
  7878. +         types and would try to merge them - this could result in
  7879. +         warning messages. */
  7880. +          for (t=TYPE_MAIN_VARIANT(type); t; t=TYPE_NEXT_VARIANT(t))
  7881. +        if (comptypes(t, type)==1
  7882. +            && attribute_list_equal(TYPE_ATTRIBUTES(t), attrs))
  7883. +              break;
  7884. +          if (t)
  7885. +        type=t;
  7886. +          else
  7887. +        {
  7888. +          /* Create a new variant, with differing attributes.
  7889. +             (Hack! Type with differing attributes should no longer be
  7890. +             a variant of its main type. See comment above for
  7891. +             explanation why this was necessary). */
  7892. +          type=build_type_copy(type);
  7893. +          TYPE_ATTRIBUTES(type)=attrs;
  7894. +        }
  7895. +#endif
  7896. +          TREE_TYPE(decl)=type;
  7897. +        }
  7898. +      else
  7899. +        error_with_decl(decl,
  7900. +        "register number for `%s' isn't suitable for the data type");
  7901. +    }
  7902. +      else
  7903. +    error("invalid register name `%s'", regname);
  7904. +    }
  7905. +#else /* !TARGET_AMIGAOS */
  7906. +    error("explicit register specification for parameters is not supported for this target");
  7907. +#endif /* !TARGET_AMIGAOS */
  7908.  
  7909.    decl = pushdecl (decl);
  7910.  
  7911. diff -rup --new-file baseline/fsf/gcc/c-gperf.h amiga/fsf/gcc/c-gperf.h
  7912. --- baseline/fsf/gcc/c-gperf.h    Fri Mar  4 12:15:53 1994
  7913. +++ amiga/fsf/gcc/c-gperf.h    Wed Dec 31 17:00:00 1969
  7914. @@ -1,184 +0,0 @@
  7915. -/* C code produced by gperf version 2.5 (GNU C++ version) */
  7916. -/* Command-line: gperf -p -j1 -i 1 -g -o -t -G -N is_reserved_word -k1,3,$ c-parse.gperf  */
  7917. -struct resword { char *name; short token; enum rid rid; };
  7918. -
  7919. -#define TOTAL_KEYWORDS 79
  7920. -#define MIN_WORD_LENGTH 2
  7921. -#define MAX_WORD_LENGTH 20
  7922. -#define MIN_HASH_VALUE 10
  7923. -#define MAX_HASH_VALUE 144
  7924. -/* maximum key range = 135, duplicates = 0 */
  7925. -
  7926. -#ifdef __GNUC__
  7927. -__inline
  7928. -#endif
  7929. -static unsigned int
  7930. -hash (str, len)
  7931. -     register char *str;
  7932. -     register int unsigned len;
  7933. -{
  7934. -  static unsigned char asso_values[] =
  7935. -    {
  7936. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7937. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7938. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7939. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7940. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7941. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7942. -     145, 145, 145, 145,  25, 145, 145, 145, 145, 145,
  7943. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7944. -     145, 145, 145, 145, 145, 145, 145, 145, 145, 145,
  7945. -     145, 145, 145, 145, 145,   1, 145,  46,   8,  15,
  7946. -      61,   6,  36,  48,   3,   5, 145,  18,  63,  25,
  7947. -      29,  76,   1, 145,  13,   2,   1,  51,  37,   9,
  7948. -       9,   1,   3, 145, 145, 145, 145, 145,
  7949. -    };
  7950. -  register int hval = len;
  7951. -
  7952. -  switch (hval)
  7953. -    {
  7954. -      default:
  7955. -      case 3:
  7956. -        hval += asso_values[str[2]];
  7957. -      case 2:
  7958. -      case 1:
  7959. -        hval += asso_values[str[0]];
  7960. -    }
  7961. -  return hval + asso_values[str[len - 1]];
  7962. -}
  7963. -
  7964. -static struct resword wordlist[] =
  7965. -{
  7966. -  {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  7967. -  {"",}, 
  7968. -  {"int",  TYPESPEC, RID_INT},
  7969. -  {"",}, {"",}, 
  7970. -  {"__typeof__",  TYPEOF, NORID},
  7971. -  {"__signed__",  TYPESPEC, RID_SIGNED},
  7972. -  {"__imag__",  IMAGPART, NORID},
  7973. -  {"switch",  SWITCH, NORID},
  7974. -  {"__inline__",  SCSPEC, RID_INLINE},
  7975. -  {"else",  ELSE, NORID},
  7976. -  {"__iterator__",  SCSPEC, RID_ITERATOR},
  7977. -  {"__inline",  SCSPEC, RID_INLINE},
  7978. -  {"__extension__",  EXTENSION, NORID},
  7979. -  {"struct",  STRUCT, NORID},
  7980. -  {"__real__",  REALPART, NORID},
  7981. -  {"__const",  TYPE_QUAL, RID_CONST},
  7982. -  {"while",  WHILE, NORID},
  7983. -  {"__const__",  TYPE_QUAL, RID_CONST},
  7984. -  {"case",  CASE, NORID},
  7985. -  {"__complex__",  TYPESPEC, RID_COMPLEX},
  7986. -  {"__iterator",  SCSPEC, RID_ITERATOR},
  7987. -  {"bycopy",  TYPE_QUAL, RID_BYCOPY},
  7988. -  {"",}, {"",}, {"",}, 
  7989. -  {"__complex",  TYPESPEC, RID_COMPLEX},
  7990. -  {"",}, 
  7991. -  {"in",  TYPE_QUAL, RID_IN},
  7992. -  {"break",  BREAK, NORID},
  7993. -  {"@defs",  DEFS, NORID},
  7994. -  {"",}, {"",}, {"",}, 
  7995. -  {"extern",  SCSPEC, RID_EXTERN},
  7996. -  {"if",  IF, NORID},
  7997. -  {"typeof",  TYPEOF, NORID},
  7998. -  {"typedef",  SCSPEC, RID_TYPEDEF},
  7999. -  {"__typeof",  TYPEOF, NORID},
  8000. -  {"sizeof",  SIZEOF, NORID},
  8001. -  {"",}, 
  8002. -  {"return",  RETURN, NORID},
  8003. -  {"const",  TYPE_QUAL, RID_CONST},
  8004. -  {"__volatile__",  TYPE_QUAL, RID_VOLATILE},
  8005. -  {"@private",  PRIVATE, NORID},
  8006. -  {"@selector",  SELECTOR, NORID},
  8007. -  {"__volatile",  TYPE_QUAL, RID_VOLATILE},
  8008. -  {"__asm__",  ASM_KEYWORD, NORID},
  8009. -  {"",}, {"",}, 
  8010. -  {"continue",  CONTINUE, NORID},
  8011. -  {"__alignof__",  ALIGNOF, NORID},
  8012. -  {"__imag",  IMAGPART, NORID},
  8013. -  {"__attribute__",  ATTRIBUTE, NORID},
  8014. -  {"",}, {"",}, 
  8015. -  {"__attribute",  ATTRIBUTE, NORID},
  8016. -  {"for",  FOR, NORID},
  8017. -  {"",}, 
  8018. -  {"@encode",  ENCODE, NORID},
  8019. -  {"id",  OBJECTNAME, RID_ID},
  8020. -  {"static",  SCSPEC, RID_STATIC},
  8021. -  {"@interface",  INTERFACE, NORID},
  8022. -  {"",}, 
  8023. -  {"__signed",  TYPESPEC, RID_SIGNED},
  8024. -  {"",}, 
  8025. -  {"__label__",  LABEL, NORID},
  8026. -  {"",}, {"",}, 
  8027. -  {"__asm",  ASM_KEYWORD, NORID},
  8028. -  {"char",  TYPESPEC, RID_CHAR},
  8029. -  {"",}, 
  8030. -  {"inline",  SCSPEC, RID_INLINE},
  8031. -  {"out",  TYPE_QUAL, RID_OUT},
  8032. -  {"register",  SCSPEC, RID_REGISTER},
  8033. -  {"__real",  REALPART, NORID},
  8034. -  {"short",  TYPESPEC, RID_SHORT},
  8035. -  {"",}, 
  8036. -  {"enum",  ENUM, NORID},
  8037. -  {"inout",  TYPE_QUAL, RID_INOUT},
  8038. -  {"",}, 
  8039. -  {"oneway",  TYPE_QUAL, RID_ONEWAY},
  8040. -  {"union",  UNION, NORID},
  8041. -  {"",}, 
  8042. -  {"__alignof",  ALIGNOF, NORID},
  8043. -  {"",}, 
  8044. -  {"@implementation",  IMPLEMENTATION, NORID},
  8045. -  {"",}, 
  8046. -  {"@class",  CLASS, NORID},
  8047. -  {"",}, 
  8048. -  {"@public",  PUBLIC, NORID},
  8049. -  {"asm",  ASM_KEYWORD, NORID},
  8050. -  {"",}, {"",}, {"",}, {"",}, {"",}, 
  8051. -  {"default",  DEFAULT, NORID},
  8052. -  {"",}, 
  8053. -  {"void",  TYPESPEC, RID_VOID},
  8054. -  {"",}, 
  8055. -  {"@protected",  PROTECTED, NORID},
  8056. -  {"@protocol",  PROTOCOL, NORID},
  8057. -  {"",}, {"",}, {"",}, 
  8058. -  {"volatile",  TYPE_QUAL, RID_VOLATILE},
  8059. -  {"",}, {"",}, 
  8060. -  {"signed",  TYPESPEC, RID_SIGNED},
  8061. -  {"float",  TYPESPEC, RID_FLOAT},
  8062. -  {"@end",  END, NORID},
  8063. -  {"",}, {"",}, 
  8064. -  {"unsigned",  TYPESPEC, RID_UNSIGNED},
  8065. -  {"@compatibility_alias",  ALIAS, NORID},
  8066. -  {"double",  TYPESPEC, RID_DOUBLE},
  8067. -  {"",}, {"",}, 
  8068. -  {"auto",  SCSPEC, RID_AUTO},
  8069. -  {"",}, 
  8070. -  {"goto",  GOTO, NORID},
  8071. -  {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  8072. -  {"do",  DO, NORID},
  8073. -  {"",}, {"",}, {"",}, {"",}, 
  8074. -  {"long",  TYPESPEC, RID_LONG},
  8075. -};
  8076. -
  8077. -#ifdef __GNUC__
  8078. -__inline
  8079. -#endif
  8080. -struct resword *
  8081. -is_reserved_word (str, len)
  8082. -     register char *str;
  8083. -     register unsigned int len;
  8084. -{
  8085. -  if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
  8086. -    {
  8087. -      register int key = hash (str, len);
  8088. -
  8089. -      if (key <= MAX_HASH_VALUE && key >= 0)
  8090. -        {
  8091. -          register char *s = wordlist[key].name;
  8092. -
  8093. -          if (*s == *str && !strcmp (str + 1, s + 1))
  8094. -            return &wordlist[key];
  8095. -        }
  8096. -    }
  8097. -  return 0;
  8098. -}
  8099. diff -rup --new-file baseline/fsf/gcc/c-parse.c amiga/fsf/gcc/c-parse.c
  8100. --- baseline/fsf/gcc/c-parse.c    Sat Sep 23 09:22:53 1995
  8101. +++ amiga/fsf/gcc/c-parse.c    Wed Dec 31 17:00:00 1969
  8102. @@ -1,3683 +0,0 @@
  8103. -
  8104. -/*  A Bison parser, made from c-parse.y with Bison version GNU Bison version 1.22
  8105. -  */
  8106. -
  8107. -#define YYBISON 1  /* Identify Bison output.  */
  8108. -
  8109. -#define    IDENTIFIER    258
  8110. -#define    TYPENAME    259
  8111. -#define    SCSPEC    260
  8112. -#define    TYPESPEC    261
  8113. -#define    TYPE_QUAL    262
  8114. -#define    CONSTANT    263
  8115. -#define    STRING    264
  8116. -#define    ELLIPSIS    265
  8117. -#define    SIZEOF    266
  8118. -#define    ENUM    267
  8119. -#define    STRUCT    268
  8120. -#define    UNION    269
  8121. -#define    IF    270
  8122. -#define    ELSE    271
  8123. -#define    WHILE    272
  8124. -#define    DO    273
  8125. -#define    FOR    274
  8126. -#define    SWITCH    275
  8127. -#define    CASE    276
  8128. -#define    DEFAULT    277
  8129. -#define    BREAK    278
  8130. -#define    CONTINUE    279
  8131. -#define    RETURN    280
  8132. -#define    GOTO    281
  8133. -#define    ASM_KEYWORD    282
  8134. -#define    TYPEOF    283
  8135. -#define    ALIGNOF    284
  8136. -#define    ATTRIBUTE    285
  8137. -#define    EXTENSION    286
  8138. -#define    LABEL    287
  8139. -#define    REALPART    288
  8140. -#define    IMAGPART    289
  8141. -#define    ASSIGN    290
  8142. -#define    OROR    291
  8143. -#define    ANDAND    292
  8144. -#define    EQCOMPARE    293
  8145. -#define    ARITHCOMPARE    294
  8146. -#define    LSHIFT    295
  8147. -#define    RSHIFT    296
  8148. -#define    UNARY    297
  8149. -#define    PLUSPLUS    298
  8150. -#define    MINUSMINUS    299
  8151. -#define    HYPERUNARY    300
  8152. -#define    POINTSAT    301
  8153. -#define    INTERFACE    302
  8154. -#define    IMPLEMENTATION    303
  8155. -#define    END    304
  8156. -#define    SELECTOR    305
  8157. -#define    DEFS    306
  8158. -#define    ENCODE    307
  8159. -#define    CLASSNAME    308
  8160. -#define    PUBLIC    309
  8161. -#define    PRIVATE    310
  8162. -#define    PROTECTED    311
  8163. -#define    PROTOCOL    312
  8164. -#define    OBJECTNAME    313
  8165. -#define    CLASS    314
  8166. -#define    ALIAS    315
  8167. -#define    OBJC_STRING    316
  8168. -
  8169. -#line 55 "c-parse.y"
  8170. -
  8171. -#include <stdio.h>
  8172. -#include <errno.h>
  8173. -#include <setjmp.h>
  8174. -
  8175. -#include "config.h"
  8176. -#include "tree.h"
  8177. -#include "input.h"
  8178. -#include "c-lex.h"
  8179. -#include "c-tree.h"
  8180. -#include "flags.h"
  8181. -
  8182. -#ifdef MULTIBYTE_CHARS
  8183. -#include <stdlib.h>
  8184. -#include <locale.h>
  8185. -#endif
  8186. -
  8187. -
  8188. -/* Since parsers are distinct for each language, put the language string
  8189. -   definition here.  */
  8190. -char *language_string = "GNU C";
  8191. -
  8192. -#ifndef errno
  8193. -extern int errno;
  8194. -#endif
  8195. -
  8196. -void yyerror ();
  8197. -
  8198. -/* Like YYERROR but do call yyerror.  */
  8199. -#define YYERROR1 { yyerror ("syntax error"); YYERROR; }
  8200. -
  8201. -/* Cause the `yydebug' variable to be defined.  */
  8202. -#define YYDEBUG 1
  8203. -
  8204. -#line 92 "c-parse.y"
  8205. -typedef union {long itype; tree ttype; enum tree_code code;
  8206. -    char *filename; int lineno; int ends_in_label; } YYSTYPE;
  8207. -#line 206 "c-parse.y"
  8208. -
  8209. -/* Number of statements (loosely speaking) seen so far.  */
  8210. -static int stmt_count;
  8211. -
  8212. -/* Input file and line number of the end of the body of last simple_if;
  8213. -   used by the stmt-rule immediately after simple_if returns.  */
  8214. -static char *if_stmt_file;
  8215. -static int if_stmt_line;
  8216. -
  8217. -/* List of types and structure classes of the current declaration.  */
  8218. -static tree current_declspecs;
  8219. -static tree prefix_attributes = NULL_TREE;
  8220. -
  8221. -/* Stack of saved values of current_declspecs and prefix_attributes.  */
  8222. -static tree declspec_stack;
  8223. -
  8224. -/* 1 if we explained undeclared var errors.  */
  8225. -static int undeclared_variable_notice;
  8226. -
  8227. -
  8228. -/* Tell yyparse how to print a token's value, if yydebug is set.  */
  8229. -
  8230. -#define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL)
  8231. -extern void yyprint ();
  8232. -
  8233. -#ifndef YYLTYPE
  8234. -typedef
  8235. -  struct yyltype
  8236. -    {
  8237. -      int timestamp;
  8238. -      int first_line;
  8239. -      int first_column;
  8240. -      int last_line;
  8241. -      int last_column;
  8242. -      char *text;
  8243. -   }
  8244. -  yyltype;
  8245. -
  8246. -#define YYLTYPE yyltype
  8247. -#endif
  8248. -
  8249. -#include <stdio.h>
  8250. -
  8251. -#ifndef __cplusplus
  8252. -#ifndef __STDC__
  8253. -#define const
  8254. -#endif
  8255. -#endif
  8256. -
  8257. -
  8258. -
  8259. -#define    YYFINAL        658
  8260. -#define    YYFLAG        -32768
  8261. -#define    YYNTBASE    84
  8262. -
  8263. -#define YYTRANSLATE(x) ((unsigned)(x) <= 316 ? yytranslate[x] : 228)
  8264. -
  8265. -static const char yytranslate[] = {     0,
  8266. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8267. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8268. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8269. -     2,     2,    80,     2,     2,     2,    52,    43,     2,    59,
  8270. -    76,    50,    48,    81,    49,    58,    51,     2,     2,     2,
  8271. -     2,     2,     2,     2,     2,     2,     2,    38,    77,     2,
  8272. -    36,     2,    37,     2,     2,     2,     2,     2,     2,     2,
  8273. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8274. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8275. -    60,     2,    83,    42,     2,     2,     2,     2,     2,     2,
  8276. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8277. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8278. -     2,     2,    82,    41,    78,    79,     2,     2,     2,     2,
  8279. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8280. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8281. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8282. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8283. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8284. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8285. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8286. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8287. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8288. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8289. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8290. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  8291. -     2,     2,     2,     2,     2,     1,     2,     3,     4,     5,
  8292. -     6,     7,     8,     9,    10,    11,    12,    13,    14,    15,
  8293. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  8294. -    26,    27,    28,    29,    30,    31,    32,    33,    34,    35,
  8295. -    39,    40,    44,    45,    46,    47,    53,    54,    55,    56,
  8296. -    57,    61,    62,    63,    64,    65,    66,    67,    68,    69,
  8297. -    70,    71,    72,    73,    74,    75
  8298. -};
  8299. -
  8300. -#if YYDEBUG != 0
  8301. -static const short yyprhs[] = {     0,
  8302. -     0,     1,     3,     4,     7,     8,    12,    14,    16,    22,
  8303. -    26,    31,    36,    39,    42,    45,    48,    50,    51,    52,
  8304. -    60,    65,    66,    67,    75,    80,    81,    82,    89,    93,
  8305. -    95,    97,    99,   101,   103,   105,   107,   109,   111,   113,
  8306. -   114,   116,   118,   122,   124,   127,   128,   132,   135,   138,
  8307. -   141,   146,   149,   154,   157,   160,   162,   167,   168,   176,
  8308. -   178,   182,   186,   190,   194,   198,   202,   206,   210,   214,
  8309. -   218,   222,   226,   230,   234,   240,   244,   248,   250,   252,
  8310. -   254,   258,   262,   263,   268,   273,   278,   282,   286,   289,
  8311. -   292,   294,   297,   298,   300,   303,   307,   309,   311,   314,
  8312. -   317,   322,   327,   330,   333,   337,   339,   341,   344,   347,
  8313. -   348,   349,   354,   359,   363,   367,   370,   373,   376,   380,
  8314. -   381,   384,   387,   389,   391,   394,   397,   400,   404,   405,
  8315. -   408,   410,   412,   414,   419,   424,   426,   428,   430,   432,
  8316. -   436,   438,   442,   443,   448,   449,   456,   460,   461,   468,
  8317. -   472,   473,   475,   477,   480,   487,   489,   493,   494,   496,
  8318. -   501,   508,   513,   515,   517,   519,   521,   523,   524,   529,
  8319. -   531,   532,   535,   537,   541,   543,   544,   549,   551,   552,
  8320. -   561,   562,   569,   570,   576,   577,   582,   583,   589,   590,
  8321. -   591,   597,   598,   599,   605,   607,   609,   613,   617,   622,
  8322. -   626,   630,   634,   636,   640,   645,   649,   653,   657,   659,
  8323. -   663,   667,   671,   676,   680,   684,   686,   687,   695,   701,
  8324. -   704,   705,   713,   719,   722,   723,   732,   733,   741,   744,
  8325. -   745,   747,   748,   750,   752,   755,   756,   760,   763,   767,
  8326. -   769,   773,   775,   777,   779,   783,   788,   795,   801,   803,
  8327. -   807,   809,   811,   815,   818,   821,   822,   824,   826,   829,
  8328. -   830,   833,   837,   841,   844,   848,   853,   857,   860,   864,
  8329. -   867,   871,   873,   875,   878,   881,   882,   884,   887,   888,
  8330. -   889,   891,   893,   896,   900,   902,   905,   908,   915,   921,
  8331. -   927,   930,   933,   938,   939,   944,   945,   946,   950,   955,
  8332. -   959,   961,   963,   965,   967,   970,   971,   976,   978,   982,
  8333. -   983,   984,   992,   998,  1001,  1002,  1003,  1004,  1017,  1018,
  8334. -  1025,  1028,  1031,  1034,  1038,  1045,  1054,  1065,  1078,  1082,
  8335. -  1087,  1089,  1091,  1092,  1099,  1103,  1109,  1112,  1115,  1116,
  8336. -  1118,  1119,  1121,  1122,  1124,  1126,  1130,  1135,  1137,  1141,
  8337. -  1142,  1145,  1148,  1149,  1154,  1157,  1158,  1160,  1162,  1166,
  8338. -  1168,  1172,  1177,  1182,  1187,  1192,  1197,  1198,  1201,  1203,
  8339. -  1206,  1208,  1212,  1214
  8340. -};
  8341. -
  8342. -static const short yyrhs[] = {    -1,
  8343. -    85,     0,     0,    86,    88,     0,     0,    85,    87,    88,
  8344. -     0,    90,     0,    89,     0,    27,    59,    99,    76,    77,
  8345. -     0,   116,   127,    77,     0,   121,   116,   127,    77,     0,
  8346. -   119,   116,   126,    77,     0,   121,    77,     0,   119,    77,
  8347. -     0,     1,    77,     0,     1,    78,     0,    77,     0,     0,
  8348. -     0,   119,   116,   156,    91,   110,    92,   187,     0,   119,
  8349. -   116,   156,     1,     0,     0,     0,   121,   116,   159,    93,
  8350. -   110,    94,   187,     0,   121,   116,   159,     1,     0,     0,
  8351. -     0,   116,   159,    95,   110,    96,   187,     0,   116,   159,
  8352. -     1,     0,     3,     0,     4,     0,    43,     0,    49,     0,
  8353. -    48,     0,    54,     0,    55,     0,    79,     0,    80,     0,
  8354. -   101,     0,     0,   101,     0,   106,     0,   101,    81,   106,
  8355. -     0,   107,     0,    50,   104,     0,     0,    31,   103,   104,
  8356. -     0,    98,   104,     0,    40,    97,     0,    11,   102,     0,
  8357. -    11,    59,   174,    76,     0,    29,   102,     0,    29,    59,
  8358. -   174,    76,     0,    33,   104,     0,    34,   104,     0,   102,
  8359. -     0,    59,   174,    76,   104,     0,     0,    59,   174,    76,
  8360. -    82,   105,   141,    78,     0,   104,     0,   106,    48,   106,
  8361. -     0,   106,    49,   106,     0,   106,    50,   106,     0,   106,
  8362. -    51,   106,     0,   106,    52,   106,     0,   106,    46,   106,
  8363. -     0,   106,    47,   106,     0,   106,    45,   106,     0,   106,
  8364. -    44,   106,     0,   106,    43,   106,     0,   106,    41,   106,
  8365. -     0,   106,    42,   106,     0,   106,    40,   106,     0,   106,
  8366. -    39,   106,     0,   106,    37,   211,    38,   106,     0,   106,
  8367. -    36,   106,     0,   106,    35,   106,     0,     3,     0,     8,
  8368. -     0,   109,     0,    59,    99,    76,     0,    59,     1,    76,
  8369. -     0,     0,    59,   108,   188,    76,     0,   107,    59,   100,
  8370. -    76,     0,   107,    60,    99,    83,     0,   107,    58,    97,
  8371. -     0,   107,    57,    97,     0,   107,    54,     0,   107,    55,
  8372. -     0,     9,     0,   109,     9,     0,     0,   112,     0,   112,
  8373. -    10,     0,   193,   194,   113,     0,   111,     0,   182,     0,
  8374. -   112,   111,     0,   111,   182,     0,   119,   116,   126,    77,
  8375. -     0,   121,   116,   127,    77,     0,   119,    77,     0,   121,
  8376. -    77,     0,   193,   194,   118,     0,   114,     0,   182,     0,
  8377. -   115,   114,     0,   114,   182,     0,     0,     0,   119,   116,
  8378. -   126,    77,     0,   121,   116,   127,    77,     0,   119,   116,
  8379. -   150,     0,   121,   116,   153,     0,   119,    77,     0,   121,
  8380. -    77,     0,   124,   120,     0,   121,   124,   120,     0,     0,
  8381. -   120,   125,     0,   120,     5,     0,     7,     0,     5,     0,
  8382. -   121,     7,     0,   121,     5,     0,   124,   123,     0,   176,
  8383. -   124,   123,     0,     0,   123,   125,     0,     6,     0,   160,
  8384. -     0,     4,     0,    28,    59,    99,    76,     0,    28,    59,
  8385. -   174,    76,     0,     6,     0,     7,     0,   160,     0,   129,
  8386. -     0,   126,    81,   129,     0,   131,     0,   127,    81,   129,
  8387. -     0,     0,    27,    59,   109,    76,     0,     0,   156,   128,
  8388. -   133,    36,   130,   139,     0,   156,   128,   133,     0,     0,
  8389. -   159,   128,   133,    36,   132,   139,     0,   159,   128,   133,
  8390. -     0,     0,   134,     0,   135,     0,   134,   135,     0,    30,
  8391. -    59,    59,   136,    76,    76,     0,   137,     0,   136,    81,
  8392. -   137,     0,     0,   138,     0,   138,    59,     3,    76,     0,
  8393. -   138,    59,     3,    81,   101,    76,     0,   138,    59,   100,
  8394. -    76,     0,    97,     0,     5,     0,     6,     0,     7,     0,
  8395. -   106,     0,     0,    82,   140,   141,    78,     0,     1,     0,
  8396. -     0,   142,   165,     0,   143,     0,   142,    81,   143,     0,
  8397. -   106,     0,     0,    82,   144,   141,    78,     0,     1,     0,
  8398. -     0,    60,   106,    10,   106,    83,    36,   145,   143,     0,
  8399. -     0,    60,   106,    83,    36,   146,   143,     0,     0,    60,
  8400. -   106,    83,   147,   143,     0,     0,    97,    38,   148,   143,
  8401. -     0,     0,    58,    97,    36,   149,   143,     0,     0,     0,
  8402. -   156,   151,   110,   152,   188,     0,     0,     0,   159,   154,
  8403. -   110,   155,   188,     0,   157,     0,   159,     0,    59,   157,
  8404. -    76,     0,   157,    59,   223,     0,   157,    60,    99,    83,
  8405. -     0,   157,    60,    83,     0,    50,   177,   157,     0,   134,
  8406. -   117,   157,     0,     4,     0,   158,    59,   223,     0,   158,
  8407. -    60,    99,    83,     0,   158,    60,    83,     0,    50,   177,
  8408. -   158,     0,   134,   117,   158,     0,     4,     0,   159,    59,
  8409. -   223,     0,    59,   159,    76,     0,    50,   177,   159,     0,
  8410. -   159,    60,    99,    83,     0,   159,    60,    83,     0,   134,
  8411. -   117,   159,     0,     3,     0,     0,    13,    97,    82,   161,
  8412. -   167,    78,   133,     0,    13,    82,   167,    78,   133,     0,
  8413. -    13,    97,     0,     0,    14,    97,    82,   162,   167,    78,
  8414. -   133,     0,    14,    82,   167,    78,   133,     0,    14,    97,
  8415. -     0,     0,    12,    97,    82,   163,   172,   166,    78,   133,
  8416. -     0,     0,    12,    82,   164,   172,   166,    78,   133,     0,
  8417. -    12,    97,     0,     0,    81,     0,     0,    81,     0,   168,
  8418. -     0,   168,   169,     0,     0,   168,   169,    77,     0,   168,
  8419. -    77,     0,   122,   116,   170,     0,   122,     0,   176,   116,
  8420. -   170,     0,   176,     0,     1,     0,   171,     0,   170,    81,
  8421. -   171,     0,   193,   194,   156,   133,     0,   193,   194,   156,
  8422. -    38,   106,   133,     0,   193,   194,    38,   106,   133,     0,
  8423. -   173,     0,   172,    81,   173,     0,     1,     0,    97,     0,
  8424. -    97,    36,   106,     0,   122,   175,     0,   176,   175,     0,
  8425. -     0,   178,     0,     7,     0,   176,     7,     0,     0,   177,
  8426. -     7,     0,    59,   178,    76,     0,    50,   177,   178,     0,
  8427. -    50,   177,     0,   178,    59,   216,     0,   178,    60,    99,
  8428. -    83,     0,   178,    60,    83,     0,    59,   216,     0,    60,
  8429. -    99,    83,     0,    60,    83,     0,   134,   117,   178,     0,
  8430. -   180,     0,   196,     0,   180,   196,     0,   180,   182,     0,
  8431. -     0,   179,     0,     1,    77,     0,     0,     0,   185,     0,
  8432. -   186,     0,   185,   186,     0,    32,   227,    77,     0,   188,
  8433. -     0,     1,   188,     0,    82,    78,     0,    82,   183,   184,
  8434. -   115,   181,    78,     0,    82,   183,   184,     1,    78,     0,
  8435. -    82,   183,   184,   179,    78,     0,   190,   195,     0,   190,
  8436. -     1,     0,    15,    59,    99,    76,     0,     0,    18,   192,
  8437. -   195,    17,     0,     0,     0,   193,   194,   198,     0,   193,
  8438. -   194,   209,   195,     0,   193,   194,   197,     0,   198,     0,
  8439. -   209,     0,   188,     0,   206,     0,    99,    77,     0,     0,
  8440. -   189,    16,   199,   195,     0,   189,     0,   189,    16,     1,
  8441. -     0,     0,     0,    17,   200,    59,    99,    76,   201,   195,
  8442. -     0,   191,    59,    99,    76,    77,     0,   191,     1,     0,
  8443. -     0,     0,     0,    19,    59,   211,    77,   202,   211,    77,
  8444. -   203,   211,    76,   204,   195,     0,     0,    20,    59,    99,
  8445. -    76,   205,   195,     0,    23,    77,     0,    24,    77,     0,
  8446. -    25,    77,     0,    25,    99,    77,     0,    27,   210,    59,
  8447. -    99,    76,    77,     0,    27,   210,    59,    99,    38,   212,
  8448. -    76,    77,     0,    27,   210,    59,    99,    38,   212,    38,
  8449. -   212,    76,    77,     0,    27,   210,    59,    99,    38,   212,
  8450. -    38,   212,    38,   215,    76,    77,     0,    26,    97,    77,
  8451. -     0,    26,    50,    99,    77,     0,    77,     0,   207,     0,
  8452. -     0,    19,    59,   107,    76,   208,   195,     0,    21,   106,
  8453. -    38,     0,    21,   106,    10,   106,    38,     0,    22,    38,
  8454. -     0,    97,    38,     0,     0,     7,     0,     0,    99,     0,
  8455. -     0,   213,     0,   214,     0,   213,    81,   214,     0,     9,
  8456. -    59,    99,    76,     0,   109,     0,   215,    81,   109,     0,
  8457. -     0,   217,   218,     0,   220,    76,     0,     0,   221,    77,
  8458. -   219,   218,     0,     1,    76,     0,     0,    10,     0,   221,
  8459. -     0,   221,    81,    10,     0,   222,     0,   221,    81,   222,
  8460. -     0,   119,   116,   158,   133,     0,   119,   116,   159,   133,
  8461. -     0,   119,   116,   175,   133,     0,   121,   116,   159,   133,
  8462. -     0,   121,   116,   175,   133,     0,     0,   224,   225,     0,
  8463. -   218,     0,   226,    76,     0,     3,     0,   226,    81,     3,
  8464. -     0,    97,     0,   227,    81,    97,     0
  8465. -};
  8466. -
  8467. -#endif
  8468. -
  8469. -#if YYDEBUG != 0
  8470. -static const short yyrline[] = { 0,
  8471. -   233,   238,   252,   254,   254,   255,   257,   259,   260,   270,
  8472. -   281,   286,   291,   293,   295,   296,   297,   302,   309,   311,
  8473. -   316,   321,   327,   329,   334,   339,   345,   347,   352,   359,
  8474. -   361,   364,   366,   368,   370,   372,   374,   376,   380,   384,
  8475. -   387,   390,   393,   397,   399,   402,   405,   408,   412,   440,
  8476. -   445,   447,   449,   451,   453,   457,   459,   462,   466,   493,
  8477. -   495,   497,   499,   501,   503,   505,   507,   509,   511,   513,
  8478. -   515,   517,   519,   521,   523,   525,   528,   534,   633,   634,
  8479. -   636,   642,   644,   658,   681,   683,   685,   689,   695,   697,
  8480. -   702,   704,   709,   711,   712,   722,   727,   729,   730,   731,
  8481. -   734,   740,   745,   748,   756,   761,   763,   764,   765,   772,
  8482. -   782,   786,   792,   797,   802,   807,   809,   817,   820,   824,
  8483. -   826,   828,   839,   843,   845,   848,   861,   864,   868,   870,
  8484. -   878,   879,   880,   884,   886,   892,   893,   894,   897,   899,
  8485. -   902,   904,   907,   910,   916,   923,   925,   932,   939,   942,
  8486. -   949,   952,   956,   959,   963,   968,   971,   975,   978,   980,
  8487. -   982,   984,   991,   993,   994,   995,  1000,  1002,  1007,  1015,
  8488. -  1020,  1024,  1027,  1029,  1034,  1037,  1039,  1041,  1045,  1048,
  8489. -  1048,  1051,  1051,  1054,  1054,  1057,  1057,  1060,  1062,  1073,
  8490. -  1081,  1085,  1096,  1104,  1111,  1113,  1118,  1121,  1126,  1128,
  8491. -  1130,  1132,  1134,  1142,  1148,  1150,  1152,  1154,  1156,  1162,
  8492. -  1168,  1170,  1172,  1174,  1176,  1178,  1181,  1186,  1188,  1192,
  8493. -  1194,  1196,  1198,  1202,  1204,  1207,  1210,  1213,  1216,  1220,
  8494. -  1222,  1225,  1227,  1231,  1234,  1239,  1241,  1243,  1257,  1264,
  8495. -  1269,  1275,  1280,  1284,  1286,  1290,  1294,  1298,  1308,  1310,
  8496. -  1315,  1320,  1323,  1327,  1330,  1334,  1337,  1340,  1343,  1347,
  8497. -  1350,  1354,  1358,  1360,  1362,  1364,  1366,  1368,  1370,  1372,
  8498. -  1374,  1382,  1390,  1392,  1394,  1398,  1400,  1403,  1406,  1417,
  8499. -  1419,  1424,  1426,  1429,  1443,  1446,  1449,  1451,  1459,  1467,
  8500. -  1478,  1483,  1486,  1499,  1507,  1511,  1515,  1519,  1525,  1529,
  8501. -  1534,  1537,  1542,  1545,  1546,  1563,  1568,  1571,  1583,  1585,
  8502. -  1595,  1605,  1606,  1614,  1617,  1629,  1633,  1650,  1660,  1669,
  8503. -  1674,  1679,  1684,  1688,  1692,  1703,  1710,  1717,  1724,  1735,
  8504. -  1739,  1742,  1747,  1770,  1804,  1829,  1858,  1873,  1884,  1888,
  8505. -  1892,  1895,  1900,  1902,  1905,  1907,  1911,  1916,  1919,  1925,
  8506. -  1930,  1935,  1937,  1946,  1947,  1953,  1955,  1965,  1967,  1971,
  8507. -  1974,  1980,  1990,  1999,  2008,  2018,  2032,  2037,  2042,  2044,
  8508. -  2053,  2056,  2061,  2064
  8509. -};
  8510. -
  8511. -static const char * const yytname[] = {   "$","error","$illegal.","IDENTIFIER",
  8512. -"TYPENAME","SCSPEC","TYPESPEC","TYPE_QUAL","CONSTANT","STRING","ELLIPSIS","SIZEOF",
  8513. -"ENUM","STRUCT","UNION","IF","ELSE","WHILE","DO","FOR","SWITCH","CASE","DEFAULT",
  8514. -"BREAK","CONTINUE","RETURN","GOTO","ASM_KEYWORD","TYPEOF","ALIGNOF","ATTRIBUTE",
  8515. -"EXTENSION","LABEL","REALPART","IMAGPART","ASSIGN","'='","'?'","':'","OROR",
  8516. -"ANDAND","'|'","'^'","'&'","EQCOMPARE","ARITHCOMPARE","LSHIFT","RSHIFT","'+'",
  8517. -"'-'","'*'","'/'","'%'","UNARY","PLUSPLUS","MINUSMINUS","HYPERUNARY","POINTSAT",
  8518. -"'.'","'('","'['","INTERFACE","IMPLEMENTATION","END","SELECTOR","DEFS","ENCODE",
  8519. -"CLASSNAME","PUBLIC","PRIVATE","PROTECTED","PROTOCOL","OBJECTNAME","CLASS","ALIAS",
  8520. -"OBJC_STRING","')'","';'","'}'","'~'","'!'","','","'{'","']'","program","extdefs",
  8521. -"@1","@2","extdef","datadef","fndef","@3","@4","@5","@6","@7","@8","identifier",
  8522. -"unop","expr","exprlist","nonnull_exprlist","unary_expr","@9","cast_expr","@10",
  8523. -"expr_no_commas","primary","@11","string","xdecls","lineno_datadecl","datadecls",
  8524. -"datadecl","lineno_decl","decls","setspecs","setattrs","decl","typed_declspecs",
  8525. -"reserved_declspecs","declmods","typed_typespecs","reserved_typespecquals","typespec",
  8526. -"typespecqual_reserved","initdecls","notype_initdecls","maybeasm","initdcl",
  8527. -"@12","notype_initdcl","@13","maybe_attribute","attributes","attribute","attribute_list",
  8528. -"attrib","any_word","init","@14","initlist_maybe_comma","initlist1","initelt",
  8529. -"@15","@16","@17","@18","@19","@20","nested_function","@21","@22","notype_nested_function",
  8530. -"@23","@24","declarator","after_type_declarator","parm_declarator","notype_declarator",
  8531. -"structsp","@25","@26","@27","@28","maybecomma","maybecomma_warn","component_decl_list",
  8532. -"component_decl_list2","component_decl","components","component_declarator",
  8533. -"enumlist","enumerator","typename","absdcl","nonempty_type_quals","type_quals",
  8534. -"absdcl1","stmts","lineno_stmt_or_labels","xstmts","errstmt","pushlevel","maybe_label_decls",
  8535. -"label_decls","label_decl","compstmt_or_error","compstmt","simple_if","if_prefix",
  8536. -"do_stmt_start","@29","save_filename","save_lineno","lineno_labeled_stmt","lineno_stmt_or_label",
  8537. -"stmt_or_label","stmt","@30","@31","@32","@33","@34","@35","@36","all_iter_stmt",
  8538. -"all_iter_stmt_simple","@37","label","maybe_type_qual","xexpr","asm_operands",
  8539. -"nonnull_asm_operands","asm_operand","asm_clobbers","parmlist","@38","parmlist_1",
  8540. -"@39","parmlist_2","parms","parm","parmlist_or_identifiers","@40","parmlist_or_identifiers_1",
  8541. -"identifiers","identifiers_or_typenames",""
  8542. -};
  8543. -#endif
  8544. -
  8545. -static const short yyr1[] = {     0,
  8546. -    84,    84,    86,    85,    87,    85,    88,    88,    88,    89,
  8547. -    89,    89,    89,    89,    89,    89,    89,    91,    92,    90,
  8548. -    90,    93,    94,    90,    90,    95,    96,    90,    90,    97,
  8549. -    97,    98,    98,    98,    98,    98,    98,    98,    99,   100,
  8550. -   100,   101,   101,   102,   102,   103,   102,   102,   102,   102,
  8551. -   102,   102,   102,   102,   102,   104,   104,   105,   104,   106,
  8552. -   106,   106,   106,   106,   106,   106,   106,   106,   106,   106,
  8553. -   106,   106,   106,   106,   106,   106,   106,   107,   107,   107,
  8554. -   107,   107,   108,   107,   107,   107,   107,   107,   107,   107,
  8555. -   109,   109,   110,   110,   110,   111,   112,   112,   112,   112,
  8556. -   113,   113,   113,   113,   114,   115,   115,   115,   115,   116,
  8557. -   117,   118,   118,   118,   118,   118,   118,   119,   119,   120,
  8558. -   120,   120,   121,   121,   121,   121,   122,   122,   123,   123,
  8559. -   124,   124,   124,   124,   124,   125,   125,   125,   126,   126,
  8560. -   127,   127,   128,   128,   130,   129,   129,   132,   131,   131,
  8561. -   133,   133,   134,   134,   135,   136,   136,   137,   137,   137,
  8562. -   137,   137,   138,   138,   138,   138,   139,   140,   139,   139,
  8563. -   141,   141,   142,   142,   143,   144,   143,   143,   145,   143,
  8564. -   146,   143,   147,   143,   148,   143,   149,   143,   151,   152,
  8565. -   150,   154,   155,   153,   156,   156,   157,   157,   157,   157,
  8566. -   157,   157,   157,   158,   158,   158,   158,   158,   158,   159,
  8567. -   159,   159,   159,   159,   159,   159,   161,   160,   160,   160,
  8568. -   162,   160,   160,   160,   163,   160,   164,   160,   160,   165,
  8569. -   165,   166,   166,   167,   167,   168,   168,   168,   169,   169,
  8570. -   169,   169,   169,   170,   170,   171,   171,   171,   172,   172,
  8571. -   172,   173,   173,   174,   174,   175,   175,   176,   176,   177,
  8572. -   177,   178,   178,   178,   178,   178,   178,   178,   178,   178,
  8573. -   178,   179,   180,   180,   180,   181,   181,   182,   183,   184,
  8574. -   184,   185,   185,   186,   187,   187,   188,   188,   188,   188,
  8575. -   189,   189,   190,   192,   191,   193,   194,   195,   195,   196,
  8576. -   197,   197,   198,   198,   198,   199,   198,   198,   198,   200,
  8577. -   201,   198,   198,   198,   202,   203,   204,   198,   205,   198,
  8578. -   198,   198,   198,   198,   198,   198,   198,   198,   198,   198,
  8579. -   198,   206,   208,   207,   209,   209,   209,   209,   210,   210,
  8580. -   211,   211,   212,   212,   213,   213,   214,   215,   215,   217,
  8581. -   216,   218,   219,   218,   218,   220,   220,   220,   220,   221,
  8582. -   221,   222,   222,   222,   222,   222,   224,   223,   225,   225,
  8583. -   226,   226,   227,   227
  8584. -};
  8585. -
  8586. -static const short yyr2[] = {     0,
  8587. -     0,     1,     0,     2,     0,     3,     1,     1,     5,     3,
  8588. -     4,     4,     2,     2,     2,     2,     1,     0,     0,     7,
  8589. -     4,     0,     0,     7,     4,     0,     0,     6,     3,     1,
  8590. -     1,     1,     1,     1,     1,     1,     1,     1,     1,     0,
  8591. -     1,     1,     3,     1,     2,     0,     3,     2,     2,     2,
  8592. -     4,     2,     4,     2,     2,     1,     4,     0,     7,     1,
  8593. -     3,     3,     3,     3,     3,     3,     3,     3,     3,     3,
  8594. -     3,     3,     3,     3,     5,     3,     3,     1,     1,     1,
  8595. -     3,     3,     0,     4,     4,     4,     3,     3,     2,     2,
  8596. -     1,     2,     0,     1,     2,     3,     1,     1,     2,     2,
  8597. -     4,     4,     2,     2,     3,     1,     1,     2,     2,     0,
  8598. -     0,     4,     4,     3,     3,     2,     2,     2,     3,     0,
  8599. -     2,     2,     1,     1,     2,     2,     2,     3,     0,     2,
  8600. -     1,     1,     1,     4,     4,     1,     1,     1,     1,     3,
  8601. -     1,     3,     0,     4,     0,     6,     3,     0,     6,     3,
  8602. -     0,     1,     1,     2,     6,     1,     3,     0,     1,     4,
  8603. -     6,     4,     1,     1,     1,     1,     1,     0,     4,     1,
  8604. -     0,     2,     1,     3,     1,     0,     4,     1,     0,     8,
  8605. -     0,     6,     0,     5,     0,     4,     0,     5,     0,     0,
  8606. -     5,     0,     0,     5,     1,     1,     3,     3,     4,     3,
  8607. -     3,     3,     1,     3,     4,     3,     3,     3,     1,     3,
  8608. -     3,     3,     4,     3,     3,     1,     0,     7,     5,     2,
  8609. -     0,     7,     5,     2,     0,     8,     0,     7,     2,     0,
  8610. -     1,     0,     1,     1,     2,     0,     3,     2,     3,     1,
  8611. -     3,     1,     1,     1,     3,     4,     6,     5,     1,     3,
  8612. -     1,     1,     3,     2,     2,     0,     1,     1,     2,     0,
  8613. -     2,     3,     3,     2,     3,     4,     3,     2,     3,     2,
  8614. -     3,     1,     1,     2,     2,     0,     1,     2,     0,     0,
  8615. -     1,     1,     2,     3,     1,     2,     2,     6,     5,     5,
  8616. -     2,     2,     4,     0,     4,     0,     0,     3,     4,     3,
  8617. -     1,     1,     1,     1,     2,     0,     4,     1,     3,     0,
  8618. -     0,     7,     5,     2,     0,     0,     0,    12,     0,     6,
  8619. -     2,     2,     2,     3,     6,     8,    10,    12,     3,     4,
  8620. -     1,     1,     0,     6,     3,     5,     2,     2,     0,     1,
  8621. -     0,     1,     0,     1,     1,     3,     4,     1,     3,     0,
  8622. -     2,     2,     0,     4,     2,     0,     1,     1,     3,     1,
  8623. -     3,     4,     4,     4,     4,     4,     0,     2,     1,     2,
  8624. -     1,     3,     1,     3
  8625. -};
  8626. -
  8627. -static const short yydefact[] = {     3,
  8628. -     5,     0,     0,     0,   133,   124,   131,   123,     0,     0,
  8629. -     0,     0,     0,    17,     4,     8,     7,     0,   110,   110,
  8630. -   120,   132,     6,    15,    16,    30,    31,   227,   229,   236,
  8631. -   220,   236,   224,     0,     0,   216,     0,   260,     0,     0,
  8632. -   141,   111,   153,     0,    14,     0,   126,   125,    13,     0,
  8633. -   120,   118,     0,   225,     0,     0,   217,     0,   221,    78,
  8634. -    79,    91,     0,     0,    46,     0,     0,     0,    32,    34,
  8635. -    33,     0,    35,    36,     0,    37,    38,     0,     0,    39,
  8636. -    56,    60,    42,    44,    80,   258,     0,   256,   129,     0,
  8637. -   256,     0,     0,     0,    10,     0,     0,   154,    29,     0,
  8638. -   367,     0,     0,   151,   203,   260,     0,     0,   139,   111,
  8639. -     0,   195,   196,     0,     0,   119,   122,   136,   137,   121,
  8640. -   138,   251,   252,   232,   249,     0,   151,   243,   238,   110,
  8641. -   235,   110,   236,   151,   236,     0,    50,     0,    52,     0,
  8642. -    54,    55,    49,    45,     0,     0,     0,     0,    48,     0,
  8643. -     0,     0,     0,   341,     0,     0,     0,     0,     0,     0,
  8644. -     0,     0,     0,     0,     0,     0,     0,     0,    89,    90,
  8645. -     0,     0,    40,     0,    92,   134,   260,   350,     0,   111,
  8646. -   254,   257,   127,   135,   259,   129,   255,   158,   261,   212,
  8647. -   211,   142,   143,   215,     0,   210,     0,   214,     0,     0,
  8648. -    27,     0,   296,    98,   297,   150,   152,     0,     0,    12,
  8649. -     0,     0,    21,     0,   151,   367,     0,    11,    25,     0,
  8650. -     0,   233,     0,   232,   219,   296,   237,   296,     0,   223,
  8651. -     0,     0,     0,    47,    82,    81,   279,     0,     0,     9,
  8652. -    43,    77,    76,   342,     0,    74,    73,    71,    72,    70,
  8653. -    69,    68,    66,    67,    61,    62,    63,    64,    65,    88,
  8654. -    87,     0,    41,     0,   264,     0,   268,     0,   270,     0,
  8655. -     0,   350,     0,   130,   128,   164,   165,   166,   163,     0,
  8656. -   156,   159,     0,     0,   371,   357,   110,   110,   369,     0,
  8657. -   358,   360,   368,     0,   213,   278,     0,   100,    95,    99,
  8658. -     0,   148,   201,   197,   140,   202,    19,   147,   198,   200,
  8659. -     0,    23,   253,   250,   151,     0,   239,   244,   297,   241,
  8660. -   151,   151,    51,    53,   287,   280,    84,    58,    57,     0,
  8661. -    85,    86,   263,   262,   351,   269,   271,   265,   267,     0,
  8662. -     0,   158,    40,   144,   355,   256,   256,   352,   353,     0,
  8663. -   370,     0,     0,    28,   285,    96,   110,   110,     0,     0,
  8664. -   145,   199,     0,   228,   151,   296,     0,   218,   222,     0,
  8665. -     0,   281,   282,     0,    75,   266,   155,   157,    78,     0,
  8666. -   209,   260,   350,   111,   151,   151,   151,   260,   111,   151,
  8667. -   151,     0,   359,   361,   372,   286,   103,     0,   104,     0,
  8668. -   170,   168,   167,   149,    20,     0,    24,   226,   245,     0,
  8669. -   151,   373,     0,     0,     0,   296,     0,     0,   107,   297,
  8670. -   273,   283,   178,    78,     0,     0,   176,     0,   175,     0,
  8671. -   230,   173,   160,     0,   162,   264,     0,   367,     0,   362,
  8672. -   363,   364,   264,     0,   365,   366,   354,     0,     0,   143,
  8673. -     0,   146,   151,     0,   246,   284,     0,   289,   109,   108,
  8674. -   277,     0,   290,   275,   297,   274,     0,     0,     0,     0,
  8675. -   185,    59,     0,   172,     0,   207,   208,   204,   206,     0,
  8676. -   101,   102,     0,   248,   151,   374,   288,     0,   133,     0,
  8677. -   310,   294,     0,     0,     0,     0,     0,     0,     0,     0,
  8678. -   339,   331,     0,     0,   105,   110,   110,   303,   308,     0,
  8679. -     0,   300,   301,   304,   332,   302,   187,     0,   183,     0,
  8680. -     0,   174,   161,   205,   169,   247,     0,     0,   296,   341,
  8681. -     0,     0,   337,   321,   322,   323,     0,     0,     0,   340,
  8682. -     0,   338,   305,   116,     0,   117,     0,     0,   292,   297,
  8683. -   291,   314,     0,     0,     0,   181,     0,   177,   186,     0,
  8684. -     0,     0,    44,     0,     0,     0,   335,   324,     0,   329,
  8685. -     0,     0,   114,   189,     0,   115,   192,   309,   296,     0,
  8686. -     0,   188,     0,     0,   184,   293,     0,   295,   333,   315,
  8687. -   319,     0,   330,     0,   112,     0,   113,     0,   307,   298,
  8688. -   296,     0,   179,   182,   311,   296,   341,   296,   336,   343,
  8689. -     0,   190,   193,   299,   313,     0,   296,   334,     0,   320,
  8690. -     0,     0,   344,   345,   325,     0,     0,   180,   312,   316,
  8691. -     0,   343,     0,     0,   191,   194,   341,     0,     0,   326,
  8692. -   346,     0,   347,     0,     0,   317,   348,     0,   327,   296,
  8693. -     0,     0,   318,   328,   349,     0,     0,     0
  8694. -};
  8695. -
  8696. -static const short yydefgoto[] = {   656,
  8697. -     1,     2,     3,    15,    16,    17,   214,   360,   220,   363,
  8698. -   103,   297,   428,    78,   244,   262,    80,    81,   140,    82,
  8699. -   374,    83,    84,   147,    85,   201,   202,   203,   356,   415,
  8700. -   416,    18,    97,   505,   287,    52,   288,    88,   183,    21,
  8701. -   120,   108,    40,   104,   109,   406,    41,   359,   206,   207,
  8702. -    43,   280,   281,   282,   404,   451,   430,   431,   432,   470,
  8703. -   616,   584,   557,   521,   554,   573,   596,   626,   576,   598,
  8704. -   627,   193,   112,   385,   113,    22,   133,   135,   126,    53,
  8705. -   474,   223,    55,    56,   131,   317,   318,   124,   125,    90,
  8706. -   181,    91,    93,   182,   417,   418,   462,   204,   326,   371,
  8707. -   372,   373,   354,   355,   509,   510,   511,   529,   550,   301,
  8708. -   551,   421,   512,   513,   579,   528,   617,   607,   637,   650,
  8709. -   608,   514,   515,   606,   516,   541,   245,   622,   623,   624,
  8710. -   648,   267,   268,   289,   392,   290,   291,   292,   196,   197,
  8711. -   293,   294,   413
  8712. -};
  8713. -
  8714. -static const short yypact[] = {    67,
  8715. -    76,  1898,  1898,   232,-32768,-32768,-32768,-32768,    62,    91,
  8716. -   106,    23,    37,-32768,-32768,-32768,-32768,   347,    26,   939,
  8717. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,    85,-32768,
  8718. -   118,-32768,   166,  1760,  1700,-32768,    89,-32768,   347,    83,
  8719. --32768,   128,-32768,  1205,-32768,   315,-32768,-32768,-32768,   347,
  8720. --32768,   862,   454,-32768,   180,   340,-32768,   185,-32768,-32768,
  8721. --32768,-32768,  1787,  1814,-32768,  1760,  1760,   119,-32768,-32768,
  8722. --32768,  1760,-32768,-32768,  1017,-32768,-32768,  1760,   110,   190,
  8723. --32768,-32768,  2063,   576,   257,-32768,   208,   214,-32768,   210,
  8724. -  1970,   267,   466,    11,-32768,   315,   347,-32768,-32768,   289,
  8725. --32768,   559,   284,   128,-32768,-32768,   315,   113,-32768,   128,
  8726. -  1284,   178,   264,   170,  1265,   862,-32768,-32768,-32768,-32768,
  8727. --32768,-32768,   263,   235,-32768,   454,   128,-32768,-32768,   265,
  8728. -   278,   859,-32768,   128,-32768,  1017,-32768,  1017,-32768,  1760,
  8729. --32768,-32768,-32768,-32768,   282,   294,   307,   319,-32768,   283,
  8730. -  1760,  1760,  1760,  1760,  1760,  1760,  1760,  1760,  1760,  1760,
  8731. -  1760,  1760,  1760,  1760,  1760,  1760,  1760,  1760,-32768,-32768,
  8732. -   119,   119,  1760,  1760,-32768,-32768,-32768,   214,  1319,   128,
  8733. --32768,   273,   552,-32768,-32768,-32768,-32768,   912,-32768,   264,
  8734. --32768,-32768,   374,   264,   395,-32768,   702,-32768,   343,   358,
  8735. --32768,   255,    47,-32768,-32768,   403,   128,   459,   111,-32768,
  8736. -   315,   315,-32768,   284,   128,-32768,  1346,-32768,-32768,   284,
  8737. -  1760,   119,   378,   235,-32768,-32768,-32768,-32768,   382,-32768,
  8738. -   386,   376,   394,-32768,-32768,-32768,   393,   398,  1643,-32768,
  8739. -  2063,  2063,  2063,-32768,   412,  1945,  1372,  1289,  1043,  1210,
  8740. -  1257,  1609,   947,   947,   252,   252,-32768,-32768,-32768,-32768,
  8741. --32768,   399,   190,   400,   364,   219,-32768,   782,-32768,   401,
  8742. -   214,-32768,  1401,-32768,   552,-32768,-32768,-32768,-32768,   -12,
  8743. --32768,   419,    35,   405,-32768,-32768,-32768,   672,-32768,   409,
  8744. -   240,-32768,-32768,   104,-32768,-32768,    59,-32768,-32768,-32768,
  8745. -   832,-32768,   178,-32768,-32768,   178,-32768,   450,-32768,-32768,
  8746. -   407,-32768,  2063,-32768,   128,   413,   414,-32768,-32768,   414,
  8747. -   128,   128,-32768,-32768,-32768,   467,-32768,-32768,-32768,  1760,
  8748. --32768,-32768,   273,-32768,-32768,-32768,   273,-32768,-32768,   420,
  8749. -   432,   912,  1841,-32768,-32768,   353,   149,-32768,-32768,   752,
  8750. --32768,   510,   307,-32768,-32768,-32768,   437,  1568,  1194,    59,
  8751. --32768,-32768,    59,-32768,   128,-32768,    55,-32768,-32768,   119,
  8752. -   720,   467,-32768,   546,  1894,-32768,-32768,-32768,   139,   439,
  8753. --32768,-32768,   149,   128,   151,   222,   128,-32768,   128,   222,
  8754. -   128,   782,-32768,-32768,-32768,-32768,-32768,   315,-32768,   347,
  8755. --32768,-32768,  2063,-32768,-32768,  1194,-32768,-32768,-32768,  1760,
  8756. -   108,-32768,   248,   309,   640,   443,   444,   800,-32768,-32768,
  8757. --32768,-32768,-32768,   485,   119,  1760,-32768,   488,  2063,   452,
  8758. -   447,-32768,-32768,  1760,-32768,   331,   353,-32768,  1428,-32768,
  8759. --32768,-32768,   109,   149,-32768,-32768,-32768,   292,   311,    19,
  8760. -   546,-32768,  2019,  1760,-32768,-32768,   119,-32768,-32768,-32768,
  8761. --32768,   455,-32768,-32768,-32768,-32768,  1509,   496,  1919,   546,
  8762. --32768,-32768,  1074,-32768,   159,   350,   350,-32768,-32768,   451,
  8763. --32768,-32768,   457,-32768,  2019,-32768,-32768,  1589,   500,   482,
  8764. --32768,-32768,   484,   486,  1760,   506,   474,   476,  1727,   203,
  8765. -   549,-32768,   522,   492,-32768,   494,  1902,-32768,   547,   880,
  8766. -    60,-32768,-32768,-32768,-32768,-32768,-32768,  1760,   536,   495,
  8767. -  1134,-32768,-32768,-32768,-32768,-32768,  1760,   517,-32768,  1760,
  8768. -  1760,  1453,-32768,-32768,-32768,-32768,   501,  1760,   504,-32768,
  8769. -   523,-32768,-32768,-32768,   315,-32768,   347,   960,-32768,-32768,
  8770. --32768,-32768,  1760,  1134,  1996,-32768,  1134,-32768,-32768,   507,
  8771. -  1760,   568,  1004,   514,   527,  1760,-32768,-32768,   521,-32768,
  8772. -  1760,   330,-32768,   471,   357,-32768,   372,-32768,-32768,  1589,
  8773. -   534,-32768,   575,  1134,-32768,-32768,   539,-32768,-32768,-32768,
  8774. --32768,  2045,-32768,    25,-32768,   284,-32768,   284,-32768,-32768,
  8775. --32768,   535,-32768,-32768,-32768,-32768,  1760,-32768,-32768,   607,
  8776. -   540,-32768,-32768,-32768,-32768,  1134,-32768,-32768,   542,-32768,
  8777. -   562,    45,   541,-32768,-32768,   307,   307,-32768,-32768,-32768,
  8778. -  1760,   607,   550,   607,-32768,-32768,  1760,   553,    50,-32768,
  8779. --32768,   561,-32768,   395,   563,-32768,   257,   160,-32768,-32768,
  8780. -   579,   395,-32768,-32768,   257,   670,   675,-32768
  8781. -};
  8782. -
  8783. -static const short yypgoto[] = {-32768,
  8784. --32768,-32768,-32768,   669,-32768,-32768,-32768,-32768,-32768,-32768,
  8785. --32768,-32768,    -6,-32768,   -34,   338,  -154,   352,-32768,   -27,
  8786. --32768,    66,   157,-32768,  -185,  -198,   489,-32768,-32768,   275,
  8787. --32768,     5,   -83,-32768,    10,   642,    12,   641,   512,    17,
  8788. -  -147,  -367,   -41,   -94,   -61,-32768,-32768,-32768,    57,   -16,
  8789. -    -4,-32768,   354,-32768,   295,-32768,  -396,-32768,  -423,-32768,
  8790. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  8791. --32768,   -40,   -65,     9,    -7,   -32,-32768,-32768,-32768,-32768,
  8792. --32768,   478,    21,-32768,-32768,   483,   344,   578,   491,   -21,
  8793. -   -70,   680,   -88,  -129,   334,-32768,-32768,  -173,-32768,-32768,
  8794. --32768,   380,  -186,  -139,-32768,-32768,-32768,-32768,   -96,  -293,
  8795. -  -404,   337,-32768,   181,-32768,-32768,-32768,-32768,-32768,-32768,
  8796. --32768,-32768,-32768,-32768,   187,-32768,  -474,   140,-32768,   137,
  8797. --32768,   505,-32768,  -235,-32768,-32768,-32768,   423,  -188,-32768,
  8798. --32768,-32768,-32768
  8799. -};
  8800. -
  8801. -
  8802. -#define    YYLAST        2115
  8803. -
  8804. -
  8805. -static const short yytable[] = {    79,
  8806. -    87,    42,    29,    31,    33,   111,   205,   238,   114,   283,
  8807. -    44,    19,    19,    20,    20,   307,   215,   208,   263,   121,
  8808. -   187,   312,    42,    46,    50,   367,   212,   309,   298,   110,
  8809. -   448,    94,   335,    42,   192,   274,    51,    98,   141,   142,
  8810. -   146,   209,   115,   175,   144,   100,   123,   -94,   266,   522,
  8811. -   149,    89,    58,   148,   483,   564,   299,    36,   105,   353,
  8812. -   552,   143,   610,   341,    26,    27,    -1,   199,   342,   101,
  8813. -   102,   180,    89,   520,   180,    -2,    42,   101,   102,   110,
  8814. -    42,    34,   632,   121,    37,   190,   191,   644,   265,   194,
  8815. -   110,    89,   410,    26,    27,    35,   271,   559,   215,    94,
  8816. -   611,   146,    45,   146,   106,    98,   205,   186,    26,    27,
  8817. -   344,    36,   234,   107,   232,   189,   233,   205,   553,   123,
  8818. -   633,    26,    27,   205,   562,   645,   467,   274,   -94,   319,
  8819. -   582,   319,   619,   585,   226,   333,   228,    37,    37,   264,
  8820. -   237,   337,   303,    28,   270,   454,   306,    92,   186,   305,
  8821. -   121,    36,    89,   229,    89,   231,   447,    37,   388,    95,
  8822. -   604,   180,   642,    96,   260,   261,    54,   383,   179,   216,
  8823. -   217,   488,    30,   405,   599,    98,   407,   572,    37,   351,
  8824. -    37,   279,   311,   225,   352,   150,   304,    32,   263,   210,
  8825. -   230,   110,   628,   211,   110,   110,   614,   419,   388,    57,
  8826. -   190,   618,    98,   620,   194,    26,    27,   383,   179,   438,
  8827. -   439,   329,   629,   396,   433,   123,   241,   242,   243,   434,
  8828. -   246,   247,   248,   249,   250,   251,   252,   253,   254,   255,
  8829. -   256,   257,   258,   259,   523,   651,   216,   217,   340,   151,
  8830. -   652,   459,   121,    37,   464,   653,   218,    59,   180,   478,
  8831. -    96,    37,   538,   266,   180,   200,   580,   127,   -97,   -97,
  8832. -   -97,   -97,   134,   177,   -97,   175,   -97,   -97,   -97,   319,
  8833. -   151,   308,   178,   179,   420,   387,   391,   272,   273,   475,
  8834. -   101,   102,   -97,   176,   200,   184,   313,  -296,  -296,  -296,
  8835. -  -296,   346,   347,   436,   334,  -296,  -296,  -296,   221,   443,
  8836. -   437,   166,   167,   168,    51,   444,   333,   337,    24,    25,
  8837. -   357,  -296,   358,   333,   337,   222,   349,    36,   105,   420,
  8838. -   350,   465,   101,   102,   456,   188,   411,   508,   457,   384,
  8839. -   389,   272,   273,    36,   381,   279,   -97,   189,   386,   390,
  8840. -   128,  -240,  -240,     5,    37,     7,    86,   195,   508,    36,
  8841. -   110,     9,    10,    11,   227,    36,   381,   235,   449,   240,
  8842. -    37,   398,   400,   412,   106,   -93,   389,    13,   481,   236,
  8843. -   189,   364,   211,   107,    51,    94,    37,   368,   369,    98,
  8844. -   382,   110,    37,    42,    98,   296,   458,   482,   237,   383,
  8845. -   179,    96,   450,    37,   239,   375,    38,   612,   100,   613,
  8846. -   100,  -143,   382,    62,   480,    39,   595,  -143,   438,   439,
  8847. -   211,   383,   179,   177,   137,   139,   129,  -234,   468,   384,
  8848. -   384,   408,   178,   179,   403,   295,   389,   389,   190,   194,
  8849. -   101,   102,   504,   597,   296,   190,   194,    96,   302,   429,
  8850. -   508,   440,   441,   442,   476,   477,   445,   446,  -143,   330,
  8851. -   486,   323,  -143,   504,   122,   315,    26,    27,   647,   321,
  8852. -   503,    36,   105,   322,   537,   189,   655,   455,    36,   324,
  8853. -   325,   403,   189,   327,   331,   453,   506,   343,   507,   215,
  8854. -   345,   503,   332,   336,   348,   361,   635,   636,    37,   362,
  8855. -   365,   469,   560,   539,   366,    37,   565,   100,   370,   205,
  8856. -  -143,   205,   376,   569,   574,   575,  -143,   377,   106,   484,
  8857. -   545,   547,   395,   397,   435,    38,   429,   107,   581,   485,
  8858. -  -276,   463,   -30,    51,    39,   471,   587,   473,   110,   472,
  8859. -    42,   517,   487,   524,   525,   429,   594,   -31,   429,   577,
  8860. -   527,   526,   530,   533,   531,   504,   423,  -143,   424,    27,
  8861. -   534,  -143,   535,    61,    62,   540,    63,   118,   119,   542,
  8862. -   532,    60,   548,     9,    10,    11,    61,    62,   543,    63,
  8863. -   544,   556,   558,   503,    64,   561,    65,   568,    66,    67,
  8864. -   570,   571,   586,   555,   588,    68,   429,    64,    69,    65,
  8865. -   590,    66,    67,    70,    71,    72,   638,   593,    68,    73,
  8866. -    74,    69,   591,   425,    75,   426,    70,    71,    72,   602,
  8867. -   603,   615,    73,    74,   605,   621,   625,    75,   630,   429,
  8868. -   631,   634,   429,  -171,    76,    77,   640,   427,   643,   169,
  8869. -   170,   592,   171,   172,   173,   174,   646,    76,    77,   649,
  8870. -   200,   198,  -106,  -106,  -106,  -106,  -106,  -106,  -106,   429,
  8871. -  -106,  -106,  -106,  -106,  -106,   654,  -106,  -106,  -106,  -106,
  8872. -  -106,  -106,  -106,  -106,  -106,  -106,  -106,  -106,  -106,   657,
  8873. -  -106,    23,  -106,  -106,   658,     5,    47,     7,    48,  -106,
  8874. -   380,   429,  -106,     9,    10,    11,   563,  -106,  -106,  -106,
  8875. -   460,   300,   116,  -106,  -106,   378,   130,   275,  -106,    13,
  8876. -   452,   316,   284,   224,   285,     5,     6,     7,     8,   409,
  8877. -   320,   286,   314,     9,    10,    11,  -106,  -106,  -106,  -106,
  8878. -   414,  -106,  -296,  -296,  -296,  -296,  -296,  -296,  -296,    13,
  8879. -  -296,  -296,  -296,  -296,  -296,   132,  -296,  -296,  -296,  -296,
  8880. -  -296,  -296,  -296,  -296,  -296,  -296,  -296,  -296,  -296,   461,
  8881. -  -296,   422,  -296,  -296,   466,     5,     6,     7,     8,  -296,
  8882. -   600,   393,  -296,     9,    10,    11,   601,  -296,  -296,  -296,
  8883. -   641,   639,   394,  -296,  -296,     0,   338,  -356,  -296,    13,
  8884. -     0,     0,   284,     0,     0,     5,     6,     7,     8,     0,
  8885. -     0,   286,     0,     9,    10,    11,  -296,     0,  -296,  -296,
  8886. -   200,  -296,  -296,  -296,     0,     0,     0,  -296,  -296,    13,
  8887. -  -296,     0,     0,     0,  -296,     0,  -296,  -296,  -296,  -296,
  8888. -  -296,  -296,  -296,  -296,  -296,  -296,  -296,     0,  -296,     0,
  8889. -  -296,     0,  -296,  -296,     0,     5,     6,     7,     8,  -296,
  8890. -     0,     0,  -296,     9,    10,    11,     0,  -296,  -296,  -296,
  8891. -     0,     0,     0,  -296,  -296,     0,     0,  -356,  -296,    13,
  8892. -     0,     0,     5,     0,     7,   185,   117,   118,   119,     0,
  8893. -     9,    10,    11,     9,    10,    11,  -296,  -272,  -296,  -296,
  8894. -   549,  -296,  -296,  -296,     0,     0,    13,  -296,  -296,     0,
  8895. -  -296,     0,     0,     0,  -296,     0,  -296,  -296,  -296,  -296,
  8896. -  -296,  -296,  -296,  -296,  -296,  -296,  -296,     0,  -296,     0,
  8897. -  -296,     0,  -296,  -296,    26,    27,   276,   277,   278,  -296,
  8898. -     0,     0,  -296,     0,     0,     0,     0,  -296,  -296,  -296,
  8899. -     0,     0,     0,  -296,  -296,  -242,  -242,     0,  -296,     0,
  8900. -     0,     0,     5,    47,     7,    48,     0,     0,     0,     0,
  8901. -     9,    10,    11,     0,     0,     0,  -296,     0,  -296,  -296,
  8902. -   578,  -296,  -306,  -306,     0,     0,    13,  -306,  -306,     0,
  8903. -  -306,     0,     0,     0,  -306,     0,  -306,  -306,  -306,  -306,
  8904. -  -306,  -306,  -306,  -306,  -306,  -306,  -306,     0,  -306,     0,
  8905. -  -306,     0,  -306,  -306,   164,   165,   166,   167,   168,  -306,
  8906. -     0,     0,  -306,     0,     0,     0,     0,  -306,  -306,  -306,
  8907. -     0,     0,     0,  -306,  -306,    49,     0,   145,  -306,    60,
  8908. -     5,     0,     7,    86,    61,    62,     0,    63,     9,    10,
  8909. -    11,     0,     0,     0,     0,     0,  -306,     0,  -306,  -306,
  8910. -     0,  -306,     0,     0,    13,    64,     0,    65,     0,    66,
  8911. -    67,     0,     0,     0,     0,     0,    68,   169,   170,    69,
  8912. -   171,   172,   173,   174,    70,    71,    72,     0,     0,     0,
  8913. -    73,    74,     0,     0,   423,    75,   424,    27,     0,   589,
  8914. -     0,    61,    62,     0,    63,   159,   160,   161,   162,   163,
  8915. -   164,   165,   166,   167,   168,    76,    77,     0,   -83,     0,
  8916. -     0,     0,    64,     0,    65,     0,    66,    67,     0,     0,
  8917. -     0,     0,     0,    68,     0,     0,    69,     0,     0,     0,
  8918. -     0,    70,    71,    72,     0,     0,     0,    73,    74,     0,
  8919. -     0,   425,    75,   426,   423,     0,   424,    27,     0,     0,
  8920. -     0,    61,    62,     0,    63,     0,     0,     0,     0,     0,
  8921. -     0,  -231,    76,    77,     0,   427,     0,     0,     0,     0,
  8922. -     0,     0,    64,     0,    65,     0,    66,    67,     0,     0,
  8923. -     0,     0,     0,    68,     0,     0,    69,     0,     0,     0,
  8924. -     0,    70,    71,    72,     0,     0,     0,    73,    74,     0,
  8925. -     0,   425,    75,   426,   401,     0,    60,     0,     0,     0,
  8926. -     0,    61,    62,     0,    63,    99,     0,     0,   -26,   -26,
  8927. -   -26,   -26,    76,    77,     0,   427,   -26,   -26,   -26,     0,
  8928. -     0,     0,    64,     0,    65,     0,    66,    67,     0,     0,
  8929. -     0,   100,   -26,    68,  -143,     0,    69,     0,     0,     0,
  8930. -  -143,    70,    71,    72,     0,     0,     0,    73,    74,     0,
  8931. -     0,     0,    75,   160,   161,   162,   163,   164,   165,   166,
  8932. -   167,   168,     0,   101,   102,   219,     0,     0,   -22,   -22,
  8933. -   -22,   -22,    76,    77,     0,   402,   -22,   -22,   -22,     0,
  8934. -     0,  -143,     0,     0,   213,  -143,   -26,   -18,   -18,   -18,
  8935. -   -18,   100,   -22,     0,  -143,   -18,   -18,   -18,     0,     0,
  8936. -  -143,   161,   162,   163,   164,   165,   166,   167,   168,     0,
  8937. -   100,   -18,     0,  -143,     0,     0,     0,     0,     0,  -143,
  8938. -     0,    60,     0,   101,   102,     0,    61,    62,     0,    63,
  8939. -   158,   159,   160,   161,   162,   163,   164,   165,   166,   167,
  8940. -   168,  -143,     0,     0,     0,  -143,   -22,    64,    60,    65,
  8941. -     0,    66,    67,    61,    62,     0,    63,     0,    68,     0,
  8942. -  -143,    69,     0,     0,  -143,   -18,    70,    71,    72,     0,
  8943. -     0,     0,    73,    74,    64,     0,    65,    75,    66,    67,
  8944. -     0,     0,     0,     0,     0,    68,     0,     0,    69,     0,
  8945. -     0,     0,     0,    70,    71,    72,     0,    76,    77,    73,
  8946. -    74,   269,     0,    60,    75,     0,     0,     0,    61,    62,
  8947. -     0,    63,   157,   158,   159,   160,   161,   162,   163,   164,
  8948. -   165,   166,   167,   168,    76,    77,     0,     0,   310,    64,
  8949. -    60,    65,     0,    66,    67,    61,    62,     0,    63,     0,
  8950. -    68,     0,     0,    69,     0,     0,     0,     0,    70,    71,
  8951. -    72,     0,     0,     0,    73,    74,    64,     0,    65,    75,
  8952. -    66,    67,   566,     0,     0,     0,     0,    68,     0,     0,
  8953. -    69,     0,     0,     0,     0,    70,    71,    72,     0,    76,
  8954. -    77,    73,    74,   339,     0,     0,    75,   152,   153,   154,
  8955. -   567,   155,   156,   157,   158,   159,   160,   161,   162,   163,
  8956. -   164,   165,   166,   167,   168,     0,    76,    77,     0,     0,
  8957. -   479,   424,   489,     6,     7,     8,    61,    62,     0,    63,
  8958. -     9,    10,    11,   490,     0,   491,   492,   493,   494,   495,
  8959. -   496,   497,   498,   499,   500,   501,    13,    64,     0,    65,
  8960. -     0,    66,    67,     0,     0,     0,     0,     0,    68,     0,
  8961. -     0,    69,     0,     0,     0,     0,    70,    71,    72,     0,
  8962. -     0,     0,    73,    74,     0,     0,     0,    75,     0,     0,
  8963. -     0,     5,    47,     7,    48,     0,     0,     0,     0,     9,
  8964. -    10,    11,     0,     0,     0,   502,     0,    76,    77,     0,
  8965. -   237,   424,    27,     0,     0,    13,    61,    62,     0,    63,
  8966. -     0,     0,     0,   490,     0,   491,   492,   493,   494,   495,
  8967. -   496,   497,   498,   499,   500,   501,     0,    64,     0,    65,
  8968. -     0,    66,    67,     0,     0,     0,     0,     0,    68,     0,
  8969. -     0,    69,     0,     0,     0,     0,    70,    71,    72,     0,
  8970. -     0,     0,    73,    74,   399,    60,     0,    75,     0,     0,
  8971. -    61,    62,     0,    63,   162,   163,   164,   165,   166,   167,
  8972. -   168,     0,     0,     0,     0,   502,     0,    76,    77,     0,
  8973. -   237,    64,     0,    65,     0,    66,    67,     0,     0,     0,
  8974. -     0,     0,    68,     0,     0,    69,     0,     0,     0,     0,
  8975. -    70,    71,    72,     0,     0,     0,    73,    74,     0,     0,
  8976. -     0,    75,    60,     5,     0,     7,    86,    61,    62,     0,
  8977. -    63,     9,    10,    11,     0,     0,     0,     0,     0,     0,
  8978. -     0,    76,    77,     0,   328,     0,     0,    13,    64,    60,
  8979. -    65,     0,    66,    67,    61,    62,     0,    63,     0,    68,
  8980. -     0,     0,    69,     0,     0,     0,     0,    70,    71,    72,
  8981. -     0,     0,     0,    73,    74,    64,     0,    65,    75,    66,
  8982. -    67,     0,    60,     0,     0,     0,    68,    61,    62,    69,
  8983. -    63,     0,     0,     0,    70,    71,    72,     0,    76,    77,
  8984. -    73,    74,     0,     0,     0,    75,     0,     0,    64,    60,
  8985. -    65,     0,    66,    67,    61,    62,     0,    63,     0,    68,
  8986. -     0,     0,    69,   536,     0,    76,    77,    70,    71,    72,
  8987. -     0,     0,     0,    73,    74,    64,    60,    65,    75,    66,
  8988. -    67,    61,    62,     0,    63,     0,    68,     0,     0,    69,
  8989. -     0,     0,     0,     0,    70,    71,    72,     0,    76,    77,
  8990. -    73,    74,    64,   379,    65,   136,    66,    67,    61,    62,
  8991. -     0,    63,     0,    68,     0,     0,    69,     0,     0,     0,
  8992. -     0,    70,    71,    72,     0,    76,    77,    73,    74,    64,
  8993. -     0,    65,   138,    66,    67,     0,     0,     0,     0,     0,
  8994. -    68,     0,     0,    69,     0,     0,     0,     0,    70,    71,
  8995. -    72,     0,    76,    77,    73,    74,     0,     0,     4,    75,
  8996. -  -110,     5,     6,     7,     8,     5,    47,     7,    48,     9,
  8997. -    10,    11,     0,     9,    10,    11,     0,     0,     0,    76,
  8998. -    77,     0,     0,     0,    12,    13,     0,  -110,   518,    13,
  8999. -   154,     0,   155,   156,   157,   158,   159,   160,   161,   162,
  9000. -   163,   164,   165,   166,   167,   168,     0,  -110,     0,     0,
  9001. -     0,     0,     0,   152,   153,   154,  -110,   155,   156,   157,
  9002. -   158,   159,   160,   161,   162,   163,   164,   165,   166,   167,
  9003. -   168,     0,     0,     5,    14,     7,   185,     0,   546,     0,
  9004. -     0,     9,    10,    11,   156,   157,   158,   159,   160,   161,
  9005. -   162,   163,   164,   165,   166,   167,   168,    13,     0,    37,
  9006. -     0,   519,     0,     0,     0,     0,     0,     0,     0,     0,
  9007. -     0,     0,     0,     0,     0,     0,     0,     0,     0,   177,
  9008. -     0,     0,     0,     0,     0,     0,     0,     0,   178,   179,
  9009. -   152,   153,   154,     0,   155,   156,   157,   158,   159,   160,
  9010. -   161,   162,   163,   164,   165,   166,   167,   168,    37,     0,
  9011. -     0,     0,     0,   152,   153,   154,     0,   155,   156,   157,
  9012. -   158,   159,   160,   161,   162,   163,   164,   165,   166,   167,
  9013. -   168,     0,     0,     0,     0,     0,     0,     0,   583,   152,
  9014. -   153,   154,   609,   155,   156,   157,   158,   159,   160,   161,
  9015. -   162,   163,   164,   165,   166,   167,   168,   152,   153,   154,
  9016. -     0,   155,   156,   157,   158,   159,   160,   161,   162,   163,
  9017. -   164,   165,   166,   167,   168
  9018. -};
  9019. -
  9020. -static const short yycheck[] = {    34,
  9021. -    35,    18,     9,    10,    11,    46,   103,   147,    50,   195,
  9022. -    18,     2,     3,     2,     3,   214,   111,   106,   173,    52,
  9023. -    91,   220,    39,    19,    20,   319,   110,   216,   202,    46,
  9024. -   398,    39,   268,    50,    96,   183,    20,    42,    66,    67,
  9025. -    75,   107,    50,     9,    72,    27,    53,     1,   178,   473,
  9026. -    78,    35,    32,    75,   451,   530,    10,     3,     4,     1,
  9027. -     1,    68,    38,    76,     3,     4,     0,   102,    81,    59,
  9028. -    60,    88,    56,   470,    91,     0,    93,    59,    60,    96,
  9029. -    97,    59,    38,   116,    30,    93,    76,    38,   177,    97,
  9030. -   107,    75,    38,     3,     4,    59,   180,   521,   193,   107,
  9031. -    76,   136,    77,   138,    50,   110,   203,    91,     3,     4,
  9032. -    76,     3,   140,    59,   136,     7,   138,   214,    59,   126,
  9033. -    76,     3,     4,   220,   529,    76,   420,   275,    82,   226,
  9034. -   554,   228,   607,   557,   130,   265,   132,    30,    30,   174,
  9035. -    82,   271,   208,    82,   179,    38,   212,    59,   132,   211,
  9036. -   183,     3,   136,   133,   138,   135,   392,    30,    50,    77,
  9037. -   584,   178,   637,    81,   171,   172,    82,    59,    60,    59,
  9038. -    60,   465,    82,   360,   579,   180,   363,   545,    30,    76,
  9039. -    30,   188,   217,   127,    81,    76,    76,    82,   343,    77,
  9040. -   134,   208,   616,    81,   211,   212,   601,   371,    50,    82,
  9041. -   208,   606,   207,   608,   212,     3,     4,    59,    60,    59,
  9042. -    60,   239,   617,   353,    76,   222,   151,   152,   153,    81,
  9043. -   155,   156,   157,   158,   159,   160,   161,   162,   163,   164,
  9044. -   165,   166,   167,   168,    76,    76,    59,    60,   273,    81,
  9045. -    81,   415,   275,    30,   418,   650,    77,    82,   265,   438,
  9046. -    81,    30,    50,   383,   271,     1,   550,    78,     4,     5,
  9047. -     6,     7,    78,    50,    10,     9,    12,    13,    14,   366,
  9048. -    81,   215,    59,    60,   371,   346,   347,    59,    60,   434,
  9049. -    59,    60,    28,    76,     1,    76,   221,     4,     5,     6,
  9050. -     7,   287,   288,   382,    76,    12,    13,    14,    36,   388,
  9051. -   384,    50,    51,    52,   288,   389,   436,   437,    77,    78,
  9052. -   301,    28,   301,   443,   444,    81,    77,     3,     4,   416,
  9053. -    81,   418,    59,    60,    77,    59,   367,   467,    81,   346,
  9054. -   347,    59,    60,     3,     4,   342,    82,     7,   346,   347,
  9055. -     1,    77,    78,     4,    30,     6,     7,    59,   488,     3,
  9056. -   367,    12,    13,    14,    77,     3,     4,    76,   400,    77,
  9057. -    30,   357,   358,   370,    50,    82,   383,    28,    77,    76,
  9058. -     7,   315,    81,    59,   358,   383,    30,   321,   322,   384,
  9059. -    50,   398,    30,   400,   389,    77,    78,    77,    82,    59,
  9060. -    60,    81,   400,    30,    76,   330,    50,   596,    27,   598,
  9061. -    27,    30,    50,     9,   439,    59,    77,    36,    59,    60,
  9062. -    81,    59,    60,    50,    63,    64,    77,    78,   425,   436,
  9063. -   437,   365,    59,    60,   359,    83,   443,   444,   436,   437,
  9064. -    59,    60,   467,    77,    77,   443,   444,    81,    36,   374,
  9065. -   580,   385,   386,   387,   436,   437,   390,   391,    77,    38,
  9066. -   457,    76,    81,   488,     1,    78,     3,     4,   644,    78,
  9067. -   467,     3,     4,    78,   499,     7,   652,   411,     3,    76,
  9068. -    78,   406,     7,    76,    76,   410,   467,    59,   467,   574,
  9069. -    76,   488,    83,    83,    76,    36,   626,   627,    30,    83,
  9070. -    78,   426,   527,   500,    81,    30,   531,    27,    32,   596,
  9071. -    30,   598,    83,   538,   545,   547,    36,    76,    50,   453,
  9072. -   506,   507,     3,    77,    76,    50,   451,    59,   553,   454,
  9073. -    78,    78,    38,   507,    59,    38,   561,    81,   545,    78,
  9074. -   547,    36,    78,    83,    78,   470,   571,    38,   473,   547,
  9075. -    59,   485,    59,    38,    59,   580,     1,    77,     3,     4,
  9076. -    77,    81,    77,     8,     9,     7,    11,     6,     7,    38,
  9077. -   495,     3,    16,    12,    13,    14,     8,     9,    77,    11,
  9078. -    77,    36,    78,   580,    29,    59,    31,    77,    33,    34,
  9079. -    77,    59,    76,   518,    17,    40,   521,    29,    43,    31,
  9080. -    77,    33,    34,    48,    49,    50,   631,    77,    40,    54,
  9081. -    55,    43,    76,    58,    59,    60,    48,    49,    50,    76,
  9082. -    36,    77,    54,    55,    76,     9,    77,    59,    77,   554,
  9083. -    59,    81,   557,    78,    79,    80,    77,    82,    76,    54,
  9084. -    55,   566,    57,    58,    59,    60,    76,    79,    80,    77,
  9085. -     1,    83,     3,     4,     5,     6,     7,     8,     9,   584,
  9086. -    11,    12,    13,    14,    15,    77,    17,    18,    19,    20,
  9087. -    21,    22,    23,    24,    25,    26,    27,    28,    29,     0,
  9088. -    31,     3,    33,    34,     0,     4,     5,     6,     7,    40,
  9089. -   343,   616,    43,    12,    13,    14,   530,    48,    49,    50,
  9090. -   416,   203,    51,    54,    55,   342,    56,   186,    59,    28,
  9091. -   406,   224,     1,   126,     3,     4,     5,     6,     7,   366,
  9092. -   228,    10,   222,    12,    13,    14,    77,    78,    79,    80,
  9093. -     1,    82,     3,     4,     5,     6,     7,     8,     9,    28,
  9094. -    11,    12,    13,    14,    15,    56,    17,    18,    19,    20,
  9095. -    21,    22,    23,    24,    25,    26,    27,    28,    29,   416,
  9096. -    31,   372,    33,    34,   418,     4,     5,     6,     7,    40,
  9097. -   580,    10,    43,    12,    13,    14,   580,    48,    49,    50,
  9098. -   634,   632,   350,    54,    55,    -1,   272,    76,    59,    28,
  9099. -    -1,    -1,     1,    -1,    -1,     4,     5,     6,     7,    -1,
  9100. -    -1,    10,    -1,    12,    13,    14,    77,    -1,    79,    80,
  9101. -     1,    82,     3,     4,    -1,    -1,    -1,     8,     9,    28,
  9102. -    11,    -1,    -1,    -1,    15,    -1,    17,    18,    19,    20,
  9103. -    21,    22,    23,    24,    25,    26,    27,    -1,    29,    -1,
  9104. -    31,    -1,    33,    34,    -1,     4,     5,     6,     7,    40,
  9105. -    -1,    -1,    43,    12,    13,    14,    -1,    48,    49,    50,
  9106. -    -1,    -1,    -1,    54,    55,    -1,    -1,    76,    59,    28,
  9107. -    -1,    -1,     4,    -1,     6,     7,     5,     6,     7,    -1,
  9108. -    12,    13,    14,    12,    13,    14,    77,    78,    79,    80,
  9109. -     1,    82,     3,     4,    -1,    -1,    28,     8,     9,    -1,
  9110. -    11,    -1,    -1,    -1,    15,    -1,    17,    18,    19,    20,
  9111. -    21,    22,    23,    24,    25,    26,    27,    -1,    29,    -1,
  9112. -    31,    -1,    33,    34,     3,     4,     5,     6,     7,    40,
  9113. -    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,
  9114. -    -1,    -1,    -1,    54,    55,    77,    78,    -1,    59,    -1,
  9115. -    -1,    -1,     4,     5,     6,     7,    -1,    -1,    -1,    -1,
  9116. -    12,    13,    14,    -1,    -1,    -1,    77,    -1,    79,    80,
  9117. -     1,    82,     3,     4,    -1,    -1,    28,     8,     9,    -1,
  9118. -    11,    -1,    -1,    -1,    15,    -1,    17,    18,    19,    20,
  9119. -    21,    22,    23,    24,    25,    26,    27,    -1,    29,    -1,
  9120. -    31,    -1,    33,    34,    48,    49,    50,    51,    52,    40,
  9121. -    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,
  9122. -    -1,    -1,    -1,    54,    55,    77,    -1,     1,    59,     3,
  9123. -     4,    -1,     6,     7,     8,     9,    -1,    11,    12,    13,
  9124. -    14,    -1,    -1,    -1,    -1,    -1,    77,    -1,    79,    80,
  9125. -    -1,    82,    -1,    -1,    28,    29,    -1,    31,    -1,    33,
  9126. -    34,    -1,    -1,    -1,    -1,    -1,    40,    54,    55,    43,
  9127. -    57,    58,    59,    60,    48,    49,    50,    -1,    -1,    -1,
  9128. -    54,    55,    -1,    -1,     1,    59,     3,     4,    -1,    76,
  9129. -    -1,     8,     9,    -1,    11,    43,    44,    45,    46,    47,
  9130. -    48,    49,    50,    51,    52,    79,    80,    -1,    82,    -1,
  9131. -    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,    -1,
  9132. -    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,
  9133. -    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,
  9134. -    -1,    58,    59,    60,     1,    -1,     3,     4,    -1,    -1,
  9135. -    -1,     8,     9,    -1,    11,    -1,    -1,    -1,    -1,    -1,
  9136. -    -1,    78,    79,    80,    -1,    82,    -1,    -1,    -1,    -1,
  9137. -    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,    -1,
  9138. -    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,
  9139. -    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,
  9140. -    -1,    58,    59,    60,     1,    -1,     3,    -1,    -1,    -1,
  9141. -    -1,     8,     9,    -1,    11,     1,    -1,    -1,     4,     5,
  9142. -     6,     7,    79,    80,    -1,    82,    12,    13,    14,    -1,
  9143. -    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,    -1,
  9144. -    -1,    27,    28,    40,    30,    -1,    43,    -1,    -1,    -1,
  9145. -    36,    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,
  9146. -    -1,    -1,    59,    44,    45,    46,    47,    48,    49,    50,
  9147. -    51,    52,    -1,    59,    60,     1,    -1,    -1,     4,     5,
  9148. -     6,     7,    79,    80,    -1,    82,    12,    13,    14,    -1,
  9149. -    -1,    77,    -1,    -1,     1,    81,    82,     4,     5,     6,
  9150. -     7,    27,    28,    -1,    30,    12,    13,    14,    -1,    -1,
  9151. -    36,    45,    46,    47,    48,    49,    50,    51,    52,    -1,
  9152. -    27,    28,    -1,    30,    -1,    -1,    -1,    -1,    -1,    36,
  9153. -    -1,     3,    -1,    59,    60,    -1,     8,     9,    -1,    11,
  9154. -    42,    43,    44,    45,    46,    47,    48,    49,    50,    51,
  9155. -    52,    77,    -1,    -1,    -1,    81,    82,    29,     3,    31,
  9156. -    -1,    33,    34,     8,     9,    -1,    11,    -1,    40,    -1,
  9157. -    77,    43,    -1,    -1,    81,    82,    48,    49,    50,    -1,
  9158. -    -1,    -1,    54,    55,    29,    -1,    31,    59,    33,    34,
  9159. -    -1,    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,
  9160. -    -1,    -1,    -1,    48,    49,    50,    -1,    79,    80,    54,
  9161. -    55,    83,    -1,     3,    59,    -1,    -1,    -1,     8,     9,
  9162. -    -1,    11,    41,    42,    43,    44,    45,    46,    47,    48,
  9163. -    49,    50,    51,    52,    79,    80,    -1,    -1,    83,    29,
  9164. -     3,    31,    -1,    33,    34,     8,     9,    -1,    11,    -1,
  9165. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  9166. -    50,    -1,    -1,    -1,    54,    55,    29,    -1,    31,    59,
  9167. -    33,    34,    10,    -1,    -1,    -1,    -1,    40,    -1,    -1,
  9168. -    43,    -1,    -1,    -1,    -1,    48,    49,    50,    -1,    79,
  9169. -    80,    54,    55,    83,    -1,    -1,    59,    35,    36,    37,
  9170. -    38,    39,    40,    41,    42,    43,    44,    45,    46,    47,
  9171. -    48,    49,    50,    51,    52,    -1,    79,    80,    -1,    -1,
  9172. -    83,     3,     4,     5,     6,     7,     8,     9,    -1,    11,
  9173. -    12,    13,    14,    15,    -1,    17,    18,    19,    20,    21,
  9174. -    22,    23,    24,    25,    26,    27,    28,    29,    -1,    31,
  9175. -    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,    40,    -1,
  9176. -    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,    -1,
  9177. -    -1,    -1,    54,    55,    -1,    -1,    -1,    59,    -1,    -1,
  9178. -    -1,     4,     5,     6,     7,    -1,    -1,    -1,    -1,    12,
  9179. -    13,    14,    -1,    -1,    -1,    77,    -1,    79,    80,    -1,
  9180. -    82,     3,     4,    -1,    -1,    28,     8,     9,    -1,    11,
  9181. -    -1,    -1,    -1,    15,    -1,    17,    18,    19,    20,    21,
  9182. -    22,    23,    24,    25,    26,    27,    -1,    29,    -1,    31,
  9183. -    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,    40,    -1,
  9184. -    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,    -1,
  9185. -    -1,    -1,    54,    55,    77,     3,    -1,    59,    -1,    -1,
  9186. -     8,     9,    -1,    11,    46,    47,    48,    49,    50,    51,
  9187. -    52,    -1,    -1,    -1,    -1,    77,    -1,    79,    80,    -1,
  9188. -    82,    29,    -1,    31,    -1,    33,    34,    -1,    -1,    -1,
  9189. -    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,
  9190. -    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,    -1,
  9191. -    -1,    59,     3,     4,    -1,     6,     7,     8,     9,    -1,
  9192. -    11,    12,    13,    14,    -1,    -1,    -1,    -1,    -1,    -1,
  9193. -    -1,    79,    80,    -1,    82,    -1,    -1,    28,    29,     3,
  9194. -    31,    -1,    33,    34,     8,     9,    -1,    11,    -1,    40,
  9195. -    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,
  9196. -    -1,    -1,    -1,    54,    55,    29,    -1,    31,    59,    33,
  9197. -    34,    -1,     3,    -1,    -1,    -1,    40,     8,     9,    43,
  9198. -    11,    -1,    -1,    -1,    48,    49,    50,    -1,    79,    80,
  9199. -    54,    55,    -1,    -1,    -1,    59,    -1,    -1,    29,     3,
  9200. -    31,    -1,    33,    34,     8,     9,    -1,    11,    -1,    40,
  9201. -    -1,    -1,    43,    77,    -1,    79,    80,    48,    49,    50,
  9202. -    -1,    -1,    -1,    54,    55,    29,     3,    31,    59,    33,
  9203. -    34,     8,     9,    -1,    11,    -1,    40,    -1,    -1,    43,
  9204. -    -1,    -1,    -1,    -1,    48,    49,    50,    -1,    79,    80,
  9205. -    54,    55,    29,     3,    31,    59,    33,    34,     8,     9,
  9206. -    -1,    11,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,
  9207. -    -1,    48,    49,    50,    -1,    79,    80,    54,    55,    29,
  9208. -    -1,    31,    59,    33,    34,    -1,    -1,    -1,    -1,    -1,
  9209. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  9210. -    50,    -1,    79,    80,    54,    55,    -1,    -1,     1,    59,
  9211. -     3,     4,     5,     6,     7,     4,     5,     6,     7,    12,
  9212. -    13,    14,    -1,    12,    13,    14,    -1,    -1,    -1,    79,
  9213. -    80,    -1,    -1,    -1,    27,    28,    -1,    30,    10,    28,
  9214. -    37,    -1,    39,    40,    41,    42,    43,    44,    45,    46,
  9215. -    47,    48,    49,    50,    51,    52,    -1,    50,    -1,    -1,
  9216. -    -1,    -1,    -1,    35,    36,    37,    59,    39,    40,    41,
  9217. -    42,    43,    44,    45,    46,    47,    48,    49,    50,    51,
  9218. -    52,    -1,    -1,     4,    77,     6,     7,    -1,    77,    -1,
  9219. -    -1,    12,    13,    14,    40,    41,    42,    43,    44,    45,
  9220. -    46,    47,    48,    49,    50,    51,    52,    28,    -1,    30,
  9221. -    -1,    83,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  9222. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    50,
  9223. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    59,    60,
  9224. -    35,    36,    37,    -1,    39,    40,    41,    42,    43,    44,
  9225. -    45,    46,    47,    48,    49,    50,    51,    52,    30,    -1,
  9226. -    -1,    -1,    -1,    35,    36,    37,    -1,    39,    40,    41,
  9227. -    42,    43,    44,    45,    46,    47,    48,    49,    50,    51,
  9228. -    52,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    83,    35,
  9229. -    36,    37,    38,    39,    40,    41,    42,    43,    44,    45,
  9230. -    46,    47,    48,    49,    50,    51,    52,    35,    36,    37,
  9231. -    -1,    39,    40,    41,    42,    43,    44,    45,    46,    47,
  9232. -    48,    49,    50,    51,    52
  9233. -};
  9234. -/* -*-C-*-  Note some compilers choke on comments on `#line' lines.  */
  9235. -#line 3 "/usr/local/lib/bison.simple"
  9236. -
  9237. -/* Skeleton output parser for bison,
  9238. -   Copyright (C) 1984, 1989, 1990 Bob Corbett and Richard Stallman
  9239. -
  9240. -   This program is free software; you can redistribute it and/or modify
  9241. -   it under the terms of the GNU General Public License as published by
  9242. -   the Free Software Foundation; either version 1, or (at your option)
  9243. -   any later version.
  9244. -
  9245. -   This program is distributed in the hope that it will be useful,
  9246. -   but WITHOUT ANY WARRANTY; without even the implied warranty of
  9247. -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9248. -   GNU General Public License for more details.
  9249. -
  9250. -   You should have received a copy of the GNU General Public License
  9251. -   along with this program; if not, write to the Free Software
  9252. -   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  9253. -
  9254. -
  9255. -#ifndef alloca
  9256. -#ifdef __GNUC__
  9257. -#define alloca __builtin_alloca
  9258. -#else /* not GNU C.  */
  9259. -#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi)
  9260. -#include <alloca.h>
  9261. -#else /* not sparc */
  9262. -#if defined (MSDOS) && !defined (__TURBOC__)
  9263. -#include <malloc.h>
  9264. -#else /* not MSDOS, or __TURBOC__ */
  9265. -#if defined(_AIX)
  9266. -#include <malloc.h>
  9267. - #pragma alloca
  9268. -#else /* not MSDOS, __TURBOC__, or _AIX */
  9269. -#ifdef __hpux
  9270. -#ifdef __cplusplus
  9271. -extern "C" {
  9272. -void *alloca (unsigned int);
  9273. -};
  9274. -#else /* not __cplusplus */
  9275. -void *alloca ();
  9276. -#endif /* not __cplusplus */
  9277. -#endif /* __hpux */
  9278. -#endif /* not _AIX */
  9279. -#endif /* not MSDOS, or __TURBOC__ */
  9280. -#endif /* not sparc.  */
  9281. -#endif /* not GNU C.  */
  9282. -#endif /* alloca not defined.  */
  9283. -
  9284. -/* This is the parser code that is written into each bison parser
  9285. -  when the %semantic_parser declaration is not specified in the grammar.
  9286. -  It was written by Richard Stallman by simplifying the hairy parser
  9287. -  used when %semantic_parser is specified.  */
  9288. -
  9289. -/* Note: there must be only one dollar sign in this file.
  9290. -   It is replaced by the list of actions, each action
  9291. -   as one case of the switch.  */
  9292. -
  9293. -#define yyerrok        (yyerrstatus = 0)
  9294. -#define yyclearin    (yychar = YYEMPTY)
  9295. -#define YYEMPTY        -2
  9296. -#define YYEOF        0
  9297. -#define YYACCEPT    return(0)
  9298. -#define YYABORT     return(1)
  9299. -#define YYERROR        goto yyerrlab1
  9300. -/* Like YYERROR except do call yyerror.
  9301. -   This remains here temporarily to ease the
  9302. -   transition to the new meaning of YYERROR, for GCC.
  9303. -   Once GCC version 2 has supplanted version 1, this can go.  */
  9304. -#define YYFAIL        goto yyerrlab
  9305. -#define YYRECOVERING()  (!!yyerrstatus)
  9306. -#define YYBACKUP(token, value) \
  9307. -do                                \
  9308. -  if (yychar == YYEMPTY && yylen == 1)                \
  9309. -    { yychar = (token), yylval = (value);            \
  9310. -      yychar1 = YYTRANSLATE (yychar);                \
  9311. -      YYPOPSTACK;                        \
  9312. -      goto yybackup;                        \
  9313. -    }                                \
  9314. -  else                                \
  9315. -    { yyerror ("syntax error: cannot back up"); YYERROR; }    \
  9316. -while (0)
  9317. -
  9318. -#define YYTERROR    1
  9319. -#define YYERRCODE    256
  9320. -
  9321. -#ifndef YYPURE
  9322. -#define YYLEX        yylex()
  9323. -#endif
  9324. -
  9325. -#ifdef YYPURE
  9326. -#ifdef YYLSP_NEEDED
  9327. -#define YYLEX        yylex(&yylval, &yylloc)
  9328. -#else
  9329. -#define YYLEX        yylex(&yylval)
  9330. -#endif
  9331. -#endif
  9332. -
  9333. -/* If nonreentrant, generate the variables here */
  9334. -
  9335. -#ifndef YYPURE
  9336. -
  9337. -int    yychar;            /*  the lookahead symbol        */
  9338. -YYSTYPE    yylval;            /*  the semantic value of the        */
  9339. -                /*  lookahead symbol            */
  9340. -
  9341. -#ifdef YYLSP_NEEDED
  9342. -YYLTYPE yylloc;            /*  location data for the lookahead    */
  9343. -                /*  symbol                */
  9344. -#endif
  9345. -
  9346. -int yynerrs;            /*  number of parse errors so far       */
  9347. -#endif  /* not YYPURE */
  9348. -
  9349. -#if YYDEBUG != 0
  9350. -int yydebug;            /*  nonzero means print parse trace    */
  9351. -/* Since this is uninitialized, it does not stop multiple parsers
  9352. -   from coexisting.  */
  9353. -#endif
  9354. -
  9355. -/*  YYINITDEPTH indicates the initial size of the parser's stacks    */
  9356. -
  9357. -#ifndef    YYINITDEPTH
  9358. -#define YYINITDEPTH 200
  9359. -#endif
  9360. -
  9361. -/*  YYMAXDEPTH is the maximum size the stacks can grow to
  9362. -    (effective only if the built-in stack extension method is used).  */
  9363. -
  9364. -#if YYMAXDEPTH == 0
  9365. -#undef YYMAXDEPTH
  9366. -#endif
  9367. -
  9368. -#ifndef YYMAXDEPTH
  9369. -#define YYMAXDEPTH 10000
  9370. -#endif
  9371. -
  9372. -/* Prevent warning if -Wstrict-prototypes.  */
  9373. -#ifdef __GNUC__
  9374. -int yyparse (void);
  9375. -#endif
  9376. -
  9377. -#if __GNUC__ > 1        /* GNU C and GNU C++ define this.  */
  9378. -#define __yy_bcopy(FROM,TO,COUNT)    __builtin_memcpy(TO,FROM,COUNT)
  9379. -#else                /* not GNU C or C++ */
  9380. -#ifndef __cplusplus
  9381. -
  9382. -/* This is the most reliable way to avoid incompatibilities
  9383. -   in available built-in functions on various systems.  */
  9384. -static void
  9385. -__yy_bcopy (from, to, count)
  9386. -     char *from;
  9387. -     char *to;
  9388. -     int count;
  9389. -{
  9390. -  register char *f = from;
  9391. -  register char *t = to;
  9392. -  register int i = count;
  9393. -
  9394. -  while (i-- > 0)
  9395. -    *t++ = *f++;
  9396. -}
  9397. -
  9398. -#else /* __cplusplus */
  9399. -
  9400. -/* This is the most reliable way to avoid incompatibilities
  9401. -   in available built-in functions on various systems.  */
  9402. -static void
  9403. -__yy_bcopy (char *from, char *to, int count)
  9404. -{
  9405. -  register char *f = from;
  9406. -  register char *t = to;
  9407. -  register int i = count;
  9408. -
  9409. -  while (i-- > 0)
  9410. -    *t++ = *f++;
  9411. -}
  9412. -
  9413. -#endif
  9414. -#endif
  9415. -
  9416. -#line 184 "/usr/local/lib/bison.simple"
  9417. -
  9418. -/* The user can define YYPARSE_PARAM as the name of an argument to be passed
  9419. -   into yyparse.  The argument should have type void *.
  9420. -   It should actually point to an object.
  9421. -   Grammar actions can access the variable by casting it
  9422. -   to the proper pointer type.  */
  9423. -
  9424. -#ifdef YYPARSE_PARAM
  9425. -#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;
  9426. -#else
  9427. -#define YYPARSE_PARAM
  9428. -#define YYPARSE_PARAM_DECL
  9429. -#endif
  9430. -
  9431. -int
  9432. -yyparse(YYPARSE_PARAM)
  9433. -     YYPARSE_PARAM_DECL
  9434. -{
  9435. -  register int yystate;
  9436. -  register int yyn;
  9437. -  register short *yyssp;
  9438. -  register YYSTYPE *yyvsp;
  9439. -  int yyerrstatus;    /*  number of tokens to shift before error messages enabled */
  9440. -  int yychar1 = 0;        /*  lookahead token as an internal (translated) token number */
  9441. -
  9442. -  short    yyssa[YYINITDEPTH];    /*  the state stack            */
  9443. -  YYSTYPE yyvsa[YYINITDEPTH];    /*  the semantic value stack        */
  9444. -
  9445. -  short *yyss = yyssa;        /*  refer to the stacks thru separate pointers */
  9446. -  YYSTYPE *yyvs = yyvsa;    /*  to allow yyoverflow to reallocate them elsewhere */
  9447. -
  9448. -#ifdef YYLSP_NEEDED
  9449. -  YYLTYPE yylsa[YYINITDEPTH];    /*  the location stack            */
  9450. -  YYLTYPE *yyls = yylsa;
  9451. -  YYLTYPE *yylsp;
  9452. -
  9453. -#define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--)
  9454. -#else
  9455. -#define YYPOPSTACK   (yyvsp--, yyssp--)
  9456. -#endif
  9457. -
  9458. -  int yystacksize = YYINITDEPTH;
  9459. -
  9460. -#ifdef YYPURE
  9461. -  int yychar;
  9462. -  YYSTYPE yylval;
  9463. -  int yynerrs;
  9464. -#ifdef YYLSP_NEEDED
  9465. -  YYLTYPE yylloc;
  9466. -#endif
  9467. -#endif
  9468. -
  9469. -  YYSTYPE yyval;        /*  the variable used to return        */
  9470. -                /*  semantic values from the action    */
  9471. -                /*  routines                */
  9472. -
  9473. -  int yylen;
  9474. -
  9475. -#if YYDEBUG != 0
  9476. -  if (yydebug)
  9477. -    fprintf(stderr, "Starting parse\n");
  9478. -#endif
  9479. -
  9480. -  yystate = 0;
  9481. -  yyerrstatus = 0;
  9482. -  yynerrs = 0;
  9483. -  yychar = YYEMPTY;        /* Cause a token to be read.  */
  9484. -
  9485. -  /* Initialize stack pointers.
  9486. -     Waste one element of value and location stack
  9487. -     so that they stay on the same level as the state stack.
  9488. -     The wasted elements are never initialized.  */
  9489. -
  9490. -  yyssp = yyss - 1;
  9491. -  yyvsp = yyvs;
  9492. -#ifdef YYLSP_NEEDED
  9493. -  yylsp = yyls;
  9494. -#endif
  9495. -
  9496. -/* Push a new state, which is found in  yystate  .  */
  9497. -/* In all cases, when you get here, the value and location stacks
  9498. -   have just been pushed. so pushing a state here evens the stacks.  */
  9499. -yynewstate:
  9500. -
  9501. -  *++yyssp = yystate;
  9502. -
  9503. -  if (yyssp >= yyss + yystacksize - 1)
  9504. -    {
  9505. -      /* Give user a chance to reallocate the stack */
  9506. -      /* Use copies of these so that the &'s don't force the real ones into memory. */
  9507. -      YYSTYPE *yyvs1 = yyvs;
  9508. -      short *yyss1 = yyss;
  9509. -#ifdef YYLSP_NEEDED
  9510. -      YYLTYPE *yyls1 = yyls;
  9511. -#endif
  9512. -
  9513. -      /* Get the current used size of the three stacks, in elements.  */
  9514. -      int size = yyssp - yyss + 1;
  9515. -
  9516. -#ifdef yyoverflow
  9517. -      /* Each stack pointer address is followed by the size of
  9518. -     the data in use in that stack, in bytes.  */
  9519. -#ifdef YYLSP_NEEDED
  9520. -      /* This used to be a conditional around just the two extra args,
  9521. -     but that might be undefined if yyoverflow is a macro.  */
  9522. -      yyoverflow("parser stack overflow",
  9523. -         &yyss1, size * sizeof (*yyssp),
  9524. -         &yyvs1, size * sizeof (*yyvsp),
  9525. -         &yyls1, size * sizeof (*yylsp),
  9526. -         &yystacksize);
  9527. -#else
  9528. -      yyoverflow("parser stack overflow",
  9529. -         &yyss1, size * sizeof (*yyssp),
  9530. -         &yyvs1, size * sizeof (*yyvsp),
  9531. -         &yystacksize);
  9532. -#endif
  9533. -
  9534. -      yyss = yyss1; yyvs = yyvs1;
  9535. -#ifdef YYLSP_NEEDED
  9536. -      yyls = yyls1;
  9537. -#endif
  9538. -#else /* no yyoverflow */
  9539. -      /* Extend the stack our own way.  */
  9540. -      if (yystacksize >= YYMAXDEPTH)
  9541. -    {
  9542. -      yyerror("parser stack overflow");
  9543. -      return 2;
  9544. -    }
  9545. -      yystacksize *= 2;
  9546. -      if (yystacksize > YYMAXDEPTH)
  9547. -    yystacksize = YYMAXDEPTH;
  9548. -      yyss = (short *) alloca (yystacksize * sizeof (*yyssp));
  9549. -      __yy_bcopy ((char *)yyss1, (char *)yyss, size * sizeof (*yyssp));
  9550. -      yyvs = (YYSTYPE *) alloca (yystacksize * sizeof (*yyvsp));
  9551. -      __yy_bcopy ((char *)yyvs1, (char *)yyvs, size * sizeof (*yyvsp));
  9552. -#ifdef YYLSP_NEEDED
  9553. -      yyls = (YYLTYPE *) alloca (yystacksize * sizeof (*yylsp));
  9554. -      __yy_bcopy ((char *)yyls1, (char *)yyls, size * sizeof (*yylsp));
  9555. -#endif
  9556. -#endif /* no yyoverflow */
  9557. -
  9558. -      yyssp = yyss + size - 1;
  9559. -      yyvsp = yyvs + size - 1;
  9560. -#ifdef YYLSP_NEEDED
  9561. -      yylsp = yyls + size - 1;
  9562. -#endif
  9563. -
  9564. -#if YYDEBUG != 0
  9565. -      if (yydebug)
  9566. -    fprintf(stderr, "Stack size increased to %d\n", yystacksize);
  9567. -#endif
  9568. -
  9569. -      if (yyssp >= yyss + yystacksize - 1)
  9570. -    YYABORT;
  9571. -    }
  9572. -
  9573. -#if YYDEBUG != 0
  9574. -  if (yydebug)
  9575. -    fprintf(stderr, "Entering state %d\n", yystate);
  9576. -#endif
  9577. -
  9578. -  goto yybackup;
  9579. - yybackup:
  9580. -
  9581. -/* Do appropriate processing given the current state.  */
  9582. -/* Read a lookahead token if we need one and don't already have one.  */
  9583. -/* yyresume: */
  9584. -
  9585. -  /* First try to decide what to do without reference to lookahead token.  */
  9586. -
  9587. -  yyn = yypact[yystate];
  9588. -  if (yyn == YYFLAG)
  9589. -    goto yydefault;
  9590. -
  9591. -  /* Not known => get a lookahead token if don't already have one.  */
  9592. -
  9593. -  /* yychar is either YYEMPTY or YYEOF
  9594. -     or a valid token in external form.  */
  9595. -
  9596. -  if (yychar == YYEMPTY)
  9597. -    {
  9598. -#if YYDEBUG != 0
  9599. -      if (yydebug)
  9600. -    fprintf(stderr, "Reading a token: ");
  9601. -#endif
  9602. -      yychar = YYLEX;
  9603. -    }
  9604. -
  9605. -  /* Convert token to internal form (in yychar1) for indexing tables with */
  9606. -
  9607. -  if (yychar <= 0)        /* This means end of input. */
  9608. -    {
  9609. -      yychar1 = 0;
  9610. -      yychar = YYEOF;        /* Don't call YYLEX any more */
  9611. -
  9612. -#if YYDEBUG != 0
  9613. -      if (yydebug)
  9614. -    fprintf(stderr, "Now at end of input.\n");
  9615. -#endif
  9616. -    }
  9617. -  else
  9618. -    {
  9619. -      yychar1 = YYTRANSLATE(yychar);
  9620. -
  9621. -#if YYDEBUG != 0
  9622. -      if (yydebug)
  9623. -    {
  9624. -      fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]);
  9625. -      /* Give the individual parser a way to print the precise meaning
  9626. -         of a token, for further debugging info.  */
  9627. -#ifdef YYPRINT
  9628. -      YYPRINT (stderr, yychar, yylval);
  9629. -#endif
  9630. -      fprintf (stderr, ")\n");
  9631. -    }
  9632. -#endif
  9633. -    }
  9634. -
  9635. -  yyn += yychar1;
  9636. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1)
  9637. -    goto yydefault;
  9638. -
  9639. -  yyn = yytable[yyn];
  9640. -
  9641. -  /* yyn is what to do for this token type in this state.
  9642. -     Negative => reduce, -yyn is rule number.
  9643. -     Positive => shift, yyn is new state.
  9644. -       New state is final state => don't bother to shift,
  9645. -       just return success.
  9646. -     0, or most negative number => error.  */
  9647. -
  9648. -  if (yyn < 0)
  9649. -    {
  9650. -      if (yyn == YYFLAG)
  9651. -    goto yyerrlab;
  9652. -      yyn = -yyn;
  9653. -      goto yyreduce;
  9654. -    }
  9655. -  else if (yyn == 0)
  9656. -    goto yyerrlab;
  9657. -
  9658. -  if (yyn == YYFINAL)
  9659. -    YYACCEPT;
  9660. -
  9661. -  /* Shift the lookahead token.  */
  9662. -
  9663. -#if YYDEBUG != 0
  9664. -  if (yydebug)
  9665. -    fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]);
  9666. -#endif
  9667. -
  9668. -  /* Discard the token being shifted unless it is eof.  */
  9669. -  if (yychar != YYEOF)
  9670. -    yychar = YYEMPTY;
  9671. -
  9672. -  *++yyvsp = yylval;
  9673. -#ifdef YYLSP_NEEDED
  9674. -  *++yylsp = yylloc;
  9675. -#endif
  9676. -
  9677. -  /* count tokens shifted since error; after three, turn off error status.  */
  9678. -  if (yyerrstatus) yyerrstatus--;
  9679. -
  9680. -  yystate = yyn;
  9681. -  goto yynewstate;
  9682. -
  9683. -/* Do the default action for the current state.  */
  9684. -yydefault:
  9685. -
  9686. -  yyn = yydefact[yystate];
  9687. -  if (yyn == 0)
  9688. -    goto yyerrlab;
  9689. -
  9690. -/* Do a reduction.  yyn is the number of a rule to reduce with.  */
  9691. -yyreduce:
  9692. -  yylen = yyr2[yyn];
  9693. -  if (yylen > 0)
  9694. -    yyval = yyvsp[1-yylen]; /* implement default value of the action */
  9695. -
  9696. -#if YYDEBUG != 0
  9697. -  if (yydebug)
  9698. -    {
  9699. -      int i;
  9700. -
  9701. -      fprintf (stderr, "Reducing via rule %d (line %d), ",
  9702. -           yyn, yyrline[yyn]);
  9703. -
  9704. -      /* Print the symbols being reduced, and their result.  */
  9705. -      for (i = yyprhs[yyn]; yyrhs[i] > 0; i++)
  9706. -    fprintf (stderr, "%s ", yytname[yyrhs[i]]);
  9707. -      fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]);
  9708. -    }
  9709. -#endif
  9710. -
  9711. -
  9712. -  switch (yyn) {
  9713. -
  9714. -case 1:
  9715. -#line 234 "c-parse.y"
  9716. -{ if (pedantic)
  9717. -            pedwarn ("ANSI C forbids an empty source file");
  9718. -          finish_file ();
  9719. -        ;
  9720. -    break;}
  9721. -case 2:
  9722. -#line 239 "c-parse.y"
  9723. -{
  9724. -          /* In case there were missing closebraces,
  9725. -             get us back to the global binding level.  */
  9726. -          while (! global_bindings_p ())
  9727. -            poplevel (0, 0, 0);
  9728. -          finish_file ();
  9729. -        ;
  9730. -    break;}
  9731. -case 3:
  9732. -#line 253 "c-parse.y"
  9733. -{yyval.ttype = NULL_TREE; ;
  9734. -    break;}
  9735. -case 5:
  9736. -#line 254 "c-parse.y"
  9737. -{yyval.ttype = NULL_TREE; ;
  9738. -    break;}
  9739. -case 9:
  9740. -#line 261 "c-parse.y"
  9741. -{ STRIP_NOPS (yyvsp[-2].ttype);
  9742. -          if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR
  9743. -               && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST)
  9744. -              || TREE_CODE (yyvsp[-2].ttype) == STRING_CST)
  9745. -            assemble_asm (yyvsp[-2].ttype);
  9746. -          else
  9747. -            error ("argument of `asm' is not a constant string"); ;
  9748. -    break;}
  9749. -case 10:
  9750. -#line 272 "c-parse.y"
  9751. -{ if (pedantic)
  9752. -            error ("ANSI C forbids data definition with no type or storage class");
  9753. -          else if (!flag_traditional)
  9754. -            warning ("data definition has no type or storage class"); 
  9755. -
  9756. -          current_declspecs = TREE_VALUE (declspec_stack);
  9757. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9758. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9759. -          resume_momentary (yyvsp[-2].itype); ;
  9760. -    break;}
  9761. -case 11:
  9762. -#line 282 "c-parse.y"
  9763. -{ current_declspecs = TREE_VALUE (declspec_stack);
  9764. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9765. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9766. -          resume_momentary (yyvsp[-2].itype); ;
  9767. -    break;}
  9768. -case 12:
  9769. -#line 287 "c-parse.y"
  9770. -{ current_declspecs = TREE_VALUE (declspec_stack);
  9771. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9772. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9773. -          resume_momentary (yyvsp[-2].itype);  ;
  9774. -    break;}
  9775. -case 13:
  9776. -#line 292 "c-parse.y"
  9777. -{ pedwarn ("empty declaration"); ;
  9778. -    break;}
  9779. -case 14:
  9780. -#line 294 "c-parse.y"
  9781. -{ shadow_tag (yyvsp[-1].ttype); ;
  9782. -    break;}
  9783. -case 17:
  9784. -#line 298 "c-parse.y"
  9785. -{ if (pedantic)
  9786. -            pedwarn ("ANSI C does not allow extra `;' outside of a function"); ;
  9787. -    break;}
  9788. -case 18:
  9789. -#line 304 "c-parse.y"
  9790. -{ if (! start_function (yyvsp[-2].ttype, yyvsp[0].ttype, prefix_attributes,
  9791. -                    NULL_TREE, 0))
  9792. -            YYERROR1;
  9793. -          reinit_parse_for_function (); ;
  9794. -    break;}
  9795. -case 19:
  9796. -#line 309 "c-parse.y"
  9797. -{ store_parm_decls (); ;
  9798. -    break;}
  9799. -case 20:
  9800. -#line 311 "c-parse.y"
  9801. -{ finish_function (0); 
  9802. -          current_declspecs = TREE_VALUE (declspec_stack);
  9803. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9804. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9805. -          resume_momentary (yyvsp[-5].itype); ;
  9806. -    break;}
  9807. -case 21:
  9808. -#line 317 "c-parse.y"
  9809. -{ current_declspecs = TREE_VALUE (declspec_stack);
  9810. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9811. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9812. -          resume_momentary (yyvsp[-2].itype); ;
  9813. -    break;}
  9814. -case 22:
  9815. -#line 322 "c-parse.y"
  9816. -{ if (! start_function (yyvsp[-2].ttype, yyvsp[0].ttype, prefix_attributes,
  9817. -                    NULL_TREE, 0))
  9818. -            YYERROR1;
  9819. -          reinit_parse_for_function (); ;
  9820. -    break;}
  9821. -case 23:
  9822. -#line 327 "c-parse.y"
  9823. -{ store_parm_decls (); ;
  9824. -    break;}
  9825. -case 24:
  9826. -#line 329 "c-parse.y"
  9827. -{ finish_function (0); 
  9828. -          current_declspecs = TREE_VALUE (declspec_stack);
  9829. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9830. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9831. -          resume_momentary (yyvsp[-5].itype); ;
  9832. -    break;}
  9833. -case 25:
  9834. -#line 335 "c-parse.y"
  9835. -{ current_declspecs = TREE_VALUE (declspec_stack);
  9836. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9837. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9838. -          resume_momentary (yyvsp[-2].itype); ;
  9839. -    break;}
  9840. -case 26:
  9841. -#line 340 "c-parse.y"
  9842. -{ if (! start_function (NULL_TREE, yyvsp[0].ttype,
  9843. -                    prefix_attributes, NULL_TREE, 0))
  9844. -            YYERROR1;
  9845. -          reinit_parse_for_function (); ;
  9846. -    break;}
  9847. -case 27:
  9848. -#line 345 "c-parse.y"
  9849. -{ store_parm_decls (); ;
  9850. -    break;}
  9851. -case 28:
  9852. -#line 347 "c-parse.y"
  9853. -{ finish_function (0); 
  9854. -          current_declspecs = TREE_VALUE (declspec_stack);
  9855. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9856. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9857. -          resume_momentary (yyvsp[-5].itype); ;
  9858. -    break;}
  9859. -case 29:
  9860. -#line 353 "c-parse.y"
  9861. -{ current_declspecs = TREE_VALUE (declspec_stack);
  9862. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  9863. -          declspec_stack = TREE_CHAIN (declspec_stack);
  9864. -          resume_momentary (yyvsp[-2].itype); ;
  9865. -    break;}
  9866. -case 32:
  9867. -#line 365 "c-parse.y"
  9868. -{ yyval.code = ADDR_EXPR; ;
  9869. -    break;}
  9870. -case 33:
  9871. -#line 367 "c-parse.y"
  9872. -{ yyval.code = NEGATE_EXPR; ;
  9873. -    break;}
  9874. -case 34:
  9875. -#line 369 "c-parse.y"
  9876. -{ yyval.code = CONVERT_EXPR; ;
  9877. -    break;}
  9878. -case 35:
  9879. -#line 371 "c-parse.y"
  9880. -{ yyval.code = PREINCREMENT_EXPR; ;
  9881. -    break;}
  9882. -case 36:
  9883. -#line 373 "c-parse.y"
  9884. -{ yyval.code = PREDECREMENT_EXPR; ;
  9885. -    break;}
  9886. -case 37:
  9887. -#line 375 "c-parse.y"
  9888. -{ yyval.code = BIT_NOT_EXPR; ;
  9889. -    break;}
  9890. -case 38:
  9891. -#line 377 "c-parse.y"
  9892. -{ yyval.code = TRUTH_NOT_EXPR; ;
  9893. -    break;}
  9894. -case 39:
  9895. -#line 381 "c-parse.y"
  9896. -{ yyval.ttype = build_compound_expr (yyvsp[0].ttype); ;
  9897. -    break;}
  9898. -case 40:
  9899. -#line 386 "c-parse.y"
  9900. -{ yyval.ttype = NULL_TREE; ;
  9901. -    break;}
  9902. -case 42:
  9903. -#line 392 "c-parse.y"
  9904. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  9905. -    break;}
  9906. -case 43:
  9907. -#line 394 "c-parse.y"
  9908. -{ chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  9909. -    break;}
  9910. -case 45:
  9911. -#line 400 "c-parse.y"
  9912. -{ yyval.ttype = build_indirect_ref (yyvsp[0].ttype, "unary *"); ;
  9913. -    break;}
  9914. -case 46:
  9915. -#line 403 "c-parse.y"
  9916. -{ yyvsp[0].itype = pedantic;
  9917. -          pedantic = 0; ;
  9918. -    break;}
  9919. -case 47:
  9920. -#line 406 "c-parse.y"
  9921. -{ yyval.ttype = yyvsp[0].ttype;
  9922. -          pedantic = yyvsp[-2].itype; ;
  9923. -    break;}
  9924. -case 48:
  9925. -#line 409 "c-parse.y"
  9926. -{ yyval.ttype = build_unary_op (yyvsp[-1].code, yyvsp[0].ttype, 0);
  9927. -          overflow_warning (yyval.ttype); ;
  9928. -    break;}
  9929. -case 49:
  9930. -#line 413 "c-parse.y"
  9931. -{ tree label = lookup_label (yyvsp[0].ttype);
  9932. -          if (pedantic)
  9933. -            pedwarn ("ANSI C forbids `&&'");
  9934. -          if (label == 0)
  9935. -            yyval.ttype = null_pointer_node;
  9936. -          else
  9937. -            {
  9938. -              TREE_USED (label) = 1;
  9939. -              yyval.ttype = build1 (ADDR_EXPR, ptr_type_node, label);
  9940. -              TREE_CONSTANT (yyval.ttype) = 1;
  9941. -            }
  9942. -        ;
  9943. -    break;}
  9944. -case 50:
  9945. -#line 441 "c-parse.y"
  9946. -{ if (TREE_CODE (yyvsp[0].ttype) == COMPONENT_REF
  9947. -              && DECL_BIT_FIELD (TREE_OPERAND (yyvsp[0].ttype, 1)))
  9948. -            error ("`sizeof' applied to a bit-field");
  9949. -          yyval.ttype = c_sizeof (TREE_TYPE (yyvsp[0].ttype)); ;
  9950. -    break;}
  9951. -case 51:
  9952. -#line 446 "c-parse.y"
  9953. -{ yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ttype)); ;
  9954. -    break;}
  9955. -case 52:
  9956. -#line 448 "c-parse.y"
  9957. -{ yyval.ttype = c_alignof_expr (yyvsp[0].ttype); ;
  9958. -    break;}
  9959. -case 53:
  9960. -#line 450 "c-parse.y"
  9961. -{ yyval.ttype = c_alignof (groktypename (yyvsp[-1].ttype)); ;
  9962. -    break;}
  9963. -case 54:
  9964. -#line 452 "c-parse.y"
  9965. -{ yyval.ttype = build_unary_op (REALPART_EXPR, yyvsp[0].ttype, 0); ;
  9966. -    break;}
  9967. -case 55:
  9968. -#line 454 "c-parse.y"
  9969. -{ yyval.ttype = build_unary_op (IMAGPART_EXPR, yyvsp[0].ttype, 0); ;
  9970. -    break;}
  9971. -case 57:
  9972. -#line 460 "c-parse.y"
  9973. -{ tree type = groktypename (yyvsp[-2].ttype);
  9974. -          yyval.ttype = build_c_cast (type, yyvsp[0].ttype); ;
  9975. -    break;}
  9976. -case 58:
  9977. -#line 463 "c-parse.y"
  9978. -{ start_init (NULL_TREE, NULL, 0);
  9979. -          yyvsp[-2].ttype = groktypename (yyvsp[-2].ttype);
  9980. -          really_start_incremental_init (yyvsp[-2].ttype); ;
  9981. -    break;}
  9982. -case 59:
  9983. -#line 467 "c-parse.y"
  9984. -{ char *name;
  9985. -          tree result = pop_init_level (0);
  9986. -          tree type = yyvsp[-5].ttype;
  9987. -          finish_init ();
  9988. -
  9989. -          if (pedantic)
  9990. -            pedwarn ("ANSI C forbids constructor expressions");
  9991. -          if (TYPE_NAME (type) != 0)
  9992. -            {
  9993. -              if (TREE_CODE (TYPE_NAME (type)) == IDENTIFIER_NODE)
  9994. -            name = IDENTIFIER_POINTER (TYPE_NAME (type));
  9995. -              else
  9996. -            name = IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type)));
  9997. -            }
  9998. -          else
  9999. -            name = "";
  10000. -          yyval.ttype = result;
  10001. -          if (TREE_CODE (type) == ARRAY_TYPE && TYPE_SIZE (type) == 0)
  10002. -            {
  10003. -              int failure = complete_array_type (type, yyval.ttype, 1);
  10004. -              if (failure)
  10005. -            abort ();
  10006. -            }
  10007. -        ;
  10008. -    break;}
  10009. -case 61:
  10010. -#line 496 "c-parse.y"
  10011. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10012. -    break;}
  10013. -case 62:
  10014. -#line 498 "c-parse.y"
  10015. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10016. -    break;}
  10017. -case 63:
  10018. -#line 500 "c-parse.y"
  10019. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10020. -    break;}
  10021. -case 64:
  10022. -#line 502 "c-parse.y"
  10023. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10024. -    break;}
  10025. -case 65:
  10026. -#line 504 "c-parse.y"
  10027. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10028. -    break;}
  10029. -case 66:
  10030. -#line 506 "c-parse.y"
  10031. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10032. -    break;}
  10033. -case 67:
  10034. -#line 508 "c-parse.y"
  10035. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10036. -    break;}
  10037. -case 68:
  10038. -#line 510 "c-parse.y"
  10039. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10040. -    break;}
  10041. -case 69:
  10042. -#line 512 "c-parse.y"
  10043. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10044. -    break;}
  10045. -case 70:
  10046. -#line 514 "c-parse.y"
  10047. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10048. -    break;}
  10049. -case 71:
  10050. -#line 516 "c-parse.y"
  10051. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10052. -    break;}
  10053. -case 72:
  10054. -#line 518 "c-parse.y"
  10055. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10056. -    break;}
  10057. -case 73:
  10058. -#line 520 "c-parse.y"
  10059. -{ yyval.ttype = parser_build_binary_op (TRUTH_ANDIF_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10060. -    break;}
  10061. -case 74:
  10062. -#line 522 "c-parse.y"
  10063. -{ yyval.ttype = parser_build_binary_op (TRUTH_ORIF_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10064. -    break;}
  10065. -case 75:
  10066. -#line 524 "c-parse.y"
  10067. -{ yyval.ttype = build_conditional_expr (yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10068. -    break;}
  10069. -case 76:
  10070. -#line 526 "c-parse.y"
  10071. -{ yyval.ttype = build_modify_expr (yyvsp[-2].ttype, NOP_EXPR, yyvsp[0].ttype);
  10072. -          C_SET_EXP_ORIGINAL_CODE (yyval.ttype, MODIFY_EXPR); ;
  10073. -    break;}
  10074. -case 77:
  10075. -#line 529 "c-parse.y"
  10076. -{ yyval.ttype = build_modify_expr (yyvsp[-2].ttype, yyvsp[-1].code, yyvsp[0].ttype);
  10077. -          /* This inhibits warnings in truthvalue_conversion.  */
  10078. -          C_SET_EXP_ORIGINAL_CODE (yyval.ttype, ERROR_MARK); ;
  10079. -    break;}
  10080. -case 78:
  10081. -#line 536 "c-parse.y"
  10082. -{
  10083. -          yyval.ttype = lastiddecl;
  10084. -          if (!yyval.ttype || yyval.ttype == error_mark_node)
  10085. -            {
  10086. -              if (yychar == YYEMPTY)
  10087. -            yychar = YYLEX;
  10088. -              if (yychar == '(')
  10089. -            {
  10090. -                {
  10091. -                  /* Ordinary implicit function declaration.  */
  10092. -                  yyval.ttype = implicitly_declare (yyvsp[0].ttype);
  10093. -                  assemble_external (yyval.ttype);
  10094. -                  TREE_USED (yyval.ttype) = 1;
  10095. -                }
  10096. -            }
  10097. -              else if (current_function_decl == 0)
  10098. -            {
  10099. -              error ("`%s' undeclared here (not in a function)",
  10100. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  10101. -              yyval.ttype = error_mark_node;
  10102. -            }
  10103. -              else
  10104. -            {
  10105. -                {
  10106. -                  if (IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) != error_mark_node
  10107. -                  || IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) != current_function_decl)
  10108. -                {
  10109. -                  error ("`%s' undeclared (first use this function)",
  10110. -                     IDENTIFIER_POINTER (yyvsp[0].ttype));
  10111. -
  10112. -                  if (! undeclared_variable_notice)
  10113. -                    {
  10114. -                      error ("(Each undeclared identifier is reported only once");
  10115. -                      error ("for each function it appears in.)");
  10116. -                      undeclared_variable_notice = 1;
  10117. -                    }
  10118. -                }
  10119. -                  yyval.ttype = error_mark_node;
  10120. -                  /* Prevent repeated error messages.  */
  10121. -                  IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) = error_mark_node;
  10122. -                  IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) = current_function_decl;
  10123. -                }
  10124. -            }
  10125. -            }
  10126. -          else if (TREE_TYPE (yyval.ttype) == error_mark_node)
  10127. -            yyval.ttype = error_mark_node;
  10128. -          else if (C_DECL_ANTICIPATED (yyval.ttype))
  10129. -            {
  10130. -              /* The first time we see a build-in function used,
  10131. -             if it has not been declared.  */
  10132. -              C_DECL_ANTICIPATED (yyval.ttype) = 0;
  10133. -              if (yychar == YYEMPTY)
  10134. -            yychar = YYLEX;
  10135. -              if (yychar == '(')
  10136. -            {
  10137. -              /* Omit the implicit declaration we
  10138. -                 would ordinarily do, so we don't lose
  10139. -                 the actual built in type.
  10140. -                 But print a diagnostic for the mismatch.  */
  10141. -                if (TREE_CODE (yyval.ttype) != FUNCTION_DECL)
  10142. -                  error ("`%s' implicitly declared as function",
  10143. -                     IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  10144. -              else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE (yyval.ttype)))
  10145. -                    != TYPE_MODE (integer_type_node))
  10146. -                   && (TREE_TYPE (TREE_TYPE (yyval.ttype))
  10147. -                       != void_type_node))
  10148. -                pedwarn ("type mismatch in implicit declaration for built-in function `%s'",
  10149. -                     IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  10150. -              /* If it really returns void, change that to int.  */
  10151. -              if (TREE_TYPE (TREE_TYPE (yyval.ttype)) == void_type_node)
  10152. -                TREE_TYPE (yyval.ttype)
  10153. -                  = build_function_type (integer_type_node,
  10154. -                             TYPE_ARG_TYPES (TREE_TYPE (yyval.ttype)));
  10155. -            }
  10156. -              else
  10157. -            pedwarn ("built-in function `%s' used without declaration",
  10158. -                 IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  10159. -
  10160. -              /* Do what we would ordinarily do when a fn is used.  */
  10161. -              assemble_external (yyval.ttype);
  10162. -              TREE_USED (yyval.ttype) = 1;
  10163. -            }
  10164. -          else
  10165. -            {
  10166. -              assemble_external (yyval.ttype);
  10167. -              TREE_USED (yyval.ttype) = 1;
  10168. -            }
  10169. -
  10170. -          if (TREE_CODE (yyval.ttype) == CONST_DECL)
  10171. -            {
  10172. -              yyval.ttype = DECL_INITIAL (yyval.ttype);
  10173. -              /* This is to prevent an enum whose value is 0
  10174. -             from being considered a null pointer constant.  */
  10175. -              yyval.ttype = build1 (NOP_EXPR, TREE_TYPE (yyval.ttype), yyval.ttype);
  10176. -              TREE_CONSTANT (yyval.ttype) = 1;
  10177. -            }
  10178. -        ;
  10179. -    break;}
  10180. -case 80:
  10181. -#line 635 "c-parse.y"
  10182. -{ yyval.ttype = combine_strings (yyvsp[0].ttype); ;
  10183. -    break;}
  10184. -case 81:
  10185. -#line 637 "c-parse.y"
  10186. -{ char class = TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype));
  10187. -          if (class == 'e' || class == '1'
  10188. -              || class == '2' || class == '<')
  10189. -            C_SET_EXP_ORIGINAL_CODE (yyvsp[-1].ttype, ERROR_MARK);
  10190. -          yyval.ttype = yyvsp[-1].ttype; ;
  10191. -    break;}
  10192. -case 82:
  10193. -#line 643 "c-parse.y"
  10194. -{ yyval.ttype = error_mark_node; ;
  10195. -    break;}
  10196. -case 83:
  10197. -#line 645 "c-parse.y"
  10198. -{ if (current_function_decl == 0)
  10199. -            {
  10200. -              error ("braced-group within expression allowed only inside a function");
  10201. -              YYERROR;
  10202. -            }
  10203. -          /* We must force a BLOCK for this level
  10204. -             so that, if it is not expanded later,
  10205. -             there is a way to turn off the entire subtree of blocks
  10206. -             that are contained in it.  */
  10207. -          keep_next_level ();
  10208. -          push_iterator_stack ();
  10209. -          push_label_level ();
  10210. -          yyval.ttype = expand_start_stmt_expr (); ;
  10211. -    break;}
  10212. -case 84:
  10213. -#line 659 "c-parse.y"
  10214. -{ tree rtl_exp;
  10215. -          if (pedantic)
  10216. -            pedwarn ("ANSI C forbids braced-groups within expressions");
  10217. -          pop_iterator_stack ();
  10218. -          pop_label_level ();
  10219. -          rtl_exp = expand_end_stmt_expr (yyvsp[-2].ttype);
  10220. -          /* The statements have side effects, so the group does.  */
  10221. -          TREE_SIDE_EFFECTS (rtl_exp) = 1;
  10222. -
  10223. -          if (TREE_CODE (yyvsp[-1].ttype) == BLOCK)
  10224. -            {
  10225. -              /* Make a BIND_EXPR for the BLOCK already made.  */
  10226. -              yyval.ttype = build (BIND_EXPR, TREE_TYPE (rtl_exp),
  10227. -                  NULL_TREE, rtl_exp, yyvsp[-1].ttype);
  10228. -              /* Remove the block from the tree at this point.
  10229. -             It gets put back at the proper place
  10230. -             when the BIND_EXPR is expanded.  */
  10231. -              delete_block (yyvsp[-1].ttype);
  10232. -            }
  10233. -          else
  10234. -            yyval.ttype = yyvsp[-1].ttype;
  10235. -        ;
  10236. -    break;}
  10237. -case 85:
  10238. -#line 682 "c-parse.y"
  10239. -{ yyval.ttype = build_function_call (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10240. -    break;}
  10241. -case 86:
  10242. -#line 684 "c-parse.y"
  10243. -{ yyval.ttype = build_array_ref (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10244. -    break;}
  10245. -case 87:
  10246. -#line 686 "c-parse.y"
  10247. -{
  10248. -            yyval.ttype = build_component_ref (yyvsp[-2].ttype, yyvsp[0].ttype);
  10249. -        ;
  10250. -    break;}
  10251. -case 88:
  10252. -#line 690 "c-parse.y"
  10253. -{
  10254. -                  tree expr = build_indirect_ref (yyvsp[-2].ttype, "->");
  10255. -
  10256. -                    yyval.ttype = build_component_ref (expr, yyvsp[0].ttype);
  10257. -        ;
  10258. -    break;}
  10259. -case 89:
  10260. -#line 696 "c-parse.y"
  10261. -{ yyval.ttype = build_unary_op (POSTINCREMENT_EXPR, yyvsp[-1].ttype, 0); ;
  10262. -    break;}
  10263. -case 90:
  10264. -#line 698 "c-parse.y"
  10265. -{ yyval.ttype = build_unary_op (POSTDECREMENT_EXPR, yyvsp[-1].ttype, 0); ;
  10266. -    break;}
  10267. -case 92:
  10268. -#line 705 "c-parse.y"
  10269. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10270. -    break;}
  10271. -case 95:
  10272. -#line 714 "c-parse.y"
  10273. -{ c_mark_varargs ();
  10274. -          if (pedantic)
  10275. -            pedwarn ("ANSI C does not permit use of `varargs.h'"); ;
  10276. -    break;}
  10277. -case 96:
  10278. -#line 724 "c-parse.y"
  10279. -{ ;
  10280. -    break;}
  10281. -case 101:
  10282. -#line 736 "c-parse.y"
  10283. -{ current_declspecs = TREE_VALUE (declspec_stack);
  10284. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10285. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10286. -          resume_momentary (yyvsp[-2].itype); ;
  10287. -    break;}
  10288. -case 102:
  10289. -#line 741 "c-parse.y"
  10290. -{ current_declspecs = TREE_VALUE (declspec_stack);    
  10291. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10292. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10293. -          resume_momentary (yyvsp[-2].itype); ;
  10294. -    break;}
  10295. -case 103:
  10296. -#line 746 "c-parse.y"
  10297. -{ shadow_tag_warned (yyvsp[-1].ttype, 1);
  10298. -          pedwarn ("empty declaration"); ;
  10299. -    break;}
  10300. -case 104:
  10301. -#line 749 "c-parse.y"
  10302. -{ pedwarn ("empty declaration"); ;
  10303. -    break;}
  10304. -case 105:
  10305. -#line 758 "c-parse.y"
  10306. -{ ;
  10307. -    break;}
  10308. -case 110:
  10309. -#line 773 "c-parse.y"
  10310. -{ yyval.itype = suspend_momentary ();
  10311. -          pending_xref_error ();
  10312. -          declspec_stack = tree_cons (prefix_attributes,
  10313. -                          current_declspecs,
  10314. -                          declspec_stack);
  10315. -          current_declspecs = yyvsp[0].ttype; 
  10316. -          prefix_attributes = NULL_TREE; ;
  10317. -    break;}
  10318. -case 111:
  10319. -#line 783 "c-parse.y"
  10320. -{ prefix_attributes = chainon (prefix_attributes, yyvsp[0].ttype); ;
  10321. -    break;}
  10322. -case 112:
  10323. -#line 788 "c-parse.y"
  10324. -{ current_declspecs = TREE_VALUE (declspec_stack);
  10325. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10326. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10327. -          resume_momentary (yyvsp[-2].itype); ;
  10328. -    break;}
  10329. -case 113:
  10330. -#line 793 "c-parse.y"
  10331. -{ current_declspecs = TREE_VALUE (declspec_stack);
  10332. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10333. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10334. -          resume_momentary (yyvsp[-2].itype); ;
  10335. -    break;}
  10336. -case 114:
  10337. -#line 798 "c-parse.y"
  10338. -{ current_declspecs = TREE_VALUE (declspec_stack);
  10339. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10340. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10341. -          resume_momentary (yyvsp[-1].itype); ;
  10342. -    break;}
  10343. -case 115:
  10344. -#line 803 "c-parse.y"
  10345. -{ current_declspecs = TREE_VALUE (declspec_stack);
  10346. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10347. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10348. -          resume_momentary (yyvsp[-1].itype); ;
  10349. -    break;}
  10350. -case 116:
  10351. -#line 808 "c-parse.y"
  10352. -{ shadow_tag (yyvsp[-1].ttype); ;
  10353. -    break;}
  10354. -case 117:
  10355. -#line 810 "c-parse.y"
  10356. -{ pedwarn ("empty declaration"); ;
  10357. -    break;}
  10358. -case 118:
  10359. -#line 819 "c-parse.y"
  10360. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10361. -    break;}
  10362. -case 119:
  10363. -#line 821 "c-parse.y"
  10364. -{ yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ;
  10365. -    break;}
  10366. -case 120:
  10367. -#line 825 "c-parse.y"
  10368. -{ yyval.ttype = NULL_TREE; ;
  10369. -    break;}
  10370. -case 121:
  10371. -#line 827 "c-parse.y"
  10372. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  10373. -    break;}
  10374. -case 122:
  10375. -#line 829 "c-parse.y"
  10376. -{ if (extra_warnings)
  10377. -            warning ("`%s' is not at beginning of declaration",
  10378. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  10379. -          yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  10380. -    break;}
  10381. -case 123:
  10382. -#line 841 "c-parse.y"
  10383. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE);
  10384. -          TREE_STATIC (yyval.ttype) = 1; ;
  10385. -    break;}
  10386. -case 124:
  10387. -#line 844 "c-parse.y"
  10388. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  10389. -    break;}
  10390. -case 125:
  10391. -#line 846 "c-parse.y"
  10392. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype);
  10393. -          TREE_STATIC (yyval.ttype) = 1; ;
  10394. -    break;}
  10395. -case 126:
  10396. -#line 849 "c-parse.y"
  10397. -{ if (extra_warnings && TREE_STATIC (yyvsp[-1].ttype))
  10398. -            warning ("`%s' is not at beginning of declaration",
  10399. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  10400. -          yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype);
  10401. -          TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ;
  10402. -    break;}
  10403. -case 127:
  10404. -#line 863 "c-parse.y"
  10405. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10406. -    break;}
  10407. -case 128:
  10408. -#line 865 "c-parse.y"
  10409. -{ yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ;
  10410. -    break;}
  10411. -case 129:
  10412. -#line 869 "c-parse.y"
  10413. -{ yyval.ttype = NULL_TREE; ;
  10414. -    break;}
  10415. -case 130:
  10416. -#line 871 "c-parse.y"
  10417. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  10418. -    break;}
  10419. -case 133:
  10420. -#line 881 "c-parse.y"
  10421. -{ /* For a typedef name, record the meaning, not the name.
  10422. -             In case of `foo foo, bar;'.  */
  10423. -          yyval.ttype = lookup_name (yyvsp[0].ttype); ;
  10424. -    break;}
  10425. -case 134:
  10426. -#line 885 "c-parse.y"
  10427. -{ yyval.ttype = TREE_TYPE (yyvsp[-1].ttype); ;
  10428. -    break;}
  10429. -case 135:
  10430. -#line 887 "c-parse.y"
  10431. -{ yyval.ttype = groktypename (yyvsp[-1].ttype); ;
  10432. -    break;}
  10433. -case 143:
  10434. -#line 909 "c-parse.y"
  10435. -{ yyval.ttype = NULL_TREE; ;
  10436. -    break;}
  10437. -case 144:
  10438. -#line 911 "c-parse.y"
  10439. -{ if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype);
  10440. -          yyval.ttype = yyvsp[-1].ttype;
  10441. -        ;
  10442. -    break;}
  10443. -case 145:
  10444. -#line 918 "c-parse.y"
  10445. -{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1,
  10446. -                      yyvsp[-1].ttype, prefix_attributes);
  10447. -          start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ;
  10448. -    break;}
  10449. -case 146:
  10450. -#line 923 "c-parse.y"
  10451. -{ finish_init ();
  10452. -          finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ;
  10453. -    break;}
  10454. -case 147:
  10455. -#line 926 "c-parse.y"
  10456. -{ tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0,
  10457. -                       yyvsp[0].ttype, prefix_attributes);
  10458. -          finish_decl (d, NULL_TREE, yyvsp[-1].ttype); 
  10459. -                ;
  10460. -    break;}
  10461. -case 148:
  10462. -#line 934 "c-parse.y"
  10463. -{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1,
  10464. -                      yyvsp[-1].ttype, prefix_attributes);
  10465. -          start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ;
  10466. -    break;}
  10467. -case 149:
  10468. -#line 939 "c-parse.y"
  10469. -{ finish_init ();
  10470. -          decl_attributes (yyvsp[-1].ttype, yyvsp[-3].ttype, prefix_attributes);
  10471. -          finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ;
  10472. -    break;}
  10473. -case 150:
  10474. -#line 943 "c-parse.y"
  10475. -{ tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0,
  10476. -                       yyvsp[0].ttype, prefix_attributes);
  10477. -          finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ;
  10478. -    break;}
  10479. -case 151:
  10480. -#line 951 "c-parse.y"
  10481. -{ yyval.ttype = NULL_TREE; ;
  10482. -    break;}
  10483. -case 152:
  10484. -#line 953 "c-parse.y"
  10485. -{ yyval.ttype = yyvsp[0].ttype; ;
  10486. -    break;}
  10487. -case 153:
  10488. -#line 958 "c-parse.y"
  10489. -{ yyval.ttype = yyvsp[0].ttype; ;
  10490. -    break;}
  10491. -case 154:
  10492. -#line 960 "c-parse.y"
  10493. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10494. -    break;}
  10495. -case 155:
  10496. -#line 965 "c-parse.y"
  10497. -{ yyval.ttype = yyvsp[-2].ttype; ;
  10498. -    break;}
  10499. -case 156:
  10500. -#line 970 "c-parse.y"
  10501. -{ yyval.ttype = yyvsp[0].ttype; ;
  10502. -    break;}
  10503. -case 157:
  10504. -#line 972 "c-parse.y"
  10505. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10506. -    break;}
  10507. -case 158:
  10508. -#line 977 "c-parse.y"
  10509. -{ yyval.ttype = NULL_TREE; ;
  10510. -    break;}
  10511. -case 159:
  10512. -#line 979 "c-parse.y"
  10513. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ;
  10514. -    break;}
  10515. -case 160:
  10516. -#line 981 "c-parse.y"
  10517. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ;
  10518. -    break;}
  10519. -case 161:
  10520. -#line 983 "c-parse.y"
  10521. -{ yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ;
  10522. -    break;}
  10523. -case 162:
  10524. -#line 985 "c-parse.y"
  10525. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10526. -    break;}
  10527. -case 168:
  10528. -#line 1003 "c-parse.y"
  10529. -{ really_start_incremental_init (NULL_TREE);
  10530. -          /* Note that the call to clear_momentary
  10531. -             is in process_init_element.  */
  10532. -          push_momentary (); ;
  10533. -    break;}
  10534. -case 169:
  10535. -#line 1008 "c-parse.y"
  10536. -{ yyval.ttype = pop_init_level (0);
  10537. -          if (yyval.ttype == error_mark_node
  10538. -              && ! (yychar == STRING || yychar == CONSTANT))
  10539. -            pop_momentary ();
  10540. -          else
  10541. -            pop_momentary_nofree (); ;
  10542. -    break;}
  10543. -case 170:
  10544. -#line 1016 "c-parse.y"
  10545. -{ yyval.ttype = error_mark_node; ;
  10546. -    break;}
  10547. -case 171:
  10548. -#line 1022 "c-parse.y"
  10549. -{ if (pedantic)
  10550. -            pedwarn ("ANSI C forbids empty initializer braces"); ;
  10551. -    break;}
  10552. -case 175:
  10553. -#line 1036 "c-parse.y"
  10554. -{ process_init_element (yyvsp[0].ttype); ;
  10555. -    break;}
  10556. -case 176:
  10557. -#line 1038 "c-parse.y"
  10558. -{ push_init_level (0); ;
  10559. -    break;}
  10560. -case 177:
  10561. -#line 1040 "c-parse.y"
  10562. -{ process_init_element (pop_init_level (0)); ;
  10563. -    break;}
  10564. -case 179:
  10565. -#line 1046 "c-parse.y"
  10566. -{ set_init_index (yyvsp[-4].ttype, yyvsp[-2].ttype); ;
  10567. -    break;}
  10568. -case 181:
  10569. -#line 1049 "c-parse.y"
  10570. -{ set_init_index (yyvsp[-2].ttype, NULL_TREE); ;
  10571. -    break;}
  10572. -case 183:
  10573. -#line 1052 "c-parse.y"
  10574. -{ set_init_index (yyvsp[-1].ttype, NULL_TREE); ;
  10575. -    break;}
  10576. -case 185:
  10577. -#line 1055 "c-parse.y"
  10578. -{ set_init_label (yyvsp[-1].ttype); ;
  10579. -    break;}
  10580. -case 187:
  10581. -#line 1058 "c-parse.y"
  10582. -{ set_init_label (yyvsp[-1].ttype); ;
  10583. -    break;}
  10584. -case 189:
  10585. -#line 1064 "c-parse.y"
  10586. -{ push_c_function_context ();
  10587. -          if (! start_function (current_declspecs, yyvsp[0].ttype,
  10588. -                    prefix_attributes, NULL_TREE, 1))
  10589. -            {
  10590. -              pop_c_function_context ();
  10591. -              YYERROR1;
  10592. -            }
  10593. -          reinit_parse_for_function (); ;
  10594. -    break;}
  10595. -case 190:
  10596. -#line 1073 "c-parse.y"
  10597. -{ store_parm_decls (); ;
  10598. -    break;}
  10599. -case 191:
  10600. -#line 1081 "c-parse.y"
  10601. -{ finish_function (1);
  10602. -          pop_c_function_context (); ;
  10603. -    break;}
  10604. -case 192:
  10605. -#line 1087 "c-parse.y"
  10606. -{ push_c_function_context ();
  10607. -          if (! start_function (current_declspecs, yyvsp[0].ttype,
  10608. -                    prefix_attributes, NULL_TREE, 1))
  10609. -            {
  10610. -              pop_c_function_context ();
  10611. -              YYERROR1;
  10612. -            }
  10613. -          reinit_parse_for_function (); ;
  10614. -    break;}
  10615. -case 193:
  10616. -#line 1096 "c-parse.y"
  10617. -{ store_parm_decls (); ;
  10618. -    break;}
  10619. -case 194:
  10620. -#line 1104 "c-parse.y"
  10621. -{ finish_function (1);
  10622. -          pop_c_function_context (); ;
  10623. -    break;}
  10624. -case 197:
  10625. -#line 1120 "c-parse.y"
  10626. -{ yyval.ttype = yyvsp[-1].ttype; ;
  10627. -    break;}
  10628. -case 198:
  10629. -#line 1122 "c-parse.y"
  10630. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  10631. -    break;}
  10632. -case 199:
  10633. -#line 1127 "c-parse.y"
  10634. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10635. -    break;}
  10636. -case 200:
  10637. -#line 1129 "c-parse.y"
  10638. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  10639. -    break;}
  10640. -case 201:
  10641. -#line 1131 "c-parse.y"
  10642. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10643. -    break;}
  10644. -case 202:
  10645. -#line 1133 "c-parse.y"
  10646. -{ yyval.ttype = yyvsp[0].ttype; ;
  10647. -    break;}
  10648. -case 204:
  10649. -#line 1144 "c-parse.y"
  10650. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  10651. -    break;}
  10652. -case 205:
  10653. -#line 1149 "c-parse.y"
  10654. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10655. -    break;}
  10656. -case 206:
  10657. -#line 1151 "c-parse.y"
  10658. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  10659. -    break;}
  10660. -case 207:
  10661. -#line 1153 "c-parse.y"
  10662. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10663. -    break;}
  10664. -case 208:
  10665. -#line 1155 "c-parse.y"
  10666. -{ yyval.ttype = yyvsp[0].ttype; ;
  10667. -    break;}
  10668. -case 210:
  10669. -#line 1164 "c-parse.y"
  10670. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  10671. -    break;}
  10672. -case 211:
  10673. -#line 1169 "c-parse.y"
  10674. -{ yyval.ttype = yyvsp[-1].ttype; ;
  10675. -    break;}
  10676. -case 212:
  10677. -#line 1171 "c-parse.y"
  10678. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10679. -    break;}
  10680. -case 213:
  10681. -#line 1173 "c-parse.y"
  10682. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10683. -    break;}
  10684. -case 214:
  10685. -#line 1175 "c-parse.y"
  10686. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  10687. -    break;}
  10688. -case 215:
  10689. -#line 1177 "c-parse.y"
  10690. -{ yyval.ttype = yyvsp[0].ttype; ;
  10691. -    break;}
  10692. -case 217:
  10693. -#line 1183 "c-parse.y"
  10694. -{ yyval.ttype = start_struct (RECORD_TYPE, yyvsp[-1].ttype);
  10695. -          /* Start scope of tag before parsing components.  */
  10696. -        ;
  10697. -    break;}
  10698. -case 218:
  10699. -#line 1187 "c-parse.y"
  10700. -{ yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10701. -    break;}
  10702. -case 219:
  10703. -#line 1189 "c-parse.y"
  10704. -{ yyval.ttype = finish_struct (start_struct (RECORD_TYPE, NULL_TREE),
  10705. -                      yyvsp[-2].ttype, yyvsp[0].ttype);
  10706. -        ;
  10707. -    break;}
  10708. -case 220:
  10709. -#line 1193 "c-parse.y"
  10710. -{ yyval.ttype = xref_tag (RECORD_TYPE, yyvsp[0].ttype); ;
  10711. -    break;}
  10712. -case 221:
  10713. -#line 1195 "c-parse.y"
  10714. -{ yyval.ttype = start_struct (UNION_TYPE, yyvsp[-1].ttype); ;
  10715. -    break;}
  10716. -case 222:
  10717. -#line 1197 "c-parse.y"
  10718. -{ yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10719. -    break;}
  10720. -case 223:
  10721. -#line 1199 "c-parse.y"
  10722. -{ yyval.ttype = finish_struct (start_struct (UNION_TYPE, NULL_TREE),
  10723. -                      yyvsp[-2].ttype, yyvsp[0].ttype);
  10724. -        ;
  10725. -    break;}
  10726. -case 224:
  10727. -#line 1203 "c-parse.y"
  10728. -{ yyval.ttype = xref_tag (UNION_TYPE, yyvsp[0].ttype); ;
  10729. -    break;}
  10730. -case 225:
  10731. -#line 1205 "c-parse.y"
  10732. -{ yyvsp[0].itype = suspend_momentary ();
  10733. -          yyval.ttype = start_enum (yyvsp[-1].ttype); ;
  10734. -    break;}
  10735. -case 226:
  10736. -#line 1208 "c-parse.y"
  10737. -{ yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), yyvsp[0].ttype);
  10738. -          resume_momentary (yyvsp[-5].itype); ;
  10739. -    break;}
  10740. -case 227:
  10741. -#line 1211 "c-parse.y"
  10742. -{ yyvsp[0].itype = suspend_momentary ();
  10743. -          yyval.ttype = start_enum (NULL_TREE); ;
  10744. -    break;}
  10745. -case 228:
  10746. -#line 1214 "c-parse.y"
  10747. -{ yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), yyvsp[0].ttype);
  10748. -          resume_momentary (yyvsp[-5].itype); ;
  10749. -    break;}
  10750. -case 229:
  10751. -#line 1217 "c-parse.y"
  10752. -{ yyval.ttype = xref_tag (ENUMERAL_TYPE, yyvsp[0].ttype); ;
  10753. -    break;}
  10754. -case 233:
  10755. -#line 1228 "c-parse.y"
  10756. -{ if (pedantic) pedwarn ("comma at end of enumerator list"); ;
  10757. -    break;}
  10758. -case 234:
  10759. -#line 1233 "c-parse.y"
  10760. -{ yyval.ttype = yyvsp[0].ttype; ;
  10761. -    break;}
  10762. -case 235:
  10763. -#line 1235 "c-parse.y"
  10764. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype);
  10765. -          pedwarn ("no semicolon at end of struct or union"); ;
  10766. -    break;}
  10767. -case 236:
  10768. -#line 1240 "c-parse.y"
  10769. -{ yyval.ttype = NULL_TREE; ;
  10770. -    break;}
  10771. -case 237:
  10772. -#line 1242 "c-parse.y"
  10773. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
  10774. -    break;}
  10775. -case 238:
  10776. -#line 1244 "c-parse.y"
  10777. -{ if (pedantic)
  10778. -            pedwarn ("extra semicolon in struct or union specified"); ;
  10779. -    break;}
  10780. -case 239:
  10781. -#line 1259 "c-parse.y"
  10782. -{ yyval.ttype = yyvsp[0].ttype;
  10783. -          current_declspecs = TREE_VALUE (declspec_stack);
  10784. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10785. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10786. -          resume_momentary (yyvsp[-1].itype); ;
  10787. -    break;}
  10788. -case 240:
  10789. -#line 1265 "c-parse.y"
  10790. -{ if (pedantic)
  10791. -            pedwarn ("ANSI C forbids member declarations with no members");
  10792. -          shadow_tag(yyvsp[0].ttype);
  10793. -          yyval.ttype = NULL_TREE; ;
  10794. -    break;}
  10795. -case 241:
  10796. -#line 1270 "c-parse.y"
  10797. -{ yyval.ttype = yyvsp[0].ttype;
  10798. -          current_declspecs = TREE_VALUE (declspec_stack);
  10799. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  10800. -          declspec_stack = TREE_CHAIN (declspec_stack);
  10801. -          resume_momentary (yyvsp[-1].itype); ;
  10802. -    break;}
  10803. -case 242:
  10804. -#line 1276 "c-parse.y"
  10805. -{ if (pedantic)
  10806. -            pedwarn ("ANSI C forbids member declarations with no members");
  10807. -          shadow_tag(yyvsp[0].ttype);
  10808. -          yyval.ttype = NULL_TREE; ;
  10809. -    break;}
  10810. -case 243:
  10811. -#line 1281 "c-parse.y"
  10812. -{ yyval.ttype = NULL_TREE; ;
  10813. -    break;}
  10814. -case 245:
  10815. -#line 1287 "c-parse.y"
  10816. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10817. -    break;}
  10818. -case 246:
  10819. -#line 1292 "c-parse.y"
  10820. -{ yyval.ttype = grokfield (yyvsp[-3].filename, yyvsp[-2].lineno, yyvsp[-1].ttype, current_declspecs, NULL_TREE);
  10821. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  10822. -    break;}
  10823. -case 247:
  10824. -#line 1296 "c-parse.y"
  10825. -{ yyval.ttype = grokfield (yyvsp[-5].filename, yyvsp[-4].lineno, yyvsp[-3].ttype, current_declspecs, yyvsp[-1].ttype);
  10826. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  10827. -    break;}
  10828. -case 248:
  10829. -#line 1299 "c-parse.y"
  10830. -{ yyval.ttype = grokfield (yyvsp[-4].filename, yyvsp[-3].lineno, NULL_TREE, current_declspecs, yyvsp[-1].ttype);
  10831. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  10832. -    break;}
  10833. -case 250:
  10834. -#line 1311 "c-parse.y"
  10835. -{ if (yyvsp[-2].ttype == error_mark_node)
  10836. -            yyval.ttype = yyvsp[-2].ttype;
  10837. -          else
  10838. -            yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-2].ttype); ;
  10839. -    break;}
  10840. -case 251:
  10841. -#line 1316 "c-parse.y"
  10842. -{ yyval.ttype = error_mark_node; ;
  10843. -    break;}
  10844. -case 252:
  10845. -#line 1322 "c-parse.y"
  10846. -{ yyval.ttype = build_enumerator (yyvsp[0].ttype, NULL_TREE); ;
  10847. -    break;}
  10848. -case 253:
  10849. -#line 1324 "c-parse.y"
  10850. -{ yyval.ttype = build_enumerator (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  10851. -    break;}
  10852. -case 254:
  10853. -#line 1329 "c-parse.y"
  10854. -{ yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10855. -    break;}
  10856. -case 255:
  10857. -#line 1331 "c-parse.y"
  10858. -{ yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10859. -    break;}
  10860. -case 256:
  10861. -#line 1336 "c-parse.y"
  10862. -{ yyval.ttype = NULL_TREE; ;
  10863. -    break;}
  10864. -case 258:
  10865. -#line 1342 "c-parse.y"
  10866. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  10867. -    break;}
  10868. -case 259:
  10869. -#line 1344 "c-parse.y"
  10870. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  10871. -    break;}
  10872. -case 260:
  10873. -#line 1349 "c-parse.y"
  10874. -{ yyval.ttype = NULL_TREE; ;
  10875. -    break;}
  10876. -case 261:
  10877. -#line 1351 "c-parse.y"
  10878. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  10879. -    break;}
  10880. -case 262:
  10881. -#line 1356 "c-parse.y"
  10882. -{ yyval.ttype = yyvsp[-1].ttype; ;
  10883. -    break;}
  10884. -case 263:
  10885. -#line 1359 "c-parse.y"
  10886. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  10887. -    break;}
  10888. -case 264:
  10889. -#line 1361 "c-parse.y"
  10890. -{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
  10891. -    break;}
  10892. -case 265:
  10893. -#line 1363 "c-parse.y"
  10894. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  10895. -    break;}
  10896. -case 266:
  10897. -#line 1365 "c-parse.y"
  10898. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  10899. -    break;}
  10900. -case 267:
  10901. -#line 1367 "c-parse.y"
  10902. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  10903. -    break;}
  10904. -case 268:
  10905. -#line 1369 "c-parse.y"
  10906. -{ yyval.ttype = build_nt (CALL_EXPR, NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  10907. -    break;}
  10908. -case 269:
  10909. -#line 1371 "c-parse.y"
  10910. -{ yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
  10911. -    break;}
  10912. -case 270:
  10913. -#line 1373 "c-parse.y"
  10914. -{ yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); ;
  10915. -    break;}
  10916. -case 271:
  10917. -#line 1375 "c-parse.y"
  10918. -{ yyval.ttype = yyvsp[0].ttype; ;
  10919. -    break;}
  10920. -case 272:
  10921. -#line 1384 "c-parse.y"
  10922. -{
  10923. -          if (pedantic && yyvsp[0].ends_in_label)
  10924. -            pedwarn ("ANSI C forbids label at end of compound statement");
  10925. -        ;
  10926. -    break;}
  10927. -case 274:
  10928. -#line 1393 "c-parse.y"
  10929. -{ yyval.ends_in_label = yyvsp[0].ends_in_label; ;
  10930. -    break;}
  10931. -case 275:
  10932. -#line 1395 "c-parse.y"
  10933. -{ yyval.ends_in_label = 0; ;
  10934. -    break;}
  10935. -case 279:
  10936. -#line 1407 "c-parse.y"
  10937. -{ emit_line_note (input_filename, lineno);
  10938. -          pushlevel (0);
  10939. -          clear_last_expr ();
  10940. -          push_momentary ();
  10941. -          expand_start_bindings (0);
  10942. -        ;
  10943. -    break;}
  10944. -case 281:
  10945. -#line 1420 "c-parse.y"
  10946. -{ if (pedantic)
  10947. -            pedwarn ("ANSI C forbids label declarations"); ;
  10948. -    break;}
  10949. -case 284:
  10950. -#line 1431 "c-parse.y"
  10951. -{ tree link;
  10952. -          for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link))
  10953. -            {
  10954. -              tree label = shadow_label (TREE_VALUE (link));
  10955. -              C_DECLARED_LABEL_FLAG (label) = 1;
  10956. -              declare_nonlocal_label (label);
  10957. -            }
  10958. -        ;
  10959. -    break;}
  10960. -case 285:
  10961. -#line 1445 "c-parse.y"
  10962. -{;
  10963. -    break;}
  10964. -case 287:
  10965. -#line 1450 "c-parse.y"
  10966. -{ yyval.ttype = convert (void_type_node, integer_zero_node); ;
  10967. -    break;}
  10968. -case 288:
  10969. -#line 1452 "c-parse.y"
  10970. -{ emit_line_note (input_filename, lineno);
  10971. -          expand_end_bindings (getdecls (), 1, 0);
  10972. -          yyval.ttype = poplevel (1, 1, 0);
  10973. -          if (yychar == CONSTANT || yychar == STRING)
  10974. -            pop_momentary_nofree ();
  10975. -          else
  10976. -            pop_momentary (); ;
  10977. -    break;}
  10978. -case 289:
  10979. -#line 1460 "c-parse.y"
  10980. -{ emit_line_note (input_filename, lineno);
  10981. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  10982. -          yyval.ttype = poplevel (kept_level_p (), 0, 0);
  10983. -          if (yychar == CONSTANT || yychar == STRING)
  10984. -            pop_momentary_nofree ();
  10985. -          else
  10986. -            pop_momentary (); ;
  10987. -    break;}
  10988. -case 290:
  10989. -#line 1468 "c-parse.y"
  10990. -{ emit_line_note (input_filename, lineno);
  10991. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  10992. -          yyval.ttype = poplevel (kept_level_p (), 0, 0);
  10993. -          if (yychar == CONSTANT || yychar == STRING)
  10994. -            pop_momentary_nofree ();
  10995. -          else
  10996. -            pop_momentary (); ;
  10997. -    break;}
  10998. -case 293:
  10999. -#line 1488 "c-parse.y"
  11000. -{ emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  11001. -          expand_start_cond (truthvalue_conversion (yyvsp[-1].ttype), 0);
  11002. -          yyval.itype = stmt_count;
  11003. -          if_stmt_file = yyvsp[-5].filename;
  11004. -          if_stmt_line = yyvsp[-4].lineno;
  11005. -          position_after_white_space (); ;
  11006. -    break;}
  11007. -case 294:
  11008. -#line 1501 "c-parse.y"
  11009. -{ stmt_count++;
  11010. -          emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno);
  11011. -          /* See comment in `while' alternative, above.  */
  11012. -          emit_nop ();
  11013. -          expand_start_loop_continue_elsewhere (1);
  11014. -          position_after_white_space (); ;
  11015. -    break;}
  11016. -case 295:
  11017. -#line 1508 "c-parse.y"
  11018. -{ expand_loop_continue_here (); ;
  11019. -    break;}
  11020. -case 296:
  11021. -#line 1512 "c-parse.y"
  11022. -{ yyval.filename = input_filename; ;
  11023. -    break;}
  11024. -case 297:
  11025. -#line 1516 "c-parse.y"
  11026. -{ yyval.lineno = lineno; ;
  11027. -    break;}
  11028. -case 298:
  11029. -#line 1521 "c-parse.y"
  11030. -{ ;
  11031. -    break;}
  11032. -case 299:
  11033. -#line 1526 "c-parse.y"
  11034. -{ ;
  11035. -    break;}
  11036. -case 300:
  11037. -#line 1531 "c-parse.y"
  11038. -{ yyval.ends_in_label = yyvsp[0].ends_in_label; ;
  11039. -    break;}
  11040. -case 301:
  11041. -#line 1536 "c-parse.y"
  11042. -{ yyval.ends_in_label = 0; ;
  11043. -    break;}
  11044. -case 302:
  11045. -#line 1538 "c-parse.y"
  11046. -{ yyval.ends_in_label = 1; ;
  11047. -    break;}
  11048. -case 303:
  11049. -#line 1544 "c-parse.y"
  11050. -{ stmt_count++; ;
  11051. -    break;}
  11052. -case 305:
  11053. -#line 1547 "c-parse.y"
  11054. -{ stmt_count++;
  11055. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  11056. -/* It appears that this should not be done--that a non-lvalue array
  11057. -   shouldn't get an error if the value isn't used.
  11058. -   Section 3.2.2.1 says that an array lvalue gets converted to a pointer
  11059. -   if it appears as a top-level expression,
  11060. -   but says nothing about non-lvalue arrays.  */
  11061. -#if 0
  11062. -          /* Call default_conversion to get an error
  11063. -             on referring to a register array if pedantic.  */
  11064. -          if (TREE_CODE (TREE_TYPE (yyvsp[-1].ttype)) == ARRAY_TYPE
  11065. -              || TREE_CODE (TREE_TYPE (yyvsp[-1].ttype)) == FUNCTION_TYPE)
  11066. -            yyvsp[-1].ttype = default_conversion (yyvsp[-1].ttype);
  11067. -#endif
  11068. -          iterator_expand (yyvsp[-1].ttype);
  11069. -          clear_momentary (); ;
  11070. -    break;}
  11071. -case 306:
  11072. -#line 1564 "c-parse.y"
  11073. -{ expand_start_else ();
  11074. -          yyvsp[-1].itype = stmt_count;
  11075. -          position_after_white_space (); ;
  11076. -    break;}
  11077. -case 307:
  11078. -#line 1568 "c-parse.y"
  11079. -{ expand_end_cond ();
  11080. -          if (extra_warnings && stmt_count == yyvsp[-3].itype)
  11081. -            warning ("empty body in an else-statement"); ;
  11082. -    break;}
  11083. -case 308:
  11084. -#line 1572 "c-parse.y"
  11085. -{ expand_end_cond ();
  11086. -          /* This warning is here instead of in simple_if, because we
  11087. -             do not want a warning if an empty if is followed by an
  11088. -             else statement.  Increment stmt_count so we don't
  11089. -             give a second error if this is a nested `if'.  */
  11090. -          if (extra_warnings && stmt_count++ == yyvsp[0].itype)
  11091. -            warning_with_file_and_line (if_stmt_file, if_stmt_line,
  11092. -                        "empty body in an if-statement"); ;
  11093. -    break;}
  11094. -case 309:
  11095. -#line 1584 "c-parse.y"
  11096. -{ expand_end_cond (); ;
  11097. -    break;}
  11098. -case 310:
  11099. -#line 1586 "c-parse.y"
  11100. -{ stmt_count++;
  11101. -          emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno);
  11102. -          /* The emit_nop used to come before emit_line_note,
  11103. -             but that made the nop seem like part of the preceding line.
  11104. -             And that was confusing when the preceding line was
  11105. -             inside of an if statement and was not really executed.
  11106. -             I think it ought to work to put the nop after the line number.
  11107. -             We will see.  --rms, July 15, 1991.  */
  11108. -          emit_nop (); ;
  11109. -    break;}
  11110. -case 311:
  11111. -#line 1596 "c-parse.y"
  11112. -{ /* Don't start the loop till we have succeeded
  11113. -             in parsing the end test.  This is to make sure
  11114. -             that we end every loop we start.  */
  11115. -          expand_start_loop (1);
  11116. -          emit_line_note (input_filename, lineno);
  11117. -          expand_exit_loop_if_false (NULL_PTR,
  11118. -                         truthvalue_conversion (yyvsp[-1].ttype));
  11119. -          position_after_white_space (); ;
  11120. -    break;}
  11121. -case 312:
  11122. -#line 1605 "c-parse.y"
  11123. -{ expand_end_loop (); ;
  11124. -    break;}
  11125. -case 313:
  11126. -#line 1608 "c-parse.y"
  11127. -{ emit_line_note (input_filename, lineno);
  11128. -          expand_exit_loop_if_false (NULL_PTR,
  11129. -                         truthvalue_conversion (yyvsp[-2].ttype));
  11130. -          expand_end_loop ();
  11131. -          clear_momentary (); ;
  11132. -    break;}
  11133. -case 314:
  11134. -#line 1615 "c-parse.y"
  11135. -{ expand_end_loop ();
  11136. -          clear_momentary (); ;
  11137. -    break;}
  11138. -case 315:
  11139. -#line 1619 "c-parse.y"
  11140. -{ stmt_count++;
  11141. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  11142. -          /* See comment in `while' alternative, above.  */
  11143. -          emit_nop ();
  11144. -          if (yyvsp[-1].ttype) c_expand_expr_stmt (yyvsp[-1].ttype);
  11145. -          /* Next step is to call expand_start_loop_continue_elsewhere,
  11146. -             but wait till after we parse the entire for (...).
  11147. -             Otherwise, invalid input might cause us to call that
  11148. -             fn without calling expand_end_loop.  */
  11149. -        ;
  11150. -    break;}
  11151. -case 316:
  11152. -#line 1631 "c-parse.y"
  11153. -{ yyvsp[0].lineno = lineno;
  11154. -          yyval.filename = input_filename; ;
  11155. -    break;}
  11156. -case 317:
  11157. -#line 1634 "c-parse.y"
  11158. -{ 
  11159. -          /* Start the loop.  Doing this after parsing
  11160. -             all the expressions ensures we will end the loop.  */
  11161. -          expand_start_loop_continue_elsewhere (1);
  11162. -          /* Emit the end-test, with a line number.  */
  11163. -          emit_line_note (yyvsp[-2].filename, yyvsp[-3].lineno);
  11164. -          if (yyvsp[-4].ttype)
  11165. -            expand_exit_loop_if_false (NULL_PTR,
  11166. -                           truthvalue_conversion (yyvsp[-4].ttype));
  11167. -          /* Don't let the tree nodes for $9 be discarded by
  11168. -             clear_momentary during the parsing of the next stmt.  */
  11169. -          push_momentary ();
  11170. -          yyvsp[-3].lineno = lineno;
  11171. -          yyvsp[-2].filename = input_filename;
  11172. -          position_after_white_space (); ;
  11173. -    break;}
  11174. -case 318:
  11175. -#line 1650 "c-parse.y"
  11176. -{ /* Emit the increment expression, with a line number.  */
  11177. -          emit_line_note (yyvsp[-4].filename, yyvsp[-5].lineno);
  11178. -          expand_loop_continue_here ();
  11179. -          if (yyvsp[-3].ttype)
  11180. -            c_expand_expr_stmt (yyvsp[-3].ttype);
  11181. -          if (yychar == CONSTANT || yychar == STRING)
  11182. -            pop_momentary_nofree ();
  11183. -          else
  11184. -            pop_momentary ();
  11185. -          expand_end_loop (); ;
  11186. -    break;}
  11187. -case 319:
  11188. -#line 1661 "c-parse.y"
  11189. -{ stmt_count++;
  11190. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  11191. -          c_expand_start_case (yyvsp[-1].ttype);
  11192. -          /* Don't let the tree nodes for $3 be discarded by
  11193. -             clear_momentary during the parsing of the next stmt.  */
  11194. -          push_momentary ();
  11195. -          position_after_white_space (); ;
  11196. -    break;}
  11197. -case 320:
  11198. -#line 1669 "c-parse.y"
  11199. -{ expand_end_case (yyvsp[-3].ttype);
  11200. -          if (yychar == CONSTANT || yychar == STRING)
  11201. -            pop_momentary_nofree ();
  11202. -          else
  11203. -            pop_momentary (); ;
  11204. -    break;}
  11205. -case 321:
  11206. -#line 1675 "c-parse.y"
  11207. -{ stmt_count++;
  11208. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  11209. -          if ( ! expand_exit_something ())
  11210. -            error ("break statement not within loop or switch"); ;
  11211. -    break;}
  11212. -case 322:
  11213. -#line 1680 "c-parse.y"
  11214. -{ stmt_count++;
  11215. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  11216. -          if (! expand_continue_loop (NULL_PTR))
  11217. -            error ("continue statement not within a loop"); ;
  11218. -    break;}
  11219. -case 323:
  11220. -#line 1685 "c-parse.y"
  11221. -{ stmt_count++;
  11222. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  11223. -          c_expand_return (NULL_TREE); ;
  11224. -    break;}
  11225. -case 324:
  11226. -#line 1689 "c-parse.y"
  11227. -{ stmt_count++;
  11228. -          emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno);
  11229. -          c_expand_return (yyvsp[-1].ttype); ;
  11230. -    break;}
  11231. -case 325:
  11232. -#line 1693 "c-parse.y"
  11233. -{ stmt_count++;
  11234. -          emit_line_note (yyvsp[-7].filename, yyvsp[-6].lineno);
  11235. -          STRIP_NOPS (yyvsp[-2].ttype);
  11236. -          if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR
  11237. -               && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST)
  11238. -              || TREE_CODE (yyvsp[-2].ttype) == STRING_CST)
  11239. -            expand_asm (yyvsp[-2].ttype);
  11240. -          else
  11241. -            error ("argument of `asm' is not a constant string"); ;
  11242. -    break;}
  11243. -case 326:
  11244. -#line 1704 "c-parse.y"
  11245. -{ stmt_count++;
  11246. -          emit_line_note (yyvsp[-9].filename, yyvsp[-8].lineno);
  11247. -          c_expand_asm_operands (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE,
  11248. -                     yyvsp[-6].ttype == ridpointers[(int)RID_VOLATILE],
  11249. -                     input_filename, lineno); ;
  11250. -    break;}
  11251. -case 327:
  11252. -#line 1711 "c-parse.y"
  11253. -{ stmt_count++;
  11254. -          emit_line_note (yyvsp[-11].filename, yyvsp[-10].lineno);
  11255. -          c_expand_asm_operands (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE,
  11256. -                     yyvsp[-8].ttype == ridpointers[(int)RID_VOLATILE],
  11257. -                     input_filename, lineno); ;
  11258. -    break;}
  11259. -case 328:
  11260. -#line 1719 "c-parse.y"
  11261. -{ stmt_count++;
  11262. -          emit_line_note (yyvsp[-13].filename, yyvsp[-12].lineno);
  11263. -          c_expand_asm_operands (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype,
  11264. -                     yyvsp[-10].ttype == ridpointers[(int)RID_VOLATILE],
  11265. -                     input_filename, lineno); ;
  11266. -    break;}
  11267. -case 329:
  11268. -#line 1725 "c-parse.y"
  11269. -{ tree decl;
  11270. -          stmt_count++;
  11271. -          emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno);
  11272. -          decl = lookup_label (yyvsp[-1].ttype);
  11273. -          if (decl != 0)
  11274. -            {
  11275. -              TREE_USED (decl) = 1;
  11276. -              expand_goto (decl);
  11277. -            }
  11278. -        ;
  11279. -    break;}
  11280. -case 330:
  11281. -#line 1736 "c-parse.y"
  11282. -{ stmt_count++;
  11283. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  11284. -          expand_computed_goto (convert (ptr_type_node, yyvsp[-1].ttype)); ;
  11285. -    break;}
  11286. -case 333:
  11287. -#line 1749 "c-parse.y"
  11288. -{
  11289. -        /* The value returned by this action is  */
  11290. -        /*      1 if everything is OK */ 
  11291. -        /*      0 in case of error or already bound iterator */
  11292. -
  11293. -        yyval.itype = 0;
  11294. -        if (TREE_CODE (yyvsp[-1].ttype) != VAR_DECL)
  11295. -          error ("invalid `for (ITERATOR)' syntax");
  11296. -        else if (! ITERATOR_P (yyvsp[-1].ttype))
  11297. -          error ("`%s' is not an iterator",
  11298. -             IDENTIFIER_POINTER (DECL_NAME (yyvsp[-1].ttype)));
  11299. -        else if (ITERATOR_BOUND_P (yyvsp[-1].ttype))
  11300. -          error ("`for (%s)' inside expansion of same iterator",
  11301. -             IDENTIFIER_POINTER (DECL_NAME (yyvsp[-1].ttype)));
  11302. -        else
  11303. -          {
  11304. -        yyval.itype = 1;
  11305. -        iterator_for_loop_start (yyvsp[-1].ttype);
  11306. -          }
  11307. -      ;
  11308. -    break;}
  11309. -case 334:
  11310. -#line 1770 "c-parse.y"
  11311. -{
  11312. -        if (yyvsp[-1].itype)
  11313. -          iterator_for_loop_end (yyvsp[-3].ttype);
  11314. -      ;
  11315. -    break;}
  11316. -case 335:
  11317. -#line 1805 "c-parse.y"
  11318. -{ register tree value = check_case_value (yyvsp[-1].ttype);
  11319. -          register tree label
  11320. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  11321. -
  11322. -          stmt_count++;
  11323. -
  11324. -          if (value != error_mark_node)
  11325. -            {
  11326. -              tree duplicate;
  11327. -              int success = pushcase (value, convert_and_check,
  11328. -                          label, &duplicate);
  11329. -              if (success == 1)
  11330. -            error ("case label not within a switch statement");
  11331. -              else if (success == 2)
  11332. -            {
  11333. -              error ("duplicate case value");
  11334. -              error_with_decl (duplicate, "this is the first entry for that value");
  11335. -            }
  11336. -              else if (success == 3)
  11337. -            warning ("case value out of range");
  11338. -              else if (success == 5)
  11339. -            error ("case label within scope of cleanup or variable array");
  11340. -            }
  11341. -          position_after_white_space (); ;
  11342. -    break;}
  11343. -case 336:
  11344. -#line 1830 "c-parse.y"
  11345. -{ register tree value1 = check_case_value (yyvsp[-3].ttype);
  11346. -          register tree value2 = check_case_value (yyvsp[-1].ttype);
  11347. -          register tree label
  11348. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  11349. -
  11350. -          stmt_count++;
  11351. -
  11352. -          if (value1 != error_mark_node && value2 != error_mark_node)
  11353. -            {
  11354. -              tree duplicate;
  11355. -              int success = pushcase_range (value1, value2,
  11356. -                            convert_and_check, label,
  11357. -                            &duplicate);
  11358. -              if (success == 1)
  11359. -            error ("case label not within a switch statement");
  11360. -              else if (success == 2)
  11361. -            {
  11362. -              error ("duplicate case value");
  11363. -              error_with_decl (duplicate, "this is the first entry for that value");
  11364. -            }
  11365. -              else if (success == 3)
  11366. -            warning ("case value out of range");
  11367. -              else if (success == 4)
  11368. -            warning ("empty case range");
  11369. -              else if (success == 5)
  11370. -            error ("case label within scope of cleanup or variable array");
  11371. -            }
  11372. -          position_after_white_space (); ;
  11373. -    break;}
  11374. -case 337:
  11375. -#line 1859 "c-parse.y"
  11376. -{
  11377. -          tree duplicate;
  11378. -          register tree label
  11379. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  11380. -          int success = pushcase (NULL_TREE, 0, label, &duplicate);
  11381. -          stmt_count++;
  11382. -          if (success == 1)
  11383. -            error ("default label not within a switch statement");
  11384. -          else if (success == 2)
  11385. -            {
  11386. -              error ("multiple default labels in one switch");
  11387. -              error_with_decl (duplicate, "this is the first default label");
  11388. -            }
  11389. -          position_after_white_space (); ;
  11390. -    break;}
  11391. -case 338:
  11392. -#line 1874 "c-parse.y"
  11393. -{ tree label = define_label (input_filename, lineno, yyvsp[-1].ttype);
  11394. -          stmt_count++;
  11395. -          emit_nop ();
  11396. -          if (label)
  11397. -            expand_label (label);
  11398. -          position_after_white_space (); ;
  11399. -    break;}
  11400. -case 339:
  11401. -#line 1886 "c-parse.y"
  11402. -{ emit_line_note (input_filename, lineno);
  11403. -          yyval.ttype = NULL_TREE; ;
  11404. -    break;}
  11405. -case 340:
  11406. -#line 1889 "c-parse.y"
  11407. -{ emit_line_note (input_filename, lineno); ;
  11408. -    break;}
  11409. -case 341:
  11410. -#line 1894 "c-parse.y"
  11411. -{ yyval.ttype = NULL_TREE; ;
  11412. -    break;}
  11413. -case 343:
  11414. -#line 1901 "c-parse.y"
  11415. -{ yyval.ttype = NULL_TREE; ;
  11416. -    break;}
  11417. -case 346:
  11418. -#line 1908 "c-parse.y"
  11419. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  11420. -    break;}
  11421. -case 347:
  11422. -#line 1913 "c-parse.y"
  11423. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  11424. -    break;}
  11425. -case 348:
  11426. -#line 1918 "c-parse.y"
  11427. -{ yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), NULL_TREE); ;
  11428. -    break;}
  11429. -case 349:
  11430. -#line 1920 "c-parse.y"
  11431. -{ yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), yyvsp[-2].ttype); ;
  11432. -    break;}
  11433. -case 350:
  11434. -#line 1926 "c-parse.y"
  11435. -{ pushlevel (0);
  11436. -          clear_parm_order ();
  11437. -          declare_parm_level (0); ;
  11438. -    break;}
  11439. -case 351:
  11440. -#line 1930 "c-parse.y"
  11441. -{ yyval.ttype = yyvsp[0].ttype;
  11442. -          parmlist_tags_warning ();
  11443. -          poplevel (0, 0, 0); ;
  11444. -    break;}
  11445. -case 353:
  11446. -#line 1938 "c-parse.y"
  11447. -{ tree parm;
  11448. -          if (pedantic)
  11449. -            pedwarn ("ANSI C forbids forward parameter declarations");
  11450. -          /* Mark the forward decls as such.  */
  11451. -          for (parm = getdecls (); parm; parm = TREE_CHAIN (parm))
  11452. -            TREE_ASM_WRITTEN (parm) = 1;
  11453. -          clear_parm_order (); ;
  11454. -    break;}
  11455. -case 354:
  11456. -#line 1946 "c-parse.y"
  11457. -{ yyval.ttype = yyvsp[0].ttype; ;
  11458. -    break;}
  11459. -case 355:
  11460. -#line 1948 "c-parse.y"
  11461. -{ yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); ;
  11462. -    break;}
  11463. -case 356:
  11464. -#line 1954 "c-parse.y"
  11465. -{ yyval.ttype = get_parm_info (0); ;
  11466. -    break;}
  11467. -case 357:
  11468. -#line 1956 "c-parse.y"
  11469. -{ yyval.ttype = get_parm_info (0);
  11470. -          /* Gcc used to allow this as an extension.  However, it does
  11471. -             not work for all targets, and thus has been disabled.
  11472. -             Also, since func (...) and func () are indistinguishable,
  11473. -             it caused problems with the code in expand_builtin which
  11474. -             tries to verify that BUILT_IN_NEXT_ARG is being used
  11475. -             correctly.  */
  11476. -          error ("ANSI C requires a named argument before `...'");
  11477. -        ;
  11478. -    break;}
  11479. -case 358:
  11480. -#line 1966 "c-parse.y"
  11481. -{ yyval.ttype = get_parm_info (1); ;
  11482. -    break;}
  11483. -case 359:
  11484. -#line 1968 "c-parse.y"
  11485. -{ yyval.ttype = get_parm_info (0); ;
  11486. -    break;}
  11487. -case 360:
  11488. -#line 1973 "c-parse.y"
  11489. -{ push_parm_decl (yyvsp[0].ttype); ;
  11490. -    break;}
  11491. -case 361:
  11492. -#line 1975 "c-parse.y"
  11493. -{ push_parm_decl (yyvsp[0].ttype); ;
  11494. -    break;}
  11495. -case 362:
  11496. -#line 1982 "c-parse.y"
  11497. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  11498. -                             yyvsp[-1].ttype),
  11499. -                    build_tree_list (prefix_attributes,
  11500. -                             yyvsp[0].ttype));
  11501. -          current_declspecs = TREE_VALUE (declspec_stack);
  11502. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  11503. -          declspec_stack = TREE_CHAIN (declspec_stack);
  11504. -          resume_momentary (yyvsp[-2].itype); ;
  11505. -    break;}
  11506. -case 363:
  11507. -#line 1991 "c-parse.y"
  11508. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  11509. -                             yyvsp[-1].ttype),
  11510. -                    build_tree_list (prefix_attributes,
  11511. -                             yyvsp[0].ttype)); 
  11512. -          current_declspecs = TREE_VALUE (declspec_stack);
  11513. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  11514. -          declspec_stack = TREE_CHAIN (declspec_stack);
  11515. -          resume_momentary (yyvsp[-2].itype); ;
  11516. -    break;}
  11517. -case 364:
  11518. -#line 2000 "c-parse.y"
  11519. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  11520. -                             yyvsp[-1].ttype),
  11521. -                    build_tree_list (prefix_attributes,
  11522. -                             yyvsp[0].ttype));
  11523. -          current_declspecs = TREE_VALUE (declspec_stack);
  11524. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  11525. -          declspec_stack = TREE_CHAIN (declspec_stack);
  11526. -          resume_momentary (yyvsp[-2].itype); ;
  11527. -    break;}
  11528. -case 365:
  11529. -#line 2009 "c-parse.y"
  11530. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  11531. -                             yyvsp[-1].ttype),
  11532. -                    build_tree_list (prefix_attributes,
  11533. -                             yyvsp[0].ttype));
  11534. -          current_declspecs = TREE_VALUE (declspec_stack);
  11535. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  11536. -          declspec_stack = TREE_CHAIN (declspec_stack);
  11537. -          resume_momentary (yyvsp[-2].itype);  ;
  11538. -    break;}
  11539. -case 366:
  11540. -#line 2019 "c-parse.y"
  11541. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  11542. -                             yyvsp[-1].ttype),
  11543. -                    build_tree_list (prefix_attributes,
  11544. -                             yyvsp[0].ttype));
  11545. -          current_declspecs = TREE_VALUE (declspec_stack);
  11546. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  11547. -          declspec_stack = TREE_CHAIN (declspec_stack);
  11548. -          resume_momentary (yyvsp[-2].itype);  ;
  11549. -    break;}
  11550. -case 367:
  11551. -#line 2033 "c-parse.y"
  11552. -{ pushlevel (0);
  11553. -          clear_parm_order ();
  11554. -          declare_parm_level (1); ;
  11555. -    break;}
  11556. -case 368:
  11557. -#line 2037 "c-parse.y"
  11558. -{ yyval.ttype = yyvsp[0].ttype;
  11559. -          parmlist_tags_warning ();
  11560. -          poplevel (0, 0, 0); ;
  11561. -    break;}
  11562. -case 370:
  11563. -#line 2045 "c-parse.y"
  11564. -{ tree t;
  11565. -          for (t = yyvsp[-1].ttype; t; t = TREE_CHAIN (t))
  11566. -            if (TREE_VALUE (t) == NULL_TREE)
  11567. -              error ("`...' in old-style identifier list");
  11568. -          yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, yyvsp[-1].ttype); ;
  11569. -    break;}
  11570. -case 371:
  11571. -#line 2055 "c-parse.y"
  11572. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  11573. -    break;}
  11574. -case 372:
  11575. -#line 2057 "c-parse.y"
  11576. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  11577. -    break;}
  11578. -case 373:
  11579. -#line 2063 "c-parse.y"
  11580. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  11581. -    break;}
  11582. -case 374:
  11583. -#line 2065 "c-parse.y"
  11584. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  11585. -    break;}
  11586. -}
  11587. -   /* the action file gets copied in in place of this dollarsign */
  11588. -#line 480 "/usr/local/lib/bison.simple"
  11589. -
  11590. -  yyvsp -= yylen;
  11591. -  yyssp -= yylen;
  11592. -#ifdef YYLSP_NEEDED
  11593. -  yylsp -= yylen;
  11594. -#endif
  11595. -
  11596. -#if YYDEBUG != 0
  11597. -  if (yydebug)
  11598. -    {
  11599. -      short *ssp1 = yyss - 1;
  11600. -      fprintf (stderr, "state stack now");
  11601. -      while (ssp1 != yyssp)
  11602. -    fprintf (stderr, " %d", *++ssp1);
  11603. -      fprintf (stderr, "\n");
  11604. -    }
  11605. -#endif
  11606. -
  11607. -  *++yyvsp = yyval;
  11608. -
  11609. -#ifdef YYLSP_NEEDED
  11610. -  yylsp++;
  11611. -  if (yylen == 0)
  11612. -    {
  11613. -      yylsp->first_line = yylloc.first_line;
  11614. -      yylsp->first_column = yylloc.first_column;
  11615. -      yylsp->last_line = (yylsp-1)->last_line;
  11616. -      yylsp->last_column = (yylsp-1)->last_column;
  11617. -      yylsp->text = 0;
  11618. -    }
  11619. -  else
  11620. -    {
  11621. -      yylsp->last_line = (yylsp+yylen-1)->last_line;
  11622. -      yylsp->last_column = (yylsp+yylen-1)->last_column;
  11623. -    }
  11624. -#endif
  11625. -
  11626. -  /* Now "shift" the result of the reduction.
  11627. -     Determine what state that goes to,
  11628. -     based on the state we popped back to
  11629. -     and the rule number reduced by.  */
  11630. -
  11631. -  yyn = yyr1[yyn];
  11632. -
  11633. -  yystate = yypgoto[yyn - YYNTBASE] + *yyssp;
  11634. -  if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp)
  11635. -    yystate = yytable[yystate];
  11636. -  else
  11637. -    yystate = yydefgoto[yyn - YYNTBASE];
  11638. -
  11639. -  goto yynewstate;
  11640. -
  11641. -yyerrlab:   /* here on detecting error */
  11642. -
  11643. -  if (! yyerrstatus)
  11644. -    /* If not already recovering from an error, report this error.  */
  11645. -    {
  11646. -      ++yynerrs;
  11647. -
  11648. -#ifdef YYERROR_VERBOSE
  11649. -      yyn = yypact[yystate];
  11650. -
  11651. -      if (yyn > YYFLAG && yyn < YYLAST)
  11652. -    {
  11653. -      int size = 0;
  11654. -      char *msg;
  11655. -      int x, count;
  11656. -
  11657. -      count = 0;
  11658. -      /* Start X at -yyn if nec to avoid negative indexes in yycheck.  */
  11659. -      for (x = (yyn < 0 ? -yyn : 0);
  11660. -           x < (sizeof(yytname) / sizeof(char *)); x++)
  11661. -        if (yycheck[x + yyn] == x)
  11662. -          size += strlen(yytname[x]) + 15, count++;
  11663. -      msg = (char *) malloc(size + 15);
  11664. -      if (msg != 0)
  11665. -        {
  11666. -          strcpy(msg, "parse error");
  11667. -
  11668. -          if (count < 5)
  11669. -        {
  11670. -          count = 0;
  11671. -          for (x = (yyn < 0 ? -yyn : 0);
  11672. -               x < (sizeof(yytname) / sizeof(char *)); x++)
  11673. -            if (yycheck[x + yyn] == x)
  11674. -              {
  11675. -            strcat(msg, count == 0 ? ", expecting `" : " or `");
  11676. -            strcat(msg, yytname[x]);
  11677. -            strcat(msg, "'");
  11678. -            count++;
  11679. -              }
  11680. -        }
  11681. -          yyerror(msg);
  11682. -          free(msg);
  11683. -        }
  11684. -      else
  11685. -        yyerror ("parse error; also virtual memory exceeded");
  11686. -    }
  11687. -      else
  11688. -#endif /* YYERROR_VERBOSE */
  11689. -    yyerror("parse error");
  11690. -    }
  11691. -
  11692. -  goto yyerrlab1;
  11693. -yyerrlab1:   /* here on error raised explicitly by an action */
  11694. -
  11695. -  if (yyerrstatus == 3)
  11696. -    {
  11697. -      /* if just tried and failed to reuse lookahead token after an error, discard it.  */
  11698. -
  11699. -      /* return failure if at end of input */
  11700. -      if (yychar == YYEOF)
  11701. -    YYABORT;
  11702. -
  11703. -#if YYDEBUG != 0
  11704. -      if (yydebug)
  11705. -    fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]);
  11706. -#endif
  11707. -
  11708. -      yychar = YYEMPTY;
  11709. -    }
  11710. -
  11711. -  /* Else will try to reuse lookahead token
  11712. -     after shifting the error token.  */
  11713. -
  11714. -  yyerrstatus = 3;        /* Each real token shifted decrements this */
  11715. -
  11716. -  goto yyerrhandle;
  11717. -
  11718. -yyerrdefault:  /* current state does not do anything special for the error token. */
  11719. -
  11720. -#if 0
  11721. -  /* This is wrong; only states that explicitly want error tokens
  11722. -     should shift them.  */
  11723. -  yyn = yydefact[yystate];  /* If its default is to accept any token, ok.  Otherwise pop it.*/
  11724. -  if (yyn) goto yydefault;
  11725. -#endif
  11726. -
  11727. -yyerrpop:   /* pop the current state because it cannot handle the error token */
  11728. -
  11729. -  if (yyssp == yyss) YYABORT;
  11730. -  yyvsp--;
  11731. -  yystate = *--yyssp;
  11732. -#ifdef YYLSP_NEEDED
  11733. -  yylsp--;
  11734. -#endif
  11735. -
  11736. -#if YYDEBUG != 0
  11737. -  if (yydebug)
  11738. -    {
  11739. -      short *ssp1 = yyss - 1;
  11740. -      fprintf (stderr, "Error: state stack now");
  11741. -      while (ssp1 != yyssp)
  11742. -    fprintf (stderr, " %d", *++ssp1);
  11743. -      fprintf (stderr, "\n");
  11744. -    }
  11745. -#endif
  11746. -
  11747. -yyerrhandle:
  11748. -
  11749. -  yyn = yypact[yystate];
  11750. -  if (yyn == YYFLAG)
  11751. -    goto yyerrdefault;
  11752. -
  11753. -  yyn += YYTERROR;
  11754. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR)
  11755. -    goto yyerrdefault;
  11756. -
  11757. -  yyn = yytable[yyn];
  11758. -  if (yyn < 0)
  11759. -    {
  11760. -      if (yyn == YYFLAG)
  11761. -    goto yyerrpop;
  11762. -      yyn = -yyn;
  11763. -      goto yyreduce;
  11764. -    }
  11765. -  else if (yyn == 0)
  11766. -    goto yyerrpop;
  11767. -
  11768. -  if (yyn == YYFINAL)
  11769. -    YYACCEPT;
  11770. -
  11771. -#if YYDEBUG != 0
  11772. -  if (yydebug)
  11773. -    fprintf(stderr, "Shifting error token, ");
  11774. -#endif
  11775. -
  11776. -  *++yyvsp = yylval;
  11777. -#ifdef YYLSP_NEEDED
  11778. -  *++yylsp = yylloc;
  11779. -#endif
  11780. -
  11781. -  yystate = yyn;
  11782. -  goto yynewstate;
  11783. -}
  11784. -#line 2068 "c-parse.y"
  11785. -
  11786. diff -rup --new-file baseline/fsf/gcc/c-parse.h amiga/fsf/gcc/c-parse.h
  11787. --- baseline/fsf/gcc/c-parse.h    Sat Sep 23 09:22:53 1995
  11788. +++ amiga/fsf/gcc/c-parse.h    Wed Dec 31 17:00:00 1969
  11789. @@ -1,64 +0,0 @@
  11790. -typedef union {long itype; tree ttype; enum tree_code code;
  11791. -    char *filename; int lineno; int ends_in_label; } YYSTYPE;
  11792. -#define    IDENTIFIER    258
  11793. -#define    TYPENAME    259
  11794. -#define    SCSPEC    260
  11795. -#define    TYPESPEC    261
  11796. -#define    TYPE_QUAL    262
  11797. -#define    CONSTANT    263
  11798. -#define    STRING    264
  11799. -#define    ELLIPSIS    265
  11800. -#define    SIZEOF    266
  11801. -#define    ENUM    267
  11802. -#define    STRUCT    268
  11803. -#define    UNION    269
  11804. -#define    IF    270
  11805. -#define    ELSE    271
  11806. -#define    WHILE    272
  11807. -#define    DO    273
  11808. -#define    FOR    274
  11809. -#define    SWITCH    275
  11810. -#define    CASE    276
  11811. -#define    DEFAULT    277
  11812. -#define    BREAK    278
  11813. -#define    CONTINUE    279
  11814. -#define    RETURN    280
  11815. -#define    GOTO    281
  11816. -#define    ASM_KEYWORD    282
  11817. -#define    TYPEOF    283
  11818. -#define    ALIGNOF    284
  11819. -#define    ATTRIBUTE    285
  11820. -#define    EXTENSION    286
  11821. -#define    LABEL    287
  11822. -#define    REALPART    288
  11823. -#define    IMAGPART    289
  11824. -#define    ASSIGN    290
  11825. -#define    OROR    291
  11826. -#define    ANDAND    292
  11827. -#define    EQCOMPARE    293
  11828. -#define    ARITHCOMPARE    294
  11829. -#define    LSHIFT    295
  11830. -#define    RSHIFT    296
  11831. -#define    UNARY    297
  11832. -#define    PLUSPLUS    298
  11833. -#define    MINUSMINUS    299
  11834. -#define    HYPERUNARY    300
  11835. -#define    POINTSAT    301
  11836. -#define    INTERFACE    302
  11837. -#define    IMPLEMENTATION    303
  11838. -#define    END    304
  11839. -#define    SELECTOR    305
  11840. -#define    DEFS    306
  11841. -#define    ENCODE    307
  11842. -#define    CLASSNAME    308
  11843. -#define    PUBLIC    309
  11844. -#define    PRIVATE    310
  11845. -#define    PROTECTED    311
  11846. -#define    PROTOCOL    312
  11847. -#define    OBJECTNAME    313
  11848. -#define    CLASS    314
  11849. -#define    ALIAS    315
  11850. -#define    OBJC_STRING    316
  11851. -
  11852. -
  11853. -extern YYSTYPE yylval;
  11854. diff -rup --new-file baseline/fsf/gcc/c-parse.in amiga/fsf/gcc/c-parse.in
  11855. --- baseline/fsf/gcc/c-parse.in    Fri Sep 22 16:08:07 1995
  11856. +++ amiga/fsf/gcc/c-parse.in    Sat Sep 28 00:00:00 1996
  11857. @@ -2156,56 +2156,75 @@ parmlist_2:  /* empty */
  11858.  
  11859.  parms:
  11860.      parm
  11861. -        { push_parm_decl ($1); }
  11862. +/* Amiga-specific support for explicit register specification for parameters.
  11863. +   KI 1.04.1996 */
  11864. +        { push_parm_decl (TREE_PURPOSE($1), TREE_VALUE($1)); }
  11865.      | parms ',' parm
  11866. -        { push_parm_decl ($3); }
  11867. +/* Amiga-specific support for explicit register specification for parameters.
  11868. +   KI 1.04.1996 */
  11869. +        { push_parm_decl (TREE_PURPOSE($3), TREE_VALUE($3)); }
  11870.      ;
  11871.  
  11872.  /* A single parameter declaration or parameter type name,
  11873.     as found in a parmlist.  */
  11874.  parm:
  11875. -      typed_declspecs setspecs parm_declarator maybe_attribute
  11876. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11877. -                             $3),
  11878. -                    build_tree_list (prefix_attributes,
  11879. -                             $4));
  11880. +/* Amiga-specific support for explicit register specification for parameters.
  11881. +   KI 1.04.1996 */
  11882. +      typed_declspecs setspecs parm_declarator maybeasm maybe_attribute
  11883. +        { $$ = build_tree_list (
  11884. +             build_tree_list (build_tree_list (current_declspecs,
  11885. +                               $3),
  11886. +                      build_tree_list (prefix_attributes,
  11887. +                               $5)), $4);
  11888.            current_declspecs = TREE_VALUE (declspec_stack);
  11889.            prefix_attributes = TREE_PURPOSE (declspec_stack);
  11890.            declspec_stack = TREE_CHAIN (declspec_stack);
  11891.            resume_momentary ($2); }
  11892. -    | typed_declspecs setspecs notype_declarator maybe_attribute
  11893. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11894. -                             $3),
  11895. -                    build_tree_list (prefix_attributes,
  11896. -                             $4)); 
  11897. +/* Amiga-specific support for explicit register specification for parameters.
  11898. +   KI 1.04.1996 */
  11899. +    | typed_declspecs setspecs notype_declarator maybeasm maybe_attribute
  11900. +        { $$ = build_tree_list (
  11901. +             build_tree_list (build_tree_list (current_declspecs,
  11902. +                               $3),
  11903. +                      build_tree_list (prefix_attributes,
  11904. +                               $5)), $4); 
  11905.            current_declspecs = TREE_VALUE (declspec_stack);
  11906.            prefix_attributes = TREE_PURPOSE (declspec_stack);
  11907.            declspec_stack = TREE_CHAIN (declspec_stack);
  11908.            resume_momentary ($2); }
  11909. -    | typed_declspecs setspecs absdcl maybe_attribute
  11910. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11911. -                             $3),
  11912. -                    build_tree_list (prefix_attributes,
  11913. -                             $4));
  11914. +/* Amiga-specific support for explicit register specification for parameters.
  11915. +   KI 1.04.1996 */
  11916. +    | typed_declspecs setspecs absdcl maybeasm maybe_attribute
  11917. +        { $$ = build_tree_list (
  11918. +             build_tree_list (build_tree_list (current_declspecs,
  11919. +                               $3),
  11920. +                      build_tree_list (prefix_attributes,
  11921. +                               $5)), $4);
  11922.            current_declspecs = TREE_VALUE (declspec_stack);
  11923.            prefix_attributes = TREE_PURPOSE (declspec_stack);
  11924.            declspec_stack = TREE_CHAIN (declspec_stack);
  11925.            resume_momentary ($2); }
  11926. -    | declmods setspecs notype_declarator maybe_attribute
  11927. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11928. -                             $3),
  11929. -                    build_tree_list (prefix_attributes,
  11930. -                             $4));
  11931. +/* Amiga-specific support for explicit register specification for parameters.
  11932. +   KI 1.04.1996 */
  11933. +    | declmods setspecs notype_declarator maybeasm maybe_attribute
  11934. +        { $$ = build_tree_list (
  11935. +             build_tree_list (build_tree_list (current_declspecs,
  11936. +                               $3),
  11937. +                      build_tree_list (prefix_attributes,
  11938. +                               $5)), $4);
  11939.            current_declspecs = TREE_VALUE (declspec_stack);
  11940.            prefix_attributes = TREE_PURPOSE (declspec_stack);
  11941.            declspec_stack = TREE_CHAIN (declspec_stack);
  11942.            resume_momentary ($2);  }
  11943.  
  11944. -    | declmods setspecs absdcl maybe_attribute
  11945. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11946. -                             $3),
  11947. -                    build_tree_list (prefix_attributes,
  11948. -                             $4));
  11949. +/* Amiga-specific support for explicit register specification for parameters.
  11950. +   KI 1.04.1996 */
  11951. +    | declmods setspecs absdcl maybeasm maybe_attribute
  11952. +        { $$ = build_tree_list (
  11953. +             build_tree_list (build_tree_list (current_declspecs,
  11954. +                               $3),
  11955. +                      build_tree_list (prefix_attributes,
  11956. +                               $5)), $4);
  11957.            current_declspecs = TREE_VALUE (declspec_stack);
  11958.            prefix_attributes = TREE_PURPOSE (declspec_stack);
  11959.            declspec_stack = TREE_CHAIN (declspec_stack);
  11960. @@ -2680,30 +2699,43 @@ mydecl:
  11961.  
  11962.  myparms:
  11963.      myparm
  11964. -        { push_parm_decl ($1); }
  11965. +/* Amiga-specific support for explicit register specification for parameters.
  11966. +   KI 1.04.1996 */
  11967. +        { push_parm_decl (TREE_PURPOSE($1), TREE_VALUE($1)); }
  11968.      | myparms ',' myparm
  11969. -        { push_parm_decl ($3); }
  11970. +/* Amiga-specific support for explicit register specification for parameters.
  11971. +   KI 1.04.1996 */
  11972. +        { push_parm_decl (TREE_PURPOSE($3), TREE_VALUE($3)); }
  11973.      ;
  11974.  
  11975.  /* A single parameter declaration or parameter type name,
  11976. -   as found in a parmlist. DOES NOT ALLOW AN INITIALIZER OR ASMSPEC */
  11977. +   as found in a parmlist. DOES NOT ALLOW AN INITIALIZER */
  11978.  
  11979.  myparm:
  11980. -      parm_declarator maybe_attribute
  11981. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11982. +/* Amiga-specific support for explicit register specification for parameters.
  11983. +   KI 1.04.1996 */
  11984. +      parm_declarator maybeasm maybe_attribute
  11985. +        { $$ = build_tree_list (
  11986. +             build_tree_list (build_tree_list (current_declspecs,
  11987.                               $1),
  11988. -                    build_tree_list (prefix_attributes,
  11989. -                             $2)); }
  11990. -    | notype_declarator maybe_attribute
  11991. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11992. -                             $1),
  11993. -                    build_tree_list (prefix_attributes,
  11994. -                             $2)); }
  11995. -    | absdcl maybe_attribute
  11996. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  11997. -                             $1),
  11998. -                    build_tree_list (prefix_attributes,
  11999. -                             $2)); }
  12000. +                      build_tree_list (prefix_attributes,
  12001. +                             $3)), $2); }
  12002. +/* Amiga-specific support for explicit register specification for parameters.
  12003. +   KI 1.04.1996 */
  12004. +    | notype_declarator maybeasm maybe_attribute
  12005. +        { $$ = build_tree_list (
  12006. +             build_tree_list (build_tree_list (current_declspecs,
  12007. +                               $1),
  12008. +                      build_tree_list (prefix_attributes,
  12009. +                               $3)), $2); }
  12010. +/* Amiga-specific support for explicit register specification for parameters.
  12011. +   KI 1.04.1996 */
  12012. +    | absdcl maybeasm maybe_attribute
  12013. +        { $$ = build_tree_list (
  12014. +             build_tree_list (build_tree_list (current_declspecs,
  12015. +                               $1),
  12016. +                      build_tree_list (prefix_attributes,
  12017. +                               $3)), $2); }
  12018.      ;
  12019.  
  12020.  optparmlist:
  12021. diff -rup --new-file baseline/fsf/gcc/c-parse.y amiga/fsf/gcc/c-parse.y
  12022. --- baseline/fsf/gcc/c-parse.y    Sat Sep 23 09:22:42 1995
  12023. +++ amiga/fsf/gcc/c-parse.y    Wed Dec 31 17:00:00 1969
  12024. @@ -1,2068 +0,0 @@
  12025. -/* YACC parser for C syntax and for Objective C.  -*-c-*-
  12026. -   Copyright (C) 1987, 88, 89, 92, 93, 94, 1995 Free Software Foundation, Inc.
  12027. -
  12028. -This file is part of GNU CC.
  12029. -
  12030. -GNU CC is free software; you can redistribute it and/or modify
  12031. -it under the terms of the GNU General Public License as published by
  12032. -the Free Software Foundation; either version 2, or (at your option)
  12033. -any later version.
  12034. -
  12035. -GNU CC is distributed in the hope that it will be useful,
  12036. -but WITHOUT ANY WARRANTY; without even the implied warranty of
  12037. -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12038. -GNU General Public License for more details.
  12039. -
  12040. -You should have received a copy of the GNU General Public License
  12041. -along with GNU CC; see the file COPYING.  If not, write to
  12042. -the Free Software Foundation, 59 Temple Place - Suite 330,
  12043. -Boston, MA 02111-1307, USA.  */
  12044. -
  12045. -/* This file defines the grammar of C and that of Objective C.
  12046. -   ifobjc ... end ifobjc  conditionals contain code for Objective C only.
  12047. -   ifc ... end ifc  conditionals contain code for C only.
  12048. -   Sed commands in Makefile.in are used to convert this file into
  12049. -   c-parse.y and into objc-parse.y.  */
  12050. -
  12051. -/* To whomever it may concern: I have heard that such a thing was once
  12052. -   written by AT&T, but I have never seen it.  */
  12053. -
  12054. -%expect 34
  12055. -
  12056. -/* These are the 23 conflicts you should get in parse.output;
  12057. -   the state numbers may vary if minor changes in the grammar are made.
  12058. -
  12059. -State 42 contains 1 shift/reduce conflict.  (Two ways to parse ATTRIBUTE.)
  12060. -State 44 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12061. -State 103 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12062. -State 110 contains 1 shift/reduce conflict.  (Two ways to parse ATTRIBUTE.)
  12063. -State 111 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12064. -State 115 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12065. -State 132 contains 1 shift/reduce conflict.  (See comment at component_decl.)
  12066. -State 180 contains 1 shift/reduce conflict.  (Two ways to parse ATTRIBUTE.)
  12067. -State 194 contains 2 shift/reduce conflict.  (Four ways to parse this.)
  12068. -State 202 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12069. -State 214 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12070. -State 220 contains 1 shift/reduce conflict.  (Two ways to recover from error.)
  12071. -State 304 contains 2 shift/reduce conflicts.  (Four ways to parse this.)
  12072. -State 335 contains 2 shift/reduce conflicts.  (Four ways to parse this.)
  12073. -State 347 contains 1 shift/reduce conflict.  (Two ways to parse ATTRIBUTES.)
  12074. -State 352 contains 1 shift/reduce conflict.  (Two ways to parse ATTRIBUTES.)
  12075. -State 383 contains 2 shift/reduce conflicts.  (Four ways to parse this.)
  12076. -State 434 contains 2 shift/reduce conflicts.  (Four ways to parse this.)  */
  12077. -
  12078. -
  12079. -%{
  12080. -#include <stdio.h>
  12081. -#include <errno.h>
  12082. -#include <setjmp.h>
  12083. -
  12084. -#include "config.h"
  12085. -#include "tree.h"
  12086. -#include "input.h"
  12087. -#include "c-lex.h"
  12088. -#include "c-tree.h"
  12089. -#include "flags.h"
  12090. -
  12091. -#ifdef MULTIBYTE_CHARS
  12092. -#include <stdlib.h>
  12093. -#include <locale.h>
  12094. -#endif
  12095. -
  12096. -
  12097. -/* Since parsers are distinct for each language, put the language string
  12098. -   definition here.  */
  12099. -char *language_string = "GNU C";
  12100. -
  12101. -#ifndef errno
  12102. -extern int errno;
  12103. -#endif
  12104. -
  12105. -void yyerror ();
  12106. -
  12107. -/* Like YYERROR but do call yyerror.  */
  12108. -#define YYERROR1 { yyerror ("syntax error"); YYERROR; }
  12109. -
  12110. -/* Cause the `yydebug' variable to be defined.  */
  12111. -#define YYDEBUG 1
  12112. -%}
  12113. -
  12114. -%start program
  12115. -
  12116. -%union {long itype; tree ttype; enum tree_code code;
  12117. -    char *filename; int lineno; int ends_in_label; }
  12118. -
  12119. -/* All identifiers that are not reserved words
  12120. -   and are not declared typedefs in the current block */
  12121. -%token IDENTIFIER
  12122. -
  12123. -/* All identifiers that are declared typedefs in the current block.
  12124. -   In some contexts, they are treated just like IDENTIFIER,
  12125. -   but they can also serve as typespecs in declarations.  */
  12126. -%token TYPENAME
  12127. -
  12128. -/* Reserved words that specify storage class.
  12129. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  12130. -%token SCSPEC
  12131. -
  12132. -/* Reserved words that specify type.
  12133. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  12134. -%token TYPESPEC
  12135. -
  12136. -/* Reserved words that qualify type: "const" or "volatile".
  12137. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  12138. -%token TYPE_QUAL
  12139. -
  12140. -/* Character or numeric constants.
  12141. -   yylval is the node for the constant.  */
  12142. -%token CONSTANT
  12143. -
  12144. -/* String constants in raw form.
  12145. -   yylval is a STRING_CST node.  */
  12146. -%token STRING
  12147. -
  12148. -/* "...", used for functions with variable arglists.  */
  12149. -%token ELLIPSIS
  12150. -
  12151. -/* the reserved words */
  12152. -/* SCO include files test "ASM", so use something else. */
  12153. -%token SIZEOF ENUM STRUCT UNION IF ELSE WHILE DO FOR SWITCH CASE DEFAULT
  12154. -%token BREAK CONTINUE RETURN GOTO ASM_KEYWORD TYPEOF ALIGNOF
  12155. -%token ATTRIBUTE EXTENSION LABEL
  12156. -%token REALPART IMAGPART
  12157. -
  12158. -/* Add precedence rules to solve dangling else s/r conflict */
  12159. -%nonassoc IF
  12160. -%nonassoc ELSE
  12161. -
  12162. -/* Define the operator tokens and their precedences.
  12163. -   The value is an integer because, if used, it is the tree code
  12164. -   to use in the expression made from the operator.  */
  12165. -
  12166. -%right <code> ASSIGN '='
  12167. -%right <code> '?' ':'
  12168. -%left <code> OROR
  12169. -%left <code> ANDAND
  12170. -%left <code> '|'
  12171. -%left <code> '^'
  12172. -%left <code> '&'
  12173. -%left <code> EQCOMPARE
  12174. -%left <code> ARITHCOMPARE
  12175. -%left <code> LSHIFT RSHIFT
  12176. -%left <code> '+' '-'
  12177. -%left <code> '*' '/' '%'
  12178. -%right <code> UNARY PLUSPLUS MINUSMINUS
  12179. -%left HYPERUNARY
  12180. -%left <code> POINTSAT '.' '(' '['
  12181. -
  12182. -/* The Objective-C keywords.  These are included in C and in
  12183. -   Objective C, so that the token codes are the same in both.  */
  12184. -%token INTERFACE IMPLEMENTATION END SELECTOR DEFS ENCODE
  12185. -%token CLASSNAME PUBLIC PRIVATE PROTECTED PROTOCOL OBJECTNAME CLASS ALIAS
  12186. -
  12187. -/* Objective-C string constants in raw form.
  12188. -   yylval is an OBJC_STRING_CST node.  */
  12189. -%token OBJC_STRING
  12190. -
  12191. -
  12192. -%type <code> unop
  12193. -
  12194. -%type <ttype> identifier IDENTIFIER TYPENAME CONSTANT expr nonnull_exprlist exprlist
  12195. -%type <ttype> expr_no_commas cast_expr unary_expr primary string STRING
  12196. -%type <ttype> typed_declspecs reserved_declspecs
  12197. -%type <ttype> typed_typespecs reserved_typespecquals
  12198. -%type <ttype> declmods typespec typespecqual_reserved
  12199. -%type <ttype> SCSPEC TYPESPEC TYPE_QUAL nonempty_type_quals maybe_type_qual
  12200. -%type <ttype> initdecls notype_initdecls initdcl notype_initdcl
  12201. -%type <ttype> init maybeasm
  12202. -%type <ttype> asm_operands nonnull_asm_operands asm_operand asm_clobbers
  12203. -%type <ttype> maybe_attribute attributes attribute attribute_list attrib
  12204. -%type <ttype> any_word
  12205. -
  12206. -%type <ttype> compstmt
  12207. -
  12208. -%type <ttype> declarator
  12209. -%type <ttype> notype_declarator after_type_declarator
  12210. -%type <ttype> parm_declarator
  12211. -
  12212. -%type <ttype> structsp component_decl_list component_decl_list2
  12213. -%type <ttype> component_decl components component_declarator
  12214. -%type <ttype> enumlist enumerator
  12215. -%type <ttype> typename absdcl absdcl1 type_quals
  12216. -%type <ttype> xexpr parms parm identifiers
  12217. -
  12218. -%type <ttype> parmlist parmlist_1 parmlist_2
  12219. -%type <ttype> parmlist_or_identifiers parmlist_or_identifiers_1
  12220. -%type <ttype> identifiers_or_typenames
  12221. -
  12222. -%type <itype> setspecs
  12223. -
  12224. -%type <ends_in_label> lineno_stmt_or_label lineno_stmt_or_labels stmt_or_label
  12225. -
  12226. -%type <filename> save_filename
  12227. -%type <lineno> save_lineno
  12228. -
  12229. -
  12230. -%{
  12231. -/* Number of statements (loosely speaking) seen so far.  */
  12232. -static int stmt_count;
  12233. -
  12234. -/* Input file and line number of the end of the body of last simple_if;
  12235. -   used by the stmt-rule immediately after simple_if returns.  */
  12236. -static char *if_stmt_file;
  12237. -static int if_stmt_line;
  12238. -
  12239. -/* List of types and structure classes of the current declaration.  */
  12240. -static tree current_declspecs;
  12241. -static tree prefix_attributes = NULL_TREE;
  12242. -
  12243. -/* Stack of saved values of current_declspecs and prefix_attributes.  */
  12244. -static tree declspec_stack;
  12245. -
  12246. -/* 1 if we explained undeclared var errors.  */
  12247. -static int undeclared_variable_notice;
  12248. -
  12249. -
  12250. -/* Tell yyparse how to print a token's value, if yydebug is set.  */
  12251. -
  12252. -#define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL)
  12253. -extern void yyprint ();
  12254. -%}
  12255. -
  12256. -%%
  12257. -program: /* empty */
  12258. -        { if (pedantic)
  12259. -            pedwarn ("ANSI C forbids an empty source file");
  12260. -          finish_file ();
  12261. -        }
  12262. -    | extdefs
  12263. -        {
  12264. -          /* In case there were missing closebraces,
  12265. -             get us back to the global binding level.  */
  12266. -          while (! global_bindings_p ())
  12267. -            poplevel (0, 0, 0);
  12268. -          finish_file ();
  12269. -        }
  12270. -    ;
  12271. -
  12272. -/* the reason for the strange actions in this rule
  12273. - is so that notype_initdecls when reached via datadef
  12274. - can find a valid list of type and sc specs in $0. */
  12275. -
  12276. -extdefs:
  12277. -    {$<ttype>$ = NULL_TREE; } extdef
  12278. -    | extdefs {$<ttype>$ = NULL_TREE; } extdef
  12279. -    ;
  12280. -
  12281. -extdef:
  12282. -    fndef
  12283. -    | datadef
  12284. -    | ASM_KEYWORD '(' expr ')' ';'
  12285. -        { STRIP_NOPS ($3);
  12286. -          if ((TREE_CODE ($3) == ADDR_EXPR
  12287. -               && TREE_CODE (TREE_OPERAND ($3, 0)) == STRING_CST)
  12288. -              || TREE_CODE ($3) == STRING_CST)
  12289. -            assemble_asm ($3);
  12290. -          else
  12291. -            error ("argument of `asm' is not a constant string"); }
  12292. -    ;
  12293. -
  12294. -datadef:
  12295. -      setspecs notype_initdecls ';'
  12296. -        { if (pedantic)
  12297. -            error ("ANSI C forbids data definition with no type or storage class");
  12298. -          else if (!flag_traditional)
  12299. -            warning ("data definition has no type or storage class"); 
  12300. -
  12301. -          current_declspecs = TREE_VALUE (declspec_stack);
  12302. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12303. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12304. -          resume_momentary ($1); }
  12305. -        | declmods setspecs notype_initdecls ';'
  12306. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12307. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12308. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12309. -          resume_momentary ($2); }
  12310. -    | typed_declspecs setspecs initdecls ';'
  12311. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12312. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12313. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12314. -          resume_momentary ($2);  }
  12315. -        | declmods ';'
  12316. -      { pedwarn ("empty declaration"); }
  12317. -    | typed_declspecs ';'
  12318. -      { shadow_tag ($1); }
  12319. -    | error ';'
  12320. -    | error '}'
  12321. -    | ';'
  12322. -        { if (pedantic)
  12323. -            pedwarn ("ANSI C does not allow extra `;' outside of a function"); }
  12324. -    ;
  12325. -
  12326. -fndef:
  12327. -      typed_declspecs setspecs declarator
  12328. -        { if (! start_function ($1, $3, prefix_attributes,
  12329. -                    NULL_TREE, 0))
  12330. -            YYERROR1;
  12331. -          reinit_parse_for_function (); }
  12332. -      xdecls
  12333. -        { store_parm_decls (); }
  12334. -      compstmt_or_error
  12335. -        { finish_function (0); 
  12336. -          current_declspecs = TREE_VALUE (declspec_stack);
  12337. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12338. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12339. -          resume_momentary ($2); }
  12340. -    | typed_declspecs setspecs declarator error
  12341. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12342. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12343. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12344. -          resume_momentary ($2); }
  12345. -    | declmods setspecs notype_declarator
  12346. -        { if (! start_function ($1, $3, prefix_attributes,
  12347. -                    NULL_TREE, 0))
  12348. -            YYERROR1;
  12349. -          reinit_parse_for_function (); }
  12350. -      xdecls
  12351. -        { store_parm_decls (); }
  12352. -      compstmt_or_error
  12353. -        { finish_function (0); 
  12354. -          current_declspecs = TREE_VALUE (declspec_stack);
  12355. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12356. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12357. -          resume_momentary ($2); }
  12358. -    | declmods setspecs notype_declarator error
  12359. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12360. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12361. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12362. -          resume_momentary ($2); }
  12363. -    | setspecs notype_declarator
  12364. -        { if (! start_function (NULL_TREE, $2,
  12365. -                    prefix_attributes, NULL_TREE, 0))
  12366. -            YYERROR1;
  12367. -          reinit_parse_for_function (); }
  12368. -      xdecls
  12369. -        { store_parm_decls (); }
  12370. -      compstmt_or_error
  12371. -        { finish_function (0); 
  12372. -          current_declspecs = TREE_VALUE (declspec_stack);
  12373. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12374. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12375. -          resume_momentary ($1); }
  12376. -    | setspecs notype_declarator error
  12377. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12378. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12379. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12380. -          resume_momentary ($1); }
  12381. -    ;
  12382. -
  12383. -identifier:
  12384. -    IDENTIFIER
  12385. -    | TYPENAME
  12386. -    ;
  12387. -
  12388. -unop:     '&'
  12389. -        { $$ = ADDR_EXPR; }
  12390. -    | '-'
  12391. -        { $$ = NEGATE_EXPR; }
  12392. -    | '+'
  12393. -        { $$ = CONVERT_EXPR; }
  12394. -    | PLUSPLUS
  12395. -        { $$ = PREINCREMENT_EXPR; }
  12396. -    | MINUSMINUS
  12397. -        { $$ = PREDECREMENT_EXPR; }
  12398. -    | '~'
  12399. -        { $$ = BIT_NOT_EXPR; }
  12400. -    | '!'
  12401. -        { $$ = TRUTH_NOT_EXPR; }
  12402. -    ;
  12403. -
  12404. -expr:    nonnull_exprlist
  12405. -        { $$ = build_compound_expr ($1); }
  12406. -    ;
  12407. -
  12408. -exprlist:
  12409. -      /* empty */
  12410. -        { $$ = NULL_TREE; }
  12411. -    | nonnull_exprlist
  12412. -    ;
  12413. -
  12414. -nonnull_exprlist:
  12415. -    expr_no_commas
  12416. -        { $$ = build_tree_list (NULL_TREE, $1); }
  12417. -    | nonnull_exprlist ',' expr_no_commas
  12418. -        { chainon ($1, build_tree_list (NULL_TREE, $3)); }
  12419. -    ;
  12420. -
  12421. -unary_expr:
  12422. -    primary
  12423. -    | '*' cast_expr   %prec UNARY
  12424. -        { $$ = build_indirect_ref ($2, "unary *"); }
  12425. -    /* __extension__ turns off -pedantic for following primary.  */
  12426. -    | EXTENSION
  12427. -        { $<itype>1 = pedantic;
  12428. -          pedantic = 0; }
  12429. -      cast_expr      %prec UNARY
  12430. -        { $$ = $3;
  12431. -          pedantic = $<itype>1; }
  12432. -    | unop cast_expr  %prec UNARY
  12433. -        { $$ = build_unary_op ($1, $2, 0);
  12434. -          overflow_warning ($$); }
  12435. -    /* Refer to the address of a label as a pointer.  */
  12436. -    | ANDAND identifier
  12437. -        { tree label = lookup_label ($2);
  12438. -          if (pedantic)
  12439. -            pedwarn ("ANSI C forbids `&&'");
  12440. -          if (label == 0)
  12441. -            $$ = null_pointer_node;
  12442. -          else
  12443. -            {
  12444. -              TREE_USED (label) = 1;
  12445. -              $$ = build1 (ADDR_EXPR, ptr_type_node, label);
  12446. -              TREE_CONSTANT ($$) = 1;
  12447. -            }
  12448. -        }
  12449. -/* This seems to be impossible on some machines, so let's turn it off.
  12450. -   You can use __builtin_next_arg to find the anonymous stack args.
  12451. -    | '&' ELLIPSIS
  12452. -        { tree types = TYPE_ARG_TYPES (TREE_TYPE (current_function_decl));
  12453. -          $$ = error_mark_node;
  12454. -          if (TREE_VALUE (tree_last (types)) == void_type_node)
  12455. -            error ("`&...' used in function with fixed number of arguments");
  12456. -          else
  12457. -            {
  12458. -              if (pedantic)
  12459. -            pedwarn ("ANSI C forbids `&...'");
  12460. -              $$ = tree_last (DECL_ARGUMENTS (current_function_decl));
  12461. -              $$ = build_unary_op (ADDR_EXPR, $$, 0);
  12462. -            } }
  12463. -*/
  12464. -    | SIZEOF unary_expr  %prec UNARY
  12465. -        { if (TREE_CODE ($2) == COMPONENT_REF
  12466. -              && DECL_BIT_FIELD (TREE_OPERAND ($2, 1)))
  12467. -            error ("`sizeof' applied to a bit-field");
  12468. -          $$ = c_sizeof (TREE_TYPE ($2)); }
  12469. -    | SIZEOF '(' typename ')'  %prec HYPERUNARY
  12470. -        { $$ = c_sizeof (groktypename ($3)); }
  12471. -    | ALIGNOF unary_expr  %prec UNARY
  12472. -        { $$ = c_alignof_expr ($2); }
  12473. -    | ALIGNOF '(' typename ')'  %prec HYPERUNARY
  12474. -        { $$ = c_alignof (groktypename ($3)); }
  12475. -    | REALPART cast_expr %prec UNARY
  12476. -        { $$ = build_unary_op (REALPART_EXPR, $2, 0); }
  12477. -    | IMAGPART cast_expr %prec UNARY
  12478. -        { $$ = build_unary_op (IMAGPART_EXPR, $2, 0); }
  12479. -    ;
  12480. -
  12481. -cast_expr:
  12482. -    unary_expr
  12483. -    | '(' typename ')' cast_expr  %prec UNARY
  12484. -        { tree type = groktypename ($2);
  12485. -          $$ = build_c_cast (type, $4); }
  12486. -    | '(' typename ')' '{' 
  12487. -        { start_init (NULL_TREE, NULL, 0);
  12488. -          $2 = groktypename ($2);
  12489. -          really_start_incremental_init ($2); }
  12490. -      initlist_maybe_comma '}'  %prec UNARY
  12491. -        { char *name;
  12492. -          tree result = pop_init_level (0);
  12493. -          tree type = $2;
  12494. -          finish_init ();
  12495. -
  12496. -          if (pedantic)
  12497. -            pedwarn ("ANSI C forbids constructor expressions");
  12498. -          if (TYPE_NAME (type) != 0)
  12499. -            {
  12500. -              if (TREE_CODE (TYPE_NAME (type)) == IDENTIFIER_NODE)
  12501. -            name = IDENTIFIER_POINTER (TYPE_NAME (type));
  12502. -              else
  12503. -            name = IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type)));
  12504. -            }
  12505. -          else
  12506. -            name = "";
  12507. -          $$ = result;
  12508. -          if (TREE_CODE (type) == ARRAY_TYPE && TYPE_SIZE (type) == 0)
  12509. -            {
  12510. -              int failure = complete_array_type (type, $$, 1);
  12511. -              if (failure)
  12512. -            abort ();
  12513. -            }
  12514. -        }
  12515. -    ;
  12516. -
  12517. -expr_no_commas:
  12518. -      cast_expr
  12519. -    | expr_no_commas '+' expr_no_commas
  12520. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12521. -    | expr_no_commas '-' expr_no_commas
  12522. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12523. -    | expr_no_commas '*' expr_no_commas
  12524. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12525. -    | expr_no_commas '/' expr_no_commas
  12526. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12527. -    | expr_no_commas '%' expr_no_commas
  12528. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12529. -    | expr_no_commas LSHIFT expr_no_commas
  12530. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12531. -    | expr_no_commas RSHIFT expr_no_commas
  12532. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12533. -    | expr_no_commas ARITHCOMPARE expr_no_commas
  12534. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12535. -    | expr_no_commas EQCOMPARE expr_no_commas
  12536. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12537. -    | expr_no_commas '&' expr_no_commas
  12538. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12539. -    | expr_no_commas '|' expr_no_commas
  12540. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12541. -    | expr_no_commas '^' expr_no_commas
  12542. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  12543. -    | expr_no_commas ANDAND expr_no_commas
  12544. -        { $$ = parser_build_binary_op (TRUTH_ANDIF_EXPR, $1, $3); }
  12545. -    | expr_no_commas OROR expr_no_commas
  12546. -        { $$ = parser_build_binary_op (TRUTH_ORIF_EXPR, $1, $3); }
  12547. -    | expr_no_commas '?' xexpr ':' expr_no_commas
  12548. -        { $$ = build_conditional_expr ($1, $3, $5); }
  12549. -    | expr_no_commas '=' expr_no_commas
  12550. -        { $$ = build_modify_expr ($1, NOP_EXPR, $3);
  12551. -          C_SET_EXP_ORIGINAL_CODE ($$, MODIFY_EXPR); }
  12552. -    | expr_no_commas ASSIGN expr_no_commas
  12553. -        { $$ = build_modify_expr ($1, $2, $3);
  12554. -          /* This inhibits warnings in truthvalue_conversion.  */
  12555. -          C_SET_EXP_ORIGINAL_CODE ($$, ERROR_MARK); }
  12556. -    ;
  12557. -
  12558. -primary:
  12559. -    IDENTIFIER
  12560. -        {
  12561. -          $$ = lastiddecl;
  12562. -          if (!$$ || $$ == error_mark_node)
  12563. -            {
  12564. -              if (yychar == YYEMPTY)
  12565. -            yychar = YYLEX;
  12566. -              if (yychar == '(')
  12567. -            {
  12568. -                {
  12569. -                  /* Ordinary implicit function declaration.  */
  12570. -                  $$ = implicitly_declare ($1);
  12571. -                  assemble_external ($$);
  12572. -                  TREE_USED ($$) = 1;
  12573. -                }
  12574. -            }
  12575. -              else if (current_function_decl == 0)
  12576. -            {
  12577. -              error ("`%s' undeclared here (not in a function)",
  12578. -                 IDENTIFIER_POINTER ($1));
  12579. -              $$ = error_mark_node;
  12580. -            }
  12581. -              else
  12582. -            {
  12583. -                {
  12584. -                  if (IDENTIFIER_GLOBAL_VALUE ($1) != error_mark_node
  12585. -                  || IDENTIFIER_ERROR_LOCUS ($1) != current_function_decl)
  12586. -                {
  12587. -                  error ("`%s' undeclared (first use this function)",
  12588. -                     IDENTIFIER_POINTER ($1));
  12589. -
  12590. -                  if (! undeclared_variable_notice)
  12591. -                    {
  12592. -                      error ("(Each undeclared identifier is reported only once");
  12593. -                      error ("for each function it appears in.)");
  12594. -                      undeclared_variable_notice = 1;
  12595. -                    }
  12596. -                }
  12597. -                  $$ = error_mark_node;
  12598. -                  /* Prevent repeated error messages.  */
  12599. -                  IDENTIFIER_GLOBAL_VALUE ($1) = error_mark_node;
  12600. -                  IDENTIFIER_ERROR_LOCUS ($1) = current_function_decl;
  12601. -                }
  12602. -            }
  12603. -            }
  12604. -          else if (TREE_TYPE ($$) == error_mark_node)
  12605. -            $$ = error_mark_node;
  12606. -          else if (C_DECL_ANTICIPATED ($$))
  12607. -            {
  12608. -              /* The first time we see a build-in function used,
  12609. -             if it has not been declared.  */
  12610. -              C_DECL_ANTICIPATED ($$) = 0;
  12611. -              if (yychar == YYEMPTY)
  12612. -            yychar = YYLEX;
  12613. -              if (yychar == '(')
  12614. -            {
  12615. -              /* Omit the implicit declaration we
  12616. -                 would ordinarily do, so we don't lose
  12617. -                 the actual built in type.
  12618. -                 But print a diagnostic for the mismatch.  */
  12619. -                if (TREE_CODE ($$) != FUNCTION_DECL)
  12620. -                  error ("`%s' implicitly declared as function",
  12621. -                     IDENTIFIER_POINTER (DECL_NAME ($$)));
  12622. -              else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE ($$)))
  12623. -                    != TYPE_MODE (integer_type_node))
  12624. -                   && (TREE_TYPE (TREE_TYPE ($$))
  12625. -                       != void_type_node))
  12626. -                pedwarn ("type mismatch in implicit declaration for built-in function `%s'",
  12627. -                     IDENTIFIER_POINTER (DECL_NAME ($$)));
  12628. -              /* If it really returns void, change that to int.  */
  12629. -              if (TREE_TYPE (TREE_TYPE ($$)) == void_type_node)
  12630. -                TREE_TYPE ($$)
  12631. -                  = build_function_type (integer_type_node,
  12632. -                             TYPE_ARG_TYPES (TREE_TYPE ($$)));
  12633. -            }
  12634. -              else
  12635. -            pedwarn ("built-in function `%s' used without declaration",
  12636. -                 IDENTIFIER_POINTER (DECL_NAME ($$)));
  12637. -
  12638. -              /* Do what we would ordinarily do when a fn is used.  */
  12639. -              assemble_external ($$);
  12640. -              TREE_USED ($$) = 1;
  12641. -            }
  12642. -          else
  12643. -            {
  12644. -              assemble_external ($$);
  12645. -              TREE_USED ($$) = 1;
  12646. -            }
  12647. -
  12648. -          if (TREE_CODE ($$) == CONST_DECL)
  12649. -            {
  12650. -              $$ = DECL_INITIAL ($$);
  12651. -              /* This is to prevent an enum whose value is 0
  12652. -             from being considered a null pointer constant.  */
  12653. -              $$ = build1 (NOP_EXPR, TREE_TYPE ($$), $$);
  12654. -              TREE_CONSTANT ($$) = 1;
  12655. -            }
  12656. -        }
  12657. -    | CONSTANT
  12658. -    | string
  12659. -        { $$ = combine_strings ($1); }
  12660. -    | '(' expr ')'
  12661. -        { char class = TREE_CODE_CLASS (TREE_CODE ($2));
  12662. -          if (class == 'e' || class == '1'
  12663. -              || class == '2' || class == '<')
  12664. -            C_SET_EXP_ORIGINAL_CODE ($2, ERROR_MARK);
  12665. -          $$ = $2; }
  12666. -    | '(' error ')'
  12667. -        { $$ = error_mark_node; }
  12668. -    | '('
  12669. -        { if (current_function_decl == 0)
  12670. -            {
  12671. -              error ("braced-group within expression allowed only inside a function");
  12672. -              YYERROR;
  12673. -            }
  12674. -          /* We must force a BLOCK for this level
  12675. -             so that, if it is not expanded later,
  12676. -             there is a way to turn off the entire subtree of blocks
  12677. -             that are contained in it.  */
  12678. -          keep_next_level ();
  12679. -          push_iterator_stack ();
  12680. -          push_label_level ();
  12681. -          $<ttype>$ = expand_start_stmt_expr (); }
  12682. -      compstmt ')'
  12683. -        { tree rtl_exp;
  12684. -          if (pedantic)
  12685. -            pedwarn ("ANSI C forbids braced-groups within expressions");
  12686. -          pop_iterator_stack ();
  12687. -          pop_label_level ();
  12688. -          rtl_exp = expand_end_stmt_expr ($<ttype>2);
  12689. -          /* The statements have side effects, so the group does.  */
  12690. -          TREE_SIDE_EFFECTS (rtl_exp) = 1;
  12691. -
  12692. -          if (TREE_CODE ($3) == BLOCK)
  12693. -            {
  12694. -              /* Make a BIND_EXPR for the BLOCK already made.  */
  12695. -              $$ = build (BIND_EXPR, TREE_TYPE (rtl_exp),
  12696. -                  NULL_TREE, rtl_exp, $3);
  12697. -              /* Remove the block from the tree at this point.
  12698. -             It gets put back at the proper place
  12699. -             when the BIND_EXPR is expanded.  */
  12700. -              delete_block ($3);
  12701. -            }
  12702. -          else
  12703. -            $$ = $3;
  12704. -        }
  12705. -    | primary '(' exprlist ')'   %prec '.'
  12706. -        { $$ = build_function_call ($1, $3); }
  12707. -    | primary '[' expr ']'   %prec '.'
  12708. -        { $$ = build_array_ref ($1, $3); }
  12709. -    | primary '.' identifier
  12710. -        {
  12711. -            $$ = build_component_ref ($1, $3);
  12712. -        }
  12713. -    | primary POINTSAT identifier
  12714. -        {
  12715. -                  tree expr = build_indirect_ref ($1, "->");
  12716. -
  12717. -                    $$ = build_component_ref (expr, $3);
  12718. -        }
  12719. -    | primary PLUSPLUS
  12720. -        { $$ = build_unary_op (POSTINCREMENT_EXPR, $1, 0); }
  12721. -    | primary MINUSMINUS
  12722. -        { $$ = build_unary_op (POSTDECREMENT_EXPR, $1, 0); }
  12723. -    ;
  12724. -
  12725. -/* Produces a STRING_CST with perhaps more STRING_CSTs chained onto it.  */
  12726. -string:
  12727. -      STRING
  12728. -    | string STRING
  12729. -        { $$ = chainon ($1, $2); }
  12730. -    ;
  12731. -
  12732. -
  12733. -xdecls:
  12734. -    /* empty */
  12735. -    | datadecls
  12736. -    | datadecls ELLIPSIS
  12737. -        /* ... is used here to indicate a varargs function.  */
  12738. -        { c_mark_varargs ();
  12739. -          if (pedantic)
  12740. -            pedwarn ("ANSI C does not permit use of `varargs.h'"); }
  12741. -    ;
  12742. -
  12743. -/* The following are analogous to lineno_decl, decls and decl
  12744. -   except that they do not allow nested functions.
  12745. -   They are used for old-style parm decls.  */
  12746. -lineno_datadecl:
  12747. -      save_filename save_lineno datadecl
  12748. -        { }
  12749. -    ;
  12750. -
  12751. -datadecls:
  12752. -    lineno_datadecl
  12753. -    | errstmt
  12754. -    | datadecls lineno_datadecl
  12755. -    | lineno_datadecl errstmt
  12756. -    ;
  12757. -
  12758. -datadecl:
  12759. -    typed_declspecs setspecs initdecls ';'
  12760. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12761. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12762. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12763. -          resume_momentary ($2); }
  12764. -    | declmods setspecs notype_initdecls ';'
  12765. -        { current_declspecs = TREE_VALUE (declspec_stack);    
  12766. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12767. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12768. -          resume_momentary ($2); }
  12769. -    | typed_declspecs ';'
  12770. -        { shadow_tag_warned ($1, 1);
  12771. -          pedwarn ("empty declaration"); }
  12772. -    | declmods ';'
  12773. -        { pedwarn ("empty declaration"); }
  12774. -    ;
  12775. -
  12776. -/* This combination which saves a lineno before a decl
  12777. -   is the normal thing to use, rather than decl itself.
  12778. -   This is to avoid shift/reduce conflicts in contexts
  12779. -   where statement labels are allowed.  */
  12780. -lineno_decl:
  12781. -      save_filename save_lineno decl
  12782. -        { }
  12783. -    ;
  12784. -
  12785. -decls:
  12786. -    lineno_decl
  12787. -    | errstmt
  12788. -    | decls lineno_decl
  12789. -    | lineno_decl errstmt
  12790. -    ;
  12791. -
  12792. -/* records the type and storage class specs to use for processing
  12793. -   the declarators that follow.
  12794. -   Maintains a stack of outer-level values of current_declspecs,
  12795. -   for the sake of parm declarations nested in function declarators.  */
  12796. -setspecs: /* empty */
  12797. -        { $$ = suspend_momentary ();
  12798. -          pending_xref_error ();
  12799. -          declspec_stack = tree_cons (prefix_attributes,
  12800. -                          current_declspecs,
  12801. -                          declspec_stack);
  12802. -          current_declspecs = $<ttype>0; 
  12803. -          prefix_attributes = NULL_TREE; }
  12804. -    ;
  12805. -
  12806. -setattrs: /* empty */
  12807. -        { prefix_attributes = chainon (prefix_attributes, $<ttype>0); }
  12808. -    ;
  12809. -
  12810. -decl:
  12811. -    typed_declspecs setspecs initdecls ';'
  12812. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12813. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12814. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12815. -          resume_momentary ($2); }
  12816. -    | declmods setspecs notype_initdecls ';'
  12817. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12818. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12819. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12820. -          resume_momentary ($2); }
  12821. -    | typed_declspecs setspecs nested_function
  12822. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12823. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12824. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12825. -          resume_momentary ($2); }
  12826. -    | declmods setspecs notype_nested_function
  12827. -        { current_declspecs = TREE_VALUE (declspec_stack);
  12828. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  12829. -          declspec_stack = TREE_CHAIN (declspec_stack);
  12830. -          resume_momentary ($2); }
  12831. -    | typed_declspecs ';'
  12832. -        { shadow_tag ($1); }
  12833. -    | declmods ';'
  12834. -        { pedwarn ("empty declaration"); }
  12835. -    ;
  12836. -
  12837. -/* Declspecs which contain at least one type specifier or typedef name.
  12838. -   (Just `const' or `volatile' is not enough.)
  12839. -   A typedef'd name following these is taken as a name to be declared.  */
  12840. -
  12841. -typed_declspecs:
  12842. -      typespec reserved_declspecs
  12843. -        { $$ = tree_cons (NULL_TREE, $1, $2); }
  12844. -    | declmods typespec reserved_declspecs
  12845. -        { $$ = chainon ($3, tree_cons (NULL_TREE, $2, $1)); }
  12846. -    ;
  12847. -
  12848. -reserved_declspecs:  /* empty */
  12849. -        { $$ = NULL_TREE; }
  12850. -    | reserved_declspecs typespecqual_reserved
  12851. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  12852. -    | reserved_declspecs SCSPEC
  12853. -        { if (extra_warnings)
  12854. -            warning ("`%s' is not at beginning of declaration",
  12855. -                 IDENTIFIER_POINTER ($2));
  12856. -          $$ = tree_cons (NULL_TREE, $2, $1); }
  12857. -    ;
  12858. -
  12859. -/* List of just storage classes and type modifiers.
  12860. -   A declaration can start with just this, but then it cannot be used
  12861. -   to redeclare a typedef-name.  */
  12862. -
  12863. -declmods:
  12864. -      TYPE_QUAL
  12865. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE);
  12866. -          TREE_STATIC ($$) = 1; }
  12867. -    | SCSPEC
  12868. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE); }
  12869. -    | declmods TYPE_QUAL
  12870. -        { $$ = tree_cons (NULL_TREE, $2, $1);
  12871. -          TREE_STATIC ($$) = 1; }
  12872. -    | declmods SCSPEC
  12873. -        { if (extra_warnings && TREE_STATIC ($1))
  12874. -            warning ("`%s' is not at beginning of declaration",
  12875. -                 IDENTIFIER_POINTER ($2));
  12876. -          $$ = tree_cons (NULL_TREE, $2, $1);
  12877. -          TREE_STATIC ($$) = TREE_STATIC ($1); }
  12878. -    ;
  12879. -
  12880. -
  12881. -/* Used instead of declspecs where storage classes are not allowed
  12882. -   (that is, for typenames and structure components).
  12883. -   Don't accept a typedef-name if anything but a modifier precedes it.  */
  12884. -
  12885. -typed_typespecs:
  12886. -      typespec reserved_typespecquals
  12887. -        { $$ = tree_cons (NULL_TREE, $1, $2); }
  12888. -    | nonempty_type_quals typespec reserved_typespecquals
  12889. -        { $$ = chainon ($3, tree_cons (NULL_TREE, $2, $1)); }
  12890. -    ;
  12891. -
  12892. -reserved_typespecquals:  /* empty */
  12893. -        { $$ = NULL_TREE; }
  12894. -    | reserved_typespecquals typespecqual_reserved
  12895. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  12896. -    ;
  12897. -
  12898. -/* A typespec (but not a type qualifier).
  12899. -   Once we have seen one of these in a declaration,
  12900. -   if a typedef name appears then it is being redeclared.  */
  12901. -
  12902. -typespec: TYPESPEC
  12903. -    | structsp
  12904. -    | TYPENAME
  12905. -        { /* For a typedef name, record the meaning, not the name.
  12906. -             In case of `foo foo, bar;'.  */
  12907. -          $$ = lookup_name ($1); }
  12908. -    | TYPEOF '(' expr ')'
  12909. -        { $$ = TREE_TYPE ($3); }
  12910. -    | TYPEOF '(' typename ')'
  12911. -        { $$ = groktypename ($3); }
  12912. -    ;
  12913. -
  12914. -/* A typespec that is a reserved word, or a type qualifier.  */
  12915. -
  12916. -typespecqual_reserved: TYPESPEC
  12917. -    | TYPE_QUAL
  12918. -    | structsp
  12919. -    ;
  12920. -
  12921. -initdecls:
  12922. -    initdcl
  12923. -    | initdecls ',' initdcl
  12924. -    ;
  12925. -
  12926. -notype_initdecls:
  12927. -    notype_initdcl
  12928. -    | notype_initdecls ',' initdcl
  12929. -    ;
  12930. -
  12931. -maybeasm:
  12932. -      /* empty */
  12933. -        { $$ = NULL_TREE; }
  12934. -    | ASM_KEYWORD '(' string ')'
  12935. -        { if (TREE_CHAIN ($3)) $3 = combine_strings ($3);
  12936. -          $$ = $3;
  12937. -        }
  12938. -    ;
  12939. -
  12940. -initdcl:
  12941. -      declarator maybeasm maybe_attribute '='
  12942. -        { $<ttype>$ = start_decl ($1, current_declspecs, 1,
  12943. -                      $3, prefix_attributes);
  12944. -          start_init ($<ttype>$, $2, global_bindings_p ()); }
  12945. -      init
  12946. -/* Note how the declaration of the variable is in effect while its init is parsed! */
  12947. -        { finish_init ();
  12948. -          finish_decl ($<ttype>5, $6, $2); }
  12949. -    | declarator maybeasm maybe_attribute
  12950. -        { tree d = start_decl ($1, current_declspecs, 0,
  12951. -                       $3, prefix_attributes);
  12952. -          finish_decl (d, NULL_TREE, $2); 
  12953. -                }
  12954. -    ;
  12955. -
  12956. -notype_initdcl:
  12957. -      notype_declarator maybeasm maybe_attribute '='
  12958. -        { $<ttype>$ = start_decl ($1, current_declspecs, 1,
  12959. -                      $3, prefix_attributes);
  12960. -          start_init ($<ttype>$, $2, global_bindings_p ()); }
  12961. -      init
  12962. -/* Note how the declaration of the variable is in effect while its init is parsed! */
  12963. -        { finish_init ();
  12964. -          decl_attributes ($<ttype>5, $3, prefix_attributes);
  12965. -          finish_decl ($<ttype>5, $6, $2); }
  12966. -    | notype_declarator maybeasm maybe_attribute
  12967. -        { tree d = start_decl ($1, current_declspecs, 0,
  12968. -                       $3, prefix_attributes);
  12969. -          finish_decl (d, NULL_TREE, $2); }
  12970. -    ;
  12971. -/* the * rules are dummies to accept the Apollo extended syntax
  12972. -   so that the header files compile. */
  12973. -maybe_attribute:
  12974. -      /* empty */
  12975. -          { $$ = NULL_TREE; }
  12976. -    | attributes
  12977. -        { $$ = $1; }
  12978. -    ;
  12979. -attributes:
  12980. -      attribute
  12981. -        { $$ = $1; }
  12982. -    | attributes attribute
  12983. -        { $$ = chainon ($1, $2); }
  12984. -    ;
  12985. -
  12986. -attribute:
  12987. -      ATTRIBUTE '(' '(' attribute_list ')' ')'
  12988. -        { $$ = $4; }
  12989. -    ;
  12990. -
  12991. -attribute_list:
  12992. -      attrib
  12993. -        { $$ = $1; }
  12994. -    | attribute_list ',' attrib
  12995. -        { $$ = chainon ($1, $3); }
  12996. -    ;
  12997. -attrib:
  12998. -    /* empty */
  12999. -        { $$ = NULL_TREE; }
  13000. -    | any_word
  13001. -        { $$ = build_tree_list ($1, NULL_TREE); }
  13002. -    | any_word '(' IDENTIFIER ')'
  13003. -        { $$ = build_tree_list ($1, build_tree_list (NULL_TREE, $3)); }
  13004. -    | any_word '(' IDENTIFIER ',' nonnull_exprlist ')'
  13005. -        { $$ = build_tree_list ($1, tree_cons (NULL_TREE, $3, $5)); }
  13006. -    | any_word '(' exprlist ')'
  13007. -        { $$ = build_tree_list ($1, $3); }
  13008. -    ;
  13009. -
  13010. -/* This still leaves out most reserved keywords,
  13011. -   shouldn't we include them?  */
  13012. -
  13013. -any_word:
  13014. -      identifier
  13015. -    | SCSPEC
  13016. -    | TYPESPEC
  13017. -    | TYPE_QUAL
  13018. -    ;
  13019. -
  13020. -/* Initializers.  `init' is the entry point.  */
  13021. -
  13022. -init:
  13023. -    expr_no_commas
  13024. -    | '{'
  13025. -        { really_start_incremental_init (NULL_TREE);
  13026. -          /* Note that the call to clear_momentary
  13027. -             is in process_init_element.  */
  13028. -          push_momentary (); }
  13029. -      initlist_maybe_comma '}'
  13030. -        { $$ = pop_init_level (0);
  13031. -          if ($$ == error_mark_node
  13032. -              && ! (yychar == STRING || yychar == CONSTANT))
  13033. -            pop_momentary ();
  13034. -          else
  13035. -            pop_momentary_nofree (); }
  13036. -
  13037. -    | error
  13038. -        { $$ = error_mark_node; }
  13039. -    ;
  13040. -
  13041. -/* `initlist_maybe_comma' is the guts of an initializer in braces.  */
  13042. -initlist_maybe_comma:
  13043. -      /* empty */
  13044. -        { if (pedantic)
  13045. -            pedwarn ("ANSI C forbids empty initializer braces"); }
  13046. -    | initlist1 maybecomma
  13047. -    ;
  13048. -
  13049. -initlist1:
  13050. -      initelt
  13051. -    | initlist1 ',' initelt
  13052. -    ;
  13053. -
  13054. -/* `initelt' is a single element of an initializer.
  13055. -   It may use braces.  */
  13056. -initelt:
  13057. -    expr_no_commas
  13058. -        { process_init_element ($1); }
  13059. -    | '{' 
  13060. -        { push_init_level (0); }
  13061. -      initlist_maybe_comma '}'
  13062. -        { process_init_element (pop_init_level (0)); }
  13063. -    | error
  13064. -    /* These are for labeled elements.  The syntax for an array element
  13065. -       initializer conflicts with the syntax for an Objective-C message,
  13066. -       so don't include these productions in the Objective-C grammar.  */
  13067. -    | '[' expr_no_commas ELLIPSIS expr_no_commas ']' '='
  13068. -        { set_init_index ($2, $4); }
  13069. -      initelt
  13070. -    | '[' expr_no_commas ']' '='
  13071. -        { set_init_index ($2, NULL_TREE); }
  13072. -      initelt
  13073. -    | '[' expr_no_commas ']'
  13074. -        { set_init_index ($2, NULL_TREE); }
  13075. -      initelt
  13076. -    | identifier ':'
  13077. -        { set_init_label ($1); }
  13078. -      initelt
  13079. -    | '.' identifier '='
  13080. -        { set_init_label ($2); }
  13081. -      initelt
  13082. -    ;
  13083. -
  13084. -nested_function:
  13085. -      declarator
  13086. -        { push_c_function_context ();
  13087. -          if (! start_function (current_declspecs, $1,
  13088. -                    prefix_attributes, NULL_TREE, 1))
  13089. -            {
  13090. -              pop_c_function_context ();
  13091. -              YYERROR1;
  13092. -            }
  13093. -          reinit_parse_for_function (); }
  13094. -       xdecls
  13095. -        { store_parm_decls (); }
  13096. -/* This used to use compstmt_or_error.
  13097. -   That caused a bug with input `f(g) int g {}',
  13098. -   where the use of YYERROR1 above caused an error
  13099. -   which then was handled by compstmt_or_error.
  13100. -   There followed a repeated execution of that same rule,
  13101. -   which called YYERROR1 again, and so on.  */
  13102. -      compstmt
  13103. -        { finish_function (1);
  13104. -          pop_c_function_context (); }
  13105. -    ;
  13106. -
  13107. -notype_nested_function:
  13108. -      notype_declarator
  13109. -        { push_c_function_context ();
  13110. -          if (! start_function (current_declspecs, $1,
  13111. -                    prefix_attributes, NULL_TREE, 1))
  13112. -            {
  13113. -              pop_c_function_context ();
  13114. -              YYERROR1;
  13115. -            }
  13116. -          reinit_parse_for_function (); }
  13117. -      xdecls
  13118. -        { store_parm_decls (); }
  13119. -/* This used to use compstmt_or_error.
  13120. -   That caused a bug with input `f(g) int g {}',
  13121. -   where the use of YYERROR1 above caused an error
  13122. -   which then was handled by compstmt_or_error.
  13123. -   There followed a repeated execution of that same rule,
  13124. -   which called YYERROR1 again, and so on.  */
  13125. -      compstmt
  13126. -        { finish_function (1);
  13127. -          pop_c_function_context (); }
  13128. -    ;
  13129. -
  13130. -/* Any kind of declarator (thus, all declarators allowed
  13131. -   after an explicit typespec).  */
  13132. -
  13133. -declarator:
  13134. -      after_type_declarator
  13135. -    | notype_declarator
  13136. -    ;
  13137. -
  13138. -/* A declarator that is allowed only after an explicit typespec.  */
  13139. -
  13140. -after_type_declarator:
  13141. -      '(' after_type_declarator ')'
  13142. -        { $$ = $2; }
  13143. -    | after_type_declarator '(' parmlist_or_identifiers  %prec '.'
  13144. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  13145. -/*    | after_type_declarator '(' error ')'  %prec '.'
  13146. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  13147. -          poplevel (0, 0, 0); }  */
  13148. -    | after_type_declarator '[' expr ']'  %prec '.'
  13149. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  13150. -    | after_type_declarator '[' ']'  %prec '.'
  13151. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  13152. -    | '*' type_quals after_type_declarator  %prec UNARY
  13153. -        { $$ = make_pointer_declarator ($2, $3); }
  13154. -    | attributes setattrs after_type_declarator
  13155. -        { $$ = $3; }
  13156. -    | TYPENAME
  13157. -    ;
  13158. -
  13159. -/* Kinds of declarator that can appear in a parameter list
  13160. -   in addition to notype_declarator.  This is like after_type_declarator
  13161. -   but does not allow a typedef name in parentheses as an identifier
  13162. -   (because it would conflict with a function with that typedef as arg).  */
  13163. -
  13164. -parm_declarator:
  13165. -      parm_declarator '(' parmlist_or_identifiers  %prec '.'
  13166. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  13167. -/*    | parm_declarator '(' error ')'  %prec '.'
  13168. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  13169. -          poplevel (0, 0, 0); }  */
  13170. -    | parm_declarator '[' expr ']'  %prec '.'
  13171. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  13172. -    | parm_declarator '[' ']'  %prec '.'
  13173. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  13174. -    | '*' type_quals parm_declarator  %prec UNARY
  13175. -        { $$ = make_pointer_declarator ($2, $3); }
  13176. -    | attributes setattrs parm_declarator
  13177. -        { $$ = $3; }
  13178. -    | TYPENAME
  13179. -    ;
  13180. -
  13181. -/* A declarator allowed whether or not there has been
  13182. -   an explicit typespec.  These cannot redeclare a typedef-name.  */
  13183. -
  13184. -notype_declarator:
  13185. -      notype_declarator '(' parmlist_or_identifiers  %prec '.'
  13186. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  13187. -/*    | notype_declarator '(' error ')'  %prec '.'
  13188. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  13189. -          poplevel (0, 0, 0); }  */
  13190. -    | '(' notype_declarator ')'
  13191. -        { $$ = $2; }
  13192. -    | '*' type_quals notype_declarator  %prec UNARY
  13193. -        { $$ = make_pointer_declarator ($2, $3); }
  13194. -    | notype_declarator '[' expr ']'  %prec '.'
  13195. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  13196. -    | notype_declarator '[' ']'  %prec '.'
  13197. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  13198. -    | attributes setattrs notype_declarator
  13199. -        { $$ = $3; }
  13200. -    | IDENTIFIER
  13201. -    ;
  13202. -
  13203. -structsp:
  13204. -      STRUCT identifier '{'
  13205. -        { $$ = start_struct (RECORD_TYPE, $2);
  13206. -          /* Start scope of tag before parsing components.  */
  13207. -        }
  13208. -      component_decl_list '}' maybe_attribute 
  13209. -        { $$ = finish_struct ($<ttype>4, $5, $7); }
  13210. -    | STRUCT '{' component_decl_list '}' maybe_attribute
  13211. -        { $$ = finish_struct (start_struct (RECORD_TYPE, NULL_TREE),
  13212. -                      $3, $5);
  13213. -        }
  13214. -    | STRUCT identifier
  13215. -        { $$ = xref_tag (RECORD_TYPE, $2); }
  13216. -    | UNION identifier '{'
  13217. -        { $$ = start_struct (UNION_TYPE, $2); }
  13218. -      component_decl_list '}' maybe_attribute
  13219. -        { $$ = finish_struct ($<ttype>4, $5, $7); }
  13220. -    | UNION '{' component_decl_list '}' maybe_attribute
  13221. -        { $$ = finish_struct (start_struct (UNION_TYPE, NULL_TREE),
  13222. -                      $3, $5);
  13223. -        }
  13224. -    | UNION identifier
  13225. -        { $$ = xref_tag (UNION_TYPE, $2); }
  13226. -    | ENUM identifier '{'
  13227. -        { $<itype>3 = suspend_momentary ();
  13228. -          $$ = start_enum ($2); }
  13229. -      enumlist maybecomma_warn '}' maybe_attribute
  13230. -        { $$ = finish_enum ($<ttype>4, nreverse ($5), $8);
  13231. -          resume_momentary ($<itype>3); }
  13232. -    | ENUM '{'
  13233. -        { $<itype>2 = suspend_momentary ();
  13234. -          $$ = start_enum (NULL_TREE); }
  13235. -      enumlist maybecomma_warn '}' maybe_attribute
  13236. -        { $$ = finish_enum ($<ttype>3, nreverse ($4), $7);
  13237. -          resume_momentary ($<itype>2); }
  13238. -    | ENUM identifier
  13239. -        { $$ = xref_tag (ENUMERAL_TYPE, $2); }
  13240. -    ;
  13241. -
  13242. -maybecomma:
  13243. -      /* empty */
  13244. -    | ','
  13245. -    ;
  13246. -
  13247. -maybecomma_warn:
  13248. -      /* empty */
  13249. -    | ','
  13250. -        { if (pedantic) pedwarn ("comma at end of enumerator list"); }
  13251. -    ;
  13252. -
  13253. -component_decl_list:
  13254. -      component_decl_list2
  13255. -        { $$ = $1; }
  13256. -    | component_decl_list2 component_decl
  13257. -        { $$ = chainon ($1, $2);
  13258. -          pedwarn ("no semicolon at end of struct or union"); }
  13259. -    ;
  13260. -
  13261. -component_decl_list2:    /* empty */
  13262. -        { $$ = NULL_TREE; }
  13263. -    | component_decl_list2 component_decl ';'
  13264. -        { $$ = chainon ($1, $2); }
  13265. -    | component_decl_list2 ';'
  13266. -        { if (pedantic)
  13267. -            pedwarn ("extra semicolon in struct or union specified"); }
  13268. -    ;
  13269. -
  13270. -/* There is a shift-reduce conflict here, because `components' may
  13271. -   start with a `typename'.  It happens that shifting (the default resolution)
  13272. -   does the right thing, because it treats the `typename' as part of
  13273. -   a `typed_typespecs'.
  13274. -
  13275. -   It is possible that this same technique would allow the distinction
  13276. -   between `notype_initdecls' and `initdecls' to be eliminated.
  13277. -   But I am being cautious and not trying it.  */
  13278. -
  13279. -component_decl:
  13280. -      typed_typespecs setspecs components
  13281. -        { $$ = $3;
  13282. -          current_declspecs = TREE_VALUE (declspec_stack);
  13283. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  13284. -          declspec_stack = TREE_CHAIN (declspec_stack);
  13285. -          resume_momentary ($2); }
  13286. -    | typed_typespecs
  13287. -        { if (pedantic)
  13288. -            pedwarn ("ANSI C forbids member declarations with no members");
  13289. -          shadow_tag($1);
  13290. -          $$ = NULL_TREE; }
  13291. -    | nonempty_type_quals setspecs components
  13292. -        { $$ = $3;
  13293. -          current_declspecs = TREE_VALUE (declspec_stack);
  13294. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  13295. -          declspec_stack = TREE_CHAIN (declspec_stack);
  13296. -          resume_momentary ($2); }
  13297. -    | nonempty_type_quals
  13298. -        { if (pedantic)
  13299. -            pedwarn ("ANSI C forbids member declarations with no members");
  13300. -          shadow_tag($1);
  13301. -          $$ = NULL_TREE; }
  13302. -    | error
  13303. -        { $$ = NULL_TREE; }
  13304. -    ;
  13305. -
  13306. -components:
  13307. -      component_declarator
  13308. -    | components ',' component_declarator
  13309. -        { $$ = chainon ($1, $3); }
  13310. -    ;
  13311. -
  13312. -component_declarator:
  13313. -      save_filename save_lineno declarator maybe_attribute
  13314. -        { $$ = grokfield ($1, $2, $3, current_declspecs, NULL_TREE);
  13315. -          decl_attributes ($$, $4, prefix_attributes); }
  13316. -    | save_filename save_lineno
  13317. -      declarator ':' expr_no_commas maybe_attribute
  13318. -        { $$ = grokfield ($1, $2, $3, current_declspecs, $5);
  13319. -          decl_attributes ($$, $6, prefix_attributes); }
  13320. -    | save_filename save_lineno ':' expr_no_commas maybe_attribute
  13321. -        { $$ = grokfield ($1, $2, NULL_TREE, current_declspecs, $4);
  13322. -          decl_attributes ($$, $5, prefix_attributes); }
  13323. -    ;
  13324. -
  13325. -/* We chain the enumerators in reverse order.
  13326. -   They are put in forward order where enumlist is used.
  13327. -   (The order used to be significant, but no longer is so.
  13328. -   However, we still maintain the order, just to be clean.)  */
  13329. -
  13330. -enumlist:
  13331. -      enumerator
  13332. -    | enumlist ',' enumerator
  13333. -        { if ($1 == error_mark_node)
  13334. -            $$ = $1;
  13335. -          else
  13336. -            $$ = chainon ($3, $1); }
  13337. -    | error
  13338. -        { $$ = error_mark_node; }
  13339. -    ;
  13340. -
  13341. -
  13342. -enumerator:
  13343. -      identifier
  13344. -        { $$ = build_enumerator ($1, NULL_TREE); }
  13345. -    | identifier '=' expr_no_commas
  13346. -        { $$ = build_enumerator ($1, $3); }
  13347. -    ;
  13348. -
  13349. -typename:
  13350. -    typed_typespecs absdcl
  13351. -        { $$ = build_tree_list ($1, $2); }
  13352. -    | nonempty_type_quals absdcl
  13353. -        { $$ = build_tree_list ($1, $2); }
  13354. -    ;
  13355. -
  13356. -absdcl:   /* an absolute declarator */
  13357. -    /* empty */
  13358. -        { $$ = NULL_TREE; }
  13359. -    | absdcl1
  13360. -    ;
  13361. -
  13362. -nonempty_type_quals:
  13363. -      TYPE_QUAL
  13364. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE); }
  13365. -    | nonempty_type_quals TYPE_QUAL
  13366. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  13367. -    ;
  13368. -
  13369. -type_quals:
  13370. -      /* empty */
  13371. -        { $$ = NULL_TREE; }
  13372. -    | type_quals TYPE_QUAL
  13373. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  13374. -    ;
  13375. -
  13376. -absdcl1:  /* a nonempty absolute declarator */
  13377. -      '(' absdcl1 ')'
  13378. -        { $$ = $2; }
  13379. -      /* `(typedef)1' is `int'.  */
  13380. -    | '*' type_quals absdcl1  %prec UNARY
  13381. -        { $$ = make_pointer_declarator ($2, $3); }
  13382. -    | '*' type_quals  %prec UNARY
  13383. -        { $$ = make_pointer_declarator ($2, NULL_TREE); }
  13384. -    | absdcl1 '(' parmlist  %prec '.'
  13385. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  13386. -    | absdcl1 '[' expr ']'  %prec '.'
  13387. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  13388. -    | absdcl1 '[' ']'  %prec '.'
  13389. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  13390. -    | '(' parmlist  %prec '.'
  13391. -        { $$ = build_nt (CALL_EXPR, NULL_TREE, $2, NULL_TREE); }
  13392. -    | '[' expr ']'  %prec '.'
  13393. -        { $$ = build_nt (ARRAY_REF, NULL_TREE, $2); }
  13394. -    | '[' ']'  %prec '.'
  13395. -        { $$ = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); }
  13396. -    | attributes setattrs absdcl1
  13397. -        { $$ = $3; }
  13398. -    ;
  13399. -
  13400. -/* at least one statement, the first of which parses without error.  */
  13401. -/* stmts is used only after decls, so an invalid first statement
  13402. -   is actually regarded as an invalid decl and part of the decls.  */
  13403. -
  13404. -stmts:
  13405. -    lineno_stmt_or_labels
  13406. -        {
  13407. -          if (pedantic && $1)
  13408. -            pedwarn ("ANSI C forbids label at end of compound statement");
  13409. -        }
  13410. -    ;
  13411. -
  13412. -lineno_stmt_or_labels:
  13413. -      lineno_stmt_or_label
  13414. -    | lineno_stmt_or_labels lineno_stmt_or_label
  13415. -        { $$ = $2; }
  13416. -    | lineno_stmt_or_labels errstmt
  13417. -        { $$ = 0; }
  13418. -    ;
  13419. -
  13420. -xstmts:
  13421. -    /* empty */
  13422. -    | stmts
  13423. -    ;
  13424. -
  13425. -errstmt:  error ';'
  13426. -    ;
  13427. -
  13428. -pushlevel:  /* empty */
  13429. -        { emit_line_note (input_filename, lineno);
  13430. -          pushlevel (0);
  13431. -          clear_last_expr ();
  13432. -          push_momentary ();
  13433. -          expand_start_bindings (0);
  13434. -        }
  13435. -    ;
  13436. -
  13437. -/* Read zero or more forward-declarations for labels
  13438. -   that nested functions can jump to.  */
  13439. -maybe_label_decls:
  13440. -      /* empty */
  13441. -    | label_decls
  13442. -        { if (pedantic)
  13443. -            pedwarn ("ANSI C forbids label declarations"); }
  13444. -    ;
  13445. -
  13446. -label_decls:
  13447. -      label_decl
  13448. -    | label_decls label_decl
  13449. -    ;
  13450. -
  13451. -label_decl:
  13452. -      LABEL identifiers_or_typenames ';'
  13453. -        { tree link;
  13454. -          for (link = $2; link; link = TREE_CHAIN (link))
  13455. -            {
  13456. -              tree label = shadow_label (TREE_VALUE (link));
  13457. -              C_DECLARED_LABEL_FLAG (label) = 1;
  13458. -              declare_nonlocal_label (label);
  13459. -            }
  13460. -        }
  13461. -    ;
  13462. -
  13463. -/* This is the body of a function definition.
  13464. -   It causes syntax errors to ignore to the next openbrace.  */
  13465. -compstmt_or_error:
  13466. -      compstmt
  13467. -        {}
  13468. -    | error compstmt
  13469. -    ;
  13470. -
  13471. -compstmt: '{' '}'
  13472. -        { $$ = convert (void_type_node, integer_zero_node); }
  13473. -    | '{' pushlevel maybe_label_decls decls xstmts '}'
  13474. -        { emit_line_note (input_filename, lineno);
  13475. -          expand_end_bindings (getdecls (), 1, 0);
  13476. -          $$ = poplevel (1, 1, 0);
  13477. -          if (yychar == CONSTANT || yychar == STRING)
  13478. -            pop_momentary_nofree ();
  13479. -          else
  13480. -            pop_momentary (); }
  13481. -    | '{' pushlevel maybe_label_decls error '}'
  13482. -        { emit_line_note (input_filename, lineno);
  13483. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  13484. -          $$ = poplevel (kept_level_p (), 0, 0);
  13485. -          if (yychar == CONSTANT || yychar == STRING)
  13486. -            pop_momentary_nofree ();
  13487. -          else
  13488. -            pop_momentary (); }
  13489. -    | '{' pushlevel maybe_label_decls stmts '}'
  13490. -        { emit_line_note (input_filename, lineno);
  13491. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  13492. -          $$ = poplevel (kept_level_p (), 0, 0);
  13493. -          if (yychar == CONSTANT || yychar == STRING)
  13494. -            pop_momentary_nofree ();
  13495. -          else
  13496. -            pop_momentary (); }
  13497. -    ;
  13498. -
  13499. -/* Value is number of statements counted as of the closeparen.  */
  13500. -simple_if:
  13501. -      if_prefix lineno_labeled_stmt
  13502. -/* Make sure expand_end_cond is run once
  13503. -   for each call to expand_start_cond.
  13504. -   Otherwise a crash is likely.  */
  13505. -    | if_prefix error
  13506. -    ;
  13507. -
  13508. -if_prefix:
  13509. -      IF '(' expr ')'
  13510. -        { emit_line_note ($<filename>-1, $<lineno>0);
  13511. -          expand_start_cond (truthvalue_conversion ($3), 0);
  13512. -          $<itype>$ = stmt_count;
  13513. -          if_stmt_file = $<filename>-1;
  13514. -          if_stmt_line = $<lineno>0;
  13515. -          position_after_white_space (); }
  13516. -    ;
  13517. -
  13518. -/* This is a subroutine of stmt.
  13519. -   It is used twice, once for valid DO statements
  13520. -   and once for catching errors in parsing the end test.  */
  13521. -do_stmt_start:
  13522. -      DO
  13523. -        { stmt_count++;
  13524. -          emit_line_note ($<filename>-1, $<lineno>0);
  13525. -          /* See comment in `while' alternative, above.  */
  13526. -          emit_nop ();
  13527. -          expand_start_loop_continue_elsewhere (1);
  13528. -          position_after_white_space (); }
  13529. -      lineno_labeled_stmt WHILE
  13530. -        { expand_loop_continue_here (); }
  13531. -    ;
  13532. -
  13533. -save_filename:
  13534. -        { $$ = input_filename; }
  13535. -    ;
  13536. -
  13537. -save_lineno:
  13538. -        { $$ = lineno; }
  13539. -    ;
  13540. -
  13541. -lineno_labeled_stmt:
  13542. -      save_filename save_lineno stmt
  13543. -        { }
  13544. -/*    | save_filename save_lineno error
  13545. -        { }
  13546. -*/
  13547. -    | save_filename save_lineno label lineno_labeled_stmt
  13548. -        { }
  13549. -    ;
  13550. -
  13551. -lineno_stmt_or_label:
  13552. -      save_filename save_lineno stmt_or_label
  13553. -        { $$ = $3; }
  13554. -    ;
  13555. -
  13556. -stmt_or_label:
  13557. -      stmt
  13558. -        { $$ = 0; }
  13559. -    | label
  13560. -        { $$ = 1; }
  13561. -    ;
  13562. -
  13563. -/* Parse a single real statement, not including any labels.  */
  13564. -stmt:
  13565. -      compstmt
  13566. -        { stmt_count++; }
  13567. -        | all_iter_stmt 
  13568. -    | expr ';'
  13569. -        { stmt_count++;
  13570. -          emit_line_note ($<filename>-1, $<lineno>0);
  13571. -/* It appears that this should not be done--that a non-lvalue array
  13572. -   shouldn't get an error if the value isn't used.
  13573. -   Section 3.2.2.1 says that an array lvalue gets converted to a pointer
  13574. -   if it appears as a top-level expression,
  13575. -   but says nothing about non-lvalue arrays.  */
  13576. -#if 0
  13577. -          /* Call default_conversion to get an error
  13578. -             on referring to a register array if pedantic.  */
  13579. -          if (TREE_CODE (TREE_TYPE ($1)) == ARRAY_TYPE
  13580. -              || TREE_CODE (TREE_TYPE ($1)) == FUNCTION_TYPE)
  13581. -            $1 = default_conversion ($1);
  13582. -#endif
  13583. -          iterator_expand ($1);
  13584. -          clear_momentary (); }
  13585. -    | simple_if ELSE
  13586. -        { expand_start_else ();
  13587. -          $<itype>1 = stmt_count;
  13588. -          position_after_white_space (); }
  13589. -      lineno_labeled_stmt
  13590. -        { expand_end_cond ();
  13591. -          if (extra_warnings && stmt_count == $<itype>1)
  13592. -            warning ("empty body in an else-statement"); }
  13593. -    | simple_if %prec IF
  13594. -        { expand_end_cond ();
  13595. -          /* This warning is here instead of in simple_if, because we
  13596. -             do not want a warning if an empty if is followed by an
  13597. -             else statement.  Increment stmt_count so we don't
  13598. -             give a second error if this is a nested `if'.  */
  13599. -          if (extra_warnings && stmt_count++ == $<itype>1)
  13600. -            warning_with_file_and_line (if_stmt_file, if_stmt_line,
  13601. -                        "empty body in an if-statement"); }
  13602. -/* Make sure expand_end_cond is run once
  13603. -   for each call to expand_start_cond.
  13604. -   Otherwise a crash is likely.  */
  13605. -    | simple_if ELSE error
  13606. -        { expand_end_cond (); }
  13607. -    | WHILE
  13608. -        { stmt_count++;
  13609. -          emit_line_note ($<filename>-1, $<lineno>0);
  13610. -          /* The emit_nop used to come before emit_line_note,
  13611. -             but that made the nop seem like part of the preceding line.
  13612. -             And that was confusing when the preceding line was
  13613. -             inside of an if statement and was not really executed.
  13614. -             I think it ought to work to put the nop after the line number.
  13615. -             We will see.  --rms, July 15, 1991.  */
  13616. -          emit_nop (); }
  13617. -      '(' expr ')'
  13618. -        { /* Don't start the loop till we have succeeded
  13619. -             in parsing the end test.  This is to make sure
  13620. -             that we end every loop we start.  */
  13621. -          expand_start_loop (1);
  13622. -          emit_line_note (input_filename, lineno);
  13623. -          expand_exit_loop_if_false (NULL_PTR,
  13624. -                         truthvalue_conversion ($4));
  13625. -          position_after_white_space (); }
  13626. -      lineno_labeled_stmt
  13627. -        { expand_end_loop (); }
  13628. -    | do_stmt_start
  13629. -      '(' expr ')' ';'
  13630. -        { emit_line_note (input_filename, lineno);
  13631. -          expand_exit_loop_if_false (NULL_PTR,
  13632. -                         truthvalue_conversion ($3));
  13633. -          expand_end_loop ();
  13634. -          clear_momentary (); }
  13635. -/* This rule is needed to make sure we end every loop we start.  */
  13636. -    | do_stmt_start error
  13637. -        { expand_end_loop ();
  13638. -          clear_momentary (); }
  13639. -    | FOR
  13640. -      '(' xexpr ';'
  13641. -        { stmt_count++;
  13642. -          emit_line_note ($<filename>-1, $<lineno>0);
  13643. -          /* See comment in `while' alternative, above.  */
  13644. -          emit_nop ();
  13645. -          if ($3) c_expand_expr_stmt ($3);
  13646. -          /* Next step is to call expand_start_loop_continue_elsewhere,
  13647. -             but wait till after we parse the entire for (...).
  13648. -             Otherwise, invalid input might cause us to call that
  13649. -             fn without calling expand_end_loop.  */
  13650. -        }
  13651. -      xexpr ';'
  13652. -        /* Can't emit now; wait till after expand_start_loop...  */
  13653. -        { $<lineno>7 = lineno;
  13654. -          $<filename>$ = input_filename; }
  13655. -      xexpr ')'
  13656. -        { 
  13657. -          /* Start the loop.  Doing this after parsing
  13658. -             all the expressions ensures we will end the loop.  */
  13659. -          expand_start_loop_continue_elsewhere (1);
  13660. -          /* Emit the end-test, with a line number.  */
  13661. -          emit_line_note ($<filename>8, $<lineno>7);
  13662. -          if ($6)
  13663. -            expand_exit_loop_if_false (NULL_PTR,
  13664. -                           truthvalue_conversion ($6));
  13665. -          /* Don't let the tree nodes for $9 be discarded by
  13666. -             clear_momentary during the parsing of the next stmt.  */
  13667. -          push_momentary ();
  13668. -          $<lineno>7 = lineno;
  13669. -          $<filename>8 = input_filename;
  13670. -          position_after_white_space (); }
  13671. -      lineno_labeled_stmt
  13672. -        { /* Emit the increment expression, with a line number.  */
  13673. -          emit_line_note ($<filename>8, $<lineno>7);
  13674. -          expand_loop_continue_here ();
  13675. -          if ($9)
  13676. -            c_expand_expr_stmt ($9);
  13677. -          if (yychar == CONSTANT || yychar == STRING)
  13678. -            pop_momentary_nofree ();
  13679. -          else
  13680. -            pop_momentary ();
  13681. -          expand_end_loop (); }
  13682. -    | SWITCH '(' expr ')'
  13683. -        { stmt_count++;
  13684. -          emit_line_note ($<filename>-1, $<lineno>0);
  13685. -          c_expand_start_case ($3);
  13686. -          /* Don't let the tree nodes for $3 be discarded by
  13687. -             clear_momentary during the parsing of the next stmt.  */
  13688. -          push_momentary ();
  13689. -          position_after_white_space (); }
  13690. -      lineno_labeled_stmt
  13691. -        { expand_end_case ($3);
  13692. -          if (yychar == CONSTANT || yychar == STRING)
  13693. -            pop_momentary_nofree ();
  13694. -          else
  13695. -            pop_momentary (); }
  13696. -    | BREAK ';'
  13697. -        { stmt_count++;
  13698. -          emit_line_note ($<filename>-1, $<lineno>0);
  13699. -          if ( ! expand_exit_something ())
  13700. -            error ("break statement not within loop or switch"); }
  13701. -    | CONTINUE ';'
  13702. -        { stmt_count++;
  13703. -          emit_line_note ($<filename>-1, $<lineno>0);
  13704. -          if (! expand_continue_loop (NULL_PTR))
  13705. -            error ("continue statement not within a loop"); }
  13706. -    | RETURN ';'
  13707. -        { stmt_count++;
  13708. -          emit_line_note ($<filename>-1, $<lineno>0);
  13709. -          c_expand_return (NULL_TREE); }
  13710. -    | RETURN expr ';'
  13711. -        { stmt_count++;
  13712. -          emit_line_note ($<filename>-1, $<lineno>0);
  13713. -          c_expand_return ($2); }
  13714. -    | ASM_KEYWORD maybe_type_qual '(' expr ')' ';'
  13715. -        { stmt_count++;
  13716. -          emit_line_note ($<filename>-1, $<lineno>0);
  13717. -          STRIP_NOPS ($4);
  13718. -          if ((TREE_CODE ($4) == ADDR_EXPR
  13719. -               && TREE_CODE (TREE_OPERAND ($4, 0)) == STRING_CST)
  13720. -              || TREE_CODE ($4) == STRING_CST)
  13721. -            expand_asm ($4);
  13722. -          else
  13723. -            error ("argument of `asm' is not a constant string"); }
  13724. -    /* This is the case with just output operands.  */
  13725. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ')' ';'
  13726. -        { stmt_count++;
  13727. -          emit_line_note ($<filename>-1, $<lineno>0);
  13728. -          c_expand_asm_operands ($4, $6, NULL_TREE, NULL_TREE,
  13729. -                     $2 == ridpointers[(int)RID_VOLATILE],
  13730. -                     input_filename, lineno); }
  13731. -    /* This is the case with input operands as well.  */
  13732. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ':' asm_operands ')' ';'
  13733. -        { stmt_count++;
  13734. -          emit_line_note ($<filename>-1, $<lineno>0);
  13735. -          c_expand_asm_operands ($4, $6, $8, NULL_TREE,
  13736. -                     $2 == ridpointers[(int)RID_VOLATILE],
  13737. -                     input_filename, lineno); }
  13738. -    /* This is the case with clobbered registers as well.  */
  13739. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ':'
  13740. -        asm_operands ':' asm_clobbers ')' ';'
  13741. -        { stmt_count++;
  13742. -          emit_line_note ($<filename>-1, $<lineno>0);
  13743. -          c_expand_asm_operands ($4, $6, $8, $10,
  13744. -                     $2 == ridpointers[(int)RID_VOLATILE],
  13745. -                     input_filename, lineno); }
  13746. -    | GOTO identifier ';'
  13747. -        { tree decl;
  13748. -          stmt_count++;
  13749. -          emit_line_note ($<filename>-1, $<lineno>0);
  13750. -          decl = lookup_label ($2);
  13751. -          if (decl != 0)
  13752. -            {
  13753. -              TREE_USED (decl) = 1;
  13754. -              expand_goto (decl);
  13755. -            }
  13756. -        }
  13757. -    | GOTO '*' expr ';'
  13758. -        { stmt_count++;
  13759. -          emit_line_note ($<filename>-1, $<lineno>0);
  13760. -          expand_computed_goto (convert (ptr_type_node, $3)); }
  13761. -    | ';'
  13762. -    ;
  13763. -
  13764. -all_iter_stmt:
  13765. -      all_iter_stmt_simple
  13766. -/*    | all_iter_stmt_with_decl */
  13767. -    ;
  13768. -
  13769. -all_iter_stmt_simple:
  13770. -      FOR '(' primary ')' 
  13771. -      {
  13772. -        /* The value returned by this action is  */
  13773. -        /*      1 if everything is OK */ 
  13774. -        /*      0 in case of error or already bound iterator */
  13775. -
  13776. -        $<itype>$ = 0;
  13777. -        if (TREE_CODE ($3) != VAR_DECL)
  13778. -          error ("invalid `for (ITERATOR)' syntax");
  13779. -        else if (! ITERATOR_P ($3))
  13780. -          error ("`%s' is not an iterator",
  13781. -             IDENTIFIER_POINTER (DECL_NAME ($3)));
  13782. -        else if (ITERATOR_BOUND_P ($3))
  13783. -          error ("`for (%s)' inside expansion of same iterator",
  13784. -             IDENTIFIER_POINTER (DECL_NAME ($3)));
  13785. -        else
  13786. -          {
  13787. -        $<itype>$ = 1;
  13788. -        iterator_for_loop_start ($3);
  13789. -          }
  13790. -      }
  13791. -      lineno_labeled_stmt
  13792. -      {
  13793. -        if ($<itype>5)
  13794. -          iterator_for_loop_end ($3);
  13795. -      }
  13796. -
  13797. -/*  This really should allow any kind of declaration,
  13798. -    for generality.  Fix it before turning it back on.
  13799. -
  13800. -all_iter_stmt_with_decl:
  13801. -      FOR '(' ITERATOR pushlevel setspecs iterator_spec ')' 
  13802. -      {
  13803. -*/        /* The value returned by this action is  */
  13804. -        /*      1 if everything is OK */ 
  13805. -        /*      0 in case of error or already bound iterator */
  13806. -/*
  13807. -        iterator_for_loop_start ($6);
  13808. -      }
  13809. -      lineno_labeled_stmt
  13810. -      {
  13811. -        iterator_for_loop_end ($6);
  13812. -        emit_line_note (input_filename, lineno);
  13813. -        expand_end_bindings (getdecls (), 1, 0);
  13814. -        $<ttype>$ = poplevel (1, 1, 0);
  13815. -        if (yychar == CONSTANT || yychar == STRING)
  13816. -          pop_momentary_nofree ();
  13817. -        else
  13818. -          pop_momentary ();        
  13819. -      }
  13820. -*/
  13821. -
  13822. -/* Any kind of label, including jump labels and case labels.
  13823. -   ANSI C accepts labels only before statements, but we allow them
  13824. -   also at the end of a compound statement.  */
  13825. -
  13826. -label:      CASE expr_no_commas ':'
  13827. -        { register tree value = check_case_value ($2);
  13828. -          register tree label
  13829. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  13830. -
  13831. -          stmt_count++;
  13832. -
  13833. -          if (value != error_mark_node)
  13834. -            {
  13835. -              tree duplicate;
  13836. -              int success = pushcase (value, convert_and_check,
  13837. -                          label, &duplicate);
  13838. -              if (success == 1)
  13839. -            error ("case label not within a switch statement");
  13840. -              else if (success == 2)
  13841. -            {
  13842. -              error ("duplicate case value");
  13843. -              error_with_decl (duplicate, "this is the first entry for that value");
  13844. -            }
  13845. -              else if (success == 3)
  13846. -            warning ("case value out of range");
  13847. -              else if (success == 5)
  13848. -            error ("case label within scope of cleanup or variable array");
  13849. -            }
  13850. -          position_after_white_space (); }
  13851. -    | CASE expr_no_commas ELLIPSIS expr_no_commas ':'
  13852. -        { register tree value1 = check_case_value ($2);
  13853. -          register tree value2 = check_case_value ($4);
  13854. -          register tree label
  13855. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  13856. -
  13857. -          stmt_count++;
  13858. -
  13859. -          if (value1 != error_mark_node && value2 != error_mark_node)
  13860. -            {
  13861. -              tree duplicate;
  13862. -              int success = pushcase_range (value1, value2,
  13863. -                            convert_and_check, label,
  13864. -                            &duplicate);
  13865. -              if (success == 1)
  13866. -            error ("case label not within a switch statement");
  13867. -              else if (success == 2)
  13868. -            {
  13869. -              error ("duplicate case value");
  13870. -              error_with_decl (duplicate, "this is the first entry for that value");
  13871. -            }
  13872. -              else if (success == 3)
  13873. -            warning ("case value out of range");
  13874. -              else if (success == 4)
  13875. -            warning ("empty case range");
  13876. -              else if (success == 5)
  13877. -            error ("case label within scope of cleanup or variable array");
  13878. -            }
  13879. -          position_after_white_space (); }
  13880. -    | DEFAULT ':'
  13881. -        {
  13882. -          tree duplicate;
  13883. -          register tree label
  13884. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  13885. -          int success = pushcase (NULL_TREE, 0, label, &duplicate);
  13886. -          stmt_count++;
  13887. -          if (success == 1)
  13888. -            error ("default label not within a switch statement");
  13889. -          else if (success == 2)
  13890. -            {
  13891. -              error ("multiple default labels in one switch");
  13892. -              error_with_decl (duplicate, "this is the first default label");
  13893. -            }
  13894. -          position_after_white_space (); }
  13895. -    | identifier ':'
  13896. -        { tree label = define_label (input_filename, lineno, $1);
  13897. -          stmt_count++;
  13898. -          emit_nop ();
  13899. -          if (label)
  13900. -            expand_label (label);
  13901. -          position_after_white_space (); }
  13902. -    ;
  13903. -
  13904. -/* Either a type-qualifier or nothing.  First thing in an `asm' statement.  */
  13905. -
  13906. -maybe_type_qual:
  13907. -    /* empty */
  13908. -        { emit_line_note (input_filename, lineno);
  13909. -          $$ = NULL_TREE; }
  13910. -    | TYPE_QUAL
  13911. -        { emit_line_note (input_filename, lineno); }
  13912. -    ;
  13913. -
  13914. -xexpr:
  13915. -    /* empty */
  13916. -        { $$ = NULL_TREE; }
  13917. -    | expr
  13918. -    ;
  13919. -
  13920. -/* These are the operands other than the first string and colon
  13921. -   in  asm ("addextend %2,%1": "=dm" (x), "0" (y), "g" (*x))  */
  13922. -asm_operands: /* empty */
  13923. -        { $$ = NULL_TREE; }
  13924. -    | nonnull_asm_operands
  13925. -    ;
  13926. -
  13927. -nonnull_asm_operands:
  13928. -      asm_operand
  13929. -    | nonnull_asm_operands ',' asm_operand
  13930. -        { $$ = chainon ($1, $3); }
  13931. -    ;
  13932. -
  13933. -asm_operand:
  13934. -      STRING '(' expr ')'
  13935. -        { $$ = build_tree_list ($1, $3); }
  13936. -    ;
  13937. -
  13938. -asm_clobbers:
  13939. -      string
  13940. -        { $$ = tree_cons (NULL_TREE, combine_strings ($1), NULL_TREE); }
  13941. -    | asm_clobbers ',' string
  13942. -        { $$ = tree_cons (NULL_TREE, combine_strings ($3), $1); }
  13943. -    ;
  13944. -
  13945. -/* This is what appears inside the parens in a function declarator.
  13946. -   Its value is a list of ..._TYPE nodes.  */
  13947. -parmlist:
  13948. -        { pushlevel (0);
  13949. -          clear_parm_order ();
  13950. -          declare_parm_level (0); }
  13951. -      parmlist_1
  13952. -        { $$ = $2;
  13953. -          parmlist_tags_warning ();
  13954. -          poplevel (0, 0, 0); }
  13955. -    ;
  13956. -
  13957. -parmlist_1:
  13958. -      parmlist_2 ')'
  13959. -    | parms ';'
  13960. -        { tree parm;
  13961. -          if (pedantic)
  13962. -            pedwarn ("ANSI C forbids forward parameter declarations");
  13963. -          /* Mark the forward decls as such.  */
  13964. -          for (parm = getdecls (); parm; parm = TREE_CHAIN (parm))
  13965. -            TREE_ASM_WRITTEN (parm) = 1;
  13966. -          clear_parm_order (); }
  13967. -      parmlist_1
  13968. -        { $$ = $4; }
  13969. -    | error ')'
  13970. -        { $$ = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); }
  13971. -    ;
  13972. -
  13973. -/* This is what appears inside the parens in a function declarator.
  13974. -   Is value is represented in the format that grokdeclarator expects.  */
  13975. -parmlist_2:  /* empty */
  13976. -        { $$ = get_parm_info (0); }
  13977. -    | ELLIPSIS
  13978. -        { $$ = get_parm_info (0);
  13979. -          /* Gcc used to allow this as an extension.  However, it does
  13980. -             not work for all targets, and thus has been disabled.
  13981. -             Also, since func (...) and func () are indistinguishable,
  13982. -             it caused problems with the code in expand_builtin which
  13983. -             tries to verify that BUILT_IN_NEXT_ARG is being used
  13984. -             correctly.  */
  13985. -          error ("ANSI C requires a named argument before `...'");
  13986. -        }
  13987. -    | parms
  13988. -        { $$ = get_parm_info (1); }
  13989. -    | parms ',' ELLIPSIS
  13990. -        { $$ = get_parm_info (0); }
  13991. -    ;
  13992. -
  13993. -parms:
  13994. -    parm
  13995. -        { push_parm_decl ($1); }
  13996. -    | parms ',' parm
  13997. -        { push_parm_decl ($3); }
  13998. -    ;
  13999. -
  14000. -/* A single parameter declaration or parameter type name,
  14001. -   as found in a parmlist.  */
  14002. -parm:
  14003. -      typed_declspecs setspecs parm_declarator maybe_attribute
  14004. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  14005. -                             $3),
  14006. -                    build_tree_list (prefix_attributes,
  14007. -                             $4));
  14008. -          current_declspecs = TREE_VALUE (declspec_stack);
  14009. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  14010. -          declspec_stack = TREE_CHAIN (declspec_stack);
  14011. -          resume_momentary ($2); }
  14012. -    | typed_declspecs setspecs notype_declarator maybe_attribute
  14013. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  14014. -                             $3),
  14015. -                    build_tree_list (prefix_attributes,
  14016. -                             $4)); 
  14017. -          current_declspecs = TREE_VALUE (declspec_stack);
  14018. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  14019. -          declspec_stack = TREE_CHAIN (declspec_stack);
  14020. -          resume_momentary ($2); }
  14021. -    | typed_declspecs setspecs absdcl maybe_attribute
  14022. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  14023. -                             $3),
  14024. -                    build_tree_list (prefix_attributes,
  14025. -                             $4));
  14026. -          current_declspecs = TREE_VALUE (declspec_stack);
  14027. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  14028. -          declspec_stack = TREE_CHAIN (declspec_stack);
  14029. -          resume_momentary ($2); }
  14030. -    | declmods setspecs notype_declarator maybe_attribute
  14031. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  14032. -                             $3),
  14033. -                    build_tree_list (prefix_attributes,
  14034. -                             $4));
  14035. -          current_declspecs = TREE_VALUE (declspec_stack);
  14036. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  14037. -          declspec_stack = TREE_CHAIN (declspec_stack);
  14038. -          resume_momentary ($2);  }
  14039. -
  14040. -    | declmods setspecs absdcl maybe_attribute
  14041. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  14042. -                             $3),
  14043. -                    build_tree_list (prefix_attributes,
  14044. -                             $4));
  14045. -          current_declspecs = TREE_VALUE (declspec_stack);
  14046. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  14047. -          declspec_stack = TREE_CHAIN (declspec_stack);
  14048. -          resume_momentary ($2);  }
  14049. -    ;
  14050. -
  14051. -/* This is used in a function definition
  14052. -   where either a parmlist or an identifier list is ok.
  14053. -   Its value is a list of ..._TYPE nodes or a list of identifiers.  */
  14054. -parmlist_or_identifiers:
  14055. -        { pushlevel (0);
  14056. -          clear_parm_order ();
  14057. -          declare_parm_level (1); }
  14058. -      parmlist_or_identifiers_1
  14059. -        { $$ = $2;
  14060. -          parmlist_tags_warning ();
  14061. -          poplevel (0, 0, 0); }
  14062. -    ;
  14063. -
  14064. -parmlist_or_identifiers_1:
  14065. -      parmlist_1
  14066. -    | identifiers ')'
  14067. -        { tree t;
  14068. -          for (t = $1; t; t = TREE_CHAIN (t))
  14069. -            if (TREE_VALUE (t) == NULL_TREE)
  14070. -              error ("`...' in old-style identifier list");
  14071. -          $$ = tree_cons (NULL_TREE, NULL_TREE, $1); }
  14072. -    ;
  14073. -
  14074. -/* A nonempty list of identifiers.  */
  14075. -identifiers:
  14076. -    IDENTIFIER
  14077. -        { $$ = build_tree_list (NULL_TREE, $1); }
  14078. -    | identifiers ',' IDENTIFIER
  14079. -        { $$ = chainon ($1, build_tree_list (NULL_TREE, $3)); }
  14080. -    ;
  14081. -
  14082. -/* A nonempty list of identifiers, including typenames.  */
  14083. -identifiers_or_typenames:
  14084. -    identifier
  14085. -        { $$ = build_tree_list (NULL_TREE, $1); }
  14086. -    | identifiers_or_typenames ',' identifier
  14087. -        { $$ = chainon ($1, build_tree_list (NULL_TREE, $3)); }
  14088. -    ;
  14089. -
  14090. -%%
  14091. diff -rup --new-file baseline/fsf/gcc/c-tree.h amiga/fsf/gcc/c-tree.h
  14092. --- baseline/fsf/gcc/c-tree.h    Thu Jun 15 04:13:40 1995
  14093. +++ amiga/fsf/gcc/c-tree.h    Sat Sep 28 00:00:00 1996
  14094. @@ -293,7 +293,9 @@ extern void print_lang_type             
  14095.                                   int));
  14096.  extern void push_c_function_context             PROTO((void));
  14097.  extern void push_label_level                    PROTO((void));
  14098. -extern void push_parm_decl                      PROTO((tree));
  14099. +/* Amiga-specific support for explicit register specification for parameters.
  14100. +   KI 1.04.1996 */
  14101. +extern void push_parm_decl                      PROTO((tree, tree));
  14102.  extern tree pushdecl                            PROTO((tree));
  14103.  extern tree pushdecl_top_level                  PROTO((tree));
  14104.  extern void pushlevel                           PROTO((int));
  14105. diff -rup --new-file baseline/fsf/gcc/calls.c amiga/fsf/gcc/calls.c
  14106. --- baseline/fsf/gcc/calls.c    Thu Oct 26 18:53:43 1995
  14107. +++ amiga/fsf/gcc/calls.c    Sat Sep 28 00:00:00 1996
  14108. @@ -2284,6 +2284,14 @@ emit_library_call VPROTO((rtx orgfun, in
  14109.  
  14110.    argvec = (struct arg *) alloca (nargs * sizeof (struct arg));
  14111.  
  14112. +#if defined (TARGET_AMIGAOS)
  14113. +/* how would you do this RIGHT ?? fake a DECL node? dunno... */
  14114. +#ifdef ENCODE_SECTION_INFO
  14115. +  /* mark it as a function (to be in the text section that is) */
  14116. +  SYMBOL_REF_FLAG (fun) = 1;
  14117. +#endif
  14118. +#endif
  14119. +
  14120.    INIT_CUMULATIVE_ARGS (args_so_far, NULL_TREE, fun);
  14121.  
  14122.    args_size.constant = 0;
  14123. @@ -2591,6 +2599,14 @@ emit_library_call_value VPROTO((rtx orgf
  14124.       library functions shouldn't have many args.  */
  14125.  
  14126.    argvec = (struct arg *) alloca ((nargs + 1) * sizeof (struct arg));
  14127. +
  14128. +#if defined (TARGET_AMIGAOS)
  14129. +/* how would you do this RIGHT ?? fake a DECL node? dunno... */
  14130. +#ifdef ENCODE_SECTION_INFO
  14131. +  /* mark it as a function (to be in the text section that is) */
  14132. +  SYMBOL_REF_FLAG (fun) = 1;
  14133. +#endif
  14134. +#endif
  14135.  
  14136.    INIT_CUMULATIVE_ARGS (args_so_far, NULL_TREE, fun);
  14137.  
  14138. diff -rup --new-file baseline/fsf/gcc/cccp.c amiga/fsf/gcc/cccp.c
  14139. --- baseline/fsf/gcc/cccp.c    Thu Oct 26 15:07:26 1995
  14140. +++ amiga/fsf/gcc/cccp.c    Sat Sep 28 00:00:00 1996
  14141. @@ -40,6 +40,17 @@ typedef unsigned char U_CHAR;
  14142.  #include "config.h"
  14143.  #endif /* not EMACS */
  14144.  
  14145. +/* The ABS_FILENAME macro returns whether or not a filename 
  14146. +   starting at "begin" and "length" characters long, is an
  14147. +   absolute pathname. */
  14148. +#ifndef ABS_FILENAME
  14149. +#ifdef DIR_SEPARATOR
  14150. +#define ABS_FILENAME(begin,length) (*(begin) == '/' || *(begin) == DIR_SEPARATOR)
  14151. +#else
  14152. +#define ABS_FILENAME(begin,length) (*(begin) == '/')
  14153. +#endif
  14154. +#endif
  14155. +
  14156.  #ifndef STANDARD_INCLUDE_DIR
  14157.  #define STANDARD_INCLUDE_DIR "/usr/include"
  14158.  #endif
  14159. @@ -310,6 +321,11 @@ typedef struct { unsigned :16, :16, :16;
  14160.  #define INCLUDE_LEN_FUDGE 0
  14161.  #endif
  14162.  
  14163. +#ifndef OPEN_CASE_SENSITIVE
  14164. +/* Default is standard open() */
  14165. +#define OPEN_CASE_SENSITIVE open
  14166. +#endif
  14167. +
  14168.  /* External declarations.  */
  14169.  
  14170.  extern char *version_string;
  14171. @@ -589,6 +605,8 @@ static struct default_include {
  14172.    = INCLUDE_DEFAULTS;
  14173.  #else
  14174.    = {
  14175. +    /* Pick up GNU C++ specific include files for specific gcc release. */
  14176. +    { GPLUSPLUS_INCLUDE_DIR_SPECIFIC, 1, 1},
  14177.      /* Pick up GNU C++ specific include files.  */
  14178.      { GPLUSPLUS_INCLUDE_DIR, 1, 1 },
  14179.  #ifdef CROSS_COMPILE
  14180. @@ -1189,7 +1207,7 @@ static void append_include_chain PROTO((
  14181.  
  14182.  static void deps_output PROTO((char *, int));
  14183.  
  14184. -static void fatal PRINTF_PROTO_1((char *, ...)) __attribute__ ((noreturn));
  14185. +void fatal PRINTF_PROTO_1((char *, ...)) __attribute__ ((noreturn));
  14186.  void fancy_abort PROTO((void)) __attribute__ ((noreturn));
  14187.  static void perror_with_name PROTO((char *));
  14188.  static void pfatal_with_name PROTO((char *)) __attribute__ ((noreturn));
  14189. @@ -1311,6 +1329,10 @@ main (argc, argv)
  14190.    }
  14191.  #endif /* RLIMIT_STACK defined */
  14192.  
  14193. +#ifdef GET_DEFAULT_PRIORITY
  14194. +  GET_DEFAULT_PRIORITY ();
  14195. +#endif
  14196. +
  14197.  #ifdef SIGPIPE
  14198.    signal (SIGPIPE, pipe_closed);
  14199.  #endif
  14200. @@ -1320,6 +1342,9 @@ main (argc, argv)
  14201.  #ifdef DIR_SEPARATOR
  14202.       && cp[-1] != DIR_SEPARATOR
  14203.  #endif
  14204. +#ifdef VOL_SEPARATOR
  14205. +     && cp[-1] != VOL_SEPARATOR
  14206. +#endif
  14207.       )
  14208.      --cp;
  14209.    progname = cp;
  14210. @@ -1519,6 +1544,12 @@ main (argc, argv)
  14211.      break;
  14212.  
  14213.        case 'p':
  14214. +#ifdef PARSE_PRIORITY
  14215. +    if (PARSE_PRIORITY (argc, argv, &i))
  14216. +      {
  14217. +        break;
  14218. +      }
  14219. +#endif
  14220.      if (!strcmp (argv[i], "-pedantic"))
  14221.        pedantic = 1;
  14222.      else if (!strcmp (argv[i], "-pedantic-errors")) {
  14223. @@ -1809,6 +1840,10 @@ main (argc, argv)
  14224.      }
  14225.    }
  14226.  
  14227. +#ifdef SET_PRIORITY
  14228. +  SET_PRIORITY ();
  14229. +#endif
  14230. +
  14231.    /* Add dirs from CPATH after dirs from -I.  */
  14232.    /* There seems to be confusion about what CPATH should do,
  14233.       so for the moment it is not documented.  */
  14234. @@ -2167,6 +2202,9 @@ main (argc, argv)
  14235.        int len;
  14236.  
  14237.        /* Discard all directory prefixes from filename.  */
  14238. +#ifdef FILE_NAME_NONDIRECTORY
  14239. +      q = FILE_NAME_NONDIRECTORY (in_fname);
  14240. +#else
  14241.        if ((q = rindex (in_fname, '/')) != NULL
  14242.  #ifdef DIR_SEPARATOR
  14243.        && (q = rindex (in_fname, DIR_SEPARATOR)) != NULL
  14244. @@ -2175,7 +2213,7 @@ main (argc, argv)
  14245.      ++q;
  14246.        else
  14247.      q = in_fname;
  14248. -
  14249. +#endif
  14250.        /* Copy remainder to mungable area.  */
  14251.        p = (char *) alloca (strlen(q) + 8);
  14252.        strcpy (p, q);
  14253. @@ -3317,6 +3355,16 @@ randomchar:
  14254.         If REDO_CHAR is 1, the terminating char has already been
  14255.         backed over.  OBP-IDENT_LENGTH points to the identifier.  */
  14256.  
  14257. +#ifdef CPP_SYMNAME_HOOK
  14258. +    {
  14259. +      char *begin = obp - ident_length;
  14260. +      if (!redo_char)
  14261. +        {
  14262. +          begin--;
  14263. +        }
  14264. +      CPP_SYMNAME_HOOK (begin, ident_length);
  14265. +    }
  14266. +#endif
  14267.      if (!pcp_outfile || pcp_inside_if) {
  14268.        for (hp = hashtab[MAKE_POS (hash) % HASHSIZE]; hp != NULL;
  14269.             hp = hp->next) {
  14270. @@ -4002,7 +4050,12 @@ handle_directive (ip, op)
  14271.  
  14272.        if (!no_output && already_output == 0
  14273.        && (kt->pass_thru
  14274. +/* Phil.B 27-Mar-93 not quite sure to keep this old fix */      
  14275. +#if defined (__amigaos__) && 0
  14276. +          || ((kt->type == T_DEFINE || kt->type == T_UNDEF)
  14277. +#else
  14278.            || (kt->type == T_DEFINE
  14279. +#endif /* __amigaos__ */
  14280.            && (dump_macros == dump_names
  14281.                || dump_macros == dump_definitions)))) {
  14282.          int len;
  14283. @@ -4198,6 +4251,17 @@ special_symbol (hp, op)
  14284.  
  14285.      if (!is_idstart[*ip->bufp])
  14286.        goto oops;
  14287. +#ifdef CPP_SYMNAME_HOOK
  14288. +    {
  14289. +      extern char *strrchr ();
  14290. +      char *end = strrchr (ip->bufp, ')');
  14291. +      if (end == NULL)
  14292. +    {
  14293. +      end = ip -> bufp + strlen (ip -> bufp);
  14294. +    }
  14295. +      CPP_SYMNAME_HOOK (ip -> bufp, end - (char *) (ip -> bufp));
  14296. +    }
  14297. +#endif
  14298.      if ((hp = lookup (ip->bufp, -1, -1))) {
  14299.        if (pcp_outfile && pcp_inside_if
  14300.        && (hp->type == T_CONST
  14301. @@ -4353,6 +4417,14 @@ get_filename:
  14302.            if (tmp != NULL && tmp > ep) ep = tmp;
  14303.          }
  14304.  #endif
  14305. +#ifdef VOL_SEPARATOR
  14306. +        if (ep == NULL) ep = rindex (nam, VOL_SEPARATOR);
  14307. +        else {
  14308. +          char *tmp = rindex (nam, VOL_SEPARATOR);
  14309. +          if (tmp != NULL && tmp > ep) ep = tmp;
  14310. +        }
  14311. +        if (ep != NULL && *ep == VOL_SEPARATOR) ep++;
  14312. +#endif
  14313.  #else                /* VMS */
  14314.          ep = rindex (nam, ']');
  14315.          if (ep == NULL) ep = rindex (nam, '>');
  14316. @@ -4479,11 +4551,7 @@ get_filename:
  14317.  
  14318.    /* If specified file name is absolute, just open it.  */
  14319.  
  14320. -  if (*fbeg == '/'
  14321. -#ifdef DIR_SEPARATOR
  14322. -      || *fbeg == DIR_SEPARATOR
  14323. -#endif
  14324. -      ) {
  14325. +  if (ABS_FILENAME (fbeg, flen)) {
  14326.      strncpy (fname, (char *) fbeg, flen);
  14327.      fname[flen] = 0;
  14328.      if (redundant_include_p (fname))
  14329. @@ -4506,7 +4574,11 @@ get_filename:
  14330.      if (searchptr->fname[0] == 0)
  14331.        continue;
  14332.      strcpy (fname, skip_redundant_dir_prefix (searchptr->fname));
  14333. -    if (fname[0] && fname[strlen (fname) - 1] != '/')
  14334. +    if (fname[0] && fname[strlen (fname) - 1] != '/'
  14335. +#ifdef __amigaos__
  14336. +        && fname[strlen (fname) - 1] != ':'
  14337. +#endif
  14338. +        )
  14339.        strcat (fname, "/");
  14340.        } else {
  14341.      fname[0] = 0;
  14342. @@ -4966,7 +5038,7 @@ open_include_file (filename, searchptr)
  14343.        && ! strncmp (searchptr->fname, filename, p - filename))
  14344.      {
  14345.        /* FILENAME is in SEARCHPTR, which we've already checked.  */
  14346. -      return open (filename, O_RDONLY, 0666);
  14347. +      return (OPEN_CASE_SENSITIVE (filename, O_RDONLY, 0666));
  14348.      }
  14349.  
  14350.    if (p == filename)
  14351. @@ -4985,7 +5057,7 @@ open_include_file (filename, searchptr)
  14352.      if (! strcmp (map->map_from, from))
  14353.        return open (map->map_to, O_RDONLY, 0666);
  14354.  
  14355. -  return open (filename, O_RDONLY, 0666);
  14356. +  return (OPEN_CASE_SENSITIVE (filename, O_RDONLY, 0666));
  14357.  }
  14358.  
  14359.  /* Process the contents of include file FNAME, already open on descriptor F,
  14360. @@ -7156,6 +7228,10 @@ do_xifdef (buf, limit, op, keyword)
  14361.    /* Find the end of the identifier at the beginning.  */
  14362.    for (end = buf; is_idchar[*end]; end++);
  14363.  
  14364. +#ifdef CPP_SYMNAME_HOOK
  14365. +  CPP_SYMNAME_HOOK (buf, end - buf);
  14366. +#endif
  14367. +
  14368.    if (end == buf) {
  14369.      skip = (keyword->type == T_IFDEF);
  14370.      if (! traditional)
  14371. @@ -9948,7 +10024,7 @@ deps_output (string, spacer)
  14372.    deps_buffer[deps_size] = 0;
  14373.  }
  14374.  
  14375. -static void
  14376. +void
  14377.  fatal (PRINTF_ALIST (msg))
  14378.       PRINTF_DCL (msg)
  14379.  {
  14380. diff -rup --new-file baseline/fsf/gcc/cexp.c amiga/fsf/gcc/cexp.c
  14381. --- baseline/fsf/gcc/cexp.c    Thu Jun 15 09:53:44 1995
  14382. +++ amiga/fsf/gcc/cexp.c    Wed Dec 31 17:00:00 1969
  14383. @@ -1,1958 +0,0 @@
  14384. -
  14385. -/*  A Bison parser, made from cexp.y with Bison version GNU Bison version 1.22
  14386. -  */
  14387. -
  14388. -#define YYBISON 1  /* Identify Bison output.  */
  14389. -
  14390. -#define    INT    258
  14391. -#define    CHAR    259
  14392. -#define    NAME    260
  14393. -#define    ERROR    261
  14394. -#define    OR    262
  14395. -#define    AND    263
  14396. -#define    EQUAL    264
  14397. -#define    NOTEQUAL    265
  14398. -#define    LEQ    266
  14399. -#define    GEQ    267
  14400. -#define    LSH    268
  14401. -#define    RSH    269
  14402. -#define    UNARY    270
  14403. -
  14404. -#line 27 "cexp.y"
  14405. -
  14406. -#include "config.h"
  14407. -#include <setjmp.h>
  14408. -/* #define YYDEBUG 1 */
  14409. -
  14410. -#ifdef MULTIBYTE_CHARS
  14411. -#include <stdlib.h>
  14412. -#include <locale.h>
  14413. -#endif
  14414. -
  14415. -#include <stdio.h>
  14416. -
  14417. -typedef unsigned char U_CHAR;
  14418. -
  14419. -/* This is used for communicating lists of keywords with cccp.c.  */
  14420. -struct arglist {
  14421. -  struct arglist *next;
  14422. -  U_CHAR *name;
  14423. -  int length;
  14424. -  int argno;
  14425. -};
  14426. -
  14427. -/* Define a generic NULL if one hasn't already been defined.  */
  14428. -
  14429. -#ifndef NULL
  14430. -#define NULL 0
  14431. -#endif
  14432. -
  14433. -#ifndef GENERIC_PTR
  14434. -#if defined (USE_PROTOTYPES) ? USE_PROTOTYPES : defined (__STDC__)
  14435. -#define GENERIC_PTR void *
  14436. -#else
  14437. -#define GENERIC_PTR char *
  14438. -#endif
  14439. -#endif
  14440. -
  14441. -/* Find the largest host integer type and set its size and type.  */
  14442. -
  14443. -#ifndef HOST_BITS_PER_WIDE_INT
  14444. -
  14445. -#if HOST_BITS_PER_LONG > HOST_BITS_PER_INT
  14446. -#define HOST_BITS_PER_WIDE_INT HOST_BITS_PER_LONG
  14447. -#define HOST_WIDE_INT long
  14448. -#else
  14449. -#define HOST_BITS_PER_WIDE_INT HOST_BITS_PER_INT
  14450. -#define HOST_WIDE_INT int
  14451. -#endif
  14452. -
  14453. -#endif
  14454. -
  14455. -#ifndef NULL_PTR
  14456. -#define NULL_PTR ((GENERIC_PTR)0)
  14457. -#endif
  14458. -
  14459. -int yylex ();
  14460. -void yyerror ();
  14461. -HOST_WIDE_INT expression_value;
  14462. -
  14463. -static jmp_buf parse_return_error;
  14464. -
  14465. -/* Nonzero means count most punctuation as part of a name.  */
  14466. -static int keyword_parsing = 0;
  14467. -
  14468. -/* Nonzero means do not evaluate this expression.
  14469. -   This is a count, since unevaluated expressions can nest.  */
  14470. -static int skip_evaluation;
  14471. -
  14472. -/* some external tables of character types */
  14473. -extern unsigned char is_idstart[], is_idchar[], is_hor_space[];
  14474. -
  14475. -extern char *xmalloc ();
  14476. -
  14477. -/* Flag for -pedantic.  */
  14478. -extern int pedantic;
  14479. -
  14480. -/* Flag for -traditional.  */
  14481. -extern int traditional;
  14482. -
  14483. -#ifndef CHAR_TYPE_SIZE
  14484. -#define CHAR_TYPE_SIZE BITS_PER_UNIT
  14485. -#endif
  14486. -
  14487. -#ifndef INT_TYPE_SIZE
  14488. -#define INT_TYPE_SIZE BITS_PER_WORD
  14489. -#endif
  14490. -
  14491. -#ifndef LONG_TYPE_SIZE
  14492. -#define LONG_TYPE_SIZE BITS_PER_WORD
  14493. -#endif
  14494. -
  14495. -#ifndef WCHAR_TYPE_SIZE
  14496. -#define WCHAR_TYPE_SIZE INT_TYPE_SIZE
  14497. -#endif
  14498. -
  14499. -#ifndef MAX_CHAR_TYPE_SIZE
  14500. -#define MAX_CHAR_TYPE_SIZE CHAR_TYPE_SIZE
  14501. -#endif
  14502. -
  14503. -#ifndef MAX_INT_TYPE_SIZE
  14504. -#define MAX_INT_TYPE_SIZE INT_TYPE_SIZE
  14505. -#endif
  14506. -
  14507. -#ifndef MAX_LONG_TYPE_SIZE
  14508. -#define MAX_LONG_TYPE_SIZE LONG_TYPE_SIZE
  14509. -#endif
  14510. -
  14511. -#ifndef MAX_WCHAR_TYPE_SIZE
  14512. -#define MAX_WCHAR_TYPE_SIZE WCHAR_TYPE_SIZE
  14513. -#endif
  14514. -
  14515. -/* Yield nonzero if adding two numbers with A's and B's signs can yield a
  14516. -   number with SUM's sign, where A, B, and SUM are all C integers.  */
  14517. -#define possible_sum_sign(a, b, sum) ((((a) ^ (b)) | ~ ((a) ^ (sum))) < 0)
  14518. -
  14519. -static void integer_overflow ();
  14520. -static long left_shift ();
  14521. -static long right_shift ();
  14522. -
  14523. -#line 146 "cexp.y"
  14524. -typedef union {
  14525. -  struct constant {long value; int unsignedp;} integer;
  14526. -  struct name {U_CHAR *address; int length;} name;
  14527. -  struct arglist *keywords;
  14528. -} YYSTYPE;
  14529. -
  14530. -#ifndef YYLTYPE
  14531. -typedef
  14532. -  struct yyltype
  14533. -    {
  14534. -      int timestamp;
  14535. -      int first_line;
  14536. -      int first_column;
  14537. -      int last_line;
  14538. -      int last_column;
  14539. -      char *text;
  14540. -   }
  14541. -  yyltype;
  14542. -
  14543. -#define YYLTYPE yyltype
  14544. -#endif
  14545. -
  14546. -#include <stdio.h>
  14547. -
  14548. -#ifndef __cplusplus
  14549. -#ifndef __STDC__
  14550. -#define const
  14551. -#endif
  14552. -#endif
  14553. -
  14554. -
  14555. -
  14556. -#define    YYFINAL        77
  14557. -#define    YYFLAG        -32768
  14558. -#define    YYNTBASE    34
  14559. -
  14560. -#define YYTRANSLATE(x) ((unsigned)(x) <= 270 ? yytranslate[x] : 43)
  14561. -
  14562. -static const char yytranslate[] = {     0,
  14563. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14564. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14565. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14566. -     2,     2,    29,     2,    31,     2,    27,    14,     2,    32,
  14567. -    33,    25,    23,     9,    24,     2,    26,     2,     2,     2,
  14568. -     2,     2,     2,     2,     2,     2,     2,     8,     2,    17,
  14569. -     2,    18,     7,     2,     2,     2,     2,     2,     2,     2,
  14570. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14571. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14572. -     2,     2,     2,    13,     2,     2,     2,     2,     2,     2,
  14573. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14574. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14575. -     2,     2,     2,    12,     2,    30,     2,     2,     2,     2,
  14576. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14577. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14578. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14579. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14580. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14581. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14582. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14583. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14584. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14585. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14586. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14587. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  14588. -     2,     2,     2,     2,     2,     1,     2,     3,     4,     5,
  14589. -     6,    10,    11,    15,    16,    19,    20,    21,    22,    28
  14590. -};
  14591. -
  14592. -#if YYDEBUG != 0
  14593. -static const short yyprhs[] = {     0,
  14594. -     0,     2,     4,     8,    11,    14,    17,    20,    23,    24,
  14595. -    31,    35,    39,    43,    47,    51,    55,    59,    63,    67,
  14596. -    71,    75,    79,    83,    87,    91,    95,    99,   100,   105,
  14597. -   106,   111,   112,   113,   121,   123,   125,   127,   128,   133
  14598. -};
  14599. -
  14600. -static const short yyrhs[] = {    35,
  14601. -     0,    36,     0,    35,     9,    36,     0,    24,    36,     0,
  14602. -    29,    36,     0,    23,    36,     0,    30,    36,     0,    31,
  14603. -     5,     0,     0,    31,     5,    37,    32,    42,    33,     0,
  14604. -    32,    35,    33,     0,    36,    25,    36,     0,    36,    26,
  14605. -    36,     0,    36,    27,    36,     0,    36,    23,    36,     0,
  14606. -    36,    24,    36,     0,    36,    21,    36,     0,    36,    22,
  14607. -    36,     0,    36,    15,    36,     0,    36,    16,    36,     0,
  14608. -    36,    19,    36,     0,    36,    20,    36,     0,    36,    17,
  14609. -    36,     0,    36,    18,    36,     0,    36,    14,    36,     0,
  14610. -    36,    13,    36,     0,    36,    12,    36,     0,     0,    36,
  14611. -    11,    38,    36,     0,     0,    36,    10,    39,    36,     0,
  14612. -     0,     0,    36,     7,    40,    36,     8,    41,    36,     0,
  14613. -     3,     0,     4,     0,     5,     0,     0,    32,    42,    33,
  14614. -    42,     0,     5,    42,     0
  14615. -};
  14616. -
  14617. -#endif
  14618. -
  14619. -#if YYDEBUG != 0
  14620. -static const short yyrline[] = { 0,
  14621. -   176,   181,   182,   189,   194,   197,   199,   202,   206,   208,
  14622. -   213,   218,   230,   246,   258,   265,   272,   278,   284,   287,
  14623. -   290,   296,   302,   308,   314,   317,   320,   323,   326,   329,
  14624. -   332,   335,   337,   340,   343,   345,   347,   352,   354,   367
  14625. -};
  14626. -
  14627. -static const char * const yytname[] = {   "$","error","$illegal.","INT","CHAR",
  14628. -"NAME","ERROR","'?'","':'","','","OR","AND","'|'","'^'","'&'","EQUAL","NOTEQUAL",
  14629. -"'<'","'>'","LEQ","GEQ","LSH","RSH","'+'","'-'","'*'","'/'","'%'","UNARY","'!'",
  14630. -"'~'","'#'","'('","')'","start","exp1","exp","@1","@2","@3","@4","@5","keywords",
  14631. -""
  14632. -};
  14633. -#endif
  14634. -
  14635. -static const short yyr1[] = {     0,
  14636. -    34,    35,    35,    36,    36,    36,    36,    36,    37,    36,
  14637. -    36,    36,    36,    36,    36,    36,    36,    36,    36,    36,
  14638. -    36,    36,    36,    36,    36,    36,    36,    38,    36,    39,
  14639. -    36,    40,    41,    36,    36,    36,    36,    42,    42,    42
  14640. -};
  14641. -
  14642. -static const short yyr2[] = {     0,
  14643. -     1,     1,     3,     2,     2,     2,     2,     2,     0,     6,
  14644. -     3,     3,     3,     3,     3,     3,     3,     3,     3,     3,
  14645. -     3,     3,     3,     3,     3,     3,     3,     0,     4,     0,
  14646. -     4,     0,     0,     7,     1,     1,     1,     0,     4,     2
  14647. -};
  14648. -
  14649. -static const short yydefact[] = {     0,
  14650. -    35,    36,    37,     0,     0,     0,     0,     0,     0,     1,
  14651. -     2,     6,     4,     5,     7,     8,     0,     0,    32,    30,
  14652. -    28,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  14653. -     0,     0,     0,     0,     0,     0,     0,     0,    11,     3,
  14654. -     0,     0,     0,    27,    26,    25,    19,    20,    23,    24,
  14655. -    21,    22,    17,    18,    15,    16,    12,    13,    14,    38,
  14656. -     0,    31,    29,    38,    38,     0,    33,    40,     0,    10,
  14657. -     0,    38,    34,    39,     0,     0,     0
  14658. -};
  14659. -
  14660. -static const short yydefgoto[] = {    75,
  14661. -    10,    11,    38,    43,    42,    41,    71,    66
  14662. -};
  14663. -
  14664. -static const short yypact[] = {    12,
  14665. --32768,-32768,-32768,    12,    12,    12,    12,     1,    12,     4,
  14666. -    79,-32768,-32768,-32768,-32768,   -21,    31,    12,-32768,-32768,
  14667. --32768,    12,    12,    12,    12,    12,    12,    12,    12,    12,
  14668. -    12,    12,    12,    12,    12,    12,    12,    30,-32768,    79,
  14669. -    12,    12,    12,   110,   124,   137,   148,   148,   155,   155,
  14670. -   155,   155,   160,   160,   -17,   -17,-32768,-32768,-32768,     2,
  14671. -    58,    34,    95,     2,     2,    54,-32768,-32768,    55,-32768,
  14672. -    12,     2,    79,-32768,    63,   188,-32768
  14673. -};
  14674. -
  14675. -static const short yypgoto[] = {-32768,
  14676. -   180,    -4,-32768,-32768,-32768,-32768,-32768,   -60
  14677. -};
  14678. -
  14679. -
  14680. -#define    YYLAST        189
  14681. -
  14682. -
  14683. -static const short yytable[] = {    12,
  14684. -    13,    14,    15,    68,    69,    16,    64,    35,    36,    37,
  14685. -    -9,    74,    18,    40,     1,     2,     3,    44,    45,    46,
  14686. -    47,    48,    49,    50,    51,    52,    53,    54,    55,    56,
  14687. -    57,    58,    59,    65,     4,     5,    61,    62,    63,    18,
  14688. -     6,     7,     8,     9,    21,    22,    23,    24,    25,    26,
  14689. -    27,    28,    29,    30,    31,    32,    33,    34,    35,    36,
  14690. -    37,    60,    76,    39,    19,    67,    73,    20,    21,    22,
  14691. -    23,    24,    25,    26,    27,    28,    29,    30,    31,    32,
  14692. -    33,    34,    35,    36,    37,    19,    70,    72,    20,    21,
  14693. -    22,    23,    24,    25,    26,    27,    28,    29,    30,    31,
  14694. -    32,    33,    34,    35,    36,    37,    22,    23,    24,    25,
  14695. -    26,    27,    28,    29,    30,    31,    32,    33,    34,    35,
  14696. -    36,    37,    23,    24,    25,    26,    27,    28,    29,    30,
  14697. -    31,    32,    33,    34,    35,    36,    37,    24,    25,    26,
  14698. -    27,    28,    29,    30,    31,    32,    33,    34,    35,    36,
  14699. -    37,    25,    26,    27,    28,    29,    30,    31,    32,    33,
  14700. -    34,    35,    36,    37,    27,    28,    29,    30,    31,    32,
  14701. -    33,    34,    35,    36,    37,    31,    32,    33,    34,    35,
  14702. -    36,    37,    33,    34,    35,    36,    37,    77,    17
  14703. -};
  14704. -
  14705. -static const short yycheck[] = {     4,
  14706. -     5,     6,     7,    64,    65,     5,     5,    25,    26,    27,
  14707. -    32,    72,     9,    18,     3,     4,     5,    22,    23,    24,
  14708. -    25,    26,    27,    28,    29,    30,    31,    32,    33,    34,
  14709. -    35,    36,    37,    32,    23,    24,    41,    42,    43,     9,
  14710. -    29,    30,    31,    32,    11,    12,    13,    14,    15,    16,
  14711. -    17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
  14712. -    27,    32,     0,    33,     7,     8,    71,    10,    11,    12,
  14713. -    13,    14,    15,    16,    17,    18,    19,    20,    21,    22,
  14714. -    23,    24,    25,    26,    27,     7,    33,    33,    10,    11,
  14715. -    12,    13,    14,    15,    16,    17,    18,    19,    20,    21,
  14716. -    22,    23,    24,    25,    26,    27,    12,    13,    14,    15,
  14717. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  14718. -    26,    27,    13,    14,    15,    16,    17,    18,    19,    20,
  14719. -    21,    22,    23,    24,    25,    26,    27,    14,    15,    16,
  14720. -    17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
  14721. -    27,    15,    16,    17,    18,    19,    20,    21,    22,    23,
  14722. -    24,    25,    26,    27,    17,    18,    19,    20,    21,    22,
  14723. -    23,    24,    25,    26,    27,    21,    22,    23,    24,    25,
  14724. -    26,    27,    23,    24,    25,    26,    27,     0,     9
  14725. -};
  14726. -/* -*-C-*-  Note some compilers choke on comments on `#line' lines.  */
  14727. -#line 3 "/usr/local/lib/bison.simple"
  14728. -
  14729. -/* Skeleton output parser for bison,
  14730. -   Copyright (C) 1984, 1989, 1990 Bob Corbett and Richard Stallman
  14731. -
  14732. -   This program is free software; you can redistribute it and/or modify
  14733. -   it under the terms of the GNU General Public License as published by
  14734. -   the Free Software Foundation; either version 1, or (at your option)
  14735. -   any later version.
  14736. -
  14737. -   This program is distributed in the hope that it will be useful,
  14738. -   but WITHOUT ANY WARRANTY; without even the implied warranty of
  14739. -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14740. -   GNU General Public License for more details.
  14741. -
  14742. -   You should have received a copy of the GNU General Public License
  14743. -   along with this program; if not, write to the Free Software
  14744. -   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  14745. -
  14746. -
  14747. -#ifndef alloca
  14748. -#ifdef __GNUC__
  14749. -#define alloca __builtin_alloca
  14750. -#else /* not GNU C.  */
  14751. -#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi)
  14752. -#include <alloca.h>
  14753. -#else /* not sparc */
  14754. -#if defined (MSDOS) && !defined (__TURBOC__)
  14755. -#include <malloc.h>
  14756. -#else /* not MSDOS, or __TURBOC__ */
  14757. -#if defined(_AIX)
  14758. -#include <malloc.h>
  14759. - #pragma alloca
  14760. -#else /* not MSDOS, __TURBOC__, or _AIX */
  14761. -#ifdef __hpux
  14762. -#ifdef __cplusplus
  14763. -extern "C" {
  14764. -void *alloca (unsigned int);
  14765. -};
  14766. -#else /* not __cplusplus */
  14767. -void *alloca ();
  14768. -#endif /* not __cplusplus */
  14769. -#endif /* __hpux */
  14770. -#endif /* not _AIX */
  14771. -#endif /* not MSDOS, or __TURBOC__ */
  14772. -#endif /* not sparc.  */
  14773. -#endif /* not GNU C.  */
  14774. -#endif /* alloca not defined.  */
  14775. -
  14776. -/* This is the parser code that is written into each bison parser
  14777. -  when the %semantic_parser declaration is not specified in the grammar.
  14778. -  It was written by Richard Stallman by simplifying the hairy parser
  14779. -  used when %semantic_parser is specified.  */
  14780. -
  14781. -/* Note: there must be only one dollar sign in this file.
  14782. -   It is replaced by the list of actions, each action
  14783. -   as one case of the switch.  */
  14784. -
  14785. -#define yyerrok        (yyerrstatus = 0)
  14786. -#define yyclearin    (yychar = YYEMPTY)
  14787. -#define YYEMPTY        -2
  14788. -#define YYEOF        0
  14789. -#define YYACCEPT    return(0)
  14790. -#define YYABORT     return(1)
  14791. -#define YYERROR        goto yyerrlab1
  14792. -/* Like YYERROR except do call yyerror.
  14793. -   This remains here temporarily to ease the
  14794. -   transition to the new meaning of YYERROR, for GCC.
  14795. -   Once GCC version 2 has supplanted version 1, this can go.  */
  14796. -#define YYFAIL        goto yyerrlab
  14797. -#define YYRECOVERING()  (!!yyerrstatus)
  14798. -#define YYBACKUP(token, value) \
  14799. -do                                \
  14800. -  if (yychar == YYEMPTY && yylen == 1)                \
  14801. -    { yychar = (token), yylval = (value);            \
  14802. -      yychar1 = YYTRANSLATE (yychar);                \
  14803. -      YYPOPSTACK;                        \
  14804. -      goto yybackup;                        \
  14805. -    }                                \
  14806. -  else                                \
  14807. -    { yyerror ("syntax error: cannot back up"); YYERROR; }    \
  14808. -while (0)
  14809. -
  14810. -#define YYTERROR    1
  14811. -#define YYERRCODE    256
  14812. -
  14813. -#ifndef YYPURE
  14814. -#define YYLEX        yylex()
  14815. -#endif
  14816. -
  14817. -#ifdef YYPURE
  14818. -#ifdef YYLSP_NEEDED
  14819. -#define YYLEX        yylex(&yylval, &yylloc)
  14820. -#else
  14821. -#define YYLEX        yylex(&yylval)
  14822. -#endif
  14823. -#endif
  14824. -
  14825. -/* If nonreentrant, generate the variables here */
  14826. -
  14827. -#ifndef YYPURE
  14828. -
  14829. -int    yychar;            /*  the lookahead symbol        */
  14830. -YYSTYPE    yylval;            /*  the semantic value of the        */
  14831. -                /*  lookahead symbol            */
  14832. -
  14833. -#ifdef YYLSP_NEEDED
  14834. -YYLTYPE yylloc;            /*  location data for the lookahead    */
  14835. -                /*  symbol                */
  14836. -#endif
  14837. -
  14838. -int yynerrs;            /*  number of parse errors so far       */
  14839. -#endif  /* not YYPURE */
  14840. -
  14841. -#if YYDEBUG != 0
  14842. -int yydebug;            /*  nonzero means print parse trace    */
  14843. -/* Since this is uninitialized, it does not stop multiple parsers
  14844. -   from coexisting.  */
  14845. -#endif
  14846. -
  14847. -/*  YYINITDEPTH indicates the initial size of the parser's stacks    */
  14848. -
  14849. -#ifndef    YYINITDEPTH
  14850. -#define YYINITDEPTH 200
  14851. -#endif
  14852. -
  14853. -/*  YYMAXDEPTH is the maximum size the stacks can grow to
  14854. -    (effective only if the built-in stack extension method is used).  */
  14855. -
  14856. -#if YYMAXDEPTH == 0
  14857. -#undef YYMAXDEPTH
  14858. -#endif
  14859. -
  14860. -#ifndef YYMAXDEPTH
  14861. -#define YYMAXDEPTH 10000
  14862. -#endif
  14863. -
  14864. -/* Prevent warning if -Wstrict-prototypes.  */
  14865. -#ifdef __GNUC__
  14866. -int yyparse (void);
  14867. -#endif
  14868. -
  14869. -#if __GNUC__ > 1        /* GNU C and GNU C++ define this.  */
  14870. -#define __yy_bcopy(FROM,TO,COUNT)    __builtin_memcpy(TO,FROM,COUNT)
  14871. -#else                /* not GNU C or C++ */
  14872. -#ifndef __cplusplus
  14873. -
  14874. -/* This is the most reliable way to avoid incompatibilities
  14875. -   in available built-in functions on various systems.  */
  14876. -static void
  14877. -__yy_bcopy (from, to, count)
  14878. -     char *from;
  14879. -     char *to;
  14880. -     int count;
  14881. -{
  14882. -  register char *f = from;
  14883. -  register char *t = to;
  14884. -  register int i = count;
  14885. -
  14886. -  while (i-- > 0)
  14887. -    *t++ = *f++;
  14888. -}
  14889. -
  14890. -#else /* __cplusplus */
  14891. -
  14892. -/* This is the most reliable way to avoid incompatibilities
  14893. -   in available built-in functions on various systems.  */
  14894. -static void
  14895. -__yy_bcopy (char *from, char *to, int count)
  14896. -{
  14897. -  register char *f = from;
  14898. -  register char *t = to;
  14899. -  register int i = count;
  14900. -
  14901. -  while (i-- > 0)
  14902. -    *t++ = *f++;
  14903. -}
  14904. -
  14905. -#endif
  14906. -#endif
  14907. -
  14908. -#line 184 "/usr/local/lib/bison.simple"
  14909. -
  14910. -/* The user can define YYPARSE_PARAM as the name of an argument to be passed
  14911. -   into yyparse.  The argument should have type void *.
  14912. -   It should actually point to an object.
  14913. -   Grammar actions can access the variable by casting it
  14914. -   to the proper pointer type.  */
  14915. -
  14916. -#ifdef YYPARSE_PARAM
  14917. -#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;
  14918. -#else
  14919. -#define YYPARSE_PARAM
  14920. -#define YYPARSE_PARAM_DECL
  14921. -#endif
  14922. -
  14923. -int
  14924. -yyparse(YYPARSE_PARAM)
  14925. -     YYPARSE_PARAM_DECL
  14926. -{
  14927. -  register int yystate;
  14928. -  register int yyn;
  14929. -  register short *yyssp;
  14930. -  register YYSTYPE *yyvsp;
  14931. -  int yyerrstatus;    /*  number of tokens to shift before error messages enabled */
  14932. -  int yychar1 = 0;        /*  lookahead token as an internal (translated) token number */
  14933. -
  14934. -  short    yyssa[YYINITDEPTH];    /*  the state stack            */
  14935. -  YYSTYPE yyvsa[YYINITDEPTH];    /*  the semantic value stack        */
  14936. -
  14937. -  short *yyss = yyssa;        /*  refer to the stacks thru separate pointers */
  14938. -  YYSTYPE *yyvs = yyvsa;    /*  to allow yyoverflow to reallocate them elsewhere */
  14939. -
  14940. -#ifdef YYLSP_NEEDED
  14941. -  YYLTYPE yylsa[YYINITDEPTH];    /*  the location stack            */
  14942. -  YYLTYPE *yyls = yylsa;
  14943. -  YYLTYPE *yylsp;
  14944. -
  14945. -#define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--)
  14946. -#else
  14947. -#define YYPOPSTACK   (yyvsp--, yyssp--)
  14948. -#endif
  14949. -
  14950. -  int yystacksize = YYINITDEPTH;
  14951. -
  14952. -#ifdef YYPURE
  14953. -  int yychar;
  14954. -  YYSTYPE yylval;
  14955. -  int yynerrs;
  14956. -#ifdef YYLSP_NEEDED
  14957. -  YYLTYPE yylloc;
  14958. -#endif
  14959. -#endif
  14960. -
  14961. -  YYSTYPE yyval;        /*  the variable used to return        */
  14962. -                /*  semantic values from the action    */
  14963. -                /*  routines                */
  14964. -
  14965. -  int yylen;
  14966. -
  14967. -#if YYDEBUG != 0
  14968. -  if (yydebug)
  14969. -    fprintf(stderr, "Starting parse\n");
  14970. -#endif
  14971. -
  14972. -  yystate = 0;
  14973. -  yyerrstatus = 0;
  14974. -  yynerrs = 0;
  14975. -  yychar = YYEMPTY;        /* Cause a token to be read.  */
  14976. -
  14977. -  /* Initialize stack pointers.
  14978. -     Waste one element of value and location stack
  14979. -     so that they stay on the same level as the state stack.
  14980. -     The wasted elements are never initialized.  */
  14981. -
  14982. -  yyssp = yyss - 1;
  14983. -  yyvsp = yyvs;
  14984. -#ifdef YYLSP_NEEDED
  14985. -  yylsp = yyls;
  14986. -#endif
  14987. -
  14988. -/* Push a new state, which is found in  yystate  .  */
  14989. -/* In all cases, when you get here, the value and location stacks
  14990. -   have just been pushed. so pushing a state here evens the stacks.  */
  14991. -yynewstate:
  14992. -
  14993. -  *++yyssp = yystate;
  14994. -
  14995. -  if (yyssp >= yyss + yystacksize - 1)
  14996. -    {
  14997. -      /* Give user a chance to reallocate the stack */
  14998. -      /* Use copies of these so that the &'s don't force the real ones into memory. */
  14999. -      YYSTYPE *yyvs1 = yyvs;
  15000. -      short *yyss1 = yyss;
  15001. -#ifdef YYLSP_NEEDED
  15002. -      YYLTYPE *yyls1 = yyls;
  15003. -#endif
  15004. -
  15005. -      /* Get the current used size of the three stacks, in elements.  */
  15006. -      int size = yyssp - yyss + 1;
  15007. -
  15008. -#ifdef yyoverflow
  15009. -      /* Each stack pointer address is followed by the size of
  15010. -     the data in use in that stack, in bytes.  */
  15011. -#ifdef YYLSP_NEEDED
  15012. -      /* This used to be a conditional around just the two extra args,
  15013. -     but that might be undefined if yyoverflow is a macro.  */
  15014. -      yyoverflow("parser stack overflow",
  15015. -         &yyss1, size * sizeof (*yyssp),
  15016. -         &yyvs1, size * sizeof (*yyvsp),
  15017. -         &yyls1, size * sizeof (*yylsp),
  15018. -         &yystacksize);
  15019. -#else
  15020. -      yyoverflow("parser stack overflow",
  15021. -         &yyss1, size * sizeof (*yyssp),
  15022. -         &yyvs1, size * sizeof (*yyvsp),
  15023. -         &yystacksize);
  15024. -#endif
  15025. -
  15026. -      yyss = yyss1; yyvs = yyvs1;
  15027. -#ifdef YYLSP_NEEDED
  15028. -      yyls = yyls1;
  15029. -#endif
  15030. -#else /* no yyoverflow */
  15031. -      /* Extend the stack our own way.  */
  15032. -      if (yystacksize >= YYMAXDEPTH)
  15033. -    {
  15034. -      yyerror("parser stack overflow");
  15035. -      return 2;
  15036. -    }
  15037. -      yystacksize *= 2;
  15038. -      if (yystacksize > YYMAXDEPTH)
  15039. -    yystacksize = YYMAXDEPTH;
  15040. -      yyss = (short *) alloca (yystacksize * sizeof (*yyssp));
  15041. -      __yy_bcopy ((char *)yyss1, (char *)yyss, size * sizeof (*yyssp));
  15042. -      yyvs = (YYSTYPE *) alloca (yystacksize * sizeof (*yyvsp));
  15043. -      __yy_bcopy ((char *)yyvs1, (char *)yyvs, size * sizeof (*yyvsp));
  15044. -#ifdef YYLSP_NEEDED
  15045. -      yyls = (YYLTYPE *) alloca (yystacksize * sizeof (*yylsp));
  15046. -      __yy_bcopy ((char *)yyls1, (char *)yyls, size * sizeof (*yylsp));
  15047. -#endif
  15048. -#endif /* no yyoverflow */
  15049. -
  15050. -      yyssp = yyss + size - 1;
  15051. -      yyvsp = yyvs + size - 1;
  15052. -#ifdef YYLSP_NEEDED
  15053. -      yylsp = yyls + size - 1;
  15054. -#endif
  15055. -
  15056. -#if YYDEBUG != 0
  15057. -      if (yydebug)
  15058. -    fprintf(stderr, "Stack size increased to %d\n", yystacksize);
  15059. -#endif
  15060. -
  15061. -      if (yyssp >= yyss + yystacksize - 1)
  15062. -    YYABORT;
  15063. -    }
  15064. -
  15065. -#if YYDEBUG != 0
  15066. -  if (yydebug)
  15067. -    fprintf(stderr, "Entering state %d\n", yystate);
  15068. -#endif
  15069. -
  15070. -  goto yybackup;
  15071. - yybackup:
  15072. -
  15073. -/* Do appropriate processing given the current state.  */
  15074. -/* Read a lookahead token if we need one and don't already have one.  */
  15075. -/* yyresume: */
  15076. -
  15077. -  /* First try to decide what to do without reference to lookahead token.  */
  15078. -
  15079. -  yyn = yypact[yystate];
  15080. -  if (yyn == YYFLAG)
  15081. -    goto yydefault;
  15082. -
  15083. -  /* Not known => get a lookahead token if don't already have one.  */
  15084. -
  15085. -  /* yychar is either YYEMPTY or YYEOF
  15086. -     or a valid token in external form.  */
  15087. -
  15088. -  if (yychar == YYEMPTY)
  15089. -    {
  15090. -#if YYDEBUG != 0
  15091. -      if (yydebug)
  15092. -    fprintf(stderr, "Reading a token: ");
  15093. -#endif
  15094. -      yychar = YYLEX;
  15095. -    }
  15096. -
  15097. -  /* Convert token to internal form (in yychar1) for indexing tables with */
  15098. -
  15099. -  if (yychar <= 0)        /* This means end of input. */
  15100. -    {
  15101. -      yychar1 = 0;
  15102. -      yychar = YYEOF;        /* Don't call YYLEX any more */
  15103. -
  15104. -#if YYDEBUG != 0
  15105. -      if (yydebug)
  15106. -    fprintf(stderr, "Now at end of input.\n");
  15107. -#endif
  15108. -    }
  15109. -  else
  15110. -    {
  15111. -      yychar1 = YYTRANSLATE(yychar);
  15112. -
  15113. -#if YYDEBUG != 0
  15114. -      if (yydebug)
  15115. -    {
  15116. -      fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]);
  15117. -      /* Give the individual parser a way to print the precise meaning
  15118. -         of a token, for further debugging info.  */
  15119. -#ifdef YYPRINT
  15120. -      YYPRINT (stderr, yychar, yylval);
  15121. -#endif
  15122. -      fprintf (stderr, ")\n");
  15123. -    }
  15124. -#endif
  15125. -    }
  15126. -
  15127. -  yyn += yychar1;
  15128. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1)
  15129. -    goto yydefault;
  15130. -
  15131. -  yyn = yytable[yyn];
  15132. -
  15133. -  /* yyn is what to do for this token type in this state.
  15134. -     Negative => reduce, -yyn is rule number.
  15135. -     Positive => shift, yyn is new state.
  15136. -       New state is final state => don't bother to shift,
  15137. -       just return success.
  15138. -     0, or most negative number => error.  */
  15139. -
  15140. -  if (yyn < 0)
  15141. -    {
  15142. -      if (yyn == YYFLAG)
  15143. -    goto yyerrlab;
  15144. -      yyn = -yyn;
  15145. -      goto yyreduce;
  15146. -    }
  15147. -  else if (yyn == 0)
  15148. -    goto yyerrlab;
  15149. -
  15150. -  if (yyn == YYFINAL)
  15151. -    YYACCEPT;
  15152. -
  15153. -  /* Shift the lookahead token.  */
  15154. -
  15155. -#if YYDEBUG != 0
  15156. -  if (yydebug)
  15157. -    fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]);
  15158. -#endif
  15159. -
  15160. -  /* Discard the token being shifted unless it is eof.  */
  15161. -  if (yychar != YYEOF)
  15162. -    yychar = YYEMPTY;
  15163. -
  15164. -  *++yyvsp = yylval;
  15165. -#ifdef YYLSP_NEEDED
  15166. -  *++yylsp = yylloc;
  15167. -#endif
  15168. -
  15169. -  /* count tokens shifted since error; after three, turn off error status.  */
  15170. -  if (yyerrstatus) yyerrstatus--;
  15171. -
  15172. -  yystate = yyn;
  15173. -  goto yynewstate;
  15174. -
  15175. -/* Do the default action for the current state.  */
  15176. -yydefault:
  15177. -
  15178. -  yyn = yydefact[yystate];
  15179. -  if (yyn == 0)
  15180. -    goto yyerrlab;
  15181. -
  15182. -/* Do a reduction.  yyn is the number of a rule to reduce with.  */
  15183. -yyreduce:
  15184. -  yylen = yyr2[yyn];
  15185. -  if (yylen > 0)
  15186. -    yyval = yyvsp[1-yylen]; /* implement default value of the action */
  15187. -
  15188. -#if YYDEBUG != 0
  15189. -  if (yydebug)
  15190. -    {
  15191. -      int i;
  15192. -
  15193. -      fprintf (stderr, "Reducing via rule %d (line %d), ",
  15194. -           yyn, yyrline[yyn]);
  15195. -
  15196. -      /* Print the symbols being reduced, and their result.  */
  15197. -      for (i = yyprhs[yyn]; yyrhs[i] > 0; i++)
  15198. -    fprintf (stderr, "%s ", yytname[yyrhs[i]]);
  15199. -      fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]);
  15200. -    }
  15201. -#endif
  15202. -
  15203. -
  15204. -  switch (yyn) {
  15205. -
  15206. -case 1:
  15207. -#line 177 "cexp.y"
  15208. -{ expression_value = yyvsp[0].integer.value; ;
  15209. -    break;}
  15210. -case 3:
  15211. -#line 183 "cexp.y"
  15212. -{ if (pedantic)
  15213. -                pedwarn ("comma operator in operand of `#if'");
  15214. -              yyval.integer = yyvsp[0].integer; ;
  15215. -    break;}
  15216. -case 4:
  15217. -#line 190 "cexp.y"
  15218. -{ yyval.integer.value = - yyvsp[0].integer.value;
  15219. -              if ((yyval.integer.value & yyvsp[0].integer.value) < 0 && ! yyvsp[0].integer.unsignedp)
  15220. -                integer_overflow ();
  15221. -              yyval.integer.unsignedp = yyvsp[0].integer.unsignedp; ;
  15222. -    break;}
  15223. -case 5:
  15224. -#line 195 "cexp.y"
  15225. -{ yyval.integer.value = ! yyvsp[0].integer.value;
  15226. -              yyval.integer.unsignedp = 0; ;
  15227. -    break;}
  15228. -case 6:
  15229. -#line 198 "cexp.y"
  15230. -{ yyval.integer = yyvsp[0].integer; ;
  15231. -    break;}
  15232. -case 7:
  15233. -#line 200 "cexp.y"
  15234. -{ yyval.integer.value = ~ yyvsp[0].integer.value;
  15235. -              yyval.integer.unsignedp = yyvsp[0].integer.unsignedp; ;
  15236. -    break;}
  15237. -case 8:
  15238. -#line 203 "cexp.y"
  15239. -{ yyval.integer.value = check_assertion (yyvsp[0].name.address, yyvsp[0].name.length,
  15240. -                              0, NULL_PTR);
  15241. -              yyval.integer.unsignedp = 0; ;
  15242. -    break;}
  15243. -case 9:
  15244. -#line 207 "cexp.y"
  15245. -{ keyword_parsing = 1; ;
  15246. -    break;}
  15247. -case 10:
  15248. -#line 209 "cexp.y"
  15249. -{ yyval.integer.value = check_assertion (yyvsp[-4].name.address, yyvsp[-4].name.length,
  15250. -                              1, yyvsp[-1].keywords);
  15251. -              keyword_parsing = 0;
  15252. -              yyval.integer.unsignedp = 0; ;
  15253. -    break;}
  15254. -case 11:
  15255. -#line 214 "cexp.y"
  15256. -{ yyval.integer = yyvsp[-1].integer; ;
  15257. -    break;}
  15258. -case 12:
  15259. -#line 219 "cexp.y"
  15260. -{ yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp;
  15261. -              if (yyval.integer.unsignedp)
  15262. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value * yyvsp[0].integer.value;
  15263. -              else
  15264. -                {
  15265. -                  yyval.integer.value = yyvsp[-2].integer.value * yyvsp[0].integer.value;
  15266. -                  if (yyvsp[-2].integer.value
  15267. -                  && (yyval.integer.value / yyvsp[-2].integer.value != yyvsp[0].integer.value
  15268. -                      || (yyval.integer.value & yyvsp[-2].integer.value & yyvsp[0].integer.value) < 0))
  15269. -                integer_overflow ();
  15270. -                } ;
  15271. -    break;}
  15272. -case 13:
  15273. -#line 231 "cexp.y"
  15274. -{ if (yyvsp[0].integer.value == 0)
  15275. -                {
  15276. -                  if (!skip_evaluation)
  15277. -                error ("division by zero in #if");
  15278. -                  yyvsp[0].integer.value = 1;
  15279. -                }
  15280. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp;
  15281. -              if (yyval.integer.unsignedp)
  15282. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value / yyvsp[0].integer.value;
  15283. -              else
  15284. -                {
  15285. -                  yyval.integer.value = yyvsp[-2].integer.value / yyvsp[0].integer.value;
  15286. -                  if ((yyval.integer.value & yyvsp[-2].integer.value & yyvsp[0].integer.value) < 0)
  15287. -                integer_overflow ();
  15288. -                } ;
  15289. -    break;}
  15290. -case 14:
  15291. -#line 247 "cexp.y"
  15292. -{ if (yyvsp[0].integer.value == 0)
  15293. -                {
  15294. -                  if (!skip_evaluation)
  15295. -                error ("division by zero in #if");
  15296. -                  yyvsp[0].integer.value = 1;
  15297. -                }
  15298. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp;
  15299. -              if (yyval.integer.unsignedp)
  15300. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value % yyvsp[0].integer.value;
  15301. -              else
  15302. -                yyval.integer.value = yyvsp[-2].integer.value % yyvsp[0].integer.value; ;
  15303. -    break;}
  15304. -case 15:
  15305. -#line 259 "cexp.y"
  15306. -{ yyval.integer.value = yyvsp[-2].integer.value + yyvsp[0].integer.value;
  15307. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp;
  15308. -              if (! yyval.integer.unsignedp
  15309. -                  && ! possible_sum_sign (yyvsp[-2].integer.value, yyvsp[0].integer.value,
  15310. -                              yyval.integer.value))
  15311. -                integer_overflow (); ;
  15312. -    break;}
  15313. -case 16:
  15314. -#line 266 "cexp.y"
  15315. -{ yyval.integer.value = yyvsp[-2].integer.value - yyvsp[0].integer.value;
  15316. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp;
  15317. -              if (! yyval.integer.unsignedp
  15318. -                  && ! possible_sum_sign (yyval.integer.value, yyvsp[0].integer.value,
  15319. -                              yyvsp[-2].integer.value))
  15320. -                integer_overflow (); ;
  15321. -    break;}
  15322. -case 17:
  15323. -#line 273 "cexp.y"
  15324. -{ yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp;
  15325. -              if (yyvsp[0].integer.value < 0 && ! yyvsp[0].integer.unsignedp)
  15326. -                yyval.integer.value = right_shift (&yyvsp[-2].integer, -yyvsp[0].integer.value);
  15327. -              else
  15328. -                yyval.integer.value = left_shift (&yyvsp[-2].integer, yyvsp[0].integer.value); ;
  15329. -    break;}
  15330. -case 18:
  15331. -#line 279 "cexp.y"
  15332. -{ yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp;
  15333. -              if (yyvsp[0].integer.value < 0 && ! yyvsp[0].integer.unsignedp)
  15334. -                yyval.integer.value = left_shift (&yyvsp[-2].integer, -yyvsp[0].integer.value);
  15335. -              else
  15336. -                yyval.integer.value = right_shift (&yyvsp[-2].integer, yyvsp[0].integer.value); ;
  15337. -    break;}
  15338. -case 19:
  15339. -#line 285 "cexp.y"
  15340. -{ yyval.integer.value = (yyvsp[-2].integer.value == yyvsp[0].integer.value);
  15341. -              yyval.integer.unsignedp = 0; ;
  15342. -    break;}
  15343. -case 20:
  15344. -#line 288 "cexp.y"
  15345. -{ yyval.integer.value = (yyvsp[-2].integer.value != yyvsp[0].integer.value);
  15346. -              yyval.integer.unsignedp = 0; ;
  15347. -    break;}
  15348. -case 21:
  15349. -#line 291 "cexp.y"
  15350. -{ yyval.integer.unsignedp = 0;
  15351. -              if (yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp)
  15352. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value <= yyvsp[0].integer.value;
  15353. -              else
  15354. -                yyval.integer.value = yyvsp[-2].integer.value <= yyvsp[0].integer.value; ;
  15355. -    break;}
  15356. -case 22:
  15357. -#line 297 "cexp.y"
  15358. -{ yyval.integer.unsignedp = 0;
  15359. -              if (yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp)
  15360. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value >= yyvsp[0].integer.value;
  15361. -              else
  15362. -                yyval.integer.value = yyvsp[-2].integer.value >= yyvsp[0].integer.value; ;
  15363. -    break;}
  15364. -case 23:
  15365. -#line 303 "cexp.y"
  15366. -{ yyval.integer.unsignedp = 0;
  15367. -              if (yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp)
  15368. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value < yyvsp[0].integer.value;
  15369. -              else
  15370. -                yyval.integer.value = yyvsp[-2].integer.value < yyvsp[0].integer.value; ;
  15371. -    break;}
  15372. -case 24:
  15373. -#line 309 "cexp.y"
  15374. -{ yyval.integer.unsignedp = 0;
  15375. -              if (yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp)
  15376. -                yyval.integer.value = (unsigned long) yyvsp[-2].integer.value > yyvsp[0].integer.value;
  15377. -              else
  15378. -                yyval.integer.value = yyvsp[-2].integer.value > yyvsp[0].integer.value; ;
  15379. -    break;}
  15380. -case 25:
  15381. -#line 315 "cexp.y"
  15382. -{ yyval.integer.value = yyvsp[-2].integer.value & yyvsp[0].integer.value;
  15383. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp; ;
  15384. -    break;}
  15385. -case 26:
  15386. -#line 318 "cexp.y"
  15387. -{ yyval.integer.value = yyvsp[-2].integer.value ^ yyvsp[0].integer.value;
  15388. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp; ;
  15389. -    break;}
  15390. -case 27:
  15391. -#line 321 "cexp.y"
  15392. -{ yyval.integer.value = yyvsp[-2].integer.value | yyvsp[0].integer.value;
  15393. -              yyval.integer.unsignedp = yyvsp[-2].integer.unsignedp || yyvsp[0].integer.unsignedp; ;
  15394. -    break;}
  15395. -case 28:
  15396. -#line 324 "cexp.y"
  15397. -{ skip_evaluation += !yyvsp[-1].integer.value; ;
  15398. -    break;}
  15399. -case 29:
  15400. -#line 326 "cexp.y"
  15401. -{ skip_evaluation -= !yyvsp[-3].integer.value;
  15402. -              yyval.integer.value = (yyvsp[-3].integer.value && yyvsp[0].integer.value);
  15403. -              yyval.integer.unsignedp = 0; ;
  15404. -    break;}
  15405. -case 30:
  15406. -#line 330 "cexp.y"
  15407. -{ skip_evaluation += !!yyvsp[-1].integer.value; ;
  15408. -    break;}
  15409. -case 31:
  15410. -#line 332 "cexp.y"
  15411. -{ skip_evaluation -= !!yyvsp[-3].integer.value;
  15412. -              yyval.integer.value = (yyvsp[-3].integer.value || yyvsp[0].integer.value);
  15413. -              yyval.integer.unsignedp = 0; ;
  15414. -    break;}
  15415. -case 32:
  15416. -#line 336 "cexp.y"
  15417. -{ skip_evaluation += !yyvsp[-1].integer.value; ;
  15418. -    break;}
  15419. -case 33:
  15420. -#line 338 "cexp.y"
  15421. -{ skip_evaluation += !!yyvsp[-4].integer.value - !yyvsp[-4].integer.value; ;
  15422. -    break;}
  15423. -case 34:
  15424. -#line 340 "cexp.y"
  15425. -{ skip_evaluation -= !!yyvsp[-6].integer.value;
  15426. -              yyval.integer.value = yyvsp[-6].integer.value ? yyvsp[-3].integer.value : yyvsp[0].integer.value;
  15427. -              yyval.integer.unsignedp = yyvsp[-3].integer.unsignedp || yyvsp[0].integer.unsignedp; ;
  15428. -    break;}
  15429. -case 35:
  15430. -#line 344 "cexp.y"
  15431. -{ yyval.integer = yylval.integer; ;
  15432. -    break;}
  15433. -case 36:
  15434. -#line 346 "cexp.y"
  15435. -{ yyval.integer = yylval.integer; ;
  15436. -    break;}
  15437. -case 37:
  15438. -#line 348 "cexp.y"
  15439. -{ yyval.integer.value = 0;
  15440. -              yyval.integer.unsignedp = 0; ;
  15441. -    break;}
  15442. -case 38:
  15443. -#line 353 "cexp.y"
  15444. -{ yyval.keywords = 0; ;
  15445. -    break;}
  15446. -case 39:
  15447. -#line 355 "cexp.y"
  15448. -{ struct arglist *temp;
  15449. -              yyval.keywords = (struct arglist *) xmalloc (sizeof (struct arglist));
  15450. -              yyval.keywords->next = yyvsp[-2].keywords;
  15451. -              yyval.keywords->name = (U_CHAR *) "(";
  15452. -              yyval.keywords->length = 1;
  15453. -              temp = yyval.keywords;
  15454. -              while (temp != 0 && temp->next != 0)
  15455. -                temp = temp->next;
  15456. -              temp->next = (struct arglist *) xmalloc (sizeof (struct arglist));
  15457. -              temp->next->next = yyvsp[0].keywords;
  15458. -              temp->next->name = (U_CHAR *) ")";
  15459. -              temp->next->length = 1; ;
  15460. -    break;}
  15461. -case 40:
  15462. -#line 368 "cexp.y"
  15463. -{ yyval.keywords = (struct arglist *) xmalloc (sizeof (struct arglist));
  15464. -              yyval.keywords->name = yyvsp[-1].name.address;
  15465. -              yyval.keywords->length = yyvsp[-1].name.length;
  15466. -              yyval.keywords->next = yyvsp[0].keywords; ;
  15467. -    break;}
  15468. -}
  15469. -   /* the action file gets copied in in place of this dollarsign */
  15470. -#line 480 "/usr/local/lib/bison.simple"
  15471. -
  15472. -  yyvsp -= yylen;
  15473. -  yyssp -= yylen;
  15474. -#ifdef YYLSP_NEEDED
  15475. -  yylsp -= yylen;
  15476. -#endif
  15477. -
  15478. -#if YYDEBUG != 0
  15479. -  if (yydebug)
  15480. -    {
  15481. -      short *ssp1 = yyss - 1;
  15482. -      fprintf (stderr, "state stack now");
  15483. -      while (ssp1 != yyssp)
  15484. -    fprintf (stderr, " %d", *++ssp1);
  15485. -      fprintf (stderr, "\n");
  15486. -    }
  15487. -#endif
  15488. -
  15489. -  *++yyvsp = yyval;
  15490. -
  15491. -#ifdef YYLSP_NEEDED
  15492. -  yylsp++;
  15493. -  if (yylen == 0)
  15494. -    {
  15495. -      yylsp->first_line = yylloc.first_line;
  15496. -      yylsp->first_column = yylloc.first_column;
  15497. -      yylsp->last_line = (yylsp-1)->last_line;
  15498. -      yylsp->last_column = (yylsp-1)->last_column;
  15499. -      yylsp->text = 0;
  15500. -    }
  15501. -  else
  15502. -    {
  15503. -      yylsp->last_line = (yylsp+yylen-1)->last_line;
  15504. -      yylsp->last_column = (yylsp+yylen-1)->last_column;
  15505. -    }
  15506. -#endif
  15507. -
  15508. -  /* Now "shift" the result of the reduction.
  15509. -     Determine what state that goes to,
  15510. -     based on the state we popped back to
  15511. -     and the rule number reduced by.  */
  15512. -
  15513. -  yyn = yyr1[yyn];
  15514. -
  15515. -  yystate = yypgoto[yyn - YYNTBASE] + *yyssp;
  15516. -  if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp)
  15517. -    yystate = yytable[yystate];
  15518. -  else
  15519. -    yystate = yydefgoto[yyn - YYNTBASE];
  15520. -
  15521. -  goto yynewstate;
  15522. -
  15523. -yyerrlab:   /* here on detecting error */
  15524. -
  15525. -  if (! yyerrstatus)
  15526. -    /* If not already recovering from an error, report this error.  */
  15527. -    {
  15528. -      ++yynerrs;
  15529. -
  15530. -#ifdef YYERROR_VERBOSE
  15531. -      yyn = yypact[yystate];
  15532. -
  15533. -      if (yyn > YYFLAG && yyn < YYLAST)
  15534. -    {
  15535. -      int size = 0;
  15536. -      char *msg;
  15537. -      int x, count;
  15538. -
  15539. -      count = 0;
  15540. -      /* Start X at -yyn if nec to avoid negative indexes in yycheck.  */
  15541. -      for (x = (yyn < 0 ? -yyn : 0);
  15542. -           x < (sizeof(yytname) / sizeof(char *)); x++)
  15543. -        if (yycheck[x + yyn] == x)
  15544. -          size += strlen(yytname[x]) + 15, count++;
  15545. -      msg = (char *) malloc(size + 15);
  15546. -      if (msg != 0)
  15547. -        {
  15548. -          strcpy(msg, "parse error");
  15549. -
  15550. -          if (count < 5)
  15551. -        {
  15552. -          count = 0;
  15553. -          for (x = (yyn < 0 ? -yyn : 0);
  15554. -               x < (sizeof(yytname) / sizeof(char *)); x++)
  15555. -            if (yycheck[x + yyn] == x)
  15556. -              {
  15557. -            strcat(msg, count == 0 ? ", expecting `" : " or `");
  15558. -            strcat(msg, yytname[x]);
  15559. -            strcat(msg, "'");
  15560. -            count++;
  15561. -              }
  15562. -        }
  15563. -          yyerror(msg);
  15564. -          free(msg);
  15565. -        }
  15566. -      else
  15567. -        yyerror ("parse error; also virtual memory exceeded");
  15568. -    }
  15569. -      else
  15570. -#endif /* YYERROR_VERBOSE */
  15571. -    yyerror("parse error");
  15572. -    }
  15573. -
  15574. -  goto yyerrlab1;
  15575. -yyerrlab1:   /* here on error raised explicitly by an action */
  15576. -
  15577. -  if (yyerrstatus == 3)
  15578. -    {
  15579. -      /* if just tried and failed to reuse lookahead token after an error, discard it.  */
  15580. -
  15581. -      /* return failure if at end of input */
  15582. -      if (yychar == YYEOF)
  15583. -    YYABORT;
  15584. -
  15585. -#if YYDEBUG != 0
  15586. -      if (yydebug)
  15587. -    fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]);
  15588. -#endif
  15589. -
  15590. -      yychar = YYEMPTY;
  15591. -    }
  15592. -
  15593. -  /* Else will try to reuse lookahead token
  15594. -     after shifting the error token.  */
  15595. -
  15596. -  yyerrstatus = 3;        /* Each real token shifted decrements this */
  15597. -
  15598. -  goto yyerrhandle;
  15599. -
  15600. -yyerrdefault:  /* current state does not do anything special for the error token. */
  15601. -
  15602. -#if 0
  15603. -  /* This is wrong; only states that explicitly want error tokens
  15604. -     should shift them.  */
  15605. -  yyn = yydefact[yystate];  /* If its default is to accept any token, ok.  Otherwise pop it.*/
  15606. -  if (yyn) goto yydefault;
  15607. -#endif
  15608. -
  15609. -yyerrpop:   /* pop the current state because it cannot handle the error token */
  15610. -
  15611. -  if (yyssp == yyss) YYABORT;
  15612. -  yyvsp--;
  15613. -  yystate = *--yyssp;
  15614. -#ifdef YYLSP_NEEDED
  15615. -  yylsp--;
  15616. -#endif
  15617. -
  15618. -#if YYDEBUG != 0
  15619. -  if (yydebug)
  15620. -    {
  15621. -      short *ssp1 = yyss - 1;
  15622. -      fprintf (stderr, "Error: state stack now");
  15623. -      while (ssp1 != yyssp)
  15624. -    fprintf (stderr, " %d", *++ssp1);
  15625. -      fprintf (stderr, "\n");
  15626. -    }
  15627. -#endif
  15628. -
  15629. -yyerrhandle:
  15630. -
  15631. -  yyn = yypact[yystate];
  15632. -  if (yyn == YYFLAG)
  15633. -    goto yyerrdefault;
  15634. -
  15635. -  yyn += YYTERROR;
  15636. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR)
  15637. -    goto yyerrdefault;
  15638. -
  15639. -  yyn = yytable[yyn];
  15640. -  if (yyn < 0)
  15641. -    {
  15642. -      if (yyn == YYFLAG)
  15643. -    goto yyerrpop;
  15644. -      yyn = -yyn;
  15645. -      goto yyreduce;
  15646. -    }
  15647. -  else if (yyn == 0)
  15648. -    goto yyerrpop;
  15649. -
  15650. -  if (yyn == YYFINAL)
  15651. -    YYACCEPT;
  15652. -
  15653. -#if YYDEBUG != 0
  15654. -  if (yydebug)
  15655. -    fprintf(stderr, "Shifting error token, ");
  15656. -#endif
  15657. -
  15658. -  *++yyvsp = yylval;
  15659. -#ifdef YYLSP_NEEDED
  15660. -  *++yylsp = yylloc;
  15661. -#endif
  15662. -
  15663. -  yystate = yyn;
  15664. -  goto yynewstate;
  15665. -}
  15666. -#line 373 "cexp.y"
  15667. -
  15668. -
  15669. -/* During parsing of a C expression, the pointer to the next character
  15670. -   is in this variable.  */
  15671. -
  15672. -static char *lexptr;
  15673. -
  15674. -/* Take care of parsing a number (anything that starts with a digit).
  15675. -   Set yylval and return the token type; update lexptr.
  15676. -   LEN is the number of characters in it.  */
  15677. -
  15678. -/* maybe needs to actually deal with floating point numbers */
  15679. -
  15680. -int
  15681. -parse_number (olen)
  15682. -     int olen;
  15683. -{
  15684. -  register char *p = lexptr;
  15685. -  register int c;
  15686. -  register unsigned long n = 0, nd, ULONG_MAX_over_base;
  15687. -  register int base = 10;
  15688. -  register int len = olen;
  15689. -  register int overflow = 0;
  15690. -  register int digit, largest_digit = 0;
  15691. -  int spec_long = 0;
  15692. -
  15693. -  for (c = 0; c < len; c++)
  15694. -    if (p[c] == '.') {
  15695. -      /* It's a float since it contains a point.  */
  15696. -      yyerror ("floating point numbers not allowed in #if expressions");
  15697. -      return ERROR;
  15698. -    }
  15699. -
  15700. -  yylval.integer.unsignedp = 0;
  15701. -
  15702. -  if (len >= 3 && (!strncmp (p, "0x", 2) || !strncmp (p, "0X", 2))) {
  15703. -    p += 2;
  15704. -    base = 16;
  15705. -    len -= 2;
  15706. -  }
  15707. -  else if (*p == '0')
  15708. -    base = 8;
  15709. -
  15710. -  ULONG_MAX_over_base = (unsigned long) -1 / base;
  15711. -
  15712. -  for (; len > 0; len--) {
  15713. -    c = *p++;
  15714. -
  15715. -    if (c >= '0' && c <= '9')
  15716. -      digit = c - '0';
  15717. -    else if (base == 16 && c >= 'a' && c <= 'f')
  15718. -      digit = c - 'a' + 10;
  15719. -    else if (base == 16 && c >= 'A' && c <= 'F')
  15720. -      digit = c - 'A' + 10;
  15721. -    else {
  15722. -      /* `l' means long, and `u' means unsigned.  */
  15723. -      while (1) {
  15724. -    if (c == 'l' || c == 'L')
  15725. -      {
  15726. -        if (spec_long)
  15727. -          yyerror ("two `l's in integer constant");
  15728. -        spec_long = 1;
  15729. -      }
  15730. -    else if (c == 'u' || c == 'U')
  15731. -      {
  15732. -        if (yylval.integer.unsignedp)
  15733. -          yyerror ("two `u's in integer constant");
  15734. -        yylval.integer.unsignedp = 1;
  15735. -      }
  15736. -    else
  15737. -      break;
  15738. -
  15739. -    if (--len == 0)
  15740. -      break;
  15741. -    c = *p++;
  15742. -      }
  15743. -      /* Don't look for any more digits after the suffixes.  */
  15744. -      break;
  15745. -    }
  15746. -    if (largest_digit < digit)
  15747. -      largest_digit = digit;
  15748. -    nd = n * base + digit;
  15749. -    overflow |= ULONG_MAX_over_base < n | nd < n;
  15750. -    n = nd;
  15751. -  }
  15752. -
  15753. -  if (len != 0) {
  15754. -    yyerror ("Invalid number in #if expression");
  15755. -    return ERROR;
  15756. -  }
  15757. -
  15758. -  if (base <= largest_digit)
  15759. -    warning ("integer constant contains digits beyond the radix");
  15760. -
  15761. -  if (overflow)
  15762. -    warning ("integer constant out of range");
  15763. -
  15764. -  /* If too big to be signed, consider it unsigned.  */
  15765. -  if ((long) n < 0 && ! yylval.integer.unsignedp)
  15766. -    {
  15767. -      if (base == 10)
  15768. -    warning ("integer constant is so large that it is unsigned");
  15769. -      yylval.integer.unsignedp = 1;
  15770. -    }
  15771. -
  15772. -  lexptr = p;
  15773. -  yylval.integer.value = n;
  15774. -  return INT;
  15775. -}
  15776. -
  15777. -struct token {
  15778. -  char *operator;
  15779. -  int token;
  15780. -};
  15781. -
  15782. -static struct token tokentab2[] = {
  15783. -  {"&&", AND},
  15784. -  {"||", OR},
  15785. -  {"<<", LSH},
  15786. -  {">>", RSH},
  15787. -  {"==", EQUAL},
  15788. -  {"!=", NOTEQUAL},
  15789. -  {"<=", LEQ},
  15790. -  {">=", GEQ},
  15791. -  {"++", ERROR},
  15792. -  {"--", ERROR},
  15793. -  {NULL, ERROR}
  15794. -};
  15795. -
  15796. -/* Read one token, getting characters through lexptr.  */
  15797. -
  15798. -int
  15799. -yylex ()
  15800. -{
  15801. -  register int c;
  15802. -  register int namelen;
  15803. -  register unsigned char *tokstart;
  15804. -  register struct token *toktab;
  15805. -  int wide_flag;
  15806. -
  15807. - retry:
  15808. -
  15809. -  tokstart = (unsigned char *) lexptr;
  15810. -  c = *tokstart;
  15811. -  /* See if it is a special token of length 2.  */
  15812. -  if (! keyword_parsing)
  15813. -    for (toktab = tokentab2; toktab->operator != NULL; toktab++)
  15814. -      if (c == *toktab->operator && tokstart[1] == toktab->operator[1]) {
  15815. -    lexptr += 2;
  15816. -    if (toktab->token == ERROR)
  15817. -      {
  15818. -        char *buf = (char *) alloca (40);
  15819. -        sprintf (buf, "`%s' not allowed in operand of `#if'", toktab->operator);
  15820. -        yyerror (buf);
  15821. -      }
  15822. -    return toktab->token;
  15823. -      }
  15824. -
  15825. -  switch (c) {
  15826. -  case 0:
  15827. -    return 0;
  15828. -    
  15829. -  case ' ':
  15830. -  case '\t':
  15831. -  case '\r':
  15832. -  case '\n':
  15833. -    lexptr++;
  15834. -    goto retry;
  15835. -    
  15836. -  case 'L':
  15837. -    /* Capital L may start a wide-string or wide-character constant.  */
  15838. -    if (lexptr[1] == '\'')
  15839. -      {
  15840. -    lexptr++;
  15841. -    wide_flag = 1;
  15842. -    goto char_constant;
  15843. -      }
  15844. -    if (lexptr[1] == '"')
  15845. -      {
  15846. -    lexptr++;
  15847. -    wide_flag = 1;
  15848. -    goto string_constant;
  15849. -      }
  15850. -    break;
  15851. -
  15852. -  case '\'':
  15853. -    wide_flag = 0;
  15854. -  char_constant:
  15855. -    lexptr++;
  15856. -    if (keyword_parsing) {
  15857. -      char *start_ptr = lexptr - 1;
  15858. -      while (1) {
  15859. -    c = *lexptr++;
  15860. -    if (c == '\\')
  15861. -      c = parse_escape (&lexptr);
  15862. -    else if (c == '\'')
  15863. -      break;
  15864. -      }
  15865. -      yylval.name.address = tokstart;
  15866. -      yylval.name.length = lexptr - start_ptr;
  15867. -      return NAME;
  15868. -    }
  15869. -
  15870. -    /* This code for reading a character constant
  15871. -       handles multicharacter constants and wide characters.
  15872. -       It is mostly copied from c-lex.c.  */
  15873. -    {
  15874. -      register int result = 0;
  15875. -      register num_chars = 0;
  15876. -      unsigned width = MAX_CHAR_TYPE_SIZE;
  15877. -      int max_chars;
  15878. -      char *token_buffer;
  15879. -
  15880. -      if (wide_flag)
  15881. -    {
  15882. -      width = MAX_WCHAR_TYPE_SIZE;
  15883. -#ifdef MULTIBYTE_CHARS
  15884. -      max_chars = MB_CUR_MAX;
  15885. -#else
  15886. -      max_chars = 1;
  15887. -#endif
  15888. -    }
  15889. -      else
  15890. -    max_chars = MAX_LONG_TYPE_SIZE / width;
  15891. -
  15892. -      token_buffer = (char *) alloca (max_chars + 1);
  15893. -
  15894. -      while (1)
  15895. -    {
  15896. -      c = *lexptr++;
  15897. -
  15898. -      if (c == '\'' || c == EOF)
  15899. -        break;
  15900. -
  15901. -      if (c == '\\')
  15902. -        {
  15903. -          c = parse_escape (&lexptr);
  15904. -          if (width < HOST_BITS_PER_INT
  15905. -          && (unsigned) c >= (1 << width))
  15906. -        pedwarn ("escape sequence out of range for character");
  15907. -        }
  15908. -
  15909. -      num_chars++;
  15910. -
  15911. -      /* Merge character into result; ignore excess chars.  */
  15912. -      if (num_chars < max_chars + 1)
  15913. -        {
  15914. -          if (width < HOST_BITS_PER_INT)
  15915. -        result = (result << width) | (c & ((1 << width) - 1));
  15916. -          else
  15917. -        result = c;
  15918. -          token_buffer[num_chars - 1] = c;
  15919. -        }
  15920. -    }
  15921. -
  15922. -      token_buffer[num_chars] = 0;
  15923. -
  15924. -      if (c != '\'')
  15925. -    error ("malformatted character constant");
  15926. -      else if (num_chars == 0)
  15927. -    error ("empty character constant");
  15928. -      else if (num_chars > max_chars)
  15929. -    {
  15930. -      num_chars = max_chars;
  15931. -      error ("character constant too long");
  15932. -    }
  15933. -      else if (num_chars != 1 && ! traditional)
  15934. -    warning ("multi-character character constant");
  15935. -
  15936. -      /* If char type is signed, sign-extend the constant.  */
  15937. -      if (! wide_flag)
  15938. -    {
  15939. -      int num_bits = num_chars * width;
  15940. -
  15941. -      if (lookup ("__CHAR_UNSIGNED__", sizeof ("__CHAR_UNSIGNED__")-1, -1)
  15942. -          || ((result >> (num_bits - 1)) & 1) == 0)
  15943. -        yylval.integer.value
  15944. -          = result & ((unsigned long) ~0 >> (HOST_BITS_PER_LONG - num_bits));
  15945. -      else
  15946. -        yylval.integer.value
  15947. -          = result | ~((unsigned long) ~0 >> (HOST_BITS_PER_LONG - num_bits));
  15948. -    }
  15949. -      else
  15950. -    {
  15951. -#ifdef MULTIBYTE_CHARS
  15952. -      /* Set the initial shift state and convert the next sequence.  */
  15953. -      result = 0;
  15954. -      /* In all locales L'\0' is zero and mbtowc will return zero,
  15955. -         so don't use it.  */
  15956. -      if (num_chars > 1
  15957. -          || (num_chars == 1 && token_buffer[0] != '\0'))
  15958. -        {
  15959. -          wchar_t wc;
  15960. -          (void) mbtowc (NULL_PTR, NULL_PTR, 0);
  15961. -          if (mbtowc (& wc, token_buffer, num_chars) == num_chars)
  15962. -        result = wc;
  15963. -          else
  15964. -        warning ("Ignoring invalid multibyte character");
  15965. -        }
  15966. -#endif
  15967. -      yylval.integer.value = result;
  15968. -    }
  15969. -    }
  15970. -
  15971. -    /* This is always a signed type.  */
  15972. -    yylval.integer.unsignedp = 0;
  15973. -    
  15974. -    return CHAR;
  15975. -
  15976. -    /* some of these chars are invalid in constant expressions;
  15977. -       maybe do something about them later */
  15978. -  case '/':
  15979. -  case '+':
  15980. -  case '-':
  15981. -  case '*':
  15982. -  case '%':
  15983. -  case '|':
  15984. -  case '&':
  15985. -  case '^':
  15986. -  case '~':
  15987. -  case '!':
  15988. -  case '@':
  15989. -  case '<':
  15990. -  case '>':
  15991. -  case '[':
  15992. -  case ']':
  15993. -  case '.':
  15994. -  case '?':
  15995. -  case ':':
  15996. -  case '=':
  15997. -  case '{':
  15998. -  case '}':
  15999. -  case ',':
  16000. -  case '#':
  16001. -    if (keyword_parsing)
  16002. -      break;
  16003. -  case '(':
  16004. -  case ')':
  16005. -    lexptr++;
  16006. -    return c;
  16007. -
  16008. -  case '"':
  16009. -  string_constant:
  16010. -    if (keyword_parsing) {
  16011. -      char *start_ptr = lexptr;
  16012. -      lexptr++;
  16013. -      while (1) {
  16014. -    c = *lexptr++;
  16015. -    if (c == '\\')
  16016. -      c = parse_escape (&lexptr);
  16017. -    else if (c == '"')
  16018. -      break;
  16019. -      }
  16020. -      yylval.name.address = tokstart;
  16021. -      yylval.name.length = lexptr - start_ptr;
  16022. -      return NAME;
  16023. -    }
  16024. -    yyerror ("string constants not allowed in #if expressions");
  16025. -    return ERROR;
  16026. -  }
  16027. -
  16028. -  if (c >= '0' && c <= '9' && !keyword_parsing) {
  16029. -    /* It's a number */
  16030. -    for (namelen = 0;
  16031. -     c = tokstart[namelen], is_idchar[c] || c == '.'; 
  16032. -     namelen++)
  16033. -      ;
  16034. -    return parse_number (namelen);
  16035. -  }
  16036. -
  16037. -  /* It is a name.  See how long it is.  */
  16038. -
  16039. -  if (keyword_parsing) {
  16040. -    for (namelen = 0;; namelen++) {
  16041. -      if (is_hor_space[tokstart[namelen]])
  16042. -    break;
  16043. -      if (tokstart[namelen] == '(' || tokstart[namelen] == ')')
  16044. -    break;
  16045. -      if (tokstart[namelen] == '"' || tokstart[namelen] == '\'')
  16046. -    break;
  16047. -    }
  16048. -  } else {
  16049. -    if (!is_idstart[c]) {
  16050. -      yyerror ("Invalid token in expression");
  16051. -      return ERROR;
  16052. -    }
  16053. -
  16054. -    for (namelen = 0; is_idchar[tokstart[namelen]]; namelen++)
  16055. -      ;
  16056. -  }
  16057. -  
  16058. -  lexptr += namelen;
  16059. -  yylval.name.address = tokstart;
  16060. -  yylval.name.length = namelen;
  16061. -  return NAME;
  16062. -}
  16063. -
  16064. -
  16065. -/* Parse a C escape sequence.  STRING_PTR points to a variable
  16066. -   containing a pointer to the string to parse.  That pointer
  16067. -   is updated past the characters we use.  The value of the
  16068. -   escape sequence is returned.
  16069. -
  16070. -   A negative value means the sequence \ newline was seen,
  16071. -   which is supposed to be equivalent to nothing at all.
  16072. -
  16073. -   If \ is followed by a null character, we return a negative
  16074. -   value and leave the string pointer pointing at the null character.
  16075. -
  16076. -   If \ is followed by 000, we return 0 and leave the string pointer
  16077. -   after the zeros.  A value of 0 does not mean end of string.  */
  16078. -
  16079. -int
  16080. -parse_escape (string_ptr)
  16081. -     char **string_ptr;
  16082. -{
  16083. -  register int c = *(*string_ptr)++;
  16084. -  switch (c)
  16085. -    {
  16086. -    case 'a':
  16087. -      return TARGET_BELL;
  16088. -    case 'b':
  16089. -      return TARGET_BS;
  16090. -    case 'e':
  16091. -    case 'E':
  16092. -      if (pedantic)
  16093. -    pedwarn ("non-ANSI-standard escape sequence, `\\%c'", c);
  16094. -      return 033;
  16095. -    case 'f':
  16096. -      return TARGET_FF;
  16097. -    case 'n':
  16098. -      return TARGET_NEWLINE;
  16099. -    case 'r':
  16100. -      return TARGET_CR;
  16101. -    case 't':
  16102. -      return TARGET_TAB;
  16103. -    case 'v':
  16104. -      return TARGET_VT;
  16105. -    case '\n':
  16106. -      return -2;
  16107. -    case 0:
  16108. -      (*string_ptr)--;
  16109. -      return 0;
  16110. -      
  16111. -    case '0':
  16112. -    case '1':
  16113. -    case '2':
  16114. -    case '3':
  16115. -    case '4':
  16116. -    case '5':
  16117. -    case '6':
  16118. -    case '7':
  16119. -      {
  16120. -    register int i = c - '0';
  16121. -    register int count = 0;
  16122. -    while (++count < 3)
  16123. -      {
  16124. -        c = *(*string_ptr)++;
  16125. -        if (c >= '0' && c <= '7')
  16126. -          i = (i << 3) + c - '0';
  16127. -        else
  16128. -          {
  16129. -        (*string_ptr)--;
  16130. -        break;
  16131. -          }
  16132. -      }
  16133. -    if ((i & ~((1 << MAX_CHAR_TYPE_SIZE) - 1)) != 0)
  16134. -      {
  16135. -        i &= (1 << MAX_CHAR_TYPE_SIZE) - 1;
  16136. -        warning ("octal character constant does not fit in a byte");
  16137. -      }
  16138. -    return i;
  16139. -      }
  16140. -    case 'x':
  16141. -      {
  16142. -    register unsigned i = 0, overflow = 0, digits_found = 0, digit;
  16143. -    for (;;)
  16144. -      {
  16145. -        c = *(*string_ptr)++;
  16146. -        if (c >= '0' && c <= '9')
  16147. -          digit = c - '0';
  16148. -        else if (c >= 'a' && c <= 'f')
  16149. -          digit = c - 'a' + 10;
  16150. -        else if (c >= 'A' && c <= 'F')
  16151. -          digit = c - 'A' + 10;
  16152. -        else
  16153. -          {
  16154. -        (*string_ptr)--;
  16155. -        break;
  16156. -          }
  16157. -        overflow |= i ^ (i << 4 >> 4);
  16158. -        i = (i << 4) + digit;
  16159. -        digits_found = 1;
  16160. -      }
  16161. -    if (!digits_found)
  16162. -      yyerror ("\\x used with no following hex digits");
  16163. -    if (overflow | (i & ~((1 << BITS_PER_UNIT) - 1)))
  16164. -      {
  16165. -        i &= (1 << BITS_PER_UNIT) - 1;
  16166. -        warning ("hex character constant does not fit in a byte");
  16167. -      }
  16168. -    return i;
  16169. -      }
  16170. -    default:
  16171. -      return c;
  16172. -    }
  16173. -}
  16174. -
  16175. -void
  16176. -yyerror (s)
  16177. -     char *s;
  16178. -{
  16179. -  error (s);
  16180. -  skip_evaluation = 0;
  16181. -  longjmp (parse_return_error, 1);
  16182. -}
  16183. -
  16184. -static void
  16185. -integer_overflow ()
  16186. -{
  16187. -  if (!skip_evaluation && pedantic)
  16188. -    pedwarn ("integer overflow in preprocessor expression");
  16189. -}
  16190. -
  16191. -static long
  16192. -left_shift (a, b)
  16193. -     struct constant *a;
  16194. -     unsigned long b;
  16195. -{
  16196. -   /* It's unclear from the C standard whether shifts can overflow.
  16197. -      The following code ignores overflow; perhaps a C standard
  16198. -      interpretation ruling is needed.  */
  16199. -  if (b >= HOST_BITS_PER_LONG)
  16200. -    return 0;
  16201. -  else if (a->unsignedp)
  16202. -    return (unsigned long) a->value << b;
  16203. -  else
  16204. -    return a->value << b;
  16205. -}
  16206. -
  16207. -static long
  16208. -right_shift (a, b)
  16209. -     struct constant *a;
  16210. -     unsigned long b;
  16211. -{
  16212. -  if (b >= HOST_BITS_PER_LONG)
  16213. -    return a->unsignedp ? 0 : a->value >> (HOST_BITS_PER_LONG - 1);
  16214. -  else if (a->unsignedp)
  16215. -    return (unsigned long) a->value >> b;
  16216. -  else
  16217. -    return a->value >> b;
  16218. -}
  16219. -
  16220. -/* This page contains the entry point to this file.  */
  16221. -
  16222. -/* Parse STRING as an expression, and complain if this fails
  16223. -   to use up all of the contents of STRING.  */
  16224. -/* We do not support C comments.  They should be removed before
  16225. -   this function is called.  */
  16226. -
  16227. -HOST_WIDE_INT
  16228. -parse_c_expression (string)
  16229. -     char *string;
  16230. -{
  16231. -  lexptr = string;
  16232. -  
  16233. -  if (lexptr == 0 || *lexptr == 0) {
  16234. -    error ("empty #if expression");
  16235. -    return 0;            /* don't include the #if group */
  16236. -  }
  16237. -
  16238. -  /* if there is some sort of scanning error, just return 0 and assume
  16239. -     the parsing routine has printed an error message somewhere.
  16240. -     there is surely a better thing to do than this.     */
  16241. -  if (setjmp (parse_return_error))
  16242. -    return 0;
  16243. -
  16244. -  if (yyparse ())
  16245. -    return 0;            /* actually this is never reached
  16246. -                   the way things stand. */
  16247. -  if (*lexptr)
  16248. -    error ("Junk after end of expression.");
  16249. -
  16250. -  return expression_value;    /* set by yyparse () */
  16251. -}
  16252. -
  16253. -#ifdef TEST_EXP_READER
  16254. -extern int yydebug;
  16255. -
  16256. -/* Main program for testing purposes.  */
  16257. -int
  16258. -main ()
  16259. -{
  16260. -  int n, c;
  16261. -  char buf[1024];
  16262. -
  16263. -/*
  16264. -  yydebug = 1;
  16265. -*/
  16266. -  initialize_random_junk ();
  16267. -
  16268. -  for (;;) {
  16269. -    printf ("enter expression: ");
  16270. -    n = 0;
  16271. -    while ((buf[n] = getchar ()) != '\n' && buf[n] != EOF)
  16272. -      n++;
  16273. -    if (buf[n] == EOF)
  16274. -      break;
  16275. -    buf[n] = '\0';
  16276. -    printf ("parser returned %ld\n", parse_c_expression (buf));
  16277. -  }
  16278. -
  16279. -  return 0;
  16280. -}
  16281. -
  16282. -/* table to tell if char can be part of a C identifier. */
  16283. -unsigned char is_idchar[256];
  16284. -/* table to tell if char can be first char of a c identifier. */
  16285. -unsigned char is_idstart[256];
  16286. -/* table to tell if c is horizontal space.  isspace () thinks that
  16287. -   newline is space; this is not a good idea for this program. */
  16288. -char is_hor_space[256];
  16289. -
  16290. -/*
  16291. - * initialize random junk in the hash table and maybe other places
  16292. - */
  16293. -initialize_random_junk ()
  16294. -{
  16295. -  register int i;
  16296. -
  16297. -  /*
  16298. -   * Set up is_idchar and is_idstart tables.  These should be
  16299. -   * faster than saying (is_alpha (c) || c == '_'), etc.
  16300. -   * Must do set up these things before calling any routines tthat
  16301. -   * refer to them.
  16302. -   */
  16303. -  for (i = 'a'; i <= 'z'; i++) {
  16304. -    ++is_idchar[i - 'a' + 'A'];
  16305. -    ++is_idchar[i];
  16306. -    ++is_idstart[i - 'a' + 'A'];
  16307. -    ++is_idstart[i];
  16308. -  }
  16309. -  for (i = '0'; i <= '9'; i++)
  16310. -    ++is_idchar[i];
  16311. -  ++is_idchar['_'];
  16312. -  ++is_idstart['_'];
  16313. -#if DOLLARS_IN_IDENTIFIERS
  16314. -  ++is_idchar['$'];
  16315. -  ++is_idstart['$'];
  16316. -#endif
  16317. -
  16318. -  /* horizontal space table */
  16319. -  ++is_hor_space[' '];
  16320. -  ++is_hor_space['\t'];
  16321. -}
  16322. -
  16323. -error (msg)
  16324. -{
  16325. -  printf ("error: %s\n", msg);
  16326. -}
  16327. -
  16328. -warning (msg)
  16329. -{
  16330. -  printf ("warning: %s\n", msg);
  16331. -}
  16332. -
  16333. -struct hashnode *
  16334. -lookup (name, len, hash)
  16335. -     char *name;
  16336. -     int len;
  16337. -     int hash;
  16338. -{
  16339. -  return (DEFAULT_SIGNED_CHAR) ? 0 : ((struct hashnode *) -1);
  16340. -}
  16341. -#endif
  16342. diff -rup --new-file baseline/fsf/gcc/config/m68k/amigaos.c amiga/fsf/gcc/config/m68k/amigaos.c
  16343. --- baseline/fsf/gcc/config/m68k/amigaos.c    Wed Dec 31 17:00:00 1969
  16344. +++ amiga/fsf/gcc/config/m68k/amigaos.c    Tue Oct  1 08:42:25 1996
  16345. @@ -0,0 +1,448 @@
  16346. +/* Definitions of target machine for GNU compiler.  amiga 68000/68020 version.
  16347. +   Copyright (C) 1992 Free Software Foundation, Inc.
  16348. +   Contributed by Markus M. Wild (wild@amiga.physik.unizh.ch).
  16349. +
  16350. +This file is part of GNU CC.
  16351. +
  16352. +GNU CC is free software; you can redistribute it and/or modify
  16353. +it under the terms of the GNU General Public License as published by
  16354. +the Free Software Foundation; either version 2, or (at your option)
  16355. +any later version.
  16356. +
  16357. +GNU CC is distributed in the hope that it will be useful,
  16358. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  16359. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16360. +GNU General Public License for more details.
  16361. +
  16362. +You should have received a copy of the GNU General Public License
  16363. +along with GNU CC; see the file COPYING.  If not, write to
  16364. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  16365. +
  16366. +#include "tree.h"
  16367. +#include "c-tree.h"
  16368. +#include "m68k/m68k.c"
  16369. +
  16370. +/* Does operand (which is a symbolic_operand) live in text space? If
  16371. +   so SYMBOL_REF_FLAG, which is set by ENCODE_SECTION_INFO, will be true.
  16372. +
  16373. +   This function is used in base relative code generation. */
  16374. +
  16375. +int
  16376. +read_only_operand (operand)
  16377. +     rtx operand;
  16378. +{
  16379. +  if (GET_CODE (operand) == CONST)
  16380. +    operand = XEXP (XEXP (operand, 0), 0);
  16381. +  if (GET_CODE (operand) == SYMBOL_REF)
  16382. +    return SYMBOL_REF_FLAG (operand) || CONSTANT_POOL_ADDRESS_P (operand);
  16383. +  return 1;
  16384. +}
  16385. +
  16386. + /*
  16387. + * Support for Amiga-specific variable and function attributes.
  16388. + * KI 15.02.96
  16389. + */
  16390. +
  16391. +#define AMIGA_CHIP_SECTION_NAME ".datachip"
  16392. +
  16393. +/* Return nonzero if IDENTIFIER with arguments ARGS is a valid machine
  16394. +   specific attribute for DECL.  The attributes in ATTRIBUTES have previously
  16395. +   been assigned to DECL. */
  16396. +
  16397. +int
  16398. +valid_amigaos_decl_attribute(tree decl, tree attributes, tree identifier,
  16399. +                 tree args)
  16400. +{
  16401. +  if (is_attribute_p("chip", identifier))
  16402. +#ifdef ASM_OUTPUT_SECTION_NAME
  16403. +    {
  16404. +      if (TREE_CODE(decl)==VAR_DECL)
  16405. +    {
  16406. +      if (!TREE_STATIC(decl) && !DECL_EXTERNAL(decl))
  16407. +        error("`chip' attribute cannot be specified for local variables");
  16408. +      else
  16409. +        {
  16410. +          /* The decl may have already been given a section attribute from
  16411. +         a previous declaration.  Ensure they match.  */
  16412. +          if (DECL_SECTION_NAME (decl) == NULL_TREE)
  16413. +        {
  16414. +          DECL_SECTION_NAME (decl) =
  16415. +            build_string(strlen(AMIGA_CHIP_SECTION_NAME)+1,
  16416. +              AMIGA_CHIP_SECTION_NAME);
  16417. +          TREE_TYPE(DECL_SECTION_NAME (decl)) = string_type_node;
  16418. +        }
  16419. +          else if (strcmp (TREE_STRING_POINTER (DECL_SECTION_NAME (decl)),
  16420. +                   AMIGA_CHIP_SECTION_NAME) != 0)
  16421. +        error_with_decl (decl,
  16422. +          "`chip' for `%s' conflicts with previous declaration");
  16423. +          if (args!=NULL_TREE)
  16424. +        warning("superfluous arguments to `chip' attribute ignored");
  16425. +          return 1;
  16426. +        }
  16427. +    }
  16428. +      else
  16429. +    error_with_decl (decl, "`chip' attribute not allowed for `%s'");
  16430. +    }
  16431. +#else
  16432. +    error("`chip' attribute is not supported for this target");
  16433. +#endif
  16434. +
  16435. +  return 0;
  16436. +}
  16437. +
  16438. +/* Return nonzero if IDENTIFIER with arguments ARGS is a valid machine
  16439. +   specific attribute for TYPE.  The attributes in ATTRIBUTES have previously
  16440. +   been assigned to TYPE. */
  16441. +
  16442. +int
  16443. +valid_amigaos_type_attribute(tree type, tree attributes, tree identifier,
  16444. +                 tree args)
  16445. +{
  16446. +  if (is_attribute_p("interrupt", identifier)
  16447. +      || is_attribute_p("saveds", identifier)
  16448. +      || is_attribute_p("stackext", identifier)
  16449. +      || is_attribute_p("stkparm", identifier)
  16450. +      || is_attribute_p("regparm", identifier))
  16451. +    {
  16452. +      if (TREE_CODE(type)==FUNCTION_TYPE || TREE_CODE(type)==METHOD_TYPE)
  16453. +    {
  16454. +      /* "regparm" accepts one optional argument - number of registers in
  16455. +         single class that should be used to pass arguments. */
  16456. +      if (is_attribute_p("regparm", identifier))
  16457. +        {
  16458. +          if (lookup_attribute("stkparm", attributes))
  16459. +        error("`regparm' and `stkparm' are mutually exclusive");
  16460. +          if (args && TREE_CODE(args)==TREE_LIST)
  16461. +        {
  16462. +          tree numofregs=TREE_VALUE(args);
  16463. +          if (numofregs)
  16464. +            {
  16465. +              if (TREE_CODE(numofregs)!=INTEGER_CST
  16466. +              || TREE_INT_CST_HIGH(numofregs)
  16467. +              || TREE_INT_CST_LOW(numofregs)<1
  16468. +              || TREE_INT_CST_LOW(numofregs)>4)
  16469. +            error("invalid argument to `regparm' attribute");
  16470. +              /* Will cause warning if user provided us with more
  16471. +             arguments. */
  16472. +              args=TREE_CHAIN(args);
  16473. +            }
  16474. +        }
  16475. +        }
  16476. +      if (is_attribute_p("stkparm", identifier)
  16477. +          && lookup_attribute("regparm", attributes))
  16478. +        error("`regparm' and `stkparm' are mutually exclusive");
  16479. +      if ((is_attribute_p("stackext", identifier)
  16480. +        && lookup_attribute("interrupt", attributes))
  16481. +          || (is_attribute_p("interrupt", identifier)
  16482. +        && lookup_attribute("stackext", attributes)))
  16483. +        error("`stackext' and `interrupt' are mutually exclusive");
  16484. +      if (args!=NULL_TREE)
  16485. +        warning("superfluous arguments to `%s' attribute ignored",
  16486. +          IDENTIFIER_POINTER(identifier));
  16487. +      return 1;
  16488. +    }
  16489. +    /* Don't treat it as error if this is a pointer to function - in such
  16490. +       a case this function will be called again with inner function type.
  16491. +     */
  16492. +      else if (TREE_CODE(type)!=POINTER_TYPE
  16493. +      || TREE_CODE(TREE_TYPE(type))!=FUNCTION_TYPE)
  16494. +    error("`%s' attribute used in wrong context",
  16495. +      IDENTIFIER_POINTER(identifier));
  16496. +    }
  16497. +
  16498. +  return 0;
  16499. +}
  16500. +
  16501. +/* Return zero if the attributes on TYPE1 and TYPE2 are incompatible,
  16502. +   one if they are compatible, and two if they are nearly compatible
  16503. +   (which causes a warning to be generated). */
  16504. +
  16505. +int
  16506. +comp_amigaos_type_attributes(tree type1, tree type2)
  16507. +{
  16508. +  /* Functions or methods are incompatible if they specify mutually exclusive
  16509. +     ways of passing arguments. */
  16510. +  if (TREE_CODE(type1)==FUNCTION_TYPE || TREE_CODE(type1)==METHOD_TYPE)
  16511. +    {
  16512. +      tree arg1, arg2;
  16513. +      arg1=TYPE_ARG_TYPES(type1);
  16514. +      arg2=TYPE_ARG_TYPES(type2);
  16515. +      for (; arg1 && arg2; arg1=TREE_CHAIN(arg1), arg2=TREE_CHAIN(arg2))
  16516. +    if (TREE_VALUE(arg1) && TREE_VALUE(arg2))
  16517. +      {
  16518. +        tree asm1, asm2;
  16519. +        asm1=lookup_attribute("asm", TYPE_ATTRIBUTES(TREE_VALUE(arg1)));
  16520. +        asm2=lookup_attribute("asm", TYPE_ATTRIBUTES(TREE_VALUE(arg2)));
  16521. +        if (asm1 && asm2)
  16522. +          {
  16523. +        if (TREE_INT_CST_LOW(TREE_VALUE(asm1))!=
  16524. +            TREE_INT_CST_LOW(TREE_VALUE(asm2)))
  16525. +        return 0; /* Two different registers specified. */
  16526. +          }
  16527. +        else
  16528. +          if (asm1 || asm2)
  16529. +        return 0; /* "asm" used in only one type. */
  16530. +      }
  16531. +      if ((lookup_attribute("stkparm", TYPE_ATTRIBUTES(type1)) ? 1 : 0)!=
  16532. +        (lookup_attribute("stkparm", TYPE_ATTRIBUTES(type2)) ? 1 : 0)
  16533. +      || (lookup_attribute("regparm", TYPE_ATTRIBUTES(type1)) ? 1 : 0)!=
  16534. +        (lookup_attribute("regparm", TYPE_ATTRIBUTES(type2)) ? 1 : 0))
  16535. +    return 0; /* "stkparm" and "regparm" are mutually exclusive. */
  16536. +      if ((arg1=lookup_attribute("regparm", TYPE_ATTRIBUTES(type1)))
  16537. +      && (arg2=lookup_attribute("regparm", TYPE_ATTRIBUTES(type2))))
  16538. +    {
  16539. +      int num1=-1, num2=-1;
  16540. +      if (TREE_VALUE(arg1) && TREE_CODE(TREE_VALUE(arg1))==TREE_LIST)
  16541. +        {
  16542. +          tree numofregs=TREE_VALUE(TREE_VALUE(arg1));
  16543. +          if (numofregs)
  16544. +        num1=TREE_INT_CST_LOW(numofregs);
  16545. +        }
  16546. +      if (TREE_VALUE(arg2) && TREE_CODE(TREE_VALUE(arg2))==TREE_LIST)
  16547. +        {
  16548. +          tree numofregs=TREE_VALUE(TREE_VALUE(arg2));
  16549. +          if (numofregs)
  16550. +        num2=TREE_INT_CST_LOW(numofregs);
  16551. +        }
  16552. +      if (num1!=num2)
  16553. +        return 0; /* Different numbers, or no number in one type. */
  16554. +    }
  16555. +    }
  16556. +  return 1;
  16557. +}
  16558. +
  16559. +/* Common routine used to check if "a4" should be preserved/restored.  */
  16560. +
  16561. +int
  16562. +amigaos_restore_a4(void)
  16563. +{
  16564. +  return (flag_pic>=3 && (TARGET_RESTORE_A4 || TARGET_ALWAYS_RESTORE_A4
  16565. +        || lookup_attribute("saveds",
  16566. +         TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl)))));
  16567. +}
  16568. +
  16569. +/* Don't output epilogue as RTL if preserving "a4".  */
  16570. +
  16571. +int
  16572. +amigaos_use_return_insn(void)
  16573. +{
  16574. +  return (use_return_insn() && !amigaos_restore_a4());
  16575. +}
  16576. +
  16577. + /*
  16578. +Stack checking and auto-extend
  16579. +
  16580. +This is my first attempt to implement stack extension with gcc.
  16581. +If you think some things should be changed please write
  16582. +to me immediately (fleischr@izfm.uni-stuttgart.de, or even better
  16583. +to amiga-gcc-port@lists.funet.fi for discussion).
  16584. +
  16585. +If you don't want to recompile gcc (to check it out) you can still
  16586. +test the example supported (bigtest.c) or read the documentation.
  16587. +Simply do a 'make' to build it.
  16588. +
  16589. +Matthias
  16590. +*/
  16591. +
  16592. +rtx gen_stack_management_call (stack_pointer, arg, func)
  16593. +     rtx stack_pointer; /* rtx to put the result into       */
  16594. +     rtx arg;           /* The argument to put into d0      */
  16595. +     char *func;        /* The name of the function to call */
  16596. +{
  16597. +  rtx fcall, assem;
  16598. +  emit_move_insn (gen_rtx (REG, SImode, 0), arg); /* Move arg to d0 */
  16599. +  assem = gen_rtx (ASM_OPERANDS, VOIDmode, func, "=r", 0,
  16600. +                   rtvec_alloc(1), rtvec_alloc(1), "internal", 0);
  16601. +  XVECEXP (assem, 3, 0) = gen_rtx (REG, SImode, 0);
  16602. +  XVECEXP (assem, 4, 0) = gen_rtx (ASM_INPUT, SImode, "r");
  16603. +  fcall = gen_rtx (PARALLEL, VOIDmode, rtvec_alloc(1+4));
  16604. +  XVECEXP (fcall, 0, 0)
  16605. +    = gen_rtx (SET, VOIDmode, stack_pointer, assem);
  16606. +  XVECEXP (fcall, 0, 1)
  16607. +    = gen_rtx (CLOBBER, VOIDmode, gen_rtx (REG, QImode, 9));
  16608. +  XVECEXP (fcall, 0, 2)
  16609. +    = gen_rtx (CLOBBER, VOIDmode, gen_rtx (REG, QImode, 8));
  16610. +  XVECEXP (fcall, 0, 3)
  16611. +    = gen_rtx (CLOBBER, VOIDmode, gen_rtx (REG, QImode, 1));
  16612. +  XVECEXP (fcall, 0, 4)
  16613. +    = gen_rtx (CLOBBER, VOIDmode, gen_rtx (REG, QImode, 0));  
  16614. +  return fcall; /* call function sp=func(d0) */
  16615. +}
  16616. +
  16617. +rtx gen_stack_cleanup_call (stack_pointer,sa)
  16618. +     rtx stack_pointer;
  16619. +     rtx sa;
  16620. +{
  16621. +  return gen_stack_management_call (stack_pointer, sa, "jbsr ___move_d0_sp");
  16622. +}
  16623. +
  16624. + /*
  16625. + * Support for passing arguments in registers. KI 30.03.96
  16626. + */
  16627. +
  16628. +char *amigaos_regparm_string;
  16629. +int amigaos_regparm;
  16630. +
  16631. +/* A function for initializing the variable CUM for the state at the
  16632. +   beginning of the argument list.  The variable has type
  16633. +   `CUMULATIVE_ARGS'.  The value of FNTYPE is the tree node for the data
  16634. +   type of the function which will receive the args, or 0 if the args are
  16635. +   to a compiler support library function.
  16636. +
  16637. +   When processing a call to a compiler support library function,
  16638. +   LIBNAME identifies which one.  It is a `symbol_ref' rtx which
  16639. +   contains the name of the function, as a string.  LIBNAME is 0 when
  16640. +   an ordinary C function call is being processed.  Thus, each time
  16641. +   this macro is called, either LIBNAME or FNTYPE is nonzero, but
  16642. +   never both of them at once. */
  16643. +
  16644. +void
  16645. +amigaos_init_cumulative_args(CUMULATIVE_ARGS *cum, tree fntype, tree libname)
  16646. +{
  16647. +  cum->regnum=-1;
  16648. +  cum->regsused=0;
  16649. +  cum->numofregparm=amigaos_regparm;
  16650. +  if (fntype)
  16651. +    {
  16652. +      if (lookup_attribute("stkparm", TYPE_ATTRIBUTES(fntype)))
  16653. +    cum->numofregparm=0;
  16654. +      else
  16655. +    {
  16656. +      tree ratree;
  16657. +      if (ratree=lookup_attribute("regparm", TYPE_ATTRIBUTES(fntype)))
  16658. +        {
  16659. +          cum->numofregparm=(amigaos_regparm ? amigaos_regparm : 2);
  16660. +          if (TREE_VALUE(ratree)
  16661. +          && TREE_CODE(TREE_VALUE(ratree))==TREE_LIST)
  16662. +        {
  16663. +          tree numofregs=TREE_VALUE(TREE_VALUE(ratree));
  16664. +          cum->numofregparm=
  16665. +            (numofregs ? TREE_INT_CST_LOW(numofregs) :
  16666. +              (amigaos_regparm ? amigaos_regparm : 2));
  16667. +        }
  16668. +        }
  16669. +    }
  16670. +      cum->formaltype=TYPE_ARG_TYPES(fntype);
  16671. +    }
  16672. +  else /* Call to compiler-support function. */
  16673. +    {
  16674. +      cum->numofregparm=0;
  16675. +      cum->formaltype=0;
  16676. +    }
  16677. +
  16678. +  if (cum->numofregparm)
  16679. +    {
  16680. +      /* If this is a vararg call, put all arguments on stack. */
  16681. +      tree param, next_param;
  16682. +      for (param=TYPE_ARG_TYPES(fntype); param; param=next_param)
  16683. +    {
  16684. +      next_param=TREE_CHAIN(param);
  16685. +      if (!next_param && TREE_VALUE(param)!=void_type_node)
  16686. +        cum->numofregparm=0;
  16687. +    }
  16688. +    }
  16689. +#ifndef PCC_STATIC_STRUCT_RETURN
  16690. +  /* If return value is a structure, it's address is passed as additional
  16691. +     argument in a1, so we can't use this register for our purposes. */
  16692. +  if (cum->numofregparm)
  16693. +      if (TREE_CODE(TREE_TYPE(fntype))==RECORD_TYPE
  16694. +      || TREE_CODE(TREE_TYPE(fntype))==UNION_TYPE)
  16695. +    cum->regsused |= 1 << STRUCT_VALUE_REGNUM;
  16696. +#endif
  16697. +}
  16698. +
  16699. +/* A function to update the summarizer variable CUM to advance past an
  16700. +   argument in the argument list. The values MODE, TYPE and NAMED describe
  16701. +   that argument.  Once this is done, the variable CUM is suitable for
  16702. +   analyzing the *following* argument with `FUNCTION_ARG', etc. */
  16703. +
  16704. +void
  16705. +amigaos_function_arg_advance(CUMULATIVE_ARGS *cum, enum machine_mode mode,
  16706. +                 tree type, int named)
  16707. +{
  16708. +  if (cum->regnum!=-1)
  16709. +    {
  16710. +      cum->regsused |= (1 << cum->regnum);
  16711. +      cum->regnum=-1;
  16712. +    }
  16713. +  if (cum->formaltype)
  16714. +    cum->formaltype=TREE_CHAIN((tree)cum->formaltype);
  16715. +}
  16716. +
  16717. +/* A C expression that controls whether a function argument is passed
  16718. +   in a register, and which register.
  16719. +
  16720. +   The arguments are CUM, which summarizes all the previous
  16721. +   arguments; MODE, the machine mode of the argument; TYPE, the data
  16722. +   type of the argument as a tree node or 0 if that is not known
  16723. +   (which happens for C support library functions); and NAMED, which
  16724. +   is 1 for an ordinary argument and 0 for nameless arguments that
  16725. +   correspond to `...' in the called function's prototype.
  16726. +
  16727. +   The value of the expression should either be a `reg' RTX for the
  16728. +   hard register in which to pass the argument, or zero to pass the
  16729. +   argument on the stack. */
  16730. +
  16731. +struct rtx_def *
  16732. +amigaos_function_arg(CUMULATIVE_ARGS *cum, enum machine_mode mode,
  16733. +  tree type, int named)
  16734. +{
  16735. +  tree asmtree;
  16736. +  if (cum->formaltype && TREE_VALUE((tree)cum->formaltype)
  16737. +      && (asmtree=lookup_attribute("asm",
  16738. +            TYPE_ATTRIBUTES(TREE_VALUE((tree)cum->formaltype)))))
  16739. +    {
  16740. +#if 0
  16741. +      /* See c-decl.c/push_parm_decl for an explanation why this doesn't work.
  16742. +       */
  16743. +      cum->regnum=TREE_INT_CST_LOW(TREE_VALUE(TREE_VALUE(asmtree)));
  16744. +#else
  16745. +      cum->regnum=TREE_INT_CST_LOW(TREE_VALUE(asmtree));
  16746. +#endif
  16747. +      if (cum->regsused & (1 << cum->regnum))
  16748. +    error("two parameters allocated for one register");
  16749. +      return gen_rtx(REG, mode, cum->regnum);
  16750. +    }
  16751. +  else if (cum->numofregparm)
  16752. +    {
  16753. +      if (GET_MODE_CLASS(mode)==MODE_INT && GET_MODE_SIZE(mode)<=4)
  16754. +    {
  16755. +      if (POINTER_TYPE_P(type))
  16756. +        {
  16757. +          int count;
  16758. +          long mask=0x100;
  16759. +          for (count=0; count<cum->numofregparm; count++, mask<<=1)
  16760. +        if (!(cum->regsused & mask))
  16761. +          {
  16762. +            cum->regnum=count+8;
  16763. +            break;
  16764. +          }
  16765. +        }
  16766. +      else
  16767. +        {
  16768. +          int count;
  16769. +          long mask=0x1;
  16770. +          for (count=0; count<cum->numofregparm; count++, mask<<=1)
  16771. +        if (!(cum->regsused & mask))
  16772. +          {
  16773. +            cum->regnum=count;
  16774. +            break;
  16775. +          }
  16776. +        }
  16777. +    }
  16778. +      if (TARGET_68881 && GET_MODE_CLASS(mode)==MODE_FLOAT)
  16779. +    {
  16780. +      int count;
  16781. +      long mask=0x10000;
  16782. +      for (count=0; count<cum->numofregparm; count++, mask<<=1)
  16783. +        if (!(cum->regsused & mask))
  16784. +          {
  16785. +        cum->regnum=count+16;
  16786. +        break;
  16787. +          }
  16788. +    }
  16789. +      if (cum->regnum!=-1)
  16790. +    return gen_rtx(REG, mode, cum->regnum);
  16791. +    }
  16792. +  return 0;
  16793. +}
  16794. diff -rup --new-file baseline/fsf/gcc/config/m68k/amigaos.h amiga/fsf/gcc/config/m68k/amigaos.h
  16795. --- baseline/fsf/gcc/config/m68k/amigaos.h    Wed Dec 31 17:00:00 1969
  16796. +++ amiga/fsf/gcc/config/m68k/amigaos.h    Tue Oct  1 08:50:01 1996
  16797. @@ -0,0 +1,634 @@
  16798. +/* Definitions of target machine for GNU compiler.  amiga 68000/68020 version.
  16799. +   Copyright (C) 1992 Free Software Foundation, Inc.
  16800. +   Contributed by Markus M. Wild (wild@amiga.physik.unizh.ch).
  16801. +
  16802. +This file is part of GNU CC.
  16803. +
  16804. +GNU CC is free software; you can redistribute it and/or modify
  16805. +it under the terms of the GNU General Public License as published by
  16806. +the Free Software Foundation; either version 2, or (at your option)
  16807. +any later version.
  16808. +
  16809. +GNU CC is distributed in the hope that it will be useful,
  16810. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  16811. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16812. +GNU General Public License for more details.
  16813. +
  16814. +You should have received a copy of the GNU General Public License
  16815. +along with GNU CC; see the file COPYING.  If not, write to
  16816. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  16817. +
  16818. +/* Phil.B 12-Mar-95: Define USE_GAS if GCC is supposed to work with the GNU
  16819. +   assembler, GNU linker and GNU debugger using DBX debugging information. */
  16820. +
  16821. +#define USE_GAS
  16822. +
  16823. +/* Control assembler-syntax conditionals in m68k.md.  */
  16824. +
  16825. +#ifndef USE_GAS
  16826. +#define MOTOROLA        /* Use Motorola syntax rather than "MIT" */
  16827. +#endif /* !USE_GAS */
  16828. +
  16829. +#include "m68k/m68k.h"
  16830. +
  16831. +/* Enable some special Amiga only features.  FIXME: This define should
  16832. +   be eliminated in favor of more general ways to enable the features. */
  16833. +
  16834. +#define TARGET_AMIGAOS
  16835. +
  16836. +/* See m68k.h for bits in TARGET_DEFAULT.
  16837. +   0 means 68000, no hardware fpu (68881/68882/68040).
  16838. +   7 means 68020 (or higher) with hardware fpu.  */
  16839. +
  16840. +#ifndef TARGET_DEFAULT
  16841. +#define TARGET_DEFAULT 0
  16842. +#endif
  16843. +
  16844. +/* Define __HAVE_68881__ in preprocessor according to the -m flags.
  16845. +   This will control the use of inline 68881 insns in certain macros.
  16846. +   Also inform the program which CPU this is for.  */
  16847. +
  16848. +#if TARGET_DEFAULT & 02
  16849. +
  16850. +/* -m68881 is the default */
  16851. +#define CPP_SPEC \
  16852. +"%{!msoft-float:-D__HAVE_68881__ }\
  16853. +%{!ansi:%{m68000:-Dmc68010}%{mc68000:-Dmc68010}%{m68030:-Dmc68030}%{mc68030:-Dmc68030}%{m68040:-Dmc68040}\
  16854. +%{mc68040:-Dmc68040}%{!mc68000:%{!m68000:-Dmc68020}}}"
  16855. +
  16856. +#else
  16857. +
  16858. +/* -msoft-float is the default, assume -mc68000 as well */
  16859. +#define CPP_SPEC \
  16860. +"%{m68881:-D__HAVE_68881__ }\
  16861. +%{!ansi:%{m68020:-Dmc68020}%{mc68020:-Dmc68020}%{m68020-40:-Dmc68020}%{m68030:-Dmc68030}%{m68040:-Dmc68040}%{m68060:-Dmc68060}}"
  16862. +
  16863. +/* Don't try using XFmode since we don't have appropriate runtime software
  16864. +   support.  */
  16865. +#undef LONG_DOUBLE_TYPE_SIZE
  16866. +#define LONG_DOUBLE_TYPE_SIZE 64
  16867. +
  16868. +#endif
  16869. +
  16870. +/* -m68000 requires special flags to the assembler.  */
  16871. +
  16872. +#define ASM_SPEC "\
  16873. + %{m68000:-mc68010}\
  16874. + %{mc68000:-mc68010}\
  16875. + %{m68020:-mc68020}\
  16876. + %{mc68020:-mc68020}\
  16877. + %{m68030:-mc68030}\
  16878. + %{m68040:-mc68040}\
  16879. + %{m68060:-mc68060}\
  16880. + %{m68020-40:-mc68020}\
  16881. + %{!mc68000:%{!m68000:%{!mc68020:%{!m68020:%{!m68030:%{!m68040:%{!m68060:%{!m68020-40:-mc68010}}}}}}}}\
  16882. + %{msmall-code:-sc}\
  16883. +"
  16884. +
  16885. +/* amiga/amigaos are the new "standard" defines for the Amiga, MCH_AMIGA
  16886. + * was used before and is included for compatibility reasons.
  16887. + * "amigados" and "__amigados__" are obsolescent and will generate cpp warnings */
  16888. +
  16889. +#define CPP_PREDEFINES "\
  16890. + -Dmc68000\
  16891. + -Damiga\
  16892. + -Damigaos\
  16893. + -Damigados\
  16894. + -DMCH_AMIGA\
  16895. + -DAMIGA\
  16896. + -D__chip=__attribute__((chip))\
  16897. + -D__saveds=__attribute__((saveds))\
  16898. + -D__interrupt=__attribute__((interrupt))\
  16899. + -D__stackext=__attribute__((stackext))\
  16900. + -D__regargs=__attribute__((regparm))\
  16901. + -D__stdargs=__attribute__((stkparm))\
  16902. + -D__aligned=__attribute__((aligned(4)))\
  16903. + -Asystem(amigaos)\
  16904. + -Asystem(amigados)\
  16905. + -Acpu(m68k)\
  16906. + -Amachine(m68k)\
  16907. +"
  16908. +/* Choose the right startup file, depending on whether we use base relative
  16909. +   code, base relative code with automatic relocation (-resident), or plain
  16910. +   crt0.o. 
  16911. +  
  16912. +   Profiling is currently only available for plain startup.
  16913. +   mcrt0.o does not (yet) exist. */
  16914. +
  16915. +#define STARTFILE_SPEC \
  16916. + "%{!noixemul:%{resident:rcrt0.o%s}%{!resident:%{!fbaserel:%{pg:gcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}}\
  16917. +%{fbaserel:%{pg:bgcrt0.o%s}%{!pg:%{p:bmcrt0.o%s}%{!p:bcrt0.o%s}}}}}\
  16918. +%{noixemul:%{resident:libnix/nrcrt0.o%s}%{!resident:%{fbaserel:libnix/nbcrt0.o%s}%{!fbaserel:libnix/ncrt0.o%s}}}"
  16919. +
  16920. +#define ENDFILE_SPEC "%{noixemul:-lstubs}"
  16921. +
  16922. +/* Automatically search libamiga.a for AmigaOS specific functions.  Note
  16923. +   that we first search the standard C library to resolve as much as
  16924. +   possible from there, since it has names that are duplicated in libamiga.a
  16925. +   which we *don't* want from there.  Then search libamiga.a for any calls
  16926. +   that were not generated inline, and finally search the standard C library
  16927. +   again to resolve any references that libamiga.a might have generated.
  16928. +   This may only be a temporary solution since it might be better to simply
  16929. +   remove the things from libamiga.a that should be pulled in from libc.a
  16930. +   instead, which would eliminate the first reference to libc.a.  Note that
  16931. +   if we don't search it automatically, it is very easy for the user to try
  16932. +   to put in a -lamiga himself and get it in the wrong place, so that (for
  16933. +   example) calls like sprintf come from -lamiga rather than -lc. */
  16934. +
  16935. +#define LIB_SPEC "%{!noixemul:%{!p:%{!pg:-lc -lamiga -lc}}%{p:-lc_p}%{pg:-lc_p}}%{noixemul:-lnixmain -lnix -lamiga %{mstackcheck:-lstack} %{mstackextend:-lstack}}"
  16936. +
  16937. +/* if debugging, tell the linker to output amiga-hunk symbols *and* a BSD
  16938. +   compatible debug hunk (which will probably change in the future, it's not
  16939. +   tremendously useful in its current state). */
  16940. +
  16941. +#define LINK_SPEC "%{noixemul:-fl libnix} %{fbaserel:%{!resident:-m amiga_bss -fl libb}}\
  16942. +%{resident:-m amiga_bss -amiga-datadata-reloc -fl libb} %{g:-amiga-debug-hunk} \
  16943. +%{m68020:-fl libm020} %{m68030:-fl libm020} %{m68040:-fl libm020} %{m68020-40:-fl libm020} %{m68881:-fl libm881}\
  16944. +%{mc68020:-fl libm020} %{m68060:-fl libm020}"
  16945. +
  16946. +#define CC1_SPEC "%{resident:-fbaserel }%{msmall-code:-fno-function-cse } "
  16947. +
  16948. +#define CC1PLUS_SPEC "%{resident:-fbaserel }%{msmall-code:-fno-function-cse } "
  16949. +
  16950. +/* Compile with stack extension.  */
  16951. +#define MASK_STACKEXTEND 0x40000000
  16952. +#define TARGET_STACKEXTEND (((target_flags & MASK_STACKEXTEND)        \
  16953. +  && !lookup_attribute("interrupt",                    \
  16954. +    TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl))))            \
  16955. +  || lookup_attribute("stackext",                    \
  16956. +    TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl))))
  16957. +
  16958. +/* Compile with stack checking.  */
  16959. +#define MASK_STACKCHECK 0x20000000
  16960. +#define TARGET_STACKCHECK ((target_flags & MASK_STACKCHECK)        \
  16961. +  && !(target_flags & MASK_STACKEXTEND)                    \
  16962. +  && !lookup_attribute("interrupt",                    \
  16963. +    TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl)))            \
  16964. +  && !lookup_attribute("stackext",                    \
  16965. +    TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl))))
  16966. +
  16967. +/* Compile with a4 restoring in public functions.  */
  16968. +#define MASK_RESTORE_A4 0x10000000
  16969. +#define TARGET_RESTORE_A4                        \
  16970. +  ((target_flags & MASK_RESTORE_A4) && TREE_PUBLIC(current_function_decl))
  16971. +
  16972. +/* Compile with a4 restoring in all functions.  */
  16973. +#define MASK_ALWAYS_RESTORE_A4 0x8000000
  16974. +#define TARGET_ALWAYS_RESTORE_A4 (target_flags & MASK_ALWAYS_RESTORE_A4)
  16975. +
  16976. +#ifndef MASK_REGPARM /* Will be defined in 2.8.0.  */
  16977. +#define MASK_REGPARM 0x10
  16978. +#endif
  16979. +
  16980. +/* provide a dummy entry for the small-code switch. This is currently only
  16981. +   needed by the assembler (explanations: m68k.h), but will be used by cc1
  16982. +   to output 16bit pc-relative code later.
  16983. +   PhB 21-Jun-95: use now SUBTARGET_SWITCHES instead of redefining
  16984. +   whole TARGET_SWITCHES, means that all additions made to m68k.* are
  16985. +   now taken into account */
  16986. +
  16987. +#undef SUBTARGET_SWITCHES
  16988. +#define SUBTARGET_SWITCHES  \
  16989. +    { "small-code", 0 }, /* Affects *_SPEC and/or GAS.  */ \
  16990. +    { "stackcheck", MASK_STACKCHECK},        \
  16991. +    { "no-stackcheck", -MASK_STACKCHECK},    \
  16992. +    { "stackextend", MASK_STACKEXTEND},        \
  16993. +    { "no-stackextend", -MASK_STACKEXTEND},    \
  16994. +    { "fixedstack", -(MASK_STACKCHECK | MASK_STACKEXTEND)}, \
  16995. +    { "regparm", MASK_REGPARM},            \
  16996. +    { "no-regparm", -MASK_REGPARM},        \
  16997. +    { "restore-a4", MASK_RESTORE_A4},        \
  16998. +    { "no-restore-a4", -MASK_RESTORE_A4},    \
  16999. +    { "always-restore-a4", MASK_ALWAYS_RESTORE_A4}, \
  17000. +    { "no-always-restore-a4", -MASK_ALWAYS_RESTORE_A4},
  17001. +
  17002. +/* Every structure or union's size must be a multiple of 2 bytes.  */
  17003. +
  17004. +#define STRUCTURE_SIZE_BOUNDARY 16
  17005. +
  17006. +/* This is (almost;-)) BSD, so it wants DBX format.  */
  17007. +
  17008. +#define DBX_DEBUGGING_INFO
  17009. +
  17010. +/* Allow folding division by zero.  */
  17011. +#define REAL_INFINITY
  17012. +
  17013. +/* The following was hacked into final.c, to allow some notice of
  17014. + * source line and filename to be injected into the assembly code,
  17015. + * even if not using one of the "approved" debuggers (albaugh@agames.com).
  17016. + */
  17017. +#if 0
  17018. +#define ASM_NOTE_SOURCE_LINE(FILE, LINE, FILENAME)\
  17019. +  fprintf(file,"*#line %d \"%s\"\n",(LINE),(FILENAME))
  17020. +#endif
  17021. +
  17022. +#if 0    /* This apparently is no longer necessary? */
  17023. +
  17024. +/* This is how to output an assembler line defining a `double' constant.  */
  17025. +
  17026. +#undef ASM_OUTPUT_DOUBLE
  17027. +#define ASM_OUTPUT_DOUBLE(FILE,VALUE)                    \
  17028. +  {                                    \
  17029. +    if (REAL_VALUE_ISINF (VALUE))                    \
  17030. +      fprintf (FILE, "\t.double 0r%s99e999\n", (VALUE) > 0 ? "" : "-");    \
  17031. +    else if (isnan (VALUE))                        \
  17032. +      {                                    \
  17033. +    union { double d; long l[2];} t;                \
  17034. +    t.d = (VALUE);                            \
  17035. +    fprintf (FILE, "\t.long 0x%lx\n\t.long 0x%lx\n", t.l[0], t.l[1]); \
  17036. +      }                                    \
  17037. +    else                                \
  17038. +      fprintf (FILE, "\t.double 0r%.17g\n", VALUE);            \
  17039. +  }
  17040. +
  17041. +/* This is how to output an assembler line defining a `float' constant.  */
  17042. +
  17043. +#undef ASM_OUTPUT_FLOAT
  17044. +#define ASM_OUTPUT_FLOAT(FILE,VALUE)                    \
  17045. +  {                                    \
  17046. +    if (REAL_VALUE_ISINF (VALUE))                    \
  17047. +      fprintf (FILE, "\t.single 0r%s99e999\n", (VALUE) > 0 ? "" : "-");    \
  17048. +    else if (isnan (VALUE))                        \
  17049. +      {                                    \
  17050. +    union { float f; long l;} t;                    \
  17051. +    t.f = (VALUE);                            \
  17052. +    fprintf (FILE, "\t.long 0x%lx\n", t.l);                \
  17053. +      }                                    \
  17054. +    else                                \
  17055. +      fprintf (FILE, "\t.single 0r%.9g\n", VALUE);            \
  17056. +  }
  17057. +
  17058. +/* This is how to output an assembler lines defining floating operands.
  17059. +   There's no way to output a NaN's fraction, so we lose it.  */
  17060. +  
  17061. +#undef ASM_OUTPUT_FLOAT_OPERAND
  17062. +#define ASM_OUTPUT_FLOAT_OPERAND(CODE,FILE,VALUE)                \
  17063. + do {                                \
  17064. +      if (CODE == 'f')                        \
  17065. +        {                            \
  17066. +          (REAL_VALUE_ISINF ((VALUE))                        \
  17067. +           ? asm_fprintf (FILE, "%I0r%s99e999", ((VALUE) > 0 ? "" : "-")) \
  17068. +           : (VALUE) == -0.0                            \
  17069. +           ? asm_fprintf (FILE, "%I0r-0.0")                    \
  17070. +           : asm_fprintf (FILE, "%I0r%.9g", (VALUE))) \
  17071. +        } else {                                        \
  17072. +          long l;                        \
  17073. +          REAL_VALUE_TO_TARGET_SINGLE (VALUE, l);        \
  17074. +          if (sizeof (int) == sizeof (long))            \
  17075. +            asm_fprintf ((FILE), "%I0x%x", l);            \
  17076. +          else                            \
  17077. +            asm_fprintf ((FILE), "%I0x%lx", l);            \
  17078. +        }                            \
  17079. +     } while (0)
  17080. +
  17081. +#undef ASM_OUTPUT_DOUBLE_OPERAND
  17082. +#define ASM_OUTPUT_DOUBLE_OPERAND(FILE,VALUE)                \
  17083. +  (REAL_VALUE_ISINF ((VALUE))                        \
  17084. +   ? asm_fprintf (FILE, "%I0r%s99e999", ((VALUE) > 0 ? "" : "-")) \
  17085. +   : (VALUE) == -0.0                            \
  17086. +   ? asm_fprintf (FILE, "%I0r-0.0")                    \
  17087. +   : asm_fprintf (FILE, "%I0r%.17g", (VALUE)))
  17088. +
  17089. +#endif    /* 0 */
  17090. +
  17091. +/* use A5 as framepointer instead of A6, this makes A6 available as a
  17092. +   general purpose register, and can thus be used without problems in
  17093. +   direct library calls. */
  17094. +
  17095. +#undef FRAME_POINTER_REGNUM
  17096. +#define FRAME_POINTER_REGNUM 13
  17097. +#undef ARG_POINTER_REGNUM
  17098. +#define ARG_POINTER_REGNUM 13
  17099. +
  17100. +/* we use A4 for this, not A5, which is the framepointer */
  17101. +#undef PIC_OFFSET_TABLE_REGNUM
  17102. +#define PIC_OFFSET_TABLE_REGNUM 12
  17103. +
  17104. +/* setup a default shell return value for those (gazillion..) programs that
  17105. +   (inspite of ANSI-C) declare main() to be void (or even VOID...) and thus
  17106. +   cause the shell to randomly caugh upon executing such programs (contrary
  17107. +   to Unix, AmigaOS scripts are terminated with an error if a program returns
  17108. +   with an error code above the `error' or even `failure' level
  17109. +   (which is configurable with the FAILAT command) */
  17110. +
  17111. +#define DEFAULT_MAIN_RETURN c_expand_return (integer_zero_node)
  17112. +
  17113. +/* given that symbolic_operand(X), return TRUE if no special
  17114. +   base relative relocation is necessary */
  17115. +
  17116. +#define LEGITIMATE_BASEREL_OPERAND_P(X) \
  17117. +  (flag_pic >= 3 && read_only_operand (X))
  17118. +
  17119. +#undef LEGITIMATE_PIC_OPERAND_P
  17120. +#define LEGITIMATE_PIC_OPERAND_P(X) \
  17121. +  (! symbolic_operand (X, VOIDmode) || LEGITIMATE_BASEREL_OPERAND_P (X))
  17122. +
  17123. +/* Phil.B 12-Mar-95: check if this would fix some PIC problems */
  17124. +/* In m68k svr4, a symbol_ref rtx can be a valid PIC operand if it is an
  17125. +   operand of a function call. */
  17126. +/* #undef LEGITIMATE_PIC_OPERAND_P
  17127. +#define LEGITIMATE_PIC_OPERAND_P(X) \
  17128. +  (! symbolic_operand (X, VOIDmode) \
  17129. +   || ((GET_CODE(X) == SYMBOL_REF) && SYMBOL_REF_FLAG(X)))
  17130. +*/
  17131. +
  17132. +/* Define this macro if references to a symbol must be treated
  17133. +   differently depending on something about the variable or
  17134. +   function named by the symbol (such as what section it is in).
  17135. +
  17136. +   The macro definition, if any, is executed immediately after the
  17137. +   rtl for DECL or other node is created.
  17138. +   The value of the rtl will be a `mem' whose address is a
  17139. +   `symbol_ref'.
  17140. +
  17141. +   The usual thing for this macro to do is to a flag in the
  17142. +   `symbol_ref' (such as `SYMBOL_REF_FLAG') or to store a modified
  17143. +   name string in the `symbol_ref' (if one bit is not enough
  17144. +   information).
  17145. +
  17146. +   On the Amiga we use this to indicate if a symbol is in text or
  17147. +   data space.  */
  17148. +
  17149. +#define ENCODE_SECTION_INFO(DECL)\
  17150. +do                                    \
  17151. +  {                                    \
  17152. +    if (TREE_CODE (DECL) == FUNCTION_DECL)                \
  17153. +      SYMBOL_REF_FLAG (XEXP (DECL_RTL (DECL), 0)) = 1;            \
  17154. +    else                                \
  17155. +      {                                    \
  17156. +    rtx rtl = (TREE_CODE_CLASS (TREE_CODE (DECL)) != 'd'        \
  17157. +           ? TREE_CST_RTL (DECL) : DECL_RTL (DECL));        \
  17158. +    if (RTX_UNCHANGING_P (rtl) && !MEM_VOLATILE_P (rtl))        \
  17159. +      SYMBOL_REF_FLAG (XEXP (rtl, 0)) = 1;                \
  17160. +      }                                    \
  17161. +  }                                    \
  17162. +while (0)
  17163. +
  17164. +#undef SELECT_RTX_SECTION
  17165. +#define SELECT_RTX_SECTION(MODE, X) readonly_data_section ();
  17166. +
  17167. +/* according to varasm.c, RELOC referrs *only* to whether constants (!)
  17168. +   are addressed by address. This doesn't matter in baserelative code,
  17169. +   so we allow (inspite of flag_pic) readonly_data_section() in that
  17170. +   case */
  17171. +
  17172. +#undef SELECT_SECTION
  17173. +#define SELECT_SECTION(DECL, RELOC)                    \
  17174. +{                                    \
  17175. +  if (TREE_CODE (DECL) == STRING_CST)                    \
  17176. +    {                                    \
  17177. +      if (! flag_writable_strings)                    \
  17178. +    readonly_data_section ();                    \
  17179. +      else                                \
  17180. +    data_section ();                        \
  17181. +    }                                    \
  17182. +  else if (TREE_CODE (DECL) == VAR_DECL)                \
  17183. +    {                                    \
  17184. +      if ((flag_pic && flag_pic < 3 && RELOC)                \
  17185. +      || !TREE_READONLY (DECL) || TREE_SIDE_EFFECTS (DECL))        \
  17186. +    data_section ();                        \
  17187. +      else                                \
  17188. +    readonly_data_section ();                    \
  17189. +    }                                    \
  17190. +  else                                    \
  17191. +    readonly_data_section ();                        \
  17192. +}
  17193. +
  17194. +/* GAS supports alignment up to 32768 bytes.  */
  17195. +#undef ASM_OUTPUT_ALIGN
  17196. +#define ASM_OUTPUT_ALIGN(FILE, LOG)    \
  17197. +  if ((LOG)==1)                \
  17198. +    fprintf((FILE), "\t.even\n");    \
  17199. +  else                    \
  17200. +    fprintf((FILE), "\t.align %d\n", (LOG));
  17201. +#define MAX_OFILE_ALIGNMENT ((1 << 15)*BITS_PER_UNIT)
  17202. +
  17203. +#undef WCHAR_TYPE
  17204. +#define WCHAR_TYPE "unsigned int"
  17205. +
  17206. +/*
  17207. + * Support for Amiga-specific variable and function attributes.
  17208. + * KI 11.02.96
  17209. + */
  17210. +
  17211. +/* If defined, a C expression whose value is nonzero if IDENTIFIER
  17212. +   with arguments ARGS is a valid machine specific attribute for DECL.
  17213. +   The attributes in ATTRIBUTES have previously been assigned to DECL. */
  17214. +
  17215. +#define VALID_MACHINE_DECL_ATTRIBUTE(decl, attributes, identifier, args) \
  17216. +  (valid_amigaos_decl_attribute(decl, attributes, identifier, args))
  17217. +
  17218. +/* If defined, a C expression whose value is nonzero if IDENTIFIER
  17219. +   with arguments ARGS is a valid machine specific attribute for TYPE.
  17220. +   The attributes in ATTRIBUTES have previously been assigned to TYPE. */
  17221. +
  17222. +#define VALID_MACHINE_TYPE_ATTRIBUTE(type, attributes, identifier, args) \
  17223. +  (valid_amigaos_type_attribute(type, attributes, identifier, args))
  17224. +
  17225. +/* If defined, a C expression whose value is zero if the attributes on
  17226. +   TYPE1 and TYPE2 are incompatible, one if they are compatible, and
  17227. +   two if they are nearly compatible (which causes a warning to be
  17228. +   generated). */
  17229. +
  17230. +#define COMP_TYPE_ATTRIBUTES(type1, type2) \
  17231. +  (comp_amigaos_type_attributes(type1, type2))
  17232. +
  17233. +/* Preserve the initial value of a4.  */
  17234. +
  17235. +#define PROLOGUE_EXTRA_SAVE(mask, num_saved_regs)            \
  17236. +  if (amigaos_restore_a4())                        \
  17237. +    {                                    \
  17238. +      mask |= 1 << (15-PIC_OFFSET_TABLE_REGNUM);            \
  17239. +      num_saved_regs++;                            \
  17240. +    }
  17241. +
  17242. +/* Make a4 point at data hunk.  */
  17243. +
  17244. +#define PROLOGUE_SET_PIC_REG(stream)                    \
  17245. +  if (flag_pic>=3)                            \
  17246. +    {                                    \
  17247. +      if (TARGET_RESTORE_A4 || TARGET_ALWAYS_RESTORE_A4)        \
  17248. +    {                                \
  17249. +      char *r = reg_names[PIC_OFFSET_TABLE_REGNUM];            \
  17250. +      asm_fprintf(stream, "\tmovel %USysBase,%s\n"            \
  17251. +                  "\tmovel %s@(0x114),%s\n"            \
  17252. +                  "\tmovel %s@(0x2e),%s\n"            \
  17253. +                  "\tmovel %s@(%U__a4_offset),%s\n",    \
  17254. +                  r, r, r, r, r, r, r            \
  17255. +        );                                \
  17256. +    }                                \
  17257. +      else if (lookup_attribute("saveds",                \
  17258. +           TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl))))    \
  17259. +    asm_fprintf(stream, "\tlea %U__a4_init,%s\n",            \
  17260. +      reg_names[PIC_OFFSET_TABLE_REGNUM]);                \
  17261. +    }
  17262. +
  17263. +/* Restore the initial value of a4.  */
  17264. +
  17265. +#define EPILOGUE_EXTRA_RESTORE(mask, nregs)                \
  17266. +  if (amigaos_restore_a4())                        \
  17267. +    {                                    \
  17268. +      mask |= 1 << PIC_OFFSET_TABLE_REGNUM;                \
  17269. +      nregs++;                                \
  17270. +    }
  17271. +
  17272. +/* If preserving a4, let the code generator know about it.  */
  17273. +
  17274. +#undef SUBTARGET_INITIAL_FP_OFFSET
  17275. +#define SUBTARGET_INITIAL_FP_OFFSET(offset)                \
  17276. +  if (amigaos_restore_a4())                        \
  17277. +    offset+=4;
  17278. +
  17279. +/* Determine if the epilogue should be output as RTL.  */
  17280. +
  17281. +#undef USE_RETURN_INSN
  17282. +#define USE_RETURN_INSN amigaos_use_return_insn()
  17283. +
  17284. +/* Generate the test of d0 before return to set cc register in "interrupt"
  17285. +   function.  */
  17286. +
  17287. +#define EPILOGUE_EXTRA_TEST(stream)                    \
  17288. +  if (lookup_attribute("interrupt",                    \
  17289. +    TYPE_ATTRIBUTES(TREE_TYPE(current_function_decl))))        \
  17290. +    asm_fprintf(stream, "\ttstl %R%s\n", reg_names[0])
  17291. +
  17292. +
  17293. +/*
  17294. + * Support for automatic stack extension.
  17295. + */
  17296. +
  17297. +#define HAVE_restore_stack_nonlocal 1
  17298. +#define gen_restore_stack_nonlocal \
  17299. +(TARGET_STACKEXTEND?gen_stack_cleanup_call:gen_move_insn)
  17300. +
  17301. +#define HAVE_restore_stack_function 1
  17302. +#define gen_restore_stack_function gen_restore_stack_nonlocal
  17303. +
  17304. +#define HAVE_restore_stack_block 1
  17305. +#define gen_restore_stack_block gen_restore_stack_nonlocal
  17306. +
  17307. +/* Reserve PIC_OFFSET_TABLE_REGNUM (a5) for doing PIC relocation if position
  17308. +   independent code is being generated, by making it a fixed register. */
  17309. +
  17310. +#define CONDITIONAL_REGISTER_USAGE            \
  17311. +{                            \
  17312. +  if (flag_pic)                        \
  17313. +    fixed_regs[PIC_OFFSET_TABLE_REGNUM] = 1;        \
  17314. +  /* prevent saving/restoring of the base reg */    \
  17315. +  if (flag_pic == 3 || flag_pic == 4)            \
  17316. +    call_used_regs[PIC_OFFSET_TABLE_REGNUM] = 1;    \
  17317. +}
  17318. +
  17319. +/* m68k.h defines this, which causes structures to be returned in static
  17320. +   storage, resulting in nonreentrant code, which we don't want. */
  17321. +
  17322. +#undef PCC_STATIC_STRUCT_RETURN
  17323. +
  17324. +/*
  17325. + * Support for passing arguments in registers.
  17326. + */
  17327. +
  17328. +extern char *amigaos_regparm_string;
  17329. +extern int amigaos_regparm;
  17330. +
  17331. +/* Custom structure used as "CUM" (see below).
  17332. +   regsused: bitmask of registers already used.
  17333. +   regnum: register number of recently passed argument, or -1 if passed on
  17334. +     stack.
  17335. +   numofregparm: number of registers in single class to be used to pass
  17336. +     arguments. 0 for stack calls.
  17337. +  formaltype: formal type of current argument (taken from function prototype).
  17338. +    This is necessary for explicit register specification. */
  17339. +
  17340. +struct amigaosargs
  17341. +{
  17342. +  long regsused;
  17343. +  short regnum;
  17344. +  short numofregparm;
  17345. +  void *formaltype;
  17346. +};
  17347. +
  17348. +/* A C type for declaring a variable that is used as the first
  17349. +   argument of `FUNCTION_ARG' and other related values. 
  17350. +
  17351. +   We use our own structure "amigaosargs". */
  17352. +
  17353. +#undef CUMULATIVE_ARGS
  17354. +#define CUMULATIVE_ARGS struct amigaosargs
  17355. +
  17356. +/* A C statement (sans semicolon) for initializing the variable CUM
  17357. +   for the state at the beginning of the argument list. */
  17358. +
  17359. +#undef INIT_CUMULATIVE_ARGS
  17360. +#define INIT_CUMULATIVE_ARGS(CUM,FNTYPE,LIBNAME)    \
  17361. +  (amigaos_init_cumulative_args(&(CUM), (FNTYPE), (LIBNAME)))
  17362. +
  17363. +/* A C statement (sans semicolon) to update the summarizer variable
  17364. +   CUM to advance past an argument in the argument list. */
  17365. +
  17366. +#undef FUNCTION_ARG_ADVANCE
  17367. +#define FUNCTION_ARG_ADVANCE(CUM, MODE, TYPE, NAMED)    \
  17368. +  (amigaos_function_arg_advance(&(CUM), (MODE), (TYPE), (NAMED)))
  17369. +
  17370. +/* A C expression that controls whether a function argument is passed
  17371. +   in a register, and which register. */
  17372. +
  17373. +#undef FUNCTION_ARG
  17374. +#define FUNCTION_ARG(CUM, MODE, TYPE, NAMED)        \
  17375. +  ((struct rtx_def*)amigaos_function_arg(&(CUM), (MODE), (TYPE), (NAMED)))
  17376. +
  17377. +/* A C expression for the number of words, at the beginning of an
  17378. +   argument, must be put in registers.  The value must be zero for
  17379. +   arguments that are passed entirely in registers or that are
  17380. +   entirely pushed on the stack.
  17381. +
  17382. +   We don't want any arguments to be passed partially in registers and
  17383. +   partially on stack. */
  17384. +
  17385. +#undef FUNCTION_ARG_PARTIAL_NREGS
  17386. +#define FUNCTION_ARG_PARTIAL_NREGS(CUM, MODE, TYPE, NAMED) (0)
  17387. +
  17388. +/* A C expression that is nonzero if REGNO is the number of a hard
  17389. +   register in which function arguments are sometimes passed.
  17390. +
  17391. +   Using __attribute__ ((regparm))/-mregparm we can pass arguments in up to
  17392. +   four first registers of each class.
  17393. +
  17394. +   Explicitly, we can pass arguments in practically every register. The
  17395. +   following macro "doesn't know" about it - making it accept all the
  17396. +   registers resulted in "fixed or forbidden register was spilled" message
  17397. +   during compilation of objc/sendmsg.c (__builtin_apply). This small "lie"
  17398. +   shouldn't cause any troubles. */
  17399. +
  17400. +#undef FUNCTION_ARG_REGNO_P
  17401. +#define FUNCTION_ARG_REGNO_P(N)            \
  17402. +  (((N)>=0 && (N)<4) || ((N)>=8 && (N)<12)    \
  17403. +    || (TARGET_68881 && (N)>16 && (N)<20))
  17404. +
  17405. +/* This macro is similar to `TARGET_SWITCHES' but defines names of
  17406. +   command options that have values.  Its definition is an
  17407. +   initializer with a subgrouping for each command option. */
  17408. +
  17409. +#define TARGET_OPTIONS                \
  17410. +{                        \
  17411. +  { "regparm=", &amigaos_regparm_string }    \
  17412. +}
  17413. +
  17414. +#undef SUBTARGET_OVERRIDE_OPTIONS
  17415. +#define SUBTARGET_OVERRIDE_OPTIONS            \
  17416. +{                            \
  17417. +  if (amigaos_regparm_string)                \
  17418. +  {                            \
  17419. +    amigaos_regparm=atoi(amigaos_regparm_string);    \
  17420. +    if (amigaos_regparm<1 || amigaos_regparm>4)        \
  17421. +      fatal ("-mregparm=%s is not between 1 and 4",    \
  17422. +    amigaos_regparm_string);            \
  17423. +  }                            \
  17424. +  if (TARGET_REGPARM)                    \
  17425. +    amigaos_regparm=2;                    \
  17426. +}
  17427. +
  17428. +/* Used in cpp to do special handling on symbols found in #if,
  17429. +   #ifdef, #ifndef, and #if defined directives. */
  17430. +
  17431. +#define CPP_SYMNAME_HOOK amiga_cpp_symname_hook
  17432. diff -rup --new-file baseline/fsf/gcc/config/m68k/m68k.c amiga/fsf/gcc/config/m68k/m68k.c
  17433. --- baseline/fsf/gcc/config/m68k/m68k.c    Thu Sep 28 11:00:17 1995
  17434. +++ amiga/fsf/gcc/config/m68k/m68k.c    Sat Sep 28 00:00:00 1996
  17435. @@ -62,10 +62,12 @@ rtx legitimize_pic_address ();
  17436.  void
  17437.  finalize_pic ()
  17438.  {
  17439. -  if (flag_pic && current_function_uses_pic_offset_table)
  17440. +  if (flag_pic && (flag_pic < 3) && current_function_uses_pic_offset_table)
  17441.      {
  17442.        rtx insn = gen_rtx (USE, VOIDmode, pic_offset_table_rtx);
  17443. +#ifndef TARGET_AMIGAOS
  17444.        emit_insn_after (insn, get_insns ());
  17445. +#endif
  17446.        emit_insn (insn);
  17447.      }
  17448.  }
  17449. @@ -94,10 +96,50 @@ output_function_prologue (stream, size)
  17450.    int num_saved_regs = 0;
  17451.    extern char call_used_regs[];
  17452.    int fsize = (size + 3) & -4;
  17453. -  
  17454.  
  17455. +
  17456. +/* Matthias Fleischer stack-checking and auto-extend for the Amiga */  
  17457. +#ifndef MOTOROLA
  17458. +  if (TARGET_STACKCHECK)
  17459. +    {
  17460. +      if (fsize<256)
  17461. +    asm_fprintf(stream, "\tcmpl %s,sp\n"
  17462. +            "\tjcs ___stkovf\n",
  17463. +            (flag_pic==3 ? "a4@(___stk_limit:W)" : (flag_pic==4
  17464. +              ? "a4@(___stk_limit:L)" : "___stk_limit")));
  17465. +      else if(fsize<0x8000)
  17466. +        asm_fprintf (stream, "\tmovel #%d:W,d0\n\tjbsr ___stkchk_d0\n",
  17467. +                 fsize, reg_names[FRAME_POINTER_REGNUM]);
  17468. +      else
  17469. +        asm_fprintf (stream, "\tmovel #%d,d0\n\tjbsr ___stkchk_d0\n",
  17470. +                 fsize, reg_names[FRAME_POINTER_REGNUM]);
  17471. +    }
  17472. +#endif
  17473.    if (frame_pointer_needed)
  17474.      {
  17475. +/* Matthias Fleischer stack-checking and auto-extend for the Amiga */  
  17476. +#ifndef MOTOROLA
  17477. +      if (TARGET_STACKEXTEND)
  17478. +        {
  17479. +      if (fsize<128)
  17480. +        asm_fprintf (stream, "\tcmpl %s,sp\n"
  17481. +                 "\tjcc 0f\n"
  17482. +                 "\tmoveq #%d,d0\n"
  17483. +                 "\tmoveq #0,d1\n"
  17484. +                 "\tjbsr ___stkext_f\n"
  17485. +                 "0:\tlink %s,#%d:W\n",
  17486. +              (flag_pic==3 ? "a4@(___stk_limit:W)" : (flag_pic==4
  17487. +                ? "a4@(___stk_limit:L)" : "___stk_limit")),
  17488. +              fsize, reg_names[FRAME_POINTER_REGNUM], -fsize);
  17489. +      else if(fsize<0x8000)
  17490. +         asm_fprintf (stream, "\tmovel #%d:W,d0\n\tjbsr ___link_%s_d0_f\n",
  17491. +                   fsize, reg_names[FRAME_POINTER_REGNUM]);
  17492. +          else
  17493. +         asm_fprintf (stream, "\tmovel #%d,d0\n\tjbsr ___link_%s_d0_f\n",
  17494. +                   fsize, reg_names[FRAME_POINTER_REGNUM]);
  17495. +    }
  17496. +      else
  17497. +#endif
  17498.        if (fsize == 0 && TARGET_68040)
  17499.      {
  17500.      /* on the 68040, pea + move is faster than link.w 0 */
  17501. @@ -143,6 +185,37 @@ output_function_prologue (stream, size)
  17502.  #endif
  17503.      }
  17504.      }
  17505. +/* Matthias Fleischer stack-checking and auto-extend for the Amiga */  
  17506. +#ifndef MOTOROLA
  17507. +  else if (TARGET_STACKEXTEND)
  17508. +    {
  17509. +      if (!fsize)
  17510. +    asm_fprintf (stream, "\tcmpl %s,sp\n"
  17511. +                 "\tjcc 0f\n"
  17512. +                 "\tmoveq #0,d0\n"
  17513. +                 "\tmoveq #0,d1\n"
  17514. +                 "\tjbsr ___stkext_f\n"
  17515. +                 "0:\n",
  17516. +              (flag_pic==3 ? "a4@(___stk_limit:W)" : (flag_pic==4
  17517. +            ? "a4@(___stk_limit:L)" : "___stk_limit")));
  17518. +      else if (fsize<128)
  17519. +    asm_fprintf (stream, "\tcmpl %s,sp\n"
  17520. +                 "\tjcc 0f\n"
  17521. +                 "\tmoveq #%d,d0\n"
  17522. +                 "\tmoveq #0,d1\n"
  17523. +                 "\tjbsr ___stkext_f\n"
  17524. +                 "0:\taddw #%d,sp\n",
  17525. +              (flag_pic==3 ? "a4@(___stk_limit:W)" : (flag_pic==4
  17526. +            ? "a4@(___stk_limit:L)" : "___stk_limit")),
  17527. +              fsize+4, -(fsize+4));
  17528. +      else if (fsize+4<0x8000)
  17529. +    asm_fprintf (stream, "\tmovel #%d:W,d0\n\tjbsr ___sub_d0_sp_f\n",
  17530. +               fsize + 4, reg_names[FRAME_POINTER_REGNUM]);
  17531. +      else
  17532. +    asm_fprintf (stream, "\tmovel %0I%d,d0\n\tjbsr ___sub_d0_sp_f\n",
  17533. +               fsize + 4, reg_names[FRAME_POINTER_REGNUM]);
  17534. +    }
  17535. +#endif
  17536.    else if (fsize)
  17537.      {
  17538.        /* Adding negative number is faster on the 68040.  */
  17539. @@ -201,6 +274,9 @@ output_function_prologue (stream, size)
  17540.        mask &= ~ (1 << (15 - FRAME_POINTER_REGNUM));
  17541.        num_saved_regs--;
  17542.      }
  17543. +#ifdef PROLOGUE_EXTRA_SAVE
  17544. +  PROLOGUE_EXTRA_SAVE (mask, num_saved_regs);
  17545. +#endif
  17546.  
  17547.  #if NEED_PROBE
  17548.    fprintf (stream, "\ttstl sp@(%d)\n", NEED_PROBE - num_saved_regs * 4);
  17549. @@ -234,7 +310,7 @@ output_function_prologue (stream, size)
  17550.        asm_fprintf (stream, "\tmoveml %0I0x%x,%Rsp@-\n", mask);
  17551.  #endif
  17552.      }
  17553. -  if (flag_pic && current_function_uses_pic_offset_table)
  17554. +  if (flag_pic && (flag_pic < 3) && current_function_uses_pic_offset_table)
  17555.      {
  17556.  #ifdef MOTOROLA
  17557.        asm_fprintf (stream, "\t%Olea (%Rpc, %U_GLOBAL_OFFSET_TABLE_@GOTPC), %s\n",
  17558. @@ -247,6 +323,9 @@ output_function_prologue (stream, size)
  17559.             reg_names[PIC_OFFSET_TABLE_REGNUM]);
  17560.  #endif
  17561.      }
  17562. +#ifdef PROLOGUE_SET_PIC_REG
  17563. +  PROLOGUE_SET_PIC_REG(stream);
  17564. +#endif
  17565.  }
  17566.  
  17567.  /* Return true if this function's epilogue can be output as RTL.  */
  17568. @@ -329,6 +408,9 @@ output_function_epilogue (stream, size)
  17569.          nregs++;
  17570.      mask |= 1 << regno;
  17571.        }
  17572. +#ifdef EPILOGUE_EXTRA_RESTORE
  17573. +  EPILOGUE_EXTRA_RESTORE(mask, nregs);
  17574. +#endif
  17575.    offset = foffset + nregs * 4;
  17576.    if (offset + fsize >= 0x8000
  17577.        && frame_pointer_needed
  17578. @@ -510,6 +592,12 @@ output_function_epilogue (stream, size)
  17579.        fpoffset -= 8;
  17580.      }
  17581.    if (frame_pointer_needed)
  17582. +#ifndef MOTOROLA
  17583. +    if (TARGET_STACKEXTEND && current_function_calls_alloca)
  17584. +      asm_fprintf (stream, "\tjra ___unlk_%s_rts\n",
  17585. +                   reg_names[FRAME_POINTER_REGNUM]);
  17586. +      else
  17587. +#endif
  17588.      fprintf (stream, "\tunlk %s\n",
  17589.           reg_names[FRAME_POINTER_REGNUM]);
  17590.    else if (fsize)
  17591. @@ -533,10 +621,15 @@ output_function_epilogue (stream, size)
  17592.  #endif
  17593.      }
  17594.      }
  17595. +#ifdef EPILOGUE_EXTRA_TEST
  17596. +  EPILOGUE_EXTRA_TEST(stream);
  17597. +#endif
  17598.    if (current_function_pops_args)
  17599.      asm_fprintf (stream, "\trtd %0I%d\n", current_function_pops_args);
  17600.    else
  17601. -    fprintf (stream, "\trts\n");
  17602. +    if (!TARGET_STACKEXTEND ||
  17603. +       !frame_pointer_needed || !current_function_calls_alloca)
  17604. +      fprintf (stream, "\trts\n");
  17605.  }
  17606.  
  17607.  /* Similar to general_operand, but exclude stack_pointer_rtx.  */
  17608. @@ -999,12 +1092,20 @@ legitimize_pic_address (orig, mode, reg)
  17609.    /* First handle a simple SYMBOL_REF or LABEL_REF */
  17610.    if (GET_CODE (orig) == SYMBOL_REF || GET_CODE (orig) == LABEL_REF)
  17611.      {
  17612. +#ifdef LEGITIMATE_BASEREL_OPERAND_P
  17613. +  if (LEGITIMATE_BASEREL_OPERAND_P (orig))
  17614. +    return orig;
  17615. +#endif
  17616. +
  17617.        if (reg == 0)
  17618.      abort ();
  17619.  
  17620. -      pic_ref = gen_rtx (MEM, Pmode,
  17621. -             gen_rtx (PLUS, Pmode,
  17622. -                  pic_offset_table_rtx, orig));
  17623. +      if (flag_pic >= 3)
  17624. +    pic_ref = gen_rtx (PLUS, Pmode, pic_offset_table_rtx, orig);
  17625. +      else
  17626. +        pic_ref = gen_rtx (MEM, Pmode,
  17627. +               gen_rtx (PLUS, Pmode,
  17628. +                    pic_offset_table_rtx, orig));
  17629.        current_function_uses_pic_offset_table = 1;
  17630.        RTX_UNCHANGING_P (pic_ref) = 1;
  17631.        emit_move_insn (reg, pic_ref);
  17632. @@ -2455,6 +2556,10 @@ print_operand_address (file, addr)
  17633.                fprintf (file, ":w");
  17634.              if ((flag_pic == 2) && (breg == pic_offset_table_rtx))
  17635.                fprintf (file, ":l");
  17636. +            if ((flag_pic == 3) && (breg == pic_offset_table_rtx))
  17637. +              fprintf (file, ":W");
  17638. +            if ((flag_pic == 4) && (breg == pic_offset_table_rtx))
  17639. +              fprintf (file, ":L");
  17640.            }
  17641.          if (addr != 0 && ireg != 0)
  17642.            {
  17643. diff -rup --new-file baseline/fsf/gcc/config/m68k/m68k.h amiga/fsf/gcc/config/m68k/m68k.h
  17644. --- baseline/fsf/gcc/config/m68k/m68k.h    Fri Oct 20 16:10:26 1995
  17645. +++ amiga/fsf/gcc/config/m68k/m68k.h    Sat Sep 28 00:00:00 1996
  17646. @@ -918,6 +918,8 @@ extern enum reg_class regno_reg_class[];
  17647.     of a local variable as a function of frame_pointer_needed, which
  17648.     is hard.  */
  17649.  
  17650. +#define SUBTARGET_INITIAL_FP_OFFSET(offset)
  17651. +
  17652.  #define INITIAL_FRAME_POINTER_OFFSET(DEPTH)            \
  17653.  { int regno;                            \
  17654.    int offset = -4;                        \
  17655. @@ -927,6 +929,7 @@ extern enum reg_class regno_reg_class[];
  17656.    for (regno = 0; regno < 16; regno++)                \
  17657.      if (regs_ever_live[regno] && ! call_used_regs[regno])    \
  17658.        offset += 4;                        \
  17659. +  SUBTARGET_INITIAL_FP_OFFSET(offset);                \
  17660.    (DEPTH) = (offset + ((get_frame_size () + 3) & -4)        \
  17661.           + (get_frame_size () == 0 ? 0 : 4));        \
  17662.  }
  17663. diff -rup --new-file baseline/fsf/gcc/config/m68k/m68k.md amiga/fsf/gcc/config/m68k/m68k.md
  17664. --- baseline/fsf/gcc/config/m68k/m68k.md    Tue Nov  7 08:57:30 1995
  17665. +++ amiga/fsf/gcc/config/m68k/m68k.md    Sat Sep 28 00:00:00 1996
  17666. @@ -439,7 +439,11 @@
  17667.    ""
  17668.    "
  17669.  {
  17670. -  if (flag_pic && symbolic_operand (operands[1], SImode)) 
  17671. +  if (flag_pic && symbolic_operand (operands[1], SImode)
  17672. +#ifdef LEGITIMATE_BASEREL_OPERAND_P
  17673. +      && (flag_pic < 3 || !LEGITIMATE_BASEREL_OPERAND_P (operands[1]))
  17674. +#endif
  17675. +     )
  17676.      {
  17677.        /* The source is an address which requires PIC relocation.  
  17678.           Call legitimize_pic_address with the source, mode, and a relocation
  17679. @@ -786,13 +790,18 @@
  17680.  {
  17681.    if (flag_pic && symbolic_operand (operands[1], SImode)) 
  17682.      {
  17683. -      /* The source is an address which requires PIC relocation.  
  17684. -         Call legitimize_pic_address with the source, mode, and a relocation
  17685. -         register (a new pseudo, or the final destination if reload_in_progress
  17686. -         is set).   Then fall through normally */
  17687. -      extern rtx legitimize_pic_address();
  17688. -      rtx temp = reload_in_progress ? operands[0] : gen_reg_rtx (Pmode);
  17689. -      operands[1] = legitimize_pic_address (operands[1], SImode, temp);
  17690. +#ifdef LEGITIMATE_BASEREL_OPERAND_P
  17691. +      if (flag_pic < 3 || !LEGITIMATE_BASEREL_OPERAND_P (operands[1]))
  17692. +#endif
  17693. +      {
  17694. +        /* The source is an address which requires PIC relocation.  
  17695. +           Call legitimize_pic_address with the source, mode, and a relocation
  17696. +           register (a new pseudo, or the final destination if reload_in_progress
  17697. +           is set).   Then fall through normally */
  17698. +        extern rtx legitimize_pic_address();
  17699. +        rtx temp = reload_in_progress ? operands[0] : gen_reg_rtx (Pmode);
  17700. +        operands[1] = legitimize_pic_address (operands[1], SImode, temp);
  17701. +      }
  17702.      }
  17703.  }")
  17704.  
  17705. @@ -2154,8 +2163,9 @@
  17706.  
  17707.        /* These insns can result from reloads to access
  17708.       stack slots over 64k from the frame pointer.  */
  17709. -      if (GET_CODE (operands[2]) == CONST_INT
  17710. -      && INTVAL (operands[2]) + 0x8000 >= (unsigned) 0x10000)
  17711. +      if (((GET_CODE (operands[2]) == CONST_INT
  17712. +       && INTVAL (operands[2]) + 0x8000 >= (unsigned) 0x10000))
  17713. +      || (flag_pic == 4 && operands[1] == pic_offset_table_rtx))
  17714.          return \"move%.l %2,%0\;add%.l %1,%0\";
  17715.  #ifdef SGS
  17716.        if (GET_CODE (operands[2]) == REG)
  17717. @@ -5874,7 +5884,7 @@
  17718.    ""
  17719.    "
  17720.  {
  17721. -  if (flag_pic && GET_CODE (XEXP (operands[0], 0)) == SYMBOL_REF)
  17722. +  if (flag_pic && flag_pic < 3 && GET_CODE (XEXP (operands[0], 0)) == SYMBOL_REF)
  17723.      SYMBOL_REF_FLAG (XEXP (operands[0], 0)) = 1;
  17724.  }")
  17725.  
  17726. @@ -5884,7 +5894,7 @@
  17727.       (match_operand:SI 1 "general_operand" "g"))]
  17728.    ;; Operand 1 not really used on the m68000.
  17729.  
  17730. -  "! flag_pic"
  17731. +  "(! flag_pic || flag_pic >= 3)"
  17732.    "*
  17733.  #if defined (MOTOROLA) && !defined (USE_GAS)
  17734.  #ifdef MOTOROLA_BSR
  17735. @@ -5904,7 +5914,7 @@
  17736.       (match_operand:SI 1 "general_operand" "g"))]
  17737.    ;; Operand 1 not really used on the m68000.
  17738.  
  17739. -  "flag_pic"
  17740. +  "(flag_pic && flag_pic < 3)"
  17741.    "*
  17742.    if (GET_CODE (operands[0]) == MEM 
  17743.        && GET_CODE (XEXP (operands[0], 0)) == SYMBOL_REF)
  17744. @@ -5937,7 +5947,7 @@
  17745.    ""
  17746.    "
  17747.  {
  17748. -  if (flag_pic && GET_CODE (XEXP (operands[1], 0)) == SYMBOL_REF)
  17749. +  if (flag_pic && flag_pic < 3 && GET_CODE (XEXP (operands[1], 0)) == SYMBOL_REF)
  17750.      SYMBOL_REF_FLAG (XEXP (operands[1], 0)) = 1;
  17751.  }")
  17752.  
  17753. @@ -5947,7 +5957,7 @@
  17754.      (call (match_operand:QI 1 "memory_operand" "o")
  17755.            (match_operand:SI 2 "general_operand" "g")))]
  17756.    ;; Operand 2 not really used on the m68000.
  17757. -  "! flag_pic"
  17758. +  "(! flag_pic || flag_pic >= 3)"
  17759.    "*
  17760.  #if defined (MOTOROLA) && !defined (USE_GAS)
  17761.  #ifdef MOTOROLA_BSR
  17762. @@ -5967,7 +5977,7 @@
  17763.      (call (match_operand:QI 1 "memory_operand" "o")
  17764.            (match_operand:SI 2 "general_operand" "g")))]
  17765.    ;; Operand 2 not really used on the m68000.
  17766. -  "flag_pic"
  17767. +  "(flag_pic && flag_pic < 3)"
  17768.    "*
  17769.    if (GET_CODE (operands[1]) == MEM 
  17770.        && GET_CODE (XEXP (operands[1], 0)) == SYMBOL_REF)
  17771. diff -rup --new-file baseline/fsf/gcc/config/m68k/t-amigaos amiga/fsf/gcc/config/m68k/t-amigaos
  17772. --- baseline/fsf/gcc/config/m68k/t-amigaos    Wed Dec 31 17:00:00 1969
  17773. +++ amiga/fsf/gcc/config/m68k/t-amigaos    Sat Sep 28 00:00:00 1996
  17774. @@ -0,0 +1,291 @@
  17775. +# Makefile fragment for AmigaOS target.
  17776. +
  17777. +# We generate three additional things:
  17778. +#
  17779. +# libb/libgcc.a
  17780. +#    A base relative version of libgcc.a which is used when compiling and
  17781. +#    linking with the '-resident' option.
  17782. +#
  17783. +# libb/libm020/libgcc.a
  17784. +#    An accelerated base relative version of libgcc.a which is used when
  17785. +#    compiling and linking with the '-mc68020' & '-resident' options.
  17786. +#
  17787. +# libm020/libgcc.a
  17788. +#    An accelerated version of libgcc.a which is used when compiling and
  17789. +#    linking with the '-mc68020' option.
  17790. +#
  17791. +
  17792. +XGCC = xgcc $(PIPE)
  17793. +GCC_FOR_TARGET = ./$(XGCC) -B./
  17794. +
  17795. +# The standard additional target flags for the compiler.
  17796. +
  17797. +T_CFLAGS =
  17798. +
  17799. +# Each compilation environment (Manx, Dice, GCC, SAS/C, etc) provides its
  17800. +# own equivalent of the UNIX /usr/include tree.  For gcc, the standard headers
  17801. +# are in /ade/include and system specific headers are in /ade/os-include.
  17802. +# Use these paths for fixincludes.
  17803. +
  17804. +SYSTEM_HEADER_DIR = /ade/include
  17805. +OTHER_FIXINCLUDES_DIRS = /ade/os-include
  17806. +
  17807. +# We don't need a libgcc1, it's all in ixemul.library
  17808. +
  17809. +LIBGCC1 = libgcc1.null
  17810. +CROSS_LIBGCC1 = libgcc1.null
  17811. +
  17812. +# Flags to use when compiling the base relative version of libgcc.a.
  17813. +# Explicitly force -resident in the compilation flags.
  17814. +
  17815. +LIBBGCC2_CFLAGS = $(LIBGCC2_CFLAGS) -resident
  17816. +
  17817. +# Flags to use when compiling the 68020 versions of libgcc.a.
  17818. +# Explicitly force -mc68020 in the compilation flags.
  17819. +
  17820. +LIBM020GCC2_CFLAGS = $(LIBGCC2_CFLAGS) -mc68020
  17821. +
  17822. +# Flags to use when compiling the base relative 68020 versions of libgcc.a.
  17823. +# Explicitly force -mc68020 & -resident in the compilation flags.
  17824. +
  17825. +LIBBM020GCC2_CFLAGS = $(LIBGCC2_CFLAGS) -resident -mc68020
  17826. +
  17827. +# Additional target dependent options for compiling libgcc.a.  This just
  17828. +# ensures that we don't compile libgcc* with anything other than a
  17829. +# fixed stack.
  17830. +
  17831. +TARGET_LIBGCC2_CFLAGS = -mfixedstack
  17832. +
  17833. +# Build the base relative library and accelerated libraries.
  17834. +# It is later copied into /ade/lib/gcc-lib/amigaos/<version>/libb/libgcc.a, whereas
  17835. +# libgcc.a is copied into /ade/lib/gcc-lib/amigaos/<version>/libgcc.a.
  17836. +# Accelerated libraries are copied into same directories, with an extra dir level
  17837. +# libm020, thus libb/libm020. It doesn't work very well to define one of the
  17838. +# EXTRA_* macros to contain libb/libgcc.a, particularly for doing "make stageN"
  17839. +# or "make install".
  17840. +
  17841. +GCC_PARTS=$(GCC_PASSES) libgcc.a libb/libgcc.a libm020/libgcc.a \
  17842. +        libb/libm020/libgcc.a $(EXTRA_PROGRAMS) $(USE_COLLECT2) $(EXTRA_PARTS)
  17843. +
  17844. +# Add install_libbgcc to normal define of INSTALL_LIBGCC.
  17845. +
  17846. +INSTALL_LIBGCC = install-libgcc install-libbgcc install-libm020gcc install-libbm020gcc
  17847. +
  17848. +# This includes the knowledge that target amigaos doesn't need libgcc1.a
  17849. +
  17850. +libb/libgcc.a: libgcc1.null libgcc2.c libgcc2.ready $(CONFIG_H) \
  17851. +   $(LIB2FUNCS_EXTRA) machmode.h longlong.h gbl-ctors.h config.status
  17852. +# Actually build it in tmplibbgcc.a, then rename at end,
  17853. +# so that libb/libgcc.a itself remains nonexistent if compilation is aborted.
  17854. +    -rm -f tmplibbgcc.a
  17855. +# -e causes any failing command to make this rule fail.
  17856. +# -e doesn't work in certain shells, so we test $$? as well.
  17857. +    set -e; \
  17858. +    for name in $(LIB2FUNCS); \
  17859. +    do \
  17860. +      echo $${name}; \
  17861. +      $(GCC_FOR_TARGET) $(LIBBGCC2_CFLAGS) $(INCLUDES) -c -DL$${name} \
  17862. +          $(srcdir)/libgcc2.c -o $${name}.o; \
  17863. +      if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17864. +      $(AR) $(AR_FLAGS) tmplibbgcc.a $${name}.o; \
  17865. +      rm -f $${name}.o; \
  17866. +    done
  17867. +# Some shells crash when a loop has no items.
  17868. +# So make sure there is always at least one--`..'.
  17869. +# Then ignore it.
  17870. +# We don't use -e here because there are if statements
  17871. +# that should not make the command give up when the if condition is false.
  17872. +# Instead, we test for failure after each command where it matters.
  17873. +    -for file in .. $(LIB2FUNCS_EXTRA); \
  17874. +    do \
  17875. +      if [ x$${file} != x.. ]; then \
  17876. +        name=`echo $${file} | sed -e 's/[.]c$$//' -e 's/[.]asm$$//'`; \
  17877. +        echo $${name}; \
  17878. +        if [ $${name}.asm = $${file} ]; then \
  17879. +          cp $${file} $${name}.s || exit 1; file=$${name}.s; \
  17880. +        else true; fi; \
  17881. +        $(GCC_FOR_TARGET) $(LIBBGCC2_CFLAGS) $(INCLUDES) -c $${file}; \
  17882. +        if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17883. +        $(AR) $(AR_FLAGS) tmplibbgcc.a $${name}.o; \
  17884. +        rm -f $${name}.[so]; \
  17885. +      else true; \
  17886. +      fi; \
  17887. +    done
  17888. +    -if $(RANLIB_TEST) ; then $(RANLIB) tmplibbgcc.a; else true; fi
  17889. +    -if [ -d libb ] ; then true ; else mkdir libb ; fi
  17890. +    mv tmplibbgcc.a libb/libgcc.a
  17891. +
  17892. +
  17893. +install-libbgcc: libb/libgcc.a install-dir
  17894. +    -if [ -d $(libsubdir)/libb ] ; then true ; else mkdir $(libsubdir)/libb ; fi
  17895. +    -if [ -f libb/libgcc.a ] ; then \
  17896. +      rm -f $(libsubdir)/libb/libgcc.a; \
  17897. +      $(INSTALL_DATA) libb/libgcc.a $(libsubdir)/libb/libgcc.a; \
  17898. +      if $(RANLIB_TEST) ; then \
  17899. +        (cd $(libsubdir)/libb; $(RANLIB) libgcc.a); else true; fi; \
  17900. +      chmod a-x $(libsubdir)/libb/libgcc.a; \
  17901. +    else true; fi
  17902. +
  17903. +libm020/libgcc.a: libgcc1.null libgcc2.c libgcc2.ready $(CONFIG_H) \
  17904. +   $(LIB2FUNCS_EXTRA) machmode.h longlong.h gbl-ctors.h config.status
  17905. +# Actually build it in tmplibm020gcc.a, then rename at end,
  17906. +# so that libm020/libgcc.a itself remains nonexistent if compilation is aborted.
  17907. +    -rm -f tmplibm020gcc.a
  17908. +# -e causes any failing command to make this rule fail.
  17909. +# -e doesn't work in certain shells, so we test $$? as well.
  17910. +    set -e; \
  17911. +    for name in $(LIB2FUNCS); \
  17912. +    do \
  17913. +      echo $${name}; \
  17914. +      $(GCC_FOR_TARGET) $(LIBM020GCC2_CFLAGS) $(INCLUDES) -c -DL$${name} \
  17915. +          $(srcdir)/libgcc2.c -o $${name}.o; \
  17916. +      if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17917. +      $(AR) $(AR_FLAGS) tmplibm020gcc.a $${name}.o; \
  17918. +      rm -f $${name}.o; \
  17919. +    done
  17920. +# Some shells crash when a loop has no items.
  17921. +# So make sure there is always at least one--`..'.
  17922. +# Then ignore it.
  17923. +# We don't use -e here because there are if statements
  17924. +# that should not make the command give up when the if condition is false.
  17925. +# Instead, we test for failure after each command where it matters.
  17926. +    -for file in .. $(LIB2FUNCS_EXTRA); \
  17927. +    do \
  17928. +      if [ x$${file} != x.. ]; then \
  17929. +        name=`echo $${file} | sed -e 's/[.]c$$//' -e 's/[.]asm$$//'`; \
  17930. +        echo $${name}; \
  17931. +        if [ $${name}.asm = $${file} ]; then \
  17932. +          cp $${file} $${name}.s || exit 1; file=$${name}.s; \
  17933. +        else true; fi; \
  17934. +        $(GCC_FOR_TARGET) $(LIBBGCC2_CFLAGS) $(INCLUDES) -c $${file}; \
  17935. +        if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17936. +        $(AR) $(AR_FLAGS) tmplibm020gcc.a $${name}.o; \
  17937. +        rm -f $${name}.[so]; \
  17938. +      else true; \
  17939. +      fi; \
  17940. +    done
  17941. +    -if $(RANLIB_TEST) ; then $(RANLIB) tmplibm020gcc.a; else true; fi
  17942. +    -if [ -d libm020 ] ; then true ; else mkdir libm020 ; fi
  17943. +    mv tmplibm020gcc.a libm020/libgcc.a
  17944. +
  17945. +
  17946. +install-libm020gcc: libm020/libgcc.a install-dir
  17947. +    -if [ -d $(libsubdir)/libm020 ] ; then true ; else mkdir $(libsubdir)/libm020 ; fi
  17948. +    -if [ -f libm020/libgcc.a ] ; then \
  17949. +      rm -f $(libsubdir)/libm020/libgcc.a; \
  17950. +      $(INSTALL_DATA) libm020/libgcc.a $(libsubdir)/libm020/libgcc.a; \
  17951. +      if $(RANLIB_TEST) ; then \
  17952. +        (cd $(libsubdir)/libm020; $(RANLIB) libgcc.a); else true; fi; \
  17953. +      chmod a-x $(libsubdir)/libm020/libgcc.a; \
  17954. +    else true; fi
  17955. +
  17956. +libb/libm020/libgcc.a: libgcc1.null libgcc2.c libgcc2.ready $(CONFIG_H) \
  17957. +   $(LIB2FUNCS_EXTRA) machmode.h longlong.h gbl-ctors.h config.status
  17958. +# Actually build it in tmplibbm020gcc.a, then rename at end,
  17959. +# so that libb/libm020/libgcc.a itself remains nonexistent if compilation is aborted.
  17960. +    -rm -f tmplibbm020gcc.a
  17961. +# -e causes any failing command to make this rule fail.
  17962. +# -e doesn't work in certain shells, so we test $$? as well.
  17963. +    set -e; \
  17964. +    for name in $(LIB2FUNCS); \
  17965. +    do \
  17966. +      echo $${name}; \
  17967. +      $(GCC_FOR_TARGET) $(LIBBM020GCC2_CFLAGS) $(INCLUDES) -c -DL$${name} \
  17968. +          $(srcdir)/libgcc2.c -o $${name}.o; \
  17969. +      if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17970. +      $(AR) $(AR_FLAGS) tmplibbm020gcc.a $${name}.o; \
  17971. +      rm -f $${name}.o; \
  17972. +    done
  17973. +# Some shells crash when a loop has no items.
  17974. +# So make sure there is always at least one--`..'.
  17975. +# Then ignore it.
  17976. +# We don't use -e here because there are if statements
  17977. +# that should not make the command give up when the if condition is false.
  17978. +# Instead, we test for failure after each command where it matters.
  17979. +    -for file in .. $(LIB2FUNCS_EXTRA); \
  17980. +    do \
  17981. +      if [ x$${file} != x.. ]; then \
  17982. +        name=`echo $${file} | sed -e 's/[.]c$$//' -e 's/[.]asm$$//'`; \
  17983. +        echo $${name}; \
  17984. +        if [ $${name}.asm = $${file} ]; then \
  17985. +          cp $${file} $${name}.s || exit 1; file=$${name}.s; \
  17986. +        else true; fi; \
  17987. +        $(GCC_FOR_TARGET) $(LIBBGCC2_CFLAGS) $(INCLUDES) -c $${file}; \
  17988. +        if [ $$? -eq 0 ] ; then true; else exit 1; fi; \
  17989. +        $(AR) $(AR_FLAGS) tmplibbm020gcc.a $${name}.o; \
  17990. +        rm -f $${name}.[so]; \
  17991. +      else true; \
  17992. +      fi; \
  17993. +    done
  17994. +    -if $(RANLIB_TEST) ; then $(RANLIB) tmplibbm020gcc.a; else true; fi
  17995. +    -if [ -d libb ] ; then true ; else mkdir libb ; fi
  17996. +    -if [ -d libb/libm020 ] ; then true ; else mkdir libb/libm020 ; fi
  17997. +    mv tmplibbm020gcc.a libb/libm020/libgcc.a
  17998. +
  17999. +
  18000. +install-libbm020gcc: libb/libm020/libgcc.a install-dir
  18001. +    -if [ -d $(libsubdir)/libb/libm020 ] ; then true ; else mkdir $(libsubdir)/libb/libm020 ; fi
  18002. +    -if [ -f libb/libm020/libgcc.a ] ; then \
  18003. +      rm -f $(libsubdir)/libb/libm020/libgcc.a; \
  18004. +      $(INSTALL_DATA) libb/libm020/libgcc.a $(libsubdir)/libb/libm020/libgcc.a; \
  18005. +      if $(RANLIB_TEST) ; then \
  18006. +        (cd $(libsubdir)/libb/libm020; $(RANLIB) libgcc.a); else true; fi; \
  18007. +      chmod a-x $(libsubdir)/libb/libm020/libgcc.a; \
  18008. +    else true; fi
  18009. +
  18010. +# When making one of the stage<N> dirs, we need to make subdirs for
  18011. +# additional libraries, and copy them there. base-relative libraries
  18012. +# and accelerated libraries are preserved through stages.
  18013. +
  18014. +EXTRA_STAGE1_TARGETS = stage1-libamiga
  18015. +EXTRA_STAGE2_TARGETS = stage2-libamiga
  18016. +EXTRA_STAGE3_TARGETS = stage3-libamiga
  18017. +EXTRA_STAGE4_TARGETW = stage4-libamiga
  18018. +
  18019. +stage1-libamiga:
  18020. +    -if [ -d stage1 ] ; then true ; else mkdir stage1 ; fi
  18021. +    -if [ -d stage1/libb ] ; then true ; else mkdir stage1/libb ; fi
  18022. +    -if [ -d stage1/libb/libm020 ] ; then true ; else mkdir stage1/libb/libm020 ; fi
  18023. +    -if [ -d stage1/libm020 ] ; then true ; else mkdir stage1/libm020 ; fi
  18024. +    -cp libb/libgcc.a stage1/libb/libgcc.a
  18025. +    -cp libb/libm020/libgcc.a stage1/libb/libm020/libgcc.a
  18026. +    -cp libm020/libgcc.a stage1/libm020/libgcc.a
  18027. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage1/libb/libgcc.i; else true; fi
  18028. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage1/libb/libm020/libgcc.a; else true; fi
  18029. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage1/libm020/libgcc.a; else true; fi
  18030. +
  18031. +stage2-libamiga:
  18032. +    -if [ -d stage2 ] ; then true ; else mkdir stage2 ; fi
  18033. +    -if [ -d stage2/libb ] ; then true ; else mkdir stage2/libb ; fi
  18034. +    -if [ -d stage2/libb/libm020 ] ; then true ; else mkdir stage2/libb/libm020 ; fi
  18035. +    -if [ -d stage2/libm020 ] ; then true ; else mkdir stage2/libm020 ; fi
  18036. +    -cp libb/libgcc.a stage2/libb/libgcc.a
  18037. +    -cp libb/libm020/libgcc.a stage2/libb/libm020/libgcc.a
  18038. +    -cp libm020/libgcc.a stage2/libm020/libgcc.a
  18039. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage2/libb/libgcc.a; else true; fi
  18040. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage2/libb/libm020/libgcc.a; else true; fi
  18041. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage2/libm020/libgcc.a; else true; fi
  18042. +
  18043. +stage3-libamiga:
  18044. +    -if [ -d stage3 ] ; then true ; else mkdir stage3 ; fi
  18045. +    -if [ -d stage3/libb ] ; then true ; else mkdir stage3/libb ; fi
  18046. +    -if [ -d stage3/libb/libm020 ] ; then true ; else mkdir stage3/libb/libm020 ; fi
  18047. +    -if [ -d stage3/libm020 ] ; then true ; else mkdir stage3/libm020 ; fi
  18048. +    -cp libb/libgcc.a stage3/libb/libgcc.a
  18049. +    -cp libb/libm020/libgcc.a stage3/libb/libm020/libgcc.a
  18050. +    -cp libm020/libgcc.a stage3/libm020/libgcc.a
  18051. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage3/libb/libgcc.a; else true; fi
  18052. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage3/libb/libm020/libgcc.a; else true; fi
  18053. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage3/libm020/libgcc.a; else true; fi
  18054. +
  18055. +stage4-libamiga:
  18056. +    -if [ -d stage4 ] ; then true ; else mkdir stage4 ; fi
  18057. +    -if [ -d stage4/libb ] ; then true ; else mkdir stage4/libb ; fi
  18058. +    -if [ -d stage4/libb/libm020 ] ; then true ; else mkdir stage4/libb/libm020 ; fi
  18059. +    -if [ -d stage4/libm020 ] ; then true ; else mkdir stage4/libm020 ; fi
  18060. +    -cp libb/libgcc.a stage4/libb/libgcc.a
  18061. +    -cp libb/libm020/libgcc.a stage4/libb/libm020/libgcc.a
  18062. +    -cp libm020/libgcc.a stage4/libm020/libgcc.a
  18063. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage4/libb/libgcc.a; else true; fi
  18064. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage4/libb/libm020/libgcc.a; else true; fi
  18065. +    -if $(RANLIB_TEST) ; then $(RANLIB) stage4/libm020/libgcc.a; else true; fi
  18066. diff -rup --new-file baseline/fsf/gcc/config/m68k/x-amigaos amiga/fsf/gcc/config/m68k/x-amigaos
  18067. --- baseline/fsf/gcc/config/m68k/x-amigaos    Wed Dec 31 17:00:00 1969
  18068. +++ amiga/fsf/gcc/config/m68k/x-amigaos    Sat Sep 28 00:00:00 1996
  18069. @@ -0,0 +1,51 @@
  18070. +# Makefile fragment for AmigaOS host
  18071. +
  18072. +# Note: It doesn't do any good to try to define prefix or local_prefix
  18073. +# in the host overrides because configure will just change them back.
  18074. +# You either have to give an appropriate option to configure or live with
  18075. +# an Amiga specific patch to configure.  See the note in configure.  -fnf
  18076. +
  18077. +# Building under amigaos almost certainly requires an already working gcc.
  18078. +# To bootstrap without "-pipe" do "make PIPE=".
  18079. +
  18080. +CC = gcc
  18081. +
  18082. +# Build residentable versions of the gcc executables by default.  Use
  18083. +# "make RESIDENT=" to build non-residentable versions.
  18084. +# Note:  This failed during bootstrapping of 2.5.5.
  18085. +
  18086. +#RESIDENT = -resident
  18087. +
  18088. +# Disable -pipe for now since I had problems bootstrapping gcc 2.5.5 with
  18089. +# it. (fnf)
  18090. +#PIPE = -pipe
  18091. +
  18092. +# Allow the user to override the default host optimization with gcc, or if the
  18093. +# host compiler is not gcc and doesn't understand -O<N>.
  18094. +
  18095. +X_OPTIMIZE = -O2 -fomit-frame-pointer
  18096. +
  18097. +# The standard additional host flags for the compiler.
  18098. +
  18099. +X_CFLAGS = $(X_OPTIMIZE) $(RESIDENT) $(PIPE)
  18100. +
  18101. +# Additional host flags that are not used when compiling with GCC_FOR_TARGET,
  18102. +# such as when compiling the libgcc* runtime archives.
  18103. +
  18104. +XCFLAGS = -mstackextend
  18105. +
  18106. +# Man pages get a wierd suffix...
  18107. +
  18108. +manext = .0
  18109. +
  18110. +# Ranlib does exist, but may not be in a path where the default RANLIB_TEST
  18111. +# expects it, so just force it to true.
  18112. +
  18113. +RANLIB_TEST = true
  18114. +
  18115. +# Extra objects that get compiled and linked to the C preprocessor
  18116. +
  18117. +EXTRA_CPP_OBJS = amigacpp.o
  18118. +
  18119. +# Build supplimentary Amiga host support file for C preprocessor
  18120. +amigacpp.o: amigacpp.c
  18121. diff -rup --new-file baseline/fsf/gcc/config/m68k/xm-amigaos.h amiga/fsf/gcc/config/m68k/xm-amigaos.h
  18122. --- baseline/fsf/gcc/config/m68k/xm-amigaos.h    Wed Dec 31 17:00:00 1969
  18123. +++ amiga/fsf/gcc/config/m68k/xm-amigaos.h    Sat Sep 28 00:00:00 1996
  18124. @@ -0,0 +1,251 @@
  18125. +/* Configuration for GNU C-compiler for Commodore Amiga, running AmigaOS.
  18126. +   Copyright (C) 1992 Free Software Foundation, Inc.
  18127. +   Contributed by Markus M. Wild (wild@amiga.physik.unizh.ch).
  18128. +
  18129. +This file is part of GNU CC.
  18130. +
  18131. +GNU CC is free software; you can redistribute it and/or modify
  18132. +it under the terms of the GNU General Public License as published by
  18133. +the Free Software Foundation; either version 2, or (at your option)
  18134. +any later version.
  18135. +
  18136. +GNU CC is distributed in the hope that it will be useful,
  18137. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  18138. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18139. +GNU General Public License for more details.
  18140. +
  18141. +You should have received a copy of the GNU General Public License
  18142. +along with GNU CC; see the file COPYING.  If not, write to
  18143. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  18144. +
  18145. +/* first include the generic header, then modify some parts.. */
  18146. +
  18147. +#include "m68k/xm-m68k.h"
  18148. +
  18149. +#ifndef _FCNTL_H_
  18150. +#include <fcntl.h>
  18151. +#endif
  18152. +
  18153. +/* Define various things that the Amiga host has. */
  18154. +
  18155. +#define HAVE_VPRINTF
  18156. +#define HAVE_PUTENV
  18157. +#define HAVE_STRERROR
  18158. +#define HAVE_ATEXIT
  18159. +#define HAVE_RENAME
  18160. +
  18161. +/* The Amiga has case independent filesystems.  A good example of where this
  18162. +   causes problems is the conflict between the C include file <string.h> and
  18163. +   the C++ include file <String.h>, where the C++ include file dir is
  18164. +   searched first and thus causes includes of <string.h> to include
  18165. +   <String.h> instead.  There is an undocumented feature of gcc which uses a
  18166. +   file called header.gcc in the first directory to redirect includes to a
  18167. +   different directory, but it has the disadvantages in that it requires an
  18168. +   absolute pathname to the file being redirected to, and also needs to be
  18169. +   maintained and updated for each new file conflict.  An alternate method
  18170. +   to solve this problem is to define the macro OPEN_CASE_SENSITIVE as the
  18171. +   name of the function that takes the same args as open() and does case
  18172. +   dependent opens. */
  18173. +
  18174. +#ifdef O_CASE    /* ixemul feature to be implemented */
  18175. +#define OPEN_CASE_SENSITIVE(fn,flags,mode) open((fn),(flags)|O_CASE,(mode))
  18176. +#else
  18177. +#define OPEN_CASE_SENSITIVE amiga_open_case_sensitive
  18178. +#endif
  18179. +
  18180. +extern int amiga_open_case_sensitive ();
  18181. +
  18182. +/* Define routines that parse a --priority option, set a default priority,
  18183. +   and actually change the priority. */
  18184. +
  18185. +#define GET_DEFAULT_PRIORITY amiga_get_default_priority
  18186. +extern void amiga_get_default_priority ();
  18187. +
  18188. +#define PARSE_PRIORITY amiga_parse_priority
  18189. +extern int amiga_parse_priority ();
  18190. +
  18191. +#define SET_PRIORITY amiga_set_priority
  18192. +extern void amiga_set_priority ();
  18193. +
  18194. +/* This macro returns whether a pathname is absolute */
  18195. +
  18196. +#define ABSOLUTE_FILENAME(begin,length) amiga_abs_filename((begin),(length))
  18197. +extern int amiga_abs_filename ();
  18198. +
  18199. +/* On the Amiga, there are two pathname separators, '/' (DIR_SEPARATOR)
  18200. +   and ':' (VOL_SEPARATOR).  DIR_SEPARATOR defaults to the correct
  18201. +   character, so we don't have to explicitly set it. */
  18202. +
  18203. +#define VOL_SEPARATOR ':'
  18204. +
  18205. +/* Amiga specific headers, such as from the Native Developer Update kits,
  18206. +   go in SYSTEM_INCLUDE_DIR.  STANDARD_INCLUDE_DIR is the equivalent of
  18207. +   Unix "/usr/include".  All other include paths are set in Makefile. */
  18208. +
  18209. +#define SYSTEM_INCLUDE_DIR    "/ade/os-include"
  18210. +#define STANDARD_INCLUDE_DIR    "/ade/include"
  18211. +
  18212. +/* Fork one piped subcommand.  SEARCH_FLAG is the system call to use
  18213. +   (either execv or execvp).  ARGV is the arg vector to use.
  18214. +   NOT_LAST is nonzero if this is not the last subcommand
  18215. +   (i.e. its output should be piped to the next one.)  */
  18216. +
  18217. +#define PEXECUTE(SEARCH_FLAG,PROGRAM,ARGV,NOT_LAST) \
  18218. +({int (*_func)() = (SEARCH_FLAG ? execv : execvp);            \
  18219. +  int _pid;                                \
  18220. +  int _pdes[2];                                \
  18221. +  int _input_desc = last_pipe_input;                    \
  18222. +  int _output_desc = STDOUT_FILE_NO;                    \
  18223. +  int _retries, _sleep_interval, _result;                \
  18224. +                                    \
  18225. +  /* If this isn't the last process, make a pipe for its output,    \
  18226. +     and record it as waiting to be the input to the next process.  */    \
  18227. +                                    \
  18228. +  if (NOT_LAST)                                \
  18229. +    {                                    \
  18230. +      if (pipe (_pdes) < 0)                        \
  18231. +    pfatal_with_name ("pipe");                    \
  18232. +      _output_desc = _pdes[WRITE_PORT];                    \
  18233. +      last_pipe_input = _pdes[READ_PORT];                \
  18234. +    }                                    \
  18235. +  else                                    \
  18236. +    last_pipe_input = STDIN_FILE_NO;                    \
  18237. +                                    \
  18238. +  /* Fork a subprocess; wait and retry if it fails.  */            \
  18239. +  _sleep_interval = 1;                            \
  18240. +  for (_retries = 0; _retries < 4; _retries++)                \
  18241. +    {                                    \
  18242. +      _pid = vfork ();                            \
  18243. +      if (_pid >= 0)                            \
  18244. +    break;                                \
  18245. +      sleep (_sleep_interval);                        \
  18246. +      _sleep_interval *= 2;                        \
  18247. +    }                                    \
  18248. +                                    \
  18249. +  switch (_pid)                                \
  18250. +    {                                    \
  18251. +    case -1:                                \
  18252. +      pfatal_with_name ("vfork");                    \
  18253. +      /* NOTREACHED */                            \
  18254. +      _result = 0;                            \
  18255. +      break;                                \
  18256. +                                    \
  18257. +    case 0: /* child */                            \
  18258. +      /* Move the input and output pipes into place, if nec.  */    \
  18259. +      if (_input_desc != STDIN_FILE_NO)                    \
  18260. +    {                                \
  18261. +      close (STDIN_FILE_NO);                    \
  18262. +      dup (_input_desc);                        \
  18263. +      close (_input_desc);                        \
  18264. +    }                                \
  18265. +      if (_output_desc != STDOUT_FILE_NO)                \
  18266. +    {                                \
  18267. +      close (STDOUT_FILE_NO);                    \
  18268. +      dup (_output_desc);                        \
  18269. +      close (_output_desc);                        \
  18270. +    }                                \
  18271. +                                    \
  18272. +      /* Close the parent's descs that aren't wanted here.  */        \
  18273. +      if (last_pipe_input != STDIN_FILE_NO)                \
  18274. +    close (last_pipe_input);                    \
  18275. +                                    \
  18276. +      /* Exec the program.  */                        \
  18277. +      (*_func) (PROGRAM, ARGV);                        \
  18278. +      perror_exec (PROGRAM);                        \
  18279. +      exit (-1);                            \
  18280. +      /* NOTREACHED */                            \
  18281. +      _result = 0;                            \
  18282. +      break;                                \
  18283. +                                    \
  18284. +    default:                                \
  18285. +      /* In the parent, after forking.                    \
  18286. +     Close the descriptors that we made for this child.  */        \
  18287. +      if (_input_desc != STDIN_FILE_NO)                    \
  18288. +    close (_input_desc);                        \
  18289. +      if (_output_desc != STDOUT_FILE_NO)                \
  18290. +    close (_output_desc);                        \
  18291. +                                    \
  18292. +      /* Return child's process number.  */                \
  18293. +      _result = _pid;                            \
  18294. +      break;                                \
  18295. +    }                                     \
  18296. +_result; })                                \
  18297. +
  18298. +#define PEXECUTE_RESULT(STATUS, COMMAND) \
  18299. +  ({ wait (& STATUS); })
  18300. +
  18301. +/* the following macros are stolen more or less from xm-vms.h ... */
  18302. +
  18303. +/* This macro is used to help compare filenames in cp-lex.c.  */
  18304. +
  18305. +#define FILE_NAME_NONDIRECTORY(C)                \
  18306. +({                                \
  18307. +   extern char *rindex();                    \
  18308. +   char * pnt_ = (C), * pnt1_;                    \
  18309. +   pnt1_ = rindex (pnt_, '/');                     \
  18310. +   pnt1_ = (pnt1_ == 0 ? rindex (pnt_, ':') : pnt1_);        \
  18311. +   (pnt1_ == 0 ? pnt_ : pnt1_ + 1);                \
  18312. + })
  18313. +
  18314. +/* Macro to generate the name of the cross reference file.  The standard
  18315. +   one does not work, since it was written assuming that the conventions
  18316. +   of a unix style filesystem will work on the host system.
  18317. +   Contrary to VMS, I'm using the original unix filename, there's no reason
  18318. +   not to use this under AmigaOS. */
  18319. +
  18320. +#define XREF_FILE_NAME(BUFF, NAME)    \
  18321. +  s = FILE_NAME_NONDIRECTORY (NAME);            \
  18322. +  if (s == NAME) sprintf(BUFF, ".%s.gxref", NAME);    \
  18323. +  else {                        \
  18324. +    unsigned char ch = *s; /* could be Latin1 char.. */    \
  18325. +    /* temporary: cut the filename from the directory */\
  18326. +    *s = 0;                        \
  18327. +    sprintf (BUFF, "%s.%c%s.gxref", NAME, ch, s+1);    \
  18328. +    /* and restore the filename */            \
  18329. +    *s = ch;                        \
  18330. +  }                            \
  18331. +
  18332. +/* Macro that is used in cp-xref.c to determine whether a file name is
  18333. +   absolute or not.
  18334. +
  18335. +   This checks for both, '/' as first character, since we're running under
  18336. +   ixemul.library which provides for this unix'ism, and for the usual 
  18337. +   logical-terminator, ':', somewhere in the filename. */
  18338. +
  18339. +#define FILE_NAME_ABSOLUTE_P(NAME) (NAME[0] == '/' || index(NAME, ':'))
  18340. +
  18341. +/* the colon conflicts with the name space of logicals */
  18342. +
  18343. +#define PATH_SEPARATOR ','
  18344. +
  18345. +/* Phil.B 17-Apr-95 Added stack checking code submitted by Kriton Kyrimis
  18346. +   (kyrimis@theseas.ntua.gr) on 10-Feb-95, modified for inclusion into gcc
  18347. +
  18348. +   What stackcheck does is to add the following code at the beginning of
  18349. +   each function:
  18350. +    cmpl __StackBottom,sp
  18351. +    bccs .+8
  18352. +    jmp __StackOverflow
  18353. +
  18354. +   _StackBottom and _StackOverflow() are defined in stackchecksetup.c.
  18355. +   _StackBottom is set to the bottom of the stack plus some leeway for
  18356. +   subroutine arguments (128 bytes).  _StackOverflow() sets the stack
  18357. +   pointer to a sane value, prints an error message and exits.
  18358. +
  18359. +   Even with stack checking, you cannot be completely safe, as overflows
  18360. +   are detected on function entry, rather than during function execution.
  18361. +   E.g.,
  18362. +    crash(){
  18363. +      char scribble[100000];
  18364. +      int i;
  18365. +      for (i=0; i<100000; i++) scribble[i]=0;
  18366. +      check(scribble);
  18367. +    }
  18368. +    check(char *x){}
  18369. +   In the above example, stack overflow and its side-effects will occur in
  18370. +   crash(), but it will be detected in check(), when it is too late. (The
  18371. +   same thing happens with SAS/C's stack checking, BTW.)
  18372. +*/
  18373. +
  18374. +/* #defined AMIGA_STACK_CHECKING */
  18375. diff -rup --new-file baseline/fsf/gcc/config/rs6000/amigaos.h amiga/fsf/gcc/config/rs6000/amigaos.h
  18376. --- baseline/fsf/gcc/config/rs6000/amigaos.h    Wed Dec 31 17:00:00 1969
  18377. +++ amiga/fsf/gcc/config/rs6000/amigaos.h    Sat Sep 28 00:00:00 1996
  18378. @@ -0,0 +1,64 @@
  18379. +/* Definitions of target machine for GNU compiler.  Amiga powerpc version.
  18380. +   Copyright (C) 1996 Free Software Foundation, Inc.
  18381. +
  18382. +This file is part of GNU CC.
  18383. +
  18384. +GNU CC is free software; you can redistribute it and/or modify
  18385. +it under the terms of the GNU General Public License as published by
  18386. +the Free Software Foundation; either version 2, or (at your option)
  18387. +any later version.
  18388. +
  18389. +GNU CC is distributed in the hope that it will be useful,
  18390. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  18391. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18392. +GNU General Public License for more details.
  18393. +
  18394. +You should have received a copy of the GNU General Public License
  18395. +along with GNU CC; see the file COPYING.  If not, write to
  18396. +the Free Software Foundation, 59 Temple Place - Suite 330,
  18397. +Boston, MA 02111-1307, USA.  */
  18398. +
  18399. +#include "rs6000/sysv4.h"
  18400. +
  18401. +/* Enable some special Amiga only features.  FIXME: This define should
  18402. +   be eliminated in favor of more general ways to enable the features. */
  18403. +
  18404. +#define TARGET_AMIGAOS
  18405. +
  18406. +#undef CPP_PREDEFINES
  18407. +#define CPP_PREDEFINES "-DPPC -Damiga -Damigaos -DMCH_AMIGA -DAMIGA -Asystem(amigaos) --Acpu(powerpc) -Amachine(powerpc)"
  18408. +
  18409. +/* Choose the right startup file, depending on whether we use base relative
  18410. +   code, base relative code with automatic relocation (-resident), or plain
  18411. +   crt0.o. 
  18412. +  
  18413. +   Profiling is currently only available for plain startup.
  18414. +   mcrt0.o does not (yet) exist. */
  18415. +
  18416. +#undef STARTFILE_SPEC
  18417. +#define STARTFILE_SPEC \
  18418. + "%{!noixemul:%{resident:rcrt0.o%s}%{!resident:%{!fbaserel:%{pg:gcrt0.o%s}%{!pg:%{p:mcrt0.o%s}%{!p:crt0.o%s}}}\
  18419. +%{fbaserel:%{pg:bgcrt0.o%s}%{!pg:%{p:bmcrt0.o%s}%{!p:bcrt0.o%s}}}}}\
  18420. +%{noixemul:%{resident:libnix/nrcrt0.o%s}%{!resident:%{fbaserel:libnix/nbcrt0.o%s}%{!fbaserel:libnix/ncrt0.o%s}}}"
  18421. +
  18422. +#undef ENDFILE_SPEC
  18423. +#define ENDFILE_SPEC "%{noixemul:-lstubs}"
  18424. +
  18425. +/* Automatically search libamiga.a for AmigaOS specific functions.  Note
  18426. +   that we first search the standard C library to resolve as much as
  18427. +   possible from there, since it has names that are duplicated in libamiga.a
  18428. +   which we *don't* want from there.  Then search the standard C library
  18429. +   again to resolve any references that libamiga.a might have generated.
  18430. +   This may only be a temporary solution since it might be better to simply
  18431. +   remove the things from libamiga.a that should be pulled in from libc.a
  18432. +   instead, which would eliminate the first reference to libc.a. */
  18433. +
  18434. +#undef LIB_SPEC
  18435. +#define LIB_SPEC "%{!noixemul:%{!p:%{!pg:-lc -lamiga -lc}}%{p:-lc_p}%{pg:-lc_p}}%{noixemul:-lnixmain -lnix -lamiga}"
  18436. +
  18437. +/* This is (almost;-)) BSD, so it wants DBX format.  */
  18438. +
  18439. +#undef PREFERRED_DEBUGGING_TYPE
  18440. +#define PREFERRED_DEBUGGING_TYPE DBX_DEBUG
  18441. +#define DBX_DEBUGGING_INFO
  18442. +#define    DWARF_DEBUGGING_INFO
  18443. diff -rup --new-file baseline/fsf/gcc/config/rs6000/rs6000.c amiga/fsf/gcc/config/rs6000/rs6000.c
  18444. --- baseline/fsf/gcc/config/rs6000/rs6000.c    Sat Jun 29 09:26:26 1996
  18445. +++ amiga/fsf/gcc/config/rs6000/rs6000.c    Sat Sep 28 00:00:00 1996
  18446. @@ -2967,7 +2967,7 @@ output_epilog (file, size)
  18447.  
  18448.       System V.4 Powerpc's (and the embedded ABI derived from it) use a
  18449.       different traceback table located before the prologue.  */
  18450. -#ifndef USING_SVR4_H
  18451. +#if !defined(USING_SVR4_H) && !defined(NO_TRACEBACK_TABLE)
  18452.    if (! flag_inhibit_size_directive)
  18453.      {
  18454.        char *fname = XSTR (XEXP (DECL_RTL (current_function_decl), 0), 0);
  18455. @@ -3384,6 +3384,8 @@ rs6000_gen_section_name (buf, filename, 
  18456.  
  18457.  /* Write function profiler code. */
  18458.  
  18459. +#ifndef NO_OUTPUT_FUNCTION_PROFILER
  18460. +
  18461.  void
  18462.  output_function_profiler (file, labelno)
  18463.    FILE *file;
  18464. @@ -3445,6 +3447,8 @@ output_function_profiler (file, labelno)
  18465.      fprintf (file, "\tai %d,%d,0\n", i, j);
  18466.  #endif
  18467.  }
  18468. +
  18469. +#endif    /* #ifndef NO_OUTPUT_FUNCTION_PROFILER */
  18470.  
  18471.  /* Adjust the cost of a scheduling dependency.  Return the new cost of
  18472.     a dependency LINK or INSN on DEP_INSN.  COST is the current cost.  */
  18473. diff -rup --new-file baseline/fsf/gcc/config/rs6000/t-amigaos amiga/fsf/gcc/config/rs6000/t-amigaos
  18474. --- baseline/fsf/gcc/config/rs6000/t-amigaos    Wed Dec 31 17:00:00 1969
  18475. +++ amiga/fsf/gcc/config/rs6000/t-amigaos    Sat Sep 28 00:00:00 1996
  18476. @@ -0,0 +1,47 @@
  18477. +# Makefile fragment for AmigaOS target.
  18478. +
  18479. +# Do not build libgcc1.
  18480. +LIBGCC1 =
  18481. +CROSS_LIBGCC1 =
  18482. +
  18483. +# These are really part of libgcc1, but this will cause them to be
  18484. +# built correctly, so... [taken from t-sparclite]
  18485. +LIB2FUNCS_EXTRA = fp-bit.c dp-bit.c
  18486. +
  18487. +dp-bit.c: $(srcdir)/config/fp-bit.c
  18488. +    cat $(srcdir)/config/fp-bit.c > dp-bit.c
  18489. +
  18490. +fp-bit.c: $(srcdir)/config/fp-bit.c
  18491. +    echo '#define FLOAT' > fp-bit.c
  18492. +    cat $(srcdir)/config/fp-bit.c >> fp-bit.c
  18493. +
  18494. +# Build libgcc.a with different options.
  18495. +
  18496. +#MULTILIB_OPTIONS    = msoft-float \
  18497. +#              mlittle
  18498. +
  18499. +#MULTILIB_DIRNAMES    = soft-float \
  18500. +#              little-endian
  18501. +
  18502. +#MULTILIB_MATCHES    = mlittle=mlittle-endian \
  18503. +#              msoft-float=mcpu?403 \
  18504. +#              msoft-float=mcpu?mpc403 \
  18505. +#              msoft-float=mcpu?ppc403
  18506. +
  18507. +#LIBGCC = stmp-multilib
  18508. +LIBGCC =
  18509. +#INSTALL_LIBGCC = install-multilib
  18510. +INSTALL_LIBGCC =
  18511. +
  18512. +# Each compilation environment (Manx, Dice, GCC, SAS/C, etc) provides its
  18513. +# own equivalent of the UNIX /usr/include tree.  For gcc, the standard headers
  18514. +# are in /ade/include and system specific headers are in /ade/os-include.
  18515. +# Use these paths for fixincludes.
  18516. +
  18517. +SYSTEM_HEADER_DIR = /ade/include
  18518. +OTHER_FIXINCLUDES_DIRS = /ade/os-include
  18519. +
  18520. +# We don't need a libgcc1, it's all in ixemul.library
  18521. +
  18522. +LIBGCC1 = libgcc1.null
  18523. +CROSS_LIBGCC1 = libgcc1.null
  18524. diff -rup --new-file baseline/fsf/gcc/config/rs6000/x-amigaos amiga/fsf/gcc/config/rs6000/x-amigaos
  18525. --- baseline/fsf/gcc/config/rs6000/x-amigaos    Wed Dec 31 17:00:00 1969
  18526. +++ amiga/fsf/gcc/config/rs6000/x-amigaos    Sat Sep 28 00:00:00 1996
  18527. @@ -0,0 +1,49 @@
  18528. +# Note: It doesn't do any good to try to define prefix or local_prefix
  18529. +# in the host overrides because configure will just change them back.
  18530. +# You either have to give an appropriate option to configure or live with
  18531. +# an Amiga specific patch to configure.  See the note in configure.  -fnf
  18532. +
  18533. +# Building under AmigaOS almost certainly requires an already working gcc.
  18534. +# To bootstrap without "-pipe" do "make PIPE=".
  18535. +
  18536. +CC = gcc $(PIPE)
  18537. +
  18538. +# Disable -pipe for now since I had problems bootstrapping gcc 2.5.5 with
  18539. +# it. (fnf)
  18540. +#PIPE = -pipe
  18541. +
  18542. +# Allow the user to override the default host optimization with gcc, or if the
  18543. +# host compiler is not gcc and doesn't understand -O<N>.
  18544. +
  18545. +X_OPTIMIZE = -O2
  18546. +
  18547. +# The standard additional host flags for the compiler.
  18548. +
  18549. +X_CFLAGS = $(X_OPTIMIZE)
  18550. +
  18551. +# Man pages get a wierd suffix...
  18552. +
  18553. +manext = .0
  18554. +
  18555. +# We really shouldn't specify CFLAGS from here, but there's no other way
  18556. +# to get rid of the `-g' indoctrinated by Makefile.in.  Note this becomes
  18557. +# part of both the host compilation CFLAGS and the target compilation
  18558. +# CFLAGS.
  18559. +
  18560. +CFLAGS =
  18561. +
  18562. +# Ranlib does exist, but may not be in a path where the default RANLIB_TEST
  18563. +# expects it, so just force it to true.
  18564. +
  18565. +RANLIB_TEST = true
  18566. +
  18567. +# toplev.o target need to define additional flags to handle stack
  18568. +# allocation in real main. As for now we hack building of toplev.o
  18569. +# defining MAYBE_USE_COLLECT2 flag, which is only used for toplev.o.
  18570. +# Then we define EXTRA_OBJS to amigasup.o.
  18571. +
  18572. +MAYBE_USE_COLLECT2= -Dmain=stkmain -Dexit=stkexit
  18573. +EXTRA_OBJS = amigasup.o
  18574. +
  18575. +# Build supplimentary Amiga host support file.
  18576. +amigasup.o: amigasup.c
  18577. diff -rup --new-file baseline/fsf/gcc/config/rs6000/xm-amigaos.h amiga/fsf/gcc/config/rs6000/xm-amigaos.h
  18578. --- baseline/fsf/gcc/config/rs6000/xm-amigaos.h    Wed Dec 31 17:00:00 1969
  18579. +++ amiga/fsf/gcc/config/rs6000/xm-amigaos.h    Sat Sep 28 00:00:00 1996
  18580. @@ -0,0 +1,218 @@
  18581. +/* Configuration for GNU C-compiler for Commodore Amiga, running AmigaOS.
  18582. +   Copyright (C) 1996 Free Software Foundation, Inc.
  18583. +
  18584. +This file is part of GNU CC.
  18585. +
  18586. +GNU CC is free software; you can redistribute it and/or modify
  18587. +it under the terms of the GNU General Public License as published by
  18588. +the Free Software Foundation; either version 2, or (at your option)
  18589. +any later version.
  18590. +
  18591. +GNU CC is distributed in the hope that it will be useful,
  18592. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  18593. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  18594. +GNU General Public License for more details.
  18595. +
  18596. +You should have received a copy of the GNU General Public License
  18597. +along with GNU CC; see the file COPYING.  If not, write to
  18598. +the Free Software Foundation, 59 Temple Place - Suite 330,
  18599. +Boston, MA 02111-1307, USA.  */
  18600. +
  18601. +#include "rs6000/xm-sysv4.h"
  18602. +
  18603. +/* Define various things that the Amiga host has. */
  18604. +
  18605. +#define HAVE_VPRINTF
  18606. +#define HAVE_PUTENV
  18607. +#define HAVE_STRERROR
  18608. +#define HAVE_ATEXIT
  18609. +#define HAVE_RENAME
  18610. +
  18611. +#if 0
  18612. +
  18613. +/* On the Amiga, there are two pathname separators, '/' (DIR_SEPARATOR)
  18614. +   and ':' (VOL_SEPARATOR).  DIR_SEPARATOR defaults to the correct
  18615. +   character, so we don't have to explicitly set it. */
  18616. +
  18617. +#define VOL_SEPARATOR ':'
  18618. +
  18619. +/* Amiga specific headers, such as from the Native Developer Update kits,
  18620. +   go in SYSTEM_INCLUDE_DIR.  STANDARD_INCLUDE_DIR is the equivalent of
  18621. +   Unix "/usr/include".  All other include paths are set in Makefile. */
  18622. +
  18623. +#define SYSTEM_INCLUDE_DIR    "/ade/os-include"
  18624. +#define STANDARD_INCLUDE_DIR    "/ade/include"
  18625. +
  18626. +/* Fork one piped subcommand.  SEARCH_FLAG is the system call to use
  18627. +   (either execv or execvp).  ARGV is the arg vector to use.
  18628. +   NOT_LAST is nonzero if this is not the last subcommand
  18629. +   (i.e. its output should be piped to the next one.)  */
  18630. +
  18631. +#define PEXECUTE(SEARCH_FLAG,PROGRAM,ARGV,NOT_LAST) \
  18632. +({int (*_func)() = (SEARCH_FLAG ? execv : execvp);            \
  18633. +  int _pid;                                \
  18634. +  int _pdes[2];                                \
  18635. +  int _input_desc = last_pipe_input;                    \
  18636. +  int _output_desc = STDOUT_FILE_NO;                    \
  18637. +  int _retries, _sleep_interval, _result;                \
  18638. +                                    \
  18639. +  /* If this isn't the last process, make a pipe for its output,    \
  18640. +     and record it as waiting to be the input to the next process.  */    \
  18641. +                                    \
  18642. +  if (NOT_LAST)                                \
  18643. +    {                                    \
  18644. +      if (pipe (_pdes) < 0)                        \
  18645. +    pfatal_with_name ("pipe");                    \
  18646. +      _output_desc = _pdes[WRITE_PORT];                    \
  18647. +      last_pipe_input = _pdes[READ_PORT];                \
  18648. +    }                                    \
  18649. +  else                                    \
  18650. +    last_pipe_input = STDIN_FILE_NO;                    \
  18651. +                                    \
  18652. +  /* Fork a subprocess; wait and retry if it fails.  */            \
  18653. +  _sleep_interval = 1;                            \
  18654. +  for (_retries = 0; _retries < 4; _retries++)                \
  18655. +    {                                    \
  18656. +      _pid = vfork ();                            \
  18657. +      if (_pid >= 0)                            \
  18658. +    break;                                \
  18659. +      sleep (_sleep_interval);                        \
  18660. +      _sleep_interval *= 2;                        \
  18661. +    }                                    \
  18662. +                                    \
  18663. +  switch (_pid)                                \
  18664. +    {                                    \
  18665. +    case -1:                                \
  18666. +      pfatal_with_name ("vfork");                    \
  18667. +      /* NOTREACHED */                            \
  18668. +      _result = 0;                            \
  18669. +      break;                                \
  18670. +                                    \
  18671. +    case 0: /* child */                            \
  18672. +      /* Move the input and output pipes into place, if nec.  */    \
  18673. +      if (_input_desc != STDIN_FILE_NO)                    \
  18674. +    {                                \
  18675. +      close (STDIN_FILE_NO);                    \
  18676. +      dup (_input_desc);                        \
  18677. +      close (_input_desc);                        \
  18678. +    }                                \
  18679. +      if (_output_desc != STDOUT_FILE_NO)                \
  18680. +    {                                \
  18681. +      close (STDOUT_FILE_NO);                    \
  18682. +      dup (_output_desc);                        \
  18683. +      close (_output_desc);                        \
  18684. +    }                                \
  18685. +                                    \
  18686. +      /* Close the parent's descs that aren't wanted here.  */        \
  18687. +      if (last_pipe_input != STDIN_FILE_NO)                \
  18688. +    close (last_pipe_input);                    \
  18689. +                                    \
  18690. +      /* Exec the program.  */                        \
  18691. +      (*_func) (PROGRAM, ARGV);                        \
  18692. +      perror_exec (PROGRAM);                        \
  18693. +      exit (-1);                            \
  18694. +      /* NOTREACHED */                            \
  18695. +      _result = 0;                            \
  18696. +      break;                                \
  18697. +                                    \
  18698. +    default:                                \
  18699. +      /* In the parent, after forking.                    \
  18700. +     Close the descriptors that we made for this child.  */        \
  18701. +      if (_input_desc != STDIN_FILE_NO)                    \
  18702. +    close (_input_desc);                        \
  18703. +      if (_output_desc != STDOUT_FILE_NO)                \
  18704. +    close (_output_desc);                        \
  18705. +                                    \
  18706. +      /* Return child's process number.  */                \
  18707. +      _result = _pid;                            \
  18708. +      break;                                \
  18709. +    }                                     \
  18710. +_result; })                                \
  18711. +
  18712. +#define PEXECUTE_RESULT(STATUS, COMMAND) \
  18713. +  ({ wait (& STATUS); })
  18714. +
  18715. +/* the following macros are stolen more or less from xm-vms.h ... */
  18716. +
  18717. +/* This macro is used to help compare filenames in cp-lex.c.
  18718. +
  18719. +   We also need to make sure that the names are all lower case, because
  18720. +   we must be able to compare filenames to determine if a file implements
  18721. +   a class.  */
  18722. +
  18723. +#define FILE_NAME_NONDIRECTORY(C)                \
  18724. +({                                \
  18725. +   extern char *rindex();                    \
  18726. +   char * pnt_ = (C), * pnt1_;                    \
  18727. +   pnt1_ = pnt_ - 1;                        \
  18728. +   while (*++pnt1_)                        \
  18729. +     if ((*pnt1_ >= 'A' && *pnt1_ <= 'Z')) *pnt1_ |= 0x20;    \
  18730. +   pnt1_ = rindex (pnt_, '/');                     \
  18731. +   pnt1_ = (pnt1_ == 0 ? rindex (pnt_, ':') : pnt1_);        \
  18732. +   (pnt1_ == 0 ? pnt_ : pnt1_ + 1);                \
  18733. + })
  18734. +
  18735. +/* Macro to generate the name of the cross reference file.  The standard
  18736. +   one does not work, since it was written assuming that the conventions
  18737. +   of a unix style filesystem will work on the host system.
  18738. +   Contrary to VMS, I'm using the original unix filename, there's no reason
  18739. +   not to use this under AmigaOS. */
  18740. +
  18741. +#define XREF_FILE_NAME(BUFF, NAME)    \
  18742. +  s = FILE_NAME_NONDIRECTORY (NAME);            \
  18743. +  if (s == NAME) sprintf(BUFF, ".%s.gxref", NAME);    \
  18744. +  else {                        \
  18745. +    unsigned char ch = *s; /* could be Latin1 char.. */    \
  18746. +    /* temporary: cut the filename from the directory */\
  18747. +    *s = 0;                        \
  18748. +    sprintf (BUFF, "%s.%c%s.gxref", NAME, ch, s+1);    \
  18749. +    /* and restore the filename */            \
  18750. +    *s = ch;                        \
  18751. +  }                            \
  18752. +
  18753. +/* Macro that is used in cp-xref.c to determine whether a file name is
  18754. +   absolute or not.
  18755. +
  18756. +   This checks for both, '/' as first character, since we're running under
  18757. +   ixemul.library which provides for this unix'ism, and for the usual 
  18758. +   logical-terminator, ':', somewhere in the filename. */
  18759. +
  18760. +#define FILE_NAME_ABSOLUTE_P(NAME) (NAME[0] == '/' || index(NAME, ':'))
  18761. +
  18762. +/* the colon conflicts with the name space of logicals */
  18763. +
  18764. +#define PATH_SEPARATOR ','
  18765. +
  18766. +/* Phil.B 17-Apr-95 Added stack checking code submitted by Kriton Kyrimis
  18767. +   (kyrimis@theseas.ntua.gr) on 10-Feb-95, modified for inclusion into gcc
  18768. +
  18769. +   What stackcheck does is to add the following code at the beginning of
  18770. +   each function:
  18771. +    cmpl __StackBottom,sp
  18772. +    bccs .+8
  18773. +    jmp __StackOverflow
  18774. +
  18775. +   _StackBottom and _StackOverflow() are defined in stackchecksetup.c.
  18776. +   _StackBottom is set to the bottom of the stack plus some leeway for
  18777. +   subroutine arguments (128 bytes).  _StackOverflow() sets the stack
  18778. +   pointer to a sane value, prints an error message and exits.
  18779. +
  18780. +   Even with stack checking, you cannot be completely safe, as overflows
  18781. +   are detected on function entry, rather than during function execution.
  18782. +   E.g.,
  18783. +    crash(){
  18784. +      char scribble[100000];
  18785. +      int i;
  18786. +      for (i=0; i<100000; i++) scribble[i]=0;
  18787. +      check(scribble);
  18788. +    }
  18789. +    check(char *x){}
  18790. +   In the above example, stack overflow and its side-effects will occur in
  18791. +   crash(), but it will be detected in check(), when it is too late. (The
  18792. +   same thing happens with SAS/C's stack checking, BTW.)
  18793. +*/
  18794. +
  18795. +/* #defined AMIGA_STACK_CHECKING */
  18796. +
  18797. +#endif
  18798. diff -rup --new-file baseline/fsf/gcc/config.sub amiga/fsf/gcc/config.sub
  18799. --- baseline/fsf/gcc/config.sub    Thu Jun 15 14:01:49 1995
  18800. +++ amiga/fsf/gcc/config.sub    Sat Sep 28 00:00:00 1996
  18801. @@ -176,11 +176,11 @@ case $basic_machine in
  18802.          os=-sysv
  18803.          ;;
  18804.      amiga | amiga-*)
  18805. -        basic_machine=m68k-cbm
  18806. +        basic_machine=m68k-unknown
  18807.          ;;
  18808. -    amigados)
  18809. -        basic_machine=m68k-cbm
  18810. -        os=-amigados
  18811. +    amigaos)
  18812. +        basic_machine=m68k-unknown
  18813. +        os=-amigaos
  18814.          ;;
  18815.      amigaunix | amix)
  18816.          basic_machine=m68k-cbm
  18817. @@ -635,7 +635,7 @@ case $os in
  18818.      -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
  18819.            | -vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[345]* \
  18820.            | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \
  18821. -          | -amigados* | -msdos* | -newsos* | -unicos* | -aos* \
  18822. +          | -amigaos* | -msdos* | -newsos* | -unicos* | -aos* \
  18823.            | -nindy* | -vxworks* | -ebmon* | -hms* | -mvs* | -clix* \
  18824.            | -riscos* | -linux* | -uniplus* | -iris* | -rtu* | -xenix* \
  18825.            | -hiux* | -386bsd* | -netbsd* | -freebsd* | -riscix* \
  18826. @@ -761,7 +761,7 @@ case $basic_machine in
  18827.          os=-sysv
  18828.          ;;
  18829.      *-cbm)
  18830. -        os=-amigados
  18831. +        os=-amigaos
  18832.          ;;
  18833.      *-dg)
  18834.          os=-dgux
  18835. diff -rup --new-file baseline/fsf/gcc/configure amiga/fsf/gcc/configure
  18836. --- baseline/fsf/gcc/configure    Sun Nov 26 12:39:15 1995
  18837. +++ amiga/fsf/gcc/configure    Sat Sep 28 00:00:00 1996
  18838. @@ -4,6 +4,10 @@
  18839.  
  18840.  #This file is part of GNU CC.
  18841.  
  18842. +# AmigaOS Notes:  Where "echo" can be invoked with a first arg that
  18843. +# starts with '-', run the external echo instead, since the pdksh builtin
  18844. +# version botches this case.
  18845. +
  18846.  #GNU CC is free software; you can redistribute it and/or modify
  18847.  #it under the terms of the GNU General Public License as published by
  18848.  #the Free Software Foundation; either version 2, or (at your option)
  18849. @@ -53,29 +57,45 @@ progname=$0
  18850.  
  18851.  # Default --srcdir to the directory where the script is found, 
  18852.  # if a directory was specified.
  18853. -# The second sed call is to convert `.//configure' to `./configure'.
  18854. -srcdir=`echo $0 | sed 's|//|/|' | sed 's|/[^/]*$||'`
  18855. +# The first sed call works around a bug in the AmigaOS port of sksh, where
  18856. +# $0 has a trailing slash appended to it.  It is a NOP for other systems.
  18857. +# The third sed call is to convert `.//configure' to `./configure'.
  18858. +srcdir=`echo $0 | sed 's|/$||' | sed 's|//|/|' | sed 's|/[^/]*$||'`
  18859.  if [ x$srcdir = x$0 ]
  18860.  then
  18861.  srcdir=
  18862.  fi
  18863. +# On systems where GCC is the native compiler, $prefix should be
  18864. +# /usr. But the user can change it with configure --prefix=/foo/bar
  18865. +native_prefix=/usr
  18866.  
  18867.  host=
  18868.  
  18869. -# Default prefix to /usr/local.
  18870. -prefix=/usr/local
  18871. -
  18872. +# Note:  For AmigaOS we want this to default to /ade unless we specify
  18873. +# otherwise to configure.  We also don't want to have to remember to always
  18874. +# configure with "--prefix=/ade".  Changing it in Makefile.in or in
  18875. +# config/m68k/x-amigaos is ineffective since configure will always change
  18876. +# it back in the final generated Makefile, so we have to go to the root of
  18877. +# the problem, which is here.  There should be a way to do this in the
  18878. +# individual machine configuration files!  -fnf
  18879. +# here.  -fnf
  18880. +# Default prefix to "/ade".
  18881. +prefix=/ade
  18882. +  
  18883.  # On systems where GCC is the native compiler, $prefix should be
  18884.  # /usr. But the user can change it with configure --prefix=/foo/bar
  18885.  native_prefix=/usr
  18886.   
  18887. -# local_prefix specifies where to find the directory /usr/local/include
  18888. +# local_prefix specifies where to find the directory /ade/local/include
  18889.  # We don't use $(prefix) for this
  18890. -# because we always want GCC to search /usr/local/include
  18891. -# even if GCC is installed somewhere other than /usr/local.
  18892. +# because we always want GCC to search /ade/local/include
  18893. +# even if GCC is installed somewhere other than /ade/local.
  18894.  # Think THREE TIMES before specifying any other value for this!
  18895.  # DO NOT make this use $prefix!
  18896. -local_prefix=/usr/local
  18897. +# Note:  See AmigaOS note above for this AmigaOS specific change.  -fnf
  18898. +# NoteII:We don't want to have yet-another-assign so we use /ade/local
  18899. +local_prefix=/ade/local
  18900.  # Default is to let the Makefile set exec_prefix from $(prefix)
  18901.  exec_prefix='$(prefix)'
  18902.  #
  18903. @@ -87,8 +107,13 @@ program_transform_name=
  18904.  program_transform_set=
  18905.  
  18906.  remove=rm
  18907. -hard_link=ln
  18908. -symbolic_link='ln -s'
  18909. +# AmigaOS specific change.  Although we support symbolic links using
  18910. +# the GNU tools, they need to be made using the syntax "somewhere:foo/bar"
  18911. +# and not "/somewhere/foo/bar", since they must be in standard AmigaOS
  18912. +# format.  This should probably be done by having GNU ln translate paths
  18913. +# that start with '/' to canonical AmigaOS device:name form.
  18914. +hard_link=cp
  18915. +symbolic_link=cp
  18916.  copy=cp
  18917.  
  18918.  # Record all the arguments, to write them in config.status.
  18919. @@ -167,15 +192,18 @@ do
  18920.      next_arg=
  18921.      ;;
  18922.    *)
  18923. -    case $arg in
  18924. -      -*)
  18925. -    if [ x$name1 != x ]
  18926. -    then
  18927. -        echo "Positional arguments must be last." 1>&2
  18928. -        exit 1
  18929. -    fi
  18930. -    ;;
  18931. -    esac
  18932. +
  18933. +# Note: This causes problems in the Amiga port for some reason
  18934. +# and eliminating it seems to cause no trouble.  -fnf
  18935. +#    case $arg in
  18936. +#      -*)
  18937. +#    if [ x$name1 != x ]
  18938. +#    then
  18939. +#        echo "Positional arguments must be last." 1>&2
  18940. +#        exit 1
  18941. +#    fi
  18942. +#    ;;
  18943. +#    esac
  18944.  
  18945.      case $arg in
  18946.       -srcdir | --srcdir | --srcdi | --srcd | --src | --sr)
  18947. @@ -496,7 +524,8 @@ for machine in $canon_build $canon_host 
  18948.      use_collect2=
  18949.      # Set this to override the default target model.
  18950.      target_cpu_default=
  18951. -    # Set this to force use of install.sh.
  18952. +    # Set this to force use of install.sh (if set to 'yes')
  18953. +    # Set to name of installer to use a custom installer.
  18954.      broken_install=
  18955.      # Set this to control which fixincludes program to use.
  18956.      fixincludes=fixincludes
  18957. @@ -1474,6 +1503,16 @@ for machine in $canon_build $canon_host 
  18958.          use_collect2=yes
  18959.          extra_headers=math-68881.h
  18960.          ;;
  18961. +    m68k-*-amigaos*)
  18962. +        xm_file=m68k/xm-amigaos.h
  18963. +        out_file=m68k/amigaos.c
  18964. +        tm_file=m68k/amigaos.h
  18965. +        tmake_file=m68k/t-amigaos
  18966. +        xmake_file=m68k/x-amigaos
  18967. +        fixincludes=Makefile.in # Headers are already fixed.
  18968. +        broken_install=cp
  18969. +        install_headers_dir=install-headers-cp
  18970. +        ;;
  18971.      m68k-wrs-vxworks*)
  18972.          tm_file=m68k/vxm68k.h
  18973.          tmake_file=m68k/t-vxworks68
  18974. @@ -2118,6 +2157,16 @@ for machine in $canon_build $canon_host 
  18975.          xmake_file=romp/x-mach
  18976.          use_collect2=yes
  18977.          ;;
  18978. +    powerpc-*-amigaos*)
  18979. +        cpu_type=rs6000
  18980. +        xm_file=rs6000/xm-amigaos.h
  18981. +        tm_file=rs6000/amigaos.h
  18982. +        tmake_file=rs6000/t-amigaos
  18983. +        xmake_file=rs6000/x-amigaos
  18984. +        fixincludes=Makefile.in # Headers are already fixed.
  18985. +        broken_install=cp
  18986. +        install_headers_dir=install-headers-cp
  18987. +        ;;
  18988.      powerpc-ibm-aix[456789].*)
  18989.          cpu_type=rs6000
  18990.          tm_file=rs6000/aix41ppc.h
  18991. @@ -2555,16 +2604,15 @@ lang_specs_files=
  18992.  lang_options_files=
  18993.  rm -f specs.h options.h
  18994.  touch specs.h options.h
  18995. -for subdir in . $subdirs
  18996. +for lang_specs in $srcdir/*/lang-specs.h
  18997.  do
  18998. -    if [ -f $srcdir/$subdir/lang-specs.h ]; then
  18999. -        echo "#include \"$subdir/lang-specs.h\"" >>specs.h
  19000. -        lang_specs_files="$lang_specs_files $srcdir/$subdir/lang-specs.h"
  19001. -    fi
  19002. -    if [ -f $srcdir/$subdir/lang-options.h ]; then
  19003. -        echo "#include \"$subdir/lang-options.h\"" >>options.h
  19004. -        lang_options_files="$lang_options_files $srcdir/$subdir/lang-options.h"
  19005. -    fi
  19006. +    echo "#include \"$lang_specs\"" >>specs.h
  19007. +    lang_specs_files="$lang_specs_files $lang_specs"
  19008. +done
  19009. +for lang_options in $srcdir/*/lang-options.h
  19010. +do
  19011. +    echo "#include \"$lang_options\"" >>options.h
  19012. +    lang_options_files="$lang_options_files $lang_options"
  19013.  done
  19014.  
  19015.  # Define SET_MAKE if this old version of `make' doesn't define $(MAKE).
  19016. @@ -2670,8 +2718,14 @@ do
  19017.      then true
  19018.      else
  19019.          rm -f Makefile.xx
  19020. -        abssrcdir=`cd ${srcdir}; pwd`
  19021. -        sed "s|^INSTALL = .*|INSTALL = ${abssrcdir}/install.sh -c|" Makefile.tem > Makefile.xx
  19022. +         if [ x$host_broken_install = xyes ]
  19023. +         then
  19024. +             abssrcdir=`cd ${srcdir}; pwd`
  19025. +             installer="${abssrcdir}/install.sh -c"
  19026. +         else
  19027. +             installer=$host_broken_install
  19028. +         fi
  19029. +         sed "s|^INSTALL = .*|INSTALL = ${installer}|" Makefile.tem > Makefile.xx
  19030.          rm -f Makefile.tem
  19031.          mv Makefile.xx Makefile.tem
  19032.      fi
  19033. @@ -2898,7 +2952,7 @@ MAYBE_TARGET_DEFAULT = -DTARGET_CPU_DEFA
  19034.          # with a set of hooks, reached indirectly via lang.${target}.
  19035.  
  19036.          target_list="all.build all.cross start.encap rest.encap \
  19037. -            info dvi \
  19038. +            info guide dvi \
  19039.              install-normal install-common install-info install-man \
  19040.              uninstall distdir \
  19041.              mostlyclean clean distclean extraclean maintainer-clean \
  19042. @@ -2926,10 +2980,10 @@ MAYBE_TARGET_DEFAULT = -DTARGET_CPU_DEFA
  19043.          rm -f symtest.tem
  19044.          if $symbolic_link symtest1.tem symtest.tem 2>/dev/null
  19045.          then
  19046. -            sed -e 's,CC=set-by-configure,CC=$(CC),' \
  19047. +            sed -e 's,CC=set-by-configure,CC=\$(CC),' \
  19048.                  Makefile.tem > Makefile.xx
  19049.          else
  19050. -            sed -e "s,CC=set-by-configure,CC=\`case '$(CC)' in stage*) echo '$(CC)' | sed -e 's|stage|../stage|g';; *) echo '$(CC)';; esac\`," \
  19051. +            sed -e "s,CC=set-by-configure,CC=\`case '\$(CC)' in stage*) echo '\$(CC)' | sed -e 's|stage|../stage|g';; *) echo '\$(CC)';; esac\`," \
  19052.                  Makefile.tem > Makefile.xx
  19053.          fi
  19054.          rm -f Makefile.tem
  19055. diff -rup --new-file baseline/fsf/gcc/cp/Make-lang.in amiga/fsf/gcc/cp/Make-lang.in
  19056. --- baseline/fsf/gcc/cp/Make-lang.in    Tue Sep 12 14:15:52 1995
  19057. +++ amiga/fsf/gcc/cp/Make-lang.in    Sat Sep 28 00:00:00 1996
  19058. @@ -73,7 +73,7 @@ g++-cross: $(srcdir)/cp/g++.c version.o 
  19059.  
  19060.  cxxmain.o: cplus-dem.c demangle.h
  19061.      rm -f cxxmain.c
  19062. -    ln -s $(srcdir)/cplus-dem.c cxxmain.c > /dev/null 2>&1 \
  19063. +    $(SYMLINK) $(srcdir)/cplus-dem.c cxxmain.c > /dev/null 2>&1 \
  19064.       || cp $(srcdir)/cplus-dem.c cxxmain.c
  19065.      $(CC) -c -DMAIN $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
  19066.        -DVERSION=\"$(version)\" cxxmain.c
  19067. @@ -104,6 +104,7 @@ c++.start.encap: g++
  19068.  c++.rest.encap: $(DEMANGLER_PROG)
  19069.  
  19070.  c++.info:
  19071. +c++.guide:
  19072.  c++.dvi:
  19073.  
  19074.  # Install hooks:
  19075. @@ -121,7 +122,7 @@ c++.install-common:
  19076.          $(INSTALL_PROGRAM) g++-cross$(exeext) $(bindir)/$(GXX_CROSS_NAME)$(exeext); \
  19077.          chmod a+x $(bindir)/$(GXX_CROSS_NAME)$(exeext); \
  19078.          rm -f $(bindir)/$(CXX_CROSS_NAME)$(exeext); \
  19079. -        ln $(bindir)/$(GXX_CROSS_NAME)$(exeext) $(bindir)/$(CXX_CROSS_NAME)$(exeext) \
  19080. +        $(HARDLINK) $(bindir)/$(GXX_CROSS_NAME)$(exeext) $(bindir)/$(CXX_CROSS_NAME)$(exeext) \
  19081.            > /dev/null 2>&1 \
  19082.            || cp $(bindir)/$(GXX_CROSS_NAME)$(exeext) $(bindir)/$(CXX_CROSS_NAME)$(exeext) ; \
  19083.        else \
  19084. @@ -129,7 +130,7 @@ c++.install-common:
  19085.          $(INSTALL_PROGRAM) g++$(exeext) $(bindir)/$(GXX_INSTALL_NAME)$(exeext); \
  19086.          chmod a+x $(bindir)/$(GXX_INSTALL_NAME)$(exeext); \
  19087.          rm -f $(bindir)/$(CXX_INSTALL_NAME)$(exeext); \
  19088. -        ln $(bindir)/$(GXX_INSTALL_NAME)$(exeext) $(bindir)/$(CXX_INSTALL_NAME)$(exeext) \
  19089. +        $(HARDLINK) $(bindir)/$(GXX_INSTALL_NAME)$(exeext) $(bindir)/$(CXX_INSTALL_NAME)$(exeext) \
  19090.            > /dev/null 2>&1 \
  19091.            || cp $(bindir)/$(GXX_INSTALL_NAME)$(exeext) $(bindir)/$(CXX_INSTALL_NAME)$(exeext) ; \
  19092.        fi ; \
  19093. @@ -193,5 +194,5 @@ c++.distdir:
  19094.      cd cp ; $(MAKE) $(FLAGS_TO_PASS) $(CXX_FLAGS_TO_PASS) parse.c hash.h
  19095.      cd cp; \
  19096.      for file in *[0-9a-zA-Z+]; do \
  19097. -      ln $$file ../tmp/cp >/dev/null 2>&1 || cp $$file ../tmp/cp; \
  19098. +      $(HARDLINK) $$file ../tmp/cp >/dev/null 2>&1 || cp $$file ../tmp/cp; \
  19099.      done
  19100. diff -rup --new-file baseline/fsf/gcc/cp/Makefile.in amiga/fsf/gcc/cp/Makefile.in
  19101. --- baseline/fsf/gcc/cp/Makefile.in    Mon Aug 28 03:28:34 1995
  19102. +++ amiga/fsf/gcc/cp/Makefile.in    Sat Sep 28 00:00:00 1996
  19103. @@ -189,8 +189,8 @@ RTL_H = $(srcdir)/../rtl.h $(srcdir)/../
  19104.  TREE_H = $(srcdir)/../tree.h $(srcdir)/../real.h $(srcdir)/../tree.def \
  19105.      $(srcdir)/../machmode.h $(srcdir)/../machmode.def
  19106.  CXX_TREE_H = $(TREE_H) cp-tree.h tree.def
  19107. -PARSE_H = $(srcdir)/parse.h
  19108. -PARSE_C = $(srcdir)/parse.c
  19109. +PARSE_H = parse.h
  19110. +PARSE_C = parse.c
  19111.  
  19112.  parse.o : $(PARSE_C) $(CONFIG_H) $(CXX_TREE_H) $(srcdir)/../flags.h lex.h
  19113.      $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $(BIG_SWITCHFLAG) \
  19114. @@ -200,8 +200,8 @@ CONFLICTS = expect 5 shift/reduce confli
  19115.  $(PARSE_H) : $(PARSE_C)
  19116.  $(PARSE_C) : $(srcdir)/parse.y
  19117.      @echo $(CONFLICTS)
  19118. -    cd $(srcdir); $(BISON) $(BISONFLAGS) -d -o parse.c parse.y
  19119. -    cd $(srcdir); grep '^#define[     ]*YYEMPTY' parse.c >>parse.h
  19120. +    $(BISON) $(BISONFLAGS) -d -o parse.c $(srcdir)/parse.y
  19121. +    grep '^#define[     ]*YYEMPTY' parse.c >>parse.h
  19122.  #$(PARSE_C) $(PARSE_H) : stamp-parse ; @true
  19123.  #stamp-parse: $(srcdir)/parse.y
  19124.  #    @echo $(CONFLICTS)
  19125. @@ -216,9 +216,12 @@ $(PARSE_C) : $(srcdir)/parse.y
  19126.  # But this would screw things for people that don't have gperf,
  19127.  # if gxx.gpref got touched, say.
  19128.  # Thus you have to remove hash.h to force it to be re-made.
  19129. -$(srcdir)/hash.h:
  19130. +# ADE note: Rebuild if necessary, we have gperf
  19131. +hash.h: $(srcdir)/gxx.gperf
  19132. +    echo '/*WARNING: This file is automatically generated!*/' >tmp-hash.h
  19133.      gperf -p -j1 -g -o -t -N is_reserved_word '-k1,4,7,$$' \
  19134. -        $(srcdir)/gxx.gperf >$(srcdir)/hash.h
  19135. +        $(srcdir)/gxx.gperf >>tmp-hash.h
  19136. +    $(srcdir)/../move-if-change tmp-hash.h $@
  19137.  
  19138.  spew.o : spew.c $(CONFIG_H) $(CXX_TREE_H) \
  19139.    $(PARSE_H) $(srcdir)/../flags.h lex.h
  19140. @@ -254,11 +257,12 @@ repo.o : repo.c $(CONFIG_H) $(CXX_TREE_H
  19141.  
  19142.  # Update the tags table.
  19143.  TAGS: force
  19144. +    objdir=`pwd`;                \
  19145.      cd $(srcdir) ;                \
  19146. -    etags *.c *.h ;                \
  19147. -    echo 'l' | tr 'l' '\f' >> TAGS ;    \
  19148. -    echo 'parse.y,0' >> TAGS ;         \
  19149. -    etags -a ../*.h ../*.c;
  19150. +    etags *.c *.h -o $$objdir/TAGS ;    \
  19151. +    echo 'l' | tr 'l' '\f' >> $$objdir/TAGS ;    \
  19152. +    echo 'parse.y,0' >> $$objdir/TAGS ;    \
  19153. +    etags -a ../*.h ../*.c $$objdir/TAGS;
  19154.  
  19155.  .PHONY: TAGS
  19156.  
  19157. diff -rup --new-file baseline/fsf/gcc/cp/hash.h amiga/fsf/gcc/cp/hash.h
  19158. --- baseline/fsf/gcc/cp/hash.h    Wed Oct 11 19:29:43 1995
  19159. +++ amiga/fsf/gcc/cp/hash.h    Wed Dec 31 17:00:00 1969
  19160. @@ -1,221 +0,0 @@
  19161. -/* C code produced by gperf version 2.5 (GNU C++ version) */
  19162. -/* Command-line: gperf -p -j1 -g -o -t -N is_reserved_word -k1,4,7,$ ../../../devo/gcc/cp/gxx.gperf  */
  19163. -/* Command-line: gperf -p -j1 -g -o -t -N is_reserved_word -k1,4,$,7 gplus.gperf  */
  19164. -struct resword { char *name; short token; enum rid rid;};
  19165. -
  19166. -#define TOTAL_KEYWORDS 97
  19167. -#define MIN_WORD_LENGTH 2
  19168. -#define MAX_WORD_LENGTH 16
  19169. -#define MIN_HASH_VALUE 4
  19170. -#define MAX_HASH_VALUE 219
  19171. -/* maximum key range = 216, duplicates = 0 */
  19172. -
  19173. -#ifdef __GNUC__
  19174. -inline
  19175. -#endif
  19176. -static unsigned int
  19177. -hash (str, len)
  19178. -     register char *str;
  19179. -     register int unsigned len;
  19180. -{
  19181. -  static unsigned char asso_values[] =
  19182. -    {
  19183. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19184. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19185. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19186. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19187. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19188. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19189. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19190. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19191. -     220, 220, 220, 220, 220, 220, 220, 220, 220, 220,
  19192. -     220, 220, 220, 220, 220,   0, 220,  88,  16,  19,
  19193. -      52,   0,   9,  72,   1,  77, 220,   0,   0,  38,
  19194. -      13,  44,  38,  30,  27,  57,   1,  14,   0,   2,
  19195. -       2,   7, 220, 220, 220, 220, 220, 220,
  19196. -    };
  19197. -  register int hval = len;
  19198. -
  19199. -  switch (hval)
  19200. -    {
  19201. -      default:
  19202. -      case 7:
  19203. -        hval += asso_values[str[6]];
  19204. -      case 6:
  19205. -      case 5:
  19206. -      case 4:
  19207. -        hval += asso_values[str[3]];
  19208. -      case 3:
  19209. -      case 2:
  19210. -      case 1:
  19211. -        hval += asso_values[str[0]];
  19212. -    }
  19213. -  return hval + asso_values[str[len - 1]];
  19214. -}
  19215. -
  19216. -#ifdef __GNUC__
  19217. -inline
  19218. -#endif
  19219. -struct resword *
  19220. -is_reserved_word (str, len)
  19221. -     register char *str;
  19222. -     register unsigned int len;
  19223. -{
  19224. -  static struct resword wordlist[] =
  19225. -    {
  19226. -      {"",}, {"",}, {"",}, {"",}, 
  19227. -      {"else",  ELSE, NORID,},
  19228. -      {"true",  CXX_TRUE, NORID,},
  19229. -      {"",}, 
  19230. -      {"while",  WHILE, NORID,},
  19231. -      {"virtual",  SCSPEC, RID_VIRTUAL,},
  19232. -      {"",}, {"",}, 
  19233. -      {"try",  TRY, NORID,},
  19234. -      {"",}, {"",}, {"",}, {"",}, 
  19235. -      {"typeof",  TYPEOF, NORID,},
  19236. -      {"not",  '!', NORID,},
  19237. -      {"new",  NEW, NORID,},
  19238. -      {"extern",  SCSPEC, RID_EXTERN,},
  19239. -      {"bool",  TYPESPEC, RID_BOOL,},
  19240. -      {"",}, {"",}, 
  19241. -      {"case",  CASE, NORID,},
  19242. -      {"__alignof__",  ALIGNOF, NORID},
  19243. -      {"",}, 
  19244. -      {"typedef",  SCSPEC, RID_TYPEDEF,},
  19245. -      {"",}, 
  19246. -      {"__extension__",  EXTENSION, NORID},
  19247. -      {"",}, {"",}, 
  19248. -      {"__alignof",  ALIGNOF, NORID},
  19249. -      {"xor",  '^', NORID,},
  19250. -      {"",}, 
  19251. -      {"__inline",  SCSPEC, RID_INLINE},
  19252. -      {"",}, 
  19253. -      {"__inline__",  SCSPEC, RID_INLINE},
  19254. -      {"",}, 
  19255. -      {"xor_eq",  ASSIGN, NORID,},
  19256. -      {"for",  FOR, NORID,},
  19257. -      {"",}, {"",}, 
  19258. -      {"continue",  CONTINUE, NORID,},
  19259. -      {"",}, 
  19260. -      {"catch",  CATCH, NORID,},
  19261. -      {"private",  VISSPEC, RID_PRIVATE,},
  19262. -      {"",}, 
  19263. -      {"typename",  TYPENAME_KEYWORD, NORID,},
  19264. -      {"template",  TEMPLATE, RID_TEMPLATE,},
  19265. -      {"not_eq",  EQCOMPARE, NORID,},
  19266. -      {"",}, {"",}, 
  19267. -      {"throw",  THROW, NORID,},
  19268. -      {"__const",  TYPE_QUAL, RID_CONST},
  19269. -      {"__const__",  TYPE_QUAL, RID_CONST},
  19270. -      {"__volatile",  TYPE_QUAL, RID_VOLATILE},
  19271. -      {"__wchar_t",  TYPESPEC, RID_WCHAR  /* Unique to ANSI C++ */,},
  19272. -      {"__volatile__",  TYPE_QUAL, RID_VOLATILE},
  19273. -      {"delete",  DELETE, NORID,},
  19274. -      {"typeid",  TYPEID, NORID,},
  19275. -      {"return",  RETURN, NORID,},
  19276. -      {"__typeof__",  TYPEOF, NORID},
  19277. -      {"compl",  '~', NORID,},
  19278. -      {"public",  VISSPEC, RID_PUBLIC,},
  19279. -      {"__asm__",  GCC_ASM_KEYWORD, NORID},
  19280. -      {"switch",  SWITCH, NORID,},
  19281. -      {"",}, 
  19282. -      {"friend",  SCSPEC, RID_FRIEND,},
  19283. -      {"__typeof",  TYPEOF, NORID},
  19284. -      {"",}, 
  19285. -      {"static_cast",  STATIC_CAST, NORID,},
  19286. -      {"false",  CXX_FALSE, NORID,},
  19287. -      {"sizeof",  SIZEOF, NORID,},
  19288. -      {"or",  OROR, NORID,},
  19289. -      {"double",  TYPESPEC, RID_DOUBLE,},
  19290. -      {"",}, 
  19291. -      {"union",  AGGR, RID_UNION,},
  19292. -      {"char",  TYPESPEC, RID_CHAR,},
  19293. -      {"struct",  AGGR, RID_RECORD,},
  19294. -      {"or_eq",  ASSIGN, NORID,},
  19295. -      {"enum",  ENUM, NORID,},
  19296. -      {"int",  TYPESPEC, RID_INT,},
  19297. -      {"const",  TYPE_QUAL, RID_CONST,},
  19298. -      {"static",  SCSPEC, RID_STATIC,},
  19299. -      {"reinterpret_cast",  REINTERPRET_CAST, NORID,},
  19300. -      {"",}, 
  19301. -      {"explicit",  SCSPEC, RID_EXPLICIT,},
  19302. -      {"__signed__",  TYPESPEC, RID_SIGNED},
  19303. -      {"if",  IF, NORID,},
  19304. -      {"__attribute",  ATTRIBUTE, NORID},
  19305. -      {"short",  TYPESPEC, RID_SHORT,},
  19306. -      {"__attribute__",  ATTRIBUTE, NORID},
  19307. -      {"bitor",  '|', NORID,},
  19308. -      {"signature",  AGGR, RID_SIGNATURE    /* Extension */,},
  19309. -      {"",}, 
  19310. -      {"__sigof__",  SIGOF, NORID        /* Extension */,},
  19311. -      {"volatile",  TYPE_QUAL, RID_VOLATILE,},
  19312. -      {"__label__",  LABEL, NORID},
  19313. -      {"do",  DO, NORID,},
  19314. -      {"",}, 
  19315. -      {"__asm",  GCC_ASM_KEYWORD, NORID},
  19316. -      {"protected",  VISSPEC, RID_PROTECTED,},
  19317. -      {"",}, 
  19318. -      {"float",  TYPESPEC, RID_FLOAT,},
  19319. -      {"using",  USING, NORID,},
  19320. -      {"",}, 
  19321. -      {"const_cast",  CONST_CAST, NORID,},
  19322. -      {"",}, 
  19323. -      {"void",  TYPESPEC, RID_VOID,},
  19324. -      {"break",  BREAK, NORID,},
  19325. -      {"namespace",  NAMESPACE, NORID,},
  19326. -      {"",}, {"",}, {"",}, {"",}, 
  19327. -      {"sigof",  SIGOF, NORID        /* Extension */,},
  19328. -      {"",}, {"",}, {"",}, 
  19329. -      {"this",  THIS, NORID,},
  19330. -      {"",}, {"",}, {"",}, {"",}, 
  19331. -      {"and_eq",  ASSIGN, NORID,},
  19332. -      {"",}, {"",}, {"",}, 
  19333. -      {"signed",  TYPESPEC, RID_SIGNED,},
  19334. -      {"asm",  ASM_KEYWORD, NORID,},
  19335. -      {"",}, {"",}, {"",}, 
  19336. -      {"mutable",  SCSPEC, RID_MUTABLE,},
  19337. -      {"",}, {"",}, {"",}, 
  19338. -      {"__signed",  TYPESPEC, RID_SIGNED},
  19339. -      {"class",  AGGR, RID_CLASS,},
  19340. -      {"register",  SCSPEC, RID_REGISTER,},
  19341. -      {"",}, {"",}, {"",}, 
  19342. -      {"and",  ANDAND, NORID,},
  19343. -      {"",}, {"",}, {"",}, {"",}, 
  19344. -      {"long",  TYPESPEC, RID_LONG,},
  19345. -      {"default",  DEFAULT, NORID,},
  19346. -      {"operator",  OPERATOR, NORID,},
  19347. -      {"unsigned",  TYPESPEC, RID_UNSIGNED,},
  19348. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19349. -      {"inline",  SCSPEC, RID_INLINE,},
  19350. -      {"",}, 
  19351. -      {"bitand",  '&', NORID,},
  19352. -      {"",}, 
  19353. -      {"goto",  GOTO, NORID,},
  19354. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19355. -      {"dynamic_cast",  DYNAMIC_CAST, NORID,},
  19356. -      {"",}, {"",}, {"",}, {"",}, {"",}, 
  19357. -      {"__signature__",  AGGR, RID_SIGNATURE    /* Extension */,},
  19358. -      {"",}, 
  19359. -      {"auto",  SCSPEC, RID_AUTO,},
  19360. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19361. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19362. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19363. -      {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, {"",}, 
  19364. -      {"",}, {"",}, 
  19365. -      {"overload",  OVERLOAD, NORID,},
  19366. -    };
  19367. -
  19368. -  if (len <= MAX_WORD_LENGTH && len >= MIN_WORD_LENGTH)
  19369. -    {
  19370. -      register int key = hash (str, len);
  19371. -
  19372. -      if (key <= MAX_HASH_VALUE && key >= 0)
  19373. -        {
  19374. -          register char *s = wordlist[key].name;
  19375. -
  19376. -          if (*s == *str && !strcmp (str + 1, s + 1))
  19377. -            return &wordlist[key];
  19378. -        }
  19379. -    }
  19380. -  return 0;
  19381. -}
  19382. diff -rup --new-file baseline/fsf/gcc/cp/parse.c amiga/fsf/gcc/cp/parse.c
  19383. --- baseline/fsf/gcc/cp/parse.c    Sun Nov  5 14:55:55 1995
  19384. +++ amiga/fsf/gcc/cp/parse.c    Wed Dec 31 17:00:00 1969
  19385. @@ -1,7756 +0,0 @@
  19386. -
  19387. -/*  A Bison parser, made from parse.y with Bison version GNU Bison version 1.22
  19388. -  */
  19389. -
  19390. -#define YYBISON 1  /* Identify Bison output.  */
  19391. -
  19392. -#define    IDENTIFIER    258
  19393. -#define    TYPENAME    259
  19394. -#define    SCSPEC    260
  19395. -#define    TYPESPEC    261
  19396. -#define    TYPE_QUAL    262
  19397. -#define    CONSTANT    263
  19398. -#define    STRING    264
  19399. -#define    ELLIPSIS    265
  19400. -#define    SIZEOF    266
  19401. -#define    ENUM    267
  19402. -#define    IF    268
  19403. -#define    ELSE    269
  19404. -#define    WHILE    270
  19405. -#define    DO    271
  19406. -#define    FOR    272
  19407. -#define    SWITCH    273
  19408. -#define    CASE    274
  19409. -#define    DEFAULT    275
  19410. -#define    BREAK    276
  19411. -#define    CONTINUE    277
  19412. -#define    RETURN    278
  19413. -#define    GOTO    279
  19414. -#define    ASM_KEYWORD    280
  19415. -#define    GCC_ASM_KEYWORD    281
  19416. -#define    TYPEOF    282
  19417. -#define    ALIGNOF    283
  19418. -#define    SIGOF    284
  19419. -#define    ATTRIBUTE    285
  19420. -#define    EXTENSION    286
  19421. -#define    LABEL    287
  19422. -#define    AGGR    288
  19423. -#define    VISSPEC    289
  19424. -#define    DELETE    290
  19425. -#define    NEW    291
  19426. -#define    OVERLOAD    292
  19427. -#define    THIS    293
  19428. -#define    OPERATOR    294
  19429. -#define    CXX_TRUE    295
  19430. -#define    CXX_FALSE    296
  19431. -#define    NAMESPACE    297
  19432. -#define    TYPENAME_KEYWORD    298
  19433. -#define    USING    299
  19434. -#define    LEFT_RIGHT    300
  19435. -#define    TEMPLATE    301
  19436. -#define    TYPEID    302
  19437. -#define    DYNAMIC_CAST    303
  19438. -#define    STATIC_CAST    304
  19439. -#define    REINTERPRET_CAST    305
  19440. -#define    CONST_CAST    306
  19441. -#define    SCOPE    307
  19442. -#define    EMPTY    308
  19443. -#define    PTYPENAME    309
  19444. -#define    NSNAME    310
  19445. -#define    THROW    311
  19446. -#define    ASSIGN    312
  19447. -#define    OROR    313
  19448. -#define    ANDAND    314
  19449. -#define    MIN_MAX    315
  19450. -#define    EQCOMPARE    316
  19451. -#define    ARITHCOMPARE    317
  19452. -#define    LSHIFT    318
  19453. -#define    RSHIFT    319
  19454. -#define    POINTSAT_STAR    320
  19455. -#define    DOT_STAR    321
  19456. -#define    UNARY    322
  19457. -#define    PLUSPLUS    323
  19458. -#define    MINUSMINUS    324
  19459. -#define    HYPERUNARY    325
  19460. -#define    PAREN_STAR_PAREN    326
  19461. -#define    POINTSAT    327
  19462. -#define    TRY    328
  19463. -#define    CATCH    329
  19464. -#define    TYPENAME_ELLIPSIS    330
  19465. -#define    PRE_PARSED_FUNCTION_DECL    331
  19466. -#define    EXTERN_LANG_STRING    332
  19467. -#define    ALL    333
  19468. -#define    PRE_PARSED_CLASS_DECL    334
  19469. -#define    TYPENAME_DEFN    335
  19470. -#define    IDENTIFIER_DEFN    336
  19471. -#define    PTYPENAME_DEFN    337
  19472. -#define    END_OF_LINE    338
  19473. -#define    END_OF_SAVED_INPUT    339
  19474. -
  19475. -#line 29 "parse.y"
  19476. -
  19477. -/* Cause the `yydebug' variable to be defined.  */
  19478. -#define YYDEBUG 1
  19479. -
  19480. -#include "config.h"
  19481. -
  19482. -#include <stdio.h>
  19483. -#include <errno.h>
  19484. -
  19485. -#include "tree.h"
  19486. -#include "input.h"
  19487. -#include "flags.h"
  19488. -#include "lex.h"
  19489. -#include "cp-tree.h"
  19490. -#include "output.h"
  19491. -
  19492. -/* Since parsers are distinct for each language, put the language string
  19493. -   definition here.  (fnf) */
  19494. -char *language_string = "GNU C++";
  19495. -
  19496. -extern tree void_list_node;
  19497. -extern struct obstack permanent_obstack;
  19498. -
  19499. -#ifndef errno
  19500. -extern int errno;
  19501. -#endif
  19502. -
  19503. -extern int end_of_file;
  19504. -extern int current_class_depth;
  19505. -
  19506. -/* FSF LOCAL dje prefix attributes */
  19507. -extern tree strip_attrs        PROTO((tree));
  19508. -/* END FSF LOCAL */
  19509. -
  19510. -void yyerror ();
  19511. -
  19512. -/* Like YYERROR but do call yyerror.  */
  19513. -#define YYERROR1 { yyerror ("syntax error"); YYERROR; }
  19514. -
  19515. -#define OP0(NODE) (TREE_OPERAND (NODE, 0))
  19516. -#define OP1(NODE) (TREE_OPERAND (NODE, 1))
  19517. -
  19518. -/* Contains the statement keyword (if/while/do) to include in an
  19519. -   error message if the user supplies an empty conditional expression.  */
  19520. -static char *cond_stmt_keyword;
  19521. -
  19522. -/* Nonzero if we have an `extern "C"' acting as an extern specifier.  */
  19523. -int have_extern_spec;
  19524. -int used_extern_spec;
  19525. -
  19526. -void yyhook ();
  19527. -
  19528. -/* Cons up an empty parameter list.  */
  19529. -#ifdef __GNUC__
  19530. -__inline
  19531. -#endif
  19532. -static tree
  19533. -empty_parms ()
  19534. -{
  19535. -  tree parms;
  19536. -
  19537. -  if (strict_prototype)
  19538. -    parms = void_list_node;
  19539. -  else
  19540. -    parms = NULL_TREE;
  19541. -  return parms;
  19542. -}
  19543. -
  19544. -#line 100 "parse.y"
  19545. -typedef union {long itype; tree ttype; char *strtype; enum tree_code code; } YYSTYPE;
  19546. -#line 278 "parse.y"
  19547. -
  19548. -/* List of types and structure classes of the current declaration.  */
  19549. -static tree current_declspecs;
  19550. -/* List of prefix attributes in effect.
  19551. -   Prefix attributes are parsed by the reserved_declspecs and declmods
  19552. -   rules.  They create a list that contains *both* declspecs and attrs.  */
  19553. -/* ??? It is not clear yet that all cases where an attribute can now appear in
  19554. -   a declspec list have been updated.  */
  19555. -static tree prefix_attributes;
  19556. -
  19557. -/* When defining an aggregate, this is the most recent one being defined.  */
  19558. -static tree current_aggr;
  19559. -
  19560. -/* Tell yyparse how to print a token's value, if yydebug is set.  */
  19561. -
  19562. -#define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL)
  19563. -extern void yyprint ();
  19564. -extern tree combine_strings        PROTO((tree));
  19565. -
  19566. -#ifndef YYLTYPE
  19567. -typedef
  19568. -  struct yyltype
  19569. -    {
  19570. -      int timestamp;
  19571. -      int first_line;
  19572. -      int first_column;
  19573. -      int last_line;
  19574. -      int last_column;
  19575. -      char *text;
  19576. -   }
  19577. -  yyltype;
  19578. -
  19579. -#define YYLTYPE yyltype
  19580. -#endif
  19581. -
  19582. -#include <stdio.h>
  19583. -
  19584. -#ifndef __cplusplus
  19585. -#ifndef __STDC__
  19586. -#define const
  19587. -#endif
  19588. -#endif
  19589. -
  19590. -
  19591. -
  19592. -#define    YYFINAL        1399
  19593. -#define    YYFLAG        -32768
  19594. -#define    YYNTBASE    109
  19595. -
  19596. -#define YYTRANSLATE(x) ((unsigned)(x) <= 339 ? yytranslate[x] : 364)
  19597. -
  19598. -static const char yytranslate[] = {     0,
  19599. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19600. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19601. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19602. -     2,     2,   107,     2,     2,     2,    80,    68,     2,    91,
  19603. -   105,    78,    76,    57,    77,    90,    79,     2,     2,     2,
  19604. -     2,     2,     2,     2,     2,     2,     2,    60,    58,    72,
  19605. -    62,    73,    63,     2,     2,     2,     2,     2,     2,     2,
  19606. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19607. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19608. -    92,     2,   108,    67,     2,     2,     2,     2,     2,     2,
  19609. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19610. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19611. -     2,     2,    56,    66,   106,    86,     2,     2,     2,     2,
  19612. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19613. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19614. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19615. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19616. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19617. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19618. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19619. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19620. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19621. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19622. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19623. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  19624. -     2,     2,     2,     2,     2,     1,     2,     3,     4,     5,
  19625. -     6,     7,     8,     9,    10,    11,    12,    13,    14,    15,
  19626. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  19627. -    26,    27,    28,    29,    30,    31,    32,    33,    34,    35,
  19628. -    36,    37,    38,    39,    40,    41,    42,    43,    44,    45,
  19629. -    46,    47,    48,    49,    50,    51,    52,    53,    54,    55,
  19630. -    59,    61,    64,    65,    69,    70,    71,    74,    75,    81,
  19631. -    82,    83,    84,    85,    87,    88,    89,    93,    94,    95,
  19632. -    96,    97,    98,    99,   100,   101,   102,   103,   104
  19633. -};
  19634. -
  19635. -#if YYDEBUG != 0
  19636. -static const short yyprhs[] = {     0,
  19637. -     0,     1,     3,     4,     7,    10,    12,    13,    14,    15,
  19638. -    17,    19,    20,    23,    25,    27,    29,    31,    37,    42,
  19639. -    47,    52,    53,    60,    61,    67,    73,    76,    81,    84,
  19640. -    88,    92,    94,    96,    99,   102,   104,   107,   108,   114,
  19641. -   116,   120,   122,   125,   127,   130,   132,   136,   138,   142,
  19642. -   144,   148,   149,   155,   156,   162,   163,   169,   170,   176,
  19643. -   180,   184,   191,   199,   204,   208,   212,   214,   216,   218,
  19644. -   220,   222,   225,   229,   233,   237,   241,   244,   247,   250,
  19645. -   253,   256,   258,   260,   262,   263,   265,   268,   269,   271,
  19646. -   276,   277,   283,   287,   291,   294,   298,   302,   305,   307,
  19647. -   314,   319,   323,   327,   330,   333,   336,   341,   344,   348,
  19648. -   349,   350,   352,   356,   359,   363,   365,   370,   373,   378,
  19649. -   381,   386,   389,   391,   393,   395,   397,   399,   401,   403,
  19650. -   405,   407,   409,   413,   417,   420,   425,   430,   434,   438,
  19651. -   443,   447,   452,   453,   455,   459,   461,   463,   464,   471,
  19652. -   472,   474,   475,   478,   480,   482,   484,   486,   488,   490,
  19653. -   492,   494,   498,   500,   504,   505,   507,   509,   510,   519,
  19654. -   521,   523,   527,   532,   536,   539,   541,   545,   549,   553,
  19655. -   557,   559,   561,   563,   564,   568,   571,   574,   577,   580,
  19656. -   583,   586,   591,   594,   599,   602,   606,   610,   615,   620,
  19657. -   626,   632,   639,   642,   647,   653,   657,   661,   665,   667,
  19658. -   671,   674,   678,   683,   685,   688,   694,   696,   700,   704,
  19659. -   708,   712,   716,   720,   724,   728,   732,   736,   740,   744,
  19660. -   748,   752,   756,   760,   764,   768,   772,   778,   782,   786,
  19661. -   788,   791,   795,   797,   799,   801,   803,   805,   807,   809,
  19662. -   812,   815,   819,   821,   823,   827,   829,   831,   833,   835,
  19663. -   839,   843,   847,   848,   853,   854,   861,   864,   869,   872,
  19664. -   875,   877,   882,   884,   885,   886,   896,   897,   898,   908,
  19665. -   909,   910,   920,   921,   922,   932,   937,   942,   945,   948,
  19666. -   950,   955,   958,   961,   964,   970,   974,   980,   984,   989,
  19667. -   996,   999,  1001,  1004,  1006,  1009,  1011,  1013,  1015,  1018,
  19668. -  1019,  1022,  1025,  1029,  1033,  1037,  1041,  1045,  1048,  1051,
  19669. -  1053,  1055,  1057,  1060,  1063,  1066,  1069,  1071,  1073,  1075,
  19670. -  1077,  1080,  1083,  1087,  1091,  1095,  1100,  1102,  1105,  1108,
  19671. -  1111,  1113,  1115,  1117,  1120,  1123,  1126,  1128,  1130,  1133,
  19672. -  1136,  1140,  1142,  1145,  1147,  1149,  1151,  1156,  1161,  1166,
  19673. -  1171,  1173,  1175,  1177,  1179,  1183,  1185,  1189,  1191,  1195,
  19674. -  1196,  1201,  1202,  1210,  1215,  1216,  1224,  1229,  1230,  1238,
  19675. -  1243,  1244,  1252,  1257,  1258,  1260,  1262,  1265,  1272,  1274,
  19676. -  1278,  1279,  1281,  1286,  1293,  1298,  1300,  1302,  1304,  1306,
  19677. -  1308,  1312,  1313,  1316,  1318,  1321,  1325,  1330,  1332,  1334,
  19678. -  1338,  1343,  1350,  1354,  1360,  1361,  1369,  1374,  1375,  1382,
  19679. -  1386,  1389,  1392,  1395,  1400,  1402,  1403,  1405,  1406,  1408,
  19680. -  1410,  1413,  1416,  1419,  1422,  1426,  1429,  1431,  1434,  1438,
  19681. -  1442,  1446,  1449,  1450,  1452,  1456,  1459,  1462,  1464,  1466,
  19682. -  1467,  1470,  1474,  1476,  1481,  1483,  1487,  1489,  1494,  1499,
  19683. -  1502,  1505,  1509,  1513,  1515,  1516,  1518,  1523,  1527,  1529,
  19684. -  1532,  1535,  1538,  1541,  1544,  1547,  1550,  1552,  1555,  1558,
  19685. -  1564,  1567,  1569,  1579,  1587,  1589,  1590,  1592,  1596,  1597,
  19686. -  1599,  1603,  1605,  1607,  1609,  1611,  1617,  1622,  1628,  1633,
  19687. -  1637,  1643,  1648,  1654,  1659,  1663,  1665,  1669,  1671,  1675,
  19688. -  1678,  1680,  1687,  1688,  1691,  1693,  1696,  1697,  1700,  1705,
  19689. -  1710,  1713,  1718,  1722,  1726,  1729,  1732,  1736,  1738,  1740,
  19690. -  1742,  1745,  1749,  1754,  1758,  1762,  1765,  1767,  1771,  1775,
  19691. -  1778,  1781,  1785,  1787,  1791,  1795,  1798,  1801,  1805,  1807,
  19692. -  1811,  1815,  1820,  1824,  1826,  1829,  1832,  1834,  1837,  1842,
  19693. -  1847,  1850,  1852,  1854,  1856,  1859,  1862,  1865,  1868,  1870,
  19694. -  1873,  1875,  1878,  1881,  1885,  1887,  1891,  1894,  1898,  1901,
  19695. -  1904,  1908,  1910,  1914,  1919,  1923,  1926,  1929,  1931,  1935,
  19696. -  1938,  1941,  1943,  1946,  1950,  1952,  1956,  1958,  1964,  1968,
  19697. -  1973,  1977,  1982,  1985,  1988,  1992,  1995,  1997,  1999,  2002,
  19698. -  2005,  2008,  2009,  2010,  2011,  2013,  2015,  2018,  2022,  2024,
  19699. -  2027,  2032,  2033,  2034,  2041,  2043,  2047,  2049,  2051,  2053,
  19700. -  2056,  2057,  2058,  2065,  2067,  2068,  2069,  2077,  2078,  2079,
  19701. -  2087,  2088,  2089,  2090,  2091,  2106,  2107,  2108,  2118,  2119,
  19702. -  2125,  2126,  2134,  2135,  2140,  2143,  2146,  2149,  2153,  2160,
  19703. -  2169,  2180,  2193,  2198,  2202,  2205,  2208,  2210,  2212,  2213,
  19704. -  2214,  2221,  2222,  2223,  2229,  2230,  2231,  2232,  2233,  2243,
  19705. -  2245,  2247,  2251,  2255,  2258,  2261,  2264,  2267,  2269,  2272,
  19706. -  2273,  2275,  2276,  2278,  2280,  2281,  2283,  2285,  2289,  2294,
  19707. -  2296,  2300,  2301,  2303,  2305,  2307,  2310,  2313,  2316,  2318,
  19708. -  2320,  2323,  2326,  2329,  2332,  2334,  2338,  2341,  2344,  2349,
  19709. -  2352,  2355,  2358,  2361,  2364,  2367,  2369,  2372,  2375,  2377,
  19710. -  2379,  2380,  2381,  2383,  2384,  2389,  2392,  2394,  2396,  2400,
  19711. -  2401,  2405,  2409,  2413,  2415,  2418,  2421,  2424,  2427,  2430,
  19712. -  2433,  2436,  2439,  2442,  2445,  2448,  2451,  2454,  2457,  2460,
  19713. -  2463,  2466,  2469,  2472,  2475,  2478,  2481,  2484,  2488,  2491,
  19714. -  2494,  2497,  2500,  2504,  2507,  2510,  2515,  2520,  2524
  19715. -};
  19716. -
  19717. -static const short yyrhs[] = {    -1,
  19718. -   110,     0,     0,   111,   116,     0,   110,   116,     0,   110,
  19719. -     0,     0,     0,     0,    25,     0,    26,     0,     0,   117,
  19720. -   118,     0,   141,     0,   137,     0,   131,     0,   129,     0,
  19721. -   115,    91,   200,   105,    58,     0,   123,    56,   112,   106,
  19722. -     0,   123,   113,   141,   114,     0,   123,   113,   137,   114,
  19723. -     0,     0,    42,   151,    56,   119,   112,   106,     0,     0,
  19724. -    42,    56,   120,   112,   106,     0,    42,   151,    62,   122,
  19725. -    58,     0,   121,    58,     0,    44,    42,   122,    58,     0,
  19726. -    44,   284,     0,    44,   294,   284,     0,    44,   294,   183,
  19727. -     0,   183,     0,   284,     0,   294,   284,     0,   294,   183,
  19728. -     0,    97,     0,   123,    97,     0,     0,    46,    72,   125,
  19729. -   126,    73,     0,   128,     0,   126,    57,   128,     0,   242,
  19730. -     0,   242,   151,     0,    43,     0,    43,   151,     0,   127,
  19731. -     0,   127,    62,   213,     0,   354,     0,    37,   130,    58,
  19732. -     0,     3,     0,   130,    57,     3,     0,     0,   124,   244,
  19733. -    56,   132,    58,     0,     0,   124,   245,    56,   133,    58,
  19734. -     0,     0,   124,   244,    60,   134,    58,     0,     0,   124,
  19735. -   245,    60,   135,    58,     0,   124,   244,    58,     0,   124,
  19736. -   245,    58,     0,   124,   281,   358,   218,   227,   136,     0,
  19737. -   124,   207,   204,   358,   218,   227,   136,     0,   124,   210,
  19738. -   281,   136,     0,   124,     1,   106,     0,   124,     1,    58,
  19739. -     0,    56,     0,    60,     0,    58,     0,    62,     0,    23,
  19740. -     0,   217,    58,     0,   210,   216,    58,     0,   210,   281,
  19741. -    58,     0,   207,   215,    58,     0,   207,   204,    58,     0,
  19742. -   210,    58,     0,   154,    58,     0,   207,    58,     0,     1,
  19743. -    58,     0,     1,   106,     0,    58,     0,   201,     0,   147,
  19744. -     0,     0,   146,     0,   146,    58,     0,     0,   104,     0,
  19745. -   143,   139,   138,   306,     0,     0,   143,   139,   329,   142,
  19746. -   140,     0,   207,   204,     1,     0,   210,   281,     1,     0,
  19747. -   281,     1,     0,   207,   204,   358,     0,   210,   281,   358,
  19748. -     0,   281,   358,     0,    96,     0,   207,    91,   349,   105,
  19749. -   272,   358,     0,   207,    45,   272,   358,     0,   207,   204,
  19750. -   358,     0,   210,   281,   358,     0,   281,   358,     0,    23,
  19751. -     3,     0,   145,   234,     0,   145,    91,   174,   105,     0,
  19752. -   145,    45,     0,    60,   148,   149,     0,     0,     0,   150,
  19753. -     0,   149,    57,   150,     0,   149,     1,     0,    91,   174,
  19754. -   105,     0,    45,     0,   152,    91,   174,   105,     0,   152,
  19755. -    45,     0,   291,    91,   174,   105,     0,   291,    45,     0,
  19756. -   285,    91,   174,   105,     0,   285,    45,     0,     3,     0,
  19757. -     4,     0,    54,     0,    55,     0,     3,     0,    54,     0,
  19758. -    55,     0,   101,     0,   100,     0,   102,     0,    46,   243,
  19759. -   162,     0,    46,   207,   204,     0,    46,   281,     0,     5,
  19760. -    46,   243,   162,     0,     5,    46,   207,   204,     0,     5,
  19761. -    46,   281,     0,   156,   157,   162,     0,    54,    72,   158,
  19762. -    73,     0,    54,    72,    73,     0,     4,    72,   158,    73,
  19763. -     0,     0,   159,     0,   158,    57,   159,     0,   206,     0,
  19764. -   181,     0,     0,    99,   251,   161,   256,   257,   106,     0,
  19765. -     0,   160,     0,     0,   160,   163,     0,    77,     0,    76,
  19766. -     0,    84,     0,    85,     0,   107,     0,   173,     0,   181,
  19767. -     0,    45,     0,    91,   165,   105,     0,    45,     0,    91,
  19768. -   169,   105,     0,     0,   169,     0,     1,     0,     0,   339,
  19769. -   204,   358,   218,   227,    62,   170,   235,     0,   165,     0,
  19770. -   106,     0,   303,   299,   106,     0,   303,   299,     1,   106,
  19771. -     0,   303,     1,   106,     0,    56,   171,     0,   313,     0,
  19772. -   181,    57,   181,     0,   181,    57,     1,     0,   173,    57,
  19773. -   181,     0,   173,    57,     1,     0,   181,     0,   173,     0,
  19774. -   186,     0,     0,    31,   176,   180,     0,    78,   180,     0,
  19775. -    68,   180,     0,    86,   180,     0,   164,   180,     0,    65,
  19776. -   151,     0,    11,   175,     0,    11,    91,   206,   105,     0,
  19777. -    28,   175,     0,    28,    91,   206,   105,     0,   197,   271,
  19778. -     0,   197,   271,   178,     0,   197,   177,   271,     0,   197,
  19779. -   177,   271,   178,     0,   197,    91,   206,   105,     0,   197,
  19780. -    91,   206,   105,   178,     0,   197,   177,    91,   206,   105,
  19781. -     0,   197,   177,    91,   206,   105,   178,     0,   198,   180,
  19782. -     0,   198,    92,   108,   180,     0,   198,    92,   165,   108,
  19783. -   180,     0,    91,   174,   105,     0,    56,   174,   106,     0,
  19784. -    91,   174,   105,     0,    45,     0,    91,   213,   105,     0,
  19785. -    62,   235,     0,    91,   206,   105,     0,   179,    91,   206,
  19786. -   105,     0,   175,     0,   179,   175,     0,   179,    56,   236,
  19787. -   240,   106,     0,   180,     0,   181,    81,   181,     0,   181,
  19788. -    82,   181,     0,   181,    76,   181,     0,   181,    77,   181,
  19789. -     0,   181,    78,   181,     0,   181,    79,   181,     0,   181,
  19790. -    80,   181,     0,   181,    74,   181,     0,   181,    75,   181,
  19791. -     0,   181,    71,   181,     0,   181,    72,   181,     0,   181,
  19792. -    73,   181,     0,   181,    70,   181,     0,   181,    69,   181,
  19793. -     0,   181,    68,   181,     0,   181,    66,   181,     0,   181,
  19794. -    67,   181,     0,   181,    65,   181,     0,   181,    64,   181,
  19795. -     0,   181,    63,   344,    60,   181,     0,   181,    62,   181,
  19796. -     0,   181,    61,   181,     0,    59,     0,    59,   181,     0,
  19797. -    86,   356,   151,     0,   363,     0,     3,     0,    54,     0,
  19798. -    55,     0,   182,     0,     4,     0,   182,     0,    78,   184,
  19799. -     0,    68,   184,     0,    91,   184,   105,     0,   283,     0,
  19800. -   182,     0,    91,   184,   105,     0,   182,     0,     8,     0,
  19801. -   199,     0,   200,     0,    91,   165,   105,     0,    91,   184,
  19802. -   105,     0,    91,     1,   105,     0,     0,    91,   187,   307,
  19803. -   105,     0,     0,   186,    91,   174,   105,   188,   163,     0,
  19804. -   186,    45,     0,   186,    92,   165,   108,     0,   186,    84,
  19805. -     0,   186,    85,     0,    38,     0,     7,    91,   174,   105,
  19806. -     0,   287,     0,     0,     0,    48,    72,   189,   206,    73,
  19807. -   190,    91,   165,   105,     0,     0,     0,    49,    72,   191,
  19808. -   206,    73,   192,    91,   165,   105,     0,     0,     0,    50,
  19809. -    72,   193,   206,    73,   194,    91,   165,   105,     0,     0,
  19810. -     0,    51,    72,   195,   206,    73,   196,    91,   165,   105,
  19811. -     0,    47,    91,   165,   105,     0,    47,    91,   206,   105,
  19812. -     0,   294,     3,     0,   294,   363,     0,   286,     0,   286,
  19813. -    91,   174,   105,     0,   286,    45,     0,   202,   183,     0,
  19814. -   202,   286,     0,   202,   183,    91,   174,   105,     0,   202,
  19815. -   183,    45,     0,   202,   286,    91,   174,   105,     0,   202,
  19816. -   286,    45,     0,   202,    86,     6,    45,     0,   202,     6,
  19817. -    52,    86,     6,    45,     0,   202,     1,     0,    36,     0,
  19818. -   294,    36,     0,    35,     0,   294,   198,     0,    40,     0,
  19819. -    41,     0,     9,     0,   200,     9,     0,     0,   186,    90,
  19820. -     0,   186,    89,     0,   213,   204,    58,     0,   207,   204,
  19821. -    58,     0,   213,   215,    58,     0,   207,   215,    58,     0,
  19822. -   210,   216,    58,     0,   207,    58,     0,   210,    58,     0,
  19823. -   277,     0,   281,     0,    45,     0,   205,    45,     0,   211,
  19824. -   297,     0,   273,   297,     0,   213,   297,     0,   211,     0,
  19825. -   273,     0,   211,     0,   208,     0,   210,   213,     0,   213,
  19826. -   209,     0,   213,   212,   209,     0,   210,   213,   209,     0,
  19827. -   210,   213,   212,     0,   210,   213,   212,   209,     0,     5,
  19828. -     0,   209,   214,     0,   209,     5,     0,   209,   228,     0,
  19829. -   228,     0,   273,     0,     5,     0,   210,     7,     0,   210,
  19830. -     5,     0,   210,   228,     0,   228,     0,   213,     0,   273,
  19831. -   213,     0,   213,   212,     0,   273,   213,   212,     0,   214,
  19832. -     0,   212,   214,     0,   237,     0,     6,     0,   291,     0,
  19833. -    27,    91,   165,   105,     0,    27,    91,   206,   105,     0,
  19834. -    29,    91,   165,   105,     0,    29,    91,   206,   105,     0,
  19835. -     6,     0,     7,     0,   237,     0,   219,     0,   215,    57,
  19836. -   221,     0,   223,     0,   216,    57,   221,     0,   225,     0,
  19837. -   217,    57,   221,     0,     0,   115,    91,   200,   105,     0,
  19838. -     0,   204,   358,   218,   227,    62,   220,   235,     0,   204,
  19839. -   358,   218,   227,     0,     0,   204,   358,   218,   227,    62,
  19840. -   222,   235,     0,   204,   358,   218,   227,     0,     0,   281,
  19841. -   358,   218,   227,    62,   224,   235,     0,   281,   358,   218,
  19842. -   227,     0,     0,   281,   358,   218,   227,    62,   226,   235,
  19843. -     0,   281,   358,   218,   227,     0,     0,   228,     0,   229,
  19844. -     0,   228,   229,     0,    30,    91,    91,   230,   105,   105,
  19845. -     0,   231,     0,   230,    57,   231,     0,     0,   232,     0,
  19846. -   232,    91,     3,   105,     0,   232,    91,     3,    57,   174,
  19847. -   105,     0,   232,    91,   174,   105,     0,   151,     0,     5,
  19848. -     0,     6,     0,     7,     0,   151,     0,   233,    57,   151,
  19849. -     0,     0,    62,   235,     0,   181,     0,    56,   106,     0,
  19850. -    56,   236,   106,     0,    56,   236,    57,   106,     0,     1,
  19851. -     0,   235,     0,   236,    57,   235,     0,    92,   181,   108,
  19852. -   235,     0,   236,    57,    19,   181,    60,   235,     0,   151,
  19853. -    60,   235,     0,   236,    57,   151,    60,   235,     0,     0,
  19854. -    12,   151,    56,   238,   269,   241,   106,     0,    12,   151,
  19855. -    56,   106,     0,     0,    12,    56,   239,   269,   241,   106,
  19856. -     0,    12,    56,   106,     0,    12,   151,     0,    12,   292,
  19857. -     0,    43,   292,     0,   250,   256,   257,   106,     0,   250,
  19858. -     0,     0,    57,     0,     0,    57,     0,    33,     0,   242,
  19859. -     5,     0,   242,     6,     0,   242,     7,     0,   242,    33,
  19860. -     0,   242,   156,    58,     0,   242,   151,     0,   243,     0,
  19861. -   242,   153,     0,   242,   156,    56,     0,   242,   156,    60,
  19862. -     0,   242,   289,   151,     0,   242,   155,     0,     0,   244,
  19863. -     0,   245,   247,   251,     0,   246,   251,     0,   242,    56,
  19864. -     0,   249,     0,   248,     0,     0,    60,   356,     0,    60,
  19865. -   356,   252,     0,   253,     0,   252,    57,   356,   253,     0,
  19866. -   254,     0,   255,   356,   254,     0,   291,     0,    29,    91,
  19867. -   165,   105,     0,    29,    91,   206,   105,     0,    34,   356,
  19868. -     0,     5,   356,     0,   255,    34,   356,     0,   255,     5,
  19869. -   356,     0,    56,     0,     0,   258,     0,   257,    34,    60,
  19870. -   258,     0,   257,    34,    60,     0,   259,     0,   258,   259,
  19871. -     0,   260,    58,     0,   260,   106,     0,   144,    60,     0,
  19872. -   144,    93,     0,   144,    23,     0,   144,    56,     0,    58,
  19873. -     0,   207,   261,     0,   210,   262,     0,   281,   358,   218,
  19874. -   227,   234,     0,    60,   181,     0,     1,     0,   207,    91,
  19875. -   349,   105,   272,   358,   218,   227,   234,     0,   207,    45,
  19876. -   272,   358,   218,   227,   234,     0,   121,     0,     0,   263,
  19877. -     0,   261,    57,   264,     0,     0,   266,     0,   262,    57,
  19878. -   268,     0,   265,     0,   266,     0,   267,     0,   268,     0,
  19879. -   277,   358,   218,   227,   234,     0,     4,    60,   181,   227,
  19880. -     0,   281,   358,   218,   227,   234,     0,     3,    60,   181,
  19881. -   227,     0,    60,   181,   227,     0,   277,   358,   218,   227,
  19882. -   234,     0,     4,    60,   181,   227,     0,   281,   358,   218,
  19883. -   227,   234,     0,     3,    60,   181,   227,     0,    60,   181,
  19884. -   227,     0,   270,     0,   269,    57,   270,     0,   151,     0,
  19885. -   151,    62,   181,     0,   339,   295,     0,   339,     0,    91,
  19886. -   206,   105,    92,   165,   108,     0,     0,   272,     7,     0,
  19887. -     7,     0,   273,     7,     0,     0,   274,   165,     0,   274,
  19888. -    91,   174,   105,     0,   274,    91,   349,   105,     0,   274,
  19889. -    45,     0,   274,    91,     1,   105,     0,    78,   273,   277,
  19890. -     0,    68,   273,   277,     0,    78,   277,     0,    68,   277,
  19891. -     0,   293,   272,   277,     0,   280,     0,   288,     0,   279,
  19892. -     0,   289,   288,     0,   280,   276,   272,     0,   280,    92,
  19893. -   275,   108,     0,   280,    92,   108,     0,    91,   277,   105,
  19894. -     0,   289,   288,     0,   288,     0,    78,   273,   281,     0,
  19895. -    68,   273,   281,     0,    78,   281,     0,    68,   281,     0,
  19896. -   293,   272,   281,     0,   185,     0,    78,   273,   281,     0,
  19897. -    68,   273,   281,     0,    78,   282,     0,    68,   282,     0,
  19898. -   293,   272,   281,     0,   283,     0,   185,   276,   272,     0,
  19899. -    91,   282,   105,     0,   185,    92,   275,   108,     0,   185,
  19900. -    92,   108,     0,   285,     0,   289,   183,     0,   289,   182,
  19901. -     0,   285,     0,   294,   285,     0,   213,    91,   174,   105,
  19902. -     0,   213,    91,   184,   105,     0,   213,   205,     0,     4,
  19903. -     0,   155,     0,   290,     0,   289,   290,     0,     4,    52,
  19904. -     0,    55,    52,     0,   155,    52,     0,   278,     0,   294,
  19905. -   278,     0,   279,     0,   294,   278,     0,   289,    78,     0,
  19906. -   294,   289,    78,     0,    52,     0,    78,   272,   295,     0,
  19907. -    78,   272,     0,    68,   272,   295,     0,    68,   272,     0,
  19908. -   293,   272,     0,   293,   272,   295,     0,   296,     0,    92,
  19909. -   165,   108,     0,   296,    92,   275,   108,     0,    78,   273,
  19910. -   297,     0,    78,   297,     0,    78,   273,     0,    78,     0,
  19911. -    68,   273,   297,     0,    68,   297,     0,    68,   273,     0,
  19912. -    68,     0,   293,   272,     0,   293,   272,   297,     0,   298,
  19913. -     0,    91,   297,   105,     0,    88,     0,   298,    91,   349,
  19914. -   105,   272,     0,   298,    45,   272,     0,   298,    92,   275,
  19915. -   108,     0,   298,    92,   108,     0,    91,   350,   105,   272,
  19916. -     0,   179,   272,     0,   205,   272,     0,    92,   275,   108,
  19917. -     0,    92,   108,     0,   312,     0,   300,     0,   299,   312,
  19918. -     0,   299,   300,     0,     1,    58,     0,     0,     0,     0,
  19919. -   304,     0,   305,     0,   304,   305,     0,    32,   233,    58,
  19920. -     0,   307,     0,     1,   307,     0,    56,   301,   171,   302,
  19921. -     0,     0,     0,    13,   309,   301,   167,   310,   311,     0,
  19922. -   307,     0,   301,   313,   302,     0,   307,     0,   313,     0,
  19923. -   203,     0,   165,    58,     0,     0,     0,   308,    14,   314,
  19924. -   311,   315,   302,     0,   308,     0,     0,     0,    15,   316,
  19925. -   301,   167,   317,   172,   302,     0,     0,     0,    16,   318,
  19926. -   311,    15,   319,   166,    58,     0,     0,     0,     0,     0,
  19927. -    17,   320,    91,   342,   321,   301,   168,    58,   322,   344,
  19928. -   105,   323,   172,   302,     0,     0,     0,    18,   301,    91,
  19929. -   169,   105,   324,   311,   325,   302,     0,     0,    19,   181,
  19930. -    60,   326,   312,     0,     0,    19,   181,    10,   181,    60,
  19931. -   327,   312,     0,     0,    20,    60,   328,   312,     0,    21,
  19932. -    58,     0,    22,    58,     0,    23,    58,     0,    23,   165,
  19933. -    58,     0,   115,   343,    91,   200,   105,    58,     0,   115,
  19934. -   343,    91,   200,    60,   345,   105,    58,     0,   115,   343,
  19935. -    91,   200,    60,   345,    60,   345,   105,    58,     0,   115,
  19936. -   343,    91,   200,    60,   345,    60,   345,    60,   348,   105,
  19937. -    58,     0,    24,    78,   165,    58,     0,    24,   151,    58,
  19938. -     0,   341,   312,     0,   341,   106,     0,    58,     0,   332,
  19939. -     0,     0,     0,    93,   330,   138,   306,   331,   335,     0,
  19940. -     0,     0,    93,   333,   307,   334,   335,     0,     0,     0,
  19941. -     0,     0,   335,    94,   301,   336,   340,   337,   307,   338,
  19942. -   302,     0,   211,     0,   273,     0,    91,    10,   105,     0,
  19943. -    91,   355,   105,     0,     3,    60,     0,    54,    60,     0,
  19944. -     4,    60,     0,   344,    58,     0,   203,     0,    56,   171,
  19945. -     0,     0,     7,     0,     0,   165,     0,     1,     0,     0,
  19946. -   346,     0,   347,     0,   346,    57,   347,     0,     9,    91,
  19947. -   165,   105,     0,     9,     0,   348,    57,     9,     0,     0,
  19948. -   350,     0,   206,     0,   351,     0,   352,    10,     0,   351,
  19949. -    10,     0,   206,    10,     0,    10,     0,    95,     0,   351,
  19950. -    95,     0,   206,    95,     0,   351,    60,     0,   206,    60,
  19951. -     0,   353,     0,   355,    62,   235,     0,   352,   354,     0,
  19952. -   352,   357,     0,   352,   357,    62,   235,     0,   351,    57,
  19953. -     0,   206,    57,     0,   208,   204,     0,   211,   204,     0,
  19954. -   213,   204,     0,   208,   297,     0,   208,     0,   210,   281,
  19955. -     0,   355,   234,     0,   353,     0,   206,     0,     0,     0,
  19956. -   281,     0,     0,    59,    91,   360,   105,     0,    59,    45,
  19957. -     0,   206,     0,   359,     0,   360,    57,   359,     0,     0,
  19958. -    78,   272,   361,     0,    68,   272,   361,     0,   293,   272,
  19959. -   361,     0,    39,     0,   362,    78,     0,   362,    79,     0,
  19960. -   362,    80,     0,   362,    76,     0,   362,    77,     0,   362,
  19961. -    68,     0,   362,    66,     0,   362,    67,     0,   362,    86,
  19962. -     0,   362,    57,     0,   362,    71,     0,   362,    72,     0,
  19963. -   362,    73,     0,   362,    70,     0,   362,    61,     0,   362,
  19964. -    62,     0,   362,    74,     0,   362,    75,     0,   362,    84,
  19965. -     0,   362,    85,     0,   362,    65,     0,   362,    64,     0,
  19966. -   362,   107,     0,   362,    63,    60,     0,   362,    69,     0,
  19967. -   362,    89,     0,   362,    81,     0,   362,    45,     0,   362,
  19968. -    92,   108,     0,   362,    36,     0,   362,    35,     0,   362,
  19969. -    36,    92,   108,     0,   362,    35,    92,   108,     0,   362,
  19970. -   339,   361,     0,   362,     1,     0
  19971. -};
  19972. -
  19973. -#endif
  19974. -
  19975. -#if YYDEBUG != 0
  19976. -static const short yyrline[] = { 0,
  19977. -   299,   300,   314,   316,   317,   321,   323,   326,   331,   335,
  19978. -   337,   340,   343,   347,   350,   352,   354,   355,   358,   360,
  19979. -   363,   366,   368,   370,   372,   374,   376,   378,   382,   385,
  19980. -   387,   391,   393,   394,   396,   400,   403,   409,   412,   416,
  19981. -   419,   423,   433,   435,   437,   441,   451,   453,   456,   461,
  19982. -   463,   467,   473,   473,   476,   476,   479,   479,   492,   492,
  19983. -   497,   502,   519,   540,   553,   554,   557,   558,   559,   560,
  19984. -   561,   564,   567,   570,   577,   582,   590,   592,   593,   613,
  19985. -   614,   615,   618,   621,   625,   627,   628,   631,   633,   636,
  19986. -   642,   647,   647,   649,   651,   655,   663,   669,   674,   682,
  19987. -   693,   700,   703,   706,   710,   718,   720,   722,   726,   739,
  19988. -   759,   762,   764,   765,   768,   774,   780,   782,   784,   786,
  19989. -   789,   793,   799,   801,   802,   803,   806,   808,   809,   812,
  19990. -   814,   815,   818,   821,   824,   826,   828,   831,   835,   840,
  19991. -   843,   845,   849,   854,   857,   861,   864,   867,   901,   919,
  19992. -   922,   926,   929,   933,   935,   937,   939,   941,   945,   947,
  19993. -   950,   955,   959,   964,   968,   971,   973,   977,   997,  1004,
  19994. -  1007,  1009,  1010,  1011,  1014,  1017,  1021,  1025,  1028,  1030,
  19995. -  1034,  1037,  1040,  1049,  1052,  1055,  1057,  1059,  1061,  1068,
  19996. -  1079,  1101,  1103,  1105,  1110,  1112,  1114,  1116,  1118,  1121,
  19997. -  1123,  1125,  1128,  1130,  1134,  1140,  1143,  1150,  1153,  1155,
  19998. -  1163,  1172,  1178,  1184,  1186,  1188,  1201,  1204,  1206,  1208,
  19999. -  1210,  1212,  1214,  1216,  1218,  1220,  1222,  1224,  1226,  1228,
  20000. -  1230,  1232,  1234,  1236,  1238,  1240,  1242,  1244,  1247,  1254,
  20001. -  1256,  1273,  1276,  1277,  1278,  1279,  1282,  1284,  1287,  1289,
  20002. -  1291,  1293,  1297,  1299,  1300,  1304,  1324,  1325,  1326,  1328,
  20003. -  1336,  1344,  1346,  1354,  1375,  1380,  1387,  1394,  1396,  1405,
  20004. -  1410,  1433,  1477,  1478,  1480,  1482,  1485,  1487,  1489,  1492,
  20005. -  1494,  1496,  1499,  1501,  1503,  1506,  1508,  1511,  1550,  1557,
  20006. -  1559,  1561,  1563,  1566,  1569,  1585,  1601,  1613,  1626,  1635,
  20007. -  1645,  1690,  1692,  1696,  1698,  1702,  1705,  1710,  1712,  1716,
  20008. -  1729,  1731,  1738,  1749,  1760,  1766,  1771,  1773,  1778,  1785,
  20009. -  1787,  1791,  1795,  1801,  1804,  1806,  1808,  1810,  1819,  1821,
  20010. -  1824,  1827,  1829,  1831,  1833,  1835,  1840,  1846,  1848,  1853,
  20011. -  1855,  1864,  1867,  1869,  1872,  1878,  1880,  1890,  1893,  1895,
  20012. -  1897,  1901,  1904,  1912,  1913,  1914,  1915,  1919,  1923,  1937,
  20013. -  1955,  1956,  1957,  1960,  1962,  1965,  1967,  1970,  1972,  1975,
  20014. -  1978,  1982,  2000,  2002,  2021,  2027,  2028,  2034,  2043,  2045,
  20015. -  2055,  2064,  2066,  2078,  2081,  2085,  2088,  2092,  2097,  2100,
  20016. -  2104,  2107,  2109,  2111,  2113,  2120,  2122,  2123,  2124,  2128,
  20017. -  2131,  2135,  2138,  2141,  2143,  2146,  2149,  2152,  2158,  2161,
  20018. -  2164,  2166,  2168,  2170,  2174,  2178,  2182,  2185,  2188,  2192,
  20019. -  2195,  2197,  2199,  2202,  2250,  2260,  2262,  2265,  2267,  2271,
  20020. -  2272,  2274,  2276,  2278,  2282,  2291,  2294,  2297,  2300,  2306,
  20021. -  2310,  2313,  2317,  2321,  2324,  2331,  2339,  2344,  2344,  2346,
  20022. -  2349,  2351,  2355,  2357,  2361,  2388,  2418,  2420,  2442,  2466,
  20023. -  2468,  2472,  2498,  2507,  2573,  2576,  2583,  2594,  2603,  2607,
  20024. -  2622,  2625,  2630,  2632,  2634,  2636,  2638,  2642,  2648,  2650,
  20025. -  2653,  2655,  2666,  2673,  2680,  2686,  2689,  2690,  2701,  2704,
  20026. -  2705,  2716,  2718,  2721,  2723,  2726,  2733,  2741,  2748,  2754,
  20027. -  2762,  2766,  2771,  2775,  2778,  2787,  2789,  2793,  2796,  2801,
  20028. -  2804,  2808,  2817,  2820,  2824,  2827,  2834,  2838,  2844,  2847,
  20029. -  2849,  2851,  2857,  2860,  2862,  2864,  2866,  2870,  2873,  2887,
  20030. -  2890,  2895,  2898,  2900,  2902,  2904,  2908,  2914,  2917,  2919,
  20031. -  2921,  2923,  2927,  2930,  2933,  2935,  2937,  2939,  2943,  2946,
  20032. -  2949,  2951,  2953,  2955,  2964,  2970,  2976,  2978,  2982,  2985,
  20033. -  2987,  2991,  2993,  2996,  2998,  3004,  3007,  3009,  3023,  3025,
  20034. -  3029,  3031,  3035,  3038,  3044,  3050,  3053,  3055,  3057,  3059,
  20035. -  3063,  3067,  3071,  3074,  3079,  3082,  3084,  3086,  3088,  3090,
  20036. -  3092,  3094,  3096,  3100,  3104,  3108,  3112,  3113,  3115,  3117,
  20037. -  3119,  3121,  3123,  3125,  3127,  3129,  3137,  3139,  3140,  3141,
  20038. -  3144,  3151,  3159,  3167,  3169,  3174,  3176,  3179,  3193,  3196,
  20039. -  3199,  3203,  3206,  3210,  3212,  3215,  3219,  3222,  3225,  3228,
  20040. -  3241,  3244,  3246,  3247,  3253,  3258,  3260,  3263,  3267,  3270,
  20041. -  3276,  3288,  3292,  3295,  3299,  3312,  3320,  3324,  3325,  3350,
  20042. -  3350,  3382,  3382,  3398,  3398,  3402,  3406,  3409,  3414,  3421,
  20043. -  3430,  3439,  3448,  3451,  3457,  3459,  3463,  3465,  3468,  3475,
  20044. -  3479,  3485,  3489,  3492,  3495,  3497,  3500,  3502,  3504,  3506,
  20045. -  3508,  3511,  3524,  3529,  3537,  3539,  3543,  3546,  3547,  3552,
  20046. -  3556,  3560,  3563,  3564,  3570,  3572,  3575,  3577,  3581,  3586,
  20047. -  3589,  3599,  3606,  3607,  3614,  3620,  3625,  3629,  3634,  3641,
  20048. -  3645,  3649,  3654,  3665,  3679,  3682,  3684,  3686,  3688,  3692,
  20049. -  3694,  3702,  3722,  3724,  3726,  3729,  3732,  3737,  3742,  3744,
  20050. -  3747,  3769,  3775,  3782,  3785,  3787,  3791,  3796,  3798,  3805,
  20051. -  3808,  3810,  3812,  3818,  3822,  3825,  3827,  3829,  3831,  3833,
  20052. -  3835,  3837,  3839,  3841,  3843,  3845,  3847,  3849,  3851,  3853,
  20053. -  3855,  3857,  3859,  3861,  3863,  3865,  3867,  3869,  3871,  3873,
  20054. -  3875,  3877,  3879,  3881,  3883,  3885,  3887,  3890,  3892
  20055. -};
  20056. -
  20057. -static const char * const yytname[] = {   "$","error","$illegal.","IDENTIFIER",
  20058. -"TYPENAME","SCSPEC","TYPESPEC","TYPE_QUAL","CONSTANT","STRING","ELLIPSIS","SIZEOF",
  20059. -"ENUM","IF","ELSE","WHILE","DO","FOR","SWITCH","CASE","DEFAULT","BREAK","CONTINUE",
  20060. -"RETURN","GOTO","ASM_KEYWORD","GCC_ASM_KEYWORD","TYPEOF","ALIGNOF","SIGOF","ATTRIBUTE",
  20061. -"EXTENSION","LABEL","AGGR","VISSPEC","DELETE","NEW","OVERLOAD","THIS","OPERATOR",
  20062. -"CXX_TRUE","CXX_FALSE","NAMESPACE","TYPENAME_KEYWORD","USING","LEFT_RIGHT","TEMPLATE",
  20063. -"TYPEID","DYNAMIC_CAST","STATIC_CAST","REINTERPRET_CAST","CONST_CAST","SCOPE",
  20064. -"EMPTY","PTYPENAME","NSNAME","'{'","','","';'","THROW","':'","ASSIGN","'='",
  20065. -"'?'","OROR","ANDAND","'|'","'^'","'&'","MIN_MAX","EQCOMPARE","ARITHCOMPARE",
  20066. -"'<'","'>'","LSHIFT","RSHIFT","'+'","'-'","'*'","'/'","'%'","POINTSAT_STAR",
  20067. -"DOT_STAR","UNARY","PLUSPLUS","MINUSMINUS","'~'","HYPERUNARY","PAREN_STAR_PAREN",
  20068. -"POINTSAT","'.'","'('","'['","TRY","CATCH","TYPENAME_ELLIPSIS","PRE_PARSED_FUNCTION_DECL",
  20069. -"EXTERN_LANG_STRING","ALL","PRE_PARSED_CLASS_DECL","TYPENAME_DEFN","IDENTIFIER_DEFN",
  20070. -"PTYPENAME_DEFN","END_OF_LINE","END_OF_SAVED_INPUT","')'","'}'","'!'","']'",
  20071. -"program","extdefs","@1","extdefs_opt",".hush_warning",".warning_ok","asm_keyword",
  20072. -"lang_extdef","@2","extdef","@3","@4","using_decl","any_id","extern_lang_string",
  20073. -"template_header","@5","template_parm_list","template_type_parm","template_parm",
  20074. -"overloaddef","ov_identifiers","template_def","@6","@7","@8","@9","fn_tmpl_end",
  20075. -"datadef","ctor_initializer_opt","maybe_return_init","eat_saved_input","fndef",
  20076. -"@10","fn.def1","fn.def2","return_id","return_init","base_init",".set_base_init",
  20077. -"member_init_list","member_init","identifier","notype_identifier","identifier_defn",
  20078. -"explicit_instantiation","template_type","template_type_name","tmpl.2","template_arg_list",
  20079. -"template_arg","template_instantiate_once","@11","template_instantiation","template_instantiate_some",
  20080. -"unop","expr","paren_expr_or_null","paren_cond_or_null","xcond","condition",
  20081. -"@12","compstmtend","already_scoped_stmt","nontrivial_exprlist","nonnull_exprlist",
  20082. -"unary_expr","@13","new_placement","new_initializer","regcast_or_absdcl","cast_expr",
  20083. -"expr_no_commas","notype_unqualified_id","unqualified_id","expr_or_declarator",
  20084. -"direct_notype_declarator","primary","@14","@15","@16","@17","@18","@19","@20",
  20085. -"@21","@22","@23","new","delete","boolean.literal","string","nodecls","object",
  20086. -"decl","declarator","fcast_or_absdcl","type_id","typed_declspecs","typed_declspecs1",
  20087. -"reserved_declspecs","declmods","typed_typespecs","reserved_typespecquals","typespec",
  20088. -"typespecqual_reserved","initdecls","notype_initdecls","nomods_initdecls","maybeasm",
  20089. -"initdcl0","@24","initdcl","@25","notype_initdcl0","@26","nomods_initdcl0","@27",
  20090. -"maybe_attribute","attributes","attribute","attribute_list","attrib","any_word",
  20091. -"identifiers_or_typenames","maybe_init","init","initlist","structsp","@28","@29",
  20092. -"maybecomma","maybecomma_warn","aggr","specialization","named_class_head_sans_basetype",
  20093. -"named_class_head_sans_basetype_defn","named_complex_class_head_sans_basetype",
  20094. -"do_xref_defn","named_class_head","unnamed_class_head","class_head","maybe_base_class_list",
  20095. -"base_class_list","base_class","base_class.1","base_class_access_list","left_curly",
  20096. -"opt.component_decl_list","component_decl_list","component_decl","component_decl_1",
  20097. -"components","notype_components","component_declarator0","component_declarator",
  20098. -"after_type_component_declarator0","notype_component_declarator0","after_type_component_declarator",
  20099. -"notype_component_declarator","enumlist","enumerator","new_type_id","type_quals",
  20100. -"nonempty_type_quals","suspend_mom","nonmomentary_expr","maybe_parmlist","after_type_declarator",
  20101. -"qualified_type_name","nested_type","direct_after_type_declarator","notype_declarator",
  20102. -"complex_notype_declarator","complex_direct_notype_declarator","qualified_id",
  20103. -"notype_qualified_id","overqualified_id","functional_cast","type_name","nested_name_specifier",
  20104. -"nested_name_specifier_1","complete_type_name","complex_type_name","ptr_to_mem",
  20105. -"global_scope","new_declarator","direct_new_declarator","absdcl","direct_abstract_declarator",
  20106. -"stmts","errstmt",".pushlevel",".poplevel","maybe_label_decls","label_decls",
  20107. -"label_decl","compstmt_or_error","compstmt","simple_if","@30","@31","implicitly_scoped_stmt",
  20108. -"stmt","simple_stmt","@32","@33","@34","@35","@36","@37","@38","@39","@40","@41",
  20109. -"@42","@43","@44","@45","@46","function_try_block","@47","@48","try_block","@49",
  20110. -"@50","handler_seq","@51","@52","@53","type_specifier_seq","handler_args","label_colon",
  20111. -"for.init.statement","maybe_type_qual","xexpr","asm_operands","nonnull_asm_operands",
  20112. -"asm_operand","asm_clobbers","parmlist","complex_parmlist","parms","parms_comma",
  20113. -"named_parm","full_parm","parm","see_typename","bad_parm","exception_specification_opt",
  20114. -"ansi_raise_identifier","ansi_raise_identifiers","conversion_declarator","operator",
  20115. -"operator_name",""
  20116. -};
  20117. -#endif
  20118. -
  20119. -static const short yyr1[] = {     0,
  20120. -   109,   109,   111,   110,   110,   112,   112,   113,   114,   115,
  20121. -   115,   117,   116,   118,   118,   118,   118,   118,   118,   118,
  20122. -   118,   119,   118,   120,   118,   118,   118,   118,   121,   121,
  20123. -   121,   122,   122,   122,   122,   123,   123,   125,   124,   126,
  20124. -   126,   127,   127,   127,   127,   128,   128,   128,   129,   130,
  20125. -   130,   132,   131,   133,   131,   134,   131,   135,   131,   131,
  20126. -   131,   131,   131,   131,   131,   131,   136,   136,   136,   136,
  20127. -   136,   137,   137,   137,   137,   137,   137,   137,   137,   137,
  20128. -   137,   137,   138,   138,   139,   139,   139,   140,   140,   141,
  20129. -   142,   141,   141,   141,   141,   143,   143,   143,   143,   144,
  20130. -   144,   144,   144,   144,   145,   146,   146,   146,   147,   148,
  20131. -   149,   149,   149,   149,   150,   150,   150,   150,   150,   150,
  20132. -   150,   150,   151,   151,   151,   151,   152,   152,   152,   153,
  20133. -   153,   153,   154,   154,   154,   154,   154,   154,   155,   156,
  20134. -   156,   156,   157,   158,   158,   159,   159,   161,   160,   162,
  20135. -   162,   163,   163,   164,   164,   164,   164,   164,   165,   165,
  20136. -   166,   166,   167,   167,   168,   168,   168,   170,   169,   169,
  20137. -   171,   171,   171,   171,   172,   172,   173,   173,   173,   173,
  20138. -   174,   174,   175,   176,   175,   175,   175,   175,   175,   175,
  20139. -   175,   175,   175,   175,   175,   175,   175,   175,   175,   175,
  20140. -   175,   175,   175,   175,   175,   177,   177,   178,   178,   178,
  20141. -   178,   179,   179,   180,   180,   180,   181,   181,   181,   181,
  20142. -   181,   181,   181,   181,   181,   181,   181,   181,   181,   181,
  20143. -   181,   181,   181,   181,   181,   181,   181,   181,   181,   181,
  20144. -   181,   182,   182,   182,   182,   182,   183,   183,   184,   184,
  20145. -   184,   184,   185,   185,   185,   186,   186,   186,   186,   186,
  20146. -   186,   186,   187,   186,   188,   186,   186,   186,   186,   186,
  20147. -   186,   186,   186,   189,   190,   186,   191,   192,   186,   193,
  20148. -   194,   186,   195,   196,   186,   186,   186,   186,   186,   186,
  20149. -   186,   186,   186,   186,   186,   186,   186,   186,   186,   186,
  20150. -   186,   197,   197,   198,   198,   199,   199,   200,   200,   201,
  20151. -   202,   202,   203,   203,   203,   203,   203,   203,   203,   204,
  20152. -   204,   205,   205,   206,   206,   206,   206,   206,   207,   207,
  20153. -   208,   208,   208,   208,   208,   208,   209,   209,   209,   209,
  20154. -   209,   210,   210,   210,   210,   210,   210,   211,   211,   211,
  20155. -   211,   212,   212,   213,   213,   213,   213,   213,   213,   213,
  20156. -   214,   214,   214,   215,   215,   216,   216,   217,   217,   218,
  20157. -   218,   220,   219,   219,   222,   221,   221,   224,   223,   223,
  20158. -   226,   225,   225,   227,   227,   228,   228,   229,   230,   230,
  20159. -   231,   231,   231,   231,   231,   232,   232,   232,   232,   233,
  20160. -   233,   234,   234,   235,   235,   235,   235,   235,   236,   236,
  20161. -   236,   236,   236,   236,   238,   237,   237,   239,   237,   237,
  20162. -   237,   237,   237,   237,   237,   240,   240,   241,   241,   242,
  20163. -   242,   242,   242,   242,   243,   244,   244,   245,   245,   245,
  20164. -   246,   246,   247,   248,   248,   248,   249,   250,   250,   251,
  20165. -   251,   251,   252,   252,   253,   253,   254,   254,   254,   255,
  20166. -   255,   255,   255,   256,   257,   257,   257,   257,   258,   258,
  20167. -   259,   259,   259,   259,   259,   259,   259,   260,   260,   260,
  20168. -   260,   260,   260,   260,   260,   261,   261,   261,   262,   262,
  20169. -   262,   263,   263,   264,   264,   265,   265,   266,   266,   266,
  20170. -   267,   267,   268,   268,   268,   269,   269,   270,   270,   271,
  20171. -   271,   271,   272,   272,   273,   273,   274,   275,   276,   276,
  20172. -   276,   276,   277,   277,   277,   277,   277,   277,   278,   278,
  20173. -   279,   280,   280,   280,   280,   280,   280,   281,   281,   281,
  20174. -   281,   281,   281,   282,   282,   282,   282,   282,   282,   283,
  20175. -   283,   283,   283,   283,   284,   285,   286,   286,   287,   287,
  20176. -   287,   288,   288,   289,   289,   290,   290,   290,   291,   291,
  20177. -   292,   292,   293,   293,   294,   295,   295,   295,   295,   295,
  20178. -   295,   295,   296,   296,   297,   297,   297,   297,   297,   297,
  20179. -   297,   297,   297,   297,   297,   298,   298,   298,   298,   298,
  20180. -   298,   298,   298,   298,   298,   298,   299,   299,   299,   299,
  20181. -   300,   301,   302,   303,   303,   304,   304,   305,   306,   306,
  20182. -   307,   309,   310,   308,   311,   311,   312,   312,   313,   313,
  20183. -   314,   315,   313,   313,   316,   317,   313,   318,   319,   313,
  20184. -   320,   321,   322,   323,   313,   324,   325,   313,   326,   313,
  20185. -   327,   313,   328,   313,   313,   313,   313,   313,   313,   313,
  20186. -   313,   313,   313,   313,   313,   313,   313,   313,   330,   331,
  20187. -   329,   333,   334,   332,   335,   336,   337,   338,   335,   339,
  20188. -   339,   340,   340,   341,   341,   341,   342,   342,   342,   343,
  20189. -   343,   344,   344,   344,   345,   345,   346,   346,   347,   348,
  20190. -   348,   349,   349,   349,   350,   350,   350,   350,   350,   350,
  20191. -   350,   350,   350,   350,   351,   351,   351,   351,   351,   352,
  20192. -   352,   353,   353,   353,   353,   353,   353,   354,   355,   355,
  20193. -   356,   357,   357,   358,   358,   358,   359,   360,   360,   361,
  20194. -   361,   361,   361,   362,   363,   363,   363,   363,   363,   363,
  20195. -   363,   363,   363,   363,   363,   363,   363,   363,   363,   363,
  20196. -   363,   363,   363,   363,   363,   363,   363,   363,   363,   363,
  20197. -   363,   363,   363,   363,   363,   363,   363,   363,   363
  20198. -};
  20199. -
  20200. -static const short yyr2[] = {     0,
  20201. -     0,     1,     0,     2,     2,     1,     0,     0,     0,     1,
  20202. -     1,     0,     2,     1,     1,     1,     1,     5,     4,     4,
  20203. -     4,     0,     6,     0,     5,     5,     2,     4,     2,     3,
  20204. -     3,     1,     1,     2,     2,     1,     2,     0,     5,     1,
  20205. -     3,     1,     2,     1,     2,     1,     3,     1,     3,     1,
  20206. -     3,     0,     5,     0,     5,     0,     5,     0,     5,     3,
  20207. -     3,     6,     7,     4,     3,     3,     1,     1,     1,     1,
  20208. -     1,     2,     3,     3,     3,     3,     2,     2,     2,     2,
  20209. -     2,     1,     1,     1,     0,     1,     2,     0,     1,     4,
  20210. -     0,     5,     3,     3,     2,     3,     3,     2,     1,     6,
  20211. -     4,     3,     3,     2,     2,     2,     4,     2,     3,     0,
  20212. -     0,     1,     3,     2,     3,     1,     4,     2,     4,     2,
  20213. -     4,     2,     1,     1,     1,     1,     1,     1,     1,     1,
  20214. -     1,     1,     3,     3,     2,     4,     4,     3,     3,     4,
  20215. -     3,     4,     0,     1,     3,     1,     1,     0,     6,     0,
  20216. -     1,     0,     2,     1,     1,     1,     1,     1,     1,     1,
  20217. -     1,     3,     1,     3,     0,     1,     1,     0,     8,     1,
  20218. -     1,     3,     4,     3,     2,     1,     3,     3,     3,     3,
  20219. -     1,     1,     1,     0,     3,     2,     2,     2,     2,     2,
  20220. -     2,     4,     2,     4,     2,     3,     3,     4,     4,     5,
  20221. -     5,     6,     2,     4,     5,     3,     3,     3,     1,     3,
  20222. -     2,     3,     4,     1,     2,     5,     1,     3,     3,     3,
  20223. -     3,     3,     3,     3,     3,     3,     3,     3,     3,     3,
  20224. -     3,     3,     3,     3,     3,     3,     5,     3,     3,     1,
  20225. -     2,     3,     1,     1,     1,     1,     1,     1,     1,     2,
  20226. -     2,     3,     1,     1,     3,     1,     1,     1,     1,     3,
  20227. -     3,     3,     0,     4,     0,     6,     2,     4,     2,     2,
  20228. -     1,     4,     1,     0,     0,     9,     0,     0,     9,     0,
  20229. -     0,     9,     0,     0,     9,     4,     4,     2,     2,     1,
  20230. -     4,     2,     2,     2,     5,     3,     5,     3,     4,     6,
  20231. -     2,     1,     2,     1,     2,     1,     1,     1,     2,     0,
  20232. -     2,     2,     3,     3,     3,     3,     3,     2,     2,     1,
  20233. -     1,     1,     2,     2,     2,     2,     1,     1,     1,     1,
  20234. -     2,     2,     3,     3,     3,     4,     1,     2,     2,     2,
  20235. -     1,     1,     1,     2,     2,     2,     1,     1,     2,     2,
  20236. -     3,     1,     2,     1,     1,     1,     4,     4,     4,     4,
  20237. -     1,     1,     1,     1,     3,     1,     3,     1,     3,     0,
  20238. -     4,     0,     7,     4,     0,     7,     4,     0,     7,     4,
  20239. -     0,     7,     4,     0,     1,     1,     2,     6,     1,     3,
  20240. -     0,     1,     4,     6,     4,     1,     1,     1,     1,     1,
  20241. -     3,     0,     2,     1,     2,     3,     4,     1,     1,     3,
  20242. -     4,     6,     3,     5,     0,     7,     4,     0,     6,     3,
  20243. -     2,     2,     2,     4,     1,     0,     1,     0,     1,     1,
  20244. -     2,     2,     2,     2,     3,     2,     1,     2,     3,     3,
  20245. -     3,     2,     0,     1,     3,     2,     2,     1,     1,     0,
  20246. -     2,     3,     1,     4,     1,     3,     1,     4,     4,     2,
  20247. -     2,     3,     3,     1,     0,     1,     4,     3,     1,     2,
  20248. -     2,     2,     2,     2,     2,     2,     1,     2,     2,     5,
  20249. -     2,     1,     9,     7,     1,     0,     1,     3,     0,     1,
  20250. -     3,     1,     1,     1,     1,     5,     4,     5,     4,     3,
  20251. -     5,     4,     5,     4,     3,     1,     3,     1,     3,     2,
  20252. -     1,     6,     0,     2,     1,     2,     0,     2,     4,     4,
  20253. -     2,     4,     3,     3,     2,     2,     3,     1,     1,     1,
  20254. -     2,     3,     4,     3,     3,     2,     1,     3,     3,     2,
  20255. -     2,     3,     1,     3,     3,     2,     2,     3,     1,     3,
  20256. -     3,     4,     3,     1,     2,     2,     1,     2,     4,     4,
  20257. -     2,     1,     1,     1,     2,     2,     2,     2,     1,     2,
  20258. -     1,     2,     2,     3,     1,     3,     2,     3,     2,     2,
  20259. -     3,     1,     3,     4,     3,     2,     2,     1,     3,     2,
  20260. -     2,     1,     2,     3,     1,     3,     1,     5,     3,     4,
  20261. -     3,     4,     2,     2,     3,     2,     1,     1,     2,     2,
  20262. -     2,     0,     0,     0,     1,     1,     2,     3,     1,     2,
  20263. -     4,     0,     0,     6,     1,     3,     1,     1,     1,     2,
  20264. -     0,     0,     6,     1,     0,     0,     7,     0,     0,     7,
  20265. -     0,     0,     0,     0,    14,     0,     0,     9,     0,     5,
  20266. -     0,     7,     0,     4,     2,     2,     2,     3,     6,     8,
  20267. -    10,    12,     4,     3,     2,     2,     1,     1,     0,     0,
  20268. -     6,     0,     0,     5,     0,     0,     0,     0,     9,     1,
  20269. -     1,     3,     3,     2,     2,     2,     2,     1,     2,     0,
  20270. -     1,     0,     1,     1,     0,     1,     1,     3,     4,     1,
  20271. -     3,     0,     1,     1,     1,     2,     2,     2,     1,     1,
  20272. -     2,     2,     2,     2,     1,     3,     2,     2,     4,     2,
  20273. -     2,     2,     2,     2,     2,     1,     2,     2,     1,     1,
  20274. -     0,     0,     1,     0,     4,     2,     1,     1,     3,     0,
  20275. -     3,     3,     3,     1,     2,     2,     2,     2,     2,     2,
  20276. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  20277. -     2,     2,     2,     2,     2,     2,     2,     3,     2,     2,
  20278. -     2,     2,     3,     2,     2,     4,     4,     3,     2
  20279. -};
  20280. -
  20281. -static const short yydefact[] = {     3,
  20282. -    12,    12,     5,     0,     4,     0,   244,   562,   343,   355,
  20283. -   515,     0,    10,    11,     0,     0,     0,   430,     0,   744,
  20284. -     0,     0,     0,     0,   575,   245,   246,    82,     0,     0,
  20285. -   731,     0,    99,    36,     0,    13,     0,     8,     0,    17,
  20286. -    16,    15,    14,    85,     0,   563,   143,   254,   543,     0,
  20287. -   330,     0,   329,   348,     0,   368,   347,   386,   354,     0,
  20288. -   437,   444,   443,   450,   449,   448,   425,   342,   569,   530,
  20289. -     0,   253,   554,   529,     0,   564,   356,   513,     0,     0,
  20290. -   243,    80,    81,   566,     0,     0,   123,   124,   125,   126,
  20291. -   418,   421,     0,   571,     0,   422,     0,     0,     0,     0,
  20292. -    50,     0,   124,   125,   126,    24,     0,     0,     0,     0,
  20293. -   423,     0,    29,     0,     0,   343,    38,     0,     0,   437,
  20294. -   135,     0,   567,     0,   541,     0,     0,     0,   540,     0,
  20295. -     0,     0,     0,   254,     0,   517,     0,   253,   513,     0,
  20296. -    27,     3,    37,     0,     0,     0,     0,   444,   443,   734,
  20297. -     0,   310,   402,    86,    78,   568,   150,   517,     0,   513,
  20298. -    79,     0,     0,     0,     0,     0,   364,   320,   528,   321,
  20299. -   537,     0,   513,   345,   344,    77,   331,     0,   366,   346,
  20300. -     0,   337,   361,   362,   332,   350,   352,   341,   363,     0,
  20301. -    72,   387,   431,   432,   433,   434,   447,   131,   130,   132,
  20302. -   436,   438,   442,   143,     0,   450,   731,   446,   464,     0,
  20303. -   516,   349,     0,    95,     0,    98,   573,   556,   531,   565,
  20304. -     0,   570,     0,   779,   775,   774,   772,   754,   759,   760,
  20305. -     0,   766,   765,   751,   752,   750,   769,   758,   755,   756,
  20306. -   757,   761,   762,   748,   749,   745,   746,   747,   771,   763,
  20307. -   764,   753,   770,     0,   767,   680,   348,   681,   740,   515,
  20308. -   257,   308,     0,     0,   184,   304,   302,   271,   306,   307,
  20309. -     0,     0,     0,     0,     0,   240,     0,     0,   155,   154,
  20310. -     0,   156,   157,     0,     0,   158,     0,   144,     0,   214,
  20311. -     0,   217,   147,   256,   183,     0,     0,   258,   259,     0,
  20312. -   146,   327,   348,   328,   557,   290,   273,     0,     0,     0,
  20313. -   437,   138,   420,     0,   415,   572,     0,   159,   160,     0,
  20314. -     0,     0,   391,     0,    49,     3,    22,     0,   248,     0,
  20315. -   247,    32,    33,     0,   555,    31,    30,     0,   134,   450,
  20316. -   151,   133,   141,     0,   539,     0,   538,   242,   251,     0,
  20317. -   547,   250,     0,   546,     0,   255,   551,     0,     0,    12,
  20318. -     0,     0,     9,     9,    66,    65,   734,     0,    52,    60,
  20319. -    56,    54,    61,    58,   370,   105,   110,   669,     0,    84,
  20320. -    83,    91,   108,     0,     0,   106,    87,   139,   553,     0,
  20321. -     0,   521,     0,   550,     0,   526,     0,   525,     0,     0,
  20322. -     0,     0,   513,    93,    76,    96,     0,    75,   517,   513,
  20323. -   536,     0,   334,   335,     0,    73,    94,    74,    97,   339,
  20324. -   338,   340,   333,   353,   734,   369,   439,   435,   440,   441,
  20325. -   445,   451,   482,     0,   477,     0,   485,     0,   486,   489,
  20326. -     0,     0,   469,     0,   734,   351,   736,     0,     0,   384,
  20327. -   514,   542,   574,     0,     0,   768,   773,   350,   513,   513,
  20328. -     0,   513,   778,     0,     0,     0,   191,     0,     0,   193,
  20329. -     0,     0,   274,   277,   280,   283,   241,   190,   187,   186,
  20330. -   188,     0,     0,     0,     0,     0,   256,     0,     0,     0,
  20331. -     0,   142,   189,     0,     0,   215,     0,     0,     0,     0,
  20332. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  20333. -     0,     0,     0,     0,     0,     0,     0,     0,   267,   269,
  20334. -   270,   312,   311,     0,     0,     0,     0,     0,   195,   511,
  20335. -     0,   203,   309,   301,     0,   731,   293,   294,     0,     0,
  20336. -   322,   592,   588,   597,     0,   517,   513,   513,   513,   324,
  20337. -   595,     0,   561,   326,     0,   325,   292,     0,   288,   303,
  20338. -   305,   558,     0,   289,   137,   136,   508,   428,   506,   417,
  20339. -     0,   357,     0,     0,   358,   359,   360,   397,   398,   399,
  20340. -   396,     0,   389,   392,    51,     0,     3,     0,    28,    35,
  20341. -    34,    44,     0,    46,    40,   730,   726,     0,   327,   348,
  20342. -    42,   328,   729,    48,   402,   148,   140,   545,   544,   255,
  20343. -   548,     0,    19,    21,    20,   370,    71,    67,    69,    68,
  20344. -    70,    64,     0,     0,     0,     0,   384,   111,   310,     0,
  20345. -   612,    90,   619,    88,   408,     0,   404,   403,   182,     0,
  20346. -   181,   518,   552,     0,   709,   710,     0,   704,   348,     0,
  20347. -   703,   705,   732,   715,     0,   524,   523,     0,     0,   535,
  20348. -     0,   384,   365,   534,     0,   532,   527,   336,   367,   384,
  20349. -   370,   731,     0,   731,   452,   453,   455,   731,   457,   481,
  20350. -   475,   476,   473,   474,   244,   562,   513,     0,   702,   734,
  20351. -   478,   487,   492,   493,   734,   734,   479,   490,   734,     0,
  20352. -   424,   470,   471,   472,   104,   737,   348,   738,     0,     0,
  20353. -   383,   385,   777,   776,   740,   740,   740,     0,     0,     0,
  20354. -   561,     0,   185,     0,     0,     0,     0,     0,     0,   262,
  20355. -     0,   260,   261,     0,   212,   145,   244,   562,   245,   246,
  20356. -     0,     0,   409,   426,     0,   239,   238,   694,   693,     0,
  20357. -   236,   235,   233,   234,   232,   231,   230,   227,   228,   229,
  20358. -   225,   226,   220,   221,   222,   223,   224,   218,   219,     0,
  20359. -     0,     0,     0,     0,     0,   197,   209,     0,     0,   196,
  20360. -   513,   513,     0,   513,   510,   582,     0,     0,     0,     0,
  20361. -   296,     0,   298,     0,   591,   590,   587,   586,   730,     0,
  20362. -     0,   606,     0,     0,   603,   323,   604,   593,   513,   702,
  20363. -   517,   592,   588,     0,     0,   513,     0,     0,     0,     0,
  20364. -   429,     0,   428,   180,   179,   178,   177,   391,     0,     0,
  20365. -    25,     0,    26,    45,     0,    39,     0,   592,   588,     0,
  20366. -   722,   513,   725,   727,   723,   724,   436,   728,     0,    18,
  20367. -   384,    53,    57,    55,    59,     0,   127,   116,   128,   129,
  20368. -     0,   109,   112,     0,     0,     0,     0,   620,   614,    89,
  20369. -    92,   405,     0,   107,   522,   519,   708,   721,   714,   712,
  20370. -     0,   520,   707,   720,   713,   711,   706,   733,   717,   718,
  20371. -     0,   374,   533,   380,   384,   461,     0,   460,   731,   731,
  20372. -   731,     0,     0,     0,   734,   384,   529,     0,     0,   102,
  20373. -     0,   370,   370,     0,   370,     0,   384,     0,   735,     0,
  20374. -   381,   742,   741,   743,   272,   192,   194,   286,   287,     0,
  20375. -     0,     0,     0,   261,   264,     0,     0,     0,     0,   213,
  20376. -     0,   265,   268,   207,   206,   199,     0,   198,   211,     0,
  20377. -     0,   579,   577,     0,   580,   517,   204,     0,     0,   299,
  20378. -     0,     0,   589,   585,   596,   513,   605,   594,   599,     0,
  20379. -   601,     0,   559,   560,     0,   291,   509,   507,   419,     0,
  20380. -   390,   388,   244,     0,    23,    41,    47,   591,   587,   592,
  20381. -   588,     0,   513,   593,     0,     0,    62,     0,   114,     0,
  20382. -   118,     0,   122,     0,   120,     0,   670,     0,   171,   613,
  20383. -     0,   615,   616,     0,   406,   592,   588,     0,   256,     0,
  20384. -   557,     0,   716,   372,   378,   377,     0,     0,     0,   463,
  20385. -   462,   456,   384,   384,   101,   500,   531,   513,   244,   562,
  20386. -     0,   488,   494,   495,   734,   734,   384,   384,   491,     0,
  20387. -   402,   739,   371,     0,   275,   278,   281,   284,     0,   413,
  20388. -     0,     0,   410,   216,   237,   152,     0,   200,   201,   208,
  20389. -   210,   578,   576,   583,   581,     0,   205,     0,   295,   297,
  20390. -   602,   513,   600,   416,     0,   393,   395,   591,   587,   593,
  20391. -     0,    63,   115,   113,     0,     0,     0,   675,   400,     0,
  20392. -   621,     0,   244,   562,   622,   635,   638,   641,   612,     0,
  20393. -     0,     0,     0,     0,     0,   245,   667,   672,   690,     0,
  20394. -   629,     0,     0,   348,     0,   608,   627,   634,   607,   628,
  20395. -   668,     0,   617,   407,     0,   560,   719,     0,     0,   375,
  20396. -   458,   459,   454,   499,   497,   384,   734,     0,     0,   384,
  20397. -   370,   370,   402,   402,   480,   382,     0,     0,     0,     0,
  20398. -   411,     0,     0,   152,   266,     0,   202,   584,   300,   598,
  20399. -     0,   149,   117,   121,   119,   671,     0,   618,   611,   174,
  20400. -   684,   686,   612,   612,   612,     0,     0,     0,   653,   655,
  20401. -   656,   657,     0,     0,     0,   685,     0,   691,     0,   630,
  20402. -   318,   734,     0,   319,     0,   734,     0,   734,     0,     0,
  20403. -   172,   610,   609,   631,   666,   665,   261,   373,   379,     0,
  20404. -   402,   100,   384,   384,   505,   384,   384,   496,   498,     0,
  20405. -     0,     0,     0,     0,   414,   153,   512,   394,   612,   401,
  20406. -     0,     0,     0,   625,     0,     0,     0,     0,   649,     0,
  20407. -   658,     0,   664,   673,     0,   314,   370,   316,   317,   370,
  20408. -     0,     0,     0,   313,   315,   173,   612,   376,   484,   384,
  20409. -   504,   502,   402,   402,     0,     0,     0,     0,   412,   676,
  20410. -   163,     0,   623,   636,   613,   639,   614,   688,   642,     0,
  20411. -   170,     0,   348,     0,     0,     0,   654,   663,   675,     0,
  20412. -   632,   402,   501,   503,   276,   279,   282,   285,     0,     0,
  20413. -   612,     0,   626,     0,   689,   612,   687,   646,   734,   651,
  20414. -   650,   674,   695,     0,   613,   483,     0,   677,   164,   624,
  20415. -   614,   613,   176,   161,     0,     0,     0,   612,   370,     0,
  20416. -     0,     0,   696,   697,   659,   633,     0,     0,     0,   175,
  20417. -   637,     0,   640,   167,     0,   166,   647,   384,   652,     0,
  20418. -   695,     0,     0,   682,   683,   678,   162,   643,   613,     0,
  20419. -     0,     0,   660,   698,   613,     0,   648,   168,   699,     0,
  20420. -     0,   679,     0,     0,   700,     0,   661,   644,   169,     0,
  20421. -     0,     0,   701,   662,   613,   645,     0,     0,     0
  20422. -};
  20423. -
  20424. -static const short yydefgoto[] = {  1397,
  20425. -   360,     2,   361,   144,   614,   449,     3,     4,    36,   587,
  20426. -   326,   437,   330,    38,    39,   338,   593,   594,   595,    40,
  20427. -   102,    41,   623,   625,   624,   626,   622,    42,   379,   152,
  20428. -   871,    43,   634,    44,   438,   153,   154,   380,   628,   862,
  20429. -   863,   567,   864,   202,    45,    46,    47,   157,   287,   288,
  20430. -   341,   849,   342,  1165,   289,  1120,  1336,  1283,  1355,  1292,
  20431. -  1384,  1010,  1332,   318,   815,   290,   471,   528,   780,   291,
  20432. -   292,   319,   294,   332,   349,    49,   295,   489,  1066,   726,
  20433. -  1157,   727,  1158,   728,  1159,   729,  1160,   296,   297,   298,
  20434. -   299,   381,   300,  1121,   425,   548,   799,  1122,    51,   185,
  20435. -   598,   302,   186,   468,   187,   166,   178,    55,   662,   167,
  20436. -  1138,   426,  1220,   179,  1139,    56,  1054,   711,    57,    58,
  20437. -   582,   583,   584,  1100,   386,   743,   744,    59,   571,   314,
  20438. -   939,   822,    60,    61,    62,    63,    64,   206,    65,    66,
  20439. -    67,   208,   675,   676,   677,   678,   210,   441,   442,   443,
  20440. -   444,   691,   697,   692,  1042,   693,   694,  1043,  1044,   568,
  20441. -   569,   529,   805,   304,   390,   391,   160,   168,    69,    70,
  20442. -   169,   170,   137,    72,   113,   305,   306,   307,    74,   308,
  20443. -    76,    77,   111,    78,   309,   785,   786,   800,   551,  1125,
  20444. -  1126,  1243,  1101,  1011,  1012,  1013,   632,  1127,  1128,  1183,
  20445. -  1311,  1245,  1129,  1130,  1267,  1325,  1184,  1312,  1185,  1314,
  20446. -  1186,  1316,  1376,  1392,  1338,  1369,  1296,  1340,  1250,   382,
  20447. -   629,  1098,  1131,  1197,  1299,  1176,  1309,  1349,  1375,  1294,
  20448. -  1328,  1132,  1289,  1199,   750,  1342,  1343,  1344,  1386,   650,
  20449. -   801,   652,   653,   654,   604,   655,   130,   890,  1257,   708,
  20450. -   709,   463,    80,    81
  20451. -};
  20452. -
  20453. -static const short yypact[] = {    97,
  20454. -   116,-32768,-32768,  8850,-32768,    40,-32768,   288,    73,-32768,
  20455. --32768,   624,-32768,-32768,   296,   300,   313,-32768,   229,-32768,
  20456. -   835,   612,  1146,  4474,-32768,   164,   228,-32768,  2545,  2545,
  20457. --32768,  1682,-32768,-32768,   317,-32768,   183,   182,  2615,-32768,
  20458. --32768,-32768,-32768,   389,   243,   383,-32768,-32768,   414,  1529,
  20459. --32768,  3016,-32768,  1349,   217,-32768,   431,-32768,-32768,  1163,
  20460. --32768,-32768,-32768,   406,-32768,-32768,   420,  1796,-32768,-32768,
  20461. -   471,-32768,-32768,-32768,   359,-32768,-32768,-32768,   122,  5657,
  20462. --32768,-32768,-32768,-32768,  7811,  9178,-32768,   288,   164,   228,
  20463. -   382,   436,   383,-32768,   122,-32768,   122,  7811,  7811,   423,
  20464. --32768,   240,-32768,-32768,-32768,-32768,   395,   288,   164,   228,
  20465. --32768,   569,-32768,   644,   644,-32768,-32768,  3469,  4823,   250,
  20466. --32768,  7639,-32768,  2622,-32768,   786,   366,  2622,-32768,   685,
  20467. -  3130,  3130,  1682,   412,   415,   450,   442,   463,-32768,   572,
  20468. --32768,   472,-32768,  8910,    65,  3469,  9222,   603,   756,   543,
  20469. -   609,   177,   136,   548,-32768,-32768,   534,   537,    38,-32768,
  20470. --32768,  3202,  3202,  4066,  1043,   298,-32768,-32768,   445,-32768,
  20471. --32768,   359,-32768,-32768,-32768,-32768,  1349,   320,-32768,   431,
  20472. -  1739,-32768,-32768,-32768,  1424,  1349,-32768,   431,-32768,  3469,
  20473. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20474. --32768,-32768,   383,   800,  1016,   406,-32768,-32768,-32768,  1925,
  20475. --32768,   925,   122,-32768,   270,   885,-32768,-32768,-32768,-32768,
  20476. -  3282,-32768,    81,-32768,   547,   550,-32768,-32768,-32768,-32768,
  20477. -   598,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20478. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20479. --32768,-32768,-32768,   562,-32768,-32768,   925,  1796,   506,   586,
  20480. --32768,-32768,  8417,  8503,-32768,-32768,-32768,-32768,-32768,-32768,
  20481. -   590,   601,   614,   618,   625,  7897,   685,  8589,-32768,-32768,
  20482. -  8589,-32768,-32768,  8589,  6100,-32768,   140,-32768,  8589,-32768,
  20483. -  7983,-32768,  9443,-32768,  1195,   704,  8069,-32768,   675,  1417,
  20484. --32768,   689,  2013,  3730,-32768,   338,-32768,  1008,  1105,  3469,
  20485. -   250,-32768,-32768,   685,   597,-32768,   604,   655,  9375,   633,
  20486. -   637,   640,   847,   745,-32768,   472,-32768,   569,   288,   692,
  20487. --32768,-32768,-32768,   644,-32768,-32768,-32768,  9332,-32768,   406,
  20488. --32768,-32768,-32768,   231,-32768,   218,-32768,-32768,-32768,  2622,
  20489. --32768,-32768,  2622,-32768,   665,-32768,-32768,  3282,    59,   695,
  20490. -   698,  9178,-32768,-32768,-32768,-32768,   543,  1176,-32768,-32768,
  20491. --32768,-32768,-32768,-32768,   457,-32768,-32768,-32768,   105,-32768,
  20492. --32768,-32768,-32768,  6186,  7897,-32768,-32768,-32768,-32768,  7897,
  20493. -   683,-32768,  5492,   801,  3787,-32768,  3787,-32768,  3853,  3853,
  20494. -  4066,   706,-32768,-32768,-32768,   885,  3469,-32768,   705,-32768,
  20495. --32768,  4278,  1424,  1349,  3469,-32768,-32768,-32768,   885,-32768,
  20496. --32768,   431,  1424,-32768,   543,-32768,-32768,-32768,-32768,-32768,
  20497. --32768,  1158,-32768,   612,-32768,  7897,-32768,   367,   881,  9014,
  20498. -    35,  4006,-32768,   124,   543,   925,-32768,  2527,   727,   431,
  20499. --32768,-32768,-32768,   724,   729,-32768,-32768,   925,-32768,-32768,
  20500. -   399,-32768,-32768,  7897,   586,  6100,-32768,   348,  6100,-32768,
  20501. -  8589,  7811,-32768,-32768,-32768,-32768,  9349,-32768,-32768,-32768,
  20502. --32768,   738,  8675,  8675,  6100,   757,   412,   766,   823,   778,
  20503. -  7811,-32768,-32768,  6008,  6100,-32768,  7897,  7897,  6272,  7897,
  20504. -  7897,  7897,  7897,  7897,  7897,  7897,  7897,  7897,  7897,  7897,
  20505. -  7897,  7897,  7897,  7897,  7897,  7897,  7897,  7897,-32768,-32768,
  20506. --32768,-32768,-32768,  7897,  7897,  7897,  7811,  4343,   284,   731,
  20507. -  6788,-32768,-32768,-32768,   840,   888,   424,   441,  1037,   366,
  20508. --32768,  2302,  2302,-32768,  3076,   791,   822,   872,-32768,-32768,
  20509. -   499,  7276,  1606,-32768,   444,-32768,-32768,  7897,-32768,-32768,
  20510. --32768,-32768,    57,-32768,-32768,-32768,   856,   862,-32768,-32768,
  20511. -   685,-32768,  6616,  6702,-32768,-32768,-32768,-32768,-32768,-32768,
  20512. --32768,   138,-32768,   838,-32768,   828,   472,   880,-32768,-32768,
  20513. --32768,   870,   308,   895,-32768,-32768,  1567,  9222,  1567,  2459,
  20514. -  1163,  2362,-32768,-32768,   898,-32768,-32768,-32768,-32768,   857,
  20515. --32768,   912,-32768,-32768,-32768,   457,-32768,-32768,-32768,-32768,
  20516. --32768,-32768,   913,   915,   917,   929,   431,    76,   930,   823,
  20517. --32768,-32768,-32768,   891,-32768,  5744,  9349,-32768,   655,   884,
  20518. -  9375,-32768,-32768,   896,-32768,-32768,   901,   189,  2792,   903,
  20519. --32768,   204,  9074,   943,   948,-32768,-32768,  3787,  3787,-32768,
  20520. -  4278,   431,-32768,-32768,   907,   801,-32768,  1424,-32768,   431,
  20521. -   457,-32768,   944,-32768,   964,-32768,-32768,   261,-32768,  9349,
  20522. --32768,-32768,-32768,-32768,   977,   622,-32768,  7897,  4673,   543,
  20523. -   986,-32768,-32768,-32768,   279,   452,   988,-32768,   543,   989,
  20524. --32768,-32768,-32768,-32768,   286,-32768,  4121,-32768,   145,   572,
  20525. -   992,   431,-32768,-32768,   364,   364,   364,   967,   972,  8159,
  20526. -   872,   973,-32768,   974,   976,  2527,  2527,  2527,  2527,-32768,
  20527. -   979,-32768,-32768,   980,-32768,-32768,   996,   712,    39,   328,
  20528. -  7897,  1022,-32768,   991,   984,  9349,  9349,-32768,-32768,  1033,
  20529. -  9461,  4349,  3589,  2144,  2250,  4153,  3772,  1437,  1437,  1437,
  20530. -   951,   951,   673,   673,    20,    20,    20,-32768,-32768,   990,
  20531. -   998,  1001,   993,  1005,  2527,   284,-32768,  6186,  7897,-32768,
  20532. --32768,-32768,  7897,-32768,-32768,  1021,  8589,  1006,  1029,  1072,
  20533. --32768,  7897,-32768,  7897,  2962,-32768,  2962,-32768,   115,  1017,
  20534. -  1020,-32768,  1018,  2527,   801,-32768,   801,  3172,-32768,  1854,
  20535. -  1023,  7459,  7459,  5294,  1028,  7983,  1030,  1105,  1041,  7897,
  20536. -   685,  1032,   862,-32768,  9349,-32768,  9349,   847,  1042,  8245,
  20537. --32768,  1036,-32768,-32768,  9332,-32768,  2560,  2025,  2025,  8970,
  20538. --32768,-32768,-32768,-32768,-32768,-32768,   337,-32768,   420,-32768,
  20539. -   431,-32768,-32768,-32768,-32768,  1176,-32768,-32768,   164,   228,
  20540. -  7897,  1092,-32768,   448,   464,   512,   105,-32768,    42,-32768,
  20541. --32768,-32768,    18,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20542. -  7369,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,  1102,
  20543. -  6186,  1103,-32768,  1109,   431,-32768,  7811,-32768,-32768,-32768,
  20544. --32768,  1154,  7897,  7897,   101,  9253,-32768,   359,  1049,-32768,
  20545. -  1932,   457,   457,  2678,  1027,  4779,   431,  2527,-32768,    63,
  20546. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,  1101,
  20547. -  1107,  1108,  1116,   857,-32768,  9327,  6186,  5836,  1076,-32768,
  20548. -  7897,-32768,-32768,-32768,-32768,   379,  1085,-32768,-32768,  1086,
  20549. -    51,   255,   255,  1097,   255,-32768,-32768,  8589,  1187,-32768,
  20550. -  1106,  1110,-32768,-32768,-32768,-32768,-32768,-32768,   801,  1111,
  20551. --32768,  1099,-32768,-32768,   900,-32768,  9349,-32768,-32768,  1114,
  20552. --32768,-32768,   151,  1117,-32768,-32768,-32768,  2226,  2226,  2817,
  20553. -  2817,  8970,-32768,  2861,  1925,  1176,-32768,  1118,-32768,    76,
  20554. --32768,  7897,-32768,  7897,-32768,  7897,-32768,   685,-32768,-32768,
  20555. -  4927,  1182,-32768,  5922,-32768,  7549,  7549,  5387,   462,  1119,
  20556. -   552,  6186,-32768,-32768,-32768,  1159,  1121,  1122,  1158,-32768,
  20557. --32768,-32768,  9253,  9253,   286,-32768,-32768,-32768,  1169,   716,
  20558. -  7897,-32768,-32768,-32768,   543,   543,   431,   431,-32768,  5052,
  20559. -   898,-32768,-32768,  6186,-32768,-32768,-32768,-32768,  6186,-32768,
  20560. -  7897,  1170,-32768,-32768,  9349,   534,  7897,-32768,   379,-32768,
  20561. --32768,-32768,-32768,-32768,-32768,  1125,-32768,  1190,-32768,-32768,
  20562. -   801,-32768,-32768,-32768,  7897,-32768,-32768,  2226,  2226,  2861,
  20563. -    44,-32768,-32768,-32768,  1136,  1139,  1142,-32768,-32768,   468,
  20564. --32768,   149,  1189,   892,-32768,-32768,-32768,-32768,-32768,  7897,
  20565. -  1196,  1203,  1204,  7725,   150,   371,-32768,-32768,  1259,  1209,
  20566. --32768,  3379,  9118,  3564,  5203,-32768,-32768,  1256,-32768,-32768,
  20567. --32768,  6894,-32768,-32768,  1167,  1532,-32768,  6186,  6186,-32768,
  20568. --32768,-32768,-32768,-32768,-32768,   431,   101,  7897,  7897,  9253,
  20569. -   457,   457,   898,   898,-32768,-32768,  1183,  1184,  1185,  1186,
  20570. --32768,  9398,  6186,   534,-32768,  1165,-32768,-32768,-32768,   801,
  20571. -  1177,-32768,-32768,-32768,-32768,  1194,   685,-32768,-32768,-32768,
  20572. --32768,-32768,-32768,-32768,   823,  1192,  1200,  5113,-32768,-32768,
  20573. --32768,-32768,  1237,  7897,  1241,-32768,   823,-32768,  1211,-32768,
  20574. --32768,   559,   662,-32768,   740,   543,  8331,   776,   808,   154,
  20575. --32768,-32768,-32768,-32768,-32768,-32768,   560,-32768,-32768,  6186,
  20576. -   898,   286,  9253,  9253,-32768,   431,   431,-32768,-32768,  7897,
  20577. -  7897,  7897,  7897,  6186,-32768,-32768,-32768,-32768,-32768,-32768,
  20578. -   531,   531,  7185,-32768,  1285,  5597,  7811,  7897,-32768,  6999,
  20579. --32768,  1246,-32768,-32768,   572,-32768,   457,-32768,-32768,   457,
  20580. -  8761,  8761,  6358,-32768,-32768,-32768,   823,-32768,-32768,   431,
  20581. --32768,-32768,   898,   898,  1201,  1202,  1205,  1208,-32768,-32768,
  20582. --32768,  7811,-32768,-32768,-32768,-32768,    42,-32768,-32768,  1247,
  20583. --32768,  1213,   178,  3469,  9421,  6999,-32768,-32768,-32768,    50,
  20584. --32768,   898,-32768,-32768,-32768,-32768,-32768,-32768,  1218,  1215,
  20585. -   823,  7092,-32768,   555,-32768,-32768,-32768,-32768,   543,-32768,
  20586. --32768,  1194,  1307,  1266,-32768,-32768,  4597,-32768,-32768,-32768,
  20587. -    42,-32768,-32768,-32768,  7897,  1269,  6444,   823,   457,  6999,
  20588. -  1239,   143,  1271,-32768,-32768,-32768,  1227,  1230,   823,-32768,
  20589. --32768,  1232,-32768,-32768,  1282,-32768,-32768,   431,-32768,  7897,
  20590. -  1307,  1283,  1307,-32768,-32768,-32768,-32768,-32768,-32768,  1284,
  20591. -  1244,   208,-32768,-32768,-32768,  6530,-32768,-32768,-32768,  1343,
  20592. -  1295,-32768,  1252,  6186,-32768,   162,-32768,-32768,-32768,  1351,
  20593. -  1304,  7092,-32768,-32768,-32768,-32768,  1363,  1365,-32768
  20594. -};
  20595. -
  20596. -static const short yypgoto[] = {-32768,
  20597. -  1366,-32768,  -294,-32768,  1003,     2,  1369,-32768,-32768,-32768,
  20598. --32768,  1368,  1045,-32768,-32768,-32768,-32768,-32768,   542,-32768,
  20599. --32768,-32768,-32768,-32768,-32768,-32768,  -809,  1236,   752,-32768,
  20600. --32768,  1242,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20601. -   390,   223,-32768,-32768,-32768,  4560,   -58,-32768,  1261,   904,
  20602. - -1001,-32768,  -118,   227,-32768,   297,-32768,   161,-32768, -1205,
  20603. --32768, -1165,    13,  1398,  -199,  -239,-32768,-32768,  -715,  2893,
  20604. -   672,  2474,  3277,   -48,   508,   186,-32768,-32768,-32768,-32768,
  20605. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,  -305,-32768,
  20606. -  -139,-32768,-32768,   163,   -34,  -276,   141,    14,  -231,  -132,
  20607. -     5,    47,  -169,    -4,   -72,  -672,   285,-32768,  -186,-32768,
  20608. --32768,  -206,-32768,-32768,-32768,-32768,-32768,   669,   278,   -43,
  20609. --32768,   579,-32768,-32768,  -500,  -159,   774,   -12,-32768,-32768,
  20610. --32768,   592,  -319,     4,  1374,  1377,-32768,-32768,-32768,-32768,
  20611. --32768,  -144,-32768,   388,   517,-32768,   578,   439,   519,  -439,
  20612. --32768,-32768,-32768,-32768,-32768,-32768,   997,-32768,   524,   869,
  20613. -   620,   914,  1273,     7,    11,  -394,  1275,  1799,   -56,    28,
  20614. --32768,  1690,  -110,   582,   -57,  3151,  1145,-32768,  3909,  1346,
  20615. -   210,  -399,  1438,  3783,  2123,  -126,-32768,  3654,-32768,-32768,
  20616. -   326,  -614, -1038,-32768,-32768,   440,   588,  -163,-32768,-32768,
  20617. --32768, -1194, -1062, -1209,-32768,-32768,-32768,-32768,-32768,-32768,
  20618. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  20619. --32768,-32768,-32768,-32768,-32768,   167,-32768,-32768,-32768,   -54,
  20620. --32768,-32768,-32768,-32768, -1197,    92,-32768,    99,-32768,  -632,
  20621. -  -337,-32768,-32768,  -333,   807,  -331,  -194,-32768,   -61,   557,
  20622. --32768,   181,-32768,  -297
  20623. -};
  20624. -
  20625. -
  20626. -#define    YYLAST        9543
  20627. -
  20628. -
  20629. -static const short yytable[] = {    54,
  20630. -   359,   204,   702,   561,   603,    35,   605,   414,    52,   216,
  20631. -    68,   564,   432,   192,   665,   165,   869,    50,   601,    54,
  20632. -   351,   354,   222,   467,   470,   259,   553,   120,   119,   450,
  20633. -    68,   586,   679,  1285,    54,   124,   128,   118,   388,    94,
  20634. -   316,   189,   446,   147,   413,    68,   997,   177,  1290,    94,
  20635. -    53,   496,   146,   423,   333,   651,   909,   337,   533,   159,
  20636. -   948,   431,  1213,   212,  1164,   335,   336,   533,   700,  1216,
  20637. -    53,   533,  1301,  1008,  1014,   257,  1310,   700,   857,     8,
  20638. -   303,    54,   392,   339,     8,    53,   258,   458,   375,   311,
  20639. -   119,   266,    68,   303,   303,   541,    -1,    82,  -125,   310,
  20640. -   517,   518,  1333,   406,   848,   630,   597,   451,    25,  1323,
  20641. -   122,   367,   421,   424,   177,    -2,  1330,   303,    86,   419,
  20642. -   858,  1315,   365,  1015,   877,     8,   256,    25,   393,   859,
  20643. -   860,  1356,    53,   458,   109,   110,   192,   350,   353,    54,
  20644. -   701,   720,   177,  1357,   192,    83,   159,  1009,    52,  1172,
  20645. -    68,   803,    87,   103,  1324,  1071,   222,    50,   453,   215,
  20646. -   631,   597,  1164,   612,   189,  1350,   861,  1053,   395,   397,
  20647. -   366,   878,   189,   189,   879,   109,   110,   970,  1383,   159,
  20648. -   383,   703,  1333,   183,   184,   640,  1092,  1297,   627,    12,
  20649. -    53,   721,   566,   647,   828,   606,   491,   384,   877,   189,
  20650. -   663,   918,  1361,   104,   105,    54,  1179,  1085,   669,   880,
  20651. -    18,  1179,   492,   883,   440,   633,    68,   136,  1390,   735,
  20652. -    22,   108,   541,   439,   638,   301,   385,  1194,   866,   704,
  20653. -  1068,   101,   670,  1321,    92,   122,   377,   142,   320,   322,
  20654. -   141,   530,   829,   107,   189,   878,  1313,  1362,   879,   919,
  20655. -  -730,   537,   222,   212,  1180,  1086,    53,   561,   108,  1266,
  20656. -   884,   451,   301,   885,   718,   900,  1391,  1380,   720,   378,
  20657. -   333,   109,   110,   190,   191,   565,   591,  1359,   143,   123,
  20658. -   303,   668,   201,   880,   220,   590,  1346,   491,   351,   354,
  20659. -   189,   257,   832,  1351,   901,   453,   324,   325,   886,   212,
  20660. -   155,  -320,   258,   607,   220,   616,    25,  -150,   109,   110,
  20661. -    13,    14,  1381,   597,   447,  -370,   136,   136,   136,   603,
  20662. -   597,   605,   781,   220,   770,   734,   772,   773,   777,   180,
  20663. -  1377,   188,   782,   600,  -320,   220,  1382,   215,  -320,    84,
  20664. -   421,   424,   256,  -370,   602,   778,   783,  -370,   340,   136,
  20665. -   421,   651,   348,  1167,   407,   408,  1396,    54,   819,    85,
  20666. -   448,     7,     8,   671,   835,   120,   119,   108,    68,   108,
  20667. -   451,  -320,   553,   424,   779,   118,   415,   416,   192,   123,
  20668. -   836,   220,   557,   705,   599,   424,    98,  -126,   649,   681,
  20669. -    99,  -370,   541,   -43,   317,   321,   180,    20,   -43,   602,
  20670. -   189,   189,   108,   100,   690,   658,   659,   140,    53,   -43,
  20671. -   189,   151,    26,    27,   220,    25,   972,   109,   110,   109,
  20672. -   110,   597,   682,   777,   180,   490,   683,   430,   558,   851,
  20673. -  1196,   459,   220,   189,   156,   177,   217,    54,   720,   599,
  20674. -   778,   460,   122,   707,    31,   189,   440,     8,    68,  1203,
  20675. -   327,  1209,   109,   110,   188,   439,   328,   597,  -517,   684,
  20676. -    17,   303,   422,   188,   303,   207,   868,   303,   791,   779,
  20677. -  1067,   214,   651,   530,  -321,   209,   217,   896,   596,   898,
  20678. -   303,    13,    14,   902,   895,   793,   303,   313,    53,  -517,
  20679. -   303,   315,  1001,  -734,  1187,  -734,  -734,   109,   110,   478,
  20680. -  -734,   603,   679,   605,  -517,   158,  -254,  -321,  1003,   108,
  20681. -   215,  -321,   561,   323,   792,   601,  -249,   220,   917,   356,
  20682. -   564,   217,   303,   257,  1177,  1178,  -734,  -734,  -734,   215,
  20683. -  -734,   794,  -734,   648,   258,  -517,   409,   458,  1002,   135,
  20684. -   600,   158,   204,   809,  -321,   581,   357,   649,   795,   797,
  20685. -  1155,   602,  -254,  -254,  1004,   220,  1005,    25,   602,   109,
  20686. -   110,  1076,   841,  -734,   845,   846,  -249,  -549,  1241,  1242,
  20687. -   920,     7,   329,   459,   256,  1281,   496,    -7,   597,   950,
  20688. -   262,   486,   597,   460,   136,   136,   136,   189,   706,   810,
  20689. -   811,   599,   961,   177,   962,   421,  -554,   212,   599,  1334,
  20690. -   866,   215,  1006,   597,  -255,   387,   719,    20,   597,   722,
  20691. -   702,   376,   725,   138,   846,   108,  1256,   215,   949,    94,
  20692. -    25,  1282,    26,    27,  1280,   490,    87,    88,   910,   679,
  20693. -   984,   301,   340,   912,   913,   745,   189,   915,   454,   352,
  20694. -   355,   455,  -554,  -554,   389,  1335,     7,   329,   600,   597,
  20695. -  -255,  -255,  1228,  1229,    31,   189,  -554,   456,   369,   602,
  20696. -   370,   998,   371,    25,  -252,   109,   110,   774,   192,   457,
  20697. -   220,   135,   473,    84,   721,    25,   464,    89,    90,    91,
  20698. -   472,   904,    20,   533,   600,   474,   642,    87,   103,   475,
  20699. -   422,   188,   108,    85,   189,   602,   476,    26,    27,   599,
  20700. -   422,  1337,   570,   633,  1029,  1030,  1031,     8,   572,    10,
  20701. -    11,   573,   138,   138,   138,    12,   742,   180,   407,  1258,
  20702. -  1269,   707,   707,   707,   707,  1047,  1048,   712,  1048,    31,
  20703. -    15,  1023,    16,   541,   108,   599,    18,   575,   104,   105,
  20704. -    25,   576,   109,   110,   577,   138,    22,   585,   220,   589,
  20705. -   514,   515,   516,   517,   518,    25,   542,   109,   110,   526,
  20706. -   597,   222,   486,    84,   220,   486,   543,    84,   724,   610,
  20707. -   707,  -124,  1303,  1304,   951,  1149,   544,  1060,  1063,   545,
  20708. -   546,   486,    25,    85,   109,   110,   597,    85,     7,   108,
  20709. -   643,   486,   488,   596,   527,   749,   415,  1259,   781,   707,
  20710. -    -6,  1326,  1095,   613,  1096,   600,  1097,   451,   782,   649,
  20711. -   660,   372,   664,   373,   834,   374,   602,   710,   795,   797,
  20712. -   602,   771,   783,   847,    20,  1072,  1073,   788,  1075,   648,
  20713. -   600,   713,   987,  1264,   215,   600,   714,    87,   103,    26,
  20714. -    27,   602,   730,  1035,   988,   989,   602,   721,  1146,    87,
  20715. -   103,   578,   579,   580,  1063,   427,   599,   428,   742,   429,
  20716. -   599,   732,  1137,   217,   407,  1265,   930,   931,   932,   933,
  20717. -   733,    31,    87,    88,   136,   180,   649,   188,   631,   351,
  20718. -   354,   599,   735,   685,   686,  1171,   599,   602,   104,   105,
  20719. -   106,   789,   303,   790,  1156,   922,   923,   924,   802,  1161,
  20720. -   104,   105,     7,     8,   712,   351,   354,   352,   355,    13,
  20721. -    14,    54,   804,   707,  -370,   947,   806,   820,   821,    20,
  20722. -   440,    25,    68,    89,    90,   687,   188,   599,   830,   439,
  20723. -   183,   184,    25,   831,    26,    27,    12,   833,    20,   712,
  20724. -   688,  -370,  -370,    84,   745,   422,  -370,   712,   162,   479,
  20725. -   648,  1182,   480,    26,    27,   481,   837,    18,   163,   384,
  20726. -   493,  -252,    53,    85,  1226,  1227,    31,    22,   532,   850,
  20727. -   852,   689,   853,   488,   854,   596,   488,   453,  1218,  1219,
  20728. -   138,   138,   138,  1151,  1152,    31,   855,   600,   874,   377,
  20729. -    54,   352,   731,   603,   870,  1348,  1088,  1089,   602,   440,
  20730. -   875,    68,   488,  1235,  -729,   876,  1124,   882,   439,   891,
  20731. -     7,     8,  1119,   649,   893,  1123,   721,    68,    87,    88,
  20732. -   899,  1244,  1088,  1089,   602,   136,   512,   513,   514,   515,
  20733. -   516,   517,   518,  1254,   897,  1270,   903,  1028,   599,     7,
  20734. -   108,    53,   911,   404,   914,    54,    20,   938,   916,  -103,
  20735. -   581,    13,    14,   921,   440,  -123,    68,    53,   706,   817,
  20736. -  1268,    26,    27,   439,   599,  -734,   136,  -734,  -734,    89,
  20737. -    90,   925,  -734,   670,  1279,    20,   926,   927,   928,   954,
  20738. -   929,   937,  -103,   934,   935,  1222,  -103,  1202,   940,  1208,
  20739. -    26,    27,   941,    31,   942,   597,    53,   945,  -734,  -734,
  20740. -   405,   215,  -734,  1244,  -734,   943,   944,   559,     8,   946,
  20741. -   486,   189,   956,   958,   959,  1300,   960,   220,   177,  -103,
  20742. -  1124,   965,    31,   458,   966,   967,  1119,  1124,   712,  1123,
  20743. -   971,    68,   973,  1119,   974,  -734,  1123,   979,    68,   266,
  20744. -   560,   985,   723,    20,  1260,   976,   982,  1244,  1000,   108,
  20745. -   351,   354,  1358,  1038,   479,   480,    25,     8,   109,   110,
  20746. -  1062,     8,   672,  1022,  1024,    87,    88,   193,   194,   195,
  20747. -  1025,    53,   712,  1055,  1244,   136,   136,   136,    53,  1056,
  20748. -  1057,  1064,   673,   712,   220,  1366,   673,   112,  1058,  1069,
  20749. -  1070,   674,  1078,  1027,   712,   196,   135,    25,   617,   109,
  20750. -   110,   136,   136,   136,  1074,    25,  1083,   109,   110,    25,
  20751. -  1079,   109,   110,  1008,  1080,  1082,    89,    90,   197,  1084,
  20752. -  1140,  1087,  1093,  1136,  1389,  1141,  1142,   817,  1148,  1163,
  20753. -  1099,   618,  1168,   619,  1169,   620,  1062,   621,  1124,   519,
  20754. -  1173,  1124,  1293,  1174,  1119,  1124,  1175,  1123,  1181,    68,
  20755. -  1123,  1119,    68,   258,  1123,  1189,    68,  1339,   303,  1319,
  20756. -  1190,  1191,   198,   199,   200,  1198,  1200,   658,   659,  1214,
  20757. -   138,  1217,  1237,  1230,  1231,  1232,  1233,  1293,   520,   521,
  20758. -   189,  1238,  1246,   522,   523,   524,   525,  1239,   258,    53,
  20759. -  1247,  1124,    53,   256,  1251,   856,    53,  1119,  1253,  1286,
  20760. -  1123,  1255,    68,  1298,  1317,  1305,  1306,  1124,  1327,  1307,
  20761. -   712,   712,  1308,  1119,   486,  1341,  1123,  1318,    68,  1329,
  20762. -   352,   731,   600,  1345,   712,   712,  1353,  1363,   256,  1360,
  20763. -   892,  1364,  1293,   602,  1365,  1124,  1367,  1195,   894,  1368,
  20764. -  1373,  1119,    53,   258,  1123,  1378,    68,   135,  1379,    75,
  20765. -   221,  1385,  1387,   182,   183,   184,  1388,    95,    53,  1393,
  20766. -    12,  1394,  1398,  1166,  1399,     1,   615,    95,   114,    75,
  20767. -     5,    37,   588,   599,   126,   126,   986,   126,    17,   363,
  20768. -   867,    18,   344,   256,    75,   364,    53,  1124,  1020,  1094,
  20769. -  1236,    22,   136,  1119,   736,   172,  1123,    75,    68,  1240,
  20770. -   180,   188,  1284,   490,  1395,   205,   981,  1205,  1288,   873,
  20771. -  1193,   358,   148,    95,   980,   149,  1143,   534,  1032,     7,
  20772. -   329,   138,   535,   712,   223,    95,   995,   712,   420,   183,
  20773. -   184,    75,   394,  1091,  1050,    12,   698,  1049,    53,   823,
  20774. -   978,   776,    95,   410,   538,   412,   136,   136,   136,    96,
  20775. -  1212,  1133,  1372,    17,  1007,    20,    18,   114,   957,   889,
  20776. -   114,  1374,   138,   172,    95,  1322,    22,   596,    25,   126,
  20777. -    26,    27,   346,   126,  1052,     0,   126,   126,   126,     0,
  20778. -     0,     0,     0,   479,   480,     0,     0,     0,     0,    75,
  20779. -  1252,   172,    75,     0,     0,     0,     0,     0,   352,   355,
  20780. -   712,   712,   536,   712,   712,     0,     0,   172,   172,   172,
  20781. -   510,   511,   512,   513,   514,   515,   516,   517,   518,   996,
  20782. -     0,     0,     0,     0,   352,  1135,  1275,  1276,  1277,  1278,
  20783. -     0,     7,     8,     0,     0,   172,     0,     0,     0,     0,
  20784. -     0,  -255,   749,  1291,     0,     0,     0,   712,     0,     0,
  20785. -     0,     0,     0,     0,     0,    75,  -255,  -255,    95,   486,
  20786. -     0,  -255,     0,  1026,     0,     0,   126,    20,     0,     7,
  20787. -     8,   138,   138,   138,  1036,     0,  -255,     0,  1291,     0,
  20788. -    25,     0,    26,    27,     0,  1051,   161,     0,  -255,  -255,
  20789. -  -255,  -255,     0,  -255,     0,     0,   162,   138,   138,   138,
  20790. -     0,     0,     0,    95,   461,    20,   163,     0,     0,     0,
  20791. -     0,   541,  -513,     0,    31,  -513,     0,     0,    25,   164,
  20792. -    26,    27,  -255,  -255,     0,     0,  -255,     0,     0,  1077,
  20793. -     0,  1352,     0,  1291,   838,   712,  -255,     0,     0,     0,
  20794. -     0,    95,     0,     0,   839,   539,     0,   461,   461,   555,
  20795. -   806,     0,    31,     0,   544,   172,  1371,   840,   546,     0,
  20796. -     0,     0,  -513,     0,     0,  -513,     0,  -513,     0,     0,
  20797. -     0,     0,   749,   114,     0,   661,     0,     0,  -513,   114,
  20798. -     0,     0,   666,    95,     7,   108,     0,   479,   480,     0,
  20799. -     0,     0,     0,    71,     0,   126,  -513,  -513,   126,     0,
  20800. -  -513,  1144,  1145,   126,     0,     0,     0,    75,     0,     0,
  20801. -  -513,     0,     0,   121,  1020,  1153,  1154,     0,   125,   129,
  20802. -    20,     0,     0,     0,     0,     0,     0,     0,   150,     0,
  20803. -     0,   715,   716,    25,   717,    26,    27,     0,     0,   417,
  20804. -   172,   181,   172,     0,   172,   172,   172,     0,     0,   131,
  20805. -     0,     0,   172,     0,     0,     0,     0,   172,     0,   132,
  20806. -   172,  -734,     0,  -734,  -734,     0,     0,    31,  -734,   352,
  20807. -  1135,     0,   133,     0,     0,   312,     0,    95,     0,   114,
  20808. -     0,     0,   639,     0,   172,    75,     0,    75,   138,     0,
  20809. -   639,     0,     0,    95,  -734,  -734,   418,   215,  -734,     8,
  20810. -  -734,    10,   211,     0,     0,     0,     0,    12,     0,     0,
  20811. -     0,     0,     0,   345,  1221,     0,     0,   347,  1225,     0,
  20812. -   807,   808,    15,     0,    16,   807,     0,     0,    18,     0,
  20813. -     0,  -734,     0,    71,     0,     0,   368,     0,    22,     0,
  20814. -     0,     0,   138,   138,   138,     0,     0,    25,     0,   109,
  20815. -   110,   125,   129,     0,     0,     0,     0,     8,   116,    10,
  20816. -    11,   639,     0,   645,     0,    12,     0,     0,     0,     0,
  20817. -     0,     0,     0,    95,     0,   461,     0,     0,     0,     0,
  20818. -    15,     0,    16,    17,     0,   539,    18,   461,   461,     0,
  20819. -   555,  1271,  1272,     0,  1273,  1274,    22,    75,     0,   445,
  20820. -     0,     0,     0,     0,     0,    25,     0,   109,   110,     0,
  20821. -   452,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  20822. -     0,   639,     0,   639,   639,   433,     0,     7,     8,   116,
  20823. -    10,    11,   479,   480,  1039,  1040,    12,    95,  1302,     0,
  20824. -     0,     0,   172,    75,   172,   172,   205,   555,   646,   639,
  20825. -     0,    15,     0,    16,    17,   639,     0,    18,  -465,   905,
  20826. -   396,   398,   402,    20,     0,     0,     0,    22,   434,     0,
  20827. -    20,     0,     0,     0,     0,     0,    25,     0,    26,    27,
  20828. -     0,     0,   435,    25,   436,    26,    27,     0,     0,     0,
  20829. -     0,  1041,    29,     0,   172,     0,     0,     0,    75,   162,
  20830. -     0,     0,    30,   172,   172,     0,   172,     0,     0,   163,
  20831. -    31,     0,     0,     0,     0,    32,   108,    31,   183,   184,
  20832. -     0,     0,   164,     0,    12,     0,  1370,     7,     8,     0,
  20833. -  -465,    11,     0,     0,   908,     0,     0,     0,     0,   608,
  20834. -     0,     0,   609,     0,     0,    18,     0,   611,     0,     0,
  20835. -     0,   121,   461,   952,   953,    22,   955,   541,     0,     0,
  20836. -   461,   461,   461,    20,    25,     0,   109,   110,     0,   541,
  20837. -     0,    95,    95,    95,    95,     0,    25,     0,    26,    27,
  20838. -   542,   969,     0,     0,   345,     0,   347,     0,     0,     0,
  20839. -   543,     0,   838,     0,     0,     0,     0,     0,     0,     0,
  20840. -   544,   452,   839,   552,   546,     0,     0,     0,     0,     0,
  20841. -    31,     0,   544,     0,   994,   840,   546,   639,     0,     0,
  20842. -    95,     0,     0,     0,     0,     0,    79,     0,   696,   699,
  20843. -     0,   445,     0,     0,    97,     0,     0,     0,     0,     0,
  20844. -   461,     0,   461,     0,    97,   115,    79,     0,     0,    95,
  20845. -     0,   127,   127,   461,   127,    95,     0,    75,    75,    75,
  20846. -     0,    79,     0,   975,     0,     0,     0,     0,     0,     0,
  20847. -     0,     0,   127,     0,    79,     0,   639,     0,     0,     0,
  20848. -    95,     0,    95,   172,   172,   908,     0,     0,     0,   639,
  20849. -   213,   639,     0,   656,     0,   657,     0,   396,   398,   402,
  20850. -     0,     0,   213,     0,     0,     0,     0,     0,    79,     0,
  20851. -   667,   504,   505,   506,   507,   508,   509,   510,   511,   512,
  20852. -   513,   514,   515,   516,   517,   518,   908,   639,     7,     8,
  20853. -     0,     0,   211,     0,   334,     0,     0,   695,  1081,     0,
  20854. -   127,   213,     0,     0,     0,     0,   127,    95,     0,     0,
  20855. -   127,     0,     0,   127,   127,   127,   172,     0,   639,   126,
  20856. -     0,    75,     0,    95,    20,  1090,    79,     0,   127,    79,
  20857. -   541,     0,     0,     0,     0,     0,     0,    25,   639,    26,
  20858. -    27,     0,     0,     0,   127,   127,   127,   844,     0,     0,
  20859. -     0,     0,     0,   838,     0,     0,     0,   461,   461,     0,
  20860. -   461,     0,     0,   839,     0,   108,     0,     0,    11,     0,
  20861. -  1147,    31,   127,   544,     0,     0,   840,   546,   505,   506,
  20862. -   507,   508,   509,   510,   511,   512,   513,   514,   515,   516,
  20863. -   517,   518,    79,   172,   172,   172,   172,   908,     0,   172,
  20864. -    75,     0,   888,   127,     0,     0,   541,   608,   609,     0,
  20865. -   611,     0,     0,    25,  1170,   109,   110,     0,     0,     0,
  20866. -     0,   908,   908,   908,  -342,     8,  -342,    10,   211,   542,
  20867. -     0,     0,     0,    12,    95,     0,     0,     0,     0,   543,
  20868. -   213,   127,     0,     0,     0,     0,     0,     0,    15,   544,
  20869. -    16,  -342,   545,   546,    18,    75,     0,     0,     0,   639,
  20870. -  -342,   639,     0,   639,    22,     0,   541,     0,     0,     0,
  20871. -     0,     0,     0,    25,     0,   109,   110,     0,   213,     0,
  20872. -     0,     0,   540,     0,   127,   127,    79,     0,     0,   542,
  20873. -     0,   563,   127,   172,   172,   172,     0,     0,     0,   543,
  20874. -     0,     0,     0,     0,     0,     0,     0,  -342,     0,   544,
  20875. -   334,     0,   545,   546,     0,     0,   656,   657,     0,   667,
  20876. -   213,     7,     8,   182,   183,   184,     0,   172,    75,   172,
  20877. -    12,     0,   127,     0,     0,   127,     0,     0,     0,     0,
  20878. -   127,     0,   639,     0,    79,     0,     0,   402,    17,     0,
  20879. -     0,    18,     0,     0,     0,     0,     0,    20,     0,     0,
  20880. -     0,    22,     0,   541,     0,     0,     0,     0,     0,     0,
  20881. -    25,     0,    26,    27,     0,     0,     0,   127,     0,   127,
  20882. -     0,   127,   127,   127,     0,     0,   838,   125,   129,   127,
  20883. -     8,     0,    10,    11,   127,     0,   839,   127,    12,     0,
  20884. -     0,     0,     0,     0,    31,     0,   544,     7,   108,   840,
  20885. -   546,    11,   908,    15,   213,    16,   115,     0,   293,    18,
  20886. -     0,   127,    79,     8,    79,    10,     0,     0,     0,    22,
  20887. -   213,    12,     0,     0,     0,     0,     0,     0,    25,     0,
  20888. -   109,   110,     0,    20,     0,     0,    15,     0,    16,     0,
  20889. -     0,     0,    18,     0,     0,   293,    25,     0,    26,    27,
  20890. -  1046,     0,    22,  1046,   639,   445,   908,   908,   908,     0,
  20891. -     0,    25,    29,   109,   110,   145,     0,     7,     8,   116,
  20892. -    10,    11,    30,     0,     7,   108,    12,     0,   211,     0,
  20893. -    31,     0,     0,     0,     0,    32,   396,   398,   402,   172,
  20894. -     0,    15,     0,    16,    17,     0,     0,    18,     0,     0,
  20895. -   213,     0,   127,    20,     0,     0,     0,    22,     0,     0,
  20896. -    20,     0,     0,     0,   127,   127,    25,    79,    26,    27,
  20897. -     0,     0,    95,    25,   818,    26,    27,   345,   347,   402,
  20898. -  1039,   108,    29,   452,   445,   563,     0,     0,     0,    29,
  20899. -     0,     0,    30,     0,     0,     0,     0,     0,     0,    30,
  20900. -    31,     0,     0,     0,     0,    32,     0,    31,     0,  1045,
  20901. -     0,     0,    32,     0,    97,     0,    20,     0,     0,   127,
  20902. -    79,   127,   127,     0,    79,     0,     0,     0,     0,    25,
  20903. -     0,    26,    27,     0,     0,     0,     0,  1041,     0,   445,
  20904. -     0,     0,     0,     0,     0,    29,     0,     0,     0,   477,
  20905. -   213,     0,     0,     0,     0,    30,     0,     0,     0,     0,
  20906. -     0,     0,     0,    31,     0,     0,     0,     0,    32,     0,
  20907. -     0,   127,     0,     0,     0,    79,     0,   608,   609,   611,
  20908. -   127,   127,     0,   127,     0,     0,   656,   657,   396,   398,
  20909. -   402,     0,   667,     0,     7,     8,   182,   183,   184,     0,
  20910. -     0,     0,     0,    12,     0,     0,     0,     0,     0,     0,
  20911. -     0,    79,  1206,     0,   396,   398,   402,     0,     0,     7,
  20912. -     8,    17,     0,    11,    18,     0,     0,     0,     0,   127,
  20913. -    20,     0,     0,     0,    22,     0,   541,   127,   127,   127,
  20914. -     0,     0,     0,    25,     0,    26,    27,     0,   213,   213,
  20915. -   213,   213,     0,     0,     0,    20,     0,   637,   641,   838,
  20916. -     0,   541,     0,     7,     8,     0,   641,   451,    25,   839,
  20917. -    26,    27,     0,     0,     0,     0,     0,    31,     0,   544,
  20918. -     0,     0,   881,   546,   990,     0,   656,   657,   667,     0,
  20919. -     0,     0,     0,     0,   991,     0,     0,   213,     0,    20,
  20920. -     0,     0,    31,     0,   544,   541,     0,   992,   546,   680,
  20921. -     0,     0,    25,     0,    26,    27,     0,   127,     0,   127,
  20922. -     0,     0,     0,     0,     0,     0,   213,     0,   838,     0,
  20923. -   127,     0,   213,     0,   818,   818,   818,   641,   839,     0,
  20924. -   563,     0,     0,     0,     0,     0,    31,     0,   544,     0,
  20925. -     0,   840,   546,     0,     0,     0,     0,   213,     0,   213,
  20926. -   127,   127,    79,     0,   293,   108,     0,   637,   211,     0,
  20927. -   746,   747,     0,   751,   752,   753,   754,   755,   756,   757,
  20928. -   758,   759,   760,   761,   762,   763,   764,   765,   766,   767,
  20929. -   768,   769,     0,     0,     0,     0,     0,   641,     0,   641,
  20930. -   641,     0,     0,   818,     0,   402,   541,     0,     0,     0,
  20931. -     0,     0,     0,    25,     0,   109,   110,     0,     7,     8,
  20932. -   174,    10,   175,     0,   213,   641,     0,    12,     0,   542,
  20933. -     0,   641,     0,   127,     0,     0,   127,     0,    79,   543,
  20934. -   213,     0,    15,     0,    16,    17,   825,   827,    18,   544,
  20935. -     0,     0,   545,   546,    20,     0,     0,     0,    22,   396,
  20936. -   398,   402,     0,     0,     0,     0,     0,    25,     0,    26,
  20937. -    27,     0,     0,   176,   127,   127,     0,   127,     0,     8,
  20938. -   116,    10,    11,    29,     0,   645,     0,    12,     0,     0,
  20939. -     0,     0,     0,    30,     0,     0,     0,     0,     0,     0,
  20940. -     0,    31,    15,     0,    16,    17,    32,     0,    18,   637,
  20941. -   127,   127,   127,   127,    79,     0,   127,    79,    22,     0,
  20942. -   541,     0,   213,     0,     0,     0,     0,    25,     0,   109,
  20943. -   110,     0,     7,   108,     0,     0,    11,     0,   818,   818,
  20944. -   818,     0,     0,   542,     0,     0,     0,     0,     0,     0,
  20945. -     0,   213,     0,   543,    73,     0,     0,     0,     0,     0,
  20946. -     0,   906,     0,   544,     0,     0,   545,   546,    20,     0,
  20947. -   646,     0,    79,     0,    73,   108,     0,     0,   451,    73,
  20948. -    73,    25,    73,    26,    27,     0,     0,     0,     0,    73,
  20949. -     0,     0,     0,   641,   547,   547,   547,   131,     0,     0,
  20950. -    73,     0,    73,     0,     7,     8,     0,   132,    11,     0,
  20951. -   127,   127,   127,     0,   936,    31,   541,     0,     0,     0,
  20952. -   133,     0,     0,    25,     0,   109,   110,     0,     0,     0,
  20953. -     0,     0,     0,     0,     0,     0,    73,     0,     0,   542,
  20954. -    20,     0,     0,     0,   127,    79,   127,     0,     0,   543,
  20955. -     0,   637,   641,    25,     0,    26,    27,     0,     0,   544,
  20956. -     0,     0,   545,   546,     0,   641,     0,   641,    73,   162,
  20957. -     0,     0,     0,     0,    73,     0,     0,     0,    73,   163,
  20958. -    48,    73,    73,    73,     7,   108,     0,    31,   451,     0,
  20959. -     0,     0,   164,   977,    73,     0,    73,    73,     0,     0,
  20960. -    48,     0,     0,   641,     0,    48,    48,     0,   134,     0,
  20961. -     0,     0,    73,    73,    73,    48,     0,     0,     0,     0,
  20962. -    20,     0,     0,     0,     0,     0,    48,     0,    48,   818,
  20963. -     0,     0,     0,    25,   641,    26,    27,     0,     0,     0,
  20964. -    73,     0,     0,     0,     0,     0,     0,     0,     0,    29,
  20965. -     0,   218,     0,     0,   641,     0,     0,     0,     0,    30,
  20966. -    73,     0,    48,     0,   637,     0,     0,    31,     0,     0,
  20967. -     0,    73,    32,     0,     0,     0,  1033,  1034,     0,     0,
  20968. -     0,     7,     8,   818,   818,   818,     0,     0,   331,     0,
  20969. -   331,   331,     0,     0,    48,     0,     0,     0,     0,     0,
  20970. -    48,     0,   218,     0,    48,     0,     0,   134,   134,   134,
  20971. -   637,   637,     0,     0,  1065,     0,   127,    20,     0,     0,
  20972. -    48,     0,    48,    48,     0,     0,     0,     0,     0,     0,
  20973. -    25,     0,    26,    27,   547,   547,  1201,   547,    48,    48,
  20974. -   134,     0,     0,     0,   816,     0,   162,     0,   218,   213,
  20975. -     0,     0,     0,     0,     0,     0,   163,     0,     0,   562,
  20976. -    73,     0,     0,     0,    31,     0,    48,     0,     0,   164,
  20977. -     0,     7,     8,     0,     0,   641,     0,   641,     0,   641,
  20978. -     0,     0,     0,     0,     0,     0,    48,   637,     0,   547,
  20979. -     0,   547,   547,     0,   547,   637,     0,    48,     0,     0,
  20980. -    73,     0,     0,    73,     0,     0,     0,    20,    73,     0,
  20981. -     0,     0,    73,     0,  1150,     0,     0,     0,     0,     0,
  20982. -    25,     0,    26,    27,     0,     0,     0,   637,     0,     0,
  20983. -     0,     0,   637,     0,  1162,     0,   162,     0,     0,     0,
  20984. -     0,   547,     0,     0,     0,    73,   163,    73,     0,    73,
  20985. -    73,    73,     0,     0,    31,     0,     0,    73,   641,   164,
  20986. -     0,   487,    73,     0,     0,    73,     7,     8,   182,   183,
  20987. -   184,     0,     0,     0,     0,    12,   331,     0,     0,     0,
  20988. -     0,     0,     0,  1188,   218,     0,    48,     0,     0,    73,
  20989. -    73,     0,    73,    17,     0,     0,    18,     0,     0,   547,
  20990. -     0,     0,    20,     0,   331,     0,    22,     0,   541,     0,
  20991. -   331,   637,   637,     0,     0,    25,     0,    26,    27,     0,
  20992. -     0,  1223,  1224,     0,     0,     0,    48,     0,     0,    48,
  20993. -     0,   162,     0,     0,    48,     0,   637,     0,    48,     0,
  20994. -     0,   163,     0,     0,     0,     0,     0,     0,     0,    31,
  20995. -     0,     0,     0,     0,  1207,   503,   504,   505,   506,   507,
  20996. -   508,   509,   510,   511,   512,   513,   514,   515,   516,   517,
  20997. -   518,    48,     0,    48,     0,   134,   134,   134,     0,     0,
  20998. -   641,     0,     0,    48,     0,     0,     0,   547,    48,   547,
  20999. -   562,    48,     0,   637,     0,     0,     0,     0,     0,     0,
  21000. -   547,     0,     0,     0,   816,   816,   816,   637,     0,     0,
  21001. -     0,     0,     0,     0,     0,    48,    48,     0,    48,     0,
  21002. -     0,  1295,     0,     0,     0,     0,     0,     0,     0,     0,
  21003. -   547,   547,   547,     8,     0,    10,   211,     0,     0,     0,
  21004. -     0,    12,   487,     0,     0,   487,     0,    73,    73,    73,
  21005. -    73,     0,     0,     0,     0,     0,    15,     0,    16,   487,
  21006. -   487,   487,    18,     0,     0,     0,     0,     0,     0,     0,
  21007. -     0,   487,    22,   816,   541,     0,     0,     0,   865,     0,
  21008. -     0,    25,     0,   109,   110,     0,     0,     0,     0,     7,
  21009. -     8,     0,     0,   211,     0,     0,     0,   542,     0,    73,
  21010. -     0,     0,     0,    73,     0,     0,     0,   543,    73,    73,
  21011. -     0,    73,     0,     0,   139,   218,     0,   544,     0,     0,
  21012. -   545,   546,     0,     0,     0,    20,     0,     0,   487,     0,
  21013. -     0,     0,   173,     0,     0,     0,     0,     0,    25,    73,
  21014. -    26,    27,   507,   508,   509,   510,   511,   512,   513,   514,
  21015. -   515,   516,   517,   518,   162,     7,     8,   637,     0,    11,
  21016. -     0,     0,     0,     0,   163,     0,     0,     0,     0,     0,
  21017. -     0,     0,    31,    48,    48,    48,    48,   164,     0,     0,
  21018. -   547,   547,   547,   547,   547,     0,   547,     0,     0,     0,
  21019. -     0,    20,     0,     0,     0,     0,     0,     0,     0,     0,
  21020. -   173,     0,     0,     0,    25,     0,    26,    27,   816,   816,
  21021. -   816,     0,     0,   139,   139,   139,     0,     0,     0,     0,
  21022. -   399,     0,     0,     0,     0,    48,     0,     0,   173,    48,
  21023. -   400,     0,     0,     0,    48,    48,     0,    48,    31,     0,
  21024. -     0,     0,     0,   401,   173,   173,   403,     0,     0,     0,
  21025. -     0,     0,     0,     0,     0,   550,   554,   556,   171,     0,
  21026. -     0,     0,     0,     0,     0,   134,     0,     0,   562,     0,
  21027. -     0,     0,   173,     0,     0,     0,     0,     0,     0,     0,
  21028. -   547,   547,   547,   219,     0,     0,     0,     0,    73,    73,
  21029. -    73,     0,     0,     0,     0,     0,   487,     0,     0,     0,
  21030. -     0,     0,     0,   219,     0,     0,   433,     0,     7,     8,
  21031. -   116,    10,    11,     0,     0,     0,     0,    12,     0,     0,
  21032. -     0,     0,     0,     0,     0,     0,   171,     0,     0,     0,
  21033. -     0,  1021,    15,     0,    16,    17,     0,     0,    18,  -466,
  21034. -     0,   462,     0,     0,    20,     0,     0,     0,    22,   434,
  21035. -     0,     0,     0,     0,   171,     0,     0,    25,     0,    26,
  21036. -    27,    73,     0,   435,    73,   436,    73,     0,     7,     8,
  21037. -   171,   171,   171,    29,     0,     0,     0,     0,     0,     0,
  21038. -   411,     0,     0,    30,   549,   549,   549,     0,   487,   487,
  21039. -   487,    31,   173,     0,     0,     0,    32,     0,   171,     0,
  21040. -     0,     0,     0,     0,    20,     0,     0,     0,     0,     0,
  21041. -     0,  -466,     0,     0,    48,    48,   134,    25,     0,    26,
  21042. -    27,     0,     0,     0,   108,     0,   183,   184,     0,     0,
  21043. -     0,   219,    12,   399,     0,     0,     0,     0,    73,    73,
  21044. -    73,    73,    73,   400,    73,    73,     0,     0,     0,     0,
  21045. -   865,    31,     0,    18,     0,     0,   401,  1019,     0,     0,
  21046. -     0,     0,     0,    22,     0,   541,  1021,  1021,  1021,     0,
  21047. -     0,     0,    25,     0,   109,   110,     0,   173,     0,   173,
  21048. -     0,   403,   403,   403,   218,     0,     0,    48,   542,   173,
  21049. -    48,     0,    48,     0,   173,   796,   798,   173,   543,     0,
  21050. -    73,     0,     0,     0,     0,     0,     0,     0,   544,     0,
  21051. -     0,   545,   546,     0,     0,     0,   219,     0,   171,     0,
  21052. -     0,   173,   506,   507,   508,   509,   510,   511,   512,   513,
  21053. -   514,   515,   516,   517,   518,     0,     0,     0,    73,    73,
  21054. -    73,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21055. -   843,   218,   550,   554,     0,   556,     0,     0,     0,     0,
  21056. -     0,     0,     0,     0,    48,    48,   134,   134,   134,     0,
  21057. -    48,    48,    73,    73,    73,     0,     0,     0,     0,     0,
  21058. -     7,     8,     0,     0,   451,     0,     0,     0,     0,     0,
  21059. -     0,     0,  1019,  1019,  1019,     0,     0,     0,     0,     0,
  21060. -     0,     0,   554,   171,     0,   171,     0,   171,   171,   171,
  21061. -     0,     0,   784,     0,     0,   171,    20,     0,     0,     0,
  21062. -   171,     0,     0,   171,   549,   549,    48,   549,     0,    25,
  21063. -     0,    26,    27,     0,   549,     0,     0,     0,     0,     0,
  21064. -     0,     0,     0,     0,     0,   162,     8,   171,    10,    11,
  21065. -     0,     0,     0,     0,    12,   163,     0,  1021,     0,     0,
  21066. -   554,     0,     0,    31,    48,    48,    48,     0,   164,    15,
  21067. -     0,    16,     0,     0,     0,    18,     0,     0,     0,   842,
  21068. -     0,   842,   842,     0,   549,    22,     0,     0,     0,     0,
  21069. -     0,     0,     0,     0,    25,     0,   109,   110,    48,    48,
  21070. -    48,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21071. -     0,  1021,  1021,  1021,   502,   503,   504,   505,   506,   507,
  21072. -   508,   509,   510,   511,   512,   513,   514,   515,   516,   517,
  21073. -   518,   842,     0,   775,     0,     0,     0,     0,     0,     0,
  21074. -   173,   173,     0,   173,    73,     0,     0,     0,   963,     0,
  21075. -   964,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21076. -     0,   968,     0,   219,     0,   796,   798,     0,     0,     0,
  21077. -     0,   403,     0,     0,     0,     0,     7,     8,   116,    10,
  21078. -    11,     0,     0,  1019,     0,    12,     0,     0,     0,   549,
  21079. -     0,   796,   798,     0,     0,     0,     0,   462,   462,   462,
  21080. -    15,     0,    16,    17,     0,   171,    18,   171,   171,     0,
  21081. -     0,     0,    20,     0,     0,     0,    22,     0,     0,     0,
  21082. -     0,     0,     0,     0,     0,    25,     0,    26,    27,     0,
  21083. -     0,     0,     0,     0,     0,     0,     0,  1019,  1019,  1019,
  21084. -     0,    29,     0,     0,     0,   117,     0,     0,     0,     0,
  21085. -     0,    30,     0,     0,     0,     0,     0,   171,     0,    31,
  21086. -     0,     0,     0,     0,    32,     0,   171,   171,     0,   171,
  21087. -    48,    93,     0,     0,     0,     0,     0,   549,     0,   549,
  21088. -     0,    93,    93,     0,     0,     0,     0,     0,    93,    93,
  21089. -   549,    93,     0,     0,   549,   549,   549,   907,     0,     0,
  21090. -     8,   116,    10,    11,     0,     0,  1347,     0,    12,     0,
  21091. -     0,     0,     0,     0,     0,     0,     0,     0,     0,   203,
  21092. -   842,   842,   993,    15,     0,    16,    17,     0,     0,    18,
  21093. -     0,     0,     0,     0,     0,     0,     0,     0,     0,    22,
  21094. -     0,   963,   964,   796,   798,     0,     0,   968,    25,     0,
  21095. -   109,   110,     0,     0,     0,     0,     0,     0,     0,     0,
  21096. -     0,     0,     0,   993,     0,     0,     0,     0,     0,   796,
  21097. -   798,    93,     0,    93,    93,     7,     8,   116,    10,    11,
  21098. -     0,     0,   645,    93,    12,    93,    93,    93,     0,     0,
  21099. -    93,    93,    93,   173,     0,     0,     0,     0,     0,    15,
  21100. -     0,    16,    17,     0,     0,    18,     0,     0,     0,     0,
  21101. -     0,    20,     0,     0,     0,    22,     0,     0,     0,     0,
  21102. -     0,     0,     0,     0,    25,     0,    26,    27,     0,     0,
  21103. -     0,     0,     0,     0,   784,   784,     0,   784,     0,     0,
  21104. -   399,   963,   964,   968,     0,     0,   171,   171,   907,     0,
  21105. -   400,     0,     0,     0,     0,     0,     0,     0,    31,     0,
  21106. -     0,     0,     0,   401,    93,     0,     0,   646,     0,     0,
  21107. -   842,   842,   993,   993,   993,     0,   842,     0,     0,   433,
  21108. -    93,     7,     8,   116,    10,    11,     0,     0,     0,   907,
  21109. -    12,     0,     0,     0,     0,     0,     0,     0,   993,   993,
  21110. -   993,     0,     0,     0,     0,    15,     0,    16,    17,     0,
  21111. -     0,    18,  -468,     0,     0,     0,  1037,    20,    93,   171,
  21112. -     0,    22,   434,     0,     0,     0,     8,   174,    10,   175,
  21113. -    25,     0,    26,    27,    12,     0,   435,     0,   436,     0,
  21114. -     0,     0,     0,     0,     0,     0,    29,     0,     0,    15,
  21115. -     0,    16,    17,     0,     0,    18,    30,     0,     0,    93,
  21116. -     0,    93,    93,     0,    31,    22,     0,     0,     0,    32,
  21117. -   842,   842,   842,     0,    25,     0,   109,   110,     0,     0,
  21118. -     0,     0,     0,   219,  -468,     0,     0,    93,     0,     0,
  21119. -     0,     0,     0,    93,     0,     0,   171,   171,   171,   171,
  21120. -   907,     0,   171,     0,   173,    93,   173,     0,     0,    93,
  21121. -     0,     0,    93,     0,     0,     0,     0,    93,     0,     0,
  21122. -     0,     0,     0,     0,   907,   907,   907,  1102,     0,  1103,
  21123. -  1104,   116,    10,   260,   261,   262,     0,   263,    12,  1105,
  21124. -     0,  1106,  1107,  1108,  1109,  1110,  1111,  1112,  1113,  1114,
  21125. -  1115,    13,    14,    15,   264,    16,    17,   265,     0,    18,
  21126. -     0,   266,   267,     0,   268,    20,   269,   270,     0,    22,
  21127. -     0,     0,     0,   271,   272,   273,   274,   275,    25,     0,
  21128. -  1116,    27,   631,     0,  1117,   276,     0,     0,     0,   403,
  21129. -     0,   277,     0,    93,   278,     0,   171,   171,   171,     0,
  21130. -     0,     0,   279,   280,   281,     0,     0,     0,     0,     0,
  21131. -   282,   283,   284,     0,     0,     0,     0,   285,     0,  1118,
  21132. -    93,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21133. -   171,     0,   171,   286,     0,     0,     0,     0,     0,     0,
  21134. -     0,     0,     0,   403,   403,   403,     0,     0,     0,     0,
  21135. -     0,     0,   433,     0,     7,     8,   116,    10,    11,     0,
  21136. -     0,     0,     0,    12,     0,     0,     0,     0,     0,     0,
  21137. -     0,     0,     0,     0,     0,     0,   173,     0,    15,     0,
  21138. -    16,    17,     0,     0,    18,  -467,     0,     0,     0,    93,
  21139. -    20,     0,     0,     0,    22,   434,     0,     0,    93,    93,
  21140. -     0,    93,    93,    25,     0,    26,    27,     0,     0,   435,
  21141. -     0,   436,     0,     0,     0,   907,     0,     0,     0,    29,
  21142. -     0,     0,  1248,     0,     0,     0,     0,     0,     0,    30,
  21143. -     0,     0,     0,     0,     0,     0,     0,    31,     0,     0,
  21144. -     0,     0,    32,     0,     0,     0,     0,     0,     0,     0,
  21145. -     0,    93,     0,     0,     0,     0,     0,  -467,     0,     0,
  21146. -   203,     0,     0,     0,     0,     0,     0,     0,     0,   907,
  21147. -   907,   907,  1249,   497,   498,   499,   500,   501,   502,   503,
  21148. -   504,   505,   506,   507,   508,   509,   510,   511,   512,   513,
  21149. -   514,   515,   516,   517,   518,     0,     0,     0,     0,     0,
  21150. -     0,     0,   171,  1210,     0,  1103,  1104,   116,    10,   260,
  21151. -   261,   262,     0,   263,    12,  1105,     0,  1106,  1107,  1108,
  21152. -  1109,  1110,  1111,  1112,  1113,  1114,  1115,    13,    14,    15,
  21153. -   264,    16,    17,   265,     0,    18,     0,   266,   267,     0,
  21154. -   268,    20,   269,   270,     0,    22,     0,     0,     0,   271,
  21155. -   272,   273,   274,   275,    25,     0,  1116,    27,   631,     0,
  21156. -  1117,   276,     0,     0,     0,     0,    93,   277,     0,     0,
  21157. -   278,     0,     0,     0,    93,    93,    93,     0,   279,   280,
  21158. -   281,     0,     0,     0,     0,     0,   282,   283,   284,     0,
  21159. -     0,     0,     0,   285,   482,  1118,     7,     8,   116,    10,
  21160. -   260,   261,   262,   645,   263,    12,     0,     0,  1211,   286,
  21161. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21162. -    15,   264,    16,    17,   265,     0,    18,     0,   266,   267,
  21163. -     0,   268,    20,   269,   270,     0,    22,     0,   541,     0,
  21164. -   271,   272,   273,   274,   275,    25,     0,    26,    27,  -263,
  21165. -     0,     0,   276,     0,    93,     0,    93,     0,   277,     0,
  21166. -     0,   812,     0,     0,     0,     0,     0,    93,     0,   279,
  21167. -   280,   813,     0,     0,     0,     0,     0,   282,   283,   284,
  21168. -     0,   544,     0,     0,   814,   546,     0,   482,   646,     7,
  21169. -     8,   116,    10,   260,   261,   262,   645,   263,    12,     0,
  21170. -   286,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21171. -     0,     0,     0,    15,   264,    16,    17,   265,     0,    18,
  21172. -     0,   266,   267,     0,   268,    20,   269,   270,     0,    22,
  21173. -     0,   541,     0,   271,   272,   273,   274,   275,    25,     0,
  21174. -    26,    27,  -263,     0,     0,   276,     0,     0,     0,     0,
  21175. -     0,   277,     0,     0,  1016,     0,     0,     0,     0,     0,
  21176. -     0,     0,   279,   280,  1017,     0,     0,     0,     0,     0,
  21177. -   282,   283,   284,    93,   544,     0,     0,  1018,   546,     0,
  21178. -     0,   646,     0,     0,     0,     0,     0,     0,     0,     0,
  21179. -     0,     0,   644,   286,     7,     8,   116,    10,   260,   261,
  21180. -   262,   645,   263,    12,     0,     0,     0,     0,     0,     0,
  21181. -     0,    93,    93,     0,    93,     0,     0,     0,    15,   264,
  21182. -    16,    17,   265,     0,    18,     0,   266,   267,     0,   268,
  21183. -    20,   269,   270,     0,    22,     0,     0,     0,   271,   272,
  21184. -   273,   274,   275,    25,     0,    26,    27,     0,     0,     0,
  21185. -   276,     0,     0,     0,     0,     0,   277,     0,     0,   278,
  21186. -     0,     0,     0,     0,     0,     0,     0,   279,   280,   281,
  21187. -     0,     0,     0,     0,     0,   282,   283,   284,     0,     0,
  21188. -     0,     0,   285,     0,     0,     0,   646,     0,     0,     0,
  21189. -     0,     0,     0,     0,     0,     0,  -702,   748,   286,     7,
  21190. -     8,   116,    10,   260,   261,   262,     0,   263,    12,     0,
  21191. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21192. -     0,     0,     0,    15,   264,    16,    17,   265,     0,    18,
  21193. -     0,   266,   267,     0,   268,    20,   269,   270,     0,    22,
  21194. -     0,     0,     0,   271,   272,   273,   274,   275,    25,     0,
  21195. -    26,    27,  1287,     0,  -692,   276,     0,   224,     0,     0,
  21196. -     8,   277,    10,    11,   278,     0,     0,     0,    12,     0,
  21197. -     0,     0,   279,   280,   281,     0,     0,     0,     0,     0,
  21198. -   282,   283,   284,    15,     0,    16,     0,   285,     0,    18,
  21199. -     0,   225,   226,     0,     0,     0,     0,     0,     0,    22,
  21200. -     0,   227,     0,   286,     0,     0,     0,     0,    25,     0,
  21201. -   109,   110,     0,   228,     0,     0,     0,   229,   230,   231,
  21202. -   232,   233,   234,   235,   236,   237,   238,   239,   240,   241,
  21203. -   242,   243,   244,   245,   246,   247,   248,   249,     0,     0,
  21204. -   250,   251,   252,     0,   635,   253,   737,   738,   254,    10,
  21205. -   465,   261,   262,     0,   263,    12,     0,     0,     0,     0,
  21206. -     0,     0,     0,   255,     0,     0,     0,     0,     0,     0,
  21207. -    15,   264,    16,     0,   265,     0,    18,     0,   266,   267,
  21208. -     0,   268,    20,   269,   270,     0,    22,     0,     0,     0,
  21209. -   271,   272,   273,   274,   275,    25,     0,   739,   740,   636,
  21210. -     0,     0,   276,     0,     0,     0,     0,     0,   277,     0,
  21211. -     0,   278,     0,     0,     0,     0,     0,     0,     0,   279,
  21212. -   280,   281,     0,     0,     0,     0,     0,   282,   283,   284,
  21213. -     0,     0,     0,     0,   285,   741,   635,     0,   737,   738,
  21214. -     0,    10,   465,   261,   262,     0,   263,    12,     0,   872,
  21215. -   286,     0,     0,     0,  1061,     0,     0,     0,     0,     0,
  21216. -     0,     0,    15,   264,    16,     0,   265,     0,    18,     0,
  21217. -   266,   267,     0,   268,    20,   269,   270,     0,    22,     0,
  21218. -     0,     0,   271,   272,   273,   274,   275,    25,     0,   739,
  21219. -   740,   636,     0,     0,   276,     0,     0,     0,     0,     0,
  21220. -   277,     0,     0,   278,     0,     0,     0,     0,     0,     0,
  21221. -     0,   279,   280,   281,     0,     0,     0,     0,     0,   282,
  21222. -   283,   284,   635,     0,   737,   738,   285,    10,   465,   261,
  21223. -   262,     0,   263,    12,     0,     0,     0,     0,     0,     0,
  21224. -  1061,  -427,   286,     0,     0,     0,     0,     0,    15,   264,
  21225. -    16,     0,   265,     0,    18,     0,   266,   267,     0,   268,
  21226. -    20,   269,   270,     0,    22,     0,     0,     0,   271,   272,
  21227. -   273,   274,   275,    25,     0,   739,   740,   636,     0,     0,
  21228. -   276,     0,     0,     0,     0,     0,   277,     0,     0,   278,
  21229. -     0,     0,     0,     0,     0,     0,     0,   279,   280,   281,
  21230. -     0,     0,     0,     0,     0,   282,   283,   284,   635,     0,
  21231. -   737,   738,   285,    10,   465,   261,   262,     0,   263,    12,
  21232. -     0,     0,     0,     0,     0,     0,     0,  1134,   286,     0,
  21233. -     0,     0,     0,     0,    15,   264,    16,     0,   265,     0,
  21234. -    18,     0,   266,   267,     0,   268,    20,   269,   270,     0,
  21235. -    22,     0,     0,     0,   271,   272,   273,   274,   275,    25,
  21236. -     0,   739,   740,   636,     0,     0,   276,     0,     0,     0,
  21237. -     0,     0,   277,     0,     0,   278,     0,     0,     0,     0,
  21238. -     0,     0,     0,   279,   280,   281,     0,     0,     0,     0,
  21239. -     0,   282,   283,   284,     0,     0,     0,     0,   285,   741,
  21240. -   482,     0,     7,     8,     0,    10,   260,   261,   262,     0,
  21241. -   263,    12,     0,     0,   286,     0,     0,     0,     0,     0,
  21242. -     0,     0,     0,     0,     0,     0,    15,   264,    16,     0,
  21243. -   265,     0,    18,     0,   266,   267,     0,   268,    20,   269,
  21244. -   270,     0,    22,     0,     0,     0,   271,   272,   273,   274,
  21245. -   275,    25,     0,    26,    27,  -263,     0,     0,   276,     0,
  21246. -     0,     0,     0,     0,   277,     0,     0,   483,     0,     0,
  21247. -     0,     0,     0,     0,     0,   279,   280,   484,     0,     0,
  21248. -     0,     0,     0,   282,   283,   284,   635,     0,     7,     8,
  21249. -   485,    10,   465,   261,   262,     0,   263,    12,     0,     0,
  21250. -     0,     0,     0,     0,     0,     0,   286,     0,     0,     0,
  21251. -     0,     0,    15,   264,    16,     0,   265,     0,    18,     0,
  21252. -   266,   267,     0,   268,    20,   269,   270,     0,    22,     0,
  21253. -     0,     0,   271,   272,   273,   274,   275,    25,     0,    26,
  21254. -    27,   636,     0,     0,   276,     0,     0,     0,     0,     0,
  21255. -   277,     0,     0,   278,     0,     0,     0,     0,     0,     0,
  21256. -     0,   279,   280,   281,     0,     0,     0,     0,     0,   282,
  21257. -   283,   284,   748,     0,     7,     8,   285,    10,   465,   261,
  21258. -   262,     0,   263,    12,     0,     0,     0,     0,     0,     0,
  21259. -     0,     0,   286,     0,     0,     0,     0,     0,    15,   264,
  21260. -    16,     0,   265,     0,    18,     0,   266,   267,     0,   268,
  21261. -    20,   269,   270,     0,    22,     0,     0,     0,   271,   272,
  21262. -   273,   274,   275,    25,     0,    26,    27,     0,     0,     0,
  21263. -   276,  -692,     0,     0,     0,     0,   277,     0,     0,   278,
  21264. -     0,     0,     0,     0,     0,     0,     0,   279,   280,   281,
  21265. -     0,     0,     0,     0,     0,   282,   283,   284,   482,     0,
  21266. -     7,     8,   285,    10,   260,   261,   262,     0,   263,    12,
  21267. -     0,     0,     0,     0,     0,     0,     0,     0,   286,     0,
  21268. -     0,     0,     0,     0,    15,   264,    16,     0,   265,     0,
  21269. -    18,     0,   266,   267,     0,   268,    20,   269,   270,     0,
  21270. -    22,     0,     0,     0,   271,   272,   273,   274,   275,    25,
  21271. -     0,    26,    27,  -263,     0,     0,   276,     0,     0,     0,
  21272. -     0,     0,   277,     0,     0,  1261,     0,     0,     0,     0,
  21273. -     0,     0,     0,   279,   280,  1262,     0,     0,     0,     0,
  21274. -     0,   282,   283,   284,  1354,     0,     7,     8,  1263,    10,
  21275. -   260,   261,   262,     0,   263,    12,     0,     0,     0,     0,
  21276. -     0,     0,     0,     0,   286,     0,     0,     0,     0,     0,
  21277. -    15,   264,    16,     0,   265,     0,    18,     0,   266,   267,
  21278. -     0,   268,    20,   269,   270,     0,    22,     0,     0,     0,
  21279. -   271,   272,   273,   274,   275,    25,     0,    26,    27,     0,
  21280. -     0,  -165,   276,     0,     0,     0,     0,     0,   277,     0,
  21281. -     0,   278,     0,     0,     0,     0,     0,     0,     0,   279,
  21282. -   280,   281,     0,     0,     0,     0,     0,   282,   283,   284,
  21283. -   748,     0,     7,     8,   285,    10,   465,   261,   262,     0,
  21284. -   263,    12,     0,     0,     0,     0,     0,     0,     0,     0,
  21285. -   286,     0,     0,     0,     0,     0,    15,   264,    16,     0,
  21286. -   265,     0,    18,     0,   266,   267,     0,   268,    20,   269,
  21287. -   270,     0,    22,     0,     0,     0,   271,   272,   273,   274,
  21288. -   275,    25,     0,    26,    27,     0,     0,     0,   276,     0,
  21289. -     0,     0,     0,     0,   277,     0,     0,   278,     0,     0,
  21290. -     0,     0,     0,     0,     0,   279,   280,   281,     0,     0,
  21291. -     0,     0,     0,   282,   283,   284,   824,     0,     7,     8,
  21292. -   285,    10,   465,   261,   262,     0,   263,    12,     0,     0,
  21293. -     0,     0,     0,     0,  -692,     0,   286,     0,     0,     0,
  21294. -     0,     0,    15,   264,    16,     0,   265,     0,    18,     0,
  21295. -   266,   267,     0,   268,    20,   269,   270,     0,    22,     0,
  21296. -     0,     0,   271,   272,   273,   274,   275,    25,     0,    26,
  21297. -    27,     0,     0,     0,   276,     0,     0,     0,     0,     0,
  21298. -   277,     0,     0,   278,     0,     0,     0,     0,     0,     0,
  21299. -     0,   279,   280,   281,     0,     0,     0,     0,     0,   282,
  21300. -   283,   284,   826,     0,     7,     8,   285,    10,   465,   261,
  21301. -   262,     0,   263,    12,     0,     0,     0,     0,     0,     0,
  21302. -     0,     0,   286,     0,     0,     0,     0,     0,    15,   264,
  21303. -    16,     0,   265,     0,    18,     0,   266,   267,     0,   268,
  21304. -    20,   269,   270,     0,    22,     0,     0,     0,   271,   272,
  21305. -   273,   274,   275,    25,     0,    26,    27,     0,     0,     0,
  21306. -   276,     0,     0,     0,     0,     0,   277,     0,     0,   278,
  21307. -     0,     0,     0,     0,     0,     0,     0,   279,   280,   281,
  21308. -     0,     0,     0,     0,     0,   282,   283,   284,     0,     0,
  21309. -     7,     8,   285,    10,   465,   261,   262,     0,   263,    12,
  21310. -     0,     0,     0,     0,     0,     0,     0,     0,   286,     0,
  21311. -     0,     0,     0,     0,    15,   264,    16,     0,   265,     0,
  21312. -    18,     0,   266,   267,     0,   268,    20,   269,   270,     0,
  21313. -    22,     0,     0,     0,   271,   272,   273,   274,   275,    25,
  21314. -     0,    26,    27,     0,     0,     0,   276,     0,     0,     0,
  21315. -     0,     0,   277,     0,     0,   278,     0,     0,     0,     0,
  21316. -     0,     0,     0,   279,   280,   281,     0,     0,     0,     0,
  21317. -     0,   282,   283,   284,     0,     0,     0,     0,   285,     0,
  21318. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21319. -     0,     0,     0,     0,   286,   787,  1103,  1104,   116,    10,
  21320. -   260,   261,   262,     0,   263,    12,  1105,     0,  1106,  1107,
  21321. -  1108,  1109,  1110,  1111,  1112,  1113,  1114,  1115,    13,    14,
  21322. -    15,   264,    16,    17,   265,     0,    18,     0,   266,   267,
  21323. -     0,   268,    20,   269,   270,     0,    22,     0,     0,     0,
  21324. -   271,   272,   273,   274,   275,    25,     0,  1116,    27,   631,
  21325. -     0,  1117,   276,     0,     0,     0,     0,     0,   277,     0,
  21326. -     0,   278,     0,     0,     0,     0,     0,     0,     0,   279,
  21327. -   280,   281,     0,     0,     0,     0,     0,   282,   283,   284,
  21328. -     0,     0,     0,     0,   285,     0,  1118,     0,     0,     0,
  21329. -     0,     0,     0,     0,     0,     0,     0,     0,     0,  1215,
  21330. -   286,  1103,  1104,   116,    10,   260,   261,   262,     0,   263,
  21331. -    12,  1105,     0,  1106,  1107,  1108,  1109,  1110,  1111,  1112,
  21332. -  1113,  1114,  1115,    13,    14,    15,   264,    16,    17,   265,
  21333. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21334. -     0,    22,     0,     0,     0,   271,   272,   273,   274,   275,
  21335. -    25,     0,  1116,    27,   631,     0,  1117,   276,     0,     0,
  21336. -     0,     0,     0,   277,     0,     0,   278,     0,     0,     0,
  21337. -     0,     0,     0,     0,   279,   280,   281,     0,     0,     0,
  21338. -     0,     0,   282,   283,   284,     0,     0,     0,     0,   285,
  21339. -     0,  1118,     0,     0,  1103,  1104,   116,    10,   260,   261,
  21340. -   262,     0,   263,    12,  1105,   286,  1106,  1107,  1108,  1109,
  21341. -  1110,  1111,  1112,  1113,  1114,  1115,    13,    14,    15,   264,
  21342. -    16,    17,   265,     0,    18,     0,   266,   267,     0,   268,
  21343. -    20,   269,   270,     0,    22,     0,     0,     0,   271,   272,
  21344. -   273,   274,   275,    25,     0,  1116,    27,  1331,     0,  1117,
  21345. -   276,     0,     0,     0,     0,     0,   277,     0,     0,   278,
  21346. -     0,     0,     0,     0,     0,     0,     0,   279,   280,   281,
  21347. -     0,     0,     0,     0,     0,   282,   283,   284,     0,     0,
  21348. -     0,     0,   285,     0,  1118,     0,     0,  1103,  1104,   116,
  21349. -    10,   260,   261,   262,     0,   263,    12,  1105,   286,  1106,
  21350. -  1107,  1108,  1109,  1110,  1111,  1112,  1113,  1114,  1115,    13,
  21351. -    14,    15,   264,    16,    17,   265,     0,    18,     0,   266,
  21352. -   267,     0,   268,    20,   269,   270,     0,    22,     0,     0,
  21353. -     0,   271,   272,   273,   274,   275,    25,     0,  1116,    27,
  21354. -     0,     0,  1117,   276,     0,     0,     0,     0,     0,   277,
  21355. -     0,     0,   278,     0,     0,     0,     0,     0,     0,     0,
  21356. -   279,   280,   281,     0,     0,     0,     0,     0,   282,   283,
  21357. -   284,     0,     0,     0,     0,   285,     0,  1118,     7,     8,
  21358. -   116,    10,   260,   261,   262,   645,   263,    12,     0,     0,
  21359. -     0,   286,     0,     0,     0,     0,     0,     0,     0,     0,
  21360. -     0,     0,    15,   264,    16,    17,   265,     0,    18,     0,
  21361. -   266,   267,     0,   268,    20,   269,   270,     0,    22,     0,
  21362. -   541,     0,   271,   272,   273,   274,   275,    25,     0,    26,
  21363. -    27,     0,     0,     0,   276,     0,     0,     0,     0,     0,
  21364. -   277,     0,     0,   812,     0,     0,     0,     0,     0,     0,
  21365. -     0,   279,   280,   813,     0,     0,     0,     0,     0,   282,
  21366. -   283,   284,     0,   544,     0,     0,   814,   546,     0,     0,
  21367. -   646,     7,     8,   116,    10,   260,   261,   262,   645,   263,
  21368. -    12,     0,   286,     0,     0,     0,     0,     0,     0,     0,
  21369. -     0,     0,     0,     0,     0,    15,   264,    16,    17,   265,
  21370. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21371. -     0,    22,     0,   541,     0,   271,   272,   273,   274,   275,
  21372. -    25,     0,    26,    27,     0,     0,     0,   276,     0,     0,
  21373. -     0,     0,     0,   277,     0,     0,  1016,     0,     0,     0,
  21374. -     0,     0,     0,     0,   279,   280,  1017,     0,     0,     0,
  21375. -     0,     0,   282,   283,   284,     0,   544,     0,     0,  1018,
  21376. -   546,     7,     8,   646,    10,   260,   261,   262,     0,   263,
  21377. -    12,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21378. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21379. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21380. -     0,    22,     0,   541,     0,   271,   272,   273,   274,   275,
  21381. -    25,     0,    26,    27,     0,     0,     0,     0,     0,     0,
  21382. -     0,     0,     0,   277,     0,     0,   812,     0,     0,     0,
  21383. -     0,     0,     0,     0,   279,   280,   813,     0,     0,     0,
  21384. -     0,     0,   282,   283,   284,     0,   544,     0,     0,   814,
  21385. -   546,     7,     8,     0,    10,   260,   261,   262,     0,   263,
  21386. -    12,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21387. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21388. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21389. -     0,    22,     0,   541,     0,   271,   272,   273,   274,   275,
  21390. -    25,     0,    26,    27,     0,     0,     0,     0,     0,     0,
  21391. -     0,     0,     0,   277,     0,     0,  1016,     0,     0,     0,
  21392. -     0,     0,     0,     0,   279,   280,  1017,     0,     0,     0,
  21393. -     0,     0,   282,   283,   284,     0,   544,     0,     0,  1018,
  21394. -   546,     7,     8,     0,    10,   260,   261,   262,     0,   263,
  21395. -    12,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21396. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21397. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21398. -     0,    22,     0,     0,     0,   271,   272,   273,   274,   275,
  21399. -    25,     0,    26,    27,     0,     0,     0,   276,     0,     0,
  21400. -     0,     0,     0,   277,     0,     0,   278,     0,     0,     0,
  21401. -     0,   343,     0,     0,   279,   280,   281,     0,     0,     0,
  21402. -     0,     0,   282,   283,   284,     0,     0,     7,     8,   285,
  21403. -    10,   465,   261,   262,     0,   263,    12,     0,     0,     0,
  21404. -     0,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21405. -     0,    15,   264,    16,     0,   265,     0,    18,     0,   266,
  21406. -   267,     0,   268,    20,   269,   270,     0,    22,     0,     0,
  21407. -     0,   271,   272,   273,   274,   275,    25,     0,    26,    27,
  21408. -     0,     0,  1192,   276,     0,     0,     0,     0,     0,   277,
  21409. -     0,     0,   278,     0,     0,     0,     0,     0,     0,     0,
  21410. -   279,   280,   281,     0,     0,     0,     0,     0,   282,   283,
  21411. -   284,     0,     0,     7,     8,   285,    10,   260,   261,   262,
  21412. -     0,   263,    12,     0,     0,     0,     0,     0,     0,     0,
  21413. -     0,   286,     0,     0,     0,     0,     0,    15,   264,    16,
  21414. -     0,   265,     0,    18,     0,   266,   267,     0,   268,    20,
  21415. -   269,   270,     0,    22,     0,     0,     0,   271,   272,   273,
  21416. -   274,   275,    25,     0,    26,    27,     0,     0,     0,   276,
  21417. -     0,     0,     0,     0,     0,   277,     0,     0,   278,     0,
  21418. -     0,     0,     0,     0,     0,     0,   279,   280,   281,     0,
  21419. -     0,     0,     0,     0,   282,   283,   284,     0,     0,     7,
  21420. -     8,   285,    10,   465,   261,   262,     0,   263,    12,     0,
  21421. -     0,     0,     0,     0,     0,     0,     0,   286,     0,     0,
  21422. -     0,     0,     0,    15,   264,    16,     0,   265,     0,    18,
  21423. -     0,   266,   267,     0,   268,    20,   269,   270,     0,    22,
  21424. -     0,     0,     0,   271,   272,   273,   274,   275,    25,     0,
  21425. -    26,    27,     0,     0,     0,   276,     0,     0,     0,     0,
  21426. -     0,   277,     0,     0,   278,     0,     0,     0,     0,     0,
  21427. -     0,     0,   279,   280,   281,     0,     0,     0,     0,     0,
  21428. -   282,   283,   284,     0,     0,     7,     8,   285,    10,   465,
  21429. -   261,   262,     0,   263,    12,     0,     0,     0,     0,     0,
  21430. -     0,     0,     0,   286,     0,     0,     0,     0,     0,    15,
  21431. -   264,    16,     0,   265,     0,    18,     0,   266,   267,     0,
  21432. -   268,    20,   269,   270,     0,    22,     0,     0,     0,   271,
  21433. -   272,   273,   274,   275,    25,     0,    26,    27,   494,     0,
  21434. -     0,     0,     0,     0,     0,     0,     0,   277,     0,     0,
  21435. -   278,     0,     0,     0,     0,     0,     0,     0,   279,   280,
  21436. -   281,     0,     0,     0,     0,     0,   282,   283,   284,     0,
  21437. -     0,     7,     8,   495,    10,   465,   261,   262,     0,   263,
  21438. -    12,     0,     0,     0,     0,     0,     0,     0,     0,   286,
  21439. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21440. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21441. -     0,    22,     0,     0,     0,   271,   272,   273,   274,   275,
  21442. -    25,     0,    26,    27,     0,     0,     0,     0,     0,     0,
  21443. -     0,     0,     0,   277,     0,     0,   278,     0,     0,     0,
  21444. -     0,     0,     0,     0,   279,   280,   281,     0,     0,     0,
  21445. -     0,     0,   282,   283,   284,     0,     0,     0,     0,   285,
  21446. -   531,     7,     8,     0,    10,   465,   261,   262,     0,   263,
  21447. -    12,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21448. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21449. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21450. -     0,    22,     0,     0,     0,   271,   272,   273,   274,   275,
  21451. -    25,     0,    26,    27,     0,     0,     0,   276,     0,     0,
  21452. -     0,     0,     0,   277,     0,     0,   483,     0,     0,     0,
  21453. -     0,     0,     0,     0,   279,   280,   484,     0,     0,     0,
  21454. -     0,     0,   282,   283,   284,     0,     0,   983,     8,   485,
  21455. -    10,   465,   261,   262,     0,   263,    12,     0,     0,     0,
  21456. -     0,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21457. -     0,    15,   264,    16,     0,   265,     0,    18,     0,   266,
  21458. -   267,     0,   268,    20,   269,   270,     0,    22,     0,     0,
  21459. -     0,   271,   272,   273,   274,   275,    25,     0,    26,    27,
  21460. -     0,     0,     0,   276,     0,     0,     0,     0,     0,   277,
  21461. -     0,     0,   278,     0,     0,     0,     0,     0,     0,     0,
  21462. -   279,   280,   281,     0,     0,     0,     0,     0,   282,   283,
  21463. -   284,     0,     0,     7,     8,   285,    10,   465,   261,   262,
  21464. -     0,   263,    12,     0,     0,     0,     0,     0,     0,     0,
  21465. -     0,   286,     0,     0,     0,     0,     0,    15,   264,    16,
  21466. -     0,   265,     0,    18,     0,   266,   267,     0,   268,    20,
  21467. -   269,   270,     0,    22,     0,     0,     0,   271,   272,   273,
  21468. -   274,   275,    25,     0,    26,    27,     0,     0,     0,   276,
  21469. -     0,     0,     0,     0,     0,   277,     0,     0,  1261,     0,
  21470. -     0,     0,     0,     0,     0,     0,   279,   280,  1262,     0,
  21471. -     0,     0,     0,     0,   282,   283,   284,     0,     0,     7,
  21472. -     8,  1263,    10,   465,   261,   262,     0,   263,    12,     0,
  21473. -     0,     0,     0,     0,     0,     0,     0,   286,     0,     0,
  21474. -     0,     0,     0,    15,   264,    16,     0,   265,     0,    18,
  21475. -     0,   266,   267,     0,   268,    20,   269,   270,     0,    22,
  21476. -     0,     0,     0,   271,   272,   273,   274,   275,    25,     0,
  21477. -    26,    27,     0,     0,     0,     0,     0,     0,     0,     0,
  21478. -     0,   277,     0,     0,   278,     0,     0,     0,     0,     0,
  21479. -     0,     0,   279,   280,   281,     0,     0,     0,     0,     0,
  21480. -   282,   283,   284,     0,     0,     7,     8,   466,    10,   465,
  21481. -   261,   262,     0,   263,    12,     0,     0,     0,     0,     0,
  21482. -     0,     0,     0,   286,     0,     0,     0,     0,     0,    15,
  21483. -   264,    16,     0,   265,     0,    18,     0,   266,   267,     0,
  21484. -   268,    20,   269,   270,     0,    22,     0,     0,     0,   271,
  21485. -   272,   273,   274,   275,    25,     0,    26,    27,     0,     0,
  21486. -     0,     0,     0,     0,     0,     0,     0,   277,     0,     0,
  21487. -   278,     0,     0,     0,     0,     0,     0,     0,   279,   280,
  21488. -   281,     0,     0,     0,     0,     0,   282,   283,   284,     0,
  21489. -     0,     7,     8,   469,    10,   465,   261,   262,     0,   263,
  21490. -    12,     0,     0,     0,     0,     0,     0,     0,     0,   286,
  21491. -     0,     0,     0,     0,     0,    15,   264,    16,     0,   265,
  21492. -     0,    18,     0,   266,   267,     0,   268,    20,   269,   270,
  21493. -     0,    22,     0,     0,     0,   271,   272,   273,   274,   275,
  21494. -    25,     0,    26,    27,     0,     0,     0,     0,     0,     0,
  21495. -     0,     0,     0,   277,     0,     0,   278,     0,     0,     0,
  21496. -     0,     0,     0,     0,   279,   280,   281,     0,     0,     0,
  21497. -     0,     0,   282,   283,   284,     0,     0,     7,     8,   285,
  21498. -    10,   465,   261,   262,     0,   263,    12,     0,     0,     0,
  21499. -     0,     0,     0,     0,     0,   286,     0,     0,     0,     0,
  21500. -     0,    15,   264,    16,     0,   265,     0,    18,     0,   266,
  21501. -   267,     0,   268,    20,   269,   270,     0,    22,     0,     0,
  21502. -     0,   271,   272,   273,   274,   275,    25,     0,    26,    27,
  21503. -     0,     0,     0,     0,     0,     0,     0,     0,     0,   277,
  21504. -     0,     0,   483,     0,     0,     0,     0,     0,     0,     0,
  21505. -   279,   280,   484,     0,     0,     0,     0,     0,   282,   283,
  21506. -   284,     0,     0,     7,     8,   485,    10,   260,   261,   262,
  21507. -     0,   263,    12,     0,     0,     0,     0,     0,     0,     0,
  21508. -     0,   286,     0,     0,     0,     0,     0,    15,   264,    16,
  21509. -     0,   265,     0,    18,     0,   266,   267,     0,   268,    20,
  21510. -   269,   270,     0,    22,     0,     0,     0,   271,   272,   273,
  21511. -   274,   275,    25,     0,    26,    27,     0,     0,     0,     0,
  21512. -     0,     0,     0,     0,     0,   277,     0,     0,  1261,     0,
  21513. -     0,     0,     0,     0,     0,     0,   279,   280,  1262,     0,
  21514. -     0,     0,     0,     0,   282,   283,   284,     0,     0,     0,
  21515. -     6,  1263,     7,     8,     9,    10,    11,     0,     0,     0,
  21516. -     0,    12,     0,     0,     0,     0,     0,   286,     0,     0,
  21517. -     0,     0,     0,     0,    13,    14,    15,     0,    16,    17,
  21518. -     0,     0,    18,     0,     0,     0,    19,     0,    20,     0,
  21519. -     0,    21,    22,    23,     0,    24,     0,     0,     0,     0,
  21520. -     0,    25,     0,    26,    27,     0,     0,    28,     0,     0,
  21521. -     6,     0,     7,     8,     9,    10,    11,    29,     0,     0,
  21522. -     0,    12,     0,     0,     0,     0,     0,    30,     0,     0,
  21523. -     0,     0,     0,     0,     0,    31,    15,     0,    16,    17,
  21524. -    32,     0,    18,     0,     0,    33,    34,     0,    20,     0,
  21525. -     0,     0,    22,     0,     0,   362,     0,     0,     0,     0,
  21526. -     0,    25,     0,    26,    27,     0,     0,    28,     0,     0,
  21527. -     0,     0,     7,     8,   116,    10,    11,    29,     0,   645,
  21528. -     0,    12,     0,     0,     0,     0,     0,    30,     0,     0,
  21529. -     0,     0,     0,     0,     0,    31,    15,     0,    16,    17,
  21530. -    32,     0,    18,     0,     0,    33,     0,     0,    20,     0,
  21531. -     0,     0,    22,     0,   541,     0,   685,     8,   174,    10,
  21532. -   175,    25,     0,    26,    27,    12,     0,     0,     0,     0,
  21533. -     0,     0,     0,     0,     0,     0,     0,   990,     0,     0,
  21534. -    15,     0,    16,    17,     0,     0,    18,   991,     0,     0,
  21535. -     0,     0,    20,     0,     0,    31,    22,   544,     0,     0,
  21536. -   992,   546,     0,     0,   646,    25,     0,    26,    27,     0,
  21537. -     0,     0,     0,   688,     0,     0,     7,     8,   116,    10,
  21538. -    11,    29,     0,   887,     0,    12,     0,     0,     0,     0,
  21539. -     0,    30,     0,     0,     0,     0,     0,     0,     0,    31,
  21540. -    15,     0,    16,    17,    32,     0,    18,     0,     0,     0,
  21541. -     0,     0,    20,     0,     0,     0,    22,     0,     0,     0,
  21542. -     7,     8,   174,    10,   175,    25,     0,    26,    27,    12,
  21543. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  21544. -     0,    29,     0,     0,    15,     0,    16,    17,     0,     0,
  21545. -    18,    30,     0,     0,     0,     0,    20,     0,     0,    31,
  21546. -    22,     0,     0,     0,    32,     0,     0,     0,     0,    25,
  21547. -     0,    26,    27,     0,     0,  1204,     0,     0,     0,     0,
  21548. -     7,     8,   116,    10,    11,    29,     0,     0,     0,    12,
  21549. -     0,     0,     0,     0,     0,    30,     0,     0,     0,     0,
  21550. -     0,     0,     0,    31,    15,     0,    16,    17,    32,     0,
  21551. -    18,     0,     0,     0,     0,     0,    20,     0,     0,     0,
  21552. -    22,     0,     0,     0,     7,     8,   174,    10,   175,    25,
  21553. -     0,    26,    27,    12,     0,     0,     0,     0,     0,     0,
  21554. -     0,     0,     0,     0,     0,    29,     0,     0,    15,     0,
  21555. -    16,    17,     0,     0,    18,    30,     0,     0,     0,     0,
  21556. -    20,     0,     0,    31,    22,     0,     0,     0,    32,     0,
  21557. -     0,     0,     0,    25,     0,    26,    27,     0,     0,     0,
  21558. -     0,     0,    17,     0,     0,     0,     0,     0,     0,    29,
  21559. -     0,     0,     0,     0,     0,     0,     0,     0,     0,    30,
  21560. -     0,     0,     0,     0,     0,     0,     0,    31,     0,     0,
  21561. -     0,     0,    32,   497,   498,   499,   500,   501,   502,   503,
  21562. -   504,   505,   506,   507,   508,   509,   510,   511,   512,   513,
  21563. -   514,   515,   516,   517,   518,     8,   116,    10,    11,     0,
  21564. -     0,     0,     0,    12,     0,     0,     0,     0,     0,     0,
  21565. -     0,     0,     0,     0,     0,     0,     0,     0,    15,     0,
  21566. -    16,    17,     0,     0,    18,     0,     0,     0,     0,     0,
  21567. -     0,     0,     0,     0,   592,     0,     0,     0,     0,     0,
  21568. -     0,     0,     0,    25,     0,   109,   110,   497,   498,   499,
  21569. -   500,   501,   502,   503,   504,   505,   506,   507,   508,   509,
  21570. -   510,   511,   512,   513,   514,   515,   516,   517,   518,   497,
  21571. -   498,   499,   500,   501,   502,   503,   504,   505,   506,   507,
  21572. -   508,   509,   510,   511,   512,   513,   514,   515,   516,   517,
  21573. -   518,   574,     0,     0,  1059,   497,   498,   499,   500,   501,
  21574. -   502,   503,   504,   505,   506,   507,   508,   509,   510,   511,
  21575. -   512,   513,   514,   515,   516,   517,   518,  1234,   497,   498,
  21576. -   499,   500,   501,   502,   503,   504,   505,   506,   507,   508,
  21577. -   509,   510,   511,   512,   513,   514,   515,   516,   517,   518,
  21578. -  1320,   497,   498,   499,   500,   501,   502,   503,   504,   505,
  21579. -   506,   507,   508,   509,   510,   511,   512,   513,   514,   515,
  21580. -   516,   517,   518,   497,   498,   499,   500,   501,   502,   503,
  21581. -   504,   505,   506,   507,   508,     0,   510,   511,   512,   513,
  21582. -   514,   515,   516,   517,   518,   501,   502,   503,   504,   505,
  21583. -   506,   507,   508,   509,   510,   511,   512,   513,   514,   515,
  21584. -   516,   517,   518
  21585. -};
  21586. -
  21587. -static const short yycheck[] = {     4,
  21588. -   140,    60,   442,   309,   338,     4,   338,   177,     4,    71,
  21589. -     4,   309,   207,    57,   409,    50,   631,     4,   338,    24,
  21590. -   131,   132,    79,   263,   264,    80,   303,    24,    24,   216,
  21591. -    24,   326,   432,  1243,    39,    29,    30,    24,   157,    12,
  21592. -    97,    54,   212,    39,   177,    39,   856,    52,  1246,    22,
  21593. -     4,   291,    39,   186,   112,   393,   689,   115,     9,    49,
  21594. -   776,   206,  1125,    68,  1066,   114,   115,     9,    34,  1132,
  21595. -    24,     9,  1267,    32,    57,    80,  1282,    34,     3,     4,
  21596. -    85,    86,    45,   118,     4,    39,    80,   257,   150,    86,
  21597. -    86,    35,    86,    98,    99,    45,     0,    58,    60,    86,
  21598. -    81,    82,  1312,   165,   605,     1,   338,     7,    52,    60,
  21599. -    72,   146,   185,   186,   119,     0,  1311,   122,    46,   181,
  21600. -    45,  1287,    58,   106,    10,     4,    80,    52,    91,    54,
  21601. -    55,  1337,    86,   303,    54,    55,   180,   131,   132,   144,
  21602. -   106,    91,   147,  1338,   188,   106,   136,   106,   144,   106,
  21603. -   144,   546,     3,     4,   105,   105,   213,   144,    78,    59,
  21604. -    56,   393,  1164,   105,   177,  1331,    91,   105,   162,   163,
  21605. -   106,    57,   185,   186,    60,    54,    55,   810,  1376,   169,
  21606. -    45,    58,  1392,     6,     7,   385,   996,  1250,   375,    12,
  21607. -   144,   468,   311,   393,    57,   340,    57,    62,    10,   212,
  21608. -   407,    57,    60,    54,    55,   210,    58,    57,   415,    95,
  21609. -    33,    58,    73,    10,   210,   379,   210,    32,    57,   105,
  21610. -    43,     4,    45,   210,   384,    85,    91,    78,   628,   106,
  21611. -   946,     3,   419,  1296,    12,    72,    60,    56,    98,    99,
  21612. -    58,   296,   105,    21,   257,    57,  1285,   105,    60,   105,
  21613. -    62,   300,   309,   258,   106,   105,   210,   563,     4,   106,
  21614. -    57,     7,   122,    60,   464,     5,   105,    60,    91,    93,
  21615. -   328,    54,    55,    57,    58,   310,   334,  1340,    97,    52,
  21616. -   285,   414,    60,    95,    75,   334,  1325,    57,   399,   400,
  21617. -   303,   296,   587,  1332,    34,    78,    57,    58,    95,   304,
  21618. -    58,    23,   296,    73,    95,   367,    52,    58,    54,    55,
  21619. -    25,    26,   105,   545,    45,    30,   131,   132,   133,   653,
  21620. -   552,   653,    68,   114,   524,   489,   526,   527,    45,    52,
  21621. -  1369,    54,    78,   338,    56,   126,  1375,    59,    60,    52,
  21622. -   413,   414,   296,    58,   338,    62,    92,    62,    99,   164,
  21623. -   423,   689,   130,  1069,    57,    58,  1395,   362,   558,    72,
  21624. -    91,     3,     4,   425,    57,   362,   362,     4,   362,     4,
  21625. -     7,    93,   649,   446,    91,   362,    57,    58,   422,    52,
  21626. -    73,   172,    45,   445,   338,   458,    91,    60,   393,    23,
  21627. -    91,   106,    45,    57,    98,    99,   119,    39,    62,   393,
  21628. -   413,   414,     4,    91,   439,   399,   400,    91,   362,    73,
  21629. -   423,    23,    54,    55,   205,    52,   811,    54,    55,    54,
  21630. -    55,   653,    56,    45,   147,   285,    60,   205,    91,   616,
  21631. -    60,    68,   223,   446,    52,   440,    78,   442,    91,   393,
  21632. -    62,    78,    72,   448,    86,   458,   442,     4,   442,  1122,
  21633. -    56,  1124,    54,    55,   177,   442,    62,   689,    45,    93,
  21634. -    30,   466,   185,   186,   469,    60,   630,   472,    45,    91,
  21635. -    92,     1,   810,   528,    23,    56,    78,   672,   338,   674,
  21636. -   485,    25,    26,   678,   671,    45,   491,   106,   442,    45,
  21637. -   495,    56,    45,    23,  1109,    25,    26,    54,    55,   277,
  21638. -    30,   835,   902,   835,    91,    92,    45,    56,    45,     4,
  21639. -    59,    60,   818,    91,    91,   835,   105,   308,   705,   105,
  21640. -   818,    78,   527,   528,    57,    58,    56,    57,    58,    59,
  21641. -    60,    91,    62,   393,   528,    91,    92,   707,    91,    32,
  21642. -   545,    92,   601,    45,    93,   323,   105,   552,   542,   543,
  21643. -  1051,   545,    91,    92,    91,   346,    45,    52,   552,    54,
  21644. -    55,   956,   597,    93,   599,   600,   105,   105,  1183,  1184,
  21645. -   710,     3,     4,    68,   528,    45,   816,   106,   810,   779,
  21646. -     9,   285,   814,    78,   399,   400,   401,   600,   448,    91,
  21647. -    92,   545,   792,   598,   794,   668,    45,   602,   552,    45,
  21648. -  1000,    59,    91,   835,    45,    58,   466,    39,   840,   469,
  21649. -  1050,     3,   472,    32,   649,     4,    58,    59,   778,   592,
  21650. -    52,    91,    54,    55,  1239,   485,     3,     4,   690,  1029,
  21651. -   830,   491,    99,   695,   696,   495,   649,   699,    92,   132,
  21652. -   133,    92,    91,    92,   108,    91,     3,     4,   653,   881,
  21653. -    91,    92,  1153,  1154,    86,   668,   105,    60,    56,   653,
  21654. -    58,   861,    60,    52,   105,    54,    55,   527,   712,   108,
  21655. -   461,   164,    72,    52,   951,    52,    91,    54,    55,    56,
  21656. -    91,    60,    39,     9,   689,    72,   390,     3,     4,    72,
  21657. -   413,   414,     4,    72,   707,   689,    72,    54,    55,   653,
  21658. -   423,  1316,   106,   867,   899,   900,   901,     4,   105,     6,
  21659. -     7,    57,   131,   132,   133,    12,   494,   440,    57,    58,
  21660. -  1221,   726,   727,   728,   729,   912,   913,   450,   915,    86,
  21661. -    27,   891,    29,    45,     4,   689,    33,   105,    54,    55,
  21662. -    52,   105,    54,    55,   105,   164,    43,     3,   539,    58,
  21663. -    78,    79,    80,    81,    82,    52,    68,    54,    55,    56,
  21664. -   992,   818,   466,    52,   555,   469,    78,    52,   472,   105,
  21665. -   775,    60,  1273,  1274,   779,    60,    88,   937,   938,    91,
  21666. -    92,   485,    52,    72,    54,    55,  1018,    72,     3,     4,
  21667. -   108,   495,   285,   653,    91,   499,    57,    58,    68,   804,
  21668. -   106,  1302,  1002,   106,  1004,   810,  1006,     7,    78,   814,
  21669. -   105,    56,   108,    58,   592,    60,   810,    91,   812,   813,
  21670. -   814,   525,    92,   601,    39,   952,   953,   531,   955,   689,
  21671. -   835,   108,   837,    58,    59,   840,   108,     3,     4,    54,
  21672. -    55,   835,   105,   905,   838,   839,   840,  1124,  1035,     3,
  21673. -     4,     5,     6,     7,  1014,    56,   810,    58,   636,    60,
  21674. -   814,   105,  1022,    78,    57,    58,   726,   727,   728,   729,
  21675. -   105,    86,     3,     4,   689,   598,   881,   600,    56,   990,
  21676. -   991,   835,   105,     3,     4,  1085,   840,   881,    54,    55,
  21677. -    56,    52,   897,     6,  1054,   715,   716,   717,   108,  1059,
  21678. -    54,    55,     3,     4,   627,  1016,  1017,   400,   401,    25,
  21679. -    26,   916,    91,   918,    30,   775,    45,    62,    57,    39,
  21680. -   916,    52,   916,    54,    55,    45,   649,   881,    91,   916,
  21681. -     6,     7,    52,   106,    54,    55,    12,    58,    39,   662,
  21682. -    60,    57,    58,    52,   804,   668,    62,   670,    68,   278,
  21683. -   810,    60,   281,    54,    55,   284,    62,    33,    78,    62,
  21684. -   289,   105,   916,    72,  1151,  1152,    86,    43,   297,    58,
  21685. -    58,    91,    58,   466,    58,   835,   469,    78,  1138,  1139,
  21686. -   399,   400,   401,  1045,  1046,    86,    58,   992,   105,    60,
  21687. -   995,   484,   485,  1327,   104,  1327,   990,   991,   992,   995,
  21688. -   105,   995,   495,  1163,    62,   105,  1011,   105,   995,    62,
  21689. -     3,     4,  1011,  1018,   108,  1011,  1293,  1011,     3,     4,
  21690. -    57,  1185,  1016,  1017,  1018,   840,    76,    77,    78,    79,
  21691. -    80,    81,    82,  1197,    91,  1222,    60,   897,   992,     3,
  21692. -     4,   995,    57,     1,    57,  1050,    39,    57,    60,    23,
  21693. -   828,    25,    26,    62,  1050,    60,  1050,  1011,   918,   552,
  21694. -  1220,    54,    55,  1050,  1018,    23,   881,    25,    26,    54,
  21695. -    55,   105,    30,  1260,  1234,    39,   105,   105,   105,   783,
  21696. -   105,    60,    56,   105,   105,  1147,    60,  1122,   105,  1124,
  21697. -    54,    55,    60,    86,   105,  1327,  1050,   105,    56,    57,
  21698. -    58,    59,    60,  1267,    62,   108,   106,     3,     4,   105,
  21699. -   814,  1124,    92,   108,    86,  1255,    45,   908,  1123,    93,
  21700. -  1125,   105,    86,  1293,   105,   108,  1125,  1132,   851,  1125,
  21701. -   108,  1125,   105,  1132,   105,    93,  1132,   106,  1132,    35,
  21702. -    36,   106,   471,    39,  1206,   105,   105,  1311,    57,     4,
  21703. -  1261,  1262,  1339,   105,   483,   484,    52,     4,    54,    55,
  21704. -   938,     4,     5,    62,    62,     3,     4,     5,     6,     7,
  21705. -    62,  1125,   895,    73,  1338,   990,   991,   992,  1132,    73,
  21706. -    73,   106,    29,   906,   975,  1349,    29,    42,    73,   105,
  21707. -   105,    34,     6,   897,   917,    33,   689,    52,    23,    54,
  21708. -    55,  1016,  1017,  1018,   108,    52,   108,    54,    55,    52,
  21709. -   105,    54,    55,    32,   105,   105,    54,    55,    56,   106,
  21710. -    62,   105,   105,   105,  1384,   105,   105,   720,    60,    60,
  21711. -  1008,    56,   108,    58,    45,    60,  1014,    62,  1243,    45,
  21712. -   105,  1246,  1247,   105,  1243,  1250,   105,  1243,    60,  1243,
  21713. -  1246,  1250,  1246,  1247,  1250,    60,  1250,  1319,  1263,  1294,
  21714. -    58,    58,   100,   101,   102,     7,    58,  1261,  1262,    14,
  21715. -   689,   105,   108,    91,    91,    91,    91,  1282,    84,    85,
  21716. -  1293,   105,    91,    89,    90,    91,    92,    94,  1282,  1243,
  21717. -    91,  1296,  1246,  1247,    58,   627,  1250,  1296,    58,    15,
  21718. -  1296,    91,  1296,    58,    58,   105,   105,  1312,    91,   105,
  21719. -  1033,  1034,   105,  1312,  1018,     9,  1312,   105,  1312,   105,
  21720. -   813,   814,  1327,    58,  1047,  1048,    58,    57,  1282,    91,
  21721. -   662,   105,  1337,  1327,   105,  1340,   105,  1115,   670,    58,
  21722. -    58,  1340,  1296,  1337,  1340,    62,  1340,   840,   105,     4,
  21723. -    78,     9,    58,     5,     6,     7,   105,    12,  1312,     9,
  21724. -    12,    58,     0,  1067,     0,     0,   364,    22,    23,    24,
  21725. -     2,     4,   328,  1327,    29,    30,   835,    32,    30,   144,
  21726. -   629,    33,   122,  1337,    39,   144,  1340,  1392,   881,  1000,
  21727. -  1164,    43,  1207,  1392,   491,    50,  1392,    52,  1392,  1177,
  21728. -  1123,  1124,  1242,  1263,  1392,    60,   828,  1123,  1246,   636,
  21729. -  1114,   139,    39,    68,   823,    39,  1029,     1,   902,     3,
  21730. -     4,   840,     6,  1146,    79,    80,   849,  1150,     5,     6,
  21731. -     7,    86,   160,   995,   916,    12,   440,   914,  1392,   571,
  21732. -   821,   528,    97,   169,   300,   173,  1261,  1262,  1263,    12,
  21733. -  1125,  1012,  1361,    30,   867,    39,    33,   112,   787,   653,
  21734. -   115,  1363,   881,   118,   119,  1299,    43,  1327,    52,   124,
  21735. -    54,    55,   127,   128,   918,    -1,   131,   132,   133,    -1,
  21736. -    -1,    -1,    -1,   812,   813,    -1,    -1,    -1,    -1,   144,
  21737. -  1194,   146,   147,    -1,    -1,    -1,    -1,    -1,   991,   992,
  21738. -  1223,  1224,    86,  1226,  1227,    -1,    -1,   162,   163,   164,
  21739. -    74,    75,    76,    77,    78,    79,    80,    81,    82,   851,
  21740. -    -1,    -1,    -1,    -1,  1017,  1018,  1230,  1231,  1232,  1233,
  21741. -    -1,     3,     4,    -1,    -1,   190,    -1,    -1,    -1,    -1,
  21742. -    -1,    10,  1246,  1247,    -1,    -1,    -1,  1270,    -1,    -1,
  21743. -    -1,    -1,    -1,    -1,    -1,   210,    25,    26,   213,  1263,
  21744. -    -1,    30,    -1,   895,    -1,    -1,   221,    39,    -1,     3,
  21745. -     4,   990,   991,   992,   906,    -1,    45,    -1,  1282,    -1,
  21746. -    52,    -1,    54,    55,    -1,   917,    58,    -1,    57,    58,
  21747. -    59,    60,    -1,    62,    -1,    -1,    68,  1016,  1017,  1018,
  21748. -    -1,    -1,    -1,   258,   259,    39,    78,    -1,    -1,    -1,
  21749. -    -1,    45,     7,    -1,    86,    10,    -1,    -1,    52,    91,
  21750. -    54,    55,    91,    92,    -1,    -1,    95,    -1,    -1,   958,
  21751. -    -1,  1335,    -1,  1337,    68,  1358,   105,    -1,    -1,    -1,
  21752. -    -1,   296,    -1,    -1,    78,   300,    -1,   302,   303,   304,
  21753. -    45,    -1,    86,    -1,    88,   310,  1360,    91,    92,    -1,
  21754. -    -1,    -1,    57,    -1,    -1,    60,    -1,    62,    -1,    -1,
  21755. -    -1,    -1,  1376,   328,    -1,   403,    -1,    -1,    73,   334,
  21756. -    -1,    -1,   410,   338,     3,     4,    -1,  1016,  1017,    -1,
  21757. -    -1,    -1,    -1,     4,    -1,   350,    91,    92,   353,    -1,
  21758. -    95,  1033,  1034,   358,    -1,    -1,    -1,   362,    -1,    -1,
  21759. -   105,    -1,    -1,    24,  1207,  1047,  1048,    -1,    29,    30,
  21760. -    39,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    39,    -1,
  21761. -    -1,   459,   460,    52,   462,    54,    55,    -1,    -1,     1,
  21762. -   395,    52,   397,    -1,   399,   400,   401,    -1,    -1,    68,
  21763. -    -1,    -1,   407,    -1,    -1,    -1,    -1,   412,    -1,    78,
  21764. -   415,    23,    -1,    25,    26,    -1,    -1,    86,    30,  1262,
  21765. -  1263,    -1,    91,    -1,    -1,    86,    -1,   432,    -1,   434,
  21766. -    -1,    -1,   385,    -1,   439,   440,    -1,   442,  1207,    -1,
  21767. -   393,    -1,    -1,   448,    56,    57,    58,    59,    60,     4,
  21768. -    62,     6,     7,    -1,    -1,    -1,    -1,    12,    -1,    -1,
  21769. -    -1,    -1,    -1,   124,  1146,    -1,    -1,   128,  1150,    -1,
  21770. -   548,   549,    27,    -1,    29,   553,    -1,    -1,    33,    -1,
  21771. -    -1,    93,    -1,   144,    -1,    -1,   147,    -1,    43,    -1,
  21772. -    -1,    -1,  1261,  1262,  1263,    -1,    -1,    52,    -1,    54,
  21773. -    55,   162,   163,    -1,    -1,    -1,    -1,     4,     5,     6,
  21774. -     7,   464,    -1,    10,    -1,    12,    -1,    -1,    -1,    -1,
  21775. -    -1,    -1,    -1,   528,    -1,   530,    -1,    -1,    -1,    -1,
  21776. -    27,    -1,    29,    30,    -1,   540,    33,   542,   543,    -1,
  21777. -   545,  1223,  1224,    -1,  1226,  1227,    43,   552,    -1,   210,
  21778. -    -1,    -1,    -1,    -1,    -1,    52,    -1,    54,    55,    -1,
  21779. -   221,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21780. -    -1,   524,    -1,   526,   527,     1,    -1,     3,     4,     5,
  21781. -     6,     7,  1261,  1262,     3,     4,    12,   592,  1270,    -1,
  21782. -    -1,    -1,   597,   598,   599,   600,   601,   602,    95,   552,
  21783. -    -1,    27,    -1,    29,    30,   558,    -1,    33,    34,   687,
  21784. -   162,   163,   164,    39,    -1,    -1,    -1,    43,    44,    -1,
  21785. -    39,    -1,    -1,    -1,    -1,    -1,    52,    -1,    54,    55,
  21786. -    -1,    -1,    58,    52,    60,    54,    55,    -1,    -1,    -1,
  21787. -    -1,    60,    68,    -1,   649,    -1,    -1,    -1,   653,    68,
  21788. -    -1,    -1,    78,   658,   659,    -1,   661,    -1,    -1,    78,
  21789. -    86,    -1,    -1,    -1,    -1,    91,     4,    86,     6,     7,
  21790. -    -1,    -1,    91,    -1,    12,    -1,  1358,     3,     4,    -1,
  21791. -   106,     7,    -1,    -1,   689,    -1,    -1,    -1,    -1,   350,
  21792. -    -1,    -1,   353,    -1,    -1,    33,    -1,   358,    -1,    -1,
  21793. -    -1,   362,   707,   781,   782,    43,   784,    45,    -1,    -1,
  21794. -   715,   716,   717,    39,    52,    -1,    54,    55,    -1,    45,
  21795. -    -1,   726,   727,   728,   729,    -1,    52,    -1,    54,    55,
  21796. -    68,   809,    -1,    -1,   395,    -1,   397,    -1,    -1,    -1,
  21797. -    78,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21798. -    88,   412,    78,    91,    92,    -1,    -1,    -1,    -1,    -1,
  21799. -    86,    -1,    88,    -1,   842,    91,    92,   720,    -1,    -1,
  21800. -   775,    -1,    -1,    -1,    -1,    -1,     4,    -1,   439,   440,
  21801. -    -1,   442,    -1,    -1,    12,    -1,    -1,    -1,    -1,    -1,
  21802. -   795,    -1,   797,    -1,    22,    23,    24,    -1,    -1,   804,
  21803. -    -1,    29,    30,   808,    32,   810,    -1,   812,   813,   814,
  21804. -    -1,    39,    -1,   818,    -1,    -1,    -1,    -1,    -1,    -1,
  21805. -    -1,    -1,    50,    -1,    52,    -1,   779,    -1,    -1,    -1,
  21806. -   835,    -1,   837,   838,   839,   840,    -1,    -1,    -1,   792,
  21807. -    68,   794,    -1,   395,    -1,   397,    -1,   399,   400,   401,
  21808. -    -1,    -1,    80,    -1,    -1,    -1,    -1,    -1,    86,    -1,
  21809. -   412,    68,    69,    70,    71,    72,    73,    74,    75,    76,
  21810. -    77,    78,    79,    80,    81,    82,   881,   830,     3,     4,
  21811. -    -1,    -1,     7,    -1,   112,    -1,    -1,   439,   966,    -1,
  21812. -   118,   119,    -1,    -1,    -1,    -1,   124,   902,    -1,    -1,
  21813. -   128,    -1,    -1,   131,   132,   133,   911,    -1,   861,   914,
  21814. -    -1,   916,    -1,   918,    39,   993,   144,    -1,   146,   147,
  21815. -    45,    -1,    -1,    -1,    -1,    -1,    -1,    52,   881,    54,
  21816. -    55,    -1,    -1,    -1,   162,   163,   164,   598,    -1,    -1,
  21817. -    -1,    -1,    -1,    68,    -1,    -1,    -1,   952,   953,    -1,
  21818. -   955,    -1,    -1,    78,    -1,     4,    -1,    -1,     7,    -1,
  21819. -  1038,    86,   190,    88,    -1,    -1,    91,    92,    69,    70,
  21820. -    71,    72,    73,    74,    75,    76,    77,    78,    79,    80,
  21821. -    81,    82,   210,   988,   989,   990,   991,   992,    -1,   994,
  21822. -   995,    -1,   653,   221,    -1,    -1,    45,   658,   659,    -1,
  21823. -   661,    -1,    -1,    52,  1082,    54,    55,    -1,    -1,    -1,
  21824. -    -1,  1016,  1017,  1018,     3,     4,     5,     6,     7,    68,
  21825. -    -1,    -1,    -1,    12,  1029,    -1,    -1,    -1,    -1,    78,
  21826. -   258,   259,    -1,    -1,    -1,    -1,    -1,    -1,    27,    88,
  21827. -    29,    30,    91,    92,    33,  1050,    -1,    -1,    -1,  1002,
  21828. -    39,  1004,    -1,  1006,    43,    -1,    45,    -1,    -1,    -1,
  21829. -    -1,    -1,    -1,    52,    -1,    54,    55,    -1,   296,    -1,
  21830. -    -1,    -1,   300,    -1,   302,   303,   304,    -1,    -1,    68,
  21831. -    -1,   309,   310,  1088,  1089,  1090,    -1,    -1,    -1,    78,
  21832. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,    -1,    88,
  21833. -   328,    -1,    91,    92,    -1,    -1,   658,   659,    -1,   661,
  21834. -   338,     3,     4,     5,     6,     7,    -1,  1122,  1123,  1124,
  21835. -    12,    -1,   350,    -1,    -1,   353,    -1,    -1,    -1,    -1,
  21836. -   358,    -1,  1085,    -1,   362,    -1,    -1,   689,    30,    -1,
  21837. -    -1,    33,    -1,    -1,    -1,    -1,    -1,    39,    -1,    -1,
  21838. -    -1,    43,    -1,    45,    -1,    -1,    -1,    -1,    -1,    -1,
  21839. -    52,    -1,    54,    55,    -1,    -1,    -1,   395,    -1,   397,
  21840. -    -1,   399,   400,   401,    -1,    -1,    68,   838,   839,   407,
  21841. -     4,    -1,     6,     7,   412,    -1,    78,   415,    12,    -1,
  21842. -    -1,    -1,    -1,    -1,    86,    -1,    88,     3,     4,    91,
  21843. -    92,     7,  1207,    27,   432,    29,   434,    -1,    85,    33,
  21844. -    -1,   439,   440,     4,   442,     6,    -1,    -1,    -1,    43,
  21845. -   448,    12,    -1,    -1,    -1,    -1,    -1,    -1,    52,    -1,
  21846. -    54,    55,    -1,    39,    -1,    -1,    27,    -1,    29,    -1,
  21847. -    -1,    -1,    33,    -1,    -1,   122,    52,    -1,    54,    55,
  21848. -   911,    -1,    43,   914,  1207,   916,  1261,  1262,  1263,    -1,
  21849. -    -1,    52,    68,    54,    55,     1,    -1,     3,     4,     5,
  21850. -     6,     7,    78,    -1,     3,     4,    12,    -1,     7,    -1,
  21851. -    86,    -1,    -1,    -1,    -1,    91,   838,   839,   840,  1294,
  21852. -    -1,    27,    -1,    29,    30,    -1,    -1,    33,    -1,    -1,
  21853. -   528,    -1,   530,    39,    -1,    -1,    -1,    43,    -1,    -1,
  21854. -    39,    -1,    -1,    -1,   542,   543,    52,   545,    54,    55,
  21855. -    -1,    -1,  1327,    52,   552,    54,    55,   988,   989,   881,
  21856. -     3,     4,    68,   994,   995,   563,    -1,    -1,    -1,    68,
  21857. -    -1,    -1,    78,    -1,    -1,    -1,    -1,    -1,    -1,    78,
  21858. -    86,    -1,    -1,    -1,    -1,    91,    -1,    86,    -1,   911,
  21859. -    -1,    -1,    91,    -1,   592,    -1,    39,    -1,    -1,   597,
  21860. -   598,   599,   600,    -1,   602,    -1,    -1,    -1,    -1,    52,
  21861. -    -1,    54,    55,    -1,    -1,    -1,    -1,    60,    -1,  1050,
  21862. -    -1,    -1,    -1,    -1,    -1,    68,    -1,    -1,    -1,   276,
  21863. -   628,    -1,    -1,    -1,    -1,    78,    -1,    -1,    -1,    -1,
  21864. -    -1,    -1,    -1,    86,    -1,    -1,    -1,    -1,    91,    -1,
  21865. -    -1,   649,    -1,    -1,    -1,   653,    -1,  1088,  1089,  1090,
  21866. -   658,   659,    -1,   661,    -1,    -1,   988,   989,   990,   991,
  21867. -   992,    -1,   994,    -1,     3,     4,     5,     6,     7,    -1,
  21868. -    -1,    -1,    -1,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  21869. -    -1,   689,  1123,    -1,  1016,  1017,  1018,    -1,    -1,     3,
  21870. -     4,    30,    -1,     7,    33,    -1,    -1,    -1,    -1,   707,
  21871. -    39,    -1,    -1,    -1,    43,    -1,    45,   715,   716,   717,
  21872. -    -1,    -1,    -1,    52,    -1,    54,    55,    -1,   726,   727,
  21873. -   728,   729,    -1,    -1,    -1,    39,    -1,   384,   385,    68,
  21874. -    -1,    45,    -1,     3,     4,    -1,   393,     7,    52,    78,
  21875. -    54,    55,    -1,    -1,    -1,    -1,    -1,    86,    -1,    88,
  21876. -    -1,    -1,    91,    92,    68,    -1,  1088,  1089,  1090,    -1,
  21877. -    -1,    -1,    -1,    -1,    78,    -1,    -1,   775,    -1,    39,
  21878. -    -1,    -1,    86,    -1,    88,    45,    -1,    91,    92,   436,
  21879. -    -1,    -1,    52,    -1,    54,    55,    -1,   795,    -1,   797,
  21880. -    -1,    -1,    -1,    -1,    -1,    -1,   804,    -1,    68,    -1,
  21881. -   808,    -1,   810,    -1,   812,   813,   814,   464,    78,    -1,
  21882. -   818,    -1,    -1,    -1,    -1,    -1,    86,    -1,    88,    -1,
  21883. -    -1,    91,    92,    -1,    -1,    -1,    -1,   835,    -1,   837,
  21884. -   838,   839,   840,    -1,   491,     4,    -1,   494,     7,    -1,
  21885. -   497,   498,    -1,   500,   501,   502,   503,   504,   505,   506,
  21886. -   507,   508,   509,   510,   511,   512,   513,   514,   515,   516,
  21887. -   517,   518,    -1,    -1,    -1,    -1,    -1,   524,    -1,   526,
  21888. -   527,    -1,    -1,   881,    -1,  1207,    45,    -1,    -1,    -1,
  21889. -    -1,    -1,    -1,    52,    -1,    54,    55,    -1,     3,     4,
  21890. -     5,     6,     7,    -1,   902,   552,    -1,    12,    -1,    68,
  21891. -    -1,   558,    -1,   911,    -1,    -1,   914,    -1,   916,    78,
  21892. -   918,    -1,    27,    -1,    29,    30,   573,   574,    33,    88,
  21893. -    -1,    -1,    91,    92,    39,    -1,    -1,    -1,    43,  1261,
  21894. -  1262,  1263,    -1,    -1,    -1,    -1,    -1,    52,    -1,    54,
  21895. -    55,    -1,    -1,    58,   952,   953,    -1,   955,    -1,     4,
  21896. -     5,     6,     7,    68,    -1,    10,    -1,    12,    -1,    -1,
  21897. -    -1,    -1,    -1,    78,    -1,    -1,    -1,    -1,    -1,    -1,
  21898. -    -1,    86,    27,    -1,    29,    30,    91,    -1,    33,   636,
  21899. -   988,   989,   990,   991,   992,    -1,   994,   995,    43,    -1,
  21900. -    45,    -1,  1000,    -1,    -1,    -1,    -1,    52,    -1,    54,
  21901. -    55,    -1,     3,     4,    -1,    -1,     7,    -1,  1016,  1017,
  21902. -  1018,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  21903. -    -1,  1029,    -1,    78,     4,    -1,    -1,    -1,    -1,    -1,
  21904. -    -1,   688,    -1,    88,    -1,    -1,    91,    92,    39,    -1,
  21905. -    95,    -1,  1050,    -1,    24,     4,    -1,    -1,     7,    29,
  21906. -    30,    52,    32,    54,    55,    -1,    -1,    -1,    -1,    39,
  21907. -    -1,    -1,    -1,   720,   302,   303,   304,    68,    -1,    -1,
  21908. -    50,    -1,    52,    -1,     3,     4,    -1,    78,     7,    -1,
  21909. -  1088,  1089,  1090,    -1,   741,    86,    45,    -1,    -1,    -1,
  21910. -    91,    -1,    -1,    52,    -1,    54,    55,    -1,    -1,    -1,
  21911. -    -1,    -1,    -1,    -1,    -1,    -1,    86,    -1,    -1,    68,
  21912. -    39,    -1,    -1,    -1,  1122,  1123,  1124,    -1,    -1,    78,
  21913. -    -1,   778,   779,    52,    -1,    54,    55,    -1,    -1,    88,
  21914. -    -1,    -1,    91,    92,    -1,   792,    -1,   794,   118,    68,
  21915. -    -1,    -1,    -1,    -1,   124,    -1,    -1,    -1,   128,    78,
  21916. -     4,   131,   132,   133,     3,     4,    -1,    86,     7,    -1,
  21917. -    -1,    -1,    91,   820,   144,    -1,   146,   147,    -1,    -1,
  21918. -    24,    -1,    -1,   830,    -1,    29,    30,    -1,    32,    -1,
  21919. -    -1,    -1,   162,   163,   164,    39,    -1,    -1,    -1,    -1,
  21920. -    39,    -1,    -1,    -1,    -1,    -1,    50,    -1,    52,  1207,
  21921. -    -1,    -1,    -1,    52,   861,    54,    55,    -1,    -1,    -1,
  21922. -   190,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    68,
  21923. -    -1,    75,    -1,    -1,   881,    -1,    -1,    -1,    -1,    78,
  21924. -   210,    -1,    86,    -1,   891,    -1,    -1,    86,    -1,    -1,
  21925. -    -1,   221,    91,    -1,    -1,    -1,   903,   904,    -1,    -1,
  21926. -    -1,     3,     4,  1261,  1262,  1263,    -1,    -1,   112,    -1,
  21927. -   114,   115,    -1,    -1,   118,    -1,    -1,    -1,    -1,    -1,
  21928. -   124,    -1,   126,    -1,   128,    -1,    -1,   131,   132,   133,
  21929. -   937,   938,    -1,    -1,   941,    -1,  1294,    39,    -1,    -1,
  21930. -   144,    -1,   146,   147,    -1,    -1,    -1,    -1,    -1,    -1,
  21931. -    52,    -1,    54,    55,   542,   543,    58,   545,   162,   163,
  21932. -   164,    -1,    -1,    -1,   552,    -1,    68,    -1,   172,  1327,
  21933. -    -1,    -1,    -1,    -1,    -1,    -1,    78,    -1,    -1,   309,
  21934. -   310,    -1,    -1,    -1,    86,    -1,   190,    -1,    -1,    91,
  21935. -    -1,     3,     4,    -1,    -1,  1002,    -1,  1004,    -1,  1006,
  21936. -    -1,    -1,    -1,    -1,    -1,    -1,   210,  1014,    -1,   597,
  21937. -    -1,   599,   600,    -1,   602,  1022,    -1,   221,    -1,    -1,
  21938. -   350,    -1,    -1,   353,    -1,    -1,    -1,    39,   358,    -1,
  21939. -    -1,    -1,   362,    -1,  1041,    -1,    -1,    -1,    -1,    -1,
  21940. -    52,    -1,    54,    55,    -1,    -1,    -1,  1054,    -1,    -1,
  21941. -    -1,    -1,  1059,    -1,  1061,    -1,    68,    -1,    -1,    -1,
  21942. -    -1,   649,    -1,    -1,    -1,   395,    78,   397,    -1,   399,
  21943. -   400,   401,    -1,    -1,    86,    -1,    -1,   407,  1085,    91,
  21944. -    -1,   285,   412,    -1,    -1,   415,     3,     4,     5,     6,
  21945. -     7,    -1,    -1,    -1,    -1,    12,   300,    -1,    -1,    -1,
  21946. -    -1,    -1,    -1,  1110,   308,    -1,   310,    -1,    -1,   439,
  21947. -   440,    -1,   442,    30,    -1,    -1,    33,    -1,    -1,   707,
  21948. -    -1,    -1,    39,    -1,   328,    -1,    43,    -1,    45,    -1,
  21949. -   334,  1138,  1139,    -1,    -1,    52,    -1,    54,    55,    -1,
  21950. -    -1,  1148,  1149,    -1,    -1,    -1,   350,    -1,    -1,   353,
  21951. -    -1,    68,    -1,    -1,   358,    -1,  1163,    -1,   362,    -1,
  21952. -    -1,    78,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,
  21953. -    -1,    -1,    -1,    -1,    91,    67,    68,    69,    70,    71,
  21954. -    72,    73,    74,    75,    76,    77,    78,    79,    80,    81,
  21955. -    82,   395,    -1,   397,    -1,   399,   400,   401,    -1,    -1,
  21956. -  1207,    -1,    -1,   407,    -1,    -1,    -1,   795,   412,   797,
  21957. -   540,   415,    -1,  1220,    -1,    -1,    -1,    -1,    -1,    -1,
  21958. -   808,    -1,    -1,    -1,   812,   813,   814,  1234,    -1,    -1,
  21959. -    -1,    -1,    -1,    -1,    -1,   439,   440,    -1,   442,    -1,
  21960. -    -1,  1248,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21961. -   838,   839,   840,     4,    -1,     6,     7,    -1,    -1,    -1,
  21962. -    -1,    12,   466,    -1,    -1,   469,    -1,   597,   598,   599,
  21963. -   600,    -1,    -1,    -1,    -1,    -1,    27,    -1,    29,   483,
  21964. -   484,   485,    33,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21965. -    -1,   495,    43,   881,    45,    -1,    -1,    -1,   628,    -1,
  21966. -    -1,    52,    -1,    54,    55,    -1,    -1,    -1,    -1,     3,
  21967. -     4,    -1,    -1,     7,    -1,    -1,    -1,    68,    -1,   649,
  21968. -    -1,    -1,    -1,   653,    -1,    -1,    -1,    78,   658,   659,
  21969. -    -1,   661,    -1,    -1,    32,   539,    -1,    88,    -1,    -1,
  21970. -    91,    92,    -1,    -1,    -1,    39,    -1,    -1,   552,    -1,
  21971. -    -1,    -1,    50,    -1,    -1,    -1,    -1,    -1,    52,   689,
  21972. -    54,    55,    71,    72,    73,    74,    75,    76,    77,    78,
  21973. -    79,    80,    81,    82,    68,     3,     4,  1384,    -1,     7,
  21974. -    -1,    -1,    -1,    -1,    78,    -1,    -1,    -1,    -1,    -1,
  21975. -    -1,    -1,    86,   597,   598,   599,   600,    91,    -1,    -1,
  21976. -   988,   989,   990,   991,   992,    -1,   994,    -1,    -1,    -1,
  21977. -    -1,    39,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21978. -   118,    -1,    -1,    -1,    52,    -1,    54,    55,  1016,  1017,
  21979. -  1018,    -1,    -1,   131,   132,   133,    -1,    -1,    -1,    -1,
  21980. -    68,    -1,    -1,    -1,    -1,   649,    -1,    -1,   146,   653,
  21981. -    78,    -1,    -1,    -1,   658,   659,    -1,   661,    86,    -1,
  21982. -    -1,    -1,    -1,    91,   162,   163,   164,    -1,    -1,    -1,
  21983. -    -1,    -1,    -1,    -1,    -1,   302,   303,   304,    50,    -1,
  21984. -    -1,    -1,    -1,    -1,    -1,   689,    -1,    -1,   818,    -1,
  21985. -    -1,    -1,   190,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  21986. -  1088,  1089,  1090,    75,    -1,    -1,    -1,    -1,   838,   839,
  21987. -   840,    -1,    -1,    -1,    -1,    -1,   720,    -1,    -1,    -1,
  21988. -    -1,    -1,    -1,    95,    -1,    -1,     1,    -1,     3,     4,
  21989. -     5,     6,     7,    -1,    -1,    -1,    -1,    12,    -1,    -1,
  21990. -    -1,    -1,    -1,    -1,    -1,    -1,   118,    -1,    -1,    -1,
  21991. -    -1,   881,    27,    -1,    29,    30,    -1,    -1,    33,    34,
  21992. -    -1,   259,    -1,    -1,    39,    -1,    -1,    -1,    43,    44,
  21993. -    -1,    -1,    -1,    -1,   146,    -1,    -1,    52,    -1,    54,
  21994. -    55,   911,    -1,    58,   914,    60,   916,    -1,     3,     4,
  21995. -   162,   163,   164,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  21996. -   172,    -1,    -1,    78,   302,   303,   304,    -1,   812,   813,
  21997. -   814,    86,   310,    -1,    -1,    -1,    91,    -1,   190,    -1,
  21998. -    -1,    -1,    -1,    -1,    39,    -1,    -1,    -1,    -1,    -1,
  21999. -    -1,   106,    -1,    -1,   838,   839,   840,    52,    -1,    54,
  22000. -    55,    -1,    -1,    -1,     4,    -1,     6,     7,    -1,    -1,
  22001. -    -1,   223,    12,    68,    -1,    -1,    -1,    -1,   988,   989,
  22002. -   990,   991,   992,    78,   994,   995,    -1,    -1,    -1,    -1,
  22003. -  1000,    86,    -1,    33,    -1,    -1,    91,   881,    -1,    -1,
  22004. -    -1,    -1,    -1,    43,    -1,    45,  1016,  1017,  1018,    -1,
  22005. -    -1,    -1,    52,    -1,    54,    55,    -1,   395,    -1,   397,
  22006. -    -1,   399,   400,   401,   908,    -1,    -1,   911,    68,   407,
  22007. -   914,    -1,   916,    -1,   412,   542,   543,   415,    78,    -1,
  22008. -  1050,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    88,    -1,
  22009. -    -1,    91,    92,    -1,    -1,    -1,   308,    -1,   310,    -1,
  22010. -    -1,   439,    70,    71,    72,    73,    74,    75,    76,    77,
  22011. -    78,    79,    80,    81,    82,    -1,    -1,    -1,  1088,  1089,
  22012. -  1090,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22013. -   597,   975,   599,   600,    -1,   602,    -1,    -1,    -1,    -1,
  22014. -    -1,    -1,    -1,    -1,   988,   989,   990,   991,   992,    -1,
  22015. -   994,   995,  1122,  1123,  1124,    -1,    -1,    -1,    -1,    -1,
  22016. -     3,     4,    -1,    -1,     7,    -1,    -1,    -1,    -1,    -1,
  22017. -    -1,    -1,  1016,  1017,  1018,    -1,    -1,    -1,    -1,    -1,
  22018. -    -1,    -1,   649,   395,    -1,   397,    -1,   399,   400,   401,
  22019. -    -1,    -1,   530,    -1,    -1,   407,    39,    -1,    -1,    -1,
  22020. -   412,    -1,    -1,   415,   542,   543,  1050,   545,    -1,    52,
  22021. -    -1,    54,    55,    -1,   552,    -1,    -1,    -1,    -1,    -1,
  22022. -    -1,    -1,    -1,    -1,    -1,    68,     4,   439,     6,     7,
  22023. -    -1,    -1,    -1,    -1,    12,    78,    -1,  1207,    -1,    -1,
  22024. -   707,    -1,    -1,    86,  1088,  1089,  1090,    -1,    91,    27,
  22025. -    -1,    29,    -1,    -1,    -1,    33,    -1,    -1,    -1,   597,
  22026. -    -1,   599,   600,    -1,   602,    43,    -1,    -1,    -1,    -1,
  22027. -    -1,    -1,    -1,    -1,    52,    -1,    54,    55,  1122,  1123,
  22028. -  1124,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22029. -    -1,  1261,  1262,  1263,    66,    67,    68,    69,    70,    71,
  22030. -    72,    73,    74,    75,    76,    77,    78,    79,    80,    81,
  22031. -    82,   649,    -1,    91,    -1,    -1,    -1,    -1,    -1,    -1,
  22032. -   658,   659,    -1,   661,  1294,    -1,    -1,    -1,   795,    -1,
  22033. -   797,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22034. -    -1,   808,    -1,   555,    -1,   812,   813,    -1,    -1,    -1,
  22035. -    -1,   689,    -1,    -1,    -1,    -1,     3,     4,     5,     6,
  22036. -     7,    -1,    -1,  1207,    -1,    12,    -1,    -1,    -1,   707,
  22037. -    -1,   838,   839,    -1,    -1,    -1,    -1,   715,   716,   717,
  22038. -    27,    -1,    29,    30,    -1,   597,    33,   599,   600,    -1,
  22039. -    -1,    -1,    39,    -1,    -1,    -1,    43,    -1,    -1,    -1,
  22040. -    -1,    -1,    -1,    -1,    -1,    52,    -1,    54,    55,    -1,
  22041. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,  1261,  1262,  1263,
  22042. -    -1,    68,    -1,    -1,    -1,    72,    -1,    -1,    -1,    -1,
  22043. -    -1,    78,    -1,    -1,    -1,    -1,    -1,   649,    -1,    86,
  22044. -    -1,    -1,    -1,    -1,    91,    -1,   658,   659,    -1,   661,
  22045. -  1294,    12,    -1,    -1,    -1,    -1,    -1,   795,    -1,   797,
  22046. -    -1,    22,    23,    -1,    -1,    -1,    -1,    -1,    29,    30,
  22047. -   808,    32,    -1,    -1,   812,   813,   814,   689,    -1,    -1,
  22048. -     4,     5,     6,     7,    -1,    -1,    10,    -1,    12,    -1,
  22049. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    60,
  22050. -   838,   839,   840,    27,    -1,    29,    30,    -1,    -1,    33,
  22051. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    43,
  22052. -    -1,   988,   989,   990,   991,    -1,    -1,   994,    52,    -1,
  22053. -    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22054. -    -1,    -1,    -1,   881,    -1,    -1,    -1,    -1,    -1,  1016,
  22055. -  1017,   112,    -1,   114,   115,     3,     4,     5,     6,     7,
  22056. -    -1,    -1,    10,   124,    12,   126,   127,   128,    -1,    -1,
  22057. -   131,   132,   133,   911,    -1,    -1,    -1,    -1,    -1,    27,
  22058. -    -1,    29,    30,    -1,    -1,    33,    -1,    -1,    -1,    -1,
  22059. -    -1,    39,    -1,    -1,    -1,    43,    -1,    -1,    -1,    -1,
  22060. -    -1,    -1,    -1,    -1,    52,    -1,    54,    55,    -1,    -1,
  22061. -    -1,    -1,    -1,    -1,   952,   953,    -1,   955,    -1,    -1,
  22062. -    68,  1088,  1089,  1090,    -1,    -1,   838,   839,   840,    -1,
  22063. -    78,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,    -1,
  22064. -    -1,    -1,    -1,    91,   205,    -1,    -1,    95,    -1,    -1,
  22065. -   988,   989,   990,   991,   992,    -1,   994,    -1,    -1,     1,
  22066. -   221,     3,     4,     5,     6,     7,    -1,    -1,    -1,   881,
  22067. -    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,  1016,  1017,
  22068. -  1018,    -1,    -1,    -1,    -1,    27,    -1,    29,    30,    -1,
  22069. -    -1,    33,    34,    -1,    -1,    -1,   908,    39,   259,   911,
  22070. -    -1,    43,    44,    -1,    -1,    -1,     4,     5,     6,     7,
  22071. -    52,    -1,    54,    55,    12,    -1,    58,    -1,    60,    -1,
  22072. -    -1,    -1,    -1,    -1,    -1,    -1,    68,    -1,    -1,    27,
  22073. -    -1,    29,    30,    -1,    -1,    33,    78,    -1,    -1,   300,
  22074. -    -1,   302,   303,    -1,    86,    43,    -1,    -1,    -1,    91,
  22075. -  1088,  1089,  1090,    -1,    52,    -1,    54,    55,    -1,    -1,
  22076. -    -1,    -1,    -1,   975,   106,    -1,    -1,   328,    -1,    -1,
  22077. -    -1,    -1,    -1,   334,    -1,    -1,   988,   989,   990,   991,
  22078. -   992,    -1,   994,    -1,  1122,   346,  1124,    -1,    -1,   350,
  22079. -    -1,    -1,   353,    -1,    -1,    -1,    -1,   358,    -1,    -1,
  22080. -    -1,    -1,    -1,    -1,  1016,  1017,  1018,     1,    -1,     3,
  22081. -     4,     5,     6,     7,     8,     9,    -1,    11,    12,    13,
  22082. -    -1,    15,    16,    17,    18,    19,    20,    21,    22,    23,
  22083. -    24,    25,    26,    27,    28,    29,    30,    31,    -1,    33,
  22084. -    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,    43,
  22085. -    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,
  22086. -    54,    55,    56,    -1,    58,    59,    -1,    -1,    -1,  1207,
  22087. -    -1,    65,    -1,   434,    68,    -1,  1088,  1089,  1090,    -1,
  22088. -    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,
  22089. -    84,    85,    86,    -1,    -1,    -1,    -1,    91,    -1,    93,
  22090. -   461,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22091. -  1122,    -1,  1124,   107,    -1,    -1,    -1,    -1,    -1,    -1,
  22092. -    -1,    -1,    -1,  1261,  1262,  1263,    -1,    -1,    -1,    -1,
  22093. -    -1,    -1,     1,    -1,     3,     4,     5,     6,     7,    -1,
  22094. -    -1,    -1,    -1,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22095. -    -1,    -1,    -1,    -1,    -1,    -1,  1294,    -1,    27,    -1,
  22096. -    29,    30,    -1,    -1,    33,    34,    -1,    -1,    -1,   530,
  22097. -    39,    -1,    -1,    -1,    43,    44,    -1,    -1,   539,   540,
  22098. -    -1,   542,   543,    52,    -1,    54,    55,    -1,    -1,    58,
  22099. -    -1,    60,    -1,    -1,    -1,  1207,    -1,    -1,    -1,    68,
  22100. -    -1,    -1,    10,    -1,    -1,    -1,    -1,    -1,    -1,    78,
  22101. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,    -1,    -1,
  22102. -    -1,    -1,    91,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22103. -    -1,   592,    -1,    -1,    -1,    -1,    -1,   106,    -1,    -1,
  22104. -   601,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,  1261,
  22105. -  1262,  1263,    60,    61,    62,    63,    64,    65,    66,    67,
  22106. -    68,    69,    70,    71,    72,    73,    74,    75,    76,    77,
  22107. -    78,    79,    80,    81,    82,    -1,    -1,    -1,    -1,    -1,
  22108. -    -1,    -1,  1294,     1,    -1,     3,     4,     5,     6,     7,
  22109. -     8,     9,    -1,    11,    12,    13,    -1,    15,    16,    17,
  22110. -    18,    19,    20,    21,    22,    23,    24,    25,    26,    27,
  22111. -    28,    29,    30,    31,    -1,    33,    -1,    35,    36,    -1,
  22112. -    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,
  22113. -    48,    49,    50,    51,    52,    -1,    54,    55,    56,    -1,
  22114. -    58,    59,    -1,    -1,    -1,    -1,   707,    65,    -1,    -1,
  22115. -    68,    -1,    -1,    -1,   715,   716,   717,    -1,    76,    77,
  22116. -    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,
  22117. -    -1,    -1,    -1,    91,     1,    93,     3,     4,     5,     6,
  22118. -     7,     8,     9,    10,    11,    12,    -1,    -1,   106,   107,
  22119. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22120. -    27,    28,    29,    30,    31,    -1,    33,    -1,    35,    36,
  22121. -    -1,    38,    39,    40,    41,    -1,    43,    -1,    45,    -1,
  22122. -    47,    48,    49,    50,    51,    52,    -1,    54,    55,    56,
  22123. -    -1,    -1,    59,    -1,   795,    -1,   797,    -1,    65,    -1,
  22124. -    -1,    68,    -1,    -1,    -1,    -1,    -1,   808,    -1,    76,
  22125. -    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,
  22126. -    -1,    88,    -1,    -1,    91,    92,    -1,     1,    95,     3,
  22127. -     4,     5,     6,     7,     8,     9,    10,    11,    12,    -1,
  22128. -   107,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22129. -    -1,    -1,    -1,    27,    28,    29,    30,    31,    -1,    33,
  22130. -    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,    43,
  22131. -    -1,    45,    -1,    47,    48,    49,    50,    51,    52,    -1,
  22132. -    54,    55,    56,    -1,    -1,    59,    -1,    -1,    -1,    -1,
  22133. -    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,
  22134. -    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,
  22135. -    84,    85,    86,   914,    88,    -1,    -1,    91,    92,    -1,
  22136. -    -1,    95,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22137. -    -1,    -1,     1,   107,     3,     4,     5,     6,     7,     8,
  22138. -     9,    10,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22139. -    -1,   952,   953,    -1,   955,    -1,    -1,    -1,    27,    28,
  22140. -    29,    30,    31,    -1,    33,    -1,    35,    36,    -1,    38,
  22141. -    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,
  22142. -    49,    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,
  22143. -    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,
  22144. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,
  22145. -    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,
  22146. -    -1,    -1,    91,    -1,    -1,    -1,    95,    -1,    -1,    -1,
  22147. -    -1,    -1,    -1,    -1,    -1,    -1,   105,     1,   107,     3,
  22148. -     4,     5,     6,     7,     8,     9,    -1,    11,    12,    -1,
  22149. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22150. -    -1,    -1,    -1,    27,    28,    29,    30,    31,    -1,    33,
  22151. -    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,    43,
  22152. -    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,
  22153. -    54,    55,    56,    -1,    58,    59,    -1,     1,    -1,    -1,
  22154. -     4,    65,     6,     7,    68,    -1,    -1,    -1,    12,    -1,
  22155. -    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,
  22156. -    84,    85,    86,    27,    -1,    29,    -1,    91,    -1,    33,
  22157. -    -1,    35,    36,    -1,    -1,    -1,    -1,    -1,    -1,    43,
  22158. -    -1,    45,    -1,   107,    -1,    -1,    -1,    -1,    52,    -1,
  22159. -    54,    55,    -1,    57,    -1,    -1,    -1,    61,    62,    63,
  22160. -    64,    65,    66,    67,    68,    69,    70,    71,    72,    73,
  22161. -    74,    75,    76,    77,    78,    79,    80,    81,    -1,    -1,
  22162. -    84,    85,    86,    -1,     1,    89,     3,     4,    92,     6,
  22163. -     7,     8,     9,    -1,    11,    12,    -1,    -1,    -1,    -1,
  22164. -    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,    -1,
  22165. -    27,    28,    29,    -1,    31,    -1,    33,    -1,    35,    36,
  22166. -    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,
  22167. -    47,    48,    49,    50,    51,    52,    -1,    54,    55,    56,
  22168. -    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,
  22169. -    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,
  22170. -    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,
  22171. -    -1,    -1,    -1,    -1,    91,    92,     1,    -1,     3,     4,
  22172. -    -1,     6,     7,     8,     9,    -1,    11,    12,    -1,   106,
  22173. -   107,    -1,    -1,    -1,    19,    -1,    -1,    -1,    -1,    -1,
  22174. -    -1,    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,
  22175. -    35,    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,
  22176. -    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,    54,
  22177. -    55,    56,    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,
  22178. -    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  22179. -    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,
  22180. -    85,    86,     1,    -1,     3,     4,    91,     6,     7,     8,
  22181. -     9,    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22182. -    19,   106,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,
  22183. -    29,    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,
  22184. -    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,
  22185. -    49,    50,    51,    52,    -1,    54,    55,    56,    -1,    -1,
  22186. -    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,
  22187. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,
  22188. -    -1,    -1,    -1,    -1,    -1,    84,    85,    86,     1,    -1,
  22189. -     3,     4,    91,     6,     7,     8,     9,    -1,    11,    12,
  22190. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,   106,   107,    -1,
  22191. -    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,    -1,
  22192. -    33,    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,
  22193. -    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,
  22194. -    -1,    54,    55,    56,    -1,    -1,    59,    -1,    -1,    -1,
  22195. -    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,
  22196. -    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,
  22197. -    -1,    84,    85,    86,    -1,    -1,    -1,    -1,    91,    92,
  22198. -     1,    -1,     3,     4,    -1,     6,     7,     8,     9,    -1,
  22199. -    11,    12,    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,
  22200. -    -1,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,
  22201. -    31,    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,
  22202. -    41,    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,
  22203. -    51,    52,    -1,    54,    55,    56,    -1,    -1,    59,    -1,
  22204. -    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,
  22205. -    -1,    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,
  22206. -    -1,    -1,    -1,    84,    85,    86,     1,    -1,     3,     4,
  22207. -    91,     6,     7,     8,     9,    -1,    11,    12,    -1,    -1,
  22208. -    -1,    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,
  22209. -    -1,    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,
  22210. -    35,    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,
  22211. -    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,    54,
  22212. -    55,    56,    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,
  22213. -    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  22214. -    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,
  22215. -    85,    86,     1,    -1,     3,     4,    91,     6,     7,     8,
  22216. -     9,    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22217. -    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,
  22218. -    29,    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,
  22219. -    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,
  22220. -    49,    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,
  22221. -    59,    60,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,
  22222. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,
  22223. -    -1,    -1,    -1,    -1,    -1,    84,    85,    86,     1,    -1,
  22224. -     3,     4,    91,     6,     7,     8,     9,    -1,    11,    12,
  22225. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,    -1,
  22226. -    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,    -1,
  22227. -    33,    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,
  22228. -    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,
  22229. -    -1,    54,    55,    56,    -1,    -1,    59,    -1,    -1,    -1,
  22230. -    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,
  22231. -    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,
  22232. -    -1,    84,    85,    86,     1,    -1,     3,     4,    91,     6,
  22233. -     7,     8,     9,    -1,    11,    12,    -1,    -1,    -1,    -1,
  22234. -    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,
  22235. -    27,    28,    29,    -1,    31,    -1,    33,    -1,    35,    36,
  22236. -    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,
  22237. -    47,    48,    49,    50,    51,    52,    -1,    54,    55,    -1,
  22238. -    -1,    58,    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,
  22239. -    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,
  22240. -    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,
  22241. -     1,    -1,     3,     4,    91,     6,     7,     8,     9,    -1,
  22242. -    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22243. -   107,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,
  22244. -    31,    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,
  22245. -    41,    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,
  22246. -    51,    52,    -1,    54,    55,    -1,    -1,    -1,    59,    -1,
  22247. -    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,
  22248. -    -1,    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,
  22249. -    -1,    -1,    -1,    84,    85,    86,     1,    -1,     3,     4,
  22250. -    91,     6,     7,     8,     9,    -1,    11,    12,    -1,    -1,
  22251. -    -1,    -1,    -1,    -1,   105,    -1,   107,    -1,    -1,    -1,
  22252. -    -1,    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,
  22253. -    35,    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,
  22254. -    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,    54,
  22255. -    55,    -1,    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,
  22256. -    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  22257. -    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,
  22258. -    85,    86,     1,    -1,     3,     4,    91,     6,     7,     8,
  22259. -     9,    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22260. -    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,
  22261. -    29,    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,
  22262. -    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,
  22263. -    49,    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,
  22264. -    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,
  22265. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,
  22266. -    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,
  22267. -     3,     4,    91,     6,     7,     8,     9,    -1,    11,    12,
  22268. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,    -1,
  22269. -    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,    -1,
  22270. -    33,    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,
  22271. -    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,
  22272. -    -1,    54,    55,    -1,    -1,    -1,    59,    -1,    -1,    -1,
  22273. -    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,
  22274. -    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,
  22275. -    -1,    84,    85,    86,    -1,    -1,    -1,    -1,    91,    -1,
  22276. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22277. -    -1,    -1,    -1,    -1,   107,   108,     3,     4,     5,     6,
  22278. -     7,     8,     9,    -1,    11,    12,    13,    -1,    15,    16,
  22279. -    17,    18,    19,    20,    21,    22,    23,    24,    25,    26,
  22280. -    27,    28,    29,    30,    31,    -1,    33,    -1,    35,    36,
  22281. -    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,
  22282. -    47,    48,    49,    50,    51,    52,    -1,    54,    55,    56,
  22283. -    -1,    58,    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,
  22284. -    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,
  22285. -    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,
  22286. -    -1,    -1,    -1,    -1,    91,    -1,    93,    -1,    -1,    -1,
  22287. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   106,
  22288. -   107,     3,     4,     5,     6,     7,     8,     9,    -1,    11,
  22289. -    12,    13,    -1,    15,    16,    17,    18,    19,    20,    21,
  22290. -    22,    23,    24,    25,    26,    27,    28,    29,    30,    31,
  22291. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22292. -    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,
  22293. -    52,    -1,    54,    55,    56,    -1,    58,    59,    -1,    -1,
  22294. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22295. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22296. -    -1,    -1,    84,    85,    86,    -1,    -1,    -1,    -1,    91,
  22297. -    -1,    93,    -1,    -1,     3,     4,     5,     6,     7,     8,
  22298. -     9,    -1,    11,    12,    13,   107,    15,    16,    17,    18,
  22299. -    19,    20,    21,    22,    23,    24,    25,    26,    27,    28,
  22300. -    29,    30,    31,    -1,    33,    -1,    35,    36,    -1,    38,
  22301. -    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,
  22302. -    49,    50,    51,    52,    -1,    54,    55,    56,    -1,    58,
  22303. -    59,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,
  22304. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,
  22305. -    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,
  22306. -    -1,    -1,    91,    -1,    93,    -1,    -1,     3,     4,     5,
  22307. -     6,     7,     8,     9,    -1,    11,    12,    13,   107,    15,
  22308. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  22309. -    26,    27,    28,    29,    30,    31,    -1,    33,    -1,    35,
  22310. -    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,
  22311. -    -1,    47,    48,    49,    50,    51,    52,    -1,    54,    55,
  22312. -    -1,    -1,    58,    59,    -1,    -1,    -1,    -1,    -1,    65,
  22313. -    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22314. -    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,
  22315. -    86,    -1,    -1,    -1,    -1,    91,    -1,    93,     3,     4,
  22316. -     5,     6,     7,     8,     9,    10,    11,    12,    -1,    -1,
  22317. -    -1,   107,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22318. -    -1,    -1,    27,    28,    29,    30,    31,    -1,    33,    -1,
  22319. -    35,    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,
  22320. -    45,    -1,    47,    48,    49,    50,    51,    52,    -1,    54,
  22321. -    55,    -1,    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,
  22322. -    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,
  22323. -    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,
  22324. -    85,    86,    -1,    88,    -1,    -1,    91,    92,    -1,    -1,
  22325. -    95,     3,     4,     5,     6,     7,     8,     9,    10,    11,
  22326. -    12,    -1,   107,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22327. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    30,    31,
  22328. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22329. -    -1,    43,    -1,    45,    -1,    47,    48,    49,    50,    51,
  22330. -    52,    -1,    54,    55,    -1,    -1,    -1,    59,    -1,    -1,
  22331. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22332. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22333. -    -1,    -1,    84,    85,    86,    -1,    88,    -1,    -1,    91,
  22334. -    92,     3,     4,    95,     6,     7,     8,     9,    -1,    11,
  22335. -    12,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22336. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22337. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22338. -    -1,    43,    -1,    45,    -1,    47,    48,    49,    50,    51,
  22339. -    52,    -1,    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,
  22340. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22341. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22342. -    -1,    -1,    84,    85,    86,    -1,    88,    -1,    -1,    91,
  22343. -    92,     3,     4,    -1,     6,     7,     8,     9,    -1,    11,
  22344. -    12,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22345. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22346. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22347. -    -1,    43,    -1,    45,    -1,    47,    48,    49,    50,    51,
  22348. -    52,    -1,    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,
  22349. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22350. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22351. -    -1,    -1,    84,    85,    86,    -1,    88,    -1,    -1,    91,
  22352. -    92,     3,     4,    -1,     6,     7,     8,     9,    -1,    11,
  22353. -    12,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22354. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22355. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22356. -    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,
  22357. -    52,    -1,    54,    55,    -1,    -1,    -1,    59,    -1,    -1,
  22358. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22359. -    -1,    73,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22360. -    -1,    -1,    84,    85,    86,    -1,    -1,     3,     4,    91,
  22361. -     6,     7,     8,     9,    -1,    11,    12,    -1,    -1,    -1,
  22362. -    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22363. -    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,    35,
  22364. -    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,
  22365. -    -1,    47,    48,    49,    50,    51,    52,    -1,    54,    55,
  22366. -    -1,    -1,    58,    59,    -1,    -1,    -1,    -1,    -1,    65,
  22367. -    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22368. -    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,
  22369. -    86,    -1,    -1,     3,     4,    91,     6,     7,     8,     9,
  22370. -    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22371. -    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,
  22372. -    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,    39,
  22373. -    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,    49,
  22374. -    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,    59,
  22375. -    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,
  22376. -    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,    -1,
  22377. -    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,     3,
  22378. -     4,    91,     6,     7,     8,     9,    -1,    11,    12,    -1,
  22379. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,
  22380. -    -1,    -1,    -1,    27,    28,    29,    -1,    31,    -1,    33,
  22381. -    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,    43,
  22382. -    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,
  22383. -    54,    55,    -1,    -1,    -1,    59,    -1,    -1,    -1,    -1,
  22384. -    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,
  22385. -    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,
  22386. -    84,    85,    86,    -1,    -1,     3,     4,    91,     6,     7,
  22387. -     8,     9,    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,
  22388. -    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,
  22389. -    28,    29,    -1,    31,    -1,    33,    -1,    35,    36,    -1,
  22390. -    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,
  22391. -    48,    49,    50,    51,    52,    -1,    54,    55,    56,    -1,
  22392. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,
  22393. -    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,
  22394. -    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,
  22395. -    -1,     3,     4,    91,     6,     7,     8,     9,    -1,    11,
  22396. -    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,
  22397. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22398. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22399. -    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,
  22400. -    52,    -1,    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,
  22401. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22402. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22403. -    -1,    -1,    84,    85,    86,    -1,    -1,    -1,    -1,    91,
  22404. -    92,     3,     4,    -1,     6,     7,     8,     9,    -1,    11,
  22405. -    12,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22406. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22407. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22408. -    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,
  22409. -    52,    -1,    54,    55,    -1,    -1,    -1,    59,    -1,    -1,
  22410. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22411. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22412. -    -1,    -1,    84,    85,    86,    -1,    -1,     3,     4,    91,
  22413. -     6,     7,     8,     9,    -1,    11,    12,    -1,    -1,    -1,
  22414. -    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22415. -    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,    35,
  22416. -    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,
  22417. -    -1,    47,    48,    49,    50,    51,    52,    -1,    54,    55,
  22418. -    -1,    -1,    -1,    59,    -1,    -1,    -1,    -1,    -1,    65,
  22419. -    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22420. -    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,
  22421. -    86,    -1,    -1,     3,     4,    91,     6,     7,     8,     9,
  22422. -    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22423. -    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,
  22424. -    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,    39,
  22425. -    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,    49,
  22426. -    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,    59,
  22427. -    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,
  22428. -    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,    -1,
  22429. -    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,     3,
  22430. -     4,    91,     6,     7,     8,     9,    -1,    11,    12,    -1,
  22431. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,
  22432. -    -1,    -1,    -1,    27,    28,    29,    -1,    31,    -1,    33,
  22433. -    -1,    35,    36,    -1,    38,    39,    40,    41,    -1,    43,
  22434. -    -1,    -1,    -1,    47,    48,    49,    50,    51,    52,    -1,
  22435. -    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22436. -    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,
  22437. -    -1,    -1,    76,    77,    78,    -1,    -1,    -1,    -1,    -1,
  22438. -    84,    85,    86,    -1,    -1,     3,     4,    91,     6,     7,
  22439. -     8,     9,    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,
  22440. -    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,
  22441. -    28,    29,    -1,    31,    -1,    33,    -1,    35,    36,    -1,
  22442. -    38,    39,    40,    41,    -1,    43,    -1,    -1,    -1,    47,
  22443. -    48,    49,    50,    51,    52,    -1,    54,    55,    -1,    -1,
  22444. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,
  22445. -    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,
  22446. -    78,    -1,    -1,    -1,    -1,    -1,    84,    85,    86,    -1,
  22447. -    -1,     3,     4,    91,     6,     7,     8,     9,    -1,    11,
  22448. -    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,   107,
  22449. -    -1,    -1,    -1,    -1,    -1,    27,    28,    29,    -1,    31,
  22450. -    -1,    33,    -1,    35,    36,    -1,    38,    39,    40,    41,
  22451. -    -1,    43,    -1,    -1,    -1,    47,    48,    49,    50,    51,
  22452. -    52,    -1,    54,    55,    -1,    -1,    -1,    -1,    -1,    -1,
  22453. -    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,    -1,    -1,
  22454. -    -1,    -1,    -1,    -1,    76,    77,    78,    -1,    -1,    -1,
  22455. -    -1,    -1,    84,    85,    86,    -1,    -1,     3,     4,    91,
  22456. -     6,     7,     8,     9,    -1,    11,    12,    -1,    -1,    -1,
  22457. -    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,    -1,    -1,
  22458. -    -1,    27,    28,    29,    -1,    31,    -1,    33,    -1,    35,
  22459. -    36,    -1,    38,    39,    40,    41,    -1,    43,    -1,    -1,
  22460. -    -1,    47,    48,    49,    50,    51,    52,    -1,    54,    55,
  22461. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    65,
  22462. -    -1,    -1,    68,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22463. -    76,    77,    78,    -1,    -1,    -1,    -1,    -1,    84,    85,
  22464. -    86,    -1,    -1,     3,     4,    91,     6,     7,     8,     9,
  22465. -    -1,    11,    12,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22466. -    -1,   107,    -1,    -1,    -1,    -1,    -1,    27,    28,    29,
  22467. -    -1,    31,    -1,    33,    -1,    35,    36,    -1,    38,    39,
  22468. -    40,    41,    -1,    43,    -1,    -1,    -1,    47,    48,    49,
  22469. -    50,    51,    52,    -1,    54,    55,    -1,    -1,    -1,    -1,
  22470. -    -1,    -1,    -1,    -1,    -1,    65,    -1,    -1,    68,    -1,
  22471. -    -1,    -1,    -1,    -1,    -1,    -1,    76,    77,    78,    -1,
  22472. -    -1,    -1,    -1,    -1,    84,    85,    86,    -1,    -1,    -1,
  22473. -     1,    91,     3,     4,     5,     6,     7,    -1,    -1,    -1,
  22474. -    -1,    12,    -1,    -1,    -1,    -1,    -1,   107,    -1,    -1,
  22475. -    -1,    -1,    -1,    -1,    25,    26,    27,    -1,    29,    30,
  22476. -    -1,    -1,    33,    -1,    -1,    -1,    37,    -1,    39,    -1,
  22477. -    -1,    42,    43,    44,    -1,    46,    -1,    -1,    -1,    -1,
  22478. -    -1,    52,    -1,    54,    55,    -1,    -1,    58,    -1,    -1,
  22479. -     1,    -1,     3,     4,     5,     6,     7,    68,    -1,    -1,
  22480. -    -1,    12,    -1,    -1,    -1,    -1,    -1,    78,    -1,    -1,
  22481. -    -1,    -1,    -1,    -1,    -1,    86,    27,    -1,    29,    30,
  22482. -    91,    -1,    33,    -1,    -1,    96,    97,    -1,    39,    -1,
  22483. -    -1,    -1,    43,    -1,    -1,    46,    -1,    -1,    -1,    -1,
  22484. -    -1,    52,    -1,    54,    55,    -1,    -1,    58,    -1,    -1,
  22485. -    -1,    -1,     3,     4,     5,     6,     7,    68,    -1,    10,
  22486. -    -1,    12,    -1,    -1,    -1,    -1,    -1,    78,    -1,    -1,
  22487. -    -1,    -1,    -1,    -1,    -1,    86,    27,    -1,    29,    30,
  22488. -    91,    -1,    33,    -1,    -1,    96,    -1,    -1,    39,    -1,
  22489. -    -1,    -1,    43,    -1,    45,    -1,     3,     4,     5,     6,
  22490. -     7,    52,    -1,    54,    55,    12,    -1,    -1,    -1,    -1,
  22491. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    68,    -1,    -1,
  22492. -    27,    -1,    29,    30,    -1,    -1,    33,    78,    -1,    -1,
  22493. -    -1,    -1,    39,    -1,    -1,    86,    43,    88,    -1,    -1,
  22494. -    91,    92,    -1,    -1,    95,    52,    -1,    54,    55,    -1,
  22495. -    -1,    -1,    -1,    60,    -1,    -1,     3,     4,     5,     6,
  22496. -     7,    68,    -1,    10,    -1,    12,    -1,    -1,    -1,    -1,
  22497. -    -1,    78,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,
  22498. -    27,    -1,    29,    30,    91,    -1,    33,    -1,    -1,    -1,
  22499. -    -1,    -1,    39,    -1,    -1,    -1,    43,    -1,    -1,    -1,
  22500. -     3,     4,     5,     6,     7,    52,    -1,    54,    55,    12,
  22501. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  22502. -    -1,    68,    -1,    -1,    27,    -1,    29,    30,    -1,    -1,
  22503. -    33,    78,    -1,    -1,    -1,    -1,    39,    -1,    -1,    86,
  22504. -    43,    -1,    -1,    -1,    91,    -1,    -1,    -1,    -1,    52,
  22505. -    -1,    54,    55,    -1,    -1,    58,    -1,    -1,    -1,    -1,
  22506. -     3,     4,     5,     6,     7,    68,    -1,    -1,    -1,    12,
  22507. -    -1,    -1,    -1,    -1,    -1,    78,    -1,    -1,    -1,    -1,
  22508. -    -1,    -1,    -1,    86,    27,    -1,    29,    30,    91,    -1,
  22509. -    33,    -1,    -1,    -1,    -1,    -1,    39,    -1,    -1,    -1,
  22510. -    43,    -1,    -1,    -1,     3,     4,     5,     6,     7,    52,
  22511. -    -1,    54,    55,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22512. -    -1,    -1,    -1,    -1,    -1,    68,    -1,    -1,    27,    -1,
  22513. -    29,    30,    -1,    -1,    33,    78,    -1,    -1,    -1,    -1,
  22514. -    39,    -1,    -1,    86,    43,    -1,    -1,    -1,    91,    -1,
  22515. -    -1,    -1,    -1,    52,    -1,    54,    55,    -1,    -1,    -1,
  22516. -    -1,    -1,    30,    -1,    -1,    -1,    -1,    -1,    -1,    68,
  22517. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    78,
  22518. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    86,    -1,    -1,
  22519. -    -1,    -1,    91,    61,    62,    63,    64,    65,    66,    67,
  22520. -    68,    69,    70,    71,    72,    73,    74,    75,    76,    77,
  22521. -    78,    79,    80,    81,    82,     4,     5,     6,     7,    -1,
  22522. -    -1,    -1,    -1,    12,    -1,    -1,    -1,    -1,    -1,    -1,
  22523. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    27,    -1,
  22524. -    29,    30,    -1,    -1,    33,    -1,    -1,    -1,    -1,    -1,
  22525. -    -1,    -1,    -1,    -1,    43,    -1,    -1,    -1,    -1,    -1,
  22526. -    -1,    -1,    -1,    52,    -1,    54,    55,    61,    62,    63,
  22527. -    64,    65,    66,    67,    68,    69,    70,    71,    72,    73,
  22528. -    74,    75,    76,    77,    78,    79,    80,    81,    82,    61,
  22529. -    62,    63,    64,    65,    66,    67,    68,    69,    70,    71,
  22530. -    72,    73,    74,    75,    76,    77,    78,    79,    80,    81,
  22531. -    82,    57,    -1,    -1,   108,    61,    62,    63,    64,    65,
  22532. -    66,    67,    68,    69,    70,    71,    72,    73,    74,    75,
  22533. -    76,    77,    78,    79,    80,    81,    82,    60,    61,    62,
  22534. -    63,    64,    65,    66,    67,    68,    69,    70,    71,    72,
  22535. -    73,    74,    75,    76,    77,    78,    79,    80,    81,    82,
  22536. -    60,    61,    62,    63,    64,    65,    66,    67,    68,    69,
  22537. -    70,    71,    72,    73,    74,    75,    76,    77,    78,    79,
  22538. -    80,    81,    82,    61,    62,    63,    64,    65,    66,    67,
  22539. -    68,    69,    70,    71,    72,    -1,    74,    75,    76,    77,
  22540. -    78,    79,    80,    81,    82,    65,    66,    67,    68,    69,
  22541. -    70,    71,    72,    73,    74,    75,    76,    77,    78,    79,
  22542. -    80,    81,    82
  22543. -};
  22544. -/* -*-C-*-  Note some compilers choke on comments on `#line' lines.  */
  22545. -#line 3 "/usr/local/lib/bison.simple"
  22546. -
  22547. -/* Skeleton output parser for bison,
  22548. -   Copyright (C) 1984, 1989, 1990 Bob Corbett and Richard Stallman
  22549. -
  22550. -   This program is free software; you can redistribute it and/or modify
  22551. -   it under the terms of the GNU General Public License as published by
  22552. -   the Free Software Foundation; either version 1, or (at your option)
  22553. -   any later version.
  22554. -
  22555. -   This program is distributed in the hope that it will be useful,
  22556. -   but WITHOUT ANY WARRANTY; without even the implied warranty of
  22557. -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  22558. -   GNU General Public License for more details.
  22559. -
  22560. -   You should have received a copy of the GNU General Public License
  22561. -   along with this program; if not, write to the Free Software
  22562. -   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  22563. -
  22564. -
  22565. -#ifndef alloca
  22566. -#ifdef __GNUC__
  22567. -#define alloca __builtin_alloca
  22568. -#else /* not GNU C.  */
  22569. -#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi)
  22570. -#include <alloca.h>
  22571. -#else /* not sparc */
  22572. -#if defined (MSDOS) && !defined (__TURBOC__)
  22573. -#include <malloc.h>
  22574. -#else /* not MSDOS, or __TURBOC__ */
  22575. -#if defined(_AIX)
  22576. -#include <malloc.h>
  22577. - #pragma alloca
  22578. -#else /* not MSDOS, __TURBOC__, or _AIX */
  22579. -#ifdef __hpux
  22580. -#ifdef __cplusplus
  22581. -extern "C" {
  22582. -void *alloca (unsigned int);
  22583. -};
  22584. -#else /* not __cplusplus */
  22585. -void *alloca ();
  22586. -#endif /* not __cplusplus */
  22587. -#endif /* __hpux */
  22588. -#endif /* not _AIX */
  22589. -#endif /* not MSDOS, or __TURBOC__ */
  22590. -#endif /* not sparc.  */
  22591. -#endif /* not GNU C.  */
  22592. -#endif /* alloca not defined.  */
  22593. -
  22594. -/* This is the parser code that is written into each bison parser
  22595. -  when the %semantic_parser declaration is not specified in the grammar.
  22596. -  It was written by Richard Stallman by simplifying the hairy parser
  22597. -  used when %semantic_parser is specified.  */
  22598. -
  22599. -/* Note: there must be only one dollar sign in this file.
  22600. -   It is replaced by the list of actions, each action
  22601. -   as one case of the switch.  */
  22602. -
  22603. -#define yyerrok        (yyerrstatus = 0)
  22604. -#define yyclearin    (yychar = YYEMPTY)
  22605. -#define YYEMPTY        -2
  22606. -#define YYEOF        0
  22607. -#define YYACCEPT    return(0)
  22608. -#define YYABORT     return(1)
  22609. -#define YYERROR        goto yyerrlab1
  22610. -/* Like YYERROR except do call yyerror.
  22611. -   This remains here temporarily to ease the
  22612. -   transition to the new meaning of YYERROR, for GCC.
  22613. -   Once GCC version 2 has supplanted version 1, this can go.  */
  22614. -#define YYFAIL        goto yyerrlab
  22615. -#define YYRECOVERING()  (!!yyerrstatus)
  22616. -#define YYBACKUP(token, value) \
  22617. -do                                \
  22618. -  if (yychar == YYEMPTY && yylen == 1)                \
  22619. -    { yychar = (token), yylval = (value);            \
  22620. -      yychar1 = YYTRANSLATE (yychar);                \
  22621. -      YYPOPSTACK;                        \
  22622. -      goto yybackup;                        \
  22623. -    }                                \
  22624. -  else                                \
  22625. -    { yyerror ("syntax error: cannot back up"); YYERROR; }    \
  22626. -while (0)
  22627. -
  22628. -#define YYTERROR    1
  22629. -#define YYERRCODE    256
  22630. -
  22631. -#ifndef YYPURE
  22632. -#define YYLEX        yylex()
  22633. -#endif
  22634. -
  22635. -#ifdef YYPURE
  22636. -#ifdef YYLSP_NEEDED
  22637. -#define YYLEX        yylex(&yylval, &yylloc)
  22638. -#else
  22639. -#define YYLEX        yylex(&yylval)
  22640. -#endif
  22641. -#endif
  22642. -
  22643. -/* If nonreentrant, generate the variables here */
  22644. -
  22645. -#ifndef YYPURE
  22646. -
  22647. -int    yychar;            /*  the lookahead symbol        */
  22648. -YYSTYPE    yylval;            /*  the semantic value of the        */
  22649. -                /*  lookahead symbol            */
  22650. -
  22651. -#ifdef YYLSP_NEEDED
  22652. -YYLTYPE yylloc;            /*  location data for the lookahead    */
  22653. -                /*  symbol                */
  22654. -#endif
  22655. -
  22656. -int yynerrs;            /*  number of parse errors so far       */
  22657. -#endif  /* not YYPURE */
  22658. -
  22659. -#if YYDEBUG != 0
  22660. -int yydebug;            /*  nonzero means print parse trace    */
  22661. -/* Since this is uninitialized, it does not stop multiple parsers
  22662. -   from coexisting.  */
  22663. -#endif
  22664. -
  22665. -/*  YYINITDEPTH indicates the initial size of the parser's stacks    */
  22666. -
  22667. -#ifndef    YYINITDEPTH
  22668. -#define YYINITDEPTH 200
  22669. -#endif
  22670. -
  22671. -/*  YYMAXDEPTH is the maximum size the stacks can grow to
  22672. -    (effective only if the built-in stack extension method is used).  */
  22673. -
  22674. -#if YYMAXDEPTH == 0
  22675. -#undef YYMAXDEPTH
  22676. -#endif
  22677. -
  22678. -#ifndef YYMAXDEPTH
  22679. -#define YYMAXDEPTH 10000
  22680. -#endif
  22681. -
  22682. -/* Prevent warning if -Wstrict-prototypes.  */
  22683. -#ifdef __GNUC__
  22684. -int yyparse (void);
  22685. -#endif
  22686. -
  22687. -#if __GNUC__ > 1        /* GNU C and GNU C++ define this.  */
  22688. -#define __yy_bcopy(FROM,TO,COUNT)    __builtin_memcpy(TO,FROM,COUNT)
  22689. -#else                /* not GNU C or C++ */
  22690. -#ifndef __cplusplus
  22691. -
  22692. -/* This is the most reliable way to avoid incompatibilities
  22693. -   in available built-in functions on various systems.  */
  22694. -static void
  22695. -__yy_bcopy (from, to, count)
  22696. -     char *from;
  22697. -     char *to;
  22698. -     int count;
  22699. -{
  22700. -  register char *f = from;
  22701. -  register char *t = to;
  22702. -  register int i = count;
  22703. -
  22704. -  while (i-- > 0)
  22705. -    *t++ = *f++;
  22706. -}
  22707. -
  22708. -#else /* __cplusplus */
  22709. -
  22710. -/* This is the most reliable way to avoid incompatibilities
  22711. -   in available built-in functions on various systems.  */
  22712. -static void
  22713. -__yy_bcopy (char *from, char *to, int count)
  22714. -{
  22715. -  register char *f = from;
  22716. -  register char *t = to;
  22717. -  register int i = count;
  22718. -
  22719. -  while (i-- > 0)
  22720. -    *t++ = *f++;
  22721. -}
  22722. -
  22723. -#endif
  22724. -#endif
  22725. -
  22726. -#line 184 "/usr/local/lib/bison.simple"
  22727. -
  22728. -/* The user can define YYPARSE_PARAM as the name of an argument to be passed
  22729. -   into yyparse.  The argument should have type void *.
  22730. -   It should actually point to an object.
  22731. -   Grammar actions can access the variable by casting it
  22732. -   to the proper pointer type.  */
  22733. -
  22734. -#ifdef YYPARSE_PARAM
  22735. -#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;
  22736. -#else
  22737. -#define YYPARSE_PARAM
  22738. -#define YYPARSE_PARAM_DECL
  22739. -#endif
  22740. -
  22741. -int
  22742. -yyparse(YYPARSE_PARAM)
  22743. -     YYPARSE_PARAM_DECL
  22744. -{
  22745. -  register int yystate;
  22746. -  register int yyn;
  22747. -  register short *yyssp;
  22748. -  register YYSTYPE *yyvsp;
  22749. -  int yyerrstatus;    /*  number of tokens to shift before error messages enabled */
  22750. -  int yychar1 = 0;        /*  lookahead token as an internal (translated) token number */
  22751. -
  22752. -  short    yyssa[YYINITDEPTH];    /*  the state stack            */
  22753. -  YYSTYPE yyvsa[YYINITDEPTH];    /*  the semantic value stack        */
  22754. -
  22755. -  short *yyss = yyssa;        /*  refer to the stacks thru separate pointers */
  22756. -  YYSTYPE *yyvs = yyvsa;    /*  to allow yyoverflow to reallocate them elsewhere */
  22757. -
  22758. -#ifdef YYLSP_NEEDED
  22759. -  YYLTYPE yylsa[YYINITDEPTH];    /*  the location stack            */
  22760. -  YYLTYPE *yyls = yylsa;
  22761. -  YYLTYPE *yylsp;
  22762. -
  22763. -#define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--)
  22764. -#else
  22765. -#define YYPOPSTACK   (yyvsp--, yyssp--)
  22766. -#endif
  22767. -
  22768. -  int yystacksize = YYINITDEPTH;
  22769. -
  22770. -#ifdef YYPURE
  22771. -  int yychar;
  22772. -  YYSTYPE yylval;
  22773. -  int yynerrs;
  22774. -#ifdef YYLSP_NEEDED
  22775. -  YYLTYPE yylloc;
  22776. -#endif
  22777. -#endif
  22778. -
  22779. -  YYSTYPE yyval;        /*  the variable used to return        */
  22780. -                /*  semantic values from the action    */
  22781. -                /*  routines                */
  22782. -
  22783. -  int yylen;
  22784. -
  22785. -#if YYDEBUG != 0
  22786. -  if (yydebug)
  22787. -    fprintf(stderr, "Starting parse\n");
  22788. -#endif
  22789. -
  22790. -  yystate = 0;
  22791. -  yyerrstatus = 0;
  22792. -  yynerrs = 0;
  22793. -  yychar = YYEMPTY;        /* Cause a token to be read.  */
  22794. -
  22795. -  /* Initialize stack pointers.
  22796. -     Waste one element of value and location stack
  22797. -     so that they stay on the same level as the state stack.
  22798. -     The wasted elements are never initialized.  */
  22799. -
  22800. -  yyssp = yyss - 1;
  22801. -  yyvsp = yyvs;
  22802. -#ifdef YYLSP_NEEDED
  22803. -  yylsp = yyls;
  22804. -#endif
  22805. -
  22806. -/* Push a new state, which is found in  yystate  .  */
  22807. -/* In all cases, when you get here, the value and location stacks
  22808. -   have just been pushed. so pushing a state here evens the stacks.  */
  22809. -yynewstate:
  22810. -
  22811. -  *++yyssp = yystate;
  22812. -
  22813. -  if (yyssp >= yyss + yystacksize - 1)
  22814. -    {
  22815. -      /* Give user a chance to reallocate the stack */
  22816. -      /* Use copies of these so that the &'s don't force the real ones into memory. */
  22817. -      YYSTYPE *yyvs1 = yyvs;
  22818. -      short *yyss1 = yyss;
  22819. -#ifdef YYLSP_NEEDED
  22820. -      YYLTYPE *yyls1 = yyls;
  22821. -#endif
  22822. -
  22823. -      /* Get the current used size of the three stacks, in elements.  */
  22824. -      int size = yyssp - yyss + 1;
  22825. -
  22826. -#ifdef yyoverflow
  22827. -      /* Each stack pointer address is followed by the size of
  22828. -     the data in use in that stack, in bytes.  */
  22829. -#ifdef YYLSP_NEEDED
  22830. -      /* This used to be a conditional around just the two extra args,
  22831. -     but that might be undefined if yyoverflow is a macro.  */
  22832. -      yyoverflow("parser stack overflow",
  22833. -         &yyss1, size * sizeof (*yyssp),
  22834. -         &yyvs1, size * sizeof (*yyvsp),
  22835. -         &yyls1, size * sizeof (*yylsp),
  22836. -         &yystacksize);
  22837. -#else
  22838. -      yyoverflow("parser stack overflow",
  22839. -         &yyss1, size * sizeof (*yyssp),
  22840. -         &yyvs1, size * sizeof (*yyvsp),
  22841. -         &yystacksize);
  22842. -#endif
  22843. -
  22844. -      yyss = yyss1; yyvs = yyvs1;
  22845. -#ifdef YYLSP_NEEDED
  22846. -      yyls = yyls1;
  22847. -#endif
  22848. -#else /* no yyoverflow */
  22849. -      /* Extend the stack our own way.  */
  22850. -      if (yystacksize >= YYMAXDEPTH)
  22851. -    {
  22852. -      yyerror("parser stack overflow");
  22853. -      return 2;
  22854. -    }
  22855. -      yystacksize *= 2;
  22856. -      if (yystacksize > YYMAXDEPTH)
  22857. -    yystacksize = YYMAXDEPTH;
  22858. -      yyss = (short *) alloca (yystacksize * sizeof (*yyssp));
  22859. -      __yy_bcopy ((char *)yyss1, (char *)yyss, size * sizeof (*yyssp));
  22860. -      yyvs = (YYSTYPE *) alloca (yystacksize * sizeof (*yyvsp));
  22861. -      __yy_bcopy ((char *)yyvs1, (char *)yyvs, size * sizeof (*yyvsp));
  22862. -#ifdef YYLSP_NEEDED
  22863. -      yyls = (YYLTYPE *) alloca (yystacksize * sizeof (*yylsp));
  22864. -      __yy_bcopy ((char *)yyls1, (char *)yyls, size * sizeof (*yylsp));
  22865. -#endif
  22866. -#endif /* no yyoverflow */
  22867. -
  22868. -      yyssp = yyss + size - 1;
  22869. -      yyvsp = yyvs + size - 1;
  22870. -#ifdef YYLSP_NEEDED
  22871. -      yylsp = yyls + size - 1;
  22872. -#endif
  22873. -
  22874. -#if YYDEBUG != 0
  22875. -      if (yydebug)
  22876. -    fprintf(stderr, "Stack size increased to %d\n", yystacksize);
  22877. -#endif
  22878. -
  22879. -      if (yyssp >= yyss + yystacksize - 1)
  22880. -    YYABORT;
  22881. -    }
  22882. -
  22883. -#if YYDEBUG != 0
  22884. -  if (yydebug)
  22885. -    fprintf(stderr, "Entering state %d\n", yystate);
  22886. -#endif
  22887. -
  22888. -  goto yybackup;
  22889. - yybackup:
  22890. -
  22891. -/* Do appropriate processing given the current state.  */
  22892. -/* Read a lookahead token if we need one and don't already have one.  */
  22893. -/* yyresume: */
  22894. -
  22895. -  /* First try to decide what to do without reference to lookahead token.  */
  22896. -
  22897. -  yyn = yypact[yystate];
  22898. -  if (yyn == YYFLAG)
  22899. -    goto yydefault;
  22900. -
  22901. -  /* Not known => get a lookahead token if don't already have one.  */
  22902. -
  22903. -  /* yychar is either YYEMPTY or YYEOF
  22904. -     or a valid token in external form.  */
  22905. -
  22906. -  if (yychar == YYEMPTY)
  22907. -    {
  22908. -#if YYDEBUG != 0
  22909. -      if (yydebug)
  22910. -    fprintf(stderr, "Reading a token: ");
  22911. -#endif
  22912. -      yychar = YYLEX;
  22913. -    }
  22914. -
  22915. -  /* Convert token to internal form (in yychar1) for indexing tables with */
  22916. -
  22917. -  if (yychar <= 0)        /* This means end of input. */
  22918. -    {
  22919. -      yychar1 = 0;
  22920. -      yychar = YYEOF;        /* Don't call YYLEX any more */
  22921. -
  22922. -#if YYDEBUG != 0
  22923. -      if (yydebug)
  22924. -    fprintf(stderr, "Now at end of input.\n");
  22925. -#endif
  22926. -    }
  22927. -  else
  22928. -    {
  22929. -      yychar1 = YYTRANSLATE(yychar);
  22930. -
  22931. -#if YYDEBUG != 0
  22932. -      if (yydebug)
  22933. -    {
  22934. -      fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]);
  22935. -      /* Give the individual parser a way to print the precise meaning
  22936. -         of a token, for further debugging info.  */
  22937. -#ifdef YYPRINT
  22938. -      YYPRINT (stderr, yychar, yylval);
  22939. -#endif
  22940. -      fprintf (stderr, ")\n");
  22941. -    }
  22942. -#endif
  22943. -    }
  22944. -
  22945. -  yyn += yychar1;
  22946. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1)
  22947. -    goto yydefault;
  22948. -
  22949. -  yyn = yytable[yyn];
  22950. -
  22951. -  /* yyn is what to do for this token type in this state.
  22952. -     Negative => reduce, -yyn is rule number.
  22953. -     Positive => shift, yyn is new state.
  22954. -       New state is final state => don't bother to shift,
  22955. -       just return success.
  22956. -     0, or most negative number => error.  */
  22957. -
  22958. -  if (yyn < 0)
  22959. -    {
  22960. -      if (yyn == YYFLAG)
  22961. -    goto yyerrlab;
  22962. -      yyn = -yyn;
  22963. -      goto yyreduce;
  22964. -    }
  22965. -  else if (yyn == 0)
  22966. -    goto yyerrlab;
  22967. -
  22968. -  if (yyn == YYFINAL)
  22969. -    YYACCEPT;
  22970. -
  22971. -  /* Shift the lookahead token.  */
  22972. -
  22973. -#if YYDEBUG != 0
  22974. -  if (yydebug)
  22975. -    fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]);
  22976. -#endif
  22977. -
  22978. -  /* Discard the token being shifted unless it is eof.  */
  22979. -  if (yychar != YYEOF)
  22980. -    yychar = YYEMPTY;
  22981. -
  22982. -  *++yyvsp = yylval;
  22983. -#ifdef YYLSP_NEEDED
  22984. -  *++yylsp = yylloc;
  22985. -#endif
  22986. -
  22987. -  /* count tokens shifted since error; after three, turn off error status.  */
  22988. -  if (yyerrstatus) yyerrstatus--;
  22989. -
  22990. -  yystate = yyn;
  22991. -  goto yynewstate;
  22992. -
  22993. -/* Do the default action for the current state.  */
  22994. -yydefault:
  22995. -
  22996. -  yyn = yydefact[yystate];
  22997. -  if (yyn == 0)
  22998. -    goto yyerrlab;
  22999. -
  23000. -/* Do a reduction.  yyn is the number of a rule to reduce with.  */
  23001. -yyreduce:
  23002. -  yylen = yyr2[yyn];
  23003. -  if (yylen > 0)
  23004. -    yyval = yyvsp[1-yylen]; /* implement default value of the action */
  23005. -
  23006. -#if YYDEBUG != 0
  23007. -  if (yydebug)
  23008. -    {
  23009. -      int i;
  23010. -
  23011. -      fprintf (stderr, "Reducing via rule %d (line %d), ",
  23012. -           yyn, yyrline[yyn]);
  23013. -
  23014. -      /* Print the symbols being reduced, and their result.  */
  23015. -      for (i = yyprhs[yyn]; yyrhs[i] > 0; i++)
  23016. -    fprintf (stderr, "%s ", yytname[yyrhs[i]]);
  23017. -      fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]);
  23018. -    }
  23019. -#endif
  23020. -
  23021. -
  23022. -  switch (yyn) {
  23023. -
  23024. -case 2:
  23025. -#line 301 "parse.y"
  23026. -{
  23027. -          /* In case there were missing closebraces,
  23028. -             get us back to the global binding level.  */
  23029. -          while (! global_bindings_p ())
  23030. -            poplevel (0, 0, 0);
  23031. -          finish_file ();
  23032. -        ;
  23033. -    break;}
  23034. -case 3:
  23035. -#line 315 "parse.y"
  23036. -{ yyval.ttype = NULL_TREE; ;
  23037. -    break;}
  23038. -case 4:
  23039. -#line 316 "parse.y"
  23040. -{ yyval.ttype = NULL_TREE; ;
  23041. -    break;}
  23042. -case 5:
  23043. -#line 318 "parse.y"
  23044. -{ yyval.ttype = NULL_TREE; ;
  23045. -    break;}
  23046. -case 8:
  23047. -#line 327 "parse.y"
  23048. -{ have_extern_spec = 1;
  23049. -          used_extern_spec = 0;
  23050. -          yyval.ttype = NULL_TREE; ;
  23051. -    break;}
  23052. -case 9:
  23053. -#line 332 "parse.y"
  23054. -{ have_extern_spec = 0; ;
  23055. -    break;}
  23056. -case 12:
  23057. -#line 341 "parse.y"
  23058. -{ if (pending_lang_change) do_pending_lang_change(); ;
  23059. -    break;}
  23060. -case 13:
  23061. -#line 343 "parse.y"
  23062. -{ if (! toplevel_bindings_p () && ! pseudo_global_level_p())
  23063. -          pop_everything (); ;
  23064. -    break;}
  23065. -case 14:
  23066. -#line 349 "parse.y"
  23067. -{ if (pending_inlines) do_pending_inlines (); ;
  23068. -    break;}
  23069. -case 15:
  23070. -#line 351 "parse.y"
  23071. -{ if (pending_inlines) do_pending_inlines (); ;
  23072. -    break;}
  23073. -case 16:
  23074. -#line 353 "parse.y"
  23075. -{ if (pending_inlines) do_pending_inlines (); ;
  23076. -    break;}
  23077. -case 18:
  23078. -#line 356 "parse.y"
  23079. -{ if (TREE_CHAIN (yyvsp[-2].ttype)) yyvsp[-2].ttype = combine_strings (yyvsp[-2].ttype);
  23080. -          assemble_asm (yyvsp[-2].ttype); ;
  23081. -    break;}
  23082. -case 19:
  23083. -#line 359 "parse.y"
  23084. -{ pop_lang_context (); ;
  23085. -    break;}
  23086. -case 20:
  23087. -#line 361 "parse.y"
  23088. -{ if (pending_inlines) do_pending_inlines ();
  23089. -          pop_lang_context (); ;
  23090. -    break;}
  23091. -case 21:
  23092. -#line 364 "parse.y"
  23093. -{ if (pending_inlines) do_pending_inlines ();
  23094. -          pop_lang_context (); ;
  23095. -    break;}
  23096. -case 22:
  23097. -#line 367 "parse.y"
  23098. -{ push_namespace (yyvsp[-1].ttype); ;
  23099. -    break;}
  23100. -case 23:
  23101. -#line 369 "parse.y"
  23102. -{ pop_namespace (); ;
  23103. -    break;}
  23104. -case 24:
  23105. -#line 371 "parse.y"
  23106. -{ push_namespace (NULL_TREE); ;
  23107. -    break;}
  23108. -case 25:
  23109. -#line 373 "parse.y"
  23110. -{ pop_namespace (); ;
  23111. -    break;}
  23112. -case 26:
  23113. -#line 375 "parse.y"
  23114. -{ do_namespace_alias (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  23115. -    break;}
  23116. -case 27:
  23117. -#line 377 "parse.y"
  23118. -{ do_toplevel_using_decl (yyvsp[-1].ttype); ;
  23119. -    break;}
  23120. -case 28:
  23121. -#line 379 "parse.y"
  23122. -{ do_using_directive (yyvsp[-1].ttype); ;
  23123. -    break;}
  23124. -case 29:
  23125. -#line 384 "parse.y"
  23126. -{ yyval.ttype = yyvsp[0].ttype; ;
  23127. -    break;}
  23128. -case 30:
  23129. -#line 386 "parse.y"
  23130. -{ yyval.ttype = yyvsp[0].ttype; ;
  23131. -    break;}
  23132. -case 31:
  23133. -#line 388 "parse.y"
  23134. -{ yyval.ttype = yyvsp[0].ttype; ;
  23135. -    break;}
  23136. -case 34:
  23137. -#line 395 "parse.y"
  23138. -{ yyval.ttype = yyvsp[0].ttype; ;
  23139. -    break;}
  23140. -case 35:
  23141. -#line 397 "parse.y"
  23142. -{ yyval.ttype = yyvsp[0].ttype; ;
  23143. -    break;}
  23144. -case 36:
  23145. -#line 402 "parse.y"
  23146. -{ push_lang_context (yyvsp[0].ttype); ;
  23147. -    break;}
  23148. -case 37:
  23149. -#line 404 "parse.y"
  23150. -{ if (current_lang_name != yyvsp[0].ttype)
  23151. -            cp_error ("use of linkage spec `%D' is different from previous spec `%D'", yyvsp[0].ttype, current_lang_name);
  23152. -          pop_lang_context (); push_lang_context (yyvsp[0].ttype); ;
  23153. -    break;}
  23154. -case 38:
  23155. -#line 411 "parse.y"
  23156. -{ begin_template_parm_list (); ;
  23157. -    break;}
  23158. -case 39:
  23159. -#line 413 "parse.y"
  23160. -{ yyval.ttype = end_template_parm_list (yyvsp[-1].ttype); ;
  23161. -    break;}
  23162. -case 40:
  23163. -#line 418 "parse.y"
  23164. -{ yyval.ttype = process_template_parm (NULL_TREE, yyvsp[0].ttype); ;
  23165. -    break;}
  23166. -case 41:
  23167. -#line 420 "parse.y"
  23168. -{ yyval.ttype = process_template_parm (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  23169. -    break;}
  23170. -case 42:
  23171. -#line 425 "parse.y"
  23172. -{ 
  23173. -          yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE);
  23174. -         ttpa:
  23175. -          if (TREE_PURPOSE (yyval.ttype) == signature_type_node)
  23176. -            sorry ("signature as template type parameter");
  23177. -          else if (TREE_PURPOSE (yyval.ttype) != class_type_node)
  23178. -            pedwarn ("template type parameters must use the keyword `class'");
  23179. -        ;
  23180. -    break;}
  23181. -case 43:
  23182. -#line 434 "parse.y"
  23183. -{ yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); goto ttpa; ;
  23184. -    break;}
  23185. -case 44:
  23186. -#line 436 "parse.y"
  23187. -{ yyval.ttype = build_tree_list (class_type_node, NULL_TREE); ;
  23188. -    break;}
  23189. -case 45:
  23190. -#line 438 "parse.y"
  23191. -{ yyval.ttype = build_tree_list (class_type_node, yyvsp[0].ttype); ;
  23192. -    break;}
  23193. -case 46:
  23194. -#line 450 "parse.y"
  23195. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  23196. -    break;}
  23197. -case 47:
  23198. -#line 452 "parse.y"
  23199. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, yyval.ttype); ;
  23200. -    break;}
  23201. -case 49:
  23202. -#line 458 "parse.y"
  23203. -{ warning ("use of `overload' is an anachronism"); ;
  23204. -    break;}
  23205. -case 50:
  23206. -#line 462 "parse.y"
  23207. -{ declare_overloaded (yyvsp[0].ttype); ;
  23208. -    break;}
  23209. -case 51:
  23210. -#line 464 "parse.y"
  23211. -{ declare_overloaded (yyvsp[0].ttype); ;
  23212. -    break;}
  23213. -case 52:
  23214. -#line 471 "parse.y"
  23215. -{ yychar = '{'; goto template1; ;
  23216. -    break;}
  23217. -case 54:
  23218. -#line 474 "parse.y"
  23219. -{ yychar = '{'; goto template1; ;
  23220. -    break;}
  23221. -case 56:
  23222. -#line 477 "parse.y"
  23223. -{ yychar = ':'; goto template1; ;
  23224. -    break;}
  23225. -case 58:
  23226. -#line 480 "parse.y"
  23227. -{
  23228. -          yychar = ':';
  23229. -        template1:
  23230. -          if (current_aggr == signature_type_node)
  23231. -            sorry ("template type defining a signature");
  23232. -          /* Maybe pedantic warning for union?
  23233. -             How about an enum? :-)  */
  23234. -          end_template_decl (yyvsp[-2].ttype, yyvsp[-1].ttype, current_aggr, 1);
  23235. -          reinit_parse_for_template (yychar, yyvsp[-2].ttype, yyvsp[-1].ttype);
  23236. -          yychar = YYEMPTY;
  23237. -        ;
  23238. -    break;}
  23239. -case 60:
  23240. -#line 493 "parse.y"
  23241. -{
  23242. -          end_template_decl (yyvsp[-2].ttype, yyvsp[-1].ttype, current_aggr, 0);
  23243. -          /* declare $2 as template name with $1 parm list */
  23244. -        ;
  23245. -    break;}
  23246. -case 61:
  23247. -#line 498 "parse.y"
  23248. -{
  23249. -          end_template_decl (yyvsp[-2].ttype, yyvsp[-1].ttype, current_aggr, 0);
  23250. -          /* declare $2 as template name with $1 parm list */
  23251. -        ;
  23252. -    break;}
  23253. -case 62:
  23254. -#line 505 "parse.y"
  23255. -{
  23256. -          tree d;
  23257. -          int momentary;
  23258. -          int def = (yyvsp[0].itype != ';');
  23259. -          momentary = suspend_momentary ();
  23260. -          d = start_decl (yyvsp[-4].ttype, /*current_declspecs*/NULL_TREE, 0,
  23261. -                  yyvsp[-3].ttype);
  23262. -          cplus_decl_attributes (d, yyvsp[-1].ttype, /*prefix_attributes*/NULL_TREE);
  23263. -          cp_finish_decl (d, NULL_TREE, yyvsp[-2].ttype, 0, 0);
  23264. -          end_template_decl (yyvsp[-5].ttype, d, 0, def);
  23265. -          if (def)
  23266. -            reinit_parse_for_template ((int) yyvsp[0].itype, yyvsp[-5].ttype, d);
  23267. -          resume_momentary (momentary);
  23268. -        ;
  23269. -    break;}
  23270. -case 63:
  23271. -#line 522 "parse.y"
  23272. -{
  23273. -          tree d, specs, attrs;
  23274. -          int momentary;
  23275. -          int def = (yyvsp[0].itype != ';');
  23276. -          split_specs_attrs (yyvsp[-5].ttype, &specs, &attrs);
  23277. -          momentary = suspend_momentary ();
  23278. -          d = start_decl (yyvsp[-4].ttype, specs, 0, yyvsp[-3].ttype);
  23279. -          cplus_decl_attributes (d, yyvsp[-1].ttype, attrs);
  23280. -          cp_finish_decl (d, NULL_TREE, yyvsp[-2].ttype, 0, 0);
  23281. -          end_template_decl (yyvsp[-6].ttype, d, 0, def);
  23282. -          if (def)
  23283. -            {
  23284. -              reinit_parse_for_template ((int) yyvsp[0].itype, yyvsp[-6].ttype, d);
  23285. -              yychar = YYEMPTY;
  23286. -            }
  23287. -          note_list_got_semicolon (yyvsp[-5].ttype);
  23288. -          resume_momentary (momentary);
  23289. -        ;
  23290. -    break;}
  23291. -case 64:
  23292. -#line 541 "parse.y"
  23293. -{
  23294. -          tree d, specs, attrs;
  23295. -          int def = (yyvsp[0].itype != ';');
  23296. -          split_specs_attrs (yyvsp[-2].ttype, &specs, &attrs);
  23297. -          d = start_decl (yyvsp[-1].ttype, specs, 0, NULL_TREE);
  23298. -          cplus_decl_attributes (d, NULL_TREE, attrs);
  23299. -          cp_finish_decl (d, NULL_TREE, NULL_TREE, 0, 0);
  23300. -          end_template_decl (yyvsp[-3].ttype, d, 0, def);
  23301. -          if (def)
  23302. -            reinit_parse_for_template ((int) yyvsp[0].itype, yyvsp[-3].ttype, d);
  23303. -        ;
  23304. -    break;}
  23305. -case 65:
  23306. -#line 553 "parse.y"
  23307. -{ end_template_decl (yyvsp[-2].ttype, 0, 0, 0); ;
  23308. -    break;}
  23309. -case 66:
  23310. -#line 554 "parse.y"
  23311. -{ end_template_decl (yyvsp[-2].ttype, 0, 0, 0); ;
  23312. -    break;}
  23313. -case 67:
  23314. -#line 557 "parse.y"
  23315. -{ yyval.itype = '{'; ;
  23316. -    break;}
  23317. -case 68:
  23318. -#line 558 "parse.y"
  23319. -{ yyval.itype = ':'; ;
  23320. -    break;}
  23321. -case 69:
  23322. -#line 559 "parse.y"
  23323. -{ yyval.itype = ';'; ;
  23324. -    break;}
  23325. -case 70:
  23326. -#line 560 "parse.y"
  23327. -{ yyval.itype = '='; ;
  23328. -    break;}
  23329. -case 71:
  23330. -#line 561 "parse.y"
  23331. -{ yyval.itype = RETURN; ;
  23332. -    break;}
  23333. -case 72:
  23334. -#line 566 "parse.y"
  23335. -{;
  23336. -    break;}
  23337. -case 73:
  23338. -#line 568 "parse.y"
  23339. -{;
  23340. -    break;}
  23341. -case 74:
  23342. -#line 571 "parse.y"
  23343. -{ tree d, specs, attrs;
  23344. -          split_specs_attrs (yyvsp[-2].ttype, &specs, &attrs);
  23345. -          d = start_decl (yyvsp[-1].ttype, specs, 0, NULL_TREE);
  23346. -          cplus_decl_attributes (d, NULL_TREE, attrs);
  23347. -          cp_finish_decl (d, NULL_TREE, NULL_TREE, 0, 0);
  23348. -        ;
  23349. -    break;}
  23350. -case 75:
  23351. -#line 578 "parse.y"
  23352. -{
  23353. -          note_list_got_semicolon (yyval.ttype);
  23354. -        ;
  23355. -    break;}
  23356. -case 76:
  23357. -#line 583 "parse.y"
  23358. -{ tree d, specs, attrs;
  23359. -          split_specs_attrs (yyvsp[-2].ttype, &specs, &attrs);
  23360. -          d = start_decl (yyvsp[-1].ttype, specs, 0, NULL_TREE);
  23361. -          cplus_decl_attributes (d, NULL_TREE, attrs);
  23362. -          cp_finish_decl (d, NULL_TREE, NULL_TREE, 0, 0);
  23363. -          note_list_got_semicolon (yyval.ttype);
  23364. -        ;
  23365. -    break;}
  23366. -case 77:
  23367. -#line 591 "parse.y"
  23368. -{ pedwarn ("empty declaration"); ;
  23369. -    break;}
  23370. -case 79:
  23371. -#line 594 "parse.y"
  23372. -{
  23373. -        tree t, attrs;
  23374. -        split_specs_attrs (yyvsp[-1].ttype, &t, &attrs);
  23375. -        shadow_tag (t);
  23376. -        if (TREE_CODE (t) == TREE_LIST
  23377. -        && TREE_PURPOSE (t) == NULL_TREE)
  23378. -          {
  23379. -        t = TREE_VALUE (t);
  23380. -        if (IS_AGGR_TYPE (t)
  23381. -            && IDENTIFIER_TEMPLATE (TYPE_IDENTIFIER (t)))
  23382. -          {
  23383. -            if (CLASSTYPE_USE_TEMPLATE (t) == 0)
  23384. -              SET_CLASSTYPE_TEMPLATE_SPECIALIZATION (t);
  23385. -            else if (CLASSTYPE_TEMPLATE_INSTANTIATION (t))
  23386. -              error ("override declaration for already-expanded template");
  23387. -          }
  23388. -          }
  23389. -        note_list_got_semicolon (yyval.ttype);
  23390. -      ;
  23391. -    break;}
  23392. -case 83:
  23393. -#line 620 "parse.y"
  23394. -{ yyval.itype = 0; ;
  23395. -    break;}
  23396. -case 84:
  23397. -#line 622 "parse.y"
  23398. -{ yyval.itype = 1; ;
  23399. -    break;}
  23400. -case 90:
  23401. -#line 638 "parse.y"
  23402. -{
  23403. -          finish_function (lineno, (int)yyvsp[-1].itype, 0);
  23404. -          if (yyval.ttype) process_next_inline (yyval.ttype);
  23405. -        ;
  23406. -    break;}
  23407. -case 91:
  23408. -#line 643 "parse.y"
  23409. -{
  23410. -          if (yyval.ttype) process_next_inline (yyval.ttype);
  23411. -        ;
  23412. -    break;}
  23413. -case 93:
  23414. -#line 648 "parse.y"
  23415. -{;
  23416. -    break;}
  23417. -case 94:
  23418. -#line 650 "parse.y"
  23419. -{;
  23420. -    break;}
  23421. -case 95:
  23422. -#line 652 "parse.y"
  23423. -{;
  23424. -    break;}
  23425. -case 96:
  23426. -#line 657 "parse.y"
  23427. -{ tree specs, attrs;
  23428. -          split_specs_attrs (yyvsp[-2].ttype, &specs, &attrs);
  23429. -          if (! start_function (specs, yyvsp[-1].ttype, yyvsp[0].ttype, attrs, 0))
  23430. -            YYERROR1;
  23431. -          reinit_parse_for_function ();
  23432. -          yyval.ttype = NULL_TREE; ;
  23433. -    break;}
  23434. -case 97:
  23435. -#line 664 "parse.y"
  23436. -{ tree specs = strip_attrs (yyvsp[-2].ttype);
  23437. -          if (! start_function (specs, yyvsp[-1].ttype, yyvsp[0].ttype, NULL_TREE, 0))
  23438. -            YYERROR1;
  23439. -          reinit_parse_for_function ();
  23440. -          yyval.ttype = NULL_TREE; ;
  23441. -    break;}
  23442. -case 98:
  23443. -#line 670 "parse.y"
  23444. -{ if (! start_function (NULL_TREE, yyval.ttype, yyvsp[0].ttype, NULL_TREE, 0))
  23445. -            YYERROR1;
  23446. -          reinit_parse_for_function ();
  23447. -          yyval.ttype = NULL_TREE; ;
  23448. -    break;}
  23449. -case 99:
  23450. -#line 675 "parse.y"
  23451. -{ start_function (NULL_TREE, TREE_VALUE (yyval.ttype),
  23452. -                  NULL_TREE, NULL_TREE, 1);
  23453. -          reinit_parse_for_function (); ;
  23454. -    break;}
  23455. -case 100:
  23456. -#line 684 "parse.y"
  23457. -{ tree specs = strip_attrs (yyvsp[-5].ttype);
  23458. -          yyval.ttype = build_parse_node (CALL_EXPR, TREE_VALUE (specs), yyvsp[-3].ttype, yyvsp[-1].ttype);
  23459. -          yyval.ttype = start_method (TREE_CHAIN (specs), yyval.ttype, yyvsp[0].ttype);
  23460. -         rest_of_mdef:
  23461. -          if (! yyval.ttype)
  23462. -            YYERROR1;
  23463. -          if (yychar == YYEMPTY)
  23464. -            yychar = YYLEX;
  23465. -          reinit_parse_for_method (yychar, yyval.ttype); ;
  23466. -    break;}
  23467. -case 101:
  23468. -#line 694 "parse.y"
  23469. -{ tree specs = strip_attrs (yyvsp[-3].ttype);
  23470. -          yyval.ttype = build_parse_node (CALL_EXPR, TREE_VALUE (specs),
  23471. -                     empty_parms (), yyvsp[-1].ttype);
  23472. -          yyval.ttype = start_method (TREE_CHAIN (specs), yyval.ttype, yyvsp[0].ttype);
  23473. -          goto rest_of_mdef;
  23474. -        ;
  23475. -    break;}
  23476. -case 102:
  23477. -#line 701 "parse.y"
  23478. -{ tree specs = strip_attrs (yyvsp[-2].ttype);
  23479. -          yyval.ttype = start_method (specs, yyvsp[-1].ttype, yyvsp[0].ttype); goto rest_of_mdef; ;
  23480. -    break;}
  23481. -case 103:
  23482. -#line 704 "parse.y"
  23483. -{ tree specs = strip_attrs (yyvsp[-2].ttype);
  23484. -          yyval.ttype = start_method (specs, yyvsp[-1].ttype, yyvsp[0].ttype); goto rest_of_mdef; ;
  23485. -    break;}
  23486. -case 104:
  23487. -#line 707 "parse.y"
  23488. -{ yyval.ttype = start_method (NULL_TREE, yyval.ttype, yyvsp[0].ttype); goto rest_of_mdef; ;
  23489. -    break;}
  23490. -case 105:
  23491. -#line 711 "parse.y"
  23492. -{
  23493. -          if (! current_function_parms_stored)
  23494. -            store_parm_decls ();
  23495. -          yyval.ttype = yyvsp[0].ttype;
  23496. -        ;
  23497. -    break;}
  23498. -case 106:
  23499. -#line 719 "parse.y"
  23500. -{ store_return_init (yyval.ttype, yyvsp[0].ttype); ;
  23501. -    break;}
  23502. -case 107:
  23503. -#line 721 "parse.y"
  23504. -{ store_return_init (yyval.ttype, yyvsp[-1].ttype); ;
  23505. -    break;}
  23506. -case 108:
  23507. -#line 723 "parse.y"
  23508. -{ store_return_init (yyval.ttype, NULL_TREE); ;
  23509. -    break;}
  23510. -case 109:
  23511. -#line 728 "parse.y"
  23512. -{
  23513. -          if (yyvsp[0].itype == 0)
  23514. -            error ("no base initializers given following ':'");
  23515. -          setup_vtbl_ptr ();
  23516. -          /* Always keep the BLOCK node associated with the outermost
  23517. -             pair of curley braces of a function.  These are needed
  23518. -             for correct operation of dwarfout.c.  */
  23519. -          keep_next_level ();
  23520. -        ;
  23521. -    break;}
  23522. -case 110:
  23523. -#line 741 "parse.y"
  23524. -{
  23525. -          if (! current_function_parms_stored)
  23526. -            store_parm_decls ();
  23527. -
  23528. -          if (DECL_CONSTRUCTOR_P (current_function_decl))
  23529. -            {
  23530. -              /* Make a contour for the initializer list.  */
  23531. -              pushlevel (0);
  23532. -              clear_last_expr ();
  23533. -              expand_start_bindings (0);
  23534. -            }
  23535. -          else if (current_class_type == NULL_TREE)
  23536. -            error ("base initializers not allowed for non-member functions");
  23537. -          else if (! DECL_CONSTRUCTOR_P (current_function_decl))
  23538. -            error ("only constructors take base initializers");
  23539. -        ;
  23540. -    break;}
  23541. -case 111:
  23542. -#line 761 "parse.y"
  23543. -{ yyval.itype = 0; ;
  23544. -    break;}
  23545. -case 112:
  23546. -#line 763 "parse.y"
  23547. -{ yyval.itype = 1; ;
  23548. -    break;}
  23549. -case 115:
  23550. -#line 769 "parse.y"
  23551. -{
  23552. -          if (current_class_name && !flag_traditional)
  23553. -            pedwarn ("anachronistic old style base class initializer");
  23554. -          expand_member_init (C_C_D, NULL_TREE, yyvsp[-1].ttype);
  23555. -        ;
  23556. -    break;}
  23557. -case 116:
  23558. -#line 775 "parse.y"
  23559. -{
  23560. -          if (current_class_name && !flag_traditional)
  23561. -            pedwarn ("anachronistic old style base class initializer");
  23562. -          expand_member_init (C_C_D, NULL_TREE, void_type_node);
  23563. -        ;
  23564. -    break;}
  23565. -case 117:
  23566. -#line 781 "parse.y"
  23567. -{ expand_member_init (C_C_D, yyval.ttype, yyvsp[-1].ttype); ;
  23568. -    break;}
  23569. -case 118:
  23570. -#line 783 "parse.y"
  23571. -{ expand_member_init (C_C_D, yyval.ttype, void_type_node); ;
  23572. -    break;}
  23573. -case 119:
  23574. -#line 785 "parse.y"
  23575. -{ expand_member_init (C_C_D, yyval.ttype, yyvsp[-1].ttype); ;
  23576. -    break;}
  23577. -case 120:
  23578. -#line 787 "parse.y"
  23579. -{ expand_member_init (C_C_D, yyval.ttype, void_type_node); ;
  23580. -    break;}
  23581. -case 121:
  23582. -#line 790 "parse.y"
  23583. -{
  23584. -          do_member_init (OP0 (yyvsp[-3].ttype), OP1 (yyvsp[-3].ttype), yyvsp[-1].ttype);
  23585. -        ;
  23586. -    break;}
  23587. -case 122:
  23588. -#line 794 "parse.y"
  23589. -{
  23590. -          do_member_init (OP0 (yyvsp[-1].ttype), OP1 (yyvsp[-1].ttype), void_type_node);
  23591. -        ;
  23592. -    break;}
  23593. -case 133:
  23594. -#line 820 "parse.y"
  23595. -{ do_type_instantiation (yyvsp[0].ttype ? yyvsp[0].ttype : yyvsp[-1].ttype, NULL_TREE); ;
  23596. -    break;}
  23597. -case 134:
  23598. -#line 822 "parse.y"
  23599. -{ tree specs = strip_attrs (yyvsp[-1].ttype);
  23600. -          do_function_instantiation (specs, yyvsp[0].ttype, NULL_TREE); ;
  23601. -    break;}
  23602. -case 135:
  23603. -#line 825 "parse.y"
  23604. -{ do_function_instantiation (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  23605. -    break;}
  23606. -case 136:
  23607. -#line 827 "parse.y"
  23608. -{ do_type_instantiation (yyvsp[0].ttype ? yyvsp[0].ttype : yyvsp[-1].ttype, yyvsp[-3].ttype); ;
  23609. -    break;}
  23610. -case 137:
  23611. -#line 829 "parse.y"
  23612. -{ tree specs = strip_attrs (yyvsp[-1].ttype);
  23613. -          do_function_instantiation (specs, yyvsp[0].ttype, yyvsp[-3].ttype); ;
  23614. -    break;}
  23615. -case 138:
  23616. -#line 832 "parse.y"
  23617. -{ do_function_instantiation (NULL_TREE, yyvsp[0].ttype, yyvsp[-2].ttype); ;
  23618. -    break;}
  23619. -case 139:
  23620. -#line 837 "parse.y"
  23621. -{ if (yyvsp[0].ttype) yyval.ttype = yyvsp[0].ttype; ;
  23622. -    break;}
  23623. -case 140:
  23624. -#line 842 "parse.y"
  23625. -{ yyval.ttype = lookup_template_class (yyval.ttype, yyvsp[-1].ttype, NULL_TREE); ;
  23626. -    break;}
  23627. -case 141:
  23628. -#line 844 "parse.y"
  23629. -{ yyval.ttype = lookup_template_class (yyval.ttype, NULL_TREE, NULL_TREE); ;
  23630. -    break;}
  23631. -case 142:
  23632. -#line 846 "parse.y"
  23633. -{ yyval.ttype = lookup_template_class (yyval.ttype, yyvsp[-1].ttype, NULL_TREE); ;
  23634. -    break;}
  23635. -case 143:
  23636. -#line 851 "parse.y"
  23637. -{ yyval.ttype = instantiate_class_template (yyvsp[0].ttype, 1); ;
  23638. -    break;}
  23639. -case 144:
  23640. -#line 856 "parse.y"
  23641. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  23642. -    break;}
  23643. -case 145:
  23644. -#line 858 "parse.y"
  23645. -{ yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  23646. -    break;}
  23647. -case 146:
  23648. -#line 863 "parse.y"
  23649. -{ yyval.ttype = groktypename (yyval.ttype); ;
  23650. -    break;}
  23651. -case 148:
  23652. -#line 869 "parse.y"
  23653. -{
  23654. -          tree t, decl, tmpl;
  23655. -
  23656. -          tmpl = TREE_PURPOSE (IDENTIFIER_TEMPLATE (yyvsp[-1].ttype));
  23657. -          t = xref_tag (DECL_TEMPLATE_INFO (tmpl)->aggr, yyvsp[-1].ttype, yyvsp[0].ttype, 0);
  23658. -          set_current_level_tags_transparency (1);
  23659. -          my_friendly_assert (TREE_CODE (t) == RECORD_TYPE
  23660. -                      || TREE_CODE (t) == UNION_TYPE, 257);
  23661. -          yyval.ttype = t;
  23662. -
  23663. -          /* Now, put a copy of the decl in global scope, to avoid
  23664. -             recursive expansion.  */
  23665. -          decl = IDENTIFIER_LOCAL_VALUE (yyvsp[-1].ttype);
  23666. -          if (!decl)
  23667. -            decl = IDENTIFIER_CLASS_VALUE (yyvsp[-1].ttype);
  23668. -          /* Now, put a copy of the decl in global scope, to avoid
  23669. -             recursive expansion.  */
  23670. -                  if (decl)
  23671. -                    {
  23672. -              /* Need to copy it to clear the chain pointer,
  23673. -             and need to get it into permanent storage.  */
  23674. -                      my_friendly_assert (TREE_CODE (decl) == TYPE_DECL, 258);
  23675. -              push_obstacks (&permanent_obstack, &permanent_obstack);
  23676. -                      decl = copy_node (decl);
  23677. -              if (DECL_LANG_SPECIFIC (decl))
  23678. -            copy_lang_decl (decl);
  23679. -              pop_obstacks ();
  23680. -              pushdecl_top_level (decl);
  23681. -            }
  23682. -          /* Kludge; see instantiate_class_template.  */
  23683. -          TYPE_BEING_DEFINED (t) = 0;
  23684. -        ;
  23685. -    break;}
  23686. -case 149:
  23687. -#line 902 "parse.y"
  23688. -{
  23689. -          tree t = finish_struct (yyvsp[-3].ttype, yyvsp[-1].ttype, 0);
  23690. -
  23691. -          pop_obstacks ();
  23692. -          end_template_instantiation (yyvsp[-5].ttype);
  23693. -
  23694. -          repo_template_used (t);
  23695. -
  23696. -                  /* Now go after the methods & class data.  */
  23697. -                  instantiate_member_templates (yyvsp[-5].ttype);
  23698. -
  23699. -          pop_tinst_level();
  23700. -
  23701. -          CLASSTYPE_GOT_SEMICOLON (t) = 1;
  23702. -        ;
  23703. -    break;}
  23704. -case 150:
  23705. -#line 921 "parse.y"
  23706. -{ yyval.ttype = NULL_TREE; ;
  23707. -    break;}
  23708. -case 151:
  23709. -#line 923 "parse.y"
  23710. -{ yyval.ttype = yyvsp[0].ttype; ;
  23711. -    break;}
  23712. -case 152:
  23713. -#line 928 "parse.y"
  23714. -{ yyval.ttype = NULL_TREE; /* never used from here... */;
  23715. -    break;}
  23716. -case 153:
  23717. -#line 930 "parse.y"
  23718. -{ yyval.ttype = yyvsp[-1].ttype; /*???*/ ;
  23719. -    break;}
  23720. -case 154:
  23721. -#line 934 "parse.y"
  23722. -{ yyval.code = NEGATE_EXPR; ;
  23723. -    break;}
  23724. -case 155:
  23725. -#line 936 "parse.y"
  23726. -{ yyval.code = CONVERT_EXPR; ;
  23727. -    break;}
  23728. -case 156:
  23729. -#line 938 "parse.y"
  23730. -{ yyval.code = PREINCREMENT_EXPR; ;
  23731. -    break;}
  23732. -case 157:
  23733. -#line 940 "parse.y"
  23734. -{ yyval.code = PREDECREMENT_EXPR; ;
  23735. -    break;}
  23736. -case 158:
  23737. -#line 942 "parse.y"
  23738. -{ yyval.code = TRUTH_NOT_EXPR; ;
  23739. -    break;}
  23740. -case 159:
  23741. -#line 946 "parse.y"
  23742. -{ yyval.ttype = build_x_compound_expr (yyval.ttype); ;
  23743. -    break;}
  23744. -case 161:
  23745. -#line 952 "parse.y"
  23746. -{ error ("ANSI C++ forbids an empty condition for `%s'",
  23747. -             cond_stmt_keyword);
  23748. -          yyval.ttype = integer_zero_node; ;
  23749. -    break;}
  23750. -case 162:
  23751. -#line 956 "parse.y"
  23752. -{ yyval.ttype = condition_conversion (yyvsp[-1].ttype); ;
  23753. -    break;}
  23754. -case 163:
  23755. -#line 961 "parse.y"
  23756. -{ error ("ANSI C++ forbids an empty condition for `%s'",
  23757. -             cond_stmt_keyword);
  23758. -          yyval.ttype = integer_zero_node; ;
  23759. -    break;}
  23760. -case 164:
  23761. -#line 965 "parse.y"
  23762. -{ yyval.ttype = condition_conversion (yyvsp[-1].ttype); ;
  23763. -    break;}
  23764. -case 165:
  23765. -#line 970 "parse.y"
  23766. -{ yyval.ttype = NULL_TREE; ;
  23767. -    break;}
  23768. -case 166:
  23769. -#line 972 "parse.y"
  23770. -{ yyval.ttype = condition_conversion (yyval.ttype); ;
  23771. -    break;}
  23772. -case 167:
  23773. -#line 974 "parse.y"
  23774. -{ yyval.ttype = NULL_TREE; ;
  23775. -    break;}
  23776. -case 168:
  23777. -#line 979 "parse.y"
  23778. -{ {
  23779. -          tree d;
  23780. -          for (d = getdecls (); d; d = TREE_CHAIN (d))
  23781. -            if (TREE_CODE (d) == TYPE_DECL) {
  23782. -              tree s = TREE_TYPE (d);
  23783. -              if (TREE_CODE (s) == RECORD_TYPE)
  23784. -            cp_error ("definition of class `%T' in condition", s);
  23785. -              else if (TREE_CODE (s) == ENUMERAL_TYPE)
  23786. -            cp_error ("definition of enum `%T' in condition", s);
  23787. -            }
  23788. -          }
  23789. -          current_declspecs = yyvsp[-5].ttype;
  23790. -          yyvsp[0].itype = suspend_momentary ();
  23791. -          yyval.ttype = start_decl (yyvsp[-4].ttype, current_declspecs, 1, yyvsp[-3].ttype);
  23792. -          cplus_decl_attributes (yyval.ttype, yyvsp[-1].ttype,
  23793. -                     /*prefix_attributes*/ NULL_TREE);
  23794. -        ;
  23795. -    break;}
  23796. -case 169:
  23797. -#line 997 "parse.y"
  23798. -{ 
  23799. -          cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-3].ttype, 0, LOOKUP_ONLYCONVERTING);
  23800. -          resume_momentary (yyvsp[-2].itype);
  23801. -          yyval.ttype = yyvsp[-1].ttype; 
  23802. -          if (TREE_CODE (TREE_TYPE (yyval.ttype)) == ARRAY_TYPE)
  23803. -            cp_error ("definition of array `%#D' in condition", yyval.ttype); 
  23804. -        ;
  23805. -    break;}
  23806. -case 175:
  23807. -#line 1016 "parse.y"
  23808. -{ finish_stmt (); ;
  23809. -    break;}
  23810. -case 177:
  23811. -#line 1023 "parse.y"
  23812. -{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, 
  23813. -                          build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  23814. -    break;}
  23815. -case 178:
  23816. -#line 1026 "parse.y"
  23817. -{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, 
  23818. -                          build_tree_list (NULL_TREE, error_mark_node)); ;
  23819. -    break;}
  23820. -case 179:
  23821. -#line 1029 "parse.y"
  23822. -{ chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  23823. -    break;}
  23824. -case 180:
  23825. -#line 1031 "parse.y"
  23826. -{ chainon (yyval.ttype, build_tree_list (NULL_TREE, error_mark_node)); ;
  23827. -    break;}
  23828. -case 181:
  23829. -#line 1036 "parse.y"
  23830. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  23831. -    break;}
  23832. -case 183:
  23833. -#line 1042 "parse.y"
  23834. -{
  23835. -#if 0
  23836. -          if (TREE_CODE (yyval.ttype) == TYPE_EXPR)
  23837. -            yyval.ttype = build_component_type_expr (C_C_D, yyval.ttype, NULL_TREE, 1);
  23838. -#endif
  23839. -        ;
  23840. -    break;}
  23841. -case 184:
  23842. -#line 1050 "parse.y"
  23843. -{ yyvsp[0].itype = pedantic;
  23844. -          pedantic = 0; ;
  23845. -    break;}
  23846. -case 185:
  23847. -#line 1053 "parse.y"
  23848. -{ yyval.ttype = yyvsp[0].ttype;
  23849. -          pedantic = yyvsp[-2].itype; ;
  23850. -    break;}
  23851. -case 186:
  23852. -#line 1056 "parse.y"
  23853. -{ yyval.ttype = build_x_indirect_ref (yyvsp[0].ttype, "unary *"); ;
  23854. -    break;}
  23855. -case 187:
  23856. -#line 1058 "parse.y"
  23857. -{ yyval.ttype = build_x_unary_op (ADDR_EXPR, yyvsp[0].ttype); ;
  23858. -    break;}
  23859. -case 188:
  23860. -#line 1060 "parse.y"
  23861. -{ yyval.ttype = build_x_unary_op (BIT_NOT_EXPR, yyvsp[0].ttype); ;
  23862. -    break;}
  23863. -case 189:
  23864. -#line 1062 "parse.y"
  23865. -{ yyval.ttype = build_x_unary_op (yyvsp[-1].code, yyvsp[0].ttype);
  23866. -          if (yyvsp[-1].code == NEGATE_EXPR && TREE_CODE (yyvsp[0].ttype) == INTEGER_CST)
  23867. -            TREE_NEGATED_INT (yyval.ttype) = 1;
  23868. -          overflow_warning (yyval.ttype);
  23869. -        ;
  23870. -    break;}
  23871. -case 190:
  23872. -#line 1069 "parse.y"
  23873. -{ tree label = lookup_label (yyvsp[0].ttype);
  23874. -          if (label == NULL_TREE)
  23875. -            yyval.ttype = null_pointer_node;
  23876. -          else
  23877. -            {
  23878. -              TREE_USED (label) = 1;
  23879. -              yyval.ttype = build1 (ADDR_EXPR, ptr_type_node, label);
  23880. -              TREE_CONSTANT (yyval.ttype) = 1;
  23881. -            }
  23882. -        ;
  23883. -    break;}
  23884. -case 191:
  23885. -#line 1080 "parse.y"
  23886. -{ if (TREE_CODE (yyvsp[0].ttype) == COMPONENT_REF
  23887. -              && DECL_BIT_FIELD (TREE_OPERAND (yyvsp[0].ttype, 1)))
  23888. -            error ("sizeof applied to a bit-field");
  23889. -          /* ANSI says arrays and functions are converted inside comma.
  23890. -             But we can't really convert them in build_compound_expr
  23891. -             because that would break commas in lvalues.
  23892. -             So do the conversion here if operand was a comma.  */
  23893. -          if (TREE_CODE (yyvsp[0].ttype) == COMPOUND_EXPR
  23894. -              && (TREE_CODE (TREE_TYPE (yyvsp[0].ttype)) == ARRAY_TYPE
  23895. -              || TREE_CODE (TREE_TYPE (yyvsp[0].ttype)) == FUNCTION_TYPE))
  23896. -            yyvsp[0].ttype = default_conversion (yyvsp[0].ttype);
  23897. -          else if (TREE_CODE (yyvsp[0].ttype) == TREE_LIST)
  23898. -                {
  23899. -              tree t = TREE_VALUE (yyvsp[0].ttype);
  23900. -              if (t != NULL_TREE
  23901. -              && ((TREE_TYPE (t)
  23902. -                  && TREE_CODE (TREE_TYPE (t)) == FUNCTION_TYPE)
  23903. -                  || is_overloaded_fn (t)))
  23904. -            pedwarn ("ANSI C++ forbids taking the sizeof a function type");
  23905. -            }
  23906. -          yyval.ttype = c_sizeof (TREE_TYPE (yyvsp[0].ttype)); ;
  23907. -    break;}
  23908. -case 192:
  23909. -#line 1102 "parse.y"
  23910. -{ yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ttype)); ;
  23911. -    break;}
  23912. -case 193:
  23913. -#line 1104 "parse.y"
  23914. -{ yyval.ttype = grok_alignof (yyvsp[0].ttype); ;
  23915. -    break;}
  23916. -case 194:
  23917. -#line 1106 "parse.y"
  23918. -{ yyval.ttype = c_alignof (groktypename (yyvsp[-1].ttype)); ;
  23919. -    break;}
  23920. -case 195:
  23921. -#line 1111 "parse.y"
  23922. -{ yyval.ttype = build_new (NULL_TREE, yyvsp[0].ttype, NULL_TREE, yyvsp[-1].itype); ;
  23923. -    break;}
  23924. -case 196:
  23925. -#line 1113 "parse.y"
  23926. -{ yyval.ttype = build_new (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-2].itype); ;
  23927. -    break;}
  23928. -case 197:
  23929. -#line 1115 "parse.y"
  23930. -{ yyval.ttype = build_new (yyvsp[-1].ttype, yyvsp[0].ttype, NULL_TREE, yyvsp[-2].itype); ;
  23931. -    break;}
  23932. -case 198:
  23933. -#line 1117 "parse.y"
  23934. -{ yyval.ttype = build_new (yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-3].itype); ;
  23935. -    break;}
  23936. -case 199:
  23937. -#line 1119 "parse.y"
  23938. -{ yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-1].ttype),
  23939. -                  NULL_TREE, yyvsp[-3].itype); ;
  23940. -    break;}
  23941. -case 200:
  23942. -#line 1122 "parse.y"
  23943. -{ yyval.ttype = build_new (NULL_TREE, groktypename(yyvsp[-2].ttype), yyvsp[0].ttype, yyvsp[-4].itype); ;
  23944. -    break;}
  23945. -case 201:
  23946. -#line 1124 "parse.y"
  23947. -{ yyval.ttype = build_new (yyvsp[-3].ttype, groktypename(yyvsp[-1].ttype), NULL_TREE, yyvsp[-4].itype); ;
  23948. -    break;}
  23949. -case 202:
  23950. -#line 1126 "parse.y"
  23951. -{ yyval.ttype = build_new (yyvsp[-4].ttype, groktypename(yyvsp[-2].ttype), yyvsp[0].ttype, yyvsp[-5].itype); ;
  23952. -    break;}
  23953. -case 203:
  23954. -#line 1129 "parse.y"
  23955. -{ yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 0, yyvsp[-1].itype); ;
  23956. -    break;}
  23957. -case 204:
  23958. -#line 1131 "parse.y"
  23959. -{ yyval.ttype = delete_sanity (yyvsp[0].ttype, NULL_TREE, 1, yyvsp[-3].itype);
  23960. -          if (yychar == YYEMPTY)
  23961. -            yychar = YYLEX; ;
  23962. -    break;}
  23963. -case 205:
  23964. -#line 1135 "parse.y"
  23965. -{ yyval.ttype = delete_sanity (yyvsp[0].ttype, yyvsp[-2].ttype, 2, yyvsp[-4].itype);
  23966. -          if (yychar == YYEMPTY)
  23967. -            yychar = YYLEX; ;
  23968. -    break;}
  23969. -case 206:
  23970. -#line 1142 "parse.y"
  23971. -{ yyval.ttype = yyvsp[-1].ttype; ;
  23972. -    break;}
  23973. -case 207:
  23974. -#line 1144 "parse.y"
  23975. -{
  23976. -          yyval.ttype = yyvsp[-1].ttype; 
  23977. -          pedwarn ("old style placement syntax, use () instead");
  23978. -        ;
  23979. -    break;}
  23980. -case 208:
  23981. -#line 1152 "parse.y"
  23982. -{ yyval.ttype = yyvsp[-1].ttype; ;
  23983. -    break;}
  23984. -case 209:
  23985. -#line 1154 "parse.y"
  23986. -{ yyval.ttype = NULL_TREE; ;
  23987. -    break;}
  23988. -case 210:
  23989. -#line 1156 "parse.y"
  23990. -{
  23991. -          cp_error ("`%T' is not a valid expression", yyvsp[-1].ttype);
  23992. -          yyval.ttype = error_mark_node;
  23993. -        ;
  23994. -    break;}
  23995. -case 211:
  23996. -#line 1164 "parse.y"
  23997. -{
  23998. -          if (pedantic)
  23999. -            pedwarn ("ANSI C++ forbids initialization of new expression with `='");
  24000. -          yyval.ttype = yyvsp[0].ttype;
  24001. -        ;
  24002. -    break;}
  24003. -case 212:
  24004. -#line 1174 "parse.y"
  24005. -{ yyvsp[-1].ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, void_list_node);
  24006. -          TREE_PARMLIST (yyvsp[-1].ttype) = 1;
  24007. -          yyval.ttype = build_parse_node (CALL_EXPR, NULL_TREE, yyvsp[-1].ttype, 
  24008. -                     NULL_TREE); ;
  24009. -    break;}
  24010. -case 213:
  24011. -#line 1179 "parse.y"
  24012. -{ yyvsp[-1].ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, void_list_node);
  24013. -          TREE_PARMLIST (yyvsp[-1].ttype) = 1;
  24014. -          yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, yyvsp[-1].ttype, NULL_TREE); ;
  24015. -    break;}
  24016. -case 215:
  24017. -#line 1187 "parse.y"
  24018. -{ yyval.ttype = reparse_absdcl_as_casts (yyval.ttype, yyvsp[0].ttype); ;
  24019. -    break;}
  24020. -case 216:
  24021. -#line 1189 "parse.y"
  24022. -{ 
  24023. -          tree init = build_nt (CONSTRUCTOR, NULL_TREE,
  24024. -                    nreverse (yyvsp[-2].ttype)); 
  24025. -          if (pedantic)
  24026. -            pedwarn ("ANSI C++ forbids constructor-expressions");
  24027. -          /* Indicate that this was a GNU C constructor expression.  */
  24028. -          TREE_HAS_CONSTRUCTOR (init) = 1;
  24029. -
  24030. -          yyval.ttype = reparse_absdcl_as_casts (yyval.ttype, init);
  24031. -        ;
  24032. -    break;}
  24033. -case 218:
  24034. -#line 1205 "parse.y"
  24035. -{ yyval.ttype = build_x_binary_op (MEMBER_REF, yyval.ttype, yyvsp[0].ttype); ;
  24036. -    break;}
  24037. -case 219:
  24038. -#line 1207 "parse.y"
  24039. -{ yyval.ttype = build_m_component_ref (yyval.ttype, yyvsp[0].ttype); ;
  24040. -    break;}
  24041. -case 220:
  24042. -#line 1209 "parse.y"
  24043. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24044. -    break;}
  24045. -case 221:
  24046. -#line 1211 "parse.y"
  24047. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24048. -    break;}
  24049. -case 222:
  24050. -#line 1213 "parse.y"
  24051. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24052. -    break;}
  24053. -case 223:
  24054. -#line 1215 "parse.y"
  24055. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24056. -    break;}
  24057. -case 224:
  24058. -#line 1217 "parse.y"
  24059. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24060. -    break;}
  24061. -case 225:
  24062. -#line 1219 "parse.y"
  24063. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24064. -    break;}
  24065. -case 226:
  24066. -#line 1221 "parse.y"
  24067. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24068. -    break;}
  24069. -case 227:
  24070. -#line 1223 "parse.y"
  24071. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24072. -    break;}
  24073. -case 228:
  24074. -#line 1225 "parse.y"
  24075. -{ yyval.ttype = build_x_binary_op (LT_EXPR, yyval.ttype, yyvsp[0].ttype); ;
  24076. -    break;}
  24077. -case 229:
  24078. -#line 1227 "parse.y"
  24079. -{ yyval.ttype = build_x_binary_op (GT_EXPR, yyval.ttype, yyvsp[0].ttype); ;
  24080. -    break;}
  24081. -case 230:
  24082. -#line 1229 "parse.y"
  24083. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24084. -    break;}
  24085. -case 231:
  24086. -#line 1231 "parse.y"
  24087. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24088. -    break;}
  24089. -case 232:
  24090. -#line 1233 "parse.y"
  24091. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24092. -    break;}
  24093. -case 233:
  24094. -#line 1235 "parse.y"
  24095. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24096. -    break;}
  24097. -case 234:
  24098. -#line 1237 "parse.y"
  24099. -{ yyval.ttype = build_x_binary_op (yyvsp[-1].code, yyval.ttype, yyvsp[0].ttype); ;
  24100. -    break;}
  24101. -case 235:
  24102. -#line 1239 "parse.y"
  24103. -{ yyval.ttype = build_x_binary_op (TRUTH_ANDIF_EXPR, yyval.ttype, yyvsp[0].ttype); ;
  24104. -    break;}
  24105. -case 236:
  24106. -#line 1241 "parse.y"
  24107. -{ yyval.ttype = build_x_binary_op (TRUTH_ORIF_EXPR, yyval.ttype, yyvsp[0].ttype); ;
  24108. -    break;}
  24109. -case 237:
  24110. -#line 1243 "parse.y"
  24111. -{ yyval.ttype = build_x_conditional_expr (yyval.ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  24112. -    break;}
  24113. -case 238:
  24114. -#line 1245 "parse.y"
  24115. -{ yyval.ttype = build_modify_expr (yyval.ttype, NOP_EXPR, yyvsp[0].ttype);
  24116. -                  C_SET_EXP_ORIGINAL_CODE (yyval.ttype, MODIFY_EXPR); ;
  24117. -    break;}
  24118. -case 239:
  24119. -#line 1248 "parse.y"
  24120. -{ register tree rval;
  24121. -          if ((rval = build_opfncall (MODIFY_EXPR, LOOKUP_NORMAL, yyval.ttype, yyvsp[0].ttype,
  24122. -                         make_node (yyvsp[-1].code))))
  24123. -            yyval.ttype = rval;
  24124. -          else
  24125. -            yyval.ttype = build_modify_expr (yyval.ttype, yyvsp[-1].code, yyvsp[0].ttype); ;
  24126. -    break;}
  24127. -case 240:
  24128. -#line 1255 "parse.y"
  24129. -{ yyval.ttype = build_throw (NULL_TREE); ;
  24130. -    break;}
  24131. -case 241:
  24132. -#line 1257 "parse.y"
  24133. -{ yyval.ttype = build_throw (yyvsp[0].ttype); ;
  24134. -    break;}
  24135. -case 242:
  24136. -#line 1275 "parse.y"
  24137. -{ yyval.ttype = build_parse_node (BIT_NOT_EXPR, yyvsp[0].ttype); ;
  24138. -    break;}
  24139. -case 250:
  24140. -#line 1290 "parse.y"
  24141. -{ yyval.ttype = build_parse_node (INDIRECT_REF, yyvsp[0].ttype); ;
  24142. -    break;}
  24143. -case 251:
  24144. -#line 1292 "parse.y"
  24145. -{ yyval.ttype = build_parse_node (ADDR_EXPR, yyvsp[0].ttype); ;
  24146. -    break;}
  24147. -case 252:
  24148. -#line 1294 "parse.y"
  24149. -{ yyval.ttype = yyvsp[-1].ttype; ;
  24150. -    break;}
  24151. -case 255:
  24152. -#line 1301 "parse.y"
  24153. -{ yyval.ttype = finish_decl_parsing (yyvsp[-1].ttype); ;
  24154. -    break;}
  24155. -case 256:
  24156. -#line 1306 "parse.y"
  24157. -{
  24158. -          if (TREE_CODE (yyval.ttype) == BIT_NOT_EXPR)
  24159. -            yyval.ttype = build_x_unary_op (BIT_NOT_EXPR, TREE_OPERAND (yyval.ttype, 0));
  24160. -          else if (IDENTIFIER_OPNAME_P (yyval.ttype))
  24161. -            {
  24162. -              tree op = yyval.ttype;
  24163. -              yyval.ttype = lookup_name (op, 0);
  24164. -              if (yyval.ttype == NULL_TREE)
  24165. -            {
  24166. -              if (op != ansi_opname[ERROR_MARK])
  24167. -                error ("operator %s not defined",
  24168. -                   operator_name_string (op));
  24169. -              yyval.ttype = error_mark_node;
  24170. -            }
  24171. -            }
  24172. -          else
  24173. -            yyval.ttype = do_identifier (yyval.ttype);
  24174. -        ;
  24175. -    break;}
  24176. -case 259:
  24177. -#line 1327 "parse.y"
  24178. -{ yyval.ttype = combine_strings (yyval.ttype); ;
  24179. -    break;}
  24180. -case 260:
  24181. -#line 1329 "parse.y"
  24182. -{ char class;
  24183. -          yyval.ttype = yyvsp[-1].ttype;
  24184. -          class = TREE_CODE_CLASS (TREE_CODE (yyval.ttype));
  24185. -          if (class == 'e' || class == '1'
  24186. -              || class == '2' || class == '<')
  24187. -                    /* This inhibits warnings in truthvalue_conversion. */
  24188. -            C_SET_EXP_ORIGINAL_CODE (yyval.ttype, ERROR_MARK); ;
  24189. -    break;}
  24190. -case 261:
  24191. -#line 1337 "parse.y"
  24192. -{ char class;
  24193. -          yyval.ttype = reparse_decl_as_expr (NULL_TREE, yyvsp[-1].ttype);
  24194. -          class = TREE_CODE_CLASS (TREE_CODE (yyval.ttype));
  24195. -          if (class == 'e' || class == '1'
  24196. -              || class == '2' || class == '<')
  24197. -                    /* This inhibits warnings in truthvalue_conversion. */
  24198. -            C_SET_EXP_ORIGINAL_CODE (yyval.ttype, ERROR_MARK); ;
  24199. -    break;}
  24200. -case 262:
  24201. -#line 1345 "parse.y"
  24202. -{ yyval.ttype = error_mark_node; ;
  24203. -    break;}
  24204. -case 263:
  24205. -#line 1347 "parse.y"
  24206. -{ if (current_function_decl == 0)
  24207. -            {
  24208. -              error ("braced-group within expression allowed only inside a function");
  24209. -              YYERROR;
  24210. -            }
  24211. -          keep_next_level ();
  24212. -          yyval.ttype = expand_start_stmt_expr (); ;
  24213. -    break;}
  24214. -case 264:
  24215. -#line 1355 "parse.y"
  24216. -{ tree rtl_exp;
  24217. -          if (pedantic)
  24218. -            pedwarn ("ANSI C++ forbids braced-groups within expressions");
  24219. -          rtl_exp = expand_end_stmt_expr (yyvsp[-2].ttype);
  24220. -          /* The statements have side effects, so the group does.  */
  24221. -          TREE_SIDE_EFFECTS (rtl_exp) = 1;
  24222. -
  24223. -          if (TREE_CODE (yyvsp[-1].ttype) == BLOCK)
  24224. -            {
  24225. -              /* Make a BIND_EXPR for the BLOCK already made.  */
  24226. -              yyval.ttype = build (BIND_EXPR, TREE_TYPE (rtl_exp),
  24227. -                  NULL_TREE, rtl_exp, yyvsp[-1].ttype);
  24228. -              /* Remove the block from the tree at this point.
  24229. -             It gets put back at the proper place
  24230. -             when the BIND_EXPR is expanded.  */
  24231. -              delete_block (yyvsp[-1].ttype);
  24232. -            }
  24233. -          else
  24234. -            yyval.ttype = yyvsp[-1].ttype;
  24235. -        ;
  24236. -    break;}
  24237. -case 265:
  24238. -#line 1376 "parse.y"
  24239. -{ /* [eichin:19911016.1902EST] */
  24240. -                  yyval.ttype = build_x_function_call (yyvsp[-3].ttype, yyvsp[-1].ttype, current_class_decl); 
  24241. -                  /* here we instantiate_class_template as needed... */
  24242. -                  do_pending_templates ();
  24243. -                ;
  24244. -    break;}
  24245. -case 266:
  24246. -#line 1380 "parse.y"
  24247. -{
  24248. -                  if (TREE_CODE (yyvsp[-1].ttype) == CALL_EXPR
  24249. -                      && TREE_TYPE (yyvsp[-1].ttype) != void_type_node)
  24250. -                yyval.ttype = require_complete_type (yyvsp[-1].ttype);
  24251. -                  else
  24252. -                    yyval.ttype = yyvsp[-1].ttype;
  24253. -                ;
  24254. -    break;}
  24255. -case 267:
  24256. -#line 1388 "parse.y"
  24257. -{
  24258. -          yyval.ttype = build_x_function_call (yyval.ttype, NULL_TREE, current_class_decl);
  24259. -          if (TREE_CODE (yyval.ttype) == CALL_EXPR
  24260. -              && TREE_TYPE (yyval.ttype) != void_type_node)
  24261. -            yyval.ttype = require_complete_type (yyval.ttype);
  24262. -                ;
  24263. -    break;}
  24264. -case 268:
  24265. -#line 1395 "parse.y"
  24266. -{ yyval.ttype = grok_array_decl (yyval.ttype, yyvsp[-1].ttype); ;
  24267. -    break;}
  24268. -case 269:
  24269. -#line 1397 "parse.y"
  24270. -{ /* If we get an OFFSET_REF, turn it into what it really
  24271. -             means (e.g., a COMPONENT_REF).  This way if we've got,
  24272. -             say, a reference to a static member that's being operated
  24273. -             on, we don't end up trying to find a member operator for
  24274. -             the class it's in.  */
  24275. -          if (TREE_CODE (yyval.ttype) == OFFSET_REF)
  24276. -            yyval.ttype = resolve_offset_ref (yyval.ttype);
  24277. -          yyval.ttype = build_x_unary_op (POSTINCREMENT_EXPR, yyval.ttype); ;
  24278. -    break;}
  24279. -case 270:
  24280. -#line 1406 "parse.y"
  24281. -{ if (TREE_CODE (yyval.ttype) == OFFSET_REF)
  24282. -            yyval.ttype = resolve_offset_ref (yyval.ttype);
  24283. -          yyval.ttype = build_x_unary_op (POSTDECREMENT_EXPR, yyval.ttype); ;
  24284. -    break;}
  24285. -case 271:
  24286. -#line 1411 "parse.y"
  24287. -{ if (current_class_decl)
  24288. -            {
  24289. -#ifdef WARNING_ABOUT_CCD
  24290. -              TREE_USED (current_class_decl) = 1;
  24291. -#endif
  24292. -              yyval.ttype = current_class_decl;
  24293. -            }
  24294. -          else if (current_function_decl
  24295. -               && DECL_STATIC_FUNCTION_P (current_function_decl))
  24296. -            {
  24297. -              error ("`this' is unavailable for static member functions");
  24298. -              yyval.ttype = error_mark_node;
  24299. -            }
  24300. -          else
  24301. -            {
  24302. -              if (current_function_decl)
  24303. -            error ("invalid use of `this' in non-member function");
  24304. -              else
  24305. -            error ("invalid use of `this' at top level");
  24306. -              yyval.ttype = error_mark_node;
  24307. -            }
  24308. -        ;
  24309. -    break;}
  24310. -case 272:
  24311. -#line 1434 "parse.y"
  24312. -{
  24313. -          tree type;
  24314. -          tree id = yyval.ttype;
  24315. -
  24316. -          /* This is a C cast in C++'s `functional' notation.  */
  24317. -          if (yyvsp[-1].ttype == error_mark_node)
  24318. -            {
  24319. -              yyval.ttype = error_mark_node;
  24320. -              break;
  24321. -            }
  24322. -#if 0
  24323. -          if (yyvsp[-1].ttype == NULL_TREE)
  24324. -            {
  24325. -              error ("cannot cast null list to type `%s'",
  24326. -                     IDENTIFIER_POINTER (TYPE_NAME (id)));
  24327. -              yyval.ttype = error_mark_node;
  24328. -              break;
  24329. -            }
  24330. -#endif
  24331. -#if 0
  24332. -          /* type is not set! (mrs) */
  24333. -          if (type == error_mark_node)
  24334. -            yyval.ttype = error_mark_node;
  24335. -          else
  24336. -#endif
  24337. -            {
  24338. -              if (id == ridpointers[(int) RID_CONST])
  24339. -                type = build_type_variant (integer_type_node, 1, 0);
  24340. -              else if (id == ridpointers[(int) RID_VOLATILE])
  24341. -                type = build_type_variant (integer_type_node, 0, 1);
  24342. -#if 0
  24343. -              /* should not be able to get here (mrs) */
  24344. -              else if (id == ridpointers[(int) RID_FRIEND])
  24345. -                {
  24346. -                  error ("cannot cast expression to `friend' type");
  24347. -                  yyval.ttype = error_mark_node;
  24348. -                  break;
  24349. -                }
  24350. -#endif
  24351. -              else my_friendly_abort (79);
  24352. -              yyval.ttype = build_c_cast (type, build_compound_expr (yyvsp[-1].ttype), 1);
  24353. -            }
  24354. -        ;
  24355. -    break;}
  24356. -case 274:
  24357. -#line 1479 "parse.y"
  24358. -{ dont_allow_type_definitions = "inside dynamic_cast"; ;
  24359. -    break;}
  24360. -case 275:
  24361. -#line 1481 "parse.y"
  24362. -{ dont_allow_type_definitions = 0; ;
  24363. -    break;}
  24364. -case 276:
  24365. -#line 1483 "parse.y"
  24366. -{ tree type = groktypename (yyvsp[-5].ttype);
  24367. -          yyval.ttype = build_dynamic_cast (type, yyvsp[-1].ttype); ;
  24368. -    break;}
  24369. -case 277:
  24370. -#line 1486 "parse.y"
  24371. -{ dont_allow_type_definitions = "inside static_cast"; ;
  24372. -    break;}
  24373. -case 278:
  24374. -#line 1488 "parse.y"
  24375. -{ dont_allow_type_definitions = 0; ;
  24376. -    break;}
  24377. -case 279:
  24378. -#line 1490 "parse.y"
  24379. -{ tree type = groktypename (yyvsp[-5].ttype);
  24380. -          yyval.ttype = build_static_cast (type, yyvsp[-1].ttype); ;
  24381. -    break;}
  24382. -case 280:
  24383. -#line 1493 "parse.y"
  24384. -{ dont_allow_type_definitions = "inside reinterpret_cast"; ;
  24385. -    break;}
  24386. -case 281:
  24387. -#line 1495 "parse.y"
  24388. -{ dont_allow_type_definitions = 0; ;
  24389. -    break;}
  24390. -case 282:
  24391. -#line 1497 "parse.y"
  24392. -{ tree type = groktypename (yyvsp[-5].ttype);
  24393. -          yyval.ttype = build_reinterpret_cast (type, yyvsp[-1].ttype); ;
  24394. -    break;}
  24395. -case 283:
  24396. -#line 1500 "parse.y"
  24397. -{ dont_allow_type_definitions = "inside const_cast"; ;
  24398. -    break;}
  24399. -case 284:
  24400. -#line 1502 "parse.y"
  24401. -{ dont_allow_type_definitions = 0; ;
  24402. -    break;}
  24403. -case 285:
  24404. -#line 1504 "parse.y"
  24405. -{ tree type = groktypename (yyvsp[-5].ttype);
  24406. -          yyval.ttype = build_const_cast (type, yyvsp[-1].ttype); ;
  24407. -    break;}
  24408. -case 286:
  24409. -#line 1507 "parse.y"
  24410. -{ yyval.ttype = build_typeid (yyvsp[-1].ttype); ;
  24411. -    break;}
  24412. -case 287:
  24413. -#line 1509 "parse.y"
  24414. -{ tree type = groktypename (yyvsp[-1].ttype);
  24415. -          yyval.ttype = get_typeid (TYPE_MAIN_VARIANT (type)); ;
  24416. -    break;}
  24417. -case 288:
  24418. -#line 1512 "parse.y"
  24419. -{
  24420. -        do_scoped_id:
  24421. -          yyval.ttype = IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype);
  24422. -          if (yychar == YYEMPTY)
  24423. -            yychar = YYLEX;
  24424. -          if (! yyval.ttype)
  24425. -            {
  24426. -              if (yychar == '(' || yychar == LEFT_RIGHT)
  24427. -            yyval.ttype = implicitly_declare (yyvsp[0].ttype);
  24428. -              else
  24429. -            {
  24430. -              if (IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) != error_mark_node)
  24431. -                error ("undeclared variable `%s' (first use here)",
  24432. -                   IDENTIFIER_POINTER (yyvsp[0].ttype));
  24433. -              yyval.ttype = error_mark_node;
  24434. -              /* Prevent repeated error messages.  */
  24435. -              IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) = error_mark_node;
  24436. -            }
  24437. -            }
  24438. -          else
  24439. -            {
  24440. -              if (TREE_CODE (yyval.ttype) == ADDR_EXPR)
  24441. -            assemble_external (TREE_OPERAND (yyval.ttype, 0));
  24442. -              else
  24443. -            assemble_external (yyval.ttype);
  24444. -              TREE_USED (yyval.ttype) = 1;
  24445. -            }
  24446. -          if (TREE_CODE (yyval.ttype) == CONST_DECL)
  24447. -            {
  24448. -              /* XXX CHS - should we set TREE_USED of the constant? */
  24449. -              yyval.ttype = DECL_INITIAL (yyval.ttype);
  24450. -              /* This is to prevent an enum whose value is 0
  24451. -             from being considered a null pointer constant.  */
  24452. -              yyval.ttype = build1 (NOP_EXPR, TREE_TYPE (yyval.ttype), yyval.ttype);
  24453. -              TREE_CONSTANT (yyval.ttype) = 1;
  24454. -            }
  24455. -
  24456. -        ;
  24457. -    break;}
  24458. -case 289:
  24459. -#line 1551 "parse.y"
  24460. -{
  24461. -          got_scope = NULL_TREE;
  24462. -          if (TREE_CODE (yyvsp[0].ttype) == IDENTIFIER_NODE)
  24463. -            goto do_scoped_id;
  24464. -          yyval.ttype = yyvsp[0].ttype;
  24465. -        ;
  24466. -    break;}
  24467. -case 290:
  24468. -#line 1558 "parse.y"
  24469. -{ yyval.ttype = build_offset_ref (OP0 (yyval.ttype), OP1 (yyval.ttype)); ;
  24470. -    break;}
  24471. -case 291:
  24472. -#line 1560 "parse.y"
  24473. -{ yyval.ttype = build_member_call (OP0 (yyval.ttype), OP1 (yyval.ttype), yyvsp[-1].ttype); ;
  24474. -    break;}
  24475. -case 292:
  24476. -#line 1562 "parse.y"
  24477. -{ yyval.ttype = build_member_call (OP0 (yyval.ttype), OP1 (yyval.ttype), NULL_TREE); ;
  24478. -    break;}
  24479. -case 293:
  24480. -#line 1564 "parse.y"
  24481. -{ got_object = NULL_TREE;
  24482. -          yyval.ttype = build_component_ref (yyval.ttype, yyvsp[0].ttype, NULL_TREE, 1); ;
  24483. -    break;}
  24484. -case 294:
  24485. -#line 1567 "parse.y"
  24486. -{ got_object = NULL_TREE;
  24487. -          yyval.ttype = build_object_ref (yyval.ttype, OP0 (yyvsp[0].ttype), OP1 (yyvsp[0].ttype)); ;
  24488. -    break;}
  24489. -case 295:
  24490. -#line 1570 "parse.y"
  24491. -{
  24492. -          got_object = NULL_TREE;
  24493. -#if 0
  24494. -          /* This is a future direction of this code, but because
  24495. -             build_x_function_call cannot always undo what is done
  24496. -             in build_component_ref entirely yet, we cannot do this. */
  24497. -          yyval.ttype = build_x_function_call (build_component_ref (yyval.ttype, yyvsp[-3].ttype, NULL_TREE, 1), yyvsp[-1].ttype, yyval.ttype);
  24498. -          if (TREE_CODE (yyval.ttype) == CALL_EXPR
  24499. -              && TREE_TYPE (yyval.ttype) != void_type_node)
  24500. -            yyval.ttype = require_complete_type (yyval.ttype);
  24501. -#else
  24502. -          yyval.ttype = build_method_call (yyval.ttype, yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE,
  24503. -                      (LOOKUP_NORMAL|LOOKUP_AGGR));
  24504. -#endif
  24505. -        ;
  24506. -    break;}
  24507. -case 296:
  24508. -#line 1586 "parse.y"
  24509. -{
  24510. -          got_object = NULL_TREE;
  24511. -#if 0
  24512. -          /* This is a future direction of this code, but because
  24513. -             build_x_function_call cannot always undo what is done
  24514. -             in build_component_ref entirely yet, we cannot do this. */
  24515. -          yyval.ttype = build_x_function_call (build_component_ref (yyval.ttype, yyvsp[-1].ttype, NULL_TREE, 1), NULL_TREE, yyval.ttype);
  24516. -          if (TREE_CODE (yyval.ttype) == CALL_EXPR
  24517. -              && TREE_TYPE (yyval.ttype) != void_type_node)
  24518. -            yyval.ttype = require_complete_type (yyval.ttype);
  24519. -#else
  24520. -          yyval.ttype = build_method_call (yyval.ttype, yyvsp[-1].ttype, NULL_TREE, NULL_TREE,
  24521. -                      (LOOKUP_NORMAL|LOOKUP_AGGR));
  24522. -#endif
  24523. -        ;
  24524. -    break;}
  24525. -case 297:
  24526. -#line 1602 "parse.y"
  24527. -{
  24528. -          got_object = NULL_TREE;
  24529. -          if (IS_SIGNATURE (IDENTIFIER_TYPE_VALUE (OP0 (yyvsp[-3].ttype))))
  24530. -            {
  24531. -              warning ("signature name in scope resolution ignored");
  24532. -              yyval.ttype = build_method_call (yyval.ttype, OP1 (yyvsp[-3].ttype), yyvsp[-1].ttype, NULL_TREE,
  24533. -                          (LOOKUP_NORMAL|LOOKUP_AGGR));
  24534. -            }
  24535. -          else
  24536. -            yyval.ttype = build_scoped_method_call (yyval.ttype, OP0 (yyvsp[-3].ttype), OP1 (yyvsp[-3].ttype), yyvsp[-1].ttype);
  24537. -        ;
  24538. -    break;}
  24539. -case 298:
  24540. -#line 1614 "parse.y"
  24541. -{
  24542. -          got_object = NULL_TREE;
  24543. -          if (IS_SIGNATURE (IDENTIFIER_TYPE_VALUE (OP0 (yyvsp[-1].ttype))))
  24544. -            {
  24545. -              warning ("signature name in scope resolution ignored");
  24546. -              yyval.ttype = build_method_call (yyval.ttype, OP1 (yyvsp[-1].ttype), NULL_TREE, NULL_TREE,
  24547. -                          (LOOKUP_NORMAL|LOOKUP_AGGR));
  24548. -            }
  24549. -          else
  24550. -            yyval.ttype = build_scoped_method_call (yyval.ttype, OP0 (yyvsp[-1].ttype), OP1 (yyvsp[-1].ttype), NULL_TREE);
  24551. -        ;
  24552. -    break;}
  24553. -case 299:
  24554. -#line 1627 "parse.y"
  24555. -{
  24556. -          got_object = NULL_TREE;
  24557. -          if (IDENTIFIER_GLOBAL_VALUE (yyvsp[-1].ttype)
  24558. -              && (TREE_CODE (TREE_TYPE (yyvsp[-3].ttype)) 
  24559. -              != TREE_CODE (TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (yyvsp[-1].ttype)))))
  24560. -            cp_error ("`%E' is not of type `%T'", yyvsp[-3].ttype, yyvsp[-1].ttype);
  24561. -          yyval.ttype = convert (void_type_node, yyvsp[-3].ttype);
  24562. -        ;
  24563. -    break;}
  24564. -case 300:
  24565. -#line 1636 "parse.y"
  24566. -{
  24567. -          got_object = NULL_TREE;
  24568. -          if (yyvsp[-4].ttype != yyvsp[-1].ttype)
  24569. -            cp_error ("destructor specifier `%T::~%T()' must have matching names", yyvsp[-4].ttype, yyvsp[-1].ttype);
  24570. -          if (TREE_CODE (TREE_TYPE (yyvsp[-5].ttype))
  24571. -              != TREE_CODE (TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (yyvsp[-4].ttype))))
  24572. -            cp_error ("`%E' is not of type `%T'", yyvsp[-5].ttype, yyvsp[-4].ttype);
  24573. -          yyval.ttype = convert (void_type_node, yyvsp[-5].ttype);
  24574. -        ;
  24575. -    break;}
  24576. -case 301:
  24577. -#line 1646 "parse.y"
  24578. -{
  24579. -          got_object = NULL_TREE;
  24580. -          yyval.ttype = error_mark_node;
  24581. -        ;
  24582. -    break;}
  24583. -case 302:
  24584. -#line 1691 "parse.y"
  24585. -{ yyval.itype = 0; ;
  24586. -    break;}
  24587. -case 303:
  24588. -#line 1693 "parse.y"
  24589. -{ got_scope = NULL_TREE; yyval.itype = 1; ;
  24590. -    break;}
  24591. -case 304:
  24592. -#line 1697 "parse.y"
  24593. -{ yyval.itype = 0; ;
  24594. -    break;}
  24595. -case 305:
  24596. -#line 1699 "parse.y"
  24597. -{ got_scope = NULL_TREE; yyval.itype = 1; ;
  24598. -    break;}
  24599. -case 306:
  24600. -#line 1704 "parse.y"
  24601. -{ yyval.ttype = boolean_true_node; ;
  24602. -    break;}
  24603. -case 307:
  24604. -#line 1706 "parse.y"
  24605. -{ yyval.ttype = boolean_false_node; ;
  24606. -    break;}
  24607. -case 309:
  24608. -#line 1713 "parse.y"
  24609. -{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
  24610. -    break;}
  24611. -case 310:
  24612. -#line 1718 "parse.y"
  24613. -{
  24614. -          if (! current_function_parms_stored)
  24615. -            store_parm_decls ();
  24616. -          setup_vtbl_ptr ();
  24617. -          /* Always keep the BLOCK node associated with the outermost
  24618. -             pair of curley braces of a function.  These are needed
  24619. -             for correct operation of dwarfout.c.  */
  24620. -          keep_next_level ();
  24621. -        ;
  24622. -    break;}
  24623. -case 311:
  24624. -#line 1730 "parse.y"
  24625. -{ got_object = TREE_TYPE (yyval.ttype); ;
  24626. -    break;}
  24627. -case 312:
  24628. -#line 1732 "parse.y"
  24629. -{
  24630. -          yyval.ttype = build_x_arrow (yyval.ttype); 
  24631. -          got_object = TREE_TYPE (yyval.ttype);
  24632. -        ;
  24633. -    break;}
  24634. -case 313:
  24635. -#line 1741 "parse.y"
  24636. -{ tree d = get_decl_list (yyvsp[-2].ttype);
  24637. -          int yes = suspend_momentary ();
  24638. -          d = start_decl (yyvsp[-1].ttype, d, 0, NULL_TREE);
  24639. -          cp_finish_decl (d, NULL_TREE, NULL_TREE, 0, 0);
  24640. -          resume_momentary (yes);
  24641. -          if (IS_AGGR_TYPE_CODE (TREE_CODE (yyvsp[-2].ttype)))
  24642. -            note_got_semicolon (yyvsp[-2].ttype);
  24643. -        ;
  24644. -    break;}
  24645. -case 314:
  24646. -#line 1750 "parse.y"
  24647. -{ tree d, specs, attrs;
  24648. -          int yes;
  24649. -          split_specs_attrs (yyvsp[-2].ttype, &specs, &attrs);
  24650. -          yes = suspend_momentary ();
  24651. -          d = start_decl (yyvsp[-1].ttype, specs, 0, NULL_TREE);
  24652. -          cplus_decl_attributes (d, NULL_TREE, attrs);
  24653. -          cp_finish_decl (d, NULL_TREE, NULL_TREE, 0, 0);
  24654. -          resume_momentary (yes);
  24655. -          note_list_got_semicolon (yyvsp[-2].ttype);
  24656. -        ;
  24657. -    break;}
  24658. -case 315:
  24659. -#line 1761 "parse.y"
  24660. -{
  24661. -          resume_momentary (yyvsp[-1].itype);
  24662. -          if (IS_AGGR_TYPE_CODE (TREE_CODE (yyvsp[-2].ttype)))
  24663. -            note_got_semicolon (yyvsp[-2].ttype);
  24664. -        ;
  24665. -    break;}
  24666. -case 316:
  24667. -#line 1767 "parse.y"
  24668. -{
  24669. -          resume_momentary (yyvsp[-1].itype);
  24670. -          note_list_got_semicolon (yyvsp[-2].ttype);
  24671. -        ;
  24672. -    break;}
  24673. -case 317:
  24674. -#line 1772 "parse.y"
  24675. -{ resume_momentary (yyvsp[-1].itype); ;
  24676. -    break;}
  24677. -case 318:
  24678. -#line 1774 "parse.y"
  24679. -{
  24680. -          shadow_tag (yyvsp[-1].ttype);
  24681. -          note_list_got_semicolon (yyvsp[-1].ttype);
  24682. -        ;
  24683. -    break;}
  24684. -case 319:
  24685. -#line 1779 "parse.y"
  24686. -{ warning ("empty declaration"); ;
  24687. -    break;}
  24688. -case 322:
  24689. -#line 1793 "parse.y"
  24690. -{ yyval.ttype = build_parse_node (CALL_EXPR, NULL_TREE, empty_parms (),
  24691. -                     NULL_TREE); ;
  24692. -    break;}
  24693. -case 323:
  24694. -#line 1796 "parse.y"
  24695. -{ yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, empty_parms (), 
  24696. -                     NULL_TREE); ;
  24697. -    break;}
  24698. -case 324:
  24699. -#line 1803 "parse.y"
  24700. -{ yyval.ttype = build_decl_list (yyval.ttype, yyvsp[0].ttype); ;
  24701. -    break;}
  24702. -case 325:
  24703. -#line 1805 "parse.y"
  24704. -{ yyval.ttype = build_decl_list (yyval.ttype, yyvsp[0].ttype); ;
  24705. -    break;}
  24706. -case 326:
  24707. -#line 1807 "parse.y"
  24708. -{ yyval.ttype = build_decl_list (get_decl_list (yyval.ttype), yyvsp[0].ttype); ;
  24709. -    break;}
  24710. -case 327:
  24711. -#line 1809 "parse.y"
  24712. -{ yyval.ttype = build_decl_list (yyval.ttype, NULL_TREE); ;
  24713. -    break;}
  24714. -case 328:
  24715. -#line 1811 "parse.y"
  24716. -{ yyval.ttype = build_decl_list (yyval.ttype, NULL_TREE); ;
  24717. -    break;}
  24718. -case 331:
  24719. -#line 1826 "parse.y"
  24720. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  24721. -    break;}
  24722. -case 332:
  24723. -#line 1828 "parse.y"
  24724. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyval.ttype, yyvsp[0].ttype); ;
  24725. -    break;}
  24726. -case 333:
  24727. -#line 1830 "parse.y"
  24728. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyval.ttype, chainon (yyvsp[-1].ttype, yyvsp[0].ttype)); ;
  24729. -    break;}
  24730. -case 334:
  24731. -#line 1832 "parse.y"
  24732. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyval.ttype)); ;
  24733. -    break;}
  24734. -case 335:
  24735. -#line 1834 "parse.y"
  24736. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyval.ttype)); ;
  24737. -    break;}
  24738. -case 336:
  24739. -#line 1836 "parse.y"
  24740. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[-2].ttype, 
  24741. -                       chainon (yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyval.ttype))); ;
  24742. -    break;}
  24743. -case 337:
  24744. -#line 1842 "parse.y"
  24745. -{ if (extra_warnings)
  24746. -            warning ("`%s' is not at beginning of declaration",
  24747. -                 IDENTIFIER_POINTER (yyval.ttype));
  24748. -          yyval.ttype = build_decl_list (NULL_TREE, yyval.ttype); ;
  24749. -    break;}
  24750. -case 338:
  24751. -#line 1847 "parse.y"
  24752. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  24753. -    break;}
  24754. -case 339:
  24755. -#line 1849 "parse.y"
  24756. -{ if (extra_warnings)
  24757. -            warning ("`%s' is not at beginning of declaration",
  24758. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  24759. -          yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  24760. -    break;}
  24761. -case 340:
  24762. -#line 1854 "parse.y"
  24763. -{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ;
  24764. -    break;}
  24765. -case 341:
  24766. -#line 1856 "parse.y"
  24767. -{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ;
  24768. -    break;}
  24769. -case 342:
  24770. -#line 1866 "parse.y"
  24771. -{ TREE_STATIC (yyval.ttype) = 1; ;
  24772. -    break;}
  24773. -case 343:
  24774. -#line 1868 "parse.y"
  24775. -{ yyval.ttype = IDENTIFIER_AS_LIST (yyval.ttype); ;
  24776. -    break;}
  24777. -case 344:
  24778. -#line 1870 "parse.y"
  24779. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype);
  24780. -          TREE_STATIC (yyval.ttype) = 1; ;
  24781. -    break;}
  24782. -case 345:
  24783. -#line 1873 "parse.y"
  24784. -{ if (extra_warnings && TREE_STATIC (yyval.ttype))
  24785. -            warning ("`%s' is not at beginning of declaration",
  24786. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  24787. -          yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype);
  24788. -          TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ;
  24789. -    break;}
  24790. -case 346:
  24791. -#line 1879 "parse.y"
  24792. -{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, yyvsp[-1].ttype); ;
  24793. -    break;}
  24794. -case 347:
  24795. -#line 1881 "parse.y"
  24796. -{ yyval.ttype = decl_tree_cons (yyvsp[0].ttype, NULL_TREE, NULL_TREE); ;
  24797. -    break;}
  24798. -case 348:
  24799. -#line 1892 "parse.y"
  24800. -{ yyval.ttype = get_decl_list (yyval.ttype); ;
  24801. -    break;}
  24802. -case 349:
  24803. -#line 1894 "parse.y"
  24804. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  24805. -    break;}
  24806. -case 350:
  24807. -#line 1896 "parse.y"
  24808. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyval.ttype, yyvsp[0].ttype); ;
  24809. -    break;}
  24810. -case 351:
  24811. -#line 1898 "parse.y"
  24812. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[-1].ttype, chainon (yyvsp[0].ttype, yyval.ttype)); ;
  24813. -    break;}
  24814. -case 352:
  24815. -#line 1903 "parse.y"
  24816. -{ yyval.ttype = build_decl_list (NULL_TREE, yyval.ttype); ;
  24817. -    break;}
  24818. -case 353:
  24819. -#line 1905 "parse.y"
  24820. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  24821. -    break;}
  24822. -case 357:
  24823. -#line 1916 "parse.y"
  24824. -{ yyval.ttype = TREE_TYPE (yyvsp[-1].ttype);
  24825. -          if (pedantic && !in_system_header)
  24826. -            pedwarn ("ANSI C++ forbids `typeof'"); ;
  24827. -    break;}
  24828. -case 358:
  24829. -#line 1920 "parse.y"
  24830. -{ yyval.ttype = groktypename (yyvsp[-1].ttype);
  24831. -          if (pedantic && !in_system_header)
  24832. -            pedwarn ("ANSI C++ forbids `typeof'"); ;
  24833. -    break;}
  24834. -case 359:
  24835. -#line 1924 "parse.y"
  24836. -{ tree type = TREE_TYPE (yyvsp[-1].ttype);
  24837. -
  24838. -          if (IS_AGGR_TYPE (type))
  24839. -            {
  24840. -              sorry ("sigof type specifier");
  24841. -              yyval.ttype = type;
  24842. -            }
  24843. -          else
  24844. -            {
  24845. -              error ("`sigof' applied to non-aggregate expression");
  24846. -              yyval.ttype = error_mark_node;
  24847. -            }
  24848. -        ;
  24849. -    break;}
  24850. -case 360:
  24851. -#line 1938 "parse.y"
  24852. -{ tree type = groktypename (yyvsp[-1].ttype);
  24853. -
  24854. -          if (IS_AGGR_TYPE (type))
  24855. -            {
  24856. -              sorry ("sigof type specifier");
  24857. -              yyval.ttype = type;
  24858. -            }
  24859. -          else
  24860. -            {
  24861. -              error("`sigof' applied to non-aggregate type");
  24862. -              yyval.ttype = error_mark_node;
  24863. -            }
  24864. -        ;
  24865. -    break;}
  24866. -case 370:
  24867. -#line 1977 "parse.y"
  24868. -{ yyval.ttype = NULL_TREE; ;
  24869. -    break;}
  24870. -case 371:
  24871. -#line 1979 "parse.y"
  24872. -{ if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype); yyval.ttype = yyvsp[-1].ttype; ;
  24873. -    break;}
  24874. -case 372:
  24875. -#line 1984 "parse.y"
  24876. -{ split_specs_attrs (yyvsp[-5].ttype, ¤t_declspecs,
  24877. -                     &prefix_attributes);
  24878. -          if (TREE_CODE (current_declspecs) != TREE_LIST)
  24879. -            current_declspecs = get_decl_list (current_declspecs);
  24880. -          if (have_extern_spec && !used_extern_spec)
  24881. -            {
  24882. -              current_declspecs = decl_tree_cons
  24883. -            (NULL_TREE, get_identifier ("extern"), 
  24884. -             current_declspecs);
  24885. -              used_extern_spec = 1;
  24886. -            }
  24887. -          yyvsp[0].itype = suspend_momentary ();
  24888. -          yyval.ttype = start_decl (yyvsp[-4].ttype, current_declspecs, 1, yyvsp[-3].ttype);
  24889. -          cplus_decl_attributes (yyval.ttype, yyvsp[-1].ttype, prefix_attributes); ;
  24890. -    break;}
  24891. -case 373:
  24892. -#line 2000 "parse.y"
  24893. -{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 0, LOOKUP_ONLYCONVERTING);
  24894. -          yyval.itype = yyvsp[-2].itype; ;
  24895. -    break;}
  24896. -case 374:
  24897. -#line 2003 "parse.y"
  24898. -{ tree d;
  24899. -          split_specs_attrs (yyvsp[-4].ttype, ¤t_declspecs,
  24900. -                     &prefix_attributes);
  24901. -          if (TREE_CODE (current_declspecs) != TREE_LIST)
  24902. -            current_declspecs = get_decl_list (current_declspecs);
  24903. -          if (have_extern_spec && !used_extern_spec)
  24904. -            {
  24905. -              current_declspecs = decl_tree_cons
  24906. -            (NULL_TREE, get_identifier ("extern"), 
  24907. -             current_declspecs);
  24908. -              used_extern_spec = 1;
  24909. -            }
  24910. -          yyval.itype = suspend_momentary ();
  24911. -          d = start_decl (yyvsp[-3].ttype, current_declspecs, 0, yyvsp[-2].ttype);
  24912. -          cplus_decl_attributes (d, yyvsp[0].ttype, prefix_attributes);
  24913. -          cp_finish_decl (d, NULL_TREE, yyvsp[-1].ttype, 0, 0); ;
  24914. -    break;}
  24915. -case 375:
  24916. -#line 2023 "parse.y"
  24917. -{ yyval.ttype = start_decl (yyvsp[-4].ttype, current_declspecs, 1, yyvsp[-3].ttype);
  24918. -          cplus_decl_attributes (yyval.ttype, yyvsp[-1].ttype, prefix_attributes); ;
  24919. -    break;}
  24920. -case 376:
  24921. -#line 2027 "parse.y"
  24922. -{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 0, LOOKUP_ONLYCONVERTING); ;
  24923. -    break;}
  24924. -case 377:
  24925. -#line 2029 "parse.y"
  24926. -{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 0, yyvsp[-2].ttype);
  24927. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes);
  24928. -          cp_finish_decl (yyval.ttype, NULL_TREE, yyvsp[-1].ttype, 0, 0); ;
  24929. -    break;}
  24930. -case 378:
  24931. -#line 2036 "parse.y"
  24932. -{ split_specs_attrs (yyvsp[-5].ttype, ¤t_declspecs,
  24933. -                     &prefix_attributes);
  24934. -          yyvsp[0].itype = suspend_momentary ();
  24935. -          yyval.ttype = start_decl (yyvsp[-4].ttype, current_declspecs, 1, yyvsp[-3].ttype);
  24936. -          cplus_decl_attributes (yyval.ttype, yyvsp[-1].ttype, prefix_attributes); ;
  24937. -    break;}
  24938. -case 379:
  24939. -#line 2043 "parse.y"
  24940. -{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 0, LOOKUP_ONLYCONVERTING);
  24941. -          yyval.itype = yyvsp[-2].itype; ;
  24942. -    break;}
  24943. -case 380:
  24944. -#line 2046 "parse.y"
  24945. -{ tree d;
  24946. -          split_specs_attrs (yyvsp[-4].ttype, ¤t_declspecs,
  24947. -                     &prefix_attributes);
  24948. -          yyval.itype = suspend_momentary ();
  24949. -          d = start_decl (yyvsp[-3].ttype, current_declspecs, 0, yyvsp[-2].ttype);
  24950. -          cplus_decl_attributes (d, yyvsp[0].ttype, prefix_attributes);
  24951. -          cp_finish_decl (d, NULL_TREE, yyvsp[-1].ttype, 0, 0); ;
  24952. -    break;}
  24953. -case 381:
  24954. -#line 2057 "parse.y"
  24955. -{ current_declspecs = NULL_TREE;
  24956. -          prefix_attributes = NULL_TREE;
  24957. -          yyvsp[0].itype = suspend_momentary ();
  24958. -          yyval.ttype = start_decl (yyvsp[-4].ttype, current_declspecs, 1, yyvsp[-3].ttype);
  24959. -          cplus_decl_attributes (yyval.ttype, yyvsp[-1].ttype, prefix_attributes); ;
  24960. -    break;}
  24961. -case 382:
  24962. -#line 2064 "parse.y"
  24963. -{ cp_finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype, 0, LOOKUP_ONLYCONVERTING);
  24964. -          yyval.itype = yyvsp[-2].itype; ;
  24965. -    break;}
  24966. -case 383:
  24967. -#line 2067 "parse.y"
  24968. -{ tree d;
  24969. -          current_declspecs = NULL_TREE;
  24970. -          prefix_attributes = NULL_TREE;
  24971. -          yyval.itype = suspend_momentary ();
  24972. -          d = start_decl (yyvsp[-3].ttype, current_declspecs, 0, yyvsp[-2].ttype);
  24973. -          cplus_decl_attributes (d, yyvsp[0].ttype, prefix_attributes);
  24974. -          cp_finish_decl (d, NULL_TREE, yyvsp[-1].ttype, 0, 0); ;
  24975. -    break;}
  24976. -case 384:
  24977. -#line 2080 "parse.y"
  24978. -{ yyval.ttype = NULL_TREE; ;
  24979. -    break;}
  24980. -case 385:
  24981. -#line 2082 "parse.y"
  24982. -{ yyval.ttype = yyvsp[0].ttype; ;
  24983. -    break;}
  24984. -case 386:
  24985. -#line 2087 "parse.y"
  24986. -{ yyval.ttype = yyvsp[0].ttype; ;
  24987. -    break;}
  24988. -case 387:
  24989. -#line 2089 "parse.y"
  24990. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  24991. -    break;}
  24992. -case 388:
  24993. -#line 2094 "parse.y"
  24994. -{ yyval.ttype = yyvsp[-2].ttype; ;
  24995. -    break;}
  24996. -case 389:
  24997. -#line 2099 "parse.y"
  24998. -{ yyval.ttype = yyvsp[0].ttype; ;
  24999. -    break;}
  25000. -case 390:
  25001. -#line 2101 "parse.y"
  25002. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  25003. -    break;}
  25004. -case 391:
  25005. -#line 2106 "parse.y"
  25006. -{ yyval.ttype = NULL_TREE; ;
  25007. -    break;}
  25008. -case 392:
  25009. -#line 2108 "parse.y"
  25010. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ;
  25011. -    break;}
  25012. -case 393:
  25013. -#line 2110 "parse.y"
  25014. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ;
  25015. -    break;}
  25016. -case 394:
  25017. -#line 2112 "parse.y"
  25018. -{ yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ;
  25019. -    break;}
  25020. -case 395:
  25021. -#line 2114 "parse.y"
  25022. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  25023. -    break;}
  25024. -case 400:
  25025. -#line 2130 "parse.y"
  25026. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  25027. -    break;}
  25028. -case 401:
  25029. -#line 2132 "parse.y"
  25030. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  25031. -    break;}
  25032. -case 402:
  25033. -#line 2137 "parse.y"
  25034. -{ yyval.ttype = NULL_TREE; ;
  25035. -    break;}
  25036. -case 403:
  25037. -#line 2139 "parse.y"
  25038. -{ yyval.ttype = yyvsp[0].ttype; ;
  25039. -    break;}
  25040. -case 405:
  25041. -#line 2144 "parse.y"
  25042. -{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, NULL_TREE);
  25043. -          TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
  25044. -    break;}
  25045. -case 406:
  25046. -#line 2147 "parse.y"
  25047. -{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-1].ttype));
  25048. -          TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
  25049. -    break;}
  25050. -case 407:
  25051. -#line 2150 "parse.y"
  25052. -{ yyval.ttype = build_nt (CONSTRUCTOR, NULL_TREE, nreverse (yyvsp[-2].ttype));
  25053. -          TREE_HAS_CONSTRUCTOR (yyval.ttype) = 1; ;
  25054. -    break;}
  25055. -case 408:
  25056. -#line 2153 "parse.y"
  25057. -{ yyval.ttype = NULL_TREE; ;
  25058. -    break;}
  25059. -case 409:
  25060. -#line 2160 "parse.y"
  25061. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  25062. -    break;}
  25063. -case 410:
  25064. -#line 2162 "parse.y"
  25065. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  25066. -    break;}
  25067. -case 411:
  25068. -#line 2165 "parse.y"
  25069. -{ yyval.ttype = build_tree_list (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  25070. -    break;}
  25071. -case 412:
  25072. -#line 2167 "parse.y"
  25073. -{ yyval.ttype = tree_cons (yyvsp[-2].ttype, yyvsp[0].ttype, yyval.ttype); ;
  25074. -    break;}
  25075. -case 413:
  25076. -#line 2169 "parse.y"
  25077. -{ yyval.ttype = build_tree_list (yyval.ttype, yyvsp[0].ttype); ;
  25078. -    break;}
  25079. -case 414:
  25080. -#line 2171 "parse.y"
  25081. -{ yyval.ttype = tree_cons (yyvsp[-2].ttype, yyvsp[0].ttype, yyval.ttype); ;
  25082. -    break;}
  25083. -case 415:
  25084. -#line 2176 "parse.y"
  25085. -{ yyvsp[0].itype = suspend_momentary ();
  25086. -          yyval.ttype = start_enum (yyvsp[-1].ttype); ;
  25087. -    break;}
  25088. -case 416:
  25089. -#line 2179 "parse.y"
  25090. -{ yyval.ttype = finish_enum (yyvsp[-3].ttype, yyvsp[-2].ttype);
  25091. -          resume_momentary ((int) yyvsp[-4].itype);
  25092. -          check_for_missing_semicolon (yyvsp[-3].ttype); ;
  25093. -    break;}
  25094. -case 417:
  25095. -#line 2183 "parse.y"
  25096. -{ yyval.ttype = finish_enum (start_enum (yyvsp[-2].ttype), NULL_TREE);
  25097. -          check_for_missing_semicolon (yyval.ttype); ;
  25098. -    break;}
  25099. -case 418:
  25100. -#line 2186 "parse.y"
  25101. -{ yyvsp[0].itype = suspend_momentary ();
  25102. -          yyval.ttype = start_enum (make_anon_name ()); ;
  25103. -    break;}
  25104. -case 419:
  25105. -#line 2189 "parse.y"
  25106. -{ yyval.ttype = finish_enum (yyvsp[-3].ttype, yyvsp[-2].ttype);
  25107. -          resume_momentary ((int) yyvsp[-5].itype);
  25108. -          check_for_missing_semicolon (yyvsp[-3].ttype); ;
  25109. -    break;}
  25110. -case 420:
  25111. -#line 2193 "parse.y"
  25112. -{ yyval.ttype = finish_enum (start_enum (make_anon_name()), NULL_TREE);
  25113. -          check_for_missing_semicolon (yyval.ttype); ;
  25114. -    break;}
  25115. -case 421:
  25116. -#line 2196 "parse.y"
  25117. -{ yyval.ttype = xref_tag (enum_type_node, yyvsp[0].ttype, NULL_TREE, 1); ;
  25118. -    break;}
  25119. -case 422:
  25120. -#line 2198 "parse.y"
  25121. -{ yyval.ttype = xref_tag (enum_type_node, yyvsp[0].ttype, NULL_TREE, 1); ;
  25122. -    break;}
  25123. -case 423:
  25124. -#line 2200 "parse.y"
  25125. -{ yyval.ttype = yyvsp[0].ttype; ;
  25126. -    break;}
  25127. -case 424:
  25128. -#line 2203 "parse.y"
  25129. -{
  25130. -          int semi;
  25131. -          tree id;
  25132. -
  25133. -#if 0
  25134. -          /* Need to rework class nesting in the
  25135. -             presence of nested classes, etc.  */
  25136. -          shadow_tag (CLASSTYPE_AS_LIST (yyval.ttype)); */
  25137. -#endif
  25138. -          if (yychar == YYEMPTY)
  25139. -            yychar = YYLEX;
  25140. -          semi = yychar == ';';
  25141. -          /* finish_struct nukes this anyway; if
  25142. -             finish_exception does too, then it can go. */
  25143. -          if (semi)
  25144. -            note_got_semicolon (yyval.ttype);
  25145. -
  25146. -          if (TREE_CODE (yyval.ttype) == ENUMERAL_TYPE)
  25147. -            /* $$ = $1 from default rule.  */;
  25148. -          else
  25149. -            {
  25150. -              yyval.ttype = finish_struct (yyval.ttype, yyvsp[-1].ttype, semi);
  25151. -              if (semi) note_got_semicolon (yyval.ttype);
  25152. -            }
  25153. -
  25154. -          pop_obstacks ();
  25155. -
  25156. -          id = TYPE_IDENTIFIER (yyval.ttype);
  25157. -          if (id && IDENTIFIER_TEMPLATE (id))
  25158. -            {
  25159. -              tree decl;
  25160. -
  25161. -              /* I don't know if the copying of this TYPE_DECL is
  25162. -               * really needed.  However, it's such a small per-
  25163. -               * formance penalty that the extra safety is a bargain.
  25164. -               * - niklas@appli.se
  25165. -               */
  25166. -              push_obstacks (&permanent_obstack, &permanent_obstack);
  25167. -              decl = copy_node (lookup_name (id, 0));
  25168. -              if (DECL_LANG_SPECIFIC (decl))
  25169. -            copy_lang_decl (decl);
  25170. -              pop_obstacks ();
  25171. -              undo_template_name_overload (id, 0);
  25172. -              pushdecl_top_level (decl);
  25173. -            }
  25174. -          if (! semi)
  25175. -            check_for_missing_semicolon (yyval.ttype); ;
  25176. -    break;}
  25177. -case 425:
  25178. -#line 2251 "parse.y"
  25179. -{
  25180. -          /* struct B: public A; is not accepted by the WP grammar.  */
  25181. -          if (TYPE_BINFO_BASETYPES (yyval.ttype) && !TYPE_SIZE (yyval.ttype)
  25182. -              && ! TYPE_BEING_DEFINED (yyval.ttype))
  25183. -            cp_error ("base clause without member specification for `%#T'",
  25184. -                  yyval.ttype);
  25185. -        ;
  25186. -    break;}
  25187. -case 429:
  25188. -#line 2268 "parse.y"
  25189. -{ if (pedantic) pedwarn ("comma at end of enumerator list"); ;
  25190. -    break;}
  25191. -case 431:
  25192. -#line 2273 "parse.y"
  25193. -{ error ("storage class specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
  25194. -    break;}
  25195. -case 432:
  25196. -#line 2275 "parse.y"
  25197. -{ error ("type specifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
  25198. -    break;}
  25199. -case 433:
  25200. -#line 2277 "parse.y"
  25201. -{ error ("type qualifier `%s' not allowed after struct or class", IDENTIFIER_POINTER (yyvsp[0].ttype)); ;
  25202. -    break;}
  25203. -case 434:
  25204. -#line 2279 "parse.y"
  25205. -{ error ("no body nor ';' separates two class, struct or union declarations"); ;
  25206. -    break;}
  25207. -case 435:
  25208. -#line 2284 "parse.y"
  25209. -{ 
  25210. -          yyungetc (';', 1); current_aggr = yyval.ttype; yyval.ttype = yyvsp[-1].ttype; 
  25211. -          if (yyvsp[-3].ttype == ridpointers[(int) RID_TEMPLATE])
  25212. -            instantiate_class_template (yyval.ttype, 2);
  25213. -        ;
  25214. -    break;}
  25215. -case 436:
  25216. -#line 2293 "parse.y"
  25217. -{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
  25218. -    break;}
  25219. -case 438:
  25220. -#line 2299 "parse.y"
  25221. -{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
  25222. -    break;}
  25223. -case 439:
  25224. -#line 2301 "parse.y"
  25225. -{ yyungetc ('{', 1);
  25226. -        aggr2:
  25227. -          current_aggr = yyval.ttype;
  25228. -          yyval.ttype = yyvsp[-1].ttype;
  25229. -          overload_template_name (yyval.ttype, 0); ;
  25230. -    break;}
  25231. -case 440:
  25232. -#line 2307 "parse.y"
  25233. -{ yyungetc (':', 1); goto aggr2; ;
  25234. -    break;}
  25235. -case 441:
  25236. -#line 2312 "parse.y"
  25237. -{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
  25238. -    break;}
  25239. -case 442:
  25240. -#line 2314 "parse.y"
  25241. -{ current_aggr = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
  25242. -    break;}
  25243. -case 443:
  25244. -#line 2318 "parse.y"
  25245. -{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, NULL_TREE, 0); ;
  25246. -    break;}
  25247. -case 444:
  25248. -#line 2323 "parse.y"
  25249. -{ yyval.ttype = xref_tag (current_aggr, yyvsp[0].ttype, NULL_TREE, 1); ;
  25250. -    break;}
  25251. -case 445:
  25252. -#line 2326 "parse.y"
  25253. -{ 
  25254. -          yyval.ttype = yyvsp[-1].ttype;
  25255. -          if (yyvsp[0].ttype)
  25256. -                    xref_basetypes (current_aggr, yyvsp[-2].ttype, yyvsp[-1].ttype, yyvsp[0].ttype); 
  25257. -        ;
  25258. -    break;}
  25259. -case 446:
  25260. -#line 2332 "parse.y"
  25261. -{ 
  25262. -          yyval.ttype = TREE_TYPE (yyvsp[-1].ttype);
  25263. -          if (yyvsp[0].ttype)
  25264. -            xref_basetypes (current_aggr, yyvsp[-1].ttype, TREE_TYPE (yyvsp[-1].ttype), yyvsp[0].ttype); 
  25265. -        ;
  25266. -    break;}
  25267. -case 447:
  25268. -#line 2340 "parse.y"
  25269. -{ yyval.ttype = xref_tag (yyval.ttype, make_anon_name (), NULL_TREE, 0);
  25270. -          yyungetc ('{', 1); ;
  25271. -    break;}
  25272. -case 450:
  25273. -#line 2348 "parse.y"
  25274. -{ yyval.ttype = NULL_TREE; ;
  25275. -    break;}
  25276. -case 451:
  25277. -#line 2350 "parse.y"
  25278. -{ yyungetc(':', 1); yyval.ttype = NULL_TREE; ;
  25279. -    break;}
  25280. -case 452:
  25281. -#line 2352 "parse.y"
  25282. -{ yyval.ttype = yyvsp[0].ttype; ;
  25283. -    break;}
  25284. -case 454:
  25285. -#line 2358 "parse.y"
  25286. -{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
  25287. -    break;}
  25288. -case 455:
  25289. -#line 2363 "parse.y"
  25290. -{
  25291. -          tree type;
  25292. -          type = IDENTIFIER_TYPE_VALUE (yyval.ttype);
  25293. -          if (! is_aggr_typedef (yyval.ttype, 1))
  25294. -            yyval.ttype = NULL_TREE;
  25295. -          else if (current_aggr == signature_type_node
  25296. -               && (! type) && (! IS_SIGNATURE (type)))
  25297. -            {
  25298. -              error ("class name not allowed as base signature");
  25299. -              yyval.ttype = NULL_TREE;
  25300. -            }
  25301. -          else if (current_aggr == signature_type_node)
  25302. -            {
  25303. -              sorry ("signature inheritance, base type `%s' ignored",
  25304. -                 IDENTIFIER_POINTER (yyval.ttype));
  25305. -              yyval.ttype = build_tree_list ((tree)access_public, yyval.ttype);
  25306. -            }
  25307. -          else if (type && IS_SIGNATURE (type))
  25308. -            {
  25309. -              error ("signature name not allowed as base class");
  25310. -              yyval.ttype = NULL_TREE;
  25311. -            }
  25312. -          else
  25313. -            yyval.ttype = build_tree_list ((tree)access_default, yyval.ttype);
  25314. -        ;
  25315. -    break;}
  25316. -case 456:
  25317. -#line 2389 "parse.y"
  25318. -{
  25319. -          tree type;
  25320. -          type = IDENTIFIER_TYPE_VALUE (yyvsp[0].ttype);
  25321. -          if (current_aggr == signature_type_node)
  25322. -            error ("access and source specifiers not allowed in signature");
  25323. -          if (! is_aggr_typedef (yyvsp[0].ttype, 1))
  25324. -            yyval.ttype = NULL_TREE;
  25325. -          else if (current_aggr == signature_type_node
  25326. -               && (! type) && (! IS_SIGNATURE (type)))
  25327. -            {
  25328. -              error ("class name not allowed as base signature");
  25329. -              yyval.ttype = NULL_TREE;
  25330. -            }
  25331. -          else if (current_aggr == signature_type_node)
  25332. -            {
  25333. -              sorry ("signature inheritance, base type `%s' ignored",
  25334. -                 IDENTIFIER_POINTER (yyval.ttype));
  25335. -              yyval.ttype = build_tree_list ((tree)access_public, yyvsp[0].ttype);
  25336. -            }
  25337. -          else if (type && IS_SIGNATURE (type))
  25338. -            {
  25339. -              error ("signature name not allowed as base class");
  25340. -              yyval.ttype = NULL_TREE;
  25341. -            }
  25342. -          else
  25343. -            yyval.ttype = build_tree_list ((tree) yyval.ttype, yyvsp[0].ttype);
  25344. -        ;
  25345. -    break;}
  25346. -case 458:
  25347. -#line 2421 "parse.y"
  25348. -{
  25349. -          if (current_aggr == signature_type_node)
  25350. -            {
  25351. -              if (IS_AGGR_TYPE (TREE_TYPE (yyvsp[-1].ttype)))
  25352. -            {
  25353. -              sorry ("`sigof' as base signature specifier");
  25354. -              /* need to return some dummy signature identifier */
  25355. -              yyval.ttype = yyvsp[-1].ttype;
  25356. -            }
  25357. -              else
  25358. -            {
  25359. -              error ("`sigof' applied to non-aggregate expression");
  25360. -              yyval.ttype = error_mark_node;
  25361. -            }
  25362. -            }
  25363. -          else
  25364. -            {
  25365. -              error ("`sigof' in struct or class declaration");
  25366. -              yyval.ttype = error_mark_node;
  25367. -            }
  25368. -        ;
  25369. -    break;}
  25370. -case 459:
  25371. -#line 2443 "parse.y"
  25372. -{
  25373. -          if (current_aggr == signature_type_node)
  25374. -            {
  25375. -              if (IS_AGGR_TYPE (groktypename (yyvsp[-1].ttype)))
  25376. -            {
  25377. -              sorry ("`sigof' as base signature specifier");
  25378. -              /* need to return some dummy signature identifier */
  25379. -              yyval.ttype = yyvsp[-1].ttype;
  25380. -            }
  25381. -              else
  25382. -            {
  25383. -              error ("`sigof' applied to non-aggregate expression");
  25384. -              yyval.ttype = error_mark_node;
  25385. -            }
  25386. -            }
  25387. -          else
  25388. -            {
  25389. -              error ("`sigof' in struct or class declaration");
  25390. -              yyval.ttype = error_mark_node;
  25391. -            }
  25392. -        ;
  25393. -    break;}
  25394. -case 461:
  25395. -#line 2469 "parse.y"
  25396. -{ if (yyval.ttype != ridpointers[(int)RID_VIRTUAL])
  25397. -            sorry ("non-virtual access");
  25398. -          yyval.itype = access_default_virtual; ;
  25399. -    break;}
  25400. -case 462:
  25401. -#line 2473 "parse.y"
  25402. -{ int err = 0;
  25403. -          if (yyvsp[-1].itype == access_protected)
  25404. -            {
  25405. -              warning ("`protected' access not implemented");
  25406. -              yyvsp[-1].itype = access_public;
  25407. -              err++;
  25408. -            }
  25409. -          else if (yyvsp[-1].itype == access_public)
  25410. -            {
  25411. -              if (yyvsp[-2].itype == access_private)
  25412. -            {
  25413. -            mixed:
  25414. -              error ("base class cannot be public and private");
  25415. -            }
  25416. -              else if (yyvsp[-2].itype == access_default_virtual)
  25417. -            yyval.itype = access_public_virtual;
  25418. -            }
  25419. -          else /* $2 == access_private */
  25420. -            {
  25421. -              if (yyvsp[-2].itype == access_public)
  25422. -            goto mixed;
  25423. -              else if (yyvsp[-2].itype == access_default_virtual)
  25424. -            yyval.itype = access_private_virtual;
  25425. -            }
  25426. -        ;
  25427. -    break;}
  25428. -case 463:
  25429. -#line 2499 "parse.y"
  25430. -{ if (yyvsp[-1].ttype != ridpointers[(int)RID_VIRTUAL])
  25431. -            sorry ("non-virtual access");
  25432. -          if (yyval.itype == access_public)
  25433. -            yyval.itype = access_public_virtual;
  25434. -          else if (yyval.itype == access_private)
  25435. -            yyval.itype = access_private_virtual; ;
  25436. -    break;}
  25437. -case 464:
  25438. -#line 2508 "parse.y"
  25439. -{ tree t = yyvsp[-1].ttype;
  25440. -          push_obstacks_nochange ();
  25441. -          end_temporary_allocation ();
  25442. -
  25443. -          if (! IS_AGGR_TYPE (t))
  25444. -            {
  25445. -              t = yyvsp[-1].ttype = make_lang_type (RECORD_TYPE);
  25446. -              TYPE_NAME (t) = get_identifier ("erroneous type");
  25447. -            }
  25448. -          if (TYPE_SIZE (t))
  25449. -            duplicate_tag_error (t);
  25450. -                  if (TYPE_SIZE (t) || TYPE_BEING_DEFINED (t))
  25451. -                    {
  25452. -                      t = make_lang_type (TREE_CODE (t));
  25453. -                      pushtag (TYPE_IDENTIFIER (yyvsp[-1].ttype), t, 0);
  25454. -                      yyvsp[-1].ttype = t;
  25455. -                    }
  25456. -          pushclass (t, 0);
  25457. -          TYPE_BEING_DEFINED (t) = 1;
  25458. -          /* Reset the interface data, at the earliest possible
  25459. -             moment, as it might have been set via a class foo;
  25460. -             before.  */
  25461. -          /* Don't change signatures.  */
  25462. -          if (! IS_SIGNATURE (t))
  25463. -            {
  25464. -              extern tree pending_vtables;
  25465. -              int needs_writing;
  25466. -              tree name = TYPE_IDENTIFIER (t);
  25467. -
  25468. -              if (! ANON_AGGRNAME_P (name))
  25469. -            {
  25470. -              CLASSTYPE_INTERFACE_ONLY (t) = interface_only;
  25471. -              SET_CLASSTYPE_INTERFACE_UNKNOWN_X
  25472. -                (t, interface_unknown);
  25473. -            }
  25474. -
  25475. -              /* Record how to set the access of this class's
  25476. -             virtual functions.  If write_virtuals == 2 or 3, then
  25477. -             inline virtuals are ``extern inline''.  */
  25478. -              switch (write_virtuals)
  25479. -            {
  25480. -            case 0:
  25481. -            case 1:
  25482. -              needs_writing = 1;
  25483. -              break;
  25484. -            case 2:
  25485. -              needs_writing = !! value_member (name, pending_vtables);
  25486. -              break;
  25487. -            case 3:
  25488. -              needs_writing = ! CLASSTYPE_INTERFACE_ONLY (t)
  25489. -                && CLASSTYPE_INTERFACE_KNOWN (t);
  25490. -              break;
  25491. -            default:
  25492. -              needs_writing = 0;
  25493. -            }
  25494. -              CLASSTYPE_VTABLE_NEEDS_WRITING (t) = needs_writing;
  25495. -            }
  25496. -#if 0
  25497. -          t = TYPE_IDENTIFIER (yyvsp[-1].ttype);
  25498. -          if (t && IDENTIFIER_TEMPLATE (t))
  25499. -            overload_template_name (t, 1);
  25500. -#endif
  25501. -        ;
  25502. -    break;}
  25503. -case 465:
  25504. -#line 2575 "parse.y"
  25505. -{ yyval.ttype = NULL_TREE; ;
  25506. -    break;}
  25507. -case 466:
  25508. -#line 2577 "parse.y"
  25509. -{
  25510. -          if (current_aggr == signature_type_node)
  25511. -            yyval.ttype = build_tree_list ((tree) access_public, yyval.ttype);
  25512. -          else
  25513. -            yyval.ttype = build_tree_list ((tree) access_default, yyval.ttype);
  25514. -        ;
  25515. -    break;}
  25516. -case 467:
  25517. -#line 2584 "parse.y"
  25518. -{
  25519. -          tree visspec = (tree) yyvsp[-2].itype;
  25520. -
  25521. -          if (current_aggr == signature_type_node)
  25522. -            {
  25523. -              error ("access specifier not allowed in signature");
  25524. -              visspec = (tree) access_public;
  25525. -            }
  25526. -          yyval.ttype = chainon (yyval.ttype, build_tree_list (visspec, yyvsp[0].ttype));
  25527. -        ;
  25528. -    break;}
  25529. -case 468:
  25530. -#line 2595 "parse.y"
  25531. -{
  25532. -          if (current_aggr == signature_type_node)
  25533. -            error ("access specifier not allowed in signature");
  25534. -        ;
  25535. -    break;}
  25536. -case 469:
  25537. -#line 2605 "parse.y"
  25538. -{ if (yyval.ttype == void_type_node) yyval.ttype = NULL_TREE; 
  25539. -        ;
  25540. -    break;}
  25541. -case 470:
  25542. -#line 2608 "parse.y"
  25543. -{ /* In pushdecl, we created a reverse list of names
  25544. -             in this binding level.  Make sure that the chain
  25545. -             of what we're trying to add isn't the item itself
  25546. -             (which can happen with what pushdecl's doing).  */
  25547. -          if (yyvsp[0].ttype != NULL_TREE && yyvsp[0].ttype != void_type_node)
  25548. -            {
  25549. -              if (TREE_CHAIN (yyvsp[0].ttype) != yyval.ttype)
  25550. -            yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype);
  25551. -              else
  25552. -            yyval.ttype = yyvsp[0].ttype;
  25553. -            }
  25554. -        ;
  25555. -    break;}
  25556. -case 471:
  25557. -#line 2624 "parse.y"
  25558. -{ ;
  25559. -    break;}
  25560. -case 472:
  25561. -#line 2626 "parse.y"
  25562. -{ error ("missing ';' before right brace");
  25563. -          yyungetc ('}', 0); ;
  25564. -    break;}
  25565. -case 473:
  25566. -#line 2631 "parse.y"
  25567. -{ yyval.ttype = finish_method (yyval.ttype); ;
  25568. -    break;}
  25569. -case 474:
  25570. -#line 2633 "parse.y"
  25571. -{ yyval.ttype = finish_method (yyval.ttype); ;
  25572. -    break;}
  25573. -case 475:
  25574. -#line 2635 "parse.y"
  25575. -{ yyval.ttype = finish_method (yyval.ttype); ;
  25576. -    break;}
  25577. -case 476:
  25578. -#line 2637 "parse.y"
  25579. -{ yyval.ttype = finish_method (yyval.ttype); ;
  25580. -    break;}
  25581. -case 477:
  25582. -#line 2639 "parse.y"
  25583. -{ yyval.ttype = NULL_TREE; ;
  25584. -    break;}
  25585. -case 478:
  25586. -#line 2647 "parse.y"
  25587. -{ yyval.ttype = grok_x_components (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25588. -    break;}
  25589. -case 479:
  25590. -#line 2649 "parse.y"
  25591. -{ yyval.ttype = grok_x_components (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25592. -    break;}
  25593. -case 480:
  25594. -#line 2651 "parse.y"
  25595. -{ yyval.ttype = grokfield (yyval.ttype, NULL_TREE, yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25596. -                  build_tree_list (yyvsp[-1].ttype, NULL_TREE)); ;
  25597. -    break;}
  25598. -case 481:
  25599. -#line 2654 "parse.y"
  25600. -{ yyval.ttype = grokbitfield (NULL_TREE, NULL_TREE, yyvsp[0].ttype); ;
  25601. -    break;}
  25602. -case 482:
  25603. -#line 2656 "parse.y"
  25604. -{ yyval.ttype = NULL_TREE; ;
  25605. -    break;}
  25606. -case 483:
  25607. -#line 2667 "parse.y"
  25608. -{ tree specs, attrs;
  25609. -          split_specs_attrs (yyvsp[-8].ttype, &specs, &attrs);
  25610. -          yyval.ttype = build_parse_node (CALL_EXPR, TREE_VALUE (specs),
  25611. -                     yyvsp[-6].ttype, yyvsp[-4].ttype);
  25612. -          yyval.ttype = grokfield (yyval.ttype, TREE_CHAIN (specs), yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25613. -                  build_tree_list (yyvsp[-1].ttype, attrs)); ;
  25614. -    break;}
  25615. -case 484:
  25616. -#line 2674 "parse.y"
  25617. -{ tree specs, attrs;
  25618. -          split_specs_attrs (yyvsp[-6].ttype, &specs, &attrs);
  25619. -          yyval.ttype = build_parse_node (CALL_EXPR, TREE_VALUE (specs),
  25620. -                     empty_parms (), yyvsp[-4].ttype);
  25621. -          yyval.ttype = grokfield (yyval.ttype, TREE_CHAIN (specs), yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25622. -                  build_tree_list (yyvsp[-1].ttype, attrs)); ;
  25623. -    break;}
  25624. -case 485:
  25625. -#line 2681 "parse.y"
  25626. -{ yyval.ttype = do_class_using_decl (yyvsp[0].ttype); ;
  25627. -    break;}
  25628. -case 486:
  25629. -#line 2688 "parse.y"
  25630. -{ yyval.ttype = NULL_TREE; ;
  25631. -    break;}
  25632. -case 488:
  25633. -#line 2691 "parse.y"
  25634. -{
  25635. -          /* In this context, void_type_node encodes
  25636. -             friends.  They have been recorded elsewhere.  */
  25637. -          if (yyval.ttype == void_type_node)
  25638. -            yyval.ttype = yyvsp[0].ttype;
  25639. -          else
  25640. -            yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype);
  25641. -        ;
  25642. -    break;}
  25643. -case 489:
  25644. -#line 2703 "parse.y"
  25645. -{ yyval.ttype = NULL_TREE; ;
  25646. -    break;}
  25647. -case 491:
  25648. -#line 2706 "parse.y"
  25649. -{
  25650. -          /* In this context, void_type_node encodes
  25651. -             friends.  They have been recorded elsewhere.  */
  25652. -          if (yyval.ttype == void_type_node)
  25653. -            yyval.ttype = yyvsp[0].ttype;
  25654. -          else
  25655. -            yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype);
  25656. -        ;
  25657. -    break;}
  25658. -case 496:
  25659. -#line 2728 "parse.y"
  25660. -{ split_specs_attrs (yyvsp[-5].ttype, ¤t_declspecs,
  25661. -                     &prefix_attributes);
  25662. -          yyvsp[-5].ttype = current_declspecs;
  25663. -          yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25664. -                  build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
  25665. -    break;}
  25666. -case 497:
  25667. -#line 2734 "parse.y"
  25668. -{ split_specs_attrs (yyvsp[-4].ttype, ¤t_declspecs,
  25669. -                     &prefix_attributes);
  25670. -          yyvsp[-4].ttype = current_declspecs;
  25671. -          yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
  25672. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25673. -    break;}
  25674. -case 498:
  25675. -#line 2743 "parse.y"
  25676. -{ split_specs_attrs (yyvsp[-5].ttype, ¤t_declspecs,
  25677. -                     &prefix_attributes);
  25678. -          yyvsp[-5].ttype = current_declspecs;
  25679. -          yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25680. -                  build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
  25681. -    break;}
  25682. -case 499:
  25683. -#line 2749 "parse.y"
  25684. -{ split_specs_attrs (yyvsp[-4].ttype, ¤t_declspecs,
  25685. -                     &prefix_attributes);
  25686. -          yyvsp[-4].ttype = current_declspecs;
  25687. -          yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
  25688. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25689. -    break;}
  25690. -case 500:
  25691. -#line 2755 "parse.y"
  25692. -{ split_specs_attrs (yyvsp[-3].ttype, ¤t_declspecs,
  25693. -                     &prefix_attributes);
  25694. -          yyvsp[-3].ttype = current_declspecs;
  25695. -          yyval.ttype = grokbitfield (NULL_TREE, current_declspecs, yyvsp[-1].ttype);
  25696. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25697. -    break;}
  25698. -case 501:
  25699. -#line 2764 "parse.y"
  25700. -{ yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25701. -                  build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
  25702. -    break;}
  25703. -case 502:
  25704. -#line 2767 "parse.y"
  25705. -{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
  25706. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25707. -    break;}
  25708. -case 503:
  25709. -#line 2773 "parse.y"
  25710. -{ yyval.ttype = grokfield (yyval.ttype, current_declspecs, yyvsp[-3].ttype, yyvsp[0].ttype, yyvsp[-2].ttype,
  25711. -                  build_tree_list (yyvsp[-1].ttype, prefix_attributes)); ;
  25712. -    break;}
  25713. -case 504:
  25714. -#line 2776 "parse.y"
  25715. -{ yyval.ttype = grokbitfield (yyval.ttype, current_declspecs, yyvsp[-1].ttype);
  25716. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25717. -    break;}
  25718. -case 505:
  25719. -#line 2779 "parse.y"
  25720. -{ yyval.ttype = grokbitfield (NULL_TREE, current_declspecs, yyvsp[-1].ttype);
  25721. -          cplus_decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  25722. -    break;}
  25723. -case 507:
  25724. -#line 2790 "parse.y"
  25725. -{ TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype; yyval.ttype = yyvsp[0].ttype; ;
  25726. -    break;}
  25727. -case 508:
  25728. -#line 2795 "parse.y"
  25729. -{ yyval.ttype = build_enumerator (yyval.ttype, NULL_TREE); ;
  25730. -    break;}
  25731. -case 509:
  25732. -#line 2797 "parse.y"
  25733. -{ yyval.ttype = build_enumerator (yyval.ttype, yyvsp[0].ttype); ;
  25734. -    break;}
  25735. -case 510:
  25736. -#line 2803 "parse.y"
  25737. -{ yyval.ttype = build_decl_list (yyval.ttype, yyvsp[0].ttype); ;
  25738. -    break;}
  25739. -case 511:
  25740. -#line 2805 "parse.y"
  25741. -{ yyval.ttype = build_decl_list (yyval.ttype, NULL_TREE); ;
  25742. -    break;}
  25743. -case 512:
  25744. -#line 2809 "parse.y"
  25745. -{
  25746. -          if (pedantic)
  25747. -            pedwarn ("ANSI C++ forbids array dimensions with parenthesized type in new");
  25748. -          yyval.ttype = build_parse_node (ARRAY_REF, TREE_VALUE (yyvsp[-4].ttype), yyvsp[-1].ttype);
  25749. -          yyval.ttype = build_decl_list (TREE_PURPOSE (yyvsp[-4].ttype), yyval.ttype);
  25750. -        ;
  25751. -    break;}
  25752. -case 513:
  25753. -#line 2819 "parse.y"
  25754. -{ yyval.ttype = NULL_TREE; ;
  25755. -    break;}
  25756. -case 514:
  25757. -#line 2821 "parse.y"
  25758. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  25759. -    break;}
  25760. -case 515:
  25761. -#line 2826 "parse.y"
  25762. -{ yyval.ttype = IDENTIFIER_AS_LIST (yyval.ttype); ;
  25763. -    break;}
  25764. -case 516:
  25765. -#line 2828 "parse.y"
  25766. -{ yyval.ttype = decl_tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  25767. -    break;}
  25768. -case 517:
  25769. -#line 2835 "parse.y"
  25770. -{ yyval.itype = suspend_momentary (); ;
  25771. -    break;}
  25772. -case 518:
  25773. -#line 2840 "parse.y"
  25774. -{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = yyvsp[0].ttype; ;
  25775. -    break;}
  25776. -case 519:
  25777. -#line 2846 "parse.y"
  25778. -{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
  25779. -    break;}
  25780. -case 520:
  25781. -#line 2848 "parse.y"
  25782. -{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = yyvsp[-1].ttype; ;
  25783. -    break;}
  25784. -case 521:
  25785. -#line 2850 "parse.y"
  25786. -{ resume_momentary ((int) yyvsp[-1].itype); yyval.ttype = empty_parms (); ;
  25787. -    break;}
  25788. -case 522:
  25789. -#line 2852 "parse.y"
  25790. -{ resume_momentary ((int) yyvsp[-3].itype); yyval.ttype = NULL_TREE; ;
  25791. -    break;}
  25792. -case 523:
  25793. -#line 2859 "parse.y"
  25794. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25795. -    break;}
  25796. -case 524:
  25797. -#line 2861 "parse.y"
  25798. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25799. -    break;}
  25800. -case 525:
  25801. -#line 2863 "parse.y"
  25802. -{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25803. -    break;}
  25804. -case 526:
  25805. -#line 2865 "parse.y"
  25806. -{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25807. -    break;}
  25808. -case 527:
  25809. -#line 2867 "parse.y"
  25810. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  25811. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  25812. -        ;
  25813. -    break;}
  25814. -case 529:
  25815. -#line 2875 "parse.y"
  25816. -{
  25817. -          /* Remember that this name has been used in the class
  25818. -             definition, as per [class.scope0] */
  25819. -          if (current_class_type
  25820. -              && TYPE_BEING_DEFINED (current_class_type)
  25821. -              && ! IDENTIFIER_CLASS_VALUE (yyval.ttype))
  25822. -            {
  25823. -              tree t = lookup_name (yyval.ttype, -2);
  25824. -              if (t)
  25825. -            pushdecl_class_level (t);
  25826. -            }
  25827. -        ;
  25828. -    break;}
  25829. -case 531:
  25830. -#line 2892 "parse.y"
  25831. -{ yyval.ttype = yyvsp[0].ttype; ;
  25832. -    break;}
  25833. -case 532:
  25834. -#line 2897 "parse.y"
  25835. -{ yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25836. -    break;}
  25837. -case 533:
  25838. -#line 2899 "parse.y"
  25839. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
  25840. -    break;}
  25841. -case 534:
  25842. -#line 2901 "parse.y"
  25843. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
  25844. -    break;}
  25845. -case 535:
  25846. -#line 2903 "parse.y"
  25847. -{ yyval.ttype = yyvsp[-1].ttype; ;
  25848. -    break;}
  25849. -case 536:
  25850. -#line 2905 "parse.y"
  25851. -{ push_nested_class (TREE_TYPE (yyval.ttype), 3);
  25852. -          yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype);
  25853. -          TREE_COMPLEXITY (yyval.ttype) = current_class_depth; ;
  25854. -    break;}
  25855. -case 538:
  25856. -#line 2916 "parse.y"
  25857. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25858. -    break;}
  25859. -case 539:
  25860. -#line 2918 "parse.y"
  25861. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25862. -    break;}
  25863. -case 540:
  25864. -#line 2920 "parse.y"
  25865. -{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25866. -    break;}
  25867. -case 541:
  25868. -#line 2922 "parse.y"
  25869. -{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25870. -    break;}
  25871. -case 542:
  25872. -#line 2924 "parse.y"
  25873. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  25874. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  25875. -        ;
  25876. -    break;}
  25877. -case 544:
  25878. -#line 2932 "parse.y"
  25879. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25880. -    break;}
  25881. -case 545:
  25882. -#line 2934 "parse.y"
  25883. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25884. -    break;}
  25885. -case 546:
  25886. -#line 2936 "parse.y"
  25887. -{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25888. -    break;}
  25889. -case 547:
  25890. -#line 2938 "parse.y"
  25891. -{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
  25892. -    break;}
  25893. -case 548:
  25894. -#line 2940 "parse.y"
  25895. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  25896. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  25897. -        ;
  25898. -    break;}
  25899. -case 550:
  25900. -#line 2948 "parse.y"
  25901. -{ yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25902. -    break;}
  25903. -case 551:
  25904. -#line 2950 "parse.y"
  25905. -{ yyval.ttype = yyvsp[-1].ttype; ;
  25906. -    break;}
  25907. -case 552:
  25908. -#line 2952 "parse.y"
  25909. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
  25910. -    break;}
  25911. -case 553:
  25912. -#line 2954 "parse.y"
  25913. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
  25914. -    break;}
  25915. -case 554:
  25916. -#line 2956 "parse.y"
  25917. -{ if (TREE_TYPE (OP0 (yyval.ttype)) != current_class_type)
  25918. -            {
  25919. -              push_nested_class (TREE_TYPE (OP0 (yyval.ttype)), 3);
  25920. -              TREE_COMPLEXITY (yyval.ttype) = current_class_depth;
  25921. -            }
  25922. -        ;
  25923. -    break;}
  25924. -case 555:
  25925. -#line 2966 "parse.y"
  25926. -{ got_scope = NULL_TREE;
  25927. -          yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
  25928. -    break;}
  25929. -case 556:
  25930. -#line 2972 "parse.y"
  25931. -{ got_scope = NULL_TREE;
  25932. -          yyval.ttype = build_parse_node (SCOPE_REF, yyval.ttype, yyvsp[0].ttype); ;
  25933. -    break;}
  25934. -case 558:
  25935. -#line 2979 "parse.y"
  25936. -{ yyval.ttype = yyvsp[0].ttype; ;
  25937. -    break;}
  25938. -case 559:
  25939. -#line 2984 "parse.y"
  25940. -{ yyval.ttype = build_functional_cast (yyval.ttype, yyvsp[-1].ttype); ;
  25941. -    break;}
  25942. -case 560:
  25943. -#line 2986 "parse.y"
  25944. -{ yyval.ttype = reparse_decl_as_expr (yyval.ttype, yyvsp[-1].ttype); ;
  25945. -    break;}
  25946. -case 561:
  25947. -#line 2988 "parse.y"
  25948. -{ yyval.ttype = reparse_absdcl_as_expr (yyval.ttype, yyvsp[0].ttype); ;
  25949. -    break;}
  25950. -case 565:
  25951. -#line 2999 "parse.y"
  25952. -{ yyval.ttype = yyvsp[0].ttype; ;
  25953. -    break;}
  25954. -case 566:
  25955. -#line 3006 "parse.y"
  25956. -{ got_scope = TREE_TYPE (yyval.ttype); ;
  25957. -    break;}
  25958. -case 567:
  25959. -#line 3008 "parse.y"
  25960. -{ got_scope = yyval.ttype; ;
  25961. -    break;}
  25962. -case 568:
  25963. -#line 3010 "parse.y"
  25964. -{ got_scope = TREE_TYPE (yyval.ttype); ;
  25965. -    break;}
  25966. -case 570:
  25967. -#line 3026 "parse.y"
  25968. -{ yyval.ttype = yyvsp[0].ttype; ;
  25969. -    break;}
  25970. -case 572:
  25971. -#line 3032 "parse.y"
  25972. -{ yyval.ttype = yyvsp[0].ttype; ;
  25973. -    break;}
  25974. -case 573:
  25975. -#line 3037 "parse.y"
  25976. -{ got_scope = NULL_TREE; ;
  25977. -    break;}
  25978. -case 574:
  25979. -#line 3039 "parse.y"
  25980. -{ yyval.ttype = yyvsp[-1].ttype; got_scope = NULL_TREE; ;
  25981. -    break;}
  25982. -case 575:
  25983. -#line 3046 "parse.y"
  25984. -{ got_scope = void_type_node; ;
  25985. -    break;}
  25986. -case 576:
  25987. -#line 3052 "parse.y"
  25988. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25989. -    break;}
  25990. -case 577:
  25991. -#line 3054 "parse.y"
  25992. -{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
  25993. -    break;}
  25994. -case 578:
  25995. -#line 3056 "parse.y"
  25996. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  25997. -    break;}
  25998. -case 579:
  25999. -#line 3058 "parse.y"
  26000. -{ yyval.ttype = make_reference_declarator (yyvsp[0].ttype, NULL_TREE); ;
  26001. -    break;}
  26002. -case 580:
  26003. -#line 3060 "parse.y"
  26004. -{ tree arg = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE);
  26005. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, arg);
  26006. -        ;
  26007. -    break;}
  26008. -case 581:
  26009. -#line 3064 "parse.y"
  26010. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  26011. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  26012. -        ;
  26013. -    break;}
  26014. -case 583:
  26015. -#line 3073 "parse.y"
  26016. -{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
  26017. -    break;}
  26018. -case 584:
  26019. -#line 3075 "parse.y"
  26020. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
  26021. -    break;}
  26022. -case 585:
  26023. -#line 3081 "parse.y"
  26024. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  26025. -    break;}
  26026. -case 586:
  26027. -#line 3083 "parse.y"
  26028. -{ yyval.ttype = make_pointer_declarator (NULL_TREE, yyvsp[0].ttype); ;
  26029. -    break;}
  26030. -case 587:
  26031. -#line 3085 "parse.y"
  26032. -{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
  26033. -    break;}
  26034. -case 588:
  26035. -#line 3087 "parse.y"
  26036. -{ yyval.ttype = make_pointer_declarator (NULL_TREE, NULL_TREE); ;
  26037. -    break;}
  26038. -case 589:
  26039. -#line 3089 "parse.y"
  26040. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  26041. -    break;}
  26042. -case 590:
  26043. -#line 3091 "parse.y"
  26044. -{ yyval.ttype = make_reference_declarator (NULL_TREE, yyvsp[0].ttype); ;
  26045. -    break;}
  26046. -case 591:
  26047. -#line 3093 "parse.y"
  26048. -{ yyval.ttype = make_reference_declarator (yyvsp[0].ttype, NULL_TREE); ;
  26049. -    break;}
  26050. -case 592:
  26051. -#line 3095 "parse.y"
  26052. -{ yyval.ttype = make_reference_declarator (NULL_TREE, NULL_TREE); ;
  26053. -    break;}
  26054. -case 593:
  26055. -#line 3097 "parse.y"
  26056. -{ tree arg = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE);
  26057. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-1].ttype, arg);
  26058. -        ;
  26059. -    break;}
  26060. -case 594:
  26061. -#line 3101 "parse.y"
  26062. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  26063. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  26064. -        ;
  26065. -    break;}
  26066. -case 596:
  26067. -#line 3110 "parse.y"
  26068. -{ yyval.ttype = yyvsp[-1].ttype; ;
  26069. -    break;}
  26070. -case 598:
  26071. -#line 3114 "parse.y"
  26072. -{ yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  26073. -    break;}
  26074. -case 599:
  26075. -#line 3116 "parse.y"
  26076. -{ yyval.ttype = build_parse_node (CALL_EXPR, yyval.ttype, empty_parms (), yyvsp[0].ttype); ;
  26077. -    break;}
  26078. -case 600:
  26079. -#line 3118 "parse.y"
  26080. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, yyvsp[-1].ttype); ;
  26081. -    break;}
  26082. -case 601:
  26083. -#line 3120 "parse.y"
  26084. -{ yyval.ttype = build_parse_node (ARRAY_REF, yyval.ttype, NULL_TREE); ;
  26085. -    break;}
  26086. -case 602:
  26087. -#line 3122 "parse.y"
  26088. -{ yyval.ttype = build_parse_node (CALL_EXPR, NULL_TREE, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  26089. -    break;}
  26090. -case 603:
  26091. -#line 3124 "parse.y"
  26092. -{ TREE_OPERAND (yyval.ttype, 2) = yyvsp[0].ttype; ;
  26093. -    break;}
  26094. -case 604:
  26095. -#line 3126 "parse.y"
  26096. -{ TREE_OPERAND (yyval.ttype, 2) = yyvsp[0].ttype; ;
  26097. -    break;}
  26098. -case 605:
  26099. -#line 3128 "parse.y"
  26100. -{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
  26101. -    break;}
  26102. -case 606:
  26103. -#line 3130 "parse.y"
  26104. -{ yyval.ttype = build_parse_node (ARRAY_REF, NULL_TREE, NULL_TREE); ;
  26105. -    break;}
  26106. -case 612:
  26107. -#line 3152 "parse.y"
  26108. -{ emit_line_note (input_filename, lineno);
  26109. -          pushlevel (0);
  26110. -          clear_last_expr ();
  26111. -          push_momentary ();
  26112. -          expand_start_bindings (0); ;
  26113. -    break;}
  26114. -case 613:
  26115. -#line 3160 "parse.y"
  26116. -{ expand_end_bindings (getdecls (), kept_level_p (), 1);
  26117. -          yyval.ttype = poplevel (kept_level_p (), 1, 0);
  26118. -          pop_momentary (); ;
  26119. -    break;}
  26120. -case 615:
  26121. -#line 3170 "parse.y"
  26122. -{ if (pedantic)
  26123. -            pedwarn ("ANSI C++ forbids label declarations"); ;
  26124. -    break;}
  26125. -case 618:
  26126. -#line 3181 "parse.y"
  26127. -{ tree link;
  26128. -          for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link))
  26129. -            {
  26130. -              tree label = shadow_label (TREE_VALUE (link));
  26131. -              C_DECLARED_LABEL_FLAG (label) = 1;
  26132. -              declare_nonlocal_label (label);
  26133. -            }
  26134. -        ;
  26135. -    break;}
  26136. -case 619:
  26137. -#line 3195 "parse.y"
  26138. -{;
  26139. -    break;}
  26140. -case 621:
  26141. -#line 3200 "parse.y"
  26142. -{ yyval.ttype = yyvsp[0].ttype; ;
  26143. -    break;}
  26144. -case 622:
  26145. -#line 3205 "parse.y"
  26146. -{ cond_stmt_keyword = "if"; ;
  26147. -    break;}
  26148. -case 623:
  26149. -#line 3207 "parse.y"
  26150. -{ emit_line_note (input_filename, lineno);
  26151. -          expand_start_cond (yyvsp[0].ttype, 0); ;
  26152. -    break;}
  26153. -case 625:
  26154. -#line 3214 "parse.y"
  26155. -{ finish_stmt (); ;
  26156. -    break;}
  26157. -case 626:
  26158. -#line 3216 "parse.y"
  26159. -{ yyval.ttype = yyvsp[0].ttype; ;
  26160. -    break;}
  26161. -case 627:
  26162. -#line 3221 "parse.y"
  26163. -{ finish_stmt (); ;
  26164. -    break;}
  26165. -case 629:
  26166. -#line 3227 "parse.y"
  26167. -{ finish_stmt (); ;
  26168. -    break;}
  26169. -case 630:
  26170. -#line 3229 "parse.y"
  26171. -{
  26172. -          tree expr = yyvsp[-1].ttype;
  26173. -          emit_line_note (input_filename, lineno);
  26174. -          /* Do default conversion if safe and possibly important,
  26175. -             in case within ({...}).  */
  26176. -          if ((TREE_CODE (TREE_TYPE (expr)) == ARRAY_TYPE
  26177. -               && lvalue_p (expr))
  26178. -              || TREE_CODE (TREE_TYPE (expr)) == FUNCTION_TYPE)
  26179. -            expr = default_conversion (expr);
  26180. -          cplus_expand_expr_stmt (expr);
  26181. -          clear_momentary ();
  26182. -          finish_stmt (); ;
  26183. -    break;}
  26184. -case 631:
  26185. -#line 3242 "parse.y"
  26186. -{ expand_start_else (); ;
  26187. -    break;}
  26188. -case 632:
  26189. -#line 3244 "parse.y"
  26190. -{ expand_end_cond (); ;
  26191. -    break;}
  26192. -case 633:
  26193. -#line 3246 "parse.y"
  26194. -{ finish_stmt (); ;
  26195. -    break;}
  26196. -case 634:
  26197. -#line 3248 "parse.y"
  26198. -{ expand_end_cond ();
  26199. -          expand_end_bindings (getdecls (), kept_level_p (), 1);
  26200. -          poplevel (kept_level_p (), 1, 0);
  26201. -          pop_momentary ();
  26202. -          finish_stmt (); ;
  26203. -    break;}
  26204. -case 635:
  26205. -#line 3254 "parse.y"
  26206. -{ emit_nop ();
  26207. -          emit_line_note (input_filename, lineno);
  26208. -          expand_start_loop (1);
  26209. -          cond_stmt_keyword = "while"; ;
  26210. -    break;}
  26211. -case 636:
  26212. -#line 3259 "parse.y"
  26213. -{ expand_exit_loop_if_false (0, yyvsp[0].ttype); ;
  26214. -    break;}
  26215. -case 637:
  26216. -#line 3261 "parse.y"
  26217. -{ expand_end_loop ();
  26218. -          finish_stmt (); ;
  26219. -    break;}
  26220. -case 638:
  26221. -#line 3264 "parse.y"
  26222. -{ emit_nop ();
  26223. -          emit_line_note (input_filename, lineno);
  26224. -          expand_start_loop_continue_elsewhere (1); ;
  26225. -    break;}
  26226. -case 639:
  26227. -#line 3268 "parse.y"
  26228. -{ expand_loop_continue_here ();
  26229. -          cond_stmt_keyword = "do"; ;
  26230. -    break;}
  26231. -case 640:
  26232. -#line 3271 "parse.y"
  26233. -{ emit_line_note (input_filename, lineno);
  26234. -          expand_exit_loop_if_false (0, yyvsp[-1].ttype);
  26235. -          expand_end_loop ();
  26236. -          clear_momentary ();
  26237. -          finish_stmt (); ;
  26238. -    break;}
  26239. -case 641:
  26240. -#line 3277 "parse.y"
  26241. -{ emit_line_note (input_filename, lineno);
  26242. -          if (flag_new_for_scope > 0)
  26243. -            {
  26244. -              /* Conditionalize .pushlevel */
  26245. -              pushlevel (0);
  26246. -              note_level_for_for ();
  26247. -              clear_last_expr ();
  26248. -              push_momentary ();
  26249. -              expand_start_bindings (0);
  26250. -            }
  26251. -        ;
  26252. -    break;}
  26253. -case 642:
  26254. -#line 3289 "parse.y"
  26255. -{ emit_nop ();
  26256. -          emit_line_note (input_filename, lineno);
  26257. -          expand_start_loop_continue_elsewhere (1); ;
  26258. -    break;}
  26259. -case 643:
  26260. -#line 3293 "parse.y"
  26261. -{ emit_line_note (input_filename, lineno);
  26262. -          if (yyvsp[-1].ttype) expand_exit_loop_if_false (0, yyvsp[-1].ttype); ;
  26263. -    break;}
  26264. -case 644:
  26265. -#line 3298 "parse.y"
  26266. -{ push_momentary (); ;
  26267. -    break;}
  26268. -case 645:
  26269. -#line 3300 "parse.y"
  26270. -{ emit_line_note (input_filename, lineno);
  26271. -          expand_loop_continue_here ();
  26272. -          if (yyvsp[-4].ttype) cplus_expand_expr_stmt (yyvsp[-4].ttype);
  26273. -          pop_momentary ();
  26274. -          expand_end_loop ();
  26275. -          if (flag_new_for_scope > 0)
  26276. -            {
  26277. -              expand_end_bindings (getdecls (), kept_level_p (), 1);
  26278. -              poplevel (kept_level_p (), 1, 0);
  26279. -              pop_momentary ();
  26280. -            }
  26281. -          finish_stmt (); ;
  26282. -    break;}
  26283. -case 646:
  26284. -#line 3313 "parse.y"
  26285. -{ emit_line_note (input_filename, lineno);
  26286. -          c_expand_start_case (yyvsp[-1].ttype);
  26287. -          push_switch ();
  26288. -          /* Don't let the tree nodes for $4 be discarded by
  26289. -             clear_momentary during the parsing of the next stmt.  */
  26290. -          push_momentary (); ;
  26291. -    break;}
  26292. -case 647:
  26293. -#line 3320 "parse.y"
  26294. -{ expand_end_case (yyvsp[-3].ttype);
  26295. -          pop_momentary ();
  26296. -          pop_switch (); ;
  26297. -    break;}
  26298. -case 648:
  26299. -#line 3324 "parse.y"
  26300. -{ finish_stmt (); ;
  26301. -    break;}
  26302. -case 649:
  26303. -#line 3326 "parse.y"
  26304. -{ register tree value = check_cp_case_value (yyvsp[-1].ttype);
  26305. -          register tree label
  26306. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  26307. -
  26308. -          if (value != error_mark_node)
  26309. -            {
  26310. -              tree duplicate;
  26311. -              int success = pushcase (value, convert_and_check,
  26312. -                          label, &duplicate);
  26313. -              if (success == 1)
  26314. -            cp_error ("case label `%E' not within a switch statement", yyvsp[-1].ttype);
  26315. -              else if (success == 2)
  26316. -            {
  26317. -              cp_error ("duplicate case value `%E'", yyvsp[-1].ttype);
  26318. -              cp_error_at ("previously used here", duplicate);
  26319. -            }
  26320. -              else if (success == 3)
  26321. -            warning ("case value out of range");
  26322. -              else if (success == 5)
  26323. -            cp_error ("case label `%E' within scope of cleanup or variable array", yyvsp[-1].ttype);
  26324. -            }
  26325. -          define_case_label (label);
  26326. -        ;
  26327. -    break;}
  26328. -case 651:
  26329. -#line 3351 "parse.y"
  26330. -{ register tree value1 = check_cp_case_value (yyvsp[-3].ttype);
  26331. -          register tree value2 = check_cp_case_value (yyvsp[-1].ttype);
  26332. -          register tree label
  26333. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  26334. -
  26335. -          if (pedantic)
  26336. -            pedwarn ("ANSI C++ forbids range expressions in switch statement");
  26337. -          if (value1 != error_mark_node
  26338. -              && value2 != error_mark_node)
  26339. -            {
  26340. -              tree duplicate;
  26341. -              int success = pushcase_range (value1, value2,
  26342. -                            convert_and_check, label,
  26343. -                            &duplicate);
  26344. -              if (success == 1)
  26345. -            error ("case label not within a switch statement");
  26346. -              else if (success == 2)
  26347. -            {
  26348. -              error ("duplicate (or overlapping) case value");
  26349. -              error_with_decl (duplicate, "this is the first entry overlapping that value");
  26350. -            }
  26351. -              else if (success == 3)
  26352. -            warning ("case value out of range");
  26353. -              else if (success == 4)
  26354. -            warning ("empty range specified");
  26355. -              else if (success == 5)
  26356. -            error ("case label within scope of cleanup or variable array");
  26357. -            }
  26358. -          define_case_label (label);
  26359. -        ;
  26360. -    break;}
  26361. -case 653:
  26362. -#line 3383 "parse.y"
  26363. -{
  26364. -          tree duplicate;
  26365. -          register tree label
  26366. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  26367. -          int success = pushcase (NULL_TREE, 0, label, &duplicate);
  26368. -          if (success == 1)
  26369. -            error ("default label not within a switch statement");
  26370. -          else if (success == 2)
  26371. -            {
  26372. -              error ("multiple default labels in one switch");
  26373. -              error_with_decl (duplicate, "this is the first default label");
  26374. -            }
  26375. -          define_case_label (NULL_TREE);
  26376. -        ;
  26377. -    break;}
  26378. -case 655:
  26379. -#line 3399 "parse.y"
  26380. -{ emit_line_note (input_filename, lineno);
  26381. -          if ( ! expand_exit_something ())
  26382. -            error ("break statement not within loop or switch"); ;
  26383. -    break;}
  26384. -case 656:
  26385. -#line 3403 "parse.y"
  26386. -{ emit_line_note (input_filename, lineno);
  26387. -          if (! expand_continue_loop (0))
  26388. -            error ("continue statement not within a loop"); ;
  26389. -    break;}
  26390. -case 657:
  26391. -#line 3407 "parse.y"
  26392. -{ emit_line_note (input_filename, lineno);
  26393. -          c_expand_return (NULL_TREE); ;
  26394. -    break;}
  26395. -case 658:
  26396. -#line 3410 "parse.y"
  26397. -{ emit_line_note (input_filename, lineno);
  26398. -          c_expand_return (yyvsp[-1].ttype);
  26399. -          finish_stmt ();
  26400. -        ;
  26401. -    break;}
  26402. -case 659:
  26403. -#line 3415 "parse.y"
  26404. -{ if (TREE_CHAIN (yyvsp[-2].ttype)) yyvsp[-2].ttype = combine_strings (yyvsp[-2].ttype);
  26405. -          emit_line_note (input_filename, lineno);
  26406. -          expand_asm (yyvsp[-2].ttype);
  26407. -          finish_stmt ();
  26408. -        ;
  26409. -    break;}
  26410. -case 660:
  26411. -#line 3422 "parse.y"
  26412. -{ if (TREE_CHAIN (yyvsp[-4].ttype)) yyvsp[-4].ttype = combine_strings (yyvsp[-4].ttype);
  26413. -          emit_line_note (input_filename, lineno);
  26414. -          c_expand_asm_operands (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE,
  26415. -                     yyvsp[-6].ttype == ridpointers[(int)RID_VOLATILE],
  26416. -                     input_filename, lineno);
  26417. -          finish_stmt ();
  26418. -        ;
  26419. -    break;}
  26420. -case 661:
  26421. -#line 3431 "parse.y"
  26422. -{ if (TREE_CHAIN (yyvsp[-6].ttype)) yyvsp[-6].ttype = combine_strings (yyvsp[-6].ttype);
  26423. -          emit_line_note (input_filename, lineno);
  26424. -          c_expand_asm_operands (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE,
  26425. -                     yyvsp[-8].ttype == ridpointers[(int)RID_VOLATILE],
  26426. -                     input_filename, lineno);
  26427. -          finish_stmt ();
  26428. -        ;
  26429. -    break;}
  26430. -case 662:
  26431. -#line 3441 "parse.y"
  26432. -{ if (TREE_CHAIN (yyvsp[-8].ttype)) yyvsp[-8].ttype = combine_strings (yyvsp[-8].ttype);
  26433. -          emit_line_note (input_filename, lineno);
  26434. -          c_expand_asm_operands (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype,
  26435. -                     yyvsp[-10].ttype == ridpointers[(int)RID_VOLATILE],
  26436. -                     input_filename, lineno);
  26437. -          finish_stmt ();
  26438. -        ;
  26439. -    break;}
  26440. -case 663:
  26441. -#line 3449 "parse.y"
  26442. -{ emit_line_note (input_filename, lineno);
  26443. -          expand_computed_goto (yyvsp[-1].ttype); ;
  26444. -    break;}
  26445. -case 664:
  26446. -#line 3452 "parse.y"
  26447. -{ tree decl;
  26448. -          emit_line_note (input_filename, lineno);
  26449. -          decl = lookup_label (yyvsp[-1].ttype);
  26450. -          TREE_USED (decl) = 1;
  26451. -          expand_goto (decl); ;
  26452. -    break;}
  26453. -case 665:
  26454. -#line 3458 "parse.y"
  26455. -{ finish_stmt (); ;
  26456. -    break;}
  26457. -case 666:
  26458. -#line 3460 "parse.y"
  26459. -{ error ("label must be followed by statement");
  26460. -          yyungetc ('}', 0);
  26461. -          finish_stmt (); ;
  26462. -    break;}
  26463. -case 667:
  26464. -#line 3464 "parse.y"
  26465. -{ finish_stmt (); ;
  26466. -    break;}
  26467. -case 669:
  26468. -#line 3470 "parse.y"
  26469. -{
  26470. -          if (! current_function_parms_stored)
  26471. -            store_parm_decls ();
  26472. -          expand_start_early_try_stmts ();
  26473. -        ;
  26474. -    break;}
  26475. -case 670:
  26476. -#line 3476 "parse.y"
  26477. -{ expand_end_try_stmts ();
  26478. -          expand_start_all_catch (); ;
  26479. -    break;}
  26480. -case 671:
  26481. -#line 3479 "parse.y"
  26482. -{
  26483. -          expand_end_all_catch ();
  26484. -          finish_function (lineno, (int)yyvsp[-3].itype, 0);
  26485. -        ;
  26486. -    break;}
  26487. -case 672:
  26488. -#line 3487 "parse.y"
  26489. -{ expand_start_try_stmts (); ;
  26490. -    break;}
  26491. -case 673:
  26492. -#line 3489 "parse.y"
  26493. -{ expand_end_try_stmts ();
  26494. -          expand_start_all_catch (); ;
  26495. -    break;}
  26496. -case 674:
  26497. -#line 3492 "parse.y"
  26498. -{ expand_end_all_catch (); ;
  26499. -    break;}
  26500. -case 676:
  26501. -#line 3498 "parse.y"
  26502. -{ dont_allow_type_definitions = "inside exception declarations"; ;
  26503. -    break;}
  26504. -case 677:
  26505. -#line 3500 "parse.y"
  26506. -{ dont_allow_type_definitions = 0; ;
  26507. -    break;}
  26508. -case 678:
  26509. -#line 3502 "parse.y"
  26510. -{ expand_end_catch_block (); ;
  26511. -    break;}
  26512. -case 682:
  26513. -#line 3513 "parse.y"
  26514. -{ expand_start_catch_block (NULL_TREE, NULL_TREE); ;
  26515. -    break;}
  26516. -case 683:
  26517. -#line 3525 "parse.y"
  26518. -{ expand_start_catch_block (TREE_PURPOSE (yyvsp[-1].ttype),
  26519. -                        TREE_VALUE (yyvsp[-1].ttype)); ;
  26520. -    break;}
  26521. -case 684:
  26522. -#line 3531 "parse.y"
  26523. -{ tree label;
  26524. -        do_label:
  26525. -          label = define_label (input_filename, lineno, yyvsp[-1].ttype);
  26526. -          if (label)
  26527. -            expand_label (label);
  26528. -        ;
  26529. -    break;}
  26530. -case 685:
  26531. -#line 3538 "parse.y"
  26532. -{ goto do_label; ;
  26533. -    break;}
  26534. -case 686:
  26535. -#line 3540 "parse.y"
  26536. -{ goto do_label; ;
  26537. -    break;}
  26538. -case 687:
  26539. -#line 3545 "parse.y"
  26540. -{ if (yyvsp[-1].ttype) cplus_expand_expr_stmt (yyvsp[-1].ttype); ;
  26541. -    break;}
  26542. -case 690:
  26543. -#line 3554 "parse.y"
  26544. -{ emit_line_note (input_filename, lineno);
  26545. -          yyval.ttype = NULL_TREE; ;
  26546. -    break;}
  26547. -case 691:
  26548. -#line 3557 "parse.y"
  26549. -{ emit_line_note (input_filename, lineno); ;
  26550. -    break;}
  26551. -case 692:
  26552. -#line 3562 "parse.y"
  26553. -{ yyval.ttype = NULL_TREE; ;
  26554. -    break;}
  26555. -case 694:
  26556. -#line 3565 "parse.y"
  26557. -{ yyval.ttype = NULL_TREE; ;
  26558. -    break;}
  26559. -case 695:
  26560. -#line 3571 "parse.y"
  26561. -{ yyval.ttype = NULL_TREE; ;
  26562. -    break;}
  26563. -case 698:
  26564. -#line 3578 "parse.y"
  26565. -{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
  26566. -    break;}
  26567. -case 699:
  26568. -#line 3583 "parse.y"
  26569. -{ yyval.ttype = build_tree_list (yyval.ttype, yyvsp[-1].ttype); ;
  26570. -    break;}
  26571. -case 700:
  26572. -#line 3588 "parse.y"
  26573. -{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, NULL_TREE); ;
  26574. -    break;}
  26575. -case 701:
  26576. -#line 3590 "parse.y"
  26577. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyval.ttype); ;
  26578. -    break;}
  26579. -case 702:
  26580. -#line 3600 "parse.y"
  26581. -{
  26582. -          if (strict_prototype)
  26583. -            yyval.ttype = void_list_node;
  26584. -          else
  26585. -            yyval.ttype = NULL_TREE;
  26586. -        ;
  26587. -    break;}
  26588. -case 704:
  26589. -#line 3608 "parse.y"
  26590. -{ yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, void_list_node);
  26591. -          TREE_PARMLIST (yyval.ttype) = 1; ;
  26592. -    break;}
  26593. -case 705:
  26594. -#line 3616 "parse.y"
  26595. -{
  26596. -          yyval.ttype = chainon (yyval.ttype, void_list_node);
  26597. -          TREE_PARMLIST (yyval.ttype) = 1;
  26598. -        ;
  26599. -    break;}
  26600. -case 706:
  26601. -#line 3621 "parse.y"
  26602. -{
  26603. -          TREE_PARMLIST (yyval.ttype) = 1;
  26604. -        ;
  26605. -    break;}
  26606. -case 707:
  26607. -#line 3626 "parse.y"
  26608. -{
  26609. -          TREE_PARMLIST (yyval.ttype) = 1;
  26610. -        ;
  26611. -    break;}
  26612. -case 708:
  26613. -#line 3630 "parse.y"
  26614. -{
  26615. -          yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); 
  26616. -          TREE_PARMLIST (yyval.ttype) = 1;
  26617. -        ;
  26618. -    break;}
  26619. -case 709:
  26620. -#line 3635 "parse.y"
  26621. -{
  26622. -          /* ARM $8.2.5 has this as a boxed-off comment.  */
  26623. -          if (pedantic)
  26624. -            warning ("use of `...' without a first argument is non-portable");
  26625. -          yyval.ttype = NULL_TREE;
  26626. -        ;
  26627. -    break;}
  26628. -case 710:
  26629. -#line 3642 "parse.y"
  26630. -{
  26631. -          TREE_PARMLIST (yyval.ttype) = 1;
  26632. -        ;
  26633. -    break;}
  26634. -case 711:
  26635. -#line 3646 "parse.y"
  26636. -{
  26637. -          TREE_PARMLIST (yyval.ttype) = 1;
  26638. -        ;
  26639. -    break;}
  26640. -case 712:
  26641. -#line 3650 "parse.y"
  26642. -{
  26643. -          yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype);
  26644. -          TREE_PARMLIST (yyval.ttype) = 1;
  26645. -        ;
  26646. -    break;}
  26647. -case 713:
  26648. -#line 3655 "parse.y"
  26649. -{
  26650. -          /* This helps us recover from really nasty
  26651. -             parse errors, for example, a missing right
  26652. -             parenthesis.  */
  26653. -          yyerror ("possibly missing ')'");
  26654. -          yyval.ttype = chainon (yyval.ttype, void_list_node);
  26655. -          TREE_PARMLIST (yyval.ttype) = 1;
  26656. -          yyungetc (':', 0);
  26657. -          yychar = ')';
  26658. -        ;
  26659. -    break;}
  26660. -case 714:
  26661. -#line 3666 "parse.y"
  26662. -{
  26663. -          /* This helps us recover from really nasty
  26664. -             parse errors, for example, a missing right
  26665. -             parenthesis.  */
  26666. -          yyerror ("possibly missing ')'");
  26667. -          yyval.ttype = tree_cons (NULL_TREE, yyval.ttype, void_list_node);
  26668. -          TREE_PARMLIST (yyval.ttype) = 1;
  26669. -          yyungetc (':', 0);
  26670. -          yychar = ')';
  26671. -        ;
  26672. -    break;}
  26673. -case 715:
  26674. -#line 3681 "parse.y"
  26675. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  26676. -    break;}
  26677. -case 716:
  26678. -#line 3683 "parse.y"
  26679. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, yyval.ttype); ;
  26680. -    break;}
  26681. -case 717:
  26682. -#line 3685 "parse.y"
  26683. -{ yyval.ttype = chainon (yyval.ttype, yyvsp[0].ttype); ;
  26684. -    break;}
  26685. -case 718:
  26686. -#line 3687 "parse.y"
  26687. -{ yyval.ttype = chainon (yyval.ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  26688. -    break;}
  26689. -case 719:
  26690. -#line 3689 "parse.y"
  26691. -{ yyval.ttype = chainon (yyval.ttype, build_tree_list (yyvsp[0].ttype, yyvsp[-2].ttype)); ;
  26692. -    break;}
  26693. -case 721:
  26694. -#line 3695 "parse.y"
  26695. -{ yyval.ttype = build_tree_list (NULL_TREE, yyval.ttype); ;
  26696. -    break;}
  26697. -case 722:
  26698. -#line 3720 "parse.y"
  26699. -{ tree specs = strip_attrs (yyvsp[-1].ttype);
  26700. -          yyval.ttype = build_tree_list (specs, yyvsp[0].ttype); ;
  26701. -    break;}
  26702. -case 723:
  26703. -#line 3723 "parse.y"
  26704. -{ yyval.ttype = build_tree_list (yyval.ttype, yyvsp[0].ttype); ;
  26705. -    break;}
  26706. -case 724:
  26707. -#line 3725 "parse.y"
  26708. -{ yyval.ttype = build_tree_list (get_decl_list (yyval.ttype), yyvsp[0].ttype); ;
  26709. -    break;}
  26710. -case 725:
  26711. -#line 3727 "parse.y"
  26712. -{ tree specs = strip_attrs (yyvsp[-1].ttype);
  26713. -          yyval.ttype = build_tree_list (specs, yyvsp[0].ttype); ;
  26714. -    break;}
  26715. -case 726:
  26716. -#line 3730 "parse.y"
  26717. -{ tree specs = strip_attrs (yyvsp[0].ttype);
  26718. -          yyval.ttype = build_tree_list (specs, NULL_TREE); ;
  26719. -    break;}
  26720. -case 727:
  26721. -#line 3733 "parse.y"
  26722. -{ tree specs = strip_attrs (yyvsp[-1].ttype);
  26723. -          yyval.ttype = build_tree_list (specs, yyvsp[0].ttype); ;
  26724. -    break;}
  26725. -case 728:
  26726. -#line 3739 "parse.y"
  26727. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, yyval.ttype); ;
  26728. -    break;}
  26729. -case 731:
  26730. -#line 3748 "parse.y"
  26731. -{ see_typename (); ;
  26732. -    break;}
  26733. -case 732:
  26734. -#line 3771 "parse.y"
  26735. -{
  26736. -          error ("type specifier omitted for parameter");
  26737. -          yyval.ttype = build_tree_list (integer_type_node, NULL_TREE);
  26738. -        ;
  26739. -    break;}
  26740. -case 733:
  26741. -#line 3776 "parse.y"
  26742. -{
  26743. -          error ("type specifier omitted for parameter");
  26744. -          yyval.ttype = build_tree_list (integer_type_node, yyval.ttype);
  26745. -        ;
  26746. -    break;}
  26747. -case 734:
  26748. -#line 3784 "parse.y"
  26749. -{ yyval.ttype = NULL_TREE; ;
  26750. -    break;}
  26751. -case 735:
  26752. -#line 3786 "parse.y"
  26753. -{ yyval.ttype = yyvsp[-1].ttype; ;
  26754. -    break;}
  26755. -case 736:
  26756. -#line 3788 "parse.y"
  26757. -{ yyval.ttype = build_decl_list (NULL_TREE, NULL_TREE); ;
  26758. -    break;}
  26759. -case 737:
  26760. -#line 3793 "parse.y"
  26761. -{ yyval.ttype = build_decl_list (NULL_TREE, groktypename(yyval.ttype)); ;
  26762. -    break;}
  26763. -case 739:
  26764. -#line 3799 "parse.y"
  26765. -{
  26766. -          TREE_CHAIN (yyvsp[0].ttype) = yyval.ttype;
  26767. -          yyval.ttype = yyvsp[0].ttype;
  26768. -        ;
  26769. -    break;}
  26770. -case 740:
  26771. -#line 3807 "parse.y"
  26772. -{ yyval.ttype = NULL_TREE; ;
  26773. -    break;}
  26774. -case 741:
  26775. -#line 3809 "parse.y"
  26776. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  26777. -    break;}
  26778. -case 742:
  26779. -#line 3811 "parse.y"
  26780. -{ yyval.ttype = make_reference_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  26781. -    break;}
  26782. -case 743:
  26783. -#line 3813 "parse.y"
  26784. -{ tree arg = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype);
  26785. -          yyval.ttype = build_parse_node (SCOPE_REF, yyvsp[-2].ttype, arg);
  26786. -        ;
  26787. -    break;}
  26788. -case 744:
  26789. -#line 3819 "parse.y"
  26790. -{ got_scope = NULL_TREE; ;
  26791. -    break;}
  26792. -case 745:
  26793. -#line 3824 "parse.y"
  26794. -{ yyval.ttype = ansi_opname[MULT_EXPR]; ;
  26795. -    break;}
  26796. -case 746:
  26797. -#line 3826 "parse.y"
  26798. -{ yyval.ttype = ansi_opname[TRUNC_DIV_EXPR]; ;
  26799. -    break;}
  26800. -case 747:
  26801. -#line 3828 "parse.y"
  26802. -{ yyval.ttype = ansi_opname[TRUNC_MOD_EXPR]; ;
  26803. -    break;}
  26804. -case 748:
  26805. -#line 3830 "parse.y"
  26806. -{ yyval.ttype = ansi_opname[PLUS_EXPR]; ;
  26807. -    break;}
  26808. -case 749:
  26809. -#line 3832 "parse.y"
  26810. -{ yyval.ttype = ansi_opname[MINUS_EXPR]; ;
  26811. -    break;}
  26812. -case 750:
  26813. -#line 3834 "parse.y"
  26814. -{ yyval.ttype = ansi_opname[BIT_AND_EXPR]; ;
  26815. -    break;}
  26816. -case 751:
  26817. -#line 3836 "parse.y"
  26818. -{ yyval.ttype = ansi_opname[BIT_IOR_EXPR]; ;
  26819. -    break;}
  26820. -case 752:
  26821. -#line 3838 "parse.y"
  26822. -{ yyval.ttype = ansi_opname[BIT_XOR_EXPR]; ;
  26823. -    break;}
  26824. -case 753:
  26825. -#line 3840 "parse.y"
  26826. -{ yyval.ttype = ansi_opname[BIT_NOT_EXPR]; ;
  26827. -    break;}
  26828. -case 754:
  26829. -#line 3842 "parse.y"
  26830. -{ yyval.ttype = ansi_opname[COMPOUND_EXPR]; ;
  26831. -    break;}
  26832. -case 755:
  26833. -#line 3844 "parse.y"
  26834. -{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
  26835. -    break;}
  26836. -case 756:
  26837. -#line 3846 "parse.y"
  26838. -{ yyval.ttype = ansi_opname[LT_EXPR]; ;
  26839. -    break;}
  26840. -case 757:
  26841. -#line 3848 "parse.y"
  26842. -{ yyval.ttype = ansi_opname[GT_EXPR]; ;
  26843. -    break;}
  26844. -case 758:
  26845. -#line 3850 "parse.y"
  26846. -{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
  26847. -    break;}
  26848. -case 759:
  26849. -#line 3852 "parse.y"
  26850. -{ yyval.ttype = ansi_assopname[yyvsp[0].code]; ;
  26851. -    break;}
  26852. -case 760:
  26853. -#line 3854 "parse.y"
  26854. -{ yyval.ttype = ansi_opname [MODIFY_EXPR]; ;
  26855. -    break;}
  26856. -case 761:
  26857. -#line 3856 "parse.y"
  26858. -{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
  26859. -    break;}
  26860. -case 762:
  26861. -#line 3858 "parse.y"
  26862. -{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
  26863. -    break;}
  26864. -case 763:
  26865. -#line 3860 "parse.y"
  26866. -{ yyval.ttype = ansi_opname[POSTINCREMENT_EXPR]; ;
  26867. -    break;}
  26868. -case 764:
  26869. -#line 3862 "parse.y"
  26870. -{ yyval.ttype = ansi_opname[PREDECREMENT_EXPR]; ;
  26871. -    break;}
  26872. -case 765:
  26873. -#line 3864 "parse.y"
  26874. -{ yyval.ttype = ansi_opname[TRUTH_ANDIF_EXPR]; ;
  26875. -    break;}
  26876. -case 766:
  26877. -#line 3866 "parse.y"
  26878. -{ yyval.ttype = ansi_opname[TRUTH_ORIF_EXPR]; ;
  26879. -    break;}
  26880. -case 767:
  26881. -#line 3868 "parse.y"
  26882. -{ yyval.ttype = ansi_opname[TRUTH_NOT_EXPR]; ;
  26883. -    break;}
  26884. -case 768:
  26885. -#line 3870 "parse.y"
  26886. -{ yyval.ttype = ansi_opname[COND_EXPR]; ;
  26887. -    break;}
  26888. -case 769:
  26889. -#line 3872 "parse.y"
  26890. -{ yyval.ttype = ansi_opname[yyvsp[0].code]; ;
  26891. -    break;}
  26892. -case 770:
  26893. -#line 3874 "parse.y"
  26894. -{ yyval.ttype = ansi_opname[COMPONENT_REF]; ;
  26895. -    break;}
  26896. -case 771:
  26897. -#line 3876 "parse.y"
  26898. -{ yyval.ttype = ansi_opname[MEMBER_REF]; ;
  26899. -    break;}
  26900. -case 772:
  26901. -#line 3878 "parse.y"
  26902. -{ yyval.ttype = ansi_opname[CALL_EXPR]; ;
  26903. -    break;}
  26904. -case 773:
  26905. -#line 3880 "parse.y"
  26906. -{ yyval.ttype = ansi_opname[ARRAY_REF]; ;
  26907. -    break;}
  26908. -case 774:
  26909. -#line 3882 "parse.y"
  26910. -{ yyval.ttype = ansi_opname[NEW_EXPR]; ;
  26911. -    break;}
  26912. -case 775:
  26913. -#line 3884 "parse.y"
  26914. -{ yyval.ttype = ansi_opname[DELETE_EXPR]; ;
  26915. -    break;}
  26916. -case 776:
  26917. -#line 3886 "parse.y"
  26918. -{ yyval.ttype = ansi_opname[VEC_NEW_EXPR]; ;
  26919. -    break;}
  26920. -case 777:
  26921. -#line 3888 "parse.y"
  26922. -{ yyval.ttype = ansi_opname[VEC_DELETE_EXPR]; ;
  26923. -    break;}
  26924. -case 778:
  26925. -#line 3891 "parse.y"
  26926. -{ yyval.ttype = grokoptypename (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  26927. -    break;}
  26928. -case 779:
  26929. -#line 3893 "parse.y"
  26930. -{ yyval.ttype = ansi_opname[ERROR_MARK]; ;
  26931. -    break;}
  26932. -}
  26933. -   /* the action file gets copied in in place of this dollarsign */
  26934. -#line 480 "/usr/local/lib/bison.simple"
  26935. -
  26936. -  yyvsp -= yylen;
  26937. -  yyssp -= yylen;
  26938. -#ifdef YYLSP_NEEDED
  26939. -  yylsp -= yylen;
  26940. -#endif
  26941. -
  26942. -#if YYDEBUG != 0
  26943. -  if (yydebug)
  26944. -    {
  26945. -      short *ssp1 = yyss - 1;
  26946. -      fprintf (stderr, "state stack now");
  26947. -      while (ssp1 != yyssp)
  26948. -    fprintf (stderr, " %d", *++ssp1);
  26949. -      fprintf (stderr, "\n");
  26950. -    }
  26951. -#endif
  26952. -
  26953. -  *++yyvsp = yyval;
  26954. -
  26955. -#ifdef YYLSP_NEEDED
  26956. -  yylsp++;
  26957. -  if (yylen == 0)
  26958. -    {
  26959. -      yylsp->first_line = yylloc.first_line;
  26960. -      yylsp->first_column = yylloc.first_column;
  26961. -      yylsp->last_line = (yylsp-1)->last_line;
  26962. -      yylsp->last_column = (yylsp-1)->last_column;
  26963. -      yylsp->text = 0;
  26964. -    }
  26965. -  else
  26966. -    {
  26967. -      yylsp->last_line = (yylsp+yylen-1)->last_line;
  26968. -      yylsp->last_column = (yylsp+yylen-1)->last_column;
  26969. -    }
  26970. -#endif
  26971. -
  26972. -  /* Now "shift" the result of the reduction.
  26973. -     Determine what state that goes to,
  26974. -     based on the state we popped back to
  26975. -     and the rule number reduced by.  */
  26976. -
  26977. -  yyn = yyr1[yyn];
  26978. -
  26979. -  yystate = yypgoto[yyn - YYNTBASE] + *yyssp;
  26980. -  if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp)
  26981. -    yystate = yytable[yystate];
  26982. -  else
  26983. -    yystate = yydefgoto[yyn - YYNTBASE];
  26984. -
  26985. -  goto yynewstate;
  26986. -
  26987. -yyerrlab:   /* here on detecting error */
  26988. -
  26989. -  if (! yyerrstatus)
  26990. -    /* If not already recovering from an error, report this error.  */
  26991. -    {
  26992. -      ++yynerrs;
  26993. -
  26994. -#ifdef YYERROR_VERBOSE
  26995. -      yyn = yypact[yystate];
  26996. -
  26997. -      if (yyn > YYFLAG && yyn < YYLAST)
  26998. -    {
  26999. -      int size = 0;
  27000. -      char *msg;
  27001. -      int x, count;
  27002. -
  27003. -      count = 0;
  27004. -      /* Start X at -yyn if nec to avoid negative indexes in yycheck.  */
  27005. -      for (x = (yyn < 0 ? -yyn : 0);
  27006. -           x < (sizeof(yytname) / sizeof(char *)); x++)
  27007. -        if (yycheck[x + yyn] == x)
  27008. -          size += strlen(yytname[x]) + 15, count++;
  27009. -      msg = (char *) malloc(size + 15);
  27010. -      if (msg != 0)
  27011. -        {
  27012. -          strcpy(msg, "parse error");
  27013. -
  27014. -          if (count < 5)
  27015. -        {
  27016. -          count = 0;
  27017. -          for (x = (yyn < 0 ? -yyn : 0);
  27018. -               x < (sizeof(yytname) / sizeof(char *)); x++)
  27019. -            if (yycheck[x + yyn] == x)
  27020. -              {
  27021. -            strcat(msg, count == 0 ? ", expecting `" : " or `");
  27022. -            strcat(msg, yytname[x]);
  27023. -            strcat(msg, "'");
  27024. -            count++;
  27025. -              }
  27026. -        }
  27027. -          yyerror(msg);
  27028. -          free(msg);
  27029. -        }
  27030. -      else
  27031. -        yyerror ("parse error; also virtual memory exceeded");
  27032. -    }
  27033. -      else
  27034. -#endif /* YYERROR_VERBOSE */
  27035. -    yyerror("parse error");
  27036. -    }
  27037. -
  27038. -  goto yyerrlab1;
  27039. -yyerrlab1:   /* here on error raised explicitly by an action */
  27040. -
  27041. -  if (yyerrstatus == 3)
  27042. -    {
  27043. -      /* if just tried and failed to reuse lookahead token after an error, discard it.  */
  27044. -
  27045. -      /* return failure if at end of input */
  27046. -      if (yychar == YYEOF)
  27047. -    YYABORT;
  27048. -
  27049. -#if YYDEBUG != 0
  27050. -      if (yydebug)
  27051. -    fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]);
  27052. -#endif
  27053. -
  27054. -      yychar = YYEMPTY;
  27055. -    }
  27056. -
  27057. -  /* Else will try to reuse lookahead token
  27058. -     after shifting the error token.  */
  27059. -
  27060. -  yyerrstatus = 3;        /* Each real token shifted decrements this */
  27061. -
  27062. -  goto yyerrhandle;
  27063. -
  27064. -yyerrdefault:  /* current state does not do anything special for the error token. */
  27065. -
  27066. -#if 0
  27067. -  /* This is wrong; only states that explicitly want error tokens
  27068. -     should shift them.  */
  27069. -  yyn = yydefact[yystate];  /* If its default is to accept any token, ok.  Otherwise pop it.*/
  27070. -  if (yyn) goto yydefault;
  27071. -#endif
  27072. -
  27073. -yyerrpop:   /* pop the current state because it cannot handle the error token */
  27074. -
  27075. -  if (yyssp == yyss) YYABORT;
  27076. -  yyvsp--;
  27077. -  yystate = *--yyssp;
  27078. -#ifdef YYLSP_NEEDED
  27079. -  yylsp--;
  27080. -#endif
  27081. -
  27082. -#if YYDEBUG != 0
  27083. -  if (yydebug)
  27084. -    {
  27085. -      short *ssp1 = yyss - 1;
  27086. -      fprintf (stderr, "Error: state stack now");
  27087. -      while (ssp1 != yyssp)
  27088. -    fprintf (stderr, " %d", *++ssp1);
  27089. -      fprintf (stderr, "\n");
  27090. -    }
  27091. -#endif
  27092. -
  27093. -yyerrhandle:
  27094. -
  27095. -  yyn = yypact[yystate];
  27096. -  if (yyn == YYFLAG)
  27097. -    goto yyerrdefault;
  27098. -
  27099. -  yyn += YYTERROR;
  27100. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR)
  27101. -    goto yyerrdefault;
  27102. -
  27103. -  yyn = yytable[yyn];
  27104. -  if (yyn < 0)
  27105. -    {
  27106. -      if (yyn == YYFLAG)
  27107. -    goto yyerrpop;
  27108. -      yyn = -yyn;
  27109. -      goto yyreduce;
  27110. -    }
  27111. -  else if (yyn == 0)
  27112. -    goto yyerrpop;
  27113. -
  27114. -  if (yyn == YYFINAL)
  27115. -    YYACCEPT;
  27116. -
  27117. -#if YYDEBUG != 0
  27118. -  if (yydebug)
  27119. -    fprintf(stderr, "Shifting error token, ");
  27120. -#endif
  27121. -
  27122. -  *++yyvsp = yylval;
  27123. -#ifdef YYLSP_NEEDED
  27124. -  *++yylsp = yylloc;
  27125. -#endif
  27126. -
  27127. -  yystate = yyn;
  27128. -  goto yynewstate;
  27129. -}
  27130. -#line 3896 "parse.y"
  27131. -
  27132. -
  27133. -#ifdef SPEW_DEBUG
  27134. -const char *
  27135. -debug_yytranslate (value)
  27136. -    int value;
  27137. -{
  27138. -  return yytname[YYTRANSLATE (value)];
  27139. -}
  27140. -
  27141. -#endif
  27142. diff -rup --new-file baseline/fsf/gcc/cp/parse.h amiga/fsf/gcc/cp/parse.h
  27143. --- baseline/fsf/gcc/cp/parse.h    Sun Nov  5 14:55:57 1995
  27144. +++ amiga/fsf/gcc/cp/parse.h    Wed Dec 31 17:00:00 1969
  27145. @@ -1,87 +0,0 @@
  27146. -typedef union {long itype; tree ttype; char *strtype; enum tree_code code; } YYSTYPE;
  27147. -#define    IDENTIFIER    258
  27148. -#define    TYPENAME    259
  27149. -#define    SCSPEC    260
  27150. -#define    TYPESPEC    261
  27151. -#define    TYPE_QUAL    262
  27152. -#define    CONSTANT    263
  27153. -#define    STRING    264
  27154. -#define    ELLIPSIS    265
  27155. -#define    SIZEOF    266
  27156. -#define    ENUM    267
  27157. -#define    IF    268
  27158. -#define    ELSE    269
  27159. -#define    WHILE    270
  27160. -#define    DO    271
  27161. -#define    FOR    272
  27162. -#define    SWITCH    273
  27163. -#define    CASE    274
  27164. -#define    DEFAULT    275
  27165. -#define    BREAK    276
  27166. -#define    CONTINUE    277
  27167. -#define    RETURN    278
  27168. -#define    GOTO    279
  27169. -#define    ASM_KEYWORD    280
  27170. -#define    GCC_ASM_KEYWORD    281
  27171. -#define    TYPEOF    282
  27172. -#define    ALIGNOF    283
  27173. -#define    SIGOF    284
  27174. -#define    ATTRIBUTE    285
  27175. -#define    EXTENSION    286
  27176. -#define    LABEL    287
  27177. -#define    AGGR    288
  27178. -#define    VISSPEC    289
  27179. -#define    DELETE    290
  27180. -#define    NEW    291
  27181. -#define    OVERLOAD    292
  27182. -#define    THIS    293
  27183. -#define    OPERATOR    294
  27184. -#define    CXX_TRUE    295
  27185. -#define    CXX_FALSE    296
  27186. -#define    NAMESPACE    297
  27187. -#define    TYPENAME_KEYWORD    298
  27188. -#define    USING    299
  27189. -#define    LEFT_RIGHT    300
  27190. -#define    TEMPLATE    301
  27191. -#define    TYPEID    302
  27192. -#define    DYNAMIC_CAST    303
  27193. -#define    STATIC_CAST    304
  27194. -#define    REINTERPRET_CAST    305
  27195. -#define    CONST_CAST    306
  27196. -#define    SCOPE    307
  27197. -#define    EMPTY    308
  27198. -#define    PTYPENAME    309
  27199. -#define    NSNAME    310
  27200. -#define    THROW    311
  27201. -#define    ASSIGN    312
  27202. -#define    OROR    313
  27203. -#define    ANDAND    314
  27204. -#define    MIN_MAX    315
  27205. -#define    EQCOMPARE    316
  27206. -#define    ARITHCOMPARE    317
  27207. -#define    LSHIFT    318
  27208. -#define    RSHIFT    319
  27209. -#define    POINTSAT_STAR    320
  27210. -#define    DOT_STAR    321
  27211. -#define    UNARY    322
  27212. -#define    PLUSPLUS    323
  27213. -#define    MINUSMINUS    324
  27214. -#define    HYPERUNARY    325
  27215. -#define    PAREN_STAR_PAREN    326
  27216. -#define    POINTSAT    327
  27217. -#define    TRY    328
  27218. -#define    CATCH    329
  27219. -#define    TYPENAME_ELLIPSIS    330
  27220. -#define    PRE_PARSED_FUNCTION_DECL    331
  27221. -#define    EXTERN_LANG_STRING    332
  27222. -#define    ALL    333
  27223. -#define    PRE_PARSED_CLASS_DECL    334
  27224. -#define    TYPENAME_DEFN    335
  27225. -#define    IDENTIFIER_DEFN    336
  27226. -#define    PTYPENAME_DEFN    337
  27227. -#define    END_OF_LINE    338
  27228. -#define    END_OF_SAVED_INPUT    339
  27229. -
  27230. -
  27231. -extern YYSTYPE yylval;
  27232. -#define YYEMPTY        -2
  27233. diff -rup --new-file baseline/fsf/gcc/cpp.info amiga/fsf/gcc/cpp.info
  27234. --- baseline/fsf/gcc/cpp.info    Mon Oct  9 10:11:38 1995
  27235. +++ amiga/fsf/gcc/cpp.info    Wed Dec 31 17:00:00 1969
  27236. @@ -1,75 +0,0 @@
  27237. -This is Info file cpp.info, produced by Makeinfo-1.55 from the input
  27238. -file cpp.texi.
  27239. -
  27240. -   This file documents the GNU C Preprocessor.
  27241. -
  27242. -   Copyright 1987, 1989, 1991, 1992, 1993, 1994, 1995 Free Software
  27243. -Foundation, Inc.
  27244. -
  27245. -   Permission is granted to make and distribute verbatim copies of this
  27246. -manual provided the copyright notice and this permission notice are
  27247. -preserved on all copies.
  27248. -
  27249. -   Permission is granted to copy and distribute modified versions of
  27250. -this manual under the conditions for verbatim copying, provided also
  27251. -that the entire resulting derived work is distributed under the terms
  27252. -of a permission notice identical to this one.
  27253. -
  27254. -   Permission is granted to copy and distribute translations of this
  27255. -manual into another language, under the above conditions for modified
  27256. -versions.
  27257. -
  27258. -
  27259. -Indirect:
  27260. -cpp.info-1: 790
  27261. -cpp.info-2: 50196
  27262. -cpp.info-3: 90181
  27263. -
  27264. -Tag Table:
  27265. -(Indirect)
  27266. -Node: Top790
  27267. -Node: Global Actions3362
  27268. -Node: Directives5882
  27269. -Node: Header Files7569
  27270. -Node: Header Uses8228
  27271. -Node: Include Syntax9720
  27272. -Node: Include Operation12862
  27273. -Node: Once-Only14724
  27274. -Node: Inheritance17149
  27275. -Node: Macros19711
  27276. -Node: Simple Macros20625
  27277. -Node: Argument Macros23613
  27278. -Node: Predefined29411
  27279. -Node: Standard Predefined29841
  27280. -Node: Nonstandard Predefined36978
  27281. -Node: Stringification40554
  27282. -Node: Concatenation43480
  27283. -Node: Undefining46753
  27284. -Node: Redefining47792
  27285. -Node: Macro Pitfalls49092
  27286. -Node: Misnesting50196
  27287. -Node: Macro Parentheses51210
  27288. -Node: Swallow Semicolon53087
  27289. -Node: Side Effects54987
  27290. -Node: Self-Reference56685
  27291. -Node: Argument Prescan58961
  27292. -Node: Cascaded Macros63963
  27293. -Node: Newlines in Args65108
  27294. -Node: Conditionals66453
  27295. -Node: Conditional Uses67805
  27296. -Node: Conditional Syntax69228
  27297. -Node: #if Directive69814
  27298. -Node: #else Directive72103
  27299. -Node: #elif Directive72770
  27300. -Node: Deleted Code74148
  27301. -Node: Conditionals-Macros75209
  27302. -Node: Assertions78894
  27303. -Node: #error Directive83129
  27304. -Node: Combining Sources84569
  27305. -Node: Other Directives87480
  27306. -Node: Output88942
  27307. -Node: Invocation90181
  27308. -Node: Concept Index102005
  27309. -Node: Index104809
  27310. -
  27311. -End Tag Table
  27312. diff -rup --new-file baseline/fsf/gcc/cpp.info-1 amiga/fsf/gcc/cpp.info-1
  27313. --- baseline/fsf/gcc/cpp.info-1    Mon Oct  9 10:11:36 1995
  27314. +++ amiga/fsf/gcc/cpp.info-1    Wed Dec 31 17:00:00 1969
  27315. @@ -1,1189 +0,0 @@
  27316. -This is Info file cpp.info, produced by Makeinfo-1.55 from the input
  27317. -file cpp.texi.
  27318. -
  27319. -   This file documents the GNU C Preprocessor.
  27320. -
  27321. -   Copyright 1987, 1989, 1991, 1992, 1993, 1994, 1995 Free Software
  27322. -Foundation, Inc.
  27323. -
  27324. -   Permission is granted to make and distribute verbatim copies of this
  27325. -manual provided the copyright notice and this permission notice are
  27326. -preserved on all copies.
  27327. -
  27328. -   Permission is granted to copy and distribute modified versions of
  27329. -this manual under the conditions for verbatim copying, provided also
  27330. -that the entire resulting derived work is distributed under the terms
  27331. -of a permission notice identical to this one.
  27332. -
  27333. -   Permission is granted to copy and distribute translations of this
  27334. -manual into another language, under the above conditions for modified
  27335. -versions.
  27336. -
  27337. -
  27338. -File: cpp.info,  Node: Top,  Next: Global Actions,  Up: (DIR)
  27339. -
  27340. -The C Preprocessor
  27341. -******************
  27342. -
  27343. -   The C preprocessor is a "macro processor" that is used automatically
  27344. -by the C compiler to transform your program before actual compilation.
  27345. -It is called a macro processor because it allows you to define "macros",
  27346. -which are brief abbreviations for longer constructs.
  27347. -
  27348. -   The C preprocessor provides four separate facilities that you can
  27349. -use as you see fit:
  27350. -
  27351. -   * Inclusion of header files.  These are files of declarations that
  27352. -     can be substituted into your program.
  27353. -
  27354. -   * Macro expansion.  You can define "macros", which are abbreviations
  27355. -     for arbitrary fragments of C code, and then the C preprocessor will
  27356. -     replace the macros with their definitions throughout the program.
  27357. -
  27358. -   * Conditional compilation.  Using special preprocessing directives,
  27359. -     you can include or exclude parts of the program according to
  27360. -     various conditions.
  27361. -
  27362. -   * Line control.  If you use a program to combine or rearrange source
  27363. -     files into an intermediate file which is then compiled, you can
  27364. -     use line control to inform the compiler of where each source line
  27365. -     originally came from.
  27366. -
  27367. -   C preprocessors vary in some details.  This manual discusses the GNU
  27368. -C preprocessor, the C Compatible Compiler Preprocessor.  The GNU C
  27369. -preprocessor provides a superset of the features of ANSI Standard C.
  27370. -
  27371. -   ANSI Standard C requires the rejection of many harmless constructs
  27372. -commonly used by today's C programs.  Such incompatibility would be
  27373. -inconvenient for users, so the GNU C preprocessor is configured to
  27374. -accept these constructs by default.  Strictly speaking, to get ANSI
  27375. -Standard C, you must use the options `-trigraphs', `-undef' and
  27376. -`-pedantic', but in practice the consequences of having strict ANSI
  27377. -Standard C make it undesirable to do this.  *Note Invocation::.
  27378. -
  27379. -* Menu:
  27380. -
  27381. -* Global Actions::    Actions made uniformly on all input files.
  27382. -* Directives::        General syntax of preprocessing directives.
  27383. -* Header Files::      How and why to use header files.
  27384. -* Macros::            How and why to use macros.
  27385. -* Conditionals::      How and why to use conditionals.
  27386. -* Combining Sources:: Use of line control when you combine source files.
  27387. -* Other Directives::  Miscellaneous preprocessing directives.
  27388. -* Output::            Format of output from the C preprocessor.
  27389. -* Invocation::        How to invoke the preprocessor; command options.
  27390. -* Concept Index::     Index of concepts and terms.
  27391. -* Index::             Index of directives, predefined macros and options.
  27392. -
  27393. -
  27394. -File: cpp.info,  Node: Global Actions,  Next: Directives,  Prev: Top,  Up: Top
  27395. -
  27396. -Transformations Made Globally
  27397. -=============================
  27398. -
  27399. -   Most C preprocessor features are inactive unless you give specific
  27400. -directives to request their use.  (Preprocessing directives are lines
  27401. -starting with `#'; *note Directives::.).  But there are three
  27402. -transformations that the preprocessor always makes on all the input it
  27403. -receives, even in the absence of directives.
  27404. -
  27405. -   * All C comments are replaced with single spaces.
  27406. -
  27407. -   * Backslash-Newline sequences are deleted, no matter where.  This
  27408. -     feature allows you to break long lines for cosmetic purposes
  27409. -     without changing their meaning.
  27410. -
  27411. -   * Predefined macro names are replaced with their expansions (*note
  27412. -     Predefined::.).
  27413. -
  27414. -   The first two transformations are done *before* nearly all other
  27415. -parsing and before preprocessing directives are recognized.  Thus, for
  27416. -example, you can split a line cosmetically with Backslash-Newline
  27417. -anywhere (except when trigraphs are in use; see below).
  27418. -
  27419. -     /*
  27420. -     */ # /*
  27421. -     */ defi\
  27422. -     ne FO\
  27423. -     O 10\
  27424. -     20
  27425. -
  27426. -is equivalent into `#define FOO 1020'.  You can split even an escape
  27427. -sequence with Backslash-Newline.  For example, you can split `"foo\bar"'
  27428. -between the `\' and the `b' to get
  27429. -
  27430. -     "foo\\
  27431. -     bar"
  27432. -
  27433. -This behavior is unclean: in all other contexts, a Backslash can be
  27434. -inserted in a string constant as an ordinary character by writing a
  27435. -double Backslash, and this creates an exception.  But the ANSI C
  27436. -standard requires it.  (Strict ANSI C does not allow Newlines in string
  27437. -constants, so they do not consider this a problem.)
  27438. -
  27439. -   But there are a few exceptions to all three transformations.
  27440. -
  27441. -   * C comments and predefined macro names are not recognized inside a
  27442. -     `#include' directive in which the file name is delimited with `<'
  27443. -     and `>'.
  27444. -
  27445. -   * C comments and predefined macro names are never recognized within a
  27446. -     character or string constant.  (Strictly speaking, this is the
  27447. -     rule, not an exception, but it is worth noting here anyway.)
  27448. -
  27449. -   * Backslash-Newline may not safely be used within an ANSI "trigraph".
  27450. -     Trigraphs are converted before Backslash-Newline is deleted.  If
  27451. -     you write what looks like a trigraph with a Backslash-Newline
  27452. -     inside, the Backslash-Newline is deleted as usual, but it is then
  27453. -     too late to recognize the trigraph.
  27454. -
  27455. -     This exception is relevant only if you use the `-trigraphs' option
  27456. -     to enable trigraph processing.  *Note Invocation::.
  27457. -
  27458. -
  27459. -File: cpp.info,  Node: Directives,  Next: Header Files,  Prev: Global Actions,  Up: Top
  27460. -
  27461. -Preprocessing Directives
  27462. -========================
  27463. -
  27464. -   Most preprocessor features are active only if you use preprocessing
  27465. -directives to request their use.
  27466. -
  27467. -   Preprocessing directives are lines in your program that start with
  27468. -`#'.  The `#' is followed by an identifier that is the "directive name".
  27469. -For example, `#define' is the directive that defines a macro.
  27470. -Whitespace is also allowed before and after the `#'.
  27471. -
  27472. -   The set of valid directive names is fixed.  Programs cannot define
  27473. -new preprocessing directives.
  27474. -
  27475. -   Some directive names require arguments; these make up the rest of
  27476. -the directive line and must be separated from the directive name by
  27477. -whitespace.  For example, `#define' must be followed by a macro name
  27478. -and the intended expansion of the macro.  *Note Simple Macros::.
  27479. -
  27480. -   A preprocessing directive cannot be more than one line in normal
  27481. -circumstances.  It may be split cosmetically with Backslash-Newline,
  27482. -but that has no effect on its meaning.  Comments containing Newlines
  27483. -can also divide the directive into multiple lines, but the comments are
  27484. -changed to Spaces before the directive is interpreted.  The only way a
  27485. -significant Newline can occur in a preprocessing directive is within a
  27486. -string constant or character constant.  Note that most C compilers that
  27487. -might be applied to the output from the preprocessor do not accept
  27488. -string or character constants containing Newlines.
  27489. -
  27490. -   The `#' and the directive name cannot come from a macro expansion.
  27491. -For example, if `foo' is defined as a macro expanding to `define', that
  27492. -does not make `#foo' a valid preprocessing directive.
  27493. -
  27494. -
  27495. -File: cpp.info,  Node: Header Files,  Next: Macros,  Prev: Directives,  Up: Top
  27496. -
  27497. -Header Files
  27498. -============
  27499. -
  27500. -   A header file is a file containing C declarations and macro
  27501. -definitions (*note Macros::.) to be shared between several source
  27502. -files.  You request the use of a header file in your program with the C
  27503. -preprocessing directive `#include'.
  27504. -
  27505. -* Menu:
  27506. -
  27507. -* Header Uses::         What header files are used for.
  27508. -* Include Syntax::      How to write `#include' directives.
  27509. -* Include Operation::   What `#include' does.
  27510. -* Once-Only::        Preventing multiple inclusion of one header file.
  27511. -* Inheritance::         Including one header file in another header file.
  27512. -
  27513. -
  27514. -File: cpp.info,  Node: Header Uses,  Next: Include Syntax,  Prev: Header Files,  Up: Header Files
  27515. -
  27516. -Uses of Header Files
  27517. ---------------------
  27518. -
  27519. -   Header files serve two kinds of purposes.
  27520. -
  27521. -   * System header files declare the interfaces to parts of the
  27522. -     operating system.  You include them in your program to supply the
  27523. -     definitions and declarations you need to invoke system calls and
  27524. -     libraries.
  27525. -
  27526. -   * Your own header files contain declarations for interfaces between
  27527. -     the source files of your program.  Each time you have a group of
  27528. -     related declarations and macro definitions all or most of which
  27529. -     are needed in several different source files, it is a good idea to
  27530. -     create a header file for them.
  27531. -
  27532. -   Including a header file produces the same results in C compilation as
  27533. -copying the header file into each source file that needs it.  But such
  27534. -copying would be time-consuming and error-prone.  With a header file,
  27535. -the related declarations appear in only one place.  If they need to be
  27536. -changed, they can be changed in one place, and programs that include
  27537. -the header file will automatically use the new version when next
  27538. -recompiled.  The header file eliminates the labor of finding and
  27539. -changing all the copies as well as the risk that a failure to find one
  27540. -copy will result in inconsistencies within a program.
  27541. -
  27542. -   The usual convention is to give header files names that end with
  27543. -`.h'.  Avoid unusual characters in header file names, as they reduce
  27544. -portability.
  27545. -
  27546. -
  27547. -File: cpp.info,  Node: Include Syntax,  Next: Include Operation,  Prev: Header Uses,  Up: Header Files
  27548. -
  27549. -The `#include' Directive
  27550. -------------------------
  27551. -
  27552. -   Both user and system header files are included using the
  27553. -preprocessing directive `#include'.  It has three variants:
  27554. -
  27555. -`#include <FILE>'
  27556. -     This variant is used for system header files.  It searches for a
  27557. -     file named FILE in a list of directories specified by you, then in
  27558. -     a standard list of system directories.  You specify directories to
  27559. -     search for header files with the command option `-I' (*note
  27560. -     Invocation::.).  The option `-nostdinc' inhibits searching the
  27561. -     standard system directories; in this case only the directories you
  27562. -     specify are searched.
  27563. -
  27564. -     The parsing of this form of `#include' is slightly special because
  27565. -     comments are not recognized within the `<...>'.  Thus, in
  27566. -     `#include <x/*y>' the `/*' does not start a comment and the
  27567. -     directive specifies inclusion of a system header file named
  27568. -     `x/*y'.  Of course, a header file with such a name is unlikely to
  27569. -     exist on Unix, where shell wildcard features would make it hard to
  27570. -     manipulate.
  27571. -
  27572. -     The argument FILE may not contain a `>' character.  It may,
  27573. -     however, contain a `<' character.
  27574. -
  27575. -`#include "FILE"'
  27576. -     This variant is used for header files of your own program.  It
  27577. -     searches for a file named FILE first in the current directory,
  27578. -     then in the same directories used for system header files.  The
  27579. -     current directory is the directory of the current input file.  It
  27580. -     is tried first because it is presumed to be the location of the
  27581. -     files that the current input file refers to.  (If the `-I-' option
  27582. -     is used, the special treatment of the current directory is
  27583. -     inhibited.)
  27584. -
  27585. -     The argument FILE may not contain `"' characters.  If backslashes
  27586. -     occur within FILE, they are considered ordinary text characters,
  27587. -     not escape characters.  None of the character escape sequences
  27588. -     appropriate to string constants in C are processed.  Thus,
  27589. -     `#include "x\n\\y"' specifies a filename containing three
  27590. -     backslashes.  It is not clear why this behavior is ever useful, but
  27591. -     the ANSI standard specifies it.
  27592. -
  27593. -`#include ANYTHING ELSE'
  27594. -     This variant is called a "computed #include".  Any `#include'
  27595. -     directive whose argument does not fit the above two forms is a
  27596. -     computed include.  The text ANYTHING ELSE is checked for macro
  27597. -     calls, which are expanded (*note Macros::.).  When this is done,
  27598. -     the result must fit one of the above two variants--in particular,
  27599. -     the expanded text must in the end be surrounded by either quotes
  27600. -     or angle braces.
  27601. -
  27602. -     This feature allows you to define a macro which controls the file
  27603. -     name to be used at a later point in the program.  One application
  27604. -     of this is to allow a site-specific configuration file for your
  27605. -     program to specify the names of the system include files to be
  27606. -     used.  This can help in porting the program to various operating
  27607. -     systems in which the necessary system header files are found in
  27608. -     different places.
  27609. -
  27610. -
  27611. -File: cpp.info,  Node: Include Operation,  Next: Once-Only,  Prev: Include Syntax,  Up: Header Files
  27612. -
  27613. -How `#include' Works
  27614. ---------------------
  27615. -
  27616. -   The `#include' directive works by directing the C preprocessor to
  27617. -scan the specified file as input before continuing with the rest of the
  27618. -current file.  The output from the preprocessor contains the output
  27619. -already generated, followed by the output resulting from the included
  27620. -file, followed by the output that comes from the text after the
  27621. -`#include' directive.  For example, given a header file `header.h' as
  27622. -follows,
  27623. -
  27624. -     char *test ();
  27625. -
  27626. -and a main program called `program.c' that uses the header file, like
  27627. -this,
  27628. -
  27629. -     int x;
  27630. -     #include "header.h"
  27631. -     
  27632. -     main ()
  27633. -     {
  27634. -       printf (test ());
  27635. -     }
  27636. -
  27637. -the output generated by the C preprocessor for `program.c' as input
  27638. -would be
  27639. -
  27640. -     int x;
  27641. -     char *test ();
  27642. -     
  27643. -     main ()
  27644. -     {
  27645. -       printf (test ());
  27646. -     }
  27647. -
  27648. -   Included files are not limited to declarations and macro
  27649. -definitions; those are merely the typical uses.  Any fragment of a C
  27650. -program can be included from another file.  The include file could even
  27651. -contain the beginning of a statement that is concluded in the
  27652. -containing file, or the end of a statement that was started in the
  27653. -including file.  However, a comment or a string or character constant
  27654. -may not start in the included file and finish in the including file.
  27655. -An unterminated comment, string constant or character constant in an
  27656. -included file is considered to end (with an error message) at the end
  27657. -of the file.
  27658. -
  27659. -   It is possible for a header file to begin or end a syntactic unit
  27660. -such as a function definition, but that would be very confusing, so
  27661. -don't do it.
  27662. -
  27663. -   The line following the `#include' directive is always treated as a
  27664. -separate line by the C preprocessor even if the included file lacks a
  27665. -final newline.
  27666. -
  27667. -
  27668. -File: cpp.info,  Node: Once-Only,  Next: Inheritance,  Prev: Include Operation,  Up: Header Files
  27669. -
  27670. -Once-Only Include Files
  27671. ------------------------
  27672. -
  27673. -   Very often, one header file includes another.  It can easily result
  27674. -that a certain header file is included more than once.  This may lead
  27675. -to errors, if the header file defines structure types or typedefs, and
  27676. -is certainly wasteful.  Therefore, we often wish to prevent multiple
  27677. -inclusion of a header file.
  27678. -
  27679. -   The standard way to do this is to enclose the entire real contents
  27680. -of the file in a conditional, like this:
  27681. -
  27682. -     #ifndef FILE_FOO_SEEN
  27683. -     #define FILE_FOO_SEEN
  27684. -     
  27685. -     THE ENTIRE FILE
  27686. -     
  27687. -     #endif /* FILE_FOO_SEEN */
  27688. -
  27689. -   The macro `FILE_FOO_SEEN' indicates that the file has been included
  27690. -once already.  In a user header file, the macro name should not begin
  27691. -with `_'.  In a system header file, this name should begin with `__' to
  27692. -avoid conflicts with user programs.  In any kind of header file, the
  27693. -macro name should contain the name of the file and some additional
  27694. -text, to avoid conflicts with other header files.
  27695. -
  27696. -   The GNU C preprocessor is programmed to notice when a header file
  27697. -uses this particular construct and handle it efficiently.  If a header
  27698. -file is contained entirely in a `#ifndef' conditional, then it records
  27699. -that fact.  If a subsequent `#include' specifies the same file, and the
  27700. -macro in the `#ifndef' is already defined, then the file is entirely
  27701. -skipped, without even reading it.
  27702. -
  27703. -   There is also an explicit directive to tell the preprocessor that it
  27704. -need not include a file more than once.  This is called `#pragma once',
  27705. -and was used *in addition to* the `#ifndef' conditional around the
  27706. -contents of the header file.  `#pragma once' is now obsolete and should
  27707. -not be used at all.
  27708. -
  27709. -   In the Objective C language, there is a variant of `#include' called
  27710. -`#import' which includes a file, but does so at most once.  If you use
  27711. -`#import' *instead of* `#include', then you don't need the conditionals
  27712. -inside the header file to prevent multiple execution of the contents.
  27713. -
  27714. -   `#import' is obsolete because it is not a well designed feature.  It
  27715. -requires the users of a header file--the applications programmers--to
  27716. -know that a certain header file should only be included once.  It is
  27717. -much better for the header file's implementor to write the file so that
  27718. -users don't need to know this.  Using `#ifndef' accomplishes this goal.
  27719. -
  27720. -
  27721. -File: cpp.info,  Node: Inheritance,  Prev: Once-Only,  Up: Header Files
  27722. -
  27723. -Inheritance and Header Files
  27724. -----------------------------
  27725. -
  27726. -   "Inheritance" is what happens when one object or file derives some
  27727. -of its contents by virtual copying from another object or file.  In the
  27728. -case of C header files, inheritance means that one header file includes
  27729. -another header file and then replaces or adds something.
  27730. -
  27731. -   If the inheriting header file and the base header file have different
  27732. -names, then inheritance is straightforward: simply write `#include
  27733. -"BASE"' in the inheriting file.
  27734. -
  27735. -   Sometimes it is necessary to give the inheriting file the same name
  27736. -as the base file.  This is less straightforward.
  27737. -
  27738. -   For example, suppose an application program uses the system header
  27739. -file `sys/signal.h', but the version of `/usr/include/sys/signal.h' on
  27740. -a particular system doesn't do what the application program expects.
  27741. -It might be convenient to define a "local" version, perhaps under the
  27742. -name `/usr/local/include/sys/signal.h', to override or add to the one
  27743. -supplied by the system.
  27744. -
  27745. -   You can do this by using the option `-I.' for compilation, and
  27746. -writing a file `sys/signal.h' that does what the application program
  27747. -expects.  But making this file include the standard `sys/signal.h' is
  27748. -not so easy--writing `#include <sys/signal.h>' in that file doesn't
  27749. -work, because it includes your own version of the file, not the
  27750. -standard system version.  Used in that file itself, this leads to an
  27751. -infinite recursion and a fatal error in compilation.
  27752. -
  27753. -   `#include </usr/include/sys/signal.h>' would find the proper file,
  27754. -but that is not clean, since it makes an assumption about where the
  27755. -system header file is found.  This is bad for maintenance, since it
  27756. -means that any change in where the system's header files are kept
  27757. -requires a change somewhere else.
  27758. -
  27759. -   The clean way to solve this problem is to use `#include_next', which
  27760. -means, "Include the *next* file with this name."  This directive works
  27761. -like `#include' except in searching for the specified file: it starts
  27762. -searching the list of header file directories *after* the directory in
  27763. -which the current file was found.
  27764. -
  27765. -   Suppose you specify `-I /usr/local/include', and the list of
  27766. -directories to search also includes `/usr/include'; and suppose that
  27767. -both directories contain a file named `sys/signal.h'.  Ordinary
  27768. -`#include <sys/signal.h>' finds the file under `/usr/local/include'.
  27769. -If that file contains `#include_next <sys/signal.h>', it starts
  27770. -searching after that directory, and finds the file in `/usr/include'.
  27771. -
  27772. -
  27773. -File: cpp.info,  Node: Macros,  Next: Conditionals,  Prev: Header Files,  Up: Top
  27774. -
  27775. -Macros
  27776. -======
  27777. -
  27778. -   A macro is a sort of abbreviation which you can define once and then
  27779. -use later.  There are many complicated features associated with macros
  27780. -in the C preprocessor.
  27781. -
  27782. -* Menu:
  27783. -
  27784. -* Simple Macros::    Macros that always expand the same way.
  27785. -* Argument Macros::  Macros that accept arguments that are substituted
  27786. -                       into the macro expansion.
  27787. -* Predefined::       Predefined macros that are always available.
  27788. -* Stringification::  Macro arguments converted into string constants.
  27789. -* Concatenation::    Building tokens from parts taken from macro arguments.
  27790. -* Undefining::       Cancelling a macro's definition.
  27791. -* Redefining::       Changing a macro's definition.
  27792. -* Macro Pitfalls::   Macros can confuse the unwary.  Here we explain
  27793. -                       several common problems and strange features.
  27794. -
  27795. -
  27796. -File: cpp.info,  Node: Simple Macros,  Next: Argument Macros,  Prev: Macros,  Up: Macros
  27797. -
  27798. -Simple Macros
  27799. --------------
  27800. -
  27801. -   A "simple macro" is a kind of abbreviation.  It is a name which
  27802. -stands for a fragment of code.  Some people refer to these as "manifest
  27803. -constants".
  27804. -
  27805. -   Before you can use a macro, you must "define" it explicitly with the
  27806. -`#define' directive.  `#define' is followed by the name of the macro
  27807. -and then the code it should be an abbreviation for.  For example,
  27808. -
  27809. -     #define BUFFER_SIZE 1020
  27810. -
  27811. -defines a macro named `BUFFER_SIZE' as an abbreviation for the text
  27812. -`1020'.  If somewhere after this `#define' directive there comes a C
  27813. -statement of the form
  27814. -
  27815. -     foo = (char *) xmalloc (BUFFER_SIZE);
  27816. -
  27817. -then the C preprocessor will recognize and "expand" the macro
  27818. -`BUFFER_SIZE', resulting in
  27819. -
  27820. -     foo = (char *) xmalloc (1020);
  27821. -
  27822. -   The use of all upper case for macro names is a standard convention.
  27823. -Programs are easier to read when it is possible to tell at a glance
  27824. -which names are macros.
  27825. -
  27826. -   Normally, a macro definition must be a single line, like all C
  27827. -preprocessing directives.  (You can split a long macro definition
  27828. -cosmetically with Backslash-Newline.)  There is one exception: Newlines
  27829. -can be included in the macro definition if within a string or character
  27830. -constant.  This is because it is not possible for a macro definition to
  27831. -contain an unbalanced quote character; the definition automatically
  27832. -extends to include the matching quote character that ends the string or
  27833. -character constant.  Comments within a macro definition may contain
  27834. -Newlines, which make no difference since the comments are entirely
  27835. -replaced with Spaces regardless of their contents.
  27836. -
  27837. -   Aside from the above, there is no restriction on what can go in a
  27838. -macro body.  Parentheses need not balance.  The body need not resemble
  27839. -valid C code.  (But if it does not, you may get error messages from the
  27840. -C compiler when you use the macro.)
  27841. -
  27842. -   The C preprocessor scans your program sequentially, so macro
  27843. -definitions take effect at the place you write them.  Therefore, the
  27844. -following input to the C preprocessor
  27845. -
  27846. -     foo = X;
  27847. -     #define X 4
  27848. -     bar = X;
  27849. -
  27850. -produces as output
  27851. -
  27852. -     foo = X;
  27853. -     
  27854. -     bar = 4;
  27855. -
  27856. -   After the preprocessor expands a macro name, the macro's definition
  27857. -body is appended to the front of the remaining input, and the check for
  27858. -macro calls continues.  Therefore, the macro body can contain calls to
  27859. -other macros.  For example, after
  27860. -
  27861. -     #define BUFSIZE 1020
  27862. -     #define TABLESIZE BUFSIZE
  27863. -
  27864. -the name `TABLESIZE' when used in the program would go through two
  27865. -stages of expansion, resulting ultimately in `1020'.
  27866. -
  27867. -   This is not at all the same as defining `TABLESIZE' to be `1020'.
  27868. -The `#define' for `TABLESIZE' uses exactly the body you specify--in
  27869. -this case, `BUFSIZE'--and does not check to see whether it too is the
  27870. -name of a macro.  It's only when you *use* `TABLESIZE' that the result
  27871. -of its expansion is checked for more macro names.  *Note Cascaded
  27872. -Macros::.
  27873. -
  27874. -
  27875. -File: cpp.info,  Node: Argument Macros,  Next: Predefined,  Prev: Simple Macros,  Up: Macros
  27876. -
  27877. -Macros with Arguments
  27878. ----------------------
  27879. -
  27880. -   A simple macro always stands for exactly the same text, each time it
  27881. -is used.  Macros can be more flexible when they accept "arguments".
  27882. -Arguments are fragments of code that you supply each time the macro is
  27883. -used.  These fragments are included in the expansion of the macro
  27884. -according to the directions in the macro definition.  A macro that
  27885. -accepts arguments is called a "function-like macro" because the syntax
  27886. -for using it looks like a function call.
  27887. -
  27888. -   To define a macro that uses arguments, you write a `#define'
  27889. -directive with a list of "argument names" in parentheses after the name
  27890. -of the macro.  The argument names may be any valid C identifiers,
  27891. -separated by commas and optionally whitespace.  The open-parenthesis
  27892. -must follow the macro name immediately, with no space in between.
  27893. -
  27894. -   For example, here is a macro that computes the minimum of two numeric
  27895. -values, as it is defined in many C programs:
  27896. -
  27897. -     #define min(X, Y)  ((X) < (Y) ? (X) : (Y))
  27898. -
  27899. -(This is not the best way to define a "minimum" macro in GNU C.  *Note
  27900. -Side Effects::, for more information.)
  27901. -
  27902. -   To use a macro that expects arguments, you write the name of the
  27903. -macro followed by a list of "actual arguments" in parentheses,
  27904. -separated by commas.  The number of actual arguments you give must
  27905. -match the number of arguments the macro expects.   Examples of use of
  27906. -the macro `min' include `min (1, 2)' and `min (x + 28, *p)'.
  27907. -
  27908. -   The expansion text of the macro depends on the arguments you use.
  27909. -Each of the argument names of the macro is replaced, throughout the
  27910. -macro definition, with the corresponding actual argument.  Using the
  27911. -same macro `min' defined above, `min (1, 2)' expands into
  27912. -
  27913. -     ((1) < (2) ? (1) : (2))
  27914. -
  27915. -where `1' has been substituted for `X' and `2' for `Y'.
  27916. -
  27917. -   Likewise, `min (x + 28, *p)' expands into
  27918. -
  27919. -     ((x + 28) < (*p) ? (x + 28) : (*p))
  27920. -
  27921. -   Parentheses in the actual arguments must balance; a comma within
  27922. -parentheses does not end an argument.  However, there is no requirement
  27923. -for brackets or braces to balance, and they do not prevent a comma from
  27924. -separating arguments.  Thus,
  27925. -
  27926. -     macro (array[x = y, x + 1])
  27927. -
  27928. -passes two arguments to `macro': `array[x = y' and `x + 1]'.  If you
  27929. -want to supply `array[x = y, x + 1]' as an argument, you must write it
  27930. -as `array[(x = y, x + 1)]', which is equivalent C code.
  27931. -
  27932. -   After the actual arguments are substituted into the macro body, the
  27933. -entire result is appended to the front of the remaining input, and the
  27934. -check for macro calls continues.  Therefore, the actual arguments can
  27935. -contain calls to other macros, either with or without arguments, or
  27936. -even to the same macro.  The macro body can also contain calls to other
  27937. -macros.  For example, `min (min (a, b), c)' expands into this text:
  27938. -
  27939. -     ((((a) < (b) ? (a) : (b))) < (c)
  27940. -      ? (((a) < (b) ? (a) : (b)))
  27941. -      : (c))
  27942. -
  27943. -(Line breaks shown here for clarity would not actually be generated.)
  27944. -
  27945. -   If a macro `foo' takes one argument, and you want to supply an empty
  27946. -argument, you must write at least some whitespace between the
  27947. -parentheses, like this: `foo ( )'.  Just `foo ()' is providing no
  27948. -arguments, which is an error if `foo' expects an argument.  But `foo0
  27949. -()' is the correct way to call a macro defined to take zero arguments,
  27950. -like this:
  27951. -
  27952. -     #define foo0() ...
  27953. -
  27954. -   If you use the macro name followed by something other than an
  27955. -open-parenthesis (after ignoring any spaces, tabs and comments that
  27956. -follow), it is not a call to the macro, and the preprocessor does not
  27957. -change what you have written.  Therefore, it is possible for the same
  27958. -name to be a variable or function in your program as well as a macro,
  27959. -and you can choose in each instance whether to refer to the macro (if
  27960. -an actual argument list follows) or the variable or function (if an
  27961. -argument list does not follow).
  27962. -
  27963. -   Such dual use of one name could be confusing and should be avoided
  27964. -except when the two meanings are effectively synonymous: that is, when
  27965. -the name is both a macro and a function and the two have similar
  27966. -effects.  You can think of the name simply as a function; use of the
  27967. -name for purposes other than calling it (such as, to take the address)
  27968. -will refer to the function, while calls will expand the macro and
  27969. -generate better but equivalent code.  For example, you can use a
  27970. -function named `min' in the same source file that defines the macro.
  27971. -If you write `&min' with no argument list, you refer to the function.
  27972. -If you write `min (x, bb)', with an argument list, the macro is
  27973. -expanded.  If you write `(min) (a, bb)', where the name `min' is not
  27974. -followed by an open-parenthesis, the macro is not expanded, so you wind
  27975. -up with a call to the function `min'.
  27976. -
  27977. -   You may not define the same name as both a simple macro and a macro
  27978. -with arguments.
  27979. -
  27980. -   In the definition of a macro with arguments, the list of argument
  27981. -names must follow the macro name immediately with no space in between.
  27982. -If there is a space after the macro name, the macro is defined as
  27983. -taking no arguments, and all the rest of the line is taken to be the
  27984. -expansion.  The reason for this is that it is often useful to define a
  27985. -macro that takes no arguments and whose definition begins with an
  27986. -identifier in parentheses.  This rule about spaces makes it possible
  27987. -for you to do either this:
  27988. -
  27989. -     #define FOO(x) - 1 / (x)
  27990. -
  27991. -(which defines `FOO' to take an argument and expand into minus the
  27992. -reciprocal of that argument) or this:
  27993. -
  27994. -     #define BAR (x) - 1 / (x)
  27995. -
  27996. -(which defines `BAR' to take no argument and always expand into `(x) -
  27997. -1 / (x)').
  27998. -
  27999. -   Note that the *uses* of a macro with arguments can have spaces before
  28000. -the left parenthesis; it's the *definition* where it matters whether
  28001. -there is a space.
  28002. -
  28003. -
  28004. -File: cpp.info,  Node: Predefined,  Next: Stringification,  Prev: Argument Macros,  Up: Macros
  28005. -
  28006. -Predefined Macros
  28007. ------------------
  28008. -
  28009. -   Several simple macros are predefined.  You can use them without
  28010. -giving definitions for them.  They fall into two classes: standard
  28011. -macros and system-specific macros.
  28012. -
  28013. -* Menu:
  28014. -
  28015. -* Standard Predefined::     Standard predefined macros.
  28016. -* Nonstandard Predefined::  Nonstandard predefined macros.
  28017. -
  28018. -
  28019. -File: cpp.info,  Node: Standard Predefined,  Next: Nonstandard Predefined,  Prev: Predefined,  Up: Predefined
  28020. -
  28021. -Standard Predefined Macros
  28022. -..........................
  28023. -
  28024. -   The standard predefined macros are available with the same meanings
  28025. -regardless of the machine or operating system on which you are using
  28026. -GNU C.  Their names all start and end with double underscores.  Those
  28027. -preceding `__GNUC__' in this table are standardized by ANSI C; the rest
  28028. -are GNU C extensions.
  28029. -
  28030. -`__FILE__'
  28031. -     This macro expands to the name of the current input file, in the
  28032. -     form of a C string constant.  The precise name returned is the one
  28033. -     that was specified in `#include' or as the input file name
  28034. -     argument.
  28035. -
  28036. -`__LINE__'
  28037. -     This macro expands to the current input line number, in the form
  28038. -     of a decimal integer constant.  While we call it a predefined
  28039. -     macro, it's a pretty strange macro, since its "definition" changes
  28040. -     with each new line of source code.
  28041. -
  28042. -     This and `__FILE__' are useful in generating an error message to
  28043. -     report an inconsistency detected by the program; the message can
  28044. -     state the source line at which the inconsistency was detected.
  28045. -     For example,
  28046. -
  28047. -          fprintf (stderr, "Internal error: "
  28048. -                           "negative string length "
  28049. -                           "%d at %s, line %d.",
  28050. -                   length, __FILE__, __LINE__);
  28051. -
  28052. -     A `#include' directive changes the expansions of `__FILE__' and
  28053. -     `__LINE__' to correspond to the included file.  At the end of that
  28054. -     file, when processing resumes on the input file that contained the
  28055. -     `#include' directive, the expansions of `__FILE__' and `__LINE__'
  28056. -     revert to the values they had before the `#include' (but
  28057. -     `__LINE__' is then incremented by one as processing moves to the
  28058. -     line after the `#include').
  28059. -
  28060. -     The expansions of both `__FILE__' and `__LINE__' are altered if a
  28061. -     `#line' directive is used.  *Note Combining Sources::.
  28062. -
  28063. -`__DATE__'
  28064. -     This macro expands to a string constant that describes the date on
  28065. -     which the preprocessor is being run.  The string constant contains
  28066. -     eleven characters and looks like `"Jan 29 1987"' or `"Apr 1 1905"'.
  28067. -
  28068. -`__TIME__'
  28069. -     This macro expands to a string constant that describes the time at
  28070. -     which the preprocessor is being run.  The string constant contains
  28071. -     eight characters and looks like `"23:59:01"'.
  28072. -
  28073. -`__STDC__'
  28074. -     This macro expands to the constant 1, to signify that this is ANSI
  28075. -     Standard C.  (Whether that is actually true depends on what C
  28076. -     compiler will operate on the output from the preprocessor.)
  28077. -
  28078. -`__STDC_VERSION__'
  28079. -     This macro expands to the C Standard's version number, a long
  28080. -     integer constant of the form `YYYYMML' where YYYY and MM are the
  28081. -     year and month of the Standard version.  This signifies which
  28082. -     version of the C Standard the preprocessor conforms to.  Like
  28083. -     `__STDC__', whether this version number is accurate for the entire
  28084. -     implementation depends on what C compiler will operate on the
  28085. -     output from the preprocessor.
  28086. -
  28087. -`__GNUC__'
  28088. -     This macro is defined if and only if this is GNU C.  This macro is
  28089. -     defined only when the entire GNU C compiler is in use; if you
  28090. -     invoke the preprocessor directly, `__GNUC__' is undefined.  The
  28091. -     value identifies the major version number of GNU CC (`1' for GNU CC
  28092. -     version 1, which is now obsolete, and `2' for version 2).
  28093. -
  28094. -`__GNUC_MINOR__'
  28095. -     The macro contains the minor version number of the compiler.  This
  28096. -     can be used to work around differences between different releases
  28097. -     of the compiler (for example, if gcc 2.6.3 is known to support a
  28098. -     feature, you can test for `__GNUC__ > 2 || (__GNUC__ == 2 &&
  28099. -     __GNUC_MINOR__ >= 6)').  The last number, `3' in the example
  28100. -     above, denotes the bugfix level of the compiler; no macro contains
  28101. -     this value.
  28102. -
  28103. -`__GNUG__'
  28104. -     The GNU C compiler defines this when the compilation language is
  28105. -     C++; use `__GNUG__' to distinguish between GNU C and GNU C++.
  28106. -
  28107. -`__cplusplus'
  28108. -     The draft ANSI standard for C++ used to require predefining this
  28109. -     variable.  Though it is no longer required, GNU C++ continues to
  28110. -     define it, as do other popular C++ compilers.  You can use
  28111. -     `__cplusplus' to test whether a header is compiled by a C compiler
  28112. -     or a C++ compiler.
  28113. -
  28114. -`__STRICT_ANSI__'
  28115. -     This macro is defined if and only if the `-ansi' switch was
  28116. -     specified when GNU C was invoked.  Its definition is the null
  28117. -     string.  This macro exists primarily to direct certain GNU header
  28118. -     files not to define certain traditional Unix constructs which are
  28119. -     incompatible with ANSI C.
  28120. -
  28121. -`__BASE_FILE__'
  28122. -     This macro expands to the name of the main input file, in the form
  28123. -     of a C string constant.  This is the source file that was specified
  28124. -     as an argument when the C compiler was invoked.
  28125. -
  28126. -`__INCLUDE_LEVEL__'
  28127. -     This macro expands to a decimal integer constant that represents
  28128. -     the depth of nesting in include files.  The value of this macro is
  28129. -     incremented on every `#include' directive and decremented at every
  28130. -     end of file.  For input files specified by command line arguments,
  28131. -     the nesting level is zero.
  28132. -
  28133. -`__VERSION__'
  28134. -     This macro expands to a string which describes the version number
  28135. -     of GNU C.  The string is normally a sequence of decimal numbers
  28136. -     separated by periods, such as `"2.6.0"'.  The only reasonable use
  28137. -     of this macro is to incorporate it into a string constant.
  28138. -
  28139. -`__OPTIMIZE__'
  28140. -     This macro is defined in optimizing compilations.  It causes
  28141. -     certain GNU header files to define alternative macro definitions
  28142. -     for some system library functions.  It is unwise to refer to or
  28143. -     test the definition of this macro unless you make very sure that
  28144. -     programs will execute with the same effect regardless.
  28145. -
  28146. -`__CHAR_UNSIGNED__'
  28147. -     This macro is defined if and only if the data type `char' is
  28148. -     unsigned on the target machine.  It exists to cause the standard
  28149. -     header file `limit.h' to work correctly.  It is bad practice to
  28150. -     refer to this macro yourself; instead, refer to the standard
  28151. -     macros defined in `limit.h'.  The preprocessor uses this macro to
  28152. -     determine whether or not to sign-extend large character constants
  28153. -     written in octal; see *Note The `#if' Directive: #if Directive.
  28154. -
  28155. -`__REGISTER_PREFIX__'
  28156. -     This macro expands to a string describing the prefix applied to cpu
  28157. -     registers in assembler code.  It can be used to write assembler
  28158. -     code that is usable in multiple environments.  For example, in the
  28159. -     `m68k-aout' environment it expands to the string `""', but in the
  28160. -     `m68k-coff' environment it expands to the string `"%"'.
  28161. -
  28162. -`__USER_LABEL_PREFIX__'
  28163. -     This macro expands to a string describing the prefix applied to
  28164. -     user generated labels in assembler code.  It can be used to write
  28165. -     assembler code that is usable in multiple environments.  For
  28166. -     example, in the `m68k-aout' environment it expands to the string
  28167. -     `"_"', but in the `m68k-coff' environment it expands to the string
  28168. -     `""'.
  28169. -
  28170. -
  28171. -File: cpp.info,  Node: Nonstandard Predefined,  Prev: Standard Predefined,  Up: Predefined
  28172. -
  28173. -Nonstandard Predefined Macros
  28174. -.............................
  28175. -
  28176. -   The C preprocessor normally has several predefined macros that vary
  28177. -between machines because their purpose is to indicate what type of
  28178. -system and machine is in use.  This manual, being for all systems and
  28179. -machines, cannot tell you exactly what their names are; instead, we
  28180. -offer a list of some typical ones.  You can use `cpp -dM' to see the
  28181. -values of predefined macros; see *Note Invocation::.
  28182. -
  28183. -   Some nonstandard predefined macros describe the operating system in
  28184. -use, with more or less specificity.  For example,
  28185. -
  28186. -`unix'
  28187. -     `unix' is normally predefined on all Unix systems.
  28188. -
  28189. -`BSD'
  28190. -     `BSD' is predefined on recent versions of Berkeley Unix (perhaps
  28191. -     only in version 4.3).
  28192. -
  28193. -   Other nonstandard predefined macros describe the kind of CPU, with
  28194. -more or less specificity.  For example,
  28195. -
  28196. -`vax'
  28197. -     `vax' is predefined on Vax computers.
  28198. -
  28199. -`mc68000'
  28200. -     `mc68000' is predefined on most computers whose CPU is a Motorola
  28201. -     68000, 68010 or 68020.
  28202. -
  28203. -`m68k'
  28204. -     `m68k' is also predefined on most computers whose CPU is a 68000,
  28205. -     68010 or 68020; however, some makers use `mc68000' and some use
  28206. -     `m68k'.  Some predefine both names.  What happens in GNU C depends
  28207. -     on the system you are using it on.
  28208. -
  28209. -`M68020'
  28210. -     `M68020' has been observed to be predefined on some systems that
  28211. -     use 68020 CPUs--in addition to `mc68000' and `m68k', which are
  28212. -     less specific.
  28213. -
  28214. -`_AM29K'
  28215. -`_AM29000'
  28216. -     Both `_AM29K' and `_AM29000' are predefined for the AMD 29000 CPU
  28217. -     family.
  28218. -
  28219. -`ns32000'
  28220. -     `ns32000' is predefined on computers which use the National
  28221. -     Semiconductor 32000 series CPU.
  28222. -
  28223. -   Yet other nonstandard predefined macros describe the manufacturer of
  28224. -the system.  For example,
  28225. -
  28226. -`sun'
  28227. -     `sun' is predefined on all models of Sun computers.
  28228. -
  28229. -`pyr'
  28230. -     `pyr' is predefined on all models of Pyramid computers.
  28231. -
  28232. -`sequent'
  28233. -     `sequent' is predefined on all models of Sequent computers.
  28234. -
  28235. -   These predefined symbols are not only nonstandard, they are contrary
  28236. -to the ANSI standard because their names do not start with underscores.
  28237. -Therefore, the option `-ansi' inhibits the definition of these symbols.
  28238. -
  28239. -   This tends to make `-ansi' useless, since many programs depend on the
  28240. -customary nonstandard predefined symbols.  Even system header files
  28241. -check them and will generate incorrect declarations if they do not find
  28242. -the names that are expected.  You might think that the header files
  28243. -supplied for the Uglix computer would not need to test what machine
  28244. -they are running on, because they can simply assume it is the Uglix;
  28245. -but often they do, and they do so using the customary names.  As a
  28246. -result, very few C programs will compile with `-ansi'.  We intend to
  28247. -avoid such problems on the GNU system.
  28248. -
  28249. -   What, then, should you do in an ANSI C program to test the type of
  28250. -machine it will run on?
  28251. -
  28252. -   GNU C offers a parallel series of symbols for this purpose, whose
  28253. -names are made from the customary ones by adding `__' at the beginning
  28254. -and end.  Thus, the symbol `__vax__' would be available on a Vax, and
  28255. -so on.
  28256. -
  28257. -   The set of nonstandard predefined names in the GNU C preprocessor is
  28258. -controlled (when `cpp' is itself compiled) by the macro
  28259. -`CPP_PREDEFINES', which should be a string containing `-D' options,
  28260. -separated by spaces.  For example, on the Sun 3, we use the following
  28261. -definition:
  28262. -
  28263. -     #define CPP_PREDEFINES "-Dmc68000 -Dsun -Dunix -Dm68k"
  28264. -
  28265. -This macro is usually specified in `tm.h'.
  28266. -
  28267. -
  28268. -File: cpp.info,  Node: Stringification,  Next: Concatenation,  Prev: Predefined,  Up: Macros
  28269. -
  28270. -Stringification
  28271. ----------------
  28272. -
  28273. -   "Stringification" means turning a code fragment into a string
  28274. -constant whose contents are the text for the code fragment.  For
  28275. -example, stringifying `foo (z)' results in `"foo (z)"'.
  28276. -
  28277. -   In the C preprocessor, stringification is an option available when
  28278. -macro arguments are substituted into the macro definition.  In the body
  28279. -of the definition, when an argument name appears, the character `#'
  28280. -before the name specifies stringification of the corresponding actual
  28281. -argument when it is substituted at that point in the definition.  The
  28282. -same argument may be substituted in other places in the definition
  28283. -without stringification if the argument name appears in those places
  28284. -with no `#'.
  28285. -
  28286. -   Here is an example of a macro definition that uses stringification:
  28287. -
  28288. -     #define WARN_IF(EXP) \
  28289. -     do { if (EXP) \
  28290. -             fprintf (stderr, "Warning: " #EXP "\n"); } \
  28291. -     while (0)
  28292. -
  28293. -Here the actual argument for `EXP' is substituted once as given, into
  28294. -the `if' statement, and once as stringified, into the argument to
  28295. -`fprintf'.  The `do' and `while (0)' are a kludge to make it possible
  28296. -to write `WARN_IF (ARG);', which the resemblance of `WARN_IF' to a
  28297. -function would make C programmers want to do; see *Note Swallow
  28298. -Semicolon::.
  28299. -
  28300. -   The stringification feature is limited to transforming one macro
  28301. -argument into one string constant: there is no way to combine the
  28302. -argument with other text and then stringify it all together.  But the
  28303. -example above shows how an equivalent result can be obtained in ANSI
  28304. -Standard C using the feature that adjacent string constants are
  28305. -concatenated as one string constant.  The preprocessor stringifies the
  28306. -actual value of `EXP' into a separate string constant, resulting in
  28307. -text like
  28308. -
  28309. -     do { if (x == 0) \
  28310. -             fprintf (stderr, "Warning: " "x == 0" "\n"); } \
  28311. -     while (0)
  28312. -
  28313. -but the C compiler then sees three consecutive string constants and
  28314. -concatenates them into one, producing effectively
  28315. -
  28316. -     do { if (x == 0) \
  28317. -             fprintf (stderr, "Warning: x == 0\n"); } \
  28318. -     while (0)
  28319. -
  28320. -   Stringification in C involves more than putting doublequote
  28321. -characters around the fragment; it is necessary to put backslashes in
  28322. -front of all doublequote characters, and all backslashes in string and
  28323. -character constants, in order to get a valid C string constant with the
  28324. -proper contents.  Thus, stringifying `p = "foo\n";' results in `"p =
  28325. -\"foo\\n\";"'.  However, backslashes that are not inside of string or
  28326. -character constants are not duplicated: `\n' by itself stringifies to
  28327. -`"\n"'.
  28328. -
  28329. -   Whitespace (including comments) in the text being stringified is
  28330. -handled according to precise rules.  All leading and trailing
  28331. -whitespace is ignored.  Any sequence of whitespace in the middle of the
  28332. -text is converted to a single space in the stringified result.
  28333. -
  28334. -
  28335. -File: cpp.info,  Node: Concatenation,  Next: Undefining,  Prev: Stringification,  Up: Macros
  28336. -
  28337. -Concatenation
  28338. --------------
  28339. -
  28340. -   "Concatenation" means joining two strings into one.  In the context
  28341. -of macro expansion, concatenation refers to joining two lexical units
  28342. -into one longer one.  Specifically, an actual argument to the macro can
  28343. -be concatenated with another actual argument or with fixed text to
  28344. -produce a longer name.  The longer name might be the name of a function,
  28345. -variable or type, or a C keyword; it might even be the name of another
  28346. -macro, in which case it will be expanded.
  28347. -
  28348. -   When you define a macro, you request concatenation with the special
  28349. -operator `##' in the macro body.  When the macro is called, after
  28350. -actual arguments are substituted, all `##' operators are deleted, and
  28351. -so is any whitespace next to them (including whitespace that was part
  28352. -of an actual argument).  The result is to concatenate the syntactic
  28353. -tokens on either side of the `##'.
  28354. -
  28355. -   Consider a C program that interprets named commands.  There probably
  28356. -needs to be a table of commands, perhaps an array of structures
  28357. -declared as follows:
  28358. -
  28359. -     struct command
  28360. -     {
  28361. -       char *name;
  28362. -       void (*function) ();
  28363. -     };
  28364. -     
  28365. -     struct command commands[] =
  28366. -     {
  28367. -       { "quit", quit_command},
  28368. -       { "help", help_command},
  28369. -       ...
  28370. -     };
  28371. -
  28372. -   It would be cleaner not to have to give each command name twice,
  28373. -once in the string constant and once in the function name.  A macro
  28374. -which takes the name of a command as an argument can make this
  28375. -unnecessary.  The string constant can be created with stringification,
  28376. -and the function name by concatenating the argument with `_command'.
  28377. -Here is how it is done:
  28378. -
  28379. -     #define COMMAND(NAME)  { #NAME, NAME ## _command }
  28380. -     
  28381. -     struct command commands[] =
  28382. -     {
  28383. -       COMMAND (quit),
  28384. -       COMMAND (help),
  28385. -       ...
  28386. -     };
  28387. -
  28388. -   The usual case of concatenation is concatenating two names (or a
  28389. -name and a number) into a longer name.  But this isn't the only valid
  28390. -case.  It is also possible to concatenate two numbers (or a number and
  28391. -a name, such as `1.5' and `e3') into a number.  Also, multi-character
  28392. -operators such as `+=' can be formed by concatenation.  In some cases
  28393. -it is even possible to piece together a string constant.  However, two
  28394. -pieces of text that don't together form a valid lexical unit cannot be
  28395. -concatenated.  For example, concatenation with `x' on one side and `+'
  28396. -on the other is not meaningful because those two characters can't fit
  28397. -together in any lexical unit of C.  The ANSI standard says that such
  28398. -attempts at concatenation are undefined, but in the GNU C preprocessor
  28399. -it is well defined: it puts the `x' and `+' side by side with no
  28400. -particular special results.
  28401. -
  28402. -   Keep in mind that the C preprocessor converts comments to whitespace
  28403. -before macros are even considered.  Therefore, you cannot create a
  28404. -comment by concatenating `/' and `*': the `/*' sequence that starts a
  28405. -comment is not a lexical unit, but rather the beginning of a "long"
  28406. -space character.  Also, you can freely use comments next to a `##' in a
  28407. -macro definition, or in actual arguments that will be concatenated,
  28408. -because the comments will be converted to spaces at first sight, and
  28409. -concatenation will later discard the spaces.
  28410. -
  28411. -
  28412. -File: cpp.info,  Node: Undefining,  Next: Redefining,  Prev: Concatenation,  Up: Macros
  28413. -
  28414. -Undefining Macros
  28415. ------------------
  28416. -
  28417. -   To "undefine" a macro means to cancel its definition.  This is done
  28418. -with the `#undef' directive.  `#undef' is followed by the macro name to
  28419. -be undefined.
  28420. -
  28421. -   Like definition, undefinition occurs at a specific point in the
  28422. -source file, and it applies starting from that point.  The name ceases
  28423. -to be a macro name, and from that point on it is treated by the
  28424. -preprocessor as if it had never been a macro name.
  28425. -
  28426. -   For example,
  28427. -
  28428. -     #define FOO 4
  28429. -     x = FOO;
  28430. -     #undef FOO
  28431. -     x = FOO;
  28432. -
  28433. -expands into
  28434. -
  28435. -     x = 4;
  28436. -     
  28437. -     x = FOO;
  28438. -
  28439. -In this example, `FOO' had better be a variable or function as well as
  28440. -(temporarily) a macro, in order for the result of the expansion to be
  28441. -valid C code.
  28442. -
  28443. -   The same form of `#undef' directive will cancel definitions with
  28444. -arguments or definitions that don't expect arguments.  The `#undef'
  28445. -directive has no effect when used on a name not currently defined as a
  28446. -macro.
  28447. -
  28448. -
  28449. -File: cpp.info,  Node: Redefining,  Next: Macro Pitfalls,  Prev: Undefining,  Up: Macros
  28450. -
  28451. -Redefining Macros
  28452. ------------------
  28453. -
  28454. -   "Redefining" a macro means defining (with `#define') a name that is
  28455. -already defined as a macro.
  28456. -
  28457. -   A redefinition is trivial if the new definition is transparently
  28458. -identical to the old one.  You probably wouldn't deliberately write a
  28459. -trivial redefinition, but they can happen automatically when a header
  28460. -file is included more than once (*note Header Files::.), so they are
  28461. -accepted silently and without effect.
  28462. -
  28463. -   Nontrivial redefinition is considered likely to be an error, so it
  28464. -provokes a warning message from the preprocessor.  However, sometimes it
  28465. -is useful to change the definition of a macro in mid-compilation.  You
  28466. -can inhibit the warning by undefining the macro with `#undef' before the
  28467. -second definition.
  28468. -
  28469. -   In order for a redefinition to be trivial, the new definition must
  28470. -exactly match the one already in effect, with two possible exceptions:
  28471. -
  28472. -   * Whitespace may be added or deleted at the beginning or the end.
  28473. -
  28474. -   * Whitespace may be changed in the middle (but not inside strings).
  28475. -     However, it may not be eliminated entirely, and it may not be added
  28476. -     where there was no whitespace at all.
  28477. -
  28478. -   Recall that a comment counts as whitespace.
  28479. -
  28480. -
  28481. -File: cpp.info,  Node: Macro Pitfalls,  Prev: Redefining,  Up: Macros
  28482. -
  28483. -Pitfalls and Subtleties of Macros
  28484. ----------------------------------
  28485. -
  28486. -   In this section we describe some special rules that apply to macros
  28487. -and macro expansion, and point out certain cases in which the rules have
  28488. -counterintuitive consequences that you must watch out for.
  28489. -
  28490. -* Menu:
  28491. -
  28492. -* Misnesting::        Macros can contain unmatched parentheses.
  28493. -* Macro Parentheses:: Why apparently superfluous parentheses
  28494. -                         may be necessary to avoid incorrect grouping.
  28495. -* Swallow Semicolon:: Macros that look like functions
  28496. -                         but expand into compound statements.
  28497. -* Side Effects::      Unsafe macros that cause trouble when
  28498. -                         arguments contain side effects.
  28499. -* Self-Reference::    Macros whose definitions use the macros' own names.
  28500. -* Argument Prescan::  Actual arguments are checked for macro calls
  28501. -                         before they are substituted.
  28502. -* Cascaded Macros::   Macros whose definitions use other macros.
  28503. -* Newlines in Args::  Sometimes line numbers get confused.
  28504. -
  28505. diff -rup --new-file baseline/fsf/gcc/cpp.info-2 amiga/fsf/gcc/cpp.info-2
  28506. --- baseline/fsf/gcc/cpp.info-2    Mon Oct  9 10:11:37 1995
  28507. +++ amiga/fsf/gcc/cpp.info-2    Wed Dec 31 17:00:00 1969
  28508. @@ -1,1032 +0,0 @@
  28509. -This is Info file cpp.info, produced by Makeinfo-1.55 from the input
  28510. -file cpp.texi.
  28511. -
  28512. -   This file documents the GNU C Preprocessor.
  28513. -
  28514. -   Copyright 1987, 1989, 1991, 1992, 1993, 1994, 1995 Free Software
  28515. -Foundation, Inc.
  28516. -
  28517. -   Permission is granted to make and distribute verbatim copies of this
  28518. -manual provided the copyright notice and this permission notice are
  28519. -preserved on all copies.
  28520. -
  28521. -   Permission is granted to copy and distribute modified versions of
  28522. -this manual under the conditions for verbatim copying, provided also
  28523. -that the entire resulting derived work is distributed under the terms
  28524. -of a permission notice identical to this one.
  28525. -
  28526. -   Permission is granted to copy and distribute translations of this
  28527. -manual into another language, under the above conditions for modified
  28528. -versions.
  28529. -
  28530. -
  28531. -File: cpp.info,  Node: Misnesting,  Next: Macro Parentheses,  Prev: Macro Pitfalls,  Up: Macro Pitfalls
  28532. -
  28533. -Improperly Nested Constructs
  28534. -............................
  28535. -
  28536. -   Recall that when a macro is called with arguments, the arguments are
  28537. -substituted into the macro body and the result is checked, together with
  28538. -the rest of the input file, for more macro calls.
  28539. -
  28540. -   It is possible to piece together a macro call coming partially from
  28541. -the macro body and partially from the actual arguments.  For example,
  28542. -
  28543. -     #define double(x) (2*(x))
  28544. -     #define call_with_1(x) x(1)
  28545. -
  28546. -would expand `call_with_1 (double)' into `(2*(1))'.
  28547. -
  28548. -   Macro definitions do not have to have balanced parentheses.  By
  28549. -writing an unbalanced open parenthesis in a macro body, it is possible
  28550. -to create a macro call that begins inside the macro body but ends
  28551. -outside of it.  For example,
  28552. -
  28553. -     #define strange(file) fprintf (file, "%s %d",
  28554. -     ...
  28555. -     strange(stderr) p, 35)
  28556. -
  28557. -This bizarre example expands to `fprintf (stderr, "%s %d", p, 35)'!
  28558. -
  28559. -
  28560. -File: cpp.info,  Node: Macro Parentheses,  Next: Swallow Semicolon,  Prev: Misnesting,  Up: Macro Pitfalls
  28561. -
  28562. -Unintended Grouping of Arithmetic
  28563. -.................................
  28564. -
  28565. -   You may have noticed that in most of the macro definition examples
  28566. -shown above, each occurrence of a macro argument name had parentheses
  28567. -around it.  In addition, another pair of parentheses usually surround
  28568. -the entire macro definition.  Here is why it is best to write macros
  28569. -that way.
  28570. -
  28571. -   Suppose you define a macro as follows,
  28572. -
  28573. -     #define ceil_div(x, y) (x + y - 1) / y
  28574. -
  28575. -whose purpose is to divide, rounding up.  (One use for this operation is
  28576. -to compute how many `int' objects are needed to hold a certain number
  28577. -of `char' objects.)  Then suppose it is used as follows:
  28578. -
  28579. -     a = ceil_div (b & c, sizeof (int));
  28580. -
  28581. -This expands into
  28582. -
  28583. -     a = (b & c + sizeof (int) - 1) / sizeof (int);
  28584. -
  28585. -which does not do what is intended.  The operator-precedence rules of C
  28586. -make it equivalent to this:
  28587. -
  28588. -     a = (b & (c + sizeof (int) - 1)) / sizeof (int);
  28589. -
  28590. -But what we want is this:
  28591. -
  28592. -     a = ((b & c) + sizeof (int) - 1)) / sizeof (int);
  28593. -
  28594. -Defining the macro as
  28595. -
  28596. -     #define ceil_div(x, y) ((x) + (y) - 1) / (y)
  28597. -
  28598. -provides the desired result.
  28599. -
  28600. -   However, unintended grouping can result in another way.  Consider
  28601. -`sizeof ceil_div(1, 2)'.  That has the appearance of a C expression
  28602. -that would compute the size of the type of `ceil_div (1, 2)', but in
  28603. -fact it means something very different.  Here is what it expands to:
  28604. -
  28605. -     sizeof ((1) + (2) - 1) / (2)
  28606. -
  28607. -This would take the size of an integer and divide it by two.  The
  28608. -precedence rules have put the division outside the `sizeof' when it was
  28609. -intended to be inside.
  28610. -
  28611. -   Parentheses around the entire macro definition can prevent such
  28612. -problems.  Here, then, is the recommended way to define `ceil_div':
  28613. -
  28614. -     #define ceil_div(x, y) (((x) + (y) - 1) / (y))
  28615. -
  28616. -
  28617. -File: cpp.info,  Node: Swallow Semicolon,  Next: Side Effects,  Prev: Macro Parentheses,  Up: Macro Pitfalls
  28618. -
  28619. -Swallowing the Semicolon
  28620. -........................
  28621. -
  28622. -   Often it is desirable to define a macro that expands into a compound
  28623. -statement.  Consider, for example, the following macro, that advances a
  28624. -pointer (the argument `p' says where to find it) across whitespace
  28625. -characters:
  28626. -
  28627. -     #define SKIP_SPACES (p, limit)  \
  28628. -     { register char *lim = (limit); \
  28629. -       while (p != lim) {            \
  28630. -         if (*p++ != ' ') {          \
  28631. -           p--; break; }}}
  28632. -
  28633. -Here Backslash-Newline is used to split the macro definition, which must
  28634. -be a single line, so that it resembles the way such C code would be
  28635. -laid out if not part of a macro definition.
  28636. -
  28637. -   A call to this macro might be `SKIP_SPACES (p, lim)'.  Strictly
  28638. -speaking, the call expands to a compound statement, which is a complete
  28639. -statement with no need for a semicolon to end it.  But it looks like a
  28640. -function call.  So it minimizes confusion if you can use it like a
  28641. -function call, writing a semicolon afterward, as in `SKIP_SPACES (p,
  28642. -lim);'
  28643. -
  28644. -   But this can cause trouble before `else' statements, because the
  28645. -semicolon is actually a null statement.  Suppose you write
  28646. -
  28647. -     if (*p != 0)
  28648. -       SKIP_SPACES (p, lim);
  28649. -     else ...
  28650. -
  28651. -The presence of two statements--the compound statement and a null
  28652. -statement--in between the `if' condition and the `else' makes invalid C
  28653. -code.
  28654. -
  28655. -   The definition of the macro `SKIP_SPACES' can be altered to solve
  28656. -this problem, using a `do ... while' statement.  Here is how:
  28657. -
  28658. -     #define SKIP_SPACES (p, limit)     \
  28659. -     do { register char *lim = (limit); \
  28660. -          while (p != lim) {            \
  28661. -            if (*p++ != ' ') {          \
  28662. -              p--; break; }}}           \
  28663. -     while (0)
  28664. -
  28665. -   Now `SKIP_SPACES (p, lim);' expands into
  28666. -
  28667. -     do {...} while (0);
  28668. -
  28669. -which is one statement.
  28670. -
  28671. -
  28672. -File: cpp.info,  Node: Side Effects,  Next: Self-Reference,  Prev: Swallow Semicolon,  Up: Macro Pitfalls
  28673. -
  28674. -Duplication of Side Effects
  28675. -...........................
  28676. -
  28677. -   Many C programs define a macro `min', for "minimum", like this:
  28678. -
  28679. -     #define min(X, Y)  ((X) < (Y) ? (X) : (Y))
  28680. -
  28681. -   When you use this macro with an argument containing a side effect,
  28682. -as shown here,
  28683. -
  28684. -     next = min (x + y, foo (z));
  28685. -
  28686. -it expands as follows:
  28687. -
  28688. -     next = ((x + y) < (foo (z)) ? (x + y) : (foo (z)));
  28689. -
  28690. -where `x + y' has been substituted for `X' and `foo (z)' for `Y'.
  28691. -
  28692. -   The function `foo' is used only once in the statement as it appears
  28693. -in the program, but the expression `foo (z)' has been substituted twice
  28694. -into the macro expansion.  As a result, `foo' might be called two times
  28695. -when the statement is executed.  If it has side effects or if it takes
  28696. -a long time to compute, the results might not be what you intended.  We
  28697. -say that `min' is an "unsafe" macro.
  28698. -
  28699. -   The best solution to this problem is to define `min' in a way that
  28700. -computes the value of `foo (z)' only once.  The C language offers no
  28701. -standard way to do this, but it can be done with GNU C extensions as
  28702. -follows:
  28703. -
  28704. -     #define min(X, Y)                     \
  28705. -     ({ typeof (X) __x = (X), __y = (Y);   \
  28706. -        (__x < __y) ? __x : __y; })
  28707. -
  28708. -   If you do not wish to use GNU C extensions, the only solution is to
  28709. -be careful when *using* the macro `min'.  For example, you can
  28710. -calculate the value of `foo (z)', save it in a variable, and use that
  28711. -variable in `min':
  28712. -
  28713. -     #define min(X, Y)  ((X) < (Y) ? (X) : (Y))
  28714. -     ...
  28715. -     {
  28716. -       int tem = foo (z);
  28717. -       next = min (x + y, tem);
  28718. -     }
  28719. -
  28720. -(where we assume that `foo' returns type `int').
  28721. -
  28722. -
  28723. -File: cpp.info,  Node: Self-Reference,  Next: Argument Prescan,  Prev: Side Effects,  Up: Macro Pitfalls
  28724. -
  28725. -Self-Referential Macros
  28726. -.......................
  28727. -
  28728. -   A "self-referential" macro is one whose name appears in its
  28729. -definition.  A special feature of ANSI Standard C is that the
  28730. -self-reference is not considered a macro call.  It is passed into the
  28731. -preprocessor output unchanged.
  28732. -
  28733. -   Let's consider an example:
  28734. -
  28735. -     #define foo (4 + foo)
  28736. -
  28737. -where `foo' is also a variable in your program.
  28738. -
  28739. -   Following the ordinary rules, each reference to `foo' will expand
  28740. -into `(4 + foo)'; then this will be rescanned and will expand into `(4
  28741. -+ (4 + foo))'; and so on until it causes a fatal error (memory full) in
  28742. -the preprocessor.
  28743. -
  28744. -   However, the special rule about self-reference cuts this process
  28745. -short after one step, at `(4 + foo)'.  Therefore, this macro definition
  28746. -has the possibly useful effect of causing the program to add 4 to the
  28747. -value of `foo' wherever `foo' is referred to.
  28748. -
  28749. -   In most cases, it is a bad idea to take advantage of this feature.  A
  28750. -person reading the program who sees that `foo' is a variable will not
  28751. -expect that it is a macro as well.  The reader will come across the
  28752. -identifier `foo' in the program and think its value should be that of
  28753. -the variable `foo', whereas in fact the value is four greater.
  28754. -
  28755. -   The special rule for self-reference applies also to "indirect"
  28756. -self-reference.  This is the case where a macro X expands to use a
  28757. -macro `y', and the expansion of `y' refers to the macro `x'.  The
  28758. -resulting reference to `x' comes indirectly from the expansion of `x',
  28759. -so it is a self-reference and is not further expanded.  Thus, after
  28760. -
  28761. -     #define x (4 + y)
  28762. -     #define y (2 * x)
  28763. -
  28764. -`x' would expand into `(4 + (2 * x))'.  Clear?
  28765. -
  28766. -   But suppose `y' is used elsewhere, not from the definition of `x'.
  28767. -Then the use of `x' in the expansion of `y' is not a self-reference
  28768. -because `x' is not "in progress".  So it does expand.  However, the
  28769. -expansion of `x' contains a reference to `y', and that is an indirect
  28770. -self-reference now because `y' is "in progress".  The result is that
  28771. -`y' expands to `(2 * (4 + y))'.
  28772. -
  28773. -   It is not clear that this behavior would ever be useful, but it is
  28774. -specified by the ANSI C standard, so you may need to understand it.
  28775. -
  28776. -
  28777. -File: cpp.info,  Node: Argument Prescan,  Next: Cascaded Macros,  Prev: Self-Reference,  Up: Macro Pitfalls
  28778. -
  28779. -Separate Expansion of Macro Arguments
  28780. -.....................................
  28781. -
  28782. -   We have explained that the expansion of a macro, including the
  28783. -substituted actual arguments, is scanned over again for macro calls to
  28784. -be expanded.
  28785. -
  28786. -   What really happens is more subtle: first each actual argument text
  28787. -is scanned separately for macro calls.  Then the results of this are
  28788. -substituted into the macro body to produce the macro expansion, and the
  28789. -macro expansion is scanned again for macros to expand.
  28790. -
  28791. -   The result is that the actual arguments are scanned *twice* to expand
  28792. -macro calls in them.
  28793. -
  28794. -   Most of the time, this has no effect.  If the actual argument
  28795. -contained any macro calls, they are expanded during the first scan.
  28796. -The result therefore contains no macro calls, so the second scan does
  28797. -not change it.  If the actual argument were substituted as given, with
  28798. -no prescan, the single remaining scan would find the same macro calls
  28799. -and produce the same results.
  28800. -
  28801. -   You might expect the double scan to change the results when a
  28802. -self-referential macro is used in an actual argument of another macro
  28803. -(*note Self-Reference::.): the self-referential macro would be expanded
  28804. -once in the first scan, and a second time in the second scan.  But this
  28805. -is not what happens.  The self-references that do not expand in the
  28806. -first scan are marked so that they will not expand in the second scan
  28807. -either.
  28808. -
  28809. -   The prescan is not done when an argument is stringified or
  28810. -concatenated.  Thus,
  28811. -
  28812. -     #define str(s) #s
  28813. -     #define foo 4
  28814. -     str (foo)
  28815. -
  28816. -expands to `"foo"'.  Once more, prescan has been prevented from having
  28817. -any noticeable effect.
  28818. -
  28819. -   More precisely, stringification and concatenation use the argument as
  28820. -written, in un-prescanned form.  The same actual argument would be used
  28821. -in prescanned form if it is substituted elsewhere without
  28822. -stringification or concatenation.
  28823. -
  28824. -     #define str(s) #s lose(s)
  28825. -     #define foo 4
  28826. -     str (foo)
  28827. -
  28828. -   expands to `"foo" lose(4)'.
  28829. -
  28830. -   You might now ask, "Why mention the prescan, if it makes no
  28831. -difference?  And why not skip it and make the preprocessor faster?"
  28832. -The answer is that the prescan does make a difference in three special
  28833. -cases:
  28834. -
  28835. -   * Nested calls to a macro.
  28836. -
  28837. -   * Macros that call other macros that stringify or concatenate.
  28838. -
  28839. -   * Macros whose expansions contain unshielded commas.
  28840. -
  28841. -   We say that "nested" calls to a macro occur when a macro's actual
  28842. -argument contains a call to that very macro.  For example, if `f' is a
  28843. -macro that expects one argument, `f (f (1))' is a nested pair of calls
  28844. -to `f'.  The desired expansion is made by expanding `f (1)' and
  28845. -substituting that into the definition of `f'.  The prescan causes the
  28846. -expected result to happen.  Without the prescan, `f (1)' itself would
  28847. -be substituted as an actual argument, and the inner use of `f' would
  28848. -appear during the main scan as an indirect self-reference and would not
  28849. -be expanded.  Here, the prescan cancels an undesirable side effect (in
  28850. -the medical, not computational, sense of the term) of the special rule
  28851. -for self-referential macros.
  28852. -
  28853. -   But prescan causes trouble in certain other cases of nested macro
  28854. -calls.  Here is an example:
  28855. -
  28856. -     #define foo  a,b
  28857. -     #define bar(x) lose(x)
  28858. -     #define lose(x) (1 + (x))
  28859. -     
  28860. -     bar(foo)
  28861. -
  28862. -We would like `bar(foo)' to turn into `(1 + (foo))', which would then
  28863. -turn into `(1 + (a,b))'.  But instead, `bar(foo)' expands into
  28864. -`lose(a,b)', and you get an error because `lose' requires a single
  28865. -argument.  In this case, the problem is easily solved by the same
  28866. -parentheses that ought to be used to prevent misnesting of arithmetic
  28867. -operations:
  28868. -
  28869. -     #define foo (a,b)
  28870. -     #define bar(x) lose((x))
  28871. -
  28872. -   The problem is more serious when the operands of the macro are not
  28873. -expressions; for example, when they are statements.  Then parentheses
  28874. -are unacceptable because they would make for invalid C code:
  28875. -
  28876. -     #define foo { int a, b; ... }
  28877. -
  28878. -In GNU C you can shield the commas using the `({...})' construct which
  28879. -turns a compound statement into an expression:
  28880. -
  28881. -     #define foo ({ int a, b; ... })
  28882. -
  28883. -   Or you can rewrite the macro definition to avoid such commas:
  28884. -
  28885. -     #define foo { int a; int b; ... }
  28886. -
  28887. -   There is also one case where prescan is useful.  It is possible to
  28888. -use prescan to expand an argument and then stringify it--if you use two
  28889. -levels of macros.  Let's add a new macro `xstr' to the example shown
  28890. -above:
  28891. -
  28892. -     #define xstr(s) str(s)
  28893. -     #define str(s) #s
  28894. -     #define foo 4
  28895. -     xstr (foo)
  28896. -
  28897. -   This expands into `"4"', not `"foo"'.  The reason for the difference
  28898. -is that the argument of `xstr' is expanded at prescan (because `xstr'
  28899. -does not specify stringification or concatenation of the argument).
  28900. -The result of prescan then forms the actual argument for `str'.  `str'
  28901. -uses its argument without prescan because it performs stringification;
  28902. -but it cannot prevent or undo the prescanning already done by `xstr'.
  28903. -
  28904. -
  28905. -File: cpp.info,  Node: Cascaded Macros,  Next: Newlines in Args,  Prev: Argument Prescan,  Up: Macro Pitfalls
  28906. -
  28907. -Cascaded Use of Macros
  28908. -......................
  28909. -
  28910. -   A "cascade" of macros is when one macro's body contains a reference
  28911. -to another macro.  This is very common practice.  For example,
  28912. -
  28913. -     #define BUFSIZE 1020
  28914. -     #define TABLESIZE BUFSIZE
  28915. -
  28916. -   This is not at all the same as defining `TABLESIZE' to be `1020'.
  28917. -The `#define' for `TABLESIZE' uses exactly the body you specify--in
  28918. -this case, `BUFSIZE'--and does not check to see whether it too is the
  28919. -name of a macro.
  28920. -
  28921. -   It's only when you *use* `TABLESIZE' that the result of its expansion
  28922. -is checked for more macro names.
  28923. -
  28924. -   This makes a difference if you change the definition of `BUFSIZE' at
  28925. -some point in the source file.  `TABLESIZE', defined as shown, will
  28926. -always expand using the definition of `BUFSIZE' that is currently in
  28927. -effect:
  28928. -
  28929. -     #define BUFSIZE 1020
  28930. -     #define TABLESIZE BUFSIZE
  28931. -     #undef BUFSIZE
  28932. -     #define BUFSIZE 37
  28933. -
  28934. -Now `TABLESIZE' expands (in two stages) to `37'.  (The `#undef' is to
  28935. -prevent any warning about the nontrivial redefinition of `BUFSIZE'.)
  28936. -
  28937. -
  28938. -File: cpp.info,  Node: Newlines in Args,  Prev: Cascaded Macros,  Up: Macro Pitfalls
  28939. -
  28940. -Newlines in Macro Arguments
  28941. ----------------------------
  28942. -
  28943. -   Traditional macro processing carries forward all newlines in macro
  28944. -arguments into the expansion of the macro.  This means that, if some of
  28945. -the arguments are substituted more than once, or not at all, or out of
  28946. -order, newlines can be duplicated, lost, or moved around within the
  28947. -expansion.  If the expansion consists of multiple statements, then the
  28948. -effect is to distort the line numbers of some of these statements.  The
  28949. -result can be incorrect line numbers, in error messages or displayed in
  28950. -a debugger.
  28951. -
  28952. -   The GNU C preprocessor operating in ANSI C mode adjusts appropriately
  28953. -for multiple use of an argument--the first use expands all the
  28954. -newlines, and subsequent uses of the same argument produce no newlines.
  28955. -But even in this mode, it can produce incorrect line numbering if
  28956. -arguments are used out of order, or not used at all.
  28957. -
  28958. -   Here is an example illustrating this problem:
  28959. -
  28960. -     #define ignore_second_arg(a,b,c) a; c
  28961. -     
  28962. -     ignore_second_arg (foo (),
  28963. -                        ignored (),
  28964. -                        syntax error);
  28965. -
  28966. -The syntax error triggered by the tokens `syntax error' results in an
  28967. -error message citing line four, even though the statement text comes
  28968. -from line five.
  28969. -
  28970. -
  28971. -File: cpp.info,  Node: Conditionals,  Next: Combining Sources,  Prev: Macros,  Up: Top
  28972. -
  28973. -Conditionals
  28974. -============
  28975. -
  28976. -   In a macro processor, a "conditional" is a directive that allows a
  28977. -part of the program to be ignored during compilation, on some
  28978. -conditions.  In the C preprocessor, a conditional can test either an
  28979. -arithmetic expression or whether a name is defined as a macro.
  28980. -
  28981. -   A conditional in the C preprocessor resembles in some ways an `if'
  28982. -statement in C, but it is important to understand the difference between
  28983. -them.  The condition in an `if' statement is tested during the execution
  28984. -of your program.  Its purpose is to allow your program to behave
  28985. -differently from run to run, depending on the data it is operating on.
  28986. -The condition in a preprocessing conditional directive is tested when
  28987. -your program is compiled.  Its purpose is to allow different code to be
  28988. -included in the program depending on the situation at the time of
  28989. -compilation.
  28990. -
  28991. -* Menu:
  28992. -
  28993. -* Uses: Conditional Uses.       What conditionals are for.
  28994. -* Syntax: Conditional Syntax.   How conditionals are written.
  28995. -* Deletion: Deleted Code.       Making code into a comment.
  28996. -* Macros: Conditionals-Macros.  Why conditionals are used with macros.
  28997. -* Assertions::                How and why to use assertions.
  28998. -* Errors: #error Directive.     Detecting inconsistent compilation parameters.
  28999. -
  29000. -
  29001. -File: cpp.info,  Node: Conditional Uses,  Next: Conditional Syntax,  Up: Conditionals
  29002. -
  29003. -Why Conditionals are Used
  29004. --------------------------
  29005. -
  29006. -   Generally there are three kinds of reason to use a conditional.
  29007. -
  29008. -   * A program may need to use different code depending on the machine
  29009. -     or operating system it is to run on.  In some cases the code for
  29010. -     one operating system may be erroneous on another operating system;
  29011. -     for example, it might refer to library routines that do not exist
  29012. -     on the other system.  When this happens, it is not enough to avoid
  29013. -     executing the invalid code: merely having it in the program makes
  29014. -     it impossible to link the program and run it.  With a
  29015. -     preprocessing conditional, the offending code can be effectively
  29016. -     excised from the program when it is not valid.
  29017. -
  29018. -   * You may want to be able to compile the same source file into two
  29019. -     different programs.  Sometimes the difference between the programs
  29020. -     is that one makes frequent time-consuming consistency checks on its
  29021. -     intermediate data, or prints the values of those data for
  29022. -     debugging, while the other does not.
  29023. -
  29024. -   * A conditional whose condition is always false is a good way to
  29025. -     exclude code from the program but keep it as a sort of comment for
  29026. -     future reference.
  29027. -
  29028. -   Most simple programs that are intended to run on only one machine
  29029. -will not need to use preprocessing conditionals.
  29030. -
  29031. -
  29032. -File: cpp.info,  Node: Conditional Syntax,  Next: Deleted Code,  Prev: Conditional Uses,  Up: Conditionals
  29033. -
  29034. -Syntax of Conditionals
  29035. -----------------------
  29036. -
  29037. -   A conditional in the C preprocessor begins with a "conditional
  29038. -directive": `#if', `#ifdef' or `#ifndef'.  *Note Conditionals-Macros::,
  29039. -for information on `#ifdef' and `#ifndef'; only `#if' is explained here.
  29040. -
  29041. -* Menu:
  29042. -
  29043. -* If: #if Directive.     Basic conditionals using `#if' and `#endif'.
  29044. -* Else: #else Directive. Including some text if the condition fails.
  29045. -* Elif: #elif Directive. Testing several alternative possibilities.
  29046. -
  29047. -
  29048. -File: cpp.info,  Node: #if Directive,  Next: #else Directive,  Up: Conditional Syntax
  29049. -
  29050. -The `#if' Directive
  29051. -...................
  29052. -
  29053. -   The `#if' directive in its simplest form consists of
  29054. -
  29055. -     #if EXPRESSION
  29056. -     CONTROLLED TEXT
  29057. -     #endif /* EXPRESSION */
  29058. -
  29059. -   The comment following the `#endif' is not required, but it is a good
  29060. -practice because it helps people match the `#endif' to the
  29061. -corresponding `#if'.  Such comments should always be used, except in
  29062. -short conditionals that are not nested.  In fact, you can put anything
  29063. -at all after the `#endif' and it will be ignored by the GNU C
  29064. -preprocessor, but only comments are acceptable in ANSI Standard C.
  29065. -
  29066. -   EXPRESSION is a C expression of integer type, subject to stringent
  29067. -restrictions.  It may contain
  29068. -
  29069. -   * Integer constants, which are all regarded as `long' or `unsigned
  29070. -     long'.
  29071. -
  29072. -   * Character constants, which are interpreted according to the
  29073. -     character set and conventions of the machine and operating system
  29074. -     on which the preprocessor is running.  The GNU C preprocessor uses
  29075. -     the C data type `char' for these character constants; therefore,
  29076. -     whether some character codes are negative is determined by the C
  29077. -     compiler used to compile the preprocessor.  If it treats `char' as
  29078. -     signed, then character codes large enough to set the sign bit will
  29079. -     be considered negative; otherwise, no character code is considered
  29080. -     negative.
  29081. -
  29082. -   * Arithmetic operators for addition, subtraction, multiplication,
  29083. -     division, bitwise operations, shifts, comparisons, and logical
  29084. -     operations (`&&' and `||').
  29085. -
  29086. -   * Identifiers that are not macros, which are all treated as zero(!).
  29087. -
  29088. -   * Macro calls.  All macro calls in the expression are expanded before
  29089. -     actual computation of the expression's value begins.
  29090. -
  29091. -   Note that `sizeof' operators and `enum'-type values are not allowed.
  29092. -`enum'-type values, like all other identifiers that are not taken as
  29093. -macro calls and expanded, are treated as zero.
  29094. -
  29095. -   The CONTROLLED TEXT inside of a conditional can include
  29096. -preprocessing directives.  Then the directives inside the conditional
  29097. -are obeyed only if that branch of the conditional succeeds.  The text
  29098. -can also contain other conditional groups.  However, the `#if' and
  29099. -`#endif' directives must balance.
  29100. -
  29101. -
  29102. -File: cpp.info,  Node: #else Directive,  Next: #elif Directive,  Prev: #if Directive,  Up: Conditional Syntax
  29103. -
  29104. -The `#else' Directive
  29105. -.....................
  29106. -
  29107. -   The `#else' directive can be added to a conditional to provide
  29108. -alternative text to be used if the condition is false.  This is what it
  29109. -looks like:
  29110. -
  29111. -     #if EXPRESSION
  29112. -     TEXT-IF-TRUE
  29113. -     #else /* Not EXPRESSION */
  29114. -     TEXT-IF-FALSE
  29115. -     #endif /* Not EXPRESSION */
  29116. -
  29117. -   If EXPRESSION is nonzero, and thus the TEXT-IF-TRUE is active, then
  29118. -`#else' acts like a failing conditional and the TEXT-IF-FALSE is
  29119. -ignored.  Contrariwise, if the `#if' conditional fails, the
  29120. -TEXT-IF-FALSE is considered included.
  29121. -
  29122. -
  29123. -File: cpp.info,  Node: #elif Directive,  Prev: #else Directive,  Up: Conditional Syntax
  29124. -
  29125. -The `#elif' Directive
  29126. -.....................
  29127. -
  29128. -   One common case of nested conditionals is used to check for more
  29129. -than two possible alternatives.  For example, you might have
  29130. -
  29131. -     #if X == 1
  29132. -     ...
  29133. -     #else /* X != 1 */
  29134. -     #if X == 2
  29135. -     ...
  29136. -     #else /* X != 2 */
  29137. -     ...
  29138. -     #endif /* X != 2 */
  29139. -     #endif /* X != 1 */
  29140. -
  29141. -   Another conditional directive, `#elif', allows this to be abbreviated
  29142. -as follows:
  29143. -
  29144. -     #if X == 1
  29145. -     ...
  29146. -     #elif X == 2
  29147. -     ...
  29148. -     #else /* X != 2 and X != 1*/
  29149. -     ...
  29150. -     #endif /* X != 2 and X != 1*/
  29151. -
  29152. -   `#elif' stands for "else if".  Like `#else', it goes in the middle
  29153. -of a `#if'-`#endif' pair and subdivides it; it does not require a
  29154. -matching `#endif' of its own.  Like `#if', the `#elif' directive
  29155. -includes an expression to be tested.
  29156. -
  29157. -   The text following the `#elif' is processed only if the original
  29158. -`#if'-condition failed and the `#elif' condition succeeds.  More than
  29159. -one `#elif' can go in the same `#if'-`#endif' group.  Then the text
  29160. -after each `#elif' is processed only if the `#elif' condition succeeds
  29161. -after the original `#if' and any previous `#elif' directives within it
  29162. -have failed.  `#else' is equivalent to `#elif 1', and `#else' is
  29163. -allowed after any number of `#elif' directives, but `#elif' may not
  29164. -follow `#else'.
  29165. -
  29166. -
  29167. -File: cpp.info,  Node: Deleted Code,  Next: Conditionals-Macros,  Prev: Conditional Syntax,  Up: Conditionals
  29168. -
  29169. -Keeping Deleted Code for Future Reference
  29170. ------------------------------------------
  29171. -
  29172. -   If you replace or delete a part of the program but want to keep the
  29173. -old code around as a comment for future reference, the easy way to do
  29174. -this is to put `#if 0' before it and `#endif' after it.  This is better
  29175. -than using comment delimiters `/*' and `*/' since those won't work if
  29176. -the code already contains comments (C comments do not nest).
  29177. -
  29178. -   This works even if the code being turned off contains conditionals,
  29179. -but they must be entire conditionals (balanced `#if' and `#endif').
  29180. -
  29181. -   Conversely, do not use `#if 0' for comments which are not C code.
  29182. -Use the comment delimiters `/*' and `*/' instead.  The interior of `#if
  29183. -0' must consist of complete tokens; in particular, singlequote
  29184. -characters must balance.  But comments often contain unbalanced
  29185. -singlequote characters (known in English as apostrophes).  These
  29186. -confuse `#if 0'.  They do not confuse `/*'.
  29187. -
  29188. -
  29189. -File: cpp.info,  Node: Conditionals-Macros,  Next: Assertions,  Prev: Deleted Code,  Up: Conditionals
  29190. -
  29191. -Conditionals and Macros
  29192. ------------------------
  29193. -
  29194. -   Conditionals are useful in connection with macros or assertions,
  29195. -because those are the only ways that an expression's value can vary
  29196. -from one compilation to another.  A `#if' directive whose expression
  29197. -uses no macros or assertions is equivalent to `#if 1' or `#if 0'; you
  29198. -might as well determine which one, by computing the value of the
  29199. -expression yourself, and then simplify the program.
  29200. -
  29201. -   For example, here is a conditional that tests the expression
  29202. -`BUFSIZE == 1020', where `BUFSIZE' must be a macro.
  29203. -
  29204. -     #if BUFSIZE == 1020
  29205. -       printf ("Large buffers!\n");
  29206. -     #endif /* BUFSIZE is large */
  29207. -
  29208. -   (Programmers often wish they could test the size of a variable or
  29209. -data type in `#if', but this does not work.  The preprocessor does not
  29210. -understand `sizeof', or typedef names, or even the type keywords such
  29211. -as `int'.)
  29212. -
  29213. -   The special operator `defined' is used in `#if' expressions to test
  29214. -whether a certain name is defined as a macro.  Either `defined NAME' or
  29215. -`defined (NAME)' is an expression whose value is 1 if NAME is defined
  29216. -as macro at the current point in the program, and 0 otherwise.  For the
  29217. -`defined' operator it makes no difference what the definition of the
  29218. -macro is; all that matters is whether there is a definition.  Thus, for
  29219. -example,
  29220. -
  29221. -     #if defined (vax) || defined (ns16000)
  29222. -
  29223. -would succeed if either of the names `vax' and `ns16000' is defined as
  29224. -a macro.  You can test the same condition using assertions (*note
  29225. -Assertions::.), like this:
  29226. -
  29227. -     #if #cpu (vax) || #cpu (ns16000)
  29228. -
  29229. -   If a macro is defined and later undefined with `#undef', subsequent
  29230. -use of the `defined' operator returns 0, because the name is no longer
  29231. -defined.  If the macro is defined again with another `#define',
  29232. -`defined' will recommence returning 1.
  29233. -
  29234. -   Conditionals that test whether just one name is defined are very
  29235. -common, so there are two special short conditional directives for this
  29236. -case.
  29237. -
  29238. -`#ifdef NAME'
  29239. -     is equivalent to `#if defined (NAME)'.
  29240. -
  29241. -`#ifndef NAME'
  29242. -     is equivalent to `#if ! defined (NAME)'.
  29243. -
  29244. -   Macro definitions can vary between compilations for several reasons.
  29245. -
  29246. -   * Some macros are predefined on each kind of machine.  For example,
  29247. -     on a Vax, the name `vax' is a predefined macro.  On other
  29248. -     machines, it would not be defined.
  29249. -
  29250. -   * Many more macros are defined by system header files.  Different
  29251. -     systems and machines define different macros, or give them
  29252. -     different values.  It is useful to test these macros with
  29253. -     conditionals to avoid using a system feature on a machine where it
  29254. -     is not implemented.
  29255. -
  29256. -   * Macros are a common way of allowing users to customize a program
  29257. -     for different machines or applications.  For example, the macro
  29258. -     `BUFSIZE' might be defined in a configuration file for your
  29259. -     program that is included as a header file in each source file.  You
  29260. -     would use `BUFSIZE' in a preprocessing conditional in order to
  29261. -     generate different code depending on the chosen configuration.
  29262. -
  29263. -   * Macros can be defined or undefined with `-D' and `-U' command
  29264. -     options when you compile the program.  You can arrange to compile
  29265. -     the same source file into two different programs by choosing a
  29266. -     macro name to specify which program you want, writing conditionals
  29267. -     to test whether or how this macro is defined, and then controlling
  29268. -     the state of the macro with compiler command options.  *Note
  29269. -     Invocation::.
  29270. -
  29271. -   Assertions are usually predefined, but can be defined with
  29272. -preprocessor directives or command-line options.
  29273. -
  29274. -
  29275. -File: cpp.info,  Node: Assertions,  Next: #error Directive,  Prev: Conditionals-Macros,  Up: Conditionals
  29276. -
  29277. -Assertions
  29278. -----------
  29279. -
  29280. -   "Assertions" are a more systematic alternative to macros in writing
  29281. -conditionals to test what sort of computer or system the compiled
  29282. -program will run on.  Assertions are usually predefined, but you can
  29283. -define them with preprocessing directives or command-line options.
  29284. -
  29285. -   The macros traditionally used to describe the type of target are not
  29286. -classified in any way according to which question they answer; they may
  29287. -indicate a hardware architecture, a particular hardware model, an
  29288. -operating system, a particular version of an operating system, or
  29289. -specific configuration options.  These are jumbled together in a single
  29290. -namespace.  In contrast, each assertion consists of a named question and
  29291. -an answer.  The question is usually called the "predicate".  An
  29292. -assertion looks like this:
  29293. -
  29294. -     #PREDICATE (ANSWER)
  29295. -
  29296. -You must use a properly formed identifier for PREDICATE.  The value of
  29297. -ANSWER can be any sequence of words; all characters are significant
  29298. -except for leading and trailing whitespace, and differences in internal
  29299. -whitespace sequences are ignored.  Thus, `x + y' is different from
  29300. -`x+y' but equivalent to `x + y'.  `)' is not allowed in an answer.
  29301. -
  29302. -   Here is a conditional to test whether the answer ANSWER is asserted
  29303. -for the predicate PREDICATE:
  29304. -
  29305. -     #if #PREDICATE (ANSWER)
  29306. -
  29307. -There may be more than one answer asserted for a given predicate.  If
  29308. -you omit the answer, you can test whether *any* answer is asserted for
  29309. -PREDICATE:
  29310. -
  29311. -     #if #PREDICATE
  29312. -
  29313. -   Most of the time, the assertions you test will be predefined
  29314. -assertions.  GNU C provides three predefined predicates: `system',
  29315. -`cpu', and `machine'.  `system' is for assertions about the type of
  29316. -software, `cpu' describes the type of computer architecture, and
  29317. -`machine' gives more information about the computer.  For example, on a
  29318. -GNU system, the following assertions would be true:
  29319. -
  29320. -     #system (gnu)
  29321. -     #system (mach)
  29322. -     #system (mach 3)
  29323. -     #system (mach 3.SUBVERSION)
  29324. -     #system (hurd)
  29325. -     #system (hurd VERSION)
  29326. -
  29327. -and perhaps others.  The alternatives with more or less version
  29328. -information let you ask more or less detailed questions about the type
  29329. -of system software.
  29330. -
  29331. -   On a Unix system, you would find `#system (unix)' and perhaps one of:
  29332. -`#system (aix)', `#system (bsd)', `#system (hpux)', `#system (lynx)',
  29333. -`#system (mach)', `#system (posix)', `#system (svr3)', `#system
  29334. -(svr4)', or `#system (xpg4)' with possible version numbers following.
  29335. -
  29336. -   Other values for `system' are `#system (mvs)' and `#system (vms)'.
  29337. -
  29338. -   *Portability note:* Many Unix C compilers provide only one answer
  29339. -for the `system' assertion: `#system (unix)', if they support
  29340. -assertions at all.  This is less than useful.
  29341. -
  29342. -   An assertion with a multi-word answer is completely different from
  29343. -several assertions with individual single-word answers.  For example,
  29344. -the presence of `system (mach 3.0)' does not mean that `system (3.0)'
  29345. -is true.  It also does not directly imply `system (mach)', but in GNU
  29346. -C, that last will normally be asserted as well.
  29347. -
  29348. -   The current list of possible assertion values for `cpu' is: `#cpu
  29349. -(a29k)', `#cpu (alpha)', `#cpu (arm)', `#cpu (clipper)', `#cpu
  29350. -(convex)', `#cpu (elxsi)', `#cpu (tron)', `#cpu (h8300)', `#cpu
  29351. -(i370)', `#cpu (i386)', `#cpu (i860)', `#cpu (i960)', `#cpu (m68k)',
  29352. -`#cpu (m88k)', `#cpu (mips)', `#cpu (ns32k)', `#cpu (hppa)', `#cpu
  29353. -(pyr)', `#cpu (ibm032)', `#cpu (rs6000)', `#cpu (sh)', `#cpu (sparc)',
  29354. -`#cpu (spur)', `#cpu (tahoe)', `#cpu (vax)', `#cpu (we32000)'.
  29355. -
  29356. -   You can create assertions within a C program using `#assert', like
  29357. -this:
  29358. -
  29359. -     #assert PREDICATE (ANSWER)
  29360. -
  29361. -(Note the absence of a `#' before PREDICATE.)
  29362. -
  29363. -   Each time you do this, you assert a new true answer for PREDICATE.
  29364. -Asserting one answer does not invalidate previously asserted answers;
  29365. -they all remain true.  The only way to remove an assertion is with
  29366. -`#unassert'.  `#unassert' has the same syntax as `#assert'.  You can
  29367. -also remove all assertions about PREDICATE like this:
  29368. -
  29369. -     #unassert PREDICATE
  29370. -
  29371. -   You can also add or cancel assertions using command options when you
  29372. -run `gcc' or `cpp'.  *Note Invocation::.
  29373. -
  29374. -
  29375. -File: cpp.info,  Node: #error Directive,  Prev: Assertions,  Up: Conditionals
  29376. -
  29377. -The `#error' and `#warning' Directives
  29378. ---------------------------------------
  29379. -
  29380. -   The directive `#error' causes the preprocessor to report a fatal
  29381. -error.  The rest of the line that follows `#error' is used as the error
  29382. -message.
  29383. -
  29384. -   You would use `#error' inside of a conditional that detects a
  29385. -combination of parameters which you know the program does not properly
  29386. -support.  For example, if you know that the program will not run
  29387. -properly on a Vax, you might write
  29388. -
  29389. -     #ifdef __vax__
  29390. -     #error Won't work on Vaxen.  See comments at get_last_object.
  29391. -     #endif
  29392. -
  29393. -*Note Nonstandard Predefined::, for why this works.
  29394. -
  29395. -   If you have several configuration parameters that must be set up by
  29396. -the installation in a consistent way, you can use conditionals to detect
  29397. -an inconsistency and report it with `#error'.  For example,
  29398. -
  29399. -     #if HASH_TABLE_SIZE % 2 == 0 || HASH_TABLE_SIZE % 3 == 0 \
  29400. -         || HASH_TABLE_SIZE % 5 == 0
  29401. -     #error HASH_TABLE_SIZE should not be divisible by a small prime
  29402. -     #endif
  29403. -
  29404. -   The directive `#warning' is like the directive `#error', but causes
  29405. -the preprocessor to issue a warning and continue preprocessing.  The
  29406. -rest of the line that follows `#warning' is used as the warning message.
  29407. -
  29408. -   You might use `#warning' in obsolete header files, with a message
  29409. -directing the user to the header file which should be used instead.
  29410. -
  29411. -
  29412. -File: cpp.info,  Node: Combining Sources,  Next: Other Directives,  Prev: Conditionals,  Up: Top
  29413. -
  29414. -Combining Source Files
  29415. -======================
  29416. -
  29417. -   One of the jobs of the C preprocessor is to inform the C compiler of
  29418. -where each line of C code came from: which source file and which line
  29419. -number.
  29420. -
  29421. -   C code can come from multiple source files if you use `#include';
  29422. -both `#include' and the use of conditionals and macros can cause the
  29423. -line number of a line in the preprocessor output to be different from
  29424. -the line's number in the original source file.  You will appreciate the
  29425. -value of making both the C compiler (in error messages) and symbolic
  29426. -debuggers such as GDB use the line numbers in your source file.
  29427. -
  29428. -   The C preprocessor builds on this feature by offering a directive by
  29429. -which you can control the feature explicitly.  This is useful when a
  29430. -file for input to the C preprocessor is the output from another program
  29431. -such as the `bison' parser generator, which operates on another file
  29432. -that is the true source file.  Parts of the output from `bison' are
  29433. -generated from scratch, other parts come from a standard parser file.
  29434. -The rest are copied nearly verbatim from the source file, but their
  29435. -line numbers in the `bison' output are not the same as their original
  29436. -line numbers.  Naturally you would like compiler error messages and
  29437. -symbolic debuggers to know the original source file and line number of
  29438. -each line in the `bison' input.
  29439. -
  29440. -   `bison' arranges this by writing `#line' directives into the output
  29441. -file.  `#line' is a directive that specifies the original line number
  29442. -and source file name for subsequent input in the current preprocessor
  29443. -input file.  `#line' has three variants:
  29444. -
  29445. -`#line LINENUM'
  29446. -     Here LINENUM is a decimal integer constant.  This specifies that
  29447. -     the line number of the following line of input, in its original
  29448. -     source file, was LINENUM.
  29449. -
  29450. -`#line LINENUM FILENAME'
  29451. -     Here LINENUM is a decimal integer constant and FILENAME is a
  29452. -     string constant.  This specifies that the following line of input
  29453. -     came originally from source file FILENAME and its line number there
  29454. -     was LINENUM.  Keep in mind that FILENAME is not just a file name;
  29455. -     it is surrounded by doublequote characters so that it looks like a
  29456. -     string constant.
  29457. -
  29458. -`#line ANYTHING ELSE'
  29459. -     ANYTHING ELSE is checked for macro calls, which are expanded.  The
  29460. -     result should be a decimal integer constant followed optionally by
  29461. -     a string constant, as described above.
  29462. -
  29463. -   `#line' directives alter the results of the `__FILE__' and
  29464. -`__LINE__' predefined macros from that point on.  *Note Standard
  29465. -Predefined::.
  29466. -
  29467. -   The output of the preprocessor (which is the input for the rest of
  29468. -the compiler) contains directives that look much like `#line'
  29469. -directives.  They start with just `#' instead of `#line', but this is
  29470. -followed by a line number and file name as in `#line'.  *Note Output::.
  29471. -
  29472. -
  29473. -File: cpp.info,  Node: Other Directives,  Next: Output,  Prev: Combining Sources,  Up: Top
  29474. -
  29475. -Miscellaneous Preprocessing Directives
  29476. -======================================
  29477. -
  29478. -   This section describes three additional preprocessing directives.
  29479. -They are not very useful, but are mentioned for completeness.
  29480. -
  29481. -   The "null directive" consists of a `#' followed by a Newline, with
  29482. -only whitespace (including comments) in between.  A null directive is
  29483. -understood as a preprocessing directive but has no effect on the
  29484. -preprocessor output.  The primary significance of the existence of the
  29485. -null directive is that an input line consisting of just a `#' will
  29486. -produce no output, rather than a line of output containing just a `#'.
  29487. -Supposedly some old C programs contain such lines.
  29488. -
  29489. -   The ANSI standard specifies that the `#pragma' directive has an
  29490. -arbitrary, implementation-defined effect.  In the GNU C preprocessor,
  29491. -`#pragma' directives are not used, except for `#pragma once' (*note
  29492. -Once-Only::.).  However, they are left in the preprocessor output, so
  29493. -they are available to the compilation pass.
  29494. -
  29495. -   The `#ident' directive is supported for compatibility with certain
  29496. -other systems.  It is followed by a line of text.  On some systems, the
  29497. -text is copied into a special place in the object file; on most systems,
  29498. -the text is ignored and this directive has no effect.  Typically
  29499. -`#ident' is only used in header files supplied with those systems where
  29500. -it is meaningful.
  29501. -
  29502. -
  29503. -File: cpp.info,  Node: Output,  Next: Invocation,  Prev: Other Directives,  Up: Top
  29504. -
  29505. -C Preprocessor Output
  29506. -=====================
  29507. -
  29508. -   The output from the C preprocessor looks much like the input, except
  29509. -that all preprocessing directive lines have been replaced with blank
  29510. -lines and all comments with spaces.  Whitespace within a line is not
  29511. -altered; however, a space is inserted after the expansions of most
  29512. -macro calls.
  29513. -
  29514. -   Source file name and line number information is conveyed by lines of
  29515. -the form
  29516. -
  29517. -     # LINENUM FILENAME FLAGS
  29518. -
  29519. -which are inserted as needed into the middle of the input (but never
  29520. -within a string or character constant).  Such a line means that the
  29521. -following line originated in file FILENAME at line LINENUM.
  29522. -
  29523. -   After the file name comes zero or more flags, which are `1', `2',
  29524. -`3', or `4'.  If there are multiple flags, spaces separate them.  Here
  29525. -is what the flags mean:
  29526. -
  29527. -`1'
  29528. -     This indicates the start of a new file.
  29529. -
  29530. -`2'
  29531. -     This indicates returning to a file (after having included another
  29532. -     file).
  29533. -
  29534. -`3'
  29535. -     This indicates that the following text comes from a system header
  29536. -     file, so certain warnings should be suppressed.
  29537. -
  29538. -`4'
  29539. -     This indicates that the following text should be treated as C.
  29540. -
  29541. diff -rup --new-file baseline/fsf/gcc/cpp.info-3 amiga/fsf/gcc/cpp.info-3
  29542. --- baseline/fsf/gcc/cpp.info-3    Mon Oct  9 10:11:37 1995
  29543. +++ amiga/fsf/gcc/cpp.info-3    Wed Dec 31 17:00:00 1969
  29544. @@ -1,466 +0,0 @@
  29545. -This is Info file cpp.info, produced by Makeinfo-1.55 from the input
  29546. -file cpp.texi.
  29547. -
  29548. -   This file documents the GNU C Preprocessor.
  29549. -
  29550. -   Copyright 1987, 1989, 1991, 1992, 1993, 1994, 1995 Free Software
  29551. -Foundation, Inc.
  29552. -
  29553. -   Permission is granted to make and distribute verbatim copies of this
  29554. -manual provided the copyright notice and this permission notice are
  29555. -preserved on all copies.
  29556. -
  29557. -   Permission is granted to copy and distribute modified versions of
  29558. -this manual under the conditions for verbatim copying, provided also
  29559. -that the entire resulting derived work is distributed under the terms
  29560. -of a permission notice identical to this one.
  29561. -
  29562. -   Permission is granted to copy and distribute translations of this
  29563. -manual into another language, under the above conditions for modified
  29564. -versions.
  29565. -
  29566. -
  29567. -File: cpp.info,  Node: Invocation,  Next: Concept Index,  Prev: Output,  Up: Top
  29568. -
  29569. -Invoking the C Preprocessor
  29570. -===========================
  29571. -
  29572. -   Most often when you use the C preprocessor you will not have to
  29573. -invoke it explicitly: the C compiler will do so automatically.
  29574. -However, the preprocessor is sometimes useful on its own.
  29575. -
  29576. -   The C preprocessor expects two file names as arguments, INFILE and
  29577. -OUTFILE.  The preprocessor reads INFILE together with any other files
  29578. -it specifies with `#include'.  All the output generated by the combined
  29579. -input files is written in OUTFILE.
  29580. -
  29581. -   Either INFILE or OUTFILE may be `-', which as INFILE means to read
  29582. -from standard input and as OUTFILE means to write to standard output.
  29583. -Also, if OUTFILE or both file names are omitted, the standard output
  29584. -and standard input are used for the omitted file names.
  29585. -
  29586. -   Here is a table of command options accepted by the C preprocessor.
  29587. -These options can also be given when compiling a C program; they are
  29588. -passed along automatically to the preprocessor when it is invoked by the
  29589. -compiler.
  29590. -
  29591. -`-P'
  29592. -     Inhibit generation of `#'-lines with line-number information in
  29593. -     the output from the preprocessor (*note Output::.).  This might be
  29594. -     useful when running the preprocessor on something that is not C
  29595. -     code and will be sent to a program which might be confused by the
  29596. -     `#'-lines.
  29597. -
  29598. -`-C'
  29599. -     Do not discard comments: pass them through to the output file.
  29600. -     Comments appearing in arguments of a macro call will be copied to
  29601. -     the output before the expansion of the macro call.
  29602. -
  29603. -`-traditional'
  29604. -     Try to imitate the behavior of old-fashioned C, as opposed to ANSI
  29605. -     C.
  29606. -
  29607. -        * Traditional macro expansion pays no attention to singlequote
  29608. -          or doublequote characters; macro argument symbols are
  29609. -          replaced by the argument values even when they appear within
  29610. -          apparent string or character constants.
  29611. -
  29612. -        * Traditionally, it is permissible for a macro expansion to end
  29613. -          in the middle of a string or character constant.  The
  29614. -          constant continues into the text surrounding the macro call.
  29615. -
  29616. -        * However, traditionally the end of the line terminates a
  29617. -          string or character constant, with no error.
  29618. -
  29619. -        * In traditional C, a comment is equivalent to no text at all.
  29620. -          (In ANSI C, a comment counts as whitespace.)
  29621. -
  29622. -        * Traditional C does not have the concept of a "preprocessing
  29623. -          number".  It considers `1.0e+4' to be three tokens: `1.0e',
  29624. -          `+', and `4'.
  29625. -
  29626. -        * A macro is not suppressed within its own definition, in
  29627. -          traditional C.  Thus, any macro that is used recursively
  29628. -          inevitably causes an error.
  29629. -
  29630. -        * The character `#' has no special meaning within a macro
  29631. -          definition in traditional C.
  29632. -
  29633. -        * In traditional C, the text at the end of a macro expansion
  29634. -          can run together with the text after the macro call, to
  29635. -          produce a single token.  (This is impossible in ANSI C.)
  29636. -
  29637. -        * Traditionally, `\' inside a macro argument suppresses the
  29638. -          syntactic significance of the following character.
  29639. -
  29640. -`-trigraphs'
  29641. -     Process ANSI standard trigraph sequences.  These are
  29642. -     three-character sequences, all starting with `??', that are
  29643. -     defined by ANSI C to stand for single characters.  For example,
  29644. -     `??/' stands for `\', so `'??/n'' is a character constant for a
  29645. -     newline.  Strictly speaking, the GNU C preprocessor does not
  29646. -     support all programs in ANSI Standard C unless `-trigraphs' is
  29647. -     used, but if you ever notice the difference it will be with relief.
  29648. -
  29649. -     You don't want to know any more about trigraphs.
  29650. -
  29651. -`-pedantic'
  29652. -     Issue warnings required by the ANSI C standard in certain cases
  29653. -     such as when text other than a comment follows `#else' or `#endif'.
  29654. -
  29655. -`-pedantic-errors'
  29656. -     Like `-pedantic', except that errors are produced rather than
  29657. -     warnings.
  29658. -
  29659. -`-Wtrigraphs'
  29660. -     Warn if any trigraphs are encountered (assuming they are enabled).
  29661. -
  29662. -`-Wcomment'
  29663. -     Warn whenever a comment-start sequence `/*' appears in a comment.
  29664. -
  29665. -`-Wall'
  29666. -     Requests both `-Wtrigraphs' and `-Wcomment' (but not
  29667. -     `-Wtraditional').
  29668. -
  29669. -`-Wtraditional'
  29670. -     Warn about certain constructs that behave differently in
  29671. -     traditional and ANSI C.
  29672. -
  29673. -`-I DIRECTORY'
  29674. -     Add the directory DIRECTORY to the head of the list of directories
  29675. -     to be searched for header files (*note Include Syntax::.).  This
  29676. -     can be used to override a system header file, substituting your
  29677. -     own version, since these directories are searched before the system
  29678. -     header file directories.  If you use more than one `-I' option,
  29679. -     the directories are scanned in left-to-right order; the standard
  29680. -     system directories come after.
  29681. -
  29682. -`-I-'
  29683. -     Any directories specified with `-I' options before the `-I-'
  29684. -     option are searched only for the case of `#include "FILE"'; they
  29685. -     are not searched for `#include <FILE>'.
  29686. -
  29687. -     If additional directories are specified with `-I' options after
  29688. -     the `-I-', these directories are searched for all `#include'
  29689. -     directives.
  29690. -
  29691. -     In addition, the `-I-' option inhibits the use of the current
  29692. -     directory as the first search directory for `#include "FILE"'.
  29693. -     Therefore, the current directory is searched only if it is
  29694. -     requested explicitly with `-I.'.  Specifying both `-I-' and `-I.'
  29695. -     allows you to control precisely which directories are searched
  29696. -     before the current one and which are searched after.
  29697. -
  29698. -`-nostdinc'
  29699. -     Do not search the standard system directories for header files.
  29700. -     Only the directories you have specified with `-I' options (and the
  29701. -     current directory, if appropriate) are searched.
  29702. -
  29703. -`-nostdinc++'
  29704. -     Do not search for header files in the C++-specific standard
  29705. -     directories, but do still search the other standard directories.
  29706. -     (This option is used when building libg++.)
  29707. -
  29708. -`-D NAME'
  29709. -     Predefine NAME as a macro, with definition `1'.
  29710. -
  29711. -`-D NAME=DEFINITION'
  29712. -     Predefine NAME as a macro, with definition DEFINITION.  There are
  29713. -     no restrictions on the contents of DEFINITION, but if you are
  29714. -     invoking the preprocessor from a shell or shell-like program you
  29715. -     may need to use the shell's quoting syntax to protect characters
  29716. -     such as spaces that have a meaning in the shell syntax.  If you
  29717. -     use more than one `-D' for the same NAME, the rightmost definition
  29718. -     takes effect.
  29719. -
  29720. -`-U NAME'
  29721. -     Do not predefine NAME.  If both `-U' and `-D' are specified for
  29722. -     one name, the `-U' beats the `-D' and the name is not predefined.
  29723. -
  29724. -`-undef'
  29725. -     Do not predefine any nonstandard macros.
  29726. -
  29727. -`-A PREDICATE(ANSWER)'
  29728. -     Make an assertion with the predicate PREDICATE and answer ANSWER.
  29729. -     *Note Assertions::.
  29730. -
  29731. -     You can use `-A-' to disable all predefined assertions; it also
  29732. -     undefines all predefined macros that identify the type of target
  29733. -     system.
  29734. -
  29735. -`-dM'
  29736. -     Instead of outputting the result of preprocessing, output a list of
  29737. -     `#define' directives for all the macros defined during the
  29738. -     execution of the preprocessor, including predefined macros.  This
  29739. -     gives you a way of finding out what is predefined in your version
  29740. -     of the preprocessor; assuming you have no file `foo.h', the command
  29741. -
  29742. -          touch foo.h; cpp -dM foo.h
  29743. -
  29744. -     will show the values of any predefined macros.
  29745. -
  29746. -`-dD'
  29747. -     Like `-dM' except in two respects: it does *not* include the
  29748. -     predefined macros, and it outputs *both* the `#define' directives
  29749. -     and the result of preprocessing.  Both kinds of output go to the
  29750. -     standard output file.
  29751. -
  29752. -`-M [-MG]'
  29753. -     Instead of outputting the result of preprocessing, output a rule
  29754. -     suitable for `make' describing the dependencies of the main source
  29755. -     file.  The preprocessor outputs one `make' rule containing the
  29756. -     object file name for that source file, a colon, and the names of
  29757. -     all the included files.  If there are many included files then the
  29758. -     rule is split into several lines using `\'-newline.
  29759. -
  29760. -     `-MG' says to treat missing header files as generated files and
  29761. -     assume they live in the same directory as the source file.  It
  29762. -     must be specified in addition to `-M'.
  29763. -
  29764. -     This feature is used in automatic updating of makefiles.
  29765. -
  29766. -`-MM [-MG]'
  29767. -     Like `-M' but mention only the files included with `#include
  29768. -     "FILE"'.  System header files included with `#include <FILE>' are
  29769. -     omitted.
  29770. -
  29771. -`-MD FILE'
  29772. -     Like `-M' but the dependency information is written to FILE.  This
  29773. -     is in addition to compiling the file as specified--`-MD' does not
  29774. -     inhibit ordinary compilation the way `-M' does.
  29775. -
  29776. -     When invoking gcc, do not specify the FILE argument.  Gcc will
  29777. -     create file names made by replacing ".c" with ".d" at the end of
  29778. -     the input file names.
  29779. -
  29780. -     In Mach, you can use the utility `md' to merge multiple dependency
  29781. -     files into a single dependency file suitable for using with the
  29782. -     `make' command.
  29783. -
  29784. -`-MMD FILE'
  29785. -     Like `-MD' except mention only user header files, not system
  29786. -     header files.
  29787. -
  29788. -`-H'
  29789. -     Print the name of each header file used, in addition to other
  29790. -     normal activities.
  29791. -
  29792. -`-imacros FILE'
  29793. -     Process FILE as input, discarding the resulting output, before
  29794. -     processing the regular input file.  Because the output generated
  29795. -     from FILE is discarded, the only effect of `-imacros FILE' is to
  29796. -     make the macros defined in FILE available for use in the main
  29797. -     input.
  29798. -
  29799. -`-include FILE'
  29800. -     Process FILE as input, and include all the resulting output,
  29801. -     before processing the regular input file.
  29802. -
  29803. -`-idirafter DIR'
  29804. -     Add the directory DIR to the second include path.  The directories
  29805. -     on the second include path are searched when a header file is not
  29806. -     found in any of the directories in the main include path (the one
  29807. -     that `-I' adds to).
  29808. -
  29809. -`-iprefix PREFIX'
  29810. -     Specify PREFIX as the prefix for subsequent `-iwithprefix' options.
  29811. -
  29812. -`-iwithprefix DIR'
  29813. -     Add a directory to the second include path.  The directory's name
  29814. -     is made by concatenating PREFIX and DIR, where PREFIX was
  29815. -     specified previously with `-iprefix'.
  29816. -
  29817. -`-isystem DIR'
  29818. -     Add a directory to the beginning of the second include path,
  29819. -     marking it as a system directory, so that it gets the same special
  29820. -     treatment as is applied to the standard system directories.
  29821. -
  29822. -`-lang-c'
  29823. -`-lang-c89'
  29824. -`-lang-c++'
  29825. -`-lang-objc'
  29826. -`-lang-objc++'
  29827. -     Specify the source language.  `-lang-c' is the default; it allows
  29828. -     recognition of C++ comments (comments that begin with `//' and end
  29829. -     at end of line), since this is a common feature and it will most
  29830. -     likely be in the next C standard.  `-lang-c89' disables
  29831. -     recognition of C++ comments.  `-lang-c++' handles C++ comment
  29832. -     syntax and includes extra default include directories for C++.
  29833. -     `-lang-objc' enables the Objective C `#import' directive.
  29834. -     `-lang-objc++' enables both C++ and Objective C extensions.
  29835. -
  29836. -     These options are generated by the compiler driver `gcc', but not
  29837. -     passed from the `gcc' command line unless you use the driver's
  29838. -     `-Wp' option.
  29839. -
  29840. -`-lint'
  29841. -     Look for commands to the program checker `lint' embedded in
  29842. -     comments, and emit them preceded by `#pragma lint'.  For example,
  29843. -     the comment `/* NOTREACHED */' becomes `#pragma lint NOTREACHED'.
  29844. -
  29845. -     This option is available only when you call `cpp' directly; `gcc'
  29846. -     will not pass it from its command line.
  29847. -
  29848. -`-$'
  29849. -     Forbid the use of `$' in identifiers.  This is required for ANSI
  29850. -     conformance.  `gcc' automatically supplies this option to the
  29851. -     preprocessor if you specify `-ansi', but `gcc' doesn't recognize
  29852. -     the `-$' option itself--to use it without the other effects of
  29853. -     `-ansi', you must call the preprocessor directly.
  29854. -
  29855. -
  29856. -File: cpp.info,  Node: Concept Index,  Next: Index,  Prev: Invocation,  Up: Top
  29857. -
  29858. -Concept Index
  29859. -*************
  29860. -
  29861. -* Menu:
  29862. -
  29863. -* ##:                                   Concatenation.
  29864. -* arguments in macro definitions:       Argument Macros.
  29865. -* assertions:                           Assertions.
  29866. -* assertions, undoing:                  Assertions.
  29867. -* blank macro arguments:                Argument Macros.
  29868. -* cascaded macros:                      Cascaded Macros.
  29869. -* commenting out code:                  Deleted Code.
  29870. -* computed #include:                    Include Syntax.
  29871. -* concatenation:                        Concatenation.
  29872. -* conditionals:                         Conditionals.
  29873. -* directives:                           Directives.
  29874. -* expansion of arguments:               Argument Prescan.
  29875. -* function-like macro:                  Argument Macros.
  29876. -* header file:                          Header Files.
  29877. -* including just once:                  Once-Only.
  29878. -* inheritance:                          Inheritance.
  29879. -* invocation of the preprocessor:       Invocation.
  29880. -* line control:                         Combining Sources.
  29881. -* macro argument expansion:             Argument Prescan.
  29882. -* macro body uses macro:                Cascaded Macros.
  29883. -* macros with argument:                 Argument Macros.
  29884. -* manifest constant:                    Simple Macros.
  29885. -* newlines in macro arguments:          Newlines in Args.
  29886. -* null directive:                       Other Directives.
  29887. -* options:                              Invocation.
  29888. -* output format:                        Output.
  29889. -* overriding a header file:             Inheritance.
  29890. -* parentheses in macro bodies:          Macro Parentheses.
  29891. -* pitfalls of macros:                   Macro Pitfalls.
  29892. -* predefined macros:                    Predefined.
  29893. -* predicates:                           Assertions.
  29894. -* preprocessing directives:             Directives.
  29895. -* prescan of macro arguments:           Argument Prescan.
  29896. -* problems with macros:                 Macro Pitfalls.
  29897. -* redefining macros:                    Redefining.
  29898. -* repeated inclusion:                   Once-Only.
  29899. -* retracting assertions:                Assertions.
  29900. -* second include path:                  Invocation.
  29901. -* self-reference:                       Self-Reference.
  29902. -* semicolons (after macro calls):       Swallow Semicolon.
  29903. -* side effects (in macro arguments):    Side Effects.
  29904. -* simple macro:                         Simple Macros.
  29905. -* space as macro argument:              Argument Macros.
  29906. -* standard predefined macros:           Standard Predefined.
  29907. -* stringification:                      Stringification.
  29908. -* testing predicates:                   Assertions.
  29909. -* unassert:                             Assertions.
  29910. -* undefining macros:                    Undefining.
  29911. -* unsafe macros:                        Side Effects.
  29912. -
  29913. -
  29914. -File: cpp.info,  Node: Index,  Prev: Concept Index,  Up: Top
  29915. -
  29916. -Index of Directives, Macros and Options
  29917. -***************************************
  29918. -
  29919. -* Menu:
  29920. -
  29921. -* #assert:                              Assertions.
  29922. -* #cpu:                                 Assertions.
  29923. -* #define:                              Argument Macros.
  29924. -* #elif:                                #elif Directive.
  29925. -* #else:                                #else Directive.
  29926. -* #error:                               #error Directive.
  29927. -* #ident:                               Other Directives.
  29928. -* #if:                                  Conditional Syntax.
  29929. -* #ifdef:                               Conditionals-Macros.
  29930. -* #ifndef:                              Conditionals-Macros.
  29931. -* #import:                              Once-Only.
  29932. -* #include:                             Include Syntax.
  29933. -* #include_next:                        Inheritance.
  29934. -* #line:                                Combining Sources.
  29935. -* #machine:                             Assertions.
  29936. -* #pragma:                              Other Directives.
  29937. -* #pragma once:                         Once-Only.
  29938. -* #system:                              Assertions.
  29939. -* #unassert:                            Assertions.
  29940. -* #warning:                             #error Directive.
  29941. -* -$:                                   Invocation.
  29942. -* -A:                                   Invocation.
  29943. -* -C:                                   Invocation.
  29944. -* -D:                                   Invocation.
  29945. -* -dD:                                  Invocation.
  29946. -* -dM:                                  Invocation.
  29947. -* -H:                                   Invocation.
  29948. -* -I:                                   Invocation.
  29949. -* -idirafter:                           Invocation.
  29950. -* -imacros:                             Invocation.
  29951. -* -include:                             Invocation.
  29952. -* -iprefix:                             Invocation.
  29953. -* -isystem:                             Invocation.
  29954. -* -iwithprefix:                         Invocation.
  29955. -* -lang-c:                              Invocation.
  29956. -* -lang-c++:                            Invocation.
  29957. -* -lang-c89:                            Invocation.
  29958. -* -lang-objc:                           Invocation.
  29959. -* -lang-objc++:                         Invocation.
  29960. -* -M:                                   Invocation.
  29961. -* -MD:                                  Invocation.
  29962. -* -MM:                                  Invocation.
  29963. -* -MMD:                                 Invocation.
  29964. -* -nostdinc:                            Invocation.
  29965. -* -nostdinc++:                          Invocation.
  29966. -* -P:                                   Invocation.
  29967. -* -pedantic:                            Invocation.
  29968. -* -pedantic-errors:                     Invocation.
  29969. -* -traditional:                         Invocation.
  29970. -* -trigraphs:                           Invocation.
  29971. -* -U:                                   Invocation.
  29972. -* -undef:                               Invocation.
  29973. -* -Wall:                                Invocation.
  29974. -* -Wcomment:                            Invocation.
  29975. -* -Wtraditional:                        Invocation.
  29976. -* -Wtrigraphs:                          Invocation.
  29977. -* BSD:                                  Nonstandard Predefined.
  29978. -* defined:                              Conditionals-Macros.
  29979. -* M68020:                               Nonstandard Predefined.
  29980. -* m68k:                                 Nonstandard Predefined.
  29981. -* mc68000:                              Nonstandard Predefined.
  29982. -* ns32000:                              Nonstandard Predefined.
  29983. -* pyr:                                  Nonstandard Predefined.
  29984. -* sequent:                              Nonstandard Predefined.
  29985. -* sun:                                  Nonstandard Predefined.
  29986. -* system header files:                  Header Uses.
  29987. -* unix:                                 Nonstandard Predefined.
  29988. -* vax:                                  Nonstandard Predefined.
  29989. -* _AM29000:                             Nonstandard Predefined.
  29990. -* _AM29K:                               Nonstandard Predefined.
  29991. -* __BASE_FILE__:                        Standard Predefined.
  29992. -* __CHAR_UNSIGNED__:                    Standard Predefined.
  29993. -* __cplusplus:                          Standard Predefined.
  29994. -* __DATE__:                             Standard Predefined.
  29995. -* __FILE__:                             Standard Predefined.
  29996. -* __GNUC_MINOR__:                       Standard Predefined.
  29997. -* __GNUC__:                             Standard Predefined.
  29998. -* __GNUG__:                             Standard Predefined.
  29999. -* __INCLUDE_LEVEL_:                     Standard Predefined.
  30000. -* __LINE__:                             Standard Predefined.
  30001. -* __OPTIMIZE__:                         Standard Predefined.
  30002. -* __REGISTER_PREFIX__:                  Standard Predefined.
  30003. -* __STDC_VERSION__:                     Standard Predefined.
  30004. -* __STDC__:                             Standard Predefined.
  30005. -* __STRICT_ANSI__:                      Standard Predefined.
  30006. -* __TIME__:                             Standard Predefined.
  30007. -* __USER_LABEL_PREFIX__:                Standard Predefined.
  30008. -* __VERSION__:                          Standard Predefined.
  30009. -
  30010. -
  30011. diff -rup --new-file baseline/fsf/gcc/cpplib.c amiga/fsf/gcc/cpplib.c
  30012. --- baseline/fsf/gcc/cpplib.c    Sat Nov  4 08:43:48 1995
  30013. +++ amiga/fsf/gcc/cpplib.c    Sat Sep 28 00:00:00 1996
  30014. @@ -151,6 +151,10 @@ static char *predefs = CPP_PREDEFINES;
  30015.  #else
  30016.  static char *predefs = "";
  30017.  #endif
  30018. +
  30019. +#ifdef __amigaos__
  30020. +static int amigaos_abs_filename ();
  30021. +#endif
  30022.  
  30023.  /* We let tm.h override the types used here, to handle trivial differences
  30024.     such as the choice of unsigned int or long unsigned int for size_t.
  30025. @@ -3301,7 +3305,12 @@ do_include (pfile, keyword, unused1, unu
  30026.  
  30027.    /* If specified file name is absolute, just open it.  */
  30028.  
  30029. +/* Phil.B 10-Apr-95 check for absolute filenames */
  30030. +#ifdef __amigaos__
  30031. +  if (amigaos_abs_filename (fbeg, flen)) {
  30032. +#else
  30033.    if (*fbeg == '/') {
  30034. +#endif
  30035.      strncpy (fname, fbeg, flen);
  30036.      fname[flen] = 0;
  30037.      if (redundant_include_p (pfile, fname))
  30038. @@ -3324,6 +3333,10 @@ do_include (pfile, keyword, unused1, unu
  30039.      if (searchptr->fname[0] == 0)
  30040.        continue;
  30041.      strcpy (fname, searchptr->fname);
  30042. +/* Phil.B 10-Arp-95 Avoir foo:/ situations */
  30043. +#ifdef __amigaos__
  30044. +    if (fname[strlen (fname) - 1] != ':')
  30045. +#endif
  30046.      strcat (fname, "/");
  30047.      fname[strlen (fname) + flen] = 0;
  30048.        } else {
  30049. @@ -3397,6 +3410,10 @@ do_include (pfile, keyword, unused1, unu
  30050.                p = (char *) alloca (strlen (searchptr->fname)
  30051.                         + strlen (fname) + 2);
  30052.                strcpy (p, searchptr->fname);
  30053. +/* Phil.B 10-Arp-95 Avoir foo:/ situations */
  30054. +#ifdef __amigaos__
  30055. +                  if (p[strlen (p) - 1] != ':')
  30056. +#endif
  30057.                strcat (p, "/");
  30058.                strcat (p, fname);
  30059.                deps_output (pfile, p, ' ');
  30060. @@ -7508,6 +7525,29 @@ cpp_perror_with_name (pfile, name)
  30061.  {
  30062.    cpp_message (pfile, 1, "%s: %s: %s", progname, name, my_strerror (errno));
  30063.  }
  30064. +
  30065. +#ifdef __amigaos__
  30066. +
  30067. +/* This function returns whether the LEN characters long filename FNAME 
  30068. +   is an absolute path specification. */
  30069. +
  30070. +static int
  30071. +amigaos_abs_filename (fname, len)
  30072. +     char *fname;
  30073. +     int len;
  30074. +{
  30075. +  /* we're using ixemul.library, which treats `/foo' as `foo:', so 
  30076. +     fname[0] is to be considered absolute as well */
  30077. +  if (fname[0] == '/')
  30078. +    return 1;
  30079. +
  30080. +  /* else do an index() on fname, but one which is limited to len characters */
  30081. +  while (*fname && *fname != ':' && len) 
  30082. +    fname++, len--;
  30083. +
  30084. +  return *fname == ':';
  30085. +}
  30086. +#endif /* __amigaos__ */
  30087.  
  30088.  /* TODO:
  30089.   * No pre-compiled header file support.
  30090. diff -rup --new-file baseline/fsf/gcc/cpplib.h amiga/fsf/gcc/cpplib.h
  30091. --- baseline/fsf/gcc/cpplib.h    Thu Jun 15 04:25:11 1995
  30092. +++ amiga/fsf/gcc/cpplib.h    Sat Sep 28 00:00:00 1996
  30093. @@ -315,6 +315,11 @@ struct cpp_options {
  30094.    /* Non-0 means -v, so print the full set of include dirs.  */
  30095.    char verbose;
  30096.  
  30097. +/* Phil.B 10-Apr-95 handle amiga process priority */
  30098. +#ifdef __amigaos__
  30099. +  int amiga_priority;
  30100. +#endif /* __amigaos__ */
  30101. +
  30102.    /* Nonzero means use extra default include directories for C++.  */
  30103.  
  30104.    char cplusplus;
  30105. diff -rup --new-file baseline/fsf/gcc/cppmain.c amiga/fsf/gcc/cppmain.c
  30106. --- baseline/fsf/gcc/cppmain.c    Sat Nov  4 08:31:26 1995
  30107. +++ amiga/fsf/gcc/cppmain.c    Sat Sep 28 00:00:00 1996
  30108. @@ -34,6 +34,11 @@ char *progname;
  30109.  cpp_reader parse_in;
  30110.  cpp_options options;
  30111.  
  30112. +#ifdef __amigaos__
  30113. +#include <proto/exec.h>
  30114. +struct Task *amiga_task;
  30115. +#endif /* __amigaos__ */
  30116. +
  30117.  /* More 'friendly' abort that prints the line and file.
  30118.     config.h can #define abort fancy_abort if you like that sort of thing.  */
  30119.  
  30120. @@ -54,6 +59,15 @@ main (argc, argv)
  30121.    int argi = 1;  /* Next argument to handle. */
  30122.    struct cpp_options *opts = &options;
  30123.  
  30124. +#ifdef __amigaos__
  30125. +  {
  30126. +    char *envstr;
  30127. +
  30128. +    if (envstr = getenv("GCCPRIORITY"))
  30129. +      if (((i = atoi(envstr)) > -20) && (i < 20)) opts->amiga_priority = i;
  30130. +  }
  30131. +#endif /* __amigaos__ */
  30132. +
  30133.    p = argv[0] + strlen (argv[0]);
  30134.    while (p != argv[0] && p[-1] != '/') --p;
  30135.    progname = p;
  30136. @@ -67,6 +81,13 @@ main (argc, argv)
  30137.    if (argi < argc)
  30138.      fatal ("Invalid option `%s'", argv[argi]);
  30139.    parse_in.show_column = 1;
  30140. +
  30141. +#ifdef __amigaos__
  30142. +  Forbid();
  30143. +  amiga_task = FindTask(NULL);
  30144. +  Permit();
  30145. +  SetTaskPri(amiga_task, opts->amiga_priority);
  30146. +#endif /* __amigaos__ */
  30147.  
  30148.    i = push_parse_file (&parse_in, opts->in_fname);
  30149.    if (i != SUCCESS_EXIT_CODE)
  30150. diff -rup --new-file baseline/fsf/gcc/explow.c amiga/fsf/gcc/explow.c
  30151. --- baseline/fsf/gcc/explow.c    Thu Jun 15 04:30:10 1995
  30152. +++ amiga/fsf/gcc/explow.c    Sat Sep 28 00:00:00 1996
  30153. @@ -30,6 +30,7 @@ Boston, MA 02111-1307, USA.  */
  30154.  #include "insn-flags.h"
  30155.  #include "insn-codes.h"
  30156.  
  30157. +rtx gen_stack_cleanup_call();
  30158.  static rtx break_out_memory_refs    PROTO((rtx));
  30159.  
  30160.  /* Return an rtx for the sum of X and the integer C.
  30161. @@ -1095,6 +1096,19 @@ allocate_dynamic_stack_space (size, targ
  30162.        emit_insn (gen_allocate_stack (size));
  30163.      }
  30164.    else
  30165. +#endif
  30166. +#if 1 /* HAVE_stack_on_heap */
  30167. +#ifdef TARGET_STACKCHECK
  30168. +  if (TARGET_STACKCHECK)
  30169. +    emit_insn ((rtx)gen_stack_management_call
  30170. +                (stack_pointer_rtx, size, "jbsr ___stkchk_d0"));
  30171. +#endif
  30172. +#ifdef TARGET_STACKEXTEND
  30173. +  if (TARGET_STACKEXTEND)
  30174. +    emit_insn ((rtx)gen_stack_management_call 
  30175. +                (stack_pointer_rtx, size, "jbsr ___sub_d0_sp"));
  30176. +  else
  30177. +#endif
  30178.  #endif
  30179.      {
  30180.        size = convert_modes (Pmode, ptr_mode, size, 1);
  30181. diff -rup --new-file baseline/fsf/gcc/f/lang-options.h amiga/fsf/gcc/f/lang-options.h
  30182. --- baseline/fsf/gcc/f/lang-options.h    Wed Dec 31 17:00:00 1969
  30183. +++ amiga/fsf/gcc/f/lang-options.h    Sat Sep 28 00:00:00 1996
  30184. @@ -0,0 +1,103 @@
  30185. +/* Definitions for switches for Gnu Fortran.
  30186. +   Copyright (C) 1995 Free Software Foundation, Inc.
  30187. +   Contributed by James Craig Burley (burley@gnu.ai.mit.edu).
  30188. +
  30189. +This file is part of GNU Fortran.
  30190. +
  30191. +GNU Fortran is free software; you can redistribute it and/or modify
  30192. +it under the terms of the GNU General Public License as published by
  30193. +the Free Software Foundation; either version 2, or (at your option)
  30194. +any later version.
  30195. +
  30196. +GNU Fortran is distributed in the hope that it will be useful,
  30197. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  30198. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  30199. +GNU General Public License for more details.
  30200. +
  30201. +You should have received a copy of the GNU General Public License
  30202. +along with GNU Fortran; see the file COPYING.  If not, write to
  30203. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  30204. +
  30205. +*/
  30206. +
  30207. +/* This is the contribution to the `lang_options' array in gcc.c for
  30208. +   Fortran.  */
  30209. +
  30210. +  "-fversion",
  30211. +  "-ff90",
  30212. +  "-fno-f90",
  30213. +  "-fautomatic",
  30214. +  "-fno-automatic",
  30215. +  "-fdollar-ok",
  30216. +  "-fno-dollar-ok",
  30217. +  "-ff2c",
  30218. +  "-fno-f2c",
  30219. +  "-ff2c-library",
  30220. +  "-fno-f2c-library",
  30221. +  "-ffree-form",
  30222. +  "-fno-free-form",
  30223. +  "-ffixed-form",
  30224. +  "-fno-fixed-form",
  30225. +  "-fpedantic",
  30226. +  "-fno-pedantic",
  30227. +  "-fvxt-not-f90",
  30228. +  "-ff90-not-vxt",
  30229. +  "-fugly",
  30230. +  "-fno-ugly",
  30231. +  "-fugly-args",
  30232. +  "-fno-ugly-args",
  30233. +  "-fugly-init",
  30234. +  "-fno-ugly-init",
  30235. +  "-fdebug",
  30236. +  "-fno-debug",
  30237. +  "-finit-local-zero",
  30238. +  "-fno-init-local-zero",
  30239. +  "-fbackslash",
  30240. +  "-fno-backslash",
  30241. +  "-fintrin-case-initcap",
  30242. +  "-fintrin-case-upper",
  30243. +  "-fintrin-case-lower",
  30244. +  "-fintrin-case-any",
  30245. +  "-fmatch-case-initcap",
  30246. +  "-fmatch-case-upper",
  30247. +  "-fmatch-case-lower",
  30248. +  "-fmatch-case-any",
  30249. +  "-fsource-case-upper",
  30250. +  "-fsource-case-lower",
  30251. +  "-fsource-case-preserve",
  30252. +  "-fsymbol-case-initcap",
  30253. +  "-fsymbol-case-upper",
  30254. +  "-fsymbol-case-lower",
  30255. +  "-fsymbol-case-any",
  30256. +  "-fcase-strict-upper",
  30257. +  "-fcase-strict-lower",
  30258. +  "-fcase-initcap",
  30259. +  "-fcase-upper",
  30260. +  "-fcase-lower",
  30261. +  "-fcase-preserve",
  30262. +  "-fdcp-intrinsics-delete",
  30263. +  "-fdcp-intrinsics-hide",
  30264. +  "-fdcp-intrinsics-disable",
  30265. +  "-fdcp-intrinsics-enable",
  30266. +  "-ff2c-intrinsics-delete",
  30267. +  "-ff2c-intrinsics-hide",
  30268. +  "-ff2c-intrinsics-disable",
  30269. +  "-ff2c-intrinsics-enable",
  30270. +  "-ff90-intrinsics-delete",
  30271. +  "-ff90-intrinsics-hide",
  30272. +  "-ff90-intrinsics-disable",
  30273. +  "-ff90-intrinsics-enable",
  30274. +  "-fmil-intrinsics-delete",
  30275. +  "-fmil-intrinsics-hide",
  30276. +  "-fmil-intrinsics-disable",
  30277. +  "-fmil-intrinsics-enable",
  30278. +  "-fvxt-intrinsics-delete",
  30279. +  "-fvxt-intrinsics-hide",
  30280. +  "-fvxt-intrinsics-disable",
  30281. +  "-fvxt-intrinsics-enable",
  30282. +  "-Wimplicit",
  30283. +  "-Wno-implicit",
  30284. +  "-Wall",
  30285. +/* Prefix options.  */
  30286. +  "-I",
  30287. +  "-ffixed-line-length-",
  30288. diff -rup --new-file baseline/fsf/gcc/f/lang-specs.h amiga/fsf/gcc/f/lang-specs.h
  30289. --- baseline/fsf/gcc/f/lang-specs.h    Wed Dec 31 17:00:00 1969
  30290. +++ amiga/fsf/gcc/f/lang-specs.h    Sat Sep 28 00:00:00 1996
  30291. @@ -0,0 +1,81 @@
  30292. +/* Definitions for specs for Gnu Fortran
  30293. +   Copyright (C) 1995 Free Software Foundation, Inc.
  30294. +
  30295. +This file is part of GNU Fortran.
  30296. +
  30297. +GNU Fortran is free software; you can redistribute it and/or modify
  30298. +it under the terms of the GNU General Public License as published by
  30299. +the Free Software Foundation; either version 2, or (at your option)
  30300. +any later version.
  30301. +
  30302. +GNU Fortran is distributed in the hope that it will be useful,
  30303. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  30304. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  30305. +GNU General Public License for more details.
  30306. +
  30307. +You should have received a copy of the GNU General Public License
  30308. +along with GNU Fortran; see the file COPYING.  If not, write to
  30309. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  30310. +
  30311. +*/
  30312. +
  30313. +/* Definitions for specs for C++.
  30314. +   Copyright (C) 1995 Free Software Foundation, Inc.
  30315. +
  30316. +This file is part of GNU CC.
  30317. +
  30318. +GNU CC is free software; you can redistribute it and/or modify
  30319. +it under the terms of the GNU General Public License as published by
  30320. +the Free Software Foundation; either version 2, or (at your option)
  30321. +any later version.
  30322. +
  30323. +GNU CC is distributed in the hope that it will be useful,
  30324. +but WITHOUT ANY WARRANTY; without even the implied warranty of
  30325. +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  30326. +GNU General Public License for more details.
  30327. +
  30328. +You should have received a copy of the GNU General Public License
  30329. +along with GNU CC; see the file COPYING.  If not, write to
  30330. +the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  30331. +
  30332. +/* This is the contribution to the `default_compilers' array in gcc.c for
  30333. +   Fortran.  */
  30334. +
  30335. +  {".F", "@f77-cpp-input"},
  30336. +  {"@f77-cpp-input",
  30337. +     /* For f77 we want -traditional to avoid errors with, for
  30338. +    instance, mismatched '.  Also, we avoid unpleasant surprises
  30339. +    with substitution of names not prefixed by `_' by using %P
  30340. +    rather than %p (although this isn't consistent with SGI and
  30341. +    Sun f77, at least) so you test `__unix' rather than `unix'.
  30342. +    -D_LANGUAGE_FORTRAN is used by some compilers like SGI and
  30343. +    might as well be in there. */
  30344. +   "cpp -lang-c -P %{nostdinc*} %{C} %{v} %{A*} %{I*} %I\
  30345. +    %{C:%{!E:%eGNU C does not support -C without using -E}}\
  30346. +    %{M} %{MM} %{MD:-MD %b.d} %{MMD:-MMD %b.d} %{MG}\
  30347. +        -undef -D__GNUC__=2 %{ansi:-trigraphs -$ -D__STRICT_ANSI__}\
  30348. +    %{!undef:%P} -D_LANGUAGE_FORTRAN %{trigraphs} \
  30349. +        %c %{O*:-D__OPTIMIZE__} -traditional %{ftraditional:-traditional}\
  30350. +        %{traditional-cpp:-traditional}\
  30351. +    %{g*} %{W*} %{w} %{pedantic*} %{H} %{d*} %C %{D*} %{U*} %{i*} %Z\
  30352. +        %i %{!M:%{!MM:%{!E:%{!pipe:%g.i}}}}%{E:%W{o*}}%{M:%W{o*}}%{MM:%W{o*}} |\n",
  30353. +           "f771 %{!pipe:%g.i} \
  30354. +           %{!Q:-quiet} -dumpbase %b.F %{d*} %{m*} %{a}\
  30355. +           %{g*} %{O*} %{W*} %{w} %{pedantic*} \
  30356. +           %{v:-version -fversion} %{f*}\
  30357. +           %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
  30358. +           %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
  30359. +              %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %{keep-local-as-symbols:-L} \
  30360. +              %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
  30361. +                      %{!pipe:%g.s} %A\n }"},
  30362. +  {".f", "@f77"},
  30363. +  {".for", "@f77"},
  30364. +  {"@f77","f771 %i \
  30365. +           %{!Q:-quiet} -dumpbase %b.f %{d*} %{m*} %{a}\
  30366. +           %{g*} %{O*} %{W*} %{w} %{pedantic*} \
  30367. +           %{v:-version -fversion} %{f*}\
  30368. +           %{pg:%{fomit-frame-pointer:%e-pg and -fomit-frame-pointer are incompatible}}\
  30369. +           %{S:%W{o*}%{!o*:-o %b.s}}%{!S:-o %{|!pipe:%g.s}} |\n\
  30370. +              %{!S:as %{R} %{j} %{J} %{h} %{d2} %a %{keep-local-as-symbols:-L} \
  30371. +              %{c:%W{o*}%{!o*:-o %w%b.o}}%{!c:-o %d%w%u.o}\
  30372. +                      %{!pipe:%g.s} %A\n }"},
  30373. diff -rup --new-file baseline/fsf/gcc/final.c amiga/fsf/gcc/final.c
  30374. --- baseline/fsf/gcc/final.c    Sun Nov 26 11:50:00 1995
  30375. +++ amiga/fsf/gcc/final.c    Sat Sep 28 00:00:00 1996
  30376. @@ -2052,6 +2052,10 @@ output_source_line (file, insn)
  30377.  
  30378.    if (write_symbols != NO_DEBUG)
  30379.      {
  30380. +/* Phil.B: 03-Oct-94 added q_anote from albaugh@agames.com (Mike Albaugh) */
  30381. +#if defined(TARGET_AMIGAOS) && defined(ASM_NOTE_SOURCE_LINE)
  30382. +  ASM_NOTE_SOURCE_LINE(file,last_linenum,filename);
  30383. +#endif
  30384.  #ifdef SDB_DEBUGGING_INFO
  30385.        if (write_symbols == SDB_DEBUG
  30386.  #if 0 /* People like having line numbers even in wrong file!  */
  30387. diff -rup --new-file baseline/fsf/gcc/fixincludes amiga/fsf/gcc/fixincludes
  30388. --- baseline/fsf/gcc/fixincludes    Sat Jun 29 09:26:49 1996
  30389. +++ amiga/fsf/gcc/fixincludes    Sat Sep 28 00:00:00 1996
  30390. @@ -57,6 +57,9 @@ elif ln -s X /tmp/ShouldNotExist 2>/dev/
  30391.  else
  30392.    LINKS=false
  30393.  fi
  30394. +# AmigaOS hack - we have symbolic links, but it's generally
  30395. +# better to not depend on them working correctly.
  30396. +LINKS=false
  30397.  
  30398.  echo Finding directories and links to directories
  30399.  cd ${INPUT}
  30400. diff -rup --new-file baseline/fsf/gcc/gcc.c amiga/fsf/gcc/gcc.c
  30401. --- baseline/fsf/gcc/gcc.c    Tue Sep 12 14:15:11 1995
  30402. +++ amiga/fsf/gcc/gcc.c    Sat Sep 28 00:00:00 1996
  30403. @@ -226,6 +226,11 @@ static int verbose_flag;
  30404.  
  30405.  static int save_temps_flag;
  30406.  
  30407. +#ifdef __amigaos__
  30408. +/* Phil.B: 03-Oct-94 Flag indicating process priority */
  30409. +static int amiga_priority = 0;
  30410. +#endif
  30411. +
  30412.  /* The compiler version.  */
  30413.  
  30414.  static char *compiler_version;
  30415. @@ -819,6 +824,10 @@ struct option_map option_map[] =
  30416.     {"--pedantic-errors", "-pedantic-errors", 0},
  30417.     {"--pipe", "-pipe", 0},
  30418.     {"--prefix", "-B", "a"},
  30419. +/* Phil.B: 03-Oct-94, allow priority settings for all programs started by gcc */
  30420. +#ifdef __amigaos__
  30421. +   {"--priority", "-priority", "a"},
  30422. +#endif /* __amigaos__ */
  30423.     {"--preprocess", "-E", 0},
  30424.     {"--print-search-dirs", "-print-search-dirs", 0},
  30425.     {"--print-file-name", "-print-file-name=", "aj"},
  30426. @@ -1350,17 +1359,17 @@ static char *gcc_exec_prefix;
  30427.  #endif
  30428.  
  30429.  #ifndef STANDARD_EXEC_PREFIX
  30430. -#define STANDARD_EXEC_PREFIX "/usr/local/lib/gcc-lib/"
  30431. +#define STANDARD_EXEC_PREFIX "/ade/lib/gcc-lib/"
  30432.  #endif /* !defined STANDARD_EXEC_PREFIX */
  30433.  
  30434.  static char *standard_exec_prefix = STANDARD_EXEC_PREFIX;
  30435. -static char *standard_exec_prefix_1 = "/usr/lib/gcc/";
  30436. +static char *standard_exec_prefix_1 = "/local/lib/gcc-lib/";
  30437.  #ifdef MD_EXEC_PREFIX
  30438.  static char *md_exec_prefix = MD_EXEC_PREFIX;
  30439.  #endif
  30440.  
  30441.  #ifndef STANDARD_STARTFILE_PREFIX
  30442. -#define STANDARD_STARTFILE_PREFIX "/usr/local/lib/"
  30443. +#define STANDARD_STARTFILE_PREFIX "/ade/lib/"
  30444.  #endif /* !defined STANDARD_STARTFILE_PREFIX */
  30445.  
  30446.  #ifdef MD_STARTFILE_PREFIX
  30447. @@ -1370,11 +1379,11 @@ static char *md_startfile_prefix = MD_ST
  30448.  static char *md_startfile_prefix_1 = MD_STARTFILE_PREFIX_1;
  30449.  #endif
  30450.  static char *standard_startfile_prefix = STANDARD_STARTFILE_PREFIX;
  30451. -static char *standard_startfile_prefix_1 = "/lib/";
  30452. -static char *standard_startfile_prefix_2 = "/usr/lib/";
  30453. +static char *standard_startfile_prefix_1 = "/local/lib/";
  30454. +static char *standard_startfile_prefix_2 = "/local/lib/";
  30455.  
  30456.  #ifndef TOOLDIR_BASE_PREFIX
  30457. -#define TOOLDIR_BASE_PREFIX "/usr/local/"
  30458. +#define TOOLDIR_BASE_PREFIX "/local/"
  30459.  #endif
  30460.  static char *tooldir_base_prefix = TOOLDIR_BASE_PREFIX;
  30461.  static char *tooldir_prefix;
  30462. @@ -1575,11 +1584,17 @@ choose_temp_base ()
  30463.    base = choose_temp_base_try (P_tmpdir, base);
  30464.  #endif
  30465.  
  30466. +#ifdef __amigaos__
  30467. +  if (!base) /* No env var set */
  30468. +    base = "RAM:";
  30469. +#else
  30470.    base = choose_temp_base_try (concat4 (dir_separator_str, "usr", 
  30471.                                          dir_separator_str, "tmp"), 
  30472.                                  base);
  30473.    base = choose_temp_base_try (concat (dir_separator_str, "tmp"), base);
  30474.   
  30475. +#endif
  30476. +
  30477.    /* If all else fails, use the current directory! */  
  30478.    if (base == (char *)0) base = concat(".", dir_separator_str);
  30479.  
  30480. @@ -1588,7 +1603,11 @@ choose_temp_base ()
  30481.                                                   "ccXXXXXX")) + 1);
  30482.    strcpy (temp_filename, base);
  30483.    if (len > 0 && temp_filename[len-1] != '/'
  30484. -      && temp_filename[len-1] != DIR_SEPARATOR)
  30485. +      && temp_filename[len-1] != DIR_SEPARATOR
  30486. +#ifdef VOL_SEPARATOR
  30487. +      && temp_filename[len-1] != VOL_SEPARATOR
  30488. +#endif
  30489. +    )
  30490.      temp_filename[len++] = DIR_SEPARATOR;
  30491.    strcpy (temp_filename + len, "ccXXXXXX");
  30492.  
  30493. @@ -1749,7 +1768,11 @@ find_a_file (pprefix, name, mode)
  30494.  
  30495.    /* Determine the filename to execute (special case for absolute paths).  */
  30496.  
  30497. -  if (*name == '/' || *name == DIR_SEPARATOR)
  30498. +  if (*name == '/' || *name == DIR_SEPARATOR
  30499. +#ifdef VOL_SEPARATOR
  30500. +      || index (name, VOL_SEPARATOR)
  30501. +#endif
  30502. +    )
  30503.      {
  30504.        if (access (name, mode))
  30505.      {
  30506. @@ -1969,6 +1992,7 @@ static int last_pipe_input;
  30507.     NOT_LAST is nonzero if this is not the last subcommand
  30508.     (i.e. its output should be piped to the next one.)  */
  30509.  
  30510. +#ifndef PEXECUTE
  30511.  #ifdef __MSDOS__
  30512.  
  30513.  #include <process.h>
  30514. @@ -2139,6 +2163,7 @@ pexecute (search_flag, program, argv, no
  30515.    return (search_flag ? __spawnv : __spawnvp) (1, program, argv);
  30516.  }
  30517.  #endif /* _WIN32 */
  30518. +#endif /* !defined (PEXECUTE) */
  30519.  
  30520.  
  30521.  /* Execute the command specified by the arguments on the current line of spec.
  30522. @@ -2234,9 +2259,15 @@ execute ()
  30523.      {
  30524.        char *string = commands[i].argv[0];
  30525.  
  30526. +#ifdef PEXECUTE
  30527. +      commands[i].pid = PEXECUTE (string != commands[i].prog,
  30528. +                  string, commands[i].argv,
  30529. +                  i + 1 < n_commands);
  30530. +#else
  30531.        commands[i].pid = pexecute (string != commands[i].prog,
  30532.                    string, commands[i].argv,
  30533.                    i + 1 < n_commands);
  30534. +#endif
  30535.  
  30536.        if (string != commands[i].prog)
  30537.      free (string);
  30538. @@ -2259,6 +2290,9 @@ execute ()
  30539.      int status;
  30540.      int pid;
  30541.  
  30542. +#ifdef PEXECUTE_RESULT
  30543. +    pid = PEXECUTE_RESULT (status, commands[i]);
  30544. +#else /* PEXECUTE_RESULT */
  30545.  #ifdef __MSDOS__
  30546.          status = pid = commands[i].pid;
  30547.  #else
  30548. @@ -2268,6 +2302,7 @@ execute ()
  30549.      pid = wait (&status);
  30550.  #endif
  30551.  #endif
  30552. +#endif /* PEXECUTE_RESULT */
  30553.      if (pid < 0)
  30554.        abort ();
  30555.  
  30556. @@ -2387,6 +2422,7 @@ process_command (argc, argv)
  30557.        if (*endp == PATH_SEPARATOR || *endp == 0)
  30558.          {
  30559.            strncpy (nstore, startp, endp-startp);
  30560. +#ifndef __amigaos__
  30561.            if (endp == startp)
  30562.          strcpy (nstore, concat (".", dir_separator_str));
  30563.            else if (endp[-1] != '/' && endp[-1] != DIR_SEPARATOR)
  30564. @@ -2396,6 +2432,15 @@ process_command (argc, argv)
  30565.          }
  30566.            else
  30567.          nstore[endp-startp] = 0;
  30568. +#else
  30569. +          if (endp[-1] != '/' && endp[-1] != ':')
  30570. +        {
  30571. +          nstore[endp-startp] = '/';
  30572. +          nstore[endp-startp+1] = 0;
  30573. +        }
  30574. +          else
  30575. +        nstore[endp-startp] = 0;
  30576. +#endif
  30577.            add_prefix (&exec_prefixes, nstore, 0, 0, NULL_PTR);
  30578.            if (*endp == 0)
  30579.          break;
  30580. @@ -2418,6 +2463,7 @@ process_command (argc, argv)
  30581.        if (*endp == PATH_SEPARATOR || *endp == 0)
  30582.          {
  30583.            strncpy (nstore, startp, endp-startp);
  30584. +#ifndef __amigaos__
  30585.            if (endp == startp)
  30586.          strcpy (nstore, concat (".", dir_separator_str));
  30587.            else if (endp[-1] != '/' && endp[-1] != DIR_SEPARATOR)
  30588. @@ -2427,6 +2473,15 @@ process_command (argc, argv)
  30589.          }
  30590.            else
  30591.          nstore[endp-startp] = 0;
  30592. +#else
  30593. +          if (endp[-1] != '/' && endp[-1] != ':')
  30594. +        {
  30595. +          nstore[endp-startp] = '/';
  30596. +          nstore[endp-startp+1] = 0;
  30597. +        }
  30598. +          else
  30599. +        nstore[endp-startp] = 0;
  30600. +#endif
  30601.            add_prefix (&startfile_prefixes, nstore, 0, 0, NULL_PTR);
  30602.            if (*endp == 0)
  30603.          break;
  30604. @@ -2450,6 +2505,7 @@ process_command (argc, argv)
  30605.        if (*endp == PATH_SEPARATOR || *endp == 0)
  30606.          {
  30607.            strncpy (nstore, startp, endp-startp);
  30608. +#ifndef __amigaos__
  30609.            if (endp == startp)
  30610.          strcpy (nstore, concat (".", dir_separator_str));
  30611.            else if (endp[-1] != '/' && endp[-1] != DIR_SEPARATOR)
  30612. @@ -2459,6 +2515,15 @@ process_command (argc, argv)
  30613.          }
  30614.            else
  30615.          nstore[endp-startp] = 0;
  30616. +#else
  30617. +          if (endp[-1] != '/' && endp[-1] != ':')
  30618. +        {
  30619. +          nstore[endp-startp] = '/';
  30620. +          nstore[endp-startp+1] = 0;
  30621. +        }
  30622. +          else
  30623. +        nstore[endp-startp] = 0;
  30624. +#endif
  30625.            add_prefix (&startfile_prefixes, nstore, 0, 0, NULL_PTR);
  30626.            if (*endp == 0)
  30627.          break;
  30628. @@ -2478,6 +2543,16 @@ process_command (argc, argv)
  30629.  
  30630.    for (i = 1; i < argc; i++)
  30631.      {
  30632. +#ifdef __amigaos__
  30633. +      /* Phil.B 03-Oct-94 added -priority keyword */
  30634. +      if (! strcmp (argv[i], "-priority"))
  30635. +        {
  30636. +      if (i + 1 == argc)
  30637. +        fatal ("argument to `-priority' is missing");
  30638. +          amiga_priority = atoi(argv[++i]);
  30639. +        }
  30640. +      else
  30641. +#endif /* __amigaos__ */
  30642.        if (! strcmp (argv[i], "-dumpspecs"))
  30643.      {
  30644.        printf ("*asm:\n%s\n\n", asm_spec);
  30645. @@ -4453,10 +4528,14 @@ main (argc, argv)
  30646.        register char *p;
  30647.        int len;
  30648.  
  30649. +#ifdef FILE_NAME_NONDIRECTORY
  30650. +      input_basename = FILE_NAME_NONDIRECTORY (input_filename);
  30651. +#else
  30652.        input_basename = input_filename;
  30653.        for (p = input_filename; *p; p++)
  30654.          if (*p == '/' || *p == DIR_SEPARATOR)
  30655.            input_basename = p + 1;
  30656. +#endif
  30657.  
  30658.        /* Find a suffix starting with the last period,
  30659.           and set basename_length to exclude that suffix.  */
  30660. diff -rup --new-file baseline/fsf/gcc/gcc.info amiga/fsf/gcc/gcc.info
  30661. --- baseline/fsf/gcc/gcc.info    Sat Jun 29 09:38:13 1996
  30662. +++ amiga/fsf/gcc/gcc.info    Wed Dec 31 17:00:00 1969
  30663. @@ -1,297 +0,0 @@
  30664. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  30665. -file gcc.texi.
  30666. -
  30667. -   This file documents the use and the internals of the GNU compiler.
  30668. -
  30669. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  30670. -Boston, MA 02111-1307 USA
  30671. -
  30672. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  30673. -Foundation, Inc.
  30674. -
  30675. -   Permission is granted to make and distribute verbatim copies of this
  30676. -manual provided the copyright notice and this permission notice are
  30677. -preserved on all copies.
  30678. -
  30679. -   Permission is granted to copy and distribute modified versions of
  30680. -this manual under the conditions for verbatim copying, provided also
  30681. -that the sections entitled "GNU General Public License," "Funding for
  30682. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  30683. -included exactly as in the original, and provided that the entire
  30684. -resulting derived work is distributed under the terms of a permission
  30685. -notice identical to this one.
  30686. -
  30687. -   Permission is granted to copy and distribute translations of this
  30688. -manual into another language, under the above conditions for modified
  30689. -versions, except that the sections entitled "GNU General Public
  30690. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  30691. -`Look And Feel'", and this permission notice, may be included in
  30692. -translations approved by the Free Software Foundation instead of in the
  30693. -original English.
  30694. -
  30695. -
  30696. -Indirect:
  30697. -gcc.info-1: 1382
  30698. -gcc.info-2: 43097
  30699. -gcc.info-3: 80821
  30700. -gcc.info-4: 127851
  30701. -gcc.info-5: 174035
  30702. -gcc.info-6: 214969
  30703. -gcc.info-7: 235679
  30704. -gcc.info-8: 284365
  30705. -gcc.info-9: 332849
  30706. -gcc.info-10: 381898
  30707. -gcc.info-11: 418861
  30708. -gcc.info-12: 467700
  30709. -gcc.info-13: 516731
  30710. -gcc.info-14: 564073
  30711. -gcc.info-15: 603626
  30712. -gcc.info-16: 653599
  30713. -gcc.info-17: 702552
  30714. -gcc.info-18: 750730
  30715. -gcc.info-19: 796588
  30716. -gcc.info-20: 845390
  30717. -gcc.info-21: 889488
  30718. -gcc.info-22: 932694
  30719. -gcc.info-23: 981583
  30720. -gcc.info-24: 1031486
  30721. -gcc.info-25: 1066741
  30722. -
  30723. -Tag Table:
  30724. -(Indirect)
  30725. -Node: Top1382
  30726. -Node: Copying3067
  30727. -Node: Contributors22249
  30728. -Node: Funding27395
  30729. -Node: Look and Feel29892
  30730. -Node: G++ and GCC37501
  30731. -Node: Invoking GCC39718
  30732. -Node: Option Summary43097
  30733. -Node: Overall Options53548
  30734. -Node: Invoking G++58111
  30735. -Node: C Dialect Options59985
  30736. -Node: C++ Dialect Options70085
  30737. -Node: Warning Options80821
  30738. -Node: Debugging Options95756
  30739. -Node: Optimize Options105337
  30740. -Node: Preprocessor Options115839
  30741. -Node: Assembler Options122302
  30742. -Node: Link Options122669
  30743. -Node: Directory Options127851
  30744. -Node: Target Options131343
  30745. -Node: Submodel Options135000
  30746. -Node: M680x0 Options136381
  30747. -Node: VAX Options139890
  30748. -Node: SPARC Options140425
  30749. -Node: Convex Options146845
  30750. -Node: AMD29K Options149026
  30751. -Node: ARM Options152057
  30752. -Node: M88K Options153474
  30753. -Node: RS/6000 and PowerPC Options161421
  30754. -Node: RT Options172331
  30755. -Node: MIPS Options174035
  30756. -Node: i386 Options181661
  30757. -Node: HPPA Options187100
  30758. -Node: Intel 960 Options190196
  30759. -Node: DEC Alpha Options192806
  30760. -Node: Clipper Options194478
  30761. -Node: H8/300 Options194877
  30762. -Node: System V Options195322
  30763. -Node: Code Gen Options196008
  30764. -Node: Environment Variables204517
  30765. -Node: Running Protoize208740
  30766. -Node: Installation214969
  30767. -Node: Configurations235679
  30768. -Node: Other Dir270554
  30769. -Node: Cross-Compiler272270
  30770. -Node: Steps of Cross274101
  30771. -Node: Configure Cross275219
  30772. -Node: Tools and Libraries275856
  30773. -Node: Cross Runtime278299
  30774. -Node: Cross Headers282380
  30775. -Node: Build Cross284365
  30776. -Node: Sun Install286241
  30777. -Node: VMS Install287373
  30778. -Node: Collect2297302
  30779. -Node: Header Dirs300011
  30780. -Node: C Extensions301425
  30781. -Node: Statement Exprs304704
  30782. -Node: Local Labels306598
  30783. -Node: Labels as Values308660
  30784. -Node: Nested Functions310525
  30785. -Node: Constructing Calls314381
  30786. -Node: Naming Types316438
  30787. -Node: Typeof317532
  30788. -Node: Lvalues319397
  30789. -Node: Conditionals321837
  30790. -Node: Long Long322728
  30791. -Node: Complex324172
  30792. -Node: Zero Length326034
  30793. -Node: Variable Length326708
  30794. -Node: Macro Varargs329233
  30795. -Node: Subscripting331336
  30796. -Node: Pointer Arith331819
  30797. -Node: Initializers332384
  30798. -Node: Constructors332849
  30799. -Node: Labeled Elements334543
  30800. -Node: Case Ranges337172
  30801. -Node: Cast to Union337853
  30802. -Node: Function Attributes338931
  30803. -Node: Function Prototypes348194
  30804. -Node: C++ Comments349993
  30805. -Node: Dollar Signs350529
  30806. -Node: Character Escapes351309
  30807. -Node: Alignment351590
  30808. -Node: Variable Attributes353062
  30809. -Node: Type Attributes360970
  30810. -Node: Inline367489
  30811. -Node: Extended Asm371366
  30812. -Node: Asm Labels381898
  30813. -Node: Explicit Reg Vars383217
  30814. -Node: Global Reg Vars384465
  30815. -Node: Local Reg Vars389030
  30816. -Node: Alternate Keywords390622
  30817. -Node: Incomplete Enums392024
  30818. -Node: Function Names392780
  30819. -Node: C++ Extensions394031
  30820. -Node: Naming Results395268
  30821. -Node: Min and Max398582
  30822. -Node: Destructors and Goto400032
  30823. -Node: C++ Interface400582
  30824. -Node: Template Instantiation405805
  30825. -Node: C++ Signatures411537
  30826. -Node: Trouble415881
  30827. -Node: Actual Bugs417592
  30828. -Node: Installation Problems418861
  30829. -Node: Cross-Compiler Problems432668
  30830. -Node: Interoperation434139
  30831. -Node: External Bugs447503
  30832. -Node: Incompatibilities449635
  30833. -Node: Fixed Headers458185
  30834. -Node: Standard Libraries460527
  30835. -Node: Disappointments461774
  30836. -Node: C++ Misunderstandings465999
  30837. -Node: Static Definitions466646
  30838. -Node: Temporaries467700
  30839. -Node: Protoize Caveats469904
  30840. -Node: Non-bugs473860
  30841. -Node: Warnings and Errors482820
  30842. -Node: Bugs484590
  30843. -Node: Bug Criteria485950
  30844. -Node: Bug Lists488380
  30845. -Node: Bug Reporting489773
  30846. -Node: Sending Patches502191
  30847. -Node: Service507578
  30848. -Node: VMS508139
  30849. -Node: Include Files and VMS508532
  30850. -Node: Global Declarations512422
  30851. -Node: VMS Misc516731
  30852. -Node: Portability521057
  30853. -Node: Interface522820
  30854. -Node: Passes527453
  30855. -Node: RTL544796
  30856. -Node: RTL Objects546684
  30857. -Node: Accessors549728
  30858. -Node: Flags555054
  30859. -Node: Machine Modes564073
  30860. -Node: Constants571707
  30861. -Node: Regs and Memory576895
  30862. -Node: Arithmetic588605
  30863. -Node: Comparisons594503
  30864. -Node: Bit Fields598565
  30865. -Node: Conversions599929
  30866. -Node: RTL Declarations602817
  30867. -Node: Side Effects603626
  30868. -Node: Incdec616173
  30869. -Node: Assembler618689
  30870. -Node: Insns620211
  30871. -Node: Calls641064
  30872. -Node: Sharing643659
  30873. -Node: Reading RTL646735
  30874. -Node: Machine Desc647674
  30875. -Node: Patterns649527
  30876. -Node: Example652471
  30877. -Node: RTL Template653599
  30878. -Node: Output Template665797
  30879. -Node: Output Statement669758
  30880. -Node: Constraints673471
  30881. -Node: Simple Constraints674474
  30882. -Node: Multi-Alternative685907
  30883. -Node: Class Preferences688743
  30884. -Node: Modifiers689623
  30885. -Node: Machine Constraints692783
  30886. -Node: No Constraints701431
  30887. -Node: Standard Names702552
  30888. -Node: Pattern Ordering730460
  30889. -Node: Dependent Patterns731686
  30890. -Node: Jump Patterns734501
  30891. -Node: Insn Canonicalizations740317
  30892. -Node: Peephole Definitions743812
  30893. -Node: Expander Definitions750730
  30894. -Node: Insn Splitting758176
  30895. -Node: Insn Attributes765190
  30896. -Node: Defining Attributes766237
  30897. -Node: Expressions768249
  30898. -Node: Tagging Insns774561
  30899. -Node: Attr Example778924
  30900. -Node: Insn Lengths781300
  30901. -Node: Constant Attributes784664
  30902. -Node: Delay Slots785824
  30903. -Node: Function Units789035
  30904. -Node: Target Macros794705
  30905. -Node: Driver796588
  30906. -Node: Run-time Target808318
  30907. -Node: Storage Layout814205
  30908. -Node: Type Layout828153
  30909. -Node: Registers834576
  30910. -Node: Register Basics835556
  30911. -Node: Allocation Order839593
  30912. -Node: Values in Registers841011
  30913. -Node: Leaf Functions845390
  30914. -Node: Stack Registers847865
  30915. -Node: Obsolete Register Macros848698
  30916. -Node: Register Classes851393
  30917. -Node: Stack and Calling870928
  30918. -Node: Frame Layout871364
  30919. -Node: Frame Registers874804
  30920. -Node: Elimination878614
  30921. -Node: Stack Arguments882870
  30922. -Node: Register Arguments889488
  30923. -Node: Scalar Return898163
  30924. -Node: Aggregate Return902126
  30925. -Node: Caller Saves905841
  30926. -Node: Function Entry906991
  30927. -Node: Profiling915919
  30928. -Node: Varargs918823
  30929. -Node: Trampolines926232
  30930. -Node: Library Calls932694
  30931. -Node: Addressing Modes940752
  30932. -Node: Condition Code948340
  30933. -Node: Costs954539
  30934. -Node: Sections962918
  30935. -Node: PIC967707
  30936. -Node: Assembler Format970417
  30937. -Node: File Framework971422
  30938. -Node: Data Output975659
  30939. -Node: Uninitialized Data981583
  30940. -Node: Label Output984290
  30941. -Node: Initialization993684
  30942. -Node: Macros for Initialization999827
  30943. -Node: Instruction Output1004424
  30944. -Node: Dispatch Tables1012419
  30945. -Node: Alignment Output1014796
  30946. -Node: Debugging Info1016536
  30947. -Node: All Debuggers1017145
  30948. -Node: DBX Options1019559
  30949. -Node: DBX Hooks1024444
  30950. -Node: File Names and DBX1027783
  30951. -Node: SDB and DWARF1029756
  30952. -Node: Cross-compilation1031486
  30953. -Node: Misc1037933
  30954. -Node: Config1055059
  30955. -Node: Fragments1062504
  30956. -Node: Target Fragment1063101
  30957. -Node: Host Fragment1066139
  30958. -Node: Index1066741
  30959. -
  30960. -End Tag Table
  30961. diff -rup --new-file baseline/fsf/gcc/gcc.info-1 amiga/fsf/gcc/gcc.info-1
  30962. --- baseline/fsf/gcc/gcc.info-1    Sat Jun 29 09:37:56 1996
  30963. +++ amiga/fsf/gcc/gcc.info-1    Wed Dec 31 17:00:00 1969
  30964. @@ -1,900 +0,0 @@
  30965. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  30966. -file gcc.texi.
  30967. -
  30968. -   This file documents the use and the internals of the GNU compiler.
  30969. -
  30970. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  30971. -Boston, MA 02111-1307 USA
  30972. -
  30973. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  30974. -Foundation, Inc.
  30975. -
  30976. -   Permission is granted to make and distribute verbatim copies of this
  30977. -manual provided the copyright notice and this permission notice are
  30978. -preserved on all copies.
  30979. -
  30980. -   Permission is granted to copy and distribute modified versions of
  30981. -this manual under the conditions for verbatim copying, provided also
  30982. -that the sections entitled "GNU General Public License," "Funding for
  30983. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  30984. -included exactly as in the original, and provided that the entire
  30985. -resulting derived work is distributed under the terms of a permission
  30986. -notice identical to this one.
  30987. -
  30988. -   Permission is granted to copy and distribute translations of this
  30989. -manual into another language, under the above conditions for modified
  30990. -versions, except that the sections entitled "GNU General Public
  30991. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  30992. -`Look And Feel'", and this permission notice, may be included in
  30993. -translations approved by the Free Software Foundation instead of in the
  30994. -original English.
  30995. -
  30996. -
  30997. -File: gcc.info,  Node: Top,  Next: Copying,  Up: (DIR)
  30998. -
  30999. -Introduction
  31000. -************
  31001. -
  31002. -   This manual documents how to run, install and port the GNU compiler,
  31003. -as well as its new features and incompatibilities, and how to report
  31004. -bugs.  It corresponds to GNU CC version 2.7.2.
  31005. -
  31006. -* Menu:
  31007. -
  31008. -* Copying::         GNU General Public License says
  31009. -                     how you can copy and share GNU CC.
  31010. -* Contributors::    People who have contributed to GNU CC.
  31011. -* Funding::         How to help assure funding for free software.
  31012. -* Look and Feel::   Protect your freedom--fight "look and feel".
  31013. -
  31014. -* G++ and GCC::     You can compile C or C++ programs.
  31015. -* Invoking GCC::    Command options supported by `gcc'.
  31016. -* Installation::    How to configure, compile and install GNU CC.
  31017. -* C Extensions::    GNU extensions to the C language family.
  31018. -* C++ Extensions::  GNU extensions to the C++ language.
  31019. -* Trouble::         If you have trouble installing GNU CC.
  31020. -* Bugs::            How, why and where to report bugs.
  31021. -* Service::         How to find suppliers of support for GNU CC.
  31022. -* VMS::             Using GNU CC on VMS.
  31023. -
  31024. -* Portability::     Goals of GNU CC's portability features.
  31025. -* Interface::       Function-call interface of GNU CC output.
  31026. -* Passes::          Order of passes, what they do, and what each file is for.
  31027. -* RTL::             The intermediate representation that most passes work on.
  31028. -* Machine Desc::    How to write machine description instruction patterns.
  31029. -* Target Macros::   How to write the machine description C macros.
  31030. -* Config::          Writing the `xm-MACHINE.h' file.
  31031. -* Fragments::       Writing the `t-TARGET' and `x-HOST' files.
  31032. -
  31033. -* Index::        Index of concepts and symbol names.
  31034. -
  31035. -
  31036. -File: gcc.info,  Node: Copying,  Next: Contributors,  Prev: Top,  Up: Top
  31037. -
  31038. -GNU GENERAL PUBLIC LICENSE
  31039. -**************************
  31040. -
  31041. -                         Version 2, June 1991
  31042. -
  31043. -     Copyright (C) 1989, 1991 Free Software Foundation, Inc.
  31044. -     59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  31045. -     
  31046. -     Everyone is permitted to copy and distribute verbatim copies
  31047. -     of this license document, but changing it is not allowed.
  31048. -
  31049. -Preamble
  31050. -========
  31051. -
  31052. -   The licenses for most software are designed to take away your
  31053. -freedom to share and change it.  By contrast, the GNU General Public
  31054. -License is intended to guarantee your freedom to share and change free
  31055. -software--to make sure the software is free for all its users.  This
  31056. -General Public License applies to most of the Free Software
  31057. -Foundation's software and to any other program whose authors commit to
  31058. -using it.  (Some other Free Software Foundation software is covered by
  31059. -the GNU Library General Public License instead.)  You can apply it to
  31060. -your programs, too.
  31061. -
  31062. -   When we speak of free software, we are referring to freedom, not
  31063. -price.  Our General Public Licenses are designed to make sure that you
  31064. -have the freedom to distribute copies of free software (and charge for
  31065. -this service if you wish), that you receive source code or can get it
  31066. -if you want it, that you can change the software or use pieces of it in
  31067. -new free programs; and that you know you can do these things.
  31068. -
  31069. -   To protect your rights, we need to make restrictions that forbid
  31070. -anyone to deny you these rights or to ask you to surrender the rights.
  31071. -These restrictions translate to certain responsibilities for you if you
  31072. -distribute copies of the software, or if you modify it.
  31073. -
  31074. -   For example, if you distribute copies of such a program, whether
  31075. -gratis or for a fee, you must give the recipients all the rights that
  31076. -you have.  You must make sure that they, too, receive or can get the
  31077. -source code.  And you must show them these terms so they know their
  31078. -rights.
  31079. -
  31080. -   We protect your rights with two steps: (1) copyright the software,
  31081. -and (2) offer you this license which gives you legal permission to copy,
  31082. -distribute and/or modify the software.
  31083. -
  31084. -   Also, for each author's protection and ours, we want to make certain
  31085. -that everyone understands that there is no warranty for this free
  31086. -software.  If the software is modified by someone else and passed on, we
  31087. -want its recipients to know that what they have is not the original, so
  31088. -that any problems introduced by others will not reflect on the original
  31089. -authors' reputations.
  31090. -
  31091. -   Finally, any free program is threatened constantly by software
  31092. -patents.  We wish to avoid the danger that redistributors of a free
  31093. -program will individually obtain patent licenses, in effect making the
  31094. -program proprietary.  To prevent this, we have made it clear that any
  31095. -patent must be licensed for everyone's free use or not licensed at all.
  31096. -
  31097. -   The precise terms and conditions for copying, distribution and
  31098. -modification follow.
  31099. -
  31100. -    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
  31101. -
  31102. -  0. This License applies to any program or other work which contains a
  31103. -     notice placed by the copyright holder saying it may be distributed
  31104. -     under the terms of this General Public License.  The "Program",
  31105. -     below, refers to any such program or work, and a "work based on
  31106. -     the Program" means either the Program or any derivative work under
  31107. -     copyright law: that is to say, a work containing the Program or a
  31108. -     portion of it, either verbatim or with modifications and/or
  31109. -     translated into another language.  (Hereinafter, translation is
  31110. -     included without limitation in the term "modification".)  Each
  31111. -     licensee is addressed as "you".
  31112. -
  31113. -     Activities other than copying, distribution and modification are
  31114. -     not covered by this License; they are outside its scope.  The act
  31115. -     of running the Program is not restricted, and the output from the
  31116. -     Program is covered only if its contents constitute a work based on
  31117. -     the Program (independent of having been made by running the
  31118. -     Program).  Whether that is true depends on what the Program does.
  31119. -
  31120. -  1. You may copy and distribute verbatim copies of the Program's
  31121. -     source code as you receive it, in any medium, provided that you
  31122. -     conspicuously and appropriately publish on each copy an appropriate
  31123. -     copyright notice and disclaimer of warranty; keep intact all the
  31124. -     notices that refer to this License and to the absence of any
  31125. -     warranty; and give any other recipients of the Program a copy of
  31126. -     this License along with the Program.
  31127. -
  31128. -     You may charge a fee for the physical act of transferring a copy,
  31129. -     and you may at your option offer warranty protection in exchange
  31130. -     for a fee.
  31131. -
  31132. -  2. You may modify your copy or copies of the Program or any portion
  31133. -     of it, thus forming a work based on the Program, and copy and
  31134. -     distribute such modifications or work under the terms of Section 1
  31135. -     above, provided that you also meet all of these conditions:
  31136. -
  31137. -       a. You must cause the modified files to carry prominent notices
  31138. -          stating that you changed the files and the date of any change.
  31139. -
  31140. -       b. You must cause any work that you distribute or publish, that
  31141. -          in whole or in part contains or is derived from the Program
  31142. -          or any part thereof, to be licensed as a whole at no charge
  31143. -          to all third parties under the terms of this License.
  31144. -
  31145. -       c. If the modified program normally reads commands interactively
  31146. -          when run, you must cause it, when started running for such
  31147. -          interactive use in the most ordinary way, to print or display
  31148. -          an announcement including an appropriate copyright notice and
  31149. -          a notice that there is no warranty (or else, saying that you
  31150. -          provide a warranty) and that users may redistribute the
  31151. -          program under these conditions, and telling the user how to
  31152. -          view a copy of this License.  (Exception: if the Program
  31153. -          itself is interactive but does not normally print such an
  31154. -          announcement, your work based on the Program is not required
  31155. -          to print an announcement.)
  31156. -
  31157. -     These requirements apply to the modified work as a whole.  If
  31158. -     identifiable sections of that work are not derived from the
  31159. -     Program, and can be reasonably considered independent and separate
  31160. -     works in themselves, then this License, and its terms, do not
  31161. -     apply to those sections when you distribute them as separate
  31162. -     works.  But when you distribute the same sections as part of a
  31163. -     whole which is a work based on the Program, the distribution of
  31164. -     the whole must be on the terms of this License, whose permissions
  31165. -     for other licensees extend to the entire whole, and thus to each
  31166. -     and every part regardless of who wrote it.
  31167. -
  31168. -     Thus, it is not the intent of this section to claim rights or
  31169. -     contest your rights to work written entirely by you; rather, the
  31170. -     intent is to exercise the right to control the distribution of
  31171. -     derivative or collective works based on the Program.
  31172. -
  31173. -     In addition, mere aggregation of another work not based on the
  31174. -     Program with the Program (or with a work based on the Program) on
  31175. -     a volume of a storage or distribution medium does not bring the
  31176. -     other work under the scope of this License.
  31177. -
  31178. -  3. You may copy and distribute the Program (or a work based on it,
  31179. -     under Section 2) in object code or executable form under the terms
  31180. -     of Sections 1 and 2 above provided that you also do one of the
  31181. -     following:
  31182. -
  31183. -       a. Accompany it with the complete corresponding machine-readable
  31184. -          source code, which must be distributed under the terms of
  31185. -          Sections 1 and 2 above on a medium customarily used for
  31186. -          software interchange; or,
  31187. -
  31188. -       b. Accompany it with a written offer, valid for at least three
  31189. -          years, to give any third party, for a charge no more than your
  31190. -          cost of physically performing source distribution, a complete
  31191. -          machine-readable copy of the corresponding source code, to be
  31192. -          distributed under the terms of Sections 1 and 2 above on a
  31193. -          medium customarily used for software interchange; or,
  31194. -
  31195. -       c. Accompany it with the information you received as to the offer
  31196. -          to distribute corresponding source code.  (This alternative is
  31197. -          allowed only for noncommercial distribution and only if you
  31198. -          received the program in object code or executable form with
  31199. -          such an offer, in accord with Subsection b above.)
  31200. -
  31201. -     The source code for a work means the preferred form of the work for
  31202. -     making modifications to it.  For an executable work, complete
  31203. -     source code means all the source code for all modules it contains,
  31204. -     plus any associated interface definition files, plus the scripts
  31205. -     used to control compilation and installation of the executable.
  31206. -     However, as a special exception, the source code distributed need
  31207. -     not include anything that is normally distributed (in either
  31208. -     source or binary form) with the major components (compiler,
  31209. -     kernel, and so on) of the operating system on which the executable
  31210. -     runs, unless that component itself accompanies the executable.
  31211. -
  31212. -     If distribution of executable or object code is made by offering
  31213. -     access to copy from a designated place, then offering equivalent
  31214. -     access to copy the source code from the same place counts as
  31215. -     distribution of the source code, even though third parties are not
  31216. -     compelled to copy the source along with the object code.
  31217. -
  31218. -  4. You may not copy, modify, sublicense, or distribute the Program
  31219. -     except as expressly provided under this License.  Any attempt
  31220. -     otherwise to copy, modify, sublicense or distribute the Program is
  31221. -     void, and will automatically terminate your rights under this
  31222. -     License.  However, parties who have received copies, or rights,
  31223. -     from you under this License will not have their licenses
  31224. -     terminated so long as such parties remain in full compliance.
  31225. -
  31226. -  5. You are not required to accept this License, since you have not
  31227. -     signed it.  However, nothing else grants you permission to modify
  31228. -     or distribute the Program or its derivative works.  These actions
  31229. -     are prohibited by law if you do not accept this License.
  31230. -     Therefore, by modifying or distributing the Program (or any work
  31231. -     based on the Program), you indicate your acceptance of this
  31232. -     License to do so, and all its terms and conditions for copying,
  31233. -     distributing or modifying the Program or works based on it.
  31234. -
  31235. -  6. Each time you redistribute the Program (or any work based on the
  31236. -     Program), the recipient automatically receives a license from the
  31237. -     original licensor to copy, distribute or modify the Program
  31238. -     subject to these terms and conditions.  You may not impose any
  31239. -     further restrictions on the recipients' exercise of the rights
  31240. -     granted herein.  You are not responsible for enforcing compliance
  31241. -     by third parties to this License.
  31242. -
  31243. -  7. If, as a consequence of a court judgment or allegation of patent
  31244. -     infringement or for any other reason (not limited to patent
  31245. -     issues), conditions are imposed on you (whether by court order,
  31246. -     agreement or otherwise) that contradict the conditions of this
  31247. -     License, they do not excuse you from the conditions of this
  31248. -     License.  If you cannot distribute so as to satisfy simultaneously
  31249. -     your obligations under this License and any other pertinent
  31250. -     obligations, then as a consequence you may not distribute the
  31251. -     Program at all.  For example, if a patent license would not permit
  31252. -     royalty-free redistribution of the Program by all those who
  31253. -     receive copies directly or indirectly through you, then the only
  31254. -     way you could satisfy both it and this License would be to refrain
  31255. -     entirely from distribution of the Program.
  31256. -
  31257. -     If any portion of this section is held invalid or unenforceable
  31258. -     under any particular circumstance, the balance of the section is
  31259. -     intended to apply and the section as a whole is intended to apply
  31260. -     in other circumstances.
  31261. -
  31262. -     It is not the purpose of this section to induce you to infringe any
  31263. -     patents or other property right claims or to contest validity of
  31264. -     any such claims; this section has the sole purpose of protecting
  31265. -     the integrity of the free software distribution system, which is
  31266. -     implemented by public license practices.  Many people have made
  31267. -     generous contributions to the wide range of software distributed
  31268. -     through that system in reliance on consistent application of that
  31269. -     system; it is up to the author/donor to decide if he or she is
  31270. -     willing to distribute software through any other system and a
  31271. -     licensee cannot impose that choice.
  31272. -
  31273. -     This section is intended to make thoroughly clear what is believed
  31274. -     to be a consequence of the rest of this License.
  31275. -
  31276. -  8. If the distribution and/or use of the Program is restricted in
  31277. -     certain countries either by patents or by copyrighted interfaces,
  31278. -     the original copyright holder who places the Program under this
  31279. -     License may add an explicit geographical distribution limitation
  31280. -     excluding those countries, so that distribution is permitted only
  31281. -     in or among countries not thus excluded.  In such case, this
  31282. -     License incorporates the limitation as if written in the body of
  31283. -     this License.
  31284. -
  31285. -  9. The Free Software Foundation may publish revised and/or new
  31286. -     versions of the General Public License from time to time.  Such
  31287. -     new versions will be similar in spirit to the present version, but
  31288. -     may differ in detail to address new problems or concerns.
  31289. -
  31290. -     Each version is given a distinguishing version number.  If the
  31291. -     Program specifies a version number of this License which applies
  31292. -     to it and "any later version", you have the option of following
  31293. -     the terms and conditions either of that version or of any later
  31294. -     version published by the Free Software Foundation.  If the Program
  31295. -     does not specify a version number of this License, you may choose
  31296. -     any version ever published by the Free Software Foundation.
  31297. -
  31298. - 10. If you wish to incorporate parts of the Program into other free
  31299. -     programs whose distribution conditions are different, write to the
  31300. -     author to ask for permission.  For software which is copyrighted
  31301. -     by the Free Software Foundation, write to the Free Software
  31302. -     Foundation; we sometimes make exceptions for this.  Our decision
  31303. -     will be guided by the two goals of preserving the free status of
  31304. -     all derivatives of our free software and of promoting the sharing
  31305. -     and reuse of software generally.
  31306. -
  31307. -                                NO WARRANTY
  31308. -
  31309. - 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO
  31310. -     WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE
  31311. -     LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
  31312. -     HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT
  31313. -     WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT
  31314. -     NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  31315. -     FITNESS FOR A PARTICULAR PURPOSE.  THE ENTIRE RISK AS TO THE
  31316. -     QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU.  SHOULD THE
  31317. -     PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY
  31318. -     SERVICING, REPAIR OR CORRECTION.
  31319. -
  31320. - 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
  31321. -     WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY
  31322. -     MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE
  31323. -     LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL,
  31324. -     INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR
  31325. -     INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
  31326. -     DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU
  31327. -     OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY
  31328. -     OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN
  31329. -     ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  31330. -
  31331. -                      END OF TERMS AND CONDITIONS
  31332. -
  31333. -How to Apply These Terms to Your New Programs
  31334. -=============================================
  31335. -
  31336. -   If you develop a new program, and you want it to be of the greatest
  31337. -possible use to the public, the best way to achieve this is to make it
  31338. -free software which everyone can redistribute and change under these
  31339. -terms.
  31340. -
  31341. -   To do so, attach the following notices to the program.  It is safest
  31342. -to attach them to the start of each source file to most effectively
  31343. -convey the exclusion of warranty; and each file should have at least
  31344. -the "copyright" line and a pointer to where the full notice is found.
  31345. -
  31346. -     ONE LINE TO GIVE THE PROGRAM'S NAME AND A BRIEF IDEA OF WHAT IT DOES.
  31347. -     Copyright (C) 19YY  NAME OF AUTHOR
  31348. -     
  31349. -     This program is free software; you can redistribute it and/or modify
  31350. -     it under the terms of the GNU General Public License as published by
  31351. -     the Free Software Foundation; either version 2 of the License, or
  31352. -     (at your option) any later version.
  31353. -     
  31354. -     This program is distributed in the hope that it will be useful,
  31355. -     but WITHOUT ANY WARRANTY; without even the implied warranty of
  31356. -     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  31357. -     GNU General Public License for more details.
  31358. -     
  31359. -     You should have received a copy of the GNU General Public License
  31360. -     along with this program; if not, write to the Free Software
  31361. -     Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  31362. -
  31363. -   Also add information on how to contact you by electronic and paper
  31364. -mail.
  31365. -
  31366. -   If the program is interactive, make it output a short notice like
  31367. -this when it starts in an interactive mode:
  31368. -
  31369. -     Gnomovision version 69, Copyright (C) 19YY NAME OF AUTHOR
  31370. -     Gnomovision comes with ABSOLUTELY NO WARRANTY; for details
  31371. -     type `show w'.
  31372. -     This is free software, and you are welcome to redistribute it
  31373. -     under certain conditions; type `show c' for details.
  31374. -
  31375. -   The hypothetical commands `show w' and `show c' should show the
  31376. -appropriate parts of the General Public License.  Of course, the
  31377. -commands you use may be called something other than `show w' and `show
  31378. -c'; they could even be mouse-clicks or menu items--whatever suits your
  31379. -program.
  31380. -
  31381. -   You should also get your employer (if you work as a programmer) or
  31382. -your school, if any, to sign a "copyright disclaimer" for the program,
  31383. -if necessary.  Here is a sample; alter the names:
  31384. -
  31385. -     Yoyodyne, Inc., hereby disclaims all copyright interest in the program
  31386. -     `Gnomovision' (which makes passes at compilers) written by James Hacker.
  31387. -     
  31388. -     SIGNATURE OF TY COON, 1 April 1989
  31389. -     Ty Coon, President of Vice
  31390. -
  31391. -   This General Public License does not permit incorporating your
  31392. -program into proprietary programs.  If your program is a subroutine
  31393. -library, you may consider it more useful to permit linking proprietary
  31394. -applications with the library.  If this is what you want to do, use the
  31395. -GNU Library General Public License instead of this License.
  31396. -
  31397. -
  31398. -File: gcc.info,  Node: Contributors,  Next: Funding,  Prev: Copying,  Up: Top
  31399. -
  31400. -Contributors to GNU CC
  31401. -**********************
  31402. -
  31403. -   In addition to Richard Stallman, several people have written parts
  31404. -of GNU CC.
  31405. -
  31406. -   * The idea of using RTL and some of the optimization ideas came from
  31407. -     the program PO written at the University of Arizona by Jack
  31408. -     Davidson and Christopher Fraser.  See "Register Allocation and
  31409. -     Exhaustive Peephole Optimization", Software Practice and
  31410. -     Experience 14 (9), Sept. 1984, 857-866.
  31411. -
  31412. -   * Paul Rubin wrote most of the preprocessor.
  31413. -
  31414. -   * Leonard Tower wrote parts of the parser, RTL generator, and RTL
  31415. -     definitions, and of the Vax machine description.
  31416. -
  31417. -   * Ted Lemon wrote parts of the RTL reader and printer.
  31418. -
  31419. -   * Jim Wilson implemented loop strength reduction and some other loop
  31420. -     optimizations.
  31421. -
  31422. -   * Nobuyuki Hikichi of Software Research Associates, Tokyo,
  31423. -     contributed the support for the Sony NEWS machine.
  31424. -
  31425. -   * Charles LaBrec contributed the support for the Integrated Solutions
  31426. -     68020 system.
  31427. -
  31428. -   * Michael Tiemann of Cygnus Support wrote the front end for C++, as
  31429. -     well as the support for inline functions and instruction
  31430. -     scheduling.  Also the descriptions of the National Semiconductor
  31431. -     32000 series cpu, the SPARC cpu and part of the Motorola 88000 cpu.
  31432. -
  31433. -   * Gerald Baumgartner added the signature extension to the C++
  31434. -     front-end.
  31435. -
  31436. -   * Jan Stein of the Chalmers Computer Society provided support for
  31437. -     Genix, as well as part of the 32000 machine description.
  31438. -
  31439. -   * Randy Smith finished the Sun FPA support.
  31440. -
  31441. -   * Robert Brown implemented the support for Encore 32000 systems.
  31442. -
  31443. -   * David Kashtan of SRI adapted GNU CC to VMS.
  31444. -
  31445. -   * Alex Crain provided changes for the 3b1.
  31446. -
  31447. -   * Greg Satz and Chris Hanson assisted in making GNU CC work on HP-UX
  31448. -     for the 9000 series 300.
  31449. -
  31450. -   * William Schelter did most of the work on the Intel 80386 support.
  31451. -
  31452. -   * Christopher Smith did the port for Convex machines.
  31453. -
  31454. -   * Paul Petersen wrote the machine description for the Alliant FX/8.
  31455. -
  31456. -   * Dario Dariol contributed the four varieties of sample programs
  31457. -     that print a copy of their source.
  31458. -
  31459. -   * Alain Lichnewsky ported GNU CC to the Mips cpu.
  31460. -
  31461. -   * Devon Bowen, Dale Wiles and Kevin Zachmann ported GNU CC to the
  31462. -     Tahoe.
  31463. -
  31464. -   * Jonathan Stone wrote the machine description for the Pyramid
  31465. -     computer.
  31466. -
  31467. -   * Gary Miller ported GNU CC to Charles River Data Systems machines.
  31468. -
  31469. -   * Richard Kenner of the New York University Ultracomputer Research
  31470. -     Laboratory wrote the machine descriptions for the AMD 29000, the
  31471. -     DEC Alpha, the IBM RT PC, and the IBM RS/6000 as well as the
  31472. -     support for instruction attributes.  He also made changes to
  31473. -     better support RISC processors including changes to common
  31474. -     subexpression elimination, strength reduction, function calling
  31475. -     sequence handling, and condition code support, in addition to
  31476. -     generalizing the code for frame pointer elimination.
  31477. -
  31478. -   * Richard Kenner and Michael Tiemann jointly developed reorg.c, the
  31479. -     delay slot scheduler.
  31480. -
  31481. -   * Mike Meissner and Tom Wood of Data General finished the port to the
  31482. -     Motorola 88000.
  31483. -
  31484. -   * Masanobu Yuhara of Fujitsu Laboratories implemented the machine
  31485. -     description for the Tron architecture (specifically, the Gmicro).
  31486. -
  31487. -   * NeXT, Inc. donated the front end that supports the Objective C
  31488. -     language.
  31489. -
  31490. -   * James van Artsdalen wrote the code that makes efficient use of the
  31491. -     Intel 80387 register stack.
  31492. -
  31493. -   * Mike Meissner at the Open Software Foundation finished the port to
  31494. -     the MIPS cpu, including adding ECOFF debug support, and worked on
  31495. -     the Intel port for the Intel 80386 cpu.
  31496. -
  31497. -   * Ron Guilmette implemented the `protoize' and `unprotoize' tools,
  31498. -     the support for Dwarf symbolic debugging information, and much of
  31499. -     the support for System V Release 4.  He has also worked heavily on
  31500. -     the Intel 386 and 860 support.
  31501. -
  31502. -   * Torbjorn Granlund implemented multiply- and divide-by-constant
  31503. -     optimization, improved long long support, and improved leaf
  31504. -     function register allocation.
  31505. -
  31506. -   * Mike Stump implemented the support for Elxsi 64 bit CPU.
  31507. -
  31508. -   * John Wehle added the machine description for the Western Electric
  31509. -     32000 processor used in several 3b series machines (no relation to
  31510. -     the National Semiconductor 32000 processor).
  31511. -
  31512. -   * Holger Teutsch provided the support for the Clipper cpu.
  31513. -
  31514. -   * Kresten Krab Thorup wrote the run time support for the Objective C
  31515. -     language.
  31516. -
  31517. -   * Stephen Moshier contributed the floating point emulator that
  31518. -     assists in cross-compilation and permits support for floating
  31519. -     point numbers wider than 64 bits.
  31520. -
  31521. -   * David Edelsohn contributed the changes to RS/6000 port to make it
  31522. -     support the PowerPC and POWER2 architectures.
  31523. -
  31524. -   * Steve Chamberlain wrote the support for the Hitachi SH processor.
  31525. -
  31526. -   * Peter Schauer wrote the code to allow debugging to work on the
  31527. -     Alpha.
  31528. -
  31529. -   * Oliver M. Kellogg of Deutsche Aerospace contributed the port to the
  31530. -     MIL-STD-1750A.
  31531. -
  31532. -   * Michael K. Gschwind contributed the port to the PDP-11.
  31533. -
  31534. -
  31535. -File: gcc.info,  Node: Funding,  Next: Look and Feel,  Prev: Contributors,  Up: Top
  31536. -
  31537. -Funding Free Software
  31538. -*********************
  31539. -
  31540. -   If you want to have more free software a few years from now, it makes
  31541. -sense for you to help encourage people to contribute funds for its
  31542. -development.  The most effective approach known is to encourage
  31543. -commercial redistributors to donate.
  31544. -
  31545. -   Users of free software systems can boost the pace of development by
  31546. -encouraging for-a-fee distributors to donate part of their selling price
  31547. -to free software developers--the Free Software Foundation, and others.
  31548. -
  31549. -   The way to convince distributors to do this is to demand it and
  31550. -expect it from them.  So when you compare distributors, judge them
  31551. -partly by how much they give to free software development.  Show
  31552. -distributors they must compete to be the one who gives the most.
  31553. -
  31554. -   To make this approach work, you must insist on numbers that you can
  31555. -compare, such as, "We will donate ten dollars to the Frobnitz project
  31556. -for each disk sold."  Don't be satisfied with a vague promise, such as
  31557. -"A portion of the profits are donated," since it doesn't give a basis
  31558. -for comparison.
  31559. -
  31560. -   Even a precise fraction "of the profits from this disk" is not very
  31561. -meaningful, since creative accounting and unrelated business decisions
  31562. -can greatly alter what fraction of the sales price counts as profit.
  31563. -If the price you pay is $50, ten percent of the profit is probably less
  31564. -than a dollar; it might be a few cents, or nothing at all.
  31565. -
  31566. -   Some redistributors do development work themselves.  This is useful
  31567. -too; but to keep everyone honest, you need to inquire how much they do,
  31568. -and what kind.  Some kinds of development make much more long-term
  31569. -difference than others.  For example, maintaining a separate version of
  31570. -a program contributes very little; maintaining the standard version of a
  31571. -program for the whole community contributes much.  Easy new ports
  31572. -contribute little, since someone else would surely do them; difficult
  31573. -ports such as adding a new CPU to the GNU C compiler contribute more;
  31574. -major new features or packages contribute the most.
  31575. -
  31576. -   By establishing the idea that supporting further development is "the
  31577. -proper thing to do" when distributing free software for a fee, we can
  31578. -assure a steady flow of resources into making more free software.
  31579. -
  31580. -     Copyright (C) 1994 Free Software Foundation, Inc.
  31581. -     Verbatim copying and redistribution of this section is permitted
  31582. -     without royalty; alteration is not permitted.
  31583. -
  31584. -
  31585. -File: gcc.info,  Node: Look and Feel,  Next: G++ and GCC,  Prev: Funding,  Up: Top
  31586. -
  31587. -Protect Your Freedom--Fight "Look And Feel"
  31588. -*******************************************
  31589. -
  31590. -     This section is a political message from the League for Programming
  31591. -     Freedom to the users of GNU CC.  We have included it here because
  31592. -     the issue of interface copyright is important to the GNU project.
  31593. -
  31594. -   Apple, Lotus, and now CDC have tried to create a new form of legal
  31595. -monopoly: a copyright on a user interface.
  31596. -
  31597. -   An interface is a kind of language--a set of conventions for
  31598. -communication between two entities, human or machine.  Until a few years
  31599. -ago, the law seemed clear: interfaces were outside the domain of
  31600. -copyright, so programmers could program freely and implement whatever
  31601. -interface the users demanded.  Imitating de-facto standard interfaces,
  31602. -sometimes with improvements, was standard practice in the computer
  31603. -field.  These improvements, if accepted by the users, caught on and
  31604. -became the norm; in this way, much progress took place.
  31605. -
  31606. -   Computer users, and most software developers, were happy with this
  31607. -state of affairs.  However, large companies such as Apple and Lotus
  31608. -would prefer a different system--one in which they can own interfaces
  31609. -and thereby rid themselves of all serious competitors.  They hope that
  31610. -interface copyright will give them, in effect, monopolies on major
  31611. -classes of software.
  31612. -
  31613. -   Other large companies such as IBM and Digital also favor interface
  31614. -monopolies, for the same reason: if languages become property, they
  31615. -expect to own many de-facto standard languages.  But Apple and Lotus are
  31616. -the ones who have actually sued.  Apple's lawsuit was defeated, for
  31617. -reasons only partly related to the general issue of interface copyright.
  31618. -
  31619. -   Lotus won lawsuits against two small companies, which were thus put
  31620. -out of business.  Then Lotus sued Borland; Lotus won in the trial court
  31621. -(no surprise, since it was the same court that had ruled for Lotus twice
  31622. -before), but the court of appeals ruled in favor of Borland, which was
  31623. -assisted by a friend-of-the-court brief from the League for Programming
  31624. -Freedom.
  31625. -
  31626. -   Lotus appealed the case to the Supreme Court, which heard the case
  31627. -but was unable to reach a decision.  This failure means that the appeals
  31628. -court decision stands, in one portion of the United States, and may
  31629. -influence the other appeals courts, but it does not set a nationwide
  31630. -precedent.  The battle is not over, and it is not limited to the United
  31631. -States.
  31632. -
  31633. -   The battle is extending into other areas of software as well.  In
  31634. -1995 a company that produced a simulator for a CDC computer was shut
  31635. -down by a copyright lawsuit, in which CDC charged that the simulator
  31636. -infringed the copyright on the manuals for the computer.
  31637. -
  31638. -   If the monopolists get their way, they will hobble the software
  31639. -field:
  31640. -
  31641. -   * Gratuitous incompatibilities will burden users.  Imagine if each
  31642. -     car manufacturer had to design a different way to start, stop, and
  31643. -     steer a car.
  31644. -
  31645. -   * Users will be "locked in" to whichever interface they learn; then
  31646. -     they will be prisoners of one supplier, who will charge a
  31647. -     monopolistic price.
  31648. -
  31649. -   * Large companies have an unfair advantage wherever lawsuits become
  31650. -     commonplace.  Since they can afford to sue, they can intimidate
  31651. -     smaller developers with threats even when they don't really have a
  31652. -     case.
  31653. -
  31654. -   * Interface improvements will come slower, since incremental
  31655. -     evolution through creative partial imitation will no longer occur.
  31656. -
  31657. -   If interface monopolies are accepted, other large companies are
  31658. -waiting to grab theirs:
  31659. -
  31660. -   * Adobe is expected to claim a monopoly on the interfaces of various
  31661. -     popular application programs, if Lotus ultimately wins the case
  31662. -     against Borland.
  31663. -
  31664. -   * Open Computing magazine reported a Microsoft vice president as
  31665. -     threatening to sue people who imitate the interface of Windows.
  31666. -
  31667. -   Users invest a great deal of time and money in learning to use
  31668. -computer interfaces.  Far more, in fact, than software developers
  31669. -invest in developing *and even implementing* the interfaces.  Whoever
  31670. -can own an interface, has made its users into captives, and
  31671. -misappropriated their investment.
  31672. -
  31673. -   To protect our freedom from monopolies like these, a group of
  31674. -programmers and users have formed a grass-roots political organization,
  31675. -the League for Programming Freedom.
  31676. -
  31677. -   The purpose of the League is to oppose monopolistic practices such as
  31678. -interface copyright and software patents.  The League calls for a return
  31679. -to the legal policies of the recent past, in which programmers could
  31680. -program freely.  The League is not concerned with free software as an
  31681. -issue, and is not affiliated with the Free Software Foundation.
  31682. -
  31683. -   The League's activities include publicizing the issues, as is being
  31684. -done here, and filing friend-of-the-court briefs on behalf of
  31685. -defendants sued by monopolists.
  31686. -
  31687. -   The League's membership rolls include Donald Knuth, the foremost
  31688. -authority on algorithms, John McCarthy, inventor of Lisp, Marvin Minsky,
  31689. -founder of the MIT Artificial Intelligence lab, Guy L.  Steele, Jr.,
  31690. -author of well-known books on Lisp and C, as well as Richard Stallman,
  31691. -the developer of GNU CC.  Please join and add your name to the list.
  31692. -Membership dues in the League are $42 per year for programmers, managers
  31693. -and professionals; $10.50 for students; $21 for others.
  31694. -
  31695. -   Activist members are especially important, but members who have no
  31696. -time to give are also important.  Surveys at major ACM conferences have
  31697. -indicated a vast majority of attendees agree with the League on both
  31698. -issues (interface copyrights and software patents).  If just ten percent
  31699. -of the programmers who agree with the League join the League, we will
  31700. -probably triumph.
  31701. -
  31702. -   To join, or for more information, phone (617) 243-4091 or write to:
  31703. -
  31704. -     League for Programming Freedom
  31705. -     1 Kendall Square #143
  31706. -     P.O. Box 9171
  31707. -     Cambridge, MA 02139
  31708. -
  31709. -   You can also send electronic mail to `lpf@uunet.uu.net'.
  31710. -
  31711. -   In addition to joining the League, here are some suggestions from the
  31712. -League for other things you can do to protect your freedom to write
  31713. -programs:
  31714. -
  31715. -   * Tell your friends and colleagues about this issue and how it
  31716. -     threatens to ruin the computer industry.
  31717. -
  31718. -   * Mention that you are a League member in your `.signature', and
  31719. -     mention the League's email address for inquiries.
  31720. -
  31721. -   * Ask the companies you consider working for or working with to make
  31722. -     statements against software monopolies, and give preference to
  31723. -     those that do.
  31724. -
  31725. -   * When employers ask you to sign contracts giving them copyright on
  31726. -     your work, insist on a clause saying they will not claim the
  31727. -     copyright covers imitating the interface.
  31728. -
  31729. -   * When employers ask you to sign contracts giving them patent rights,
  31730. -     insist on clauses saying they can use these rights only
  31731. -     defensively.  Don't rely on "company policy," since that can
  31732. -     change at any time; don't rely on an individual executive's
  31733. -     private word, since that person may be replaced.  Get a commitment
  31734. -     just as binding as the commitment they get from you.
  31735. -
  31736. -   * Write to Congress to explain the importance of these issues.
  31737. -
  31738. -          House Subcommittee on Intellectual Property
  31739. -          2137 Rayburn Bldg
  31740. -          Washington, DC 20515
  31741. -          
  31742. -          Senate Subcommittee on Patents, Trademarks and Copyrights
  31743. -          United States Senate
  31744. -          Washington, DC 20510
  31745. -
  31746. -     (These committees have received lots of mail already; let's give
  31747. -     them even more.)
  31748. -
  31749. -   Democracy means nothing if you don't use it.  Stand up and be
  31750. -counted!
  31751. -
  31752. -
  31753. -File: gcc.info,  Node: G++ and GCC,  Next: Invoking GCC,  Prev: Look and Feel,  Up: Top
  31754. -
  31755. -Compile C, C++, or Objective C
  31756. -******************************
  31757. -
  31758. -   The C, C++, and Objective C versions of the compiler are integrated;
  31759. -the GNU C compiler can compile programs written in C, C++, or Objective
  31760. -C.
  31761. -
  31762. -   "GCC" is a common shorthand term for the GNU C compiler.  This is
  31763. -both the most general name for the compiler, and the name used when the
  31764. -emphasis is on compiling C programs.
  31765. -
  31766. -   When referring to C++ compilation, it is usual to call the compiler
  31767. -"G++".  Since there is only one compiler, it is also accurate to call
  31768. -it "GCC" no matter what the language context; however, the term "G++"
  31769. -is more useful when the emphasis is on compiling C++ programs.
  31770. -
  31771. -   We use the name "GNU CC" to refer to the compilation system as a
  31772. -whole, and more specifically to the language-independent part of the
  31773. -compiler.  For example, we refer to the optimization options as
  31774. -affecting the behavior of "GNU CC" or sometimes just "the compiler".
  31775. -
  31776. -   Front ends for other languages, such as Ada 9X, Fortran, Modula-3,
  31777. -and Pascal, are under development.  These front-ends, like that for
  31778. -C++, are built in subdirectories of GNU CC and link to it.  The result
  31779. -is an integrated compiler that can compile programs written in C, C++,
  31780. -Objective C, or any of the languages for which you have installed front
  31781. -ends.
  31782. -
  31783. -   In this manual, we only discuss the options for the C, Objective-C,
  31784. -and C++ compilers and those of the GNU CC core.  Consult the
  31785. -documentation of the other front ends for the options to use when
  31786. -compiling programs written in other languages.
  31787. -
  31788. -   G++ is a *compiler*, not merely a preprocessor.  G++ builds object
  31789. -code directly from your C++ program source.  There is no intermediate C
  31790. -version of the program.  (By contrast, for example, some other
  31791. -implementations use a program that generates a C program from your C++
  31792. -source.)  Avoiding an intermediate C representation of the program means
  31793. -that you get better object code, and better debugging information.  The
  31794. -GNU debugger, GDB, works with this information in the object code to
  31795. -give you comprehensive C++ source-level editing capabilities (*note C
  31796. -and C++: (gdb.info)C.).
  31797. -
  31798. -
  31799. -File: gcc.info,  Node: Invoking GCC,  Next: Installation,  Prev: G++ and GCC,  Up: Top
  31800. -
  31801. -GNU CC Command Options
  31802. -**********************
  31803. -
  31804. -   When you invoke GNU CC, it normally does preprocessing, compilation,
  31805. -assembly and linking.  The "overall options" allow you to stop this
  31806. -process at an intermediate stage.  For example, the `-c' option says
  31807. -not to run the linker.  Then the output consists of object files output
  31808. -by the assembler.
  31809. -
  31810. -   Other options are passed on to one stage of processing.  Some options
  31811. -control the preprocessor and others the compiler itself.  Yet other
  31812. -options control the assembler and linker; most of these are not
  31813. -documented here, since you rarely need to use any of them.
  31814. -
  31815. -   Most of the command line options that you can use with GNU CC are
  31816. -useful for C programs; when an option is only useful with another
  31817. -language (usually C++), the explanation says so explicitly.  If the
  31818. -description for a particular option does not mention a source language,
  31819. -you can use that option with all supported languages.
  31820. -
  31821. -   *Note Compiling C++ Programs: Invoking G++, for a summary of special
  31822. -options for compiling C++ programs.
  31823. -
  31824. -   The `gcc' program accepts options and file names as operands.  Many
  31825. -options have multiletter names; therefore multiple single-letter options
  31826. -may *not* be grouped: `-dr' is very different from `-d -r'.
  31827. -
  31828. -   You can mix options and other arguments.  For the most part, the
  31829. -order you use doesn't matter.  Order does matter when you use several
  31830. -options of the same kind; for example, if you specify `-L' more than
  31831. -once, the directories are searched in the order specified.
  31832. -
  31833. -   Many options have long names starting with `-f' or with `-W'--for
  31834. -example, `-fforce-mem', `-fstrength-reduce', `-Wformat' and so on.
  31835. -Most of these have both positive and negative forms; the negative form
  31836. -of `-ffoo' would be `-fno-foo'.  This manual documents only one of
  31837. -these two forms, whichever one is not the default.
  31838. -
  31839. -* Menu:
  31840. -
  31841. -* Option Summary::    Brief list of all options, without explanations.
  31842. -* Overall Options::     Controlling the kind of output:
  31843. -                        an executable, object files, assembler files,
  31844. -                        or preprocessed source.
  31845. -* Invoking G++::    Compiling C++ programs.
  31846. -* C Dialect Options::   Controlling the variant of C language compiled.
  31847. -* C++ Dialect Options:: Variations on C++.
  31848. -* Warning Options::     How picky should the compiler be?
  31849. -* Debugging Options::   Symbol tables, measurements, and debugging dumps.
  31850. -* Optimize Options::    How much optimization?
  31851. -* Preprocessor Options:: Controlling header files and macro definitions.
  31852. -                         Also, getting dependency information for Make.
  31853. -* Assembler Options::   Passing options to the assembler.
  31854. -* Link Options::        Specifying libraries and so on.
  31855. -* Directory Options::   Where to find header files and libraries.
  31856. -                        Where to find the compiler executable files.
  31857. -* Target Options::      Running a cross-compiler, or an old version of GNU CC.
  31858. -* Submodel Options::    Specifying minor hardware or convention variations,
  31859. -                        such as 68010 vs 68020.
  31860. -* Code Gen Options::    Specifying conventions for function calls, data layout
  31861. -                        and register usage.
  31862. -* Environment Variables:: Env vars that affect GNU CC.
  31863. -* Running Protoize::    Automatically adding or removing function prototypes.
  31864. -
  31865. diff -rup --new-file baseline/fsf/gcc/gcc.info-10 amiga/fsf/gcc/gcc.info-10
  31866. --- baseline/fsf/gcc/gcc.info-10    Sat Jun 29 09:38:00 1996
  31867. +++ amiga/fsf/gcc/gcc.info-10    Wed Dec 31 17:00:00 1969
  31868. @@ -1,869 +0,0 @@
  31869. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  31870. -file gcc.texi.
  31871. -
  31872. -   This file documents the use and the internals of the GNU compiler.
  31873. -
  31874. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  31875. -Boston, MA 02111-1307 USA
  31876. -
  31877. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  31878. -Foundation, Inc.
  31879. -
  31880. -   Permission is granted to make and distribute verbatim copies of this
  31881. -manual provided the copyright notice and this permission notice are
  31882. -preserved on all copies.
  31883. -
  31884. -   Permission is granted to copy and distribute modified versions of
  31885. -this manual under the conditions for verbatim copying, provided also
  31886. -that the sections entitled "GNU General Public License," "Funding for
  31887. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  31888. -included exactly as in the original, and provided that the entire
  31889. -resulting derived work is distributed under the terms of a permission
  31890. -notice identical to this one.
  31891. -
  31892. -   Permission is granted to copy and distribute translations of this
  31893. -manual into another language, under the above conditions for modified
  31894. -versions, except that the sections entitled "GNU General Public
  31895. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  31896. -`Look And Feel'", and this permission notice, may be included in
  31897. -translations approved by the Free Software Foundation instead of in the
  31898. -original English.
  31899. -
  31900. -
  31901. -File: gcc.info,  Node: Asm Labels,  Next: Explicit Reg Vars,  Prev: Extended Asm,  Up: C Extensions
  31902. -
  31903. -Controlling Names Used in Assembler Code
  31904. -========================================
  31905. -
  31906. -   You can specify the name to be used in the assembler code for a C
  31907. -function or variable by writing the `asm' (or `__asm__') keyword after
  31908. -the declarator as follows:
  31909. -
  31910. -     int foo asm ("myfoo") = 2;
  31911. -
  31912. -This specifies that the name to be used for the variable `foo' in the
  31913. -assembler code should be `myfoo' rather than the usual `_foo'.
  31914. -
  31915. -   On systems where an underscore is normally prepended to the name of
  31916. -a C function or variable, this feature allows you to define names for
  31917. -the linker that do not start with an underscore.
  31918. -
  31919. -   You cannot use `asm' in this way in a function *definition*; but you
  31920. -can get the same effect by writing a declaration for the function
  31921. -before its definition and putting `asm' there, like this:
  31922. -
  31923. -     extern func () asm ("FUNC");
  31924. -     
  31925. -     func (x, y)
  31926. -          int x, y;
  31927. -     ...
  31928. -
  31929. -   It is up to you to make sure that the assembler names you choose do
  31930. -not conflict with any other assembler symbols.  Also, you must not use a
  31931. -register name; that would produce completely invalid assembler code.
  31932. -GNU CC does not as yet have the ability to store static variables in
  31933. -registers.  Perhaps that will be added.
  31934. -
  31935. -
  31936. -File: gcc.info,  Node: Explicit Reg Vars,  Next: Alternate Keywords,  Prev: Asm Labels,  Up: C Extensions
  31937. -
  31938. -Variables in Specified Registers
  31939. -================================
  31940. -
  31941. -   GNU C allows you to put a few global variables into specified
  31942. -hardware registers.  You can also specify the register in which an
  31943. -ordinary register variable should be allocated.
  31944. -
  31945. -   * Global register variables reserve registers throughout the program.
  31946. -     This may be useful in programs such as programming language
  31947. -     interpreters which have a couple of global variables that are
  31948. -     accessed very often.
  31949. -
  31950. -   * Local register variables in specific registers do not reserve the
  31951. -     registers.  The compiler's data flow analysis is capable of
  31952. -     determining where the specified registers contain live values, and
  31953. -     where they are available for other uses.
  31954. -
  31955. -     These local variables are sometimes convenient for use with the
  31956. -     extended `asm' feature (*note Extended Asm::.), if you want to
  31957. -     write one output of the assembler instruction directly into a
  31958. -     particular register.  (This will work provided the register you
  31959. -     specify fits the constraints specified for that operand in the
  31960. -     `asm'.)
  31961. -
  31962. -* Menu:
  31963. -
  31964. -* Global Reg Vars::
  31965. -* Local Reg Vars::
  31966. -
  31967. -
  31968. -File: gcc.info,  Node: Global Reg Vars,  Next: Local Reg Vars,  Up: Explicit Reg Vars
  31969. -
  31970. -Defining Global Register Variables
  31971. -----------------------------------
  31972. -
  31973. -   You can define a global register variable in GNU C like this:
  31974. -
  31975. -     register int *foo asm ("a5");
  31976. -
  31977. -Here `a5' is the name of the register which should be used.  Choose a
  31978. -register which is normally saved and restored by function calls on your
  31979. -machine, so that library routines will not clobber it.
  31980. -
  31981. -   Naturally the register name is cpu-dependent, so you would need to
  31982. -conditionalize your program according to cpu type.  The register `a5'
  31983. -would be a good choice on a 68000 for a variable of pointer type.  On
  31984. -machines with register windows, be sure to choose a "global" register
  31985. -that is not affected magically by the function call mechanism.
  31986. -
  31987. -   In addition, operating systems on one type of cpu may differ in how
  31988. -they name the registers; then you would need additional conditionals.
  31989. -For example, some 68000 operating systems call this register `%a5'.
  31990. -
  31991. -   Eventually there may be a way of asking the compiler to choose a
  31992. -register automatically, but first we need to figure out how it should
  31993. -choose and how to enable you to guide the choice.  No solution is
  31994. -evident.
  31995. -
  31996. -   Defining a global register variable in a certain register reserves
  31997. -that register entirely for this use, at least within the current
  31998. -compilation.  The register will not be allocated for any other purpose
  31999. -in the functions in the current compilation.  The register will not be
  32000. -saved and restored by these functions.  Stores into this register are
  32001. -never deleted even if they would appear to be dead, but references may
  32002. -be deleted or moved or simplified.
  32003. -
  32004. -   It is not safe to access the global register variables from signal
  32005. -handlers, or from more than one thread of control, because the system
  32006. -library routines may temporarily use the register for other things
  32007. -(unless you recompile them specially for the task at hand).
  32008. -
  32009. -   It is not safe for one function that uses a global register variable
  32010. -to call another such function `foo' by way of a third function `lose'
  32011. -that was compiled without knowledge of this variable (i.e. in a
  32012. -different source file in which the variable wasn't declared).  This is
  32013. -because `lose' might save the register and put some other value there.
  32014. -For example, you can't expect a global register variable to be
  32015. -available in the comparison-function that you pass to `qsort', since
  32016. -`qsort' might have put something else in that register.  (If you are
  32017. -prepared to recompile `qsort' with the same global register variable,
  32018. -you can solve this problem.)
  32019. -
  32020. -   If you want to recompile `qsort' or other source files which do not
  32021. -actually use your global register variable, so that they will not use
  32022. -that register for any other purpose, then it suffices to specify the
  32023. -compiler option `-ffixed-REG'.  You need not actually add a global
  32024. -register declaration to their source code.
  32025. -
  32026. -   A function which can alter the value of a global register variable
  32027. -cannot safely be called from a function compiled without this variable,
  32028. -because it could clobber the value the caller expects to find there on
  32029. -return.  Therefore, the function which is the entry point into the part
  32030. -of the program that uses the global register variable must explicitly
  32031. -save and restore the value which belongs to its caller.
  32032. -
  32033. -   On most machines, `longjmp' will restore to each global register
  32034. -variable the value it had at the time of the `setjmp'.  On some
  32035. -machines, however, `longjmp' will not change the value of global
  32036. -register variables.  To be portable, the function that called `setjmp'
  32037. -should make other arrangements to save the values of the global register
  32038. -variables, and to restore them in a `longjmp'.  This way, the same
  32039. -thing will happen regardless of what `longjmp' does.
  32040. -
  32041. -   All global register variable declarations must precede all function
  32042. -definitions.  If such a declaration could appear after function
  32043. -definitions, the declaration would be too late to prevent the register
  32044. -from being used for other purposes in the preceding functions.
  32045. -
  32046. -   Global register variables may not have initial values, because an
  32047. -executable file has no means to supply initial contents for a register.
  32048. -
  32049. -   On the Sparc, there are reports that g3 ... g7 are suitable
  32050. -registers, but certain library functions, such as `getwd', as well as
  32051. -the subroutines for division and remainder, modify g3 and g4.  g1 and
  32052. -g2 are local temporaries.
  32053. -
  32054. -   On the 68000, a2 ... a5 should be suitable, as should d2 ... d7.  Of
  32055. -course, it will not do to use more than a few of those.
  32056. -
  32057. -
  32058. -File: gcc.info,  Node: Local Reg Vars,  Prev: Global Reg Vars,  Up: Explicit Reg Vars
  32059. -
  32060. -Specifying Registers for Local Variables
  32061. -----------------------------------------
  32062. -
  32063. -   You can define a local register variable with a specified register
  32064. -like this:
  32065. -
  32066. -     register int *foo asm ("a5");
  32067. -
  32068. -Here `a5' is the name of the register which should be used.  Note that
  32069. -this is the same syntax used for defining global register variables,
  32070. -but for a local variable it would appear within a function.
  32071. -
  32072. -   Naturally the register name is cpu-dependent, but this is not a
  32073. -problem, since specific registers are most often useful with explicit
  32074. -assembler instructions (*note Extended Asm::.).  Both of these things
  32075. -generally require that you conditionalize your program according to cpu
  32076. -type.
  32077. -
  32078. -   In addition, operating systems on one type of cpu may differ in how
  32079. -they name the registers; then you would need additional conditionals.
  32080. -For example, some 68000 operating systems call this register `%a5'.
  32081. -
  32082. -   Eventually there may be a way of asking the compiler to choose a
  32083. -register automatically, but first we need to figure out how it should
  32084. -choose and how to enable you to guide the choice.  No solution is
  32085. -evident.
  32086. -
  32087. -   Defining such a register variable does not reserve the register; it
  32088. -remains available for other uses in places where flow control determines
  32089. -the variable's value is not live.  However, these registers are made
  32090. -unavailable for use in the reload pass.  I would not be surprised if
  32091. -excessive use of this feature leaves the compiler too few available
  32092. -registers to compile certain functions.
  32093. -
  32094. -
  32095. -File: gcc.info,  Node: Alternate Keywords,  Next: Incomplete Enums,  Prev: Explicit Reg Vars,  Up: C Extensions
  32096. -
  32097. -Alternate Keywords
  32098. -==================
  32099. -
  32100. -   The option `-traditional' disables certain keywords; `-ansi'
  32101. -disables certain others.  This causes trouble when you want to use GNU C
  32102. -extensions, or ANSI C features, in a general-purpose header file that
  32103. -should be usable by all programs, including ANSI C programs and
  32104. -traditional ones.  The keywords `asm', `typeof' and `inline' cannot be
  32105. -used since they won't work in a program compiled with `-ansi', while
  32106. -the keywords `const', `volatile', `signed', `typeof' and `inline' won't
  32107. -work in a program compiled with `-traditional'.
  32108. -
  32109. -   The way to solve these problems is to put `__' at the beginning and
  32110. -end of each problematical keyword.  For example, use `__asm__' instead
  32111. -of `asm', `__const__' instead of `const', and `__inline__' instead of
  32112. -`inline'.
  32113. -
  32114. -   Other C compilers won't accept these alternative keywords; if you
  32115. -want to compile with another compiler, you can define the alternate
  32116. -keywords as macros to replace them with the customary keywords.  It
  32117. -looks like this:
  32118. -
  32119. -     #ifndef __GNUC__
  32120. -     #define __asm__ asm
  32121. -     #endif
  32122. -
  32123. -   `-pedantic' causes warnings for many GNU C extensions.  You can
  32124. -prevent such warnings within one expression by writing `__extension__'
  32125. -before the expression.  `__extension__' has no effect aside from this.
  32126. -
  32127. -
  32128. -File: gcc.info,  Node: Incomplete Enums,  Next: Function Names,  Prev: Alternate Keywords,  Up: C Extensions
  32129. -
  32130. -Incomplete `enum' Types
  32131. -=======================
  32132. -
  32133. -   You can define an `enum' tag without specifying its possible values.
  32134. -This results in an incomplete type, much like what you get if you write
  32135. -`struct foo' without describing the elements.  A later declaration
  32136. -which does specify the possible values completes the type.
  32137. -
  32138. -   You can't allocate variables or storage using the type while it is
  32139. -incomplete.  However, you can work with pointers to that type.
  32140. -
  32141. -   This extension may not be very useful, but it makes the handling of
  32142. -`enum' more consistent with the way `struct' and `union' are handled.
  32143. -
  32144. -   This extension is not supported by GNU C++.
  32145. -
  32146. -
  32147. -File: gcc.info,  Node: Function Names,  Prev: Incomplete Enums,  Up: C Extensions
  32148. -
  32149. -Function Names as Strings
  32150. -=========================
  32151. -
  32152. -   GNU CC predefines two string variables to be the name of the current
  32153. -function.  The variable `__FUNCTION__' is the name of the function as
  32154. -it appears in the source.  The variable `__PRETTY_FUNCTION__' is the
  32155. -name of the function pretty printed in a language specific fashion.
  32156. -
  32157. -   These names are always the same in a C function, but in a C++
  32158. -function they may be different.  For example, this program:
  32159. -
  32160. -     extern "C" {
  32161. -     extern int printf (char *, ...);
  32162. -     }
  32163. -     
  32164. -     class a {
  32165. -      public:
  32166. -       sub (int i)
  32167. -         {
  32168. -           printf ("__FUNCTION__ = %s\n", __FUNCTION__);
  32169. -           printf ("__PRETTY_FUNCTION__ = %s\n", __PRETTY_FUNCTION__);
  32170. -         }
  32171. -     };
  32172. -     
  32173. -     int
  32174. -     main (void)
  32175. -     {
  32176. -       a ax;
  32177. -       ax.sub (0);
  32178. -       return 0;
  32179. -     }
  32180. -
  32181. -gives this output:
  32182. -
  32183. -     __FUNCTION__ = sub
  32184. -     __PRETTY_FUNCTION__ = int  a::sub (int)
  32185. -
  32186. -   These names are not macros: they are predefined string variables.
  32187. -For example, `#ifdef __FUNCTION__' does not have any special meaning
  32188. -inside a function, since the preprocessor does not do anything special
  32189. -with the identifier `__FUNCTION__'.
  32190. -
  32191. -
  32192. -File: gcc.info,  Node: C++ Extensions,  Next: Trouble,  Prev: C Extensions,  Up: Top
  32193. -
  32194. -Extensions to the C++ Language
  32195. -******************************
  32196. -
  32197. -   The GNU compiler provides these extensions to the C++ language (and
  32198. -you can also use most of the C language extensions in your C++
  32199. -programs).  If you want to write code that checks whether these
  32200. -features are available, you can test for the GNU compiler the same way
  32201. -as for C programs: check for a predefined macro `__GNUC__'.  You can
  32202. -also use `__GNUG__' to test specifically for GNU C++ (*note Standard
  32203. -Predefined Macros: (cpp.info)Standard Predefined.).
  32204. -
  32205. -* Menu:
  32206. -
  32207. -* Naming Results::      Giving a name to C++ function return values.
  32208. -* Min and Max::        C++ Minimum and maximum operators.
  32209. -* Destructors and Goto:: Goto is safe to use in C++ even when destructors
  32210. -                           are needed.
  32211. -* C++ Interface::       You can use a single C++ header file for both
  32212. -                         declarations and definitions.
  32213. -* Template Instantiation:: Methods for ensuring that exactly one copy of
  32214. -                         each needed template instantiation is emitted.
  32215. -* C++ Signatures::    You can specify abstract types to get subtype
  32216. -             polymorphism independent from inheritance.
  32217. -
  32218. -
  32219. -File: gcc.info,  Node: Naming Results,  Next: Min and Max,  Up: C++ Extensions
  32220. -
  32221. -Named Return Values in C++
  32222. -==========================
  32223. -
  32224. -   GNU C++ extends the function-definition syntax to allow you to
  32225. -specify a name for the result of a function outside the body of the
  32226. -definition, in C++ programs:
  32227. -
  32228. -     TYPE
  32229. -     FUNCTIONNAME (ARGS) return RESULTNAME;
  32230. -     {
  32231. -       ...
  32232. -       BODY
  32233. -       ...
  32234. -     }
  32235. -
  32236. -   You can use this feature to avoid an extra constructor call when a
  32237. -function result has a class type.  For example, consider a function
  32238. -`m', declared as `X v = m ();', whose result is of class `X':
  32239. -
  32240. -     X
  32241. -     m ()
  32242. -     {
  32243. -       X b;
  32244. -       b.a = 23;
  32245. -       return b;
  32246. -     }
  32247. -
  32248. -   Although `m' appears to have no arguments, in fact it has one
  32249. -implicit argument: the address of the return value.  At invocation, the
  32250. -address of enough space to hold `v' is sent in as the implicit argument.
  32251. -Then `b' is constructed and its `a' field is set to the value 23.
  32252. -Finally, a copy constructor (a constructor of the form `X(X&)') is
  32253. -applied to `b', with the (implicit) return value location as the
  32254. -target, so that `v' is now bound to the return value.
  32255. -
  32256. -   But this is wasteful.  The local `b' is declared just to hold
  32257. -something that will be copied right out.  While a compiler that
  32258. -combined an "elision" algorithm with interprocedural data flow analysis
  32259. -could conceivably eliminate all of this, it is much more practical to
  32260. -allow you to assist the compiler in generating efficient code by
  32261. -manipulating the return value explicitly, thus avoiding the local
  32262. -variable and copy constructor altogether.
  32263. -
  32264. -   Using the extended GNU C++ function-definition syntax, you can avoid
  32265. -the temporary allocation and copying by naming `r' as your return value
  32266. -at the outset, and assigning to its `a' field directly:
  32267. -
  32268. -     X
  32269. -     m () return r;
  32270. -     {
  32271. -       r.a = 23;
  32272. -     }
  32273. -
  32274. -The declaration of `r' is a standard, proper declaration, whose effects
  32275. -are executed *before* any of the body of `m'.
  32276. -
  32277. -   Functions of this type impose no additional restrictions; in
  32278. -particular, you can execute `return' statements, or return implicitly by
  32279. -reaching the end of the function body ("falling off the edge").  Cases
  32280. -like
  32281. -
  32282. -     X
  32283. -     m () return r (23);
  32284. -     {
  32285. -       return;
  32286. -     }
  32287. -
  32288. -(or even `X m () return r (23); { }') are unambiguous, since the return
  32289. -value `r' has been initialized in either case.  The following code may
  32290. -be hard to read, but also works predictably:
  32291. -
  32292. -     X
  32293. -     m () return r;
  32294. -     {
  32295. -       X b;
  32296. -       return b;
  32297. -     }
  32298. -
  32299. -   The return value slot denoted by `r' is initialized at the outset,
  32300. -but the statement `return b;' overrides this value.  The compiler deals
  32301. -with this by destroying `r' (calling the destructor if there is one, or
  32302. -doing nothing if there is not), and then reinitializing `r' with `b'.
  32303. -
  32304. -   This extension is provided primarily to help people who use
  32305. -overloaded operators, where there is a great need to control not just
  32306. -the arguments, but the return values of functions.  For classes where
  32307. -the copy constructor incurs a heavy performance penalty (especially in
  32308. -the common case where there is a quick default constructor), this is a
  32309. -major savings.  The disadvantage of this extension is that you do not
  32310. -control when the default constructor for the return value is called: it
  32311. -is always called at the beginning.
  32312. -
  32313. -
  32314. -File: gcc.info,  Node: Min and Max,  Next: Destructors and Goto,  Prev: Naming Results,  Up: C++ Extensions
  32315. -
  32316. -Minimum and Maximum Operators in C++
  32317. -====================================
  32318. -
  32319. -   It is very convenient to have operators which return the "minimum"
  32320. -or the "maximum" of two arguments.  In GNU C++ (but not in GNU C),
  32321. -
  32322. -`A <? B'
  32323. -     is the "minimum", returning the smaller of the numeric values A
  32324. -     and B;
  32325. -
  32326. -`A >? B'
  32327. -     is the "maximum", returning the larger of the numeric values A and
  32328. -     B.
  32329. -
  32330. -   These operations are not primitive in ordinary C++, since you can
  32331. -use a macro to return the minimum of two things in C++, as in the
  32332. -following example.
  32333. -
  32334. -     #define MIN(X,Y) ((X) < (Y) ? : (X) : (Y))
  32335. -
  32336. -You might then use `int min = MIN (i, j);' to set MIN to the minimum
  32337. -value of variables I and J.
  32338. -
  32339. -   However, side effects in `X' or `Y' may cause unintended behavior.
  32340. -For example, `MIN (i++, j++)' will fail, incrementing the smaller
  32341. -counter twice.  A GNU C extension allows you to write safe macros that
  32342. -avoid this kind of problem (*note Naming an Expression's Type: Naming
  32343. -Types.).  However, writing `MIN' and `MAX' as macros also forces you to
  32344. -use function-call notation notation for a fundamental arithmetic
  32345. -operation.  Using GNU C++ extensions, you can write `int min = i <? j;'
  32346. -instead.
  32347. -
  32348. -   Since `<?' and `>?' are built into the compiler, they properly
  32349. -handle expressions with side-effects;  `int min = i++ <? j++;' works
  32350. -correctly.
  32351. -
  32352. -
  32353. -File: gcc.info,  Node: Destructors and Goto,  Next: C++ Interface,  Prev: Min and Max,  Up: C++ Extensions
  32354. -
  32355. -`goto' and Destructors in GNU C++
  32356. -=================================
  32357. -
  32358. -   In C++ programs, you can safely use the `goto' statement.  When you
  32359. -use it to exit a block which contains aggregates requiring destructors,
  32360. -the destructors will run before the `goto' transfers control.  (In ANSI
  32361. -C++, `goto' is restricted to targets within the current block.)
  32362. -
  32363. -   The compiler still forbids using `goto' to *enter* a scope that
  32364. -requires constructors.
  32365. -
  32366. -
  32367. -File: gcc.info,  Node: C++ Interface,  Next: Template Instantiation,  Prev: Destructors and Goto,  Up: C++ Extensions
  32368. -
  32369. -Declarations and Definitions in One Header
  32370. -==========================================
  32371. -
  32372. -   C++ object definitions can be quite complex.  In principle, your
  32373. -source code will need two kinds of things for each object that you use
  32374. -across more than one source file.  First, you need an "interface"
  32375. -specification, describing its structure with type declarations and
  32376. -function prototypes.  Second, you need the "implementation" itself.  It
  32377. -can be tedious to maintain a separate interface description in a header
  32378. -file, in parallel to the actual implementation.  It is also dangerous,
  32379. -since separate interface and implementation definitions may not remain
  32380. -parallel.
  32381. -
  32382. -   With GNU C++, you can use a single header file for both purposes.
  32383. -
  32384. -     *Warning:* The mechanism to specify this is in transition.  For the
  32385. -     nonce, you must use one of two `#pragma' commands; in a future
  32386. -     release of GNU C++, an alternative mechanism will make these
  32387. -     `#pragma' commands unnecessary.
  32388. -
  32389. -   The header file contains the full definitions, but is marked with
  32390. -`#pragma interface' in the source code.  This allows the compiler to
  32391. -use the header file only as an interface specification when ordinary
  32392. -source files incorporate it with `#include'.  In the single source file
  32393. -where the full implementation belongs, you can use either a naming
  32394. -convention or `#pragma implementation' to indicate this alternate use
  32395. -of the header file.
  32396. -
  32397. -`#pragma interface'
  32398. -`#pragma interface "SUBDIR/OBJECTS.h"'
  32399. -     Use this directive in *header files* that define object classes,
  32400. -     to save space in most of the object files that use those classes.
  32401. -     Normally, local copies of certain information (backup copies of
  32402. -     inline member functions, debugging information, and the internal
  32403. -     tables that implement virtual functions) must be kept in each
  32404. -     object file that includes class definitions.  You can use this
  32405. -     pragma to avoid such duplication.  When a header file containing
  32406. -     `#pragma interface' is included in a compilation, this auxiliary
  32407. -     information will not be generated (unless the main input source
  32408. -     file itself uses `#pragma implementation').  Instead, the object
  32409. -     files will contain references to be resolved at link time.
  32410. -
  32411. -     The second form of this directive is useful for the case where you
  32412. -     have multiple headers with the same name in different directories.
  32413. -     If you use this form, you must specify the same string to `#pragma
  32414. -     implementation'.
  32415. -
  32416. -`#pragma implementation'
  32417. -`#pragma implementation "OBJECTS.h"'
  32418. -     Use this pragma in a *main input file*, when you want full output
  32419. -     from included header files to be generated (and made globally
  32420. -     visible).  The included header file, in turn, should use `#pragma
  32421. -     interface'.  Backup copies of inline member functions, debugging
  32422. -     information, and the internal tables used to implement virtual
  32423. -     functions are all generated in implementation files.
  32424. -
  32425. -     If you use `#pragma implementation' with no argument, it applies to
  32426. -     an include file with the same basename(1) as your source file.
  32427. -     For example, in `allclass.cc', `#pragma implementation' by itself
  32428. -     is equivalent to `#pragma implementation "allclass.h"'.
  32429. -
  32430. -     In versions of GNU C++ prior to 2.6.0 `allclass.h' was treated as
  32431. -     an implementation file whenever you would include it from
  32432. -     `allclass.cc' even if you never specified `#pragma
  32433. -     implementation'.  This was deemed to be more trouble than it was
  32434. -     worth, however, and disabled.
  32435. -
  32436. -     If you use an explicit `#pragma implementation', it must appear in
  32437. -     your source file *before* you include the affected header files.
  32438. -
  32439. -     Use the string argument if you want a single implementation file to
  32440. -     include code from multiple header files.  (You must also use
  32441. -     `#include' to include the header file; `#pragma implementation'
  32442. -     only specifies how to use the file--it doesn't actually include
  32443. -     it.)
  32444. -
  32445. -     There is no way to split up the contents of a single header file
  32446. -     into multiple implementation files.
  32447. -
  32448. -   `#pragma implementation' and `#pragma interface' also have an effect
  32449. -on function inlining.
  32450. -
  32451. -   If you define a class in a header file marked with `#pragma
  32452. -interface', the effect on a function defined in that class is similar to
  32453. -an explicit `extern' declaration--the compiler emits no code at all to
  32454. -define an independent version of the function.  Its definition is used
  32455. -only for inlining with its callers.
  32456. -
  32457. -   Conversely, when you include the same header file in a main source
  32458. -file that declares it as `#pragma implementation', the compiler emits
  32459. -code for the function itself; this defines a version of the function
  32460. -that can be found via pointers (or by callers compiled without
  32461. -inlining).  If all calls to the function can be inlined, you can avoid
  32462. -emitting the function by compiling with `-fno-implement-inlines'.  If
  32463. -any calls were not inlined, you will get linker errors.
  32464. -
  32465. -   ---------- Footnotes ----------
  32466. -
  32467. -   (1)  A file's "basename" was the name stripped of all leading path
  32468. -information and of trailing suffixes, such as `.h' or `.C' or `.cc'.
  32469. -
  32470. -
  32471. -File: gcc.info,  Node: Template Instantiation,  Next: C++ Signatures,  Prev: C++ Interface,  Up: C++ Extensions
  32472. -
  32473. -Where's the Template?
  32474. -=====================
  32475. -
  32476. -   C++ templates are the first language feature to require more
  32477. -intelligence from the environment than one usually finds on a UNIX
  32478. -system.  Somehow the compiler and linker have to make sure that each
  32479. -template instance occurs exactly once in the executable if it is needed,
  32480. -and not at all otherwise.  There are two basic approaches to this
  32481. -problem, which I will refer to as the Borland model and the Cfront
  32482. -model.
  32483. -
  32484. -Borland model
  32485. -     Borland C++ solved the template instantiation problem by adding
  32486. -     the code equivalent of common blocks to their linker; template
  32487. -     instances are emitted in each translation unit that uses them, and
  32488. -     they are collapsed together at run time.  The advantage of this
  32489. -     model is that the linker only has to consider the object files
  32490. -     themselves; there is no external complexity to worry about.  This
  32491. -     disadvantage is that compilation time is increased because the
  32492. -     template code is being compiled repeatedly.  Code written for this
  32493. -     model tends to include definitions of all member templates in the
  32494. -     header file, since they must be seen to be compiled.
  32495. -
  32496. -Cfront model
  32497. -     The AT&T C++ translator, Cfront, solved the template instantiation
  32498. -     problem by creating the notion of a template repository, an
  32499. -     automatically maintained place where template instances are
  32500. -     stored.  As individual object files are built, notes are placed in
  32501. -     the repository to record where templates and potential type
  32502. -     arguments were seen so that the subsequent instantiation step
  32503. -     knows where to find them.  At link time, any needed instances are
  32504. -     generated and linked in.  The advantages of this model are more
  32505. -     optimal compilation speed and the ability to use the system
  32506. -     linker; to implement the Borland model a compiler vendor also
  32507. -     needs to replace the linker.  The disadvantages are vastly
  32508. -     increased complexity, and thus potential for error; theoretically,
  32509. -     this should be just as transparent, but in practice it has been
  32510. -     very difficult to build multiple programs in one directory and one
  32511. -     program in multiple directories using Cfront.  Code written for
  32512. -     this model tends to separate definitions of non-inline member
  32513. -     templates into a separate file, which is magically found by the
  32514. -     link preprocessor when a template needs to be instantiated.
  32515. -
  32516. -   Currently, g++ implements neither automatic model.  In the mean time,
  32517. -you have three options for dealing with template instantiations:
  32518. -
  32519. -  1. Do nothing.  Pretend g++ does implement automatic instantiation
  32520. -     management.  Code written for the Borland model will work fine, but
  32521. -     each translation unit will contain instances of each of the
  32522. -     templates it uses.  In a large program, this can lead to an
  32523. -     unacceptable amount of code duplication.
  32524. -
  32525. -  2. Add `#pragma interface' to all files containing template
  32526. -     definitions.  For each of these files, add `#pragma implementation
  32527. -     "FILENAME"' to the top of some `.C' file which `#include's it.
  32528. -     Then compile everything with -fexternal-templates.  The templates
  32529. -     will then only be expanded in the translation unit which
  32530. -     implements them (i.e. has a `#pragma implementation' line for the
  32531. -     file where they live); all other files will use external
  32532. -     references.  If you're lucky, everything should work properly.  If
  32533. -     you get undefined symbol errors, you need to make sure that each
  32534. -     template instance which is used in the program is used in the file
  32535. -     which implements that template.  If you don't have any use for a
  32536. -     particular instance in that file, you can just instantiate it
  32537. -     explicitly, using the syntax from the latest C++ working paper:
  32538. -
  32539. -          template class A<int>;
  32540. -          template ostream& operator << (ostream&, const A<int>&);
  32541. -
  32542. -     This strategy will work with code written for either model.  If
  32543. -     you are using code written for the Cfront model, the file
  32544. -     containing a class template and the file containing its member
  32545. -     templates should be implemented in the same translation unit.
  32546. -
  32547. -     A slight variation on this approach is to use the flag
  32548. -     -falt-external-templates instead; this flag causes template
  32549. -     instances to be emitted in the translation unit that implements
  32550. -     the header where they are first instantiated, rather than the one
  32551. -     which implements the file where the templates are defined.  This
  32552. -     header must be the same in all translation units, or things are
  32553. -     likely to break.
  32554. -
  32555. -     *Note Declarations and Definitions in One Header: C++ Interface,
  32556. -     for more discussion of these pragmas.
  32557. -
  32558. -  3. Explicitly instantiate all the template instances you use, and
  32559. -     compile with -fno-implicit-templates.  This is probably your best
  32560. -     bet; it may require more knowledge of exactly which templates you
  32561. -     are using, but it's less mysterious than the previous approach,
  32562. -     and it doesn't require any `#pragma's or other g++-specific code.
  32563. -     You can scatter the instantiations throughout your program, you
  32564. -     can create one big file to do all the instantiations, or you can
  32565. -     create tiny files like
  32566. -
  32567. -          #include "Foo.h"
  32568. -          #include "Foo.cc"
  32569. -          
  32570. -          template class Foo<int>;
  32571. -
  32572. -     for each instance you need, and create a template instantiation
  32573. -     library from those.  I'm partial to the last, but your mileage may
  32574. -     vary.  If you are using Cfront-model code, you can probably get
  32575. -     away with not using -fno-implicit-templates when compiling files
  32576. -     that don't `#include' the member template definitions.
  32577. -
  32578. -
  32579. -File: gcc.info,  Node: C++ Signatures,  Prev: Template Instantiation,  Up: C++ Extensions
  32580. -
  32581. -Type Abstraction using Signatures
  32582. -=================================
  32583. -
  32584. -   In GNU C++, you can use the keyword `signature' to define a
  32585. -completely abstract class interface as a datatype.  You can connect this
  32586. -abstraction with actual classes using signature pointers.  If you want
  32587. -to use signatures, run the GNU compiler with the `-fhandle-signatures'
  32588. -command-line option.  (With this option, the compiler reserves a second
  32589. -keyword `sigof' as well, for a future extension.)
  32590. -
  32591. -   Roughly, signatures are type abstractions or interfaces of classes.
  32592. -Some other languages have similar facilities.  C++ signatures are
  32593. -related to ML's signatures, Haskell's type classes, definition modules
  32594. -in Modula-2, interface modules in Modula-3, abstract types in Emerald,
  32595. -type modules in Trellis/Owl, categories in Scratchpad II, and types in
  32596. -POOL-I.  For a more detailed discussion of signatures, see `Signatures:
  32597. -A Language Extension for Improving Type Abstraction and Subtype
  32598. -Polymorphism in C++' by Gerald Baumgartner and Vincent F. Russo (Tech
  32599. -report CSD-TR-95-051, Dept. of Computer Sciences, Purdue University,
  32600. -August 1995, a slightly improved version appeared in
  32601. -*Software--Practice & Experience*, 25(8), pp. 863-889, August 1995).
  32602. -You can get the tech report by anonymous FTP from `ftp.cs.purdue.edu'
  32603. -in `pub/gb/Signature-design.ps.gz'.
  32604. -
  32605. -   Syntactically, a signature declaration is a collection of member
  32606. -function declarations and nested type declarations.  For example, this
  32607. -signature declaration defines a new abstract type `S' with member
  32608. -functions `int foo ()' and `int bar (int)':
  32609. -
  32610. -     signature S
  32611. -     {
  32612. -       int foo ();
  32613. -       int bar (int);
  32614. -     };
  32615. -
  32616. -   Since signature types do not include implementation definitions, you
  32617. -cannot write an instance of a signature directly.  Instead, you can
  32618. -define a pointer to any class that contains the required interfaces as a
  32619. -"signature pointer".  Such a class "implements" the signature type.
  32620. -
  32621. -   To use a class as an implementation of `S', you must ensure that the
  32622. -class has public member functions `int foo ()' and `int bar (int)'.
  32623. -The class can have other member functions as well, public or not; as
  32624. -long as it offers what's declared in the signature, it is suitable as
  32625. -an implementation of that signature type.
  32626. -
  32627. -   For example, suppose that `C' is a class that meets the requirements
  32628. -of signature `S' (`C' "conforms to" `S').  Then
  32629. -
  32630. -     C obj;
  32631. -     S * p = &obj;
  32632. -
  32633. -defines a signature pointer `p' and initializes it to point to an
  32634. -object of type `C'.  The member function call `int i = p->foo ();'
  32635. -executes `obj.foo ()'.
  32636. -
  32637. -   Abstract virtual classes provide somewhat similar facilities in
  32638. -standard C++.  There are two main advantages to using signatures
  32639. -instead:
  32640. -
  32641. -  1. Subtyping becomes independent from inheritance.  A class or
  32642. -     signature type `T' is a subtype of a signature type `S'
  32643. -     independent of any inheritance hierarchy as long as all the member
  32644. -     functions declared in `S' are also found in `T'.  So you can
  32645. -     define a subtype hierarchy that is completely independent from any
  32646. -     inheritance (implementation) hierarchy, instead of being forced to
  32647. -     use types that mirror the class inheritance hierarchy.
  32648. -
  32649. -  2. Signatures allow you to work with existing class hierarchies as
  32650. -     implementations of a signature type.  If those class hierarchies
  32651. -     are only available in compiled form, you're out of luck with
  32652. -     abstract virtual classes, since an abstract virtual class cannot
  32653. -     be retrofitted on top of existing class hierarchies.  So you would
  32654. -     be required to write interface classes as subtypes of the abstract
  32655. -     virtual class.
  32656. -
  32657. -   There is one more detail about signatures.  A signature declaration
  32658. -can contain member function *definitions* as well as member function
  32659. -declarations.  A signature member function with a full definition is
  32660. -called a *default implementation*; classes need not contain that
  32661. -particular interface in order to conform.  For example, a class `C' can
  32662. -conform to the signature
  32663. -
  32664. -     signature T
  32665. -     {
  32666. -       int f (int);
  32667. -       int f0 () { return f (0); };
  32668. -     };
  32669. -
  32670. -whether or not `C' implements the member function `int f0 ()'.  If you
  32671. -define `C::f0', that definition takes precedence; otherwise, the
  32672. -default implementation `S::f0' applies.
  32673. -
  32674. -
  32675. -File: gcc.info,  Node: Trouble,  Next: Bugs,  Prev: C++ Extensions,  Up: Top
  32676. -
  32677. -Known Causes of Trouble with GNU CC
  32678. -***********************************
  32679. -
  32680. -   This section describes known problems that affect users of GNU CC.
  32681. -Most of these are not GNU CC bugs per se--if they were, we would fix
  32682. -them.  But the result for a user may be like the result of a bug.
  32683. -
  32684. -   Some of these problems are due to bugs in other software, some are
  32685. -missing features that are too much work to add, and some are places
  32686. -where people's opinions differ as to what is best.
  32687. -
  32688. -* Menu:
  32689. -
  32690. -* Actual Bugs::              Bugs we will fix later.
  32691. -* Installation Problems::     Problems that manifest when you install GNU CC.
  32692. -* Cross-Compiler Problems::   Common problems of cross compiling with GNU CC.
  32693. -* Interoperation::      Problems using GNU CC with other compilers,
  32694. -               and with certain linkers, assemblers and debuggers.
  32695. -* External Bugs::    Problems compiling certain programs.
  32696. -* Incompatibilities::   GNU CC is incompatible with traditional C.
  32697. -* Fixed Headers::       GNU C uses corrected versions of system header files.
  32698. -                           This is necessary, but doesn't always work smoothly.
  32699. -* Standard Libraries::  GNU C uses the system C library, which might not be
  32700. -                           compliant with the ISO/ANSI C standard.
  32701. -* Disappointments::     Regrettable things we can't change, but not quite bugs.
  32702. -* C++ Misunderstandings::     Common misunderstandings with GNU C++.
  32703. -* Protoize Caveats::    Things to watch out for when using `protoize'.
  32704. -* Non-bugs::        Things we think are right, but some others disagree.
  32705. -* Warnings and Errors:: Which problems in your code get warnings,
  32706. -                         and which get errors.
  32707. -
  32708. -
  32709. -File: gcc.info,  Node: Actual Bugs,  Next: Installation Problems,  Up: Trouble
  32710. -
  32711. -Actual Bugs We Haven't Fixed Yet
  32712. -================================
  32713. -
  32714. -   * The `fixincludes' script interacts badly with automounters; if the
  32715. -     directory of system header files is automounted, it tends to be
  32716. -     unmounted while `fixincludes' is running.  This would seem to be a
  32717. -     bug in the automounter.  We don't know any good way to work around
  32718. -     it.
  32719. -
  32720. -   * The `fixproto' script will sometimes add prototypes for the
  32721. -     `sigsetjmp' and `siglongjmp' functions that reference the
  32722. -     `jmp_buf' type before that type is defined.  To work around this,
  32723. -     edit the offending file and place the typedef in front of the
  32724. -     prototypes.
  32725. -
  32726. -   * There are several obscure case of mis-using struct, union, and
  32727. -     enum tags that are not detected as errors by the compiler.
  32728. -
  32729. -   * When `-pedantic-errors' is specified, GNU C will incorrectly give
  32730. -     an error message when a function name is specified in an expression
  32731. -     involving the comma operator.
  32732. -
  32733. -   * Loop unrolling doesn't work properly for certain C++ programs.
  32734. -     This is a bug in the C++ front end.  It sometimes emits incorrect
  32735. -     debug info, and the loop unrolling code is unable to recover from
  32736. -     this error.
  32737. -
  32738. diff -rup --new-file baseline/fsf/gcc/gcc.info-11 amiga/fsf/gcc/gcc.info-11
  32739. --- baseline/fsf/gcc/gcc.info-11    Sat Jun 29 09:38:01 1996
  32740. +++ amiga/fsf/gcc/gcc.info-11    Wed Dec 31 17:00:00 1969
  32741. @@ -1,1144 +0,0 @@
  32742. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  32743. -file gcc.texi.
  32744. -
  32745. -   This file documents the use and the internals of the GNU compiler.
  32746. -
  32747. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  32748. -Boston, MA 02111-1307 USA
  32749. -
  32750. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  32751. -Foundation, Inc.
  32752. -
  32753. -   Permission is granted to make and distribute verbatim copies of this
  32754. -manual provided the copyright notice and this permission notice are
  32755. -preserved on all copies.
  32756. -
  32757. -   Permission is granted to copy and distribute modified versions of
  32758. -this manual under the conditions for verbatim copying, provided also
  32759. -that the sections entitled "GNU General Public License," "Funding for
  32760. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  32761. -included exactly as in the original, and provided that the entire
  32762. -resulting derived work is distributed under the terms of a permission
  32763. -notice identical to this one.
  32764. -
  32765. -   Permission is granted to copy and distribute translations of this
  32766. -manual into another language, under the above conditions for modified
  32767. -versions, except that the sections entitled "GNU General Public
  32768. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  32769. -`Look And Feel'", and this permission notice, may be included in
  32770. -translations approved by the Free Software Foundation instead of in the
  32771. -original English.
  32772. -
  32773. -
  32774. -File: gcc.info,  Node: Installation Problems,  Next: Cross-Compiler Problems,  Prev: Actual Bugs,  Up: Trouble
  32775. -
  32776. -Installation Problems
  32777. -=====================
  32778. -
  32779. -   This is a list of problems (and some apparent problems which don't
  32780. -really mean anything is wrong) that show up during installation of GNU
  32781. -CC.
  32782. -
  32783. -   * On certain systems, defining certain environment variables such as
  32784. -     `CC' can interfere with the functioning of `make'.
  32785. -
  32786. -   * If you encounter seemingly strange errors when trying to build the
  32787. -     compiler in a directory other than the source directory, it could
  32788. -     be because you have previously configured the compiler in the
  32789. -     source directory.  Make sure you have done all the necessary
  32790. -     preparations.  *Note Other Dir::.
  32791. -
  32792. -   * If you build GNU CC on a BSD system using a directory stored in a
  32793. -     System V file system, problems may occur in running `fixincludes'
  32794. -     if the System V file system doesn't support symbolic links.  These
  32795. -     problems result in a failure to fix the declaration of `size_t' in
  32796. -     `sys/types.h'.  If you find that `size_t' is a signed type and
  32797. -     that type mismatches occur, this could be the cause.
  32798. -
  32799. -     The solution is not to use such a directory for building GNU CC.
  32800. -
  32801. -   * In previous versions of GNU CC, the `gcc' driver program looked for
  32802. -     `as' and `ld' in various places; for example, in files beginning
  32803. -     with `/usr/local/lib/gcc-'.  GNU CC version 2 looks for them in
  32804. -     the directory `/usr/local/lib/gcc-lib/TARGET/VERSION'.
  32805. -
  32806. -     Thus, to use a version of `as' or `ld' that is not the system
  32807. -     default, for example `gas' or GNU `ld', you must put them in that
  32808. -     directory (or make links to them from that directory).
  32809. -
  32810. -   * Some commands executed when making the compiler may fail (return a
  32811. -     non-zero status) and be ignored by `make'.  These failures, which
  32812. -     are often due to files that were not found, are expected, and can
  32813. -     safely be ignored.
  32814. -
  32815. -   * It is normal to have warnings in compiling certain files about
  32816. -     unreachable code and about enumeration type clashes.  These files'
  32817. -     names begin with `insn-'.  Also, `real.c' may get some warnings
  32818. -     that you can ignore.
  32819. -
  32820. -   * Sometimes `make' recompiles parts of the compiler when installing
  32821. -     the compiler.  In one case, this was traced down to a bug in
  32822. -     `make'.  Either ignore the problem or switch to GNU Make.
  32823. -
  32824. -   * If you have installed a program known as purify, you may find that
  32825. -     it causes errors while linking `enquire', which is part of building
  32826. -     GNU CC.  The fix is to get rid of the file `real-ld' which purify
  32827. -     installs--so that GNU CC won't try to use it.
  32828. -
  32829. -   * On SLS 1.01, a Linux-based GNU system, there is a problem with
  32830. -     `libc.a': it does not contain the obstack functions.  However, GNU
  32831. -     CC assumes that the obstack functions are in `libc.a' when it is
  32832. -     the GNU C library.  To work around this problem, change the
  32833. -     `__GNU_LIBRARY__' conditional around line 31 to `#if 1'.
  32834. -
  32835. -   * On some 386 systems, building the compiler never finishes because
  32836. -     `enquire' hangs due to a hardware problem in the motherboard--it
  32837. -     reports floating point exceptions to the kernel incorrectly.  You
  32838. -     can install GNU CC except for `float.h' by patching out the
  32839. -     command to run `enquire'.  You may also be able to fix the problem
  32840. -     for real by getting a replacement motherboard.  This problem was
  32841. -     observed in Revision E of the Micronics motherboard, and is fixed
  32842. -     in Revision F.  It has also been observed in the MYLEX MXA-33
  32843. -     motherboard.
  32844. -
  32845. -     If you encounter this problem, you may also want to consider
  32846. -     removing the FPU from the socket during the compilation.
  32847. -     Alternatively, if you are running SCO Unix, you can reboot and
  32848. -     force the FPU to be ignored.  To do this, type `hd(40)unix auto
  32849. -     ignorefpu'.
  32850. -
  32851. -   * On some 386 systems, GNU CC crashes trying to compile `enquire.c'.
  32852. -     This happens on machines that don't have a 387 FPU chip.  On 386
  32853. -     machines, the system kernel is supposed to emulate the 387 when you
  32854. -     don't have one.  The crash is due to a bug in the emulator.
  32855. -
  32856. -     One of these systems is the Unix from Interactive Systems: 386/ix.
  32857. -     On this system, an alternate emulator is provided, and it does
  32858. -     work.  To use it, execute this command as super-user:
  32859. -
  32860. -          ln /etc/emulator.rel1 /etc/emulator
  32861. -
  32862. -     and then reboot the system.  (The default emulator file remains
  32863. -     present under the name `emulator.dflt'.)
  32864. -
  32865. -     Try using `/etc/emulator.att', if you have such a problem on the
  32866. -     SCO system.
  32867. -
  32868. -     Another system which has this problem is Esix.  We don't know
  32869. -     whether it has an alternate emulator that works.
  32870. -
  32871. -     On NetBSD 0.8, a similar problem manifests itself as these error
  32872. -     messages:
  32873. -
  32874. -          enquire.c: In function `fprop':
  32875. -          enquire.c:2328: floating overflow
  32876. -
  32877. -   * On SCO systems, when compiling GNU CC with the system's compiler,
  32878. -     do not use `-O'.  Some versions of the system's compiler miscompile
  32879. -     GNU CC with `-O'.
  32880. -
  32881. -   * Sometimes on a Sun 4 you may observe a crash in the program
  32882. -     `genflags' or `genoutput' while building GNU CC.  This is said to
  32883. -     be due to a bug in `sh'.  You can probably get around it by running
  32884. -     `genflags' or `genoutput' manually and then retrying the `make'.
  32885. -
  32886. -   * On Solaris 2, executables of GNU CC version 2.0.2 are commonly
  32887. -     available, but they have a bug that shows up when compiling current
  32888. -     versions of GNU CC: undefined symbol errors occur during assembly
  32889. -     if you use `-g'.
  32890. -
  32891. -     The solution is to compile the current version of GNU CC without
  32892. -     `-g'.  That makes a working compiler which you can use to recompile
  32893. -     with `-g'.
  32894. -
  32895. -   * Solaris 2 comes with a number of optional OS packages.  Some of
  32896. -     these packages are needed to use GNU CC fully.  If you did not
  32897. -     install all optional packages when installing Solaris, you will
  32898. -     need to verify that the packages that GNU CC needs are installed.
  32899. -
  32900. -     To check whether an optional package is installed, use the
  32901. -     `pkginfo' command.  To add an optional package, use the `pkgadd'
  32902. -     command.  For further details, see the Solaris documentation.
  32903. -
  32904. -     For Solaris 2.0 and 2.1, GNU CC needs six packages: `SUNWarc',
  32905. -     `SUNWbtool', `SUNWesu', `SUNWhea', `SUNWlibm', and `SUNWtoo'.
  32906. -
  32907. -     For Solaris 2.2, GNU CC needs an additional seventh package:
  32908. -     `SUNWsprot'.
  32909. -
  32910. -   * On Solaris 2, trying to use the linker and other tools in
  32911. -     `/usr/ucb' to install GNU CC has been observed to cause trouble.
  32912. -     For example, the linker may hang indefinitely.  The fix is to
  32913. -     remove `/usr/ucb' from your `PATH'.
  32914. -
  32915. -   * If you use the 1.31 version of the MIPS assembler (such as was
  32916. -     shipped with Ultrix 3.1), you will need to use the
  32917. -     -fno-delayed-branch switch when optimizing floating point code.
  32918. -     Otherwise, the assembler will complain when the GCC compiler fills
  32919. -     a branch delay slot with a floating point instruction, such as
  32920. -     `add.d'.
  32921. -
  32922. -   * If on a MIPS system you get an error message saying "does not have
  32923. -     gp sections for all it's [sic] sectons [sic]", don't worry about
  32924. -     it.  This happens whenever you use GAS with the MIPS linker, but
  32925. -     there is not really anything wrong, and it is okay to use the
  32926. -     output file.  You can stop such warnings by installing the GNU
  32927. -     linker.
  32928. -
  32929. -     It would be nice to extend GAS to produce the gp tables, but they
  32930. -     are optional, and there should not be a warning about their
  32931. -     absence.
  32932. -
  32933. -   * In Ultrix 4.0 on the MIPS machine, `stdio.h' does not work with GNU
  32934. -     CC at all unless it has been fixed with `fixincludes'.  This causes
  32935. -     problems in building GNU CC.  Once GNU CC is installed, the
  32936. -     problems go away.
  32937. -
  32938. -     To work around this problem, when making the stage 1 compiler,
  32939. -     specify this option to Make:
  32940. -
  32941. -          GCC_FOR_TARGET="./xgcc -B./ -I./include"
  32942. -
  32943. -     When making stage 2 and stage 3, specify this option:
  32944. -
  32945. -          CFLAGS="-g -I./include"
  32946. -
  32947. -   * Users have reported some problems with version 2.0 of the MIPS
  32948. -     compiler tools that were shipped with Ultrix 4.1.  Version 2.10
  32949. -     which came with Ultrix 4.2 seems to work fine.
  32950. -
  32951. -     Users have also reported some problems with version 2.20 of the
  32952. -     MIPS compiler tools that were shipped with RISC/os 4.x.  The
  32953. -     earlier version 2.11 seems to work fine.
  32954. -
  32955. -   * Some versions of the MIPS linker will issue an assertion failure
  32956. -     when linking code that uses `alloca' against shared libraries on
  32957. -     RISC-OS 5.0, and DEC's OSF/1 systems.  This is a bug in the
  32958. -     linker, that is supposed to be fixed in future revisions.  To
  32959. -     protect against this, GNU CC passes `-non_shared' to the linker
  32960. -     unless you pass an explicit `-shared' or `-call_shared' switch.
  32961. -
  32962. -   * On System V release 3, you may get this error message while
  32963. -     linking:
  32964. -
  32965. -          ld fatal: failed to write symbol name SOMETHING
  32966. -           in strings table for file WHATEVER
  32967. -
  32968. -     This probably indicates that the disk is full or your ULIMIT won't
  32969. -     allow the file to be as large as it needs to be.
  32970. -
  32971. -     This problem can also result because the kernel parameter `MAXUMEM'
  32972. -     is too small.  If so, you must regenerate the kernel and make the
  32973. -     value much larger.  The default value is reported to be 1024; a
  32974. -     value of 32768 is said to work.  Smaller values may also work.
  32975. -
  32976. -   * On System V, if you get an error like this,
  32977. -
  32978. -          /usr/local/lib/bison.simple: In function `yyparse':
  32979. -          /usr/local/lib/bison.simple:625: virtual memory exhausted
  32980. -
  32981. -     that too indicates a problem with disk space, ULIMIT, or `MAXUMEM'.
  32982. -
  32983. -   * Current GNU CC versions probably do not work on version 2 of the
  32984. -     NeXT operating system.
  32985. -
  32986. -   * On NeXTStep 3.0, the Objective C compiler does not work, due,
  32987. -     apparently, to a kernel bug that it happens to trigger.  This
  32988. -     problem does not happen on 3.1.
  32989. -
  32990. -   * On the Tower models 4N0 and 6N0, by default a process is not
  32991. -     allowed to have more than one megabyte of memory.  GNU CC cannot
  32992. -     compile itself (or many other programs) with `-O' in that much
  32993. -     memory.
  32994. -
  32995. -     To solve this problem, reconfigure the kernel adding the following
  32996. -     line to the configuration file:
  32997. -
  32998. -          MAXUMEM = 4096
  32999. -
  33000. -   * On HP 9000 series 300 or 400 running HP-UX release 8.0, there is a
  33001. -     bug in the assembler that must be fixed before GNU CC can be
  33002. -     built.  This bug manifests itself during the first stage of
  33003. -     compilation, while building `libgcc2.a':
  33004. -
  33005. -          _floatdisf
  33006. -          cc1: warning: `-g' option not supported on this version of GCC
  33007. -          cc1: warning: `-g1' option not supported on this version of GCC
  33008. -          ./xgcc: Internal compiler error: program as got fatal signal 11
  33009. -
  33010. -     A patched version of the assembler is available by anonymous ftp
  33011. -     from `altdorf.ai.mit.edu' as the file
  33012. -     `archive/cph/hpux-8.0-assembler'.  If you have HP software support,
  33013. -     the patch can also be obtained directly from HP, as described in
  33014. -     the following note:
  33015. -
  33016. -          This is the patched assembler, to patch SR#1653-010439, where
  33017. -          the assembler aborts on floating point constants.
  33018. -
  33019. -          The bug is not really in the assembler, but in the shared
  33020. -          library version of the function "cvtnum(3c)".  The bug on
  33021. -          "cvtnum(3c)" is SR#4701-078451.  Anyway, the attached
  33022. -          assembler uses the archive library version of "cvtnum(3c)"
  33023. -          and thus does not exhibit the bug.
  33024. -
  33025. -     This patch is also known as PHCO_4484.
  33026. -
  33027. -   * On HP-UX version 8.05, but not on 8.07 or more recent versions,
  33028. -     the `fixproto' shell script triggers a bug in the system shell.
  33029. -     If you encounter this problem, upgrade your operating system or
  33030. -     use BASH (the GNU shell) to run `fixproto'.
  33031. -
  33032. -   * Some versions of the Pyramid C compiler are reported to be unable
  33033. -     to compile GNU CC.  You must use an older version of GNU CC for
  33034. -     bootstrapping.  One indication of this problem is if you get a
  33035. -     crash when GNU CC compiles the function `muldi3' in file
  33036. -     `libgcc2.c'.
  33037. -
  33038. -     You may be able to succeed by getting GNU CC version 1, installing
  33039. -     it, and using it to compile GNU CC version 2.  The bug in the
  33040. -     Pyramid C compiler does not seem to affect GNU CC version 1.
  33041. -
  33042. -   * There may be similar problems on System V Release 3.1 on 386
  33043. -     systems.
  33044. -
  33045. -   * On the Intel Paragon (an i860 machine), if you are using operating
  33046. -     system version 1.0, you will get warnings or errors about
  33047. -     redefinition of `va_arg' when you build GNU CC.
  33048. -
  33049. -     If this happens, then you need to link most programs with the
  33050. -     library `iclib.a'.  You must also modify `stdio.h' as follows:
  33051. -     before the lines
  33052. -
  33053. -          #if     defined(__i860__) && !defined(_VA_LIST)
  33054. -          #include <va_list.h>
  33055. -
  33056. -     insert the line
  33057. -
  33058. -          #if __PGC__
  33059. -
  33060. -     and after the lines
  33061. -
  33062. -          extern int  vprintf(const char *, va_list );
  33063. -          extern int  vsprintf(char *, const char *, va_list );
  33064. -          #endif
  33065. -
  33066. -     insert the line
  33067. -
  33068. -          #endif /* __PGC__ */
  33069. -
  33070. -     These problems don't exist in operating system version 1.1.
  33071. -
  33072. -   * On the Altos 3068, programs compiled with GNU CC won't work unless
  33073. -     you fix a kernel bug.  This happens using system versions V.2.2
  33074. -     1.0gT1 and V.2.2 1.0e and perhaps later versions as well.  See the
  33075. -     file `README.ALTOS'.
  33076. -
  33077. -   * You will get several sorts of compilation and linking errors on the
  33078. -     we32k if you don't follow the special instructions.  *Note
  33079. -     Configurations::.
  33080. -
  33081. -   * A bug in the HP-UX 8.05 (and earlier) shell will cause the fixproto
  33082. -     program to report an error of the form:
  33083. -
  33084. -          ./fixproto: sh internal 1K buffer overflow
  33085. -
  33086. -     To fix this, change the first line of the fixproto script to look
  33087. -     like:
  33088. -
  33089. -          #!/bin/ksh
  33090. -
  33091. -
  33092. -File: gcc.info,  Node: Cross-Compiler Problems,  Next: Interoperation,  Prev: Installation Problems,  Up: Trouble
  33093. -
  33094. -Cross-Compiler Problems
  33095. -=======================
  33096. -
  33097. -   You may run into problems with cross compilation on certain machines,
  33098. -for several reasons.
  33099. -
  33100. -   * Cross compilation can run into trouble for certain machines because
  33101. -     some target machines' assemblers require floating point numbers to
  33102. -     be written as *integer* constants in certain contexts.
  33103. -
  33104. -     The compiler writes these integer constants by examining the
  33105. -     floating point value as an integer and printing that integer,
  33106. -     because this is simple to write and independent of the details of
  33107. -     the floating point representation.  But this does not work if the
  33108. -     compiler is running on a different machine with an incompatible
  33109. -     floating point format, or even a different byte-ordering.
  33110. -
  33111. -     In addition, correct constant folding of floating point values
  33112. -     requires representing them in the target machine's format.  (The C
  33113. -     standard does not quite require this, but in practice it is the
  33114. -     only way to win.)
  33115. -
  33116. -     It is now possible to overcome these problems by defining macros
  33117. -     such as `REAL_VALUE_TYPE'.  But doing so is a substantial amount of
  33118. -     work for each target machine.  *Note Cross-compilation::.
  33119. -
  33120. -   * At present, the program `mips-tfile' which adds debug support to
  33121. -     object files on MIPS systems does not work in a cross compile
  33122. -     environment.
  33123. -
  33124. -
  33125. -File: gcc.info,  Node: Interoperation,  Next: External Bugs,  Prev: Cross-Compiler Problems,  Up: Trouble
  33126. -
  33127. -Interoperation
  33128. -==============
  33129. -
  33130. -   This section lists various difficulties encountered in using GNU C or
  33131. -GNU C++ together with other compilers or with the assemblers, linkers,
  33132. -libraries and debuggers on certain systems.
  33133. -
  33134. -   * Objective C does not work on the RS/6000.
  33135. -
  33136. -   * GNU C++ does not do name mangling in the same way as other C++
  33137. -     compilers.  This means that object files compiled with one compiler
  33138. -     cannot be used with another.
  33139. -
  33140. -     This effect is intentional, to protect you from more subtle
  33141. -     problems.  Compilers differ as to many internal details of C++
  33142. -     implementation, including: how class instances are laid out, how
  33143. -     multiple inheritance is implemented, and how virtual function
  33144. -     calls are handled.  If the name encoding were made the same, your
  33145. -     programs would link against libraries provided from other
  33146. -     compilers--but the programs would then crash when run.
  33147. -     Incompatible libraries are then detected at link time, rather than
  33148. -     at run time.
  33149. -
  33150. -   * Older GDB versions sometimes fail to read the output of GNU CC
  33151. -     version 2.  If you have trouble, get GDB version 4.4 or later.
  33152. -
  33153. -   * DBX rejects some files produced by GNU CC, though it accepts
  33154. -     similar constructs in output from PCC.  Until someone can supply a
  33155. -     coherent description of what is valid DBX input and what is not,
  33156. -     there is nothing I can do about these problems.  You are on your
  33157. -     own.
  33158. -
  33159. -   * The GNU assembler (GAS) does not support PIC.  To generate PIC
  33160. -     code, you must use some other assembler, such as `/bin/as'.
  33161. -
  33162. -   * On some BSD systems, including some versions of Ultrix, use of
  33163. -     profiling causes static variable destructors (currently used only
  33164. -     in C++) not to be run.
  33165. -
  33166. -   * Use of `-I/usr/include' may cause trouble.
  33167. -
  33168. -     Many systems come with header files that won't work with GNU CC
  33169. -     unless corrected by `fixincludes'.  The corrected header files go
  33170. -     in a new directory; GNU CC searches this directory before
  33171. -     `/usr/include'.  If you use `-I/usr/include', this tells GNU CC to
  33172. -     search `/usr/include' earlier on, before the corrected headers.
  33173. -     The result is that you get the uncorrected header files.
  33174. -
  33175. -     Instead, you should use these options (when compiling C programs):
  33176. -
  33177. -          -I/usr/local/lib/gcc-lib/TARGET/VERSION/include -I/usr/include
  33178. -
  33179. -     For C++ programs, GNU CC also uses a special directory that
  33180. -     defines C++ interfaces to standard C subroutines.  This directory
  33181. -     is meant to be searched *before* other standard include
  33182. -     directories, so that it takes precedence.  If you are compiling
  33183. -     C++ programs and specifying include directories explicitly, use
  33184. -     this option first, then the two options above:
  33185. -
  33186. -          -I/usr/local/lib/g++-include
  33187. -
  33188. -   * On some SGI systems, when you use `-lgl_s' as an option, it gets
  33189. -     translated magically to `-lgl_s -lX11_s -lc_s'.  Naturally, this
  33190. -     does not happen when you use GNU CC.  You must specify all three
  33191. -     options explicitly.
  33192. -
  33193. -   * On a Sparc, GNU CC aligns all values of type `double' on an 8-byte
  33194. -     boundary, and it expects every `double' to be so aligned.  The Sun
  33195. -     compiler usually gives `double' values 8-byte alignment, with one
  33196. -     exception: function arguments of type `double' may not be aligned.
  33197. -
  33198. -     As a result, if a function compiled with Sun CC takes the address
  33199. -     of an argument of type `double' and passes this pointer of type
  33200. -     `double *' to a function compiled with GNU CC, dereferencing the
  33201. -     pointer may cause a fatal signal.
  33202. -
  33203. -     One way to solve this problem is to compile your entire program
  33204. -     with GNU CC.  Another solution is to modify the function that is
  33205. -     compiled with Sun CC to copy the argument into a local variable;
  33206. -     local variables are always properly aligned.  A third solution is
  33207. -     to modify the function that uses the pointer to dereference it via
  33208. -     the following function `access_double' instead of directly with
  33209. -     `*':
  33210. -
  33211. -          inline double
  33212. -          access_double (double *unaligned_ptr)
  33213. -          {
  33214. -            union d2i { double d; int i[2]; };
  33215. -          
  33216. -            union d2i *p = (union d2i *) unaligned_ptr;
  33217. -            union d2i u;
  33218. -          
  33219. -            u.i[0] = p->i[0];
  33220. -            u.i[1] = p->i[1];
  33221. -          
  33222. -            return u.d;
  33223. -          }
  33224. -
  33225. -     Storing into the pointer can be done likewise with the same union.
  33226. -
  33227. -   * On Solaris, the `malloc' function in the `libmalloc.a' library may
  33228. -     allocate memory that is only 4 byte aligned.  Since GNU CC on the
  33229. -     Sparc assumes that doubles are 8 byte aligned, this may result in a
  33230. -     fatal signal if doubles are stored in memory allocated by the
  33231. -     `libmalloc.a' library.
  33232. -
  33233. -     The solution is to not use the `libmalloc.a' library.  Use instead
  33234. -     `malloc' and related functions from `libc.a'; they do not have
  33235. -     this problem.
  33236. -
  33237. -   * Sun forgot to include a static version of `libdl.a' with some
  33238. -     versions of SunOS (mainly 4.1).  This results in undefined symbols
  33239. -     when linking static binaries (that is, if you use `-static').  If
  33240. -     you see undefined symbols `_dlclose', `_dlsym' or `_dlopen' when
  33241. -     linking, compile and link against the file `mit/util/misc/dlsym.c'
  33242. -     from the MIT version of X windows.
  33243. -
  33244. -   * The 128-bit long double format that the Sparc port supports
  33245. -     currently works by using the architecturally defined quad-word
  33246. -     floating point instructions.  Since there is no hardware that
  33247. -     supports these instructions they must be emulated by the operating
  33248. -     system.  Long doubles do not work in Sun OS versions 4.0.3 and
  33249. -     earlier, because the kernel emulator uses an obsolete and
  33250. -     incompatible format.  Long doubles do not work in Sun OS version
  33251. -     4.1.1 due to a problem in a Sun library.  Long doubles do work on
  33252. -     Sun OS versions 4.1.2 and higher, but GNU CC does not enable them
  33253. -     by default.  Long doubles appear to work in Sun OS 5.x (Solaris
  33254. -     2.x).
  33255. -
  33256. -   * On HP-UX version 9.01 on the HP PA, the HP compiler `cc' does not
  33257. -     compile GNU CC correctly.  We do not yet know why.  However, GNU CC
  33258. -     compiled on earlier HP-UX versions works properly on HP-UX 9.01
  33259. -     and can compile itself properly on 9.01.
  33260. -
  33261. -   * On the HP PA machine, ADB sometimes fails to work on functions
  33262. -     compiled with GNU CC.  Specifically, it fails to work on functions
  33263. -     that use `alloca' or variable-size arrays.  This is because GNU CC
  33264. -     doesn't generate HP-UX unwind descriptors for such functions.  It
  33265. -     may even be impossible to generate them.
  33266. -
  33267. -   * Debugging (`-g') is not supported on the HP PA machine, unless you
  33268. -     use the preliminary GNU tools (*note Installation::.).
  33269. -
  33270. -   * Taking the address of a label may generate errors from the HP-UX
  33271. -     PA assembler.  GAS for the PA does not have this problem.
  33272. -
  33273. -   * Using floating point parameters for indirect calls to static
  33274. -     functions will not work when using the HP assembler.  There simply
  33275. -     is no way for GCC to specify what registers hold arguments for
  33276. -     static functions when using the HP assembler.  GAS for the PA does
  33277. -     not have this problem.
  33278. -
  33279. -   * In extremely rare cases involving some very large functions you may
  33280. -     receive errors from the HP linker complaining about an out of
  33281. -     bounds unconditional branch offset.  This used to occur more often
  33282. -     in previous versions of GNU CC, but is now exceptionally rare.  If
  33283. -     you should run into it, you can work around by making your
  33284. -     function smaller.
  33285. -
  33286. -   * GNU CC compiled code sometimes emits warnings from the HP-UX
  33287. -     assembler of the form:
  33288. -
  33289. -          (warning) Use of GR3 when
  33290. -            frame >= 8192 may cause conflict.
  33291. -
  33292. -     These warnings are harmless and can be safely ignored.
  33293. -
  33294. -   * The current version of the assembler (`/bin/as') for the RS/6000
  33295. -     has certain problems that prevent the `-g' option in GCC from
  33296. -     working.  Note that `Makefile.in' uses `-g' by default when
  33297. -     compiling `libgcc2.c'.
  33298. -
  33299. -     IBM has produced a fixed version of the assembler.  The upgraded
  33300. -     assembler unfortunately was not included in any of the AIX 3.2
  33301. -     update PTF releases (3.2.2, 3.2.3, or 3.2.3e).  Users of AIX 3.1
  33302. -     should request PTF U403044 from IBM and users of AIX 3.2 should
  33303. -     request PTF U416277.  See the file `README.RS6000' for more
  33304. -     details on these updates.
  33305. -
  33306. -     You can test for the presense of a fixed assembler by using the
  33307. -     command
  33308. -
  33309. -          as -u < /dev/null
  33310. -
  33311. -     If the command exits normally, the assembler fix already is
  33312. -     installed.  If the assembler complains that "-u" is an unknown
  33313. -     flag, you need to order the fix.
  33314. -
  33315. -   * On the IBM RS/6000, compiling code of the form
  33316. -
  33317. -          extern int foo;
  33318. -          
  33319. -          ... foo ...
  33320. -          
  33321. -          static int foo;
  33322. -
  33323. -     will cause the linker to report an undefined symbol `foo'.
  33324. -     Although this behavior differs from most other systems, it is not a
  33325. -     bug because redefining an `extern' variable as `static' is
  33326. -     undefined in ANSI C.
  33327. -
  33328. -   * AIX on the RS/6000 provides support (NLS) for environments outside
  33329. -     of the United States.  Compilers and assemblers use NLS to support
  33330. -     locale-specific representations of various objects including
  33331. -     floating-point numbers ("." vs "," for separating decimal
  33332. -     fractions).  There have been problems reported where the library
  33333. -     linked with GCC does not produce the same floating-point formats
  33334. -     that the assembler accepts.  If you have this problem, set the
  33335. -     LANG environment variable to "C" or "En_US".
  33336. -
  33337. -   * Even if you specify `-fdollars-in-identifiers', you cannot
  33338. -     successfully use `$' in identifiers on the RS/6000 due to a
  33339. -     restriction in the IBM assembler.  GAS supports these identifiers.
  33340. -
  33341. -   * On the RS/6000, XLC version 1.3.0.0 will miscompile `jump.c'.  XLC
  33342. -     version 1.3.0.1 or later fixes this problem.  You can obtain
  33343. -     XLC-1.3.0.2 by requesting PTF 421749 from IBM.
  33344. -
  33345. -   * There is an assembler bug in versions of DG/UX prior to 5.4.2.01
  33346. -     that occurs when the `fldcr' instruction is used.  GNU CC uses
  33347. -     `fldcr' on the 88100 to serialize volatile memory references.  Use
  33348. -     the option `-mno-serialize-volatile' if your version of the
  33349. -     assembler has this bug.
  33350. -
  33351. -   * On VMS, GAS versions 1.38.1 and earlier may cause spurious warning
  33352. -     messages from the linker.  These warning messages complain of
  33353. -     mismatched psect attributes.  You can ignore them.  *Note VMS
  33354. -     Install::.
  33355. -
  33356. -   * On NewsOS version 3, if you include both of the files `stddef.h'
  33357. -     and `sys/types.h', you get an error because there are two typedefs
  33358. -     of `size_t'.  You should change `sys/types.h' by adding these
  33359. -     lines around the definition of `size_t':
  33360. -
  33361. -          #ifndef _SIZE_T
  33362. -          #define _SIZE_T
  33363. -          ACTUAL TYPEDEF HERE
  33364. -          #endif
  33365. -
  33366. -   * On the Alliant, the system's own convention for returning
  33367. -     structures and unions is unusual, and is not compatible with GNU
  33368. -     CC no matter what options are used.
  33369. -
  33370. -   * On the IBM RT PC, the MetaWare HighC compiler (hc) uses a different
  33371. -     convention for structure and union returning.  Use the option
  33372. -     `-mhc-struct-return' to tell GNU CC to use a convention compatible
  33373. -     with it.
  33374. -
  33375. -   * On Ultrix, the Fortran compiler expects registers 2 through 5 to
  33376. -     be saved by function calls.  However, the C compiler uses
  33377. -     conventions compatible with BSD Unix: registers 2 through 5 may be
  33378. -     clobbered by function calls.
  33379. -
  33380. -     GNU CC uses the same convention as the Ultrix C compiler.  You can
  33381. -     use these options to produce code compatible with the Fortran
  33382. -     compiler:
  33383. -
  33384. -          -fcall-saved-r2 -fcall-saved-r3 -fcall-saved-r4 -fcall-saved-r5
  33385. -
  33386. -   * On the WE32k, you may find that programs compiled with GNU CC do
  33387. -     not work with the standard shared C library.  You may need to link
  33388. -     with the ordinary C compiler.  If you do so, you must specify the
  33389. -     following options:
  33390. -
  33391. -          -L/usr/local/lib/gcc-lib/we32k-att-sysv/2.7.1 -lgcc -lc_s
  33392. -
  33393. -     The first specifies where to find the library `libgcc.a' specified
  33394. -     with the `-lgcc' option.
  33395. -
  33396. -     GNU CC does linking by invoking `ld', just as `cc' does, and there
  33397. -     is no reason why it *should* matter which compilation program you
  33398. -     use to invoke `ld'.  If someone tracks this problem down, it can
  33399. -     probably be fixed easily.
  33400. -
  33401. -   * On the Alpha, you may get assembler errors about invalid syntax as
  33402. -     a result of floating point constants.  This is due to a bug in the
  33403. -     C library functions `ecvt', `fcvt' and `gcvt'.  Given valid
  33404. -     floating point numbers, they sometimes print `NaN'.
  33405. -
  33406. -   * On Irix 4.0.5F (and perhaps in some other versions), an assembler
  33407. -     bug sometimes reorders instructions incorrectly when optimization
  33408. -     is turned on.  If you think this may be happening to you, try
  33409. -     using the GNU assembler; GAS version 2.1 supports ECOFF on Irix.
  33410. -
  33411. -     Or use the `-noasmopt' option when you compile GNU CC with itself,
  33412. -     and then again when you compile your program.  (This is a temporary
  33413. -     kludge to turn off assembler optimization on Irix.)  If this
  33414. -     proves to be what you need, edit the assembler spec in the file
  33415. -     `specs' so that it unconditionally passes `-O0' to the assembler,
  33416. -     and never passes `-O2' or `-O3'.
  33417. -
  33418. -
  33419. -File: gcc.info,  Node: External Bugs,  Next: Incompatibilities,  Prev: Interoperation,  Up: Trouble
  33420. -
  33421. -Problems Compiling Certain Programs
  33422. -===================================
  33423. -
  33424. -   Certain programs have problems compiling.
  33425. -
  33426. -   * Parse errors may occur compiling X11 on a Decstation running
  33427. -     Ultrix 4.2 because of problems in DEC's versions of the X11 header
  33428. -     files `X11/Xlib.h' and `X11/Xutil.h'.  People recommend adding
  33429. -     `-I/usr/include/mit' to use the MIT versions of the header files,
  33430. -     using the `-traditional' switch to turn off ANSI C, or fixing the
  33431. -     header files by adding this:
  33432. -
  33433. -          #ifdef __STDC__
  33434. -          #define NeedFunctionPrototypes 0
  33435. -          #endif
  33436. -
  33437. -   * If you have trouble compiling Perl on a SunOS 4 system, it may be
  33438. -     because Perl specifies `-I/usr/ucbinclude'.  This accesses the
  33439. -     unfixed header files.  Perl specifies the options
  33440. -
  33441. -          -traditional -Dvolatile=__volatile__
  33442. -          -I/usr/include/sun -I/usr/ucbinclude
  33443. -          -fpcc-struct-return
  33444. -
  33445. -     most of which are unnecessary with GCC 2.4.5 and newer versions.
  33446. -     You can make a properly working Perl by setting `ccflags' to
  33447. -     `-fwritable-strings' (implied by the `-traditional' in the
  33448. -     original options) and `cppflags' to empty in `config.sh', then
  33449. -     typing `./doSH; make depend; make'.
  33450. -
  33451. -   * On various 386 Unix systems derived from System V, including SCO,
  33452. -     ISC, and ESIX, you may get error messages about running out of
  33453. -     virtual memory while compiling certain programs.
  33454. -
  33455. -     You can prevent this problem by linking GNU CC with the GNU malloc
  33456. -     (which thus replaces the malloc that comes with the system).  GNU
  33457. -     malloc is available as a separate package, and also in the file
  33458. -     `src/gmalloc.c' in the GNU Emacs 19 distribution.
  33459. -
  33460. -     If you have installed GNU malloc as a separate library package,
  33461. -     use this option when you relink GNU CC:
  33462. -
  33463. -          MALLOC=/usr/local/lib/libgmalloc.a
  33464. -
  33465. -     Alternatively, if you have compiled `gmalloc.c' from Emacs 19, copy
  33466. -     the object file to `gmalloc.o' and use this option when you relink
  33467. -     GNU CC:
  33468. -
  33469. -          MALLOC=gmalloc.o
  33470. -
  33471. -
  33472. -File: gcc.info,  Node: Incompatibilities,  Next: Fixed Headers,  Prev: External Bugs,  Up: Trouble
  33473. -
  33474. -Incompatibilities of GNU CC
  33475. -===========================
  33476. -
  33477. -   There are several noteworthy incompatibilities between GNU C and most
  33478. -existing (non-ANSI) versions of C.  The `-traditional' option
  33479. -eliminates many of these incompatibilities, *but not all*, by telling
  33480. -GNU C to behave like the other C compilers.
  33481. -
  33482. -   * GNU CC normally makes string constants read-only.  If several
  33483. -     identical-looking string constants are used, GNU CC stores only one
  33484. -     copy of the string.
  33485. -
  33486. -     One consequence is that you cannot call `mktemp' with a string
  33487. -     constant argument.  The function `mktemp' always alters the string
  33488. -     its argument points to.
  33489. -
  33490. -     Another consequence is that `sscanf' does not work on some systems
  33491. -     when passed a string constant as its format control string or
  33492. -     input.  This is because `sscanf' incorrectly tries to write into
  33493. -     the string constant.  Likewise `fscanf' and `scanf'.
  33494. -
  33495. -     The best solution to these problems is to change the program to use
  33496. -     `char'-array variables with initialization strings for these
  33497. -     purposes instead of string constants.  But if this is not possible,
  33498. -     you can use the `-fwritable-strings' flag, which directs GNU CC to
  33499. -     handle string constants the same way most C compilers do.
  33500. -     `-traditional' also has this effect, among others.
  33501. -
  33502. -   * `-2147483648' is positive.
  33503. -
  33504. -     This is because 2147483648 cannot fit in the type `int', so
  33505. -     (following the ANSI C rules) its data type is `unsigned long int'.
  33506. -     Negating this value yields 2147483648 again.
  33507. -
  33508. -   * GNU CC does not substitute macro arguments when they appear inside
  33509. -     of string constants.  For example, the following macro in GNU CC
  33510. -
  33511. -          #define foo(a) "a"
  33512. -
  33513. -     will produce output `"a"' regardless of what the argument A is.
  33514. -
  33515. -     The `-traditional' option directs GNU CC to handle such cases
  33516. -     (among others) in the old-fashioned (non-ANSI) fashion.
  33517. -
  33518. -   * When you use `setjmp' and `longjmp', the only automatic variables
  33519. -     guaranteed to remain valid are those declared `volatile'.  This is
  33520. -     a consequence of automatic register allocation.  Consider this
  33521. -     function:
  33522. -
  33523. -          jmp_buf j;
  33524. -          
  33525. -          foo ()
  33526. -          {
  33527. -            int a, b;
  33528. -          
  33529. -            a = fun1 ();
  33530. -            if (setjmp (j))
  33531. -              return a;
  33532. -          
  33533. -            a = fun2 ();
  33534. -            /* `longjmp (j)' may occur in `fun3'. */
  33535. -            return a + fun3 ();
  33536. -          }
  33537. -
  33538. -     Here `a' may or may not be restored to its first value when the
  33539. -     `longjmp' occurs.  If `a' is allocated in a register, then its
  33540. -     first value is restored; otherwise, it keeps the last value stored
  33541. -     in it.
  33542. -
  33543. -     If you use the `-W' option with the `-O' option, you will get a
  33544. -     warning when GNU CC thinks such a problem might be possible.
  33545. -
  33546. -     The `-traditional' option directs GNU C to put variables in the
  33547. -     stack by default, rather than in registers, in functions that call
  33548. -     `setjmp'.  This results in the behavior found in traditional C
  33549. -     compilers.
  33550. -
  33551. -   * Programs that use preprocessing directives in the middle of macro
  33552. -     arguments do not work with GNU CC.  For example, a program like
  33553. -     this will not work:
  33554. -
  33555. -          foobar (
  33556. -          #define luser
  33557. -                  hack)
  33558. -
  33559. -     ANSI C does not permit such a construct.  It would make sense to
  33560. -     support it when `-traditional' is used, but it is too much work to
  33561. -     implement.
  33562. -
  33563. -   * Declarations of external variables and functions within a block
  33564. -     apply only to the block containing the declaration.  In other
  33565. -     words, they have the same scope as any other declaration in the
  33566. -     same place.
  33567. -
  33568. -     In some other C compilers, a `extern' declaration affects all the
  33569. -     rest of the file even if it happens within a block.
  33570. -
  33571. -     The `-traditional' option directs GNU C to treat all `extern'
  33572. -     declarations as global, like traditional compilers.
  33573. -
  33574. -   * In traditional C, you can combine `long', etc., with a typedef
  33575. -     name, as shown here:
  33576. -
  33577. -          typedef int foo;
  33578. -          typedef long foo bar;
  33579. -
  33580. -     In ANSI C, this is not allowed: `long' and other type modifiers
  33581. -     require an explicit `int'.  Because this criterion is expressed by
  33582. -     Bison grammar rules rather than C code, the `-traditional' flag
  33583. -     cannot alter it.
  33584. -
  33585. -   * PCC allows typedef names to be used as function parameters.  The
  33586. -     difficulty described immediately above applies here too.
  33587. -
  33588. -   * PCC allows whitespace in the middle of compound assignment
  33589. -     operators such as `+='.  GNU CC, following the ANSI standard, does
  33590. -     not allow this.  The difficulty described immediately above
  33591. -     applies here too.
  33592. -
  33593. -   * GNU CC complains about unterminated character constants inside of
  33594. -     preprocessing conditionals that fail.  Some programs have English
  33595. -     comments enclosed in conditionals that are guaranteed to fail; if
  33596. -     these comments contain apostrophes, GNU CC will probably report an
  33597. -     error.  For example, this code would produce an error:
  33598. -
  33599. -          #if 0
  33600. -          You can't expect this to work.
  33601. -          #endif
  33602. -
  33603. -     The best solution to such a problem is to put the text into an
  33604. -     actual C comment delimited by `/*...*/'.  However, `-traditional'
  33605. -     suppresses these error messages.
  33606. -
  33607. -   * Many user programs contain the declaration `long time ();'.  In the
  33608. -     past, the system header files on many systems did not actually
  33609. -     declare `time', so it did not matter what type your program
  33610. -     declared it to return.  But in systems with ANSI C headers, `time'
  33611. -     is declared to return `time_t', and if that is not the same as
  33612. -     `long', then `long time ();' is erroneous.
  33613. -
  33614. -     The solution is to change your program to use `time_t' as the
  33615. -     return type of `time'.
  33616. -
  33617. -   * When compiling functions that return `float', PCC converts it to a
  33618. -     double.  GNU CC actually returns a `float'.  If you are concerned
  33619. -     with PCC compatibility, you should declare your functions to return
  33620. -     `double'; you might as well say what you mean.
  33621. -
  33622. -   * When compiling functions that return structures or unions, GNU CC
  33623. -     output code normally uses a method different from that used on most
  33624. -     versions of Unix.  As a result, code compiled with GNU CC cannot
  33625. -     call a structure-returning function compiled with PCC, and vice
  33626. -     versa.
  33627. -
  33628. -     The method used by GNU CC is as follows: a structure or union
  33629. -     which is 1, 2, 4 or 8 bytes long is returned like a scalar.  A
  33630. -     structure or union with any other size is stored into an address
  33631. -     supplied by the caller (usually in a special, fixed register, but
  33632. -     on some machines it is passed on the stack).  The
  33633. -     machine-description macros `STRUCT_VALUE' and
  33634. -     `STRUCT_INCOMING_VALUE' tell GNU CC where to pass this address.
  33635. -
  33636. -     By contrast, PCC on most target machines returns structures and
  33637. -     unions of any size by copying the data into an area of static
  33638. -     storage, and then returning the address of that storage as if it
  33639. -     were a pointer value.  The caller must copy the data from that
  33640. -     memory area to the place where the value is wanted.  GNU CC does
  33641. -     not use this method because it is slower and nonreentrant.
  33642. -
  33643. -     On some newer machines, PCC uses a reentrant convention for all
  33644. -     structure and union returning.  GNU CC on most of these machines
  33645. -     uses a compatible convention when returning structures and unions
  33646. -     in memory, but still returns small structures and unions in
  33647. -     registers.
  33648. -
  33649. -     You can tell GNU CC to use a compatible convention for all
  33650. -     structure and union returning with the option
  33651. -     `-fpcc-struct-return'.
  33652. -
  33653. -   * GNU C complains about program fragments such as `0x74ae-0x4000'
  33654. -     which appear to be two hexadecimal constants separated by the minus
  33655. -     operator.  Actually, this string is a single "preprocessing token".
  33656. -     Each such token must correspond to one token in C.  Since this
  33657. -     does not, GNU C prints an error message.  Although it may appear
  33658. -     obvious that what is meant is an operator and two values, the ANSI
  33659. -     C standard specifically requires that this be treated as erroneous.
  33660. -
  33661. -     A "preprocessing token" is a "preprocessing number" if it begins
  33662. -     with a digit and is followed by letters, underscores, digits,
  33663. -     periods and `e+', `e-', `E+', or `E-' character sequences.
  33664. -
  33665. -     To make the above program fragment valid, place whitespace in
  33666. -     front of the minus sign.  This whitespace will end the
  33667. -     preprocessing number.
  33668. -
  33669. -
  33670. -File: gcc.info,  Node: Fixed Headers,  Next: Standard Libraries,  Prev: Incompatibilities,  Up: Trouble
  33671. -
  33672. -Fixed Header Files
  33673. -==================
  33674. -
  33675. -   GNU CC needs to install corrected versions of some system header
  33676. -files.  This is because most target systems have some header files that
  33677. -won't work with GNU CC unless they are changed.  Some have bugs, some
  33678. -are incompatible with ANSI C, and some depend on special features of
  33679. -other compilers.
  33680. -
  33681. -   Installing GNU CC automatically creates and installs the fixed header
  33682. -files, by running a program called `fixincludes' (or for certain
  33683. -targets an alternative such as `fixinc.svr4').  Normally, you don't
  33684. -need to pay attention to this.  But there are cases where it doesn't do
  33685. -the right thing automatically.
  33686. -
  33687. -   * If you update the system's header files, such as by installing a
  33688. -     new system version, the fixed header files of GNU CC are not
  33689. -     automatically updated.  The easiest way to update them is to
  33690. -     reinstall GNU CC.  (If you want to be clever, look in the makefile
  33691. -     and you can find a shortcut.)
  33692. -
  33693. -   * On some systems, in particular SunOS 4, header file directories
  33694. -     contain machine-specific symbolic links in certain places.  This
  33695. -     makes it possible to share most of the header files among hosts
  33696. -     running the same version of SunOS 4 on different machine models.
  33697. -
  33698. -     The programs that fix the header files do not understand this
  33699. -     special way of using symbolic links; therefore, the directory of
  33700. -     fixed header files is good only for the machine model used to
  33701. -     build it.
  33702. -
  33703. -     In SunOS 4, only programs that look inside the kernel will notice
  33704. -     the difference between machine models.  Therefore, for most
  33705. -     purposes, you need not be concerned about this.
  33706. -
  33707. -     It is possible to make separate sets of fixed header files for the
  33708. -     different machine models, and arrange a structure of symbolic
  33709. -     links so as to use the proper set, but you'll have to do this by
  33710. -     hand.
  33711. -
  33712. -   * On Lynxos, GNU CC by default does not fix the header files.  This
  33713. -     is because bugs in the shell cause the `fixincludes' script to
  33714. -     fail.
  33715. -
  33716. -     This means you will encounter problems due to bugs in the system
  33717. -     header files.  It may be no comfort that they aren't GNU CC's
  33718. -     fault, but it does mean that there's nothing for us to do about
  33719. -     them.
  33720. -
  33721. -
  33722. -File: gcc.info,  Node: Standard Libraries,  Next: Disappointments,  Prev: Fixed Headers,  Up: Trouble
  33723. -
  33724. -Standard Libraries
  33725. -==================
  33726. -
  33727. -   GNU CC by itself attempts to be what the ISO/ANSI C standard calls a
  33728. -"conforming freestanding implementation".  This means all ANSI C
  33729. -language features are available, as well as the contents of `float.h',
  33730. -`limits.h', `stdarg.h', and `stddef.h'.  The rest of the C library is
  33731. -supplied by the vendor of the operating system.  If that C library
  33732. -doesn't conform to the C standards, then your programs might get
  33733. -warnings (especially when using `-Wall') that you don't expect.
  33734. -
  33735. -   For example, the `sprintf' function on SunOS 4.1.3 returns `char *'
  33736. -while the C standard says that `sprintf' returns an `int'.  The
  33737. -`fixincludes' program could make the prototype for this function match
  33738. -the Standard, but that would be wrong, since the function will still
  33739. -return `char *'.
  33740. -
  33741. -   If you need a Standard compliant library, then you need to find one,
  33742. -as GNU CC does not provide one.  The GNU C library (called `glibc') has
  33743. -been ported to a number of operating systems, and provides ANSI/ISO,
  33744. -POSIX, BSD and SystemV compatibility.  You could also ask your operating
  33745. -system vendor if newer libraries are available.
  33746. -
  33747. -
  33748. -File: gcc.info,  Node: Disappointments,  Next: C++ Misunderstandings,  Prev: Standard Libraries,  Up: Trouble
  33749. -
  33750. -Disappointments and Misunderstandings
  33751. -=====================================
  33752. -
  33753. -   These problems are perhaps regrettable, but we don't know any
  33754. -practical way around them.
  33755. -
  33756. -   * Certain local variables aren't recognized by debuggers when you
  33757. -     compile with optimization.
  33758. -
  33759. -     This occurs because sometimes GNU CC optimizes the variable out of
  33760. -     existence.  There is no way to tell the debugger how to compute the
  33761. -     value such a variable "would have had", and it is not clear that
  33762. -     would be desirable anyway.  So GNU CC simply does not mention the
  33763. -     eliminated variable when it writes debugging information.
  33764. -
  33765. -     You have to expect a certain amount of disagreement between the
  33766. -     executable and your source code, when you use optimization.
  33767. -
  33768. -   * Users often think it is a bug when GNU CC reports an error for code
  33769. -     like this:
  33770. -
  33771. -          int foo (struct mumble *);
  33772. -          
  33773. -          struct mumble { ... };
  33774. -          
  33775. -          int foo (struct mumble *x)
  33776. -          { ... }
  33777. -
  33778. -     This code really is erroneous, because the scope of `struct
  33779. -     mumble' in the prototype is limited to the argument list
  33780. -     containing it.  It does not refer to the `struct mumble' defined
  33781. -     with file scope immediately below--they are two unrelated types
  33782. -     with similar names in different scopes.
  33783. -
  33784. -     But in the definition of `foo', the file-scope type is used
  33785. -     because that is available to be inherited.  Thus, the definition
  33786. -     and the prototype do not match, and you get an error.
  33787. -
  33788. -     This behavior may seem silly, but it's what the ANSI standard
  33789. -     specifies.  It is easy enough for you to make your code work by
  33790. -     moving the definition of `struct mumble' above the prototype.
  33791. -     It's not worth being incompatible with ANSI C just to avoid an
  33792. -     error for the example shown above.
  33793. -
  33794. -   * Accesses to bitfields even in volatile objects works by accessing
  33795. -     larger objects, such as a byte or a word.  You cannot rely on what
  33796. -     size of object is accessed in order to read or write the bitfield;
  33797. -     it may even vary for a given bitfield according to the precise
  33798. -     usage.
  33799. -
  33800. -     If you care about controlling the amount of memory that is
  33801. -     accessed, use volatile but do not use bitfields.
  33802. -
  33803. -   * GNU CC comes with shell scripts to fix certain known problems in
  33804. -     system header files.  They install corrected copies of various
  33805. -     header files in a special directory where only GNU CC will
  33806. -     normally look for them.  The scripts adapt to various systems by
  33807. -     searching all the system header files for the problem cases that
  33808. -     we know about.
  33809. -
  33810. -     If new system header files are installed, nothing automatically
  33811. -     arranges to update the corrected header files.  You will have to
  33812. -     reinstall GNU CC to fix the new header files.  More specifically,
  33813. -     go to the build directory and delete the files `stmp-fixinc' and
  33814. -     `stmp-headers', and the subdirectory `include'; then do `make
  33815. -     install' again.
  33816. -
  33817. -   * On 68000 systems, you can get paradoxical results if you test the
  33818. -     precise values of floating point numbers.  For example, you can
  33819. -     find that a floating point value which is not a NaN is not equal
  33820. -     to itself.  This results from the fact that the the floating point
  33821. -     registers hold a few more bits of precision than fit in a `double'
  33822. -     in memory.  Compiled code moves values between memory and floating
  33823. -     point registers at its convenience, and moving them into memory
  33824. -     truncates them.
  33825. -
  33826. -     You can partially avoid this problem by using the `-ffloat-store'
  33827. -     option (*note Optimize Options::.).
  33828. -
  33829. -   * On the MIPS, variable argument functions using `varargs.h' cannot
  33830. -     have a floating point value for the first argument.  The reason
  33831. -     for this is that in the absence of a prototype in scope, if the
  33832. -     first argument is a floating point, it is passed in a floating
  33833. -     point register, rather than an integer register.
  33834. -
  33835. -     If the code is rewritten to use the ANSI standard `stdarg.h'
  33836. -     method of variable arguments, and the prototype is in scope at the
  33837. -     time of the call, everything will work fine.
  33838. -
  33839. -
  33840. -File: gcc.info,  Node: C++ Misunderstandings,  Next: Protoize Caveats,  Prev: Disappointments,  Up: Trouble
  33841. -
  33842. -Common Misunderstandings with GNU C++
  33843. -=====================================
  33844. -
  33845. -   C++ is a complex language and an evolving one, and its standard
  33846. -definition (the ANSI C++ draft standard) is also evolving.  As a result,
  33847. -your C++ compiler may occasionally surprise you, even when its behavior
  33848. -is correct.  This section discusses some areas that frequently give
  33849. -rise to questions of this sort.
  33850. -
  33851. -* Menu:
  33852. -
  33853. -* Static Definitions::  Static member declarations are not definitions
  33854. -* Temporaries::         Temporaries may vanish before you expect
  33855. -
  33856. -
  33857. -File: gcc.info,  Node: Static Definitions,  Next: Temporaries,  Up: C++ Misunderstandings
  33858. -
  33859. -Declare *and* Define Static Members
  33860. ------------------------------------
  33861. -
  33862. -   When a class has static data members, it is not enough to *declare*
  33863. -the static member; you must also *define* it.  For example:
  33864. -
  33865. -     class Foo
  33866. -     {
  33867. -       ...
  33868. -       void method();
  33869. -       static int bar;
  33870. -     };
  33871. -
  33872. -   This declaration only establishes that the class `Foo' has an `int'
  33873. -named `Foo::bar', and a member function named `Foo::method'.  But you
  33874. -still need to define *both* `method' and `bar' elsewhere.  According to
  33875. -the draft ANSI standard, you must supply an initializer in one (and
  33876. -only one) source file, such as:
  33877. -
  33878. -     int Foo::bar = 0;
  33879. -
  33880. -   Other C++ compilers may not correctly implement the standard
  33881. -behavior.  As a result, when you switch to `g++' from one of these
  33882. -compilers, you may discover that a program that appeared to work
  33883. -correctly in fact does not conform to the standard: `g++' reports as
  33884. -undefined symbols any static data members that lack definitions.
  33885. -
  33886. diff -rup --new-file baseline/fsf/gcc/gcc.info-12 amiga/fsf/gcc/gcc.info-12
  33887. --- baseline/fsf/gcc/gcc.info-12    Sat Jun 29 09:38:02 1996
  33888. +++ amiga/fsf/gcc/gcc.info-12    Wed Dec 31 17:00:00 1969
  33889. @@ -1,1110 +0,0 @@
  33890. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  33891. -file gcc.texi.
  33892. -
  33893. -   This file documents the use and the internals of the GNU compiler.
  33894. -
  33895. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  33896. -Boston, MA 02111-1307 USA
  33897. -
  33898. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  33899. -Foundation, Inc.
  33900. -
  33901. -   Permission is granted to make and distribute verbatim copies of this
  33902. -manual provided the copyright notice and this permission notice are
  33903. -preserved on all copies.
  33904. -
  33905. -   Permission is granted to copy and distribute modified versions of
  33906. -this manual under the conditions for verbatim copying, provided also
  33907. -that the sections entitled "GNU General Public License," "Funding for
  33908. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  33909. -included exactly as in the original, and provided that the entire
  33910. -resulting derived work is distributed under the terms of a permission
  33911. -notice identical to this one.
  33912. -
  33913. -   Permission is granted to copy and distribute translations of this
  33914. -manual into another language, under the above conditions for modified
  33915. -versions, except that the sections entitled "GNU General Public
  33916. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  33917. -`Look And Feel'", and this permission notice, may be included in
  33918. -translations approved by the Free Software Foundation instead of in the
  33919. -original English.
  33920. -
  33921. -
  33922. -File: gcc.info,  Node: Temporaries,  Prev: Static Definitions,  Up: C++ Misunderstandings
  33923. -
  33924. -Temporaries May Vanish Before You Expect
  33925. -----------------------------------------
  33926. -
  33927. -   It is dangerous to use pointers or references to *portions* of a
  33928. -temporary object.  The compiler may very well delete the object before
  33929. -you expect it to, leaving a pointer to garbage.  The most common place
  33930. -where this problem crops up is in classes like the libg++ `String'
  33931. -class, that define a conversion function to type `char *' or `const
  33932. -char *'.  However, any class that returns a pointer to some internal
  33933. -structure is potentially subject to this problem.
  33934. -
  33935. -   For example, a program may use a function `strfunc' that returns
  33936. -`String' objects, and another function `charfunc' that operates on
  33937. -pointers to `char':
  33938. -
  33939. -     String strfunc ();
  33940. -     void charfunc (const char *);
  33941. -
  33942. -In this situation, it may seem natural to write
  33943. -`charfunc (strfunc ());' based on the knowledge that class `String' has
  33944. -an explicit conversion to `char' pointers.  However, what really
  33945. -happens is akin to `charfunc (strfunc ().convert ());', where the
  33946. -`convert' method is a function to do the same data conversion normally
  33947. -performed by a cast.  Since the last use of the temporary `String'
  33948. -object is the call to the conversion function, the compiler may delete
  33949. -that object before actually calling `charfunc'.  The compiler has no
  33950. -way of knowing that deleting the `String' object will invalidate the
  33951. -pointer.  The pointer then points to garbage, so that by the time
  33952. -`charfunc' is called, it gets an invalid argument.
  33953. -
  33954. -   Code like this may run successfully under some other compilers,
  33955. -especially those that delete temporaries relatively late.  However, the
  33956. -GNU C++ behavior is also standard-conforming, so if your program depends
  33957. -on late destruction of temporaries it is not portable.
  33958. -
  33959. -   If you think this is surprising, you should be aware that the ANSI
  33960. -C++ committee continues to debate the lifetime-of-temporaries problem.
  33961. -
  33962. -   For now, at least, the safe way to write such code is to give the
  33963. -temporary a name, which forces it to remain until the end of the scope
  33964. -of the name.  For example:
  33965. -
  33966. -     String& tmp = strfunc ();
  33967. -     charfunc (tmp);
  33968. -
  33969. -
  33970. -File: gcc.info,  Node: Protoize Caveats,  Next: Non-bugs,  Prev: C++ Misunderstandings,  Up: Trouble
  33971. -
  33972. -Caveats of using `protoize'
  33973. -===========================
  33974. -
  33975. -   The conversion programs `protoize' and `unprotoize' can sometimes
  33976. -change a source file in a way that won't work unless you rearrange it.
  33977. -
  33978. -   * `protoize' can insert references to a type name or type tag before
  33979. -     the definition, or in a file where they are not defined.
  33980. -
  33981. -     If this happens, compiler error messages should show you where the
  33982. -     new references are, so fixing the file by hand is straightforward.
  33983. -
  33984. -   * There are some C constructs which `protoize' cannot figure out.
  33985. -     For example, it can't determine argument types for declaring a
  33986. -     pointer-to-function variable; this you must do by hand.  `protoize'
  33987. -     inserts a comment containing `???' each time it finds such a
  33988. -     variable; so you can find all such variables by searching for this
  33989. -     string.  ANSI C does not require declaring the argument types of
  33990. -     pointer-to-function types.
  33991. -
  33992. -   * Using `unprotoize' can easily introduce bugs.  If the program
  33993. -     relied on prototypes to bring about conversion of arguments, these
  33994. -     conversions will not take place in the program without prototypes.
  33995. -     One case in which you can be sure `unprotoize' is safe is when you
  33996. -     are removing prototypes that were made with `protoize'; if the
  33997. -     program worked before without any prototypes, it will work again
  33998. -     without them.
  33999. -
  34000. -     You can find all the places where this problem might occur by
  34001. -     compiling the program with the `-Wconversion' option.  It prints a
  34002. -     warning whenever an argument is converted.
  34003. -
  34004. -   * Both conversion programs can be confused if there are macro calls
  34005. -     in and around the text to be converted.  In other words, the
  34006. -     standard syntax for a declaration or definition must not result
  34007. -     from expanding a macro.  This problem is inherent in the design of
  34008. -     C and cannot be fixed.  If only a few functions have confusing
  34009. -     macro calls, you can easily convert them manually.
  34010. -
  34011. -   * `protoize' cannot get the argument types for a function whose
  34012. -     definition was not actually compiled due to preprocessing
  34013. -     conditionals.  When this happens, `protoize' changes nothing in
  34014. -     regard to such a function.  `protoize' tries to detect such
  34015. -     instances and warn about them.
  34016. -
  34017. -     You can generally work around this problem by using `protoize' step
  34018. -     by step, each time specifying a different set of `-D' options for
  34019. -     compilation, until all of the functions have been converted.
  34020. -     There is no automatic way to verify that you have got them all,
  34021. -     however.
  34022. -
  34023. -   * Confusion may result if there is an occasion to convert a function
  34024. -     declaration or definition in a region of source code where there
  34025. -     is more than one formal parameter list present.  Thus, attempts to
  34026. -     convert code containing multiple (conditionally compiled) versions
  34027. -     of a single function header (in the same vicinity) may not produce
  34028. -     the desired (or expected) results.
  34029. -
  34030. -     If you plan on converting source files which contain such code, it
  34031. -     is recommended that you first make sure that each conditionally
  34032. -     compiled region of source code which contains an alternative
  34033. -     function header also contains at least one additional follower
  34034. -     token (past the final right parenthesis of the function header).
  34035. -     This should circumvent the problem.
  34036. -
  34037. -   * `unprotoize' can become confused when trying to convert a function
  34038. -     definition or declaration which contains a declaration for a
  34039. -     pointer-to-function formal argument which has the same name as the
  34040. -     function being defined or declared.  We recommand you avoid such
  34041. -     choices of formal parameter names.
  34042. -
  34043. -   * You might also want to correct some of the indentation by hand and
  34044. -     break long lines.  (The conversion programs don't write lines
  34045. -     longer than eighty characters in any case.)
  34046. -
  34047. -
  34048. -File: gcc.info,  Node: Non-bugs,  Next: Warnings and Errors,  Prev: Protoize Caveats,  Up: Trouble
  34049. -
  34050. -Certain Changes We Don't Want to Make
  34051. -=====================================
  34052. -
  34053. -   This section lists changes that people frequently request, but which
  34054. -we do not make because we think GNU CC is better without them.
  34055. -
  34056. -   * Checking the number and type of arguments to a function which has
  34057. -     an old-fashioned definition and no prototype.
  34058. -
  34059. -     Such a feature would work only occasionally--only for calls that
  34060. -     appear in the same file as the called function, following the
  34061. -     definition.  The only way to check all calls reliably is to add a
  34062. -     prototype for the function.  But adding a prototype eliminates the
  34063. -     motivation for this feature.  So the feature is not worthwhile.
  34064. -
  34065. -   * Warning about using an expression whose type is signed as a shift
  34066. -     count.
  34067. -
  34068. -     Shift count operands are probably signed more often than unsigned.
  34069. -     Warning about this would cause far more annoyance than good.
  34070. -
  34071. -   * Warning about assigning a signed value to an unsigned variable.
  34072. -
  34073. -     Such assignments must be very common; warning about them would
  34074. -     cause more annoyance than good.
  34075. -
  34076. -   * Warning about unreachable code.
  34077. -
  34078. -     It's very common to have unreachable code in machine-generated
  34079. -     programs.  For example, this happens normally in some files of GNU
  34080. -     C itself.
  34081. -
  34082. -   * Warning when a non-void function value is ignored.
  34083. -
  34084. -     Coming as I do from a Lisp background, I balk at the idea that
  34085. -     there is something dangerous about discarding a value.  There are
  34086. -     functions that return values which some callers may find useful;
  34087. -     it makes no sense to clutter the program with a cast to `void'
  34088. -     whenever the value isn't useful.
  34089. -
  34090. -   * Assuming (for optimization) that the address of an external symbol
  34091. -     is never zero.
  34092. -
  34093. -     This assumption is false on certain systems when `#pragma weak' is
  34094. -     used.
  34095. -
  34096. -   * Making `-fshort-enums' the default.
  34097. -
  34098. -     This would cause storage layout to be incompatible with most other
  34099. -     C compilers.  And it doesn't seem very important, given that you
  34100. -     can get the same result in other ways.  The case where it matters
  34101. -     most is when the enumeration-valued object is inside a structure,
  34102. -     and in that case you can specify a field width explicitly.
  34103. -
  34104. -   * Making bitfields unsigned by default on particular machines where
  34105. -     "the ABI standard" says to do so.
  34106. -
  34107. -     The ANSI C standard leaves it up to the implementation whether a
  34108. -     bitfield declared plain `int' is signed or not.  This in effect
  34109. -     creates two alternative dialects of C.
  34110. -
  34111. -     The GNU C compiler supports both dialects; you can specify the
  34112. -     signed dialect with `-fsigned-bitfields' and the unsigned dialect
  34113. -     with `-funsigned-bitfields'.  However, this leaves open the
  34114. -     question of which dialect to use by default.
  34115. -
  34116. -     Currently, the preferred dialect makes plain bitfields signed,
  34117. -     because this is simplest.  Since `int' is the same as `signed int'
  34118. -     in every other context, it is cleanest for them to be the same in
  34119. -     bitfields as well.
  34120. -
  34121. -     Some computer manufacturers have published Application Binary
  34122. -     Interface standards which specify that plain bitfields should be
  34123. -     unsigned.  It is a mistake, however, to say anything about this
  34124. -     issue in an ABI.  This is because the handling of plain bitfields
  34125. -     distinguishes two dialects of C.  Both dialects are meaningful on
  34126. -     every type of machine.  Whether a particular object file was
  34127. -     compiled using signed bitfields or unsigned is of no concern to
  34128. -     other object files, even if they access the same bitfields in the
  34129. -     same data structures.
  34130. -
  34131. -     A given program is written in one or the other of these two
  34132. -     dialects.  The program stands a chance to work on most any machine
  34133. -     if it is compiled with the proper dialect.  It is unlikely to work
  34134. -     at all if compiled with the wrong dialect.
  34135. -
  34136. -     Many users appreciate the GNU C compiler because it provides an
  34137. -     environment that is uniform across machines.  These users would be
  34138. -     inconvenienced if the compiler treated plain bitfields differently
  34139. -     on certain machines.
  34140. -
  34141. -     Occasionally users write programs intended only for a particular
  34142. -     machine type.  On these occasions, the users would benefit if the
  34143. -     GNU C compiler were to support by default the same dialect as the
  34144. -     other compilers on that machine.  But such applications are rare.
  34145. -     And users writing a program to run on more than one type of
  34146. -     machine cannot possibly benefit from this kind of compatibility.
  34147. -
  34148. -     This is why GNU CC does and will treat plain bitfields in the same
  34149. -     fashion on all types of machines (by default).
  34150. -
  34151. -     There are some arguments for making bitfields unsigned by default
  34152. -     on all machines.  If, for example, this becomes a universal de
  34153. -     facto standard, it would make sense for GNU CC to go along with
  34154. -     it.  This is something to be considered in the future.
  34155. -
  34156. -     (Of course, users strongly concerned about portability should
  34157. -     indicate explicitly in each bitfield whether it is signed or not.
  34158. -     In this way, they write programs which have the same meaning in
  34159. -     both C dialects.)
  34160. -
  34161. -   * Undefining `__STDC__' when `-ansi' is not used.
  34162. -
  34163. -     Currently, GNU CC defines `__STDC__' as long as you don't use
  34164. -     `-traditional'.  This provides good results in practice.
  34165. -
  34166. -     Programmers normally use conditionals on `__STDC__' to ask whether
  34167. -     it is safe to use certain features of ANSI C, such as function
  34168. -     prototypes or ANSI token concatenation.  Since plain `gcc' supports
  34169. -     all the features of ANSI C, the correct answer to these questions
  34170. -     is "yes".
  34171. -
  34172. -     Some users try to use `__STDC__' to check for the availability of
  34173. -     certain library facilities.  This is actually incorrect usage in
  34174. -     an ANSI C program, because the ANSI C standard says that a
  34175. -     conforming freestanding implementation should define `__STDC__'
  34176. -     even though it does not have the library facilities.  `gcc -ansi
  34177. -     -pedantic' is a conforming freestanding implementation, and it is
  34178. -     therefore required to define `__STDC__', even though it does not
  34179. -     come with an ANSI C library.
  34180. -
  34181. -     Sometimes people say that defining `__STDC__' in a compiler that
  34182. -     does not completely conform to the ANSI C standard somehow
  34183. -     violates the standard.  This is illogical.  The standard is a
  34184. -     standard for compilers that claim to support ANSI C, such as `gcc
  34185. -     -ansi'--not for other compilers such as plain `gcc'.  Whatever the
  34186. -     ANSI C standard says is relevant to the design of plain `gcc'
  34187. -     without `-ansi' only for pragmatic reasons, not as a requirement.
  34188. -
  34189. -   * Undefining `__STDC__' in C++.
  34190. -
  34191. -     Programs written to compile with C++-to-C translators get the
  34192. -     value of `__STDC__' that goes with the C compiler that is
  34193. -     subsequently used.  These programs must test `__STDC__' to
  34194. -     determine what kind of C preprocessor that compiler uses: whether
  34195. -     they should concatenate tokens in the ANSI C fashion or in the
  34196. -     traditional fashion.
  34197. -
  34198. -     These programs work properly with GNU C++ if `__STDC__' is defined.
  34199. -     They would not work otherwise.
  34200. -
  34201. -     In addition, many header files are written to provide prototypes
  34202. -     in ANSI C but not in traditional C.  Many of these header files
  34203. -     can work without change in C++ provided `__STDC__' is defined.  If
  34204. -     `__STDC__' is not defined, they will all fail, and will all need
  34205. -     to be changed to test explicitly for C++ as well.
  34206. -
  34207. -   * Deleting "empty" loops.
  34208. -
  34209. -     GNU CC does not delete "empty" loops because the most likely reason
  34210. -     you would put one in a program is to have a delay.  Deleting them
  34211. -     will not make real programs run any faster, so it would be
  34212. -     pointless.
  34213. -
  34214. -     It would be different if optimization of a nonempty loop could
  34215. -     produce an empty one.  But this generally can't happen.
  34216. -
  34217. -   * Making side effects happen in the same order as in some other
  34218. -     compiler.
  34219. -
  34220. -     It is never safe to depend on the order of evaluation of side
  34221. -     effects.  For example, a function call like this may very well
  34222. -     behave differently from one compiler to another:
  34223. -
  34224. -          void func (int, int);
  34225. -          
  34226. -          int i = 2;
  34227. -          func (i++, i++);
  34228. -
  34229. -     There is no guarantee (in either the C or the C++ standard language
  34230. -     definitions) that the increments will be evaluated in any
  34231. -     particular order.  Either increment might happen first.  `func'
  34232. -     might get the arguments `2, 3', or it might get `3, 2', or even
  34233. -     `2, 2'.
  34234. -
  34235. -   * Not allowing structures with volatile fields in registers.
  34236. -
  34237. -     Strictly speaking, there is no prohibition in the ANSI C standard
  34238. -     against allowing structures with volatile fields in registers, but
  34239. -     it does not seem to make any sense and is probably not what you
  34240. -     wanted to do.  So the compiler will give an error message in this
  34241. -     case.
  34242. -
  34243. -
  34244. -File: gcc.info,  Node: Warnings and Errors,  Prev: Non-bugs,  Up: Trouble
  34245. -
  34246. -Warning Messages and Error Messages
  34247. -===================================
  34248. -
  34249. -   The GNU compiler can produce two kinds of diagnostics: errors and
  34250. -warnings.  Each kind has a different purpose:
  34251. -
  34252. -     *Errors* report problems that make it impossible to compile your
  34253. -     program.  GNU CC reports errors with the source file name and line
  34254. -     number where the problem is apparent.
  34255. -
  34256. -     *Warnings* report other unusual conditions in your code that *may*
  34257. -     indicate a problem, although compilation can (and does) proceed.
  34258. -     Warning messages also report the source file name and line number,
  34259. -     but include the text `warning:' to distinguish them from error
  34260. -     messages.
  34261. -
  34262. -   Warnings may indicate danger points where you should check to make
  34263. -sure that your program really does what you intend; or the use of
  34264. -obsolete features; or the use of nonstandard features of GNU C or C++.
  34265. -Many warnings are issued only if you ask for them, with one of the `-W'
  34266. -options (for instance, `-Wall' requests a variety of useful warnings).
  34267. -
  34268. -   GNU CC always tries to compile your program if possible; it never
  34269. -gratuitously rejects a program whose meaning is clear merely because
  34270. -(for instance) it fails to conform to a standard.  In some cases,
  34271. -however, the C and C++ standards specify that certain extensions are
  34272. -forbidden, and a diagnostic *must* be issued by a conforming compiler.
  34273. -The `-pedantic' option tells GNU CC to issue warnings in such cases;
  34274. -`-pedantic-errors' says to make them errors instead.  This does not
  34275. -mean that *all* non-ANSI constructs get warnings or errors.
  34276. -
  34277. -   *Note Options to Request or Suppress Warnings: Warning Options, for
  34278. -more detail on these and related command-line options.
  34279. -
  34280. -
  34281. -File: gcc.info,  Node: Bugs,  Next: Service,  Prev: Trouble,  Up: Top
  34282. -
  34283. -Reporting Bugs
  34284. -**************
  34285. -
  34286. -   Your bug reports play an essential role in making GNU CC reliable.
  34287. -
  34288. -   When you encounter a problem, the first thing to do is to see if it
  34289. -is already known.  *Note Trouble::.  If it isn't known, then you should
  34290. -report the problem.
  34291. -
  34292. -   Reporting a bug may help you by bringing a solution to your problem,
  34293. -or it may not.  (If it does not, look in the service directory; see
  34294. -*Note Service::.)  In any case, the principal function of a bug report
  34295. -is to help the entire community by making the next version of GNU CC
  34296. -work better.  Bug reports are your contribution to the maintenance of
  34297. -GNU CC.
  34298. -
  34299. -   Since the maintainers are very overloaded, we cannot respond to every
  34300. -bug report.  However, if the bug has not been fixed, we are likely to
  34301. -send you a patch and ask you to tell us whether it works.
  34302. -
  34303. -   In order for a bug report to serve its purpose, you must include the
  34304. -information that makes for fixing the bug.
  34305. -
  34306. -* Menu:
  34307. -
  34308. -* Criteria:  Bug Criteria.   Have you really found a bug?
  34309. -* Where: Bug Lists.         Where to send your bug report.
  34310. -* Reporting: Bug Reporting.  How to report a bug effectively.
  34311. -* Patches: Sending Patches.  How to send a patch for GNU CC.
  34312. -* Known: Trouble.            Known problems.
  34313. -* Help: Service.             Where to ask for help.
  34314. -
  34315. -
  34316. -File: gcc.info,  Node: Bug Criteria,  Next: Bug Lists,  Up: Bugs
  34317. -
  34318. -Have You Found a Bug?
  34319. -=====================
  34320. -
  34321. -   If you are not sure whether you have found a bug, here are some
  34322. -guidelines:
  34323. -
  34324. -   * If the compiler gets a fatal signal, for any input whatever, that
  34325. -     is a compiler bug.  Reliable compilers never crash.
  34326. -
  34327. -   * If the compiler produces invalid assembly code, for any input
  34328. -     whatever (except an `asm' statement), that is a compiler bug,
  34329. -     unless the compiler reports errors (not just warnings) which would
  34330. -     ordinarily prevent the assembler from being run.
  34331. -
  34332. -   * If the compiler produces valid assembly code that does not
  34333. -     correctly execute the input source code, that is a compiler bug.
  34334. -
  34335. -     However, you must double-check to make sure, because you may have
  34336. -     run into an incompatibility between GNU C and traditional C (*note
  34337. -     Incompatibilities::.).  These incompatibilities might be considered
  34338. -     bugs, but they are inescapable consequences of valuable features.
  34339. -
  34340. -     Or you may have a program whose behavior is undefined, which
  34341. -     happened by chance to give the desired results with another C or
  34342. -     C++ compiler.
  34343. -
  34344. -     For example, in many nonoptimizing compilers, you can write `x;'
  34345. -     at the end of a function instead of `return x;', with the same
  34346. -     results.  But the value of the function is undefined if `return'
  34347. -     is omitted; it is not a bug when GNU CC produces different results.
  34348. -
  34349. -     Problems often result from expressions with two increment
  34350. -     operators, as in `f (*p++, *p++)'.  Your previous compiler might
  34351. -     have interpreted that expression the way you intended; GNU CC might
  34352. -     interpret it another way.  Neither compiler is wrong.  The bug is
  34353. -     in your code.
  34354. -
  34355. -     After you have localized the error to a single source line, it
  34356. -     should be easy to check for these things.  If your program is
  34357. -     correct and well defined, you have found a compiler bug.
  34358. -
  34359. -   * If the compiler produces an error message for valid input, that is
  34360. -     a compiler bug.
  34361. -
  34362. -   * If the compiler does not produce an error message for invalid
  34363. -     input, that is a compiler bug.  However, you should note that your
  34364. -     idea of "invalid input" might be my idea of "an extension" or
  34365. -     "support for traditional practice".
  34366. -
  34367. -   * If you are an experienced user of C or C++ compilers, your
  34368. -     suggestions for improvement of GNU CC or GNU C++ are welcome in
  34369. -     any case.
  34370. -
  34371. -
  34372. -File: gcc.info,  Node: Bug Lists,  Next: Bug Reporting,  Prev: Bug Criteria,  Up: Bugs
  34373. -
  34374. -Where to Report Bugs
  34375. -====================
  34376. -
  34377. -   Send bug reports for GNU C to `bug-gcc@prep.ai.mit.edu'.
  34378. -
  34379. -   Send bug reports for GNU C++ to `bug-g++@prep.ai.mit.edu'.  If your
  34380. -bug involves the C++ class library libg++, send mail to
  34381. -`bug-lib-g++@prep.ai.mit.edu'.  If you're not sure, you can send the
  34382. -bug report to both lists.
  34383. -
  34384. -   *Do not send bug reports to `help-gcc@prep.ai.mit.edu' or to the
  34385. -newsgroup `gnu.gcc.help'.* Most users of GNU CC do not want to receive
  34386. -bug reports.  Those that do, have asked to be on `bug-gcc' and/or
  34387. -`bug-g++'.
  34388. -
  34389. -   The mailing lists `bug-gcc' and `bug-g++' both have newsgroups which
  34390. -serve as repeaters: `gnu.gcc.bug' and `gnu.g++.bug'.  Each mailing list
  34391. -and its newsgroup carry exactly the same messages.
  34392. -
  34393. -   Often people think of posting bug reports to the newsgroup instead of
  34394. -mailing them.  This appears to work, but it has one problem which can be
  34395. -crucial: a newsgroup posting does not contain a mail path back to the
  34396. -sender.  Thus, if maintainers need more information, they may be unable
  34397. -to reach you.  For this reason, you should always send bug reports by
  34398. -mail to the proper mailing list.
  34399. -
  34400. -   As a last resort, send bug reports on paper to:
  34401. -
  34402. -     GNU Compiler Bugs
  34403. -     Free Software Foundation
  34404. -     59 Temple Place - Suite 330
  34405. -     Boston, MA 02111-1307, USA
  34406. -
  34407. -
  34408. -File: gcc.info,  Node: Bug Reporting,  Next: Sending Patches,  Prev: Bug Lists,  Up: Bugs
  34409. -
  34410. -How to Report Bugs
  34411. -==================
  34412. -
  34413. -   The fundamental principle of reporting bugs usefully is this:
  34414. -*report all the facts*.  If you are not sure whether to state a fact or
  34415. -leave it out, state it!
  34416. -
  34417. -   Often people omit facts because they think they know what causes the
  34418. -problem and they conclude that some details don't matter.  Thus, you
  34419. -might assume that the name of the variable you use in an example does
  34420. -not matter.  Well, probably it doesn't, but one cannot be sure.
  34421. -Perhaps the bug is a stray memory reference which happens to fetch from
  34422. -the location where that name is stored in memory; perhaps, if the name
  34423. -were different, the contents of that location would fool the compiler
  34424. -into doing the right thing despite the bug.  Play it safe and give a
  34425. -specific, complete example.  That is the easiest thing for you to do,
  34426. -and the most helpful.
  34427. -
  34428. -   Keep in mind that the purpose of a bug report is to enable someone to
  34429. -fix the bug if it is not known.  It isn't very important what happens if
  34430. -the bug is already known.  Therefore, always write your bug reports on
  34431. -the assumption that the bug is not known.
  34432. -
  34433. -   Sometimes people give a few sketchy facts and ask, "Does this ring a
  34434. -bell?"  This cannot help us fix a bug, so it is basically useless.  We
  34435. -respond by asking for enough details to enable us to investigate.  You
  34436. -might as well expedite matters by sending them to begin with.
  34437. -
  34438. -   Try to make your bug report self-contained.  If we have to ask you
  34439. -for more information, it is best if you include all the previous
  34440. -information in your response, as well as the information that was
  34441. -missing.
  34442. -
  34443. -   Please report each bug in a separate message.  This makes it easier
  34444. -for us to track which bugs have been fixed and to forward your bugs
  34445. -reports to the appropriate maintainer.
  34446. -
  34447. -   Do not compress and encode any part of your bug report using programs
  34448. -such as `uuencode'.  If you do so it will slow down the processing of
  34449. -your bug.  If you must submit multiple large files, use `shar', which
  34450. -allows us to read your message without having to run any decompression
  34451. -programs.
  34452. -
  34453. -   To enable someone to investigate the bug, you should include all
  34454. -these things:
  34455. -
  34456. -   * The version of GNU CC.  You can get this by running it with the
  34457. -     `-v' option.
  34458. -
  34459. -     Without this, we won't know whether there is any point in looking
  34460. -     for the bug in the current version of GNU CC.
  34461. -
  34462. -   * A complete input file that will reproduce the bug.  If the bug is
  34463. -     in the C preprocessor, send a source file and any header files
  34464. -     that it requires.  If the bug is in the compiler proper (`cc1'),
  34465. -     run your source file through the C preprocessor by doing `gcc -E
  34466. -     SOURCEFILE > OUTFILE', then include the contents of OUTFILE in the
  34467. -     bug report.  (When you do this, use the same `-I', `-D' or `-U'
  34468. -     options that you used in actual compilation.)
  34469. -
  34470. -     A single statement is not enough of an example.  In order to
  34471. -     compile it, it must be embedded in a complete file of compiler
  34472. -     input; and the bug might depend on the details of how this is done.
  34473. -
  34474. -     Without a real example one can compile, all anyone can do about
  34475. -     your bug report is wish you luck.  It would be futile to try to
  34476. -     guess how to provoke the bug.  For example, bugs in register
  34477. -     allocation and reloading frequently depend on every little detail
  34478. -     of the function they happen in.
  34479. -
  34480. -     Even if the input file that fails comes from a GNU program, you
  34481. -     should still send the complete test case.  Don't ask the GNU CC
  34482. -     maintainers to do the extra work of obtaining the program in
  34483. -     question--they are all overworked as it is.  Also, the problem may
  34484. -     depend on what is in the header files on your system; it is
  34485. -     unreliable for the GNU CC maintainers to try the problem with the
  34486. -     header files available to them.  By sending CPP output, you can
  34487. -     eliminate this source of uncertainty and save us a certain
  34488. -     percentage of wild goose chases.
  34489. -
  34490. -   * The command arguments you gave GNU CC or GNU C++ to compile that
  34491. -     example and observe the bug.  For example, did you use `-O'?  To
  34492. -     guarantee you won't omit something important, list all the options.
  34493. -
  34494. -     If we were to try to guess the arguments, we would probably guess
  34495. -     wrong and then we would not encounter the bug.
  34496. -
  34497. -   * The type of machine you are using, and the operating system name
  34498. -     and version number.
  34499. -
  34500. -   * The operands you gave to the `configure' command when you installed
  34501. -     the compiler.
  34502. -
  34503. -   * A complete list of any modifications you have made to the compiler
  34504. -     source.  (We don't promise to investigate the bug unless it
  34505. -     happens in an unmodified compiler.  But if you've made
  34506. -     modifications and don't tell us, then you are sending us on a wild
  34507. -     goose chase.)
  34508. -
  34509. -     Be precise about these changes.  A description in English is not
  34510. -     enough--send a context diff for them.
  34511. -
  34512. -     Adding files of your own (such as a machine description for a
  34513. -     machine we don't support) is a modification of the compiler source.
  34514. -
  34515. -   * Details of any other deviations from the standard procedure for
  34516. -     installing GNU CC.
  34517. -
  34518. -   * A description of what behavior you observe that you believe is
  34519. -     incorrect.  For example, "The compiler gets a fatal signal," or,
  34520. -     "The assembler instruction at line 208 in the output is incorrect."
  34521. -
  34522. -     Of course, if the bug is that the compiler gets a fatal signal,
  34523. -     then one can't miss it.  But if the bug is incorrect output, the
  34524. -     maintainer might not notice unless it is glaringly wrong.  None of
  34525. -     us has time to study all the assembler code from a 50-line C
  34526. -     program just on the chance that one instruction might be wrong.
  34527. -     We need *you* to do this part!
  34528. -
  34529. -     Even if the problem you experience is a fatal signal, you should
  34530. -     still say so explicitly.  Suppose something strange is going on,
  34531. -     such as, your copy of the compiler is out of synch, or you have
  34532. -     encountered a bug in the C library on your system.  (This has
  34533. -     happened!)  Your copy might crash and the copy here would not.  If
  34534. -     you said to expect a crash, then when the compiler here fails to
  34535. -     crash, we would know that the bug was not happening.  If you don't
  34536. -     say to expect a crash, then we would not know whether the bug was
  34537. -     happening.  We would not be able to draw any conclusion from our
  34538. -     observations.
  34539. -
  34540. -     If the problem is a diagnostic when compiling GNU CC with some
  34541. -     other compiler, say whether it is a warning or an error.
  34542. -
  34543. -     Often the observed symptom is incorrect output when your program
  34544. -     is run.  Sad to say, this is not enough information unless the
  34545. -     program is short and simple.  None of us has time to study a large
  34546. -     program to figure out how it would work if compiled correctly,
  34547. -     much less which line of it was compiled wrong.  So you will have
  34548. -     to do that.  Tell us which source line it is, and what incorrect
  34549. -     result happens when that line is executed.  A person who
  34550. -     understands the program can find this as easily as finding a bug
  34551. -     in the program itself.
  34552. -
  34553. -   * If you send examples of assembler code output from GNU CC or GNU
  34554. -     C++, please use `-g' when you make them.  The debugging information
  34555. -     includes source line numbers which are essential for correlating
  34556. -     the output with the input.
  34557. -
  34558. -   * If you wish to mention something in the GNU CC source, refer to it
  34559. -     by context, not by line number.
  34560. -
  34561. -     The line numbers in the development sources don't match those in
  34562. -     your sources.  Your line numbers would convey no useful
  34563. -     information to the maintainers.
  34564. -
  34565. -   * Additional information from a debugger might enable someone to
  34566. -     find a problem on a machine which he does not have available.
  34567. -     However, you need to think when you collect this information if
  34568. -     you want it to have any chance of being useful.
  34569. -
  34570. -     For example, many people send just a backtrace, but that is never
  34571. -     useful by itself.  A simple backtrace with arguments conveys little
  34572. -     about GNU CC because the compiler is largely data-driven; the same
  34573. -     functions are called over and over for different RTL insns, doing
  34574. -     different things depending on the details of the insn.
  34575. -
  34576. -     Most of the arguments listed in the backtrace are useless because
  34577. -     they are pointers to RTL list structure.  The numeric values of the
  34578. -     pointers, which the debugger prints in the backtrace, have no
  34579. -     significance whatever; all that matters is the contents of the
  34580. -     objects they point to (and most of the contents are other such
  34581. -     pointers).
  34582. -
  34583. -     In addition, most compiler passes consist of one or more loops that
  34584. -     scan the RTL insn sequence.  The most vital piece of information
  34585. -     about such a loop--which insn it has reached--is usually in a
  34586. -     local variable, not in an argument.
  34587. -
  34588. -     What you need to provide in addition to a backtrace are the values
  34589. -     of the local variables for several stack frames up.  When a local
  34590. -     variable or an argument is an RTX, first print its value and then
  34591. -     use the GDB command `pr' to print the RTL expression that it points
  34592. -     to.  (If GDB doesn't run on your machine, use your debugger to call
  34593. -     the function `debug_rtx' with the RTX as an argument.)  In
  34594. -     general, whenever a variable is a pointer, its value is no use
  34595. -     without the data it points to.
  34596. -
  34597. -   Here are some things that are not necessary:
  34598. -
  34599. -   * A description of the envelope of the bug.
  34600. -
  34601. -     Often people who encounter a bug spend a lot of time investigating
  34602. -     which changes to the input file will make the bug go away and which
  34603. -     changes will not affect it.
  34604. -
  34605. -     This is often time consuming and not very useful, because the way
  34606. -     we will find the bug is by running a single example under the
  34607. -     debugger with breakpoints, not by pure deduction from a series of
  34608. -     examples.  You might as well save your time for something else.
  34609. -
  34610. -     Of course, if you can find a simpler example to report *instead* of
  34611. -     the original one, that is a convenience.  Errors in the output
  34612. -     will be easier to spot, running under the debugger will take less
  34613. -     time, etc.  Most GNU CC bugs involve just one function, so the
  34614. -     most straightforward way to simplify an example is to delete all
  34615. -     the function definitions except the one where the bug occurs.
  34616. -     Those earlier in the file may be replaced by external declarations
  34617. -     if the crucial function depends on them.  (Exception: inline
  34618. -     functions may affect compilation of functions defined later in the
  34619. -     file.)
  34620. -
  34621. -     However, simplification is not vital; if you don't want to do this,
  34622. -     report the bug anyway and send the entire test case you used.
  34623. -
  34624. -   * In particular, some people insert conditionals `#ifdef BUG' around
  34625. -     a statement which, if removed, makes the bug not happen.  These
  34626. -     are just clutter; we won't pay any attention to them anyway.
  34627. -     Besides, you should send us cpp output, and that can't have
  34628. -     conditionals.
  34629. -
  34630. -   * A patch for the bug.
  34631. -
  34632. -     A patch for the bug is useful if it is a good one.  But don't omit
  34633. -     the necessary information, such as the test case, on the
  34634. -     assumption that a patch is all we need.  We might see problems
  34635. -     with your patch and decide to fix the problem another way, or we
  34636. -     might not understand it at all.
  34637. -
  34638. -     Sometimes with a program as complicated as GNU CC it is very hard
  34639. -     to construct an example that will make the program follow a
  34640. -     certain path through the code.  If you don't send the example, we
  34641. -     won't be able to construct one, so we won't be able to verify that
  34642. -     the bug is fixed.
  34643. -
  34644. -     And if we can't understand what bug you are trying to fix, or why
  34645. -     your patch should be an improvement, we won't install it.  A test
  34646. -     case will help us to understand.
  34647. -
  34648. -     *Note Sending Patches::, for guidelines on how to make it easy for
  34649. -     us to understand and install your patches.
  34650. -
  34651. -   * A guess about what the bug is or what it depends on.
  34652. -
  34653. -     Such guesses are usually wrong.  Even I can't guess right about
  34654. -     such things without first using the debugger to find the facts.
  34655. -
  34656. -   * A core dump file.
  34657. -
  34658. -     We have no way of examining a core dump for your type of machine
  34659. -     unless we have an identical system--and if we do have one, we
  34660. -     should be able to reproduce the crash ourselves.
  34661. -
  34662. -
  34663. -File: gcc.info,  Node: Sending Patches,  Prev: Bug Reporting,  Up: Bugs
  34664. -
  34665. -Sending Patches for GNU CC
  34666. -==========================
  34667. -
  34668. -   If you would like to write bug fixes or improvements for the GNU C
  34669. -compiler, that is very helpful.  Send suggested fixes to the bug report
  34670. -mailing list, `bug-gcc@prep.ai.mit.edu'.
  34671. -
  34672. -   Please follow these guidelines so we can study your patches
  34673. -efficiently.  If you don't follow these guidelines, your information
  34674. -might still be useful, but using it will take extra work.  Maintaining
  34675. -GNU C is a lot of work in the best of circumstances, and we can't keep
  34676. -up unless you do your best to help.
  34677. -
  34678. -   * Send an explanation with your changes of what problem they fix or
  34679. -     what improvement they bring about.  For a bug fix, just include a
  34680. -     copy of the bug report, and explain why the change fixes the bug.
  34681. -
  34682. -     (Referring to a bug report is not as good as including it, because
  34683. -     then we will have to look it up, and we have probably already
  34684. -     deleted it if we've already fixed the bug.)
  34685. -
  34686. -   * Always include a proper bug report for the problem you think you
  34687. -     have fixed.  We need to convince ourselves that the change is
  34688. -     right before installing it.  Even if it is right, we might have
  34689. -     trouble judging it if we don't have a way to reproduce the problem.
  34690. -
  34691. -   * Include all the comments that are appropriate to help people
  34692. -     reading the source in the future understand why this change was
  34693. -     needed.
  34694. -
  34695. -   * Don't mix together changes made for different reasons.  Send them
  34696. -     *individually*.
  34697. -
  34698. -     If you make two changes for separate reasons, then we might not
  34699. -     want to install them both.  We might want to install just one.  If
  34700. -     you send them all jumbled together in a single set of diffs, we
  34701. -     have to do extra work to disentangle them--to figure out which
  34702. -     parts of the change serve which purpose.  If we don't have time
  34703. -     for this, we might have to ignore your changes entirely.
  34704. -
  34705. -     If you send each change as soon as you have written it, with its
  34706. -     own explanation, then the two changes never get tangled up, and we
  34707. -     can consider each one properly without any extra work to
  34708. -     disentangle them.
  34709. -
  34710. -     Ideally, each change you send should be impossible to subdivide
  34711. -     into parts that we might want to consider separately, because each
  34712. -     of its parts gets its motivation from the other parts.
  34713. -
  34714. -   * Send each change as soon as that change is finished.  Sometimes
  34715. -     people think they are helping us by accumulating many changes to
  34716. -     send them all together.  As explained above, this is absolutely
  34717. -     the worst thing you could do.
  34718. -
  34719. -     Since you should send each change separately, you might as well
  34720. -     send it right away.  That gives us the option of installing it
  34721. -     immediately if it is important.
  34722. -
  34723. -   * Use `diff -c' to make your diffs.  Diffs without context are hard
  34724. -     for us to install reliably.  More than that, they make it hard for
  34725. -     us to study the diffs to decide whether we want to install them.
  34726. -     Unidiff format is better than contextless diffs, but not as easy
  34727. -     to read as `-c' format.
  34728. -
  34729. -     If you have GNU diff, use `diff -cp', which shows the name of the
  34730. -     function that each change occurs in.
  34731. -
  34732. -   * Write the change log entries for your changes.  We get lots of
  34733. -     changes, and we don't have time to do all the change log writing
  34734. -     ourselves.
  34735. -
  34736. -     Read the `ChangeLog' file to see what sorts of information to put
  34737. -     in, and to learn the style that we use.  The purpose of the change
  34738. -     log is to show people where to find what was changed.  So you need
  34739. -     to be specific about what functions you changed; in large
  34740. -     functions, it's often helpful to indicate where within the
  34741. -     function the change was.
  34742. -
  34743. -     On the other hand, once you have shown people where to find the
  34744. -     change, you need not explain its purpose.  Thus, if you add a new
  34745. -     function, all you need to say about it is that it is new.  If you
  34746. -     feel that the purpose needs explaining, it probably does--but the
  34747. -     explanation will be much more useful if you put it in comments in
  34748. -     the code.
  34749. -
  34750. -     If you would like your name to appear in the header line for who
  34751. -     made the change, send us the header line.
  34752. -
  34753. -   * When you write the fix, keep in mind that we can't install a
  34754. -     change that would break other systems.
  34755. -
  34756. -     People often suggest fixing a problem by changing
  34757. -     machine-independent files such as `toplev.c' to do something
  34758. -     special that a particular system needs.  Sometimes it is totally
  34759. -     obvious that such changes would break GNU CC for almost all users.
  34760. -     We can't possibly make a change like that.  At best it might tell
  34761. -     us how to write another patch that would solve the problem
  34762. -     acceptably.
  34763. -
  34764. -     Sometimes people send fixes that *might* be an improvement in
  34765. -     general--but it is hard to be sure of this.  It's hard to install
  34766. -     such changes because we have to study them very carefully.  Of
  34767. -     course, a good explanation of the reasoning by which you concluded
  34768. -     the change was correct can help convince us.
  34769. -
  34770. -     The safest changes are changes to the configuration files for a
  34771. -     particular machine.  These are safe because they can't create new
  34772. -     bugs on other machines.
  34773. -
  34774. -     Please help us keep up with the workload by designing the patch in
  34775. -     a form that is good to install.
  34776. -
  34777. -
  34778. -File: gcc.info,  Node: Service,  Next: VMS,  Prev: Bugs,  Up: Top
  34779. -
  34780. -How To Get Help with GNU CC
  34781. -***************************
  34782. -
  34783. -   If you need help installing, using or changing GNU CC, there are two
  34784. -ways to find it:
  34785. -
  34786. -   * Send a message to a suitable network mailing list.  First try
  34787. -     `bug-gcc@prep.ai.mit.edu', and if that brings no response, try
  34788. -     `help-gcc@prep.ai.mit.edu'.
  34789. -
  34790. -   * Look in the service directory for someone who might help you for a
  34791. -     fee.  The service directory is found in the file named `SERVICE'
  34792. -     in the GNU CC distribution.
  34793. -
  34794. -
  34795. -File: gcc.info,  Node: VMS,  Next: Portability,  Prev: Service,  Up: Top
  34796. -
  34797. -Using GNU CC on VMS
  34798. -*******************
  34799. -
  34800. -   Here is how to use GNU CC on VMS.
  34801. -
  34802. -* Menu:
  34803. -
  34804. -* Include Files and VMS::  Where the preprocessor looks for the include files.
  34805. -* Global Declarations::    How to do globaldef, globalref and globalvalue with
  34806. -                           GNU CC.
  34807. -* VMS Misc::           Misc information.
  34808. -
  34809. -
  34810. -File: gcc.info,  Node: Include Files and VMS,  Next: Global Declarations,  Up: VMS
  34811. -
  34812. -Include Files and VMS
  34813. -=====================
  34814. -
  34815. -   Due to the differences between the filesystems of Unix and VMS, GNU
  34816. -CC attempts to translate file names in `#include' into names that VMS
  34817. -will understand.  The basic strategy is to prepend a prefix to the
  34818. -specification of the include file, convert the whole filename to a VMS
  34819. -filename, and then try to open the file.  GNU CC tries various prefixes
  34820. -one by one until one of them succeeds:
  34821. -
  34822. -  1. The first prefix is the `GNU_CC_INCLUDE:' logical name: this is
  34823. -     where GNU C header files are traditionally stored.  If you wish to
  34824. -     store header files in non-standard locations, then you can assign
  34825. -     the logical `GNU_CC_INCLUDE' to be a search list, where each
  34826. -     element of the list is suitable for use with a rooted logical.
  34827. -
  34828. -  2. The next prefix tried is `SYS$SYSROOT:[SYSLIB.]'.  This is where
  34829. -     VAX-C header files are traditionally stored.
  34830. -
  34831. -  3. If the include file specification by itself is a valid VMS
  34832. -     filename, the preprocessor then uses this name with no prefix in
  34833. -     an attempt to open the include file.
  34834. -
  34835. -  4. If the file specification is not a valid VMS filename (i.e. does
  34836. -     not contain a device or a directory specifier, and contains a `/'
  34837. -     character), the preprocessor tries to convert it from Unix syntax
  34838. -     to VMS syntax.
  34839. -
  34840. -     Conversion works like this: the first directory name becomes a
  34841. -     device, and the rest of the directories are converted into
  34842. -     VMS-format directory names.  For example, the name `X11/foobar.h'
  34843. -     is translated to `X11:[000000]foobar.h' or `X11:foobar.h',
  34844. -     whichever one can be opened.  This strategy allows you to assign a
  34845. -     logical name to point to the actual location of the header files.
  34846. -
  34847. -  5. If none of these strategies succeeds, the `#include' fails.
  34848. -
  34849. -   Include directives of the form:
  34850. -
  34851. -     #include foobar
  34852. -
  34853. -are a common source of incompatibility between VAX-C and GNU CC.  VAX-C
  34854. -treats this much like a standard `#include <foobar.h>' directive.  That
  34855. -is incompatible with the ANSI C behavior implemented by GNU CC: to
  34856. -expand the name `foobar' as a macro.  Macro expansion should eventually
  34857. -yield one of the two standard formats for `#include':
  34858. -
  34859. -     #include "FILE"
  34860. -     #include <FILE>
  34861. -
  34862. -   If you have this problem, the best solution is to modify the source
  34863. -to convert the `#include' directives to one of the two standard forms.
  34864. -That will work with either compiler.  If you want a quick and dirty fix,
  34865. -define the file names as macros with the proper expansion, like this:
  34866. -
  34867. -     #define stdio <stdio.h>
  34868. -
  34869. -This will work, as long as the name doesn't conflict with anything else
  34870. -in the program.
  34871. -
  34872. -   Another source of incompatibility is that VAX-C assumes that:
  34873. -
  34874. -     #include "foobar"
  34875. -
  34876. -is actually asking for the file `foobar.h'.  GNU CC does not make this
  34877. -assumption, and instead takes what you ask for literally; it tries to
  34878. -read the file `foobar'.  The best way to avoid this problem is to
  34879. -always specify the desired file extension in your include directives.
  34880. -
  34881. -   GNU CC for VMS is distributed with a set of include files that is
  34882. -sufficient to compile most general purpose programs.  Even though the
  34883. -GNU CC distribution does not contain header files to define constants
  34884. -and structures for some VMS system-specific functions, there is no
  34885. -reason why you cannot use GNU CC with any of these functions.  You first
  34886. -may have to generate or create header files, either by using the public
  34887. -domain utility `UNSDL' (which can be found on a DECUS tape), or by
  34888. -extracting the relevant modules from one of the system macro libraries,
  34889. -and using an editor to construct a C header file.
  34890. -
  34891. -   A `#include' file name cannot contain a DECNET node name.  The
  34892. -preprocessor reports an I/O error if you attempt to use a node name,
  34893. -whether explicitly, or implicitly via a logical name.
  34894. -
  34895. -
  34896. -File: gcc.info,  Node: Global Declarations,  Next: VMS Misc,  Prev: Include Files and VMS,  Up: VMS
  34897. -
  34898. -Global Declarations and VMS
  34899. -===========================
  34900. -
  34901. -   GNU CC does not provide the `globalref', `globaldef' and
  34902. -`globalvalue' keywords of VAX-C.  You can get the same effect with an
  34903. -obscure feature of GAS, the GNU assembler.  (This requires GAS version
  34904. -1.39 or later.)  The following macros allow you to use this feature in
  34905. -a fairly natural way:
  34906. -
  34907. -     #ifdef __GNUC__
  34908. -     #define GLOBALREF(TYPE,NAME)                      \
  34909. -       TYPE NAME                                       \
  34910. -       asm ("_$$PsectAttributes_GLOBALSYMBOL$$" #NAME)
  34911. -     #define GLOBALDEF(TYPE,NAME,VALUE)                \
  34912. -       TYPE NAME                                       \
  34913. -       asm ("_$$PsectAttributes_GLOBALSYMBOL$$" #NAME) \
  34914. -         = VALUE
  34915. -     #define GLOBALVALUEREF(TYPE,NAME)                 \
  34916. -       const TYPE NAME[1]                              \
  34917. -       asm ("_$$PsectAttributes_GLOBALVALUE$$" #NAME)
  34918. -     #define GLOBALVALUEDEF(TYPE,NAME,VALUE)           \
  34919. -       const TYPE NAME[1]                              \
  34920. -       asm ("_$$PsectAttributes_GLOBALVALUE$$" #NAME)  \
  34921. -         = {VALUE}
  34922. -     #else
  34923. -     #define GLOBALREF(TYPE,NAME) \
  34924. -       globalref TYPE NAME
  34925. -     #define GLOBALDEF(TYPE,NAME,VALUE) \
  34926. -       globaldef TYPE NAME = VALUE
  34927. -     #define GLOBALVALUEDEF(TYPE,NAME,VALUE) \
  34928. -       globalvalue TYPE NAME = VALUE
  34929. -     #define GLOBALVALUEREF(TYPE,NAME) \
  34930. -       globalvalue TYPE NAME
  34931. -     #endif
  34932. -
  34933. -(The `_$$PsectAttributes_GLOBALSYMBOL' prefix at the start of the name
  34934. -is removed by the assembler, after it has modified the attributes of
  34935. -the symbol).  These macros are provided in the VMS binaries
  34936. -distribution in a header file `GNU_HACKS.H'.  An example of the usage
  34937. -is:
  34938. -
  34939. -     GLOBALREF (int, ijk);
  34940. -     GLOBALDEF (int, jkl, 0);
  34941. -
  34942. -   The macros `GLOBALREF' and `GLOBALDEF' cannot be used
  34943. -straightforwardly for arrays, since there is no way to insert the array
  34944. -dimension into the declaration at the right place.  However, you can
  34945. -declare an array with these macros if you first define a typedef for the
  34946. -array type, like this:
  34947. -
  34948. -     typedef int intvector[10];
  34949. -     GLOBALREF (intvector, foo);
  34950. -
  34951. -   Array and structure initializers will also break the macros; you can
  34952. -define the initializer to be a macro of its own, or you can expand the
  34953. -`GLOBALDEF' macro by hand.  You may find a case where you wish to use
  34954. -the `GLOBALDEF' macro with a large array, but you are not interested in
  34955. -explicitly initializing each element of the array.  In such cases you
  34956. -can use an initializer like: `{0,}', which will initialize the entire
  34957. -array to `0'.
  34958. -
  34959. -   A shortcoming of this implementation is that a variable declared with
  34960. -`GLOBALVALUEREF' or `GLOBALVALUEDEF' is always an array.  For example,
  34961. -the declaration:
  34962. -
  34963. -     GLOBALVALUEREF(int, ijk);
  34964. -
  34965. -declares the variable `ijk' as an array of type `int [1]'.  This is
  34966. -done because a globalvalue is actually a constant; its "value" is what
  34967. -the linker would normally consider an address.  That is not how an
  34968. -integer value works in C, but it is how an array works.  So treating
  34969. -the symbol as an array name gives consistent results--with the
  34970. -exception that the value seems to have the wrong type.  *Don't try to
  34971. -access an element of the array.*  It doesn't have any elements.  The
  34972. -array "address" may not be the address of actual storage.
  34973. -
  34974. -   The fact that the symbol is an array may lead to warnings where the
  34975. -variable is used.  Insert type casts to avoid the warnings.  Here is an
  34976. -example; it takes advantage of the ANSI C feature allowing macros that
  34977. -expand to use the same name as the macro itself.
  34978. -
  34979. -     GLOBALVALUEREF (int, ss$_normal);
  34980. -     GLOBALVALUEDEF (int, xyzzy,123);
  34981. -     #ifdef __GNUC__
  34982. -     #define ss$_normal ((int) ss$_normal)
  34983. -     #define xyzzy ((int) xyzzy)
  34984. -     #endif
  34985. -
  34986. -   Don't use `globaldef' or `globalref' with a variable whose type is
  34987. -an enumeration type; this is not implemented.  Instead, make the
  34988. -variable an integer, and use a `globalvaluedef' for each of the
  34989. -enumeration values.  An example of this would be:
  34990. -
  34991. -     #ifdef __GNUC__
  34992. -     GLOBALDEF (int, color, 0);
  34993. -     GLOBALVALUEDEF (int, RED, 0);
  34994. -     GLOBALVALUEDEF (int, BLUE, 1);
  34995. -     GLOBALVALUEDEF (int, GREEN, 3);
  34996. -     #else
  34997. -     enum globaldef color {RED, BLUE, GREEN = 3};
  34998. -     #endif
  34999. -
  35000. diff -rup --new-file baseline/fsf/gcc/gcc.info-13 amiga/fsf/gcc/gcc.info-13
  35001. --- baseline/fsf/gcc/gcc.info-13    Sat Jun 29 09:38:02 1996
  35002. +++ amiga/fsf/gcc/gcc.info-13    Wed Dec 31 17:00:00 1969
  35003. @@ -1,1057 +0,0 @@
  35004. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  35005. -file gcc.texi.
  35006. -
  35007. -   This file documents the use and the internals of the GNU compiler.
  35008. -
  35009. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  35010. -Boston, MA 02111-1307 USA
  35011. -
  35012. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  35013. -Foundation, Inc.
  35014. -
  35015. -   Permission is granted to make and distribute verbatim copies of this
  35016. -manual provided the copyright notice and this permission notice are
  35017. -preserved on all copies.
  35018. -
  35019. -   Permission is granted to copy and distribute modified versions of
  35020. -this manual under the conditions for verbatim copying, provided also
  35021. -that the sections entitled "GNU General Public License," "Funding for
  35022. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  35023. -included exactly as in the original, and provided that the entire
  35024. -resulting derived work is distributed under the terms of a permission
  35025. -notice identical to this one.
  35026. -
  35027. -   Permission is granted to copy and distribute translations of this
  35028. -manual into another language, under the above conditions for modified
  35029. -versions, except that the sections entitled "GNU General Public
  35030. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  35031. -`Look And Feel'", and this permission notice, may be included in
  35032. -translations approved by the Free Software Foundation instead of in the
  35033. -original English.
  35034. -
  35035. -
  35036. -File: gcc.info,  Node: VMS Misc,  Prev: Global Declarations,  Up: VMS
  35037. -
  35038. -Other VMS Issues
  35039. -================
  35040. -
  35041. -   GNU CC automatically arranges for `main' to return 1 by default if
  35042. -you fail to specify an explicit return value.  This will be interpreted
  35043. -by VMS as a status code indicating a normal successful completion.
  35044. -Version 1 of GNU CC did not provide this default.
  35045. -
  35046. -   GNU CC on VMS works only with the GNU assembler, GAS.  You need
  35047. -version 1.37 or later of GAS in order to produce value debugging
  35048. -information for the VMS debugger.  Use the ordinary VMS linker with the
  35049. -object files produced by GAS.
  35050. -
  35051. -   Under previous versions of GNU CC, the generated code would
  35052. -occasionally give strange results when linked to the sharable `VAXCRTL'
  35053. -library.  Now this should work.
  35054. -
  35055. -   A caveat for use of `const' global variables: the `const' modifier
  35056. -must be specified in every external declaration of the variable in all
  35057. -of the source files that use that variable.  Otherwise the linker will
  35058. -issue warnings about conflicting attributes for the variable.  Your
  35059. -program will still work despite the warnings, but the variable will be
  35060. -placed in writable storage.
  35061. -
  35062. -   Although the VMS linker does distinguish between upper and lower case
  35063. -letters in global symbols, most VMS compilers convert all such symbols
  35064. -into upper case and most run-time library routines also have upper case
  35065. -names.  To be able to reliably call such routines, GNU CC (by means of
  35066. -the assembler GAS) converts global symbols into upper case like other
  35067. -VMS compilers.  However, since the usual practice in C is to distinguish
  35068. -case, GNU CC (via GAS) tries to preserve usual C behavior by augmenting
  35069. -each name that is not all lower case.  This means truncating the name
  35070. -to at most 23 characters and then adding more characters at the end
  35071. -which encode the case pattern of those 23.   Names which contain at
  35072. -least one dollar sign are an exception; they are converted directly into
  35073. -upper case without augmentation.
  35074. -
  35075. -   Name augmentation yields bad results for programs that use
  35076. -precompiled libraries (such as Xlib) which were generated by another
  35077. -compiler.  You can use the compiler option `/NOCASE_HACK' to inhibit
  35078. -augmentation; it makes external C functions and variables
  35079. -case-independent as is usual on VMS.  Alternatively, you could write
  35080. -all references to the functions and variables in such libraries using
  35081. -lower case; this will work on VMS, but is not portable to other
  35082. -systems.  The compiler option `/NAMES' also provides control over
  35083. -global name handling.
  35084. -
  35085. -   Function and variable names are handled somewhat differently with GNU
  35086. -C++.  The GNU C++ compiler performs "name mangling" on function names,
  35087. -which means that it adds information to the function name to describe
  35088. -the data types of the arguments that the function takes.  One result of
  35089. -this is that the name of a function can become very long.  Since the
  35090. -VMS linker only recognizes the first 31 characters in a name, special
  35091. -action is taken to ensure that each function and variable has a unique
  35092. -name that can be represented in 31 characters.
  35093. -
  35094. -   If the name (plus a name augmentation, if required) is less than 32
  35095. -characters in length, then no special action is performed.  If the name
  35096. -is longer than 31 characters, the assembler (GAS) will generate a hash
  35097. -string based upon the function name, truncate the function name to 23
  35098. -characters, and append the hash string to the truncated name.  If the
  35099. -`/VERBOSE' compiler option is used, the assembler will print both the
  35100. -full and truncated names of each symbol that is truncated.
  35101. -
  35102. -   The `/NOCASE_HACK' compiler option should not be used when you are
  35103. -compiling programs that use libg++.  libg++ has several instances of
  35104. -objects (i.e.  `Filebuf' and `filebuf') which become indistinguishable
  35105. -in a case-insensitive environment.  This leads to cases where you need
  35106. -to inhibit augmentation selectively (if you were using libg++ and Xlib
  35107. -in the same program, for example).  There is no special feature for
  35108. -doing this, but you can get the result by defining a macro for each
  35109. -mixed case symbol for which you wish to inhibit augmentation.  The
  35110. -macro should expand into the lower case equivalent of itself.  For
  35111. -example:
  35112. -
  35113. -     #define StuDlyCapS studlycaps
  35114. -
  35115. -   These macro definitions can be placed in a header file to minimize
  35116. -the number of changes to your source code.
  35117. -
  35118. -
  35119. -File: gcc.info,  Node: Portability,  Next: Interface,  Prev: VMS,  Up: Top
  35120. -
  35121. -GNU CC and Portability
  35122. -**********************
  35123. -
  35124. -   The main goal of GNU CC was to make a good, fast compiler for
  35125. -machines in the class that the GNU system aims to run on: 32-bit
  35126. -machines that address 8-bit bytes and have several general registers.
  35127. -Elegance, theoretical power and simplicity are only secondary.
  35128. -
  35129. -   GNU CC gets most of the information about the target machine from a
  35130. -machine description which gives an algebraic formula for each of the
  35131. -machine's instructions.  This is a very clean way to describe the
  35132. -target.  But when the compiler needs information that is difficult to
  35133. -express in this fashion, I have not hesitated to define an ad-hoc
  35134. -parameter to the machine description.  The purpose of portability is to
  35135. -reduce the total work needed on the compiler; it was not of interest
  35136. -for its own sake.
  35137. -
  35138. -   GNU CC does not contain machine dependent code, but it does contain
  35139. -code that depends on machine parameters such as endianness (whether the
  35140. -most significant byte has the highest or lowest address of the bytes in
  35141. -a word) and the availability of autoincrement addressing.  In the
  35142. -RTL-generation pass, it is often necessary to have multiple strategies
  35143. -for generating code for a particular kind of syntax tree, strategies
  35144. -that are usable for different combinations of parameters.  Often I have
  35145. -not tried to address all possible cases, but only the common ones or
  35146. -only the ones that I have encountered.  As a result, a new target may
  35147. -require additional strategies.  You will know if this happens because
  35148. -the compiler will call `abort'.  Fortunately, the new strategies can be
  35149. -added in a machine-independent fashion, and will affect only the target
  35150. -machines that need them.
  35151. -
  35152. -
  35153. -File: gcc.info,  Node: Interface,  Next: Passes,  Prev: Portability,  Up: Top
  35154. -
  35155. -Interfacing to GNU CC Output
  35156. -****************************
  35157. -
  35158. -   GNU CC is normally configured to use the same function calling
  35159. -convention normally in use on the target system.  This is done with the
  35160. -machine-description macros described (*note Target Macros::.).
  35161. -
  35162. -   However, returning of structure and union values is done differently
  35163. -on some target machines.  As a result, functions compiled with PCC
  35164. -returning such types cannot be called from code compiled with GNU CC,
  35165. -and vice versa.  This does not cause trouble often because few Unix
  35166. -library routines return structures or unions.
  35167. -
  35168. -   GNU CC code returns structures and unions that are 1, 2, 4 or 8 bytes
  35169. -long in the same registers used for `int' or `double' return values.
  35170. -(GNU CC typically allocates variables of such types in registers also.)
  35171. -Structures and unions of other sizes are returned by storing them into
  35172. -an address passed by the caller (usually in a register).  The
  35173. -machine-description macros `STRUCT_VALUE' and `STRUCT_INCOMING_VALUE'
  35174. -tell GNU CC where to pass this address.
  35175. -
  35176. -   By contrast, PCC on most target machines returns structures and
  35177. -unions of any size by copying the data into an area of static storage,
  35178. -and then returning the address of that storage as if it were a pointer
  35179. -value.  The caller must copy the data from that memory area to the
  35180. -place where the value is wanted.  This is slower than the method used
  35181. -by GNU CC, and fails to be reentrant.
  35182. -
  35183. -   On some target machines, such as RISC machines and the 80386, the
  35184. -standard system convention is to pass to the subroutine the address of
  35185. -where to return the value.  On these machines, GNU CC has been
  35186. -configured to be compatible with the standard compiler, when this method
  35187. -is used.  It may not be compatible for structures of 1, 2, 4 or 8 bytes.
  35188. -
  35189. -   GNU CC uses the system's standard convention for passing arguments.
  35190. -On some machines, the first few arguments are passed in registers; in
  35191. -others, all are passed on the stack.  It would be possible to use
  35192. -registers for argument passing on any machine, and this would probably
  35193. -result in a significant speedup.  But the result would be complete
  35194. -incompatibility with code that follows the standard convention.  So this
  35195. -change is practical only if you are switching to GNU CC as the sole C
  35196. -compiler for the system.  We may implement register argument passing on
  35197. -certain machines once we have a complete GNU system so that we can
  35198. -compile the libraries with GNU CC.
  35199. -
  35200. -   On some machines (particularly the Sparc), certain types of arguments
  35201. -are passed "by invisible reference".  This means that the value is
  35202. -stored in memory, and the address of the memory location is passed to
  35203. -the subroutine.
  35204. -
  35205. -   If you use `longjmp', beware of automatic variables.  ANSI C says
  35206. -that automatic variables that are not declared `volatile' have undefined
  35207. -values after a `longjmp'.  And this is all GNU CC promises to do,
  35208. -because it is very difficult to restore register variables correctly,
  35209. -and one of GNU CC's features is that it can put variables in registers
  35210. -without your asking it to.
  35211. -
  35212. -   If you want a variable to be unaltered by `longjmp', and you don't
  35213. -want to write `volatile' because old C compilers don't accept it, just
  35214. -take the address of the variable.  If a variable's address is ever
  35215. -taken, even if just to compute it and ignore it, then the variable
  35216. -cannot go in a register:
  35217. -
  35218. -     {
  35219. -       int careful;
  35220. -       &careful;
  35221. -       ...
  35222. -     }
  35223. -
  35224. -   Code compiled with GNU CC may call certain library routines.  Most of
  35225. -them handle arithmetic for which there are no instructions.  This
  35226. -includes multiply and divide on some machines, and floating point
  35227. -operations on any machine for which floating point support is disabled
  35228. -with `-msoft-float'.  Some standard parts of the C library, such as
  35229. -`bcopy' or `memcpy', are also called automatically.  The usual function
  35230. -call interface is used for calling the library routines.
  35231. -
  35232. -   These library routines should be defined in the library `libgcc.a',
  35233. -which GNU CC automatically searches whenever it links a program.  On
  35234. -machines that have multiply and divide instructions, if hardware
  35235. -floating point is in use, normally `libgcc.a' is not needed, but it is
  35236. -searched just in case.
  35237. -
  35238. -   Each arithmetic function is defined in `libgcc1.c' to use the
  35239. -corresponding C arithmetic operator.  As long as the file is compiled
  35240. -with another C compiler, which supports all the C arithmetic operators,
  35241. -this file will work portably.  However, `libgcc1.c' does not work if
  35242. -compiled with GNU CC, because each arithmetic function would compile
  35243. -into a call to itself!
  35244. -
  35245. -
  35246. -File: gcc.info,  Node: Passes,  Next: RTL,  Prev: Interface,  Up: Top
  35247. -
  35248. -Passes and Files of the Compiler
  35249. -********************************
  35250. -
  35251. -   The overall control structure of the compiler is in `toplev.c'.  This
  35252. -file is responsible for initialization, decoding arguments, opening and
  35253. -closing files, and sequencing the passes.
  35254. -
  35255. -   The parsing pass is invoked only once, to parse the entire input.
  35256. -The RTL intermediate code for a function is generated as the function
  35257. -is parsed, a statement at a time.  Each statement is read in as a
  35258. -syntax tree and then converted to RTL; then the storage for the tree
  35259. -for the statement is reclaimed.  Storage for types (and the expressions
  35260. -for their sizes), declarations, and a representation of the binding
  35261. -contours and how they nest, remain until the function is finished being
  35262. -compiled; these are all needed to output the debugging information.
  35263. -
  35264. -   Each time the parsing pass reads a complete function definition or
  35265. -top-level declaration, it calls either the function
  35266. -`rest_of_compilation', or the function `rest_of_decl_compilation' in
  35267. -`toplev.c', which are responsible for all further processing necessary,
  35268. -ending with output of the assembler language.  All other compiler
  35269. -passes run, in sequence, within `rest_of_compilation'.  When that
  35270. -function returns from compiling a function definition, the storage used
  35271. -for that function definition's compilation is entirely freed, unless it
  35272. -is an inline function (*note An Inline Function is As Fast As a Macro:
  35273. -Inline.).
  35274. -
  35275. -   Here is a list of all the passes of the compiler and their source
  35276. -files.  Also included is a description of where debugging dumps can be
  35277. -requested with `-d' options.
  35278. -
  35279. -   * Parsing.  This pass reads the entire text of a function definition,
  35280. -     constructing partial syntax trees.  This and RTL generation are no
  35281. -     longer truly separate passes (formerly they were), but it is
  35282. -     easier to think of them as separate.
  35283. -
  35284. -     The tree representation does not entirely follow C syntax, because
  35285. -     it is intended to support other languages as well.
  35286. -
  35287. -     Language-specific data type analysis is also done in this pass,
  35288. -     and every tree node that represents an expression has a data type
  35289. -     attached.  Variables are represented as declaration nodes.
  35290. -
  35291. -     Constant folding and some arithmetic simplifications are also done
  35292. -     during this pass.
  35293. -
  35294. -     The language-independent source files for parsing are
  35295. -     `stor-layout.c', `fold-const.c', and `tree.c'.  There are also
  35296. -     header files `tree.h' and `tree.def' which define the format of
  35297. -     the tree representation.
  35298. -
  35299. -     The source files to parse C are `c-parse.in', `c-decl.c',
  35300. -     `c-typeck.c', `c-aux-info.c', `c-convert.c', and `c-lang.c' along
  35301. -     with header files `c-lex.h', and `c-tree.h'.
  35302. -
  35303. -     The source files for parsing C++ are `cp-parse.y', `cp-class.c',
  35304. -     `cp-cvt.c', `cp-decl.c', `cp-decl2.c', `cp-dem.c', `cp-except.c',
  35305. -     `cp-expr.c', `cp-init.c', `cp-lex.c', `cp-method.c', `cp-ptree.c',
  35306. -     `cp-search.c', `cp-tree.c', `cp-type2.c', and `cp-typeck.c', along
  35307. -     with header files `cp-tree.def', `cp-tree.h', and `cp-decl.h'.
  35308. -
  35309. -     The special source files for parsing Objective C are
  35310. -     `objc-parse.y', `objc-actions.c', `objc-tree.def', and
  35311. -     `objc-actions.h'.  Certain C-specific files are used for this as
  35312. -     well.
  35313. -
  35314. -     The file `c-common.c' is also used for all of the above languages.
  35315. -
  35316. -   * RTL generation.  This is the conversion of syntax tree into RTL
  35317. -     code.  It is actually done statement-by-statement during parsing,
  35318. -     but for most purposes it can be thought of as a separate pass.
  35319. -
  35320. -     This is where the bulk of target-parameter-dependent code is found,
  35321. -     since often it is necessary for strategies to apply only when
  35322. -     certain standard kinds of instructions are available.  The purpose
  35323. -     of named instruction patterns is to provide this information to
  35324. -     the RTL generation pass.
  35325. -
  35326. -     Optimization is done in this pass for `if'-conditions that are
  35327. -     comparisons, boolean operations or conditional expressions.  Tail
  35328. -     recursion is detected at this time also.  Decisions are made about
  35329. -     how best to arrange loops and how to output `switch' statements.
  35330. -
  35331. -     The source files for RTL generation include `stmt.c', `calls.c',
  35332. -     `expr.c', `explow.c', `expmed.c', `function.c', `optabs.c' and
  35333. -     `emit-rtl.c'.  Also, the file `insn-emit.c', generated from the
  35334. -     machine description by the program `genemit', is used in this
  35335. -     pass.  The header file `expr.h' is used for communication within
  35336. -     this pass.
  35337. -
  35338. -     The header files `insn-flags.h' and `insn-codes.h', generated from
  35339. -     the machine description by the programs `genflags' and `gencodes',
  35340. -     tell this pass which standard names are available for use and
  35341. -     which patterns correspond to them.
  35342. -
  35343. -     Aside from debugging information output, none of the following
  35344. -     passes refers to the tree structure representation of the function
  35345. -     (only part of which is saved).
  35346. -
  35347. -     The decision of whether the function can and should be expanded
  35348. -     inline in its subsequent callers is made at the end of rtl
  35349. -     generation.  The function must meet certain criteria, currently
  35350. -     related to the size of the function and the types and number of
  35351. -     parameters it has.  Note that this function may contain loops,
  35352. -     recursive calls to itself (tail-recursive functions can be
  35353. -     inlined!), gotos, in short, all constructs supported by GNU CC.
  35354. -     The file `integrate.c' contains the code to save a function's rtl
  35355. -     for later inlining and to inline that rtl when the function is
  35356. -     called.  The header file `integrate.h' is also used for this
  35357. -     purpose.
  35358. -
  35359. -     The option `-dr' causes a debugging dump of the RTL code after
  35360. -     this pass.  This dump file's name is made by appending `.rtl' to
  35361. -     the input file name.
  35362. -
  35363. -   * Jump optimization.  This pass simplifies jumps to the following
  35364. -     instruction, jumps across jumps, and jumps to jumps.  It deletes
  35365. -     unreferenced labels and unreachable code, except that unreachable
  35366. -     code that contains a loop is not recognized as unreachable in this
  35367. -     pass.  (Such loops are deleted later in the basic block analysis.)
  35368. -     It also converts some code originally written with jumps into
  35369. -     sequences of instructions that directly set values from the
  35370. -     results of comparisons, if the machine has such instructions.
  35371. -
  35372. -     Jump optimization is performed two or three times.  The first time
  35373. -     is immediately following RTL generation.  The second time is after
  35374. -     CSE, but only if CSE says repeated jump optimization is needed.
  35375. -     The last time is right before the final pass.  That time,
  35376. -     cross-jumping and deletion of no-op move instructions are done
  35377. -     together with the optimizations described above.
  35378. -
  35379. -     The source file of this pass is `jump.c'.
  35380. -
  35381. -     The option `-dj' causes a debugging dump of the RTL code after
  35382. -     this pass is run for the first time.  This dump file's name is
  35383. -     made by appending `.jump' to the input file name.
  35384. -
  35385. -   * Register scan.  This pass finds the first and last use of each
  35386. -     register, as a guide for common subexpression elimination.  Its
  35387. -     source is in `regclass.c'.
  35388. -
  35389. -   * Jump threading.  This pass detects a condition jump that branches
  35390. -     to an identical or inverse test.  Such jumps can be `threaded'
  35391. -     through the second conditional test.  The source code for this
  35392. -     pass is in `jump.c'.  This optimization is only performed if
  35393. -     `-fthread-jumps' is enabled.
  35394. -
  35395. -   * Common subexpression elimination.  This pass also does constant
  35396. -     propagation.  Its source file is `cse.c'.  If constant propagation
  35397. -     causes conditional jumps to become unconditional or to become
  35398. -     no-ops, jump optimization is run again when CSE is finished.
  35399. -
  35400. -     The option `-ds' causes a debugging dump of the RTL code after
  35401. -     this pass.  This dump file's name is made by appending `.cse' to
  35402. -     the input file name.
  35403. -
  35404. -   * Loop optimization.  This pass moves constant expressions out of
  35405. -     loops, and optionally does strength-reduction and loop unrolling
  35406. -     as well.  Its source files are `loop.c' and `unroll.c', plus the
  35407. -     header `loop.h' used for communication between them.  Loop
  35408. -     unrolling uses some functions in `integrate.c' and the header
  35409. -     `integrate.h'.
  35410. -
  35411. -     The option `-dL' causes a debugging dump of the RTL code after
  35412. -     this pass.  This dump file's name is made by appending `.loop' to
  35413. -     the input file name.
  35414. -
  35415. -   * If `-frerun-cse-after-loop' was enabled, a second common
  35416. -     subexpression elimination pass is performed after the loop
  35417. -     optimization pass.  Jump threading is also done again at this time
  35418. -     if it was specified.
  35419. -
  35420. -     The option `-dt' causes a debugging dump of the RTL code after
  35421. -     this pass.  This dump file's name is made by appending `.cse2' to
  35422. -     the input file name.
  35423. -
  35424. -   * Stupid register allocation is performed at this point in a
  35425. -     nonoptimizing compilation.  It does a little data flow analysis as
  35426. -     well.  When stupid register allocation is in use, the next pass
  35427. -     executed is the reloading pass; the others in between are skipped.
  35428. -     The source file is `stupid.c'.
  35429. -
  35430. -   * Data flow analysis (`flow.c').  This pass divides the program into
  35431. -     basic blocks (and in the process deletes unreachable loops); then
  35432. -     it computes which pseudo-registers are live at each point in the
  35433. -     program, and makes the first instruction that uses a value point at
  35434. -     the instruction that computed the value.
  35435. -
  35436. -     This pass also deletes computations whose results are never used,
  35437. -     and combines memory references with add or subtract instructions
  35438. -     to make autoincrement or autodecrement addressing.
  35439. -
  35440. -     The option `-df' causes a debugging dump of the RTL code after
  35441. -     this pass.  This dump file's name is made by appending `.flow' to
  35442. -     the input file name.  If stupid register allocation is in use, this
  35443. -     dump file reflects the full results of such allocation.
  35444. -
  35445. -   * Instruction combination (`combine.c').  This pass attempts to
  35446. -     combine groups of two or three instructions that are related by
  35447. -     data flow into single instructions.  It combines the RTL
  35448. -     expressions for the instructions by substitution, simplifies the
  35449. -     result using algebra, and then attempts to match the result
  35450. -     against the machine description.
  35451. -
  35452. -     The option `-dc' causes a debugging dump of the RTL code after
  35453. -     this pass.  This dump file's name is made by appending `.combine'
  35454. -     to the input file name.
  35455. -
  35456. -   * Instruction scheduling (`sched.c').  This pass looks for
  35457. -     instructions whose output will not be available by the time that
  35458. -     it is used in subsequent instructions.  (Memory loads and floating
  35459. -     point instructions often have this behavior on RISC machines).  It
  35460. -     re-orders instructions within a basic block to try to separate the
  35461. -     definition and use of items that otherwise would cause pipeline
  35462. -     stalls.
  35463. -
  35464. -     Instruction scheduling is performed twice.  The first time is
  35465. -     immediately after instruction combination and the second is
  35466. -     immediately after reload.
  35467. -
  35468. -     The option `-dS' causes a debugging dump of the RTL code after this
  35469. -     pass is run for the first time.  The dump file's name is made by
  35470. -     appending `.sched' to the input file name.
  35471. -
  35472. -   * Register class preferencing.  The RTL code is scanned to find out
  35473. -     which register class is best for each pseudo register.  The source
  35474. -     file is `regclass.c'.
  35475. -
  35476. -   * Local register allocation (`local-alloc.c').  This pass allocates
  35477. -     hard registers to pseudo registers that are used only within one
  35478. -     basic block.  Because the basic block is linear, it can use fast
  35479. -     and powerful techniques to do a very good job.
  35480. -
  35481. -     The option `-dl' causes a debugging dump of the RTL code after
  35482. -     this pass.  This dump file's name is made by appending `.lreg' to
  35483. -     the input file name.
  35484. -
  35485. -   * Global register allocation (`global.c').  This pass allocates hard
  35486. -     registers for the remaining pseudo registers (those whose life
  35487. -     spans are not contained in one basic block).
  35488. -
  35489. -   * Reloading.  This pass renumbers pseudo registers with the hardware
  35490. -     registers numbers they were allocated.  Pseudo registers that did
  35491. -     not get hard registers are replaced with stack slots.  Then it
  35492. -     finds instructions that are invalid because a value has failed to
  35493. -     end up in a register, or has ended up in a register of the wrong
  35494. -     kind.  It fixes up these instructions by reloading the
  35495. -     problematical values temporarily into registers.  Additional
  35496. -     instructions are generated to do the copying.
  35497. -
  35498. -     The reload pass also optionally eliminates the frame pointer and
  35499. -     inserts instructions to save and restore call-clobbered registers
  35500. -     around calls.
  35501. -
  35502. -     Source files are `reload.c' and `reload1.c', plus the header
  35503. -     `reload.h' used for communication between them.
  35504. -
  35505. -     The option `-dg' causes a debugging dump of the RTL code after
  35506. -     this pass.  This dump file's name is made by appending `.greg' to
  35507. -     the input file name.
  35508. -
  35509. -   * Instruction scheduling is repeated here to try to avoid pipeline
  35510. -     stalls due to memory loads generated for spilled pseudo registers.
  35511. -
  35512. -     The option `-dR' causes a debugging dump of the RTL code after
  35513. -     this pass.  This dump file's name is made by appending `.sched2'
  35514. -     to the input file name.
  35515. -
  35516. -   * Jump optimization is repeated, this time including cross-jumping
  35517. -     and deletion of no-op move instructions.
  35518. -
  35519. -     The option `-dJ' causes a debugging dump of the RTL code after
  35520. -     this pass.  This dump file's name is made by appending `.jump2' to
  35521. -     the input file name.
  35522. -
  35523. -   * Delayed branch scheduling.  This optional pass attempts to find
  35524. -     instructions that can go into the delay slots of other
  35525. -     instructions, usually jumps and calls.  The source file name is
  35526. -     `reorg.c'.
  35527. -
  35528. -     The option `-dd' causes a debugging dump of the RTL code after
  35529. -     this pass.  This dump file's name is made by appending `.dbr' to
  35530. -     the input file name.
  35531. -
  35532. -   * Conversion from usage of some hard registers to usage of a register
  35533. -     stack may be done at this point.  Currently, this is supported only
  35534. -     for the floating-point registers of the Intel 80387 coprocessor.
  35535. -     The source file name is `reg-stack.c'.
  35536. -
  35537. -     The options `-dk' causes a debugging dump of the RTL code after
  35538. -     this pass.  This dump file's name is made by appending `.stack' to
  35539. -     the input file name.
  35540. -
  35541. -   * Final.  This pass outputs the assembler code for the function.  It
  35542. -     is also responsible for identifying spurious test and compare
  35543. -     instructions.  Machine-specific peephole optimizations are
  35544. -     performed at the same time.  The function entry and exit sequences
  35545. -     are generated directly as assembler code in this pass; they never
  35546. -     exist as RTL.
  35547. -
  35548. -     The source files are `final.c' plus `insn-output.c'; the latter is
  35549. -     generated automatically from the machine description by the tool
  35550. -     `genoutput'.  The header file `conditions.h' is used for
  35551. -     communication between these files.
  35552. -
  35553. -   * Debugging information output.  This is run after final because it
  35554. -     must output the stack slot offsets for pseudo registers that did
  35555. -     not get hard registers.  Source files are `dbxout.c' for DBX
  35556. -     symbol table format, `sdbout.c' for SDB symbol table format, and
  35557. -     `dwarfout.c' for DWARF symbol table format.
  35558. -
  35559. -   Some additional files are used by all or many passes:
  35560. -
  35561. -   * Every pass uses `machmode.def' and `machmode.h' which define the
  35562. -     machine modes.
  35563. -
  35564. -   * Several passes use `real.h', which defines the default
  35565. -     representation of floating point constants and how to operate on
  35566. -     them.
  35567. -
  35568. -   * All the passes that work with RTL use the header files `rtl.h' and
  35569. -     `rtl.def', and subroutines in file `rtl.c'.  The tools `gen*' also
  35570. -     use these files to read and work with the machine description RTL.
  35571. -
  35572. -   * Several passes refer to the header file `insn-config.h' which
  35573. -     contains a few parameters (C macro definitions) generated
  35574. -     automatically from the machine description RTL by the tool
  35575. -     `genconfig'.
  35576. -
  35577. -   * Several passes use the instruction recognizer, which consists of
  35578. -     `recog.c' and `recog.h', plus the files `insn-recog.c' and
  35579. -     `insn-extract.c' that are generated automatically from the machine
  35580. -     description by the tools `genrecog' and `genextract'.
  35581. -
  35582. -   * Several passes use the header files `regs.h' which defines the
  35583. -     information recorded about pseudo register usage, and
  35584. -     `basic-block.h' which defines the information recorded about basic
  35585. -     blocks.
  35586. -
  35587. -   * `hard-reg-set.h' defines the type `HARD_REG_SET', a bit-vector
  35588. -     with a bit for each hard register, and some macros to manipulate
  35589. -     it.  This type is just `int' if the machine has few enough hard
  35590. -     registers; otherwise it is an array of `int' and some of the
  35591. -     macros expand into loops.
  35592. -
  35593. -   * Several passes use instruction attributes.  A definition of the
  35594. -     attributes defined for a particular machine is in file
  35595. -     `insn-attr.h', which is generated from the machine description by
  35596. -     the program `genattr'.  The file `insn-attrtab.c' contains
  35597. -     subroutines to obtain the attribute values for insns.  It is
  35598. -     generated from the machine description by the program `genattrtab'.
  35599. -
  35600. -
  35601. -File: gcc.info,  Node: RTL,  Next: Machine Desc,  Prev: Passes,  Up: Top
  35602. -
  35603. -RTL Representation
  35604. -******************
  35605. -
  35606. -   Most of the work of the compiler is done on an intermediate
  35607. -representation called register transfer language.  In this language,
  35608. -the instructions to be output are described, pretty much one by one, in
  35609. -an algebraic form that describes what the instruction does.
  35610. -
  35611. -   RTL is inspired by Lisp lists.  It has both an internal form, made
  35612. -up of structures that point at other structures, and a textual form
  35613. -that is used in the machine description and in printed debugging dumps.
  35614. -The textual form uses nested parentheses to indicate the pointers in
  35615. -the internal form.
  35616. -
  35617. -* Menu:
  35618. -
  35619. -* RTL Objects::       Expressions vs vectors vs strings vs integers.
  35620. -* Accessors::         Macros to access expression operands or vector elts.
  35621. -* Flags::             Other flags in an RTL expression.
  35622. -* Machine Modes::     Describing the size and format of a datum.
  35623. -* Constants::         Expressions with constant values.
  35624. -* Regs and Memory::   Expressions representing register contents or memory.
  35625. -* Arithmetic::        Expressions representing arithmetic on other expressions.
  35626. -* Comparisons::       Expressions representing comparison of expressions.
  35627. -* Bit Fields::        Expressions representing bitfields in memory or reg.
  35628. -* Conversions::       Extending, truncating, floating or fixing.
  35629. -* RTL Declarations::  Declaring volatility, constancy, etc.
  35630. -* Side Effects::      Expressions for storing in registers, etc.
  35631. -* Incdec::            Embedded side-effects for autoincrement addressing.
  35632. -* Assembler::         Representing `asm' with operands.
  35633. -* Insns::             Expression types for entire insns.
  35634. -* Calls::             RTL representation of function call insns.
  35635. -* Sharing::           Some expressions are unique; others *must* be copied.
  35636. -* Reading RTL::       Reading textual RTL from a file.
  35637. -
  35638. -
  35639. -File: gcc.info,  Node: RTL Objects,  Next: Accessors,  Prev: RTL,  Up: RTL
  35640. -
  35641. -RTL Object Types
  35642. -================
  35643. -
  35644. -   RTL uses five kinds of objects: expressions, integers, wide integers,
  35645. -strings and vectors.  Expressions are the most important ones.  An RTL
  35646. -expression ("RTX", for short) is a C structure, but it is usually
  35647. -referred to with a pointer; a type that is given the typedef name `rtx'.
  35648. -
  35649. -   An integer is simply an `int'; their written form uses decimal
  35650. -digits.  A wide integer is an integral object whose type is
  35651. -`HOST_WIDE_INT' (*note Config::.); their written form uses decimal
  35652. -digits.
  35653. -
  35654. -   A string is a sequence of characters.  In core it is represented as a
  35655. -`char *' in usual C fashion, and it is written in C syntax as well.
  35656. -However, strings in RTL may never be null.  If you write an empty
  35657. -string in a machine description, it is represented in core as a null
  35658. -pointer rather than as a pointer to a null character.  In certain
  35659. -contexts, these null pointers instead of strings are valid.  Within RTL
  35660. -code, strings are most commonly found inside `symbol_ref' expressions,
  35661. -but they appear in other contexts in the RTL expressions that make up
  35662. -machine descriptions.
  35663. -
  35664. -   A vector contains an arbitrary number of pointers to expressions.
  35665. -The number of elements in the vector is explicitly present in the
  35666. -vector.  The written form of a vector consists of square brackets
  35667. -(`[...]') surrounding the elements, in sequence and with whitespace
  35668. -separating them.  Vectors of length zero are not created; null pointers
  35669. -are used instead.
  35670. -
  35671. -   Expressions are classified by "expression codes" (also called RTX
  35672. -codes).  The expression code is a name defined in `rtl.def', which is
  35673. -also (in upper case) a C enumeration constant.  The possible expression
  35674. -codes and their meanings are machine-independent.  The code of an RTX
  35675. -can be extracted with the macro `GET_CODE (X)' and altered with
  35676. -`PUT_CODE (X, NEWCODE)'.
  35677. -
  35678. -   The expression code determines how many operands the expression
  35679. -contains, and what kinds of objects they are.  In RTL, unlike Lisp, you
  35680. -cannot tell by looking at an operand what kind of object it is.
  35681. -Instead, you must know from its context--from the expression code of
  35682. -the containing expression.  For example, in an expression of code
  35683. -`subreg', the first operand is to be regarded as an expression and the
  35684. -second operand as an integer.  In an expression of code `plus', there
  35685. -are two operands, both of which are to be regarded as expressions.  In
  35686. -a `symbol_ref' expression, there is one operand, which is to be
  35687. -regarded as a string.
  35688. -
  35689. -   Expressions are written as parentheses containing the name of the
  35690. -expression type, its flags and machine mode if any, and then the
  35691. -operands of the expression (separated by spaces).
  35692. -
  35693. -   Expression code names in the `md' file are written in lower case,
  35694. -but when they appear in C code they are written in upper case.  In this
  35695. -manual, they are shown as follows: `const_int'.
  35696. -
  35697. -   In a few contexts a null pointer is valid where an expression is
  35698. -normally wanted.  The written form of this is `(nil)'.
  35699. -
  35700. -
  35701. -File: gcc.info,  Node: Accessors,  Next: Flags,  Prev: RTL Objects,  Up: RTL
  35702. -
  35703. -Access to Operands
  35704. -==================
  35705. -
  35706. -   For each expression type `rtl.def' specifies the number of contained
  35707. -objects and their kinds, with four possibilities: `e' for expression
  35708. -(actually a pointer to an expression), `i' for integer, `w' for wide
  35709. -integer, `s' for string, and `E' for vector of expressions.  The
  35710. -sequence of letters for an expression code is called its "format".
  35711. -Thus, the format of `subreg' is `ei'.
  35712. -
  35713. -   A few other format characters are used occasionally:
  35714. -
  35715. -`u'
  35716. -     `u' is equivalent to `e' except that it is printed differently in
  35717. -     debugging dumps.  It is used for pointers to insns.
  35718. -
  35719. -`n'
  35720. -     `n' is equivalent to `i' except that it is printed differently in
  35721. -     debugging dumps.  It is used for the line number or code number of
  35722. -     a `note' insn.
  35723. -
  35724. -`S'
  35725. -     `S' indicates a string which is optional.  In the RTL objects in
  35726. -     core, `S' is equivalent to `s', but when the object is read, from
  35727. -     an `md' file, the string value of this operand may be omitted.  An
  35728. -     omitted string is taken to be the null string.
  35729. -
  35730. -`V'
  35731. -     `V' indicates a vector which is optional.  In the RTL objects in
  35732. -     core, `V' is equivalent to `E', but when the object is read from
  35733. -     an `md' file, the vector value of this operand may be omitted.  An
  35734. -     omitted vector is effectively the same as a vector of no elements.
  35735. -
  35736. -`0'
  35737. -     `0' means a slot whose contents do not fit any normal category.
  35738. -     `0' slots are not printed at all in dumps, and are often used in
  35739. -     special ways by small parts of the compiler.
  35740. -
  35741. -   There are macros to get the number of operands, the format, and the
  35742. -class of an expression code:
  35743. -
  35744. -`GET_RTX_LENGTH (CODE)'
  35745. -     Number of operands of an RTX of code CODE.
  35746. -
  35747. -`GET_RTX_FORMAT (CODE)'
  35748. -     The format of an RTX of code CODE, as a C string.
  35749. -
  35750. -`GET_RTX_CLASS (CODE)'
  35751. -     A single character representing the type of RTX operation that code
  35752. -     CODE performs.
  35753. -
  35754. -     The following classes are defined:
  35755. -
  35756. -    `o'
  35757. -          An RTX code that represents an actual object, such as `reg' or
  35758. -          `mem'.  `subreg' is not in this class.
  35759. -
  35760. -    `<'
  35761. -          An RTX code for a comparison.  The codes in this class are
  35762. -          `NE', `EQ', `LE', `LT', `GE', `GT', `LEU', `LTU', `GEU',
  35763. -          `GTU'.
  35764. -
  35765. -    `1'
  35766. -          An RTX code for a unary arithmetic operation, such as `neg'.
  35767. -
  35768. -    `c'
  35769. -          An RTX code for a commutative binary operation, other than
  35770. -          `NE' and `EQ' (which have class `<').
  35771. -
  35772. -    `2'
  35773. -          An RTX code for a noncommutative binary operation, such as
  35774. -          `MINUS'.
  35775. -
  35776. -    `b'
  35777. -          An RTX code for a bitfield operation, either `ZERO_EXTRACT' or
  35778. -          `SIGN_EXTRACT'.
  35779. -
  35780. -    `3'
  35781. -          An RTX code for other three input operations, such as
  35782. -          `IF_THEN_ELSE'.
  35783. -
  35784. -    `i'
  35785. -          An RTX code for a machine insn (`INSN', `JUMP_INSN', and
  35786. -          `CALL_INSN').
  35787. -
  35788. -    `m'
  35789. -          An RTX code for something that matches in insns, such as
  35790. -          `MATCH_DUP'.
  35791. -
  35792. -    `x'
  35793. -          All other RTX codes.
  35794. -
  35795. -   Operands of expressions are accessed using the macros `XEXP',
  35796. -`XINT', `XWINT' and `XSTR'.  Each of these macros takes two arguments:
  35797. -an expression-pointer (RTX) and an operand number (counting from zero).
  35798. -Thus,
  35799. -
  35800. -     XEXP (X, 2)
  35801. -
  35802. -accesses operand 2 of expression X, as an expression.
  35803. -
  35804. -     XINT (X, 2)
  35805. -
  35806. -accesses the same operand as an integer.  `XSTR', used in the same
  35807. -fashion, would access it as a string.
  35808. -
  35809. -   Any operand can be accessed as an integer, as an expression or as a
  35810. -string.  You must choose the correct method of access for the kind of
  35811. -value actually stored in the operand.  You would do this based on the
  35812. -expression code of the containing expression.  That is also how you
  35813. -would know how many operands there are.
  35814. -
  35815. -   For example, if X is a `subreg' expression, you know that it has two
  35816. -operands which can be correctly accessed as `XEXP (X, 0)' and `XINT (X,
  35817. -1)'.  If you did `XINT (X, 0)', you would get the address of the
  35818. -expression operand but cast as an integer; that might occasionally be
  35819. -useful, but it would be cleaner to write `(int) XEXP (X, 0)'.  `XEXP
  35820. -(X, 1)' would also compile without error, and would return the second,
  35821. -integer operand cast as an expression pointer, which would probably
  35822. -result in a crash when accessed.  Nothing stops you from writing `XEXP
  35823. -(X, 28)' either, but this will access memory past the end of the
  35824. -expression with unpredictable results.
  35825. -
  35826. -   Access to operands which are vectors is more complicated.  You can
  35827. -use the macro `XVEC' to get the vector-pointer itself, or the macros
  35828. -`XVECEXP' and `XVECLEN' to access the elements and length of a vector.
  35829. -
  35830. -`XVEC (EXP, IDX)'
  35831. -     Access the vector-pointer which is operand number IDX in EXP.
  35832. -
  35833. -`XVECLEN (EXP, IDX)'
  35834. -     Access the length (number of elements) in the vector which is in
  35835. -     operand number IDX in EXP.  This value is an `int'.
  35836. -
  35837. -`XVECEXP (EXP, IDX, ELTNUM)'
  35838. -     Access element number ELTNUM in the vector which is in operand
  35839. -     number IDX in EXP.  This value is an RTX.
  35840. -
  35841. -     It is up to you to make sure that ELTNUM is not negative and is
  35842. -     less than `XVECLEN (EXP, IDX)'.
  35843. -
  35844. -   All the macros defined in this section expand into lvalues and
  35845. -therefore can be used to assign the operands, lengths and vector
  35846. -elements as well as to access them.
  35847. -
  35848. -
  35849. -File: gcc.info,  Node: Flags,  Next: Machine Modes,  Prev: Accessors,  Up: RTL
  35850. -
  35851. -Flags in an RTL Expression
  35852. -==========================
  35853. -
  35854. -   RTL expressions contain several flags (one-bit bitfields) that are
  35855. -used in certain types of expression.  Most often they are accessed with
  35856. -the following macros:
  35857. -
  35858. -`MEM_VOLATILE_P (X)'
  35859. -     In `mem' expressions, nonzero for volatile memory references.
  35860. -     Stored in the `volatil' field and printed as `/v'.
  35861. -
  35862. -`MEM_IN_STRUCT_P (X)'
  35863. -     In `mem' expressions, nonzero for reference to an entire
  35864. -     structure, union or array, or to a component of one.  Zero for
  35865. -     references to a scalar variable or through a pointer to a scalar.
  35866. -     Stored in the `in_struct' field and printed as `/s'.
  35867. -
  35868. -`REG_LOOP_TEST_P'
  35869. -     In `reg' expressions, nonzero if this register's entire life is
  35870. -     contained in the exit test code for some loop.  Stored in the
  35871. -     `in_struct' field and printed as `/s'.
  35872. -
  35873. -`REG_USERVAR_P (X)'
  35874. -     In a `reg', nonzero if it corresponds to a variable present in the
  35875. -     user's source code.  Zero for temporaries generated internally by
  35876. -     the compiler.  Stored in the `volatil' field and printed as `/v'.
  35877. -
  35878. -`REG_FUNCTION_VALUE_P (X)'
  35879. -     Nonzero in a `reg' if it is the place in which this function's
  35880. -     value is going to be returned.  (This happens only in a hard
  35881. -     register.)  Stored in the `integrated' field and printed as `/i'.
  35882. -
  35883. -     The same hard register may be used also for collecting the values
  35884. -     of functions called by this one, but `REG_FUNCTION_VALUE_P' is zero
  35885. -     in this kind of use.
  35886. -
  35887. -`SUBREG_PROMOTED_VAR_P'
  35888. -     Nonzero in a `subreg' if it was made when accessing an object that
  35889. -     was promoted to a wider mode in accord with the `PROMOTED_MODE'
  35890. -     machine description macro (*note Storage Layout::.).  In this
  35891. -     case, the mode of the `subreg' is the declared mode of the object
  35892. -     and the mode of `SUBREG_REG' is the mode of the register that
  35893. -     holds the object.  Promoted variables are always either sign- or
  35894. -     zero-extended to the wider mode on every assignment.  Stored in
  35895. -     the `in_struct' field and printed as `/s'.
  35896. -
  35897. -`SUBREG_PROMOTED_UNSIGNED_P'
  35898. -     Nonzero in a `subreg' that has `SUBREG_PROMOTED_VAR_P' nonzero if
  35899. -     the object being referenced is kept zero-extended and zero if it
  35900. -     is kept sign-extended.  Stored in the `unchanging' field and
  35901. -     printed as `/u'.
  35902. -
  35903. -`RTX_UNCHANGING_P (X)'
  35904. -     Nonzero in a `reg' or `mem' if the value is not changed.  (This
  35905. -     flag is not set for memory references via pointers to constants.
  35906. -     Such pointers only guarantee that the object will not be changed
  35907. -     explicitly by the current function.  The object might be changed by
  35908. -     other functions or by aliasing.)  Stored in the `unchanging' field
  35909. -     and printed as `/u'.
  35910. -
  35911. -`RTX_INTEGRATED_P (INSN)'
  35912. -     Nonzero in an insn if it resulted from an in-line function call.
  35913. -     Stored in the `integrated' field and printed as `/i'.  This may be
  35914. -     deleted; nothing currently depends on it.
  35915. -
  35916. -`SYMBOL_REF_USED (X)'
  35917. -     In a `symbol_ref', indicates that X has been used.  This is
  35918. -     normally only used to ensure that X is only declared external
  35919. -     once.  Stored in the `used' field.
  35920. -
  35921. -`SYMBOL_REF_FLAG (X)'
  35922. -     In a `symbol_ref', this is used as a flag for machine-specific
  35923. -     purposes.  Stored in the `volatil' field and printed as `/v'.
  35924. -
  35925. -`LABEL_OUTSIDE_LOOP_P'
  35926. -     In `label_ref' expressions, nonzero if this is a reference to a
  35927. -     label that is outside the innermost loop containing the reference
  35928. -     to the label.  Stored in the `in_struct' field and printed as `/s'.
  35929. -
  35930. -`INSN_DELETED_P (INSN)'
  35931. -     In an insn, nonzero if the insn has been deleted.  Stored in the
  35932. -     `volatil' field and printed as `/v'.
  35933. -
  35934. -`INSN_ANNULLED_BRANCH_P (INSN)'
  35935. -     In an `insn' in the delay slot of a branch insn, indicates that an
  35936. -     annulling branch should be used.  See the discussion under
  35937. -     `sequence' below.  Stored in the `unchanging' field and printed as
  35938. -     `/u'.
  35939. -
  35940. -`INSN_FROM_TARGET_P (INSN)'
  35941. -     In an `insn' in a delay slot of a branch, indicates that the insn
  35942. -     is from the target of the branch.  If the branch insn has
  35943. -     `INSN_ANNULLED_BRANCH_P' set, this insn should only be executed if
  35944. -     the branch is taken.  For annulled branches with this bit clear,
  35945. -     the insn should be executed only if the branch is not taken.
  35946. -     Stored in the `in_struct' field and printed as `/s'.
  35947. -
  35948. -`CONSTANT_POOL_ADDRESS_P (X)'
  35949. -     Nonzero in a `symbol_ref' if it refers to part of the current
  35950. -     function's "constants pool".  These are addresses close to the
  35951. -     beginning of the function, and GNU CC assumes they can be addressed
  35952. -     directly (perhaps with the help of base registers).  Stored in the
  35953. -     `unchanging' field and printed as `/u'.
  35954. -
  35955. -`CONST_CALL_P (X)'
  35956. -     In a `call_insn', indicates that the insn represents a call to a
  35957. -     const function.  Stored in the `unchanging' field and printed as
  35958. -     `/u'.
  35959. -
  35960. -`LABEL_PRESERVE_P (X)'
  35961. -     In a `code_label', indicates that the label can never be deleted.
  35962. -     Labels referenced by a non-local goto will have this bit set.
  35963. -     Stored in the `in_struct' field and printed as `/s'.
  35964. -
  35965. -`SCHED_GROUP_P (INSN)'
  35966. -     During instruction scheduling, in an insn, indicates that the
  35967. -     previous insn must be scheduled together with this insn.  This is
  35968. -     used to ensure that certain groups of instructions will not be
  35969. -     split up by the instruction scheduling pass, for example, `use'
  35970. -     insns before a `call_insn' may not be separated from the
  35971. -     `call_insn'.  Stored in the `in_struct' field and printed as `/s'.
  35972. -
  35973. -   These are the fields which the above macros refer to:
  35974. -
  35975. -`used'
  35976. -     Normally, this flag is used only momentarily, at the end of RTL
  35977. -     generation for a function, to count the number of times an
  35978. -     expression appears in insns.  Expressions that appear more than
  35979. -     once are copied, according to the rules for shared structure
  35980. -     (*note Sharing::.).
  35981. -
  35982. -     In a `symbol_ref', it indicates that an external declaration for
  35983. -     the symbol has already been written.
  35984. -
  35985. -     In a `reg', it is used by the leaf register renumbering code to
  35986. -     ensure that each register is only renumbered once.
  35987. -
  35988. -`volatil'
  35989. -     This flag is used in `mem', `symbol_ref' and `reg' expressions and
  35990. -     in insns.  In RTL dump files, it is printed as `/v'.
  35991. -
  35992. -     In a `mem' expression, it is 1 if the memory reference is volatile.
  35993. -     Volatile memory references may not be deleted, reordered or
  35994. -     combined.
  35995. -
  35996. -     In a `symbol_ref' expression, it is used for machine-specific
  35997. -     purposes.
  35998. -
  35999. -     In a `reg' expression, it is 1 if the value is a user-level
  36000. -     variable.  0 indicates an internal compiler temporary.
  36001. -
  36002. -     In an insn, 1 means the insn has been deleted.
  36003. -
  36004. -`in_struct'
  36005. -     In `mem' expressions, it is 1 if the memory datum referred to is
  36006. -     all or part of a structure or array; 0 if it is (or might be) a
  36007. -     scalar variable.  A reference through a C pointer has 0 because
  36008. -     the pointer might point to a scalar variable.  This information
  36009. -     allows the compiler to determine something about possible cases of
  36010. -     aliasing.
  36011. -
  36012. -     In an insn in the delay slot of a branch, 1 means that this insn
  36013. -     is from the target of the branch.
  36014. -
  36015. -     During instruction scheduling, in an insn, 1 means that this insn
  36016. -     must be scheduled as part of a group together with the previous
  36017. -     insn.
  36018. -
  36019. -     In `reg' expressions, it is 1 if the register has its entire life
  36020. -     contained within the test expression of some loop.
  36021. -
  36022. -     In `subreg' expressions, 1 means that the `subreg' is accessing an
  36023. -     object that has had its mode promoted from a wider mode.
  36024. -
  36025. -     In `label_ref' expressions, 1 means that the referenced label is
  36026. -     outside the innermost loop containing the insn in which the
  36027. -     `label_ref' was found.
  36028. -
  36029. -     In `code_label' expressions, it is 1 if the label may never be
  36030. -     deleted.  This is used for labels which are the target of
  36031. -     non-local gotos.
  36032. -
  36033. -     In an RTL dump, this flag is represented as `/s'.
  36034. -
  36035. -`unchanging'
  36036. -     In `reg' and `mem' expressions, 1 means that the value of the
  36037. -     expression never changes.
  36038. -
  36039. -     In `subreg' expressions, it is 1 if the `subreg' references an
  36040. -     unsigned object whose mode has been promoted to a wider mode.
  36041. -
  36042. -     In an insn, 1 means that this is an annulling branch.
  36043. -
  36044. -     In a `symbol_ref' expression, 1 means that this symbol addresses
  36045. -     something in the per-function constants pool.
  36046. -
  36047. -     In a `call_insn', 1 means that this instruction is a call to a
  36048. -     const function.
  36049. -
  36050. -     In an RTL dump, this flag is represented as `/u'.
  36051. -
  36052. -`integrated'
  36053. -     In some kinds of expressions, including insns, this flag means the
  36054. -     rtl was produced by procedure integration.
  36055. -
  36056. -     In a `reg' expression, this flag indicates the register containing
  36057. -     the value to be returned by the current function.  On machines
  36058. -     that pass parameters in registers, the same register number may be
  36059. -     used for parameters as well, but this flag is not set on such uses.
  36060. -
  36061. diff -rup --new-file baseline/fsf/gcc/gcc.info-14 amiga/fsf/gcc/gcc.info-14
  36062. --- baseline/fsf/gcc/gcc.info-14    Sat Jun 29 09:38:03 1996
  36063. +++ amiga/fsf/gcc/gcc.info-14    Wed Dec 31 17:00:00 1969
  36064. @@ -1,970 +0,0 @@
  36065. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  36066. -file gcc.texi.
  36067. -
  36068. -   This file documents the use and the internals of the GNU compiler.
  36069. -
  36070. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  36071. -Boston, MA 02111-1307 USA
  36072. -
  36073. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  36074. -Foundation, Inc.
  36075. -
  36076. -   Permission is granted to make and distribute verbatim copies of this
  36077. -manual provided the copyright notice and this permission notice are
  36078. -preserved on all copies.
  36079. -
  36080. -   Permission is granted to copy and distribute modified versions of
  36081. -this manual under the conditions for verbatim copying, provided also
  36082. -that the sections entitled "GNU General Public License," "Funding for
  36083. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  36084. -included exactly as in the original, and provided that the entire
  36085. -resulting derived work is distributed under the terms of a permission
  36086. -notice identical to this one.
  36087. -
  36088. -   Permission is granted to copy and distribute translations of this
  36089. -manual into another language, under the above conditions for modified
  36090. -versions, except that the sections entitled "GNU General Public
  36091. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  36092. -`Look And Feel'", and this permission notice, may be included in
  36093. -translations approved by the Free Software Foundation instead of in the
  36094. -original English.
  36095. -
  36096. -
  36097. -File: gcc.info,  Node: Machine Modes,  Next: Constants,  Prev: Flags,  Up: RTL
  36098. -
  36099. -Machine Modes
  36100. -=============
  36101. -
  36102. -   A machine mode describes a size of data object and the
  36103. -representation used for it.  In the C code, machine modes are
  36104. -represented by an enumeration type, `enum machine_mode', defined in
  36105. -`machmode.def'.  Each RTL expression has room for a machine mode and so
  36106. -do certain kinds of tree expressions (declarations and types, to be
  36107. -precise).
  36108. -
  36109. -   In debugging dumps and machine descriptions, the machine mode of an
  36110. -RTL expression is written after the expression code with a colon to
  36111. -separate them.  The letters `mode' which appear at the end of each
  36112. -machine mode name are omitted.  For example, `(reg:SI 38)' is a `reg'
  36113. -expression with machine mode `SImode'.  If the mode is `VOIDmode', it
  36114. -is not written at all.
  36115. -
  36116. -   Here is a table of machine modes.  The term "byte" below refers to an
  36117. -object of `BITS_PER_UNIT' bits (*note Storage Layout::.).
  36118. -
  36119. -`QImode'
  36120. -     "Quarter-Integer" mode represents a single byte treated as an
  36121. -     integer.
  36122. -
  36123. -`HImode'
  36124. -     "Half-Integer" mode represents a two-byte integer.
  36125. -
  36126. -`PSImode'
  36127. -     "Partial Single Integer" mode represents an integer which occupies
  36128. -     four bytes but which doesn't really use all four.  On some
  36129. -     machines, this is the right mode to use for pointers.
  36130. -
  36131. -`SImode'
  36132. -     "Single Integer" mode represents a four-byte integer.
  36133. -
  36134. -`PDImode'
  36135. -     "Partial Double Integer" mode represents an integer which occupies
  36136. -     eight bytes but which doesn't really use all eight.  On some
  36137. -     machines, this is the right mode to use for certain pointers.
  36138. -
  36139. -`DImode'
  36140. -     "Double Integer" mode represents an eight-byte integer.
  36141. -
  36142. -`TImode'
  36143. -     "Tetra Integer" (?) mode represents a sixteen-byte integer.
  36144. -
  36145. -`SFmode'
  36146. -     "Single Floating" mode represents a single-precision (four byte)
  36147. -     floating point number.
  36148. -
  36149. -`DFmode'
  36150. -     "Double Floating" mode represents a double-precision (eight byte)
  36151. -     floating point number.
  36152. -
  36153. -`XFmode'
  36154. -     "Extended Floating" mode represents a triple-precision (twelve
  36155. -     byte) floating point number.  This mode is used for IEEE extended
  36156. -     floating point.  On some systems not all bits within these bytes
  36157. -     will actually be used.
  36158. -
  36159. -`TFmode'
  36160. -     "Tetra Floating" mode represents a quadruple-precision (sixteen
  36161. -     byte) floating point number.
  36162. -
  36163. -`CCmode'
  36164. -     "Condition Code" mode represents the value of a condition code,
  36165. -     which is a machine-specific set of bits used to represent the
  36166. -     result of a comparison operation.  Other machine-specific modes
  36167. -     may also be used for the condition code.  These modes are not used
  36168. -     on machines that use `cc0' (see *note Condition Code::.).
  36169. -
  36170. -`BLKmode'
  36171. -     "Block" mode represents values that are aggregates to which none of
  36172. -     the other modes apply.  In RTL, only memory references can have
  36173. -     this mode, and only if they appear in string-move or vector
  36174. -     instructions.  On machines which have no such instructions,
  36175. -     `BLKmode' will not appear in RTL.
  36176. -
  36177. -`VOIDmode'
  36178. -     Void mode means the absence of a mode or an unspecified mode.  For
  36179. -     example, RTL expressions of code `const_int' have mode `VOIDmode'
  36180. -     because they can be taken to have whatever mode the context
  36181. -     requires.  In debugging dumps of RTL, `VOIDmode' is expressed by
  36182. -     the absence of any mode.
  36183. -
  36184. -`SCmode, DCmode, XCmode, TCmode'
  36185. -     These modes stand for a complex number represented as a pair of
  36186. -     floating point values.  The floating point values are in `SFmode',
  36187. -     `DFmode', `XFmode', and `TFmode', respectively.
  36188. -
  36189. -`CQImode, CHImode, CSImode, CDImode, CTImode, COImode'
  36190. -     These modes stand for a complex number represented as a pair of
  36191. -     integer values.  The integer values are in `QImode', `HImode',
  36192. -     `SImode', `DImode', `TImode', and `OImode', respectively.
  36193. -
  36194. -   The machine description defines `Pmode' as a C macro which expands
  36195. -into the machine mode used for addresses.  Normally this is the mode
  36196. -whose size is `BITS_PER_WORD', `SImode' on 32-bit machines.
  36197. -
  36198. -   The only modes which a machine description must support are
  36199. -`QImode', and the modes corresponding to `BITS_PER_WORD',
  36200. -`FLOAT_TYPE_SIZE' and `DOUBLE_TYPE_SIZE'.  The compiler will attempt to
  36201. -use `DImode' for 8-byte structures and unions, but this can be
  36202. -prevented by overriding the definition of `MAX_FIXED_MODE_SIZE'.
  36203. -Alternatively, you can have the compiler use `TImode' for 16-byte
  36204. -structures and unions.  Likewise, you can arrange for the C type `short
  36205. -int' to avoid using `HImode'.
  36206. -
  36207. -   Very few explicit references to machine modes remain in the compiler
  36208. -and these few references will soon be removed.  Instead, the machine
  36209. -modes are divided into mode classes.  These are represented by the
  36210. -enumeration type `enum mode_class' defined in `machmode.h'.  The
  36211. -possible mode classes are:
  36212. -
  36213. -`MODE_INT'
  36214. -     Integer modes.  By default these are `QImode', `HImode', `SImode',
  36215. -     `DImode', and `TImode'.
  36216. -
  36217. -`MODE_PARTIAL_INT'
  36218. -     The "partial integer" modes, `PSImode' and `PDImode'.
  36219. -
  36220. -`MODE_FLOAT'
  36221. -     floating point modes.  By default these are `SFmode', `DFmode',
  36222. -     `XFmode' and `TFmode'.
  36223. -
  36224. -`MODE_COMPLEX_INT'
  36225. -     Complex integer modes.  (These are not currently implemented).
  36226. -
  36227. -`MODE_COMPLEX_FLOAT'
  36228. -     Complex floating point modes.  By default these are `SCmode',
  36229. -     `DCmode', `XCmode', and `TCmode'.
  36230. -
  36231. -`MODE_FUNCTION'
  36232. -     Algol or Pascal function variables including a static chain.
  36233. -     (These are not currently implemented).
  36234. -
  36235. -`MODE_CC'
  36236. -     Modes representing condition code values.  These are `CCmode' plus
  36237. -     any modes listed in the `EXTRA_CC_MODES' macro.  *Note Jump
  36238. -     Patterns::, also see *Note Condition Code::.
  36239. -
  36240. -`MODE_RANDOM'
  36241. -     This is a catchall mode class for modes which don't fit into the
  36242. -     above classes.  Currently `VOIDmode' and `BLKmode' are in
  36243. -     `MODE_RANDOM'.
  36244. -
  36245. -   Here are some C macros that relate to machine modes:
  36246. -
  36247. -`GET_MODE (X)'
  36248. -     Returns the machine mode of the RTX X.
  36249. -
  36250. -`PUT_MODE (X, NEWMODE)'
  36251. -     Alters the machine mode of the RTX X to be NEWMODE.
  36252. -
  36253. -`NUM_MACHINE_MODES'
  36254. -     Stands for the number of machine modes available on the target
  36255. -     machine.  This is one greater than the largest numeric value of any
  36256. -     machine mode.
  36257. -
  36258. -`GET_MODE_NAME (M)'
  36259. -     Returns the name of mode M as a string.
  36260. -
  36261. -`GET_MODE_CLASS (M)'
  36262. -     Returns the mode class of mode M.
  36263. -
  36264. -`GET_MODE_WIDER_MODE (M)'
  36265. -     Returns the next wider natural mode.  For example, the expression
  36266. -     `GET_MODE_WIDER_MODE (QImode)' returns `HImode'.
  36267. -
  36268. -`GET_MODE_SIZE (M)'
  36269. -     Returns the size in bytes of a datum of mode M.
  36270. -
  36271. -`GET_MODE_BITSIZE (M)'
  36272. -     Returns the size in bits of a datum of mode M.
  36273. -
  36274. -`GET_MODE_MASK (M)'
  36275. -     Returns a bitmask containing 1 for all bits in a word that fit
  36276. -     within mode M.  This macro can only be used for modes whose
  36277. -     bitsize is less than or equal to `HOST_BITS_PER_INT'.
  36278. -
  36279. -`GET_MODE_ALIGNMENT (M))'
  36280. -     Return the required alignment, in bits, for an object of mode M.
  36281. -
  36282. -`GET_MODE_UNIT_SIZE (M)'
  36283. -     Returns the size in bytes of the subunits of a datum of mode M.
  36284. -     This is the same as `GET_MODE_SIZE' except in the case of complex
  36285. -     modes.  For them, the unit size is the size of the real or
  36286. -     imaginary part.
  36287. -
  36288. -`GET_MODE_NUNITS (M)'
  36289. -     Returns the number of units contained in a mode, i.e.,
  36290. -     `GET_MODE_SIZE' divided by `GET_MODE_UNIT_SIZE'.
  36291. -
  36292. -`GET_CLASS_NARROWEST_MODE (C)'
  36293. -     Returns the narrowest mode in mode class C.
  36294. -
  36295. -   The global variables `byte_mode' and `word_mode' contain modes whose
  36296. -classes are `MODE_INT' and whose bitsizes are either `BITS_PER_UNIT' or
  36297. -`BITS_PER_WORD', respectively.  On 32-bit machines, these are `QImode'
  36298. -and `SImode', respectively.
  36299. -
  36300. -
  36301. -File: gcc.info,  Node: Constants,  Next: Regs and Memory,  Prev: Machine Modes,  Up: RTL
  36302. -
  36303. -Constant Expression Types
  36304. -=========================
  36305. -
  36306. -   The simplest RTL expressions are those that represent constant
  36307. -values.
  36308. -
  36309. -`(const_int I)'
  36310. -     This type of expression represents the integer value I.  I is
  36311. -     customarily accessed with the macro `INTVAL' as in `INTVAL (EXP)',
  36312. -     which is equivalent to `XWINT (EXP, 0)'.
  36313. -
  36314. -     There is only one expression object for the integer value zero; it
  36315. -     is the value of the variable `const0_rtx'.  Likewise, the only
  36316. -     expression for integer value one is found in `const1_rtx', the only
  36317. -     expression for integer value two is found in `const2_rtx', and the
  36318. -     only expression for integer value negative one is found in
  36319. -     `constm1_rtx'.  Any attempt to create an expression of code
  36320. -     `const_int' and value zero, one, two or negative one will return
  36321. -     `const0_rtx', `const1_rtx', `const2_rtx' or `constm1_rtx' as
  36322. -     appropriate.
  36323. -
  36324. -     Similarly, there is only one object for the integer whose value is
  36325. -     `STORE_FLAG_VALUE'.  It is found in `const_true_rtx'.  If
  36326. -     `STORE_FLAG_VALUE' is one, `const_true_rtx' and `const1_rtx' will
  36327. -     point to the same object.  If `STORE_FLAG_VALUE' is -1,
  36328. -     `const_true_rtx' and `constm1_rtx' will point to the same object.
  36329. -
  36330. -`(const_double:M ADDR I0 I1 ...)'
  36331. -     Represents either a floating-point constant of mode M or an
  36332. -     integer constant too large to fit into `HOST_BITS_PER_WIDE_INT'
  36333. -     bits but small enough to fit within twice that number of bits (GNU
  36334. -     CC does not provide a mechanism to represent even larger
  36335. -     constants).  In the latter case, M will be `VOIDmode'.
  36336. -
  36337. -     ADDR is used to contain the `mem' expression that corresponds to
  36338. -     the location in memory that at which the constant can be found.  If
  36339. -     it has not been allocated a memory location, but is on the chain
  36340. -     of all `const_double' expressions in this compilation (maintained
  36341. -     using an undisplayed field), ADDR contains `const0_rtx'.  If it is
  36342. -     not on the chain, ADDR contains `cc0_rtx'.  ADDR is customarily
  36343. -     accessed with the macro `CONST_DOUBLE_MEM' and the chain field via
  36344. -     `CONST_DOUBLE_CHAIN'.
  36345. -
  36346. -     If M is `VOIDmode', the bits of the value are stored in I0 and I1.
  36347. -     I0 is customarily accessed with the macro `CONST_DOUBLE_LOW' and
  36348. -     I1 with `CONST_DOUBLE_HIGH'.
  36349. -
  36350. -     If the constant is floating point (regardless of its precision),
  36351. -     then the number of integers used to store the value depends on the
  36352. -     size of `REAL_VALUE_TYPE' (*note Cross-compilation::.).  The
  36353. -     integers represent a floating point number, but not precisely in
  36354. -     the target machine's or host machine's floating point format.  To
  36355. -     convert them to the precise bit pattern used by the target
  36356. -     machine, use the macro `REAL_VALUE_TO_TARGET_DOUBLE' and friends
  36357. -     (*note Data Output::.).
  36358. -
  36359. -     The macro `CONST0_RTX (MODE)' refers to an expression with value 0
  36360. -     in mode MODE.  If mode MODE is of mode class `MODE_INT', it
  36361. -     returns `const0_rtx'.  Otherwise, it returns a `CONST_DOUBLE'
  36362. -     expression in mode MODE.  Similarly, the macro `CONST1_RTX (MODE)'
  36363. -     refers to an expression with value 1 in mode MODE and similarly
  36364. -     for `CONST2_RTX'.
  36365. -
  36366. -`(const_string STR)'
  36367. -     Represents a constant string with value STR.  Currently this is
  36368. -     used only for insn attributes (*note Insn Attributes::.) since
  36369. -     constant strings in C are placed in memory.
  36370. -
  36371. -`(symbol_ref:MODE SYMBOL)'
  36372. -     Represents the value of an assembler label for data.  SYMBOL is a
  36373. -     string that describes the name of the assembler label.  If it
  36374. -     starts with a `*', the label is the rest of SYMBOL not including
  36375. -     the `*'.  Otherwise, the label is SYMBOL, usually prefixed with
  36376. -     `_'.
  36377. -
  36378. -     The `symbol_ref' contains a mode, which is usually `Pmode'.
  36379. -     Usually that is the only mode for which a symbol is directly valid.
  36380. -
  36381. -`(label_ref LABEL)'
  36382. -     Represents the value of an assembler label for code.  It contains
  36383. -     one operand, an expression, which must be a `code_label' that
  36384. -     appears in the instruction sequence to identify the place where
  36385. -     the label should go.
  36386. -
  36387. -     The reason for using a distinct expression type for code label
  36388. -     references is so that jump optimization can distinguish them.
  36389. -
  36390. -`(const:M EXP)'
  36391. -     Represents a constant that is the result of an assembly-time
  36392. -     arithmetic computation.  The operand, EXP, is an expression that
  36393. -     contains only constants (`const_int', `symbol_ref' and `label_ref'
  36394. -     expressions) combined with `plus' and `minus'.  However, not all
  36395. -     combinations are valid, since the assembler cannot do arbitrary
  36396. -     arithmetic on relocatable symbols.
  36397. -
  36398. -     M should be `Pmode'.
  36399. -
  36400. -`(high:M EXP)'
  36401. -     Represents the high-order bits of EXP, usually a `symbol_ref'.
  36402. -     The number of bits is machine-dependent and is normally the number
  36403. -     of bits specified in an instruction that initializes the high
  36404. -     order bits of a register.  It is used with `lo_sum' to represent
  36405. -     the typical two-instruction sequence used in RISC machines to
  36406. -     reference a global memory location.
  36407. -
  36408. -     M should be `Pmode'.
  36409. -
  36410. -
  36411. -File: gcc.info,  Node: Regs and Memory,  Next: Arithmetic,  Prev: Constants,  Up: RTL
  36412. -
  36413. -Registers and Memory
  36414. -====================
  36415. -
  36416. -   Here are the RTL expression types for describing access to machine
  36417. -registers and to main memory.
  36418. -
  36419. -`(reg:M N)'
  36420. -     For small values of the integer N (those that are less than
  36421. -     `FIRST_PSEUDO_REGISTER'), this stands for a reference to machine
  36422. -     register number N: a "hard register".  For larger values of N, it
  36423. -     stands for a temporary value or "pseudo register".  The compiler's
  36424. -     strategy is to generate code assuming an unlimited number of such
  36425. -     pseudo registers, and later convert them into hard registers or
  36426. -     into memory references.
  36427. -
  36428. -     M is the machine mode of the reference.  It is necessary because
  36429. -     machines can generally refer to each register in more than one
  36430. -     mode.  For example, a register may contain a full word but there
  36431. -     may be instructions to refer to it as a half word or as a single
  36432. -     byte, as well as instructions to refer to it as a floating point
  36433. -     number of various precisions.
  36434. -
  36435. -     Even for a register that the machine can access in only one mode,
  36436. -     the mode must always be specified.
  36437. -
  36438. -     The symbol `FIRST_PSEUDO_REGISTER' is defined by the machine
  36439. -     description, since the number of hard registers on the machine is
  36440. -     an invariant characteristic of the machine.  Note, however, that
  36441. -     not all of the machine registers must be general registers.  All
  36442. -     the machine registers that can be used for storage of data are
  36443. -     given hard register numbers, even those that can be used only in
  36444. -     certain instructions or can hold only certain types of data.
  36445. -
  36446. -     A hard register may be accessed in various modes throughout one
  36447. -     function, but each pseudo register is given a natural mode and is
  36448. -     accessed only in that mode.  When it is necessary to describe an
  36449. -     access to a pseudo register using a nonnatural mode, a `subreg'
  36450. -     expression is used.
  36451. -
  36452. -     A `reg' expression with a machine mode that specifies more than
  36453. -     one word of data may actually stand for several consecutive
  36454. -     registers.  If in addition the register number specifies a
  36455. -     hardware register, then it actually represents several consecutive
  36456. -     hardware registers starting with the specified one.
  36457. -
  36458. -     Each pseudo register number used in a function's RTL code is
  36459. -     represented by a unique `reg' expression.
  36460. -
  36461. -     Some pseudo register numbers, those within the range of
  36462. -     `FIRST_VIRTUAL_REGISTER' to `LAST_VIRTUAL_REGISTER' only appear
  36463. -     during the RTL generation phase and are eliminated before the
  36464. -     optimization phases.  These represent locations in the stack frame
  36465. -     that cannot be determined until RTL generation for the function
  36466. -     has been completed.  The following virtual register numbers are
  36467. -     defined:
  36468. -
  36469. -    `VIRTUAL_INCOMING_ARGS_REGNUM'
  36470. -          This points to the first word of the incoming arguments
  36471. -          passed on the stack.  Normally these arguments are placed
  36472. -          there by the caller, but the callee may have pushed some
  36473. -          arguments that were previously passed in registers.
  36474. -
  36475. -          When RTL generation is complete, this virtual register is
  36476. -          replaced by the sum of the register given by
  36477. -          `ARG_POINTER_REGNUM' and the value of `FIRST_PARM_OFFSET'.
  36478. -
  36479. -    `VIRTUAL_STACK_VARS_REGNUM'
  36480. -          If `FRAME_GROWS_DOWNWARD' is defined, this points to
  36481. -          immediately above the first variable on the stack.
  36482. -          Otherwise, it points to the first variable on the stack.
  36483. -
  36484. -          `VIRTUAL_STACK_VARS_REGNUM' is replaced with the sum of the
  36485. -          register given by `FRAME_POINTER_REGNUM' and the value
  36486. -          `STARTING_FRAME_OFFSET'.
  36487. -
  36488. -    `VIRTUAL_STACK_DYNAMIC_REGNUM'
  36489. -          This points to the location of dynamically allocated memory
  36490. -          on the stack immediately after the stack pointer has been
  36491. -          adjusted by the amount of memory desired.
  36492. -
  36493. -          This virtual register is replaced by the sum of the register
  36494. -          given by `STACK_POINTER_REGNUM' and the value
  36495. -          `STACK_DYNAMIC_OFFSET'.
  36496. -
  36497. -    `VIRTUAL_OUTGOING_ARGS_REGNUM'
  36498. -          This points to the location in the stack at which outgoing
  36499. -          arguments should be written when the stack is pre-pushed
  36500. -          (arguments pushed using push insns should always use
  36501. -          `STACK_POINTER_REGNUM').
  36502. -
  36503. -          This virtual register is replaced by the sum of the register
  36504. -          given by `STACK_POINTER_REGNUM' and the value
  36505. -          `STACK_POINTER_OFFSET'.
  36506. -
  36507. -`(subreg:M REG WORDNUM)'
  36508. -     `subreg' expressions are used to refer to a register in a machine
  36509. -     mode other than its natural one, or to refer to one register of a
  36510. -     multi-word `reg' that actually refers to several registers.
  36511. -
  36512. -     Each pseudo-register has a natural mode.  If it is necessary to
  36513. -     operate on it in a different mode--for example, to perform a
  36514. -     fullword move instruction on a pseudo-register that contains a
  36515. -     single byte--the pseudo-register must be enclosed in a `subreg'.
  36516. -     In such a case, WORDNUM is zero.
  36517. -
  36518. -     Usually M is at least as narrow as the mode of REG, in which case
  36519. -     it is restricting consideration to only the bits of REG that are
  36520. -     in M.
  36521. -
  36522. -     Sometimes M is wider than the mode of REG.  These `subreg'
  36523. -     expressions are often called "paradoxical".  They are used in
  36524. -     cases where we want to refer to an object in a wider mode but do
  36525. -     not care what value the additional bits have.  The reload pass
  36526. -     ensures that paradoxical references are only made to hard
  36527. -     registers.
  36528. -
  36529. -     The other use of `subreg' is to extract the individual registers of
  36530. -     a multi-register value.  Machine modes such as `DImode' and
  36531. -     `TImode' can indicate values longer than a word, values which
  36532. -     usually require two or more consecutive registers.  To access one
  36533. -     of the registers, use a `subreg' with mode `SImode' and a WORDNUM
  36534. -     that says which register.
  36535. -
  36536. -     Storing in a non-paradoxical `subreg' has undefined results for
  36537. -     bits belonging to the same word as the `subreg'.  This laxity makes
  36538. -     it easier to generate efficient code for such instructions.  To
  36539. -     represent an instruction that preserves all the bits outside of
  36540. -     those in the `subreg', use `strict_low_part' around the `subreg'.
  36541. -
  36542. -     The compilation parameter `WORDS_BIG_ENDIAN', if set to 1, says
  36543. -     that word number zero is the most significant part; otherwise, it
  36544. -     is the least significant part.
  36545. -
  36546. -     Between the combiner pass and the reload pass, it is possible to
  36547. -     have a paradoxical `subreg' which contains a `mem' instead of a
  36548. -     `reg' as its first operand.  After the reload pass, it is also
  36549. -     possible to have a non-paradoxical `subreg' which contains a
  36550. -     `mem'; this usually occurs when the `mem' is a stack slot which
  36551. -     replaced a pseudo register.
  36552. -
  36553. -     Note that it is not valid to access a `DFmode' value in `SFmode'
  36554. -     using a `subreg'.  On some machines the most significant part of a
  36555. -     `DFmode' value does not have the same format as a single-precision
  36556. -     floating value.
  36557. -
  36558. -     It is also not valid to access a single word of a multi-word value
  36559. -     in a hard register when less registers can hold the value than
  36560. -     would be expected from its size.  For example, some 32-bit
  36561. -     machines have floating-point registers that can hold an entire
  36562. -     `DFmode' value.  If register 10 were such a register `(subreg:SI
  36563. -     (reg:DF 10) 1)' would be invalid because there is no way to
  36564. -     convert that reference to a single machine register.  The reload
  36565. -     pass prevents `subreg' expressions such as these from being formed.
  36566. -
  36567. -     The first operand of a `subreg' expression is customarily accessed
  36568. -     with the `SUBREG_REG' macro and the second operand is customarily
  36569. -     accessed with the `SUBREG_WORD' macro.
  36570. -
  36571. -`(scratch:M)'
  36572. -     This represents a scratch register that will be required for the
  36573. -     execution of a single instruction and not used subsequently.  It is
  36574. -     converted into a `reg' by either the local register allocator or
  36575. -     the reload pass.
  36576. -
  36577. -     `scratch' is usually present inside a `clobber' operation (*note
  36578. -     Side Effects::.).
  36579. -
  36580. -`(cc0)'
  36581. -     This refers to the machine's condition code register.  It has no
  36582. -     operands and may not have a machine mode.  There are two ways to
  36583. -     use it:
  36584. -
  36585. -        * To stand for a complete set of condition code flags.  This is
  36586. -          best on most machines, where each comparison sets the entire
  36587. -          series of flags.
  36588. -
  36589. -          With this technique, `(cc0)' may be validly used in only two
  36590. -          contexts: as the destination of an assignment (in test and
  36591. -          compare instructions) and in comparison operators comparing
  36592. -          against zero (`const_int' with value zero; that is to say,
  36593. -          `const0_rtx').
  36594. -
  36595. -        * To stand for a single flag that is the result of a single
  36596. -          condition.  This is useful on machines that have only a
  36597. -          single flag bit, and in which comparison instructions must
  36598. -          specify the condition to test.
  36599. -
  36600. -          With this technique, `(cc0)' may be validly used in only two
  36601. -          contexts: as the destination of an assignment (in test and
  36602. -          compare instructions) where the source is a comparison
  36603. -          operator, and as the first operand of `if_then_else' (in a
  36604. -          conditional branch).
  36605. -
  36606. -     There is only one expression object of code `cc0'; it is the value
  36607. -     of the variable `cc0_rtx'.  Any attempt to create an expression of
  36608. -     code `cc0' will return `cc0_rtx'.
  36609. -
  36610. -     Instructions can set the condition code implicitly.  On many
  36611. -     machines, nearly all instructions set the condition code based on
  36612. -     the value that they compute or store.  It is not necessary to
  36613. -     record these actions explicitly in the RTL because the machine
  36614. -     description includes a prescription for recognizing the
  36615. -     instructions that do so (by means of the macro
  36616. -     `NOTICE_UPDATE_CC').  *Note Condition Code::.  Only instructions
  36617. -     whose sole purpose is to set the condition code, and instructions
  36618. -     that use the condition code, need mention `(cc0)'.
  36619. -
  36620. -     On some machines, the condition code register is given a register
  36621. -     number and a `reg' is used instead of `(cc0)'.  This is usually the
  36622. -     preferable approach if only a small subset of instructions modify
  36623. -     the condition code.  Other machines store condition codes in
  36624. -     general registers; in such cases a pseudo register should be used.
  36625. -
  36626. -     Some machines, such as the Sparc and RS/6000, have two sets of
  36627. -     arithmetic instructions, one that sets and one that does not set
  36628. -     the condition code.  This is best handled by normally generating
  36629. -     the instruction that does not set the condition code, and making a
  36630. -     pattern that both performs the arithmetic and sets the condition
  36631. -     code register (which would not be `(cc0)' in this case).  For
  36632. -     examples, search for `addcc' and `andcc' in `sparc.md'.
  36633. -
  36634. -`(pc)'
  36635. -     This represents the machine's program counter.  It has no operands
  36636. -     and may not have a machine mode.  `(pc)' may be validly used only
  36637. -     in certain specific contexts in jump instructions.
  36638. -
  36639. -     There is only one expression object of code `pc'; it is the value
  36640. -     of the variable `pc_rtx'.  Any attempt to create an expression of
  36641. -     code `pc' will return `pc_rtx'.
  36642. -
  36643. -     All instructions that do not jump alter the program counter
  36644. -     implicitly by incrementing it, but there is no need to mention
  36645. -     this in the RTL.
  36646. -
  36647. -`(mem:M ADDR)'
  36648. -     This RTX represents a reference to main memory at an address
  36649. -     represented by the expression ADDR.  M specifies how large a unit
  36650. -     of memory is accessed.
  36651. -
  36652. -
  36653. -File: gcc.info,  Node: Arithmetic,  Next: Comparisons,  Prev: Regs and Memory,  Up: RTL
  36654. -
  36655. -RTL Expressions for Arithmetic
  36656. -==============================
  36657. -
  36658. -   Unless otherwise specified, all the operands of arithmetic
  36659. -expressions must be valid for mode M.  An operand is valid for mode M
  36660. -if it has mode M, or if it is a `const_int' or `const_double' and M is
  36661. -a mode of class `MODE_INT'.
  36662. -
  36663. -   For commutative binary operations, constants should be placed in the
  36664. -second operand.
  36665. -
  36666. -`(plus:M X Y)'
  36667. -     Represents the sum of the values represented by X and Y carried
  36668. -     out in machine mode M.
  36669. -
  36670. -`(lo_sum:M X Y)'
  36671. -     Like `plus', except that it represents that sum of X and the
  36672. -     low-order bits of Y.  The number of low order bits is
  36673. -     machine-dependent but is normally the number of bits in a `Pmode'
  36674. -     item minus the number of bits set by the `high' code (*note
  36675. -     Constants::.).
  36676. -
  36677. -     M should be `Pmode'.
  36678. -
  36679. -`(minus:M X Y)'
  36680. -     Like `plus' but represents subtraction.
  36681. -
  36682. -`(compare:M X Y)'
  36683. -     Represents the result of subtracting Y from X for purposes of
  36684. -     comparison.  The result is computed without overflow, as if with
  36685. -     infinite precision.
  36686. -
  36687. -     Of course, machines can't really subtract with infinite precision.
  36688. -     However, they can pretend to do so when only the sign of the
  36689. -     result will be used, which is the case when the result is stored
  36690. -     in the condition code.   And that is the only way this kind of
  36691. -     expression may validly be used: as a value to be stored in the
  36692. -     condition codes.
  36693. -
  36694. -     The mode M is not related to the modes of X and Y, but instead is
  36695. -     the mode of the condition code value.  If `(cc0)' is used, it is
  36696. -     `VOIDmode'.  Otherwise it is some mode in class `MODE_CC', often
  36697. -     `CCmode'.  *Note Condition Code::.
  36698. -
  36699. -     Normally, X and Y must have the same mode.  Otherwise, `compare'
  36700. -     is valid only if the mode of X is in class `MODE_INT' and Y is a
  36701. -     `const_int' or `const_double' with mode `VOIDmode'.  The mode of X
  36702. -     determines what mode the comparison is to be done in; thus it must
  36703. -     not be `VOIDmode'.
  36704. -
  36705. -     If one of the operands is a constant, it should be placed in the
  36706. -     second operand and the comparison code adjusted as appropriate.
  36707. -
  36708. -     A `compare' specifying two `VOIDmode' constants is not valid since
  36709. -     there is no way to know in what mode the comparison is to be
  36710. -     performed; the comparison must either be folded during the
  36711. -     compilation or the first operand must be loaded into a register
  36712. -     while its mode is still known.
  36713. -
  36714. -`(neg:M X)'
  36715. -     Represents the negation (subtraction from zero) of the value
  36716. -     represented by X, carried out in mode M.
  36717. -
  36718. -`(mult:M X Y)'
  36719. -     Represents the signed product of the values represented by X and Y
  36720. -     carried out in machine mode M.
  36721. -
  36722. -     Some machines support a multiplication that generates a product
  36723. -     wider than the operands.  Write the pattern for this as
  36724. -
  36725. -          (mult:M (sign_extend:M X) (sign_extend:M Y))
  36726. -
  36727. -     where M is wider than the modes of X and Y, which need not be the
  36728. -     same.
  36729. -
  36730. -     Write patterns for unsigned widening multiplication similarly using
  36731. -     `zero_extend'.
  36732. -
  36733. -`(div:M X Y)'
  36734. -     Represents the quotient in signed division of X by Y, carried out
  36735. -     in machine mode M.  If M is a floating point mode, it represents
  36736. -     the exact quotient; otherwise, the integerized quotient.
  36737. -
  36738. -     Some machines have division instructions in which the operands and
  36739. -     quotient widths are not all the same; you should represent such
  36740. -     instructions using `truncate' and `sign_extend' as in,
  36741. -
  36742. -          (truncate:M1 (div:M2 X (sign_extend:M2 Y)))
  36743. -
  36744. -`(udiv:M X Y)'
  36745. -     Like `div' but represents unsigned division.
  36746. -
  36747. -`(mod:M X Y)'
  36748. -`(umod:M X Y)'
  36749. -     Like `div' and `udiv' but represent the remainder instead of the
  36750. -     quotient.
  36751. -
  36752. -`(smin:M X Y)'
  36753. -`(smax:M X Y)'
  36754. -     Represents the smaller (for `smin') or larger (for `smax') of X
  36755. -     and Y, interpreted as signed integers in mode M.
  36756. -
  36757. -`(umin:M X Y)'
  36758. -`(umax:M X Y)'
  36759. -     Like `smin' and `smax', but the values are interpreted as unsigned
  36760. -     integers.
  36761. -
  36762. -`(not:M X)'
  36763. -     Represents the bitwise complement of the value represented by X,
  36764. -     carried out in mode M, which must be a fixed-point machine mode.
  36765. -
  36766. -`(and:M X Y)'
  36767. -     Represents the bitwise logical-and of the values represented by X
  36768. -     and Y, carried out in machine mode M, which must be a fixed-point
  36769. -     machine mode.
  36770. -
  36771. -`(ior:M X Y)'
  36772. -     Represents the bitwise inclusive-or of the values represented by X
  36773. -     and Y, carried out in machine mode M, which must be a fixed-point
  36774. -     mode.
  36775. -
  36776. -`(xor:M X Y)'
  36777. -     Represents the bitwise exclusive-or of the values represented by X
  36778. -     and Y, carried out in machine mode M, which must be a fixed-point
  36779. -     mode.
  36780. -
  36781. -`(ashift:M X C)'
  36782. -     Represents the result of arithmetically shifting X left by C
  36783. -     places.  X have mode M, a fixed-point machine mode.  C be a
  36784. -     fixed-point mode or be a constant with mode `VOIDmode'; which mode
  36785. -     is determined by the mode called for in the machine description
  36786. -     entry for the left-shift instruction.  For example, on the Vax,
  36787. -     the mode of C is `QImode' regardless of M.
  36788. -
  36789. -`(lshiftrt:M X C)'
  36790. -`(ashiftrt:M X C)'
  36791. -     Like `ashift' but for right shift.  Unlike the case for left shift,
  36792. -     these two operations are distinct.
  36793. -
  36794. -`(rotate:M X C)'
  36795. -`(rotatert:M X C)'
  36796. -     Similar but represent left and right rotate.  If C is a constant,
  36797. -     use `rotate'.
  36798. -
  36799. -`(abs:M X)'
  36800. -     Represents the absolute value of X, computed in mode M.
  36801. -
  36802. -`(sqrt:M X)'
  36803. -     Represents the square root of X, computed in mode M.  Most often M
  36804. -     will be a floating point mode.
  36805. -
  36806. -`(ffs:M X)'
  36807. -     Represents one plus the index of the least significant 1-bit in X,
  36808. -     represented as an integer of mode M.  (The value is zero if X is
  36809. -     zero.)  The mode of X need not be M; depending on the target
  36810. -     machine, various mode combinations may be valid.
  36811. -
  36812. -
  36813. -File: gcc.info,  Node: Comparisons,  Next: Bit Fields,  Prev: Arithmetic,  Up: RTL
  36814. -
  36815. -Comparison Operations
  36816. -=====================
  36817. -
  36818. -   Comparison operators test a relation on two operands and are
  36819. -considered to represent a machine-dependent nonzero value described by,
  36820. -but not necessarily equal to, `STORE_FLAG_VALUE' (*note Misc::.) if the
  36821. -relation holds, or zero if it does not.  The mode of the comparison
  36822. -operation is independent of the mode of the data being compared.  If
  36823. -the comparison operation is being tested (e.g., the first operand of an
  36824. -`if_then_else'), the mode must be `VOIDmode'.  If the comparison
  36825. -operation is producing data to be stored in some variable, the mode
  36826. -must be in class `MODE_INT'.  All comparison operations producing data
  36827. -must use the same mode, which is machine-specific.
  36828. -
  36829. -   There are two ways that comparison operations may be used.  The
  36830. -comparison operators may be used to compare the condition codes `(cc0)'
  36831. -against zero, as in `(eq (cc0) (const_int 0))'.  Such a construct
  36832. -actually refers to the result of the preceding instruction in which the
  36833. -condition codes were set.  The instructing setting the condition code
  36834. -must be adjacent to the instruction using the condition code; only
  36835. -`note' insns may separate them.
  36836. -
  36837. -   Alternatively, a comparison operation may directly compare two data
  36838. -objects.  The mode of the comparison is determined by the operands; they
  36839. -must both be valid for a common machine mode.  A comparison with both
  36840. -operands constant would be invalid as the machine mode could not be
  36841. -deduced from it, but such a comparison should never exist in RTL due to
  36842. -constant folding.
  36843. -
  36844. -   In the example above, if `(cc0)' were last set to `(compare X Y)',
  36845. -the comparison operation is identical to `(eq X Y)'.  Usually only one
  36846. -style of comparisons is supported on a particular machine, but the
  36847. -combine pass will try to merge the operations to produce the `eq' shown
  36848. -in case it exists in the context of the particular insn involved.
  36849. -
  36850. -   Inequality comparisons come in two flavors, signed and unsigned.
  36851. -Thus, there are distinct expression codes `gt' and `gtu' for signed and
  36852. -unsigned greater-than.  These can produce different results for the same
  36853. -pair of integer values: for example, 1 is signed greater-than -1 but not
  36854. -unsigned greater-than, because -1 when regarded as unsigned is actually
  36855. -`0xffffffff' which is greater than 1.
  36856. -
  36857. -   The signed comparisons are also used for floating point values.
  36858. -Floating point comparisons are distinguished by the machine modes of
  36859. -the operands.
  36860. -
  36861. -`(eq:M X Y)'
  36862. -     1 if the values represented by X and Y are equal, otherwise 0.
  36863. -
  36864. -`(ne:M X Y)'
  36865. -     1 if the values represented by X and Y are not equal, otherwise 0.
  36866. -
  36867. -`(gt:M X Y)'
  36868. -     1 if the X is greater than Y.  If they are fixed-point, the
  36869. -     comparison is done in a signed sense.
  36870. -
  36871. -`(gtu:M X Y)'
  36872. -     Like `gt' but does unsigned comparison, on fixed-point numbers
  36873. -     only.
  36874. -
  36875. -`(lt:M X Y)'
  36876. -`(ltu:M X Y)'
  36877. -     Like `gt' and `gtu' but test for "less than".
  36878. -
  36879. -`(ge:M X Y)'
  36880. -`(geu:M X Y)'
  36881. -     Like `gt' and `gtu' but test for "greater than or equal".
  36882. -
  36883. -`(le:M X Y)'
  36884. -`(leu:M X Y)'
  36885. -     Like `gt' and `gtu' but test for "less than or equal".
  36886. -
  36887. -`(if_then_else COND THEN ELSE)'
  36888. -     This is not a comparison operation but is listed here because it is
  36889. -     always used in conjunction with a comparison operation.  To be
  36890. -     precise, COND is a comparison expression.  This expression
  36891. -     represents a choice, according to COND, between the value
  36892. -     represented by THEN and the one represented by ELSE.
  36893. -
  36894. -     On most machines, `if_then_else' expressions are valid only to
  36895. -     express conditional jumps.
  36896. -
  36897. -`(cond [TEST1 VALUE1 TEST2 VALUE2 ...] DEFAULT)'
  36898. -     Similar to `if_then_else', but more general.  Each of TEST1,
  36899. -     TEST2, ... is performed in turn.  The result of this expression is
  36900. -     the VALUE corresponding to the first non-zero test, or DEFAULT if
  36901. -     none of the tests are non-zero expressions.
  36902. -
  36903. -     This is currently not valid for instruction patterns and is
  36904. -     supported only for insn attributes.  *Note Insn Attributes::.
  36905. -
  36906. -
  36907. -File: gcc.info,  Node: Bit Fields,  Next: Conversions,  Prev: Comparisons,  Up: RTL
  36908. -
  36909. -Bit Fields
  36910. -==========
  36911. -
  36912. -   Special expression codes exist to represent bitfield instructions.
  36913. -These types of expressions are lvalues in RTL; they may appear on the
  36914. -left side of an assignment, indicating insertion of a value into the
  36915. -specified bit field.
  36916. -
  36917. -`(sign_extract:M LOC SIZE POS)'
  36918. -     This represents a reference to a sign-extended bit field contained
  36919. -     or starting in LOC (a memory or register reference).  The bit field
  36920. -     is SIZE bits wide and starts at bit POS.  The compilation option
  36921. -     `BITS_BIG_ENDIAN' says which end of the memory unit POS counts
  36922. -     from.
  36923. -
  36924. -     If LOC is in memory, its mode must be a single-byte integer mode.
  36925. -     If LOC is in a register, the mode to use is specified by the
  36926. -     operand of the `insv' or `extv' pattern (*note Standard Names::.)
  36927. -     and is usually a full-word integer mode.
  36928. -
  36929. -     The mode of POS is machine-specific and is also specified in the
  36930. -     `insv' or `extv' pattern.
  36931. -
  36932. -     The mode M is the same as the mode that would be used for LOC if
  36933. -     it were a register.
  36934. -
  36935. -`(zero_extract:M LOC SIZE POS)'
  36936. -     Like `sign_extract' but refers to an unsigned or zero-extended bit
  36937. -     field.  The same sequence of bits are extracted, but they are
  36938. -     filled to an entire word with zeros instead of by sign-extension.
  36939. -
  36940. -
  36941. -File: gcc.info,  Node: Conversions,  Next: RTL Declarations,  Prev: Bit Fields,  Up: RTL
  36942. -
  36943. -Conversions
  36944. -===========
  36945. -
  36946. -   All conversions between machine modes must be represented by
  36947. -explicit conversion operations.  For example, an expression which is
  36948. -the sum of a byte and a full word cannot be written as `(plus:SI
  36949. -(reg:QI 34) (reg:SI 80))' because the `plus' operation requires two
  36950. -operands of the same machine mode.  Therefore, the byte-sized operand
  36951. -is enclosed in a conversion operation, as in
  36952. -
  36953. -     (plus:SI (sign_extend:SI (reg:QI 34)) (reg:SI 80))
  36954. -
  36955. -   The conversion operation is not a mere placeholder, because there
  36956. -may be more than one way of converting from a given starting mode to
  36957. -the desired final mode.  The conversion operation code says how to do
  36958. -it.
  36959. -
  36960. -   For all conversion operations, X must not be `VOIDmode' because the
  36961. -mode in which to do the conversion would not be known.  The conversion
  36962. -must either be done at compile-time or X must be placed into a register.
  36963. -
  36964. -`(sign_extend:M X)'
  36965. -     Represents the result of sign-extending the value X to machine
  36966. -     mode M.  M must be a fixed-point mode and X a fixed-point value of
  36967. -     a mode narrower than M.
  36968. -
  36969. -`(zero_extend:M X)'
  36970. -     Represents the result of zero-extending the value X to machine
  36971. -     mode M.  M must be a fixed-point mode and X a fixed-point value of
  36972. -     a mode narrower than M.
  36973. -
  36974. -`(float_extend:M X)'
  36975. -     Represents the result of extending the value X to machine mode M.
  36976. -     m must be a floating point mode and X a floating point value of a
  36977. -     mode narrower than M.
  36978. -
  36979. -`(truncate:M X)'
  36980. -     Represents the result of truncating the value X to machine mode M.
  36981. -     M must be a fixed-point mode and X a fixed-point value of a mode
  36982. -     wider than M.
  36983. -
  36984. -`(float_truncate:M X)'
  36985. -     Represents the result of truncating the value X to machine mode M.
  36986. -     M must be a floating point mode and X a floating point value of a
  36987. -     mode wider than M.
  36988. -
  36989. -`(float:M X)'
  36990. -     Represents the result of converting fixed point value X, regarded
  36991. -     as signed, to floating point mode M.
  36992. -
  36993. -`(unsigned_float:M X)'
  36994. -     Represents the result of converting fixed point value X, regarded
  36995. -     as unsigned, to floating point mode M.
  36996. -
  36997. -`(fix:M X)'
  36998. -     When M is a fixed point mode, represents the result of converting
  36999. -     floating point value X to mode M, regarded as signed.  How
  37000. -     rounding is done is not specified, so this operation may be used
  37001. -     validly in compiling C code only for integer-valued operands.
  37002. -
  37003. -`(unsigned_fix:M X)'
  37004. -     Represents the result of converting floating point value X to
  37005. -     fixed point mode M, regarded as unsigned.  How rounding is done is
  37006. -     not specified.
  37007. -
  37008. -`(fix:M X)'
  37009. -     When M is a floating point mode, represents the result of
  37010. -     converting floating point value X (valid for mode M) to an
  37011. -     integer, still represented in floating point mode M, by rounding
  37012. -     towards zero.
  37013. -
  37014. -
  37015. -File: gcc.info,  Node: RTL Declarations,  Next: Side Effects,  Prev: Conversions,  Up: RTL
  37016. -
  37017. -Declarations
  37018. -============
  37019. -
  37020. -   Declaration expression codes do not represent arithmetic operations
  37021. -but rather state assertions about their operands.
  37022. -
  37023. -`(strict_low_part (subreg:M (reg:N R) 0))'
  37024. -     This expression code is used in only one context: as the
  37025. -     destination operand of a `set' expression.  In addition, the
  37026. -     operand of this expression must be a non-paradoxical `subreg'
  37027. -     expression.
  37028. -
  37029. -     The presence of `strict_low_part' says that the part of the
  37030. -     register which is meaningful in mode N, but is not part of mode M,
  37031. -     is not to be altered.  Normally, an assignment to such a subreg is
  37032. -     allowed to have undefined effects on the rest of the register when
  37033. -     M is less than a word.
  37034. -
  37035. diff -rup --new-file baseline/fsf/gcc/gcc.info-15 amiga/fsf/gcc/gcc.info-15
  37036. --- baseline/fsf/gcc/gcc.info-15    Sat Jun 29 09:38:03 1996
  37037. +++ amiga/fsf/gcc/gcc.info-15    Wed Dec 31 17:00:00 1969
  37038. @@ -1,1108 +0,0 @@
  37039. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  37040. -file gcc.texi.
  37041. -
  37042. -   This file documents the use and the internals of the GNU compiler.
  37043. -
  37044. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  37045. -Boston, MA 02111-1307 USA
  37046. -
  37047. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  37048. -Foundation, Inc.
  37049. -
  37050. -   Permission is granted to make and distribute verbatim copies of this
  37051. -manual provided the copyright notice and this permission notice are
  37052. -preserved on all copies.
  37053. -
  37054. -   Permission is granted to copy and distribute modified versions of
  37055. -this manual under the conditions for verbatim copying, provided also
  37056. -that the sections entitled "GNU General Public License," "Funding for
  37057. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  37058. -included exactly as in the original, and provided that the entire
  37059. -resulting derived work is distributed under the terms of a permission
  37060. -notice identical to this one.
  37061. -
  37062. -   Permission is granted to copy and distribute translations of this
  37063. -manual into another language, under the above conditions for modified
  37064. -versions, except that the sections entitled "GNU General Public
  37065. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  37066. -`Look And Feel'", and this permission notice, may be included in
  37067. -translations approved by the Free Software Foundation instead of in the
  37068. -original English.
  37069. -
  37070. -
  37071. -File: gcc.info,  Node: Side Effects,  Next: Incdec,  Prev: RTL Declarations,  Up: RTL
  37072. -
  37073. -Side Effect Expressions
  37074. -=======================
  37075. -
  37076. -   The expression codes described so far represent values, not actions.
  37077. -But machine instructions never produce values; they are meaningful only
  37078. -for their side effects on the state of the machine.  Special expression
  37079. -codes are used to represent side effects.
  37080. -
  37081. -   The body of an instruction is always one of these side effect codes;
  37082. -the codes described above, which represent values, appear only as the
  37083. -operands of these.
  37084. -
  37085. -`(set LVAL X)'
  37086. -     Represents the action of storing the value of X into the place
  37087. -     represented by LVAL.  LVAL must be an expression representing a
  37088. -     place that can be stored in: `reg' (or `subreg' or
  37089. -     `strict_low_part'), `mem', `pc' or `cc0'.
  37090. -
  37091. -     If LVAL is a `reg', `subreg' or `mem', it has a machine mode; then
  37092. -     X must be valid for that mode.
  37093. -
  37094. -     If LVAL is a `reg' whose machine mode is less than the full width
  37095. -     of the register, then it means that the part of the register
  37096. -     specified by the machine mode is given the specified value and the
  37097. -     rest of the register receives an undefined value.  Likewise, if
  37098. -     LVAL is a `subreg' whose machine mode is narrower than the mode of
  37099. -     the register, the rest of the register can be changed in an
  37100. -     undefined way.
  37101. -
  37102. -     If LVAL is a `strict_low_part' of a `subreg', then the part of the
  37103. -     register specified by the machine mode of the `subreg' is given
  37104. -     the value X and the rest of the register is not changed.
  37105. -
  37106. -     If LVAL is `(cc0)', it has no machine mode, and X may be either a
  37107. -     `compare' expression or a value that may have any mode.  The
  37108. -     latter case represents a "test" instruction.  The expression `(set
  37109. -     (cc0) (reg:M N))' is equivalent to `(set (cc0) (compare (reg:M N)
  37110. -     (const_int 0)))'.  Use the former expression to save space during
  37111. -     the compilation.
  37112. -
  37113. -     If LVAL is `(pc)', we have a jump instruction, and the
  37114. -     possibilities for X are very limited.  It may be a `label_ref'
  37115. -     expression (unconditional jump).  It may be an `if_then_else'
  37116. -     (conditional jump), in which case either the second or the third
  37117. -     operand must be `(pc)' (for the case which does not jump) and the
  37118. -     other of the two must be a `label_ref' (for the case which does
  37119. -     jump).  X may also be a `mem' or `(plus:SI (pc) Y)', where Y may
  37120. -     be a `reg' or a `mem'; these unusual patterns are used to
  37121. -     represent jumps through branch tables.
  37122. -
  37123. -     If LVAL is neither `(cc0)' nor `(pc)', the mode of LVAL must not
  37124. -     be `VOIDmode' and the mode of X must be valid for the mode of LVAL.
  37125. -
  37126. -     LVAL is customarily accessed with the `SET_DEST' macro and X with
  37127. -     the `SET_SRC' macro.
  37128. -
  37129. -`(return)'
  37130. -     As the sole expression in a pattern, represents a return from the
  37131. -     current function, on machines where this can be done with one
  37132. -     instruction, such as Vaxes.  On machines where a multi-instruction
  37133. -     "epilogue" must be executed in order to return from the function,
  37134. -     returning is done by jumping to a label which precedes the
  37135. -     epilogue, and the `return' expression code is never used.
  37136. -
  37137. -     Inside an `if_then_else' expression, represents the value to be
  37138. -     placed in `pc' to return to the caller.
  37139. -
  37140. -     Note that an insn pattern of `(return)' is logically equivalent to
  37141. -     `(set (pc) (return))', but the latter form is never used.
  37142. -
  37143. -`(call FUNCTION NARGS)'
  37144. -     Represents a function call.  FUNCTION is a `mem' expression whose
  37145. -     address is the address of the function to be called.  NARGS is an
  37146. -     expression which can be used for two purposes: on some machines it
  37147. -     represents the number of bytes of stack argument; on others, it
  37148. -     represents the number of argument registers.
  37149. -
  37150. -     Each machine has a standard machine mode which FUNCTION must have.
  37151. -     The machine description defines macro `FUNCTION_MODE' to expand
  37152. -     into the requisite mode name.  The purpose of this mode is to
  37153. -     specify what kind of addressing is allowed, on machines where the
  37154. -     allowed kinds of addressing depend on the machine mode being
  37155. -     addressed.
  37156. -
  37157. -`(clobber X)'
  37158. -     Represents the storing or possible storing of an unpredictable,
  37159. -     undescribed value into X, which must be a `reg', `scratch' or
  37160. -     `mem' expression.
  37161. -
  37162. -     One place this is used is in string instructions that store
  37163. -     standard values into particular hard registers.  It may not be
  37164. -     worth the trouble to describe the values that are stored, but it
  37165. -     is essential to inform the compiler that the registers will be
  37166. -     altered, lest it attempt to keep data in them across the string
  37167. -     instruction.
  37168. -
  37169. -     If X is `(mem:BLK (const_int 0))', it means that all memory
  37170. -     locations must be presumed clobbered.
  37171. -
  37172. -     Note that the machine description classifies certain hard
  37173. -     registers as "call-clobbered".  All function call instructions are
  37174. -     assumed by default to clobber these registers, so there is no need
  37175. -     to use `clobber' expressions to indicate this fact.  Also, each
  37176. -     function call is assumed to have the potential to alter any memory
  37177. -     location, unless the function is declared `const'.
  37178. -
  37179. -     If the last group of expressions in a `parallel' are each a
  37180. -     `clobber' expression whose arguments are `reg' or `match_scratch'
  37181. -     (*note RTL Template::.) expressions, the combiner phase can add
  37182. -     the appropriate `clobber' expressions to an insn it has
  37183. -     constructed when doing so will cause a pattern to be matched.
  37184. -
  37185. -     This feature can be used, for example, on a machine that whose
  37186. -     multiply and add instructions don't use an MQ register but which
  37187. -     has an add-accumulate instruction that does clobber the MQ
  37188. -     register.  Similarly, a combined instruction might require a
  37189. -     temporary register while the constituent instructions might not.
  37190. -
  37191. -     When a `clobber' expression for a register appears inside a
  37192. -     `parallel' with other side effects, the register allocator
  37193. -     guarantees that the register is unoccupied both before and after
  37194. -     that insn.  However, the reload phase may allocate a register used
  37195. -     for one of the inputs unless the `&' constraint is specified for
  37196. -     the selected alternative (*note Modifiers::.).  You can clobber
  37197. -     either a specific hard register, a pseudo register, or a `scratch'
  37198. -     expression; in the latter two cases, GNU CC will allocate a hard
  37199. -     register that is available there for use as a temporary.
  37200. -
  37201. -     For instructions that require a temporary register, you should use
  37202. -     `scratch' instead of a pseudo-register because this will allow the
  37203. -     combiner phase to add the `clobber' when required.  You do this by
  37204. -     coding (`clobber' (`match_scratch' ...)).  If you do clobber a
  37205. -     pseudo register, use one which appears nowhere else--generate a
  37206. -     new one each time.  Otherwise, you may confuse CSE.
  37207. -
  37208. -     There is one other known use for clobbering a pseudo register in a
  37209. -     `parallel': when one of the input operands of the insn is also
  37210. -     clobbered by the insn.  In this case, using the same pseudo
  37211. -     register in the clobber and elsewhere in the insn produces the
  37212. -     expected results.
  37213. -
  37214. -`(use X)'
  37215. -     Represents the use of the value of X.  It indicates that the value
  37216. -     in X at this point in the program is needed, even though it may
  37217. -     not be apparent why this is so.  Therefore, the compiler will not
  37218. -     attempt to delete previous instructions whose only effect is to
  37219. -     store a value in X.  X must be a `reg' expression.
  37220. -
  37221. -     During the delayed branch scheduling phase, X may be an insn.
  37222. -     This indicates that X previously was located at this place in the
  37223. -     code and its data dependencies need to be taken into account.
  37224. -     These `use' insns will be deleted before the delayed branch
  37225. -     scheduling phase exits.
  37226. -
  37227. -`(parallel [X0 X1 ...])'
  37228. -     Represents several side effects performed in parallel.  The square
  37229. -     brackets stand for a vector; the operand of `parallel' is a vector
  37230. -     of expressions.  X0, X1 and so on are individual side effect
  37231. -     expressions--expressions of code `set', `call', `return',
  37232. -     `clobber' or `use'.
  37233. -
  37234. -     "In parallel" means that first all the values used in the
  37235. -     individual side-effects are computed, and second all the actual
  37236. -     side-effects are performed.  For example,
  37237. -
  37238. -          (parallel [(set (reg:SI 1) (mem:SI (reg:SI 1)))
  37239. -                     (set (mem:SI (reg:SI 1)) (reg:SI 1))])
  37240. -
  37241. -     says unambiguously that the values of hard register 1 and the
  37242. -     memory location addressed by it are interchanged.  In both places
  37243. -     where `(reg:SI 1)' appears as a memory address it refers to the
  37244. -     value in register 1 *before* the execution of the insn.
  37245. -
  37246. -     It follows that it is *incorrect* to use `parallel' and expect the
  37247. -     result of one `set' to be available for the next one.  For
  37248. -     example, people sometimes attempt to represent a jump-if-zero
  37249. -     instruction this way:
  37250. -
  37251. -          (parallel [(set (cc0) (reg:SI 34))
  37252. -                     (set (pc) (if_then_else
  37253. -                                  (eq (cc0) (const_int 0))
  37254. -                                  (label_ref ...)
  37255. -                                  (pc)))])
  37256. -
  37257. -     But this is incorrect, because it says that the jump condition
  37258. -     depends on the condition code value *before* this instruction, not
  37259. -     on the new value that is set by this instruction.
  37260. -
  37261. -     Peephole optimization, which takes place together with final
  37262. -     assembly code output, can produce insns whose patterns consist of
  37263. -     a `parallel' whose elements are the operands needed to output the
  37264. -     resulting assembler code--often `reg', `mem' or constant
  37265. -     expressions.  This would not be well-formed RTL at any other stage
  37266. -     in compilation, but it is ok then because no further optimization
  37267. -     remains to be done.  However, the definition of the macro
  37268. -     `NOTICE_UPDATE_CC', if any, must deal with such insns if you
  37269. -     define any peephole optimizations.
  37270. -
  37271. -`(sequence [INSNS ...])'
  37272. -     Represents a sequence of insns.  Each of the INSNS that appears in
  37273. -     the vector is suitable for appearing in the chain of insns, so it
  37274. -     must be an `insn', `jump_insn', `call_insn', `code_label',
  37275. -     `barrier' or `note'.
  37276. -
  37277. -     A `sequence' RTX is never placed in an actual insn during RTL
  37278. -     generation.  It represents the sequence of insns that result from a
  37279. -     `define_expand' *before* those insns are passed to `emit_insn' to
  37280. -     insert them in the chain of insns.  When actually inserted, the
  37281. -     individual sub-insns are separated out and the `sequence' is
  37282. -     forgotten.
  37283. -
  37284. -     After delay-slot scheduling is completed, an insn and all the
  37285. -     insns that reside in its delay slots are grouped together into a
  37286. -     `sequence'.  The insn requiring the delay slot is the first insn
  37287. -     in the vector; subsequent insns are to be placed in the delay slot.
  37288. -
  37289. -     `INSN_ANNULLED_BRANCH_P' is set on an insn in a delay slot to
  37290. -     indicate that a branch insn should be used that will conditionally
  37291. -     annul the effect of the insns in the delay slots.  In such a case,
  37292. -     `INSN_FROM_TARGET_P' indicates that the insn is from the target of
  37293. -     the branch and should be executed only if the branch is taken;
  37294. -     otherwise the insn should be executed only if the branch is not
  37295. -     taken.  *Note Delay Slots::.
  37296. -
  37297. -   These expression codes appear in place of a side effect, as the body
  37298. -of an insn, though strictly speaking they do not always describe side
  37299. -effects as such:
  37300. -
  37301. -`(asm_input S)'
  37302. -     Represents literal assembler code as described by the string S.
  37303. -
  37304. -`(unspec [OPERANDS ...] INDEX)'
  37305. -`(unspec_volatile [OPERANDS ...] INDEX)'
  37306. -     Represents a machine-specific operation on OPERANDS.  INDEX
  37307. -     selects between multiple machine-specific operations.
  37308. -     `unspec_volatile' is used for volatile operations and operations
  37309. -     that may trap; `unspec' is used for other operations.
  37310. -
  37311. -     These codes may appear inside a `pattern' of an insn, inside a
  37312. -     `parallel', or inside an expression.
  37313. -
  37314. -`(addr_vec:M [LR0 LR1 ...])'
  37315. -     Represents a table of jump addresses.  The vector elements LR0,
  37316. -     etc., are `label_ref' expressions.  The mode M specifies how much
  37317. -     space is given to each address; normally M would be `Pmode'.
  37318. -
  37319. -`(addr_diff_vec:M BASE [LR0 LR1 ...])'
  37320. -     Represents a table of jump addresses expressed as offsets from
  37321. -     BASE.  The vector elements LR0, etc., are `label_ref' expressions
  37322. -     and so is BASE.  The mode M specifies how much space is given to
  37323. -     each address-difference.
  37324. -
  37325. -
  37326. -File: gcc.info,  Node: Incdec,  Next: Assembler,  Prev: Side Effects,  Up: RTL
  37327. -
  37328. -Embedded Side-Effects on Addresses
  37329. -==================================
  37330. -
  37331. -   Four special side-effect expression codes appear as memory addresses.
  37332. -
  37333. -`(pre_dec:M X)'
  37334. -     Represents the side effect of decrementing X by a standard amount
  37335. -     and represents also the value that X has after being decremented.
  37336. -     x must be a `reg' or `mem', but most machines allow only a `reg'.
  37337. -     m must be the machine mode for pointers on the machine in use.
  37338. -     The amount X is decremented by is the length in bytes of the
  37339. -     machine mode of the containing memory reference of which this
  37340. -     expression serves as the address.  Here is an example of its use:
  37341. -
  37342. -          (mem:DF (pre_dec:SI (reg:SI 39)))
  37343. -
  37344. -     This says to decrement pseudo register 39 by the length of a
  37345. -     `DFmode' value and use the result to address a `DFmode' value.
  37346. -
  37347. -`(pre_inc:M X)'
  37348. -     Similar, but specifies incrementing X instead of decrementing it.
  37349. -
  37350. -`(post_dec:M X)'
  37351. -     Represents the same side effect as `pre_dec' but a different
  37352. -     value.  The value represented here is the value X has before being
  37353. -     decremented.
  37354. -
  37355. -`(post_inc:M X)'
  37356. -     Similar, but specifies incrementing X instead of decrementing it.
  37357. -
  37358. -   These embedded side effect expressions must be used with care.
  37359. -Instruction patterns may not use them.  Until the `flow' pass of the
  37360. -compiler, they may occur only to represent pushes onto the stack.  The
  37361. -`flow' pass finds cases where registers are incremented or decremented
  37362. -in one instruction and used as an address shortly before or after;
  37363. -these cases are then transformed to use pre- or post-increment or
  37364. --decrement.
  37365. -
  37366. -   If a register used as the operand of these expressions is used in
  37367. -another address in an insn, the original value of the register is used.
  37368. -Uses of the register outside of an address are not permitted within the
  37369. -same insn as a use in an embedded side effect expression because such
  37370. -insns behave differently on different machines and hence must be treated
  37371. -as ambiguous and disallowed.
  37372. -
  37373. -   An instruction that can be represented with an embedded side effect
  37374. -could also be represented using `parallel' containing an additional
  37375. -`set' to describe how the address register is altered.  This is not
  37376. -done because machines that allow these operations at all typically
  37377. -allow them wherever a memory address is called for.  Describing them as
  37378. -additional parallel stores would require doubling the number of entries
  37379. -in the machine description.
  37380. -
  37381. -
  37382. -File: gcc.info,  Node: Assembler,  Next: Insns,  Prev: Incdec,  Up: RTL
  37383. -
  37384. -Assembler Instructions as Expressions
  37385. -=====================================
  37386. -
  37387. -   The RTX code `asm_operands' represents a value produced by a
  37388. -user-specified assembler instruction.  It is used to represent an `asm'
  37389. -statement with arguments.  An `asm' statement with a single output
  37390. -operand, like this:
  37391. -
  37392. -     asm ("foo %1,%2,%0" : "=a" (outputvar) : "g" (x + y), "di" (*z));
  37393. -
  37394. -is represented using a single `asm_operands' RTX which represents the
  37395. -value that is stored in `outputvar':
  37396. -
  37397. -     (set RTX-FOR-OUTPUTVAR
  37398. -          (asm_operands "foo %1,%2,%0" "a" 0
  37399. -                        [RTX-FOR-ADDITION-RESULT RTX-FOR-*Z]
  37400. -                        [(asm_input:M1 "g")
  37401. -                         (asm_input:M2 "di")]))
  37402. -
  37403. -Here the operands of the `asm_operands' RTX are the assembler template
  37404. -string, the output-operand's constraint, the index-number of the output
  37405. -operand among the output operands specified, a vector of input operand
  37406. -RTX's, and a vector of input-operand modes and constraints.  The mode
  37407. -M1 is the mode of the sum `x+y'; M2 is that of `*z'.
  37408. -
  37409. -   When an `asm' statement has multiple output values, its insn has
  37410. -several such `set' RTX's inside of a `parallel'.  Each `set' contains a
  37411. -`asm_operands'; all of these share the same assembler template and
  37412. -vectors, but each contains the constraint for the respective output
  37413. -operand.  They are also distinguished by the output-operand index
  37414. -number, which is 0, 1, ... for successive output operands.
  37415. -
  37416. -
  37417. -File: gcc.info,  Node: Insns,  Next: Calls,  Prev: Assembler,  Up: RTL
  37418. -
  37419. -Insns
  37420. -=====
  37421. -
  37422. -   The RTL representation of the code for a function is a doubly-linked
  37423. -chain of objects called "insns".  Insns are expressions with special
  37424. -codes that are used for no other purpose.  Some insns are actual
  37425. -instructions; others represent dispatch tables for `switch' statements;
  37426. -others represent labels to jump to or various sorts of declarative
  37427. -information.
  37428. -
  37429. -   In addition to its own specific data, each insn must have a unique
  37430. -id-number that distinguishes it from all other insns in the current
  37431. -function (after delayed branch scheduling, copies of an insn with the
  37432. -same id-number may be present in multiple places in a function, but
  37433. -these copies will always be identical and will only appear inside a
  37434. -`sequence'), and chain pointers to the preceding and following insns.
  37435. -These three fields occupy the same position in every insn, independent
  37436. -of the expression code of the insn.  They could be accessed with `XEXP'
  37437. -and `XINT', but instead three special macros are always used:
  37438. -
  37439. -`INSN_UID (I)'
  37440. -     Accesses the unique id of insn I.
  37441. -
  37442. -`PREV_INSN (I)'
  37443. -     Accesses the chain pointer to the insn preceding I.  If I is the
  37444. -     first insn, this is a null pointer.
  37445. -
  37446. -`NEXT_INSN (I)'
  37447. -     Accesses the chain pointer to the insn following I.  If I is the
  37448. -     last insn, this is a null pointer.
  37449. -
  37450. -   The first insn in the chain is obtained by calling `get_insns'; the
  37451. -last insn is the result of calling `get_last_insn'.  Within the chain
  37452. -delimited by these insns, the `NEXT_INSN' and `PREV_INSN' pointers must
  37453. -always correspond: if INSN is not the first insn,
  37454. -
  37455. -     NEXT_INSN (PREV_INSN (INSN)) == INSN
  37456. -
  37457. -is always true and if INSN is not the last insn,
  37458. -
  37459. -     PREV_INSN (NEXT_INSN (INSN)) == INSN
  37460. -
  37461. -is always true.
  37462. -
  37463. -   After delay slot scheduling, some of the insns in the chain might be
  37464. -`sequence' expressions, which contain a vector of insns.  The value of
  37465. -`NEXT_INSN' in all but the last of these insns is the next insn in the
  37466. -vector; the value of `NEXT_INSN' of the last insn in the vector is the
  37467. -same as the value of `NEXT_INSN' for the `sequence' in which it is
  37468. -contained.  Similar rules apply for `PREV_INSN'.
  37469. -
  37470. -   This means that the above invariants are not necessarily true for
  37471. -insns inside `sequence' expressions.  Specifically, if INSN is the
  37472. -first insn in a `sequence', `NEXT_INSN (PREV_INSN (INSN))' is the insn
  37473. -containing the `sequence' expression, as is the value of `PREV_INSN
  37474. -(NEXT_INSN (INSN))' is INSN is the last insn in the `sequence'
  37475. -expression.  You can use these expressions to find the containing
  37476. -`sequence' expression.
  37477. -
  37478. -   Every insn has one of the following six expression codes:
  37479. -
  37480. -`insn'
  37481. -     The expression code `insn' is used for instructions that do not
  37482. -     jump and do not do function calls.  `sequence' expressions are
  37483. -     always contained in insns with code `insn' even if one of those
  37484. -     insns should jump or do function calls.
  37485. -
  37486. -     Insns with code `insn' have four additional fields beyond the three
  37487. -     mandatory ones listed above.  These four are described in a table
  37488. -     below.
  37489. -
  37490. -`jump_insn'
  37491. -     The expression code `jump_insn' is used for instructions that may
  37492. -     jump (or, more generally, may contain `label_ref' expressions).  If
  37493. -     there is an instruction to return from the current function, it is
  37494. -     recorded as a `jump_insn'.
  37495. -
  37496. -     `jump_insn' insns have the same extra fields as `insn' insns,
  37497. -     accessed in the same way and in addition contain a field
  37498. -     `JUMP_LABEL' which is defined once jump optimization has completed.
  37499. -
  37500. -     For simple conditional and unconditional jumps, this field
  37501. -     contains the `code_label' to which this insn will (possibly
  37502. -     conditionally) branch.  In a more complex jump, `JUMP_LABEL'
  37503. -     records one of the labels that the insn refers to; the only way to
  37504. -     find the others is to scan the entire body of the insn.
  37505. -
  37506. -     Return insns count as jumps, but since they do not refer to any
  37507. -     labels, they have zero in the `JUMP_LABEL' field.
  37508. -
  37509. -`call_insn'
  37510. -     The expression code `call_insn' is used for instructions that may
  37511. -     do function calls.  It is important to distinguish these
  37512. -     instructions because they imply that certain registers and memory
  37513. -     locations may be altered unpredictably.
  37514. -
  37515. -     `call_insn' insns have the same extra fields as `insn' insns,
  37516. -     accessed in the same way and in addition contain a field
  37517. -     `CALL_INSN_FUNCTION_USAGE', which contains a list (chain of
  37518. -     `expr_list' expressions) containing `use' and `clobber'
  37519. -     expressions that denote hard registers used or clobbered by the
  37520. -     called function.  A register specified in a `clobber' in this list
  37521. -     is modified *after* the execution of the `call_insn', while a
  37522. -     register in a `clobber' in the body of the `call_insn' is
  37523. -     clobbered before the insn completes execution.  `clobber'
  37524. -     expressions in this list augment registers specified in
  37525. -     `CALL_USED_REGISTERS' (*note Register Basics::.).
  37526. -
  37527. -`code_label'
  37528. -     A `code_label' insn represents a label that a jump insn can jump
  37529. -     to.  It contains two special fields of data in addition to the
  37530. -     three standard ones.  `CODE_LABEL_NUMBER' is used to hold the
  37531. -     "label number", a number that identifies this label uniquely among
  37532. -     all the labels in the compilation (not just in the current
  37533. -     function).  Ultimately, the label is represented in the assembler
  37534. -     output as an assembler label, usually of the form `LN' where N is
  37535. -     the label number.
  37536. -
  37537. -     When a `code_label' appears in an RTL expression, it normally
  37538. -     appears within a `label_ref' which represents the address of the
  37539. -     label, as a number.
  37540. -
  37541. -     The field `LABEL_NUSES' is only defined once the jump optimization
  37542. -     phase is completed and contains the number of times this label is
  37543. -     referenced in the current function.
  37544. -
  37545. -`barrier'
  37546. -     Barriers are placed in the instruction stream when control cannot
  37547. -     flow past them.  They are placed after unconditional jump
  37548. -     instructions to indicate that the jumps are unconditional and
  37549. -     after calls to `volatile' functions, which do not return (e.g.,
  37550. -     `exit').  They contain no information beyond the three standard
  37551. -     fields.
  37552. -
  37553. -`note'
  37554. -     `note' insns are used to represent additional debugging and
  37555. -     declarative information.  They contain two nonstandard fields, an
  37556. -     integer which is accessed with the macro `NOTE_LINE_NUMBER' and a
  37557. -     string accessed with `NOTE_SOURCE_FILE'.
  37558. -
  37559. -     If `NOTE_LINE_NUMBER' is positive, the note represents the
  37560. -     position of a source line and `NOTE_SOURCE_FILE' is the source
  37561. -     file name that the line came from.  These notes control generation
  37562. -     of line number data in the assembler output.
  37563. -
  37564. -     Otherwise, `NOTE_LINE_NUMBER' is not really a line number but a
  37565. -     code with one of the following values (and `NOTE_SOURCE_FILE' must
  37566. -     contain a null pointer):
  37567. -
  37568. -    `NOTE_INSN_DELETED'
  37569. -          Such a note is completely ignorable.  Some passes of the
  37570. -          compiler delete insns by altering them into notes of this
  37571. -          kind.
  37572. -
  37573. -    `NOTE_INSN_BLOCK_BEG'
  37574. -    `NOTE_INSN_BLOCK_END'
  37575. -          These types of notes indicate the position of the beginning
  37576. -          and end of a level of scoping of variable names.  They
  37577. -          control the output of debugging information.
  37578. -
  37579. -    `NOTE_INSN_LOOP_BEG'
  37580. -    `NOTE_INSN_LOOP_END'
  37581. -          These types of notes indicate the position of the beginning
  37582. -          and end of a `while' or `for' loop.  They enable the loop
  37583. -          optimizer to find loops quickly.
  37584. -
  37585. -    `NOTE_INSN_LOOP_CONT'
  37586. -          Appears at the place in a loop that `continue' statements
  37587. -          jump to.
  37588. -
  37589. -    `NOTE_INSN_LOOP_VTOP'
  37590. -          This note indicates the place in a loop where the exit test
  37591. -          begins for those loops in which the exit test has been
  37592. -          duplicated.  This position becomes another virtual start of
  37593. -          the loop when considering loop invariants.
  37594. -
  37595. -    `NOTE_INSN_FUNCTION_END'
  37596. -          Appears near the end of the function body, just before the
  37597. -          label that `return' statements jump to (on machine where a
  37598. -          single instruction does not suffice for returning).  This
  37599. -          note may be deleted by jump optimization.
  37600. -
  37601. -    `NOTE_INSN_SETJMP'
  37602. -          Appears following each call to `setjmp' or a related function.
  37603. -
  37604. -     These codes are printed symbolically when they appear in debugging
  37605. -     dumps.
  37606. -
  37607. -   The machine mode of an insn is normally `VOIDmode', but some phases
  37608. -use the mode for various purposes; for example, the reload pass sets it
  37609. -to `HImode' if the insn needs reloading but not register elimination
  37610. -and `QImode' if both are required.  The common subexpression
  37611. -elimination pass sets the mode of an insn to `QImode' when it is the
  37612. -first insn in a block that has already been processed.
  37613. -
  37614. -   Here is a table of the extra fields of `insn', `jump_insn' and
  37615. -`call_insn' insns:
  37616. -
  37617. -`PATTERN (I)'
  37618. -     An expression for the side effect performed by this insn.  This
  37619. -     must be one of the following codes: `set', `call', `use',
  37620. -     `clobber', `return', `asm_input', `asm_output', `addr_vec',
  37621. -     `addr_diff_vec', `trap_if', `unspec', `unspec_volatile',
  37622. -     `parallel', or `sequence'.  If it is a `parallel', each element of
  37623. -     the `parallel' must be one these codes, except that `parallel'
  37624. -     expressions cannot be nested and `addr_vec' and `addr_diff_vec'
  37625. -     are not permitted inside a `parallel' expression.
  37626. -
  37627. -`INSN_CODE (I)'
  37628. -     An integer that says which pattern in the machine description
  37629. -     matches this insn, or -1 if the matching has not yet been
  37630. -     attempted.
  37631. -
  37632. -     Such matching is never attempted and this field remains -1 on an
  37633. -     insn whose pattern consists of a single `use', `clobber',
  37634. -     `asm_input', `addr_vec' or `addr_diff_vec' expression.
  37635. -
  37636. -     Matching is also never attempted on insns that result from an `asm'
  37637. -     statement.  These contain at least one `asm_operands' expression.
  37638. -     The function `asm_noperands' returns a non-negative value for such
  37639. -     insns.
  37640. -
  37641. -     In the debugging output, this field is printed as a number
  37642. -     followed by a symbolic representation that locates the pattern in
  37643. -     the `md' file as some small positive or negative offset from a
  37644. -     named pattern.
  37645. -
  37646. -`LOG_LINKS (I)'
  37647. -     A list (chain of `insn_list' expressions) giving information about
  37648. -     dependencies between instructions within a basic block.  Neither a
  37649. -     jump nor a label may come between the related insns.
  37650. -
  37651. -`REG_NOTES (I)'
  37652. -     A list (chain of `expr_list' and `insn_list' expressions) giving
  37653. -     miscellaneous information about the insn.  It is often information
  37654. -     pertaining to the registers used in this insn.
  37655. -
  37656. -   The `LOG_LINKS' field of an insn is a chain of `insn_list'
  37657. -expressions.  Each of these has two operands: the first is an insn, and
  37658. -the second is another `insn_list' expression (the next one in the
  37659. -chain).  The last `insn_list' in the chain has a null pointer as second
  37660. -operand.  The significant thing about the chain is which insns appear
  37661. -in it (as first operands of `insn_list' expressions).  Their order is
  37662. -not significant.
  37663. -
  37664. -   This list is originally set up by the flow analysis pass; it is a
  37665. -null pointer until then.  Flow only adds links for those data
  37666. -dependencies which can be used for instruction combination.  For each
  37667. -insn, the flow analysis pass adds a link to insns which store into
  37668. -registers values that are used for the first time in this insn.  The
  37669. -instruction scheduling pass adds extra links so that every dependence
  37670. -will be represented.  Links represent data dependencies,
  37671. -antidependencies and output dependencies; the machine mode of the link
  37672. -distinguishes these three types: antidependencies have mode
  37673. -`REG_DEP_ANTI', output dependencies have mode `REG_DEP_OUTPUT', and
  37674. -data dependencies have mode `VOIDmode'.
  37675. -
  37676. -   The `REG_NOTES' field of an insn is a chain similar to the
  37677. -`LOG_LINKS' field but it includes `expr_list' expressions in addition
  37678. -to `insn_list' expressions.  There are several kinds of register notes,
  37679. -which are distinguished by the machine mode, which in a register note
  37680. -is really understood as being an `enum reg_note'.  The first operand OP
  37681. -of the note is data whose meaning depends on the kind of note.
  37682. -
  37683. -   The macro `REG_NOTE_KIND (X)' returns the kind of register note.
  37684. -Its counterpart, the macro `PUT_REG_NOTE_KIND (X, NEWKIND)' sets the
  37685. -register note type of X to be NEWKIND.
  37686. -
  37687. -   Register notes are of three classes: They may say something about an
  37688. -input to an insn, they may say something about an output of an insn, or
  37689. -they may create a linkage between two insns.  There are also a set of
  37690. -values that are only used in `LOG_LINKS'.
  37691. -
  37692. -   These register notes annotate inputs to an insn:
  37693. -
  37694. -`REG_DEAD'
  37695. -     The value in OP dies in this insn; that is to say, altering the
  37696. -     value immediately after this insn would not affect the future
  37697. -     behavior of the program.
  37698. -
  37699. -     This does not necessarily mean that the register OP has no useful
  37700. -     value after this insn since it may also be an output of the insn.
  37701. -     In such a case, however, a `REG_DEAD' note would be redundant and
  37702. -     is usually not present until after the reload pass, but no code
  37703. -     relies on this fact.
  37704. -
  37705. -`REG_INC'
  37706. -     The register OP is incremented (or decremented; at this level
  37707. -     there is no distinction) by an embedded side effect inside this
  37708. -     insn.  This means it appears in a `post_inc', `pre_inc',
  37709. -     `post_dec' or `pre_dec' expression.
  37710. -
  37711. -`REG_NONNEG'
  37712. -     The register OP is known to have a nonnegative value when this
  37713. -     insn is reached.  This is used so that decrement and branch until
  37714. -     zero instructions, such as the m68k dbra, can be matched.
  37715. -
  37716. -     The `REG_NONNEG' note is added to insns only if the machine
  37717. -     description has a `decrement_and_branch_until_zero' pattern.
  37718. -
  37719. -`REG_NO_CONFLICT'
  37720. -     This insn does not cause a conflict between OP and the item being
  37721. -     set by this insn even though it might appear that it does.  In
  37722. -     other words, if the destination register and OP could otherwise be
  37723. -     assigned the same register, this insn does not prevent that
  37724. -     assignment.
  37725. -
  37726. -     Insns with this note are usually part of a block that begins with a
  37727. -     `clobber' insn specifying a multi-word pseudo register (which will
  37728. -     be the output of the block), a group of insns that each set one
  37729. -     word of the value and have the `REG_NO_CONFLICT' note attached,
  37730. -     and a final insn that copies the output to itself with an attached
  37731. -     `REG_EQUAL' note giving the expression being computed.  This block
  37732. -     is encapsulated with `REG_LIBCALL' and `REG_RETVAL' notes on the
  37733. -     first and last insns, respectively.
  37734. -
  37735. -`REG_LABEL'
  37736. -     This insn uses OP, a `code_label', but is not a `jump_insn'.  The
  37737. -     presence of this note allows jump optimization to be aware that OP
  37738. -     is, in fact, being used.
  37739. -
  37740. -   The following notes describe attributes of outputs of an insn:
  37741. -
  37742. -`REG_EQUIV'
  37743. -`REG_EQUAL'
  37744. -     This note is only valid on an insn that sets only one register and
  37745. -     indicates that that register will be equal to OP at run time; the
  37746. -     scope of this equivalence differs between the two types of notes.
  37747. -     The value which the insn explicitly copies into the register may
  37748. -     look different from OP, but they will be equal at run time.  If the
  37749. -     output of the single `set' is a `strict_low_part' expression, the
  37750. -     note refers to the register that is contained in `SUBREG_REG' of
  37751. -     the `subreg' expression.
  37752. -
  37753. -     For `REG_EQUIV', the register is equivalent to OP throughout the
  37754. -     entire function, and could validly be replaced in all its
  37755. -     occurrences by OP.  ("Validly" here refers to the data flow of the
  37756. -     program; simple replacement may make some insns invalid.)  For
  37757. -     example, when a constant is loaded into a register that is never
  37758. -     assigned any other value, this kind of note is used.
  37759. -
  37760. -     When a parameter is copied into a pseudo-register at entry to a
  37761. -     function, a note of this kind records that the register is
  37762. -     equivalent to the stack slot where the parameter was passed.
  37763. -     Although in this case the register may be set by other insns, it
  37764. -     is still valid to replace the register by the stack slot
  37765. -     throughout the function.
  37766. -
  37767. -     In the case of `REG_EQUAL', the register that is set by this insn
  37768. -     will be equal to OP at run time at the end of this insn but not
  37769. -     necessarily elsewhere in the function.  In this case, OP is
  37770. -     typically an arithmetic expression.  For example, when a sequence
  37771. -     of insns such as a library call is used to perform an arithmetic
  37772. -     operation, this kind of note is attached to the insn that produces
  37773. -     or copies the final value.
  37774. -
  37775. -     These two notes are used in different ways by the compiler passes.
  37776. -     `REG_EQUAL' is used by passes prior to register allocation (such as
  37777. -     common subexpression elimination and loop optimization) to tell
  37778. -     them how to think of that value.  `REG_EQUIV' notes are used by
  37779. -     register allocation to indicate that there is an available
  37780. -     substitute expression (either a constant or a `mem' expression for
  37781. -     the location of a parameter on the stack) that may be used in
  37782. -     place of a register if insufficient registers are available.
  37783. -
  37784. -     Except for stack homes for parameters, which are indicated by a
  37785. -     `REG_EQUIV' note and are not useful to the early optimization
  37786. -     passes and pseudo registers that are equivalent to a memory
  37787. -     location throughout there entire life, which is not detected until
  37788. -     later in the compilation, all equivalences are initially indicated
  37789. -     by an attached `REG_EQUAL' note.  In the early stages of register
  37790. -     allocation, a `REG_EQUAL' note is changed into a `REG_EQUIV' note
  37791. -     if OP is a constant and the insn represents the only set of its
  37792. -     destination register.
  37793. -
  37794. -     Thus, compiler passes prior to register allocation need only check
  37795. -     for `REG_EQUAL' notes and passes subsequent to register allocation
  37796. -     need only check for `REG_EQUIV' notes.
  37797. -
  37798. -`REG_UNUSED'
  37799. -     The register OP being set by this insn will not be used in a
  37800. -     subsequent insn.  This differs from a `REG_DEAD' note, which
  37801. -     indicates that the value in an input will not be used subsequently.
  37802. -     These two notes are independent; both may be present for the same
  37803. -     register.
  37804. -
  37805. -`REG_WAS_0'
  37806. -     The single output of this insn contained zero before this insn.
  37807. -     OP is the insn that set it to zero.  You can rely on this note if
  37808. -     it is present and OP has not been deleted or turned into a `note';
  37809. -     its absence implies nothing.
  37810. -
  37811. -   These notes describe linkages between insns.  They occur in pairs:
  37812. -one insn has one of a pair of notes that points to a second insn, which
  37813. -has the inverse note pointing back to the first insn.
  37814. -
  37815. -`REG_RETVAL'
  37816. -     This insn copies the value of a multi-insn sequence (for example, a
  37817. -     library call), and OP is the first insn of the sequence (for a
  37818. -     library call, the first insn that was generated to set up the
  37819. -     arguments for the library call).
  37820. -
  37821. -     Loop optimization uses this note to treat such a sequence as a
  37822. -     single operation for code motion purposes and flow analysis uses
  37823. -     this note to delete such sequences whose results are dead.
  37824. -
  37825. -     A `REG_EQUAL' note will also usually be attached to this insn to
  37826. -     provide the expression being computed by the sequence.
  37827. -
  37828. -`REG_LIBCALL'
  37829. -     This is the inverse of `REG_RETVAL': it is placed on the first
  37830. -     insn of a multi-insn sequence, and it points to the last one.
  37831. -
  37832. -`REG_CC_SETTER'
  37833. -`REG_CC_USER'
  37834. -     On machines that use `cc0', the insns which set and use `cc0' set
  37835. -     and use `cc0' are adjacent.  However, when branch delay slot
  37836. -     filling is done, this may no longer be true.  In this case a
  37837. -     `REG_CC_USER' note will be placed on the insn setting `cc0' to
  37838. -     point to the insn using `cc0' and a `REG_CC_SETTER' note will be
  37839. -     placed on the insn using `cc0' to point to the insn setting `cc0'.
  37840. -
  37841. -   These values are only used in the `LOG_LINKS' field, and indicate
  37842. -the type of dependency that each link represents.  Links which indicate
  37843. -a data dependence (a read after write dependence) do not use any code,
  37844. -they simply have mode `VOIDmode', and are printed without any
  37845. -descriptive text.
  37846. -
  37847. -`REG_DEP_ANTI'
  37848. -     This indicates an anti dependence (a write after read dependence).
  37849. -
  37850. -`REG_DEP_OUTPUT'
  37851. -     This indicates an output dependence (a write after write
  37852. -     dependence).
  37853. -
  37854. -   For convenience, the machine mode in an `insn_list' or `expr_list'
  37855. -is printed using these symbolic codes in debugging dumps.
  37856. -
  37857. -   The only difference between the expression codes `insn_list' and
  37858. -`expr_list' is that the first operand of an `insn_list' is assumed to
  37859. -be an insn and is printed in debugging dumps as the insn's unique id;
  37860. -the first operand of an `expr_list' is printed in the ordinary way as
  37861. -an expression.
  37862. -
  37863. -
  37864. -File: gcc.info,  Node: Calls,  Next: Sharing,  Prev: Insns,  Up: RTL
  37865. -
  37866. -RTL Representation of Function-Call Insns
  37867. -=========================================
  37868. -
  37869. -   Insns that call subroutines have the RTL expression code `call_insn'.
  37870. -These insns must satisfy special rules, and their bodies must use a
  37871. -special RTL expression code, `call'.
  37872. -
  37873. -   A `call' expression has two operands, as follows:
  37874. -
  37875. -     (call (mem:FM ADDR) NBYTES)
  37876. -
  37877. -Here NBYTES is an operand that represents the number of bytes of
  37878. -argument data being passed to the subroutine, FM is a machine mode
  37879. -(which must equal as the definition of the `FUNCTION_MODE' macro in the
  37880. -machine description) and ADDR represents the address of the subroutine.
  37881. -
  37882. -   For a subroutine that returns no value, the `call' expression as
  37883. -shown above is the entire body of the insn, except that the insn might
  37884. -also contain `use' or `clobber' expressions.
  37885. -
  37886. -   For a subroutine that returns a value whose mode is not `BLKmode',
  37887. -the value is returned in a hard register.  If this register's number is
  37888. -R, then the body of the call insn looks like this:
  37889. -
  37890. -     (set (reg:M R)
  37891. -          (call (mem:FM ADDR) NBYTES))
  37892. -
  37893. -This RTL expression makes it clear (to the optimizer passes) that the
  37894. -appropriate register receives a useful value in this insn.
  37895. -
  37896. -   When a subroutine returns a `BLKmode' value, it is handled by
  37897. -passing to the subroutine the address of a place to store the value.
  37898. -So the call insn itself does not "return" any value, and it has the
  37899. -same RTL form as a call that returns nothing.
  37900. -
  37901. -   On some machines, the call instruction itself clobbers some register,
  37902. -for example to contain the return address.  `call_insn' insns on these
  37903. -machines should have a body which is a `parallel' that contains both
  37904. -the `call' expression and `clobber' expressions that indicate which
  37905. -registers are destroyed.  Similarly, if the call instruction requires
  37906. -some register other than the stack pointer that is not explicitly
  37907. -mentioned it its RTL, a `use' subexpression should mention that
  37908. -register.
  37909. -
  37910. -   Functions that are called are assumed to modify all registers listed
  37911. -in the configuration macro `CALL_USED_REGISTERS' (*note Register
  37912. -Basics::.) and, with the exception of `const' functions and library
  37913. -calls, to modify all of memory.
  37914. -
  37915. -   Insns containing just `use' expressions directly precede the
  37916. -`call_insn' insn to indicate which registers contain inputs to the
  37917. -function.  Similarly, if registers other than those in
  37918. -`CALL_USED_REGISTERS' are clobbered by the called function, insns
  37919. -containing a single `clobber' follow immediately after the call to
  37920. -indicate which registers.
  37921. -
  37922. -
  37923. -File: gcc.info,  Node: Sharing,  Next: Reading RTL,  Prev: Calls,  Up: RTL
  37924. -
  37925. -Structure Sharing Assumptions
  37926. -=============================
  37927. -
  37928. -   The compiler assumes that certain kinds of RTL expressions are
  37929. -unique; there do not exist two distinct objects representing the same
  37930. -value.  In other cases, it makes an opposite assumption: that no RTL
  37931. -expression object of a certain kind appears in more than one place in
  37932. -the containing structure.
  37933. -
  37934. -   These assumptions refer to a single function; except for the RTL
  37935. -objects that describe global variables and external functions, and a
  37936. -few standard objects such as small integer constants, no RTL objects
  37937. -are common to two functions.
  37938. -
  37939. -   * Each pseudo-register has only a single `reg' object to represent
  37940. -     it, and therefore only a single machine mode.
  37941. -
  37942. -   * For any symbolic label, there is only one `symbol_ref' object
  37943. -     referring to it.
  37944. -
  37945. -   * There is only one `const_int' expression with value 0, only one
  37946. -     with value 1, and only one with value -1.  Some other integer
  37947. -     values are also stored uniquely.
  37948. -
  37949. -   * There is only one `pc' expression.
  37950. -
  37951. -   * There is only one `cc0' expression.
  37952. -
  37953. -   * There is only one `const_double' expression with value 0 for each
  37954. -     floating point mode.  Likewise for values 1 and 2.
  37955. -
  37956. -   * No `label_ref' or `scratch' appears in more than one place in the
  37957. -     RTL structure; in other words, it is safe to do a tree-walk of all
  37958. -     the insns in the function and assume that each time a `label_ref'
  37959. -     or `scratch' is seen it is distinct from all others that are seen.
  37960. -
  37961. -   * Only one `mem' object is normally created for each static variable
  37962. -     or stack slot, so these objects are frequently shared in all the
  37963. -     places they appear.  However, separate but equal objects for these
  37964. -     variables are occasionally made.
  37965. -
  37966. -   * When a single `asm' statement has multiple output operands, a
  37967. -     distinct `asm_operands' expression is made for each output operand.
  37968. -     However, these all share the vector which contains the sequence of
  37969. -     input operands.  This sharing is used later on to test whether two
  37970. -     `asm_operands' expressions come from the same statement, so all
  37971. -     optimizations must carefully preserve the sharing if they copy the
  37972. -     vector at all.
  37973. -
  37974. -   * No RTL object appears in more than one place in the RTL structure
  37975. -     except as described above.  Many passes of the compiler rely on
  37976. -     this by assuming that they can modify RTL objects in place without
  37977. -     unwanted side-effects on other insns.
  37978. -
  37979. -   * During initial RTL generation, shared structure is freely
  37980. -     introduced.  After all the RTL for a function has been generated,
  37981. -     all shared structure is copied by `unshare_all_rtl' in
  37982. -     `emit-rtl.c', after which the above rules are guaranteed to be
  37983. -     followed.
  37984. -
  37985. -   * During the combiner pass, shared structure within an insn can exist
  37986. -     temporarily.  However, the shared structure is copied before the
  37987. -     combiner is finished with the insn.  This is done by calling
  37988. -     `copy_rtx_if_shared', which is a subroutine of `unshare_all_rtl'.
  37989. -
  37990. -
  37991. -File: gcc.info,  Node: Reading RTL,  Prev: Sharing,  Up: RTL
  37992. -
  37993. -Reading RTL
  37994. -===========
  37995. -
  37996. -   To read an RTL object from a file, call `read_rtx'.  It takes one
  37997. -argument, a stdio stream, and returns a single RTL object.
  37998. -
  37999. -   Reading RTL from a file is very slow.  This is not currently a
  38000. -problem since reading RTL occurs only as part of building the compiler.
  38001. -
  38002. -   People frequently have the idea of using RTL stored as text in a
  38003. -file as an interface between a language front end and the bulk of GNU
  38004. -CC.  This idea is not feasible.
  38005. -
  38006. -   GNU CC was designed to use RTL internally only.  Correct RTL for a
  38007. -given program is very dependent on the particular target machine.  And
  38008. -the RTL does not contain all the information about the program.
  38009. -
  38010. -   The proper way to interface GNU CC to a new language front end is
  38011. -with the "tree" data structure.  There is no manual for this data
  38012. -structure, but it is described in the files `tree.h' and `tree.def'.
  38013. -
  38014. -
  38015. -File: gcc.info,  Node: Machine Desc,  Next: Target Macros,  Prev: RTL,  Up: Top
  38016. -
  38017. -Machine Descriptions
  38018. -********************
  38019. -
  38020. -   A machine description has two parts: a file of instruction patterns
  38021. -(`.md' file) and a C header file of macro definitions.
  38022. -
  38023. -   The `.md' file for a target machine contains a pattern for each
  38024. -instruction that the target machine supports (or at least each
  38025. -instruction that is worth telling the compiler about).  It may also
  38026. -contain comments.  A semicolon causes the rest of the line to be a
  38027. -comment, unless the semicolon is inside a quoted string.
  38028. -
  38029. -   See the next chapter for information on the C header file.
  38030. -
  38031. -* Menu:
  38032. -
  38033. -* Patterns::            How to write instruction patterns.
  38034. -* Example::             An explained example of a `define_insn' pattern.
  38035. -* RTL Template::        The RTL template defines what insns match a pattern.
  38036. -* Output Template::     The output template says how to make assembler code
  38037. -                          from such an insn.
  38038. -* Output Statement::    For more generality, write C code to output
  38039. -                          the assembler code.
  38040. -* Constraints::         When not all operands are general operands.
  38041. -* Standard Names::      Names mark patterns to use for code generation.
  38042. -* Pattern Ordering::    When the order of patterns makes a difference.
  38043. -* Dependent Patterns::  Having one pattern may make you need another.
  38044. -* Jump Patterns::       Special considerations for patterns for jump insns.
  38045. -* Insn Canonicalizations::Canonicalization of Instructions
  38046. -* Peephole Definitions::Defining machine-specific peephole optimizations.
  38047. -* Expander Definitions::Generating a sequence of several RTL insns
  38048. -                         for a standard operation.
  38049. -* Insn Splitting::    Splitting Instructions into Multiple Instructions
  38050. -* Insn Attributes::     Specifying the value of attributes for generated insns.
  38051. -
  38052. -
  38053. -File: gcc.info,  Node: Patterns,  Next: Example,  Up: Machine Desc
  38054. -
  38055. -Everything about Instruction Patterns
  38056. -=====================================
  38057. -
  38058. -   Each instruction pattern contains an incomplete RTL expression, with
  38059. -pieces to be filled in later, operand constraints that restrict how the
  38060. -pieces can be filled in, and an output pattern or C code to generate
  38061. -the assembler output, all wrapped up in a `define_insn' expression.
  38062. -
  38063. -   A `define_insn' is an RTL expression containing four or five
  38064. -operands:
  38065. -
  38066. -  1. An optional name.  The presence of a name indicate that this
  38067. -     instruction pattern can perform a certain standard job for the
  38068. -     RTL-generation pass of the compiler.  This pass knows certain
  38069. -     names and will use the instruction patterns with those names, if
  38070. -     the names are defined in the machine description.
  38071. -
  38072. -     The absence of a name is indicated by writing an empty string
  38073. -     where the name should go.  Nameless instruction patterns are never
  38074. -     used for generating RTL code, but they may permit several simpler
  38075. -     insns to be combined later on.
  38076. -
  38077. -     Names that are not thus known and used in RTL-generation have no
  38078. -     effect; they are equivalent to no name at all.
  38079. -
  38080. -  2. The "RTL template" (*note RTL Template::.) is a vector of
  38081. -     incomplete RTL expressions which show what the instruction should
  38082. -     look like.  It is incomplete because it may contain
  38083. -     `match_operand', `match_operator', and `match_dup' expressions
  38084. -     that stand for operands of the instruction.
  38085. -
  38086. -     If the vector has only one element, that element is the template
  38087. -     for the instruction pattern.  If the vector has multiple elements,
  38088. -     then the instruction pattern is a `parallel' expression containing
  38089. -     the elements described.
  38090. -
  38091. -  3. A condition.  This is a string which contains a C expression that
  38092. -     is the final test to decide whether an insn body matches this
  38093. -     pattern.
  38094. -
  38095. -     For a named pattern, the condition (if present) may not depend on
  38096. -     the data in the insn being matched, but only the
  38097. -     target-machine-type flags.  The compiler needs to test these
  38098. -     conditions during initialization in order to learn exactly which
  38099. -     named instructions are available in a particular run.
  38100. -
  38101. -     For nameless patterns, the condition is applied only when matching
  38102. -     an individual insn, and only after the insn has matched the
  38103. -     pattern's recognition template.  The insn's operands may be found
  38104. -     in the vector `operands'.
  38105. -
  38106. -  4. The "output template": a string that says how to output matching
  38107. -     insns as assembler code.  `%' in this string specifies where to
  38108. -     substitute the value of an operand.  *Note Output Template::.
  38109. -
  38110. -     When simple substitution isn't general enough, you can specify a
  38111. -     piece of C code to compute the output.  *Note Output Statement::.
  38112. -
  38113. -  5. Optionally, a vector containing the values of attributes for insns
  38114. -     matching this pattern.  *Note Insn Attributes::.
  38115. -
  38116. -
  38117. -File: gcc.info,  Node: Example,  Next: RTL Template,  Prev: Patterns,  Up: Machine Desc
  38118. -
  38119. -Example of `define_insn'
  38120. -========================
  38121. -
  38122. -   Here is an actual example of an instruction pattern, for the
  38123. -68000/68020.
  38124. -
  38125. -     (define_insn "tstsi"
  38126. -       [(set (cc0)
  38127. -             (match_operand:SI 0 "general_operand" "rm"))]
  38128. -       ""
  38129. -       "*
  38130. -     { if (TARGET_68020 || ! ADDRESS_REG_P (operands[0]))
  38131. -         return \"tstl %0\";
  38132. -       return \"cmpl #0,%0\"; }")
  38133. -
  38134. -   This is an instruction that sets the condition codes based on the
  38135. -value of a general operand.  It has no condition, so any insn whose RTL
  38136. -description has the form shown may be handled according to this
  38137. -pattern.  The name `tstsi' means "test a `SImode' value" and tells the
  38138. -RTL generation pass that, when it is necessary to test such a value, an
  38139. -insn to do so can be constructed using this pattern.
  38140. -
  38141. -   The output control string is a piece of C code which chooses which
  38142. -output template to return based on the kind of operand and the specific
  38143. -type of CPU for which code is being generated.
  38144. -
  38145. -   `"rm"' is an operand constraint.  Its meaning is explained below.
  38146. -
  38147. diff -rup --new-file baseline/fsf/gcc/gcc.info-16 amiga/fsf/gcc/gcc.info-16
  38148. --- baseline/fsf/gcc/gcc.info-16    Sat Jun 29 09:38:04 1996
  38149. +++ amiga/fsf/gcc/gcc.info-16    Wed Dec 31 17:00:00 1969
  38150. @@ -1,1327 +0,0 @@
  38151. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  38152. -file gcc.texi.
  38153. -
  38154. -   This file documents the use and the internals of the GNU compiler.
  38155. -
  38156. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  38157. -Boston, MA 02111-1307 USA
  38158. -
  38159. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  38160. -Foundation, Inc.
  38161. -
  38162. -   Permission is granted to make and distribute verbatim copies of this
  38163. -manual provided the copyright notice and this permission notice are
  38164. -preserved on all copies.
  38165. -
  38166. -   Permission is granted to copy and distribute modified versions of
  38167. -this manual under the conditions for verbatim copying, provided also
  38168. -that the sections entitled "GNU General Public License," "Funding for
  38169. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  38170. -included exactly as in the original, and provided that the entire
  38171. -resulting derived work is distributed under the terms of a permission
  38172. -notice identical to this one.
  38173. -
  38174. -   Permission is granted to copy and distribute translations of this
  38175. -manual into another language, under the above conditions for modified
  38176. -versions, except that the sections entitled "GNU General Public
  38177. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  38178. -`Look And Feel'", and this permission notice, may be included in
  38179. -translations approved by the Free Software Foundation instead of in the
  38180. -original English.
  38181. -
  38182. -
  38183. -File: gcc.info,  Node: RTL Template,  Next: Output Template,  Prev: Example,  Up: Machine Desc
  38184. -
  38185. -RTL Template
  38186. -============
  38187. -
  38188. -   The RTL template is used to define which insns match the particular
  38189. -pattern and how to find their operands.  For named patterns, the RTL
  38190. -template also says how to construct an insn from specified operands.
  38191. -
  38192. -   Construction involves substituting specified operands into a copy of
  38193. -the template.  Matching involves determining the values that serve as
  38194. -the operands in the insn being matched.  Both of these activities are
  38195. -controlled by special expression types that direct matching and
  38196. -substitution of the operands.
  38197. -
  38198. -`(match_operand:M N PREDICATE CONSTRAINT)'
  38199. -     This expression is a placeholder for operand number N of the insn.
  38200. -     When constructing an insn, operand number N will be substituted
  38201. -     at this point.  When matching an insn, whatever appears at this
  38202. -     position in the insn will be taken as operand number N; but it
  38203. -     must satisfy PREDICATE or this instruction pattern will not match
  38204. -     at all.
  38205. -
  38206. -     Operand numbers must be chosen consecutively counting from zero in
  38207. -     each instruction pattern.  There may be only one `match_operand'
  38208. -     expression in the pattern for each operand number.  Usually
  38209. -     operands are numbered in the order of appearance in `match_operand'
  38210. -     expressions.
  38211. -
  38212. -     PREDICATE is a string that is the name of a C function that
  38213. -     accepts two arguments, an expression and a machine mode.  During
  38214. -     matching, the function will be called with the putative operand as
  38215. -     the expression and M as the mode argument (if M is not specified,
  38216. -     `VOIDmode' will be used, which normally causes PREDICATE to accept
  38217. -     any mode).  If it returns zero, this instruction pattern fails to
  38218. -     match.  PREDICATE may be an empty string; then it means no test is
  38219. -     to be done on the operand, so anything which occurs in this
  38220. -     position is valid.
  38221. -
  38222. -     Most of the time, PREDICATE will reject modes other than M--but
  38223. -     not always.  For example, the predicate `address_operand' uses M
  38224. -     as the mode of memory ref that the address should be valid for.
  38225. -     Many predicates accept `const_int' nodes even though their mode is
  38226. -     `VOIDmode'.
  38227. -
  38228. -     CONSTRAINT controls reloading and the choice of the best register
  38229. -     class to use for a value, as explained later (*note
  38230. -     Constraints::.).
  38231. -
  38232. -     People are often unclear on the difference between the constraint
  38233. -     and the predicate.  The predicate helps decide whether a given
  38234. -     insn matches the pattern.  The constraint plays no role in this
  38235. -     decision; instead, it controls various decisions in the case of an
  38236. -     insn which does match.
  38237. -
  38238. -     On CISC machines, the most common PREDICATE is
  38239. -     `"general_operand"'.  This function checks that the putative
  38240. -     operand is either a constant, a register or a memory reference,
  38241. -     and that it is valid for mode M.
  38242. -
  38243. -     For an operand that must be a register, PREDICATE should be
  38244. -     `"register_operand"'.  Using `"general_operand"' would be valid,
  38245. -     since the reload pass would copy any non-register operands through
  38246. -     registers, but this would make GNU CC do extra work, it would
  38247. -     prevent invariant operands (such as constant) from being removed
  38248. -     from loops, and it would prevent the register allocator from doing
  38249. -     the best possible job.  On RISC machines, it is usually most
  38250. -     efficient to allow PREDICATE to accept only objects that the
  38251. -     constraints allow.
  38252. -
  38253. -     For an operand that must be a constant, you must be sure to either
  38254. -     use `"immediate_operand"' for PREDICATE, or make the instruction
  38255. -     pattern's extra condition require a constant, or both.  You cannot
  38256. -     expect the constraints to do this work!  If the constraints allow
  38257. -     only constants, but the predicate allows something else, the
  38258. -     compiler will crash when that case arises.
  38259. -
  38260. -`(match_scratch:M N CONSTRAINT)'
  38261. -     This expression is also a placeholder for operand number N and
  38262. -     indicates that operand must be a `scratch' or `reg' expression.
  38263. -
  38264. -     When matching patterns, this is equivalent to
  38265. -
  38266. -          (match_operand:M N "scratch_operand" PRED)
  38267. -
  38268. -     but, when generating RTL, it produces a (`scratch':M) expression.
  38269. -
  38270. -     If the last few expressions in a `parallel' are `clobber'
  38271. -     expressions whose operands are either a hard register or
  38272. -     `match_scratch', the combiner can add or delete them when
  38273. -     necessary.  *Note Side Effects::.
  38274. -
  38275. -`(match_dup N)'
  38276. -     This expression is also a placeholder for operand number N.  It is
  38277. -     used when the operand needs to appear more than once in the insn.
  38278. -
  38279. -     In construction, `match_dup' acts just like `match_operand': the
  38280. -     operand is substituted into the insn being constructed.  But in
  38281. -     matching, `match_dup' behaves differently.  It assumes that operand
  38282. -     number N has already been determined by a `match_operand'
  38283. -     appearing earlier in the recognition template, and it matches only
  38284. -     an identical-looking expression.
  38285. -
  38286. -`(match_operator:M N PREDICATE [OPERANDS...])'
  38287. -     This pattern is a kind of placeholder for a variable RTL expression
  38288. -     code.
  38289. -
  38290. -     When constructing an insn, it stands for an RTL expression whose
  38291. -     expression code is taken from that of operand N, and whose
  38292. -     operands are constructed from the patterns OPERANDS.
  38293. -
  38294. -     When matching an expression, it matches an expression if the
  38295. -     function PREDICATE returns nonzero on that expression *and* the
  38296. -     patterns OPERANDS match the operands of the expression.
  38297. -
  38298. -     Suppose that the function `commutative_operator' is defined as
  38299. -     follows, to match any expression whose operator is one of the
  38300. -     commutative arithmetic operators of RTL and whose mode is MODE:
  38301. -
  38302. -          int
  38303. -          commutative_operator (x, mode)
  38304. -               rtx x;
  38305. -               enum machine_mode mode;
  38306. -          {
  38307. -            enum rtx_code code = GET_CODE (x);
  38308. -            if (GET_MODE (x) != mode)
  38309. -              return 0;
  38310. -            return (GET_RTX_CLASS (code) == 'c'
  38311. -                    || code == EQ || code == NE);
  38312. -          }
  38313. -
  38314. -     Then the following pattern will match any RTL expression consisting
  38315. -     of a commutative operator applied to two general operands:
  38316. -
  38317. -          (match_operator:SI 3 "commutative_operator"
  38318. -            [(match_operand:SI 1 "general_operand" "g")
  38319. -             (match_operand:SI 2 "general_operand" "g")])
  38320. -
  38321. -     Here the vector `[OPERANDS...]' contains two patterns because the
  38322. -     expressions to be matched all contain two operands.
  38323. -
  38324. -     When this pattern does match, the two operands of the commutative
  38325. -     operator are recorded as operands 1 and 2 of the insn.  (This is
  38326. -     done by the two instances of `match_operand'.)  Operand 3 of the
  38327. -     insn will be the entire commutative expression: use `GET_CODE
  38328. -     (operands[3])' to see which commutative operator was used.
  38329. -
  38330. -     The machine mode M of `match_operator' works like that of
  38331. -     `match_operand': it is passed as the second argument to the
  38332. -     predicate function, and that function is solely responsible for
  38333. -     deciding whether the expression to be matched "has" that mode.
  38334. -
  38335. -     When constructing an insn, argument 3 of the gen-function will
  38336. -     specify the operation (i.e. the expression code) for the
  38337. -     expression to be made.  It should be an RTL expression, whose
  38338. -     expression code is copied into a new expression whose operands are
  38339. -     arguments 1 and 2 of the gen-function.  The subexpressions of
  38340. -     argument 3 are not used; only its expression code matters.
  38341. -
  38342. -     When `match_operator' is used in a pattern for matching an insn,
  38343. -     it usually best if the operand number of the `match_operator' is
  38344. -     higher than that of the actual operands of the insn.  This improves
  38345. -     register allocation because the register allocator often looks at
  38346. -     operands 1 and 2 of insns to see if it can do register tying.
  38347. -
  38348. -     There is no way to specify constraints in `match_operator'.  The
  38349. -     operand of the insn which corresponds to the `match_operator'
  38350. -     never has any constraints because it is never reloaded as a whole.
  38351. -     However, if parts of its OPERANDS are matched by `match_operand'
  38352. -     patterns, those parts may have constraints of their own.
  38353. -
  38354. -`(match_op_dup:M N[OPERANDS...])'
  38355. -     Like `match_dup', except that it applies to operators instead of
  38356. -     operands.  When constructing an insn, operand number N will be
  38357. -     substituted at this point.  But in matching, `match_op_dup' behaves
  38358. -     differently.  It assumes that operand number N has already been
  38359. -     determined by a `match_operator' appearing earlier in the
  38360. -     recognition template, and it matches only an identical-looking
  38361. -     expression.
  38362. -
  38363. -`(match_parallel N PREDICATE [SUBPAT...])'
  38364. -     This pattern is a placeholder for an insn that consists of a
  38365. -     `parallel' expression with a variable number of elements.  This
  38366. -     expression should only appear at the top level of an insn pattern.
  38367. -
  38368. -     When constructing an insn, operand number N will be substituted at
  38369. -     this point.  When matching an insn, it matches if the body of the
  38370. -     insn is a `parallel' expression with at least as many elements as
  38371. -     the vector of SUBPAT expressions in the `match_parallel', if each
  38372. -     SUBPAT matches the corresponding element of the `parallel', *and*
  38373. -     the function PREDICATE returns nonzero on the `parallel' that is
  38374. -     the body of the insn.  It is the responsibility of the predicate
  38375. -     to validate elements of the `parallel' beyond those listed in the
  38376. -     `match_parallel'.
  38377. -
  38378. -     A typical use of `match_parallel' is to match load and store
  38379. -     multiple expressions, which can contain a variable number of
  38380. -     elements in a `parallel'.  For example,
  38381. -
  38382. -          (define_insn ""
  38383. -            [(match_parallel 0 "load_multiple_operation"
  38384. -               [(set (match_operand:SI 1 "gpc_reg_operand" "=r")
  38385. -                     (match_operand:SI 2 "memory_operand" "m"))
  38386. -                (use (reg:SI 179))
  38387. -                (clobber (reg:SI 179))])]
  38388. -            ""
  38389. -            "loadm 0,0,%1,%2")
  38390. -
  38391. -     This example comes from `a29k.md'.  The function
  38392. -     `load_multiple_operations' is defined in `a29k.c' and checks that
  38393. -     subsequent elements in the `parallel' are the same as the `set' in
  38394. -     the pattern, except that they are referencing subsequent registers
  38395. -     and memory locations.
  38396. -
  38397. -     An insn that matches this pattern might look like:
  38398. -
  38399. -          (parallel
  38400. -           [(set (reg:SI 20) (mem:SI (reg:SI 100)))
  38401. -            (use (reg:SI 179))
  38402. -            (clobber (reg:SI 179))
  38403. -            (set (reg:SI 21)
  38404. -                 (mem:SI (plus:SI (reg:SI 100)
  38405. -                                  (const_int 4))))
  38406. -            (set (reg:SI 22)
  38407. -                 (mem:SI (plus:SI (reg:SI 100)
  38408. -                                  (const_int 8))))])
  38409. -
  38410. -`(match_par_dup N [SUBPAT...])'
  38411. -     Like `match_op_dup', but for `match_parallel' instead of
  38412. -     `match_operator'.
  38413. -
  38414. -`(address (match_operand:M N "address_operand" ""))'
  38415. -     This complex of expressions is a placeholder for an operand number
  38416. -     N in a "load address" instruction: an operand which specifies a
  38417. -     memory location in the usual way, but for which the actual operand
  38418. -     value used is the address of the location, not the contents of the
  38419. -     location.
  38420. -
  38421. -     `address' expressions never appear in RTL code, only in machine
  38422. -     descriptions.  And they are used only in machine descriptions that
  38423. -     do not use the operand constraint feature.  When operand
  38424. -     constraints are in use, the letter `p' in the constraint serves
  38425. -     this purpose.
  38426. -
  38427. -     M is the machine mode of the *memory location being addressed*,
  38428. -     not the machine mode of the address itself.  That mode is always
  38429. -     the same on a given target machine (it is `Pmode', which normally
  38430. -     is `SImode'), so there is no point in mentioning it; thus, no
  38431. -     machine mode is written in the `address' expression.  If some day
  38432. -     support is added for machines in which addresses of different
  38433. -     kinds of objects appear differently or are used differently (such
  38434. -     as the PDP-10), different formats would perhaps need different
  38435. -     machine modes and these modes might be written in the `address'
  38436. -     expression.
  38437. -
  38438. -
  38439. -File: gcc.info,  Node: Output Template,  Next: Output Statement,  Prev: RTL Template,  Up: Machine Desc
  38440. -
  38441. -Output Templates and Operand Substitution
  38442. -=========================================
  38443. -
  38444. -   The "output template" is a string which specifies how to output the
  38445. -assembler code for an instruction pattern.  Most of the template is a
  38446. -fixed string which is output literally.  The character `%' is used to
  38447. -specify where to substitute an operand; it can also be used to identify
  38448. -places where different variants of the assembler require different
  38449. -syntax.
  38450. -
  38451. -   In the simplest case, a `%' followed by a digit N says to output
  38452. -operand N at that point in the string.
  38453. -
  38454. -   `%' followed by a letter and a digit says to output an operand in an
  38455. -alternate fashion.  Four letters have standard, built-in meanings
  38456. -described below.  The machine description macro `PRINT_OPERAND' can
  38457. -define additional letters with nonstandard meanings.
  38458. -
  38459. -   `%cDIGIT' can be used to substitute an operand that is a constant
  38460. -value without the syntax that normally indicates an immediate operand.
  38461. -
  38462. -   `%nDIGIT' is like `%cDIGIT' except that the value of the constant is
  38463. -negated before printing.
  38464. -
  38465. -   `%aDIGIT' can be used to substitute an operand as if it were a
  38466. -memory reference, with the actual operand treated as the address.  This
  38467. -may be useful when outputting a "load address" instruction, because
  38468. -often the assembler syntax for such an instruction requires you to
  38469. -write the operand as if it were a memory reference.
  38470. -
  38471. -   `%lDIGIT' is used to substitute a `label_ref' into a jump
  38472. -instruction.
  38473. -
  38474. -   `%=' outputs a number which is unique to each instruction in the
  38475. -entire compilation.  This is useful for making local labels to be
  38476. -referred to more than once in a single template that generates multiple
  38477. -assembler instructions.
  38478. -
  38479. -   `%' followed by a punctuation character specifies a substitution that
  38480. -does not use an operand.  Only one case is standard: `%%' outputs a `%'
  38481. -into the assembler code.  Other nonstandard cases can be defined in the
  38482. -`PRINT_OPERAND' macro.  You must also define which punctuation
  38483. -characters are valid with the `PRINT_OPERAND_PUNCT_VALID_P' macro.
  38484. -
  38485. -   The template may generate multiple assembler instructions.  Write
  38486. -the text for the instructions, with `\;' between them.
  38487. -
  38488. -   When the RTL contains two operands which are required by constraint
  38489. -to match each other, the output template must refer only to the
  38490. -lower-numbered operand.  Matching operands are not always identical,
  38491. -and the rest of the compiler arranges to put the proper RTL expression
  38492. -for printing into the lower-numbered operand.
  38493. -
  38494. -   One use of nonstandard letters or punctuation following `%' is to
  38495. -distinguish between different assembler languages for the same machine;
  38496. -for example, Motorola syntax versus MIT syntax for the 68000.  Motorola
  38497. -syntax requires periods in most opcode names, while MIT syntax does
  38498. -not.  For example, the opcode `movel' in MIT syntax is `move.l' in
  38499. -Motorola syntax.  The same file of patterns is used for both kinds of
  38500. -output syntax, but the character sequence `%.' is used in each place
  38501. -where Motorola syntax wants a period.  The `PRINT_OPERAND' macro for
  38502. -Motorola syntax defines the sequence to output a period; the macro for
  38503. -MIT syntax defines it to do nothing.
  38504. -
  38505. -   As a special case, a template consisting of the single character `#'
  38506. -instructs the compiler to first split the insn, and then output the
  38507. -resulting instructions separately.  This helps eliminate redundancy in
  38508. -the output templates.   If you have a `define_insn' that needs to emit
  38509. -multiple assembler instructions, and there is an matching `define_split'
  38510. -already defined, then you can simply use `#' as the output template
  38511. -instead of writing an output template that emits the multiple assembler
  38512. -instructions.
  38513. -
  38514. -   If `ASSEMBLER_DIALECT' is defined, you can use
  38515. -`{option0|option1|option2}' constructs in the templates.  These
  38516. -describe multiple variants of assembler language syntax.  *Note
  38517. -Instruction Output::.
  38518. -
  38519. -
  38520. -File: gcc.info,  Node: Output Statement,  Next: Constraints,  Prev: Output Template,  Up: Machine Desc
  38521. -
  38522. -C Statements for Assembler Output
  38523. -=================================
  38524. -
  38525. -   Often a single fixed template string cannot produce correct and
  38526. -efficient assembler code for all the cases that are recognized by a
  38527. -single instruction pattern.  For example, the opcodes may depend on the
  38528. -kinds of operands; or some unfortunate combinations of operands may
  38529. -require extra machine instructions.
  38530. -
  38531. -   If the output control string starts with a `@', then it is actually
  38532. -a series of templates, each on a separate line.  (Blank lines and
  38533. -leading spaces and tabs are ignored.)  The templates correspond to the
  38534. -pattern's constraint alternatives (*note Multi-Alternative::.).  For
  38535. -example, if a target machine has a two-address add instruction `addr'
  38536. -to add into a register and another `addm' to add a register to memory,
  38537. -you might write this pattern:
  38538. -
  38539. -     (define_insn "addsi3"
  38540. -       [(set (match_operand:SI 0 "general_operand" "=r,m")
  38541. -             (plus:SI (match_operand:SI 1 "general_operand" "0,0")
  38542. -                      (match_operand:SI 2 "general_operand" "g,r")))]
  38543. -       ""
  38544. -       "@
  38545. -        addr %2,%0
  38546. -        addm %2,%0")
  38547. -
  38548. -   If the output control string starts with a `*', then it is not an
  38549. -output template but rather a piece of C program that should compute a
  38550. -template.  It should execute a `return' statement to return the
  38551. -template-string you want.  Most such templates use C string literals,
  38552. -which require doublequote characters to delimit them.  To include these
  38553. -doublequote characters in the string, prefix each one with `\'.
  38554. -
  38555. -   The operands may be found in the array `operands', whose C data type
  38556. -is `rtx []'.
  38557. -
  38558. -   It is very common to select different ways of generating assembler
  38559. -code based on whether an immediate operand is within a certain range.
  38560. -Be careful when doing this, because the result of `INTVAL' is an
  38561. -integer on the host machine.  If the host machine has more bits in an
  38562. -`int' than the target machine has in the mode in which the constant
  38563. -will be used, then some of the bits you get from `INTVAL' will be
  38564. -superfluous.  For proper results, you must carefully disregard the
  38565. -values of those bits.
  38566. -
  38567. -   It is possible to output an assembler instruction and then go on to
  38568. -output or compute more of them, using the subroutine `output_asm_insn'.
  38569. -This receives two arguments: a template-string and a vector of
  38570. -operands.  The vector may be `operands', or it may be another array of
  38571. -`rtx' that you declare locally and initialize yourself.
  38572. -
  38573. -   When an insn pattern has multiple alternatives in its constraints,
  38574. -often the appearance of the assembler code is determined mostly by
  38575. -which alternative was matched.  When this is so, the C code can test
  38576. -the variable `which_alternative', which is the ordinal number of the
  38577. -alternative that was actually satisfied (0 for the first, 1 for the
  38578. -second alternative, etc.).
  38579. -
  38580. -   For example, suppose there are two opcodes for storing zero, `clrreg'
  38581. -for registers and `clrmem' for memory locations.  Here is how a pattern
  38582. -could use `which_alternative' to choose between them:
  38583. -
  38584. -     (define_insn ""
  38585. -       [(set (match_operand:SI 0 "general_operand" "=r,m")
  38586. -             (const_int 0))]
  38587. -       ""
  38588. -       "*
  38589. -       return (which_alternative == 0
  38590. -               ? \"clrreg %0\" : \"clrmem %0\");
  38591. -       ")
  38592. -
  38593. -   The example above, where the assembler code to generate was *solely*
  38594. -determined by the alternative, could also have been specified as
  38595. -follows, having the output control string start with a `@':
  38596. -
  38597. -     (define_insn ""
  38598. -       [(set (match_operand:SI 0 "general_operand" "=r,m")
  38599. -             (const_int 0))]
  38600. -       ""
  38601. -       "@
  38602. -        clrreg %0
  38603. -        clrmem %0")
  38604. -
  38605. -
  38606. -File: gcc.info,  Node: Constraints,  Next: Standard Names,  Prev: Output Statement,  Up: Machine Desc
  38607. -
  38608. -Operand Constraints
  38609. -===================
  38610. -
  38611. -   Each `match_operand' in an instruction pattern can specify a
  38612. -constraint for the type of operands allowed.  Constraints can say
  38613. -whether an operand may be in a register, and which kinds of register;
  38614. -whether the operand can be a memory reference, and which kinds of
  38615. -address; whether the operand may be an immediate constant, and which
  38616. -possible values it may have.  Constraints can also require two operands
  38617. -to match.
  38618. -
  38619. -* Menu:
  38620. -
  38621. -* Simple Constraints::  Basic use of constraints.
  38622. -* Multi-Alternative::   When an insn has two alternative constraint-patterns.
  38623. -* Class Preferences::   Constraints guide which hard register to put things in.
  38624. -* Modifiers::           More precise control over effects of constraints.
  38625. -* Machine Constraints:: Existing constraints for some particular machines.
  38626. -* No Constraints::      Describing a clean machine without constraints.
  38627. -
  38628. -
  38629. -File: gcc.info,  Node: Simple Constraints,  Next: Multi-Alternative,  Up: Constraints
  38630. -
  38631. -Simple Constraints
  38632. -------------------
  38633. -
  38634. -   The simplest kind of constraint is a string full of letters, each of
  38635. -which describes one kind of operand that is permitted.  Here are the
  38636. -letters that are allowed:
  38637. -
  38638. -`m'
  38639. -     A memory operand is allowed, with any kind of address that the
  38640. -     machine supports in general.
  38641. -
  38642. -`o'
  38643. -     A memory operand is allowed, but only if the address is
  38644. -     "offsettable".  This means that adding a small integer (actually,
  38645. -     the width in bytes of the operand, as determined by its machine
  38646. -     mode) may be added to the address and the result is also a valid
  38647. -     memory address.
  38648. -
  38649. -     For example, an address which is constant is offsettable; so is an
  38650. -     address that is the sum of a register and a constant (as long as a
  38651. -     slightly larger constant is also within the range of
  38652. -     address-offsets supported by the machine); but an autoincrement or
  38653. -     autodecrement address is not offsettable.  More complicated
  38654. -     indirect/indexed addresses may or may not be offsettable depending
  38655. -     on the other addressing modes that the machine supports.
  38656. -
  38657. -     Note that in an output operand which can be matched by another
  38658. -     operand, the constraint letter `o' is valid only when accompanied
  38659. -     by both `<' (if the target machine has predecrement addressing)
  38660. -     and `>' (if the target machine has preincrement addressing).
  38661. -
  38662. -`V'
  38663. -     A memory operand that is not offsettable.  In other words,
  38664. -     anything that would fit the `m' constraint but not the `o'
  38665. -     constraint.
  38666. -
  38667. -`<'
  38668. -     A memory operand with autodecrement addressing (either
  38669. -     predecrement or postdecrement) is allowed.
  38670. -
  38671. -`>'
  38672. -     A memory operand with autoincrement addressing (either
  38673. -     preincrement or postincrement) is allowed.
  38674. -
  38675. -`r'
  38676. -     A register operand is allowed provided that it is in a general
  38677. -     register.
  38678. -
  38679. -`d', `a', `f', ...
  38680. -     Other letters can be defined in machine-dependent fashion to stand
  38681. -     for particular classes of registers.  `d', `a' and `f' are defined
  38682. -     on the 68000/68020 to stand for data, address and floating point
  38683. -     registers.
  38684. -
  38685. -`i'
  38686. -     An immediate integer operand (one with constant value) is allowed.
  38687. -     This includes symbolic constants whose values will be known only at
  38688. -     assembly time.
  38689. -
  38690. -`n'
  38691. -     An immediate integer operand with a known numeric value is allowed.
  38692. -     Many systems cannot support assembly-time constants for operands
  38693. -     less than a word wide.  Constraints for these operands should use
  38694. -     `n' rather than `i'.
  38695. -
  38696. -`I', `J', `K', ... `P'
  38697. -     Other letters in the range `I' through `P' may be defined in a
  38698. -     machine-dependent fashion to permit immediate integer operands with
  38699. -     explicit integer values in specified ranges.  For example, on the
  38700. -     68000, `I' is defined to stand for the range of values 1 to 8.
  38701. -     This is the range permitted as a shift count in the shift
  38702. -     instructions.
  38703. -
  38704. -`E'
  38705. -     An immediate floating operand (expression code `const_double') is
  38706. -     allowed, but only if the target floating point format is the same
  38707. -     as that of the host machine (on which the compiler is running).
  38708. -
  38709. -`F'
  38710. -     An immediate floating operand (expression code `const_double') is
  38711. -     allowed.
  38712. -
  38713. -`G', `H'
  38714. -     `G' and `H' may be defined in a machine-dependent fashion to
  38715. -     permit immediate floating operands in particular ranges of values.
  38716. -
  38717. -`s'
  38718. -     An immediate integer operand whose value is not an explicit
  38719. -     integer is allowed.
  38720. -
  38721. -     This might appear strange; if an insn allows a constant operand
  38722. -     with a value not known at compile time, it certainly must allow
  38723. -     any known value.  So why use `s' instead of `i'?  Sometimes it
  38724. -     allows better code to be generated.
  38725. -
  38726. -     For example, on the 68000 in a fullword instruction it is possible
  38727. -     to use an immediate operand; but if the immediate value is between
  38728. -     -128 and 127, better code results from loading the value into a
  38729. -     register and using the register.  This is because the load into
  38730. -     the register can be done with a `moveq' instruction.  We arrange
  38731. -     for this to happen by defining the letter `K' to mean "any integer
  38732. -     outside the range -128 to 127", and then specifying `Ks' in the
  38733. -     operand constraints.
  38734. -
  38735. -`g'
  38736. -     Any register, memory or immediate integer operand is allowed,
  38737. -     except for registers that are not general registers.
  38738. -
  38739. -`X'
  38740. -     Any operand whatsoever is allowed, even if it does not satisfy
  38741. -     `general_operand'.  This is normally used in the constraint of a
  38742. -     `match_scratch' when certain alternatives will not actually
  38743. -     require a scratch register.
  38744. -
  38745. -`0', `1', `2', ... `9'
  38746. -     An operand that matches the specified operand number is allowed.
  38747. -     If a digit is used together with letters within the same
  38748. -     alternative, the digit should come last.
  38749. -
  38750. -     This is called a "matching constraint" and what it really means is
  38751. -     that the assembler has only a single operand that fills two roles
  38752. -     considered separate in the RTL insn.  For example, an add insn has
  38753. -     two input operands and one output operand in the RTL, but on most
  38754. -     CISC machines an add instruction really has only two operands, one
  38755. -     of them an input-output operand:
  38756. -
  38757. -          addl #35,r12
  38758. -
  38759. -     Matching constraints are used in these circumstances.  More
  38760. -     precisely, the two operands that match must include one input-only
  38761. -     operand and one output-only operand.  Moreover, the digit must be a
  38762. -     smaller number than the number of the operand that uses it in the
  38763. -     constraint.
  38764. -
  38765. -     For operands to match in a particular case usually means that they
  38766. -     are identical-looking RTL expressions.  But in a few special cases
  38767. -     specific kinds of dissimilarity are allowed.  For example, `*x' as
  38768. -     an input operand will match `*x++' as an output operand.  For
  38769. -     proper results in such cases, the output template should always
  38770. -     use the output-operand's number when printing the operand.
  38771. -
  38772. -`p'
  38773. -     An operand that is a valid memory address is allowed.  This is for
  38774. -     "load address" and "push address" instructions.
  38775. -
  38776. -     `p' in the constraint must be accompanied by `address_operand' as
  38777. -     the predicate in the `match_operand'.  This predicate interprets
  38778. -     the mode specified in the `match_operand' as the mode of the memory
  38779. -     reference for which the address would be valid.
  38780. -
  38781. -`Q', `R', `S', ... `U'
  38782. -     Letters in the range `Q' through `U' may be defined in a
  38783. -     machine-dependent fashion to stand for arbitrary operand types.
  38784. -     The machine description macro `EXTRA_CONSTRAINT' is passed the
  38785. -     operand as its first argument and the constraint letter as its
  38786. -     second operand.
  38787. -
  38788. -     A typical use for this would be to distinguish certain types of
  38789. -     memory references that affect other insn operands.
  38790. -
  38791. -     Do not define these constraint letters to accept register
  38792. -     references (`reg'); the reload pass does not expect this and would
  38793. -     not handle it properly.
  38794. -
  38795. -   In order to have valid assembler code, each operand must satisfy its
  38796. -constraint.  But a failure to do so does not prevent the pattern from
  38797. -applying to an insn.  Instead, it directs the compiler to modify the
  38798. -code so that the constraint will be satisfied.  Usually this is done by
  38799. -copying an operand into a register.
  38800. -
  38801. -   Contrast, therefore, the two instruction patterns that follow:
  38802. -
  38803. -     (define_insn ""
  38804. -       [(set (match_operand:SI 0 "general_operand" "=r")
  38805. -             (plus:SI (match_dup 0)
  38806. -                      (match_operand:SI 1 "general_operand" "r")))]
  38807. -       ""
  38808. -       "...")
  38809. -
  38810. -which has two operands, one of which must appear in two places, and
  38811. -
  38812. -     (define_insn ""
  38813. -       [(set (match_operand:SI 0 "general_operand" "=r")
  38814. -             (plus:SI (match_operand:SI 1 "general_operand" "0")
  38815. -                      (match_operand:SI 2 "general_operand" "r")))]
  38816. -       ""
  38817. -       "...")
  38818. -
  38819. -which has three operands, two of which are required by a constraint to
  38820. -be identical.  If we are considering an insn of the form
  38821. -
  38822. -     (insn N PREV NEXT
  38823. -       (set (reg:SI 3)
  38824. -            (plus:SI (reg:SI 6) (reg:SI 109)))
  38825. -       ...)
  38826. -
  38827. -the first pattern would not apply at all, because this insn does not
  38828. -contain two identical subexpressions in the right place.  The pattern
  38829. -would say, "That does not look like an add instruction; try other
  38830. -patterns." The second pattern would say, "Yes, that's an add
  38831. -instruction, but there is something wrong with it."  It would direct
  38832. -the reload pass of the compiler to generate additional insns to make
  38833. -the constraint true.  The results might look like this:
  38834. -
  38835. -     (insn N2 PREV N
  38836. -       (set (reg:SI 3) (reg:SI 6))
  38837. -       ...)
  38838. -     
  38839. -     (insn N N2 NEXT
  38840. -       (set (reg:SI 3)
  38841. -            (plus:SI (reg:SI 3) (reg:SI 109)))
  38842. -       ...)
  38843. -
  38844. -   It is up to you to make sure that each operand, in each pattern, has
  38845. -constraints that can handle any RTL expression that could be present for
  38846. -that operand.  (When multiple alternatives are in use, each pattern
  38847. -must, for each possible combination of operand expressions, have at
  38848. -least one alternative which can handle that combination of operands.)
  38849. -The constraints don't need to *allow* any possible operand--when this is
  38850. -the case, they do not constrain--but they must at least point the way to
  38851. -reloading any possible operand so that it will fit.
  38852. -
  38853. -   * If the constraint accepts whatever operands the predicate permits,
  38854. -     there is no problem: reloading is never necessary for this operand.
  38855. -
  38856. -     For example, an operand whose constraints permit everything except
  38857. -     registers is safe provided its predicate rejects registers.
  38858. -
  38859. -     An operand whose predicate accepts only constant values is safe
  38860. -     provided its constraints include the letter `i'.  If any possible
  38861. -     constant value is accepted, then nothing less than `i' will do; if
  38862. -     the predicate is more selective, then the constraints may also be
  38863. -     more selective.
  38864. -
  38865. -   * Any operand expression can be reloaded by copying it into a
  38866. -     register.  So if an operand's constraints allow some kind of
  38867. -     register, it is certain to be safe.  It need not permit all
  38868. -     classes of registers; the compiler knows how to copy a register
  38869. -     into another register of the proper class in order to make an
  38870. -     instruction valid.
  38871. -
  38872. -   * A nonoffsettable memory reference can be reloaded by copying the
  38873. -     address into a register.  So if the constraint uses the letter
  38874. -     `o', all memory references are taken care of.
  38875. -
  38876. -   * A constant operand can be reloaded by allocating space in memory to
  38877. -     hold it as preinitialized data.  Then the memory reference can be
  38878. -     used in place of the constant.  So if the constraint uses the
  38879. -     letters `o' or `m', constant operands are not a problem.
  38880. -
  38881. -   * If the constraint permits a constant and a pseudo register used in
  38882. -     an insn was not allocated to a hard register and is equivalent to
  38883. -     a constant, the register will be replaced with the constant.  If
  38884. -     the predicate does not permit a constant and the insn is
  38885. -     re-recognized for some reason, the compiler will crash.  Thus the
  38886. -     predicate must always recognize any objects allowed by the
  38887. -     constraint.
  38888. -
  38889. -   If the operand's predicate can recognize registers, but the
  38890. -constraint does not permit them, it can make the compiler crash.  When
  38891. -this operand happens to be a register, the reload pass will be stymied,
  38892. -because it does not know how to copy a register temporarily into memory.
  38893. -
  38894. -
  38895. -File: gcc.info,  Node: Multi-Alternative,  Next: Class Preferences,  Prev: Simple Constraints,  Up: Constraints
  38896. -
  38897. -Multiple Alternative Constraints
  38898. ---------------------------------
  38899. -
  38900. -   Sometimes a single instruction has multiple alternative sets of
  38901. -possible operands.  For example, on the 68000, a logical-or instruction
  38902. -can combine register or an immediate value into memory, or it can
  38903. -combine any kind of operand into a register; but it cannot combine one
  38904. -memory location into another.
  38905. -
  38906. -   These constraints are represented as multiple alternatives.  An
  38907. -alternative can be described by a series of letters for each operand.
  38908. -The overall constraint for an operand is made from the letters for this
  38909. -operand from the first alternative, a comma, the letters for this
  38910. -operand from the second alternative, a comma, and so on until the last
  38911. -alternative.  Here is how it is done for fullword logical-or on the
  38912. -68000:
  38913. -
  38914. -     (define_insn "iorsi3"
  38915. -       [(set (match_operand:SI 0 "general_operand" "=m,d")
  38916. -             (ior:SI (match_operand:SI 1 "general_operand" "%0,0")
  38917. -                     (match_operand:SI 2 "general_operand" "dKs,dmKs")))]
  38918. -       ...)
  38919. -
  38920. -   The first alternative has `m' (memory) for operand 0, `0' for
  38921. -operand 1 (meaning it must match operand 0), and `dKs' for operand 2.
  38922. -The second alternative has `d' (data register) for operand 0, `0' for
  38923. -operand 1, and `dmKs' for operand 2.  The `=' and `%' in the
  38924. -constraints apply to all the alternatives; their meaning is explained
  38925. -in the next section (*note Class Preferences::.).
  38926. -
  38927. -   If all the operands fit any one alternative, the instruction is
  38928. -valid.  Otherwise, for each alternative, the compiler counts how many
  38929. -instructions must be added to copy the operands so that that
  38930. -alternative applies.  The alternative requiring the least copying is
  38931. -chosen.  If two alternatives need the same amount of copying, the one
  38932. -that comes first is chosen.  These choices can be altered with the `?'
  38933. -and `!' characters:
  38934. -
  38935. -`?'
  38936. -     Disparage slightly the alternative that the `?' appears in, as a
  38937. -     choice when no alternative applies exactly.  The compiler regards
  38938. -     this alternative as one unit more costly for each `?' that appears
  38939. -     in it.
  38940. -
  38941. -`!'
  38942. -     Disparage severely the alternative that the `!' appears in.  This
  38943. -     alternative can still be used if it fits without reloading, but if
  38944. -     reloading is needed, some other alternative will be used.
  38945. -
  38946. -   When an insn pattern has multiple alternatives in its constraints,
  38947. -often the appearance of the assembler code is determined mostly by which
  38948. -alternative was matched.  When this is so, the C code for writing the
  38949. -assembler code can use the variable `which_alternative', which is the
  38950. -ordinal number of the alternative that was actually satisfied (0 for
  38951. -the first, 1 for the second alternative, etc.).  *Note Output
  38952. -Statement::.
  38953. -
  38954. -
  38955. -File: gcc.info,  Node: Class Preferences,  Next: Modifiers,  Prev: Multi-Alternative,  Up: Constraints
  38956. -
  38957. -Register Class Preferences
  38958. ---------------------------
  38959. -
  38960. -   The operand constraints have another function: they enable the
  38961. -compiler to decide which kind of hardware register a pseudo register is
  38962. -best allocated to.  The compiler examines the constraints that apply to
  38963. -the insns that use the pseudo register, looking for the
  38964. -machine-dependent letters such as `d' and `a' that specify classes of
  38965. -registers.  The pseudo register is put in whichever class gets the most
  38966. -"votes".  The constraint letters `g' and `r' also vote: they vote in
  38967. -favor of a general register.  The machine description says which
  38968. -registers are considered general.
  38969. -
  38970. -   Of course, on some machines all registers are equivalent, and no
  38971. -register classes are defined.  Then none of this complexity is relevant.
  38972. -
  38973. -
  38974. -File: gcc.info,  Node: Modifiers,  Next: Machine Constraints,  Prev: Class Preferences,  Up: Constraints
  38975. -
  38976. -Constraint Modifier Characters
  38977. -------------------------------
  38978. -
  38979. -   Here are constraint modifier characters.
  38980. -
  38981. -`='
  38982. -     Means that this operand is write-only for this instruction: the
  38983. -     previous value is discarded and replaced by output data.
  38984. -
  38985. -`+'
  38986. -     Means that this operand is both read and written by the
  38987. -     instruction.
  38988. -
  38989. -     When the compiler fixes up the operands to satisfy the constraints,
  38990. -     it needs to know which operands are inputs to the instruction and
  38991. -     which are outputs from it.  `=' identifies an output; `+'
  38992. -     identifies an operand that is both input and output; all other
  38993. -     operands are assumed to be input only.
  38994. -
  38995. -`&'
  38996. -     Means (in a particular alternative) that this operand is written
  38997. -     before the instruction is finished using the input operands.
  38998. -     Therefore, this operand may not lie in a register that is used as
  38999. -     an input operand or as part of any memory address.
  39000. -
  39001. -     `&' applies only to the alternative in which it is written.  In
  39002. -     constraints with multiple alternatives, sometimes one alternative
  39003. -     requires `&' while others do not.  See, for example, the `movdf'
  39004. -     insn of the 68000.
  39005. -
  39006. -     `&' does not obviate the need to write `='.
  39007. -
  39008. -`%'
  39009. -     Declares the instruction to be commutative for this operand and the
  39010. -     following operand.  This means that the compiler may interchange
  39011. -     the two operands if that is the cheapest way to make all operands
  39012. -     fit the constraints.  This is often used in patterns for addition
  39013. -     instructions that really have only two operands: the result must
  39014. -     go in one of the arguments.  Here for example, is how the 68000
  39015. -     halfword-add instruction is defined:
  39016. -
  39017. -          (define_insn "addhi3"
  39018. -            [(set (match_operand:HI 0 "general_operand" "=m,r")
  39019. -               (plus:HI (match_operand:HI 1 "general_operand" "%0,0")
  39020. -                        (match_operand:HI 2 "general_operand" "di,g")))]
  39021. -            ...)
  39022. -
  39023. -`#'
  39024. -     Says that all following characters, up to the next comma, are to be
  39025. -     ignored as a constraint.  They are significant only for choosing
  39026. -     register preferences.
  39027. -
  39028. -`*'
  39029. -     Says that the following character should be ignored when choosing
  39030. -     register preferences.  `*' has no effect on the meaning of the
  39031. -     constraint as a constraint, and no effect on reloading.
  39032. -
  39033. -     Here is an example: the 68000 has an instruction to sign-extend a
  39034. -     halfword in a data register, and can also sign-extend a value by
  39035. -     copying it into an address register.  While either kind of
  39036. -     register is acceptable, the constraints on an address-register
  39037. -     destination are less strict, so it is best if register allocation
  39038. -     makes an address register its goal.  Therefore, `*' is used so
  39039. -     that the `d' constraint letter (for data register) is ignored when
  39040. -     computing register preferences.
  39041. -
  39042. -          (define_insn "extendhisi2"
  39043. -            [(set (match_operand:SI 0 "general_operand" "=*d,a")
  39044. -                  (sign_extend:SI
  39045. -                   (match_operand:HI 1 "general_operand" "0,g")))]
  39046. -            ...)
  39047. -
  39048. -
  39049. -File: gcc.info,  Node: Machine Constraints,  Next: No Constraints,  Prev: Modifiers,  Up: Constraints
  39050. -
  39051. -Constraints for Particular Machines
  39052. ------------------------------------
  39053. -
  39054. -   Whenever possible, you should use the general-purpose constraint
  39055. -letters in `asm' arguments, since they will convey meaning more readily
  39056. -to people reading your code.  Failing that, use the constraint letters
  39057. -that usually have very similar meanings across architectures.  The most
  39058. -commonly used constraints are `m' and `r' (for memory and
  39059. -general-purpose registers respectively; *note Simple Constraints::.),
  39060. -and `I', usually the letter indicating the most common
  39061. -immediate-constant format.
  39062. -
  39063. -   For each machine architecture, the `config/MACHINE.h' file defines
  39064. -additional constraints.  These constraints are used by the compiler
  39065. -itself for instruction generation, as well as for `asm' statements;
  39066. -therefore, some of the constraints are not particularly interesting for
  39067. -`asm'.  The constraints are defined through these macros:
  39068. -
  39069. -`REG_CLASS_FROM_LETTER'
  39070. -     Register class constraints (usually lower case).
  39071. -
  39072. -`CONST_OK_FOR_LETTER_P'
  39073. -     Immediate constant constraints, for non-floating point constants of
  39074. -     word size or smaller precision (usually upper case).
  39075. -
  39076. -`CONST_DOUBLE_OK_FOR_LETTER_P'
  39077. -     Immediate constant constraints, for all floating point constants
  39078. -     and for constants of greater than word size precision (usually
  39079. -     upper case).
  39080. -
  39081. -`EXTRA_CONSTRAINT'
  39082. -     Special cases of registers or memory.  This macro is not required,
  39083. -     and is only defined for some machines.
  39084. -
  39085. -   Inspecting these macro definitions in the compiler source for your
  39086. -machine is the best way to be certain you have the right constraints.
  39087. -However, here is a summary of the machine-dependent constraints
  39088. -available on some particular machines.
  39089. -
  39090. -*ARM family--`arm.h'*
  39091. -    `f'
  39092. -          Floating-point register
  39093. -
  39094. -    `F'
  39095. -          One of the floating-point constants 0.0, 0.5, 1.0, 2.0, 3.0,
  39096. -          4.0, 5.0 or 10.0
  39097. -
  39098. -    `G'
  39099. -          Floating-point constant that would satisfy the constraint `F'
  39100. -          if it were negated
  39101. -
  39102. -    `I'
  39103. -          Integer that is valid as an immediate operand in a data
  39104. -          processing instruction.  That is, an integer in the range 0
  39105. -          to 255 rotated by a multiple of 2
  39106. -
  39107. -    `J'
  39108. -          Integer in the range -4095 to 4095
  39109. -
  39110. -    `K'
  39111. -          Integer that satisfies constraint `I' when inverted (ones
  39112. -          complement)
  39113. -
  39114. -    `L'
  39115. -          Integer that satisfies constraint `I' when negated (twos
  39116. -          complement)
  39117. -
  39118. -    `M'
  39119. -          Integer in the range 0 to 32
  39120. -
  39121. -    `Q'
  39122. -          A memory reference where the exact address is in a single
  39123. -          register (``m'' is preferable for `asm' statements)
  39124. -
  39125. -    `R'
  39126. -          An item in the constant pool
  39127. -
  39128. -    `S'
  39129. -          A symbol in the text segment of the current file
  39130. -
  39131. -*AMD 29000 family--`a29k.h'*
  39132. -    `l'
  39133. -          Local register 0
  39134. -
  39135. -    `b'
  39136. -          Byte Pointer (`BP') register
  39137. -
  39138. -    `q'
  39139. -          `Q' register
  39140. -
  39141. -    `h'
  39142. -          Special purpose register
  39143. -
  39144. -    `A'
  39145. -          First accumulator register
  39146. -
  39147. -    `a'
  39148. -          Other accumulator register
  39149. -
  39150. -    `f'
  39151. -          Floating point register
  39152. -
  39153. -    `I'
  39154. -          Constant greater than 0, less than 0x100
  39155. -
  39156. -    `J'
  39157. -          Constant greater than 0, less than 0x10000
  39158. -
  39159. -    `K'
  39160. -          Constant whose high 24 bits are on (1)
  39161. -
  39162. -    `L'
  39163. -          16 bit constant whose high 8 bits are on (1)
  39164. -
  39165. -    `M'
  39166. -          32 bit constant whose high 16 bits are on (1)
  39167. -
  39168. -    `N'
  39169. -          32 bit negative constant that fits in 8 bits
  39170. -
  39171. -    `O'
  39172. -          The constant 0x80000000 or, on the 29050, any 32 bit constant
  39173. -          whose low 16 bits are 0.
  39174. -
  39175. -    `P'
  39176. -          16 bit negative constant that fits in 8 bits
  39177. -
  39178. -    `G'
  39179. -    `H'
  39180. -          A floating point constant (in `asm' statements, use the
  39181. -          machine independent `E' or `F' instead)
  39182. -
  39183. -*IBM RS6000--`rs6000.h'*
  39184. -    `b'
  39185. -          Address base register
  39186. -
  39187. -    `f'
  39188. -          Floating point register
  39189. -
  39190. -    `h'
  39191. -          `MQ', `CTR', or `LINK' register
  39192. -
  39193. -    `q'
  39194. -          `MQ' register
  39195. -
  39196. -    `c'
  39197. -          `CTR' register
  39198. -
  39199. -    `l'
  39200. -          `LINK' register
  39201. -
  39202. -    `x'
  39203. -          `CR' register (condition register) number 0
  39204. -
  39205. -    `y'
  39206. -          `CR' register (condition register)
  39207. -
  39208. -    `I'
  39209. -          Signed 16 bit constant
  39210. -
  39211. -    `J'
  39212. -          Constant whose low 16 bits are 0
  39213. -
  39214. -    `K'
  39215. -          Constant whose high 16 bits are 0
  39216. -
  39217. -    `L'
  39218. -          Constant suitable as a mask operand
  39219. -
  39220. -    `M'
  39221. -          Constant larger than 31
  39222. -
  39223. -    `N'
  39224. -          Exact power of 2
  39225. -
  39226. -    `O'
  39227. -          Zero
  39228. -
  39229. -    `P'
  39230. -          Constant whose negation is a signed 16 bit constant
  39231. -
  39232. -    `G'
  39233. -          Floating point constant that can be loaded into a register
  39234. -          with one instruction per word
  39235. -
  39236. -    `Q'
  39237. -          Memory operand that is an offset from a register (`m' is
  39238. -          preferable for `asm' statements)
  39239. -
  39240. -*Intel 386--`i386.h'*
  39241. -    `q'
  39242. -          `a', `b', `c', or `d' register
  39243. -
  39244. -    `A'
  39245. -          `a', or `d' register (for 64-bit ints)
  39246. -
  39247. -    `f'
  39248. -          Floating point register
  39249. -
  39250. -    `t'
  39251. -          First (top of stack) floating point register
  39252. -
  39253. -    `u'
  39254. -          Second floating point register
  39255. -
  39256. -    `a'
  39257. -          `a' register
  39258. -
  39259. -    `b'
  39260. -          `b' register
  39261. -
  39262. -    `c'
  39263. -          `c' register
  39264. -
  39265. -    `d'
  39266. -          `d' register
  39267. -
  39268. -    `D'
  39269. -          `di' register
  39270. -
  39271. -    `S'
  39272. -          `si' register
  39273. -
  39274. -    `I'
  39275. -          Constant in range 0 to 31 (for 32 bit shifts)
  39276. -
  39277. -    `J'
  39278. -          Constant in range 0 to 63 (for 64 bit shifts)
  39279. -
  39280. -    `K'
  39281. -          `0xff'
  39282. -
  39283. -    `L'
  39284. -          `0xffff'
  39285. -
  39286. -    `M'
  39287. -          0, 1, 2, or 3 (shifts for `lea' instruction)
  39288. -
  39289. -    `N'
  39290. -          Constant in range 0 to 255 (for `out' instruction)
  39291. -
  39292. -    `G'
  39293. -          Standard 80387 floating point constant
  39294. -
  39295. -*Intel 960--`i960.h'*
  39296. -    `f'
  39297. -          Floating point register (`fp0' to `fp3')
  39298. -
  39299. -    `l'
  39300. -          Local register (`r0' to `r15')
  39301. -
  39302. -    `b'
  39303. -          Global register (`g0' to `g15')
  39304. -
  39305. -    `d'
  39306. -          Any local or global register
  39307. -
  39308. -    `I'
  39309. -          Integers from 0 to 31
  39310. -
  39311. -    `J'
  39312. -          0
  39313. -
  39314. -    `K'
  39315. -          Integers from -31 to 0
  39316. -
  39317. -    `G'
  39318. -          Floating point 0
  39319. -
  39320. -    `H'
  39321. -          Floating point 1
  39322. -
  39323. -*MIPS--`mips.h'*
  39324. -    `d'
  39325. -          General-purpose integer register
  39326. -
  39327. -    `f'
  39328. -          Floating-point register (if available)
  39329. -
  39330. -    `h'
  39331. -          `Hi' register
  39332. -
  39333. -    `l'
  39334. -          `Lo' register
  39335. -
  39336. -    `x'
  39337. -          `Hi' or `Lo' register
  39338. -
  39339. -    `y'
  39340. -          General-purpose integer register
  39341. -
  39342. -    `z'
  39343. -          Floating-point status register
  39344. -
  39345. -    `I'
  39346. -          Signed 16 bit constant (for arithmetic instructions)
  39347. -
  39348. -    `J'
  39349. -          Zero
  39350. -
  39351. -    `K'
  39352. -          Zero-extended 16-bit constant (for logic instructions)
  39353. -
  39354. -    `L'
  39355. -          Constant with low 16 bits zero (can be loaded with `lui')
  39356. -
  39357. -    `M'
  39358. -          32 bit constant which requires two instructions to load (a
  39359. -          constant which is not `I', `K', or `L')
  39360. -
  39361. -    `N'
  39362. -          Negative 16 bit constant
  39363. -
  39364. -    `O'
  39365. -          Exact power of two
  39366. -
  39367. -    `P'
  39368. -          Positive 16 bit constant
  39369. -
  39370. -    `G'
  39371. -          Floating point zero
  39372. -
  39373. -    `Q'
  39374. -          Memory reference that can be loaded with more than one
  39375. -          instruction (`m' is preferable for `asm' statements)
  39376. -
  39377. -    `R'
  39378. -          Memory reference that can be loaded with one instruction (`m'
  39379. -          is preferable for `asm' statements)
  39380. -
  39381. -    `S'
  39382. -          Memory reference in external OSF/rose PIC format (`m' is
  39383. -          preferable for `asm' statements)
  39384. -
  39385. -*Motorola 680x0--`m68k.h'*
  39386. -    `a'
  39387. -          Address register
  39388. -
  39389. -    `d'
  39390. -          Data register
  39391. -
  39392. -    `f'
  39393. -          68881 floating-point register, if available
  39394. -
  39395. -    `x'
  39396. -          Sun FPA (floating-point) register, if available
  39397. -
  39398. -    `y'
  39399. -          First 16 Sun FPA registers, if available
  39400. -
  39401. -    `I'
  39402. -          Integer in the range 1 to 8
  39403. -
  39404. -    `J'
  39405. -          16 bit signed number
  39406. -
  39407. -    `K'
  39408. -          Signed number whose magnitude is greater than 0x80
  39409. -
  39410. -    `L'
  39411. -          Integer in the range -8 to -1
  39412. -
  39413. -    `G'
  39414. -          Floating point constant that is not a 68881 constant
  39415. -
  39416. -    `H'
  39417. -          Floating point constant that can be used by Sun FPA
  39418. -
  39419. -*SPARC--`sparc.h'*
  39420. -    `f'
  39421. -          Floating-point register
  39422. -
  39423. -    `I'
  39424. -          Signed 13 bit constant
  39425. -
  39426. -    `J'
  39427. -          Zero
  39428. -
  39429. -    `K'
  39430. -          32 bit constant with the low 12 bits clear (a constant that
  39431. -          can be loaded with the `sethi' instruction)
  39432. -
  39433. -    `G'
  39434. -          Floating-point zero
  39435. -
  39436. -    `H'
  39437. -          Signed 13 bit constant, sign-extended to 32 or 64 bits
  39438. -
  39439. -    `Q'
  39440. -          Memory reference that can be loaded with one instruction
  39441. -          (`m' is more appropriate for `asm' statements)
  39442. -
  39443. -    `S'
  39444. -          Constant, or memory address
  39445. -
  39446. -    `T'
  39447. -          Memory address aligned to an 8-byte boundary
  39448. -
  39449. -    `U'
  39450. -          Even register
  39451. -
  39452. -
  39453. -File: gcc.info,  Node: No Constraints,  Prev: Machine Constraints,  Up: Constraints
  39454. -
  39455. -Not Using Constraints
  39456. ----------------------
  39457. -
  39458. -   Some machines are so clean that operand constraints are not
  39459. -required.  For example, on the Vax, an operand valid in one context is
  39460. -valid in any other context.  On such a machine, every operand
  39461. -constraint would be `g', excepting only operands of "load address"
  39462. -instructions which are written as if they referred to a memory
  39463. -location's contents but actual refer to its address.  They would have
  39464. -constraint `p'.
  39465. -
  39466. -   For such machines, instead of writing `g' and `p' for all the
  39467. -constraints, you can choose to write a description with empty
  39468. -constraints.  Then you write `""' for the constraint in every
  39469. -`match_operand'.  Address operands are identified by writing an
  39470. -`address' expression around the `match_operand', not by their
  39471. -constraints.
  39472. -
  39473. -   When the machine description has just empty constraints, certain
  39474. -parts of compilation are skipped, making the compiler faster.  However,
  39475. -few machines actually do not need constraints; all machine descriptions
  39476. -now in existence use constraints.
  39477. -
  39478. diff -rup --new-file baseline/fsf/gcc/gcc.info-17 amiga/fsf/gcc/gcc.info-17
  39479. --- baseline/fsf/gcc/gcc.info-17    Sat Jun 29 09:38:05 1996
  39480. +++ amiga/fsf/gcc/gcc.info-17    Wed Dec 31 17:00:00 1969
  39481. @@ -1,1107 +0,0 @@
  39482. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  39483. -file gcc.texi.
  39484. -
  39485. -   This file documents the use and the internals of the GNU compiler.
  39486. -
  39487. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  39488. -Boston, MA 02111-1307 USA
  39489. -
  39490. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  39491. -Foundation, Inc.
  39492. -
  39493. -   Permission is granted to make and distribute verbatim copies of this
  39494. -manual provided the copyright notice and this permission notice are
  39495. -preserved on all copies.
  39496. -
  39497. -   Permission is granted to copy and distribute modified versions of
  39498. -this manual under the conditions for verbatim copying, provided also
  39499. -that the sections entitled "GNU General Public License," "Funding for
  39500. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  39501. -included exactly as in the original, and provided that the entire
  39502. -resulting derived work is distributed under the terms of a permission
  39503. -notice identical to this one.
  39504. -
  39505. -   Permission is granted to copy and distribute translations of this
  39506. -manual into another language, under the above conditions for modified
  39507. -versions, except that the sections entitled "GNU General Public
  39508. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  39509. -`Look And Feel'", and this permission notice, may be included in
  39510. -translations approved by the Free Software Foundation instead of in the
  39511. -original English.
  39512. -
  39513. -
  39514. -File: gcc.info,  Node: Standard Names,  Next: Pattern Ordering,  Prev: Constraints,  Up: Machine Desc
  39515. -
  39516. -Standard Pattern Names For Generation
  39517. -=====================================
  39518. -
  39519. -   Here is a table of the instruction names that are meaningful in the
  39520. -RTL generation pass of the compiler.  Giving one of these names to an
  39521. -instruction pattern tells the RTL generation pass that it can use the
  39522. -pattern in to accomplish a certain task.
  39523. -
  39524. -`movM'
  39525. -     Here M stands for a two-letter machine mode name, in lower case.
  39526. -     This instruction pattern moves data with that machine mode from
  39527. -     operand 1 to operand 0.  For example, `movsi' moves full-word data.
  39528. -
  39529. -     If operand 0 is a `subreg' with mode M of a register whose own
  39530. -     mode is wider than M, the effect of this instruction is to store
  39531. -     the specified value in the part of the register that corresponds
  39532. -     to mode M.  The effect on the rest of the register is undefined.
  39533. -
  39534. -     This class of patterns is special in several ways.  First of all,
  39535. -     each of these names *must* be defined, because there is no other
  39536. -     way to copy a datum from one place to another.
  39537. -
  39538. -     Second, these patterns are not used solely in the RTL generation
  39539. -     pass.  Even the reload pass can generate move insns to copy values
  39540. -     from stack slots into temporary registers.  When it does so, one
  39541. -     of the operands is a hard register and the other is an operand
  39542. -     that can need to be reloaded into a register.
  39543. -
  39544. -     Therefore, when given such a pair of operands, the pattern must
  39545. -     generate RTL which needs no reloading and needs no temporary
  39546. -     registers--no registers other than the operands.  For example, if
  39547. -     you support the pattern with a `define_expand', then in such a
  39548. -     case the `define_expand' mustn't call `force_reg' or any other such
  39549. -     function which might generate new pseudo registers.
  39550. -
  39551. -     This requirement exists even for subword modes on a RISC machine
  39552. -     where fetching those modes from memory normally requires several
  39553. -     insns and some temporary registers.  Look in `spur.md' to see how
  39554. -     the requirement can be satisfied.
  39555. -
  39556. -     During reload a memory reference with an invalid address may be
  39557. -     passed as an operand.  Such an address will be replaced with a
  39558. -     valid address later in the reload pass.  In this case, nothing may
  39559. -     be done with the address except to use it as it stands.  If it is
  39560. -     copied, it will not be replaced with a valid address.  No attempt
  39561. -     should be made to make such an address into a valid address and no
  39562. -     routine (such as `change_address') that will do so may be called.
  39563. -     Note that `general_operand' will fail when applied to such an
  39564. -     address.
  39565. -
  39566. -     The global variable `reload_in_progress' (which must be explicitly
  39567. -     declared if required) can be used to determine whether such special
  39568. -     handling is required.
  39569. -
  39570. -     The variety of operands that have reloads depends on the rest of
  39571. -     the machine description, but typically on a RISC machine these can
  39572. -     only be pseudo registers that did not get hard registers, while on
  39573. -     other machines explicit memory references will get optional
  39574. -     reloads.
  39575. -
  39576. -     If a scratch register is required to move an object to or from
  39577. -     memory, it can be allocated using `gen_reg_rtx' prior to reload.
  39578. -     But this is impossible during and after reload.  If there are
  39579. -     cases needing scratch registers after reload, you must define
  39580. -     `SECONDARY_INPUT_RELOAD_CLASS' and perhaps also
  39581. -     `SECONDARY_OUTPUT_RELOAD_CLASS' to detect them, and provide
  39582. -     patterns `reload_inM' or `reload_outM' to handle them.  *Note
  39583. -     Register Classes::.
  39584. -
  39585. -     The constraints on a `moveM' must permit moving any hard register
  39586. -     to any other hard register provided that `HARD_REGNO_MODE_OK'
  39587. -     permits mode M in both registers and `REGISTER_MOVE_COST' applied
  39588. -     to their classes returns a value of 2.
  39589. -
  39590. -     It is obligatory to support floating point `moveM' instructions
  39591. -     into and out of any registers that can hold fixed point values,
  39592. -     because unions and structures (which have modes `SImode' or
  39593. -     `DImode') can be in those registers and they may have floating
  39594. -     point members.
  39595. -
  39596. -     There may also be a need to support fixed point `moveM'
  39597. -     instructions in and out of floating point registers.
  39598. -     Unfortunately, I have forgotten why this was so, and I don't know
  39599. -     whether it is still true.  If `HARD_REGNO_MODE_OK' rejects fixed
  39600. -     point values in floating point registers, then the constraints of
  39601. -     the fixed point `moveM' instructions must be designed to avoid
  39602. -     ever trying to reload into a floating point register.
  39603. -
  39604. -`reload_inM'
  39605. -`reload_outM'
  39606. -     Like `movM', but used when a scratch register is required to move
  39607. -     between operand 0 and operand 1.  Operand 2 describes the scratch
  39608. -     register.  See the discussion of the `SECONDARY_RELOAD_CLASS'
  39609. -     macro in *note Register Classes::..
  39610. -
  39611. -`movstrictM'
  39612. -     Like `movM' except that if operand 0 is a `subreg' with mode M of
  39613. -     a register whose natural mode is wider, the `movstrictM'
  39614. -     instruction is guaranteed not to alter any of the register except
  39615. -     the part which belongs to mode M.
  39616. -
  39617. -`load_multiple'
  39618. -     Load several consecutive memory locations into consecutive
  39619. -     registers.  Operand 0 is the first of the consecutive registers,
  39620. -     operand 1 is the first memory location, and operand 2 is a
  39621. -     constant: the number of consecutive registers.
  39622. -
  39623. -     Define this only if the target machine really has such an
  39624. -     instruction; do not define this if the most efficient way of
  39625. -     loading consecutive registers from memory is to do them one at a
  39626. -     time.
  39627. -
  39628. -     On some machines, there are restrictions as to which consecutive
  39629. -     registers can be stored into memory, such as particular starting or
  39630. -     ending register numbers or only a range of valid counts.  For those
  39631. -     machines, use a `define_expand' (*note Expander Definitions::.)
  39632. -     and make the pattern fail if the restrictions are not met.
  39633. -
  39634. -     Write the generated insn as a `parallel' with elements being a
  39635. -     `set' of one register from the appropriate memory location (you may
  39636. -     also need `use' or `clobber' elements).  Use a `match_parallel'
  39637. -     (*note RTL Template::.) to recognize the insn.  See `a29k.md' and
  39638. -     `rs6000.md' for examples of the use of this insn pattern.
  39639. -
  39640. -`store_multiple'
  39641. -     Similar to `load_multiple', but store several consecutive registers
  39642. -     into consecutive memory locations.  Operand 0 is the first of the
  39643. -     consecutive memory locations, operand 1 is the first register, and
  39644. -     operand 2 is a constant: the number of consecutive registers.
  39645. -
  39646. -`addM3'
  39647. -     Add operand 2 and operand 1, storing the result in operand 0.  All
  39648. -     operands must have mode M.  This can be used even on two-address
  39649. -     machines, by means of constraints requiring operands 1 and 0 to be
  39650. -     the same location.
  39651. -
  39652. -`subM3', `mulM3'
  39653. -`divM3', `udivM3', `modM3', `umodM3'
  39654. -`sminM3', `smaxM3', `uminM3', `umaxM3'
  39655. -`andM3', `iorM3', `xorM3'
  39656. -     Similar, for other arithmetic operations.
  39657. -
  39658. -`mulhisi3'
  39659. -     Multiply operands 1 and 2, which have mode `HImode', and store a
  39660. -     `SImode' product in operand 0.
  39661. -
  39662. -`mulqihi3', `mulsidi3'
  39663. -     Similar widening-multiplication instructions of other widths.
  39664. -
  39665. -`umulqihi3', `umulhisi3', `umulsidi3'
  39666. -     Similar widening-multiplication instructions that do unsigned
  39667. -     multiplication.
  39668. -
  39669. -`mulM3_highpart'
  39670. -     Perform a signed multiplication of operands 1 and 2, which have
  39671. -     mode M, and store the most significant half of the product in
  39672. -     operand 0.  The least significant half of the product is discarded.
  39673. -
  39674. -`umulM3_highpart'
  39675. -     Similar, but the multiplication is unsigned.
  39676. -
  39677. -`divmodM4'
  39678. -     Signed division that produces both a quotient and a remainder.
  39679. -     Operand 1 is divided by operand 2 to produce a quotient stored in
  39680. -     operand 0 and a remainder stored in operand 3.
  39681. -
  39682. -     For machines with an instruction that produces both a quotient and
  39683. -     a remainder, provide a pattern for `divmodM4' but do not provide
  39684. -     patterns for `divM3' and `modM3'.  This allows optimization in the
  39685. -     relatively common case when both the quotient and remainder are
  39686. -     computed.
  39687. -
  39688. -     If an instruction that just produces a quotient or just a remainder
  39689. -     exists and is more efficient than the instruction that produces
  39690. -     both, write the output routine of `divmodM4' to call
  39691. -     `find_reg_note' and look for a `REG_UNUSED' note on the quotient
  39692. -     or remainder and generate the appropriate instruction.
  39693. -
  39694. -`udivmodM4'
  39695. -     Similar, but does unsigned division.
  39696. -
  39697. -`ashlM3'
  39698. -     Arithmetic-shift operand 1 left by a number of bits specified by
  39699. -     operand 2, and store the result in operand 0.  Here M is the mode
  39700. -     of operand 0 and operand 1; operand 2's mode is specified by the
  39701. -     instruction pattern, and the compiler will convert the operand to
  39702. -     that mode before generating the instruction.
  39703. -
  39704. -`ashrM3', `lshrM3', `rotlM3', `rotrM3'
  39705. -     Other shift and rotate instructions, analogous to the `ashlM3'
  39706. -     instructions.
  39707. -
  39708. -`negM2'
  39709. -     Negate operand 1 and store the result in operand 0.
  39710. -
  39711. -`absM2'
  39712. -     Store the absolute value of operand 1 into operand 0.
  39713. -
  39714. -`sqrtM2'
  39715. -     Store the square root of operand 1 into operand 0.
  39716. -
  39717. -     The `sqrt' built-in function of C always uses the mode which
  39718. -     corresponds to the C data type `double'.
  39719. -
  39720. -`ffsM2'
  39721. -     Store into operand 0 one plus the index of the least significant
  39722. -     1-bit of operand 1.  If operand 1 is zero, store zero.  M is the
  39723. -     mode of operand 0; operand 1's mode is specified by the instruction
  39724. -     pattern, and the compiler will convert the operand to that mode
  39725. -     before generating the instruction.
  39726. -
  39727. -     The `ffs' built-in function of C always uses the mode which
  39728. -     corresponds to the C data type `int'.
  39729. -
  39730. -`one_cmplM2'
  39731. -     Store the bitwise-complement of operand 1 into operand 0.
  39732. -
  39733. -`cmpM'
  39734. -     Compare operand 0 and operand 1, and set the condition codes.  The
  39735. -     RTL pattern should look like this:
  39736. -
  39737. -          (set (cc0) (compare (match_operand:M 0 ...)
  39738. -                              (match_operand:M 1 ...)))
  39739. -
  39740. -`tstM'
  39741. -     Compare operand 0 against zero, and set the condition codes.  The
  39742. -     RTL pattern should look like this:
  39743. -
  39744. -          (set (cc0) (match_operand:M 0 ...))
  39745. -
  39746. -     `tstM' patterns should not be defined for machines that do not use
  39747. -     `(cc0)'.  Doing so would confuse the optimizer since it would no
  39748. -     longer be clear which `set' operations were comparisons.  The
  39749. -     `cmpM' patterns should be used instead.
  39750. -
  39751. -`movstrM'
  39752. -     Block move instruction.  The addresses of the destination and
  39753. -     source strings are the first two operands, and both are in mode
  39754. -     `Pmode'.  The number of bytes to move is the third operand, in
  39755. -     mode M.
  39756. -
  39757. -     The fourth operand is the known shared alignment of the source and
  39758. -     destination, in the form of a `const_int' rtx.  Thus, if the
  39759. -     compiler knows that both source and destination are word-aligned,
  39760. -     it may provide the value 4 for this operand.
  39761. -
  39762. -     These patterns need not give special consideration to the
  39763. -     possibility that the source and destination strings might overlap.
  39764. -
  39765. -`cmpstrM'
  39766. -     Block compare instruction, with five operands.  Operand 0 is the
  39767. -     output; it has mode M.  The remaining four operands are like the
  39768. -     operands of `movstrM'.  The two memory blocks specified are
  39769. -     compared byte by byte in lexicographic order.  The effect of the
  39770. -     instruction is to store a value in operand 0 whose sign indicates
  39771. -     the result of the comparison.
  39772. -
  39773. -     Compute the length of a string, with three operands.  Operand 0 is
  39774. -     the result (of mode M), operand 1 is a `mem' referring to the
  39775. -     first character of the string, operand 2 is the character to
  39776. -     search for (normally zero), and operand 3 is a constant describing
  39777. -     the known alignment of the beginning of the string.
  39778. -
  39779. -`floatMN2'
  39780. -     Convert signed integer operand 1 (valid for fixed point mode M) to
  39781. -     floating point mode N and store in operand 0 (which has mode N).
  39782. -
  39783. -`floatunsMN2'
  39784. -     Convert unsigned integer operand 1 (valid for fixed point mode M)
  39785. -     to floating point mode N and store in operand 0 (which has mode N).
  39786. -
  39787. -`fixMN2'
  39788. -     Convert operand 1 (valid for floating point mode M) to fixed point
  39789. -     mode N as a signed number and store in operand 0 (which has mode
  39790. -     N).  This instruction's result is defined only when the value of
  39791. -     operand 1 is an integer.
  39792. -
  39793. -`fixunsMN2'
  39794. -     Convert operand 1 (valid for floating point mode M) to fixed point
  39795. -     mode N as an unsigned number and store in operand 0 (which has
  39796. -     mode N).  This instruction's result is defined only when the value
  39797. -     of operand 1 is an integer.
  39798. -
  39799. -`ftruncM2'
  39800. -     Convert operand 1 (valid for floating point mode M) to an integer
  39801. -     value, still represented in floating point mode M, and store it in
  39802. -     operand 0 (valid for floating point mode M).
  39803. -
  39804. -`fix_truncMN2'
  39805. -     Like `fixMN2' but works for any floating point value of mode M by
  39806. -     converting the value to an integer.
  39807. -
  39808. -`fixuns_truncMN2'
  39809. -     Like `fixunsMN2' but works for any floating point value of mode M
  39810. -     by converting the value to an integer.
  39811. -
  39812. -`truncMN'
  39813. -     Truncate operand 1 (valid for mode M) to mode N and store in
  39814. -     operand 0 (which has mode N).  Both modes must be fixed point or
  39815. -     both floating point.
  39816. -
  39817. -`extendMN'
  39818. -     Sign-extend operand 1 (valid for mode M) to mode N and store in
  39819. -     operand 0 (which has mode N).  Both modes must be fixed point or
  39820. -     both floating point.
  39821. -
  39822. -`zero_extendMN'
  39823. -     Zero-extend operand 1 (valid for mode M) to mode N and store in
  39824. -     operand 0 (which has mode N).  Both modes must be fixed point.
  39825. -
  39826. -`extv'
  39827. -     Extract a bit field from operand 1 (a register or memory operand),
  39828. -     where operand 2 specifies the width in bits and operand 3 the
  39829. -     starting bit, and store it in operand 0.  Operand 0 must have mode
  39830. -     `word_mode'.  Operand 1 may have mode `byte_mode' or `word_mode';
  39831. -     often `word_mode' is allowed only for registers.  Operands 2 and 3
  39832. -     must be valid for `word_mode'.
  39833. -
  39834. -     The RTL generation pass generates this instruction only with
  39835. -     constants for operands 2 and 3.
  39836. -
  39837. -     The bit-field value is sign-extended to a full word integer before
  39838. -     it is stored in operand 0.
  39839. -
  39840. -`extzv'
  39841. -     Like `extv' except that the bit-field value is zero-extended.
  39842. -
  39843. -`insv'
  39844. -     Store operand 3 (which must be valid for `word_mode') into a bit
  39845. -     field in operand 0, where operand 1 specifies the width in bits and
  39846. -     operand 2 the starting bit.  Operand 0 may have mode `byte_mode' or
  39847. -     `word_mode'; often `word_mode' is allowed only for registers.
  39848. -     Operands 1 and 2 must be valid for `word_mode'.
  39849. -
  39850. -     The RTL generation pass generates this instruction only with
  39851. -     constants for operands 1 and 2.
  39852. -
  39853. -`movMODEcc'
  39854. -     Conditionally move operand 2 or operand 3 into operand 0 according
  39855. -     to the comparison in operand 1.  If the comparison is true,
  39856. -     operand 2 is moved into operand 0, otherwise operand 3 is moved.
  39857. -
  39858. -     The mode of the operands being compared need not be the same as
  39859. -     the operands being moved.  Some machines, sparc64 for example,
  39860. -     have instructions that conditionally move an integer value based
  39861. -     on the floating point condition codes and vice versa.
  39862. -
  39863. -     If the machine does not have conditional move instructions, do not
  39864. -     define these patterns.
  39865. -
  39866. -`sCOND'
  39867. -     Store zero or nonzero in the operand according to the condition
  39868. -     codes.  Value stored is nonzero iff the condition COND is true.
  39869. -     cOND is the name of a comparison operation expression code, such
  39870. -     as `eq', `lt' or `leu'.
  39871. -
  39872. -     You specify the mode that the operand must have when you write the
  39873. -     `match_operand' expression.  The compiler automatically sees which
  39874. -     mode you have used and supplies an operand of that mode.
  39875. -
  39876. -     The value stored for a true condition must have 1 as its low bit,
  39877. -     or else must be negative.  Otherwise the instruction is not
  39878. -     suitable and you should omit it from the machine description.  You
  39879. -     describe to the compiler exactly which value is stored by defining
  39880. -     the macro `STORE_FLAG_VALUE' (*note Misc::.).  If a description
  39881. -     cannot be found that can be used for all the `sCOND' patterns, you
  39882. -     should omit those operations from the machine description.
  39883. -
  39884. -     These operations may fail, but should do so only in relatively
  39885. -     uncommon cases; if they would fail for common cases involving
  39886. -     integer comparisons, it is best to omit these patterns.
  39887. -
  39888. -     If these operations are omitted, the compiler will usually
  39889. -     generate code that copies the constant one to the target and
  39890. -     branches around an assignment of zero to the target.  If this code
  39891. -     is more efficient than the potential instructions used for the
  39892. -     `sCOND' pattern followed by those required to convert the result
  39893. -     into a 1 or a zero in `SImode', you should omit the `sCOND'
  39894. -     operations from the machine description.
  39895. -
  39896. -`bCOND'
  39897. -     Conditional branch instruction.  Operand 0 is a `label_ref' that
  39898. -     refers to the label to jump to.  Jump if the condition codes meet
  39899. -     condition COND.
  39900. -
  39901. -     Some machines do not follow the model assumed here where a
  39902. -     comparison instruction is followed by a conditional branch
  39903. -     instruction.  In that case, the `cmpM' (and `tstM') patterns should
  39904. -     simply store the operands away and generate all the required insns
  39905. -     in a `define_expand' (*note Expander Definitions::.) for the
  39906. -     conditional branch operations.  All calls to expand `bCOND'
  39907. -     patterns are immediately preceded by calls to expand either a
  39908. -     `cmpM' pattern or a `tstM' pattern.
  39909. -
  39910. -     Machines that use a pseudo register for the condition code value,
  39911. -     or where the mode used for the comparison depends on the condition
  39912. -     being tested, should also use the above mechanism.  *Note Jump
  39913. -     Patterns::
  39914. -
  39915. -     The above discussion also applies to the `movMODEcc' and `sCOND'
  39916. -     patterns.
  39917. -
  39918. -`call'
  39919. -     Subroutine call instruction returning no value.  Operand 0 is the
  39920. -     function to call; operand 1 is the number of bytes of arguments
  39921. -     pushed (in mode `SImode', except it is normally a `const_int');
  39922. -     operand 2 is the number of registers used as operands.
  39923. -
  39924. -     On most machines, operand 2 is not actually stored into the RTL
  39925. -     pattern.  It is supplied for the sake of some RISC machines which
  39926. -     need to put this information into the assembler code; they can put
  39927. -     it in the RTL instead of operand 1.
  39928. -
  39929. -     Operand 0 should be a `mem' RTX whose address is the address of the
  39930. -     function.  Note, however, that this address can be a `symbol_ref'
  39931. -     expression even if it would not be a legitimate memory address on
  39932. -     the target machine.  If it is also not a valid argument for a call
  39933. -     instruction, the pattern for this operation should be a
  39934. -     `define_expand' (*note Expander Definitions::.) that places the
  39935. -     address into a register and uses that register in the call
  39936. -     instruction.
  39937. -
  39938. -`call_value'
  39939. -     Subroutine call instruction returning a value.  Operand 0 is the
  39940. -     hard register in which the value is returned.  There are three more
  39941. -     operands, the same as the three operands of the `call' instruction
  39942. -     (but with numbers increased by one).
  39943. -
  39944. -     Subroutines that return `BLKmode' objects use the `call' insn.
  39945. -
  39946. -`call_pop', `call_value_pop'
  39947. -     Similar to `call' and `call_value', except used if defined and if
  39948. -     `RETURN_POPS_ARGS' is non-zero.  They should emit a `parallel'
  39949. -     that contains both the function call and a `set' to indicate the
  39950. -     adjustment made to the frame pointer.
  39951. -
  39952. -     For machines where `RETURN_POPS_ARGS' can be non-zero, the use of
  39953. -     these patterns increases the number of functions for which the
  39954. -     frame pointer can be eliminated, if desired.
  39955. -
  39956. -`untyped_call'
  39957. -     Subroutine call instruction returning a value of any type.
  39958. -     Operand 0 is the function to call; operand 1 is a memory location
  39959. -     where the result of calling the function is to be stored; operand
  39960. -     2 is a `parallel' expression where each element is a `set'
  39961. -     expression that indicates the saving of a function return value
  39962. -     into the result block.
  39963. -
  39964. -     This instruction pattern should be defined to support
  39965. -     `__builtin_apply' on machines where special instructions are needed
  39966. -     to call a subroutine with arbitrary arguments or to save the value
  39967. -     returned.  This instruction pattern is required on machines that
  39968. -     have multiple registers that can hold a return value (i.e.
  39969. -     `FUNCTION_VALUE_REGNO_P' is true for more than one register).
  39970. -
  39971. -`return'
  39972. -     Subroutine return instruction.  This instruction pattern name
  39973. -     should be defined only if a single instruction can do all the work
  39974. -     of returning from a function.
  39975. -
  39976. -     Like the `movM' patterns, this pattern is also used after the RTL
  39977. -     generation phase.  In this case it is to support machines where
  39978. -     multiple instructions are usually needed to return from a
  39979. -     function, but some class of functions only requires one
  39980. -     instruction to implement a return.  Normally, the applicable
  39981. -     functions are those which do not need to save any registers or
  39982. -     allocate stack space.
  39983. -
  39984. -     For such machines, the condition specified in this pattern should
  39985. -     only be true when `reload_completed' is non-zero and the function's
  39986. -     epilogue would only be a single instruction.  For machines with
  39987. -     register windows, the routine `leaf_function_p' may be used to
  39988. -     determine if a register window push is required.
  39989. -
  39990. -     Machines that have conditional return instructions should define
  39991. -     patterns such as
  39992. -
  39993. -          (define_insn ""
  39994. -            [(set (pc)
  39995. -                  (if_then_else (match_operator
  39996. -                                   0 "comparison_operator"
  39997. -                                   [(cc0) (const_int 0)])
  39998. -                                (return)
  39999. -                                (pc)))]
  40000. -            "CONDITION"
  40001. -            "...")
  40002. -
  40003. -     where CONDITION would normally be the same condition specified on
  40004. -     the named `return' pattern.
  40005. -
  40006. -`untyped_return'
  40007. -     Untyped subroutine return instruction.  This instruction pattern
  40008. -     should be defined to support `__builtin_return' on machines where
  40009. -     special instructions are needed to return a value of any type.
  40010. -
  40011. -     Operand 0 is a memory location where the result of calling a
  40012. -     function with `__builtin_apply' is stored; operand 1 is a
  40013. -     `parallel' expression where each element is a `set' expression
  40014. -     that indicates the restoring of a function return value from the
  40015. -     result block.
  40016. -
  40017. -`nop'
  40018. -     No-op instruction.  This instruction pattern name should always be
  40019. -     defined to output a no-op in assembler code.  `(const_int 0)' will
  40020. -     do as an RTL pattern.
  40021. -
  40022. -`indirect_jump'
  40023. -     An instruction to jump to an address which is operand zero.  This
  40024. -     pattern name is mandatory on all machines.
  40025. -
  40026. -`casesi'
  40027. -     Instruction to jump through a dispatch table, including bounds
  40028. -     checking.  This instruction takes five operands:
  40029. -
  40030. -       1. The index to dispatch on, which has mode `SImode'.
  40031. -
  40032. -       2. The lower bound for indices in the table, an integer constant.
  40033. -
  40034. -       3. The total range of indices in the table--the largest index
  40035. -          minus the smallest one (both inclusive).
  40036. -
  40037. -       4. A label that precedes the table itself.
  40038. -
  40039. -       5. A label to jump to if the index has a value outside the
  40040. -          bounds.  (If the machine-description macro
  40041. -          `CASE_DROPS_THROUGH' is defined, then an out-of-bounds index
  40042. -          drops through to the code following the jump table instead of
  40043. -          jumping to this label.  In that case, this label is not
  40044. -          actually used by the `casesi' instruction, but it is always
  40045. -          provided as an operand.)
  40046. -
  40047. -     The table is a `addr_vec' or `addr_diff_vec' inside of a
  40048. -     `jump_insn'.  The number of elements in the table is one plus the
  40049. -     difference between the upper bound and the lower bound.
  40050. -
  40051. -`tablejump'
  40052. -     Instruction to jump to a variable address.  This is a low-level
  40053. -     capability which can be used to implement a dispatch table when
  40054. -     there is no `casesi' pattern.
  40055. -
  40056. -     This pattern requires two operands: the address or offset, and a
  40057. -     label which should immediately precede the jump table.  If the
  40058. -     macro `CASE_VECTOR_PC_RELATIVE' is defined then the first operand
  40059. -     is an offset which counts from the address of the table;
  40060. -     otherwise, it is an absolute address to jump to.  In either case,
  40061. -     the first operand has mode `Pmode'.
  40062. -
  40063. -     The `tablejump' insn is always the last insn before the jump table
  40064. -     it uses.  Its assembler code normally has no need to use the
  40065. -     second operand, but you should incorporate it in the RTL pattern so
  40066. -     that the jump optimizer will not delete the table as unreachable
  40067. -     code.
  40068. -
  40069. -`save_stack_block'
  40070. -`save_stack_function'
  40071. -`save_stack_nonlocal'
  40072. -`restore_stack_block'
  40073. -`restore_stack_function'
  40074. -`restore_stack_nonlocal'
  40075. -     Most machines save and restore the stack pointer by copying it to
  40076. -     or from an object of mode `Pmode'.  Do not define these patterns on
  40077. -     such machines.
  40078. -
  40079. -     Some machines require special handling for stack pointer saves and
  40080. -     restores.  On those machines, define the patterns corresponding to
  40081. -     the non-standard cases by using a `define_expand' (*note Expander
  40082. -     Definitions::.) that produces the required insns.  The three types
  40083. -     of saves and restores are:
  40084. -
  40085. -       1. `save_stack_block' saves the stack pointer at the start of a
  40086. -          block that allocates a variable-sized object, and
  40087. -          `restore_stack_block' restores the stack pointer when the
  40088. -          block is exited.
  40089. -
  40090. -       2. `save_stack_function' and `restore_stack_function' do a
  40091. -          similar job for the outermost block of a function and are
  40092. -          used when the function allocates variable-sized objects or
  40093. -          calls `alloca'.  Only the epilogue uses the restored stack
  40094. -          pointer, allowing a simpler save or restore sequence on some
  40095. -          machines.
  40096. -
  40097. -       3. `save_stack_nonlocal' is used in functions that contain labels
  40098. -          branched to by nested functions.  It saves the stack pointer
  40099. -          in such a way that the inner function can use
  40100. -          `restore_stack_nonlocal' to restore the stack pointer.  The
  40101. -          compiler generates code to restore the frame and argument
  40102. -          pointer registers, but some machines require saving and
  40103. -          restoring additional data such as register window information
  40104. -          or stack backchains.  Place insns in these patterns to save
  40105. -          and restore any such required data.
  40106. -
  40107. -     When saving the stack pointer, operand 0 is the save area and
  40108. -     operand 1 is the stack pointer.  The mode used to allocate the
  40109. -     save area is the mode of operand 0.  You must specify an integral
  40110. -     mode, or `VOIDmode' if no save area is needed for a particular
  40111. -     type of save (either because no save is needed or because a
  40112. -     machine-specific save area can be used).  Operand 0 is the stack
  40113. -     pointer and operand 1 is the save area for restore operations.  If
  40114. -     `save_stack_block' is defined, operand 0 must not be `VOIDmode'
  40115. -     since these saves can be arbitrarily nested.
  40116. -
  40117. -     A save area is a `mem' that is at a constant offset from
  40118. -     `virtual_stack_vars_rtx' when the stack pointer is saved for use by
  40119. -     nonlocal gotos and a `reg' in the other two cases.
  40120. -
  40121. -`allocate_stack'
  40122. -     Subtract (or add if `STACK_GROWS_DOWNWARD' is undefined) operand 0
  40123. -     from the stack pointer to create space for dynamically allocated
  40124. -     data.
  40125. -
  40126. -     Do not define this pattern if all that must be done is the
  40127. -     subtraction.  Some machines require other operations such as stack
  40128. -     probes or maintaining the back chain.  Define this pattern to emit
  40129. -     those operations in addition to updating the stack pointer.
  40130. -
  40131. -
  40132. -File: gcc.info,  Node: Pattern Ordering,  Next: Dependent Patterns,  Prev: Standard Names,  Up: Machine Desc
  40133. -
  40134. -When the Order of Patterns Matters
  40135. -==================================
  40136. -
  40137. -   Sometimes an insn can match more than one instruction pattern.  Then
  40138. -the pattern that appears first in the machine description is the one
  40139. -used.  Therefore, more specific patterns (patterns that will match
  40140. -fewer things) and faster instructions (those that will produce better
  40141. -code when they do match) should usually go first in the description.
  40142. -
  40143. -   In some cases the effect of ordering the patterns can be used to hide
  40144. -a pattern when it is not valid.  For example, the 68000 has an
  40145. -instruction for converting a fullword to floating point and another for
  40146. -converting a byte to floating point.  An instruction converting an
  40147. -integer to floating point could match either one.  We put the pattern
  40148. -to convert the fullword first to make sure that one will be used rather
  40149. -than the other.  (Otherwise a large integer might be generated as a
  40150. -single-byte immediate quantity, which would not work.) Instead of using
  40151. -this pattern ordering it would be possible to make the pattern for
  40152. -convert-a-byte smart enough to deal properly with any constant value.
  40153. -
  40154. -
  40155. -File: gcc.info,  Node: Dependent Patterns,  Next: Jump Patterns,  Prev: Pattern Ordering,  Up: Machine Desc
  40156. -
  40157. -Interdependence of Patterns
  40158. -===========================
  40159. -
  40160. -   Every machine description must have a named pattern for each of the
  40161. -conditional branch names `bCOND'.  The recognition template must always
  40162. -have the form
  40163. -
  40164. -     (set (pc)
  40165. -          (if_then_else (COND (cc0) (const_int 0))
  40166. -                        (label_ref (match_operand 0 "" ""))
  40167. -                        (pc)))
  40168. -
  40169. -In addition, every machine description must have an anonymous pattern
  40170. -for each of the possible reverse-conditional branches.  Their templates
  40171. -look like
  40172. -
  40173. -     (set (pc)
  40174. -          (if_then_else (COND (cc0) (const_int 0))
  40175. -                        (pc)
  40176. -                        (label_ref (match_operand 0 "" ""))))
  40177. -
  40178. -They are necessary because jump optimization can turn direct-conditional
  40179. -branches into reverse-conditional branches.
  40180. -
  40181. -   It is often convenient to use the `match_operator' construct to
  40182. -reduce the number of patterns that must be specified for branches.  For
  40183. -example,
  40184. -
  40185. -     (define_insn ""
  40186. -       [(set (pc)
  40187. -             (if_then_else (match_operator 0 "comparison_operator"
  40188. -                                           [(cc0) (const_int 0)])
  40189. -                           (pc)
  40190. -                           (label_ref (match_operand 1 "" ""))))]
  40191. -       "CONDITION"
  40192. -       "...")
  40193. -
  40194. -   In some cases machines support instructions identical except for the
  40195. -machine mode of one or more operands.  For example, there may be
  40196. -"sign-extend halfword" and "sign-extend byte" instructions whose
  40197. -patterns are
  40198. -
  40199. -     (set (match_operand:SI 0 ...)
  40200. -          (extend:SI (match_operand:HI 1 ...)))
  40201. -     
  40202. -     (set (match_operand:SI 0 ...)
  40203. -          (extend:SI (match_operand:QI 1 ...)))
  40204. -
  40205. -Constant integers do not specify a machine mode, so an instruction to
  40206. -extend a constant value could match either pattern.  The pattern it
  40207. -actually will match is the one that appears first in the file.  For
  40208. -correct results, this must be the one for the widest possible mode
  40209. -(`HImode', here).  If the pattern matches the `QImode' instruction, the
  40210. -results will be incorrect if the constant value does not actually fit
  40211. -that mode.
  40212. -
  40213. -   Such instructions to extend constants are rarely generated because
  40214. -they are optimized away, but they do occasionally happen in nonoptimized
  40215. -compilations.
  40216. -
  40217. -   If a constraint in a pattern allows a constant, the reload pass may
  40218. -replace a register with a constant permitted by the constraint in some
  40219. -cases.  Similarly for memory references.  Because of this substitution,
  40220. -you should not provide separate patterns for increment and decrement
  40221. -instructions.  Instead, they should be generated from the same pattern
  40222. -that supports register-register add insns by examining the operands and
  40223. -generating the appropriate machine instruction.
  40224. -
  40225. -
  40226. -File: gcc.info,  Node: Jump Patterns,  Next: Insn Canonicalizations,  Prev: Dependent Patterns,  Up: Machine Desc
  40227. -
  40228. -Defining Jump Instruction Patterns
  40229. -==================================
  40230. -
  40231. -   For most machines, GNU CC assumes that the machine has a condition
  40232. -code.  A comparison insn sets the condition code, recording the results
  40233. -of both signed and unsigned comparison of the given operands.  A
  40234. -separate branch insn tests the condition code and branches or not
  40235. -according its value.  The branch insns come in distinct signed and
  40236. -unsigned flavors.  Many common machines, such as the Vax, the 68000 and
  40237. -the 32000, work this way.
  40238. -
  40239. -   Some machines have distinct signed and unsigned compare
  40240. -instructions, and only one set of conditional branch instructions.  The
  40241. -easiest way to handle these machines is to treat them just like the
  40242. -others until the final stage where assembly code is written.  At this
  40243. -time, when outputting code for the compare instruction, peek ahead at
  40244. -the following branch using `next_cc0_user (insn)'.  (The variable
  40245. -`insn' refers to the insn being output, in the output-writing code in
  40246. -an instruction pattern.)  If the RTL says that is an unsigned branch,
  40247. -output an unsigned compare; otherwise output a signed compare.  When
  40248. -the branch itself is output, you can treat signed and unsigned branches
  40249. -identically.
  40250. -
  40251. -   The reason you can do this is that GNU CC always generates a pair of
  40252. -consecutive RTL insns, possibly separated by `note' insns, one to set
  40253. -the condition code and one to test it, and keeps the pair inviolate
  40254. -until the end.
  40255. -
  40256. -   To go with this technique, you must define the machine-description
  40257. -macro `NOTICE_UPDATE_CC' to do `CC_STATUS_INIT'; in other words, no
  40258. -compare instruction is superfluous.
  40259. -
  40260. -   Some machines have compare-and-branch instructions and no condition
  40261. -code.  A similar technique works for them.  When it is time to "output"
  40262. -a compare instruction, record its operands in two static variables.
  40263. -When outputting the branch-on-condition-code instruction that follows,
  40264. -actually output a compare-and-branch instruction that uses the
  40265. -remembered operands.
  40266. -
  40267. -   It also works to define patterns for compare-and-branch instructions.
  40268. -In optimizing compilation, the pair of compare and branch instructions
  40269. -will be combined according to these patterns.  But this does not happen
  40270. -if optimization is not requested.  So you must use one of the solutions
  40271. -above in addition to any special patterns you define.
  40272. -
  40273. -   In many RISC machines, most instructions do not affect the condition
  40274. -code and there may not even be a separate condition code register.  On
  40275. -these machines, the restriction that the definition and use of the
  40276. -condition code be adjacent insns is not necessary and can prevent
  40277. -important optimizations.  For example, on the IBM RS/6000, there is a
  40278. -delay for taken branches unless the condition code register is set three
  40279. -instructions earlier than the conditional branch.  The instruction
  40280. -scheduler cannot perform this optimization if it is not permitted to
  40281. -separate the definition and use of the condition code register.
  40282. -
  40283. -   On these machines, do not use `(cc0)', but instead use a register to
  40284. -represent the condition code.  If there is a specific condition code
  40285. -register in the machine, use a hard register.  If the condition code or
  40286. -comparison result can be placed in any general register, or if there are
  40287. -multiple condition registers, use a pseudo register.
  40288. -
  40289. -   On some machines, the type of branch instruction generated may
  40290. -depend on the way the condition code was produced; for example, on the
  40291. -68k and Sparc, setting the condition code directly from an add or
  40292. -subtract instruction does not clear the overflow bit the way that a test
  40293. -instruction does, so a different branch instruction must be used for
  40294. -some conditional branches.  For machines that use `(cc0)', the set and
  40295. -use of the condition code must be adjacent (separated only by `note'
  40296. -insns) allowing flags in `cc_status' to be used.  (*Note Condition
  40297. -Code::.)  Also, the comparison and branch insns can be located from
  40298. -each other by using the functions `prev_cc0_setter' and `next_cc0_user'.
  40299. -
  40300. -   However, this is not true on machines that do not use `(cc0)'.  On
  40301. -those machines, no assumptions can be made about the adjacency of the
  40302. -compare and branch insns and the above methods cannot be used.  Instead,
  40303. -we use the machine mode of the condition code register to record
  40304. -different formats of the condition code register.
  40305. -
  40306. -   Registers used to store the condition code value should have a mode
  40307. -that is in class `MODE_CC'.  Normally, it will be `CCmode'.  If
  40308. -additional modes are required (as for the add example mentioned above in
  40309. -the Sparc), define the macro `EXTRA_CC_MODES' to list the additional
  40310. -modes required (*note Condition Code::.).  Also define `EXTRA_CC_NAMES'
  40311. -to list the names of those modes and `SELECT_CC_MODE' to choose a mode
  40312. -given an operand of a compare.
  40313. -
  40314. -   If it is known during RTL generation that a different mode will be
  40315. -required (for example, if the machine has separate compare instructions
  40316. -for signed and unsigned quantities, like most IBM processors), they can
  40317. -be specified at that time.
  40318. -
  40319. -   If the cases that require different modes would be made by
  40320. -instruction combination, the macro `SELECT_CC_MODE' determines which
  40321. -machine mode should be used for the comparison result.  The patterns
  40322. -should be written using that mode.  To support the case of the add on
  40323. -the Sparc discussed above, we have the pattern
  40324. -
  40325. -     (define_insn ""
  40326. -       [(set (reg:CC_NOOV 0)
  40327. -             (compare:CC_NOOV
  40328. -               (plus:SI (match_operand:SI 0 "register_operand" "%r")
  40329. -                        (match_operand:SI 1 "arith_operand" "rI"))
  40330. -               (const_int 0)))]
  40331. -       ""
  40332. -       "...")
  40333. -
  40334. -   The `SELECT_CC_MODE' macro on the Sparc returns `CC_NOOVmode' for
  40335. -comparisons whose argument is a `plus'.
  40336. -
  40337. -
  40338. -File: gcc.info,  Node: Insn Canonicalizations,  Next: Peephole Definitions,  Prev: Jump Patterns,  Up: Machine Desc
  40339. -
  40340. -Canonicalization of Instructions
  40341. -================================
  40342. -
  40343. -   There are often cases where multiple RTL expressions could represent
  40344. -an operation performed by a single machine instruction.  This situation
  40345. -is most commonly encountered with logical, branch, and
  40346. -multiply-accumulate instructions.  In such cases, the compiler attempts
  40347. -to convert these multiple RTL expressions into a single canonical form
  40348. -to reduce the number of insn patterns required.
  40349. -
  40350. -   In addition to algebraic simplifications, following canonicalizations
  40351. -are performed:
  40352. -
  40353. -   * For commutative and comparison operators, a constant is always
  40354. -     made the second operand.  If a machine only supports a constant as
  40355. -     the second operand, only patterns that match a constant in the
  40356. -     second operand need be supplied.
  40357. -
  40358. -     For these operators, if only one operand is a `neg', `not',
  40359. -     `mult', `plus', or `minus' expression, it will be the first
  40360. -     operand.
  40361. -
  40362. -   * For the `compare' operator, a constant is always the second operand
  40363. -     on machines where `cc0' is used (*note Jump Patterns::.).  On other
  40364. -     machines, there are rare cases where the compiler might want to
  40365. -     construct a `compare' with a constant as the first operand.
  40366. -     However, these cases are not common enough for it to be worthwhile
  40367. -     to provide a pattern matching a constant as the first operand
  40368. -     unless the machine actually has such an instruction.
  40369. -
  40370. -     An operand of `neg', `not', `mult', `plus', or `minus' is made the
  40371. -     first operand under the same conditions as above.
  40372. -
  40373. -   * `(minus X (const_int N))' is converted to `(plus X (const_int
  40374. -     -N))'.
  40375. -
  40376. -   * Within address computations (i.e., inside `mem'), a left shift is
  40377. -     converted into the appropriate multiplication by a power of two.
  40378. -
  40379. -     De`Morgan's Law is used to move bitwise negation inside a bitwise
  40380. -     logical-and or logical-or operation.  If this results in only one
  40381. -     operand being a `not' expression, it will be the first one.
  40382. -
  40383. -     A machine that has an instruction that performs a bitwise
  40384. -     logical-and of one operand with the bitwise negation of the other
  40385. -     should specify the pattern for that instruction as
  40386. -
  40387. -          (define_insn ""
  40388. -            [(set (match_operand:M 0 ...)
  40389. -                  (and:M (not:M (match_operand:M 1 ...))
  40390. -                               (match_operand:M 2 ...)))]
  40391. -            "..."
  40392. -            "...")
  40393. -
  40394. -     Similarly, a pattern for a "NAND" instruction should be written
  40395. -
  40396. -          (define_insn ""
  40397. -            [(set (match_operand:M 0 ...)
  40398. -                  (ior:M (not:M (match_operand:M 1 ...))
  40399. -                               (not:M (match_operand:M 2 ...))))]
  40400. -            "..."
  40401. -            "...")
  40402. -
  40403. -     In both cases, it is not necessary to include patterns for the many
  40404. -     logically equivalent RTL expressions.
  40405. -
  40406. -   * The only possible RTL expressions involving both bitwise
  40407. -     exclusive-or and bitwise negation are `(xor:M X Y)' and `(not:M
  40408. -     (xor:M X Y))'.
  40409. -
  40410. -   * The sum of three items, one of which is a constant, will only
  40411. -     appear in the form
  40412. -
  40413. -          (plus:M (plus:M X Y) CONSTANT)
  40414. -
  40415. -   * On machines that do not use `cc0', `(compare X (const_int 0))'
  40416. -     will be converted to X.
  40417. -
  40418. -   * Equality comparisons of a group of bits (usually a single bit)
  40419. -     with zero will be written using `zero_extract' rather than the
  40420. -     equivalent `and' or `sign_extract' operations.
  40421. -
  40422. -
  40423. -File: gcc.info,  Node: Peephole Definitions,  Next: Expander Definitions,  Prev: Insn Canonicalizations,  Up: Machine Desc
  40424. -
  40425. -Machine-Specific Peephole Optimizers
  40426. -====================================
  40427. -
  40428. -   In addition to instruction patterns the `md' file may contain
  40429. -definitions of machine-specific peephole optimizations.
  40430. -
  40431. -   The combiner does not notice certain peephole optimizations when the
  40432. -data flow in the program does not suggest that it should try them.  For
  40433. -example, sometimes two consecutive insns related in purpose can be
  40434. -combined even though the second one does not appear to use a register
  40435. -computed in the first one.  A machine-specific peephole optimizer can
  40436. -detect such opportunities.
  40437. -
  40438. -   A definition looks like this:
  40439. -
  40440. -     (define_peephole
  40441. -       [INSN-PATTERN-1
  40442. -        INSN-PATTERN-2
  40443. -        ...]
  40444. -       "CONDITION"
  40445. -       "TEMPLATE"
  40446. -       "OPTIONAL INSN-ATTRIBUTES")
  40447. -
  40448. -The last string operand may be omitted if you are not using any
  40449. -machine-specific information in this machine description.  If present,
  40450. -it must obey the same rules as in a `define_insn'.
  40451. -
  40452. -   In this skeleton, INSN-PATTERN-1 and so on are patterns to match
  40453. -consecutive insns.  The optimization applies to a sequence of insns when
  40454. -INSN-PATTERN-1 matches the first one, INSN-PATTERN-2 matches the next,
  40455. -and so on.
  40456. -
  40457. -   Each of the insns matched by a peephole must also match a
  40458. -`define_insn'.  Peepholes are checked only at the last stage just
  40459. -before code generation, and only optionally.  Therefore, any insn which
  40460. -would match a peephole but no `define_insn' will cause a crash in code
  40461. -generation in an unoptimized compilation, or at various optimization
  40462. -stages.
  40463. -
  40464. -   The operands of the insns are matched with `match_operands',
  40465. -`match_operator', and `match_dup', as usual.  What is not usual is that
  40466. -the operand numbers apply to all the insn patterns in the definition.
  40467. -So, you can check for identical operands in two insns by using
  40468. -`match_operand' in one insn and `match_dup' in the other.
  40469. -
  40470. -   The operand constraints used in `match_operand' patterns do not have
  40471. -any direct effect on the applicability of the peephole, but they will
  40472. -be validated afterward, so make sure your constraints are general enough
  40473. -to apply whenever the peephole matches.  If the peephole matches but
  40474. -the constraints are not satisfied, the compiler will crash.
  40475. -
  40476. -   It is safe to omit constraints in all the operands of the peephole;
  40477. -or you can write constraints which serve as a double-check on the
  40478. -criteria previously tested.
  40479. -
  40480. -   Once a sequence of insns matches the patterns, the CONDITION is
  40481. -checked.  This is a C expression which makes the final decision whether
  40482. -to perform the optimization (we do so if the expression is nonzero).  If
  40483. -CONDITION is omitted (in other words, the string is empty) then the
  40484. -optimization is applied to every sequence of insns that matches the
  40485. -patterns.
  40486. -
  40487. -   The defined peephole optimizations are applied after register
  40488. -allocation is complete.  Therefore, the peephole definition can check
  40489. -which operands have ended up in which kinds of registers, just by
  40490. -looking at the operands.
  40491. -
  40492. -   The way to refer to the operands in CONDITION is to write
  40493. -`operands[I]' for operand number I (as matched by `(match_operand I
  40494. -...)').  Use the variable `insn' to refer to the last of the insns
  40495. -being matched; use `prev_active_insn' to find the preceding insns.
  40496. -
  40497. -   When optimizing computations with intermediate results, you can use
  40498. -CONDITION to match only when the intermediate results are not used
  40499. -elsewhere.  Use the C expression `dead_or_set_p (INSN, OP)', where INSN
  40500. -is the insn in which you expect the value to be used for the last time
  40501. -(from the value of `insn', together with use of `prev_nonnote_insn'),
  40502. -and OP is the intermediate value (from `operands[I]').
  40503. -
  40504. -   Applying the optimization means replacing the sequence of insns with
  40505. -one new insn.  The TEMPLATE controls ultimate output of assembler code
  40506. -for this combined insn.  It works exactly like the template of a
  40507. -`define_insn'.  Operand numbers in this template are the same ones used
  40508. -in matching the original sequence of insns.
  40509. -
  40510. -   The result of a defined peephole optimizer does not need to match
  40511. -any of the insn patterns in the machine description; it does not even
  40512. -have an opportunity to match them.  The peephole optimizer definition
  40513. -itself serves as the insn pattern to control how the insn is output.
  40514. -
  40515. -   Defined peephole optimizers are run as assembler code is being
  40516. -output, so the insns they produce are never combined or rearranged in
  40517. -any way.
  40518. -
  40519. -   Here is an example, taken from the 68000 machine description:
  40520. -
  40521. -     (define_peephole
  40522. -       [(set (reg:SI 15) (plus:SI (reg:SI 15) (const_int 4)))
  40523. -        (set (match_operand:DF 0 "register_operand" "=f")
  40524. -             (match_operand:DF 1 "register_operand" "ad"))]
  40525. -       "FP_REG_P (operands[0]) && ! FP_REG_P (operands[1])"
  40526. -       "*
  40527. -     {
  40528. -       rtx xoperands[2];
  40529. -       xoperands[1] = gen_rtx (REG, SImode, REGNO (operands[1]) + 1);
  40530. -     #ifdef MOTOROLA
  40531. -       output_asm_insn (\"move.l %1,(sp)\", xoperands);
  40532. -       output_asm_insn (\"move.l %1,-(sp)\", operands);
  40533. -       return \"fmove.d (sp)+,%0\";
  40534. -     #else
  40535. -       output_asm_insn (\"movel %1,sp@\", xoperands);
  40536. -       output_asm_insn (\"movel %1,sp@-\", operands);
  40537. -       return \"fmoved sp@+,%0\";
  40538. -     #endif
  40539. -     }
  40540. -     ")
  40541. -
  40542. -   The effect of this optimization is to change
  40543. -
  40544. -     jbsr _foobar
  40545. -     addql #4,sp
  40546. -     movel d1,sp@-
  40547. -     movel d0,sp@-
  40548. -     fmoved sp@+,fp0
  40549. -
  40550. -into
  40551. -
  40552. -     jbsr _foobar
  40553. -     movel d1,sp@
  40554. -     movel d0,sp@-
  40555. -     fmoved sp@+,fp0
  40556. -
  40557. -   INSN-PATTERN-1 and so on look *almost* like the second operand of
  40558. -`define_insn'.  There is one important difference: the second operand
  40559. -of `define_insn' consists of one or more RTX's enclosed in square
  40560. -brackets.  Usually, there is only one: then the same action can be
  40561. -written as an element of a `define_peephole'.  But when there are
  40562. -multiple actions in a `define_insn', they are implicitly enclosed in a
  40563. -`parallel'.  Then you must explicitly write the `parallel', and the
  40564. -square brackets within it, in the `define_peephole'.  Thus, if an insn
  40565. -pattern looks like this,
  40566. -
  40567. -     (define_insn "divmodsi4"
  40568. -       [(set (match_operand:SI 0 "general_operand" "=d")
  40569. -             (div:SI (match_operand:SI 1 "general_operand" "0")
  40570. -                     (match_operand:SI 2 "general_operand" "dmsK")))
  40571. -        (set (match_operand:SI 3 "general_operand" "=d")
  40572. -             (mod:SI (match_dup 1) (match_dup 2)))]
  40573. -       "TARGET_68020"
  40574. -       "divsl%.l %2,%3:%0")
  40575. -
  40576. -then the way to mention this insn in a peephole is as follows:
  40577. -
  40578. -     (define_peephole
  40579. -       [...
  40580. -        (parallel
  40581. -         [(set (match_operand:SI 0 "general_operand" "=d")
  40582. -               (div:SI (match_operand:SI 1 "general_operand" "0")
  40583. -                       (match_operand:SI 2 "general_operand" "dmsK")))
  40584. -          (set (match_operand:SI 3 "general_operand" "=d")
  40585. -               (mod:SI (match_dup 1) (match_dup 2)))])
  40586. -        ...]
  40587. -       ...)
  40588. -
  40589. diff -rup --new-file baseline/fsf/gcc/gcc.info-18 amiga/fsf/gcc/gcc.info-18
  40590. --- baseline/fsf/gcc/gcc.info-18    Sat Jun 29 09:38:06 1996
  40591. +++ amiga/fsf/gcc/gcc.info-18    Wed Dec 31 17:00:00 1969
  40592. @@ -1,1057 +0,0 @@
  40593. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  40594. -file gcc.texi.
  40595. -
  40596. -   This file documents the use and the internals of the GNU compiler.
  40597. -
  40598. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  40599. -Boston, MA 02111-1307 USA
  40600. -
  40601. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  40602. -Foundation, Inc.
  40603. -
  40604. -   Permission is granted to make and distribute verbatim copies of this
  40605. -manual provided the copyright notice and this permission notice are
  40606. -preserved on all copies.
  40607. -
  40608. -   Permission is granted to copy and distribute modified versions of
  40609. -this manual under the conditions for verbatim copying, provided also
  40610. -that the sections entitled "GNU General Public License," "Funding for
  40611. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  40612. -included exactly as in the original, and provided that the entire
  40613. -resulting derived work is distributed under the terms of a permission
  40614. -notice identical to this one.
  40615. -
  40616. -   Permission is granted to copy and distribute translations of this
  40617. -manual into another language, under the above conditions for modified
  40618. -versions, except that the sections entitled "GNU General Public
  40619. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  40620. -`Look And Feel'", and this permission notice, may be included in
  40621. -translations approved by the Free Software Foundation instead of in the
  40622. -original English.
  40623. -
  40624. -
  40625. -File: gcc.info,  Node: Expander Definitions,  Next: Insn Splitting,  Prev: Peephole Definitions,  Up: Machine Desc
  40626. -
  40627. -Defining RTL Sequences for Code Generation
  40628. -==========================================
  40629. -
  40630. -   On some target machines, some standard pattern names for RTL
  40631. -generation cannot be handled with single insn, but a sequence of RTL
  40632. -insns can represent them.  For these target machines, you can write a
  40633. -`define_expand' to specify how to generate the sequence of RTL.
  40634. -
  40635. -   A `define_expand' is an RTL expression that looks almost like a
  40636. -`define_insn'; but, unlike the latter, a `define_expand' is used only
  40637. -for RTL generation and it can produce more than one RTL insn.
  40638. -
  40639. -   A `define_expand' RTX has four operands:
  40640. -
  40641. -   * The name.  Each `define_expand' must have a name, since the only
  40642. -     use for it is to refer to it by name.
  40643. -
  40644. -   * The RTL template.  This is just like the RTL template for a
  40645. -     `define_peephole' in that it is a vector of RTL expressions each
  40646. -     being one insn.
  40647. -
  40648. -   * The condition, a string containing a C expression.  This
  40649. -     expression is used to express how the availability of this pattern
  40650. -     depends on subclasses of target machine, selected by command-line
  40651. -     options when GNU CC is run.  This is just like the condition of a
  40652. -     `define_insn' that has a standard name.  Therefore, the condition
  40653. -     (if present) may not depend on the data in the insn being matched,
  40654. -     but only the target-machine-type flags.  The compiler needs to
  40655. -     test these conditions during initialization in order to learn
  40656. -     exactly which named instructions are available in a particular run.
  40657. -
  40658. -   * The preparation statements, a string containing zero or more C
  40659. -     statements which are to be executed before RTL code is generated
  40660. -     from the RTL template.
  40661. -
  40662. -     Usually these statements prepare temporary registers for use as
  40663. -     internal operands in the RTL template, but they can also generate
  40664. -     RTL insns directly by calling routines such as `emit_insn', etc.
  40665. -     Any such insns precede the ones that come from the RTL template.
  40666. -
  40667. -   Every RTL insn emitted by a `define_expand' must match some
  40668. -`define_insn' in the machine description.  Otherwise, the compiler will
  40669. -crash when trying to generate code for the insn or trying to optimize
  40670. -it.
  40671. -
  40672. -   The RTL template, in addition to controlling generation of RTL insns,
  40673. -also describes the operands that need to be specified when this pattern
  40674. -is used.  In particular, it gives a predicate for each operand.
  40675. -
  40676. -   A true operand, which needs to be specified in order to generate RTL
  40677. -from the pattern, should be described with a `match_operand' in its
  40678. -first occurrence in the RTL template.  This enters information on the
  40679. -operand's predicate into the tables that record such things.  GNU CC
  40680. -uses the information to preload the operand into a register if that is
  40681. -required for valid RTL code.  If the operand is referred to more than
  40682. -once, subsequent references should use `match_dup'.
  40683. -
  40684. -   The RTL template may also refer to internal "operands" which are
  40685. -temporary registers or labels used only within the sequence made by the
  40686. -`define_expand'.  Internal operands are substituted into the RTL
  40687. -template with `match_dup', never with `match_operand'.  The values of
  40688. -the internal operands are not passed in as arguments by the compiler
  40689. -when it requests use of this pattern.  Instead, they are computed
  40690. -within the pattern, in the preparation statements.  These statements
  40691. -compute the values and store them into the appropriate elements of
  40692. -`operands' so that `match_dup' can find them.
  40693. -
  40694. -   There are two special macros defined for use in the preparation
  40695. -statements: `DONE' and `FAIL'.  Use them with a following semicolon, as
  40696. -a statement.
  40697. -
  40698. -`DONE'
  40699. -     Use the `DONE' macro to end RTL generation for the pattern.  The
  40700. -     only RTL insns resulting from the pattern on this occasion will be
  40701. -     those already emitted by explicit calls to `emit_insn' within the
  40702. -     preparation statements; the RTL template will not be generated.
  40703. -
  40704. -`FAIL'
  40705. -     Make the pattern fail on this occasion.  When a pattern fails, it
  40706. -     means that the pattern was not truly available.  The calling
  40707. -     routines in the compiler will try other strategies for code
  40708. -     generation using other patterns.
  40709. -
  40710. -     Failure is currently supported only for binary (addition,
  40711. -     multiplication, shifting, etc.) and bitfield (`extv', `extzv', and
  40712. -     `insv') operations.
  40713. -
  40714. -   Here is an example, the definition of left-shift for the SPUR chip:
  40715. -
  40716. -     (define_expand "ashlsi3"
  40717. -       [(set (match_operand:SI 0 "register_operand" "")
  40718. -             (ashift:SI
  40719. -
  40720. -     (match_operand:SI 1 "register_operand" "")
  40721. -               (match_operand:SI 2 "nonmemory_operand" "")))]
  40722. -       ""
  40723. -       "
  40724. -
  40725. -     {
  40726. -       if (GET_CODE (operands[2]) != CONST_INT
  40727. -           || (unsigned) INTVAL (operands[2]) > 3)
  40728. -         FAIL;
  40729. -     }")
  40730. -
  40731. -This example uses `define_expand' so that it can generate an RTL insn
  40732. -for shifting when the shift-count is in the supported range of 0 to 3
  40733. -but fail in other cases where machine insns aren't available.  When it
  40734. -fails, the compiler tries another strategy using different patterns
  40735. -(such as, a library call).
  40736. -
  40737. -   If the compiler were able to handle nontrivial condition-strings in
  40738. -patterns with names, then it would be possible to use a `define_insn'
  40739. -in that case.  Here is another case (zero-extension on the 68000) which
  40740. -makes more use of the power of `define_expand':
  40741. -
  40742. -     (define_expand "zero_extendhisi2"
  40743. -       [(set (match_operand:SI 0 "general_operand" "")
  40744. -             (const_int 0))
  40745. -        (set (strict_low_part
  40746. -               (subreg:HI
  40747. -                 (match_dup 0)
  40748. -                 0))
  40749. -             (match_operand:HI 1 "general_operand" ""))]
  40750. -       ""
  40751. -       "operands[1] = make_safe_from (operands[1], operands[0]);")
  40752. -
  40753. -Here two RTL insns are generated, one to clear the entire output operand
  40754. -and the other to copy the input operand into its low half.  This
  40755. -sequence is incorrect if the input operand refers to [the old value of]
  40756. -the output operand, so the preparation statement makes sure this isn't
  40757. -so.  The function `make_safe_from' copies the `operands[1]' into a
  40758. -temporary register if it refers to `operands[0]'.  It does this by
  40759. -emitting another RTL insn.
  40760. -
  40761. -   Finally, a third example shows the use of an internal operand.
  40762. -Zero-extension on the SPUR chip is done by `and'-ing the result against
  40763. -a halfword mask.  But this mask cannot be represented by a `const_int'
  40764. -because the constant value is too large to be legitimate on this
  40765. -machine.  So it must be copied into a register with `force_reg' and
  40766. -then the register used in the `and'.
  40767. -
  40768. -     (define_expand "zero_extendhisi2"
  40769. -       [(set (match_operand:SI 0 "register_operand" "")
  40770. -             (and:SI (subreg:SI
  40771. -                       (match_operand:HI 1 "register_operand" "")
  40772. -                       0)
  40773. -                     (match_dup 2)))]
  40774. -       ""
  40775. -       "operands[2]
  40776. -          = force_reg (SImode, gen_rtx (CONST_INT,
  40777. -                                        VOIDmode, 65535)); ")
  40778. -
  40779. -   *Note:* If the `define_expand' is used to serve a standard binary or
  40780. -unary arithmetic operation or a bitfield operation, then the last insn
  40781. -it generates must not be a `code_label', `barrier' or `note'.  It must
  40782. -be an `insn', `jump_insn' or `call_insn'.  If you don't need a real insn
  40783. -at the end, emit an insn to copy the result of the operation into
  40784. -itself.  Such an insn will generate no code, but it can avoid problems
  40785. -in the compiler.
  40786. -
  40787. -
  40788. -File: gcc.info,  Node: Insn Splitting,  Next: Insn Attributes,  Prev: Expander Definitions,  Up: Machine Desc
  40789. -
  40790. -Defining How to Split Instructions
  40791. -==================================
  40792. -
  40793. -   There are two cases where you should specify how to split a pattern
  40794. -into multiple insns.  On machines that have instructions requiring delay
  40795. -slots (*note Delay Slots::.) or that have instructions whose output is
  40796. -not available for multiple cycles (*note Function Units::.), the
  40797. -compiler phases that optimize these cases need to be able to move insns
  40798. -into one-instruction delay slots.  However, some insns may generate
  40799. -more than one machine instruction.  These insns cannot be placed into a
  40800. -delay slot.
  40801. -
  40802. -   Often you can rewrite the single insn as a list of individual insns,
  40803. -each corresponding to one machine instruction.  The disadvantage of
  40804. -doing so is that it will cause the compilation to be slower and require
  40805. -more space.  If the resulting insns are too complex, it may also
  40806. -suppress some optimizations.  The compiler splits the insn if there is a
  40807. -reason to believe that it might improve instruction or delay slot
  40808. -scheduling.
  40809. -
  40810. -   The insn combiner phase also splits putative insns.  If three insns
  40811. -are merged into one insn with a complex expression that cannot be
  40812. -matched by some `define_insn' pattern, the combiner phase attempts to
  40813. -split the complex pattern into two insns that are recognized.  Usually
  40814. -it can break the complex pattern into two patterns by splitting out some
  40815. -subexpression.  However, in some other cases, such as performing an
  40816. -addition of a large constant in two insns on a RISC machine, the way to
  40817. -split the addition into two insns is machine-dependent.
  40818. -
  40819. -   The `define_split' definition tells the compiler how to split a
  40820. -complex insn into several simpler insns.  It looks like this:
  40821. -
  40822. -     (define_split
  40823. -       [INSN-PATTERN]
  40824. -       "CONDITION"
  40825. -       [NEW-INSN-PATTERN-1
  40826. -        NEW-INSN-PATTERN-2
  40827. -        ...]
  40828. -       "PREPARATION STATEMENTS")
  40829. -
  40830. -   INSN-PATTERN is a pattern that needs to be split and CONDITION is
  40831. -the final condition to be tested, as in a `define_insn'.  When an insn
  40832. -matching INSN-PATTERN and satisfying CONDITION is found, it is replaced
  40833. -in the insn list with the insns given by NEW-INSN-PATTERN-1,
  40834. -NEW-INSN-PATTERN-2, etc.
  40835. -
  40836. -   The PREPARATION STATEMENTS are similar to those statements that are
  40837. -specified for `define_expand' (*note Expander Definitions::.) and are
  40838. -executed before the new RTL is generated to prepare for the generated
  40839. -code or emit some insns whose pattern is not fixed.  Unlike those in
  40840. -`define_expand', however, these statements must not generate any new
  40841. -pseudo-registers.  Once reload has completed, they also must not
  40842. -allocate any space in the stack frame.
  40843. -
  40844. -   Patterns are matched against INSN-PATTERN in two different
  40845. -circumstances.  If an insn needs to be split for delay slot scheduling
  40846. -or insn scheduling, the insn is already known to be valid, which means
  40847. -that it must have been matched by some `define_insn' and, if
  40848. -`reload_completed' is non-zero, is known to satisfy the constraints of
  40849. -that `define_insn'.  In that case, the new insn patterns must also be
  40850. -insns that are matched by some `define_insn' and, if `reload_completed'
  40851. -is non-zero, must also satisfy the constraints of those definitions.
  40852. -
  40853. -   As an example of this usage of `define_split', consider the following
  40854. -example from `a29k.md', which splits a `sign_extend' from `HImode' to
  40855. -`SImode' into a pair of shift insns:
  40856. -
  40857. -     (define_split
  40858. -       [(set (match_operand:SI 0 "gen_reg_operand" "")
  40859. -             (sign_extend:SI (match_operand:HI 1 "gen_reg_operand" "")))]
  40860. -       ""
  40861. -       [(set (match_dup 0)
  40862. -             (ashift:SI (match_dup 1)
  40863. -                        (const_int 16)))
  40864. -        (set (match_dup 0)
  40865. -             (ashiftrt:SI (match_dup 0)
  40866. -                          (const_int 16)))]
  40867. -       "
  40868. -     { operands[1] = gen_lowpart (SImode, operands[1]); }")
  40869. -
  40870. -   When the combiner phase tries to split an insn pattern, it is always
  40871. -the case that the pattern is *not* matched by any `define_insn'.  The
  40872. -combiner pass first tries to split a single `set' expression and then
  40873. -the same `set' expression inside a `parallel', but followed by a
  40874. -`clobber' of a pseudo-reg to use as a scratch register.  In these
  40875. -cases, the combiner expects exactly two new insn patterns to be
  40876. -generated.  It will verify that these patterns match some `define_insn'
  40877. -definitions, so you need not do this test in the `define_split' (of
  40878. -course, there is no point in writing a `define_split' that will never
  40879. -produce insns that match).
  40880. -
  40881. -   Here is an example of this use of `define_split', taken from
  40882. -`rs6000.md':
  40883. -
  40884. -     (define_split
  40885. -       [(set (match_operand:SI 0 "gen_reg_operand" "")
  40886. -             (plus:SI (match_operand:SI 1 "gen_reg_operand" "")
  40887. -                      (match_operand:SI 2 "non_add_cint_operand" "")))]
  40888. -       ""
  40889. -       [(set (match_dup 0) (plus:SI (match_dup 1) (match_dup 3)))
  40890. -        (set (match_dup 0) (plus:SI (match_dup 0) (match_dup 4)))]
  40891. -     "
  40892. -     {
  40893. -       int low = INTVAL (operands[2]) & 0xffff;
  40894. -       int high = (unsigned) INTVAL (operands[2]) >> 16;
  40895. -     
  40896. -       if (low & 0x8000)
  40897. -         high++, low |= 0xffff0000;
  40898. -     
  40899. -       operands[3] = gen_rtx (CONST_INT, VOIDmode, high << 16);
  40900. -       operands[4] = gen_rtx (CONST_INT, VOIDmode, low);
  40901. -     }")
  40902. -
  40903. -   Here the predicate `non_add_cint_operand' matches any `const_int'
  40904. -that is *not* a valid operand of a single add insn.  The add with the
  40905. -smaller displacement is written so that it can be substituted into the
  40906. -address of a subsequent operation.
  40907. -
  40908. -   An example that uses a scratch register, from the same file,
  40909. -generates an equality comparison of a register and a large constant:
  40910. -
  40911. -     (define_split
  40912. -       [(set (match_operand:CC 0 "cc_reg_operand" "")
  40913. -             (compare:CC (match_operand:SI 1 "gen_reg_operand" "")
  40914. -                         (match_operand:SI 2 "non_short_cint_operand" "")))
  40915. -        (clobber (match_operand:SI 3 "gen_reg_operand" ""))]
  40916. -       "find_single_use (operands[0], insn, 0)
  40917. -        && (GET_CODE (*find_single_use (operands[0], insn, 0)) == EQ
  40918. -            || GET_CODE (*find_single_use (operands[0], insn, 0)) == NE)"
  40919. -       [(set (match_dup 3) (xor:SI (match_dup 1) (match_dup 4)))
  40920. -        (set (match_dup 0) (compare:CC (match_dup 3) (match_dup 5)))]
  40921. -       "
  40922. -     {
  40923. -       /* Get the constant we are comparing against, C, and see what it
  40924. -          looks like sign-extended to 16 bits.  Then see what constant
  40925. -          could be XOR'ed with C to get the sign-extended value.  */
  40926. -     
  40927. -       int c = INTVAL (operands[2]);
  40928. -       int sextc = (c << 16) >> 16;
  40929. -       int xorv = c ^ sextc;
  40930. -     
  40931. -       operands[4] = gen_rtx (CONST_INT, VOIDmode, xorv);
  40932. -       operands[5] = gen_rtx (CONST_INT, VOIDmode, sextc);
  40933. -     }")
  40934. -
  40935. -   To avoid confusion, don't write a single `define_split' that accepts
  40936. -some insns that match some `define_insn' as well as some insns that
  40937. -don't.  Instead, write two separate `define_split' definitions, one for
  40938. -the insns that are valid and one for the insns that are not valid.
  40939. -
  40940. -
  40941. -File: gcc.info,  Node: Insn Attributes,  Prev: Insn Splitting,  Up: Machine Desc
  40942. -
  40943. -Instruction Attributes
  40944. -======================
  40945. -
  40946. -   In addition to describing the instruction supported by the target
  40947. -machine, the `md' file also defines a group of "attributes" and a set of
  40948. -values for each.  Every generated insn is assigned a value for each
  40949. -attribute.  One possible attribute would be the effect that the insn
  40950. -has on the machine's condition code.  This attribute can then be used
  40951. -by `NOTICE_UPDATE_CC' to track the condition codes.
  40952. -
  40953. -* Menu:
  40954. -
  40955. -* Defining Attributes:: Specifying attributes and their values.
  40956. -* Expressions::         Valid expressions for attribute values.
  40957. -* Tagging Insns::       Assigning attribute values to insns.
  40958. -* Attr Example::        An example of assigning attributes.
  40959. -* Insn Lengths::        Computing the length of insns.
  40960. -* Constant Attributes:: Defining attributes that are constant.
  40961. -* Delay Slots::         Defining delay slots required for a machine.
  40962. -* Function Units::      Specifying information for insn scheduling.
  40963. -
  40964. -
  40965. -File: gcc.info,  Node: Defining Attributes,  Next: Expressions,  Up: Insn Attributes
  40966. -
  40967. -Defining Attributes and their Values
  40968. -------------------------------------
  40969. -
  40970. -   The `define_attr' expression is used to define each attribute
  40971. -required by the target machine.  It looks like:
  40972. -
  40973. -     (define_attr NAME LIST-OF-VALUES DEFAULT)
  40974. -
  40975. -   NAME is a string specifying the name of the attribute being defined.
  40976. -
  40977. -   LIST-OF-VALUES is either a string that specifies a comma-separated
  40978. -list of values that can be assigned to the attribute, or a null string
  40979. -to indicate that the attribute takes numeric values.
  40980. -
  40981. -   DEFAULT is an attribute expression that gives the value of this
  40982. -attribute for insns that match patterns whose definition does not
  40983. -include an explicit value for this attribute.  *Note Attr Example::,
  40984. -for more information on the handling of defaults.  *Note Constant
  40985. -Attributes::, for information on attributes that do not depend on any
  40986. -particular insn.
  40987. -
  40988. -   For each defined attribute, a number of definitions are written to
  40989. -the `insn-attr.h' file.  For cases where an explicit set of values is
  40990. -specified for an attribute, the following are defined:
  40991. -
  40992. -   * A `#define' is written for the symbol `HAVE_ATTR_NAME'.
  40993. -
  40994. -   * An enumeral class is defined for `attr_NAME' with elements of the
  40995. -     form `UPPER-NAME_UPPER-VALUE' where the attribute name and value
  40996. -     are first converted to upper case.
  40997. -
  40998. -   * A function `get_attr_NAME' is defined that is passed an insn and
  40999. -     returns the attribute value for that insn.
  41000. -
  41001. -   For example, if the following is present in the `md' file:
  41002. -
  41003. -     (define_attr "type" "branch,fp,load,store,arith" ...)
  41004. -
  41005. -the following lines will be written to the file `insn-attr.h'.
  41006. -
  41007. -     #define HAVE_ATTR_type
  41008. -     enum attr_type {TYPE_BRANCH, TYPE_FP, TYPE_LOAD,
  41009. -                      TYPE_STORE, TYPE_ARITH};
  41010. -     extern enum attr_type get_attr_type ();
  41011. -
  41012. -   If the attribute takes numeric values, no `enum' type will be
  41013. -defined and the function to obtain the attribute's value will return
  41014. -`int'.
  41015. -
  41016. -
  41017. -File: gcc.info,  Node: Expressions,  Next: Tagging Insns,  Prev: Defining Attributes,  Up: Insn Attributes
  41018. -
  41019. -Attribute Expressions
  41020. ----------------------
  41021. -
  41022. -   RTL expressions used to define attributes use the codes described
  41023. -above plus a few specific to attribute definitions, to be discussed
  41024. -below.  Attribute value expressions must have one of the following
  41025. -forms:
  41026. -
  41027. -`(const_int I)'
  41028. -     The integer I specifies the value of a numeric attribute.  I must
  41029. -     be non-negative.
  41030. -
  41031. -     The value of a numeric attribute can be specified either with a
  41032. -     `const_int' or as an integer represented as a string in
  41033. -     `const_string', `eq_attr' (see below), and `set_attr' (*note
  41034. -     Tagging Insns::.) expressions.
  41035. -
  41036. -`(const_string VALUE)'
  41037. -     The string VALUE specifies a constant attribute value.  If VALUE
  41038. -     is specified as `"*"', it means that the default value of the
  41039. -     attribute is to be used for the insn containing this expression.
  41040. -     `"*"' obviously cannot be used in the DEFAULT expression of a
  41041. -     `define_attr'.
  41042. -
  41043. -     If the attribute whose value is being specified is numeric, VALUE
  41044. -     must be a string containing a non-negative integer (normally
  41045. -     `const_int' would be used in this case).  Otherwise, it must
  41046. -     contain one of the valid values for the attribute.
  41047. -
  41048. -`(if_then_else TEST TRUE-VALUE FALSE-VALUE)'
  41049. -     TEST specifies an attribute test, whose format is defined below.
  41050. -     The value of this expression is TRUE-VALUE if TEST is true,
  41051. -     otherwise it is FALSE-VALUE.
  41052. -
  41053. -`(cond [TEST1 VALUE1 ...] DEFAULT)'
  41054. -     The first operand of this expression is a vector containing an even
  41055. -     number of expressions and consisting of pairs of TEST and VALUE
  41056. -     expressions.  The value of the `cond' expression is that of the
  41057. -     VALUE corresponding to the first true TEST expression.  If none of
  41058. -     the TEST expressions are true, the value of the `cond' expression
  41059. -     is that of the DEFAULT expression.
  41060. -
  41061. -   TEST expressions can have one of the following forms:
  41062. -
  41063. -`(const_int I)'
  41064. -     This test is true if I is non-zero and false otherwise.
  41065. -
  41066. -`(not TEST)'
  41067. -`(ior TEST1 TEST2)'
  41068. -`(and TEST1 TEST2)'
  41069. -     These tests are true if the indicated logical function is true.
  41070. -
  41071. -`(match_operand:M N PRED CONSTRAINTS)'
  41072. -     This test is true if operand N of the insn whose attribute value
  41073. -     is being determined has mode M (this part of the test is ignored
  41074. -     if M is `VOIDmode') and the function specified by the string PRED
  41075. -     returns a non-zero value when passed operand N and mode M (this
  41076. -     part of the test is ignored if PRED is the null string).
  41077. -
  41078. -     The CONSTRAINTS operand is ignored and should be the null string.
  41079. -
  41080. -`(le ARITH1 ARITH2)'
  41081. -`(leu ARITH1 ARITH2)'
  41082. -`(lt ARITH1 ARITH2)'
  41083. -`(ltu ARITH1 ARITH2)'
  41084. -`(gt ARITH1 ARITH2)'
  41085. -`(gtu ARITH1 ARITH2)'
  41086. -`(ge ARITH1 ARITH2)'
  41087. -`(geu ARITH1 ARITH2)'
  41088. -`(ne ARITH1 ARITH2)'
  41089. -`(eq ARITH1 ARITH2)'
  41090. -     These tests are true if the indicated comparison of the two
  41091. -     arithmetic expressions is true.  Arithmetic expressions are formed
  41092. -     with `plus', `minus', `mult', `div', `mod', `abs', `neg', `and',
  41093. -     `ior', `xor', `not', `ashift', `lshiftrt', and `ashiftrt'
  41094. -     expressions.
  41095. -
  41096. -     `const_int' and `symbol_ref' are always valid terms (*note Insn
  41097. -     Lengths::.,for additional forms).  `symbol_ref' is a string
  41098. -     denoting a C expression that yields an `int' when evaluated by the
  41099. -     `get_attr_...' routine.  It should normally be a global variable.
  41100. -
  41101. -`(eq_attr NAME VALUE)'
  41102. -     NAME is a string specifying the name of an attribute.
  41103. -
  41104. -     VALUE is a string that is either a valid value for attribute NAME,
  41105. -     a comma-separated list of values, or `!' followed by a value or
  41106. -     list.  If VALUE does not begin with a `!', this test is true if
  41107. -     the value of the NAME attribute of the current insn is in the list
  41108. -     specified by VALUE.  If VALUE begins with a `!', this test is true
  41109. -     if the attribute's value is *not* in the specified list.
  41110. -
  41111. -     For example,
  41112. -
  41113. -          (eq_attr "type" "load,store")
  41114. -
  41115. -     is equivalent to
  41116. -
  41117. -          (ior (eq_attr "type" "load") (eq_attr "type" "store"))
  41118. -
  41119. -     If NAME specifies an attribute of `alternative', it refers to the
  41120. -     value of the compiler variable `which_alternative' (*note Output
  41121. -     Statement::.) and the values must be small integers.  For example,
  41122. -
  41123. -          (eq_attr "alternative" "2,3")
  41124. -
  41125. -     is equivalent to
  41126. -
  41127. -          (ior (eq (symbol_ref "which_alternative") (const_int 2))
  41128. -               (eq (symbol_ref "which_alternative") (const_int 3)))
  41129. -
  41130. -     Note that, for most attributes, an `eq_attr' test is simplified in
  41131. -     cases where the value of the attribute being tested is known for
  41132. -     all insns matching a particular pattern.  This is by far the most
  41133. -     common case.
  41134. -
  41135. -`(attr_flag NAME)'
  41136. -     The value of an `attr_flag' expression is true if the flag
  41137. -     specified by NAME is true for the `insn' currently being scheduled.
  41138. -
  41139. -     NAME is a string specifying one of a fixed set of flags to test.
  41140. -     Test the flags `forward' and `backward' to determine the direction
  41141. -     of a conditional branch.  Test the flags `very_likely', `likely',
  41142. -     `very_unlikely', and `unlikely' to determine if a conditional
  41143. -     branch is expected to be taken.
  41144. -
  41145. -     If the `very_likely' flag is true, then the `likely' flag is also
  41146. -     true.  Likewise for the `very_unlikely' and `unlikely' flags.
  41147. -
  41148. -     This example describes a conditional branch delay slot which can
  41149. -     be nullified for forward branches that are taken (annul-true) or
  41150. -     for backward branches which are not taken (annul-false).
  41151. -
  41152. -          (define_delay (eq_attr "type" "cbranch")
  41153. -            [(eq_attr "in_branch_delay" "true")
  41154. -             (and (eq_attr "in_branch_delay" "true")
  41155. -                  (attr_flag "forward"))
  41156. -             (and (eq_attr "in_branch_delay" "true")
  41157. -                  (attr_flag "backward"))])
  41158. -
  41159. -     The `forward' and `backward' flags are false if the current `insn'
  41160. -     being scheduled is not a conditional branch.
  41161. -
  41162. -     The `very_likely' and `likely' flags are true if the `insn' being
  41163. -     scheduled is not a conditional branch.  The The `very_unlikely'
  41164. -     and `unlikely' flags are false if the `insn' being scheduled is
  41165. -     not a conditional branch.
  41166. -
  41167. -     `attr_flag' is only used during delay slot scheduling and has no
  41168. -     meaning to other passes of the compiler.
  41169. -
  41170. -
  41171. -File: gcc.info,  Node: Tagging Insns,  Next: Attr Example,  Prev: Expressions,  Up: Insn Attributes
  41172. -
  41173. -Assigning Attribute Values to Insns
  41174. ------------------------------------
  41175. -
  41176. -   The value assigned to an attribute of an insn is primarily
  41177. -determined by which pattern is matched by that insn (or which
  41178. -`define_peephole' generated it).  Every `define_insn' and
  41179. -`define_peephole' can have an optional last argument to specify the
  41180. -values of attributes for matching insns.  The value of any attribute
  41181. -not specified in a particular insn is set to the default value for that
  41182. -attribute, as specified in its `define_attr'.  Extensive use of default
  41183. -values for attributes permits the specification of the values for only
  41184. -one or two attributes in the definition of most insn patterns, as seen
  41185. -in the example in the next section.
  41186. -
  41187. -   The optional last argument of `define_insn' and `define_peephole' is
  41188. -a vector of expressions, each of which defines the value for a single
  41189. -attribute.  The most general way of assigning an attribute's value is
  41190. -to use a `set' expression whose first operand is an `attr' expression
  41191. -giving the name of the attribute being set.  The second operand of the
  41192. -`set' is an attribute expression (*note Expressions::.) giving the
  41193. -value of the attribute.
  41194. -
  41195. -   When the attribute value depends on the `alternative' attribute
  41196. -(i.e., which is the applicable alternative in the constraint of the
  41197. -insn), the `set_attr_alternative' expression can be used.  It allows
  41198. -the specification of a vector of attribute expressions, one for each
  41199. -alternative.
  41200. -
  41201. -   When the generality of arbitrary attribute expressions is not
  41202. -required, the simpler `set_attr' expression can be used, which allows
  41203. -specifying a string giving either a single attribute value or a list of
  41204. -attribute values, one for each alternative.
  41205. -
  41206. -   The form of each of the above specifications is shown below.  In
  41207. -each case, NAME is a string specifying the attribute to be set.
  41208. -
  41209. -`(set_attr NAME VALUE-STRING)'
  41210. -     VALUE-STRING is either a string giving the desired attribute value,
  41211. -     or a string containing a comma-separated list giving the values for
  41212. -     succeeding alternatives.  The number of elements must match the
  41213. -     number of alternatives in the constraint of the insn pattern.
  41214. -
  41215. -     Note that it may be useful to specify `*' for some alternative, in
  41216. -     which case the attribute will assume its default value for insns
  41217. -     matching that alternative.
  41218. -
  41219. -`(set_attr_alternative NAME [VALUE1 VALUE2 ...])'
  41220. -     Depending on the alternative of the insn, the value will be one of
  41221. -     the specified values.  This is a shorthand for using a `cond' with
  41222. -     tests on the `alternative' attribute.
  41223. -
  41224. -`(set (attr NAME) VALUE)'
  41225. -     The first operand of this `set' must be the special RTL expression
  41226. -     `attr', whose sole operand is a string giving the name of the
  41227. -     attribute being set.  VALUE is the value of the attribute.
  41228. -
  41229. -   The following shows three different ways of representing the same
  41230. -attribute value specification:
  41231. -
  41232. -     (set_attr "type" "load,store,arith")
  41233. -     
  41234. -     (set_attr_alternative "type"
  41235. -                           [(const_string "load") (const_string "store")
  41236. -                            (const_string "arith")])
  41237. -     
  41238. -     (set (attr "type")
  41239. -          (cond [(eq_attr "alternative" "1") (const_string "load")
  41240. -                 (eq_attr "alternative" "2") (const_string "store")]
  41241. -                (const_string "arith")))
  41242. -
  41243. -   The `define_asm_attributes' expression provides a mechanism to
  41244. -specify the attributes assigned to insns produced from an `asm'
  41245. -statement.  It has the form:
  41246. -
  41247. -     (define_asm_attributes [ATTR-SETS])
  41248. -
  41249. -where ATTR-SETS is specified the same as for both the `define_insn' and
  41250. -the `define_peephole' expressions.
  41251. -
  41252. -   These values will typically be the "worst case" attribute values.
  41253. -For example, they might indicate that the condition code will be
  41254. -clobbered.
  41255. -
  41256. -   A specification for a `length' attribute is handled specially.  The
  41257. -way to compute the length of an `asm' insn is to multiply the length
  41258. -specified in the expression `define_asm_attributes' by the number of
  41259. -machine instructions specified in the `asm' statement, determined by
  41260. -counting the number of semicolons and newlines in the string.
  41261. -Therefore, the value of the `length' attribute specified in a
  41262. -`define_asm_attributes' should be the maximum possible length of a
  41263. -single machine instruction.
  41264. -
  41265. -
  41266. -File: gcc.info,  Node: Attr Example,  Next: Insn Lengths,  Prev: Tagging Insns,  Up: Insn Attributes
  41267. -
  41268. -Example of Attribute Specifications
  41269. ------------------------------------
  41270. -
  41271. -   The judicious use of defaulting is important in the efficient use of
  41272. -insn attributes.  Typically, insns are divided into "types" and an
  41273. -attribute, customarily called `type', is used to represent this value.
  41274. -This attribute is normally used only to define the default value for
  41275. -other attributes.  An example will clarify this usage.
  41276. -
  41277. -   Assume we have a RISC machine with a condition code and in which only
  41278. -full-word operations are performed in registers.  Let us assume that we
  41279. -can divide all insns into loads, stores, (integer) arithmetic
  41280. -operations, floating point operations, and branches.
  41281. -
  41282. -   Here we will concern ourselves with determining the effect of an
  41283. -insn on the condition code and will limit ourselves to the following
  41284. -possible effects:  The condition code can be set unpredictably
  41285. -(clobbered), not be changed, be set to agree with the results of the
  41286. -operation, or only changed if the item previously set into the
  41287. -condition code has been modified.
  41288. -
  41289. -   Here is part of a sample `md' file for such a machine:
  41290. -
  41291. -     (define_attr "type" "load,store,arith,fp,branch" (const_string "arith"))
  41292. -     
  41293. -     (define_attr "cc" "clobber,unchanged,set,change0"
  41294. -                  (cond [(eq_attr "type" "load")
  41295. -                             (const_string "change0")
  41296. -                         (eq_attr "type" "store,branch")
  41297. -                             (const_string "unchanged")
  41298. -                         (eq_attr "type" "arith")
  41299. -                             (if_then_else (match_operand:SI 0 "" "")
  41300. -                                           (const_string "set")
  41301. -                                           (const_string "clobber"))]
  41302. -                        (const_string "clobber")))
  41303. -     
  41304. -     (define_insn ""
  41305. -       [(set (match_operand:SI 0 "general_operand" "=r,r,m")
  41306. -             (match_operand:SI 1 "general_operand" "r,m,r"))]
  41307. -       ""
  41308. -       "@
  41309. -        move %0,%1
  41310. -        load %0,%1
  41311. -        store %0,%1"
  41312. -       [(set_attr "type" "arith,load,store")])
  41313. -
  41314. -   Note that we assume in the above example that arithmetic operations
  41315. -performed on quantities smaller than a machine word clobber the
  41316. -condition code since they will set the condition code to a value
  41317. -corresponding to the full-word result.
  41318. -
  41319. -
  41320. -File: gcc.info,  Node: Insn Lengths,  Next: Constant Attributes,  Prev: Attr Example,  Up: Insn Attributes
  41321. -
  41322. -Computing the Length of an Insn
  41323. --------------------------------
  41324. -
  41325. -   For many machines, multiple types of branch instructions are
  41326. -provided, each for different length branch displacements.  In most
  41327. -cases, the assembler will choose the correct instruction to use.
  41328. -However, when the assembler cannot do so, GCC can when a special
  41329. -attribute, the `length' attribute, is defined.  This attribute must be
  41330. -defined to have numeric values by specifying a null string in its
  41331. -`define_attr'.
  41332. -
  41333. -   In the case of the `length' attribute, two additional forms of
  41334. -arithmetic terms are allowed in test expressions:
  41335. -
  41336. -`(match_dup N)'
  41337. -     This refers to the address of operand N of the current insn, which
  41338. -     must be a `label_ref'.
  41339. -
  41340. -`(pc)'
  41341. -     This refers to the address of the *current* insn.  It might have
  41342. -     been more consistent with other usage to make this the address of
  41343. -     the *next* insn but this would be confusing because the length of
  41344. -     the current insn is to be computed.
  41345. -
  41346. -   For normal insns, the length will be determined by value of the
  41347. -`length' attribute.  In the case of `addr_vec' and `addr_diff_vec' insn
  41348. -patterns, the length is computed as the number of vectors multiplied by
  41349. -the size of each vector.
  41350. -
  41351. -   Lengths are measured in addressable storage units (bytes).
  41352. -
  41353. -   The following macros can be used to refine the length computation:
  41354. -
  41355. -`FIRST_INSN_ADDRESS'
  41356. -     When the `length' insn attribute is used, this macro specifies the
  41357. -     value to be assigned to the address of the first insn in a
  41358. -     function.  If not specified, 0 is used.
  41359. -
  41360. -`ADJUST_INSN_LENGTH (INSN, LENGTH)'
  41361. -     If defined, modifies the length assigned to instruction INSN as a
  41362. -     function of the context in which it is used.  LENGTH is an lvalue
  41363. -     that contains the initially computed length of the insn and should
  41364. -     be updated with the correct length of the insn.  If updating is
  41365. -     required, INSN must not be a varying-length insn.
  41366. -
  41367. -     This macro will normally not be required.  A case in which it is
  41368. -     required is the ROMP.  On this machine, the size of an `addr_vec'
  41369. -     insn must be increased by two to compensate for the fact that
  41370. -     alignment may be required.
  41371. -
  41372. -   The routine that returns `get_attr_length' (the value of the
  41373. -`length' attribute) can be used by the output routine to determine the
  41374. -form of the branch instruction to be written, as the example below
  41375. -illustrates.
  41376. -
  41377. -   As an example of the specification of variable-length branches,
  41378. -consider the IBM 360.  If we adopt the convention that a register will
  41379. -be set to the starting address of a function, we can jump to labels
  41380. -within 4k of the start using a four-byte instruction.  Otherwise, we
  41381. -need a six-byte sequence to load the address from memory and then
  41382. -branch to it.
  41383. -
  41384. -   On such a machine, a pattern for a branch instruction might be
  41385. -specified as follows:
  41386. -
  41387. -     (define_insn "jump"
  41388. -       [(set (pc)
  41389. -             (label_ref (match_operand 0 "" "")))]
  41390. -       ""
  41391. -       "*
  41392. -     {
  41393. -        return (get_attr_length (insn) == 4
  41394. -                ? \"b %l0\" : \"l r15,=a(%l0); br r15\");
  41395. -     }"
  41396. -       [(set (attr "length") (if_then_else (lt (match_dup 0) (const_int 4096))
  41397. -                                           (const_int 4)
  41398. -                                           (const_int 6)))])
  41399. -
  41400. -
  41401. -File: gcc.info,  Node: Constant Attributes,  Next: Delay Slots,  Prev: Insn Lengths,  Up: Insn Attributes
  41402. -
  41403. -Constant Attributes
  41404. --------------------
  41405. -
  41406. -   A special form of `define_attr', where the expression for the
  41407. -default value is a `const' expression, indicates an attribute that is
  41408. -constant for a given run of the compiler.  Constant attributes may be
  41409. -used to specify which variety of processor is used.  For example,
  41410. -
  41411. -     (define_attr "cpu" "m88100,m88110,m88000"
  41412. -      (const
  41413. -       (cond [(symbol_ref "TARGET_88100") (const_string "m88100")
  41414. -              (symbol_ref "TARGET_88110") (const_string "m88110")]
  41415. -             (const_string "m88000"))))
  41416. -     
  41417. -     (define_attr "memory" "fast,slow"
  41418. -      (const
  41419. -       (if_then_else (symbol_ref "TARGET_FAST_MEM")
  41420. -                     (const_string "fast")
  41421. -                     (const_string "slow"))))
  41422. -
  41423. -   The routine generated for constant attributes has no parameters as it
  41424. -does not depend on any particular insn.  RTL expressions used to define
  41425. -the value of a constant attribute may use the `symbol_ref' form, but
  41426. -may not use either the `match_operand' form or `eq_attr' forms
  41427. -involving insn attributes.
  41428. -
  41429. -
  41430. -File: gcc.info,  Node: Delay Slots,  Next: Function Units,  Prev: Constant Attributes,  Up: Insn Attributes
  41431. -
  41432. -Delay Slot Scheduling
  41433. ----------------------
  41434. -
  41435. -   The insn attribute mechanism can be used to specify the requirements
  41436. -for delay slots, if any, on a target machine.  An instruction is said to
  41437. -require a "delay slot" if some instructions that are physically after
  41438. -the instruction are executed as if they were located before it.
  41439. -Classic examples are branch and call instructions, which often execute
  41440. -the following instruction before the branch or call is performed.
  41441. -
  41442. -   On some machines, conditional branch instructions can optionally
  41443. -"annul" instructions in the delay slot.  This means that the
  41444. -instruction will not be executed for certain branch outcomes.  Both
  41445. -instructions that annul if the branch is true and instructions that
  41446. -annul if the branch is false are supported.
  41447. -
  41448. -   Delay slot scheduling differs from instruction scheduling in that
  41449. -determining whether an instruction needs a delay slot is dependent only
  41450. -on the type of instruction being generated, not on data flow between the
  41451. -instructions.  See the next section for a discussion of data-dependent
  41452. -instruction scheduling.
  41453. -
  41454. -   The requirement of an insn needing one or more delay slots is
  41455. -indicated via the `define_delay' expression.  It has the following form:
  41456. -
  41457. -     (define_delay TEST
  41458. -                   [DELAY-1 ANNUL-TRUE-1 ANNUL-FALSE-1
  41459. -                    DELAY-2 ANNUL-TRUE-2 ANNUL-FALSE-2
  41460. -                    ...])
  41461. -
  41462. -   TEST is an attribute test that indicates whether this `define_delay'
  41463. -applies to a particular insn.  If so, the number of required delay
  41464. -slots is determined by the length of the vector specified as the second
  41465. -argument.  An insn placed in delay slot N must satisfy attribute test
  41466. -DELAY-N.  ANNUL-TRUE-N is an attribute test that specifies which insns
  41467. -may be annulled if the branch is true.  Similarly, ANNUL-FALSE-N
  41468. -specifies which insns in the delay slot may be annulled if the branch
  41469. -is false.  If annulling is not supported for that delay slot, `(nil)'
  41470. -should be coded.
  41471. -
  41472. -   For example, in the common case where branch and call insns require
  41473. -a single delay slot, which may contain any insn other than a branch or
  41474. -call, the following would be placed in the `md' file:
  41475. -
  41476. -     (define_delay (eq_attr "type" "branch,call")
  41477. -                   [(eq_attr "type" "!branch,call") (nil) (nil)])
  41478. -
  41479. -   Multiple `define_delay' expressions may be specified.  In this case,
  41480. -each such expression specifies different delay slot requirements and
  41481. -there must be no insn for which tests in two `define_delay' expressions
  41482. -are both true.
  41483. -
  41484. -   For example, if we have a machine that requires one delay slot for
  41485. -branches but two for calls,  no delay slot can contain a branch or call
  41486. -insn, and any valid insn in the delay slot for the branch can be
  41487. -annulled if the branch is true, we might represent this as follows:
  41488. -
  41489. -     (define_delay (eq_attr "type" "branch")
  41490. -        [(eq_attr "type" "!branch,call")
  41491. -         (eq_attr "type" "!branch,call")
  41492. -         (nil)])
  41493. -     
  41494. -     (define_delay (eq_attr "type" "call")
  41495. -                   [(eq_attr "type" "!branch,call") (nil) (nil)
  41496. -                    (eq_attr "type" "!branch,call") (nil) (nil)])
  41497. -
  41498. -
  41499. -File: gcc.info,  Node: Function Units,  Prev: Delay Slots,  Up: Insn Attributes
  41500. -
  41501. -Specifying Function Units
  41502. --------------------------
  41503. -
  41504. -   On most RISC machines, there are instructions whose results are not
  41505. -available for a specific number of cycles.  Common cases are
  41506. -instructions that load data from memory.  On many machines, a pipeline
  41507. -stall will result if the data is referenced too soon after the load
  41508. -instruction.
  41509. -
  41510. -   In addition, many newer microprocessors have multiple function
  41511. -units, usually one for integer and one for floating point, and often
  41512. -will incur pipeline stalls when a result that is needed is not yet
  41513. -ready.
  41514. -
  41515. -   The descriptions in this section allow the specification of how much
  41516. -time must elapse between the execution of an instruction and the time
  41517. -when its result is used.  It also allows specification of when the
  41518. -execution of an instruction will delay execution of similar instructions
  41519. -due to function unit conflicts.
  41520. -
  41521. -   For the purposes of the specifications in this section, a machine is
  41522. -divided into "function units", each of which execute a specific class
  41523. -of instructions in first-in-first-out order.  Function units that
  41524. -accept one instruction each cycle and allow a result to be used in the
  41525. -succeeding instruction (usually via forwarding) need not be specified.
  41526. -Classic RISC microprocessors will normally have a single function unit,
  41527. -which we can call `memory'.  The newer "superscalar" processors will
  41528. -often have function units for floating point operations, usually at
  41529. -least a floating point adder and multiplier.
  41530. -
  41531. -   Each usage of a function units by a class of insns is specified with
  41532. -a `define_function_unit' expression, which looks like this:
  41533. -
  41534. -     (define_function_unit NAME MULTIPLICITY SIMULTANEITY
  41535. -                           TEST READY-DELAY ISSUE-DELAY
  41536. -                          [CONFLICT-LIST])
  41537. -
  41538. -   NAME is a string giving the name of the function unit.
  41539. -
  41540. -   MULTIPLICITY is an integer specifying the number of identical units
  41541. -in the processor.  If more than one unit is specified, they will be
  41542. -scheduled independently.  Only truly independent units should be
  41543. -counted; a pipelined unit should be specified as a single unit.  (The
  41544. -only common example of a machine that has multiple function units for a
  41545. -single instruction class that are truly independent and not pipelined
  41546. -are the two multiply and two increment units of the CDC 6600.)
  41547. -
  41548. -   SIMULTANEITY specifies the maximum number of insns that can be
  41549. -executing in each instance of the function unit simultaneously or zero
  41550. -if the unit is pipelined and has no limit.
  41551. -
  41552. -   All `define_function_unit' definitions referring to function unit
  41553. -NAME must have the same name and values for MULTIPLICITY and
  41554. -SIMULTANEITY.
  41555. -
  41556. -   TEST is an attribute test that selects the insns we are describing
  41557. -in this definition.  Note that an insn may use more than one function
  41558. -unit and a function unit may be specified in more than one
  41559. -`define_function_unit'.
  41560. -
  41561. -   READY-DELAY is an integer that specifies the number of cycles after
  41562. -which the result of the instruction can be used without introducing any
  41563. -stalls.
  41564. -
  41565. -   ISSUE-DELAY is an integer that specifies the number of cycles after
  41566. -the instruction matching the TEST expression begins using this unit
  41567. -until a subsequent instruction can begin.  A cost of N indicates an N-1
  41568. -cycle delay.  A subsequent instruction may also be delayed if an
  41569. -earlier instruction has a longer READY-DELAY value.  This blocking
  41570. -effect is computed using the SIMULTANEITY, READY-DELAY, ISSUE-DELAY,
  41571. -and CONFLICT-LIST terms.  For a normal non-pipelined function unit,
  41572. -SIMULTANEITY is one, the unit is taken to block for the READY-DELAY
  41573. -cycles of the executing insn, and smaller values of ISSUE-DELAY are
  41574. -ignored.
  41575. -
  41576. -   CONFLICT-LIST is an optional list giving detailed conflict costs for
  41577. -this unit.  If specified, it is a list of condition test expressions to
  41578. -be applied to insns chosen to execute in NAME following the particular
  41579. -insn matching TEST that is already executing in NAME.  For each insn in
  41580. -the list, ISSUE-DELAY specifies the conflict cost; for insns not in the
  41581. -list, the cost is zero.  If not specified, CONFLICT-LIST defaults to
  41582. -all instructions that use the function unit.
  41583. -
  41584. -   Typical uses of this vector are where a floating point function unit
  41585. -can pipeline either single- or double-precision operations, but not
  41586. -both, or where a memory unit can pipeline loads, but not stores, etc.
  41587. -
  41588. -   As an example, consider a classic RISC machine where the result of a
  41589. -load instruction is not available for two cycles (a single "delay"
  41590. -instruction is required) and where only one load instruction can be
  41591. -executed simultaneously.  This would be specified as:
  41592. -
  41593. -     (define_function_unit "memory" 1 1 (eq_attr "type" "load") 2 0)
  41594. -
  41595. -   For the case of a floating point function unit that can pipeline
  41596. -either single or double precision, but not both, the following could be
  41597. -specified:
  41598. -
  41599. -     (define_function_unit
  41600. -        "fp" 1 0 (eq_attr "type" "sp_fp") 4 4 [(eq_attr "type" "dp_fp")])
  41601. -     (define_function_unit
  41602. -        "fp" 1 0 (eq_attr "type" "dp_fp") 4 4 [(eq_attr "type" "sp_fp")])
  41603. -
  41604. -   *Note:* The scheduler attempts to avoid function unit conflicts and
  41605. -uses all the specifications in the `define_function_unit' expression.
  41606. -It has recently come to our attention that these specifications may not
  41607. -allow modeling of some of the newer "superscalar" processors that have
  41608. -insns using multiple pipelined units.  These insns will cause a
  41609. -potential conflict for the second unit used during their execution and
  41610. -there is no way of representing that conflict.  We welcome any examples
  41611. -of how function unit conflicts work in such processors and suggestions
  41612. -for their representation.
  41613. -
  41614. -
  41615. -File: gcc.info,  Node: Target Macros,  Next: Config,  Prev: Machine Desc,  Up: Top
  41616. -
  41617. -Target Description Macros
  41618. -*************************
  41619. -
  41620. -   In addition to the file `MACHINE.md', a machine description includes
  41621. -a C header file conventionally given the name `MACHINE.h'.  This header
  41622. -file defines numerous macros that convey the information about the
  41623. -target machine that does not fit into the scheme of the `.md' file.
  41624. -The file `tm.h' should be a link to `MACHINE.h'.  The header file
  41625. -`config.h' includes `tm.h' and most compiler source files include
  41626. -`config.h'.
  41627. -
  41628. -* Menu:
  41629. -
  41630. -* Driver::              Controlling how the driver runs the compilation passes.
  41631. -* Run-time Target::     Defining `-m' options like `-m68000' and `-m68020'.
  41632. -* Storage Layout::      Defining sizes and alignments of data.
  41633. -* Type Layout::         Defining sizes and properties of basic user data types.
  41634. -* Registers::           Naming and describing the hardware registers.
  41635. -* Register Classes::    Defining the classes of hardware registers.
  41636. -* Stack and Calling::   Defining which way the stack grows and by how much.
  41637. -* Varargs::        Defining the varargs macros.
  41638. -* Trampolines::         Code set up at run time to enter a nested function.
  41639. -* Library Calls::       Controlling how library routines are implicitly called.
  41640. -* Addressing Modes::    Defining addressing modes valid for memory operands.
  41641. -* Condition Code::      Defining how insns update the condition code.
  41642. -* Costs::               Defining relative costs of different operations.
  41643. -* Sections::            Dividing storage into text, data, and other sections.
  41644. -* PIC::            Macros for position independent code.
  41645. -* Assembler Format::    Defining how to write insns and pseudo-ops to output.
  41646. -* Debugging Info::      Defining the format of debugging output.
  41647. -* Cross-compilation::   Handling floating point for cross-compilers.
  41648. -* Misc::                Everything else.
  41649. -
  41650. diff -rup --new-file baseline/fsf/gcc/gcc.info-19 amiga/fsf/gcc/gcc.info-19
  41651. --- baseline/fsf/gcc/gcc.info-19    Sat Jun 29 09:38:06 1996
  41652. +++ amiga/fsf/gcc/gcc.info-19    Wed Dec 31 17:00:00 1969
  41653. @@ -1,1202 +0,0 @@
  41654. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  41655. -file gcc.texi.
  41656. -
  41657. -   This file documents the use and the internals of the GNU compiler.
  41658. -
  41659. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  41660. -Boston, MA 02111-1307 USA
  41661. -
  41662. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  41663. -Foundation, Inc.
  41664. -
  41665. -   Permission is granted to make and distribute verbatim copies of this
  41666. -manual provided the copyright notice and this permission notice are
  41667. -preserved on all copies.
  41668. -
  41669. -   Permission is granted to copy and distribute modified versions of
  41670. -this manual under the conditions for verbatim copying, provided also
  41671. -that the sections entitled "GNU General Public License," "Funding for
  41672. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  41673. -included exactly as in the original, and provided that the entire
  41674. -resulting derived work is distributed under the terms of a permission
  41675. -notice identical to this one.
  41676. -
  41677. -   Permission is granted to copy and distribute translations of this
  41678. -manual into another language, under the above conditions for modified
  41679. -versions, except that the sections entitled "GNU General Public
  41680. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  41681. -`Look And Feel'", and this permission notice, may be included in
  41682. -translations approved by the Free Software Foundation instead of in the
  41683. -original English.
  41684. -
  41685. -
  41686. -File: gcc.info,  Node: Driver,  Next: Run-time Target,  Up: Target Macros
  41687. -
  41688. -Controlling the Compilation Driver, `gcc'
  41689. -=========================================
  41690. -
  41691. -   You can control the compilation driver.
  41692. -
  41693. -`SWITCH_TAKES_ARG (CHAR)'
  41694. -     A C expression which determines whether the option `-CHAR' takes
  41695. -     arguments.  The value should be the number of arguments that
  41696. -     option takes-zero, for many options.
  41697. -
  41698. -     By default, this macro is defined to handle the standard options
  41699. -     properly.  You need not define it unless you wish to add additional
  41700. -     options which take arguments.
  41701. -
  41702. -`WORD_SWITCH_TAKES_ARG (NAME)'
  41703. -     A C expression which determines whether the option `-NAME' takes
  41704. -     arguments.  The value should be the number of arguments that
  41705. -     option takes-zero, for many options.  This macro rather than
  41706. -     `SWITCH_TAKES_ARG' is used for multi-character option names.
  41707. -
  41708. -     By default, this macro is defined as
  41709. -     `DEFAULT_WORD_SWITCH_TAKES_ARG', which handles the standard options
  41710. -     properly.  You need not define `WORD_SWITCH_TAKES_ARG' unless you
  41711. -     wish to add additional options which take arguments.  Any
  41712. -     redefinition should call `DEFAULT_WORD_SWITCH_TAKES_ARG' and then
  41713. -     check for additional options.
  41714. -
  41715. -`SWITCHES_NEED_SPACES'
  41716. -     A string-valued C expression which is nonempty if the linker needs
  41717. -     a space between the `-L' or `-o' option and its argument.
  41718. -
  41719. -     If this macro is not defined, the default value is 0.
  41720. -
  41721. -`CPP_SPEC'
  41722. -     A C string constant that tells the GNU CC driver program options to
  41723. -     pass to CPP.  It can also specify how to translate options you
  41724. -     give to GNU CC into options for GNU CC to pass to the CPP.
  41725. -
  41726. -     Do not define this macro if it does not need to do anything.
  41727. -
  41728. -`NO_BUILTIN_SIZE_TYPE'
  41729. -     If this macro is defined, the preprocessor will not define the
  41730. -     builtin macro `__SIZE_TYPE__'.  The macro `__SIZE_TYPE__' must
  41731. -     then be defined by `CPP_SPEC' instead.
  41732. -
  41733. -     This should be defined if `SIZE_TYPE' depends on target dependent
  41734. -     flags which are not accessible to the preprocessor.  Otherwise, it
  41735. -     should not be defined.
  41736. -
  41737. -`NO_BUILTIN_PTRDIFF_TYPE'
  41738. -     If this macro is defined, the preprocessor will not define the
  41739. -     builtin macro `__PTRDIFF_TYPE__'.  The macro `__PTRDIFF_TYPE__'
  41740. -     must then be defined by `CPP_SPEC' instead.
  41741. -
  41742. -     This should be defined if `PTRDIFF_TYPE' depends on target
  41743. -     dependent flags which are not accessible to the preprocessor.
  41744. -     Otherwise, it should not be defined.
  41745. -
  41746. -`SIGNED_CHAR_SPEC'
  41747. -     A C string constant that tells the GNU CC driver program options to
  41748. -     pass to CPP.  By default, this macro is defined to pass the option
  41749. -     `-D__CHAR_UNSIGNED__' to CPP if `char' will be treated as
  41750. -     `unsigned char' by `cc1'.
  41751. -
  41752. -     Do not define this macro unless you need to override the default
  41753. -     definition.
  41754. -
  41755. -`CC1_SPEC'
  41756. -     A C string constant that tells the GNU CC driver program options to
  41757. -     pass to `cc1'.  It can also specify how to translate options you
  41758. -     give to GNU CC into options for GNU CC to pass to the `cc1'.
  41759. -
  41760. -     Do not define this macro if it does not need to do anything.
  41761. -
  41762. -`CC1PLUS_SPEC'
  41763. -     A C string constant that tells the GNU CC driver program options to
  41764. -     pass to `cc1plus'.  It can also specify how to translate options
  41765. -     you give to GNU CC into options for GNU CC to pass to the
  41766. -     `cc1plus'.
  41767. -
  41768. -     Do not define this macro if it does not need to do anything.
  41769. -
  41770. -`ASM_SPEC'
  41771. -     A C string constant that tells the GNU CC driver program options to
  41772. -     pass to the assembler.  It can also specify how to translate
  41773. -     options you give to GNU CC into options for GNU CC to pass to the
  41774. -     assembler.  See the file `sun3.h' for an example of this.
  41775. -
  41776. -     Do not define this macro if it does not need to do anything.
  41777. -
  41778. -`ASM_FINAL_SPEC'
  41779. -     A C string constant that tells the GNU CC driver program how to
  41780. -     run any programs which cleanup after the normal assembler.
  41781. -     Normally, this is not needed.  See the file `mips.h' for an
  41782. -     example of this.
  41783. -
  41784. -     Do not define this macro if it does not need to do anything.
  41785. -
  41786. -`LINK_SPEC'
  41787. -     A C string constant that tells the GNU CC driver program options to
  41788. -     pass to the linker.  It can also specify how to translate options
  41789. -     you give to GNU CC into options for GNU CC to pass to the linker.
  41790. -
  41791. -     Do not define this macro if it does not need to do anything.
  41792. -
  41793. -`LIB_SPEC'
  41794. -     Another C string constant used much like `LINK_SPEC'.  The
  41795. -     difference between the two is that `LIB_SPEC' is used at the end
  41796. -     of the command given to the linker.
  41797. -
  41798. -     If this macro is not defined, a default is provided that loads the
  41799. -     standard C library from the usual place.  See `gcc.c'.
  41800. -
  41801. -`LIBGCC_SPEC'
  41802. -     Another C string constant that tells the GNU CC driver program how
  41803. -     and when to place a reference to `libgcc.a' into the linker
  41804. -     command line.  This constant is placed both before and after the
  41805. -     value of `LIB_SPEC'.
  41806. -
  41807. -     If this macro is not defined, the GNU CC driver provides a default
  41808. -     that passes the string `-lgcc' to the linker unless the `-shared'
  41809. -     option is specified.
  41810. -
  41811. -`STARTFILE_SPEC'
  41812. -     Another C string constant used much like `LINK_SPEC'.  The
  41813. -     difference between the two is that `STARTFILE_SPEC' is used at the
  41814. -     very beginning of the command given to the linker.
  41815. -
  41816. -     If this macro is not defined, a default is provided that loads the
  41817. -     standard C startup file from the usual place.  See `gcc.c'.
  41818. -
  41819. -`ENDFILE_SPEC'
  41820. -     Another C string constant used much like `LINK_SPEC'.  The
  41821. -     difference between the two is that `ENDFILE_SPEC' is used at the
  41822. -     very end of the command given to the linker.
  41823. -
  41824. -     Do not define this macro if it does not need to do anything.
  41825. -
  41826. -`LINK_LIBGCC_SPECIAL'
  41827. -     Define this macro if the driver program should find the library
  41828. -     `libgcc.a' itself and should not pass `-L' options to the linker.
  41829. -     If you do not define this macro, the driver program will pass the
  41830. -     argument `-lgcc' to tell the linker to do the search and will pass
  41831. -     `-L' options to it.
  41832. -
  41833. -`LINK_LIBGCC_SPECIAL_1'
  41834. -     Define this macro if the driver program should find the library
  41835. -     `libgcc.a'.  If you do not define this macro, the driver program
  41836. -     will pass the argument `-lgcc' to tell the linker to do the search.
  41837. -     This macro is similar to `LINK_LIBGCC_SPECIAL', except that it does
  41838. -     not affect `-L' options.
  41839. -
  41840. -`MULTILIB_DEFAULTS'
  41841. -     Define this macro as a C expression for the initializer of an
  41842. -     array of string to tell the driver program which options are
  41843. -     defaults for this target and thus do not need to be handled
  41844. -     specially when using `MULTILIB_OPTIONS'.
  41845. -
  41846. -     Do not define this macro if `MULTILIB_OPTIONS' is not defined in
  41847. -     the target makefile fragment or if none of the options listed in
  41848. -     `MULTILIB_OPTIONS' are set by default.  *Note Target Fragment::.
  41849. -
  41850. -`RELATIVE_PREFIX_NOT_LINKDIR'
  41851. -     Define this macro to tell `gcc' that it should only translate a
  41852. -     `-B' prefix into a `-L' linker option if the prefix indicates an
  41853. -     absolute file name.
  41854. -
  41855. -`STANDARD_EXEC_PREFIX'
  41856. -     Define this macro as a C string constant if you wish to override
  41857. -     the standard choice of `/usr/local/lib/gcc-lib/' as the default
  41858. -     prefix to try when searching for the executable files of the
  41859. -     compiler.
  41860. -
  41861. -`MD_EXEC_PREFIX'
  41862. -     If defined, this macro is an additional prefix to try after
  41863. -     `STANDARD_EXEC_PREFIX'.  `MD_EXEC_PREFIX' is not searched when the
  41864. -     `-b' option is used, or the compiler is built as a cross compiler.
  41865. -
  41866. -`STANDARD_STARTFILE_PREFIX'
  41867. -     Define this macro as a C string constant if you wish to override
  41868. -     the standard choice of `/usr/local/lib/' as the default prefix to
  41869. -     try when searching for startup files such as `crt0.o'.
  41870. -
  41871. -`MD_STARTFILE_PREFIX'
  41872. -     If defined, this macro supplies an additional prefix to try after
  41873. -     the standard prefixes.  `MD_EXEC_PREFIX' is not searched when the
  41874. -     `-b' option is used, or when the compiler is built as a cross
  41875. -     compiler.
  41876. -
  41877. -`MD_STARTFILE_PREFIX_1'
  41878. -     If defined, this macro supplies yet another prefix to try after the
  41879. -     standard prefixes.  It is not searched when the `-b' option is
  41880. -     used, or when the compiler is built as a cross compiler.
  41881. -
  41882. -`INIT_ENVIRONMENT'
  41883. -     Define this macro as a C string constant if you with to set
  41884. -     environment variables for programs called by the driver, such as
  41885. -     the assembler and loader.  The driver passes the value of this
  41886. -     macro to `putenv' to initialize the necessary environment
  41887. -     variables.
  41888. -
  41889. -`LOCAL_INCLUDE_DIR'
  41890. -     Define this macro as a C string constant if you wish to override
  41891. -     the standard choice of `/usr/local/include' as the default prefix
  41892. -     to try when searching for local header files.  `LOCAL_INCLUDE_DIR'
  41893. -     comes before `SYSTEM_INCLUDE_DIR' in the search order.
  41894. -
  41895. -     Cross compilers do not use this macro and do not search either
  41896. -     `/usr/local/include' or its replacement.
  41897. -
  41898. -`SYSTEM_INCLUDE_DIR'
  41899. -     Define this macro as a C string constant if you wish to specify a
  41900. -     system-specific directory to search for header files before the
  41901. -     standard directory.  `SYSTEM_INCLUDE_DIR' comes before
  41902. -     `STANDARD_INCLUDE_DIR' in the search order.
  41903. -
  41904. -     Cross compilers do not use this macro and do not search the
  41905. -     directory specified.
  41906. -
  41907. -`STANDARD_INCLUDE_DIR'
  41908. -     Define this macro as a C string constant if you wish to override
  41909. -     the standard choice of `/usr/include' as the default prefix to try
  41910. -     when searching for header files.
  41911. -
  41912. -     Cross compilers do not use this macro and do not search either
  41913. -     `/usr/include' or its replacement.
  41914. -
  41915. -`INCLUDE_DEFAULTS'
  41916. -     Define this macro if you wish to override the entire default
  41917. -     search path for include files.  The default search path includes
  41918. -     `GCC_INCLUDE_DIR', `LOCAL_INCLUDE_DIR', `SYSTEM_INCLUDE_DIR',
  41919. -     `GPLUSPLUS_INCLUDE_DIR', and `STANDARD_INCLUDE_DIR'.  In addition,
  41920. -     `GPLUSPLUS_INCLUDE_DIR' and `GCC_INCLUDE_DIR' are defined
  41921. -     automatically by `Makefile', and specify private search areas for
  41922. -     GCC.  The directory `GPLUSPLUS_INCLUDE_DIR' is used only for C++
  41923. -     programs.
  41924. -
  41925. -     The definition should be an initializer for an array of structures.
  41926. -     Each array element should have two elements: the directory name (a
  41927. -     string constant) and a flag for C++-only directories.  Mark the
  41928. -     end of the array with a null element.  For example, here is the
  41929. -     definition used for VMS:
  41930. -
  41931. -          #define INCLUDE_DEFAULTS \
  41932. -          {                                       \
  41933. -            { "GNU_GXX_INCLUDE:", 1},             \
  41934. -            { "GNU_CC_INCLUDE:", 0},              \
  41935. -            { "SYS$SYSROOT:[SYSLIB.]", 0},        \
  41936. -            { ".", 0},                            \
  41937. -            { 0, 0}                               \
  41938. -          }
  41939. -
  41940. -   Here is the order of prefixes tried for exec files:
  41941. -
  41942. -  1. Any prefixes specified by the user with `-B'.
  41943. -
  41944. -  2. The environment variable `GCC_EXEC_PREFIX', if any.
  41945. -
  41946. -  3. The directories specified by the environment variable
  41947. -     `COMPILER_PATH'.
  41948. -
  41949. -  4. The macro `STANDARD_EXEC_PREFIX'.
  41950. -
  41951. -  5. `/usr/lib/gcc/'.
  41952. -
  41953. -  6. The macro `MD_EXEC_PREFIX', if any.
  41954. -
  41955. -   Here is the order of prefixes tried for startfiles:
  41956. -
  41957. -  1. Any prefixes specified by the user with `-B'.
  41958. -
  41959. -  2. The environment variable `GCC_EXEC_PREFIX', if any.
  41960. -
  41961. -  3. The directories specified by the environment variable
  41962. -     `LIBRARY_PATH' (native only, cross compilers do not use this).
  41963. -
  41964. -  4. The macro `STANDARD_EXEC_PREFIX'.
  41965. -
  41966. -  5. `/usr/lib/gcc/'.
  41967. -
  41968. -  6. The macro `MD_EXEC_PREFIX', if any.
  41969. -
  41970. -  7. The macro `MD_STARTFILE_PREFIX', if any.
  41971. -
  41972. -  8. The macro `STANDARD_STARTFILE_PREFIX'.
  41973. -
  41974. -  9. `/lib/'.
  41975. -
  41976. - 10. `/usr/lib/'.
  41977. -
  41978. -
  41979. -File: gcc.info,  Node: Run-time Target,  Next: Storage Layout,  Prev: Driver,  Up: Target Macros
  41980. -
  41981. -Run-time Target Specification
  41982. -=============================
  41983. -
  41984. -   Here are run-time target specifications.
  41985. -
  41986. -`CPP_PREDEFINES'
  41987. -     Define this to be a string constant containing `-D' options to
  41988. -     define the predefined macros that identify this machine and system.
  41989. -     These macros will be predefined unless the `-ansi' option is
  41990. -     specified.
  41991. -
  41992. -     In addition, a parallel set of macros are predefined, whose names
  41993. -     are made by appending `__' at the beginning and at the end.  These
  41994. -     `__' macros are permitted by the ANSI standard, so they are
  41995. -     predefined regardless of whether `-ansi' is specified.
  41996. -
  41997. -     For example, on the Sun, one can use the following value:
  41998. -
  41999. -          "-Dmc68000 -Dsun -Dunix"
  42000. -
  42001. -     The result is to define the macros `__mc68000__', `__sun__' and
  42002. -     `__unix__' unconditionally, and the macros `mc68000', `sun' and
  42003. -     `unix' provided `-ansi' is not specified.
  42004. -
  42005. -`extern int target_flags;'
  42006. -     This declaration should be present.
  42007. -
  42008. -`TARGET_...'
  42009. -     This series of macros is to allow compiler command arguments to
  42010. -     enable or disable the use of optional features of the target
  42011. -     machine.  For example, one machine description serves both the
  42012. -     68000 and the 68020; a command argument tells the compiler whether
  42013. -     it should use 68020-only instructions or not.  This command
  42014. -     argument works by means of a macro `TARGET_68020' that tests a bit
  42015. -     in `target_flags'.
  42016. -
  42017. -     Define a macro `TARGET_FEATURENAME' for each such option.  Its
  42018. -     definition should test a bit in `target_flags'; for example:
  42019. -
  42020. -          #define TARGET_68020 (target_flags & 1)
  42021. -
  42022. -     One place where these macros are used is in the
  42023. -     condition-expressions of instruction patterns.  Note how
  42024. -     `TARGET_68020' appears frequently in the 68000 machine description
  42025. -     file, `m68k.md'.  Another place they are used is in the
  42026. -     definitions of the other macros in the `MACHINE.h' file.
  42027. -
  42028. -`TARGET_SWITCHES'
  42029. -     This macro defines names of command options to set and clear bits
  42030. -     in `target_flags'.  Its definition is an initializer with a
  42031. -     subgrouping for each command option.
  42032. -
  42033. -     Each subgrouping contains a string constant, that defines the
  42034. -     option name, and a number, which contains the bits to set in
  42035. -     `target_flags'.  A negative number says to clear bits instead; the
  42036. -     negative of the number is which bits to clear.  The actual option
  42037. -     name is made by appending `-m' to the specified name.
  42038. -
  42039. -     One of the subgroupings should have a null string.  The number in
  42040. -     this grouping is the default value for `target_flags'.  Any target
  42041. -     options act starting with that value.
  42042. -
  42043. -     Here is an example which defines `-m68000' and `-m68020' with
  42044. -     opposite meanings, and picks the latter as the default:
  42045. -
  42046. -          #define TARGET_SWITCHES \
  42047. -            { { "68020", 1},      \
  42048. -              { "68000", -1},     \
  42049. -              { "", 1}}
  42050. -
  42051. -`TARGET_OPTIONS'
  42052. -     This macro is similar to `TARGET_SWITCHES' but defines names of
  42053. -     command options that have values.  Its definition is an
  42054. -     initializer with a subgrouping for each command option.
  42055. -
  42056. -     Each subgrouping contains a string constant, that defines the
  42057. -     fixed part of the option name, and the address of a variable.  The
  42058. -     variable, type `char *', is set to the variable part of the given
  42059. -     option if the fixed part matches.  The actual option name is made
  42060. -     by appending `-m' to the specified name.
  42061. -
  42062. -     Here is an example which defines `-mshort-data-NUMBER'.  If the
  42063. -     given option is `-mshort-data-512', the variable `m88k_short_data'
  42064. -     will be set to the string `"512"'.
  42065. -
  42066. -          extern char *m88k_short_data;
  42067. -          #define TARGET_OPTIONS \
  42068. -           { { "short-data-", &m88k_short_data } }
  42069. -
  42070. -`TARGET_VERSION'
  42071. -     This macro is a C statement to print on `stderr' a string
  42072. -     describing the particular machine description choice.  Every
  42073. -     machine description should define `TARGET_VERSION'.  For example:
  42074. -
  42075. -          #ifdef MOTOROLA
  42076. -          #define TARGET_VERSION \
  42077. -            fprintf (stderr, " (68k, Motorola syntax)");
  42078. -          #else
  42079. -          #define TARGET_VERSION \
  42080. -            fprintf (stderr, " (68k, MIT syntax)");
  42081. -          #endif
  42082. -
  42083. -`OVERRIDE_OPTIONS'
  42084. -     Sometimes certain combinations of command options do not make
  42085. -     sense on a particular target machine.  You can define a macro
  42086. -     `OVERRIDE_OPTIONS' to take account of this.  This macro, if
  42087. -     defined, is executed once just after all the command options have
  42088. -     been parsed.
  42089. -
  42090. -     Don't use this macro to turn on various extra optimizations for
  42091. -     `-O'.  That is what `OPTIMIZATION_OPTIONS' is for.
  42092. -
  42093. -`OPTIMIZATION_OPTIONS (LEVEL)'
  42094. -     Some machines may desire to change what optimizations are
  42095. -     performed for various optimization levels.   This macro, if
  42096. -     defined, is executed once just after the optimization level is
  42097. -     determined and before the remainder of the command options have
  42098. -     been parsed.  Values set in this macro are used as the default
  42099. -     values for the other command line options.
  42100. -
  42101. -     LEVEL is the optimization level specified; 2 if `-O2' is
  42102. -     specified, 1 if `-O' is specified, and 0 if neither is specified.
  42103. -
  42104. -     You should not use this macro to change options that are not
  42105. -     machine-specific.  These should uniformly selected by the same
  42106. -     optimization level on all supported machines.  Use this macro to
  42107. -     enable machbine-specific optimizations.
  42108. -
  42109. -     *Do not examine `write_symbols' in this macro!* The debugging
  42110. -     options are not supposed to alter the generated code.
  42111. -
  42112. -`CAN_DEBUG_WITHOUT_FP'
  42113. -     Define this macro if debugging can be performed even without a
  42114. -     frame pointer.  If this macro is defined, GNU CC will turn on the
  42115. -     `-fomit-frame-pointer' option whenever `-O' is specified.
  42116. -
  42117. -
  42118. -File: gcc.info,  Node: Storage Layout,  Next: Type Layout,  Prev: Run-time Target,  Up: Target Macros
  42119. -
  42120. -Storage Layout
  42121. -==============
  42122. -
  42123. -   Note that the definitions of the macros in this table which are
  42124. -sizes or alignments measured in bits do not need to be constant.  They
  42125. -can be C expressions that refer to static variables, such as the
  42126. -`target_flags'.  *Note Run-time Target::.
  42127. -
  42128. -`BITS_BIG_ENDIAN'
  42129. -     Define this macro to have the value 1 if the most significant bit
  42130. -     in a byte has the lowest number; otherwise define it to have the
  42131. -     value zero.  This means that bit-field instructions count from the
  42132. -     most significant bit.  If the machine has no bit-field
  42133. -     instructions, then this must still be defined, but it doesn't
  42134. -     matter which value it is defined to.  This macro need not be a
  42135. -     constant.
  42136. -
  42137. -     This macro does not affect the way structure fields are packed into
  42138. -     bytes or words; that is controlled by `BYTES_BIG_ENDIAN'.
  42139. -
  42140. -`BYTES_BIG_ENDIAN'
  42141. -     Define this macro to have the value 1 if the most significant byte
  42142. -     in a word has the lowest number.  This macro need not be a
  42143. -     constant.
  42144. -
  42145. -`WORDS_BIG_ENDIAN'
  42146. -     Define this macro to have the value 1 if, in a multiword object,
  42147. -     the most significant word has the lowest number.  This applies to
  42148. -     both memory locations and registers; GNU CC fundamentally assumes
  42149. -     that the order of words in memory is the same as the order in
  42150. -     registers.  This macro need not be a constant.
  42151. -
  42152. -`LIBGCC2_WORDS_BIG_ENDIAN'
  42153. -     Define this macro if WORDS_BIG_ENDIAN is not constant.  This must
  42154. -     be a constant value with the same meaning as WORDS_BIG_ENDIAN,
  42155. -     which will be used only when compiling libgcc2.c.  Typically the
  42156. -     value will be set based on preprocessor defines.
  42157. -
  42158. -`FLOAT_WORDS_BIG_ENDIAN'
  42159. -     Define this macro to have the value 1 if `DFmode', `XFmode' or
  42160. -     `TFmode' floating point numbers are stored in memory with the word
  42161. -     containing the sign bit at the lowest address; otherwise define it
  42162. -     to have the value 0.  This macro need not be a constant.
  42163. -
  42164. -     You need not define this macro if the ordering is the same as for
  42165. -     multi-word integers.
  42166. -
  42167. -`BITS_PER_UNIT'
  42168. -     Define this macro to be the number of bits in an addressable
  42169. -     storage unit (byte); normally 8.
  42170. -
  42171. -`BITS_PER_WORD'
  42172. -     Number of bits in a word; normally 32.
  42173. -
  42174. -`MAX_BITS_PER_WORD'
  42175. -     Maximum number of bits in a word.  If this is undefined, the
  42176. -     default is `BITS_PER_WORD'.  Otherwise, it is the constant value
  42177. -     that is the largest value that `BITS_PER_WORD' can have at
  42178. -     run-time.
  42179. -
  42180. -`UNITS_PER_WORD'
  42181. -     Number of storage units in a word; normally 4.
  42182. -
  42183. -`MIN_UNITS_PER_WORD'
  42184. -     Minimum number of units in a word.  If this is undefined, the
  42185. -     default is `UNITS_PER_WORD'.  Otherwise, it is the constant value
  42186. -     that is the smallest value that `UNITS_PER_WORD' can have at
  42187. -     run-time.
  42188. -
  42189. -`POINTER_SIZE'
  42190. -     Width of a pointer, in bits.  You must specify a value no wider
  42191. -     than the width of `Pmode'.  If it is not equal to the width of
  42192. -     `Pmode', you must define `POINTERS_EXTEND_UNSIGNED'.
  42193. -
  42194. -`POINTERS_EXTEND_UNSIGNED'
  42195. -     A C expression whose value is nonzero if pointers that need to be
  42196. -     extended from being `POINTER_SIZE' bits wide to `Pmode' are
  42197. -     sign-extended and zero if they are zero-extended.
  42198. -
  42199. -     You need not define this macro if the `POINTER_SIZE' is equal to
  42200. -     the width of `Pmode'.
  42201. -
  42202. -`PROMOTE_MODE (M, UNSIGNEDP, TYPE)'
  42203. -     A macro to update M and UNSIGNEDP when an object whose type is
  42204. -     TYPE and which has the specified mode and signedness is to be
  42205. -     stored in a register.  This macro is only called when TYPE is a
  42206. -     scalar type.
  42207. -
  42208. -     On most RISC machines, which only have operations that operate on
  42209. -     a full register, define this macro to set M to `word_mode' if M is
  42210. -     an integer mode narrower than `BITS_PER_WORD'.  In most cases,
  42211. -     only integer modes should be widened because wider-precision
  42212. -     floating-point operations are usually more expensive than their
  42213. -     narrower counterparts.
  42214. -
  42215. -     For most machines, the macro definition does not change UNSIGNEDP.
  42216. -     However, some machines, have instructions that preferentially
  42217. -     handle either signed or unsigned quantities of certain modes.  For
  42218. -     example, on the DEC Alpha, 32-bit loads from memory and 32-bit add
  42219. -     instructions sign-extend the result to 64 bits.  On such machines,
  42220. -     set UNSIGNEDP according to which kind of extension is more
  42221. -     efficient.
  42222. -
  42223. -     Do not define this macro if it would never modify M.
  42224. -
  42225. -`PROMOTE_FUNCTION_ARGS'
  42226. -     Define this macro if the promotion described by `PROMOTE_MODE'
  42227. -     should also be done for outgoing function arguments.
  42228. -
  42229. -`PROMOTE_FUNCTION_RETURN'
  42230. -     Define this macro if the promotion described by `PROMOTE_MODE'
  42231. -     should also be done for the return value of functions.
  42232. -
  42233. -     If this macro is defined, `FUNCTION_VALUE' must perform the same
  42234. -     promotions done by `PROMOTE_MODE'.
  42235. -
  42236. -`PROMOTE_FOR_CALL_ONLY'
  42237. -     Define this macro if the promotion described by `PROMOTE_MODE'
  42238. -     should *only* be performed for outgoing function arguments or
  42239. -     function return values, as specified by `PROMOTE_FUNCTION_ARGS'
  42240. -     and `PROMOTE_FUNCTION_RETURN', respectively.
  42241. -
  42242. -`PARM_BOUNDARY'
  42243. -     Normal alignment required for function parameters on the stack, in
  42244. -     bits.  All stack parameters receive at least this much alignment
  42245. -     regardless of data type.  On most machines, this is the same as the
  42246. -     size of an integer.
  42247. -
  42248. -`STACK_BOUNDARY'
  42249. -     Define this macro if you wish to preserve a certain alignment for
  42250. -     the stack pointer.  The definition is a C expression for the
  42251. -     desired alignment (measured in bits).
  42252. -
  42253. -     If `PUSH_ROUNDING' is not defined, the stack will always be aligned
  42254. -     to the specified boundary.  If `PUSH_ROUNDING' is defined and
  42255. -     specifies a less strict alignment than `STACK_BOUNDARY', the stack
  42256. -     may be momentarily unaligned while pushing arguments.
  42257. -
  42258. -`FUNCTION_BOUNDARY'
  42259. -     Alignment required for a function entry point, in bits.
  42260. -
  42261. -`BIGGEST_ALIGNMENT'
  42262. -     Biggest alignment that any data type can require on this machine,
  42263. -     in bits.
  42264. -
  42265. -`BIGGEST_FIELD_ALIGNMENT'
  42266. -     Biggest alignment that any structure field can require on this
  42267. -     machine, in bits.  If defined, this overrides `BIGGEST_ALIGNMENT'
  42268. -     for structure fields only.
  42269. -
  42270. -`MAX_OFILE_ALIGNMENT'
  42271. -     Biggest alignment supported by the object file format of this
  42272. -     machine.  Use this macro to limit the alignment which can be
  42273. -     specified using the `__attribute__ ((aligned (N)))' construct.  If
  42274. -     not defined, the default value is `BIGGEST_ALIGNMENT'.
  42275. -
  42276. -`DATA_ALIGNMENT (TYPE, BASIC-ALIGN)'
  42277. -     If defined, a C expression to compute the alignment for a static
  42278. -     variable.  TYPE is the data type, and BASIC-ALIGN is the alignment
  42279. -     that the object would ordinarily have.  The value of this macro is
  42280. -     used instead of that alignment to align the object.
  42281. -
  42282. -     If this macro is not defined, then BASIC-ALIGN is used.
  42283. -
  42284. -     One use of this macro is to increase alignment of medium-size data
  42285. -     to make it all fit in fewer cache lines.  Another is to cause
  42286. -     character arrays to be word-aligned so that `strcpy' calls that
  42287. -     copy constants to character arrays can be done inline.
  42288. -
  42289. -`CONSTANT_ALIGNMENT (CONSTANT, BASIC-ALIGN)'
  42290. -     If defined, a C expression to compute the alignment given to a
  42291. -     constant that is being placed in memory.  CONSTANT is the constant
  42292. -     and BASIC-ALIGN is the alignment that the object would ordinarily
  42293. -     have.  The value of this macro is used instead of that alignment to
  42294. -     align the object.
  42295. -
  42296. -     If this macro is not defined, then BASIC-ALIGN is used.
  42297. -
  42298. -     The typical use of this macro is to increase alignment for string
  42299. -     constants to be word aligned so that `strcpy' calls that copy
  42300. -     constants can be done inline.
  42301. -
  42302. -`EMPTY_FIELD_BOUNDARY'
  42303. -     Alignment in bits to be given to a structure bit field that
  42304. -     follows an empty field such as `int : 0;'.
  42305. -
  42306. -     Note that `PCC_BITFIELD_TYPE_MATTERS' also affects the alignment
  42307. -     that results from an empty field.
  42308. -
  42309. -`STRUCTURE_SIZE_BOUNDARY'
  42310. -     Number of bits which any structure or union's size must be a
  42311. -     multiple of.  Each structure or union's size is rounded up to a
  42312. -     multiple of this.
  42313. -
  42314. -     If you do not define this macro, the default is the same as
  42315. -     `BITS_PER_UNIT'.
  42316. -
  42317. -`STRICT_ALIGNMENT'
  42318. -     Define this macro to be the value 1 if instructions will fail to
  42319. -     work if given data not on the nominal alignment.  If instructions
  42320. -     will merely go slower in that case, define this macro as 0.
  42321. -
  42322. -`PCC_BITFIELD_TYPE_MATTERS'
  42323. -     Define this if you wish to imitate the way many other C compilers
  42324. -     handle alignment of bitfields and the structures that contain them.
  42325. -
  42326. -     The behavior is that the type written for a bitfield (`int',
  42327. -     `short', or other integer type) imposes an alignment for the
  42328. -     entire structure, as if the structure really did contain an
  42329. -     ordinary field of that type.  In addition, the bitfield is placed
  42330. -     within the structure so that it would fit within such a field, not
  42331. -     crossing a boundary for it.
  42332. -
  42333. -     Thus, on most machines, a bitfield whose type is written as `int'
  42334. -     would not cross a four-byte boundary, and would force four-byte
  42335. -     alignment for the whole structure.  (The alignment used may not be
  42336. -     four bytes; it is controlled by the other alignment parameters.)
  42337. -
  42338. -     If the macro is defined, its definition should be a C expression;
  42339. -     a nonzero value for the expression enables this behavior.
  42340. -
  42341. -     Note that if this macro is not defined, or its value is zero, some
  42342. -     bitfields may cross more than one alignment boundary.  The
  42343. -     compiler can support such references if there are `insv', `extv',
  42344. -     and `extzv' insns that can directly reference memory.
  42345. -
  42346. -     The other known way of making bitfields work is to define
  42347. -     `STRUCTURE_SIZE_BOUNDARY' as large as `BIGGEST_ALIGNMENT'.  Then
  42348. -     every structure can be accessed with fullwords.
  42349. -
  42350. -     Unless the machine has bitfield instructions or you define
  42351. -     `STRUCTURE_SIZE_BOUNDARY' that way, you must define
  42352. -     `PCC_BITFIELD_TYPE_MATTERS' to have a nonzero value.
  42353. -
  42354. -     If your aim is to make GNU CC use the same conventions for laying
  42355. -     out bitfields as are used by another compiler, here is how to
  42356. -     investigate what the other compiler does.  Compile and run this
  42357. -     program:
  42358. -
  42359. -          struct foo1
  42360. -          {
  42361. -            char x;
  42362. -            char :0;
  42363. -            char y;
  42364. -          };
  42365. -          
  42366. -          struct foo2
  42367. -          {
  42368. -            char x;
  42369. -            int :0;
  42370. -            char y;
  42371. -          };
  42372. -          
  42373. -          main ()
  42374. -          {
  42375. -            printf ("Size of foo1 is %d\n",
  42376. -                    sizeof (struct foo1));
  42377. -            printf ("Size of foo2 is %d\n",
  42378. -                    sizeof (struct foo2));
  42379. -            exit (0);
  42380. -          }
  42381. -
  42382. -     If this prints 2 and 5, then the compiler's behavior is what you
  42383. -     would get from `PCC_BITFIELD_TYPE_MATTERS'.
  42384. -
  42385. -`BITFIELD_NBYTES_LIMITED'
  42386. -     Like PCC_BITFIELD_TYPE_MATTERS except that its effect is limited to
  42387. -     aligning a bitfield within the structure.
  42388. -
  42389. -`ROUND_TYPE_SIZE (STRUCT, SIZE, ALIGN)'
  42390. -     Define this macro as an expression for the overall size of a
  42391. -     structure (given by STRUCT as a tree node) when the size computed
  42392. -     from the fields is SIZE and the alignment is ALIGN.
  42393. -
  42394. -     The default is to round SIZE up to a multiple of ALIGN.
  42395. -
  42396. -`ROUND_TYPE_ALIGN (STRUCT, COMPUTED, SPECIFIED)'
  42397. -     Define this macro as an expression for the alignment of a structure
  42398. -     (given by STRUCT as a tree node) if the alignment computed in the
  42399. -     usual way is COMPUTED and the alignment explicitly specified was
  42400. -     SPECIFIED.
  42401. -
  42402. -     The default is to use SPECIFIED if it is larger; otherwise, use
  42403. -     the smaller of COMPUTED and `BIGGEST_ALIGNMENT'
  42404. -
  42405. -`MAX_FIXED_MODE_SIZE'
  42406. -     An integer expression for the size in bits of the largest integer
  42407. -     machine mode that should actually be used.  All integer machine
  42408. -     modes of this size or smaller can be used for structures and
  42409. -     unions with the appropriate sizes.  If this macro is undefined,
  42410. -     `GET_MODE_BITSIZE (DImode)' is assumed.
  42411. -
  42412. -`CHECK_FLOAT_VALUE (MODE, VALUE, OVERFLOW)'
  42413. -     A C statement to validate the value VALUE (of type `double') for
  42414. -     mode MODE.  This means that you check whether VALUE fits within
  42415. -     the possible range of values for mode MODE on this target machine.
  42416. -     The mode MODE is always a mode of class `MODE_FLOAT'.  OVERFLOW
  42417. -     is nonzero if the value is already known to be out of range.
  42418. -
  42419. -     If VALUE is not valid or if OVERFLOW is nonzero, you should set
  42420. -     OVERFLOW to 1 and then assign some valid value to VALUE.  Allowing
  42421. -     an invalid value to go through the compiler can produce incorrect
  42422. -     assembler code which may even cause Unix assemblers to crash.
  42423. -
  42424. -     This macro need not be defined if there is no work for it to do.
  42425. -
  42426. -`TARGET_FLOAT_FORMAT'
  42427. -     A code distinguishing the floating point format of the target
  42428. -     machine.  There are three defined values:
  42429. -
  42430. -    `IEEE_FLOAT_FORMAT'
  42431. -          This code indicates IEEE floating point.  It is the default;
  42432. -          there is no need to define this macro when the format is IEEE.
  42433. -
  42434. -    `VAX_FLOAT_FORMAT'
  42435. -          This code indicates the peculiar format used on the Vax.
  42436. -
  42437. -    `UNKNOWN_FLOAT_FORMAT'
  42438. -          This code indicates any other format.
  42439. -
  42440. -     The value of this macro is compared with `HOST_FLOAT_FORMAT'
  42441. -     (*note Config::.) to determine whether the target machine has the
  42442. -     same format as the host machine.  If any other formats are
  42443. -     actually in use on supported machines, new codes should be defined
  42444. -     for them.
  42445. -
  42446. -     The ordering of the component words of floating point values
  42447. -     stored in memory is controlled by `FLOAT_WORDS_BIG_ENDIAN' for the
  42448. -     target machine and `HOST_FLOAT_WORDS_BIG_ENDIAN' for the host.
  42449. -
  42450. -
  42451. -File: gcc.info,  Node: Type Layout,  Next: Registers,  Prev: Storage Layout,  Up: Target Macros
  42452. -
  42453. -Layout of Source Language Data Types
  42454. -====================================
  42455. -
  42456. -   These macros define the sizes and other characteristics of the
  42457. -standard basic data types used in programs being compiled.  Unlike the
  42458. -macros in the previous section, these apply to specific features of C
  42459. -and related languages, rather than to fundamental aspects of storage
  42460. -layout.
  42461. -
  42462. -`INT_TYPE_SIZE'
  42463. -     A C expression for the size in bits of the type `int' on the
  42464. -     target machine.  If you don't define this, the default is one word.
  42465. -
  42466. -`MAX_INT_TYPE_SIZE'
  42467. -     Maximum number for the size in bits of the type `int' on the target
  42468. -     machine.  If this is undefined, the default is `INT_TYPE_SIZE'.
  42469. -     Otherwise, it is the constant value that is the largest value that
  42470. -     `INT_TYPE_SIZE' can have at run-time.  This is used in `cpp'.
  42471. -
  42472. -`SHORT_TYPE_SIZE'
  42473. -     A C expression for the size in bits of the type `short' on the
  42474. -     target machine.  If you don't define this, the default is half a
  42475. -     word.  (If this would be less than one storage unit, it is rounded
  42476. -     up to one unit.)
  42477. -
  42478. -`LONG_TYPE_SIZE'
  42479. -     A C expression for the size in bits of the type `long' on the
  42480. -     target machine.  If you don't define this, the default is one word.
  42481. -
  42482. -`MAX_LONG_TYPE_SIZE'
  42483. -     Maximum number for the size in bits of the type `long' on the
  42484. -     target machine.  If this is undefined, the default is
  42485. -     `LONG_TYPE_SIZE'.  Otherwise, it is the constant value that is the
  42486. -     largest value that `LONG_TYPE_SIZE' can have at run-time.  This is
  42487. -     used in `cpp'.
  42488. -
  42489. -`LONG_LONG_TYPE_SIZE'
  42490. -     A C expression for the size in bits of the type `long long' on the
  42491. -     target machine.  If you don't define this, the default is two
  42492. -     words.  If you want to support GNU Ada on your machine, the value
  42493. -     of macro must be at least 64.
  42494. -
  42495. -`CHAR_TYPE_SIZE'
  42496. -     A C expression for the size in bits of the type `char' on the
  42497. -     target machine.  If you don't define this, the default is one
  42498. -     quarter of a word.  (If this would be less than one storage unit,
  42499. -     it is rounded up to one unit.)
  42500. -
  42501. -`MAX_CHAR_TYPE_SIZE'
  42502. -     Maximum number for the size in bits of the type `char' on the
  42503. -     target machine.  If this is undefined, the default is
  42504. -     `CHAR_TYPE_SIZE'.  Otherwise, it is the constant value that is the
  42505. -     largest value that `CHAR_TYPE_SIZE' can have at run-time.  This is
  42506. -     used in `cpp'.
  42507. -
  42508. -`FLOAT_TYPE_SIZE'
  42509. -     A C expression for the size in bits of the type `float' on the
  42510. -     target machine.  If you don't define this, the default is one word.
  42511. -
  42512. -`DOUBLE_TYPE_SIZE'
  42513. -     A C expression for the size in bits of the type `double' on the
  42514. -     target machine.  If you don't define this, the default is two
  42515. -     words.
  42516. -
  42517. -`LONG_DOUBLE_TYPE_SIZE'
  42518. -     A C expression for the size in bits of the type `long double' on
  42519. -     the target machine.  If you don't define this, the default is two
  42520. -     words.
  42521. -
  42522. -`DEFAULT_SIGNED_CHAR'
  42523. -     An expression whose value is 1 or 0, according to whether the type
  42524. -     `char' should be signed or unsigned by default.  The user can
  42525. -     always override this default with the options `-fsigned-char' and
  42526. -     `-funsigned-char'.
  42527. -
  42528. -`DEFAULT_SHORT_ENUMS'
  42529. -     A C expression to determine whether to give an `enum' type only as
  42530. -     many bytes as it takes to represent the range of possible values
  42531. -     of that type.  A nonzero value means to do that; a zero value
  42532. -     means all `enum' types should be allocated like `int'.
  42533. -
  42534. -     If you don't define the macro, the default is 0.
  42535. -
  42536. -`SIZE_TYPE'
  42537. -     A C expression for a string describing the name of the data type
  42538. -     to use for size values.  The typedef name `size_t' is defined
  42539. -     using the contents of the string.
  42540. -
  42541. -     The string can contain more than one keyword.  If so, separate
  42542. -     them with spaces, and write first any length keyword, then
  42543. -     `unsigned' if appropriate, and finally `int'.  The string must
  42544. -     exactly match one of the data type names defined in the function
  42545. -     `init_decl_processing' in the file `c-decl.c'.  You may not omit
  42546. -     `int' or change the order--that would cause the compiler to crash
  42547. -     on startup.
  42548. -
  42549. -     If you don't define this macro, the default is `"long unsigned
  42550. -     int"'.
  42551. -
  42552. -`PTRDIFF_TYPE'
  42553. -     A C expression for a string describing the name of the data type
  42554. -     to use for the result of subtracting two pointers.  The typedef
  42555. -     name `ptrdiff_t' is defined using the contents of the string.  See
  42556. -     `SIZE_TYPE' above for more information.
  42557. -
  42558. -     If you don't define this macro, the default is `"long int"'.
  42559. -
  42560. -`WCHAR_TYPE'
  42561. -     A C expression for a string describing the name of the data type
  42562. -     to use for wide characters.  The typedef name `wchar_t' is defined
  42563. -     using the contents of the string.  See `SIZE_TYPE' above for more
  42564. -     information.
  42565. -
  42566. -     If you don't define this macro, the default is `"int"'.
  42567. -
  42568. -`WCHAR_TYPE_SIZE'
  42569. -     A C expression for the size in bits of the data type for wide
  42570. -     characters.  This is used in `cpp', which cannot make use of
  42571. -     `WCHAR_TYPE'.
  42572. -
  42573. -`MAX_WCHAR_TYPE_SIZE'
  42574. -     Maximum number for the size in bits of the data type for wide
  42575. -     characters.  If this is undefined, the default is
  42576. -     `WCHAR_TYPE_SIZE'.  Otherwise, it is the constant value that is the
  42577. -     largest value that `WCHAR_TYPE_SIZE' can have at run-time.  This is
  42578. -     used in `cpp'.
  42579. -
  42580. -`OBJC_INT_SELECTORS'
  42581. -     Define this macro if the type of Objective C selectors should be
  42582. -     `int'.
  42583. -
  42584. -     If this macro is not defined, then selectors should have the type
  42585. -     `struct objc_selector *'.
  42586. -
  42587. -`OBJC_SELECTORS_WITHOUT_LABELS'
  42588. -     Define this macro if the compiler can group all the selectors
  42589. -     together into a vector and use just one label at the beginning of
  42590. -     the vector.  Otherwise, the compiler must give each selector its
  42591. -     own assembler label.
  42592. -
  42593. -     On certain machines, it is important to have a separate label for
  42594. -     each selector because this enables the linker to eliminate
  42595. -     duplicate selectors.
  42596. -
  42597. -`TARGET_BELL'
  42598. -     A C constant expression for the integer value for escape sequence
  42599. -     `\a'.
  42600. -
  42601. -`TARGET_BS'
  42602. -`TARGET_TAB'
  42603. -`TARGET_NEWLINE'
  42604. -     C constant expressions for the integer values for escape sequences
  42605. -     `\b', `\t' and `\n'.
  42606. -
  42607. -`TARGET_VT'
  42608. -`TARGET_FF'
  42609. -`TARGET_CR'
  42610. -     C constant expressions for the integer values for escape sequences
  42611. -     `\v', `\f' and `\r'.
  42612. -
  42613. -
  42614. -File: gcc.info,  Node: Registers,  Next: Register Classes,  Prev: Type Layout,  Up: Target Macros
  42615. -
  42616. -Register Usage
  42617. -==============
  42618. -
  42619. -   This section explains how to describe what registers the target
  42620. -machine has, and how (in general) they can be used.
  42621. -
  42622. -   The description of which registers a specific instruction can use is
  42623. -done with register classes; see *Note Register Classes::.  For
  42624. -information on using registers to access a stack frame, see *Note Frame
  42625. -Registers::.  For passing values in registers, see *Note Register
  42626. -Arguments::.  For returning values in registers, see *Note Scalar
  42627. -Return::.
  42628. -
  42629. -* Menu:
  42630. -
  42631. -* Register Basics::        Number and kinds of registers.
  42632. -* Allocation Order::        Order in which registers are allocated.
  42633. -* Values in Registers::        What kinds of values each reg can hold.
  42634. -* Leaf Functions::        Renumbering registers for leaf functions.
  42635. -* Stack Registers::        Handling a register stack such as 80387.
  42636. -* Obsolete Register Macros::    Macros formerly used for the 80387.
  42637. -
  42638. -
  42639. -File: gcc.info,  Node: Register Basics,  Next: Allocation Order,  Up: Registers
  42640. -
  42641. -Basic Characteristics of Registers
  42642. -----------------------------------
  42643. -
  42644. -   Registers have various characteristics.
  42645. -
  42646. -`FIRST_PSEUDO_REGISTER'
  42647. -     Number of hardware registers known to the compiler.  They receive
  42648. -     numbers 0 through `FIRST_PSEUDO_REGISTER-1'; thus, the first
  42649. -     pseudo register's number really is assigned the number
  42650. -     `FIRST_PSEUDO_REGISTER'.
  42651. -
  42652. -`FIXED_REGISTERS'
  42653. -     An initializer that says which registers are used for fixed
  42654. -     purposes all throughout the compiled code and are therefore not
  42655. -     available for general allocation.  These would include the stack
  42656. -     pointer, the frame pointer (except on machines where that can be
  42657. -     used as a general register when no frame pointer is needed), the
  42658. -     program counter on machines where that is considered one of the
  42659. -     addressable registers, and any other numbered register with a
  42660. -     standard use.
  42661. -
  42662. -     This information is expressed as a sequence of numbers, separated
  42663. -     by commas and surrounded by braces.  The Nth number is 1 if
  42664. -     register N is fixed, 0 otherwise.
  42665. -
  42666. -     The table initialized from this macro, and the table initialized by
  42667. -     the following one, may be overridden at run time either
  42668. -     automatically, by the actions of the macro
  42669. -     `CONDITIONAL_REGISTER_USAGE', or by the user with the command
  42670. -     options `-ffixed-REG', `-fcall-used-REG' and `-fcall-saved-REG'.
  42671. -
  42672. -`CALL_USED_REGISTERS'
  42673. -     Like `FIXED_REGISTERS' but has 1 for each register that is
  42674. -     clobbered (in general) by function calls as well as for fixed
  42675. -     registers.  This macro therefore identifies the registers that are
  42676. -     not available for general allocation of values that must live
  42677. -     across function calls.
  42678. -
  42679. -     If a register has 0 in `CALL_USED_REGISTERS', the compiler
  42680. -     automatically saves it on function entry and restores it on
  42681. -     function exit, if the register is used within the function.
  42682. -
  42683. -`CONDITIONAL_REGISTER_USAGE'
  42684. -     Zero or more C statements that may conditionally modify two
  42685. -     variables `fixed_regs' and `call_used_regs' (both of type `char
  42686. -     []') after they have been initialized from the two preceding
  42687. -     macros.
  42688. -
  42689. -     This is necessary in case the fixed or call-clobbered registers
  42690. -     depend on target flags.
  42691. -
  42692. -     You need not define this macro if it has no work to do.
  42693. -
  42694. -     If the usage of an entire class of registers depends on the target
  42695. -     flags, you may indicate this to GCC by using this macro to modify
  42696. -     `fixed_regs' and `call_used_regs' to 1 for each of the registers
  42697. -     in the classes which should not be used by GCC.  Also define the
  42698. -     macro `REG_CLASS_FROM_LETTER' to return `NO_REGS' if it is called
  42699. -     with a letter for a class that shouldn't be used.
  42700. -
  42701. -     (However, if this class is not included in `GENERAL_REGS' and all
  42702. -     of the insn patterns whose constraints permit this class are
  42703. -     controlled by target switches, then GCC will automatically avoid
  42704. -     using these registers when the target switches are opposed to
  42705. -     them.)
  42706. -
  42707. -`NON_SAVING_SETJMP'
  42708. -     If this macro is defined and has a nonzero value, it means that
  42709. -     `setjmp' and related functions fail to save the registers, or that
  42710. -     `longjmp' fails to restore them.  To compensate, the compiler
  42711. -     avoids putting variables in registers in functions that use
  42712. -     `setjmp'.
  42713. -
  42714. -`INCOMING_REGNO (OUT)'
  42715. -     Define this macro if the target machine has register windows.
  42716. -     This C expression returns the register number as seen by the
  42717. -     called function corresponding to the register number OUT as seen
  42718. -     by the calling function.  Return OUT if register number OUT is not
  42719. -     an outbound register.
  42720. -
  42721. -`OUTGOING_REGNO (IN)'
  42722. -     Define this macro if the target machine has register windows.
  42723. -     This C expression returns the register number as seen by the
  42724. -     calling function corresponding to the register number IN as seen
  42725. -     by the called function.  Return IN if register number IN is not an
  42726. -     inbound register.
  42727. -
  42728. -
  42729. -File: gcc.info,  Node: Allocation Order,  Next: Values in Registers,  Prev: Register Basics,  Up: Registers
  42730. -
  42731. -Order of Allocation of Registers
  42732. ---------------------------------
  42733. -
  42734. -   Registers are allocated in order.
  42735. -
  42736. -`REG_ALLOC_ORDER'
  42737. -     If defined, an initializer for a vector of integers, containing the
  42738. -     numbers of hard registers in the order in which GNU CC should
  42739. -     prefer to use them (from most preferred to least).
  42740. -
  42741. -     If this macro is not defined, registers are used lowest numbered
  42742. -     first (all else being equal).
  42743. -
  42744. -     One use of this macro is on machines where the highest numbered
  42745. -     registers must always be saved and the save-multiple-registers
  42746. -     instruction supports only sequences of consecutive registers.  On
  42747. -     such machines, define `REG_ALLOC_ORDER' to be an initializer that
  42748. -     lists the highest numbered allocatable register first.
  42749. -
  42750. -`ORDER_REGS_FOR_LOCAL_ALLOC'
  42751. -     A C statement (sans semicolon) to choose the order in which to
  42752. -     allocate hard registers for pseudo-registers local to a basic
  42753. -     block.
  42754. -
  42755. -     Store the desired register order in the array `reg_alloc_order'.
  42756. -     Element 0 should be the register to allocate first; element 1, the
  42757. -     next register; and so on.
  42758. -
  42759. -     The macro body should not assume anything about the contents of
  42760. -     `reg_alloc_order' before execution of the macro.
  42761. -
  42762. -     On most machines, it is not necessary to define this macro.
  42763. -
  42764. -
  42765. -File: gcc.info,  Node: Values in Registers,  Next: Leaf Functions,  Prev: Allocation Order,  Up: Registers
  42766. -
  42767. -How Values Fit in Registers
  42768. ----------------------------
  42769. -
  42770. -   This section discusses the macros that describe which kinds of values
  42771. -(specifically, which machine modes) each register can hold, and how many
  42772. -consecutive registers are needed for a given mode.
  42773. -
  42774. -`HARD_REGNO_NREGS (REGNO, MODE)'
  42775. -     A C expression for the number of consecutive hard registers,
  42776. -     starting at register number REGNO, required to hold a value of mode
  42777. -     MODE.
  42778. -
  42779. -     On a machine where all registers are exactly one word, a suitable
  42780. -     definition of this macro is
  42781. -
  42782. -          #define HARD_REGNO_NREGS(REGNO, MODE)            \
  42783. -             ((GET_MODE_SIZE (MODE) + UNITS_PER_WORD - 1)  \
  42784. -              / UNITS_PER_WORD))
  42785. -
  42786. -`HARD_REGNO_MODE_OK (REGNO, MODE)'
  42787. -     A C expression that is nonzero if it is permissible to store a
  42788. -     value of mode MODE in hard register number REGNO (or in several
  42789. -     registers starting with that one).  For a machine where all
  42790. -     registers are equivalent, a suitable definition is
  42791. -
  42792. -          #define HARD_REGNO_MODE_OK(REGNO, MODE) 1
  42793. -
  42794. -     It is not necessary for this macro to check for the numbers of
  42795. -     fixed registers, because the allocation mechanism considers them
  42796. -     to be always occupied.
  42797. -
  42798. -     On some machines, double-precision values must be kept in even/odd
  42799. -     register pairs.  The way to implement that is to define this macro
  42800. -     to reject odd register numbers for such modes.
  42801. -
  42802. -     The minimum requirement for a mode to be OK in a register is that
  42803. -     the `movMODE' instruction pattern support moves between the
  42804. -     register and any other hard register for which the mode is OK; and
  42805. -     that moving a value into the register and back out not alter it.
  42806. -
  42807. -     Since the same instruction used to move `SImode' will work for all
  42808. -     narrower integer modes, it is not necessary on any machine for
  42809. -     `HARD_REGNO_MODE_OK' to distinguish between these modes, provided
  42810. -     you define patterns `movhi', etc., to take advantage of this.  This
  42811. -     is useful because of the interaction between `HARD_REGNO_MODE_OK'
  42812. -     and `MODES_TIEABLE_P'; it is very desirable for all integer modes
  42813. -     to be tieable.
  42814. -
  42815. -     Many machines have special registers for floating point arithmetic.
  42816. -     Often people assume that floating point machine modes are allowed
  42817. -     only in floating point registers.  This is not true.  Any
  42818. -     registers that can hold integers can safely *hold* a floating
  42819. -     point machine mode, whether or not floating arithmetic can be done
  42820. -     on it in those registers.  Integer move instructions can be used
  42821. -     to move the values.
  42822. -
  42823. -     On some machines, though, the converse is true: fixed-point machine
  42824. -     modes may not go in floating registers.  This is true if the
  42825. -     floating registers normalize any value stored in them, because
  42826. -     storing a non-floating value there would garble it.  In this case,
  42827. -     `HARD_REGNO_MODE_OK' should reject fixed-point machine modes in
  42828. -     floating registers.  But if the floating registers do not
  42829. -     automatically normalize, if you can store any bit pattern in one
  42830. -     and retrieve it unchanged without a trap, then any machine mode
  42831. -     may go in a floating register, so you can define this macro to say
  42832. -     so.
  42833. -
  42834. -     The primary significance of special floating registers is rather
  42835. -     that they are the registers acceptable in floating point arithmetic
  42836. -     instructions.  However, this is of no concern to
  42837. -     `HARD_REGNO_MODE_OK'.  You handle it by writing the proper
  42838. -     constraints for those instructions.
  42839. -
  42840. -     On some machines, the floating registers are especially slow to
  42841. -     access, so that it is better to store a value in a stack frame
  42842. -     than in such a register if floating point arithmetic is not being
  42843. -     done.  As long as the floating registers are not in class
  42844. -     `GENERAL_REGS', they will not be used unless some pattern's
  42845. -     constraint asks for one.
  42846. -
  42847. -`MODES_TIEABLE_P (MODE1, MODE2)'
  42848. -     A C expression that is nonzero if it is desirable to choose
  42849. -     register allocation so as to avoid move instructions between a
  42850. -     value of mode MODE1 and a value of mode MODE2.
  42851. -
  42852. -     If `HARD_REGNO_MODE_OK (R, MODE1)' and `HARD_REGNO_MODE_OK (R,
  42853. -     MODE2)' are ever different for any R, then `MODES_TIEABLE_P (MODE1,
  42854. -     MODE2)' must be zero.
  42855. -
  42856. diff -rup --new-file baseline/fsf/gcc/gcc.info-2 amiga/fsf/gcc/gcc.info-2
  42857. --- baseline/fsf/gcc/gcc.info-2    Sat Jun 29 09:37:56 1996
  42858. +++ amiga/fsf/gcc/gcc.info-2    Wed Dec 31 17:00:00 1969
  42859. @@ -1,904 +0,0 @@
  42860. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  42861. -file gcc.texi.
  42862. -
  42863. -   This file documents the use and the internals of the GNU compiler.
  42864. -
  42865. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  42866. -Boston, MA 02111-1307 USA
  42867. -
  42868. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  42869. -Foundation, Inc.
  42870. -
  42871. -   Permission is granted to make and distribute verbatim copies of this
  42872. -manual provided the copyright notice and this permission notice are
  42873. -preserved on all copies.
  42874. -
  42875. -   Permission is granted to copy and distribute modified versions of
  42876. -this manual under the conditions for verbatim copying, provided also
  42877. -that the sections entitled "GNU General Public License," "Funding for
  42878. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  42879. -included exactly as in the original, and provided that the entire
  42880. -resulting derived work is distributed under the terms of a permission
  42881. -notice identical to this one.
  42882. -
  42883. -   Permission is granted to copy and distribute translations of this
  42884. -manual into another language, under the above conditions for modified
  42885. -versions, except that the sections entitled "GNU General Public
  42886. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  42887. -`Look And Feel'", and this permission notice, may be included in
  42888. -translations approved by the Free Software Foundation instead of in the
  42889. -original English.
  42890. -
  42891. -
  42892. -File: gcc.info,  Node: Option Summary,  Next: Overall Options,  Up: Invoking GCC
  42893. -
  42894. -Option Summary
  42895. -==============
  42896. -
  42897. -   Here is a summary of all the options, grouped by type.  Explanations
  42898. -are in the following sections.
  42899. -
  42900. -*Overall Options*
  42901. -     *Note Options Controlling the Kind of Output: Overall Options.
  42902. -          -c  -S  -E  -o FILE  -pipe  -v  -x LANGUAGE
  42903. -
  42904. -*C Language Options*
  42905. -     *Note Options Controlling C Dialect: C Dialect Options.
  42906. -          -ansi  -fallow-single-precision -fcond-mismatch  -fno-asm
  42907. -          -fno-builtin  -fsigned-bitfields  -fsigned-char
  42908. -          -funsigned-bitfields  -funsigned-char  -fwritable-strings
  42909. -          -traditional  -traditional-cpp  -trigraphs
  42910. -
  42911. -*C++ Language Options*
  42912. -     *Note Options Controlling C++ Dialect: C++ Dialect Options.
  42913. -          -fall-virtual  -fdollars-in-identifiers  -felide-constructors
  42914. -          -fenum-int-equiv -fexternal-templates  -ffor-scope -fno-for-scope
  42915. -          -fhandle-signatures -fmemoize-lookups  -fno-default-inline -fno-gnu-keywords
  42916. -          -fnonnull-objects  -foperator-names  -fstrict-prototype
  42917. -          -fthis-is-variable -nostdinc++ -traditional  +eN
  42918. -
  42919. -*Warning Options*
  42920. -     *Note Options to Request or Suppress Warnings: Warning Options.
  42921. -          -fsyntax-only  -pedantic  -pedantic-errors
  42922. -          -w  -W  -Wall  -Waggregate-return  -Wbad-function-cast
  42923. -          -Wcast-align -Wcast-qual  -Wchar-subscript  -Wcomment
  42924. -          -Wconversion -Wenum-clash  -Werror  -Wformat
  42925. -          -Wid-clash-LEN  -Wimplicit  -Wimport  -Winline
  42926. -          -Wlarger-than-LEN  -Wmissing-declarations
  42927. -          -Wmissing-prototypes  -Wnested-externs
  42928. -          -Wno-import  -Woverloaded-virtual -Wparentheses
  42929. -          -Wpointer-arith  -Wredundant-decls -Wreorder -Wreturn-type -Wshadow
  42930. -          -Wstrict-prototypes  -Wswitch  -Wsynth  -Wtemplate-debugging
  42931. -          -Wtraditional  -Wtrigraphs -Wuninitialized  -Wunused
  42932. -          -Wwrite-strings
  42933. -
  42934. -*Debugging Options*
  42935. -     *Note Options for Debugging Your Program or GCC: Debugging Options.
  42936. -          -a  -dLETTERS  -fpretend-float
  42937. -          -g  -gLEVEL -gcoff  -gdwarf  -gdwarf+
  42938. -          -ggdb  -gstabs  -gstabs+  -gxcoff  -gxcoff+
  42939. -          -p  -pg  -print-file-name=LIBRARY  -print-libgcc-file-name
  42940. -          -print-prog-name=PROGRAM  -print-search-dirs  -save-temps
  42941. -
  42942. -*Optimization Options*
  42943. -     *Note Options that Control Optimization: Optimize Options.
  42944. -          -fcaller-saves  -fcse-follow-jumps  -fcse-skip-blocks
  42945. -          -fdelayed-branch   -fexpensive-optimizations
  42946. -          -ffast-math  -ffloat-store  -fforce-addr  -fforce-mem
  42947. -          -finline-functions  -fkeep-inline-functions
  42948. -          -fno-default-inline  -fno-defer-pop  -fno-function-cse
  42949. -          -fno-inline  -fno-peephole  -fomit-frame-pointer
  42950. -          -frerun-cse-after-loop  -fschedule-insns
  42951. -          -fschedule-insns2  -fstrength-reduce  -fthread-jumps
  42952. -          -funroll-all-loops  -funroll-loops
  42953. -          -O  -O0  -O1  -O2  -O3
  42954. -
  42955. -*Preprocessor Options*
  42956. -     *Note Options Controlling the Preprocessor: Preprocessor Options.
  42957. -          -AQUESTION(ANSWER)  -C  -dD  -dM  -dN
  42958. -          -DMACRO[=DEFN]  -E  -H
  42959. -          -idirafter DIR
  42960. -          -include FILE  -imacros FILE
  42961. -          -iprefix FILE  -iwithprefix DIR
  42962. -          -iwithprefixbefore DIR  -isystem DIR
  42963. -          -M  -MD  -MM  -MMD  -MG  -nostdinc  -P  -trigraphs
  42964. -          -undef  -UMACRO  -Wp,OPTION
  42965. -
  42966. -*Assembler Option*
  42967. -     *Note Passing Options to the Assembler: Assembler Options.
  42968. -          -Wa,OPTION
  42969. -
  42970. -*Linker Options*
  42971. -     *Note Options for Linking: Link Options.
  42972. -          OBJECT-FILE-NAME  -lLIBRARY
  42973. -          -nostartfiles  -nodefaultlibs  -nostdlib
  42974. -          -s  -static  -shared  -symbolic
  42975. -          -Wl,OPTION  -Xlinker OPTION
  42976. -          -u SYMBOL
  42977. -
  42978. -*Directory Options*
  42979. -     *Note Options for Directory Search: Directory Options.
  42980. -          -BPREFIX  -IDIR  -I-  -LDIR
  42981. -
  42982. -*Target Options*
  42983. -     *Note Target Options::.
  42984. -          -b MACHINE  -V VERSION
  42985. -
  42986. -*Machine Dependent Options*
  42987. -     *Note Hardware Models and Configurations: Submodel Options.
  42988. -          *M680x0 Options*
  42989. -          -m68000  -m68020  -m68020-40  -m68030  -m68040  -m68881
  42990. -          -mbitfield  -mc68000  -mc68020  -mfpa  -mnobitfield
  42991. -          -mrtd  -mshort  -msoft-float
  42992. -          
  42993. -          *VAX Options*
  42994. -          -mg  -mgnu  -munix
  42995. -          
  42996. -          *SPARC Options*
  42997. -          -mapp-regs  -mcypress  -mepilogue  -mflat  -mfpu  -mhard-float
  42998. -          -mhard-quad-float  -mno-app-regs  -mno-flat  -mno-fpu
  42999. -          -mno-epilogue  -mno-unaligned-doubles
  43000. -          -msoft-float  -msoft-quad-float
  43001. -          -msparclite  -msupersparc  -munaligned-doubles  -mv8
  43002. -          
  43003. -          SPARC V9 compilers support the following options
  43004. -          in addition to the above:
  43005. -          
  43006. -          -mmedlow  -mmedany
  43007. -          -mint32  -mint64  -mlong32  -mlong64
  43008. -          -mno-stack-bias  -mstack-bias
  43009. -          
  43010. -          *Convex Options*
  43011. -          -mc1  -mc2  -mc32  -mc34  -mc38
  43012. -          -margcount  -mnoargcount
  43013. -          -mlong32  -mlong64
  43014. -          -mvolatile-cache  -mvolatile-nocache
  43015. -          
  43016. -          *AMD29K Options*
  43017. -          -m29000  -m29050  -mbw  -mnbw  -mdw  -mndw
  43018. -          -mlarge  -mnormal  -msmall
  43019. -          -mkernel-registers  -mno-reuse-arg-regs
  43020. -          -mno-stack-check  -mno-storem-bug
  43021. -          -mreuse-arg-regs  -msoft-float  -mstack-check
  43022. -          -mstorem-bug  -muser-registers
  43023. -          
  43024. -          *ARM Options*
  43025. -          -mapcs -m2 -m3 -m6 -mbsd -mxopen -mno-symrename
  43026. -          
  43027. -          *M88K Options*
  43028. -          -m88000  -m88100  -m88110  -mbig-pic
  43029. -          -mcheck-zero-division  -mhandle-large-shift
  43030. -          -midentify-revision  -mno-check-zero-division
  43031. -          -mno-ocs-debug-info  -mno-ocs-frame-position
  43032. -          -mno-optimize-arg-area  -mno-serialize-volatile
  43033. -          -mno-underscores  -mocs-debug-info
  43034. -          -mocs-frame-position  -moptimize-arg-area
  43035. -          -mserialize-volatile  -mshort-data-NUM  -msvr3
  43036. -          -msvr4  -mtrap-large-shift  -muse-div-instruction
  43037. -          -mversion-03.00  -mwarn-passed-structs
  43038. -          
  43039. -          *RS/6000 and PowerPC Options*
  43040. -          -mcpu=CPU  TYPE
  43041. -          -mpower  -mno-power  -mpower2  -mno-power2
  43042. -          -mpowerpc  -mno-powerpc
  43043. -          -mpowerpc-gpopt  -mno-powerpc-gpopt
  43044. -          -mpowerpc-gfxopt  -mno-powerpc-gfxopt
  43045. -          -mnew-mnemonics  -mno-new-mnemonics
  43046. -          -mfull-toc   -mminimal-toc  -mno-fop-in-toc  -mno-sum-in-toc
  43047. -          -msoft-float  -mhard-float -mmultiple -mno-multiple
  43048. -          -mstring -mno-string -mbit-align -mno-bit-align
  43049. -          -mstrict-align -mno-strict-align -mrelocatable -mno-relocatable
  43050. -          -mtoc -mno-toc -mtraceback -mno-traceback
  43051. -          -mlittle -mlittle-endian -mbig -mbig-endian
  43052. -          -mcall-aix -mcall-sysv -mprototype
  43053. -          
  43054. -          *RT Options*
  43055. -          -mcall-lib-mul  -mfp-arg-in-fpregs  -mfp-arg-in-gregs
  43056. -          -mfull-fp-blocks  -mhc-struct-return  -min-line-mul
  43057. -          -mminimum-fp-blocks  -mnohc-struct-return
  43058. -          
  43059. -          *MIPS Options*
  43060. -          -mabicalls  -mcpu=CPU  TYPE  -membedded-data
  43061. -          -membedded-pic  -mfp32  -mfp64  -mgas  -mgp32  -mgp64
  43062. -          -mgpopt  -mhalf-pic  -mhard-float  -mint64 -mips1
  43063. -          -mips2 -mips3  -mlong64  -mlong-calls  -mmemcpy
  43064. -          -mmips-as  -mmips-tfile  -mno-abicalls
  43065. -          -mno-embedded-data  -mno-embedded-pic
  43066. -          -mno-gpopt  -mno-long-calls
  43067. -          -mno-memcpy  -mno-mips-tfile  -mno-rnames  -mno-stats
  43068. -          -mrnames -msoft-float
  43069. -          -m4650 -msingle-float -mmad
  43070. -          -mstats  -EL  -EB  -G NUM  -nocpp
  43071. -          
  43072. -          *i386 Options*
  43073. -          -m486  -m386 -mieee-fp  -mno-fancy-math-387
  43074. -          -mno-fp-ret-in-387  -msoft-float  -msvr3-shlib
  43075. -          -mno-wide-multiply -mrtd -malign-double
  43076. -          -mreg-alloc=LIST -mregparm=NUM
  43077. -          -malign-jumps=NUM -malign-loops=NUM
  43078. -          -malign-functions=NUM
  43079. -          
  43080. -          *HPPA Options*
  43081. -          -mdisable-fpregs  -mdisable-indexing  -mfast-indirect-calls
  43082. -          -mgas  -mjump-in-delay -mlong-millicode-calls -mno-disable-fpregs
  43083. -          -mno-disable-indexing -mno-fast-indirect-calls -mno-gas
  43084. -          -mno-jump-in-delay -mno-millicode-long-calls
  43085. -          -mno-portable-runtime -mno-soft-float -msoft-float
  43086. -          -mpa-risc-1-0  -mpa-risc-1-1  -mportable-runtime -mschedule=LIST
  43087. -          
  43088. -          *Intel 960 Options*
  43089. -          -mCPU TYPE  -masm-compat  -mclean-linkage
  43090. -          -mcode-align  -mcomplex-addr  -mleaf-procedures
  43091. -          -mic-compat  -mic2.0-compat  -mic3.0-compat
  43092. -          -mintel-asm  -mno-clean-linkage  -mno-code-align
  43093. -          -mno-complex-addr  -mno-leaf-procedures
  43094. -          -mno-old-align  -mno-strict-align  -mno-tail-call
  43095. -          -mnumerics  -mold-align  -msoft-float  -mstrict-align
  43096. -          -mtail-call
  43097. -          
  43098. -          *DEC Alpha Options*
  43099. -          -mfp-regs  -mno-fp-regs  -mno-soft-float
  43100. -          -msoft-float
  43101. -          
  43102. -          *Clipper Options*
  43103. -          -mc300 -mc400
  43104. -          
  43105. -          *H8/300 Options*
  43106. -          -mrelax  -mh
  43107. -          
  43108. -          *System V Options*
  43109. -          -Qy  -Qn  -YP,PATHS  -Ym,DIR
  43110. -
  43111. -*Code Generation Options*
  43112. -     *Note Options for Code Generation Conventions: Code Gen Options.
  43113. -          -fcall-saved-REG  -fcall-used-REG
  43114. -          -ffixed-REG  -finhibit-size-directive
  43115. -          -fno-common  -fno-ident  -fno-gnu-linker
  43116. -          -fpcc-struct-return  -fpic  -fPIC
  43117. -          -freg-struct-return  -fshared-data  -fshort-enums
  43118. -          -fshort-double  -fvolatile  -fvolatile-global
  43119. -          -fverbose-asm -fpack-struct +e0  +e1
  43120. -
  43121. -* Menu:
  43122. -
  43123. -* Overall Options::     Controlling the kind of output:
  43124. -                        an executable, object files, assembler files,
  43125. -                        or preprocessed source.
  43126. -* C Dialect Options::   Controlling the variant of C language compiled.
  43127. -* C++ Dialect Options:: Variations on C++.
  43128. -* Warning Options::     How picky should the compiler be?
  43129. -* Debugging Options::   Symbol tables, measurements, and debugging dumps.
  43130. -* Optimize Options::    How much optimization?
  43131. -* Preprocessor Options:: Controlling header files and macro definitions.
  43132. -                         Also, getting dependency information for Make.
  43133. -* Assembler Options::   Passing options to the assembler.
  43134. -* Link Options::        Specifying libraries and so on.
  43135. -* Directory Options::   Where to find header files and libraries.
  43136. -                        Where to find the compiler executable files.
  43137. -* Target Options::      Running a cross-compiler, or an old version of GNU CC.
  43138. -
  43139. -
  43140. -File: gcc.info,  Node: Overall Options,  Next: Invoking G++,  Prev: Option Summary,  Up: Invoking GCC
  43141. -
  43142. -Options Controlling the Kind of Output
  43143. -======================================
  43144. -
  43145. -   Compilation can involve up to four stages: preprocessing, compilation
  43146. -proper, assembly and linking, always in that order.  The first three
  43147. -stages apply to an individual source file, and end by producing an
  43148. -object file; linking combines all the object files (those newly
  43149. -compiled, and those specified as input) into an executable file.
  43150. -
  43151. -   For any given input file, the file name suffix determines what kind
  43152. -of compilation is done:
  43153. -
  43154. -`FILE.c'
  43155. -     C source code which must be preprocessed.
  43156. -
  43157. -`FILE.i'
  43158. -     C source code which should not be preprocessed.
  43159. -
  43160. -`FILE.ii'
  43161. -     C++ source code which should not be preprocessed.
  43162. -
  43163. -`FILE.m'
  43164. -     Objective-C source code.  Note that you must link with the library
  43165. -     `libobjc.a' to make an Objective-C program work.
  43166. -
  43167. -`FILE.h'
  43168. -     C header file (not to be compiled or linked).
  43169. -
  43170. -`FILE.cc'
  43171. -`FILE.cxx'
  43172. -`FILE.cpp'
  43173. -`FILE.C'
  43174. -     C++ source code which must be preprocessed.  Note that in `.cxx',
  43175. -     the last two letters must both be literally `x'.  Likewise, `.C'
  43176. -     refers to a literal capital C.
  43177. -
  43178. -`FILE.s'
  43179. -     Assembler code.
  43180. -
  43181. -`FILE.S'
  43182. -     Assembler code which must be preprocessed.
  43183. -
  43184. -`OTHER'
  43185. -     An object file to be fed straight into linking.  Any file name
  43186. -     with no recognized suffix is treated this way.
  43187. -
  43188. -   You can specify the input language explicitly with the `-x' option:
  43189. -
  43190. -`-x LANGUAGE'
  43191. -     Specify explicitly the LANGUAGE for the following input files
  43192. -     (rather than letting the compiler choose a default based on the
  43193. -     file name suffix).  This option applies to all following input
  43194. -     files until the next `-x' option.  Possible values for LANGUAGE
  43195. -     are:
  43196. -          c  objective-c  c++
  43197. -          c-header  cpp-output  c++-cpp-output
  43198. -          assembler  assembler-with-cpp
  43199. -
  43200. -`-x none'
  43201. -     Turn off any specification of a language, so that subsequent files
  43202. -     are handled according to their file name suffixes (as they are if
  43203. -     `-x' has not been used at all).
  43204. -
  43205. -   If you only want some of the stages of compilation, you can use `-x'
  43206. -(or filename suffixes) to tell `gcc' where to start, and one of the
  43207. -options `-c', `-S', or `-E' to say where `gcc' is to stop.  Note that
  43208. -some combinations (for example, `-x cpp-output -E' instruct `gcc' to do
  43209. -nothing at all.
  43210. -
  43211. -`-c'
  43212. -     Compile or assemble the source files, but do not link.  The linking
  43213. -     stage simply is not done.  The ultimate output is in the form of an
  43214. -     object file for each source file.
  43215. -
  43216. -     By default, the object file name for a source file is made by
  43217. -     replacing the suffix `.c', `.i', `.s', etc., with `.o'.
  43218. -
  43219. -     Unrecognized input files, not requiring compilation or assembly,
  43220. -     are ignored.
  43221. -
  43222. -`-S'
  43223. -     Stop after the stage of compilation proper; do not assemble.  The
  43224. -     output is in the form of an assembler code file for each
  43225. -     non-assembler input file specified.
  43226. -
  43227. -     By default, the assembler file name for a source file is made by
  43228. -     replacing the suffix `.c', `.i', etc., with `.s'.
  43229. -
  43230. -     Input files that don't require compilation are ignored.
  43231. -
  43232. -`-E'
  43233. -     Stop after the preprocessing stage; do not run the compiler
  43234. -     proper.  The output is in the form of preprocessed source code,
  43235. -     which is sent to the standard output.
  43236. -
  43237. -     Input files which don't require preprocessing are ignored.
  43238. -
  43239. -`-o FILE'
  43240. -     Place output in file FILE.  This applies regardless to whatever
  43241. -     sort of output is being produced, whether it be an executable file,
  43242. -     an object file, an assembler file or preprocessed C code.
  43243. -
  43244. -     Since only one output file can be specified, it does not make
  43245. -     sense to use `-o' when compiling more than one input file, unless
  43246. -     you are producing an executable file as output.
  43247. -
  43248. -     If `-o' is not specified, the default is to put an executable file
  43249. -     in `a.out', the object file for `SOURCE.SUFFIX' in `SOURCE.o', its
  43250. -     assembler file in `SOURCE.s', and all preprocessed C source on
  43251. -     standard output.
  43252. -
  43253. -`-v'
  43254. -     Print (on standard error output) the commands executed to run the
  43255. -     stages of compilation.  Also print the version number of the
  43256. -     compiler driver program and of the preprocessor and the compiler
  43257. -     proper.
  43258. -
  43259. -`-pipe'
  43260. -     Use pipes rather than temporary files for communication between the
  43261. -     various stages of compilation.  This fails to work on some systems
  43262. -     where the assembler is unable to read from a pipe; but the GNU
  43263. -     assembler has no trouble.
  43264. -
  43265. -
  43266. -File: gcc.info,  Node: Invoking G++,  Next: C Dialect Options,  Prev: Overall Options,  Up: Invoking GCC
  43267. -
  43268. -Compiling C++ Programs
  43269. -======================
  43270. -
  43271. -   C++ source files conventionally use one of the suffixes `.C', `.cc',
  43272. -`cpp', or `.cxx'; preprocessed C++ files use the suffix `.ii'.  GNU CC
  43273. -recognizes files with these names and compiles them as C++ programs
  43274. -even if you call the compiler the same way as for compiling C programs
  43275. -(usually with the name `gcc').
  43276. -
  43277. -   However, C++ programs often require class libraries as well as a
  43278. -compiler that understands the C++ language--and under some
  43279. -circumstances, you might want to compile programs from standard input,
  43280. -or otherwise without a suffix that flags them as C++ programs.  `g++'
  43281. -is a program that calls GNU CC with the default language set to C++,
  43282. -and automatically specifies linking against the GNU class library
  43283. -libg++.  (1) On many systems, the script `g++' is also installed with
  43284. -the name `c++'.
  43285. -
  43286. -   When you compile C++ programs, you may specify many of the same
  43287. -command-line options that you use for compiling programs in any
  43288. -language; or command-line options meaningful for C and related
  43289. -languages; or options that are meaningful only for C++ programs.  *Note
  43290. -Options Controlling C Dialect: C Dialect Options, for explanations of
  43291. -options for languages related to C.  *Note Options Controlling C++
  43292. -Dialect: C++ Dialect Options, for explanations of options that are
  43293. -meaningful only for C++ programs.
  43294. -
  43295. -   ---------- Footnotes ----------
  43296. -
  43297. -   (1)  Prior to release 2 of the compiler, there was a separate `g++'
  43298. -compiler.  That version was based on GNU CC, but not integrated with
  43299. -it.  Versions of `g++' with a `1.XX' version number--for example, `g++'
  43300. -version 1.37 or 1.42--are much less reliable than the versions
  43301. -integrated with GCC 2.  Moreover, combining G++ `1.XX' with a version 2
  43302. -GCC will simply not work.
  43303. -
  43304. -
  43305. -File: gcc.info,  Node: C Dialect Options,  Next: C++ Dialect Options,  Prev: Invoking G++,  Up: Invoking GCC
  43306. -
  43307. -Options Controlling C Dialect
  43308. -=============================
  43309. -
  43310. -   The following options control the dialect of C (or languages derived
  43311. -from C, such as C++ and Objective C) that the compiler accepts:
  43312. -
  43313. -`-ansi'
  43314. -     Support all ANSI standard C programs.
  43315. -
  43316. -     This turns off certain features of GNU C that are incompatible
  43317. -     with ANSI C, such as the `asm', `inline' and `typeof' keywords, and
  43318. -     predefined macros such as `unix' and `vax' that identify the type
  43319. -     of system you are using.  It also enables the undesirable and
  43320. -     rarely used ANSI trigraph feature, disallows `$' as part of
  43321. -     identifiers, and disables recognition of C++ style `//' comments.
  43322. -
  43323. -     The alternate keywords `__asm__', `__extension__', `__inline__'
  43324. -     and `__typeof__' continue to work despite `-ansi'.  You would not
  43325. -     want to use them in an ANSI C program, of course, but it is useful
  43326. -     to put them in header files that might be included in compilations
  43327. -     done with `-ansi'.  Alternate predefined macros such as `__unix__'
  43328. -     and `__vax__' are also available, with or without `-ansi'.
  43329. -
  43330. -     The `-ansi' option does not cause non-ANSI programs to be rejected
  43331. -     gratuitously.  For that, `-pedantic' is required in addition to
  43332. -     `-ansi'.  *Note Warning Options::.
  43333. -
  43334. -     The macro `__STRICT_ANSI__' is predefined when the `-ansi' option
  43335. -     is used.  Some header files may notice this macro and refrain from
  43336. -     declaring certain functions or defining certain macros that the
  43337. -     ANSI standard doesn't call for; this is to avoid interfering with
  43338. -     any programs that might use these names for other things.
  43339. -
  43340. -     The functions `alloca', `abort', `exit', and `_exit' are not
  43341. -     builtin functions when `-ansi' is used.
  43342. -
  43343. -`-fno-asm'
  43344. -     Do not recognize `asm', `inline' or `typeof' as a keyword, so that
  43345. -     code can use these words as identifiers.  You can use the keywords
  43346. -     `__asm__', `__inline__' and `__typeof__' instead.  `-ansi' implies
  43347. -     `-fno-asm'.
  43348. -
  43349. -     In C++, this switch only affects the `typeof' keyword, since `asm'
  43350. -     and `inline' are standard keywords.  You may want to use the
  43351. -     `-fno-gnu-keywords' flag instead, as it also disables the other,
  43352. -     C++-specific, extension keywords such as `headof'.
  43353. -
  43354. -`-fno-builtin'
  43355. -     Don't recognize builtin functions that do not begin with two
  43356. -     leading underscores.  Currently, the functions affected include
  43357. -     `abort', `abs', `alloca', `cos', `exit', `fabs', `ffs', `labs',
  43358. -     `memcmp', `memcpy', `sin', `sqrt', `strcmp', `strcpy', and
  43359. -     `strlen'.
  43360. -
  43361. -     GCC normally generates special code to handle certain builtin
  43362. -     functions more efficiently; for instance, calls to `alloca' may
  43363. -     become single instructions that adjust the stack directly, and
  43364. -     calls to `memcpy' may become inline copy loops.  The resulting
  43365. -     code is often both smaller and faster, but since the function
  43366. -     calls no longer appear as such, you cannot set a breakpoint on
  43367. -     those calls, nor can you change the behavior of the functions by
  43368. -     linking with a different library.
  43369. -
  43370. -     The `-ansi' option prevents `alloca' and `ffs' from being builtin
  43371. -     functions, since these functions do not have an ANSI standard
  43372. -     meaning.
  43373. -
  43374. -`-trigraphs'
  43375. -     Support ANSI C trigraphs.  You don't want to know about this
  43376. -     brain-damage.  The `-ansi' option implies `-trigraphs'.
  43377. -
  43378. -`-traditional'
  43379. -     Attempt to support some aspects of traditional C compilers.
  43380. -     Specifically:
  43381. -
  43382. -        * All `extern' declarations take effect globally even if they
  43383. -          are written inside of a function definition.  This includes
  43384. -          implicit declarations of functions.
  43385. -
  43386. -        * The newer keywords `typeof', `inline', `signed', `const' and
  43387. -          `volatile' are not recognized.  (You can still use the
  43388. -          alternative keywords such as `__typeof__', `__inline__', and
  43389. -          so on.)
  43390. -
  43391. -        * Comparisons between pointers and integers are always allowed.
  43392. -
  43393. -        * Integer types `unsigned short' and `unsigned char' promote to
  43394. -          `unsigned int'.
  43395. -
  43396. -        * Out-of-range floating point literals are not an error.
  43397. -
  43398. -        * Certain constructs which ANSI regards as a single invalid
  43399. -          preprocessing number, such as `0xe-0xd', are treated as
  43400. -          expressions instead.
  43401. -
  43402. -        * String "constants" are not necessarily constant; they are
  43403. -          stored in writable space, and identical looking constants are
  43404. -          allocated separately.  (This is the same as the effect of
  43405. -          `-fwritable-strings'.)
  43406. -
  43407. -        * All automatic variables not declared `register' are preserved
  43408. -          by `longjmp'.  Ordinarily, GNU C follows ANSI C: automatic
  43409. -          variables not declared `volatile' may be clobbered.
  43410. -
  43411. -        * The character escape sequences `\x' and `\a' evaluate as the
  43412. -          literal characters `x' and `a' respectively.  Without
  43413. -          `-traditional', `\x' is a prefix for the hexadecimal
  43414. -          representation of a character, and `\a' produces a bell.
  43415. -
  43416. -        * In C++ programs, assignment to `this' is permitted with
  43417. -          `-traditional'.  (The option `-fthis-is-variable' also has
  43418. -          this effect.)
  43419. -
  43420. -     You may wish to use `-fno-builtin' as well as `-traditional' if
  43421. -     your program uses names that are normally GNU C builtin functions
  43422. -     for other purposes of its own.
  43423. -
  43424. -     You cannot use `-traditional' if you include any header files that
  43425. -     rely on ANSI C features.  Some vendors are starting to ship
  43426. -     systems with ANSI C header files and you cannot use `-traditional'
  43427. -     on such systems to compile files that include any system headers.
  43428. -
  43429. -`'
  43430. -     In the preprocessor, comments convert to nothing at all, rather
  43431. -     than to a space.  This allows traditional token concatenation.
  43432. -
  43433. -`'
  43434. -     In preprocessing directive, the `#' symbol must appear as the first
  43435. -     character of a line.
  43436. -
  43437. -`'
  43438. -     In the preprocessor, macro arguments are recognized within string
  43439. -     constants in a macro definition (and their values are stringified,
  43440. -     though without additional quote marks, when they appear in such a
  43441. -     context).  The preprocessor always considers a string constant to
  43442. -     end at a newline.
  43443. -
  43444. -`'
  43445. -     The predefined macro `__STDC__' is not defined when you use
  43446. -     `-traditional', but `__GNUC__' is (since the GNU extensions which
  43447. -     `__GNUC__' indicates are not affected by `-traditional').  If you
  43448. -     need to write header files that work differently depending on
  43449. -     whether `-traditional' is in use, by testing both of these
  43450. -     predefined macros you can distinguish four situations: GNU C,
  43451. -     traditional GNU C, other ANSI C compilers, and other old C
  43452. -     compilers.  The predefined macro `__STDC_VERSION__' is also not
  43453. -     defined when you use `-traditional'.  *Note Standard Predefined
  43454. -     Macros: (cpp.info)Standard Predefined, for more discussion of
  43455. -     these and other predefined macros.
  43456. -
  43457. -`'
  43458. -     The preprocessor considers a string constant to end at a newline
  43459. -     (unless the newline is escaped with `\').  (Without `-traditional',
  43460. -     string constants can contain the newline character as typed.)
  43461. -
  43462. -`-traditional-cpp'
  43463. -     Attempt to support some aspects of traditional C preprocessors.
  43464. -     This includes the last five items in the table immediately above,
  43465. -     but none of the other effects of `-traditional'.
  43466. -
  43467. -`-fcond-mismatch'
  43468. -     Allow conditional expressions with mismatched types in the second
  43469. -     and third arguments.  The value of such an expression is void.
  43470. -
  43471. -`-funsigned-char'
  43472. -     Let the type `char' be unsigned, like `unsigned char'.
  43473. -
  43474. -     Each kind of machine has a default for what `char' should be.  It
  43475. -     is either like `unsigned char' by default or like `signed char' by
  43476. -     default.
  43477. -
  43478. -     Ideally, a portable program should always use `signed char' or
  43479. -     `unsigned char' when it depends on the signedness of an object.
  43480. -     But many programs have been written to use plain `char' and expect
  43481. -     it to be signed, or expect it to be unsigned, depending on the
  43482. -     machines they were written for.  This option, and its inverse, let
  43483. -     you make such a program work with the opposite default.
  43484. -
  43485. -     The type `char' is always a distinct type from each of `signed
  43486. -     char' or `unsigned char', even though its behavior is always just
  43487. -     like one of those two.
  43488. -
  43489. -`-fsigned-char'
  43490. -     Let the type `char' be signed, like `signed char'.
  43491. -
  43492. -     Note that this is equivalent to `-fno-unsigned-char', which is the
  43493. -     negative form of `-funsigned-char'.  Likewise, the option
  43494. -     `-fno-signed-char' is equivalent to `-funsigned-char'.
  43495. -
  43496. -`-fsigned-bitfields'
  43497. -`-funsigned-bitfields'
  43498. -`-fno-signed-bitfields'
  43499. -`-fno-unsigned-bitfields'
  43500. -     These options control whether a bitfield is signed or unsigned,
  43501. -     when the declaration does not use either `signed' or `unsigned'.
  43502. -     By default, such a bitfield is signed, because this is consistent:
  43503. -     the basic integer types such as `int' are signed types.
  43504. -
  43505. -     However, when `-traditional' is used, bitfields are all unsigned
  43506. -     no matter what.
  43507. -
  43508. -`-fwritable-strings'
  43509. -     Store string constants in the writable data segment and don't
  43510. -     uniquize them.  This is for compatibility with old programs which
  43511. -     assume they can write into string constants.  The option
  43512. -     `-traditional' also has this effect.
  43513. -
  43514. -     Writing into string constants is a very bad idea; "constants"
  43515. -     should be constant.
  43516. -
  43517. -`-fallow-single-precision'
  43518. -     Do not promote single precision math operations to double
  43519. -     precision, even when compiling with `-traditional'.
  43520. -
  43521. -     Traditional K&R C promotes all floating point operations to double
  43522. -     precision, regardless of the sizes of the operands.   On the
  43523. -     architecture for which you are compiling, single precision may be
  43524. -     faster than double precision.   If you must use `-traditional',
  43525. -     but want to use single precision operations when the operands are
  43526. -     single precision, use this option.   This option has no effect
  43527. -     when compiling with ANSI or GNU C conventions (the default).
  43528. -
  43529. -
  43530. -File: gcc.info,  Node: C++ Dialect Options,  Next: Warning Options,  Prev: C Dialect Options,  Up: Invoking GCC
  43531. -
  43532. -Options Controlling C++ Dialect
  43533. -===============================
  43534. -
  43535. -   This section describes the command-line options that are only
  43536. -meaningful for C++ programs; but you can also use most of the GNU
  43537. -compiler options regardless of what language your program is in.  For
  43538. -example, you might compile a file `firstClass.C' like this:
  43539. -
  43540. -     g++ -g -felide-constructors -O -c firstClass.C
  43541. -
  43542. -In this example, only `-felide-constructors' is an option meant only
  43543. -for C++ programs; you can use the other options with any language
  43544. -supported by GNU CC.
  43545. -
  43546. -   Here is a list of options that are *only* for compiling C++ programs:
  43547. -
  43548. -`-fno-access-control'
  43549. -     Turn off all access checking.  This switch is mainly useful for
  43550. -     working around bugs in the access control code.
  43551. -
  43552. -`-fall-virtual'
  43553. -     Treat all possible member functions as virtual, implicitly.  All
  43554. -     member functions (except for constructor functions and `new' or
  43555. -     `delete' member operators) are treated as virtual functions of the
  43556. -     class where they appear.
  43557. -
  43558. -     This does not mean that all calls to these member functions will
  43559. -     be made through the internal table of virtual functions.  Under
  43560. -     some circumstances, the compiler can determine that a call to a
  43561. -     given virtual function can be made directly; in these cases the
  43562. -     calls are direct in any case.
  43563. -
  43564. -`-fcheck-new'
  43565. -     Check that the pointer returned by `operator new' is non-null
  43566. -     before attempting to modify the storage allocated.  The current
  43567. -     Working Paper requires that `operator new' never return a null
  43568. -     pointer, so this check is normally unnecessary.
  43569. -
  43570. -`-fconserve-space'
  43571. -     Put uninitialized or runtime-initialized global variables into the
  43572. -     common segment, as C does.  This saves space in the executable at
  43573. -     the cost of not diagnosing duplicate definitions.  If you compile
  43574. -     with this flag and your program mysteriously crashes after
  43575. -     `main()' has completed, you may have an object that is being
  43576. -     destroyed twice because two definitions were merged.
  43577. -
  43578. -`-fdollars-in-identifiers'
  43579. -     Accept `$' in identifiers.  You can also explicitly prohibit use of
  43580. -     `$' with the option `-fno-dollars-in-identifiers'.  (GNU C++
  43581. -     allows `$' by default on some target systems but not others.)
  43582. -     Traditional C allowed the character `$' to form part of
  43583. -     identifiers.  However, ANSI C and C++ forbid `$' in identifiers.
  43584. -
  43585. -`-fenum-int-equiv'
  43586. -     Anachronistically permit implicit conversion of `int' to
  43587. -     enumeration types.  Current C++ allows conversion of `enum' to
  43588. -     `int', but not the other way around.
  43589. -
  43590. -`-fexternal-templates'
  43591. -     Cause template instantiations to obey `#pragma interface' and
  43592. -     `implementation'; template instances are emitted or not according
  43593. -     to the location of the template definition.  *Note Template
  43594. -     Instantiation::, for more information.
  43595. -
  43596. -`-falt-external-templates'
  43597. -     Similar to -fexternal-templates, but template instances are
  43598. -     emitted or not according to the place where they are first
  43599. -     instantiated.  *Note Template Instantiation::, for more
  43600. -     information.
  43601. -
  43602. -`-ffor-scope'
  43603. -`-fno-for-scope'
  43604. -     If -ffor-scope is specified, the scope of variables declared in a
  43605. -     for-init-statement is limited to the `for' loop itself, as
  43606. -     specified by the draft C++ standard.  If -fno-for-scope is
  43607. -     specified, the scope of variables declared in a for-init-statement
  43608. -     extends to the end of the enclosing scope, as was the case in old
  43609. -     versions of gcc, and other (traditional) implementations of C++.
  43610. -
  43611. -     The default if neither flag is given to follow the standard, but
  43612. -     to allow and give a warning for old-style code that would
  43613. -     otherwise be invalid, or have different behavior.
  43614. -
  43615. -`-fno-gnu-keywords'
  43616. -     Do not recognize `classof', `headof', `signature', `sigof' or
  43617. -     `typeof' as a keyword, so that code can use these words as
  43618. -     identifiers.  You can use the keywords `__classof__',
  43619. -     `__headof__', `__signature__', `__sigof__', and `__typeof__'
  43620. -     instead.  `-ansi' implies `-fno-gnu-keywords'.
  43621. -
  43622. -`-fno-implicit-templates'
  43623. -     Never emit code for templates which are instantiated implicitly
  43624. -     (i.e. by use); only emit code for explicit instantiations.  *Note
  43625. -     Template Instantiation::, for more information.
  43626. -
  43627. -`-fhandle-signatures'
  43628. -     Recognize the `signature' and `sigof' keywords for specifying
  43629. -     abstract types.  The default (`-fno-handle-signatures') is not to
  43630. -     recognize them.  *Note Type Abstraction using Signatures: C++
  43631. -     Signatures.
  43632. -
  43633. -`-fhuge-objects'
  43634. -     Support virtual function calls for objects that exceed the size
  43635. -     representable by a `short int'.  Users should not use this flag by
  43636. -     default; if you need to use it, the compiler will tell you so.  If
  43637. -     you compile any of your code with this flag, you must compile
  43638. -     *all* of your code with this flag (including libg++, if you use
  43639. -     it).
  43640. -
  43641. -     This flag is not useful when compiling with -fvtable-thunks.
  43642. -
  43643. -`-fno-implement-inlines'
  43644. -     To save space, do not emit out-of-line copies of inline functions
  43645. -     controlled by `#pragma implementation'.  This will cause linker
  43646. -     errors if these functions are not inlined everywhere they are
  43647. -     called.
  43648. -
  43649. -`-fmemoize-lookups'
  43650. -`-fsave-memoized'
  43651. -     Use heuristics to compile faster.  These heuristics are not
  43652. -     enabled by default, since they are only effective for certain
  43653. -     input files.  Other input files compile more slowly.
  43654. -
  43655. -     The first time the compiler must build a call to a member function
  43656. -     (or reference to a data member), it must (1) determine whether the
  43657. -     class implements member functions of that name; (2) resolve which
  43658. -     member function to call (which involves figuring out what sorts of
  43659. -     type conversions need to be made); and (3) check the visibility of
  43660. -     the member function to the caller.  All of this adds up to slower
  43661. -     compilation.  Normally, the second time a call is made to that
  43662. -     member function (or reference to that data member), it must go
  43663. -     through the same lengthy process again.  This means that code like
  43664. -     this:
  43665. -
  43666. -          cout << "This " << p << " has " << n << " legs.\n";
  43667. -
  43668. -     makes six passes through all three steps.  By using a software
  43669. -     cache, a "hit" significantly reduces this cost.  Unfortunately,
  43670. -     using the cache introduces another layer of mechanisms which must
  43671. -     be implemented, and so incurs its own overhead.
  43672. -     `-fmemoize-lookups' enables the software cache.
  43673. -
  43674. -     Because access privileges (visibility) to members and member
  43675. -     functions may differ from one function context to the next, G++
  43676. -     may need to flush the cache.  With the `-fmemoize-lookups' flag,
  43677. -     the cache is flushed after every function that is compiled.  The
  43678. -     `-fsave-memoized' flag enables the same software cache, but when
  43679. -     the compiler determines that the context of the last function
  43680. -     compiled would yield the same access privileges of the next
  43681. -     function to compile, it preserves the cache.  This is most helpful
  43682. -     when defining many member functions for the same class: with the
  43683. -     exception of member functions which are friends of other classes,
  43684. -     each member function has exactly the same access privileges as
  43685. -     every other, and the cache need not be flushed.
  43686. -
  43687. -     The code that implements these flags has rotted; you should
  43688. -     probably avoid using them.
  43689. -
  43690. -`-fstrict-prototype'
  43691. -     Within an `extern "C"' linkage specification, treat a function
  43692. -     declaration with no arguments, such as `int foo ();', as declaring
  43693. -     the function to take no arguments.  Normally, such a declaration
  43694. -     means that the function `foo' can take any combination of
  43695. -     arguments, as in C.  `-pedantic' implies `-fstrict-prototype'
  43696. -     unless overridden with `-fno-strict-prototype'.
  43697. -
  43698. -     This flag no longer affects declarations with C++ linkage.
  43699. -
  43700. -`-fno-nonnull-objects'
  43701. -     Don't assume that a reference is initialized to refer to a valid
  43702. -     object.  Although the current C++ Working Paper prohibits null
  43703. -     references, some old code may rely on them, and you can use
  43704. -     `-fno-nonnull-objects' to turn on checking.
  43705. -
  43706. -     At the moment, the compiler only does this checking for
  43707. -     conversions to virtual base classes.
  43708. -
  43709. -`-foperator-names'
  43710. -     Recognize the operator name keywords `and', `bitand', `bitor',
  43711. -     `compl', `not', `or' and `xor' as synonyms for the symbols they
  43712. -     refer to.  `-ansi' implies `-foperator-names'.
  43713. -
  43714. -`-fthis-is-variable'
  43715. -     Permit assignment to `this'.  The incorporation of user-defined
  43716. -     free store management into C++ has made assignment to `this' an
  43717. -     anachronism.  Therefore, by default it is invalid to assign to
  43718. -     `this' within a class member function; that is, GNU C++ treats
  43719. -     `this' in a member function of class `X' as a non-lvalue of type
  43720. -     `X *'.  However, for backwards compatibility, you can make it
  43721. -     valid with `-fthis-is-variable'.
  43722. -
  43723. -`-fvtable-thunks'
  43724. -     Use `thunks' to implement the virtual function dispatch table
  43725. -     (`vtable').  The traditional (cfront-style) approach to
  43726. -     implementing vtables was to store a pointer to the function and two
  43727. -     offsets for adjusting the `this' pointer at the call site.  Newer
  43728. -     implementations store a single pointer to a `thunk' function which
  43729. -     does any necessary adjustment and then calls the target function.
  43730. -
  43731. -     This option also enables a heuristic for controlling emission of
  43732. -     vtables; if a class has any non-inline virtual functions, the
  43733. -     vtable will be emitted in the translation unit containing the
  43734. -     first one of those.
  43735. -
  43736. -`-nostdinc++'
  43737. -     Do not search for header files in the standard directories
  43738. -     specific to C++, but do still search the other standard
  43739. -     directories.  (This option is used when building libg++.)
  43740. -
  43741. -`-traditional'
  43742. -     For C++ programs (in addition to the effects that apply to both C
  43743. -     and C++), this has the same effect as `-fthis-is-variable'.  *Note
  43744. -     Options Controlling C Dialect: C Dialect Options.
  43745. -
  43746. -   In addition, these optimization, warning, and code generation options
  43747. -have meanings only for C++ programs:
  43748. -
  43749. -`-fno-default-inline'
  43750. -     Do not assume `inline' for functions defined inside a class scope.
  43751. -     *Note Options That Control Optimization: Optimize Options.
  43752. -
  43753. -`-Wenum-clash'
  43754. -`-Woverloaded-virtual'
  43755. -`-Wtemplate-debugging'
  43756. -     Warnings that apply only to C++ programs.  *Note Options to
  43757. -     Request or Suppress Warnings: Warning Options.
  43758. -
  43759. -`+eN'
  43760. -     Control how virtual function definitions are used, in a fashion
  43761. -     compatible with `cfront' 1.x.  *Note Options for Code Generation
  43762. -     Conventions: Code Gen Options.
  43763. -
  43764. diff -rup --new-file baseline/fsf/gcc/gcc.info-20 amiga/fsf/gcc/gcc.info-20
  43765. --- baseline/fsf/gcc/gcc.info-20    Sat Jun 29 09:38:07 1996
  43766. +++ amiga/fsf/gcc/gcc.info-20    Wed Dec 31 17:00:00 1969
  43767. @@ -1,981 +0,0 @@
  43768. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  43769. -file gcc.texi.
  43770. -
  43771. -   This file documents the use and the internals of the GNU compiler.
  43772. -
  43773. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  43774. -Boston, MA 02111-1307 USA
  43775. -
  43776. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  43777. -Foundation, Inc.
  43778. -
  43779. -   Permission is granted to make and distribute verbatim copies of this
  43780. -manual provided the copyright notice and this permission notice are
  43781. -preserved on all copies.
  43782. -
  43783. -   Permission is granted to copy and distribute modified versions of
  43784. -this manual under the conditions for verbatim copying, provided also
  43785. -that the sections entitled "GNU General Public License," "Funding for
  43786. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  43787. -included exactly as in the original, and provided that the entire
  43788. -resulting derived work is distributed under the terms of a permission
  43789. -notice identical to this one.
  43790. -
  43791. -   Permission is granted to copy and distribute translations of this
  43792. -manual into another language, under the above conditions for modified
  43793. -versions, except that the sections entitled "GNU General Public
  43794. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  43795. -`Look And Feel'", and this permission notice, may be included in
  43796. -translations approved by the Free Software Foundation instead of in the
  43797. -original English.
  43798. -
  43799. -
  43800. -File: gcc.info,  Node: Leaf Functions,  Next: Stack Registers,  Prev: Values in Registers,  Up: Registers
  43801. -
  43802. -Handling Leaf Functions
  43803. ------------------------
  43804. -
  43805. -   On some machines, a leaf function (i.e., one which makes no calls)
  43806. -can run more efficiently if it does not make its own register window.
  43807. -Often this means it is required to receive its arguments in the
  43808. -registers where they are passed by the caller, instead of the registers
  43809. -where they would normally arrive.
  43810. -
  43811. -   The special treatment for leaf functions generally applies only when
  43812. -other conditions are met; for example, often they may use only those
  43813. -registers for its own variables and temporaries.  We use the term "leaf
  43814. -function" to mean a function that is suitable for this special
  43815. -handling, so that functions with no calls are not necessarily "leaf
  43816. -functions".
  43817. -
  43818. -   GNU CC assigns register numbers before it knows whether the function
  43819. -is suitable for leaf function treatment.  So it needs to renumber the
  43820. -registers in order to output a leaf function.  The following macros
  43821. -accomplish this.
  43822. -
  43823. -`LEAF_REGISTERS'
  43824. -     A C initializer for a vector, indexed by hard register number,
  43825. -     which contains 1 for a register that is allowable in a candidate
  43826. -     for leaf function treatment.
  43827. -
  43828. -     If leaf function treatment involves renumbering the registers,
  43829. -     then the registers marked here should be the ones before
  43830. -     renumbering--those that GNU CC would ordinarily allocate.  The
  43831. -     registers which will actually be used in the assembler code, after
  43832. -     renumbering, should not be marked with 1 in this vector.
  43833. -
  43834. -     Define this macro only if the target machine offers a way to
  43835. -     optimize the treatment of leaf functions.
  43836. -
  43837. -`LEAF_REG_REMAP (REGNO)'
  43838. -     A C expression whose value is the register number to which REGNO
  43839. -     should be renumbered, when a function is treated as a leaf
  43840. -     function.
  43841. -
  43842. -     If REGNO is a register number which should not appear in a leaf
  43843. -     function before renumbering, then the expression should yield -1,
  43844. -     which will cause the compiler to abort.
  43845. -
  43846. -     Define this macro only if the target machine offers a way to
  43847. -     optimize the treatment of leaf functions, and registers need to be
  43848. -     renumbered to do this.
  43849. -
  43850. -   Normally, `FUNCTION_PROLOGUE' and `FUNCTION_EPILOGUE' must treat
  43851. -leaf functions specially.  It can test the C variable `leaf_function'
  43852. -which is nonzero for leaf functions.  (The variable `leaf_function' is
  43853. -defined only if `LEAF_REGISTERS' is defined.)
  43854. -
  43855. -
  43856. -File: gcc.info,  Node: Stack Registers,  Next: Obsolete Register Macros,  Prev: Leaf Functions,  Up: Registers
  43857. -
  43858. -Registers That Form a Stack
  43859. ----------------------------
  43860. -
  43861. -   There are special features to handle computers where some of the
  43862. -"registers" form a stack, as in the 80387 coprocessor for the 80386.
  43863. -Stack registers are normally written by pushing onto the stack, and are
  43864. -numbered relative to the top of the stack.
  43865. -
  43866. -   Currently, GNU CC can only handle one group of stack-like registers,
  43867. -and they must be consecutively numbered.
  43868. -
  43869. -`STACK_REGS'
  43870. -     Define this if the machine has any stack-like registers.
  43871. -
  43872. -`FIRST_STACK_REG'
  43873. -     The number of the first stack-like register.  This one is the top
  43874. -     of the stack.
  43875. -
  43876. -`LAST_STACK_REG'
  43877. -     The number of the last stack-like register.  This one is the
  43878. -     bottom of the stack.
  43879. -
  43880. -
  43881. -File: gcc.info,  Node: Obsolete Register Macros,  Prev: Stack Registers,  Up: Registers
  43882. -
  43883. -Obsolete Macros for Controlling Register Usage
  43884. -----------------------------------------------
  43885. -
  43886. -   These features do not work very well.  They exist because they used
  43887. -to be required to generate correct code for the 80387 coprocessor of the
  43888. -80386.  They are no longer used by that machine description and may be
  43889. -removed in a later version of the compiler.  Don't use them!
  43890. -
  43891. -`OVERLAPPING_REGNO_P (REGNO)'
  43892. -     If defined, this is a C expression whose value is nonzero if hard
  43893. -     register number REGNO is an overlapping register.  This means a
  43894. -     hard register which overlaps a hard register with a different
  43895. -     number.  (Such overlap is undesirable, but occasionally it allows
  43896. -     a machine to be supported which otherwise could not be.)  This
  43897. -     macro must return nonzero for *all* the registers which overlap
  43898. -     each other.  GNU CC can use an overlapping register only in
  43899. -     certain limited ways.  It can be used for allocation within a
  43900. -     basic block, and may be spilled for reloading; that is all.
  43901. -
  43902. -     If this macro is not defined, it means that none of the hard
  43903. -     registers overlap each other.  This is the usual situation.
  43904. -
  43905. -`INSN_CLOBBERS_REGNO_P (INSN, REGNO)'
  43906. -     If defined, this is a C expression whose value should be nonzero if
  43907. -     the insn INSN has the effect of mysteriously clobbering the
  43908. -     contents of hard register number REGNO.  By "mysterious" we mean
  43909. -     that the insn's RTL expression doesn't describe such an effect.
  43910. -
  43911. -     If this macro is not defined, it means that no insn clobbers
  43912. -     registers mysteriously.  This is the usual situation; all else
  43913. -     being equal, it is best for the RTL expression to show all the
  43914. -     activity.
  43915. -
  43916. -`PRESERVE_DEATH_INFO_REGNO_P (REGNO)'
  43917. -     If defined, this is a C expression whose value is nonzero if
  43918. -     accurate `REG_DEAD' notes are needed for hard register number REGNO
  43919. -     at the time of outputting the assembler code.  When this is so, a
  43920. -     few optimizations that take place after register allocation and
  43921. -     could invalidate the death notes are not done when this register is
  43922. -     involved.
  43923. -
  43924. -     You would arrange to preserve death info for a register when some
  43925. -     of the code in the machine description which is executed to write
  43926. -     the assembler code looks at the death notes.  This is necessary
  43927. -     only when the actual hardware feature which GNU CC thinks of as a
  43928. -     register is not actually a register of the usual sort.  (It might,
  43929. -     for example, be a hardware stack.)
  43930. -
  43931. -     If this macro is not defined, it means that no death notes need to
  43932. -     be preserved.  This is the usual situation.
  43933. -
  43934. -
  43935. -File: gcc.info,  Node: Register Classes,  Next: Stack and Calling,  Prev: Registers,  Up: Target Macros
  43936. -
  43937. -Register Classes
  43938. -================
  43939. -
  43940. -   On many machines, the numbered registers are not all equivalent.
  43941. -For example, certain registers may not be allowed for indexed
  43942. -addressing; certain registers may not be allowed in some instructions.
  43943. -These machine restrictions are described to the compiler using
  43944. -"register classes".
  43945. -
  43946. -   You define a number of register classes, giving each one a name and
  43947. -saying which of the registers belong to it.  Then you can specify
  43948. -register classes that are allowed as operands to particular instruction
  43949. -patterns.
  43950. -
  43951. -   In general, each register will belong to several classes.  In fact,
  43952. -one class must be named `ALL_REGS' and contain all the registers.
  43953. -Another class must be named `NO_REGS' and contain no registers.  Often
  43954. -the union of two classes will be another class; however, this is not
  43955. -required.
  43956. -
  43957. -   One of the classes must be named `GENERAL_REGS'.  There is nothing
  43958. -terribly special about the name, but the operand constraint letters `r'
  43959. -and `g' specify this class.  If `GENERAL_REGS' is the same as
  43960. -`ALL_REGS', just define it as a macro which expands to `ALL_REGS'.
  43961. -
  43962. -   Order the classes so that if class X is contained in class Y then X
  43963. -has a lower class number than Y.
  43964. -
  43965. -   The way classes other than `GENERAL_REGS' are specified in operand
  43966. -constraints is through machine-dependent operand constraint letters.
  43967. -You can define such letters to correspond to various classes, then use
  43968. -them in operand constraints.
  43969. -
  43970. -   You should define a class for the union of two classes whenever some
  43971. -instruction allows both classes.  For example, if an instruction allows
  43972. -either a floating point (coprocessor) register or a general register
  43973. -for a certain operand, you should define a class `FLOAT_OR_GENERAL_REGS'
  43974. -which includes both of them.  Otherwise you will get suboptimal code.
  43975. -
  43976. -   You must also specify certain redundant information about the
  43977. -register classes: for each class, which classes contain it and which
  43978. -ones are contained in it; for each pair of classes, the largest class
  43979. -contained in their union.
  43980. -
  43981. -   When a value occupying several consecutive registers is expected in a
  43982. -certain class, all the registers used must belong to that class.
  43983. -Therefore, register classes cannot be used to enforce a requirement for
  43984. -a register pair to start with an even-numbered register.  The way to
  43985. -specify this requirement is with `HARD_REGNO_MODE_OK'.
  43986. -
  43987. -   Register classes used for input-operands of bitwise-and or shift
  43988. -instructions have a special requirement: each such class must have, for
  43989. -each fixed-point machine mode, a subclass whose registers can transfer
  43990. -that mode to or from memory.  For example, on some machines, the
  43991. -operations for single-byte values (`QImode') are limited to certain
  43992. -registers.  When this is so, each register class that is used in a
  43993. -bitwise-and or shift instruction must have a subclass consisting of
  43994. -registers from which single-byte values can be loaded or stored.  This
  43995. -is so that `PREFERRED_RELOAD_CLASS' can always have a possible value to
  43996. -return.
  43997. -
  43998. -`enum reg_class'
  43999. -     An enumeral type that must be defined with all the register class
  44000. -     names as enumeral values.  `NO_REGS' must be first.  `ALL_REGS'
  44001. -     must be the last register class, followed by one more enumeral
  44002. -     value, `LIM_REG_CLASSES', which is not a register class but rather
  44003. -     tells how many classes there are.
  44004. -
  44005. -     Each register class has a number, which is the value of casting
  44006. -     the class name to type `int'.  The number serves as an index in
  44007. -     many of the tables described below.
  44008. -
  44009. -`N_REG_CLASSES'
  44010. -     The number of distinct register classes, defined as follows:
  44011. -
  44012. -          #define N_REG_CLASSES (int) LIM_REG_CLASSES
  44013. -
  44014. -`REG_CLASS_NAMES'
  44015. -     An initializer containing the names of the register classes as C
  44016. -     string constants.  These names are used in writing some of the
  44017. -     debugging dumps.
  44018. -
  44019. -`REG_CLASS_CONTENTS'
  44020. -     An initializer containing the contents of the register classes, as
  44021. -     integers which are bit masks.  The Nth integer specifies the
  44022. -     contents of class N.  The way the integer MASK is interpreted is
  44023. -     that register R is in the class if `MASK & (1 << R)' is 1.
  44024. -
  44025. -     When the machine has more than 32 registers, an integer does not
  44026. -     suffice.  Then the integers are replaced by sub-initializers,
  44027. -     braced groupings containing several integers.  Each
  44028. -     sub-initializer must be suitable as an initializer for the type
  44029. -     `HARD_REG_SET' which is defined in `hard-reg-set.h'.
  44030. -
  44031. -`REGNO_REG_CLASS (REGNO)'
  44032. -     A C expression whose value is a register class containing hard
  44033. -     register REGNO.  In general there is more than one such class;
  44034. -     choose a class which is "minimal", meaning that no smaller class
  44035. -     also contains the register.
  44036. -
  44037. -`BASE_REG_CLASS'
  44038. -     A macro whose definition is the name of the class to which a valid
  44039. -     base register must belong.  A base register is one used in an
  44040. -     address which is the register value plus a displacement.
  44041. -
  44042. -`INDEX_REG_CLASS'
  44043. -     A macro whose definition is the name of the class to which a valid
  44044. -     index register must belong.  An index register is one used in an
  44045. -     address where its value is either multiplied by a scale factor or
  44046. -     added to another register (as well as added to a displacement).
  44047. -
  44048. -`REG_CLASS_FROM_LETTER (CHAR)'
  44049. -     A C expression which defines the machine-dependent operand
  44050. -     constraint letters for register classes.  If CHAR is such a
  44051. -     letter, the value should be the register class corresponding to
  44052. -     it.  Otherwise, the value should be `NO_REGS'.  The register
  44053. -     letter `r', corresponding to class `GENERAL_REGS', will not be
  44054. -     passed to this macro; you do not need to handle it.
  44055. -
  44056. -`REGNO_OK_FOR_BASE_P (NUM)'
  44057. -     A C expression which is nonzero if register number NUM is suitable
  44058. -     for use as a base register in operand addresses.  It may be either
  44059. -     a suitable hard register or a pseudo register that has been
  44060. -     allocated such a hard register.
  44061. -
  44062. -`REGNO_OK_FOR_INDEX_P (NUM)'
  44063. -     A C expression which is nonzero if register number NUM is suitable
  44064. -     for use as an index register in operand addresses.  It may be
  44065. -     either a suitable hard register or a pseudo register that has been
  44066. -     allocated such a hard register.
  44067. -
  44068. -     The difference between an index register and a base register is
  44069. -     that the index register may be scaled.  If an address involves the
  44070. -     sum of two registers, neither one of them scaled, then either one
  44071. -     may be labeled the "base" and the other the "index"; but whichever
  44072. -     labeling is used must fit the machine's constraints of which
  44073. -     registers may serve in each capacity.  The compiler will try both
  44074. -     labelings, looking for one that is valid, and will reload one or
  44075. -     both registers only if neither labeling works.
  44076. -
  44077. -`PREFERRED_RELOAD_CLASS (X, CLASS)'
  44078. -     A C expression that places additional restrictions on the register
  44079. -     class to use when it is necessary to copy value X into a register
  44080. -     in class CLASS.  The value is a register class; perhaps CLASS, or
  44081. -     perhaps another, smaller class.  On many machines, the following
  44082. -     definition is safe:
  44083. -
  44084. -          #define PREFERRED_RELOAD_CLASS(X,CLASS) CLASS
  44085. -
  44086. -     Sometimes returning a more restrictive class makes better code.
  44087. -     For example, on the 68000, when X is an integer constant that is
  44088. -     in range for a `moveq' instruction, the value of this macro is
  44089. -     always `DATA_REGS' as long as CLASS includes the data registers.
  44090. -     Requiring a data register guarantees that a `moveq' will be used.
  44091. -
  44092. -     If X is a `const_double', by returning `NO_REGS' you can force X
  44093. -     into a memory constant.  This is useful on certain machines where
  44094. -     immediate floating values cannot be loaded into certain kinds of
  44095. -     registers.
  44096. -
  44097. -`PREFERRED_OUTPUT_RELOAD_CLASS (X, CLASS)'
  44098. -     Like `PREFERRED_RELOAD_CLASS', but for output reloads instead of
  44099. -     input reloads.  If you don't define this macro, the default is to
  44100. -     use CLASS, unchanged.
  44101. -
  44102. -`LIMIT_RELOAD_CLASS (MODE, CLASS)'
  44103. -     A C expression that places additional restrictions on the register
  44104. -     class to use when it is necessary to be able to hold a value of
  44105. -     mode MODE in a reload register for which class CLASS would
  44106. -     ordinarily be used.
  44107. -
  44108. -     Unlike `PREFERRED_RELOAD_CLASS', this macro should be used when
  44109. -     there are certain modes that simply can't go in certain reload
  44110. -     classes.
  44111. -
  44112. -     The value is a register class; perhaps CLASS, or perhaps another,
  44113. -     smaller class.
  44114. -
  44115. -     Don't define this macro unless the target machine has limitations
  44116. -     which require the macro to do something nontrivial.
  44117. -
  44118. -`SECONDARY_RELOAD_CLASS (CLASS, MODE, X)'
  44119. -`SECONDARY_INPUT_RELOAD_CLASS (CLASS, MODE, X)'
  44120. -`SECONDARY_OUTPUT_RELOAD_CLASS (CLASS, MODE, X)'
  44121. -     Many machines have some registers that cannot be copied directly
  44122. -     to or from memory or even from other types of registers.  An
  44123. -     example is the `MQ' register, which on most machines, can only be
  44124. -     copied to or from general registers, but not memory.  Some
  44125. -     machines allow copying all registers to and from memory, but
  44126. -     require a scratch register for stores to some memory locations
  44127. -     (e.g., those with symbolic address on the RT, and those with
  44128. -     certain symbolic address on the Sparc when compiling PIC).  In
  44129. -     some cases, both an intermediate and a scratch register are
  44130. -     required.
  44131. -
  44132. -     You should define these macros to indicate to the reload phase
  44133. -     that it may need to allocate at least one register for a reload in
  44134. -     addition to the register to contain the data.  Specifically, if
  44135. -     copying X to a register CLASS in MODE requires an intermediate
  44136. -     register, you should define `SECONDARY_INPUT_RELOAD_CLASS' to
  44137. -     return the largest register class all of whose registers can be
  44138. -     used as intermediate registers or scratch registers.
  44139. -
  44140. -     If copying a register CLASS in MODE to X requires an intermediate
  44141. -     or scratch register, `SECONDARY_OUTPUT_RELOAD_CLASS' should be
  44142. -     defined to return the largest register class required.  If the
  44143. -     requirements for input and output reloads are the same, the macro
  44144. -     `SECONDARY_RELOAD_CLASS' should be used instead of defining both
  44145. -     macros identically.
  44146. -
  44147. -     The values returned by these macros are often `GENERAL_REGS'.
  44148. -     Return `NO_REGS' if no spare register is needed; i.e., if X can be
  44149. -     directly copied to or from a register of CLASS in MODE without
  44150. -     requiring a scratch register.  Do not define this macro if it
  44151. -     would always return `NO_REGS'.
  44152. -
  44153. -     If a scratch register is required (either with or without an
  44154. -     intermediate register), you should define patterns for
  44155. -     `reload_inM' or `reload_outM', as required (*note Standard
  44156. -     Names::..  These patterns, which will normally be implemented with
  44157. -     a `define_expand', should be similar to the `movM' patterns,
  44158. -     except that operand 2 is the scratch register.
  44159. -
  44160. -     Define constraints for the reload register and scratch register
  44161. -     that contain a single register class.  If the original reload
  44162. -     register (whose class is CLASS) can meet the constraint given in
  44163. -     the pattern, the value returned by these macros is used for the
  44164. -     class of the scratch register.  Otherwise, two additional reload
  44165. -     registers are required.  Their classes are obtained from the
  44166. -     constraints in the insn pattern.
  44167. -
  44168. -     X might be a pseudo-register or a `subreg' of a pseudo-register,
  44169. -     which could either be in a hard register or in memory.  Use
  44170. -     `true_regnum' to find out; it will return -1 if the pseudo is in
  44171. -     memory and the hard register number if it is in a register.
  44172. -
  44173. -     These macros should not be used in the case where a particular
  44174. -     class of registers can only be copied to memory and not to another
  44175. -     class of registers.  In that case, secondary reload registers are
  44176. -     not needed and would not be helpful.  Instead, a stack location
  44177. -     must be used to perform the copy and the `movM' pattern should use
  44178. -     memory as a intermediate storage.  This case often occurs between
  44179. -     floating-point and general registers.
  44180. -
  44181. -`SECONDARY_MEMORY_NEEDED (CLASS1, CLASS2, M)'
  44182. -     Certain machines have the property that some registers cannot be
  44183. -     copied to some other registers without using memory.  Define this
  44184. -     macro on those machines to be a C expression that is non-zero if
  44185. -     objects of mode M in registers of CLASS1 can only be copied to
  44186. -     registers of class CLASS2 by storing a register of CLASS1 into
  44187. -     memory and loading that memory location into a register of CLASS2.
  44188. -
  44189. -     Do not define this macro if its value would always be zero.
  44190. -
  44191. -`SECONDARY_MEMORY_NEEDED_RTX (MODE)'
  44192. -     Normally when `SECONDARY_MEMORY_NEEDED' is defined, the compiler
  44193. -     allocates a stack slot for a memory location needed for register
  44194. -     copies.  If this macro is defined, the compiler instead uses the
  44195. -     memory location defined by this macro.
  44196. -
  44197. -     Do not define this macro if you do not define
  44198. -     `SECONDARY_MEMORY_NEEDED'.
  44199. -
  44200. -`SECONDARY_MEMORY_NEEDED_MODE (MODE)'
  44201. -     When the compiler needs a secondary memory location to copy
  44202. -     between two registers of mode MODE, it normally allocates
  44203. -     sufficient memory to hold a quantity of `BITS_PER_WORD' bits and
  44204. -     performs the store and load operations in a mode that many bits
  44205. -     wide and whose class is the same as that of MODE.
  44206. -
  44207. -     This is right thing to do on most machines because it ensures that
  44208. -     all bits of the register are copied and prevents accesses to the
  44209. -     registers in a narrower mode, which some machines prohibit for
  44210. -     floating-point registers.
  44211. -
  44212. -     However, this default behavior is not correct on some machines,
  44213. -     such as the DEC Alpha, that store short integers in floating-point
  44214. -     registers differently than in integer registers.  On those
  44215. -     machines, the default widening will not work correctly and you
  44216. -     must define this macro to suppress that widening in some cases.
  44217. -     See the file `alpha.h' for details.
  44218. -
  44219. -     Do not define this macro if you do not define
  44220. -     `SECONDARY_MEMORY_NEEDED' or if widening MODE to a mode that is
  44221. -     `BITS_PER_WORD' bits wide is correct for your machine.
  44222. -
  44223. -`SMALL_REGISTER_CLASSES'
  44224. -     Normally the compiler avoids choosing registers that have been
  44225. -     explicitly mentioned in the rtl as spill registers (these
  44226. -     registers are normally those used to pass parameters and return
  44227. -     values).  However, some machines have so few registers of certain
  44228. -     classes that there would not be enough registers to use as spill
  44229. -     registers if this were done.
  44230. -
  44231. -     Define `SMALL_REGISTER_CLASSES' on these machines.  When it is
  44232. -     defined, the compiler allows registers explicitly used in the rtl
  44233. -     to be used as spill registers but avoids extending the lifetime of
  44234. -     these registers.
  44235. -
  44236. -     It is always safe to define this macro, but if you unnecessarily
  44237. -     define it, you will reduce the amount of optimizations that can be
  44238. -     performed in some cases.  If you do not define this macro when it
  44239. -     is required, the compiler will run out of spill registers and
  44240. -     print a fatal error message.  For most machines, you should not
  44241. -     define this macro.
  44242. -
  44243. -`CLASS_LIKELY_SPILLED_P (CLASS)'
  44244. -     A C expression whose value is nonzero if pseudos that have been
  44245. -     assigned to registers of class CLASS would likely be spilled
  44246. -     because registers of CLASS are needed for spill registers.
  44247. -
  44248. -     The default value of this macro returns 1 if CLASS has exactly one
  44249. -     register and zero otherwise.  On most machines, this default
  44250. -     should be used.  Only define this macro to some other expression
  44251. -     if pseudo allocated by `local-alloc.c' end up in memory because
  44252. -     their hard registers were needed for spill registers.  If this
  44253. -     macro returns nonzero for those classes, those pseudos will only
  44254. -     be allocated by `global.c', which knows how to reallocate the
  44255. -     pseudo to another register.  If there would not be another
  44256. -     register available for reallocation, you should not change the
  44257. -     definition of this macro since the only effect of such a
  44258. -     definition would be to slow down register allocation.
  44259. -
  44260. -`CLASS_MAX_NREGS (CLASS, MODE)'
  44261. -     A C expression for the maximum number of consecutive registers of
  44262. -     class CLASS needed to hold a value of mode MODE.
  44263. -
  44264. -     This is closely related to the macro `HARD_REGNO_NREGS'.  In fact,
  44265. -     the value of the macro `CLASS_MAX_NREGS (CLASS, MODE)' should be
  44266. -     the maximum value of `HARD_REGNO_NREGS (REGNO, MODE)' for all
  44267. -     REGNO values in the class CLASS.
  44268. -
  44269. -     This macro helps control the handling of multiple-word values in
  44270. -     the reload pass.
  44271. -
  44272. -`CLASS_CANNOT_CHANGE_SIZE'
  44273. -     If defined, a C expression for a class that contains registers
  44274. -     which the compiler must always access in a mode that is the same
  44275. -     size as the mode in which it loaded the register.
  44276. -
  44277. -     For the example, loading 32-bit integer or floating-point objects
  44278. -     into floating-point registers on the Alpha extends them to 64-bits.
  44279. -     Therefore loading a 64-bit object and then storing it as a 32-bit
  44280. -     object does not store the low-order 32-bits, as would be the case
  44281. -     for a normal register.  Therefore, `alpha.h' defines this macro as
  44282. -     `FLOAT_REGS'.
  44283. -
  44284. -   Three other special macros describe which operands fit which
  44285. -constraint letters.
  44286. -
  44287. -`CONST_OK_FOR_LETTER_P (VALUE, C)'
  44288. -     A C expression that defines the machine-dependent operand
  44289. -     constraint letters that specify particular ranges of integer
  44290. -     values.  If C is one of those letters, the expression should check
  44291. -     that VALUE, an integer, is in the appropriate range and return 1
  44292. -     if so, 0 otherwise.  If C is not one of those letters, the value
  44293. -     should be 0 regardless of VALUE.
  44294. -
  44295. -`CONST_DOUBLE_OK_FOR_LETTER_P (VALUE, C)'
  44296. -     A C expression that defines the machine-dependent operand
  44297. -     constraint letters that specify particular ranges of
  44298. -     `const_double' values.
  44299. -
  44300. -     If C is one of those letters, the expression should check that
  44301. -     VALUE, an RTX of code `const_double', is in the appropriate range
  44302. -     and return 1 if so, 0 otherwise.  If C is not one of those
  44303. -     letters, the value should be 0 regardless of VALUE.
  44304. -
  44305. -     `const_double' is used for all floating-point constants and for
  44306. -     `DImode' fixed-point constants.  A given letter can accept either
  44307. -     or both kinds of values.  It can use `GET_MODE' to distinguish
  44308. -     between these kinds.
  44309. -
  44310. -`EXTRA_CONSTRAINT (VALUE, C)'
  44311. -     A C expression that defines the optional machine-dependent
  44312. -     constraint letters that can be used to segregate specific types of
  44313. -     operands, usually memory references, for the target machine.
  44314. -     Normally this macro will not be defined.  If it is required for a
  44315. -     particular target machine, it should return 1 if VALUE corresponds
  44316. -     to the operand type represented by the constraint letter C.  If C
  44317. -     is not defined as an extra constraint, the value returned should
  44318. -     be 0 regardless of VALUE.
  44319. -
  44320. -     For example, on the ROMP, load instructions cannot have their
  44321. -     output in r0 if the memory reference contains a symbolic address.
  44322. -     Constraint letter `Q' is defined as representing a memory address
  44323. -     that does *not* contain a symbolic address.  An alternative is
  44324. -     specified with a `Q' constraint on the input and `r' on the
  44325. -     output.  The next alternative specifies `m' on the input and a
  44326. -     register class that does not include r0 on the output.
  44327. -
  44328. -
  44329. -File: gcc.info,  Node: Stack and Calling,  Next: Varargs,  Prev: Register Classes,  Up: Target Macros
  44330. -
  44331. -Stack Layout and Calling Conventions
  44332. -====================================
  44333. -
  44334. -   This describes the stack layout and calling conventions.
  44335. -
  44336. -* Menu:
  44337. -
  44338. -* Frame Layout::
  44339. -* Frame Registers::
  44340. -* Elimination::
  44341. -* Stack Arguments::
  44342. -* Register Arguments::
  44343. -* Scalar Return::
  44344. -* Aggregate Return::
  44345. -* Caller Saves::
  44346. -* Function Entry::
  44347. -* Profiling::
  44348. -
  44349. -
  44350. -File: gcc.info,  Node: Frame Layout,  Next: Frame Registers,  Up: Stack and Calling
  44351. -
  44352. -Basic Stack Layout
  44353. -------------------
  44354. -
  44355. -   Here is the basic stack layout.
  44356. -
  44357. -`STACK_GROWS_DOWNWARD'
  44358. -     Define this macro if pushing a word onto the stack moves the stack
  44359. -     pointer to a smaller address.
  44360. -
  44361. -     When we say, "define this macro if ...," it means that the
  44362. -     compiler checks this macro only with `#ifdef' so the precise
  44363. -     definition used does not matter.
  44364. -
  44365. -`FRAME_GROWS_DOWNWARD'
  44366. -     Define this macro if the addresses of local variable slots are at
  44367. -     negative offsets from the frame pointer.
  44368. -
  44369. -`ARGS_GROW_DOWNWARD'
  44370. -     Define this macro if successive arguments to a function occupy
  44371. -     decreasing addresses on the stack.
  44372. -
  44373. -`STARTING_FRAME_OFFSET'
  44374. -     Offset from the frame pointer to the first local variable slot to
  44375. -     be allocated.
  44376. -
  44377. -     If `FRAME_GROWS_DOWNWARD', find the next slot's offset by
  44378. -     subtracting the first slot's length from `STARTING_FRAME_OFFSET'.
  44379. -     Otherwise, it is found by adding the length of the first slot to
  44380. -     the value `STARTING_FRAME_OFFSET'.
  44381. -
  44382. -`STACK_POINTER_OFFSET'
  44383. -     Offset from the stack pointer register to the first location at
  44384. -     which outgoing arguments are placed.  If not specified, the
  44385. -     default value of zero is used.  This is the proper value for most
  44386. -     machines.
  44387. -
  44388. -     If `ARGS_GROW_DOWNWARD', this is the offset to the location above
  44389. -     the first location at which outgoing arguments are placed.
  44390. -
  44391. -`FIRST_PARM_OFFSET (FUNDECL)'
  44392. -     Offset from the argument pointer register to the first argument's
  44393. -     address.  On some machines it may depend on the data type of the
  44394. -     function.
  44395. -
  44396. -     If `ARGS_GROW_DOWNWARD', this is the offset to the location above
  44397. -     the first argument's address.
  44398. -
  44399. -`STACK_DYNAMIC_OFFSET (FUNDECL)'
  44400. -     Offset from the stack pointer register to an item dynamically
  44401. -     allocated on the stack, e.g., by `alloca'.
  44402. -
  44403. -     The default value for this macro is `STACK_POINTER_OFFSET' plus the
  44404. -     length of the outgoing arguments.  The default is correct for most
  44405. -     machines.  See `function.c' for details.
  44406. -
  44407. -`DYNAMIC_CHAIN_ADDRESS (FRAMEADDR)'
  44408. -     A C expression whose value is RTL representing the address in a
  44409. -     stack frame where the pointer to the caller's frame is stored.
  44410. -     Assume that FRAMEADDR is an RTL expression for the address of the
  44411. -     stack frame itself.
  44412. -
  44413. -     If you don't define this macro, the default is to return the value
  44414. -     of FRAMEADDR--that is, the stack frame address is also the address
  44415. -     of the stack word that points to the previous frame.
  44416. -
  44417. -`SETUP_FRAME_ADDRESSES ()'
  44418. -     If defined, a C expression that produces the machine-specific code
  44419. -     to setup the stack so that arbitrary frames can be accessed.  For
  44420. -     example, on the Sparc, we must flush all of the register windows
  44421. -     to the stack before we can access arbitrary stack frames.  This
  44422. -     macro will seldom need to be defined.
  44423. -
  44424. -`RETURN_ADDR_RTX (COUNT, FRAMEADDR)'
  44425. -     A C expression whose value is RTL representing the value of the
  44426. -     return address for the frame COUNT steps up from the current frame.
  44427. -     fRAMEADDR is the frame pointer of the COUNT frame, or the frame
  44428. -     pointer of the COUNT - 1 frame if `RETURN_ADDR_IN_PREVIOUS_FRAME'
  44429. -     is defined.
  44430. -
  44431. -`RETURN_ADDR_IN_PREVIOUS_FRAME'
  44432. -     Define this if the return address of a particular stack frame is
  44433. -     accessed from the frame pointer of the previous stack frame.
  44434. -
  44435. -
  44436. -File: gcc.info,  Node: Frame Registers,  Next: Elimination,  Prev: Frame Layout,  Up: Stack and Calling
  44437. -
  44438. -Registers That Address the Stack Frame
  44439. ---------------------------------------
  44440. -
  44441. -   This discusses registers that address the stack frame.
  44442. -
  44443. -`STACK_POINTER_REGNUM'
  44444. -     The register number of the stack pointer register, which must also
  44445. -     be a fixed register according to `FIXED_REGISTERS'.  On most
  44446. -     machines, the hardware determines which register this is.
  44447. -
  44448. -`FRAME_POINTER_REGNUM'
  44449. -     The register number of the frame pointer register, which is used to
  44450. -     access automatic variables in the stack frame.  On some machines,
  44451. -     the hardware determines which register this is.  On other
  44452. -     machines, you can choose any register you wish for this purpose.
  44453. -
  44454. -`HARD_FRAME_POINTER_REGNUM'
  44455. -     On some machines the offset between the frame pointer and starting
  44456. -     offset of the automatic variables is not known until after register
  44457. -     allocation has been done (for example, because the saved registers
  44458. -     are between these two locations).  On those machines, define
  44459. -     `FRAME_POINTER_REGNUM' the number of a special, fixed register to
  44460. -     be used internally until the offset is known, and define
  44461. -     `HARD_FRAME_POINTER_REGNUM' to be actual the hard register number
  44462. -     used for the frame pointer.
  44463. -
  44464. -     You should define this macro only in the very rare circumstances
  44465. -     when it is not possible to calculate the offset between the frame
  44466. -     pointer and the automatic variables until after register
  44467. -     allocation has been completed.  When this macro is defined, you
  44468. -     must also indicate in your definition of `ELIMINABLE_REGS' how to
  44469. -     eliminate `FRAME_POINTER_REGNUM' into either
  44470. -     `HARD_FRAME_POINTER_REGNUM' or `STACK_POINTER_REGNUM'.
  44471. -
  44472. -     Do not define this macro if it would be the same as
  44473. -     `FRAME_POINTER_REGNUM'.
  44474. -
  44475. -`ARG_POINTER_REGNUM'
  44476. -     The register number of the arg pointer register, which is used to
  44477. -     access the function's argument list.  On some machines, this is
  44478. -     the same as the frame pointer register.  On some machines, the
  44479. -     hardware determines which register this is.  On other machines,
  44480. -     you can choose any register you wish for this purpose.  If this is
  44481. -     not the same register as the frame pointer register, then you must
  44482. -     mark it as a fixed register according to `FIXED_REGISTERS', or
  44483. -     arrange to be able to eliminate it (*note Elimination::.).
  44484. -
  44485. -`STATIC_CHAIN_REGNUM'
  44486. -`STATIC_CHAIN_INCOMING_REGNUM'
  44487. -     Register numbers used for passing a function's static chain
  44488. -     pointer.  If register windows are used, the register number as
  44489. -     seen by the called function is `STATIC_CHAIN_INCOMING_REGNUM',
  44490. -     while the register number as seen by the calling function is
  44491. -     `STATIC_CHAIN_REGNUM'.  If these registers are the same,
  44492. -     `STATIC_CHAIN_INCOMING_REGNUM' need not be defined.
  44493. -
  44494. -     The static chain register need not be a fixed register.
  44495. -
  44496. -     If the static chain is passed in memory, these macros should not be
  44497. -     defined; instead, the next two macros should be defined.
  44498. -
  44499. -`STATIC_CHAIN'
  44500. -`STATIC_CHAIN_INCOMING'
  44501. -     If the static chain is passed in memory, these macros provide rtx
  44502. -     giving `mem' expressions that denote where they are stored.
  44503. -     `STATIC_CHAIN' and `STATIC_CHAIN_INCOMING' give the locations as
  44504. -     seen by the calling and called functions, respectively.  Often the
  44505. -     former will be at an offset from the stack pointer and the latter
  44506. -     at an offset from the frame pointer.
  44507. -
  44508. -     The variables `stack_pointer_rtx', `frame_pointer_rtx', and
  44509. -     `arg_pointer_rtx' will have been initialized prior to the use of
  44510. -     these macros and should be used to refer to those items.
  44511. -
  44512. -     If the static chain is passed in a register, the two previous
  44513. -     macros should be defined instead.
  44514. -
  44515. -
  44516. -File: gcc.info,  Node: Elimination,  Next: Stack Arguments,  Prev: Frame Registers,  Up: Stack and Calling
  44517. -
  44518. -Eliminating Frame Pointer and Arg Pointer
  44519. ------------------------------------------
  44520. -
  44521. -   This is about eliminating the frame pointer and arg pointer.
  44522. -
  44523. -`FRAME_POINTER_REQUIRED'
  44524. -     A C expression which is nonzero if a function must have and use a
  44525. -     frame pointer.  This expression is evaluated  in the reload pass.
  44526. -     If its value is nonzero the function will have a frame pointer.
  44527. -
  44528. -     The expression can in principle examine the current function and
  44529. -     decide according to the facts, but on most machines the constant 0
  44530. -     or the constant 1 suffices.  Use 0 when the machine allows code to
  44531. -     be generated with no frame pointer, and doing so saves some time
  44532. -     or space.  Use 1 when there is no possible advantage to avoiding a
  44533. -     frame pointer.
  44534. -
  44535. -     In certain cases, the compiler does not know how to produce valid
  44536. -     code without a frame pointer.  The compiler recognizes those cases
  44537. -     and automatically gives the function a frame pointer regardless of
  44538. -     what `FRAME_POINTER_REQUIRED' says.  You don't need to worry about
  44539. -     them.
  44540. -
  44541. -     In a function that does not require a frame pointer, the frame
  44542. -     pointer register can be allocated for ordinary usage, unless you
  44543. -     mark it as a fixed register.  See `FIXED_REGISTERS' for more
  44544. -     information.
  44545. -
  44546. -`INITIAL_FRAME_POINTER_OFFSET (DEPTH-VAR)'
  44547. -     A C statement to store in the variable DEPTH-VAR the difference
  44548. -     between the frame pointer and the stack pointer values immediately
  44549. -     after the function prologue.  The value would be computed from
  44550. -     information such as the result of `get_frame_size ()' and the
  44551. -     tables of registers `regs_ever_live' and `call_used_regs'.
  44552. -
  44553. -     If `ELIMINABLE_REGS' is defined, this macro will be not be used and
  44554. -     need not be defined.  Otherwise, it must be defined even if
  44555. -     `FRAME_POINTER_REQUIRED' is defined to always be true; in that
  44556. -     case, you may set DEPTH-VAR to anything.
  44557. -
  44558. -`ELIMINABLE_REGS'
  44559. -     If defined, this macro specifies a table of register pairs used to
  44560. -     eliminate unneeded registers that point into the stack frame.  If
  44561. -     it is not defined, the only elimination attempted by the compiler
  44562. -     is to replace references to the frame pointer with references to
  44563. -     the stack pointer.
  44564. -
  44565. -     The definition of this macro is a list of structure
  44566. -     initializations, each of which specifies an original and
  44567. -     replacement register.
  44568. -
  44569. -     On some machines, the position of the argument pointer is not
  44570. -     known until the compilation is completed.  In such a case, a
  44571. -     separate hard register must be used for the argument pointer.
  44572. -     This register can be eliminated by replacing it with either the
  44573. -     frame pointer or the argument pointer, depending on whether or not
  44574. -     the frame pointer has been eliminated.
  44575. -
  44576. -     In this case, you might specify:
  44577. -          #define ELIMINABLE_REGS  \
  44578. -          {{ARG_POINTER_REGNUM, STACK_POINTER_REGNUM}, \
  44579. -           {ARG_POINTER_REGNUM, FRAME_POINTER_REGNUM}, \
  44580. -           {FRAME_POINTER_REGNUM, STACK_POINTER_REGNUM}}
  44581. -
  44582. -     Note that the elimination of the argument pointer with the stack
  44583. -     pointer is specified first since that is the preferred elimination.
  44584. -
  44585. -`CAN_ELIMINATE (FROM-REG, TO-REG)'
  44586. -     A C expression that returns non-zero if the compiler is allowed to
  44587. -     try to replace register number FROM-REG with register number
  44588. -     TO-REG.  This macro need only be defined if `ELIMINABLE_REGS' is
  44589. -     defined, and will usually be the constant 1, since most of the
  44590. -     cases preventing register elimination are things that the compiler
  44591. -     already knows about.
  44592. -
  44593. -`INITIAL_ELIMINATION_OFFSET (FROM-REG, TO-REG, OFFSET-VAR)'
  44594. -     This macro is similar to `INITIAL_FRAME_POINTER_OFFSET'.  It
  44595. -     specifies the initial difference between the specified pair of
  44596. -     registers.  This macro must be defined if `ELIMINABLE_REGS' is
  44597. -     defined.
  44598. -
  44599. -`LONGJMP_RESTORE_FROM_STACK'
  44600. -     Define this macro if the `longjmp' function restores registers from
  44601. -     the stack frames, rather than from those saved specifically by
  44602. -     `setjmp'.  Certain quantities must not be kept in registers across
  44603. -     a call to `setjmp' on such machines.
  44604. -
  44605. -
  44606. -File: gcc.info,  Node: Stack Arguments,  Next: Register Arguments,  Prev: Elimination,  Up: Stack and Calling
  44607. -
  44608. -Passing Function Arguments on the Stack
  44609. ----------------------------------------
  44610. -
  44611. -   The macros in this section control how arguments are passed on the
  44612. -stack.  See the following section for other macros that control passing
  44613. -certain arguments in registers.
  44614. -
  44615. -`PROMOTE_PROTOTYPES'
  44616. -     Define this macro if an argument declared in a prototype as an
  44617. -     integral type smaller than `int' should actually be passed as an
  44618. -     `int'.  In addition to avoiding errors in certain cases of
  44619. -     mismatch, it also makes for better code on certain machines.
  44620. -
  44621. -`PUSH_ROUNDING (NPUSHED)'
  44622. -     A C expression that is the number of bytes actually pushed onto the
  44623. -     stack when an instruction attempts to push NPUSHED bytes.
  44624. -
  44625. -     If the target machine does not have a push instruction, do not
  44626. -     define this macro.  That directs GNU CC to use an alternate
  44627. -     strategy: to allocate the entire argument block and then store the
  44628. -     arguments into it.
  44629. -
  44630. -     On some machines, the definition
  44631. -
  44632. -          #define PUSH_ROUNDING(BYTES) (BYTES)
  44633. -
  44634. -     will suffice.  But on other machines, instructions that appear to
  44635. -     push one byte actually push two bytes in an attempt to maintain
  44636. -     alignment.  Then the definition should be
  44637. -
  44638. -          #define PUSH_ROUNDING(BYTES) (((BYTES) + 1) & ~1)
  44639. -
  44640. -`ACCUMULATE_OUTGOING_ARGS'
  44641. -     If defined, the maximum amount of space required for outgoing
  44642. -     arguments will be computed and placed into the variable
  44643. -     `current_function_outgoing_args_size'.  No space will be pushed
  44644. -     onto the stack for each call; instead, the function prologue should
  44645. -     increase the stack frame size by this amount.
  44646. -
  44647. -     Defining both `PUSH_ROUNDING' and `ACCUMULATE_OUTGOING_ARGS' is
  44648. -     not proper.
  44649. -
  44650. -`REG_PARM_STACK_SPACE (FNDECL)'
  44651. -     Define this macro if functions should assume that stack space has
  44652. -     been allocated for arguments even when their values are passed in
  44653. -     registers.
  44654. -
  44655. -     The value of this macro is the size, in bytes, of the area
  44656. -     reserved for arguments passed in registers for the function
  44657. -     represented by FNDECL.
  44658. -
  44659. -     This space can be allocated by the caller, or be a part of the
  44660. -     machine-dependent stack frame: `OUTGOING_REG_PARM_STACK_SPACE' says
  44661. -     which.
  44662. -
  44663. -`MAYBE_REG_PARM_STACK_SPACE'
  44664. -`FINAL_REG_PARM_STACK_SPACE (CONST_SIZE, VAR_SIZE)'
  44665. -     Define these macros in addition to the one above if functions might
  44666. -     allocate stack space for arguments even when their values are
  44667. -     passed in registers.  These should be used when the stack space
  44668. -     allocated for arguments in registers is not a simple constant
  44669. -     independent of the function declaration.
  44670. -
  44671. -     The value of the first macro is the size, in bytes, of the area
  44672. -     that we should initially assume would be reserved for arguments
  44673. -     passed in registers.
  44674. -
  44675. -     The value of the second macro is the actual size, in bytes, of the
  44676. -     area that will be reserved for arguments passed in registers.
  44677. -     This takes two arguments: an integer representing the number of
  44678. -     bytes of fixed sized arguments on the stack, and a tree
  44679. -     representing the number of bytes of variable sized arguments on
  44680. -     the stack.
  44681. -
  44682. -     When these macros are defined, `REG_PARM_STACK_SPACE' will only be
  44683. -     called for libcall functions, the current function, or for a
  44684. -     function being called when it is known that such stack space must
  44685. -     be allocated.  In each case this value can be easily computed.
  44686. -
  44687. -     When deciding whether a called function needs such stack space,
  44688. -     and how much space to reserve, GNU CC uses these two macros
  44689. -     instead of `REG_PARM_STACK_SPACE'.
  44690. -
  44691. -`OUTGOING_REG_PARM_STACK_SPACE'
  44692. -     Define this if it is the responsibility of the caller to allocate
  44693. -     the area reserved for arguments passed in registers.
  44694. -
  44695. -     If `ACCUMULATE_OUTGOING_ARGS' is defined, this macro controls
  44696. -     whether the space for these arguments counts in the value of
  44697. -     `current_function_outgoing_args_size'.
  44698. -
  44699. -`STACK_PARMS_IN_REG_PARM_AREA'
  44700. -     Define this macro if `REG_PARM_STACK_SPACE' is defined, but the
  44701. -     stack parameters don't skip the area specified by it.
  44702. -
  44703. -     Normally, when a parameter is not passed in registers, it is
  44704. -     placed on the stack beyond the `REG_PARM_STACK_SPACE' area.
  44705. -     Defining this macro suppresses this behavior and causes the
  44706. -     parameter to be passed on the stack in its natural location.
  44707. -
  44708. -`RETURN_POPS_ARGS (FUNDECL, FUNTYPE, STACK-SIZE)'
  44709. -     A C expression that should indicate the number of bytes of its own
  44710. -     arguments that a function pops on returning, or 0 if the function
  44711. -     pops no arguments and the caller must therefore pop them all after
  44712. -     the function returns.
  44713. -
  44714. -     FUNDECL is a C variable whose value is a tree node that describes
  44715. -     the function in question.  Normally it is a node of type
  44716. -     `FUNCTION_DECL' that describes the declaration of the function.
  44717. -     From this it is possible to obtain the DECL_MACHINE_ATTRIBUTES of
  44718. -     the function.
  44719. -
  44720. -     FUNTYPE is a C variable whose value is a tree node that describes
  44721. -     the function in question.  Normally it is a node of type
  44722. -     `FUNCTION_TYPE' that describes the data type of the function.
  44723. -     From this it is possible to obtain the data types of the value and
  44724. -     arguments (if known).
  44725. -
  44726. -     When a call to a library function is being considered, FUNTYPE
  44727. -     will contain an identifier node for the library function.  Thus, if
  44728. -     you need to distinguish among various library functions, you can
  44729. -     do so by their names.  Note that "library function" in this
  44730. -     context means a function used to perform arithmetic, whose name is
  44731. -     known specially in the compiler and was not mentioned in the C
  44732. -     code being compiled.
  44733. -
  44734. -     STACK-SIZE is the number of bytes of arguments passed on the
  44735. -     stack.  If a variable number of bytes is passed, it is zero, and
  44736. -     argument popping will always be the responsibility of the calling
  44737. -     function.
  44738. -
  44739. -     On the Vax, all functions always pop their arguments, so the
  44740. -     definition of this macro is STACK-SIZE.  On the 68000, using the
  44741. -     standard calling convention, no functions pop their arguments, so
  44742. -     the value of the macro is always 0 in this case.  But an
  44743. -     alternative calling convention is available in which functions
  44744. -     that take a fixed number of arguments pop them but other functions
  44745. -     (such as `printf') pop nothing (the caller pops all).  When this
  44746. -     convention is in use, FUNTYPE is examined to determine whether a
  44747. -     function takes a fixed number of arguments.
  44748. -
  44749. diff -rup --new-file baseline/fsf/gcc/gcc.info-21 amiga/fsf/gcc/gcc.info-21
  44750. --- baseline/fsf/gcc/gcc.info-21    Sat Jun 29 09:38:08 1996
  44751. +++ amiga/fsf/gcc/gcc.info-21    Wed Dec 31 17:00:00 1969
  44752. @@ -1,927 +0,0 @@
  44753. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  44754. -file gcc.texi.
  44755. -
  44756. -   This file documents the use and the internals of the GNU compiler.
  44757. -
  44758. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  44759. -Boston, MA 02111-1307 USA
  44760. -
  44761. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  44762. -Foundation, Inc.
  44763. -
  44764. -   Permission is granted to make and distribute verbatim copies of this
  44765. -manual provided the copyright notice and this permission notice are
  44766. -preserved on all copies.
  44767. -
  44768. -   Permission is granted to copy and distribute modified versions of
  44769. -this manual under the conditions for verbatim copying, provided also
  44770. -that the sections entitled "GNU General Public License," "Funding for
  44771. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  44772. -included exactly as in the original, and provided that the entire
  44773. -resulting derived work is distributed under the terms of a permission
  44774. -notice identical to this one.
  44775. -
  44776. -   Permission is granted to copy and distribute translations of this
  44777. -manual into another language, under the above conditions for modified
  44778. -versions, except that the sections entitled "GNU General Public
  44779. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  44780. -`Look And Feel'", and this permission notice, may be included in
  44781. -translations approved by the Free Software Foundation instead of in the
  44782. -original English.
  44783. -
  44784. -
  44785. -File: gcc.info,  Node: Register Arguments,  Next: Scalar Return,  Prev: Stack Arguments,  Up: Stack and Calling
  44786. -
  44787. -Passing Arguments in Registers
  44788. -------------------------------
  44789. -
  44790. -   This section describes the macros which let you control how various
  44791. -types of arguments are passed in registers or how they are arranged in
  44792. -the stack.
  44793. -
  44794. -`FUNCTION_ARG (CUM, MODE, TYPE, NAMED)'
  44795. -     A C expression that controls whether a function argument is passed
  44796. -     in a register, and which register.
  44797. -
  44798. -     The arguments are CUM, which summarizes all the previous
  44799. -     arguments; MODE, the machine mode of the argument; TYPE, the data
  44800. -     type of the argument as a tree node or 0 if that is not known
  44801. -     (which happens for C support library functions); and NAMED, which
  44802. -     is 1 for an ordinary argument and 0 for nameless arguments that
  44803. -     correspond to `...' in the called function's prototype.
  44804. -
  44805. -     The value of the expression should either be a `reg' RTX for the
  44806. -     hard register in which to pass the argument, or zero to pass the
  44807. -     argument on the stack.
  44808. -
  44809. -     For machines like the Vax and 68000, where normally all arguments
  44810. -     are pushed, zero suffices as a definition.
  44811. -
  44812. -     The usual way to make the ANSI library `stdarg.h' work on a machine
  44813. -     where some arguments are usually passed in registers, is to cause
  44814. -     nameless arguments to be passed on the stack instead.  This is done
  44815. -     by making `FUNCTION_ARG' return 0 whenever NAMED is 0.
  44816. -
  44817. -     You may use the macro `MUST_PASS_IN_STACK (MODE, TYPE)' in the
  44818. -     definition of this macro to determine if this argument is of a
  44819. -     type that must be passed in the stack.  If `REG_PARM_STACK_SPACE'
  44820. -     is not defined and `FUNCTION_ARG' returns non-zero for such an
  44821. -     argument, the compiler will abort.  If `REG_PARM_STACK_SPACE' is
  44822. -     defined, the argument will be computed in the stack and then
  44823. -     loaded into a register.
  44824. -
  44825. -`FUNCTION_INCOMING_ARG (CUM, MODE, TYPE, NAMED)'
  44826. -     Define this macro if the target machine has "register windows", so
  44827. -     that the register in which a function sees an arguments is not
  44828. -     necessarily the same as the one in which the caller passed the
  44829. -     argument.
  44830. -
  44831. -     For such machines, `FUNCTION_ARG' computes the register in which
  44832. -     the caller passes the value, and `FUNCTION_INCOMING_ARG' should be
  44833. -     defined in a similar fashion to tell the function being called
  44834. -     where the arguments will arrive.
  44835. -
  44836. -     If `FUNCTION_INCOMING_ARG' is not defined, `FUNCTION_ARG' serves
  44837. -     both purposes.
  44838. -
  44839. -`FUNCTION_ARG_PARTIAL_NREGS (CUM, MODE, TYPE, NAMED)'
  44840. -     A C expression for the number of words, at the beginning of an
  44841. -     argument, must be put in registers.  The value must be zero for
  44842. -     arguments that are passed entirely in registers or that are
  44843. -     entirely pushed on the stack.
  44844. -
  44845. -     On some machines, certain arguments must be passed partially in
  44846. -     registers and partially in memory.  On these machines, typically
  44847. -     the first N words of arguments are passed in registers, and the
  44848. -     rest on the stack.  If a multi-word argument (a `double' or a
  44849. -     structure) crosses that boundary, its first few words must be
  44850. -     passed in registers and the rest must be pushed.  This macro tells
  44851. -     the compiler when this occurs, and how many of the words should go
  44852. -     in registers.
  44853. -
  44854. -     `FUNCTION_ARG' for these arguments should return the first
  44855. -     register to be used by the caller for this argument; likewise
  44856. -     `FUNCTION_INCOMING_ARG', for the called function.
  44857. -
  44858. -`FUNCTION_ARG_PASS_BY_REFERENCE (CUM, MODE, TYPE, NAMED)'
  44859. -     A C expression that indicates when an argument must be passed by
  44860. -     reference.  If nonzero for an argument, a copy of that argument is
  44861. -     made in memory and a pointer to the argument is passed instead of
  44862. -     the argument itself.  The pointer is passed in whatever way is
  44863. -     appropriate for passing a pointer to that type.
  44864. -
  44865. -     On machines where `REG_PARM_STACK_SPACE' is not defined, a suitable
  44866. -     definition of this macro might be
  44867. -          #define FUNCTION_ARG_PASS_BY_REFERENCE\
  44868. -          (CUM, MODE, TYPE, NAMED)  \
  44869. -            MUST_PASS_IN_STACK (MODE, TYPE)
  44870. -
  44871. -`FUNCTION_ARG_CALLEE_COPIES (CUM, MODE, TYPE, NAMED)'
  44872. -     If defined, a C expression that indicates when it is the called
  44873. -     function's responsibility to make a copy of arguments passed by
  44874. -     invisible reference.  Normally, the caller makes a copy and passes
  44875. -     the address of the copy to the routine being called.  When
  44876. -     FUNCTION_ARG_CALLEE_COPIES is defined and is nonzero, the caller
  44877. -     does not make a copy.  Instead, it passes a pointer to the "live"
  44878. -     value.  The called function must not modify this value.  If it can
  44879. -     be determined that the value won't be modified, it need not make a
  44880. -     copy; otherwise a copy must be made.
  44881. -
  44882. -`CUMULATIVE_ARGS'
  44883. -     A C type for declaring a variable that is used as the first
  44884. -     argument of `FUNCTION_ARG' and other related values.  For some
  44885. -     target machines, the type `int' suffices and can hold the number
  44886. -     of bytes of argument so far.
  44887. -
  44888. -     There is no need to record in `CUMULATIVE_ARGS' anything about the
  44889. -     arguments that have been passed on the stack.  The compiler has
  44890. -     other variables to keep track of that.  For target machines on
  44891. -     which all arguments are passed on the stack, there is no need to
  44892. -     store anything in `CUMULATIVE_ARGS'; however, the data structure
  44893. -     must exist and should not be empty, so use `int'.
  44894. -
  44895. -`INIT_CUMULATIVE_ARGS (CUM, FNTYPE, LIBNAME)'
  44896. -     A C statement (sans semicolon) for initializing the variable CUM
  44897. -     for the state at the beginning of the argument list.  The variable
  44898. -     has type `CUMULATIVE_ARGS'.  The value of FNTYPE is the tree node
  44899. -     for the data type of the function which will receive the args, or 0
  44900. -     if the args are to a compiler support library function.
  44901. -
  44902. -     When processing a call to a compiler support library function,
  44903. -     LIBNAME identifies which one.  It is a `symbol_ref' rtx which
  44904. -     contains the name of the function, as a string.  LIBNAME is 0 when
  44905. -     an ordinary C function call is being processed.  Thus, each time
  44906. -     this macro is called, either LIBNAME or FNTYPE is nonzero, but
  44907. -     never both of them at once.
  44908. -
  44909. -`INIT_CUMULATIVE_INCOMING_ARGS (CUM, FNTYPE, LIBNAME)'
  44910. -     Like `INIT_CUMULATIVE_ARGS' but overrides it for the purposes of
  44911. -     finding the arguments for the function being compiled.  If this
  44912. -     macro is undefined, `INIT_CUMULATIVE_ARGS' is used instead.
  44913. -
  44914. -     The value passed for LIBNAME is always 0, since library routines
  44915. -     with special calling conventions are never compiled with GNU CC.
  44916. -     The argument LIBNAME exists for symmetry with
  44917. -     `INIT_CUMULATIVE_ARGS'.
  44918. -
  44919. -`FUNCTION_ARG_ADVANCE (CUM, MODE, TYPE, NAMED)'
  44920. -     A C statement (sans semicolon) to update the summarizer variable
  44921. -     CUM to advance past an argument in the argument list.  The values
  44922. -     MODE, TYPE and NAMED describe that argument.  Once this is done,
  44923. -     the variable CUM is suitable for analyzing the *following*
  44924. -     argument with `FUNCTION_ARG', etc.
  44925. -
  44926. -     This macro need not do anything if the argument in question was
  44927. -     passed on the stack.  The compiler knows how to track the amount
  44928. -     of stack space used for arguments without any special help.
  44929. -
  44930. -`FUNCTION_ARG_PADDING (MODE, TYPE)'
  44931. -     If defined, a C expression which determines whether, and in which
  44932. -     direction, to pad out an argument with extra space.  The value
  44933. -     should be of type `enum direction': either `upward' to pad above
  44934. -     the argument, `downward' to pad below, or `none' to inhibit
  44935. -     padding.
  44936. -
  44937. -     The *amount* of padding is always just enough to reach the next
  44938. -     multiple of `FUNCTION_ARG_BOUNDARY'; this macro does not control
  44939. -     it.
  44940. -
  44941. -     This macro has a default definition which is right for most
  44942. -     systems.  For little-endian machines, the default is to pad
  44943. -     upward.  For big-endian machines, the default is to pad downward
  44944. -     for an argument of constant size shorter than an `int', and upward
  44945. -     otherwise.
  44946. -
  44947. -`FUNCTION_ARG_BOUNDARY (MODE, TYPE)'
  44948. -     If defined, a C expression that gives the alignment boundary, in
  44949. -     bits, of an argument with the specified mode and type.  If it is
  44950. -     not defined, `PARM_BOUNDARY' is used for all arguments.
  44951. -
  44952. -`FUNCTION_ARG_REGNO_P (REGNO)'
  44953. -     A C expression that is nonzero if REGNO is the number of a hard
  44954. -     register in which function arguments are sometimes passed.  This
  44955. -     does *not* include implicit arguments such as the static chain and
  44956. -     the structure-value address.  On many machines, no registers can be
  44957. -     used for this purpose since all function arguments are pushed on
  44958. -     the stack.
  44959. -
  44960. -
  44961. -File: gcc.info,  Node: Scalar Return,  Next: Aggregate Return,  Prev: Register Arguments,  Up: Stack and Calling
  44962. -
  44963. -How Scalar Function Values Are Returned
  44964. ----------------------------------------
  44965. -
  44966. -   This section discusses the macros that control returning scalars as
  44967. -values--values that can fit in registers.
  44968. -
  44969. -`TRADITIONAL_RETURN_FLOAT'
  44970. -     Define this macro if `-traditional' should not cause functions
  44971. -     declared to return `float' to convert the value to `double'.
  44972. -
  44973. -`FUNCTION_VALUE (VALTYPE, FUNC)'
  44974. -     A C expression to create an RTX representing the place where a
  44975. -     function returns a value of data type VALTYPE.  VALTYPE is a tree
  44976. -     node representing a data type.  Write `TYPE_MODE (VALTYPE)' to get
  44977. -     the machine mode used to represent that type.  On many machines,
  44978. -     only the mode is relevant.  (Actually, on most machines, scalar
  44979. -     values are returned in the same place regardless of mode).
  44980. -
  44981. -     If `PROMOTE_FUNCTION_RETURN' is defined, you must apply the same
  44982. -     promotion rules specified in `PROMOTE_MODE' if VALTYPE is a scalar
  44983. -     type.
  44984. -
  44985. -     If the precise function being called is known, FUNC is a tree node
  44986. -     (`FUNCTION_DECL') for it; otherwise, FUNC is a null pointer.  This
  44987. -     makes it possible to use a different value-returning convention
  44988. -     for specific functions when all their calls are known.
  44989. -
  44990. -     `FUNCTION_VALUE' is not used for return vales with aggregate data
  44991. -     types, because these are returned in another way.  See
  44992. -     `STRUCT_VALUE_REGNUM' and related macros, below.
  44993. -
  44994. -`FUNCTION_OUTGOING_VALUE (VALTYPE, FUNC)'
  44995. -     Define this macro if the target machine has "register windows" so
  44996. -     that the register in which a function returns its value is not the
  44997. -     same as the one in which the caller sees the value.
  44998. -
  44999. -     For such machines, `FUNCTION_VALUE' computes the register in which
  45000. -     the caller will see the value.  `FUNCTION_OUTGOING_VALUE' should be
  45001. -     defined in a similar fashion to tell the function where to put the
  45002. -     value.
  45003. -
  45004. -     If `FUNCTION_OUTGOING_VALUE' is not defined, `FUNCTION_VALUE'
  45005. -     serves both purposes.
  45006. -
  45007. -     `FUNCTION_OUTGOING_VALUE' is not used for return vales with
  45008. -     aggregate data types, because these are returned in another way.
  45009. -     See `STRUCT_VALUE_REGNUM' and related macros, below.
  45010. -
  45011. -`LIBCALL_VALUE (MODE)'
  45012. -     A C expression to create an RTX representing the place where a
  45013. -     library function returns a value of mode MODE.  If the precise
  45014. -     function being called is known, FUNC is a tree node
  45015. -     (`FUNCTION_DECL') for it; otherwise, FUNC is a null pointer.  This
  45016. -     makes it possible to use a different value-returning convention
  45017. -     for specific functions when all their calls are known.
  45018. -
  45019. -     Note that "library function" in this context means a compiler
  45020. -     support routine, used to perform arithmetic, whose name is known
  45021. -     specially by the compiler and was not mentioned in the C code being
  45022. -     compiled.
  45023. -
  45024. -     The definition of `LIBRARY_VALUE' need not be concerned aggregate
  45025. -     data types, because none of the library functions returns such
  45026. -     types.
  45027. -
  45028. -`FUNCTION_VALUE_REGNO_P (REGNO)'
  45029. -     A C expression that is nonzero if REGNO is the number of a hard
  45030. -     register in which the values of called function may come back.
  45031. -
  45032. -     A register whose use for returning values is limited to serving as
  45033. -     the second of a pair (for a value of type `double', say) need not
  45034. -     be recognized by this macro.  So for most machines, this definition
  45035. -     suffices:
  45036. -
  45037. -          #define FUNCTION_VALUE_REGNO_P(N) ((N) == 0)
  45038. -
  45039. -     If the machine has register windows, so that the caller and the
  45040. -     called function use different registers for the return value, this
  45041. -     macro should recognize only the caller's register numbers.
  45042. -
  45043. -`APPLY_RESULT_SIZE'
  45044. -     Define this macro if `untyped_call' and `untyped_return' need more
  45045. -     space than is implied by `FUNCTION_VALUE_REGNO_P' for saving and
  45046. -     restoring an arbitrary return value.
  45047. -
  45048. -
  45049. -File: gcc.info,  Node: Aggregate Return,  Next: Caller Saves,  Prev: Scalar Return,  Up: Stack and Calling
  45050. -
  45051. -How Large Values Are Returned
  45052. ------------------------------
  45053. -
  45054. -   When a function value's mode is `BLKmode' (and in some other cases),
  45055. -the value is not returned according to `FUNCTION_VALUE' (*note Scalar
  45056. -Return::.).  Instead, the caller passes the address of a block of
  45057. -memory in which the value should be stored.  This address is called the
  45058. -"structure value address".
  45059. -
  45060. -   This section describes how to control returning structure values in
  45061. -memory.
  45062. -
  45063. -`RETURN_IN_MEMORY (TYPE)'
  45064. -     A C expression which can inhibit the returning of certain function
  45065. -     values in registers, based on the type of value.  A nonzero value
  45066. -     says to return the function value in memory, just as large
  45067. -     structures are always returned.  Here TYPE will be a C expression
  45068. -     of type `tree', representing the data type of the value.
  45069. -
  45070. -     Note that values of mode `BLKmode' must be explicitly handled by
  45071. -     this macro.  Also, the option `-fpcc-struct-return' takes effect
  45072. -     regardless of this macro.  On most systems, it is possible to
  45073. -     leave the macro undefined; this causes a default definition to be
  45074. -     used, whose value is the constant 1 for `BLKmode' values, and 0
  45075. -     otherwise.
  45076. -
  45077. -     Do not use this macro to indicate that structures and unions
  45078. -     should always be returned in memory.  You should instead use
  45079. -     `DEFAULT_PCC_STRUCT_RETURN' to indicate this.
  45080. -
  45081. -`DEFAULT_PCC_STRUCT_RETURN'
  45082. -     Define this macro to be 1 if all structure and union return values
  45083. -     must be in memory.  Since this results in slower code, this should
  45084. -     be defined only if needed for compatibility with other compilers
  45085. -     or with an ABI.  If you define this macro to be 0, then the
  45086. -     conventions used for structure and union return values are decided
  45087. -     by the `RETURN_IN_MEMORY' macro.
  45088. -
  45089. -     If not defined, this defaults to the value 1.
  45090. -
  45091. -`STRUCT_VALUE_REGNUM'
  45092. -     If the structure value address is passed in a register, then
  45093. -     `STRUCT_VALUE_REGNUM' should be the number of that register.
  45094. -
  45095. -`STRUCT_VALUE'
  45096. -     If the structure value address is not passed in a register, define
  45097. -     `STRUCT_VALUE' as an expression returning an RTX for the place
  45098. -     where the address is passed.  If it returns 0, the address is
  45099. -     passed as an "invisible" first argument.
  45100. -
  45101. -`STRUCT_VALUE_INCOMING_REGNUM'
  45102. -     On some architectures the place where the structure value address
  45103. -     is found by the called function is not the same place that the
  45104. -     caller put it.  This can be due to register windows, or it could
  45105. -     be because the function prologue moves it to a different place.
  45106. -
  45107. -     If the incoming location of the structure value address is in a
  45108. -     register, define this macro as the register number.
  45109. -
  45110. -`STRUCT_VALUE_INCOMING'
  45111. -     If the incoming location is not a register, then you should define
  45112. -     `STRUCT_VALUE_INCOMING' as an expression for an RTX for where the
  45113. -     called function should find the value.  If it should find the
  45114. -     value on the stack, define this to create a `mem' which refers to
  45115. -     the frame pointer.  A definition of 0 means that the address is
  45116. -     passed as an "invisible" first argument.
  45117. -
  45118. -`PCC_STATIC_STRUCT_RETURN'
  45119. -     Define this macro if the usual system convention on the target
  45120. -     machine for returning structures and unions is for the called
  45121. -     function to return the address of a static variable containing the
  45122. -     value.
  45123. -
  45124. -     Do not define this if the usual system convention is for the
  45125. -     caller to pass an address to the subroutine.
  45126. -
  45127. -     This macro has effect in `-fpcc-struct-return' mode, but it does
  45128. -     nothing when you use `-freg-struct-return' mode.
  45129. -
  45130. -
  45131. -File: gcc.info,  Node: Caller Saves,  Next: Function Entry,  Prev: Aggregate Return,  Up: Stack and Calling
  45132. -
  45133. -Caller-Saves Register Allocation
  45134. ---------------------------------
  45135. -
  45136. -   If you enable it, GNU CC can save registers around function calls.
  45137. -This makes it possible to use call-clobbered registers to hold
  45138. -variables that must live across calls.
  45139. -
  45140. -`DEFAULT_CALLER_SAVES'
  45141. -     Define this macro if function calls on the target machine do not
  45142. -     preserve any registers; in other words, if `CALL_USED_REGISTERS'
  45143. -     has 1 for all registers.  This macro enables `-fcaller-saves' by
  45144. -     default.  Eventually that option will be enabled by default on all
  45145. -     machines and both the option and this macro will be eliminated.
  45146. -
  45147. -`CALLER_SAVE_PROFITABLE (REFS, CALLS)'
  45148. -     A C expression to determine whether it is worthwhile to consider
  45149. -     placing a pseudo-register in a call-clobbered hard register and
  45150. -     saving and restoring it around each function call.  The expression
  45151. -     should be 1 when this is worth doing, and 0 otherwise.
  45152. -
  45153. -     If you don't define this macro, a default is used which is good on
  45154. -     most machines: `4 * CALLS < REFS'.
  45155. -
  45156. -
  45157. -File: gcc.info,  Node: Function Entry,  Next: Profiling,  Prev: Caller Saves,  Up: Stack and Calling
  45158. -
  45159. -Function Entry and Exit
  45160. ------------------------
  45161. -
  45162. -   This section describes the macros that output function entry
  45163. -("prologue") and exit ("epilogue") code.
  45164. -
  45165. -`FUNCTION_PROLOGUE (FILE, SIZE)'
  45166. -     A C compound statement that outputs the assembler code for entry
  45167. -     to a function.  The prologue is responsible for setting up the
  45168. -     stack frame, initializing the frame pointer register, saving
  45169. -     registers that must be saved, and allocating SIZE additional bytes
  45170. -     of storage for the local variables.  SIZE is an integer.  FILE is
  45171. -     a stdio stream to which the assembler code should be output.
  45172. -
  45173. -     The label for the beginning of the function need not be output by
  45174. -     this macro.  That has already been done when the macro is run.
  45175. -
  45176. -     To determine which registers to save, the macro can refer to the
  45177. -     array `regs_ever_live': element R is nonzero if hard register R is
  45178. -     used anywhere within the function.  This implies the function
  45179. -     prologue should save register R, provided it is not one of the
  45180. -     call-used registers.  (`FUNCTION_EPILOGUE' must likewise use
  45181. -     `regs_ever_live'.)
  45182. -
  45183. -     On machines that have "register windows", the function entry code
  45184. -     does not save on the stack the registers that are in the windows,
  45185. -     even if they are supposed to be preserved by function calls;
  45186. -     instead it takes appropriate steps to "push" the register stack,
  45187. -     if any non-call-used registers are used in the function.
  45188. -
  45189. -     On machines where functions may or may not have frame-pointers, the
  45190. -     function entry code must vary accordingly; it must set up the frame
  45191. -     pointer if one is wanted, and not otherwise.  To determine whether
  45192. -     a frame pointer is in wanted, the macro can refer to the variable
  45193. -     `frame_pointer_needed'.  The variable's value will be 1 at run
  45194. -     time in a function that needs a frame pointer.  *Note
  45195. -     Elimination::.
  45196. -
  45197. -     The function entry code is responsible for allocating any stack
  45198. -     space required for the function.  This stack space consists of the
  45199. -     regions listed below.  In most cases, these regions are allocated
  45200. -     in the order listed, with the last listed region closest to the
  45201. -     top of the stack (the lowest address if `STACK_GROWS_DOWNWARD' is
  45202. -     defined, and the highest address if it is not defined).  You can
  45203. -     use a different order for a machine if doing so is more convenient
  45204. -     or required for compatibility reasons.  Except in cases where
  45205. -     required by standard or by a debugger, there is no reason why the
  45206. -     stack layout used by GCC need agree with that used by other
  45207. -     compilers for a machine.
  45208. -
  45209. -        * A region of `current_function_pretend_args_size' bytes of
  45210. -          uninitialized space just underneath the first argument
  45211. -          arriving on the stack.  (This may not be at the very start of
  45212. -          the allocated stack region if the calling sequence has pushed
  45213. -          anything else since pushing the stack arguments.  But
  45214. -          usually, on such machines, nothing else has been pushed yet,
  45215. -          because the function prologue itself does all the pushing.)
  45216. -          This region is used on machines where an argument may be
  45217. -          passed partly in registers and partly in memory, and, in some
  45218. -          cases to support the features in `varargs.h' and `stdargs.h'.
  45219. -
  45220. -        * An area of memory used to save certain registers used by the
  45221. -          function.  The size of this area, which may also include
  45222. -          space for such things as the return address and pointers to
  45223. -          previous stack frames, is machine-specific and usually
  45224. -          depends on which registers have been used in the function.
  45225. -          Machines with register windows often do not require a save
  45226. -          area.
  45227. -
  45228. -        * A region of at least SIZE bytes, possibly rounded up to an
  45229. -          allocation boundary, to contain the local variables of the
  45230. -          function.  On some machines, this region and the save area
  45231. -          may occur in the opposite order, with the save area closer to
  45232. -          the top of the stack.
  45233. -
  45234. -        * Optionally, when `ACCUMULATE_OUTGOING_ARGS' is defined, a
  45235. -          region of `current_function_outgoing_args_size' bytes to be
  45236. -          used for outgoing argument lists of the function.  *Note
  45237. -          Stack Arguments::.
  45238. -
  45239. -     Normally, it is necessary for the macros `FUNCTION_PROLOGUE' and
  45240. -     `FUNCTION_EPILOGUE' to treat leaf functions specially.  The C
  45241. -     variable `leaf_function' is nonzero for such a function.
  45242. -
  45243. -`EXIT_IGNORE_STACK'
  45244. -     Define this macro as a C expression that is nonzero if the return
  45245. -     instruction or the function epilogue ignores the value of the stack
  45246. -     pointer; in other words, if it is safe to delete an instruction to
  45247. -     adjust the stack pointer before a return from the function.
  45248. -
  45249. -     Note that this macro's value is relevant only for functions for
  45250. -     which frame pointers are maintained.  It is never safe to delete a
  45251. -     final stack adjustment in a function that has no frame pointer,
  45252. -     and the compiler knows this regardless of `EXIT_IGNORE_STACK'.
  45253. -
  45254. -`FUNCTION_EPILOGUE (FILE, SIZE)'
  45255. -     A C compound statement that outputs the assembler code for exit
  45256. -     from a function.  The epilogue is responsible for restoring the
  45257. -     saved registers and stack pointer to their values when the
  45258. -     function was called, and returning control to the caller.  This
  45259. -     macro takes the same arguments as the macro `FUNCTION_PROLOGUE',
  45260. -     and the registers to restore are determined from `regs_ever_live'
  45261. -     and `CALL_USED_REGISTERS' in the same way.
  45262. -
  45263. -     On some machines, there is a single instruction that does all the
  45264. -     work of returning from the function.  On these machines, give that
  45265. -     instruction the name `return' and do not define the macro
  45266. -     `FUNCTION_EPILOGUE' at all.
  45267. -
  45268. -     Do not define a pattern named `return' if you want the
  45269. -     `FUNCTION_EPILOGUE' to be used.  If you want the target switches
  45270. -     to control whether return instructions or epilogues are used,
  45271. -     define a `return' pattern with a validity condition that tests the
  45272. -     target switches appropriately.  If the `return' pattern's validity
  45273. -     condition is false, epilogues will be used.
  45274. -
  45275. -     On machines where functions may or may not have frame-pointers, the
  45276. -     function exit code must vary accordingly.  Sometimes the code for
  45277. -     these two cases is completely different.  To determine whether a
  45278. -     frame pointer is wanted, the macro can refer to the variable
  45279. -     `frame_pointer_needed'.  The variable's value will be 1 when
  45280. -     compiling a function that needs a frame pointer.
  45281. -
  45282. -     Normally, `FUNCTION_PROLOGUE' and `FUNCTION_EPILOGUE' must treat
  45283. -     leaf functions specially.  The C variable `leaf_function' is
  45284. -     nonzero for such a function.  *Note Leaf Functions::.
  45285. -
  45286. -     On some machines, some functions pop their arguments on exit while
  45287. -     others leave that for the caller to do.  For example, the 68020
  45288. -     when given `-mrtd' pops arguments in functions that take a fixed
  45289. -     number of arguments.
  45290. -
  45291. -     Your definition of the macro `RETURN_POPS_ARGS' decides which
  45292. -     functions pop their own arguments.  `FUNCTION_EPILOGUE' needs to
  45293. -     know what was decided.  The variable that is called
  45294. -     `current_function_pops_args' is the number of bytes of its
  45295. -     arguments that a function should pop.  *Note Scalar Return::.
  45296. -
  45297. -`DELAY_SLOTS_FOR_EPILOGUE'
  45298. -     Define this macro if the function epilogue contains delay slots to
  45299. -     which instructions from the rest of the function can be "moved".
  45300. -     The definition should be a C expression whose value is an integer
  45301. -     representing the number of delay slots there.
  45302. -
  45303. -`ELIGIBLE_FOR_EPILOGUE_DELAY (INSN, N)'
  45304. -     A C expression that returns 1 if INSN can be placed in delay slot
  45305. -     number N of the epilogue.
  45306. -
  45307. -     The argument N is an integer which identifies the delay slot now
  45308. -     being considered (since different slots may have different rules of
  45309. -     eligibility).  It is never negative and is always less than the
  45310. -     number of epilogue delay slots (what `DELAY_SLOTS_FOR_EPILOGUE'
  45311. -     returns).  If you reject a particular insn for a given delay slot,
  45312. -     in principle, it may be reconsidered for a subsequent delay slot.
  45313. -     Also, other insns may (at least in principle) be considered for
  45314. -     the so far unfilled delay slot.
  45315. -
  45316. -     The insns accepted to fill the epilogue delay slots are put in an
  45317. -     RTL list made with `insn_list' objects, stored in the variable
  45318. -     `current_function_epilogue_delay_list'.  The insn for the first
  45319. -     delay slot comes first in the list.  Your definition of the macro
  45320. -     `FUNCTION_EPILOGUE' should fill the delay slots by outputting the
  45321. -     insns in this list, usually by calling `final_scan_insn'.
  45322. -
  45323. -     You need not define this macro if you did not define
  45324. -     `DELAY_SLOTS_FOR_EPILOGUE'.
  45325. -
  45326. -
  45327. -File: gcc.info,  Node: Profiling,  Prev: Function Entry,  Up: Stack and Calling
  45328. -
  45329. -Generating Code for Profiling
  45330. ------------------------------
  45331. -
  45332. -   These macros will help you generate code for profiling.
  45333. -
  45334. -`FUNCTION_PROFILER (FILE, LABELNO)'
  45335. -     A C statement or compound statement to output to FILE some
  45336. -     assembler code to call the profiling subroutine `mcount'.  Before
  45337. -     calling, the assembler code must load the address of a counter
  45338. -     variable into a register where `mcount' expects to find the
  45339. -     address.  The name of this variable is `LP' followed by the number
  45340. -     LABELNO, so you would generate the name using `LP%d' in a
  45341. -     `fprintf'.
  45342. -
  45343. -     The details of how the address should be passed to `mcount' are
  45344. -     determined by your operating system environment, not by GNU CC.  To
  45345. -     figure them out, compile a small program for profiling using the
  45346. -     system's installed C compiler and look at the assembler code that
  45347. -     results.
  45348. -
  45349. -`PROFILE_BEFORE_PROLOGUE'
  45350. -     Define this macro if the code for function profiling should come
  45351. -     before the function prologue.  Normally, the profiling code comes
  45352. -     after.
  45353. -
  45354. -`FUNCTION_BLOCK_PROFILER (FILE, LABELNO)'
  45355. -     A C statement or compound statement to output to FILE some
  45356. -     assembler code to initialize basic-block profiling for the current
  45357. -     object module.  This code should call the subroutine
  45358. -     `__bb_init_func' once per object module, passing it as its sole
  45359. -     argument the address of a block allocated in the object module.
  45360. -
  45361. -     The name of the block is a local symbol made with this statement:
  45362. -
  45363. -          ASM_GENERATE_INTERNAL_LABEL (BUFFER, "LPBX", 0);
  45364. -
  45365. -     Of course, since you are writing the definition of
  45366. -     `ASM_GENERATE_INTERNAL_LABEL' as well as that of this macro, you
  45367. -     can take a short cut in the definition of this macro and use the
  45368. -     name that you know will result.
  45369. -
  45370. -     The first word of this block is a flag which will be nonzero if the
  45371. -     object module has already been initialized.  So test this word
  45372. -     first, and do not call `__bb_init_func' if the flag is nonzero.
  45373. -
  45374. -`BLOCK_PROFILER (FILE, BLOCKNO)'
  45375. -     A C statement or compound statement to increment the count
  45376. -     associated with the basic block number BLOCKNO.  Basic blocks are
  45377. -     numbered separately from zero within each compilation.  The count
  45378. -     associated with block number BLOCKNO is at index BLOCKNO in a
  45379. -     vector of words; the name of this array is a local symbol made
  45380. -     with this statement:
  45381. -
  45382. -          ASM_GENERATE_INTERNAL_LABEL (BUFFER, "LPBX", 2);
  45383. -
  45384. -     Of course, since you are writing the definition of
  45385. -     `ASM_GENERATE_INTERNAL_LABEL' as well as that of this macro, you
  45386. -     can take a short cut in the definition of this macro and use the
  45387. -     name that you know will result.
  45388. -
  45389. -`BLOCK_PROFILER_CODE'
  45390. -     A C function or functions which are needed in the library to
  45391. -     support block profiling.
  45392. -
  45393. -
  45394. -File: gcc.info,  Node: Varargs,  Next: Trampolines,  Prev: Stack and Calling,  Up: Target Macros
  45395. -
  45396. -Implementing the Varargs Macros
  45397. -===============================
  45398. -
  45399. -   GNU CC comes with an implementation of `varargs.h' and `stdarg.h'
  45400. -that work without change on machines that pass arguments on the stack.
  45401. -Other machines require their own implementations of varargs, and the
  45402. -two machine independent header files must have conditionals to include
  45403. -it.
  45404. -
  45405. -   ANSI `stdarg.h' differs from traditional `varargs.h' mainly in the
  45406. -calling convention for `va_start'.  The traditional implementation
  45407. -takes just one argument, which is the variable in which to store the
  45408. -argument pointer.  The ANSI implementation of `va_start' takes an
  45409. -additional second argument.  The user is supposed to write the last
  45410. -named argument of the function here.
  45411. -
  45412. -   However, `va_start' should not use this argument.  The way to find
  45413. -the end of the named arguments is with the built-in functions described
  45414. -below.
  45415. -
  45416. -`__builtin_saveregs ()'
  45417. -     Use this built-in function to save the argument registers in
  45418. -     memory so that the varargs mechanism can access them.  Both ANSI
  45419. -     and traditional versions of `va_start' must use
  45420. -     `__builtin_saveregs', unless you use `SETUP_INCOMING_VARARGS' (see
  45421. -     below) instead.
  45422. -
  45423. -     On some machines, `__builtin_saveregs' is open-coded under the
  45424. -     control of the macro `EXPAND_BUILTIN_SAVEREGS'.  On other machines,
  45425. -     it calls a routine written in assembler language, found in
  45426. -     `libgcc2.c'.
  45427. -
  45428. -     Code generated for the call to `__builtin_saveregs' appears at the
  45429. -     beginning of the function, as opposed to where the call to
  45430. -     `__builtin_saveregs' is written, regardless of what the code is.
  45431. -     This is because the registers must be saved before the function
  45432. -     starts to use them for its own purposes.
  45433. -
  45434. -`__builtin_args_info (CATEGORY)'
  45435. -     Use this built-in function to find the first anonymous arguments in
  45436. -     registers.
  45437. -
  45438. -     In general, a machine may have several categories of registers
  45439. -     used for arguments, each for a particular category of data types.
  45440. -     (For example, on some machines, floating-point registers are used
  45441. -     for floating-point arguments while other arguments are passed in
  45442. -     the general registers.) To make non-varargs functions use the
  45443. -     proper calling convention, you have defined the `CUMULATIVE_ARGS'
  45444. -     data type to record how many registers in each category have been
  45445. -     used so far
  45446. -
  45447. -     `__builtin_args_info' accesses the same data structure of type
  45448. -     `CUMULATIVE_ARGS' after the ordinary argument layout is finished
  45449. -     with it, with CATEGORY specifying which word to access.  Thus, the
  45450. -     value indicates the first unused register in a given category.
  45451. -
  45452. -     Normally, you would use `__builtin_args_info' in the implementation
  45453. -     of `va_start', accessing each category just once and storing the
  45454. -     value in the `va_list' object.  This is because `va_list' will
  45455. -     have to update the values, and there is no way to alter the values
  45456. -     accessed by `__builtin_args_info'.
  45457. -
  45458. -`__builtin_next_arg (LASTARG)'
  45459. -     This is the equivalent of `__builtin_args_info', for stack
  45460. -     arguments.  It returns the address of the first anonymous stack
  45461. -     argument, as type `void *'. If `ARGS_GROW_DOWNWARD', it returns
  45462. -     the address of the location above the first anonymous stack
  45463. -     argument.  Use it in `va_start' to initialize the pointer for
  45464. -     fetching arguments from the stack.  Also use it in `va_start' to
  45465. -     verify that the second parameter LASTARG is the last named argument
  45466. -     of the current function.
  45467. -
  45468. -`__builtin_classify_type (OBJECT)'
  45469. -     Since each machine has its own conventions for which data types are
  45470. -     passed in which kind of register, your implementation of `va_arg'
  45471. -     has to embody these conventions.  The easiest way to categorize the
  45472. -     specified data type is to use `__builtin_classify_type' together
  45473. -     with `sizeof' and `__alignof__'.
  45474. -
  45475. -     `__builtin_classify_type' ignores the value of OBJECT, considering
  45476. -     only its data type.  It returns an integer describing what kind of
  45477. -     type that is--integer, floating, pointer, structure, and so on.
  45478. -
  45479. -     The file `typeclass.h' defines an enumeration that you can use to
  45480. -     interpret the values of `__builtin_classify_type'.
  45481. -
  45482. -   These machine description macros help implement varargs:
  45483. -
  45484. -`EXPAND_BUILTIN_SAVEREGS (ARGS)'
  45485. -     If defined, is a C expression that produces the machine-specific
  45486. -     code for a call to `__builtin_saveregs'.  This code will be moved
  45487. -     to the very beginning of the function, before any parameter access
  45488. -     are made.  The return value of this function should be an RTX that
  45489. -     contains the value to use as the return of `__builtin_saveregs'.
  45490. -
  45491. -     The argument ARGS is a `tree_list' containing the arguments that
  45492. -     were passed to `__builtin_saveregs'.
  45493. -
  45494. -     If this macro is not defined, the compiler will output an ordinary
  45495. -     call to the library function `__builtin_saveregs'.
  45496. -
  45497. -`SETUP_INCOMING_VARARGS (ARGS_SO_FAR, MODE, TYPE,'
  45498. -     PRETEND_ARGS_SIZE, SECOND_TIME) This macro offers an alternative
  45499. -     to using `__builtin_saveregs' and defining the macro
  45500. -     `EXPAND_BUILTIN_SAVEREGS'.  Use it to store the anonymous register
  45501. -     arguments into the stack so that all the arguments appear to have
  45502. -     been passed consecutively on the stack.  Once this is done, you
  45503. -     can use the standard implementation of varargs that works for
  45504. -     machines that pass all their arguments on the stack.
  45505. -
  45506. -     The argument ARGS_SO_FAR is the `CUMULATIVE_ARGS' data structure,
  45507. -     containing the values that obtain after processing of the named
  45508. -     arguments.  The arguments MODE and TYPE describe the last named
  45509. -     argument--its machine mode and its data type as a tree node.
  45510. -
  45511. -     The macro implementation should do two things: first, push onto the
  45512. -     stack all the argument registers *not* used for the named
  45513. -     arguments, and second, store the size of the data thus pushed into
  45514. -     the `int'-valued variable whose name is supplied as the argument
  45515. -     PRETEND_ARGS_SIZE.  The value that you store here will serve as
  45516. -     additional offset for setting up the stack frame.
  45517. -
  45518. -     Because you must generate code to push the anonymous arguments at
  45519. -     compile time without knowing their data types,
  45520. -     `SETUP_INCOMING_VARARGS' is only useful on machines that have just
  45521. -     a single category of argument register and use it uniformly for
  45522. -     all data types.
  45523. -
  45524. -     If the argument SECOND_TIME is nonzero, it means that the
  45525. -     arguments of the function are being analyzed for the second time.
  45526. -     This happens for an inline function, which is not actually
  45527. -     compiled until the end of the source file.  The macro
  45528. -     `SETUP_INCOMING_VARARGS' should not generate any instructions in
  45529. -     this case.
  45530. -
  45531. -`STRICT_ARGUMENT_NAMING'
  45532. -     Define this macro if the location where a function argument is
  45533. -     passed depends on whether or not it is a named argument.
  45534. -
  45535. -     This macro controls how the NAMED argument to `FUNCTION_ARG' is
  45536. -     set for varargs and stdarg functions.  With this macro defined,
  45537. -     the NAMED argument is always true for named arguments, and false
  45538. -     for unnamed arguments.  If this is not defined, but
  45539. -     `SETUP_INCOMING_VARARGS' is defined, then all arguments are
  45540. -     treated as named.  Otherwise, all named arguments except the last
  45541. -     are treated as named.
  45542. -
  45543. -
  45544. -File: gcc.info,  Node: Trampolines,  Next: Library Calls,  Prev: Varargs,  Up: Target Macros
  45545. -
  45546. -Trampolines for Nested Functions
  45547. -================================
  45548. -
  45549. -   A "trampoline" is a small piece of code that is created at run time
  45550. -when the address of a nested function is taken.  It normally resides on
  45551. -the stack, in the stack frame of the containing function.  These macros
  45552. -tell GNU CC how to generate code to allocate and initialize a
  45553. -trampoline.
  45554. -
  45555. -   The instructions in the trampoline must do two things: load a
  45556. -constant address into the static chain register, and jump to the real
  45557. -address of the nested function.  On CISC machines such as the m68k,
  45558. -this requires two instructions, a move immediate and a jump.  Then the
  45559. -two addresses exist in the trampoline as word-long immediate operands.
  45560. -On RISC machines, it is often necessary to load each address into a
  45561. -register in two parts.  Then pieces of each address form separate
  45562. -immediate operands.
  45563. -
  45564. -   The code generated to initialize the trampoline must store the
  45565. -variable parts--the static chain value and the function address--into
  45566. -the immediate operands of the instructions.  On a CISC machine, this is
  45567. -simply a matter of copying each address to a memory reference at the
  45568. -proper offset from the start of the trampoline.  On a RISC machine, it
  45569. -may be necessary to take out pieces of the address and store them
  45570. -separately.
  45571. -
  45572. -`TRAMPOLINE_TEMPLATE (FILE)'
  45573. -     A C statement to output, on the stream FILE, assembler code for a
  45574. -     block of data that contains the constant parts of a trampoline.
  45575. -     This code should not include a label--the label is taken care of
  45576. -     automatically.
  45577. -
  45578. -`TRAMPOLINE_SECTION'
  45579. -     The name of a subroutine to switch to the section in which the
  45580. -     trampoline template is to be placed (*note Sections::.).  The
  45581. -     default is a value of `readonly_data_section', which places the
  45582. -     trampoline in the section containing read-only data.
  45583. -
  45584. -`TRAMPOLINE_SIZE'
  45585. -     A C expression for the size in bytes of the trampoline, as an
  45586. -     integer.
  45587. -
  45588. -`TRAMPOLINE_ALIGNMENT'
  45589. -     Alignment required for trampolines, in bits.
  45590. -
  45591. -     If you don't define this macro, the value of `BIGGEST_ALIGNMENT'
  45592. -     is used for aligning trampolines.
  45593. -
  45594. -`INITIALIZE_TRAMPOLINE (ADDR, FNADDR, STATIC_CHAIN)'
  45595. -     A C statement to initialize the variable parts of a trampoline.
  45596. -     aDDR is an RTX for the address of the trampoline; FNADDR is an RTX
  45597. -     for the address of the nested function; STATIC_CHAIN is an RTX for
  45598. -     the static chain value that should be passed to the function when
  45599. -     it is called.
  45600. -
  45601. -`ALLOCATE_TRAMPOLINE (FP)'
  45602. -     A C expression to allocate run-time space for a trampoline.  The
  45603. -     expression value should be an RTX representing a memory reference
  45604. -     to the space for the trampoline.
  45605. -
  45606. -     If this macro is not defined, by default the trampoline is
  45607. -     allocated as a stack slot.  This default is right for most
  45608. -     machines.  The exceptions are machines where it is impossible to
  45609. -     execute instructions in the stack area.  On such machines, you may
  45610. -     have to implement a separate stack, using this macro in
  45611. -     conjunction with `FUNCTION_PROLOGUE' and `FUNCTION_EPILOGUE'.
  45612. -
  45613. -     FP points to a data structure, a `struct function', which
  45614. -     describes the compilation status of the immediate containing
  45615. -     function of the function which the trampoline is for.  Normally
  45616. -     (when `ALLOCATE_TRAMPOLINE' is not defined), the stack slot for the
  45617. -     trampoline is in the stack frame of this containing function.
  45618. -     Other allocation strategies probably must do something analogous
  45619. -     with this information.
  45620. -
  45621. -   Implementing trampolines is difficult on many machines because they
  45622. -have separate instruction and data caches.  Writing into a stack
  45623. -location fails to clear the memory in the instruction cache, so when
  45624. -the program jumps to that location, it executes the old contents.
  45625. -
  45626. -   Here are two possible solutions.  One is to clear the relevant parts
  45627. -of the instruction cache whenever a trampoline is set up.  The other is
  45628. -to make all trampolines identical, by having them jump to a standard
  45629. -subroutine.  The former technique makes trampoline execution faster; the
  45630. -latter makes initialization faster.
  45631. -
  45632. -   To clear the instruction cache when a trampoline is initialized,
  45633. -define the following macros which describe the shape of the cache.
  45634. -
  45635. -`INSN_CACHE_SIZE'
  45636. -     The total size in bytes of the cache.
  45637. -
  45638. -`INSN_CACHE_LINE_WIDTH'
  45639. -     The length in bytes of each cache line.  The cache is divided into
  45640. -     cache lines which are disjoint slots, each holding a contiguous
  45641. -     chunk of data fetched from memory.  Each time data is brought into
  45642. -     the cache, an entire line is read at once.  The data loaded into a
  45643. -     cache line is always aligned on a boundary equal to the line size.
  45644. -
  45645. -`INSN_CACHE_DEPTH'
  45646. -     The number of alternative cache lines that can hold any particular
  45647. -     memory location.
  45648. -
  45649. -   Alternatively, if the machine has system calls or instructions to
  45650. -clear the instruction cache directly, you can define the following
  45651. -macro.
  45652. -
  45653. -`CLEAR_INSN_CACHE (BEG, END)'
  45654. -     If defined, expands to a C expression clearing the *instruction
  45655. -     cache* in the specified interval.  If it is not defined, and the
  45656. -     macro INSN_CACHE_SIZE is defined, some generic code is generated
  45657. -     to clear the cache.  The definition of this macro would typically
  45658. -     be a series of `asm' statements.  Both BEG and END are both pointer
  45659. -     expressions.
  45660. -
  45661. -   To use a standard subroutine, define the following macro.  In
  45662. -addition, you must make sure that the instructions in a trampoline fill
  45663. -an entire cache line with identical instructions, or else ensure that
  45664. -the beginning of the trampoline code is always aligned at the same
  45665. -point in its cache line.  Look in `m68k.h' as a guide.
  45666. -
  45667. -`TRANSFER_FROM_TRAMPOLINE'
  45668. -     Define this macro if trampolines need a special subroutine to do
  45669. -     their work.  The macro should expand to a series of `asm'
  45670. -     statements which will be compiled with GNU CC.  They go in a
  45671. -     library function named `__transfer_from_trampoline'.
  45672. -
  45673. -     If you need to avoid executing the ordinary prologue code of a
  45674. -     compiled C function when you jump to the subroutine, you can do so
  45675. -     by placing a special label of your own in the assembler code.  Use
  45676. -     one `asm' statement to generate an assembler label, and another to
  45677. -     make the label global.  Then trampolines can use that label to
  45678. -     jump directly to your special assembler code.
  45679. -
  45680. diff -rup --new-file baseline/fsf/gcc/gcc.info-22 amiga/fsf/gcc/gcc.info-22
  45681. --- baseline/fsf/gcc/gcc.info-22    Sat Jun 29 09:38:08 1996
  45682. +++ amiga/fsf/gcc/gcc.info-22    Wed Dec 31 17:00:00 1969
  45683. @@ -1,1116 +0,0 @@
  45684. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  45685. -file gcc.texi.
  45686. -
  45687. -   This file documents the use and the internals of the GNU compiler.
  45688. -
  45689. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  45690. -Boston, MA 02111-1307 USA
  45691. -
  45692. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  45693. -Foundation, Inc.
  45694. -
  45695. -   Permission is granted to make and distribute verbatim copies of this
  45696. -manual provided the copyright notice and this permission notice are
  45697. -preserved on all copies.
  45698. -
  45699. -   Permission is granted to copy and distribute modified versions of
  45700. -this manual under the conditions for verbatim copying, provided also
  45701. -that the sections entitled "GNU General Public License," "Funding for
  45702. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  45703. -included exactly as in the original, and provided that the entire
  45704. -resulting derived work is distributed under the terms of a permission
  45705. -notice identical to this one.
  45706. -
  45707. -   Permission is granted to copy and distribute translations of this
  45708. -manual into another language, under the above conditions for modified
  45709. -versions, except that the sections entitled "GNU General Public
  45710. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  45711. -`Look And Feel'", and this permission notice, may be included in
  45712. -translations approved by the Free Software Foundation instead of in the
  45713. -original English.
  45714. -
  45715. -
  45716. -File: gcc.info,  Node: Library Calls,  Next: Addressing Modes,  Prev: Trampolines,  Up: Target Macros
  45717. -
  45718. -Implicit Calls to Library Routines
  45719. -==================================
  45720. -
  45721. -   Here is an explanation of implicit calls to library routines.
  45722. -
  45723. -`MULSI3_LIBCALL'
  45724. -     A C string constant giving the name of the function to call for
  45725. -     multiplication of one signed full-word by another.  If you do not
  45726. -     define this macro, the default name is used, which is `__mulsi3',
  45727. -     a function defined in `libgcc.a'.
  45728. -
  45729. -`DIVSI3_LIBCALL'
  45730. -     A C string constant giving the name of the function to call for
  45731. -     division of one signed full-word by another.  If you do not define
  45732. -     this macro, the default name is used, which is `__divsi3', a
  45733. -     function defined in `libgcc.a'.
  45734. -
  45735. -`UDIVSI3_LIBCALL'
  45736. -     A C string constant giving the name of the function to call for
  45737. -     division of one unsigned full-word by another.  If you do not
  45738. -     define this macro, the default name is used, which is `__udivsi3',
  45739. -     a function defined in `libgcc.a'.
  45740. -
  45741. -`MODSI3_LIBCALL'
  45742. -     A C string constant giving the name of the function to call for the
  45743. -     remainder in division of one signed full-word by another.  If you
  45744. -     do not define this macro, the default name is used, which is
  45745. -     `__modsi3', a function defined in `libgcc.a'.
  45746. -
  45747. -`UMODSI3_LIBCALL'
  45748. -     A C string constant giving the name of the function to call for the
  45749. -     remainder in division of one unsigned full-word by another.  If
  45750. -     you do not define this macro, the default name is used, which is
  45751. -     `__umodsi3', a function defined in `libgcc.a'.
  45752. -
  45753. -`MULDI3_LIBCALL'
  45754. -     A C string constant giving the name of the function to call for
  45755. -     multiplication of one signed double-word by another.  If you do not
  45756. -     define this macro, the default name is used, which is `__muldi3',
  45757. -     a function defined in `libgcc.a'.
  45758. -
  45759. -`DIVDI3_LIBCALL'
  45760. -     A C string constant giving the name of the function to call for
  45761. -     division of one signed double-word by another.  If you do not
  45762. -     define this macro, the default name is used, which is `__divdi3', a
  45763. -     function defined in `libgcc.a'.
  45764. -
  45765. -`UDIVDI3_LIBCALL'
  45766. -     A C string constant giving the name of the function to call for
  45767. -     division of one unsigned full-word by another.  If you do not
  45768. -     define this macro, the default name is used, which is `__udivdi3',
  45769. -     a function defined in `libgcc.a'.
  45770. -
  45771. -`MODDI3_LIBCALL'
  45772. -     A C string constant giving the name of the function to call for the
  45773. -     remainder in division of one signed double-word by another.  If
  45774. -     you do not define this macro, the default name is used, which is
  45775. -     `__moddi3', a function defined in `libgcc.a'.
  45776. -
  45777. -`UMODDI3_LIBCALL'
  45778. -     A C string constant giving the name of the function to call for the
  45779. -     remainder in division of one unsigned full-word by another.  If
  45780. -     you do not define this macro, the default name is used, which is
  45781. -     `__umoddi3', a function defined in `libgcc.a'.
  45782. -
  45783. -`INIT_TARGET_OPTABS'
  45784. -     Define this macro as a C statement that declares additional library
  45785. -     routines renames existing ones. `init_optabs' calls this macro
  45786. -     after initializing all the normal library routines.
  45787. -
  45788. -`TARGET_EDOM'
  45789. -     The value of `EDOM' on the target machine, as a C integer constant
  45790. -     expression.  If you don't define this macro, GNU CC does not
  45791. -     attempt to deposit the value of `EDOM' into `errno' directly.
  45792. -     Look in `/usr/include/errno.h' to find the value of `EDOM' on your
  45793. -     system.
  45794. -
  45795. -     If you do not define `TARGET_EDOM', then compiled code reports
  45796. -     domain errors by calling the library function and letting it
  45797. -     report the error.  If mathematical functions on your system use
  45798. -     `matherr' when there is an error, then you should leave
  45799. -     `TARGET_EDOM' undefined so that `matherr' is used normally.
  45800. -
  45801. -`GEN_ERRNO_RTX'
  45802. -     Define this macro as a C expression to create an rtl expression
  45803. -     that refers to the global "variable" `errno'.  (On certain systems,
  45804. -     `errno' may not actually be a variable.)  If you don't define this
  45805. -     macro, a reasonable default is used.
  45806. -
  45807. -`TARGET_MEM_FUNCTIONS'
  45808. -     Define this macro if GNU CC should generate calls to the System V
  45809. -     (and ANSI C) library functions `memcpy' and `memset' rather than
  45810. -     the BSD functions `bcopy' and `bzero'.
  45811. -
  45812. -`LIBGCC_NEEDS_DOUBLE'
  45813. -     Define this macro if only `float' arguments cannot be passed to
  45814. -     library routines (so they must be converted to `double').  This
  45815. -     macro affects both how library calls are generated and how the
  45816. -     library routines in `libgcc1.c' accept their arguments.  It is
  45817. -     useful on machines where floating and fixed point arguments are
  45818. -     passed differently, such as the i860.
  45819. -
  45820. -`FLOAT_ARG_TYPE'
  45821. -     Define this macro to override the type used by the library
  45822. -     routines to pick up arguments of type `float'.  (By default, they
  45823. -     use a union of `float' and `int'.)
  45824. -
  45825. -     The obvious choice would be `float'--but that won't work with
  45826. -     traditional C compilers that expect all arguments declared as
  45827. -     `float' to arrive as `double'.  To avoid this conversion, the
  45828. -     library routines ask for the value as some other type and then
  45829. -     treat it as a `float'.
  45830. -
  45831. -     On some systems, no other type will work for this.  For these
  45832. -     systems, you must use `LIBGCC_NEEDS_DOUBLE' instead, to force
  45833. -     conversion of the values `double' before they are passed.
  45834. -
  45835. -`FLOATIFY (PASSED-VALUE)'
  45836. -     Define this macro to override the way library routines redesignate
  45837. -     a `float' argument as a `float' instead of the type it was passed
  45838. -     as.  The default is an expression which takes the `float' field of
  45839. -     the union.
  45840. -
  45841. -`FLOAT_VALUE_TYPE'
  45842. -     Define this macro to override the type used by the library
  45843. -     routines to return values that ought to have type `float'.  (By
  45844. -     default, they use `int'.)
  45845. -
  45846. -     The obvious choice would be `float'--but that won't work with
  45847. -     traditional C compilers gratuitously convert values declared as
  45848. -     `float' into `double'.
  45849. -
  45850. -`INTIFY (FLOAT-VALUE)'
  45851. -     Define this macro to override the way the value of a
  45852. -     `float'-returning library routine should be packaged in order to
  45853. -     return it.  These functions are actually declared to return type
  45854. -     `FLOAT_VALUE_TYPE' (normally `int').
  45855. -
  45856. -     These values can't be returned as type `float' because traditional
  45857. -     C compilers would gratuitously convert the value to a `double'.
  45858. -
  45859. -     A local variable named `intify' is always available when the macro
  45860. -     `INTIFY' is used.  It is a union of a `float' field named `f' and
  45861. -     a field named `i' whose type is `FLOAT_VALUE_TYPE' or `int'.
  45862. -
  45863. -     If you don't define this macro, the default definition works by
  45864. -     copying the value through that union.
  45865. -
  45866. -`nongcc_SI_type'
  45867. -     Define this macro as the name of the data type corresponding to
  45868. -     `SImode' in the system's own C compiler.
  45869. -
  45870. -     You need not define this macro if that type is `long int', as it
  45871. -     usually is.
  45872. -
  45873. -`nongcc_word_type'
  45874. -     Define this macro as the name of the data type corresponding to the
  45875. -     word_mode in the system's own C compiler.
  45876. -
  45877. -     You need not define this macro if that type is `long int', as it
  45878. -     usually is.
  45879. -
  45880. -`perform_...'
  45881. -     Define these macros to supply explicit C statements to carry out
  45882. -     various arithmetic operations on types `float' and `double' in the
  45883. -     library routines in `libgcc1.c'.  See that file for a full list of
  45884. -     these macros and their arguments.
  45885. -
  45886. -     On most machines, you don't need to define any of these macros,
  45887. -     because the C compiler that comes with the system takes care of
  45888. -     doing them.
  45889. -
  45890. -`NEXT_OBJC_RUNTIME'
  45891. -     Define this macro to generate code for Objective C message sending
  45892. -     using the calling convention of the NeXT system.  This calling
  45893. -     convention involves passing the object, the selector and the
  45894. -     method arguments all at once to the method-lookup library function.
  45895. -
  45896. -     The default calling convention passes just the object and the
  45897. -     selector to the lookup function, which returns a pointer to the
  45898. -     method.
  45899. -
  45900. -
  45901. -File: gcc.info,  Node: Addressing Modes,  Next: Condition Code,  Prev: Library Calls,  Up: Target Macros
  45902. -
  45903. -Addressing Modes
  45904. -================
  45905. -
  45906. -   This is about addressing modes.
  45907. -
  45908. -`HAVE_POST_INCREMENT'
  45909. -     Define this macro if the machine supports post-increment
  45910. -     addressing.
  45911. -
  45912. -`HAVE_PRE_INCREMENT'
  45913. -`HAVE_POST_DECREMENT'
  45914. -`HAVE_PRE_DECREMENT'
  45915. -     Similar for other kinds of addressing.
  45916. -
  45917. -`CONSTANT_ADDRESS_P (X)'
  45918. -     A C expression that is 1 if the RTX X is a constant which is a
  45919. -     valid address.  On most machines, this can be defined as
  45920. -     `CONSTANT_P (X)', but a few machines are more restrictive in which
  45921. -     constant addresses are supported.
  45922. -
  45923. -     `CONSTANT_P' accepts integer-values expressions whose values are
  45924. -     not explicitly known, such as `symbol_ref', `label_ref', and
  45925. -     `high' expressions and `const' arithmetic expressions, in addition
  45926. -     to `const_int' and `const_double' expressions.
  45927. -
  45928. -`MAX_REGS_PER_ADDRESS'
  45929. -     A number, the maximum number of registers that can appear in a
  45930. -     valid memory address.  Note that it is up to you to specify a
  45931. -     value equal to the maximum number that `GO_IF_LEGITIMATE_ADDRESS'
  45932. -     would ever accept.
  45933. -
  45934. -`GO_IF_LEGITIMATE_ADDRESS (MODE, X, LABEL)'
  45935. -     A C compound statement with a conditional `goto LABEL;' executed
  45936. -     if X (an RTX) is a legitimate memory address on the target machine
  45937. -     for a memory operand of mode MODE.
  45938. -
  45939. -     It usually pays to define several simpler macros to serve as
  45940. -     subroutines for this one.  Otherwise it may be too complicated to
  45941. -     understand.
  45942. -
  45943. -     This macro must exist in two variants: a strict variant and a
  45944. -     non-strict one.  The strict variant is used in the reload pass.  It
  45945. -     must be defined so that any pseudo-register that has not been
  45946. -     allocated a hard register is considered a memory reference.  In
  45947. -     contexts where some kind of register is required, a pseudo-register
  45948. -     with no hard register must be rejected.
  45949. -
  45950. -     The non-strict variant is used in other passes.  It must be
  45951. -     defined to accept all pseudo-registers in every context where some
  45952. -     kind of register is required.
  45953. -
  45954. -     Compiler source files that want to use the strict variant of this
  45955. -     macro define the macro `REG_OK_STRICT'.  You should use an `#ifdef
  45956. -     REG_OK_STRICT' conditional to define the strict variant in that
  45957. -     case and the non-strict variant otherwise.
  45958. -
  45959. -     Subroutines to check for acceptable registers for various purposes
  45960. -     (one for base registers, one for index registers, and so on) are
  45961. -     typically among the subroutines used to define
  45962. -     `GO_IF_LEGITIMATE_ADDRESS'.  Then only these subroutine macros
  45963. -     need have two variants; the higher levels of macros may be the
  45964. -     same whether strict or not.
  45965. -
  45966. -     Normally, constant addresses which are the sum of a `symbol_ref'
  45967. -     and an integer are stored inside a `const' RTX to mark them as
  45968. -     constant.  Therefore, there is no need to recognize such sums
  45969. -     specifically as legitimate addresses.  Normally you would simply
  45970. -     recognize any `const' as legitimate.
  45971. -
  45972. -     Usually `PRINT_OPERAND_ADDRESS' is not prepared to handle constant
  45973. -     sums that are not marked with  `const'.  It assumes that a naked
  45974. -     `plus' indicates indexing.  If so, then you *must* reject such
  45975. -     naked constant sums as illegitimate addresses, so that none of
  45976. -     them will be given to `PRINT_OPERAND_ADDRESS'.
  45977. -
  45978. -     On some machines, whether a symbolic address is legitimate depends
  45979. -     on the section that the address refers to.  On these machines,
  45980. -     define the macro `ENCODE_SECTION_INFO' to store the information
  45981. -     into the `symbol_ref', and then check for it here.  When you see a
  45982. -     `const', you will have to look inside it to find the `symbol_ref'
  45983. -     in order to determine the section.  *Note Assembler Format::.
  45984. -
  45985. -     The best way to modify the name string is by adding text to the
  45986. -     beginning, with suitable punctuation to prevent any ambiguity.
  45987. -     Allocate the new name in `saveable_obstack'.  You will have to
  45988. -     modify `ASM_OUTPUT_LABELREF' to remove and decode the added text
  45989. -     and output the name accordingly, and define `STRIP_NAME_ENCODING'
  45990. -     to access the original name string.
  45991. -
  45992. -     You can check the information stored here into the `symbol_ref' in
  45993. -     the definitions of the macros `GO_IF_LEGITIMATE_ADDRESS' and
  45994. -     `PRINT_OPERAND_ADDRESS'.
  45995. -
  45996. -`REG_OK_FOR_BASE_P (X)'
  45997. -     A C expression that is nonzero if X (assumed to be a `reg' RTX) is
  45998. -     valid for use as a base register.  For hard registers, it should
  45999. -     always accept those which the hardware permits and reject the
  46000. -     others.  Whether the macro accepts or rejects pseudo registers
  46001. -     must be controlled by `REG_OK_STRICT' as described above.  This
  46002. -     usually requires two variant definitions, of which `REG_OK_STRICT'
  46003. -     controls the one actually used.
  46004. -
  46005. -`REG_OK_FOR_INDEX_P (X)'
  46006. -     A C expression that is nonzero if X (assumed to be a `reg' RTX) is
  46007. -     valid for use as an index register.
  46008. -
  46009. -     The difference between an index register and a base register is
  46010. -     that the index register may be scaled.  If an address involves the
  46011. -     sum of two registers, neither one of them scaled, then either one
  46012. -     may be labeled the "base" and the other the "index"; but whichever
  46013. -     labeling is used must fit the machine's constraints of which
  46014. -     registers may serve in each capacity.  The compiler will try both
  46015. -     labelings, looking for one that is valid, and will reload one or
  46016. -     both registers only if neither labeling works.
  46017. -
  46018. -`LEGITIMIZE_ADDRESS (X, OLDX, MODE, WIN)'
  46019. -     A C compound statement that attempts to replace X with a valid
  46020. -     memory address for an operand of mode MODE.  WIN will be a C
  46021. -     statement label elsewhere in the code; the macro definition may use
  46022. -
  46023. -          GO_IF_LEGITIMATE_ADDRESS (MODE, X, WIN);
  46024. -
  46025. -     to avoid further processing if the address has become legitimate.
  46026. -
  46027. -     X will always be the result of a call to `break_out_memory_refs',
  46028. -     and OLDX will be the operand that was given to that function to
  46029. -     produce X.
  46030. -
  46031. -     The code generated by this macro should not alter the substructure
  46032. -     of X.  If it transforms X into a more legitimate form, it should
  46033. -     assign X (which will always be a C variable) a new value.
  46034. -
  46035. -     It is not necessary for this macro to come up with a legitimate
  46036. -     address.  The compiler has standard ways of doing so in all cases.
  46037. -     In fact, it is safe for this macro to do nothing.  But often a
  46038. -     machine-dependent strategy can generate better code.
  46039. -
  46040. -`GO_IF_MODE_DEPENDENT_ADDRESS (ADDR, LABEL)'
  46041. -     A C statement or compound statement with a conditional `goto
  46042. -     LABEL;' executed if memory address X (an RTX) can have different
  46043. -     meanings depending on the machine mode of the memory reference it
  46044. -     is used for or if the address is valid for some modes but not
  46045. -     others.
  46046. -
  46047. -     Autoincrement and autodecrement addresses typically have
  46048. -     mode-dependent effects because the amount of the increment or
  46049. -     decrement is the size of the operand being addressed.  Some
  46050. -     machines have other mode-dependent addresses.  Many RISC machines
  46051. -     have no mode-dependent addresses.
  46052. -
  46053. -     You may assume that ADDR is a valid address for the machine.
  46054. -
  46055. -`LEGITIMATE_CONSTANT_P (X)'
  46056. -     A C expression that is nonzero if X is a legitimate constant for
  46057. -     an immediate operand on the target machine.  You can assume that X
  46058. -     satisfies `CONSTANT_P', so you need not check this.  In fact, `1'
  46059. -     is a suitable definition for this macro on machines where anything
  46060. -     `CONSTANT_P' is valid.
  46061. -
  46062. -
  46063. -File: gcc.info,  Node: Condition Code,  Next: Costs,  Prev: Addressing Modes,  Up: Target Macros
  46064. -
  46065. -Condition Code Status
  46066. -=====================
  46067. -
  46068. -   This describes the condition code status.
  46069. -
  46070. -   The file `conditions.h' defines a variable `cc_status' to describe
  46071. -how the condition code was computed (in case the interpretation of the
  46072. -condition code depends on the instruction that it was set by).  This
  46073. -variable contains the RTL expressions on which the condition code is
  46074. -currently based, and several standard flags.
  46075. -
  46076. -   Sometimes additional machine-specific flags must be defined in the
  46077. -machine description header file.  It can also add additional
  46078. -machine-specific information by defining `CC_STATUS_MDEP'.
  46079. -
  46080. -`CC_STATUS_MDEP'
  46081. -     C code for a data type which is used for declaring the `mdep'
  46082. -     component of `cc_status'.  It defaults to `int'.
  46083. -
  46084. -     This macro is not used on machines that do not use `cc0'.
  46085. -
  46086. -`CC_STATUS_MDEP_INIT'
  46087. -     A C expression to initialize the `mdep' field to "empty".  The
  46088. -     default definition does nothing, since most machines don't use the
  46089. -     field anyway.  If you want to use the field, you should probably
  46090. -     define this macro to initialize it.
  46091. -
  46092. -     This macro is not used on machines that do not use `cc0'.
  46093. -
  46094. -`NOTICE_UPDATE_CC (EXP, INSN)'
  46095. -     A C compound statement to set the components of `cc_status'
  46096. -     appropriately for an insn INSN whose body is EXP.  It is this
  46097. -     macro's responsibility to recognize insns that set the condition
  46098. -     code as a byproduct of other activity as well as those that
  46099. -     explicitly set `(cc0)'.
  46100. -
  46101. -     This macro is not used on machines that do not use `cc0'.
  46102. -
  46103. -     If there are insns that do not set the condition code but do alter
  46104. -     other machine registers, this macro must check to see whether they
  46105. -     invalidate the expressions that the condition code is recorded as
  46106. -     reflecting.  For example, on the 68000, insns that store in address
  46107. -     registers do not set the condition code, which means that usually
  46108. -     `NOTICE_UPDATE_CC' can leave `cc_status' unaltered for such insns.
  46109. -     But suppose that the previous insn set the condition code based
  46110. -     on location `a4@(102)' and the current insn stores a new value in
  46111. -     `a4'.  Although the condition code is not changed by this, it will
  46112. -     no longer be true that it reflects the contents of `a4@(102)'.
  46113. -     Therefore, `NOTICE_UPDATE_CC' must alter `cc_status' in this case
  46114. -     to say that nothing is known about the condition code value.
  46115. -
  46116. -     The definition of `NOTICE_UPDATE_CC' must be prepared to deal with
  46117. -     the results of peephole optimization: insns whose patterns are
  46118. -     `parallel' RTXs containing various `reg', `mem' or constants which
  46119. -     are just the operands.  The RTL structure of these insns is not
  46120. -     sufficient to indicate what the insns actually do.  What
  46121. -     `NOTICE_UPDATE_CC' should do when it sees one is just to run
  46122. -     `CC_STATUS_INIT'.
  46123. -
  46124. -     A possible definition of `NOTICE_UPDATE_CC' is to call a function
  46125. -     that looks at an attribute (*note Insn Attributes::.) named, for
  46126. -     example, `cc'.  This avoids having detailed information about
  46127. -     patterns in two places, the `md' file and in `NOTICE_UPDATE_CC'.
  46128. -
  46129. -`EXTRA_CC_MODES'
  46130. -     A list of names to be used for additional modes for condition code
  46131. -     values in registers (*note Jump Patterns::.).  These names are
  46132. -     added to `enum machine_mode' and all have class `MODE_CC'.  By
  46133. -     convention, they should start with `CC' and end with `mode'.
  46134. -
  46135. -     You should only define this macro if your machine does not use
  46136. -     `cc0' and only if additional modes are required.
  46137. -
  46138. -`EXTRA_CC_NAMES'
  46139. -     A list of C strings giving the names for the modes listed in
  46140. -     `EXTRA_CC_MODES'.  For example, the Sparc defines this macro and
  46141. -     `EXTRA_CC_MODES' as
  46142. -
  46143. -          #define EXTRA_CC_MODES CC_NOOVmode, CCFPmode, CCFPEmode
  46144. -          #define EXTRA_CC_NAMES "CC_NOOV", "CCFP", "CCFPE"
  46145. -
  46146. -     This macro is not required if `EXTRA_CC_MODES' is not defined.
  46147. -
  46148. -`SELECT_CC_MODE (OP, X, Y)'
  46149. -     Returns a mode from class `MODE_CC' to be used when comparison
  46150. -     operation code OP is applied to rtx X and Y.  For example, on the
  46151. -     Sparc, `SELECT_CC_MODE' is defined as (see *note Jump Patterns::.
  46152. -     for a description of the reason for this definition)
  46153. -
  46154. -          #define SELECT_CC_MODE(OP,X,Y) \
  46155. -            (GET_MODE_CLASS (GET_MODE (X)) == MODE_FLOAT          \
  46156. -             ? ((OP == EQ || OP == NE) ? CCFPmode : CCFPEmode)    \
  46157. -             : ((GET_CODE (X) == PLUS || GET_CODE (X) == MINUS    \
  46158. -                 || GET_CODE (X) == NEG) \
  46159. -                ? CC_NOOVmode : CCmode))
  46160. -
  46161. -     You need not define this macro if `EXTRA_CC_MODES' is not defined.
  46162. -
  46163. -`CANONICALIZE_COMPARISON (CODE, OP0, OP1)'
  46164. -     One some machines not all possible comparisons are defined, but
  46165. -     you can convert an invalid comparison into a valid one.  For
  46166. -     example, the Alpha does not have a `GT' comparison, but you can
  46167. -     use an `LT' comparison instead and swap the order of the operands.
  46168. -
  46169. -     On such machines, define this macro to be a C statement to do any
  46170. -     required conversions.  CODE is the initial comparison code and OP0
  46171. -     and OP1 are the left and right operands of the comparison,
  46172. -     respectively.  You should modify CODE, OP0, and OP1 as required.
  46173. -
  46174. -     GNU CC will not assume that the comparison resulting from this
  46175. -     macro is valid but will see if the resulting insn matches a
  46176. -     pattern in the `md' file.
  46177. -
  46178. -     You need not define this macro if it would never change the
  46179. -     comparison code or operands.
  46180. -
  46181. -`REVERSIBLE_CC_MODE (MODE)'
  46182. -     A C expression whose value is one if it is always safe to reverse a
  46183. -     comparison whose mode is MODE.  If `SELECT_CC_MODE' can ever
  46184. -     return MODE for a floating-point inequality comparison, then
  46185. -     `REVERSIBLE_CC_MODE (MODE)' must be zero.
  46186. -
  46187. -     You need not define this macro if it would always returns zero or
  46188. -     if the floating-point format is anything other than
  46189. -     `IEEE_FLOAT_FORMAT'.  For example, here is the definition used on
  46190. -     the Sparc, where floating-point inequality comparisons are always
  46191. -     given `CCFPEmode':
  46192. -
  46193. -          #define REVERSIBLE_CC_MODE(MODE)  ((MODE) != CCFPEmode)
  46194. -
  46195. -
  46196. -File: gcc.info,  Node: Costs,  Next: Sections,  Prev: Condition Code,  Up: Target Macros
  46197. -
  46198. -Describing Relative Costs of Operations
  46199. -=======================================
  46200. -
  46201. -   These macros let you describe the relative speed of various
  46202. -operations on the target machine.
  46203. -
  46204. -`CONST_COSTS (X, CODE, OUTER_CODE)'
  46205. -     A part of a C `switch' statement that describes the relative costs
  46206. -     of constant RTL expressions.  It must contain `case' labels for
  46207. -     expression codes `const_int', `const', `symbol_ref', `label_ref'
  46208. -     and `const_double'.  Each case must ultimately reach a `return'
  46209. -     statement to return the relative cost of the use of that kind of
  46210. -     constant value in an expression.  The cost may depend on the
  46211. -     precise value of the constant, which is available for examination
  46212. -     in X, and the rtx code of the expression in which it is contained,
  46213. -     found in OUTER_CODE.
  46214. -
  46215. -     CODE is the expression code--redundant, since it can be obtained
  46216. -     with `GET_CODE (X)'.
  46217. -
  46218. -`RTX_COSTS (X, CODE, OUTER_CODE)'
  46219. -     Like `CONST_COSTS' but applies to nonconstant RTL expressions.
  46220. -     This can be used, for example, to indicate how costly a multiply
  46221. -     instruction is.  In writing this macro, you can use the construct
  46222. -     `COSTS_N_INSNS (N)' to specify a cost equal to N fast
  46223. -     instructions.  OUTER_CODE is the code of the expression in which X
  46224. -     is contained.
  46225. -
  46226. -     This macro is optional; do not define it if the default cost
  46227. -     assumptions are adequate for the target machine.
  46228. -
  46229. -`ADDRESS_COST (ADDRESS)'
  46230. -     An expression giving the cost of an addressing mode that contains
  46231. -     ADDRESS.  If not defined, the cost is computed from the ADDRESS
  46232. -     expression and the `CONST_COSTS' values.
  46233. -
  46234. -     For most CISC machines, the default cost is a good approximation
  46235. -     of the true cost of the addressing mode.  However, on RISC
  46236. -     machines, all instructions normally have the same length and
  46237. -     execution time.  Hence all addresses will have equal costs.
  46238. -
  46239. -     In cases where more than one form of an address is known, the form
  46240. -     with the lowest cost will be used.  If multiple forms have the
  46241. -     same, lowest, cost, the one that is the most complex will be used.
  46242. -
  46243. -     For example, suppose an address that is equal to the sum of a
  46244. -     register and a constant is used twice in the same basic block.
  46245. -     When this macro is not defined, the address will be computed in a
  46246. -     register and memory references will be indirect through that
  46247. -     register.  On machines where the cost of the addressing mode
  46248. -     containing the sum is no higher than that of a simple indirect
  46249. -     reference, this will produce an additional instruction and
  46250. -     possibly require an additional register.  Proper specification of
  46251. -     this macro eliminates this overhead for such machines.
  46252. -
  46253. -     Similar use of this macro is made in strength reduction of loops.
  46254. -
  46255. -     ADDRESS need not be valid as an address.  In such a case, the cost
  46256. -     is not relevant and can be any value; invalid addresses need not be
  46257. -     assigned a different cost.
  46258. -
  46259. -     On machines where an address involving more than one register is as
  46260. -     cheap as an address computation involving only one register,
  46261. -     defining `ADDRESS_COST' to reflect this can cause two registers to
  46262. -     be live over a region of code where only one would have been if
  46263. -     `ADDRESS_COST' were not defined in that manner.  This effect should
  46264. -     be considered in the definition of this macro.  Equivalent costs
  46265. -     should probably only be given to addresses with different numbers
  46266. -     of registers on machines with lots of registers.
  46267. -
  46268. -     This macro will normally either not be defined or be defined as a
  46269. -     constant.
  46270. -
  46271. -`REGISTER_MOVE_COST (FROM, TO)'
  46272. -     A C expression for the cost of moving data from a register in class
  46273. -     FROM to one in class TO.  The classes are expressed using the
  46274. -     enumeration values such as `GENERAL_REGS'.  A value of 4 is the
  46275. -     default; other values are interpreted relative to that.
  46276. -
  46277. -     It is not required that the cost always equal 2 when FROM is the
  46278. -     same as TO; on some machines it is expensive to move between
  46279. -     registers if they are not general registers.
  46280. -
  46281. -     If reload sees an insn consisting of a single `set' between two
  46282. -     hard registers, and if `REGISTER_MOVE_COST' applied to their
  46283. -     classes returns a value of 2, reload does not check to ensure that
  46284. -     the constraints of the insn are met.  Setting a cost of other than
  46285. -     2 will allow reload to verify that the constraints are met.  You
  46286. -     should do this if the `movM' pattern's constraints do not allow
  46287. -     such copying.
  46288. -
  46289. -`MEMORY_MOVE_COST (M)'
  46290. -     A C expression for the cost of moving data of mode M between a
  46291. -     register and memory.  A value of 2 is the default; this cost is
  46292. -     relative to those in `REGISTER_MOVE_COST'.
  46293. -
  46294. -     If moving between registers and memory is more expensive than
  46295. -     between two registers, you should define this macro to express the
  46296. -     relative cost.
  46297. -
  46298. -`BRANCH_COST'
  46299. -     A C expression for the cost of a branch instruction.  A value of 1
  46300. -     is the default; other values are interpreted relative to that.
  46301. -
  46302. -   Here are additional macros which do not specify precise relative
  46303. -costs, but only that certain actions are more expensive than GNU CC
  46304. -would ordinarily expect.
  46305. -
  46306. -`SLOW_BYTE_ACCESS'
  46307. -     Define this macro as a C expression which is nonzero if accessing
  46308. -     less than a word of memory (i.e. a `char' or a `short') is no
  46309. -     faster than accessing a word of memory, i.e., if such access
  46310. -     require more than one instruction or if there is no difference in
  46311. -     cost between byte and (aligned) word loads.
  46312. -
  46313. -     When this macro is not defined, the compiler will access a field by
  46314. -     finding the smallest containing object; when it is defined, a
  46315. -     fullword load will be used if alignment permits.  Unless bytes
  46316. -     accesses are faster than word accesses, using word accesses is
  46317. -     preferable since it may eliminate subsequent memory access if
  46318. -     subsequent accesses occur to other fields in the same word of the
  46319. -     structure, but to different bytes.
  46320. -
  46321. -`SLOW_ZERO_EXTEND'
  46322. -     Define this macro if zero-extension (of a `char' or `short' to an
  46323. -     `int') can be done faster if the destination is a register that is
  46324. -     known to be zero.
  46325. -
  46326. -     If you define this macro, you must have instruction patterns that
  46327. -     recognize RTL structures like this:
  46328. -
  46329. -          (set (strict_low_part (subreg:QI (reg:SI ...) 0)) ...)
  46330. -
  46331. -     and likewise for `HImode'.
  46332. -
  46333. -`SLOW_UNALIGNED_ACCESS'
  46334. -     Define this macro to be the value 1 if unaligned accesses have a
  46335. -     cost many times greater than aligned accesses, for example if they
  46336. -     are emulated in a trap handler.
  46337. -
  46338. -     When this macro is non-zero, the compiler will act as if
  46339. -     `STRICT_ALIGNMENT' were non-zero when generating code for block
  46340. -     moves.  This can cause significantly more instructions to be
  46341. -     produced.  Therefore, do not set this macro non-zero if unaligned
  46342. -     accesses only add a cycle or two to the time for a memory access.
  46343. -
  46344. -     If the value of this macro is always zero, it need not be defined.
  46345. -
  46346. -`DONT_REDUCE_ADDR'
  46347. -     Define this macro to inhibit strength reduction of memory
  46348. -     addresses.  (On some machines, such strength reduction seems to do
  46349. -     harm rather than good.)
  46350. -
  46351. -`MOVE_RATIO'
  46352. -     The number of scalar move insns which should be generated instead
  46353. -     of a string move insn or a library call.  Increasing the value
  46354. -     will always make code faster, but eventually incurs high cost in
  46355. -     increased code size.
  46356. -
  46357. -     If you don't define this, a reasonable default is used.
  46358. -
  46359. -`NO_FUNCTION_CSE'
  46360. -     Define this macro if it is as good or better to call a constant
  46361. -     function address than to call an address kept in a register.
  46362. -
  46363. -`NO_RECURSIVE_FUNCTION_CSE'
  46364. -     Define this macro if it is as good or better for a function to call
  46365. -     itself with an explicit address than to call an address kept in a
  46366. -     register.
  46367. -
  46368. -`ADJUST_COST (INSN, LINK, DEP_INSN, COST)'
  46369. -     A C statement (sans semicolon) to update the integer variable COST
  46370. -     based on the relationship between INSN that is dependent on
  46371. -     DEP_INSN through the dependence LINK.  The default is to make no
  46372. -     adjustment to COST.  This can be used for example to specify to
  46373. -     the scheduler that an output- or anti-dependence does not incur
  46374. -     the same cost as a data-dependence.
  46375. -
  46376. -
  46377. -File: gcc.info,  Node: Sections,  Next: PIC,  Prev: Costs,  Up: Target Macros
  46378. -
  46379. -Dividing the Output into Sections (Texts, Data, ...)
  46380. -====================================================
  46381. -
  46382. -   An object file is divided into sections containing different types of
  46383. -data.  In the most common case, there are three sections: the "text
  46384. -section", which holds instructions and read-only data; the "data
  46385. -section", which holds initialized writable data; and the "bss section",
  46386. -which holds uninitialized data.  Some systems have other kinds of
  46387. -sections.
  46388. -
  46389. -   The compiler must tell the assembler when to switch sections.  These
  46390. -macros control what commands to output to tell the assembler this.  You
  46391. -can also define additional sections.
  46392. -
  46393. -`TEXT_SECTION_ASM_OP'
  46394. -     A C expression whose value is a string containing the assembler
  46395. -     operation that should precede instructions and read-only data.
  46396. -     Normally `".text"' is right.
  46397. -
  46398. -`DATA_SECTION_ASM_OP'
  46399. -     A C expression whose value is a string containing the assembler
  46400. -     operation to identify the following data as writable initialized
  46401. -     data.  Normally `".data"' is right.
  46402. -
  46403. -`SHARED_SECTION_ASM_OP'
  46404. -     if defined, a C expression whose value is a string containing the
  46405. -     assembler operation to identify the following data as shared data.
  46406. -     If not defined, `DATA_SECTION_ASM_OP' will be used.
  46407. -
  46408. -`INIT_SECTION_ASM_OP'
  46409. -     if defined, a C expression whose value is a string containing the
  46410. -     assembler operation to identify the following data as
  46411. -     initialization code.  If not defined, GNU CC will assume such a
  46412. -     section does not exist.
  46413. -
  46414. -`EXTRA_SECTIONS'
  46415. -     A list of names for sections other than the standard two, which are
  46416. -     `in_text' and `in_data'.  You need not define this macro on a
  46417. -     system with no other sections (that GCC needs to use).
  46418. -
  46419. -`EXTRA_SECTION_FUNCTIONS'
  46420. -     One or more functions to be defined in `varasm.c'.  These
  46421. -     functions should do jobs analogous to those of `text_section' and
  46422. -     `data_section', for your additional sections.  Do not define this
  46423. -     macro if you do not define `EXTRA_SECTIONS'.
  46424. -
  46425. -`READONLY_DATA_SECTION'
  46426. -     On most machines, read-only variables, constants, and jump tables
  46427. -     are placed in the text section.  If this is not the case on your
  46428. -     machine, this macro should be defined to be the name of a function
  46429. -     (either `data_section' or a function defined in `EXTRA_SECTIONS')
  46430. -     that switches to the section to be used for read-only items.
  46431. -
  46432. -     If these items should be placed in the text section, this macro
  46433. -     should not be defined.
  46434. -
  46435. -`SELECT_SECTION (EXP, RELOC)'
  46436. -     A C statement or statements to switch to the appropriate section
  46437. -     for output of EXP.  You can assume that EXP is either a `VAR_DECL'
  46438. -     node or a constant of some sort.  RELOC indicates whether the
  46439. -     initial value of EXP requires link-time relocations.  Select the
  46440. -     section by calling `text_section' or one of the alternatives for
  46441. -     other sections.
  46442. -
  46443. -     Do not define this macro if you put all read-only variables and
  46444. -     constants in the read-only data section (usually the text section).
  46445. -
  46446. -`SELECT_RTX_SECTION (MODE, RTX)'
  46447. -     A C statement or statements to switch to the appropriate section
  46448. -     for output of RTX in mode MODE.  You can assume that RTX is some
  46449. -     kind of constant in RTL.  The argument MODE is redundant except in
  46450. -     the case of a `const_int' rtx.  Select the section by calling
  46451. -     `text_section' or one of the alternatives for other sections.
  46452. -
  46453. -     Do not define this macro if you put all constants in the read-only
  46454. -     data section.
  46455. -
  46456. -`JUMP_TABLES_IN_TEXT_SECTION'
  46457. -     Define this macro if jump tables (for `tablejump' insns) should be
  46458. -     output in the text section, along with the assembler instructions.
  46459. -     Otherwise, the readonly data section is used.
  46460. -
  46461. -     This macro is irrelevant if there is no separate readonly data
  46462. -     section.
  46463. -
  46464. -`ENCODE_SECTION_INFO (DECL)'
  46465. -     Define this macro if references to a symbol must be treated
  46466. -     differently depending on something about the variable or function
  46467. -     named by the symbol (such as what section it is in).
  46468. -
  46469. -     The macro definition, if any, is executed immediately after the
  46470. -     rtl for DECL has been created and stored in `DECL_RTL (DECL)'.
  46471. -     The value of the rtl will be a `mem' whose address is a
  46472. -     `symbol_ref'.
  46473. -
  46474. -     The usual thing for this macro to do is to record a flag in the
  46475. -     `symbol_ref' (such as `SYMBOL_REF_FLAG') or to store a modified
  46476. -     name string in the `symbol_ref' (if one bit is not enough
  46477. -     information).
  46478. -
  46479. -`STRIP_NAME_ENCODING (VAR, SYM_NAME)'
  46480. -     Decode SYM_NAME and store the real name part in VAR, sans the
  46481. -     characters that encode section info.  Define this macro if
  46482. -     `ENCODE_SECTION_INFO' alters the symbol's name string.
  46483. -
  46484. -
  46485. -File: gcc.info,  Node: PIC,  Next: Assembler Format,  Prev: Sections,  Up: Target Macros
  46486. -
  46487. -Position Independent Code
  46488. -=========================
  46489. -
  46490. -   This section describes macros that help implement generation of
  46491. -position independent code.  Simply defining these macros is not enough
  46492. -to generate valid PIC; you must also add support to the macros
  46493. -`GO_IF_LEGITIMATE_ADDRESS' and `PRINT_OPERAND_ADDRESS', as well as
  46494. -`LEGITIMIZE_ADDRESS'.  You must modify the definition of `movsi' to do
  46495. -something appropriate when the source operand contains a symbolic
  46496. -address.  You may also need to alter the handling of switch statements
  46497. -so that they use relative addresses.
  46498. -
  46499. -`PIC_OFFSET_TABLE_REGNUM'
  46500. -     The register number of the register used to address a table of
  46501. -     static data addresses in memory.  In some cases this register is
  46502. -     defined by a processor's "application binary interface" (ABI).
  46503. -     When this macro is defined, RTL is generated for this register
  46504. -     once, as with the stack pointer and frame pointer registers.  If
  46505. -     this macro is not defined, it is up to the machine-dependent files
  46506. -     to allocate such a register (if necessary).
  46507. -
  46508. -`PIC_OFFSET_TABLE_REG_CALL_CLOBBERED'
  46509. -     Define this macro if the register defined by
  46510. -     `PIC_OFFSET_TABLE_REGNUM' is clobbered by calls.  Do not define
  46511. -     this macro if `PPIC_OFFSET_TABLE_REGNUM' is not defined.
  46512. -
  46513. -`FINALIZE_PIC'
  46514. -     By generating position-independent code, when two different
  46515. -     programs (A and B) share a common library (libC.a), the text of
  46516. -     the library can be shared whether or not the library is linked at
  46517. -     the same address for both programs.  In some of these
  46518. -     environments, position-independent code requires not only the use
  46519. -     of different addressing modes, but also special code to enable the
  46520. -     use of these addressing modes.
  46521. -
  46522. -     The `FINALIZE_PIC' macro serves as a hook to emit these special
  46523. -     codes once the function is being compiled into assembly code, but
  46524. -     not before.  (It is not done before, because in the case of
  46525. -     compiling an inline function, it would lead to multiple PIC
  46526. -     prologues being included in functions which used inline functions
  46527. -     and were compiled to assembly language.)
  46528. -
  46529. -`LEGITIMATE_PIC_OPERAND_P (X)'
  46530. -     A C expression that is nonzero if X is a legitimate immediate
  46531. -     operand on the target machine when generating position independent
  46532. -     code.  You can assume that X satisfies `CONSTANT_P', so you need
  46533. -     not check this.  You can also assume FLAG_PIC is true, so you need
  46534. -     not check it either.  You need not define this macro if all
  46535. -     constants (including `SYMBOL_REF') can be immediate operands when
  46536. -     generating position independent code.
  46537. -
  46538. -
  46539. -File: gcc.info,  Node: Assembler Format,  Next: Debugging Info,  Prev: PIC,  Up: Target Macros
  46540. -
  46541. -Defining the Output Assembler Language
  46542. -======================================
  46543. -
  46544. -   This section describes macros whose principal purpose is to describe
  46545. -how to write instructions in assembler language-rather than what the
  46546. -instructions do.
  46547. -
  46548. -* Menu:
  46549. -
  46550. -* File Framework::       Structural information for the assembler file.
  46551. -* Data Output::          Output of constants (numbers, strings, addresses).
  46552. -* Uninitialized Data::   Output of uninitialized variables.
  46553. -* Label Output::         Output and generation of labels.
  46554. -* Initialization::       General principles of initialization
  46555. -               and termination routines.
  46556. -* Macros for Initialization::
  46557. -             Specific macros that control the handling of
  46558. -               initialization and termination routines.
  46559. -* Instruction Output::   Output of actual instructions.
  46560. -* Dispatch Tables::      Output of jump tables.
  46561. -* Alignment Output::     Pseudo ops for alignment and skipping data.
  46562. -
  46563. -
  46564. -File: gcc.info,  Node: File Framework,  Next: Data Output,  Up: Assembler Format
  46565. -
  46566. -The Overall Framework of an Assembler File
  46567. -------------------------------------------
  46568. -
  46569. -   This describes the overall framework of an assembler file.
  46570. -
  46571. -`ASM_FILE_START (STREAM)'
  46572. -     A C expression which outputs to the stdio stream STREAM some
  46573. -     appropriate text to go at the start of an assembler file.
  46574. -
  46575. -     Normally this macro is defined to output a line containing
  46576. -     `#NO_APP', which is a comment that has no effect on most
  46577. -     assemblers but tells the GNU assembler that it can save time by not
  46578. -     checking for certain assembler constructs.
  46579. -
  46580. -     On systems that use SDB, it is necessary to output certain
  46581. -     commands; see `attasm.h'.
  46582. -
  46583. -`ASM_FILE_END (STREAM)'
  46584. -     A C expression which outputs to the stdio stream STREAM some
  46585. -     appropriate text to go at the end of an assembler file.
  46586. -
  46587. -     If this macro is not defined, the default is to output nothing
  46588. -     special at the end of the file.  Most systems don't require any
  46589. -     definition.
  46590. -
  46591. -     On systems that use SDB, it is necessary to output certain
  46592. -     commands; see `attasm.h'.
  46593. -
  46594. -`ASM_IDENTIFY_GCC (FILE)'
  46595. -     A C statement to output assembler commands which will identify the
  46596. -     object file as having been compiled with GNU CC (or another GNU
  46597. -     compiler).
  46598. -
  46599. -     If you don't define this macro, the string `gcc_compiled.:' is
  46600. -     output.  This string is calculated to define a symbol which, on
  46601. -     BSD systems, will never be defined for any other reason.  GDB
  46602. -     checks for the presence of this symbol when reading the symbol
  46603. -     table of an executable.
  46604. -
  46605. -     On non-BSD systems, you must arrange communication with GDB in
  46606. -     some other fashion.  If GDB is not used on your system, you can
  46607. -     define this macro with an empty body.
  46608. -
  46609. -`ASM_COMMENT_START'
  46610. -     A C string constant describing how to begin a comment in the target
  46611. -     assembler language.  The compiler assumes that the comment will
  46612. -     end at the end of the line.
  46613. -
  46614. -`ASM_APP_ON'
  46615. -     A C string constant for text to be output before each `asm'
  46616. -     statement or group of consecutive ones.  Normally this is
  46617. -     `"#APP"', which is a comment that has no effect on most assemblers
  46618. -     but tells the GNU assembler that it must check the lines that
  46619. -     follow for all valid assembler constructs.
  46620. -
  46621. -`ASM_APP_OFF'
  46622. -     A C string constant for text to be output after each `asm'
  46623. -     statement or group of consecutive ones.  Normally this is
  46624. -     `"#NO_APP"', which tells the GNU assembler to resume making the
  46625. -     time-saving assumptions that are valid for ordinary compiler
  46626. -     output.
  46627. -
  46628. -`ASM_OUTPUT_SOURCE_FILENAME (STREAM, NAME)'
  46629. -     A C statement to output COFF information or DWARF debugging
  46630. -     information which indicates that filename NAME is the current
  46631. -     source file to the stdio stream STREAM.
  46632. -
  46633. -     This macro need not be defined if the standard form of output for
  46634. -     the file format in use is appropriate.
  46635. -
  46636. -`ASM_OUTPUT_SOURCE_LINE (STREAM, LINE)'
  46637. -     A C statement to output DBX or SDB debugging information before
  46638. -     code for line number LINE of the current source file to the stdio
  46639. -     stream STREAM.
  46640. -
  46641. -     This macro need not be defined if the standard form of debugging
  46642. -     information for the debugger in use is appropriate.
  46643. -
  46644. -`ASM_OUTPUT_IDENT (STREAM, STRING)'
  46645. -     A C statement to output something to the assembler file to handle a
  46646. -     `#ident' directive containing the text STRING.  If this macro is
  46647. -     not defined, nothing is output for a `#ident' directive.
  46648. -
  46649. -`ASM_OUTPUT_SECTION_NAME (STREAM, DECL, NAME)'
  46650. -     A C statement to output something to the assembler file to switch
  46651. -     to section NAME for object DECL which is either a `FUNCTION_DECL',
  46652. -     a `VAR_DECL' or `NULL_TREE'.  Some target formats do not support
  46653. -     arbitrary sections.  Do not define this macro in such cases.
  46654. -
  46655. -     At present this macro is only used to support section attributes.
  46656. -     When this macro is undefined, section attributes are disabled.
  46657. -
  46658. -`OBJC_PROLOGUE'
  46659. -     A C statement to output any assembler statements which are
  46660. -     required to precede any Objective C object definitions or message
  46661. -     sending.  The statement is executed only when compiling an
  46662. -     Objective C program.
  46663. -
  46664. -
  46665. -File: gcc.info,  Node: Data Output,  Next: Uninitialized Data,  Prev: File Framework,  Up: Assembler Format
  46666. -
  46667. -Output of Data
  46668. ---------------
  46669. -
  46670. -   This describes data output.
  46671. -
  46672. -`ASM_OUTPUT_LONG_DOUBLE (STREAM, VALUE)'
  46673. -`ASM_OUTPUT_DOUBLE (STREAM, VALUE)'
  46674. -`ASM_OUTPUT_FLOAT (STREAM, VALUE)'
  46675. -`ASM_OUTPUT_THREE_QUARTER_FLOAT (STREAM, VALUE)'
  46676. -`ASM_OUTPUT_SHORT_FLOAT (STREAM, VALUE)'
  46677. -`ASM_OUTPUT_BYTE_FLOAT (STREAM, VALUE)'
  46678. -     A C statement to output to the stdio stream STREAM an assembler
  46679. -     instruction to assemble a floating-point constant of `TFmode',
  46680. -     `DFmode', `SFmode', `TQFmode', `HFmode', or `QFmode',
  46681. -     respectively, whose value is VALUE.  VALUE will be a C expression
  46682. -     of type `REAL_VALUE_TYPE'.  Macros such as
  46683. -     `REAL_VALUE_TO_TARGET_DOUBLE' are useful for writing these
  46684. -     definitions.
  46685. -
  46686. -`ASM_OUTPUT_QUADRUPLE_INT (STREAM, EXP)'
  46687. -`ASM_OUTPUT_DOUBLE_INT (STREAM, EXP)'
  46688. -`ASM_OUTPUT_INT (STREAM, EXP)'
  46689. -`ASM_OUTPUT_SHORT (STREAM, EXP)'
  46690. -`ASM_OUTPUT_CHAR (STREAM, EXP)'
  46691. -     A C statement to output to the stdio stream STREAM an assembler
  46692. -     instruction to assemble an integer of 16, 8, 4, 2 or 1 bytes,
  46693. -     respectively, whose value is VALUE.  The argument EXP will be an
  46694. -     RTL expression which represents a constant value.  Use
  46695. -     `output_addr_const (STREAM, EXP)' to output this value as an
  46696. -     assembler expression.
  46697. -
  46698. -     For sizes larger than `UNITS_PER_WORD', if the action of a macro
  46699. -     would be identical to repeatedly calling the macro corresponding to
  46700. -     a size of `UNITS_PER_WORD', once for each word, you need not define
  46701. -     the macro.
  46702. -
  46703. -`ASM_OUTPUT_BYTE (STREAM, VALUE)'
  46704. -     A C statement to output to the stdio stream STREAM an assembler
  46705. -     instruction to assemble a single byte containing the number VALUE.
  46706. -
  46707. -`ASM_BYTE_OP'
  46708. -     A C string constant giving the pseudo-op to use for a sequence of
  46709. -     single-byte constants.  If this macro is not defined, the default
  46710. -     is `"byte"'.
  46711. -
  46712. -`ASM_OUTPUT_ASCII (STREAM, PTR, LEN)'
  46713. -     A C statement to output to the stdio stream STREAM an assembler
  46714. -     instruction to assemble a string constant containing the LEN bytes
  46715. -     at PTR.  PTR will be a C expression of type `char *' and LEN a C
  46716. -     expression of type `int'.
  46717. -
  46718. -     If the assembler has a `.ascii' pseudo-op as found in the Berkeley
  46719. -     Unix assembler, do not define the macro `ASM_OUTPUT_ASCII'.
  46720. -
  46721. -`ASM_OUTPUT_POOL_PROLOGUE (FILE FUNNAME FUNDECL SIZE)'
  46722. -     A C statement to output assembler commands to define the start of
  46723. -     the constant pool for a function.  FUNNAME is a string giving the
  46724. -     name of the function.  Should the return type of the function be
  46725. -     required, it can be obtained via FUNDECL.  SIZE is the size, in
  46726. -     bytes, of the constant pool that will be written immediately after
  46727. -     this call.
  46728. -
  46729. -     If no constant-pool prefix is required, the usual case, this macro
  46730. -     need not be defined.
  46731. -
  46732. -`ASM_OUTPUT_SPECIAL_POOL_ENTRY (FILE, X, MODE, ALIGN, LABELNO, JUMPTO)'
  46733. -     A C statement (with or without semicolon) to output a constant in
  46734. -     the constant pool, if it needs special treatment.  (This macro
  46735. -     need not do anything for RTL expressions that can be output
  46736. -     normally.)
  46737. -
  46738. -     The argument FILE is the standard I/O stream to output the
  46739. -     assembler code on.  X is the RTL expression for the constant to
  46740. -     output, and MODE is the machine mode (in case X is a `const_int').
  46741. -     ALIGN is the required alignment for the value X; you should
  46742. -     output an assembler directive to force this much alignment.
  46743. -
  46744. -     The argument LABELNO is a number to use in an internal label for
  46745. -     the address of this pool entry.  The definition of this macro is
  46746. -     responsible for outputting the label definition at the proper
  46747. -     place.  Here is how to do this:
  46748. -
  46749. -          ASM_OUTPUT_INTERNAL_LABEL (FILE, "LC", LABELNO);
  46750. -
  46751. -     When you output a pool entry specially, you should end with a
  46752. -     `goto' to the label JUMPTO.  This will prevent the same pool entry
  46753. -     from being output a second time in the usual manner.
  46754. -
  46755. -     You need not define this macro if it would do nothing.
  46756. -
  46757. -`IS_ASM_LOGICAL_LINE_SEPARATOR (C)'
  46758. -     Define this macro as a C expression which is nonzero if C is used
  46759. -     as a logical line separator by the assembler.
  46760. -
  46761. -     If you do not define this macro, the default is that only the
  46762. -     character `;' is treated as a logical line separator.
  46763. -
  46764. -`ASM_OPEN_PAREN'
  46765. -`ASM_CLOSE_PAREN'
  46766. -     These macros are defined as C string constant, describing the
  46767. -     syntax in the assembler for grouping arithmetic expressions.  The
  46768. -     following definitions are correct for most assemblers:
  46769. -
  46770. -          #define ASM_OPEN_PAREN "("
  46771. -          #define ASM_CLOSE_PAREN ")"
  46772. -
  46773. -   These macros are provided by `real.h' for writing the definitions of
  46774. -`ASM_OUTPUT_DOUBLE' and the like:
  46775. -
  46776. -`REAL_VALUE_TO_TARGET_SINGLE (X, L)'
  46777. -`REAL_VALUE_TO_TARGET_DOUBLE (X, L)'
  46778. -`REAL_VALUE_TO_TARGET_LONG_DOUBLE (X, L)'
  46779. -     These translate X, of type `REAL_VALUE_TYPE', to the target's
  46780. -     floating point representation, and store its bit pattern in the
  46781. -     array of `long int' whose address is L.  The number of elements in
  46782. -     the output array is determined by the size of the desired target
  46783. -     floating point data type: 32 bits of it go in each `long int' array
  46784. -     element.  Each array element holds 32 bits of the result, even if
  46785. -     `long int' is wider than 32 bits on the host machine.
  46786. -
  46787. -     The array element values are designed so that you can print them
  46788. -     out using `fprintf' in the order they should appear in the target
  46789. -     machine's memory.
  46790. -
  46791. -`REAL_VALUE_TO_DECIMAL (X, FORMAT, STRING)'
  46792. -     This macro converts X, of type `REAL_VALUE_TYPE', to a decimal
  46793. -     number and stores it as a string into STRING.  You must pass, as
  46794. -     STRING, the address of a long enough block of space to hold the
  46795. -     result.
  46796. -
  46797. -     The argument FORMAT is a `printf'-specification that serves as a
  46798. -     suggestion for how to format the output string.
  46799. -
  46800. diff -rup --new-file baseline/fsf/gcc/gcc.info-23 amiga/fsf/gcc/gcc.info-23
  46801. --- baseline/fsf/gcc/gcc.info-23    Sat Jun 29 09:38:09 1996
  46802. +++ amiga/fsf/gcc/gcc.info-23    Wed Dec 31 17:00:00 1969
  46803. @@ -1,1146 +0,0 @@
  46804. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  46805. -file gcc.texi.
  46806. -
  46807. -   This file documents the use and the internals of the GNU compiler.
  46808. -
  46809. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  46810. -Boston, MA 02111-1307 USA
  46811. -
  46812. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  46813. -Foundation, Inc.
  46814. -
  46815. -   Permission is granted to make and distribute verbatim copies of this
  46816. -manual provided the copyright notice and this permission notice are
  46817. -preserved on all copies.
  46818. -
  46819. -   Permission is granted to copy and distribute modified versions of
  46820. -this manual under the conditions for verbatim copying, provided also
  46821. -that the sections entitled "GNU General Public License," "Funding for
  46822. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  46823. -included exactly as in the original, and provided that the entire
  46824. -resulting derived work is distributed under the terms of a permission
  46825. -notice identical to this one.
  46826. -
  46827. -   Permission is granted to copy and distribute translations of this
  46828. -manual into another language, under the above conditions for modified
  46829. -versions, except that the sections entitled "GNU General Public
  46830. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  46831. -`Look And Feel'", and this permission notice, may be included in
  46832. -translations approved by the Free Software Foundation instead of in the
  46833. -original English.
  46834. -
  46835. -
  46836. -File: gcc.info,  Node: Uninitialized Data,  Next: Label Output,  Prev: Data Output,  Up: Assembler Format
  46837. -
  46838. -Output of Uninitialized Variables
  46839. ----------------------------------
  46840. -
  46841. -   Each of the macros in this section is used to do the whole job of
  46842. -outputting a single uninitialized variable.
  46843. -
  46844. -`ASM_OUTPUT_COMMON (STREAM, NAME, SIZE, ROUNDED)'
  46845. -     A C statement (sans semicolon) to output to the stdio stream
  46846. -     STREAM the assembler definition of a common-label named NAME whose
  46847. -     size is SIZE bytes.  The variable ROUNDED is the size rounded up
  46848. -     to whatever alignment the caller wants.
  46849. -
  46850. -     Use the expression `assemble_name (STREAM, NAME)' to output the
  46851. -     name itself; before and after that, output the additional
  46852. -     assembler syntax for defining the name, and a newline.
  46853. -
  46854. -     This macro controls how the assembler definitions of uninitialized
  46855. -     global variables are output.
  46856. -
  46857. -`ASM_OUTPUT_ALIGNED_COMMON (STREAM, NAME, SIZE, ALIGNMENT)'
  46858. -     Like `ASM_OUTPUT_COMMON' except takes the required alignment as a
  46859. -     separate, explicit argument.  If you define this macro, it is used
  46860. -     in place of `ASM_OUTPUT_COMMON', and gives you more flexibility in
  46861. -     handling the required alignment of the variable.  The alignment is
  46862. -     specified as the number of bits.
  46863. -
  46864. -`ASM_OUTPUT_SHARED_COMMON (STREAM, NAME, SIZE, ROUNDED)'
  46865. -     If defined, it is similar to `ASM_OUTPUT_COMMON', except that it
  46866. -     is used when NAME is shared.  If not defined, `ASM_OUTPUT_COMMON'
  46867. -     will be used.
  46868. -
  46869. -`ASM_OUTPUT_LOCAL (STREAM, NAME, SIZE, ROUNDED)'
  46870. -     A C statement (sans semicolon) to output to the stdio stream
  46871. -     STREAM the assembler definition of a local-common-label named NAME
  46872. -     whose size is SIZE bytes.  The variable ROUNDED is the size
  46873. -     rounded up to whatever alignment the caller wants.
  46874. -
  46875. -     Use the expression `assemble_name (STREAM, NAME)' to output the
  46876. -     name itself; before and after that, output the additional
  46877. -     assembler syntax for defining the name, and a newline.
  46878. -
  46879. -     This macro controls how the assembler definitions of uninitialized
  46880. -     static variables are output.
  46881. -
  46882. -`ASM_OUTPUT_ALIGNED_LOCAL (STREAM, NAME, SIZE, ALIGNMENT)'
  46883. -     Like `ASM_OUTPUT_LOCAL' except takes the required alignment as a
  46884. -     separate, explicit argument.  If you define this macro, it is used
  46885. -     in place of `ASM_OUTPUT_LOCAL', and gives you more flexibility in
  46886. -     handling the required alignment of the variable.  The alignment is
  46887. -     specified as the number of bits.
  46888. -
  46889. -`ASM_OUTPUT_SHARED_LOCAL (STREAM, NAME, SIZE, ROUNDED)'
  46890. -     If defined, it is similar to `ASM_OUTPUT_LOCAL', except that it is
  46891. -     used when NAME is shared.  If not defined, `ASM_OUTPUT_LOCAL' will
  46892. -     be used.
  46893. -
  46894. -
  46895. -File: gcc.info,  Node: Label Output,  Next: Initialization,  Prev: Uninitialized Data,  Up: Assembler Format
  46896. -
  46897. -Output and Generation of Labels
  46898. --------------------------------
  46899. -
  46900. -   This is about outputting labels.
  46901. -
  46902. -`ASM_OUTPUT_LABEL (STREAM, NAME)'
  46903. -     A C statement (sans semicolon) to output to the stdio stream
  46904. -     STREAM the assembler definition of a label named NAME.  Use the
  46905. -     expression `assemble_name (STREAM, NAME)' to output the name
  46906. -     itself; before and after that, output the additional assembler
  46907. -     syntax for defining the name, and a newline.
  46908. -
  46909. -`ASM_DECLARE_FUNCTION_NAME (STREAM, NAME, DECL)'
  46910. -     A C statement (sans semicolon) to output to the stdio stream
  46911. -     STREAM any text necessary for declaring the name NAME of a
  46912. -     function which is being defined.  This macro is responsible for
  46913. -     outputting the label definition (perhaps using
  46914. -     `ASM_OUTPUT_LABEL').  The argument DECL is the `FUNCTION_DECL'
  46915. -     tree node representing the function.
  46916. -
  46917. -     If this macro is not defined, then the function name is defined in
  46918. -     the usual manner as a label (by means of `ASM_OUTPUT_LABEL').
  46919. -
  46920. -`ASM_DECLARE_FUNCTION_SIZE (STREAM, NAME, DECL)'
  46921. -     A C statement (sans semicolon) to output to the stdio stream
  46922. -     STREAM any text necessary for declaring the size of a function
  46923. -     which is being defined.  The argument NAME is the name of the
  46924. -     function.  The argument DECL is the `FUNCTION_DECL' tree node
  46925. -     representing the function.
  46926. -
  46927. -     If this macro is not defined, then the function size is not
  46928. -     defined.
  46929. -
  46930. -`ASM_DECLARE_OBJECT_NAME (STREAM, NAME, DECL)'
  46931. -     A C statement (sans semicolon) to output to the stdio stream
  46932. -     STREAM any text necessary for declaring the name NAME of an
  46933. -     initialized variable which is being defined.  This macro must
  46934. -     output the label definition (perhaps using `ASM_OUTPUT_LABEL').
  46935. -     The argument DECL is the `VAR_DECL' tree node representing the
  46936. -     variable.
  46937. -
  46938. -     If this macro is not defined, then the variable name is defined in
  46939. -     the usual manner as a label (by means of `ASM_OUTPUT_LABEL').
  46940. -
  46941. -`ASM_FINISH_DECLARE_OBJECT (STREAM, DECL, TOPLEVEL, ATEND)'
  46942. -     A C statement (sans semicolon) to finish up declaring a variable
  46943. -     name once the compiler has processed its initializer fully and
  46944. -     thus has had a chance to determine the size of an array when
  46945. -     controlled by an initializer.  This is used on systems where it's
  46946. -     necessary to declare something about the size of the object.
  46947. -
  46948. -     If you don't define this macro, that is equivalent to defining it
  46949. -     to do nothing.
  46950. -
  46951. -`ASM_GLOBALIZE_LABEL (STREAM, NAME)'
  46952. -     A C statement (sans semicolon) to output to the stdio stream
  46953. -     STREAM some commands that will make the label NAME global; that
  46954. -     is, available for reference from other files.  Use the expression
  46955. -     `assemble_name (STREAM, NAME)' to output the name itself; before
  46956. -     and after that, output the additional assembler syntax for making
  46957. -     that name global, and a newline.
  46958. -
  46959. -`ASM_WEAKEN_LABEL'
  46960. -     A C statement (sans semicolon) to output to the stdio stream
  46961. -     STREAM some commands that will make the label NAME weak; that is,
  46962. -     available for reference from other files but only used if no other
  46963. -     definition is available.  Use the expression `assemble_name
  46964. -     (STREAM, NAME)' to output the name itself; before and after that,
  46965. -     output the additional assembler syntax for making that name weak,
  46966. -     and a newline.
  46967. -
  46968. -     If you don't define this macro, GNU CC will not support weak
  46969. -     symbols and you should not define the `SUPPORTS_WEAK' macro.
  46970. -
  46971. -`SUPPORTS_WEAK'
  46972. -     A C expression which evaluates to true if the target supports weak
  46973. -     symbols.
  46974. -
  46975. -     If you don't define this macro, `defaults.h' provides a default
  46976. -     definition.  If `ASM_WEAKEN_LABEL' is defined, the default
  46977. -     definition is `1'; otherwise, it is `0'.  Define this macro if you
  46978. -     want to control weak symbol support with a compiler flag such as
  46979. -     `-melf'.
  46980. -
  46981. -`ASM_OUTPUT_EXTERNAL (STREAM, DECL, NAME)'
  46982. -     A C statement (sans semicolon) to output to the stdio stream
  46983. -     STREAM any text necessary for declaring the name of an external
  46984. -     symbol named NAME which is referenced in this compilation but not
  46985. -     defined.  The value of DECL is the tree node for the declaration.
  46986. -
  46987. -     This macro need not be defined if it does not need to output
  46988. -     anything.  The GNU assembler and most Unix assemblers don't
  46989. -     require anything.
  46990. -
  46991. -`ASM_OUTPUT_EXTERNAL_LIBCALL (STREAM, SYMREF)'
  46992. -     A C statement (sans semicolon) to output on STREAM an assembler
  46993. -     pseudo-op to declare a library function name external.  The name
  46994. -     of the library function is given by SYMREF, which has type `rtx'
  46995. -     and is a `symbol_ref'.
  46996. -
  46997. -     This macro need not be defined if it does not need to output
  46998. -     anything.  The GNU assembler and most Unix assemblers don't
  46999. -     require anything.
  47000. -
  47001. -`ASM_OUTPUT_LABELREF (STREAM, NAME)'
  47002. -     A C statement (sans semicolon) to output to the stdio stream
  47003. -     STREAM a reference in assembler syntax to a label named NAME.
  47004. -     This should add `_' to the front of the name, if that is customary
  47005. -     on your operating system, as it is in most Berkeley Unix systems.
  47006. -     This macro is used in `assemble_name'.
  47007. -
  47008. -`ASM_OUTPUT_INTERNAL_LABEL (STREAM, PREFIX, NUM)'
  47009. -     A C statement to output to the stdio stream STREAM a label whose
  47010. -     name is made from the string PREFIX and the number NUM.
  47011. -
  47012. -     It is absolutely essential that these labels be distinct from the
  47013. -     labels used for user-level functions and variables.  Otherwise,
  47014. -     certain programs will have name conflicts with internal labels.
  47015. -
  47016. -     It is desirable to exclude internal labels from the symbol table
  47017. -     of the object file.  Most assemblers have a naming convention for
  47018. -     labels that should be excluded; on many systems, the letter `L' at
  47019. -     the beginning of a label has this effect.  You should find out what
  47020. -     convention your system uses, and follow it.
  47021. -
  47022. -     The usual definition of this macro is as follows:
  47023. -
  47024. -          fprintf (STREAM, "L%s%d:\n", PREFIX, NUM)
  47025. -
  47026. -`ASM_GENERATE_INTERNAL_LABEL (STRING, PREFIX, NUM)'
  47027. -     A C statement to store into the string STRING a label whose name
  47028. -     is made from the string PREFIX and the number NUM.
  47029. -
  47030. -     This string, when output subsequently by `assemble_name', should
  47031. -     produce the output that `ASM_OUTPUT_INTERNAL_LABEL' would produce
  47032. -     with the same PREFIX and NUM.
  47033. -
  47034. -     If the string begins with `*', then `assemble_name' will output
  47035. -     the rest of the string unchanged.  It is often convenient for
  47036. -     `ASM_GENERATE_INTERNAL_LABEL' to use `*' in this way.  If the
  47037. -     string doesn't start with `*', then `ASM_OUTPUT_LABELREF' gets to
  47038. -     output the string, and may change it.  (Of course,
  47039. -     `ASM_OUTPUT_LABELREF' is also part of your machine description, so
  47040. -     you should know what it does on your machine.)
  47041. -
  47042. -`ASM_FORMAT_PRIVATE_NAME (OUTVAR, NAME, NUMBER)'
  47043. -     A C expression to assign to OUTVAR (which is a variable of type
  47044. -     `char *') a newly allocated string made from the string NAME and
  47045. -     the number NUMBER, with some suitable punctuation added.  Use
  47046. -     `alloca' to get space for the string.
  47047. -
  47048. -     The string will be used as an argument to `ASM_OUTPUT_LABELREF' to
  47049. -     produce an assembler label for an internal static variable whose
  47050. -     name is NAME.  Therefore, the string must be such as to result in
  47051. -     valid assembler code.  The argument NUMBER is different each time
  47052. -     this macro is executed; it prevents conflicts between
  47053. -     similarly-named internal static variables in different scopes.
  47054. -
  47055. -     Ideally this string should not be a valid C identifier, to prevent
  47056. -     any conflict with the user's own symbols.  Most assemblers allow
  47057. -     periods or percent signs in assembler symbols; putting at least
  47058. -     one of these between the name and the number will suffice.
  47059. -
  47060. -`ASM_OUTPUT_DEF (STREAM, NAME, VALUE)'
  47061. -     A C statement to output to the stdio stream STREAM assembler code
  47062. -     which defines (equates) the symbol NAME to have the value VALUE.
  47063. -
  47064. -     If SET_ASM_OP is defined, a default definition is provided which is
  47065. -     correct for most systems.
  47066. -
  47067. -`OBJC_GEN_METHOD_LABEL (BUF, IS_INST, CLASS_NAME, CAT_NAME, SEL_NAME)'
  47068. -     Define this macro to override the default assembler names used for
  47069. -     Objective C methods.
  47070. -
  47071. -     The default name is a unique method number followed by the name of
  47072. -     the class (e.g. `_1_Foo').  For methods in categories, the name of
  47073. -     the category is also included in the assembler name (e.g.
  47074. -     `_1_Foo_Bar').
  47075. -
  47076. -     These names are safe on most systems, but make debugging difficult
  47077. -     since the method's selector is not present in the name.
  47078. -     Therefore, particular systems define other ways of computing names.
  47079. -
  47080. -     BUF is an expression of type `char *' which gives you a buffer in
  47081. -     which to store the name; its length is as long as CLASS_NAME,
  47082. -     CAT_NAME and SEL_NAME put together, plus 50 characters extra.
  47083. -
  47084. -     The argument IS_INST specifies whether the method is an instance
  47085. -     method or a class method; CLASS_NAME is the name of the class;
  47086. -     CAT_NAME is the name of the category (or NULL if the method is not
  47087. -     in a category); and SEL_NAME is the name of the selector.
  47088. -
  47089. -     On systems where the assembler can handle quoted names, you can
  47090. -     use this macro to provide more human-readable names.
  47091. -
  47092. -
  47093. -File: gcc.info,  Node: Initialization,  Next: Macros for Initialization,  Prev: Label Output,  Up: Assembler Format
  47094. -
  47095. -How Initialization Functions Are Handled
  47096. -----------------------------------------
  47097. -
  47098. -   The compiled code for certain languages includes "constructors"
  47099. -(also called "initialization routines")--functions to initialize data
  47100. -in the program when the program is started.  These functions need to be
  47101. -called before the program is "started"--that is to say, before `main'
  47102. -is called.
  47103. -
  47104. -   Compiling some languages generates "destructors" (also called
  47105. -"termination routines") that should be called when the program
  47106. -terminates.
  47107. -
  47108. -   To make the initialization and termination functions work, the
  47109. -compiler must output something in the assembler code to cause those
  47110. -functions to be called at the appropriate time.  When you port the
  47111. -compiler to a new system, you need to specify how to do this.
  47112. -
  47113. -   There are two major ways that GCC currently supports the execution of
  47114. -initialization and termination functions.  Each way has two variants.
  47115. -Much of the structure is common to all four variations.
  47116. -
  47117. -   The linker must build two lists of these functions--a list of
  47118. -initialization functions, called `__CTOR_LIST__', and a list of
  47119. -termination functions, called `__DTOR_LIST__'.
  47120. -
  47121. -   Each list always begins with an ignored function pointer (which may
  47122. -hold 0, -1, or a count of the function pointers after it, depending on
  47123. -the environment).  This is followed by a series of zero or more function
  47124. -pointers to constructors (or destructors), followed by a function
  47125. -pointer containing zero.
  47126. -
  47127. -   Depending on the operating system and its executable file format,
  47128. -either `crtstuff.c' or `libgcc2.c' traverses these lists at startup
  47129. -time and exit time.  Constructors are called in reverse order of the
  47130. -list; destructors in forward order.
  47131. -
  47132. -   The best way to handle static constructors works only for object file
  47133. -formats which provide arbitrarily-named sections.  A section is set
  47134. -aside for a list of constructors, and another for a list of destructors.
  47135. -Traditionally these are called `.ctors' and `.dtors'.  Each object file
  47136. -that defines an initialization function also puts a word in the
  47137. -constructor section to point to that function.  The linker accumulates
  47138. -all these words into one contiguous `.ctors' section.  Termination
  47139. -functions are handled similarly.
  47140. -
  47141. -   To use this method, you need appropriate definitions of the macros
  47142. -`ASM_OUTPUT_CONSTRUCTOR' and `ASM_OUTPUT_DESTRUCTOR'.  Usually you can
  47143. -get them by including `svr4.h'.
  47144. -
  47145. -   When arbitrary sections are available, there are two variants,
  47146. -depending upon how the code in `crtstuff.c' is called.  On systems that
  47147. -support an "init" section which is executed at program startup, parts
  47148. -of `crtstuff.c' are compiled into that section.  The program is linked
  47149. -by the `gcc' driver like this:
  47150. -
  47151. -     ld -o OUTPUT_FILE crtbegin.o ... crtend.o -lgcc
  47152. -
  47153. -   The head of a function (`__do_global_ctors') appears in the init
  47154. -section of `crtbegin.o'; the remainder of the function appears in the
  47155. -init section of `crtend.o'.  The linker will pull these two parts of
  47156. -the section together, making a whole function.  If any of the user's
  47157. -object files linked into the middle of it contribute code, then that
  47158. -code will be executed as part of the body of `__do_global_ctors'.
  47159. -
  47160. -   To use this variant, you must define the `INIT_SECTION_ASM_OP' macro
  47161. -properly.
  47162. -
  47163. -   If no init section is available, do not define
  47164. -`INIT_SECTION_ASM_OP'.  Then `__do_global_ctors' is built into the text
  47165. -section like all other functions, and resides in `libgcc.a'.  When GCC
  47166. -compiles any function called `main', it inserts a procedure call to
  47167. -`__main' as the first executable code after the function prologue.  The
  47168. -`__main' function, also defined in `libgcc2.c', simply calls
  47169. -`__do_global_ctors'.
  47170. -
  47171. -   In file formats that don't support arbitrary sections, there are
  47172. -again two variants.  In the simplest variant, the GNU linker (GNU `ld')
  47173. -and an `a.out' format must be used.  In this case,
  47174. -`ASM_OUTPUT_CONSTRUCTOR' is defined to produce a `.stabs' entry of type
  47175. -`N_SETT', referencing the name `__CTOR_LIST__', and with the address of
  47176. -the void function containing the initialization code as its value.  The
  47177. -GNU linker recognizes this as a request to add the value to a "set";
  47178. -the values are accumulated, and are eventually placed in the executable
  47179. -as a vector in the format described above, with a leading (ignored)
  47180. -count and a trailing zero element.  `ASM_OUTPUT_DESTRUCTOR' is handled
  47181. -similarly.  Since no init section is available, the absence of
  47182. -`INIT_SECTION_ASM_OP' causes the compilation of `main' to call `__main'
  47183. -as above, starting the initialization process.
  47184. -
  47185. -   The last variant uses neither arbitrary sections nor the GNU linker.
  47186. -This is preferable when you want to do dynamic linking and when using
  47187. -file formats which the GNU linker does not support, such as `ECOFF'.  In
  47188. -this case, `ASM_OUTPUT_CONSTRUCTOR' does not produce an `N_SETT'
  47189. -symbol; initialization and termination functions are recognized simply
  47190. -by their names.  This requires an extra program in the linkage step,
  47191. -called `collect2'.  This program pretends to be the linker, for use
  47192. -with GNU CC; it does its job by running the ordinary linker, but also
  47193. -arranges to include the vectors of initialization and termination
  47194. -functions.  These functions are called via `__main' as described above.
  47195. -
  47196. -   Choosing among these configuration options has been simplified by a
  47197. -set of operating-system-dependent files in the `config' subdirectory.
  47198. -These files define all of the relevant parameters.  Usually it is
  47199. -sufficient to include one into your specific machine-dependent
  47200. -configuration file.  These files are:
  47201. -
  47202. -`aoutos.h'
  47203. -     For operating systems using the `a.out' format.
  47204. -
  47205. -`next.h'
  47206. -     For operating systems using the `MachO' format.
  47207. -
  47208. -`svr3.h'
  47209. -     For System V Release 3 and similar systems using `COFF' format.
  47210. -
  47211. -`svr4.h'
  47212. -     For System V Release 4 and similar systems using `ELF' format.
  47213. -
  47214. -`vms.h'
  47215. -     For the VMS operating system.
  47216. -
  47217. -   The following section describes the specific macros that control and
  47218. -customize the handling of initialization and termination functions.
  47219. -
  47220. -
  47221. -File: gcc.info,  Node: Macros for Initialization,  Next: Instruction Output,  Prev: Initialization,  Up: Assembler Format
  47222. -
  47223. -Macros Controlling Initialization Routines
  47224. -------------------------------------------
  47225. -
  47226. -   Here are the macros that control how the compiler handles
  47227. -initialization and termination functions:
  47228. -
  47229. -`INIT_SECTION_ASM_OP'
  47230. -     If defined, a C string constant for the assembler operation to
  47231. -     identify the following data as initialization code.  If not
  47232. -     defined, GNU CC will assume such a section does not exist.  When
  47233. -     you are using special sections for initialization and termination
  47234. -     functions, this macro also controls how `crtstuff.c' and
  47235. -     `libgcc2.c' arrange to run the initialization functions.
  47236. -
  47237. -`HAS_INIT_SECTION'
  47238. -     If defined, `main' will not call `__main' as described above.
  47239. -     This macro should be defined for systems that control the contents
  47240. -     of the init section on a symbol-by-symbol basis, such as OSF/1,
  47241. -     and should not be defined explicitly for systems that support
  47242. -     `INIT_SECTION_ASM_OP'.
  47243. -
  47244. -`LD_INIT_SWITCH'
  47245. -     If defined, a C string constant for a switch that tells the linker
  47246. -     that the following symbol is an initialization routine.
  47247. -
  47248. -`LD_FINI_SWITCH'
  47249. -     If defined, a C string constant for a switch that tells the linker
  47250. -     that the following symbol is a finalization routine.
  47251. -
  47252. -`INVOKE__main'
  47253. -     If defined, `main' will call `__main' despite the presence of
  47254. -     `INIT_SECTION_ASM_OP'.  This macro should be defined for systems
  47255. -     where the init section is not actually run automatically, but is
  47256. -     still useful for collecting the lists of constructors and
  47257. -     destructors.
  47258. -
  47259. -`ASM_OUTPUT_CONSTRUCTOR (STREAM, NAME)'
  47260. -     Define this macro as a C statement to output on the stream STREAM
  47261. -     the assembler code to arrange to call the function named NAME at
  47262. -     initialization time.
  47263. -
  47264. -     Assume that NAME is the name of a C function generated
  47265. -     automatically by the compiler.  This function takes no arguments.
  47266. -     Use the function `assemble_name' to output the name NAME; this
  47267. -     performs any system-specific syntactic transformations such as
  47268. -     adding an underscore.
  47269. -
  47270. -     If you don't define this macro, nothing special is output to
  47271. -     arrange to call the function.  This is correct when the function
  47272. -     will be called in some other manner--for example, by means of the
  47273. -     `collect2' program, which looks through the symbol table to find
  47274. -     these functions by their names.
  47275. -
  47276. -`ASM_OUTPUT_DESTRUCTOR (STREAM, NAME)'
  47277. -     This is like `ASM_OUTPUT_CONSTRUCTOR' but used for termination
  47278. -     functions rather than initialization functions.
  47279. -
  47280. -   If your system uses `collect2' as the means of processing
  47281. -constructors, then that program normally uses `nm' to scan an object
  47282. -file for constructor functions to be called.  On certain kinds of
  47283. -systems, you can define these macros to make `collect2' work faster
  47284. -(and, in some cases, make it work at all):
  47285. -
  47286. -`OBJECT_FORMAT_COFF'
  47287. -     Define this macro if the system uses COFF (Common Object File
  47288. -     Format) object files, so that `collect2' can assume this format
  47289. -     and scan object files directly for dynamic constructor/destructor
  47290. -     functions.
  47291. -
  47292. -`OBJECT_FORMAT_ROSE'
  47293. -     Define this macro if the system uses ROSE format object files, so
  47294. -     that `collect2' can assume this format and scan object files
  47295. -     directly for dynamic constructor/destructor functions.
  47296. -
  47297. -     These macros are effective only in a native compiler; `collect2' as
  47298. -     part of a cross compiler always uses `nm' for the target machine.
  47299. -
  47300. -`REAL_NM_FILE_NAME'
  47301. -     Define this macro as a C string constant containing the file name
  47302. -     to use to execute `nm'.  The default is to search the path
  47303. -     normally for `nm'.
  47304. -
  47305. -     If your system supports shared libraries and has a program to list
  47306. -     the dynamic dependencies of a given library or executable, you can
  47307. -     define these macros to enable support for running initialization
  47308. -     and termination functions in shared libraries:
  47309. -
  47310. -`LDD_SUFFIX'
  47311. -     Define this macro to a C string constant containing the name of the
  47312. -     program which lists dynamic dependencies, like `"ldd"' under SunOS
  47313. -     4.
  47314. -
  47315. -`PARSE_LDD_OUTPUT (PTR)'
  47316. -     Define this macro to be C code that extracts filenames from the
  47317. -     output of the program denoted by `LDD_SUFFIX'.  PTR is a variable
  47318. -     of type `char *' that points to the beginning of a line of output
  47319. -     from `LDD_SUFFIX'.  If the line lists a dynamic dependency, the
  47320. -     code must advance PTR to the beginning of the filename on that
  47321. -     line.  Otherwise, it must set PTR to `NULL'.
  47322. -
  47323. -
  47324. -File: gcc.info,  Node: Instruction Output,  Next: Dispatch Tables,  Prev: Macros for Initialization,  Up: Assembler Format
  47325. -
  47326. -Output of Assembler Instructions
  47327. ---------------------------------
  47328. -
  47329. -   This describes assembler instruction output.
  47330. -
  47331. -`REGISTER_NAMES'
  47332. -     A C initializer containing the assembler's names for the machine
  47333. -     registers, each one as a C string constant.  This is what
  47334. -     translates register numbers in the compiler into assembler
  47335. -     language.
  47336. -
  47337. -`ADDITIONAL_REGISTER_NAMES'
  47338. -     If defined, a C initializer for an array of structures containing
  47339. -     a name and a register number.  This macro defines additional names
  47340. -     for hard registers, thus allowing the `asm' option in declarations
  47341. -     to refer to registers using alternate names.
  47342. -
  47343. -`ASM_OUTPUT_OPCODE (STREAM, PTR)'
  47344. -     Define this macro if you are using an unusual assembler that
  47345. -     requires different names for the machine instructions.
  47346. -
  47347. -     The definition is a C statement or statements which output an
  47348. -     assembler instruction opcode to the stdio stream STREAM.  The
  47349. -     macro-operand PTR is a variable of type `char *' which points to
  47350. -     the opcode name in its "internal" form--the form that is written
  47351. -     in the machine description.  The definition should output the
  47352. -     opcode name to STREAM, performing any translation you desire, and
  47353. -     increment the variable PTR to point at the end of the opcode so
  47354. -     that it will not be output twice.
  47355. -
  47356. -     In fact, your macro definition may process less than the entire
  47357. -     opcode name, or more than the opcode name; but if you want to
  47358. -     process text that includes `%'-sequences to substitute operands,
  47359. -     you must take care of the substitution yourself.  Just be sure to
  47360. -     increment PTR over whatever text should not be output normally.
  47361. -
  47362. -     If you need to look at the operand values, they can be found as the
  47363. -     elements of `recog_operand'.
  47364. -
  47365. -     If the macro definition does nothing, the instruction is output in
  47366. -     the usual way.
  47367. -
  47368. -`FINAL_PRESCAN_INSN (INSN, OPVEC, NOPERANDS)'
  47369. -     If defined, a C statement to be executed just prior to the output
  47370. -     of assembler code for INSN, to modify the extracted operands so
  47371. -     they will be output differently.
  47372. -
  47373. -     Here the argument OPVEC is the vector containing the operands
  47374. -     extracted from INSN, and NOPERANDS is the number of elements of
  47375. -     the vector which contain meaningful data for this insn.  The
  47376. -     contents of this vector are what will be used to convert the insn
  47377. -     template into assembler code, so you can change the assembler
  47378. -     output by changing the contents of the vector.
  47379. -
  47380. -     This macro is useful when various assembler syntaxes share a single
  47381. -     file of instruction patterns; by defining this macro differently,
  47382. -     you can cause a large class of instructions to be output
  47383. -     differently (such as with rearranged operands).  Naturally,
  47384. -     variations in assembler syntax affecting individual insn patterns
  47385. -     ought to be handled by writing conditional output routines in
  47386. -     those patterns.
  47387. -
  47388. -     If this macro is not defined, it is equivalent to a null statement.
  47389. -
  47390. -`PRINT_OPERAND (STREAM, X, CODE)'
  47391. -     A C compound statement to output to stdio stream STREAM the
  47392. -     assembler syntax for an instruction operand X.  X is an RTL
  47393. -     expression.
  47394. -
  47395. -     CODE is a value that can be used to specify one of several ways of
  47396. -     printing the operand.  It is used when identical operands must be
  47397. -     printed differently depending on the context.  CODE comes from the
  47398. -     `%' specification that was used to request printing of the
  47399. -     operand.  If the specification was just `%DIGIT' then CODE is 0;
  47400. -     if the specification was `%LTR DIGIT' then CODE is the ASCII code
  47401. -     for LTR.
  47402. -
  47403. -     If X is a register, this macro should print the register's name.
  47404. -     The names can be found in an array `reg_names' whose type is `char
  47405. -     *[]'.  `reg_names' is initialized from `REGISTER_NAMES'.
  47406. -
  47407. -     When the machine description has a specification `%PUNCT' (a `%'
  47408. -     followed by a punctuation character), this macro is called with a
  47409. -     null pointer for X and the punctuation character for CODE.
  47410. -
  47411. -`PRINT_OPERAND_PUNCT_VALID_P (CODE)'
  47412. -     A C expression which evaluates to true if CODE is a valid
  47413. -     punctuation character for use in the `PRINT_OPERAND' macro.  If
  47414. -     `PRINT_OPERAND_PUNCT_VALID_P' is not defined, it means that no
  47415. -     punctuation characters (except for the standard one, `%') are used
  47416. -     in this way.
  47417. -
  47418. -`PRINT_OPERAND_ADDRESS (STREAM, X)'
  47419. -     A C compound statement to output to stdio stream STREAM the
  47420. -     assembler syntax for an instruction operand that is a memory
  47421. -     reference whose address is X.  X is an RTL expression.
  47422. -
  47423. -     On some machines, the syntax for a symbolic address depends on the
  47424. -     section that the address refers to.  On these machines, define the
  47425. -     macro `ENCODE_SECTION_INFO' to store the information into the
  47426. -     `symbol_ref', and then check for it here.  *Note Assembler
  47427. -     Format::.
  47428. -
  47429. -`DBR_OUTPUT_SEQEND(FILE)'
  47430. -     A C statement, to be executed after all slot-filler instructions
  47431. -     have been output.  If necessary, call `dbr_sequence_length' to
  47432. -     determine the number of slots filled in a sequence (zero if not
  47433. -     currently outputting a sequence), to decide how many no-ops to
  47434. -     output, or whatever.
  47435. -
  47436. -     Don't define this macro if it has nothing to do, but it is helpful
  47437. -     in reading assembly output if the extent of the delay sequence is
  47438. -     made explicit (e.g. with white space).
  47439. -
  47440. -     Note that output routines for instructions with delay slots must be
  47441. -     prepared to deal with not being output as part of a sequence (i.e.
  47442. -     when the scheduling pass is not run, or when no slot fillers could
  47443. -     be found.)  The variable `final_sequence' is null when not
  47444. -     processing a sequence, otherwise it contains the `sequence' rtx
  47445. -     being output.
  47446. -
  47447. -`REGISTER_PREFIX'
  47448. -`LOCAL_LABEL_PREFIX'
  47449. -`USER_LABEL_PREFIX'
  47450. -`IMMEDIATE_PREFIX'
  47451. -     If defined, C string expressions to be used for the `%R', `%L',
  47452. -     `%U', and `%I' options of `asm_fprintf' (see `final.c').  These
  47453. -     are useful when a single `md' file must support multiple assembler
  47454. -     formats.  In that case, the various `tm.h' files can define these
  47455. -     macros differently.
  47456. -
  47457. -`ASSEMBLER_DIALECT'
  47458. -     If your target supports multiple dialects of assembler language
  47459. -     (such as different opcodes), define this macro as a C expression
  47460. -     that gives the numeric index of the assembler language dialect to
  47461. -     use, with zero as the first variant.
  47462. -
  47463. -     If this macro is defined, you may use
  47464. -     `{option0|option1|option2...}' constructs in the output templates
  47465. -     of patterns (*note Output Template::.) or in the first argument of
  47466. -     `asm_fprintf'.  This construct outputs `option0', `option1' or
  47467. -     `option2', etc., if the value of `ASSEMBLER_DIALECT' is zero, one
  47468. -     or two, etc.  Any special characters within these strings retain
  47469. -     their usual meaning.
  47470. -
  47471. -     If you do not define this macro, the characters `{', `|' and `}'
  47472. -     do not have any special meaning when used in templates or operands
  47473. -     to `asm_fprintf'.
  47474. -
  47475. -     Define the macros `REGISTER_PREFIX', `LOCAL_LABEL_PREFIX',
  47476. -     `USER_LABEL_PREFIX' and `IMMEDIATE_PREFIX' if you can express the
  47477. -     variations in assemble language syntax with that mechanism.  Define
  47478. -     `ASSEMBLER_DIALECT' and use the `{option0|option1}' syntax if the
  47479. -     syntax variant are larger and involve such things as different
  47480. -     opcodes or operand order.
  47481. -
  47482. -`ASM_OUTPUT_REG_PUSH (STREAM, REGNO)'
  47483. -     A C expression to output to STREAM some assembler code which will
  47484. -     push hard register number REGNO onto the stack.  The code need not
  47485. -     be optimal, since this macro is used only when profiling.
  47486. -
  47487. -`ASM_OUTPUT_REG_POP (STREAM, REGNO)'
  47488. -     A C expression to output to STREAM some assembler code which will
  47489. -     pop hard register number REGNO off of the stack.  The code need
  47490. -     not be optimal, since this macro is used only when profiling.
  47491. -
  47492. -
  47493. -File: gcc.info,  Node: Dispatch Tables,  Next: Alignment Output,  Prev: Instruction Output,  Up: Assembler Format
  47494. -
  47495. -Output of Dispatch Tables
  47496. --------------------------
  47497. -
  47498. -   This concerns dispatch tables.
  47499. -
  47500. -`ASM_OUTPUT_ADDR_DIFF_ELT (STREAM, VALUE, REL)'
  47501. -     This macro should be provided on machines where the addresses in a
  47502. -     dispatch table are relative to the table's own address.
  47503. -
  47504. -     The definition should be a C statement to output to the stdio
  47505. -     stream STREAM an assembler pseudo-instruction to generate a
  47506. -     difference between two labels.  VALUE and REL are the numbers of
  47507. -     two internal labels.  The definitions of these labels are output
  47508. -     using `ASM_OUTPUT_INTERNAL_LABEL', and they must be printed in the
  47509. -     same way here.  For example,
  47510. -
  47511. -          fprintf (STREAM, "\t.word L%d-L%d\n",
  47512. -                   VALUE, REL)
  47513. -
  47514. -`ASM_OUTPUT_ADDR_VEC_ELT (STREAM, VALUE)'
  47515. -     This macro should be provided on machines where the addresses in a
  47516. -     dispatch table are absolute.
  47517. -
  47518. -     The definition should be a C statement to output to the stdio
  47519. -     stream STREAM an assembler pseudo-instruction to generate a
  47520. -     reference to a label.  VALUE is the number of an internal label
  47521. -     whose definition is output using `ASM_OUTPUT_INTERNAL_LABEL'.  For
  47522. -     example,
  47523. -
  47524. -          fprintf (STREAM, "\t.word L%d\n", VALUE)
  47525. -
  47526. -`ASM_OUTPUT_CASE_LABEL (STREAM, PREFIX, NUM, TABLE)'
  47527. -     Define this if the label before a jump-table needs to be output
  47528. -     specially.  The first three arguments are the same as for
  47529. -     `ASM_OUTPUT_INTERNAL_LABEL'; the fourth argument is the jump-table
  47530. -     which follows (a `jump_insn' containing an `addr_vec' or
  47531. -     `addr_diff_vec').
  47532. -
  47533. -     This feature is used on system V to output a `swbeg' statement for
  47534. -     the table.
  47535. -
  47536. -     If this macro is not defined, these labels are output with
  47537. -     `ASM_OUTPUT_INTERNAL_LABEL'.
  47538. -
  47539. -`ASM_OUTPUT_CASE_END (STREAM, NUM, TABLE)'
  47540. -     Define this if something special must be output at the end of a
  47541. -     jump-table.  The definition should be a C statement to be executed
  47542. -     after the assembler code for the table is written.  It should write
  47543. -     the appropriate code to stdio stream STREAM.  The argument TABLE
  47544. -     is the jump-table insn, and NUM is the label-number of the
  47545. -     preceding label.
  47546. -
  47547. -     If this macro is not defined, nothing special is output at the end
  47548. -     of the jump-table.
  47549. -
  47550. -
  47551. -File: gcc.info,  Node: Alignment Output,  Prev: Dispatch Tables,  Up: Assembler Format
  47552. -
  47553. -Assembler Commands for Alignment
  47554. ---------------------------------
  47555. -
  47556. -   This describes commands for alignment.
  47557. -
  47558. -`ASM_OUTPUT_ALIGN_CODE (FILE)'
  47559. -     A C expression to output text to align the location counter in the
  47560. -     way that is desirable at a point in the code that is reached only
  47561. -     by jumping.
  47562. -
  47563. -     This macro need not be defined if you don't want any special
  47564. -     alignment to be done at such a time.  Most machine descriptions do
  47565. -     not currently define the macro.
  47566. -
  47567. -`ASM_OUTPUT_LOOP_ALIGN (FILE)'
  47568. -     A C expression to output text to align the location counter in the
  47569. -     way that is desirable at the beginning of a loop.
  47570. -
  47571. -     This macro need not be defined if you don't want any special
  47572. -     alignment to be done at such a time.  Most machine descriptions do
  47573. -     not currently define the macro.
  47574. -
  47575. -`ASM_OUTPUT_SKIP (STREAM, NBYTES)'
  47576. -     A C statement to output to the stdio stream STREAM an assembler
  47577. -     instruction to advance the location counter by NBYTES bytes.
  47578. -     Those bytes should be zero when loaded.  NBYTES will be a C
  47579. -     expression of type `int'.
  47580. -
  47581. -`ASM_NO_SKIP_IN_TEXT'
  47582. -     Define this macro if `ASM_OUTPUT_SKIP' should not be used in the
  47583. -     text section because it fails put zeros in the bytes that are
  47584. -     skipped.  This is true on many Unix systems, where the pseudo-op
  47585. -     to skip bytes produces no-op instructions rather than zeros when
  47586. -     used in the text section.
  47587. -
  47588. -`ASM_OUTPUT_ALIGN (STREAM, POWER)'
  47589. -     A C statement to output to the stdio stream STREAM an assembler
  47590. -     command to advance the location counter to a multiple of 2 to the
  47591. -     POWER bytes.  POWER will be a C expression of type `int'.
  47592. -
  47593. -
  47594. -File: gcc.info,  Node: Debugging Info,  Next: Cross-compilation,  Prev: Assembler Format,  Up: Target Macros
  47595. -
  47596. -Controlling Debugging Information Format
  47597. -========================================
  47598. -
  47599. -   This describes how to specify debugging information.
  47600. -
  47601. -* Menu:
  47602. -
  47603. -* All Debuggers::      Macros that affect all debugging formats uniformly.
  47604. -* DBX Options::        Macros enabling specific options in DBX format.
  47605. -* DBX Hooks::          Hook macros for varying DBX format.
  47606. -* File Names and DBX:: Macros controlling output of file names in DBX format.
  47607. -* SDB and DWARF::      Macros for SDB (COFF) and DWARF formats.
  47608. -
  47609. -
  47610. -File: gcc.info,  Node: All Debuggers,  Next: DBX Options,  Up: Debugging Info
  47611. -
  47612. -Macros Affecting All Debugging Formats
  47613. ---------------------------------------
  47614. -
  47615. -   These macros affect all debugging formats.
  47616. -
  47617. -`DBX_REGISTER_NUMBER (REGNO)'
  47618. -     A C expression that returns the DBX register number for the
  47619. -     compiler register number REGNO.  In simple cases, the value of this
  47620. -     expression may be REGNO itself.  But sometimes there are some
  47621. -     registers that the compiler knows about and DBX does not, or vice
  47622. -     versa.  In such cases, some register may need to have one number in
  47623. -     the compiler and another for DBX.
  47624. -
  47625. -     If two registers have consecutive numbers inside GNU CC, and they
  47626. -     can be used as a pair to hold a multiword value, then they *must*
  47627. -     have consecutive numbers after renumbering with
  47628. -     `DBX_REGISTER_NUMBER'.  Otherwise, debuggers will be unable to
  47629. -     access such a pair, because they expect register pairs to be
  47630. -     consecutive in their own numbering scheme.
  47631. -
  47632. -     If you find yourself defining `DBX_REGISTER_NUMBER' in way that
  47633. -     does not preserve register pairs, then what you must do instead is
  47634. -     redefine the actual register numbering scheme.
  47635. -
  47636. -`DEBUGGER_AUTO_OFFSET (X)'
  47637. -     A C expression that returns the integer offset value for an
  47638. -     automatic variable having address X (an RTL expression).  The
  47639. -     default computation assumes that X is based on the frame-pointer
  47640. -     and gives the offset from the frame-pointer.  This is required for
  47641. -     targets that produce debugging output for DBX or COFF-style
  47642. -     debugging output for SDB and allow the frame-pointer to be
  47643. -     eliminated when the `-g' options is used.
  47644. -
  47645. -`DEBUGGER_ARG_OFFSET (OFFSET, X)'
  47646. -     A C expression that returns the integer offset value for an
  47647. -     argument having address X (an RTL expression).  The nominal offset
  47648. -     is OFFSET.
  47649. -
  47650. -`PREFERRED_DEBUGGING_TYPE'
  47651. -     A C expression that returns the type of debugging output GNU CC
  47652. -     produces when the user specifies `-g' or `-ggdb'.  Define this if
  47653. -     you have arranged for GNU CC to support more than one format of
  47654. -     debugging output.  Currently, the allowable values are `DBX_DEBUG',
  47655. -     `SDB_DEBUG', `DWARF_DEBUG', and `XCOFF_DEBUG'.
  47656. -
  47657. -     The value of this macro only affects the default debugging output;
  47658. -     the user can always get a specific type of output by using
  47659. -     `-gstabs', `-gcoff', `-gdwarf', or `-gxcoff'.
  47660. -
  47661. -
  47662. -File: gcc.info,  Node: DBX Options,  Next: DBX Hooks,  Prev: All Debuggers,  Up: Debugging Info
  47663. -
  47664. -Specific Options for DBX Output
  47665. --------------------------------
  47666. -
  47667. -   These are specific options for DBX output.
  47668. -
  47669. -`DBX_DEBUGGING_INFO'
  47670. -     Define this macro if GNU CC should produce debugging output for DBX
  47671. -     in response to the `-g' option.
  47672. -
  47673. -`XCOFF_DEBUGGING_INFO'
  47674. -     Define this macro if GNU CC should produce XCOFF format debugging
  47675. -     output in response to the `-g' option.  This is a variant of DBX
  47676. -     format.
  47677. -
  47678. -`DEFAULT_GDB_EXTENSIONS'
  47679. -     Define this macro to control whether GNU CC should by default
  47680. -     generate GDB's extended version of DBX debugging information
  47681. -     (assuming DBX-format debugging information is enabled at all).  If
  47682. -     you don't define the macro, the default is 1: always generate the
  47683. -     extended information if there is any occasion to.
  47684. -
  47685. -`DEBUG_SYMS_TEXT'
  47686. -     Define this macro if all `.stabs' commands should be output while
  47687. -     in the text section.
  47688. -
  47689. -`ASM_STABS_OP'
  47690. -     A C string constant naming the assembler pseudo op to use instead
  47691. -     of `.stabs' to define an ordinary debugging symbol.  If you don't
  47692. -     define this macro, `.stabs' is used.  This macro applies only to
  47693. -     DBX debugging information format.
  47694. -
  47695. -`ASM_STABD_OP'
  47696. -     A C string constant naming the assembler pseudo op to use instead
  47697. -     of `.stabd' to define a debugging symbol whose value is the current
  47698. -     location.  If you don't define this macro, `.stabd' is used.  This
  47699. -     macro applies only to DBX debugging information format.
  47700. -
  47701. -`ASM_STABN_OP'
  47702. -     A C string constant naming the assembler pseudo op to use instead
  47703. -     of `.stabn' to define a debugging symbol with no name.  If you
  47704. -     don't define this macro, `.stabn' is used.  This macro applies
  47705. -     only to DBX debugging information format.
  47706. -
  47707. -`DBX_NO_XREFS'
  47708. -     Define this macro if DBX on your system does not support the
  47709. -     construct `xsTAGNAME'.  On some systems, this construct is used to
  47710. -     describe a forward reference to a structure named TAGNAME.  On
  47711. -     other systems, this construct is not supported at all.
  47712. -
  47713. -`DBX_CONTIN_LENGTH'
  47714. -     A symbol name in DBX-format debugging information is normally
  47715. -     continued (split into two separate `.stabs' directives) when it
  47716. -     exceeds a certain length (by default, 80 characters).  On some
  47717. -     operating systems, DBX requires this splitting; on others,
  47718. -     splitting must not be done.  You can inhibit splitting by defining
  47719. -     this macro with the value zero.  You can override the default
  47720. -     splitting-length by defining this macro as an expression for the
  47721. -     length you desire.
  47722. -
  47723. -`DBX_CONTIN_CHAR'
  47724. -     Normally continuation is indicated by adding a `\' character to
  47725. -     the end of a `.stabs' string when a continuation follows.  To use
  47726. -     a different character instead, define this macro as a character
  47727. -     constant for the character you want to use.  Do not define this
  47728. -     macro if backslash is correct for your system.
  47729. -
  47730. -`DBX_STATIC_STAB_DATA_SECTION'
  47731. -     Define this macro if it is necessary to go to the data section
  47732. -     before outputting the `.stabs' pseudo-op for a non-global static
  47733. -     variable.
  47734. -
  47735. -`DBX_TYPE_DECL_STABS_CODE'
  47736. -     The value to use in the "code" field of the `.stabs' directive for
  47737. -     a typedef.  The default is `N_LSYM'.
  47738. -
  47739. -`DBX_STATIC_CONST_VAR_CODE'
  47740. -     The value to use in the "code" field of the `.stabs' directive for
  47741. -     a static variable located in the text section.  DBX format does not
  47742. -     provide any "right" way to do this.  The default is `N_FUN'.
  47743. -
  47744. -`DBX_REGPARM_STABS_CODE'
  47745. -     The value to use in the "code" field of the `.stabs' directive for
  47746. -     a parameter passed in registers.  DBX format does not provide any
  47747. -     "right" way to do this.  The default is `N_RSYM'.
  47748. -
  47749. -`DBX_REGPARM_STABS_LETTER'
  47750. -     The letter to use in DBX symbol data to identify a symbol as a
  47751. -     parameter passed in registers.  DBX format does not customarily
  47752. -     provide any way to do this.  The default is `'P''.
  47753. -
  47754. -`DBX_MEMPARM_STABS_LETTER'
  47755. -     The letter to use in DBX symbol data to identify a symbol as a
  47756. -     stack parameter.  The default is `'p''.
  47757. -
  47758. -`DBX_FUNCTION_FIRST'
  47759. -     Define this macro if the DBX information for a function and its
  47760. -     arguments should precede the assembler code for the function.
  47761. -     Normally, in DBX format, the debugging information entirely
  47762. -     follows the assembler code.
  47763. -
  47764. -`DBX_LBRAC_FIRST'
  47765. -     Define this macro if the `N_LBRAC' symbol for a block should
  47766. -     precede the debugging information for variables and functions
  47767. -     defined in that block.  Normally, in DBX format, the `N_LBRAC'
  47768. -     symbol comes first.
  47769. -
  47770. -`DBX_BLOCKS_FUNCTION_RELATIVE'
  47771. -     Define this macro if the value of a symbol describing the scope of
  47772. -     a block (`N_LBRAC' or `N_RBRAC') should be relative to the start
  47773. -     of the enclosing function.  Normally, GNU C uses an absolute
  47774. -     address.
  47775. -
  47776. -
  47777. -File: gcc.info,  Node: DBX Hooks,  Next: File Names and DBX,  Prev: DBX Options,  Up: Debugging Info
  47778. -
  47779. -Open-Ended Hooks for DBX Format
  47780. --------------------------------
  47781. -
  47782. -   These are hooks for DBX format.
  47783. -
  47784. -`DBX_OUTPUT_LBRAC (STREAM, NAME)'
  47785. -     Define this macro to say how to output to STREAM the debugging
  47786. -     information for the start of a scope level for variable names.  The
  47787. -     argument NAME is the name of an assembler symbol (for use with
  47788. -     `assemble_name') whose value is the address where the scope begins.
  47789. -
  47790. -`DBX_OUTPUT_RBRAC (STREAM, NAME)'
  47791. -     Like `DBX_OUTPUT_LBRAC', but for the end of a scope level.
  47792. -
  47793. -`DBX_OUTPUT_ENUM (STREAM, TYPE)'
  47794. -     Define this macro if the target machine requires special handling
  47795. -     to output an enumeration type.  The definition should be a C
  47796. -     statement (sans semicolon) to output the appropriate information
  47797. -     to STREAM for the type TYPE.
  47798. -
  47799. -`DBX_OUTPUT_FUNCTION_END (STREAM, FUNCTION)'
  47800. -     Define this macro if the target machine requires special output at
  47801. -     the end of the debugging information for a function.  The
  47802. -     definition should be a C statement (sans semicolon) to output the
  47803. -     appropriate information to STREAM.  FUNCTION is the
  47804. -     `FUNCTION_DECL' node for the function.
  47805. -
  47806. -`DBX_OUTPUT_STANDARD_TYPES (SYMS)'
  47807. -     Define this macro if you need to control the order of output of the
  47808. -     standard data types at the beginning of compilation.  The argument
  47809. -     SYMS is a `tree' which is a chain of all the predefined global
  47810. -     symbols, including names of data types.
  47811. -
  47812. -     Normally, DBX output starts with definitions of the types for
  47813. -     integers and characters, followed by all the other predefined
  47814. -     types of the particular language in no particular order.
  47815. -
  47816. -     On some machines, it is necessary to output different particular
  47817. -     types first.  To do this, define `DBX_OUTPUT_STANDARD_TYPES' to
  47818. -     output those symbols in the necessary order.  Any predefined types
  47819. -     that you don't explicitly output will be output afterward in no
  47820. -     particular order.
  47821. -
  47822. -     Be careful not to define this macro so that it works only for C.
  47823. -     There are no global variables to access most of the built-in
  47824. -     types, because another language may have another set of types.
  47825. -     The way to output a particular type is to look through SYMS to see
  47826. -     if you can find it.  Here is an example:
  47827. -
  47828. -          {
  47829. -            tree decl;
  47830. -            for (decl = syms; decl; decl = TREE_CHAIN (decl))
  47831. -              if (!strcmp (IDENTIFIER_POINTER (DECL_NAME (decl)),
  47832. -                           "long int"))
  47833. -                dbxout_symbol (decl);
  47834. -            ...
  47835. -          }
  47836. -
  47837. -     This does nothing if the expected type does not exist.
  47838. -
  47839. -     See the function `init_decl_processing' in `c-decl.c' to find the
  47840. -     names to use for all the built-in C types.
  47841. -
  47842. -     Here is another way of finding a particular type:
  47843. -
  47844. -          {
  47845. -            tree decl;
  47846. -            for (decl = syms; decl; decl = TREE_CHAIN (decl))
  47847. -              if (TREE_CODE (decl) == TYPE_DECL
  47848. -                  && (TREE_CODE (TREE_TYPE (decl))
  47849. -                      == INTEGER_CST)
  47850. -                  && TYPE_PRECISION (TREE_TYPE (decl)) == 16
  47851. -                  && TYPE_UNSIGNED (TREE_TYPE (decl)))
  47852. -          /* This must be `unsigned short'.  */
  47853. -                dbxout_symbol (decl);
  47854. -            ...
  47855. -          }
  47856. -
  47857. -
  47858. -File: gcc.info,  Node: File Names and DBX,  Next: SDB and DWARF,  Prev: DBX Hooks,  Up: Debugging Info
  47859. -
  47860. -File Names in DBX Format
  47861. -------------------------
  47862. -
  47863. -   This describes file names in DBX format.
  47864. -
  47865. -`DBX_WORKING_DIRECTORY'
  47866. -     Define this if DBX wants to have the current directory recorded in
  47867. -     each object file.
  47868. -
  47869. -     Note that the working directory is always recorded if GDB
  47870. -     extensions are enabled.
  47871. -
  47872. -`DBX_OUTPUT_MAIN_SOURCE_FILENAME (STREAM, NAME)'
  47873. -     A C statement to output DBX debugging information to the stdio
  47874. -     stream STREAM which indicates that file NAME is the main source
  47875. -     file--the file specified as the input file for compilation.  This
  47876. -     macro is called only once, at the beginning of compilation.
  47877. -
  47878. -     This macro need not be defined if the standard form of output for
  47879. -     DBX debugging information is appropriate.
  47880. -
  47881. -`DBX_OUTPUT_MAIN_SOURCE_DIRECTORY (STREAM, NAME)'
  47882. -     A C statement to output DBX debugging information to the stdio
  47883. -     stream STREAM which indicates that the current directory during
  47884. -     compilation is named NAME.
  47885. -
  47886. -     This macro need not be defined if the standard form of output for
  47887. -     DBX debugging information is appropriate.
  47888. -
  47889. -`DBX_OUTPUT_MAIN_SOURCE_FILE_END (STREAM, NAME)'
  47890. -     A C statement to output DBX debugging information at the end of
  47891. -     compilation of the main source file NAME.
  47892. -
  47893. -     If you don't define this macro, nothing special is output at the
  47894. -     end of compilation, which is correct for most machines.
  47895. -
  47896. -`DBX_OUTPUT_SOURCE_FILENAME (STREAM, NAME)'
  47897. -     A C statement to output DBX debugging information to the stdio
  47898. -     stream STREAM which indicates that file NAME is the current source
  47899. -     file.  This output is generated each time input shifts to a
  47900. -     different source file as a result of `#include', the end of an
  47901. -     included file, or a `#line' command.
  47902. -
  47903. -     This macro need not be defined if the standard form of output for
  47904. -     DBX debugging information is appropriate.
  47905. -
  47906. -
  47907. -File: gcc.info,  Node: SDB and DWARF,  Prev: File Names and DBX,  Up: Debugging Info
  47908. -
  47909. -Macros for SDB and DWARF Output
  47910. --------------------------------
  47911. -
  47912. -   Here are macros for SDB and DWARF output.
  47913. -
  47914. -`SDB_DEBUGGING_INFO'
  47915. -     Define this macro if GNU CC should produce COFF-style debugging
  47916. -     output for SDB in response to the `-g' option.
  47917. -
  47918. -`DWARF_DEBUGGING_INFO'
  47919. -     Define this macro if GNU CC should produce dwarf format debugging
  47920. -     output in response to the `-g' option.
  47921. -
  47922. -`PUT_SDB_...'
  47923. -     Define these macros to override the assembler syntax for the
  47924. -     special SDB assembler directives.  See `sdbout.c' for a list of
  47925. -     these macros and their arguments.  If the standard syntax is used,
  47926. -     you need not define them yourself.
  47927. -
  47928. -`SDB_DELIM'
  47929. -     Some assemblers do not support a semicolon as a delimiter, even
  47930. -     between SDB assembler directives.  In that case, define this macro
  47931. -     to be the delimiter to use (usually `\n').  It is not necessary to
  47932. -     define a new set of `PUT_SDB_OP' macros if this is the only change
  47933. -     required.
  47934. -
  47935. -`SDB_GENERATE_FAKE'
  47936. -     Define this macro to override the usual method of constructing a
  47937. -     dummy name for anonymous structure and union types.  See
  47938. -     `sdbout.c' for more information.
  47939. -
  47940. -`SDB_ALLOW_UNKNOWN_REFERENCES'
  47941. -     Define this macro to allow references to unknown structure, union,
  47942. -     or enumeration tags to be emitted.  Standard COFF does not allow
  47943. -     handling of unknown references, MIPS ECOFF has support for it.
  47944. -
  47945. -`SDB_ALLOW_FORWARD_REFERENCES'
  47946. -     Define this macro to allow references to structure, union, or
  47947. -     enumeration tags that have not yet been seen to be handled.  Some
  47948. -     assemblers choke if forward tags are used, while some require it.
  47949. -
  47950. diff -rup --new-file baseline/fsf/gcc/gcc.info-24 amiga/fsf/gcc/gcc.info-24
  47951. --- baseline/fsf/gcc/gcc.info-24    Sat Jun 29 09:38:10 1996
  47952. +++ amiga/fsf/gcc/gcc.info-24    Wed Dec 31 17:00:00 1969
  47953. @@ -1,852 +0,0 @@
  47954. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  47955. -file gcc.texi.
  47956. -
  47957. -   This file documents the use and the internals of the GNU compiler.
  47958. -
  47959. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  47960. -Boston, MA 02111-1307 USA
  47961. -
  47962. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  47963. -Foundation, Inc.
  47964. -
  47965. -   Permission is granted to make and distribute verbatim copies of this
  47966. -manual provided the copyright notice and this permission notice are
  47967. -preserved on all copies.
  47968. -
  47969. -   Permission is granted to copy and distribute modified versions of
  47970. -this manual under the conditions for verbatim copying, provided also
  47971. -that the sections entitled "GNU General Public License," "Funding for
  47972. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  47973. -included exactly as in the original, and provided that the entire
  47974. -resulting derived work is distributed under the terms of a permission
  47975. -notice identical to this one.
  47976. -
  47977. -   Permission is granted to copy and distribute translations of this
  47978. -manual into another language, under the above conditions for modified
  47979. -versions, except that the sections entitled "GNU General Public
  47980. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  47981. -`Look And Feel'", and this permission notice, may be included in
  47982. -translations approved by the Free Software Foundation instead of in the
  47983. -original English.
  47984. -
  47985. -
  47986. -File: gcc.info,  Node: Cross-compilation,  Next: Misc,  Prev: Debugging Info,  Up: Target Macros
  47987. -
  47988. -Cross Compilation and Floating Point
  47989. -====================================
  47990. -
  47991. -   While all modern machines use 2's complement representation for
  47992. -integers, there are a variety of representations for floating point
  47993. -numbers.  This means that in a cross-compiler the representation of
  47994. -floating point numbers in the compiled program may be different from
  47995. -that used in the machine doing the compilation.
  47996. -
  47997. -   Because different representation systems may offer different amounts
  47998. -of range and precision, the cross compiler cannot safely use the host
  47999. -machine's floating point arithmetic.  Therefore, floating point
  48000. -constants must be represented in the target machine's format.  This
  48001. -means that the cross compiler cannot use `atof' to parse a floating
  48002. -point constant; it must have its own special routine to use instead.
  48003. -Also, constant folding must emulate the target machine's arithmetic (or
  48004. -must not be done at all).
  48005. -
  48006. -   The macros in the following table should be defined only if you are
  48007. -cross compiling between different floating point formats.
  48008. -
  48009. -   Otherwise, don't define them.  Then default definitions will be set
  48010. -up which use `double' as the data type, `==' to test for equality, etc.
  48011. -
  48012. -   You don't need to worry about how many times you use an operand of
  48013. -any of these macros.  The compiler never uses operands which have side
  48014. -effects.
  48015. -
  48016. -`REAL_VALUE_TYPE'
  48017. -     A macro for the C data type to be used to hold a floating point
  48018. -     value in the target machine's format.  Typically this would be a
  48019. -     `struct' containing an array of `int'.
  48020. -
  48021. -`REAL_VALUES_EQUAL (X, Y)'
  48022. -     A macro for a C expression which compares for equality the two
  48023. -     values, X and Y, both of type `REAL_VALUE_TYPE'.
  48024. -
  48025. -`REAL_VALUES_LESS (X, Y)'
  48026. -     A macro for a C expression which tests whether X is less than Y,
  48027. -     both values being of type `REAL_VALUE_TYPE' and interpreted as
  48028. -     floating point numbers in the target machine's representation.
  48029. -
  48030. -`REAL_VALUE_LDEXP (X, SCALE)'
  48031. -     A macro for a C expression which performs the standard library
  48032. -     function `ldexp', but using the target machine's floating point
  48033. -     representation.  Both X and the value of the expression have type
  48034. -     `REAL_VALUE_TYPE'.  The second argument, SCALE, is an integer.
  48035. -
  48036. -`REAL_VALUE_FIX (X)'
  48037. -     A macro whose definition is a C expression to convert the
  48038. -     target-machine floating point value X to a signed integer.  X has
  48039. -     type `REAL_VALUE_TYPE'.
  48040. -
  48041. -`REAL_VALUE_UNSIGNED_FIX (X)'
  48042. -     A macro whose definition is a C expression to convert the
  48043. -     target-machine floating point value X to an unsigned integer.  X
  48044. -     has type `REAL_VALUE_TYPE'.
  48045. -
  48046. -`REAL_VALUE_RNDZINT (X)'
  48047. -     A macro whose definition is a C expression to round the
  48048. -     target-machine floating point value X towards zero to an integer
  48049. -     value (but still as a floating point number).  X has type
  48050. -     `REAL_VALUE_TYPE', and so does the value.
  48051. -
  48052. -`REAL_VALUE_UNSIGNED_RNDZINT (X)'
  48053. -     A macro whose definition is a C expression to round the
  48054. -     target-machine floating point value X towards zero to an unsigned
  48055. -     integer value (but still represented as a floating point number).
  48056. -     x has type `REAL_VALUE_TYPE', and so does the value.
  48057. -
  48058. -`REAL_VALUE_ATOF (STRING, MODE)'
  48059. -     A macro for a C expression which converts STRING, an expression of
  48060. -     type `char *', into a floating point number in the target machine's
  48061. -     representation for mode MODE.  The value has type
  48062. -     `REAL_VALUE_TYPE'.
  48063. -
  48064. -`REAL_INFINITY'
  48065. -     Define this macro if infinity is a possible floating point value,
  48066. -     and therefore division by 0 is legitimate.
  48067. -
  48068. -`REAL_VALUE_ISINF (X)'
  48069. -     A macro for a C expression which determines whether X, a floating
  48070. -     point value, is infinity.  The value has type `int'.  By default,
  48071. -     this is defined to call `isinf'.
  48072. -
  48073. -`REAL_VALUE_ISNAN (X)'
  48074. -     A macro for a C expression which determines whether X, a floating
  48075. -     point value, is a "nan" (not-a-number).  The value has type `int'.
  48076. -     By default, this is defined to call `isnan'.
  48077. -
  48078. -   Define the following additional macros if you want to make floating
  48079. -point constant folding work while cross compiling.  If you don't define
  48080. -them, cross compilation is still possible, but constant folding will
  48081. -not happen for floating point values.
  48082. -
  48083. -`REAL_ARITHMETIC (OUTPUT, CODE, X, Y)'
  48084. -     A macro for a C statement which calculates an arithmetic operation
  48085. -     of the two floating point values X and Y, both of type
  48086. -     `REAL_VALUE_TYPE' in the target machine's representation, to
  48087. -     produce a result of the same type and representation which is
  48088. -     stored in OUTPUT (which will be a variable).
  48089. -
  48090. -     The operation to be performed is specified by CODE, a tree code
  48091. -     which will always be one of the following: `PLUS_EXPR',
  48092. -     `MINUS_EXPR', `MULT_EXPR', `RDIV_EXPR', `MAX_EXPR', `MIN_EXPR'.
  48093. -
  48094. -     The expansion of this macro is responsible for checking for
  48095. -     overflow.  If overflow happens, the macro expansion should execute
  48096. -     the statement `return 0;', which indicates the inability to
  48097. -     perform the arithmetic operation requested.
  48098. -
  48099. -`REAL_VALUE_NEGATE (X)'
  48100. -     A macro for a C expression which returns the negative of the
  48101. -     floating point value X.  Both X and the value of the expression
  48102. -     have type `REAL_VALUE_TYPE' and are in the target machine's
  48103. -     floating point representation.
  48104. -
  48105. -     There is no way for this macro to report overflow, since overflow
  48106. -     can't happen in the negation operation.
  48107. -
  48108. -`REAL_VALUE_TRUNCATE (MODE, X)'
  48109. -     A macro for a C expression which converts the floating point value
  48110. -     X to mode MODE.
  48111. -
  48112. -     Both X and the value of the expression are in the target machine's
  48113. -     floating point representation and have type `REAL_VALUE_TYPE'.
  48114. -     However, the value should have an appropriate bit pattern to be
  48115. -     output properly as a floating constant whose precision accords
  48116. -     with mode MODE.
  48117. -
  48118. -     There is no way for this macro to report overflow.
  48119. -
  48120. -`REAL_VALUE_TO_INT (LOW, HIGH, X)'
  48121. -     A macro for a C expression which converts a floating point value X
  48122. -     into a double-precision integer which is then stored into LOW and
  48123. -     HIGH, two variables of type INT.
  48124. -
  48125. -`REAL_VALUE_FROM_INT (X, LOW, HIGH)'
  48126. -     A macro for a C expression which converts a double-precision
  48127. -     integer found in LOW and HIGH, two variables of type INT, into a
  48128. -     floating point value which is then stored into X.
  48129. -
  48130. -
  48131. -File: gcc.info,  Node: Misc,  Prev: Cross-compilation,  Up: Target Macros
  48132. -
  48133. -Miscellaneous Parameters
  48134. -========================
  48135. -
  48136. -   Here are several miscellaneous parameters.
  48137. -
  48138. -`PREDICATE_CODES'
  48139. -     Define this if you have defined special-purpose predicates in the
  48140. -     file `MACHINE.c'.  This macro is called within an initializer of an
  48141. -     array of structures.  The first field in the structure is the name
  48142. -     of a predicate and the second field is an array of rtl codes.  For
  48143. -     each predicate, list all rtl codes that can be in expressions
  48144. -     matched by the predicate.  The list should have a trailing comma.
  48145. -     Here is an example of two entries in the list for a typical RISC
  48146. -     machine:
  48147. -
  48148. -          #define PREDICATE_CODES \
  48149. -            {"gen_reg_rtx_operand", {SUBREG, REG}},  \
  48150. -            {"reg_or_short_cint_operand", {SUBREG, REG, CONST_INT}},
  48151. -
  48152. -     Defining this macro does not affect the generated code (however,
  48153. -     incorrect definitions that omit an rtl code that may be matched by
  48154. -     the predicate can cause the compiler to malfunction).  Instead, it
  48155. -     allows the table built by `genrecog' to be more compact and
  48156. -     efficient, thus speeding up the compiler.  The most important
  48157. -     predicates to include in the list specified by this macro are
  48158. -     thoses used in the most insn patterns.
  48159. -
  48160. -`CASE_VECTOR_MODE'
  48161. -     An alias for a machine mode name.  This is the machine mode that
  48162. -     elements of a jump-table should have.
  48163. -
  48164. -`CASE_VECTOR_PC_RELATIVE'
  48165. -     Define this macro if jump-tables should contain relative addresses.
  48166. -
  48167. -`CASE_DROPS_THROUGH'
  48168. -     Define this if control falls through a `case' insn when the index
  48169. -     value is out of range.  This means the specified default-label is
  48170. -     actually ignored by the `case' insn proper.
  48171. -
  48172. -`CASE_VALUES_THRESHOLD'
  48173. -     Define this to be the smallest number of different values for
  48174. -     which it is best to use a jump-table instead of a tree of
  48175. -     conditional branches.  The default is four for machines with a
  48176. -     `casesi' instruction and five otherwise.  This is best for most
  48177. -     machines.
  48178. -
  48179. -`WORD_REGISTER_OPERATIONS'
  48180. -     Define this macro if operations between registers with integral
  48181. -     mode smaller than a word are always performed on the entire
  48182. -     register.  Most RISC machines have this property and most CISC
  48183. -     machines do not.
  48184. -
  48185. -`LOAD_EXTEND_OP (MODE)'
  48186. -     Define this macro to be a C expression indicating when insns that
  48187. -     read memory in MODE, an integral mode narrower than a word, set the
  48188. -     bits outside of MODE to be either the sign-extension or the
  48189. -     zero-extension of the data read.  Return `SIGN_EXTEND' for values
  48190. -     of MODE for which the insn sign-extends, `ZERO_EXTEND' for which
  48191. -     it zero-extends, and `NIL' for other modes.
  48192. -
  48193. -     This macro is not called with MODE non-integral or with a width
  48194. -     greater than or equal to `BITS_PER_WORD', so you may return any
  48195. -     value in this case.  Do not define this macro if it would always
  48196. -     return `NIL'.  On machines where this macro is defined, you will
  48197. -     normally define it as the constant `SIGN_EXTEND' or `ZERO_EXTEND'.
  48198. -
  48199. -`IMPLICIT_FIX_EXPR'
  48200. -     An alias for a tree code that should be used by default for
  48201. -     conversion of floating point values to fixed point.  Normally,
  48202. -     `FIX_ROUND_EXPR' is used.
  48203. -
  48204. -`FIXUNS_TRUNC_LIKE_FIX_TRUNC'
  48205. -     Define this macro if the same instructions that convert a floating
  48206. -     point number to a signed fixed point number also convert validly
  48207. -     to an unsigned one.
  48208. -
  48209. -`EASY_DIV_EXPR'
  48210. -     An alias for a tree code that is the easiest kind of division to
  48211. -     compile code for in the general case.  It may be `TRUNC_DIV_EXPR',
  48212. -     `FLOOR_DIV_EXPR', `CEIL_DIV_EXPR' or `ROUND_DIV_EXPR'.  These four
  48213. -     division operators differ in how they round the result to an
  48214. -     integer.  `EASY_DIV_EXPR' is used when it is permissible to use
  48215. -     any of those kinds of division and the choice should be made on
  48216. -     the basis of efficiency.
  48217. -
  48218. -`MOVE_MAX'
  48219. -     The maximum number of bytes that a single instruction can move
  48220. -     quickly from memory to memory.
  48221. -
  48222. -`MAX_MOVE_MAX'
  48223. -     The maximum number of bytes that a single instruction can move
  48224. -     quickly from memory to memory.  If this is undefined, the default
  48225. -     is `MOVE_MAX'.  Otherwise, it is the constant value that is the
  48226. -     largest value that `MOVE_MAX' can have at run-time.
  48227. -
  48228. -`SHIFT_COUNT_TRUNCATED'
  48229. -     A C expression that is nonzero if on this machine the number of
  48230. -     bits actually used for the count of a shift operation is equal to
  48231. -     the number of bits needed to represent the size of the object
  48232. -     being shifted.  When this macro is non-zero, the compiler will
  48233. -     assume that it is safe to omit a sign-extend, zero-extend, and
  48234. -     certain bitwise `and' instructions that truncates the count of a
  48235. -     shift operation.  On machines that have instructions that act on
  48236. -     bitfields at variable positions, which may include `bit test'
  48237. -     instructions, a nonzero `SHIFT_COUNT_TRUNCATED' also enables
  48238. -     deletion of truncations of the values that serve as arguments to
  48239. -     bitfield instructions.
  48240. -
  48241. -     If both types of instructions truncate the count (for shifts) and
  48242. -     position (for bitfield operations), or if no variable-position
  48243. -     bitfield instructions exist, you should define this macro.
  48244. -
  48245. -     However, on some machines, such as the 80386 and the 680x0,
  48246. -     truncation only applies to shift operations and not the (real or
  48247. -     pretended) bitfield operations.  Define `SHIFT_COUNT_TRUNCATED' to
  48248. -     be zero on such machines.  Instead, add patterns to the `md' file
  48249. -     that include the implied truncation of the shift instructions.
  48250. -
  48251. -     You need not define this macro if it would always have the value
  48252. -     of zero.
  48253. -
  48254. -`TRULY_NOOP_TRUNCATION (OUTPREC, INPREC)'
  48255. -     A C expression which is nonzero if on this machine it is safe to
  48256. -     "convert" an integer of INPREC bits to one of OUTPREC bits (where
  48257. -     OUTPREC is smaller than INPREC) by merely operating on it as if it
  48258. -     had only OUTPREC bits.
  48259. -
  48260. -     On many machines, this expression can be 1.
  48261. -
  48262. -     When `TRULY_NOOP_TRUNCATION' returns 1 for a pair of sizes for
  48263. -     modes for which `MODES_TIEABLE_P' is 0, suboptimal code can result.
  48264. -     If this is the case, making `TRULY_NOOP_TRUNCATION' return 0 in
  48265. -     such cases may improve things.
  48266. -
  48267. -`STORE_FLAG_VALUE'
  48268. -     A C expression describing the value returned by a comparison
  48269. -     operator with an integral mode and stored by a store-flag
  48270. -     instruction (`sCOND') when the condition is true.  This
  48271. -     description must apply to *all* the `sCOND' patterns and all the
  48272. -     comparison operators whose results have a `MODE_INT' mode.
  48273. -
  48274. -     A value of 1 or -1 means that the instruction implementing the
  48275. -     comparison operator returns exactly 1 or -1 when the comparison is
  48276. -     true and 0 when the comparison is false.  Otherwise, the value
  48277. -     indicates which bits of the result are guaranteed to be 1 when the
  48278. -     comparison is true.  This value is interpreted in the mode of the
  48279. -     comparison operation, which is given by the mode of the first
  48280. -     operand in the `sCOND' pattern.  Either the low bit or the sign
  48281. -     bit of `STORE_FLAG_VALUE' be on.  Presently, only those bits are
  48282. -     used by the compiler.
  48283. -
  48284. -     If `STORE_FLAG_VALUE' is neither 1 or -1, the compiler will
  48285. -     generate code that depends only on the specified bits.  It can also
  48286. -     replace comparison operators with equivalent operations if they
  48287. -     cause the required bits to be set, even if the remaining bits are
  48288. -     undefined.  For example, on a machine whose comparison operators
  48289. -     return an `SImode' value and where `STORE_FLAG_VALUE' is defined as
  48290. -     `0x80000000', saying that just the sign bit is relevant, the
  48291. -     expression
  48292. -
  48293. -          (ne:SI (and:SI X (const_int POWER-OF-2)) (const_int 0))
  48294. -
  48295. -     can be converted to
  48296. -
  48297. -          (ashift:SI X (const_int N))
  48298. -
  48299. -     where N is the appropriate shift count to move the bit being
  48300. -     tested into the sign bit.
  48301. -
  48302. -     There is no way to describe a machine that always sets the
  48303. -     low-order bit for a true value, but does not guarantee the value
  48304. -     of any other bits, but we do not know of any machine that has such
  48305. -     an instruction.  If you are trying to port GNU CC to such a
  48306. -     machine, include an instruction to perform a logical-and of the
  48307. -     result with 1 in the pattern for the comparison operators and let
  48308. -     us know (*note How to Report Bugs: Bug Reporting.).
  48309. -
  48310. -     Often, a machine will have multiple instructions that obtain a
  48311. -     value from a comparison (or the condition codes).  Here are rules
  48312. -     to guide the choice of value for `STORE_FLAG_VALUE', and hence the
  48313. -     instructions to be used:
  48314. -
  48315. -        * Use the shortest sequence that yields a valid definition for
  48316. -          `STORE_FLAG_VALUE'.  It is more efficient for the compiler to
  48317. -          "normalize" the value (convert it to, e.g., 1 or 0) than for
  48318. -          the comparison operators to do so because there may be
  48319. -          opportunities to combine the normalization with other
  48320. -          operations.
  48321. -
  48322. -        * For equal-length sequences, use a value of 1 or -1, with -1
  48323. -          being slightly preferred on machines with expensive jumps and
  48324. -          1 preferred on other machines.
  48325. -
  48326. -        * As a second choice, choose a value of `0x80000001' if
  48327. -          instructions exist that set both the sign and low-order bits
  48328. -          but do not define the others.
  48329. -
  48330. -        * Otherwise, use a value of `0x80000000'.
  48331. -
  48332. -     Many machines can produce both the value chosen for
  48333. -     `STORE_FLAG_VALUE' and its negation in the same number of
  48334. -     instructions.  On those machines, you should also define a pattern
  48335. -     for those cases, e.g., one matching
  48336. -
  48337. -          (set A (neg:M (ne:M B C)))
  48338. -
  48339. -     Some machines can also perform `and' or `plus' operations on
  48340. -     condition code values with less instructions than the corresponding
  48341. -     `sCOND' insn followed by `and' or `plus'.  On those machines,
  48342. -     define the appropriate patterns.  Use the names `incscc' and
  48343. -     `decscc', respectively, for the the patterns which perform `plus'
  48344. -     or `minus' operations on condition code values.  See `rs6000.md'
  48345. -     for some examples.  The GNU Superoptizer can be used to find such
  48346. -     instruction sequences on other machines.
  48347. -
  48348. -     You need not define `STORE_FLAG_VALUE' if the machine has no
  48349. -     store-flag instructions.
  48350. -
  48351. -`FLOAT_STORE_FLAG_VALUE'
  48352. -     A C expression that gives a non-zero floating point value that is
  48353. -     returned when comparison operators with floating-point results are
  48354. -     true.  Define this macro on machine that have comparison
  48355. -     operations that return floating-point values.  If there are no
  48356. -     such operations, do not define this macro.
  48357. -
  48358. -`Pmode'
  48359. -     An alias for the machine mode for pointers.  On most machines,
  48360. -     define this to be the integer mode corresponding to the width of a
  48361. -     hardware pointer; `SImode' on 32-bit machine or `DImode' on 64-bit
  48362. -     machines.  On some machines you must define this to be one of the
  48363. -     partial integer modes, such as `PSImode'.
  48364. -
  48365. -     The width of `Pmode' must be at least as large as the value of
  48366. -     `POINTER_SIZE'.  If it is not equal, you must define the macro
  48367. -     `POINTERS_EXTEND_UNSIGNED' to specify how pointers are extended to
  48368. -     `Pmode'.
  48369. -
  48370. -`FUNCTION_MODE'
  48371. -     An alias for the machine mode used for memory references to
  48372. -     functions being called, in `call' RTL expressions.  On most
  48373. -     machines this should be `QImode'.
  48374. -
  48375. -`INTEGRATE_THRESHOLD (DECL)'
  48376. -     A C expression for the maximum number of instructions above which
  48377. -     the function DECL should not be inlined.  DECL is a
  48378. -     `FUNCTION_DECL' node.
  48379. -
  48380. -     The default definition of this macro is 64 plus 8 times the number
  48381. -     of arguments that the function accepts.  Some people think a larger
  48382. -     threshold should be used on RISC machines.
  48383. -
  48384. -`SCCS_DIRECTIVE'
  48385. -     Define this if the preprocessor should ignore `#sccs' directives
  48386. -     and print no error message.
  48387. -
  48388. -`NO_IMPLICIT_EXTERN_C'
  48389. -     Define this macro if the system header files support C++ as well
  48390. -     as C.  This macro inhibits the usual method of using system header
  48391. -     files in C++, which is to pretend that the file's contents are
  48392. -     enclosed in `extern "C" {...}'.
  48393. -
  48394. -`HANDLE_PRAGMA (STREAM)'
  48395. -     Define this macro if you want to implement any pragmas.  If
  48396. -     defined, it should be a C statement to be executed when `#pragma'
  48397. -     is seen.  The argument STREAM is the stdio input stream from which
  48398. -     the source text can be read.
  48399. -
  48400. -     It is generally a bad idea to implement new uses of `#pragma'.  The
  48401. -     only reason to define this macro is for compatibility with other
  48402. -     compilers that do support `#pragma' for the sake of any user
  48403. -     programs which already use it.
  48404. -
  48405. -`VALID_MACHINE_DECL_ATTRIBUTE (DECL, ATTRIBUTES, IDENTIFIER, ARGS)'
  48406. -     If defined, a C expression whose value is nonzero if IDENTIFIER
  48407. -     with arguments ARGS is a valid machine specific attribute for DECL.
  48408. -     The attributes in ATTRIBUTES have previously been assigned to DECL.
  48409. -
  48410. -`VALID_MACHINE_TYPE_ATTRIBUTE (TYPE, ATTRIBUTES, IDENTIFIER, ARGS)'
  48411. -     If defined, a C expression whose value is nonzero if IDENTIFIER
  48412. -     with arguments ARGS is a valid machine specific attribute for TYPE.
  48413. -     The attributes in ATTRIBUTES have previously been assigned to TYPE.
  48414. -
  48415. -`COMP_TYPE_ATTRIBUTES (TYPE1, TYPE2)'
  48416. -     If defined, a C expression whose value is zero if the attributes on
  48417. -     TYPE1 and TYPE2 are incompatible, one if they are compatible, and
  48418. -     two if they are nearly compatible (which causes a warning to be
  48419. -     generated).
  48420. -
  48421. -`SET_DEFAULT_TYPE_ATTRIBUTES (TYPE)'
  48422. -     If defined, a C statement that assigns default attributes to newly
  48423. -     defined TYPE.
  48424. -
  48425. -`DOLLARS_IN_IDENTIFIERS'
  48426. -     Define this macro to control use of the character `$' in identifier
  48427. -     names.  The value should be 0, 1, or 2.  0 means `$' is not allowed
  48428. -     by default; 1 means it is allowed by default if `-traditional' is
  48429. -     used; 2 means it is allowed by default provided `-ansi' is not
  48430. -     used.  1 is the default; there is no need to define this macro in
  48431. -     that case.
  48432. -
  48433. -`NO_DOLLAR_IN_LABEL'
  48434. -     Define this macro if the assembler does not accept the character
  48435. -     `$' in label names.  By default constructors and destructors in
  48436. -     G++ have `$' in the identifiers.  If this macro is defined, `.' is
  48437. -     used instead.
  48438. -
  48439. -`NO_DOT_IN_LABEL'
  48440. -     Define this macro if the assembler does not accept the character
  48441. -     `.' in label names.  By default constructors and destructors in G++
  48442. -     have names that use `.'.  If this macro is defined, these names
  48443. -     are rewritten to avoid `.'.
  48444. -
  48445. -`DEFAULT_MAIN_RETURN'
  48446. -     Define this macro if the target system expects every program's
  48447. -     `main' function to return a standard "success" value by default
  48448. -     (if no other value is explicitly returned).
  48449. -
  48450. -     The definition should be a C statement (sans semicolon) to
  48451. -     generate the appropriate rtl instructions.  It is used only when
  48452. -     compiling the end of `main'.
  48453. -
  48454. -`HAVE_ATEXIT'
  48455. -     Define this if the target system supports the function `atexit'
  48456. -     from the ANSI C standard.  If this is not defined, and
  48457. -     `INIT_SECTION_ASM_OP' is not defined, a default `exit' function
  48458. -     will be provided to support C++.
  48459. -
  48460. -`EXIT_BODY'
  48461. -     Define this if your `exit' function needs to do something besides
  48462. -     calling an external function `_cleanup' before terminating with
  48463. -     `_exit'.  The `EXIT_BODY' macro is only needed if netiher
  48464. -     `HAVE_ATEXIT' nor `INIT_SECTION_ASM_OP' are defined.
  48465. -
  48466. -`INSN_SETS_ARE_DELAYED (INSN)'
  48467. -     Define this macro as a C expression that is nonzero if it is safe
  48468. -     for the delay slot scheduler to place instructions in the delay
  48469. -     slot of INSN, even if they appear to use a resource set or
  48470. -     clobbered in INSN.  INSN is always a `jump_insn' or an `insn'; GNU
  48471. -     CC knows that every `call_insn' has this behavior.  On machines
  48472. -     where some `insn' or `jump_insn' is really a function call and
  48473. -     hence has this behavior, you should define this macro.
  48474. -
  48475. -     You need not define this macro if it would always return zero.
  48476. -
  48477. -`INSN_REFERENCES_ARE_DELAYED (INSN)'
  48478. -     Define this macro as a C expression that is nonzero if it is safe
  48479. -     for the delay slot scheduler to place instructions in the delay
  48480. -     slot of INSN, even if they appear to set or clobber a resource
  48481. -     referenced in INSN.  INSN is always a `jump_insn' or an `insn'.
  48482. -     On machines where some `insn' or `jump_insn' is really a function
  48483. -     call and its operands are registers whose use is actually in the
  48484. -     subroutine it calls, you should define this macro.  Doing so
  48485. -     allows the delay slot scheduler to move instructions which copy
  48486. -     arguments into the argument registers into the delay slot of INSN.
  48487. -
  48488. -     You need not define this macro if it would always return zero.
  48489. -
  48490. -`MACHINE_DEPENDENT_REORG (INSN)'
  48491. -     In rare cases, correct code generation requires extra machine
  48492. -     dependent processing between the second jump optimization pass and
  48493. -     delayed branch scheduling.  On those machines, define this macro
  48494. -     as a C statement to act on the code starting at INSN.
  48495. -
  48496. -
  48497. -File: gcc.info,  Node: Config,  Next: Fragments,  Prev: Target Macros,  Up: Top
  48498. -
  48499. -The Configuration File
  48500. -**********************
  48501. -
  48502. -   The configuration file `xm-MACHINE.h' contains macro definitions
  48503. -that describe the machine and system on which the compiler is running,
  48504. -unlike the definitions in `MACHINE.h', which describe the machine for
  48505. -which the compiler is producing output.  Most of the values in
  48506. -`xm-MACHINE.h' are actually the same on all machines that GNU CC runs
  48507. -on, so large parts of all configuration files are identical.  But there
  48508. -are some macros that vary:
  48509. -
  48510. -`USG'
  48511. -     Define this macro if the host system is System V.
  48512. -
  48513. -`VMS'
  48514. -     Define this macro if the host system is VMS.
  48515. -
  48516. -`FATAL_EXIT_CODE'
  48517. -     A C expression for the status code to be returned when the compiler
  48518. -     exits after serious errors.
  48519. -
  48520. -`SUCCESS_EXIT_CODE'
  48521. -     A C expression for the status code to be returned when the compiler
  48522. -     exits without serious errors.
  48523. -
  48524. -`HOST_WORDS_BIG_ENDIAN'
  48525. -     Defined if the host machine stores words of multi-word values in
  48526. -     big-endian order.  (GNU CC does not depend on the host byte
  48527. -     ordering within a word.)
  48528. -
  48529. -`HOST_FLOAT_WORDS_BIG_ENDIAN'
  48530. -     Define this macro to be 1 if the host machine stores `DFmode',
  48531. -     `XFmode' or `TFmode' floating point numbers in memory with the
  48532. -     word containing the sign bit at the lowest address; otherwise,
  48533. -     define it to be zero.
  48534. -
  48535. -     This macro need not be defined if the ordering is the same as for
  48536. -     multi-word integers.
  48537. -
  48538. -`HOST_FLOAT_FORMAT'
  48539. -     A numeric code distinguishing the floating point format for the
  48540. -     host machine.  See `TARGET_FLOAT_FORMAT' in *Note Storage Layout::
  48541. -     for the alternatives and default.
  48542. -
  48543. -`HOST_BITS_PER_CHAR'
  48544. -     A C expression for the number of bits in `char' on the host
  48545. -     machine.
  48546. -
  48547. -`HOST_BITS_PER_SHORT'
  48548. -     A C expression for the number of bits in `short' on the host
  48549. -     machine.
  48550. -
  48551. -`HOST_BITS_PER_INT'
  48552. -     A C expression for the number of bits in `int' on the host machine.
  48553. -
  48554. -`HOST_BITS_PER_LONG'
  48555. -     A C expression for the number of bits in `long' on the host
  48556. -     machine.
  48557. -
  48558. -`ONLY_INT_FIELDS'
  48559. -     Define this macro to indicate that the host compiler only supports
  48560. -     `int' bit fields, rather than other integral types, including
  48561. -     `enum', as do most C compilers.
  48562. -
  48563. -`OBSTACK_CHUNK_SIZE'
  48564. -     A C expression for the size of ordinary obstack chunks.  If you
  48565. -     don't define this, a usually-reasonable default is used.
  48566. -
  48567. -`OBSTACK_CHUNK_ALLOC'
  48568. -     The function used to allocate obstack chunks.  If you don't define
  48569. -     this, `xmalloc' is used.
  48570. -
  48571. -`OBSTACK_CHUNK_FREE'
  48572. -     The function used to free obstack chunks.  If you don't define
  48573. -     this, `free' is used.
  48574. -
  48575. -`USE_C_ALLOCA'
  48576. -     Define this macro to indicate that the compiler is running with the
  48577. -     `alloca' implemented in C.  This version of `alloca' can be found
  48578. -     in the file `alloca.c'; to use it, you must also alter the
  48579. -     `Makefile' variable `ALLOCA'.  (This is done automatically for the
  48580. -     systems on which we know it is needed.)
  48581. -
  48582. -     If you do define this macro, you should probably do it as follows:
  48583. -
  48584. -          #ifndef __GNUC__
  48585. -          #define USE_C_ALLOCA
  48586. -          #else
  48587. -          #define alloca __builtin_alloca
  48588. -          #endif
  48589. -
  48590. -     so that when the compiler is compiled with GNU CC it uses the more
  48591. -     efficient built-in `alloca' function.
  48592. -
  48593. -`FUNCTION_CONVERSION_BUG'
  48594. -     Define this macro to indicate that the host compiler does not
  48595. -     properly handle converting a function value to a
  48596. -     pointer-to-function when it is used in an expression.
  48597. -
  48598. -`HAVE_VPRINTF'
  48599. -     Define this if the library function `vprintf' is available on your
  48600. -     system.
  48601. -
  48602. -`MULTIBYTE_CHARS'
  48603. -     Define this macro to enable support for multibyte characters in the
  48604. -     input to GNU CC.  This requires that the host system support the
  48605. -     ANSI C library functions for converting multibyte characters to
  48606. -     wide characters.
  48607. -
  48608. -`HAVE_PUTENV'
  48609. -     Define this if the library function `putenv' is available on your
  48610. -     system.
  48611. -
  48612. -`POSIX'
  48613. -     Define this if your system is POSIX.1 compliant.
  48614. -
  48615. -`NO_SYS_SIGLIST'
  48616. -     Define this if your system *does not* provide the variable
  48617. -     `sys_siglist'.
  48618. -
  48619. -`DONT_DECLARE_SYS_SIGLIST'
  48620. -     Define this if your system has the variable `sys_siglist', and
  48621. -     there is already a declaration of it in the system header files.
  48622. -
  48623. -`USE_PROTOTYPES'
  48624. -     Define this to be 1 if you know that the host compiler supports
  48625. -     prototypes, even if it doesn't define __STDC__, or define it to be
  48626. -     0 if you do not want any prototypes used in compiling GNU CC.  If
  48627. -     `USE_PROTOTYPES' is not defined, it will be determined
  48628. -     automatically whether your compiler supports prototypes by
  48629. -     checking if `__STDC__' is defined.
  48630. -
  48631. -`NO_MD_PROTOTYPES'
  48632. -     Define this if you wish suppression of prototypes generated from
  48633. -     the machine description file, but to use other prototypes within
  48634. -     GNU CC.  If `USE_PROTOTYPES' is defined to be 0, or the host
  48635. -     compiler does not support prototypes, this macro has no effect.
  48636. -
  48637. -`MD_CALL_PROTOTYPES'
  48638. -     Define this if you wish to generate prototypes for the `gen_call'
  48639. -     or `gen_call_value' functions generated from the machine
  48640. -     description file.  If `USE_PROTOTYPES' is defined to be 0, or the
  48641. -     host compiler does not support prototypes, or `NO_MD_PROTOTYPES'
  48642. -     is defined, this macro has no effect.  As soon as all of the
  48643. -     machine descriptions are modified to have the appropriate number
  48644. -     of arguments, this macro will be removed.
  48645. -
  48646. -     Some systems do provide this variable, but with a different name
  48647. -     such as `_sys_siglist'.  On these systems, you can define
  48648. -     `sys_siglist' as a macro which expands into the name actually
  48649. -     provided.
  48650. -
  48651. -`NO_STAB_H'
  48652. -     Define this if your system does not have the include file
  48653. -     `stab.h'.  If `USG' is defined, `NO_STAB_H' is assumed.
  48654. -
  48655. -`PATH_SEPARATOR'
  48656. -     Define this macro to be a C character constant representing the
  48657. -     character used to separate components in paths.  The default value
  48658. -     is.  the colon character
  48659. -
  48660. -`DIR_SEPARATOR'
  48661. -     If your system uses some character other than slash to separate
  48662. -     directory names within a file specification, define this macro to
  48663. -     be a C character constant specifying that character.  When GNU CC
  48664. -     displays file names, the character you specify will be used.  GNU
  48665. -     CC will test for both slash and the character you specify when
  48666. -     parsing filenames.
  48667. -
  48668. -`OBJECT_SUFFIX'
  48669. -     Define this macro to be a C string representing the suffix for
  48670. -     object files on your machine.  If you do not define this macro,
  48671. -     GNU CC will use `.o' as the suffix for object files.
  48672. -
  48673. -`EXECUTABLE_SUFFIX'
  48674. -     Define this macro to be a C string representing the suffix for
  48675. -     executable files on your machine.  If you do not define this
  48676. -     macro, GNU CC will use the null string as the suffix for object
  48677. -     files.
  48678. -
  48679. -`COLLECT_EXPORT_LIST'
  48680. -     If defined, `collect2' will scan the individual object files
  48681. -     specified on its command line and create an export list for the
  48682. -     linker.  Define this macro for systems like AIX, where the linker
  48683. -     discards object files that are not referenced from `main' and uses
  48684. -     export lists.
  48685. -
  48686. -   In addition, configuration files for system V define `bcopy',
  48687. -`bzero' and `bcmp' as aliases.  Some files define `alloca' as a macro
  48688. -when compiled with GNU CC, in order to take advantage of the benefit of
  48689. -GNU CC's built-in `alloca'.
  48690. -
  48691. -
  48692. -File: gcc.info,  Node: Fragments,  Next: Index,  Prev: Config,  Up: Top
  48693. -
  48694. -Makefile Fragments
  48695. -******************
  48696. -
  48697. -   When you configure GNU CC using the `configure' script (*note
  48698. -Installation::.), it will construct the file `Makefile' from the
  48699. -template file `Makefile.in'.  When it does this, it will incorporate
  48700. -makefile fragment files from the `config' directory, named `t-TARGET'
  48701. -and `x-HOST'.  If these files do not exist, it means nothing needs to
  48702. -be added for a given target or host.
  48703. -
  48704. -* Menu:
  48705. -
  48706. -* Target Fragment:: Writing the `t-TARGET' file.
  48707. -* Host Fragment::   Writing the `x-HOST' file.
  48708. -
  48709. -
  48710. -File: gcc.info,  Node: Target Fragment,  Next: Host Fragment,  Up: Fragments
  48711. -
  48712. -The Target Makefile Fragment
  48713. -============================
  48714. -
  48715. -   The target makefile fragment, `t-TARGET', defines special target
  48716. -dependent variables and targets used in the `Makefile':
  48717. -
  48718. -`LIBGCC1'
  48719. -     The rule to use to build `libgcc1.a'.  If your target does not
  48720. -     need to use the functions in `libgcc1.a', set this to empty.
  48721. -     *Note Interface::.
  48722. -
  48723. -`CROSS_LIBGCC1'
  48724. -     The rule to use to build `libgcc1.a' when building a cross
  48725. -     compiler.  If your target does not need to use the functions in
  48726. -     `libgcc1.a', set this to empty.  *Note Cross Runtime::.
  48727. -
  48728. -`LIBGCC2_CFLAGS'
  48729. -     Compiler flags to use when compiling `libgcc2.c'.
  48730. -
  48731. -`LIB2FUNCS_EXTRA'
  48732. -     A list of source file names to be compiled or assembled and
  48733. -     inserted into `libgcc.a'.
  48734. -
  48735. -`CRTSTUFF_T_CFLAGS'
  48736. -     Special flags used when compiling `crtstuff.c'.  *Note
  48737. -     Initialization::.
  48738. -
  48739. -`MULTILIB_OPTIONS'
  48740. -     For some targets, invoking GNU CC in different ways produces
  48741. -     objects that can not be linked together.  For example, for some
  48742. -     targets GNU CC produces both big and little endian code.  For
  48743. -     these targets, you must arrange for multiple versions of
  48744. -     `libgcc.a' to be compiled, one for each set of incompatible
  48745. -     options.  When GNU CC invokes the linker, it arranges to link in
  48746. -     the right version of `libgcc.a', based on the command line options
  48747. -     used.
  48748. -
  48749. -     The `MULTILIB_OPTIONS' macro lists the set of options for which
  48750. -     special versions of `libgcc.a' must be built.  Write options that
  48751. -     are mutually incompatible side by side, separated by a slash.
  48752. -     Write options that may be used together separated by a space.  The
  48753. -     build procedure will build all combinations of compatible options.
  48754. -
  48755. -     For example, if you set `MULTILIB_OPTIONS' to `m68000/m68020
  48756. -     msoft-float', `Makefile' will build special versions of `libgcc.a'
  48757. -     using the options `-m68000', `-m68020', `-msoft-float', `-m68000
  48758. -     -msoft-float', and `-m68020 -msoft-float'.
  48759. -
  48760. -`MULTILIB_DIRNAMES'
  48761. -     If `MULTILIB_OPTIONS' is used, this variable specifies the
  48762. -     directory names that should be used to hold the various libraries.
  48763. -     Write one element in `MULTILIB_DIRNAMES' for each element in
  48764. -     `MULTILIB_OPTIONS'.  If `MULTILIB_DIRNAMES' is not used, the
  48765. -     default value will be `MULTILIB_OPTIONS', with all slashes treated
  48766. -     as spaces.
  48767. -
  48768. -     For example, if `MULTILIB_OPTIONS' is `m68000/m68020 msoft-float',
  48769. -     then the default value of `MULTILIB_DIRNAMES' is `m68000 m68020
  48770. -     msoft-float'.  You may specify a different value if you desire a
  48771. -     different set of directory names.
  48772. -
  48773. -`MULTILIB_MATCHES'
  48774. -     Sometimes the same option may be written in two different ways.
  48775. -     If an option is listed in `MULTILIB_OPTIONS', GNU CC needs to know
  48776. -     about any synonyms.  In that case, set `MULTILIB_MATCHES' to a
  48777. -     list of items of the form `option=option' to describe all relevant
  48778. -     synonyms.  For example, `m68000=mc68000 m68020=mc68020'.
  48779. -
  48780. -
  48781. -File: gcc.info,  Node: Host Fragment,  Prev: Target Fragment,  Up: Fragments
  48782. -
  48783. -The Host Makefile Fragment
  48784. -==========================
  48785. -
  48786. -   The host makefile fragment, `x-HOST', defines special host dependent
  48787. -variables and targets used in the `Makefile':
  48788. -
  48789. -`CC'
  48790. -     The compiler to use when building the first stage.
  48791. -
  48792. -`CLIB'
  48793. -     Additional host libraries to link with.
  48794. -
  48795. -`OLDCC'
  48796. -     The compiler to use when building `libgcc1.a' for a native
  48797. -     compilation.
  48798. -
  48799. -`OLDAR'
  48800. -     The version of `ar' to use when building `libgcc1.a' for a native
  48801. -     compilation.
  48802. -
  48803. -`INSTALL'
  48804. -     The install program to use.
  48805. -
  48806. diff -rup --new-file baseline/fsf/gcc/gcc.info-25 amiga/fsf/gcc/gcc.info-25
  48807. --- baseline/fsf/gcc/gcc.info-25    Sat Jun 29 09:38:12 1996
  48808. +++ amiga/fsf/gcc/gcc.info-25    Wed Dec 31 17:00:00 1969
  48809. @@ -1,1945 +0,0 @@
  48810. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  48811. -file gcc.texi.
  48812. -
  48813. -   This file documents the use and the internals of the GNU compiler.
  48814. -
  48815. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  48816. -Boston, MA 02111-1307 USA
  48817. -
  48818. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  48819. -Foundation, Inc.
  48820. -
  48821. -   Permission is granted to make and distribute verbatim copies of this
  48822. -manual provided the copyright notice and this permission notice are
  48823. -preserved on all copies.
  48824. -
  48825. -   Permission is granted to copy and distribute modified versions of
  48826. -this manual under the conditions for verbatim copying, provided also
  48827. -that the sections entitled "GNU General Public License," "Funding for
  48828. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  48829. -included exactly as in the original, and provided that the entire
  48830. -resulting derived work is distributed under the terms of a permission
  48831. -notice identical to this one.
  48832. -
  48833. -   Permission is granted to copy and distribute translations of this
  48834. -manual into another language, under the above conditions for modified
  48835. -versions, except that the sections entitled "GNU General Public
  48836. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  48837. -`Look And Feel'", and this permission notice, may be included in
  48838. -translations approved by the Free Software Foundation instead of in the
  48839. -original English.
  48840. -
  48841. -
  48842. -File: gcc.info,  Node: Index,  Prev: Fragments,  Up: Top
  48843. -
  48844. -Index
  48845. -*****
  48846. -
  48847. -* Menu:
  48848. -
  48849. -* #pragma:                              Misc.
  48850. -* $:                                    Dollar Signs.
  48851. -* ':                                    Incompatibilities.
  48852. -* (nil):                                RTL Objects.
  48853. -* //:                                   C++ Comments.
  48854. -* <?:                                   Min and Max.
  48855. -* >?:                                   Min and Max.
  48856. -* ?: side effect:                       Conditionals.
  48857. -* #pragma implementation, implied:      C++ Interface.
  48858. -* #pragma, reason for not using:        Function Attributes.
  48859. -* # in template:                        Output Template.
  48860. -* * in template:                        Output Statement.
  48861. -* -lgcc, use with -nodefaultlibs:       Link Options.
  48862. -* -lgcc, use with -nostdlib:            Link Options.
  48863. -* -nodefaultlibs and unresolved references: Link Options.
  48864. -* -nostdlib and unresolved references:  Link Options.
  48865. -* ?: extensions:                        Conditionals.
  48866. -* ?: extensions:                        Lvalues.
  48867. -* absM2 instruction pattern:            Standard Names.
  48868. -* abs and attributes:                   Expressions.
  48869. -* ACCUMULATE_OUTGOING_ARGS and stack frames: Function Entry.
  48870. -* addM3 instruction pattern:            Standard Names.
  48871. -* addr_diff_vec, length of:             Insn Lengths.
  48872. -* addr_vec, length of:                  Insn Lengths.
  48873. -* alias attribute:                      Function Attributes.
  48874. -* aligned attribute:                    Type Attributes.
  48875. -* aligned attribute:                    Variable Attributes.
  48876. -* allocate_stack instruction pattern:   Standard Names.
  48877. -* alloca and SunOs:                     Installation.
  48878. -* alloca vs variable-length arrays:     Variable Length.
  48879. -* alloca, for SunOs:                    Sun Install.
  48880. -* alloca, for Unos:                     Configurations.
  48881. -* andM3 instruction pattern:            Standard Names.
  48882. -* and and attributes:                   Expressions.
  48883. -* and, canonicalization of:             Insn Canonicalizations.
  48884. -* ARG_POINTER_REGNUM and virtual registers: Regs and Memory.
  48885. -* ashiftrt and attributes:              Expressions.
  48886. -* ashift and attributes:                Expressions.
  48887. -* ashlM3 instruction pattern:           Standard Names.
  48888. -* ashrM3 instruction pattern:           Standard Names.
  48889. -* asm_operands, RTL sharing:            Sharing.
  48890. -* asm_operands, usage:                  Assembler.
  48891. -* asm expressions:                      Extended Asm.
  48892. -* bCOND instruction pattern:            Standard Names.
  48893. -* bcopy, implicit usage:                Library Calls.
  48894. -* BITS_BIG_ENDIAN, effect on sign_extract: Bit Fields.
  48895. -* BLKmode, and function return values:  Calls.
  48896. -* bzero, implicit usage:                Library Calls.
  48897. -* call_insn and /u:                     Flags.
  48898. -* call_pop instruction pattern:         Standard Names.
  48899. -* call_value_pop instruction pattern:   Standard Names.
  48900. -* call_value instruction pattern:       Standard Names.
  48901. -* call instruction pattern:             Standard Names.
  48902. -* call usage:                           Calls.
  48903. -* casesi instruction pattern:           Standard Names.
  48904. -* cc0, RTL sharing:                     Sharing.
  48905. -* cmpM instruction pattern:             Standard Names.
  48906. -* cmpstrM instruction pattern:          Standard Names.
  48907. -* code_label and /i:                    Flags.
  48908. -* compare, canonicalization of:         Insn Canonicalizations.
  48909. -* cond and attributes:                  Expressions.
  48910. -* constructor function attribute:       Function Attributes.
  48911. -* const_double, RTL sharing:            Sharing.
  48912. -* const_int and attribute tests:        Expressions.
  48913. -* const_int and attributes:             Expressions.
  48914. -* const_int, RTL sharing:               Sharing.
  48915. -* const_string and attributes:          Expressions.
  48916. -* const applied to function:            Function Attributes.
  48917. -* const function attribute:             Function Attributes.
  48918. -* define_insn example:                  Example.
  48919. -* destructor function attribute:        Function Attributes.
  48920. -* divM3 instruction pattern:            Standard Names.
  48921. -* divmodM4 instruction pattern:         Standard Names.
  48922. -* div and attributes:                   Expressions.
  48923. -* EDOM, implicit usage:                 Library Calls.
  48924. -* ENCODE_SECTION_INFO and address validation: Addressing Modes.
  48925. -* ENCODE_SECTION_INFO usage:            Instruction Output.
  48926. -* eq and attributes:                    Expressions.
  48927. -* errno, implicit usage:                Library Calls.
  48928. -* extendMN instruction pattern:         Standard Names.
  48929. -* extv instruction pattern:             Standard Names.
  48930. -* extzv instruction pattern:            Standard Names.
  48931. -* ffsM2 instruction pattern:            Standard Names.
  48932. -* FIRST_PARM_OFFSET and virtual registers: Regs and Memory.
  48933. -* fixMN2 instruction pattern:           Standard Names.
  48934. -* fixunsMN2 instruction pattern:        Standard Names.
  48935. -* fixuns_truncMN2 instruction pattern:  Standard Names.
  48936. -* fix_truncMN2 instruction pattern:     Standard Names.
  48937. -* floatMN2 instruction pattern:         Standard Names.
  48938. -* floatunsMN2 instruction pattern:      Standard Names.
  48939. -* float as function value type:         Incompatibilities.
  48940. -* format function attribute:            Function Attributes.
  48941. -* FRAME_GROWS_DOWNWARD and virtual registers: Regs and Memory.
  48942. -* FRAME_POINTER_REGNUM and virtual registers: Regs and Memory.
  48943. -* fscanf, and constant strings:         Incompatibilities.
  48944. -* ftruncM2 instruction pattern:         Standard Names.
  48945. -* FUNCTION_EPILOGUE and trampolines:    Trampolines.
  48946. -* FUNCTION_PROLOGUE and trampolines:    Trampolines.
  48947. -* g++ 1.XX:                             Invoking G++.
  48948. -* g++ older version:                    Invoking G++.
  48949. -* g++, separate compiler:               Invoking G++.
  48950. -* genflags, crash on Sun 4:             Installation Problems.
  48951. -* geu and attributes:                   Expressions.
  48952. -* ge and attributes:                    Expressions.
  48953. -* goto in C++:                          Destructors and Goto.
  48954. -* gprof:                                Debugging Options.
  48955. -* gtu and attributes:                   Expressions.
  48956. -* gt and attributes:                    Expressions.
  48957. -* HImode, in insn:                      Insns.
  48958. -* if_then_else and attributes:          Expressions.
  48959. -* if_then_else usage:                   Side Effects.
  48960. -* indirect_jump instruction pattern:    Standard Names.
  48961. -* inline automatic for C++ member fns:  Inline.
  48962. -* insn and /i:                          Flags.
  48963. -* insn and /s:                          Flags.
  48964. -* insn and /u:                          Flags.
  48965. -* insv instruction pattern:             Standard Names.
  48966. -* integrated, in insn:                  Flags.
  48967. -* integrated, in reg:                   Flags.
  48968. -* in_struct, in code_label:             Flags.
  48969. -* in_struct, in insn:                   Flags.
  48970. -* in_struct, in insn:                   Flags.
  48971. -* in_struct, in label_ref:              Flags.
  48972. -* in_struct, in mem:                    Flags.
  48973. -* in_struct, in reg:                    Flags.
  48974. -* in_struct, in subreg:                 Flags.
  48975. -* iorM3 instruction pattern:            Standard Names.
  48976. -* ior and attributes:                   Expressions.
  48977. -* ior, canonicalization of:             Insn Canonicalizations.
  48978. -* label_ref and /s:                     Flags.
  48979. -* label_ref, RTL sharing:               Sharing.
  48980. -* leu and attributes:                   Expressions.
  48981. -* le and attributes:                    Expressions.
  48982. -* load_multiple instruction pattern:    Standard Names.
  48983. -* long long data types:                 Long Long.
  48984. -* longjmp and automatic variables:      Interface.
  48985. -* longjmp and automatic variables:      C Dialect Options.
  48986. -* longjmp incompatibilities:            Incompatibilities.
  48987. -* longjmp warnings:                     Warning Options.
  48988. -* lshiftrt and attributes:              Expressions.
  48989. -* lshrM3 instruction pattern:           Standard Names.
  48990. -* lt and attributes:                    Expressions.
  48991. -* main and the exit status:             VMS Misc.
  48992. -* match_dup and attributes:             Insn Lengths.
  48993. -* match_operand and attributes:         Expressions.
  48994. -* maxM3 instruction pattern:            Standard Names.
  48995. -* memcpy, implicit usage:               Library Calls.
  48996. -* memset, implicit usage:               Library Calls.
  48997. -* mem and /s:                           Flags.
  48998. -* mem and /u:                           Flags.
  48999. -* mem and /v:                           Flags.
  49000. -* mem, RTL sharing:                     Sharing.
  49001. -* minM3 instruction pattern:            Standard Names.
  49002. -* minus and attributes:                 Expressions.
  49003. -* minus, canonicalization of:           Insn Canonicalizations.
  49004. -* mktemp, and constant strings:         Incompatibilities.
  49005. -* modM3 instruction pattern:            Standard Names.
  49006. -* mode attribute:                       Variable Attributes.
  49007. -* mod and attributes:                   Expressions.
  49008. -* movMODEcc instruction pattern:        Standard Names.
  49009. -* movM instruction pattern:             Standard Names.
  49010. -* movstrM instruction pattern:          Standard Names.
  49011. -* movstrictM instruction pattern:       Standard Names.
  49012. -* mulM3 instruction pattern:            Standard Names.
  49013. -* mulhisi3 instruction pattern:         Standard Names.
  49014. -* mulqihi3 instruction pattern:         Standard Names.
  49015. -* mulsidi3 instruction pattern:         Standard Names.
  49016. -* mult and attributes:                  Expressions.
  49017. -* mult, canonicalization of:            Insn Canonicalizations.
  49018. -* MUST_PASS_IN_STACK, and FUNCTION_ARG: Register Arguments.
  49019. -* negM2 instruction pattern:            Standard Names.
  49020. -* neg and attributes:                   Expressions.
  49021. -* neg, canonicalization of:             Insn Canonicalizations.
  49022. -* ne and attributes:                    Expressions.
  49023. -* nocommon attribute:                   Variable Attributes.
  49024. -* nop instruction pattern:              Standard Names.
  49025. -* noreturn function attribute:          Function Attributes.
  49026. -* not and attributes:                   Expressions.
  49027. -* not, canonicalization of:             Insn Canonicalizations.
  49028. -* one_cmplM2 instruction pattern:       Standard Names.
  49029. -* packed attribute:                     Variable Attributes.
  49030. -* pc and attributes:                    Insn Lengths.
  49031. -* pc, RTL sharing:                      Sharing.
  49032. -* plus and attributes:                  Expressions.
  49033. -* plus, canonicalization of:            Insn Canonicalizations.
  49034. -* prof:                                 Debugging Options.
  49035. -* PUSH_ROUNDING, interaction with STACK_BOUNDARY: Storage Layout.
  49036. -* QImode, in insn:                      Insns.
  49037. -* qsort, and global register variables: Global Reg Vars.
  49038. -* REG_PARM_STACK_SPACE, and FUNCTION_ARG: Register Arguments.
  49039. -* reg and /i:                           Flags.
  49040. -* reg and /s:                           Flags.
  49041. -* reg and /u:                           Flags.
  49042. -* reg and /v:                           Flags.
  49043. -* reg, RTL sharing:                     Sharing.
  49044. -* reload_in instruction pattern:        Standard Names.
  49045. -* reload_out instruction pattern:       Standard Names.
  49046. -* restore_stack_block instruction pattern: Standard Names.
  49047. -* restore_stack_function instruction pattern: Standard Names.
  49048. -* restore_stack_nonlocal instruction pattern: Standard Names.
  49049. -* return instruction pattern:           Standard Names.
  49050. -* return, in C++ function header:       Naming Results.
  49051. -* rotlM3 instruction pattern:           Standard Names.
  49052. -* rotrM3 instruction pattern:           Standard Names.
  49053. -* sCOND instruction pattern:            Standard Names.
  49054. -* save_stack_block instruction pattern: Standard Names.
  49055. -* save_stack_function instruction pattern: Standard Names.
  49056. -* save_stack_nonlocal instruction pattern: Standard Names.
  49057. -* scanf, and constant strings:          Incompatibilities.
  49058. -* scratch, RTL sharing:                 Sharing.
  49059. -* section function attribute:           Function Attributes.
  49060. -* section variable attribute:           Variable Attributes.
  49061. -* setjmp incompatibilities:             Incompatibilities.
  49062. -* signature in C++, advantages:         C++ Signatures.
  49063. -* sign_extract, canonicalization of:    Insn Canonicalizations.
  49064. -* smulM3_highpart instruction pattern:  Standard Names.
  49065. -* sqrtM2 instruction pattern:           Standard Names.
  49066. -* sscanf, and constant strings:         Incompatibilities.
  49067. -* STACK_DYNAMIC_OFFSET and virtual registers: Regs and Memory.
  49068. -* STACK_POINTER_OFFSET and virtual registers: Regs and Memory.
  49069. -* STACK_POINTER_REGNUM and virtual registers: Regs and Memory.
  49070. -* STARTING_FRAME_OFFSET and virtual registers: Regs and Memory.
  49071. -* strlenM instruction pattern:          Standard Names.
  49072. -* subM3 instruction pattern:            Standard Names.
  49073. -* subreg and /s:                        Flags.
  49074. -* subreg and /u:                        Flags.
  49075. -* subreg, in strict_low_part:           RTL Declarations.
  49076. -* subreg, special reload handling:      Regs and Memory.
  49077. -* SYMBOL_REF_FLAG, in ENCODE_SECTION_INFO: Sections.
  49078. -* symbol_ref and /u:                    Flags.
  49079. -* symbol_ref and /v:                    Flags.
  49080. -* symbol_ref, RTL sharing:              Sharing.
  49081. -* tablejump instruction pattern:        Standard Names.
  49082. -* tcov:                                 Debugging Options.
  49083. -* truncMN instruction pattern:          Standard Names.
  49084. -* tstM instruction pattern:             Standard Names.
  49085. -* udivM3 instruction pattern:           Standard Names.
  49086. -* udivmodM4 instruction pattern:        Standard Names.
  49087. -* umaxM3 instruction pattern:           Standard Names.
  49088. -* uminM3 instruction pattern:           Standard Names.
  49089. -* umodM3 instruction pattern:           Standard Names.
  49090. -* umulM3_highpart instruction pattern:  Standard Names.
  49091. -* umulhisi3 instruction pattern:        Standard Names.
  49092. -* umulqihi3 instruction pattern:        Standard Names.
  49093. -* umulsidi3 instruction pattern:        Standard Names.
  49094. -* unchanging, in call_insn:             Flags.
  49095. -* unchanging, in insn:                  Flags.
  49096. -* unchanging, in reg and mem:           Flags.
  49097. -* unchanging, in subreg:                Flags.
  49098. -* unchanging, in symbol_ref:            Flags.
  49099. -* untyped_call instruction pattern:     Standard Names.
  49100. -* untyped_return instruction pattern:   Standard Names.
  49101. -* used, in symbol_ref:                  Flags.
  49102. -* volatile applied to function:         Function Attributes.
  49103. -* volatil, in insn:                     Flags.
  49104. -* volatil, in mem:                      Flags.
  49105. -* volatil, in reg:                      Flags.
  49106. -* volatil, in symbol_ref:               Flags.
  49107. -* weak attribute:                       Function Attributes.
  49108. -* WORDS_BIG_ENDIAN, effect on subreg:   Regs and Memory.
  49109. -* xorM3 instruction pattern:            Standard Names.
  49110. -* xor, canonicalization of:             Insn Canonicalizations.
  49111. -* zero_extendMN instruction pattern:    Standard Names.
  49112. -* zero_extract, canonicalization of:    Insn Canonicalizations.
  49113. -* libgcc.a:                             Library Calls.
  49114. -* stdarg.h and register arguments:      Register Arguments.
  49115. -* stdarg.h and RT PC:                   RT Options.
  49116. -* t-TARGET:                             Target Fragment.
  49117. -* tm.h macros:                          Target Macros.
  49118. -* varargs.h and RT PC:                  RT Options.
  49119. -* VAXCRTL:                              VMS Misc.
  49120. -* x-HOST:                               Host Fragment.
  49121. -* xm-MACHINE.h:                         Config.
  49122. -* ! in constraint:                      Multi-Alternative.
  49123. -* # in constraint:                      Modifiers.
  49124. -* % in constraint:                      Modifiers.
  49125. -* % in template:                        Output Template.
  49126. -* & in constraint:                      Modifiers.
  49127. -* * in constraint:                      Modifiers.
  49128. -* + in constraint:                      Modifiers.
  49129. -* /i in RTL dump:                       Flags.
  49130. -* /s in RTL dump:                       Flags.
  49131. -* /s in RTL dump:                       Flags.
  49132. -* /u in RTL dump:                       Flags.
  49133. -* /v in RTL dump:                       Flags.
  49134. -* 0 in constraint:                      Simple Constraints.
  49135. -* < in constraint:                      Simple Constraints.
  49136. -* = in constraint:                      Modifiers.
  49137. -* > in constraint:                      Simple Constraints.
  49138. -* ? in constraint:                      Multi-Alternative.
  49139. -* d in constraint:                      Simple Constraints.
  49140. -* E in constraint:                      Simple Constraints.
  49141. -* F in constraint:                      Simple Constraints.
  49142. -* G in constraint:                      Simple Constraints.
  49143. -* g in constraint:                      Simple Constraints.
  49144. -* H in constraint:                      Simple Constraints.
  49145. -* I in constraint:                      Simple Constraints.
  49146. -* i in constraint:                      Simple Constraints.
  49147. -* m in constraint:                      Simple Constraints.
  49148. -* n in constraint:                      Simple Constraints.
  49149. -* o in constraint:                      Simple Constraints.
  49150. -* p in constraint:                      Simple Constraints.
  49151. -* Q, in constraint:                     Simple Constraints.
  49152. -* r in constraint:                      Simple Constraints.
  49153. -* store_multiple instruction pattern:   Standard Names.
  49154. -* s in constraint:                      Simple Constraints.
  49155. -* V in constraint:                      Simple Constraints.
  49156. -* X in constraint:                      Simple Constraints.
  49157. -* _ in variables in macros:             Naming Types.
  49158. -* abort:                                Portability.
  49159. -* abort:                                C Dialect Options.
  49160. -* abs:                                  Arithmetic.
  49161. -* abs:                                  C Dialect Options.
  49162. -* absolute value:                       Arithmetic.
  49163. -* access to operands:                   Accessors.
  49164. -* accessors:                            Accessors.
  49165. -* ACCUMULATE_OUTGOING_ARGS:             Stack Arguments.
  49166. -* ADDITIONAL_REGISTER_NAMES:            Instruction Output.
  49167. -* address:                              RTL Template.
  49168. -* address constraints:                  Simple Constraints.
  49169. -* address of a label:                   Labels as Values.
  49170. -* addressing modes:                     Addressing Modes.
  49171. -* ADDRESS_COST:                         Costs.
  49172. -* address_operand:                      Simple Constraints.
  49173. -* addr_diff_vec:                        Side Effects.
  49174. -* addr_vec:                             Side Effects.
  49175. -* ADJUST_COST:                          Costs.
  49176. -* ADJUST_INSN_LENGTH:                   Insn Lengths.
  49177. -* aggregates as return values:          Aggregate Return.
  49178. -* alignment:                            Alignment.
  49179. -* Alliant:                              Interoperation.
  49180. -* alloca:                               C Dialect Options.
  49181. -* ALLOCATE_TRAMPOLINE:                  Trampolines.
  49182. -* ALL_REGS:                             Register Classes.
  49183. -* alternate keywords:                   Alternate Keywords.
  49184. -* AMD29K options:                       AMD29K Options.
  49185. -* analysis, data flow:                  Passes.
  49186. -* and:                                  Arithmetic.
  49187. -* ANSI support:                         C Dialect Options.
  49188. -* apostrophes:                          Incompatibilities.
  49189. -* APPLY_RESULT_SIZE:                    Scalar Return.
  49190. -* ARGS_GROW_DOWNWARD:                   Frame Layout.
  49191. -* argument passing:                     Interface.
  49192. -* arguments in frame (88k):             M88K Options.
  49193. -* arguments in registers:               Register Arguments.
  49194. -* arguments on stack:                   Stack Arguments.
  49195. -* ARG_POINTER_REGNUM:                   Frame Registers.
  49196. -* arg_pointer_rtx:                      Frame Registers.
  49197. -* arithmetic libraries:                 Interface.
  49198. -* arithmetic shift:                     Arithmetic.
  49199. -* arithmetic simplifications:           Passes.
  49200. -* arithmetic, in RTL:                   Arithmetic.
  49201. -* ARM options:                          ARM Options.
  49202. -* arrays of length zero:                Zero Length.
  49203. -* arrays of variable length:            Variable Length.
  49204. -* arrays, non-lvalue:                   Subscripting.
  49205. -* ashift:                               Arithmetic.
  49206. -* ashiftrt:                             Arithmetic.
  49207. -* ASM_APP_OFF:                          File Framework.
  49208. -* ASM_APP_ON:                           File Framework.
  49209. -* ASM_BYTE_OP:                          Data Output.
  49210. -* ASM_CLOSE_PAREN:                      Data Output.
  49211. -* ASM_COMMENT_START:                    File Framework.
  49212. -* ASM_DECLARE_FUNCTION_NAME:            Label Output.
  49213. -* ASM_DECLARE_FUNCTION_SIZE:            Label Output.
  49214. -* ASM_DECLARE_OBJECT_NAME:              Label Output.
  49215. -* ASM_FILE_END:                         File Framework.
  49216. -* ASM_FILE_START:                       File Framework.
  49217. -* ASM_FINAL_SPEC:                       Driver.
  49218. -* ASM_FINISH_DECLARE_OBJECT:            Label Output.
  49219. -* ASM_FORMAT_PRIVATE_NAME:              Label Output.
  49220. -* asm_fprintf:                          Instruction Output.
  49221. -* ASM_GENERATE_INTERNAL_LABEL:          Label Output.
  49222. -* ASM_GLOBALIZE_LABEL:                  Label Output.
  49223. -* ASM_IDENTIFY_GCC:                     File Framework.
  49224. -* asm_input:                            Side Effects.
  49225. -* asm_noperands:                        Insns.
  49226. -* ASM_NO_SKIP_IN_TEXT:                  Alignment Output.
  49227. -* ASM_OPEN_PAREN:                       Data Output.
  49228. -* ASM_OUTPUT_ADDR_DIFF_ELT:             Dispatch Tables.
  49229. -* ASM_OUTPUT_ADDR_VEC_ELT:              Dispatch Tables.
  49230. -* ASM_OUTPUT_ALIGN:                     Alignment Output.
  49231. -* ASM_OUTPUT_ALIGNED_COMMON:            Uninitialized Data.
  49232. -* ASM_OUTPUT_ALIGNED_LOCAL:             Uninitialized Data.
  49233. -* ASM_OUTPUT_ALIGN_CODE:                Alignment Output.
  49234. -* ASM_OUTPUT_ASCII:                     Data Output.
  49235. -* ASM_OUTPUT_BYTE:                      Data Output.
  49236. -* ASM_OUTPUT_CASE_END:                  Dispatch Tables.
  49237. -* ASM_OUTPUT_CASE_LABEL:                Dispatch Tables.
  49238. -* ASM_OUTPUT_CHAR:                      Data Output.
  49239. -* ASM_OUTPUT_COMMON:                    Uninitialized Data.
  49240. -* ASM_OUTPUT_CONSTRUCTOR:               Macros for Initialization.
  49241. -* ASM_OUTPUT_DEF:                       Label Output.
  49242. -* ASM_OUTPUT_DESTRUCTOR:                Macros for Initialization.
  49243. -* ASM_OUTPUT_DOUBLE:                    Data Output.
  49244. -* ASM_OUTPUT_DOUBLE_INT:                Data Output.
  49245. -* ASM_OUTPUT_EXTERNAL:                  Label Output.
  49246. -* ASM_OUTPUT_EXTERNAL_LIBCALL:          Label Output.
  49247. -* ASM_OUTPUT_FLOAT:                     Data Output.
  49248. -* ASM_OUTPUT_IDENT:                     File Framework.
  49249. -* ASM_OUTPUT_INT:                       Data Output.
  49250. -* ASM_OUTPUT_INTERNAL_LABEL:            Label Output.
  49251. -* ASM_OUTPUT_LABEL:                     Label Output.
  49252. -* ASM_OUTPUT_LABELREF:                  Label Output.
  49253. -* ASM_OUTPUT_LOCAL:                     Uninitialized Data.
  49254. -* ASM_OUTPUT_LONG_DOUBLE:               Data Output.
  49255. -* ASM_OUTPUT_LOOP_ALIGN:                Alignment Output.
  49256. -* ASM_OUTPUT_OPCODE:                    Instruction Output.
  49257. -* ASM_OUTPUT_POOL_PROLOGUE:             Data Output.
  49258. -* ASM_OUTPUT_QUADRUPLE_INT:             Data Output.
  49259. -* ASM_OUTPUT_REG_POP:                   Instruction Output.
  49260. -* ASM_OUTPUT_REG_PUSH:                  Instruction Output.
  49261. -* ASM_OUTPUT_SECTION_NAME:              File Framework.
  49262. -* ASM_OUTPUT_SHARED_COMMON:             Uninitialized Data.
  49263. -* ASM_OUTPUT_SHARED_LOCAL:              Uninitialized Data.
  49264. -* ASM_OUTPUT_SHORT:                     Data Output.
  49265. -* ASM_OUTPUT_SKIP:                      Alignment Output.
  49266. -* ASM_OUTPUT_SOURCE_FILENAME:           File Framework.
  49267. -* ASM_OUTPUT_SOURCE_LINE:               File Framework.
  49268. -* ASM_OUTPUT_SPECIAL_POOL_ENTRY:        Data Output.
  49269. -* ASM_SPEC:                             Driver.
  49270. -* ASM_STABD_OP:                         DBX Options.
  49271. -* ASM_STABN_OP:                         DBX Options.
  49272. -* ASM_STABS_OP:                         DBX Options.
  49273. -* ASM_WEAKEN_LABEL:                     Label Output.
  49274. -* assembler format:                     File Framework.
  49275. -* assembler instructions:               Extended Asm.
  49276. -* assembler instructions in RTL:        Assembler.
  49277. -* assembler names for identifiers:      Asm Labels.
  49278. -* assembler syntax, 88k:                M88K Options.
  49279. -* ASSEMBLER_DIALECT:                    Instruction Output.
  49280. -* assemble_name:                        Label Output.
  49281. -* assembly code, invalid:               Bug Criteria.
  49282. -* assigning attribute values to insns:  Tagging Insns.
  49283. -* asterisk in template:                 Output Statement.
  49284. -* atof:                                 Cross-compilation.
  49285. -* attr:                                 Tagging Insns.
  49286. -* attribute expressions:                Expressions.
  49287. -* attribute of types:                   Type Attributes.
  49288. -* attribute of variables:               Variable Attributes.
  49289. -* attribute specifications:             Attr Example.
  49290. -* attribute specifications example:     Attr Example.
  49291. -* attributes, defining:                 Defining Attributes.
  49292. -* attr_flag:                            Expressions.
  49293. -* autoincrement addressing, availability: Portability.
  49294. -* autoincrement/decrement addressing:   Simple Constraints.
  49295. -* autoincrement/decrement analysis:     Passes.
  49296. -* automatic inline for C++ member fns:  Inline.
  49297. -* backslash:                            Output Template.
  49298. -* backtrace for bug reports:            Bug Reporting.
  49299. -* barrier:                              Insns.
  49300. -* BASE_REG_CLASS:                       Register Classes.
  49301. -* basic blocks:                         Passes.
  49302. -* bcmp:                                 Config.
  49303. -* BIGGEST_ALIGNMENT:                    Storage Layout.
  49304. -* BIGGEST_FIELD_ALIGNMENT:              Storage Layout.
  49305. -* Bison parser generator:               Installation.
  49306. -* bit fields:                           Bit Fields.
  49307. -* bit shift overflow (88k):             M88K Options.
  49308. -* BITFIELD_NBYTES_LIMITED:              Storage Layout.
  49309. -* BITS_BIG_ENDIAN:                      Storage Layout.
  49310. -* BITS_PER_UNIT:                        Storage Layout.
  49311. -* BITS_PER_WORD:                        Storage Layout.
  49312. -* bitwise complement:                   Arithmetic.
  49313. -* bitwise exclusive-or:                 Arithmetic.
  49314. -* bitwise inclusive-or:                 Arithmetic.
  49315. -* bitwise logical-and:                  Arithmetic.
  49316. -* BLKmode:                              Machine Modes.
  49317. -* BLOCK_PROFILER:                       Profiling.
  49318. -* BLOCK_PROFILER_CODE:                  Profiling.
  49319. -* BRANCH_COST:                          Costs.
  49320. -* break_out_memory_refs:                Addressing Modes.
  49321. -* bug criteria:                         Bug Criteria.
  49322. -* bug report mailing lists:             Bug Lists.
  49323. -* bugs:                                 Bugs.
  49324. -* bugs, known:                          Trouble.
  49325. -* builtin functions:                    C Dialect Options.
  49326. -* byte writes (29k):                    AMD29K Options.
  49327. -* BYTES_BIG_ENDIAN:                     Storage Layout.
  49328. -* byte_mode:                            Machine Modes.
  49329. -* bzero:                                Config.
  49330. -* C compilation options:                Invoking GCC.
  49331. -* C intermediate output, nonexistent:   G++ and GCC.
  49332. -* C language extensions:                C Extensions.
  49333. -* C language, traditional:              C Dialect Options.
  49334. -* C statements for assembler output:    Output Statement.
  49335. -* c++:                                  Invoking G++.
  49336. -* C++:                                  G++ and GCC.
  49337. -* C++ comments:                         C++ Comments.
  49338. -* C++ compilation options:              Invoking GCC.
  49339. -* C++ interface and implementation headers: C++ Interface.
  49340. -* C++ language extensions:              C++ Extensions.
  49341. -* C++ member fns, automatically inline: Inline.
  49342. -* C++ misunderstandings:                C++ Misunderstandings.
  49343. -* C++ named return value:               Naming Results.
  49344. -* C++ options, command line:            C++ Dialect Options.
  49345. -* C++ pragmas, effect on inlining:      C++ Interface.
  49346. -* C++ signatures:                       C++ Signatures.
  49347. -* C++ source file suffixes:             Invoking G++.
  49348. -* C++ static data, declaring and defining: Static Definitions.
  49349. -* C++ subtype polymorphism:             C++ Signatures.
  49350. -* C++ type abstraction:                 C++ Signatures.
  49351. -* call:                                 Side Effects.
  49352. -* call-clobbered register:              Register Basics.
  49353. -* call-saved register:                  Register Basics.
  49354. -* call-used register:                   Register Basics.
  49355. -* CALLER_SAVE_PROFITABLE:               Caller Saves.
  49356. -* calling conventions:                  Stack and Calling.
  49357. -* calling functions in RTL:             Calls.
  49358. -* call_insn:                            Insns.
  49359. -* CALL_INSN_FUNCTION_USAGE:             Insns.
  49360. -* CALL_USED_REGISTERS:                  Register Basics.
  49361. -* call_used_regs:                       Register Basics.
  49362. -* canonicalization of instructions:     Insn Canonicalizations.
  49363. -* CANONICALIZE_COMPARISON:              Condition Code.
  49364. -* CAN_DEBUG_WITHOUT_FP:                 Run-time Target.
  49365. -* CAN_ELIMINATE:                        Elimination.
  49366. -* case labels in initializers:          Labeled Elements.
  49367. -* case ranges:                          Case Ranges.
  49368. -* case sensitivity and VMS:             VMS Misc.
  49369. -* CASE_DROPS_THROUGH:                   Misc.
  49370. -* CASE_VALUES_THRESHOLD:                Misc.
  49371. -* CASE_VECTOR_MODE:                     Misc.
  49372. -* CASE_VECTOR_PC_RELATIVE:              Misc.
  49373. -* cast to a union:                      Cast to Union.
  49374. -* casts as lvalues:                     Lvalues.
  49375. -* CC:                                   Host Fragment.
  49376. -* cc0:                                  Regs and Memory.
  49377. -* cc0_rtx:                              Regs and Memory.
  49378. -* CC1PLUS_SPEC:                         Driver.
  49379. -* CC1_SPEC:                             Driver.
  49380. -* CCmode:                               Machine Modes.
  49381. -* cc_status:                            Condition Code.
  49382. -* CC_STATUS_MDEP:                       Condition Code.
  49383. -* CC_STATUS_MDEP_INIT:                  Condition Code.
  49384. -* CDImode:                              Machine Modes.
  49385. -* change_address:                       Standard Names.
  49386. -* CHAR_TYPE_SIZE:                       Type Layout.
  49387. -* CHECK_FLOAT_VALUE:                    Storage Layout.
  49388. -* CHImode:                              Machine Modes.
  49389. -* class definitions, register:          Register Classes.
  49390. -* class preference constraints:         Class Preferences.
  49391. -* classes of RTX codes:                 Accessors.
  49392. -* CLASS_LIKELY_SPILLED_P:               Register Classes.
  49393. -* CLASS_MAX_NREGS:                      Register Classes.
  49394. -* CLEAR_INSN_CACHE:                     Trampolines.
  49395. -* CLIB:                                 Host Fragment.
  49396. -* clobber:                              Side Effects.
  49397. -* code generation conventions:          Code Gen Options.
  49398. -* code generation RTL sequences:        Expander Definitions.
  49399. -* code motion:                          Passes.
  49400. -* codes, RTL expression:                RTL Objects.
  49401. -* code_label:                           Insns.
  49402. -* CODE_LABEL_NUMBER:                    Insns.
  49403. -* COImode:                              Machine Modes.
  49404. -* COLLECT_EXPORT_LIST:                  Config.
  49405. -* combiner pass:                        Regs and Memory.
  49406. -* command options:                      Invoking GCC.
  49407. -* comments, C++ style:                  C++ Comments.
  49408. -* common subexpression elimination:     Passes.
  49409. -* compare:                              Arithmetic.
  49410. -* compilation in a separate directory:  Other Dir.
  49411. -* compiler bugs, reporting:             Bug Reporting.
  49412. -* compiler compared to C++ preprocessor: G++ and GCC.
  49413. -* compiler options, C++:                C++ Dialect Options.
  49414. -* compiler passes and files:            Passes.
  49415. -* compiler version, specifying:         Target Options.
  49416. -* COMPILER_PATH:                        Environment Variables.
  49417. -* complement, bitwise:                  Arithmetic.
  49418. -* complex numbers:                      Complex.
  49419. -* compound expressions as lvalues:      Lvalues.
  49420. -* computed gotos:                       Labels as Values.
  49421. -* computing the length of an insn:      Insn Lengths.
  49422. -* COMP_TYPE_ATTRIBUTES:                 Misc.
  49423. -* cond:                                 Comparisons.
  49424. -* condition code register:              Regs and Memory.
  49425. -* condition code status:                Condition Code.
  49426. -* condition codes:                      Comparisons.
  49427. -* conditional expressions as lvalues:   Lvalues.
  49428. -* conditional expressions, extensions:  Conditionals.
  49429. -* CONDITIONAL_REGISTER_USAGE:           Register Basics.
  49430. -* conditions, in patterns:              Patterns.
  49431. -* configuration file:                   Config.
  49432. -* configurations supported by GNU CC:   Configurations.
  49433. -* conflicting types:                    Disappointments.
  49434. -* const0_rtx:                           Constants.
  49435. -* CONST0_RTX:                           Constants.
  49436. -* const1_rtx:                           Constants.
  49437. -* CONST1_RTX:                           Constants.
  49438. -* CONST2_RTX:                           Constants.
  49439. -* const2_rtx:                           Constants.
  49440. -* constant attributes:                  Constant Attributes.
  49441. -* constant folding:                     Passes.
  49442. -* constant folding and floating point:  Cross-compilation.
  49443. -* constant propagation:                 Passes.
  49444. -* constants in constraints:             Simple Constraints.
  49445. -* CONSTANT_ADDRESS_P:                   Addressing Modes.
  49446. -* CONSTANT_ALIGNMENT:                   Storage Layout.
  49447. -* CONSTANT_P:                           Addressing Modes.
  49448. -* CONSTANT_POOL_ADDRESS_P:              Flags.
  49449. -* constm1_rtx:                          Constants.
  49450. -* constraint modifier characters:       Modifiers.
  49451. -* constraint, matching:                 Simple Constraints.
  49452. -* constraints:                          Constraints.
  49453. -* constraints, machine specific:        Machine Constraints.
  49454. -* constructing calls:                   Constructing Calls.
  49455. -* constructor expressions:              Constructors.
  49456. -* constructors vs goto:                 Destructors and Goto.
  49457. -* constructors, automatic calls:        Collect2.
  49458. -* constructors, output of:              Initialization.
  49459. -* CONST_CALL_P:                         Flags.
  49460. -* CONST_COSTS:                          Costs.
  49461. -* const_double:                         Constants.
  49462. -* CONST_DOUBLE_CHAIN:                   Constants.
  49463. -* CONST_DOUBLE_LOW:                     Constants.
  49464. -* CONST_DOUBLE_MEM:                     Constants.
  49465. -* CONST_DOUBLE_OK_FOR_LETTER_P:         Register Classes.
  49466. -* const_int:                            Constants.
  49467. -* CONST_OK_FOR_LETTER_P:                Register Classes.
  49468. -* const_string:                         Constants.
  49469. -* const_true_rtx:                       Constants.
  49470. -* contributors:                         Contributors.
  49471. -* controlling register usage:           Register Basics.
  49472. -* controlling the compilation driver:   Driver.
  49473. -* conventions, run-time:                Interface.
  49474. -* conversions:                          Conversions.
  49475. -* Convex options:                       Convex Options.
  49476. -* copy_rtx_if_shared:                   Sharing.
  49477. -* core dump:                            Bug Criteria.
  49478. -* cos:                                  C Dialect Options.
  49479. -* costs of instructions:                Costs.
  49480. -* COSTS_N_INSNS:                        Costs.
  49481. -* CPLUS_INCLUDE_PATH:                   Environment Variables.
  49482. -* CPP_PREDEFINES:                       Run-time Target.
  49483. -* CPP_SPEC:                             Driver.
  49484. -* CQImode:                              Machine Modes.
  49485. -* cross compilation and floating point: Cross-compilation.
  49486. -* cross compiling:                      Target Options.
  49487. -* cross-compiler, installation:         Cross-Compiler.
  49488. -* cross-jumping:                        Passes.
  49489. -* CROSS_LIBGCC1:                        Target Fragment.
  49490. -* CRTSTUFF_T_CFLAGS:                    Target Fragment.
  49491. -* CSImode:                              Machine Modes.
  49492. -* CTImode:                              Machine Modes.
  49493. -* CUMULATIVE_ARGS:                      Register Arguments.
  49494. -* current_function_epilogue_delay_list: Function Entry.
  49495. -* current_function_outgoing_args_size:  Stack Arguments.
  49496. -* current_function_pops_args:           Function Entry.
  49497. -* current_function_pretend_args_size:   Function Entry.
  49498. -* C_INCLUDE_PATH:                       Environment Variables.
  49499. -* data flow analysis:                   Passes.
  49500. -* DATA_ALIGNMENT:                       Storage Layout.
  49501. -* data_section:                         Sections.
  49502. -* DATA_SECTION_ASM_OP:                  Sections.
  49503. -* DBR_OUTPUT_SEQEND:                    Instruction Output.
  49504. -* dbr_sequence_length:                  Instruction Output.
  49505. -* DBX:                                  Interoperation.
  49506. -* DBX_BLOCKS_FUNCTION_RELATIVE:         DBX Options.
  49507. -* DBX_CONTIN_CHAR:                      DBX Options.
  49508. -* DBX_CONTIN_LENGTH:                    DBX Options.
  49509. -* DBX_DEBUGGING_INFO:                   DBX Options.
  49510. -* DBX_FUNCTION_FIRST:                   DBX Options.
  49511. -* DBX_LBRAC_FIRST:                      DBX Options.
  49512. -* DBX_MEMPARM_STABS_LETTER:             DBX Options.
  49513. -* DBX_NO_XREFS:                         DBX Options.
  49514. -* DBX_OUTPUT_ENUM:                      DBX Hooks.
  49515. -* DBX_OUTPUT_FUNCTION_END:              DBX Hooks.
  49516. -* DBX_OUTPUT_LBRAC:                     DBX Hooks.
  49517. -* DBX_OUTPUT_MAIN_SOURCE_DIRECTORY:     File Names and DBX.
  49518. -* DBX_OUTPUT_MAIN_SOURCE_FILENAME:      File Names and DBX.
  49519. -* DBX_OUTPUT_MAIN_SOURCE_FILE_END:      File Names and DBX.
  49520. -* DBX_OUTPUT_RBRAC:                     DBX Hooks.
  49521. -* DBX_OUTPUT_SOURCE_FILENAME:           File Names and DBX.
  49522. -* DBX_OUTPUT_STANDARD_TYPES:            DBX Hooks.
  49523. -* DBX_REGISTER_NUMBER:                  All Debuggers.
  49524. -* DBX_REGPARM_STABS_CODE:               DBX Options.
  49525. -* DBX_REGPARM_STABS_LETTER:             DBX Options.
  49526. -* DBX_STATIC_CONST_VAR_CODE:            DBX Options.
  49527. -* DBX_STATIC_STAB_DATA_SECTION:         DBX Options.
  49528. -* DBX_TYPE_DECL_STABS_CODE:             DBX Options.
  49529. -* DBX_WORKING_DIRECTORY:                File Names and DBX.
  49530. -* DCmode:                               Machine Modes.
  49531. -* De Morgan's law:                      Insn Canonicalizations.
  49532. -* dead code:                            Passes.
  49533. -* dead_or_set_p:                        Peephole Definitions.
  49534. -* deallocating variable length arrays:  Variable Length.
  49535. -* death notes:                          Obsolete Register Macros.
  49536. -* DEBUGGER_ARG_OFFSET:                  All Debuggers.
  49537. -* DEBUGGER_AUTO_OFFSET:                 All Debuggers.
  49538. -* debugging information generation:     Passes.
  49539. -* debugging information options:        Debugging Options.
  49540. -* debugging, 88k OCS:                   M88K Options.
  49541. -* debug_rtx:                            Bug Reporting.
  49542. -* DEBUG_SYMS_TEXT:                      DBX Options.
  49543. -* declaration scope:                    Incompatibilities.
  49544. -* declarations inside expressions:      Statement Exprs.
  49545. -* declarations, RTL:                    RTL Declarations.
  49546. -* declaring attributes of functions:    Function Attributes.
  49547. -* declaring static data in C++:         Static Definitions.
  49548. -* default implementation, signature member function: C++ Signatures.
  49549. -* DEFAULT_CALLER_SAVES:                 Caller Saves.
  49550. -* DEFAULT_GDB_EXTENSIONS:               DBX Options.
  49551. -* DEFAULT_MAIN_RETURN:                  Misc.
  49552. -* DEFAULT_PCC_STRUCT_RETURN:            Aggregate Return.
  49553. -* DEFAULT_SHORT_ENUMS:                  Type Layout.
  49554. -* DEFAULT_SIGNED_CHAR:                  Type Layout.
  49555. -* define_asm_attributes:                Tagging Insns.
  49556. -* define_attr:                          Defining Attributes.
  49557. -* define_delay:                         Delay Slots.
  49558. -* define_expand:                        Expander Definitions.
  49559. -* define_function_unit:                 Function Units.
  49560. -* define_insn:                          Patterns.
  49561. -* define_peephole:                      Expander Definitions.
  49562. -* define_split:                         Insn Splitting.
  49563. -* defining attributes and their values: Defining Attributes.
  49564. -* defining jump instruction patterns:   Jump Patterns.
  49565. -* defining peephole optimizers:         Peephole Definitions.
  49566. -* defining RTL sequences for code generation: Expander Definitions.
  49567. -* defining static data in C++:          Static Definitions.
  49568. -* delay slots, defining:                Delay Slots.
  49569. -* delayed branch scheduling:            Passes.
  49570. -* DELAY_SLOTS_FOR_EPILOGUE:             Function Entry.
  49571. -* dependencies for make as output:      Environment Variables.
  49572. -* dependencies, make:                   Preprocessor Options.
  49573. -* DEPENDENCIES_OUTPUT:                  Environment Variables.
  49574. -* Dependent Patterns:                   Dependent Patterns.
  49575. -* destructors vs goto:                  Destructors and Goto.
  49576. -* destructors, output of:               Initialization.
  49577. -* detecting -traditional:               C Dialect Options.
  49578. -* DFmode:                               Machine Modes.
  49579. -* dialect options:                      C Dialect Options.
  49580. -* digits in constraint:                 Simple Constraints.
  49581. -* DImode:                               Machine Modes.
  49582. -* directory options:                    Directory Options.
  49583. -* DIR_SEPARATOR:                        Config.
  49584. -* disabling certain registers:          Register Basics.
  49585. -* dispatch table:                       Dispatch Tables.
  49586. -* div:                                  Arithmetic.
  49587. -* DIVDI3_LIBCALL:                       Library Calls.
  49588. -* divide instruction, 88k:              M88K Options.
  49589. -* division:                             Arithmetic.
  49590. -* division:                             Arithmetic.
  49591. -* division:                             Arithmetic.
  49592. -* DIVSI3_LIBCALL:                       Library Calls.
  49593. -* dollar signs in identifier names:     Dollar Signs.
  49594. -* DOLLARS_IN_IDENTIFIERS:               Misc.
  49595. -* DONE:                                 Expander Definitions.
  49596. -* DONT_DECLARE_SYS_SIGLIST:             Config.
  49597. -* DONT_REDUCE_ADDR:                     Costs.
  49598. -* double-word arithmetic:               Long Long.
  49599. -* DOUBLE_TYPE_SIZE:                     Type Layout.
  49600. -* downward funargs:                     Nested Functions.
  49601. -* driver:                               Driver.
  49602. -* DW bit (29k):                         AMD29K Options.
  49603. -* DWARF_DEBUGGING_INFO:                 SDB and DWARF.
  49604. -* DYNAMIC_CHAIN_ADDRESS:                Frame Layout.
  49605. -* EASY_DIV_EXPR:                        Misc.
  49606. -* ELIGIBLE_FOR_EPILOGUE_DELAY:          Function Entry.
  49607. -* ELIMINABLE_REGS:                      Elimination.
  49608. -* empty constraints:                    No Constraints.
  49609. -* EMPTY_FIELD_BOUNDARY:                 Storage Layout.
  49610. -* ENCODE_SECTION_INFO:                  Sections.
  49611. -* ENDFILE_SPEC:                         Driver.
  49612. -* endianness:                           Portability.
  49613. -* enum machine_mode:                    Machine Modes.
  49614. -* enum reg_class:                       Register Classes.
  49615. -* enumeration clash warnings:           Warning Options.
  49616. -* environment variables:                Environment Variables.
  49617. -* epilogue:                             Function Entry.
  49618. -* eq:                                   Comparisons.
  49619. -* equal:                                Comparisons.
  49620. -* eq_attr:                              Expressions.
  49621. -* error messages:                       Warnings and Errors.
  49622. -* escape sequences, traditional:        C Dialect Options.
  49623. -* exclamation point:                    Multi-Alternative.
  49624. -* exclusive-or, bitwise:                Arithmetic.
  49625. -* EXECUTABLE_SUFFIX:                    Config.
  49626. -* exit:                                 C Dialect Options.
  49627. -* exit status and VMS:                  VMS Misc.
  49628. -* EXIT_BODY:                            Misc.
  49629. -* EXIT_IGNORE_STACK:                    Function Entry.
  49630. -* expander definitions:                 Expander Definitions.
  49631. -* EXPAND_BUILTIN_SAVEREGS:              Varargs.
  49632. -* explicit register variables:          Explicit Reg Vars.
  49633. -* expression codes:                     RTL Objects.
  49634. -* expressions containing statements:    Statement Exprs.
  49635. -* expressions, compound, as lvalues:    Lvalues.
  49636. -* expressions, conditional, as lvalues: Lvalues.
  49637. -* expressions, constructor:             Constructors.
  49638. -* expr_list:                            Insns.
  49639. -* extended asm:                         Extended Asm.
  49640. -* extensible constraints:               Simple Constraints.
  49641. -* extensions, ?::                       Conditionals.
  49642. -* extensions, ?::                       Lvalues.
  49643. -* extensions, C language:               C Extensions.
  49644. -* extensions, C++ language:             C++ Extensions.
  49645. -* extern int target_flags:              Run-time Target.
  49646. -* external declaration scope:           Incompatibilities.
  49647. -* EXTRA_CC_MODES:                       Condition Code.
  49648. -* EXTRA_CC_NAMES:                       Condition Code.
  49649. -* EXTRA_CONSTRAINT:                     Register Classes.
  49650. -* EXTRA_SECTIONS:                       Sections.
  49651. -* EXTRA_SECTION_FUNCTIONS:              Sections.
  49652. -* fabs:                                 C Dialect Options.
  49653. -* FAIL:                                 Expander Definitions.
  49654. -* fatal signal:                         Bug Criteria.
  49655. -* FATAL_EXIT_CODE:                      Config.
  49656. -* features, optional, in system conventions: Run-time Target.
  49657. -* ffs:                                  C Dialect Options.
  49658. -* ffs:                                  Arithmetic.
  49659. -* file name suffix:                     Overall Options.
  49660. -* file names:                           Link Options.
  49661. -* files and passes of the compiler:     Passes.
  49662. -* final pass:                           Passes.
  49663. -* FINALIZE_PIC:                         PIC.
  49664. -* FINAL_PRESCAN_INSN:                   Instruction Output.
  49665. -* FINAL_REG_PARM_STACK_SPACE:           Stack Arguments.
  49666. -* final_scan_insn:                      Function Entry.
  49667. -* final_sequence:                       Instruction Output.
  49668. -* FIRST_INSN_ADDRESS:                   Insn Lengths.
  49669. -* FIRST_PARM_OFFSET:                    Frame Layout.
  49670. -* FIRST_PSEUDO_REGISTER:                Register Basics.
  49671. -* FIRST_STACK_REG:                      Stack Registers.
  49672. -* FIRST_VIRTUAL_REGISTER:               Regs and Memory.
  49673. -* fix:                                  Conversions.
  49674. -* fix:                                  Conversions.
  49675. -* fixed register:                       Register Basics.
  49676. -* FIXED_REGISTERS:                      Register Basics.
  49677. -* fixed_regs:                           Register Basics.
  49678. -* FIXUNS_TRUNC_LIKE_FIX_TRUNC:          Misc.
  49679. -* flags in RTL expression:              Flags.
  49680. -* float:                                Conversions.
  49681. -* FLOATIFY:                             Library Calls.
  49682. -* floating point and cross compilation: Cross-compilation.
  49683. -* FLOAT_ARG_TYPE:                       Library Calls.
  49684. -* float_extend:                         Conversions.
  49685. -* FLOAT_STORE_FLAG_VALUE:               Misc.
  49686. -* float_truncate:                       Conversions.
  49687. -* FLOAT_TYPE_SIZE:                      Type Layout.
  49688. -* FLOAT_VALUE_TYPE:                     Library Calls.
  49689. -* FLOAT_WORDS_BIG_ENDIAN:               Storage Layout.
  49690. -* force_reg:                            Standard Names.
  49691. -* forwarding calls:                     Constructing Calls.
  49692. -* frame layout:                         Frame Layout.
  49693. -* FRAME_GROWS_DOWNWARD:                 Frame Layout.
  49694. -* frame_pointer_needed:                 Function Entry.
  49695. -* FRAME_POINTER_REGNUM:                 Frame Registers.
  49696. -* FRAME_POINTER_REQUIRED:               Elimination.
  49697. -* frame_pointer_rtx:                    Frame Registers.
  49698. -* function attributes:                  Function Attributes.
  49699. -* function call conventions:            Interface.
  49700. -* function entry and exit:              Function Entry.
  49701. -* function pointers, arithmetic:        Pointer Arith.
  49702. -* function prototype declarations:      Function Prototypes.
  49703. -* function units, for scheduling:       Function Units.
  49704. -* function, size of pointer to:         Pointer Arith.
  49705. -* function-call insns:                  Calls.
  49706. -* functions in arbitrary sections:      Function Attributes.
  49707. -* functions that are passed arguments in registers on the 386: Function Attributes.
  49708. -* functions that are passed arguments in registers on the 386: Function Attributes.
  49709. -* functions that do not pop the argument stack on the 386: Function Attributes.
  49710. -* functions that do pop the argument stack on the 386: Function Attributes.
  49711. -* functions that have no side effects:  Function Attributes.
  49712. -* functions that never return:          Function Attributes.
  49713. -* functions that pop the argument stack on the 386: Function Attributes.
  49714. -* functions that pop the argument stack on the 386: Function Attributes.
  49715. -* functions with printf or scanf style arguments: Function Attributes.
  49716. -* functions, leaf:                      Leaf Functions.
  49717. -* FUNCTION_ARG:                         Register Arguments.
  49718. -* FUNCTION_ARG_ADVANCE:                 Register Arguments.
  49719. -* FUNCTION_ARG_BOUNDARY:                Register Arguments.
  49720. -* FUNCTION_ARG_CALLEE_COPIES:           Register Arguments.
  49721. -* FUNCTION_ARG_PADDING:                 Register Arguments.
  49722. -* FUNCTION_ARG_PARTIAL_NREGS:           Register Arguments.
  49723. -* FUNCTION_ARG_PASS_BY_REFERENCE:       Register Arguments.
  49724. -* FUNCTION_ARG_REGNO_P:                 Register Arguments.
  49725. -* FUNCTION_BLOCK_PROFILER:              Profiling.
  49726. -* FUNCTION_BOUNDARY:                    Storage Layout.
  49727. -* FUNCTION_CONVERSION_BUG:              Config.
  49728. -* FUNCTION_EPILOGUE:                    Function Entry.
  49729. -* FUNCTION_INCOMING_ARG:                Register Arguments.
  49730. -* FUNCTION_MODE:                        Misc.
  49731. -* FUNCTION_OUTGOING_VALUE:              Scalar Return.
  49732. -* FUNCTION_PROFILER:                    Profiling.
  49733. -* FUNCTION_PROLOGUE:                    Function Entry.
  49734. -* FUNCTION_VALUE:                       Scalar Return.
  49735. -* FUNCTION_VALUE_REGNO_P:               Scalar Return.
  49736. -* G++:                                  G++ and GCC.
  49737. -* g++:                                  Invoking G++.
  49738. -* GCC:                                  G++ and GCC.
  49739. -* GCC_EXEC_PREFIX:                      Environment Variables.
  49740. -* ge:                                   Comparisons.
  49741. -* gencodes:                             Passes.
  49742. -* genconfig:                            Passes.
  49743. -* generalized lvalues:                  Lvalues.
  49744. -* general_operand:                      RTL Template.
  49745. -* GENERAL_REGS:                         Register Classes.
  49746. -* generating assembler output:          Output Statement.
  49747. -* generating insns:                     RTL Template.
  49748. -* genflags:                             Passes.
  49749. -* GEN_ERRNO_RTX:                        Library Calls.
  49750. -* get_attr:                             Expressions.
  49751. -* get_attr_length:                      Insn Lengths.
  49752. -* GET_CLASS_NARROWEST_MODE:             Machine Modes.
  49753. -* GET_CODE:                             RTL Objects.
  49754. -* get_frame_size:                       Elimination.
  49755. -* get_insns:                            Insns.
  49756. -* get_last_insn:                        Insns.
  49757. -* GET_MODE:                             Machine Modes.
  49758. -* GET_MODE_ALIGNMENT:                   Machine Modes.
  49759. -* GET_MODE_BITSIZE:                     Machine Modes.
  49760. -* GET_MODE_CLASS:                       Machine Modes.
  49761. -* GET_MODE_MASK:                        Machine Modes.
  49762. -* GET_MODE_NAME:                        Machine Modes.
  49763. -* GET_MODE_NUNITS:                      Machine Modes.
  49764. -* GET_MODE_SIZE:                        Machine Modes.
  49765. -* GET_MODE_UNIT_SIZE:                   Machine Modes.
  49766. -* GET_MODE_WIDER_MODE:                  Machine Modes.
  49767. -* GET_RTX_CLASS:                        Accessors.
  49768. -* GET_RTX_FORMAT:                       Accessors.
  49769. -* GET_RTX_LENGTH:                       Accessors.
  49770. -* geu:                                  Comparisons.
  49771. -* global offset table:                  Code Gen Options.
  49772. -* global register after longjmp:        Global Reg Vars.
  49773. -* global register allocation:           Passes.
  49774. -* global register variables:            Global Reg Vars.
  49775. -* GLOBALDEF:                            Global Declarations.
  49776. -* GLOBALREF:                            Global Declarations.
  49777. -* GLOBALVALUEDEF:                       Global Declarations.
  49778. -* GLOBALVALUEREF:                       Global Declarations.
  49779. -* GNU CC and portability:               Portability.
  49780. -* GNU CC command options:               Invoking GCC.
  49781. -* goto with computed label:             Labels as Values.
  49782. -* GO_IF_LEGITIMATE_ADDRESS:             Addressing Modes.
  49783. -* GO_IF_MODE_DEPENDENT_ADDRESS:         Addressing Modes.
  49784. -* gp-relative references (MIPS):        MIPS Options.
  49785. -* greater than:                         Comparisons.
  49786. -* greater than:                         Comparisons.
  49787. -* greater than:                         Comparisons.
  49788. -* grouping options:                     Invoking GCC.
  49789. -* gt:                                   Comparisons.
  49790. -* gtu:                                  Comparisons.
  49791. -* HANDLE_PRAGMA:                        Misc.
  49792. -* hard registers:                       Regs and Memory.
  49793. -* hardware models and configurations, specifying: Submodel Options.
  49794. -* HARD_FRAME_POINTER_REGNUM:            Frame Registers.
  49795. -* HARD_REGNO_MODE_OK:                   Values in Registers.
  49796. -* HARD_REGNO_NREGS:                     Values in Registers.
  49797. -* HAS_INIT_SECTION:                     Macros for Initialization.
  49798. -* HAVE_ATEXIT:                          Misc.
  49799. -* HAVE_POST_DECREMENT:                  Addressing Modes.
  49800. -* HAVE_POST_INCREMENT:                  Addressing Modes.
  49801. -* HAVE_PRE_DECREMENT:                   Addressing Modes.
  49802. -* HAVE_PRE_INCREMENT:                   Addressing Modes.
  49803. -* HAVE_PUTENV:                          Config.
  49804. -* HAVE_VPRINTF:                         Config.
  49805. -* header files and VMS:                 Include Files and VMS.
  49806. -* high:                                 Constants.
  49807. -* HImode:                               Machine Modes.
  49808. -* host makefile fragment:               Host Fragment.
  49809. -* HOST_BITS_PER_CHAR:                   Config.
  49810. -* HOST_BITS_PER_INT:                    Config.
  49811. -* HOST_BITS_PER_LONG:                   Config.
  49812. -* HOST_BITS_PER_SHORT:                  Config.
  49813. -* HOST_FLOAT_FORMAT:                    Config.
  49814. -* HOST_FLOAT_WORDS_BIG_ENDIAN:          Config.
  49815. -* HOST_WORDS_BIG_ENDIAN:                Config.
  49816. -* HPPA Options:                         HPPA Options.
  49817. -* i386 Options:                         i386 Options.
  49818. -* IBM RS/6000 and PowerPC Options:      RS/6000 and PowerPC Options.
  49819. -* IBM RT options:                       RT Options.
  49820. -* IBM RT PC:                            Interoperation.
  49821. -* identifier names, dollar signs in:    Dollar Signs.
  49822. -* identifiers, names in assembler code: Asm Labels.
  49823. -* identifying source, compiler (88k):   M88K Options.
  49824. -* IEEE_FLOAT_FORMAT:                    Storage Layout.
  49825. -* if_then_else:                         Comparisons.
  49826. -* immediate_operand:                    RTL Template.
  49827. -* IMMEDIATE_PREFIX:                     Instruction Output.
  49828. -* implicit argument: return value:      Naming Results.
  49829. -* IMPLICIT_FIX_EXPR:                    Misc.
  49830. -* implied #pragma implementation:       C++ Interface.
  49831. -* include files and VMS:                Include Files and VMS.
  49832. -* INCLUDE_DEFAULTS:                     Driver.
  49833. -* inclusive-or, bitwise:                Arithmetic.
  49834. -* INCOMING_REGNO:                       Register Basics.
  49835. -* incompatibilities of GNU CC:          Incompatibilities.
  49836. -* increment operators:                  Bug Criteria.
  49837. -* INDEX_REG_CLASS:                      Register Classes.
  49838. -* initialization routines:              Initialization.
  49839. -* initializations in expressions:       Constructors.
  49840. -* initializers with labeled elements:   Labeled Elements.
  49841. -* initializers, non-constant:           Initializers.
  49842. -* INITIALIZE_TRAMPOLINE:                Trampolines.
  49843. -* INITIAL_ELIMINATION_OFFSET:           Elimination.
  49844. -* INITIAL_FRAME_POINTER_OFFSET:         Elimination.
  49845. -* INIT_CUMULATIVE_ARGS:                 Register Arguments.
  49846. -* INIT_CUMULATIVE_INCOMING_ARGS:        Register Arguments.
  49847. -* INIT_ENVIRONMENT:                     Driver.
  49848. -* INIT_SECTION_ASM_OP:                  Macros for Initialization.
  49849. -* INIT_SECTION_ASM_OP:                  Sections.
  49850. -* INIT_TARGET_OPTABS:                   Library Calls.
  49851. -* inline functions:                     Inline.
  49852. -* inline functions, omission of:        Inline.
  49853. -* inline, automatic:                    Passes.
  49854. -* inlining and C++ pragmas:             C++ Interface.
  49855. -* insn:                                 Insns.
  49856. -* insn attributes:                      Insn Attributes.
  49857. -* insn canonicalization:                Insn Canonicalizations.
  49858. -* insn lengths, computing:              Insn Lengths.
  49859. -* insn splitting:                       Insn Splitting.
  49860. -* insn-attr.h:                          Defining Attributes.
  49861. -* insns:                                Insns.
  49862. -* insns, generating:                    RTL Template.
  49863. -* insns, recognizing:                   RTL Template.
  49864. -* INSN_ANNULLED_BRANCH_P:               Flags.
  49865. -* INSN_CACHE_DEPTH:                     Trampolines.
  49866. -* INSN_CACHE_LINE_WIDTH:                Trampolines.
  49867. -* INSN_CACHE_SIZE:                      Trampolines.
  49868. -* INSN_CLOBBERS_REGNO_P:                Obsolete Register Macros.
  49869. -* INSN_CODE:                            Insns.
  49870. -* INSN_DELETED_P:                       Flags.
  49871. -* INSN_FROM_TARGET_P:                   Flags.
  49872. -* insn_list:                            Insns.
  49873. -* INSN_REFERENCES_ARE_DELAYED:          Misc.
  49874. -* INSN_SETS_ARE_DELAYED:                Misc.
  49875. -* INSN_UID:                             Insns.
  49876. -* INSTALL:                              Host Fragment.
  49877. -* installation trouble:                 Trouble.
  49878. -* installing GNU CC:                    Installation.
  49879. -* installing GNU CC on the Sun:         Sun Install.
  49880. -* installing GNU CC on VMS:             VMS Install.
  49881. -* instruction attributes:               Insn Attributes.
  49882. -* instruction combination:              Passes.
  49883. -* instruction patterns:                 Patterns.
  49884. -* instruction recognizer:               Passes.
  49885. -* instruction scheduling:               Passes.
  49886. -* instruction scheduling:               Passes.
  49887. -* instruction splitting:                Insn Splitting.
  49888. -* integrated:                           Flags.
  49889. -* INTEGRATE_THRESHOLD:                  Misc.
  49890. -* integrating function code:            Inline.
  49891. -* Intel 386 Options:                    i386 Options.
  49892. -* Interdependence of Patterns:          Dependent Patterns.
  49893. -* interface and implementation headers, C++: C++ Interface.
  49894. -* interfacing to GNU CC output:         Interface.
  49895. -* intermediate C version, nonexistent:  G++ and GCC.
  49896. -* INTIFY:                               Library Calls.
  49897. -* introduction:                         Top.
  49898. -* INT_TYPE_SIZE:                        Type Layout.
  49899. -* invalid assembly code:                Bug Criteria.
  49900. -* invalid input:                        Bug Criteria.
  49901. -* INVOKE__main:                         Macros for Initialization.
  49902. -* invoking g++:                         Invoking G++.
  49903. -* in_data:                              Sections.
  49904. -* in_struct:                            Flags.
  49905. -* in_text:                              Sections.
  49906. -* ior:                                  Arithmetic.
  49907. -* isinf:                                Cross-compilation.
  49908. -* isnan:                                Cross-compilation.
  49909. -* IS_ASM_LOGICAL_LINE_SEPARATOR:        Data Output.
  49910. -* jump instruction patterns:            Jump Patterns.
  49911. -* jump instructions and set:            Side Effects.
  49912. -* jump optimization:                    Passes.
  49913. -* jump threading:                       Passes.
  49914. -* jump_insn:                            Insns.
  49915. -* JUMP_LABEL:                           Insns.
  49916. -* JUMP_TABLES_IN_TEXT_SECTION:          Sections.
  49917. -* kernel and user registers (29k):      AMD29K Options.
  49918. -* keywords, alternate:                  Alternate Keywords.
  49919. -* known causes of trouble:              Trouble.
  49920. -* labeled elements in initializers:     Labeled Elements.
  49921. -* labels as values:                     Labels as Values.
  49922. -* LABEL_NUSES:                          Insns.
  49923. -* LABEL_OUTSIDE_LOOP_P:                 Flags.
  49924. -* LABEL_PRESERVE_P:                     Flags.
  49925. -* label_ref:                            Constants.
  49926. -* labs:                                 C Dialect Options.
  49927. -* language dialect options:             C Dialect Options.
  49928. -* large bit shifts (88k):               M88K Options.
  49929. -* large return values:                  Aggregate Return.
  49930. -* LAST_STACK_REG:                       Stack Registers.
  49931. -* LAST_VIRTUAL_REGISTER:                Regs and Memory.
  49932. -* LDD_SUFFIX:                           Macros for Initialization.
  49933. -* ldexp:                                Cross-compilation.
  49934. -* LD_FINI_SWITCH:                       Macros for Initialization.
  49935. -* LD_INIT_SWITCH:                       Macros for Initialization.
  49936. -* le:                                   Comparisons.
  49937. -* leaf functions:                       Leaf Functions.
  49938. -* leaf_function:                        Leaf Functions.
  49939. -* leaf_function_p:                      Standard Names.
  49940. -* LEAF_REGISTERS:                       Leaf Functions.
  49941. -* LEAF_REG_REMAP:                       Leaf Functions.
  49942. -* left rotate:                          Arithmetic.
  49943. -* left shift:                           Arithmetic.
  49944. -* LEGITIMATE_CONSTANT_P:                Addressing Modes.
  49945. -* LEGITIMATE_PIC_OPERAND_P:             PIC.
  49946. -* LEGITIMIZE_ADDRESS:                   Addressing Modes.
  49947. -* length-zero arrays:                   Zero Length.
  49948. -* less than:                            Comparisons.
  49949. -* less than or equal:                   Comparisons.
  49950. -* leu:                                  Comparisons.
  49951. -* LIB2FUNCS_EXTRA:                      Target Fragment.
  49952. -* LIBCALL_VALUE:                        Scalar Return.
  49953. -* LIBGCC1:                              Target Fragment.
  49954. -* LIBGCC2_CFLAGS:                       Target Fragment.
  49955. -* LIBGCC2_WORDS_BIG_ENDIAN:             Storage Layout.
  49956. -* LIBGCC_NEEDS_DOUBLE:                  Library Calls.
  49957. -* LIBGCC_SPEC:                          Driver.
  49958. -* Libraries:                            Link Options.
  49959. -* library subroutine names:             Library Calls.
  49960. -* LIBRARY_PATH:                         Environment Variables.
  49961. -* LIB_SPEC:                             Driver.
  49962. -* LIMIT_RELOAD_CLASS:                   Register Classes.
  49963. -* link options:                         Link Options.
  49964. -* LINK_LIBGCC_SPECIAL:                  Driver.
  49965. -* LINK_LIBGCC_SPECIAL_1:                Driver.
  49966. -* LINK_SPEC:                            Driver.
  49967. -* load address instruction:             Simple Constraints.
  49968. -* LOAD_EXTEND_OP:                       Misc.
  49969. -* local labels:                         Local Labels.
  49970. -* local register allocation:            Passes.
  49971. -* local variables in macros:            Naming Types.
  49972. -* local variables, specifying registers: Local Reg Vars.
  49973. -* LOCAL_INCLUDE_DIR:                    Driver.
  49974. -* LOCAL_LABEL_PREFIX:                   Instruction Output.
  49975. -* logical-and, bitwise:                 Arithmetic.
  49976. -* LOG_LINKS:                            Insns.
  49977. -* longjmp:                              Global Reg Vars.
  49978. -* LONGJMP_RESTORE_FROM_STACK:           Elimination.
  49979. -* LONG_DOUBLE_TYPE_SIZE:                Type Layout.
  49980. -* LONG_LONG_TYPE_SIZE:                  Type Layout.
  49981. -* LONG_TYPE_SIZE:                       Type Layout.
  49982. -* loop optimization:                    Passes.
  49983. -* lo_sum:                               Arithmetic.
  49984. -* lshiftrt:                             Arithmetic.
  49985. -* lt:                                   Comparisons.
  49986. -* ltu:                                  Comparisons.
  49987. -* lvalues, generalized:                 Lvalues.
  49988. -* M680x0 options:                       M680x0 Options.
  49989. -* M88k options:                         M88K Options.
  49990. -* machine dependent options:            Submodel Options.
  49991. -* machine description macros:           Target Macros.
  49992. -* machine descriptions:                 Machine Desc.
  49993. -* machine mode conversions:             Conversions.
  49994. -* machine modes:                        Machine Modes.
  49995. -* machine specific constraints:         Machine Constraints.
  49996. -* MACHINE_DEPENDENT_REORG:              Misc.
  49997. -* macro with variable arguments:        Macro Varargs.
  49998. -* macros containing asm:                Extended Asm.
  49999. -* macros, inline alternative:           Inline.
  50000. -* macros, local labels:                 Local Labels.
  50001. -* macros, local variables in:           Naming Types.
  50002. -* macros, statements in expressions:    Statement Exprs.
  50003. -* macros, target description:           Target Macros.
  50004. -* macros, types of arguments:           Typeof.
  50005. -* make:                                 Preprocessor Options.
  50006. -* makefile fragment:                    Fragments.
  50007. -* make_safe_from:                       Expander Definitions.
  50008. -* matching constraint:                  Simple Constraints.
  50009. -* matching operands:                    Output Template.
  50010. -* match_dup:                            RTL Template.
  50011. -* match_operand:                        RTL Template.
  50012. -* match_operator:                       RTL Template.
  50013. -* match_op_dup:                         RTL Template.
  50014. -* match_parallel:                       RTL Template.
  50015. -* match_par_dup:                        RTL Template.
  50016. -* match_scratch:                        RTL Template.
  50017. -* math libraries:                       Interface.
  50018. -* math, in RTL:                         Arithmetic.
  50019. -* maximum operator:                     Min and Max.
  50020. -* MAX_BITS_PER_WORD:                    Storage Layout.
  50021. -* MAX_CHAR_TYPE_SIZE:                   Type Layout.
  50022. -* MAX_FIXED_MODE_SIZE:                  Storage Layout.
  50023. -* MAX_INT_TYPE_SIZE:                    Type Layout.
  50024. -* MAX_LONG_TYPE_SIZE:                   Type Layout.
  50025. -* MAX_MOVE_MAX:                         Misc.
  50026. -* MAX_OFILE_ALIGNMENT:                  Storage Layout.
  50027. -* MAX_REGS_PER_ADDRESS:                 Addressing Modes.
  50028. -* MAX_WCHAR_TYPE_SIZE:                  Type Layout.
  50029. -* MAYBE_REG_PARM_STACK_SPACE:           Stack Arguments.
  50030. -* mcount:                               Profiling.
  50031. -* MD_CALL_PROTOTYPES:                   Config.
  50032. -* MD_EXEC_PREFIX:                       Driver.
  50033. -* MD_STARTFILE_PREFIX:                  Driver.
  50034. -* MD_STARTFILE_PREFIX_1:                Driver.
  50035. -* mem:                                  Regs and Memory.
  50036. -* member fns, automatically inline:     Inline.
  50037. -* memcmp:                               C Dialect Options.
  50038. -* memcpy:                               C Dialect Options.
  50039. -* memory model (29k):                   AMD29K Options.
  50040. -* memory reference, nonoffsettable:     Simple Constraints.
  50041. -* memory references in constraints:     Simple Constraints.
  50042. -* MEMORY_MOVE_COST:                     Costs.
  50043. -* MEM_IN_STRUCT_P:                      Flags.
  50044. -* MEM_VOLATILE_P:                       Flags.
  50045. -* messages, warning:                    Warning Options.
  50046. -* messages, warning and error:          Warnings and Errors.
  50047. -* middle-operands, omitted:             Conditionals.
  50048. -* minimum operator:                     Min and Max.
  50049. -* minus:                                Arithmetic.
  50050. -* MIN_UNITS_PER_WORD:                   Storage Layout.
  50051. -* MIPS options:                         MIPS Options.
  50052. -* misunderstandings in C++:             C++ Misunderstandings.
  50053. -* mod:                                  Arithmetic.
  50054. -* MODDI3_LIBCALL:                       Library Calls.
  50055. -* mode classes:                         Machine Modes.
  50056. -* MODES_TIEABLE_P:                      Values in Registers.
  50057. -* MODE_CC:                              Machine Modes.
  50058. -* MODE_COMPLEX_FLOAT:                   Machine Modes.
  50059. -* MODE_COMPLEX_INT:                     Machine Modes.
  50060. -* MODE_FLOAT:                           Machine Modes.
  50061. -* MODE_FUNCTION:                        Machine Modes.
  50062. -* MODE_INT:                             Machine Modes.
  50063. -* MODE_PARTIAL_INT:                     Machine Modes.
  50064. -* MODE_RANDOM:                          Machine Modes.
  50065. -* modifiers in constraints:             Modifiers.
  50066. -* MODSI3_LIBCALL:                       Library Calls.
  50067. -* MOVE_MAX:                             Misc.
  50068. -* MOVE_RATIO:                           Costs.
  50069. -* MULDI3_LIBCALL:                       Library Calls.
  50070. -* MULSI3_LIBCALL:                       Library Calls.
  50071. -* mult:                                 Arithmetic.
  50072. -* MULTIBYTE_CHARS:                      Config.
  50073. -* MULTILIB_DEFAULTS:                    Driver.
  50074. -* MULTILIB_DIRNAMES:                    Target Fragment.
  50075. -* MULTILIB_MATCHES:                     Target Fragment.
  50076. -* MULTILIB_OPTIONS:                     Target Fragment.
  50077. -* multiple alternative constraints:     Multi-Alternative.
  50078. -* multiplication:                       Arithmetic.
  50079. -* multiprecision arithmetic:            Long Long.
  50080. -* name augmentation:                    VMS Misc.
  50081. -* named patterns and conditions:        Patterns.
  50082. -* named return value in C++:            Naming Results.
  50083. -* names used in assembler code:         Asm Labels.
  50084. -* names, pattern:                       Standard Names.
  50085. -* naming convention, implementation headers: C++ Interface.
  50086. -* naming types:                         Naming Types.
  50087. -* ne:                                   Comparisons.
  50088. -* neg:                                  Arithmetic.
  50089. -* nested functions:                     Nested Functions.
  50090. -* nested functions, trampolines for:    Trampolines.
  50091. -* newline vs string constants:          C Dialect Options.
  50092. -* next_cc0_user:                        Jump Patterns.
  50093. -* NEXT_INSN:                            Insns.
  50094. -* NEXT_OBJC_RUNTIME:                    Library Calls.
  50095. -* nil:                                  RTL Objects.
  50096. -* no constraints:                       No Constraints.
  50097. -* no-op move instructions:              Passes.
  50098. -* non-constant initializers:            Initializers.
  50099. -* non-static inline function:           Inline.
  50100. -* nongcc_SI_type:                       Library Calls.
  50101. -* nongcc_word_type:                     Library Calls.
  50102. -* nonoffsettable memory reference:      Simple Constraints.
  50103. -* NON_SAVING_SETJMP:                    Register Basics.
  50104. -* not:                                  Arithmetic.
  50105. -* not equal:                            Comparisons.
  50106. -* not using constraints:                No Constraints.
  50107. -* note:                                 Insns.
  50108. -* NOTE_INSN_BLOCK_BEG:                  Insns.
  50109. -* NOTE_INSN_BLOCK_END:                  Insns.
  50110. -* NOTE_INSN_DELETED:                    Insns.
  50111. -* NOTE_INSN_FUNCTION_END:               Insns.
  50112. -* NOTE_INSN_LOOP_BEG:                   Insns.
  50113. -* NOTE_INSN_LOOP_CONT:                  Insns.
  50114. -* NOTE_INSN_LOOP_END:                   Insns.
  50115. -* NOTE_INSN_LOOP_VTOP:                  Insns.
  50116. -* NOTE_INSN_SETJMP:                     Insns.
  50117. -* NOTE_LINE_NUMBER:                     Insns.
  50118. -* NOTE_SOURCE_FILE:                     Insns.
  50119. -* NOTICE_UPDATE_CC:                     Condition Code.
  50120. -* NO_BUILTIN_PTRDIFF_TYPE:              Driver.
  50121. -* NO_BUILTIN_SIZE_TYPE:                 Driver.
  50122. -* NO_DOLLAR_IN_LABEL:                   Misc.
  50123. -* NO_DOT_IN_LABEL:                      Misc.
  50124. -* NO_FUNCTION_CSE:                      Costs.
  50125. -* NO_IMPLICIT_EXTERN_C:                 Misc.
  50126. -* NO_MD_PROTOTYPES:                     Config.
  50127. -* NO_RECURSIVE_FUNCTION_CSE:            Costs.
  50128. -* NO_REGS:                              Register Classes.
  50129. -* NO_STAB_H:                            Config.
  50130. -* NO_SYS_SIGLIST:                       Config.
  50131. -* NUM_MACHINE_MODES:                    Machine Modes.
  50132. -* N_REG_CLASSES:                        Register Classes.
  50133. -* OBJC_GEN_METHOD_LABEL:                Label Output.
  50134. -* OBJC_INCLUDE_PATH:                    Environment Variables.
  50135. -* OBJC_INT_SELECTORS:                   Type Layout.
  50136. -* OBJC_PROLOGUE:                        File Framework.
  50137. -* OBJC_SELECTORS_WITHOUT_LABELS:        Type Layout.
  50138. -* Objective C:                          G++ and GCC.
  50139. -* OBJECT_FORMAT_COFF:                   Macros for Initialization.
  50140. -* OBJECT_FORMAT_ROSE:                   Macros for Initialization.
  50141. -* OBJECT_SUFFIX:                        Config.
  50142. -* OBSTACK_CHUNK_ALLOC:                  Config.
  50143. -* OBSTACK_CHUNK_FREE:                   Config.
  50144. -* OBSTACK_CHUNK_SIZE:                   Config.
  50145. -* obstack_free:                         Configurations.
  50146. -* OCS (88k):                            M88K Options.
  50147. -* offsettable address:                  Simple Constraints.
  50148. -* old-style function definitions:       Function Prototypes.
  50149. -* OLDAR:                                Host Fragment.
  50150. -* OLDCC:                                Host Fragment.
  50151. -* omitted middle-operands:              Conditionals.
  50152. -* ONLY_INT_FIELDS:                      Config.
  50153. -* open coding:                          Inline.
  50154. -* operand access:                       Accessors.
  50155. -* operand constraints:                  Constraints.
  50156. -* operand substitution:                 Output Template.
  50157. -* operands:                             Patterns.
  50158. -* OPTIMIZATION_OPTIONS:                 Run-time Target.
  50159. -* optimize options:                     Optimize Options.
  50160. -* optional hardware or system features: Run-time Target.
  50161. -* options to control warnings:          Warning Options.
  50162. -* options, C++:                         C++ Dialect Options.
  50163. -* options, code generation:             Code Gen Options.
  50164. -* options, debugging:                   Debugging Options.
  50165. -* options, dialect:                     C Dialect Options.
  50166. -* options, directory search:            Directory Options.
  50167. -* options, GNU CC command:              Invoking GCC.
  50168. -* options, grouping:                    Invoking GCC.
  50169. -* options, linking:                     Link Options.
  50170. -* options, optimization:                Optimize Options.
  50171. -* options, order:                       Invoking GCC.
  50172. -* options, preprocessor:                Preprocessor Options.
  50173. -* order of evaluation, side effects:    Non-bugs.
  50174. -* order of options:                     Invoking GCC.
  50175. -* order of register allocation:         Allocation Order.
  50176. -* Ordering of Patterns:                 Pattern Ordering.
  50177. -* ORDER_REGS_FOR_LOCAL_ALLOC:           Allocation Order.
  50178. -* other directory, compilation in:      Other Dir.
  50179. -* OUTGOING_REGNO:                       Register Basics.
  50180. -* OUTGOING_REG_PARM_STACK_SPACE:        Stack Arguments.
  50181. -* output file option:                   Overall Options.
  50182. -* output of assembler code:             File Framework.
  50183. -* output statements:                    Output Statement.
  50184. -* output templates:                     Output Template.
  50185. -* output_addr_const:                    Data Output.
  50186. -* output_asm_insn:                      Output Statement.
  50187. -* overflow while constant folding:      Cross-compilation.
  50188. -* OVERLAPPING_REGNO_P:                  Obsolete Register Macros.
  50189. -* overloaded virtual fn, warning:       Warning Options.
  50190. -* OVERRIDE_OPTIONS:                     Run-time Target.
  50191. -* parallel:                             Side Effects.
  50192. -* parameter forward declaration:        Variable Length.
  50193. -* parameters, miscellaneous:            Misc.
  50194. -* PARM_BOUNDARY:                        Storage Layout.
  50195. -* parser generator, Bison:              Installation.
  50196. -* PARSE_LDD_OUTPUT:                     Macros for Initialization.
  50197. -* parsing pass:                         Passes.
  50198. -* passes and files of the compiler:     Passes.
  50199. -* passing arguments:                    Interface.
  50200. -* PATH_SEPARATOR:                       Config.
  50201. -* PATTERN:                              Insns.
  50202. -* pattern conditions:                   Patterns.
  50203. -* pattern names:                        Standard Names.
  50204. -* Pattern Ordering:                     Pattern Ordering.
  50205. -* patterns:                             Patterns.
  50206. -* pc:                                   Regs and Memory.
  50207. -* PCC_BITFIELD_TYPE_MATTERS:            Storage Layout.
  50208. -* PCC_STATIC_STRUCT_RETURN:             Aggregate Return.
  50209. -* pc_rtx:                               Regs and Memory.
  50210. -* PDImode:                              Machine Modes.
  50211. -* peephole optimization:                Passes.
  50212. -* peephole optimization, RTL representation: Side Effects.
  50213. -* peephole optimizer definitions:       Peephole Definitions.
  50214. -* percent sign:                         Output Template.
  50215. -* perform_...:                          Library Calls.
  50216. -* PIC:                                  Code Gen Options.
  50217. -* PIC:                                  PIC.
  50218. -* PIC_OFFSET_TABLE_REGNUM:              PIC.
  50219. -* PIC_OFFSET_TABLE_REG_CALL_CLOBBERED:  PIC.
  50220. -* plus:                                 Arithmetic.
  50221. -* Pmode:                                Misc.
  50222. -* pointer arguments:                    Function Attributes.
  50223. -* POINTERS_EXTEND_UNSIGNED:             Storage Layout.
  50224. -* POINTER_SIZE:                         Storage Layout.
  50225. -* portability:                          Portability.
  50226. -* portions of temporary objects, pointers to: Temporaries.
  50227. -* position independent code:            PIC.
  50228. -* POSIX:                                Config.
  50229. -* post_dec:                             Incdec.
  50230. -* post_inc:                             Incdec.
  50231. -* pragma:                               Misc.
  50232. -* pragma, reason for not using:         Function Attributes.
  50233. -* pragmas in C++, effect on inlining:   C++ Interface.
  50234. -* pragmas, interface and implementation: C++ Interface.
  50235. -* predefined macros:                    Run-time Target.
  50236. -* PREDICATE_CODES:                      Misc.
  50237. -* PREFERRED_DEBUGGING_TYPE:             All Debuggers.
  50238. -* PREFERRED_OUTPUT_RELOAD_CLASS:        Register Classes.
  50239. -* PREFERRED_RELOAD_CLASS:               Register Classes.
  50240. -* preprocessing numbers:                Incompatibilities.
  50241. -* preprocessing tokens:                 Incompatibilities.
  50242. -* preprocessor options:                 Preprocessor Options.
  50243. -* PRESERVE_DEATH_INFO_REGNO_P:          Obsolete Register Macros.
  50244. -* prev_active_insn:                     Peephole Definitions.
  50245. -* prev_cc0_setter:                      Jump Patterns.
  50246. -* PREV_INSN:                            Insns.
  50247. -* pre_dec:                              Incdec.
  50248. -* pre_inc:                              Incdec.
  50249. -* PRINT_OPERAND:                        Instruction Output.
  50250. -* PRINT_OPERAND_ADDRESS:                Instruction Output.
  50251. -* PRINT_OPERAND_PUNCT_VALID_P:          Instruction Output.
  50252. -* processor selection (29k):            AMD29K Options.
  50253. -* product:                              Arithmetic.
  50254. -* PROFILE_BEFORE_PROLOGUE:              Profiling.
  50255. -* profiling, code generation:           Profiling.
  50256. -* program counter:                      Regs and Memory.
  50257. -* prologue:                             Function Entry.
  50258. -* PROMOTE_FOR_CALL_ONLY:                Storage Layout.
  50259. -* PROMOTE_FUNCTION_ARGS:                Storage Layout.
  50260. -* PROMOTE_FUNCTION_RETURN:              Storage Layout.
  50261. -* PROMOTE_MODE:                         Storage Layout.
  50262. -* PROMOTE_PROTOTYPES:                   Stack Arguments.
  50263. -* promotion of formal parameters:       Function Prototypes.
  50264. -* pseudo registers:                     Regs and Memory.
  50265. -* PSImode:                              Machine Modes.
  50266. -* PTRDIFF_TYPE:                         Type Layout.
  50267. -* push address instruction:             Simple Constraints.
  50268. -* PUSH_ROUNDING:                        Stack Arguments.
  50269. -* putenv:                               Config.
  50270. -* PUT_CODE:                             RTL Objects.
  50271. -* PUT_MODE:                             Machine Modes.
  50272. -* PUT_REG_NOTE_KIND:                    Insns.
  50273. -* PUT_SDB_...:                          SDB and DWARF.
  50274. -* QImode:                               Machine Modes.
  50275. -* question mark:                        Multi-Alternative.
  50276. -* quotient:                             Arithmetic.
  50277. -* r0-relative references (88k):         M88K Options.
  50278. -* ranges in case statements:            Case Ranges.
  50279. -* read-only strings:                    Incompatibilities.
  50280. -* READONLY_DATA_SECTION:                Sections.
  50281. -* REAL_ARITHMETIC:                      Cross-compilation.
  50282. -* REAL_INFINITY:                        Cross-compilation.
  50283. -* REAL_NM_FILE_NAME:                    Macros for Initialization.
  50284. -* REAL_VALUES_EQUAL:                    Cross-compilation.
  50285. -* REAL_VALUES_LESS:                     Cross-compilation.
  50286. -* REAL_VALUE_ATOF:                      Cross-compilation.
  50287. -* REAL_VALUE_FIX:                       Cross-compilation.
  50288. -* REAL_VALUE_FROM_INT:                  Cross-compilation.
  50289. -* REAL_VALUE_ISINF:                     Cross-compilation.
  50290. -* REAL_VALUE_ISNAN:                     Cross-compilation.
  50291. -* REAL_VALUE_LDEXP:                     Cross-compilation.
  50292. -* REAL_VALUE_NEGATE:                    Cross-compilation.
  50293. -* REAL_VALUE_RNDZINT:                   Cross-compilation.
  50294. -* REAL_VALUE_TO_DECIMAL:                Data Output.
  50295. -* REAL_VALUE_TO_INT:                    Cross-compilation.
  50296. -* REAL_VALUE_TO_TARGET_DOUBLE:          Data Output.
  50297. -* REAL_VALUE_TO_TARGET_LONG_DOUBLE:     Data Output.
  50298. -* REAL_VALUE_TO_TARGET_SINGLE:          Data Output.
  50299. -* REAL_VALUE_TRUNCATE:                  Cross-compilation.
  50300. -* REAL_VALUE_TYPE:                      Cross-compilation.
  50301. -* REAL_VALUE_UNSIGNED_FIX:              Cross-compilation.
  50302. -* REAL_VALUE_UNSIGNED_RNDZINT:          Cross-compilation.
  50303. -* recognizing insns:                    RTL Template.
  50304. -* recog_operand:                        Instruction Output.
  50305. -* reg:                                  Regs and Memory.
  50306. -* register allocation:                  Passes.
  50307. -* register allocation order:            Allocation Order.
  50308. -* register allocation, stupid:          Passes.
  50309. -* register class definitions:           Register Classes.
  50310. -* register class preference constraints: Class Preferences.
  50311. -* register class preference pass:       Passes.
  50312. -* register pairs:                       Values in Registers.
  50313. -* register positions in frame (88k):    M88K Options.
  50314. -* register positions in frame (88k):    M88K Options.
  50315. -* Register Transfer Language (RTL):     RTL.
  50316. -* register usage:                       Registers.
  50317. -* register use analysis:                Passes.
  50318. -* register variable after longjmp:      Global Reg Vars.
  50319. -* register-to-stack conversion:         Passes.
  50320. -* registers:                            Extended Asm.
  50321. -* registers arguments:                  Register Arguments.
  50322. -* registers for local variables:        Local Reg Vars.
  50323. -* registers in constraints:             Simple Constraints.
  50324. -* registers, global allocation:         Explicit Reg Vars.
  50325. -* registers, global variables in:       Global Reg Vars.
  50326. -* REGISTER_MOVE_COST:                   Costs.
  50327. -* REGISTER_NAMES:                       Instruction Output.
  50328. -* register_operand:                     RTL Template.
  50329. -* REGISTER_PREFIX:                      Instruction Output.
  50330. -* REGNO_OK_FOR_BASE_P:                  Register Classes.
  50331. -* REGNO_OK_FOR_INDEX_P:                 Register Classes.
  50332. -* REGNO_REG_CLASS:                      Register Classes.
  50333. -* regs_ever_live:                       Function Entry.
  50334. -* REG_ALLOC_ORDER:                      Allocation Order.
  50335. -* REG_CC_SETTER:                        Insns.
  50336. -* REG_CC_USER:                          Insns.
  50337. -* REG_CLASS_CONTENTS:                   Register Classes.
  50338. -* REG_CLASS_FROM_LETTER:                Register Classes.
  50339. -* REG_CLASS_NAMES:                      Register Classes.
  50340. -* REG_DEAD:                             Insns.
  50341. -* REG_DEP_ANTI:                         Insns.
  50342. -* REG_DEP_OUTPUT:                       Insns.
  50343. -* REG_EQUAL:                            Insns.
  50344. -* REG_EQUIV:                            Insns.
  50345. -* REG_FUNCTION_VALUE_P:                 Flags.
  50346. -* REG_INC:                              Insns.
  50347. -* REG_LABEL:                            Insns.
  50348. -* REG_LIBCALL:                          Insns.
  50349. -* REG_LOOP_TEST_P:                      Flags.
  50350. -* reg_names:                            Instruction Output.
  50351. -* REG_NONNEG:                           Insns.
  50352. -* REG_NOTES:                            Insns.
  50353. -* REG_NOTE_KIND:                        Insns.
  50354. -* REG_NO_CONFLICT:                      Insns.
  50355. -* REG_OK_FOR_BASE_P:                    Addressing Modes.
  50356. -* REG_OK_FOR_INDEX_P:                   Addressing Modes.
  50357. -* REG_OK_STRICT:                        Addressing Modes.
  50358. -* REG_PARM_STACK_SPACE:                 Stack Arguments.
  50359. -* REG_RETVAL:                           Insns.
  50360. -* REG_UNUSED:                           Insns.
  50361. -* REG_USERVAR_P:                        Flags.
  50362. -* REG_WAS_0:                            Insns.
  50363. -* relative costs:                       Costs.
  50364. -* RELATIVE_PREFIX_NOT_LINKDIR:          Driver.
  50365. -* reload pass:                          Regs and Memory.
  50366. -* reloading:                            Passes.
  50367. -* reload_completed:                     Standard Names.
  50368. -* reload_in_progress:                   Standard Names.
  50369. -* remainder:                            Arithmetic.
  50370. -* reordering, warning:                  Warning Options.
  50371. -* reporting bugs:                       Bugs.
  50372. -* representation of RTL:                RTL.
  50373. -* rest argument (in macro):             Macro Varargs.
  50374. -* rest_of_compilation:                  Passes.
  50375. -* rest_of_decl_compilation:             Passes.
  50376. -* return:                               Side Effects.
  50377. -* return value of main:                 VMS Misc.
  50378. -* return value, named, in C++:          Naming Results.
  50379. -* return values in registers:           Scalar Return.
  50380. -* returning aggregate values:           Aggregate Return.
  50381. -* returning structures and unions:      Interface.
  50382. -* RETURN_ADDR_IN_PREVIOUS_FRAME:        Frame Layout.
  50383. -* RETURN_ADDR_RTX:                      Frame Layout.
  50384. -* RETURN_IN_MEMORY:                     Aggregate Return.
  50385. -* RETURN_POPS_ARGS:                     Stack Arguments.
  50386. -* REVERSIBLE_CC_MODE:                   Condition Code.
  50387. -* right rotate:                         Arithmetic.
  50388. -* right shift:                          Arithmetic.
  50389. -* rotate:                               Arithmetic.
  50390. -* rotate:                               Arithmetic.
  50391. -* rotatert:                             Arithmetic.
  50392. -* ROUND_TYPE_ALIGN:                     Storage Layout.
  50393. -* ROUND_TYPE_SIZE:                      Storage Layout.
  50394. -* RS/6000 and PowerPC Options:          RS/6000 and PowerPC Options.
  50395. -* RT options:                           RT Options.
  50396. -* RT PC:                                Interoperation.
  50397. -* RTL addition:                         Arithmetic.
  50398. -* RTL comparison:                       Arithmetic.
  50399. -* RTL comparison operations:            Comparisons.
  50400. -* RTL constant expression types:        Constants.
  50401. -* RTL constants:                        Constants.
  50402. -* RTL declarations:                     RTL Declarations.
  50403. -* RTL difference:                       Arithmetic.
  50404. -* RTL expression:                       RTL Objects.
  50405. -* RTL expressions for arithmetic:       Arithmetic.
  50406. -* RTL format:                           Accessors.
  50407. -* RTL format characters:                Accessors.
  50408. -* RTL function-call insns:              Calls.
  50409. -* RTL generation:                       Passes.
  50410. -* RTL insn template:                    RTL Template.
  50411. -* RTL integers:                         RTL Objects.
  50412. -* RTL memory expressions:               Regs and Memory.
  50413. -* RTL object types:                     RTL Objects.
  50414. -* RTL postdecrement:                    Incdec.
  50415. -* RTL postincrement:                    Incdec.
  50416. -* RTL predecrement:                     Incdec.
  50417. -* RTL preincrement:                     Incdec.
  50418. -* RTL register expressions:             Regs and Memory.
  50419. -* RTL representation:                   RTL.
  50420. -* RTL side effect expressions:          Side Effects.
  50421. -* RTL strings:                          RTL Objects.
  50422. -* RTL structure sharing assumptions:    Sharing.
  50423. -* RTL subtraction:                      Arithmetic.
  50424. -* RTL sum:                              Arithmetic.
  50425. -* RTL vectors:                          RTL Objects.
  50426. -* RTX (See RTL):                        RTL Objects.
  50427. -* RTX_COSTS:                            Costs.
  50428. -* RTX_INTEGRATED_P:                     Flags.
  50429. -* RTX_UNCHANGING_P:                     Flags.
  50430. -* run-time conventions:                 Interface.
  50431. -* run-time options:                     Code Gen Options.
  50432. -* run-time target specification:        Run-time Target.
  50433. -* saveable_obstack:                     Addressing Modes.
  50434. -* scalars, returned as values:          Scalar Return.
  50435. -* SCCS_DIRECTIVE:                       Misc.
  50436. -* scheduling, delayed branch:           Passes.
  50437. -* scheduling, instruction:              Passes.
  50438. -* scheduling, instruction:              Passes.
  50439. -* SCHED_GROUP_P:                        Flags.
  50440. -* SCmode:                               Machine Modes.
  50441. -* scope of a variable length array:     Variable Length.
  50442. -* scope of declaration:                 Disappointments.
  50443. -* scope of external declarations:       Incompatibilities.
  50444. -* scratch:                              Regs and Memory.
  50445. -* scratch operands:                     Regs and Memory.
  50446. -* SDB_ALLOW_FORWARD_REFERENCES:         SDB and DWARF.
  50447. -* SDB_ALLOW_UNKNOWN_REFERENCES:         SDB and DWARF.
  50448. -* SDB_DEBUGGING_INFO:                   SDB and DWARF.
  50449. -* SDB_DELIM:                            SDB and DWARF.
  50450. -* SDB_GENERATE_FAKE:                    SDB and DWARF.
  50451. -* search path:                          Directory Options.
  50452. -* second include path:                  Preprocessor Options.
  50453. -* SECONDARY_INPUT_RELOAD_CLASS:         Register Classes.
  50454. -* SECONDARY_MEMORY_NEEDED:              Register Classes.
  50455. -* SECONDARY_MEMORY_NEEDED_MODE:         Register Classes.
  50456. -* SECONDARY_MEMORY_NEEDED_RTX:          Register Classes.
  50457. -* SECONDARY_OUTPUT_RELOAD_CLASS:        Register Classes.
  50458. -* SECONDARY_RELOAD_CLASS:               Register Classes.
  50459. -* SELECT_CC_MODE:                       Condition Code.
  50460. -* SELECT_RTX_SECTION:                   Sections.
  50461. -* SELECT_SECTION:                       Sections.
  50462. -* separate directory, compilation in:   Other Dir.
  50463. -* sequence:                             Side Effects.
  50464. -* sequential consistency on 88k:        M88K Options.
  50465. -* set:                                  Side Effects.
  50466. -* setjmp:                               Global Reg Vars.
  50467. -* SETUP_FRAME_ADDRESSES:                Frame Layout.
  50468. -* SETUP_INCOMING_VARARGS:               Varargs.
  50469. -* set_attr:                             Tagging Insns.
  50470. -* set_attr_alternative:                 Tagging Insns.
  50471. -* SET_DEFAULT_TYPE_ATTRIBUTES:          Misc.
  50472. -* SET_DEST:                             Side Effects.
  50473. -* SET_SRC:                              Side Effects.
  50474. -* SFmode:                               Machine Modes.
  50475. -* shared strings:                       Incompatibilities.
  50476. -* shared VMS run time system:           VMS Misc.
  50477. -* SHARED_SECTION_ASM_OP:                Sections.
  50478. -* sharing of RTL components:            Sharing.
  50479. -* shift:                                Arithmetic.
  50480. -* SHIFT_COUNT_TRUNCATED:                Misc.
  50481. -* SHORT_TYPE_SIZE:                      Type Layout.
  50482. -* side effect in ?::                    Conditionals.
  50483. -* side effects, macro argument:         Statement Exprs.
  50484. -* side effects, order of evaluation:    Non-bugs.
  50485. -* signature:                            C++ Signatures.
  50486. -* signature member function default implementation: C++ Signatures.
  50487. -* signatures, C++:                      C++ Signatures.
  50488. -* signed division:                      Arithmetic.
  50489. -* signed maximum:                       Arithmetic.
  50490. -* signed minimum:                       Arithmetic.
  50491. -* SIGNED_CHAR_SPEC:                     Driver.
  50492. -* sign_extend:                          Conversions.
  50493. -* sign_extract:                         Bit Fields.
  50494. -* SImode:                               Machine Modes.
  50495. -* simple constraints:                   Simple Constraints.
  50496. -* simplifications, arithmetic:          Passes.
  50497. -* sin:                                  C Dialect Options.
  50498. -* sizeof:                               Typeof.
  50499. -* SIZE_TYPE:                            Type Layout.
  50500. -* SLOW_BYTE_ACCESS:                     Costs.
  50501. -* SLOW_UNALIGNED_ACCESS:                Costs.
  50502. -* SLOW_ZERO_EXTEND:                     Costs.
  50503. -* smaller data references (88k):        M88K Options.
  50504. -* smaller data references (MIPS):       MIPS Options.
  50505. -* SMALL_REGISTER_CLASSES:               Register Classes.
  50506. -* smax:                                 Arithmetic.
  50507. -* smin:                                 Arithmetic.
  50508. -* SPARC options:                        SPARC Options.
  50509. -* specified registers:                  Explicit Reg Vars.
  50510. -* specifying compiler version and target machine: Target Options.
  50511. -* specifying hardware config:           Submodel Options.
  50512. -* specifying machine version:           Target Options.
  50513. -* specifying registers for local variables: Local Reg Vars.
  50514. -* speed of instructions:                Costs.
  50515. -* splitting instructions:               Insn Splitting.
  50516. -* sqrt:                                 Arithmetic.
  50517. -* sqrt:                                 C Dialect Options.
  50518. -* square root:                          Arithmetic.
  50519. -* stack arguments:                      Stack Arguments.
  50520. -* stack checks (29k):                   AMD29K Options.
  50521. -* stack frame layout:                   Frame Layout.
  50522. -* STACK_BOUNDARY:                       Storage Layout.
  50523. -* STACK_DYNAMIC_OFFSET:                 Frame Layout.
  50524. -* STACK_GROWS_DOWNWARD:                 Frame Layout.
  50525. -* STACK_PARMS_IN_REG_PARM_AREA:         Stack Arguments.
  50526. -* STACK_POINTER_OFFSET:                 Frame Layout.
  50527. -* STACK_POINTER_REGNUM:                 Frame Registers.
  50528. -* stack_pointer_rtx:                    Frame Registers.
  50529. -* STACK_REGS:                           Stack Registers.
  50530. -* stage1:                               Installation.
  50531. -* standard pattern names:               Standard Names.
  50532. -* STANDARD_EXEC_PREFIX:                 Driver.
  50533. -* STANDARD_INCLUDE_DIR:                 Driver.
  50534. -* STANDARD_STARTFILE_PREFIX:            Driver.
  50535. -* start files:                          Tools and Libraries.
  50536. -* STARTFILE_SPEC:                       Driver.
  50537. -* STARTING_FRAME_OFFSET:                Frame Layout.
  50538. -* statements inside expressions:        Statement Exprs.
  50539. -* static data in C++, declaring and defining: Static Definitions.
  50540. -* STATIC_CHAIN:                         Frame Registers.
  50541. -* STATIC_CHAIN_INCOMING:                Frame Registers.
  50542. -* STATIC_CHAIN_INCOMING_REGNUM:         Frame Registers.
  50543. -* STATIC_CHAIN_REGNUM:                  Frame Registers.
  50544. -* storage layout:                       Storage Layout.
  50545. -* storem bug (29k):                     AMD29K Options.
  50546. -* STORE_FLAG_VALUE:                     Misc.
  50547. -* strcmp:                               C Dialect Options.
  50548. -* strcpy:                               C Dialect Options.
  50549. -* strcpy:                               Storage Layout.
  50550. -* strength-reduction:                   Passes.
  50551. -* STRICT_ALIGNMENT:                     Storage Layout.
  50552. -* STRICT_ARGUMENT_NAMING:               Varargs.
  50553. -* strict_low_part:                      RTL Declarations.
  50554. -* string constants:                     Incompatibilities.
  50555. -* string constants vs newline:          C Dialect Options.
  50556. -* STRIP_NAME_ENCODING:                  Sections.
  50557. -* strlen:                               C Dialect Options.
  50558. -* structure passing (88k):              M88K Options.
  50559. -* structure value address:              Aggregate Return.
  50560. -* structures:                           Incompatibilities.
  50561. -* structures, constructor expression:   Constructors.
  50562. -* structures, returning:                Interface.
  50563. -* STRUCTURE_SIZE_BOUNDARY:              Storage Layout.
  50564. -* STRUCT_VALUE:                         Aggregate Return.
  50565. -* STRUCT_VALUE_INCOMING:                Aggregate Return.
  50566. -* STRUCT_VALUE_INCOMING_REGNUM:         Aggregate Return.
  50567. -* STRUCT_VALUE_REGNUM:                  Aggregate Return.
  50568. -* stupid register allocation:           Passes.
  50569. -* submodel options:                     Submodel Options.
  50570. -* subreg:                               Regs and Memory.
  50571. -* SUBREG_PROMOTED_UNSIGNED_P:           Flags.
  50572. -* SUBREG_PROMOTED_VAR_P:                Flags.
  50573. -* SUBREG_REG:                           Regs and Memory.
  50574. -* SUBREG_WORD:                          Regs and Memory.
  50575. -* subscripting:                         Subscripting.
  50576. -* subscripting and function values:     Subscripting.
  50577. -* subtype polymorphism, C++:            C++ Signatures.
  50578. -* SUCCESS_EXIT_CODE:                    Config.
  50579. -* suffixes for C++ source:              Invoking G++.
  50580. -* Sun installation:                     Sun Install.
  50581. -* SUPPORTS_WEAK:                        Label Output.
  50582. -* suppressing warnings:                 Warning Options.
  50583. -* surprises in C++:                     C++ Misunderstandings.
  50584. -* SVr4:                                 M88K Options.
  50585. -* SWITCHES_NEED_SPACES:                 Driver.
  50586. -* SWITCH_TAKES_ARG:                     Driver.
  50587. -* symbolic label:                       Sharing.
  50588. -* symbol_ref:                           Constants.
  50589. -* SYMBOL_REF_FLAG:                      Flags.
  50590. -* SYMBOL_REF_USED:                      Flags.
  50591. -* syntax checking:                      Warning Options.
  50592. -* synthesized methods, warning:         Warning Options.
  50593. -* SYSTEM_INCLUDE_DIR:                   Driver.
  50594. -* sys_siglist:                          Config.
  50595. -* tagging insns:                        Tagging Insns.
  50596. -* tail recursion optimization:          Passes.
  50597. -* target description macros:            Target Macros.
  50598. -* target machine, specifying:           Target Options.
  50599. -* target makefile fragment:             Target Fragment.
  50600. -* target options:                       Target Options.
  50601. -* target specifications:                Run-time Target.
  50602. -* target-parameter-dependent code:      Passes.
  50603. -* TARGET_BELL:                          Type Layout.
  50604. -* TARGET_BS:                            Type Layout.
  50605. -* TARGET_CR:                            Type Layout.
  50606. -* TARGET_EDOM:                          Library Calls.
  50607. -* TARGET_FF:                            Type Layout.
  50608. -* TARGET_FLOAT_FORMAT:                  Storage Layout.
  50609. -* TARGET_MEM_FUNCTIONS:                 Library Calls.
  50610. -* TARGET_NEWLINE:                       Type Layout.
  50611. -* TARGET_OPTIONS:                       Run-time Target.
  50612. -* TARGET_SWITCHES:                      Run-time Target.
  50613. -* TARGET_TAB:                           Type Layout.
  50614. -* TARGET_VERSION:                       Run-time Target.
  50615. -* TARGET_VT:                            Type Layout.
  50616. -* TCmode:                               Machine Modes.
  50617. -* template debugging:                   Warning Options.
  50618. -* template instantiation:               Template Instantiation.
  50619. -* temporaries, lifetime of:             Temporaries.
  50620. -* termination routines:                 Initialization.
  50621. -* text_section:                         Sections.
  50622. -* TEXT_SECTION_ASM_OP:                  Sections.
  50623. -* TFmode:                               Machine Modes.
  50624. -* thunks:                               Nested Functions.
  50625. -* TImode:                               Machine Modes.
  50626. -* TMPDIR:                               Environment Variables.
  50627. -* top level of compiler:                Passes.
  50628. -* traditional C language:               C Dialect Options.
  50629. -* TRADITIONAL_RETURN_FLOAT:             Scalar Return.
  50630. -* trampolines for nested functions:     Trampolines.
  50631. -* TRAMPOLINE_ALIGNMENT:                 Trampolines.
  50632. -* TRAMPOLINE_SECTION:                   Trampolines.
  50633. -* TRAMPOLINE_SIZE:                      Trampolines.
  50634. -* TRAMPOLINE_TEMPLATE:                  Trampolines.
  50635. -* TRANSFER_FROM_TRAMPOLINE:             Trampolines.
  50636. -* TRULY_NOOP_TRUNCATION:                Misc.
  50637. -* truncate:                             Conversions.
  50638. -* type abstraction, C++:                C++ Signatures.
  50639. -* type alignment:                       Alignment.
  50640. -* type attributes:                      Type Attributes.
  50641. -* typedef names as function parameters: Incompatibilities.
  50642. -* typeof:                               Typeof.
  50643. -* udiv:                                 Arithmetic.
  50644. -* UDIVDI3_LIBCALL:                      Library Calls.
  50645. -* UDIVSI3_LIBCALL:                      Library Calls.
  50646. -* Ultrix calling convention:            Interoperation.
  50647. -* umax:                                 Arithmetic.
  50648. -* umin:                                 Arithmetic.
  50649. -* umod:                                 Arithmetic.
  50650. -* UMODDI3_LIBCALL:                      Library Calls.
  50651. -* UMODSI3_LIBCALL:                      Library Calls.
  50652. -* unchanging:                           Flags.
  50653. -* undefined behavior:                   Bug Criteria.
  50654. -* undefined function value:             Bug Criteria.
  50655. -* underscores in variables in macros:   Naming Types.
  50656. -* underscores, avoiding (88k):          M88K Options.
  50657. -* union, casting to a:                  Cast to Union.
  50658. -* unions:                               Incompatibilities.
  50659. -* unions, returning:                    Interface.
  50660. -* UNITS_PER_WORD:                       Storage Layout.
  50661. -* UNKNOWN_FLOAT_FORMAT:                 Storage Layout.
  50662. -* unreachable code:                     Passes.
  50663. -* unresolved references and -nodefaultlibs: Link Options.
  50664. -* unresolved references and -nostdlib:  Link Options.
  50665. -* unshare_all_rtl:                      Sharing.
  50666. -* unsigned division:                    Arithmetic.
  50667. -* unsigned greater than:                Comparisons.
  50668. -* unsigned greater than:                Comparisons.
  50669. -* unsigned less than:                   Comparisons.
  50670. -* unsigned less than:                   Comparisons.
  50671. -* unsigned minimum and maximum:         Arithmetic.
  50672. -* unsigned_fix:                         Conversions.
  50673. -* unsigned_float:                       Conversions.
  50674. -* unspec:                               Side Effects.
  50675. -* unspec_volatile:                      Side Effects.
  50676. -* use:                                  Side Effects.
  50677. -* used:                                 Flags.
  50678. -* USER_LABEL_PREFIX:                    Instruction Output.
  50679. -* USE_C_ALLOCA:                         Config.
  50680. -* USE_PROTOTYPES:                       Config.
  50681. -* USG:                                  Config.
  50682. -* VALID_MACHINE_DECL_ATTRIBUTE:         Misc.
  50683. -* VALID_MACHINE_TYPE_ATTRIBUTE:         Misc.
  50684. -* value after longjmp:                  Global Reg Vars.
  50685. -* values, returned by functions:        Scalar Return.
  50686. -* varargs implementation:               Varargs.
  50687. -* variable alignment:                   Alignment.
  50688. -* variable attributes:                  Variable Attributes.
  50689. -* variable number of arguments:         Macro Varargs.
  50690. -* variable-length array scope:          Variable Length.
  50691. -* variable-length arrays:               Variable Length.
  50692. -* variables in specified registers:     Explicit Reg Vars.
  50693. -* variables, local, in macros:          Naming Types.
  50694. -* Vax calling convention:               Interoperation.
  50695. -* VAX options:                          VAX Options.
  50696. -* VAX_FLOAT_FORMAT:                     Storage Layout.
  50697. -* VIRTUAL_INCOMING_ARGS_REGNUM:         Regs and Memory.
  50698. -* VIRTUAL_OUTGOING_ARGS_REGNUM:         Regs and Memory.
  50699. -* VIRTUAL_STACK_DYNAMIC_REGNUM:         Regs and Memory.
  50700. -* VIRTUAL_STACK_VARS_REGNUM:            Regs and Memory.
  50701. -* VMS:                                  Config.
  50702. -* VMS and case sensitivity:             VMS Misc.
  50703. -* VMS and include files:                Include Files and VMS.
  50704. -* VMS installation:                     VMS Install.
  50705. -* void pointers, arithmetic:            Pointer Arith.
  50706. -* void, size of pointer to:             Pointer Arith.
  50707. -* VOIDmode:                             Machine Modes.
  50708. -* volatil:                              Flags.
  50709. -* volatile memory references:           Flags.
  50710. -* voting between constraint alternatives: Class Preferences.
  50711. -* vprintf:                              Config.
  50712. -* warning for enumeration conversions:  Warning Options.
  50713. -* warning for overloaded virtual fn:    Warning Options.
  50714. -* warning for reordering of member initializers: Warning Options.
  50715. -* warning for synthesized methods:      Warning Options.
  50716. -* warning messages:                     Warning Options.
  50717. -* warnings vs errors:                   Warnings and Errors.
  50718. -* WCHAR_TYPE:                           Type Layout.
  50719. -* WCHAR_TYPE_SIZE:                      Type Layout.
  50720. -* which_alternative:                    Output Statement.
  50721. -* whitespace:                           Incompatibilities.
  50722. -* WORDS_BIG_ENDIAN:                     Storage Layout.
  50723. -* word_mode:                            Machine Modes.
  50724. -* WORD_REGISTER_OPERATIONS:             Misc.
  50725. -* WORD_SWITCH_TAKES_ARG:                Driver.
  50726. -* XCmode:                               Machine Modes.
  50727. -* XCOFF_DEBUGGING_INFO:                 DBX Options.
  50728. -* XEXP:                                 Accessors.
  50729. -* XFmode:                               Machine Modes.
  50730. -* XINT:                                 Accessors.
  50731. -* xor:                                  Arithmetic.
  50732. -* XSTR:                                 Accessors.
  50733. -* XVEC:                                 Accessors.
  50734. -* XVECEXP:                              Accessors.
  50735. -* XVECLEN:                              Accessors.
  50736. -* XWINT:                                Accessors.
  50737. -* zero division on 88k:                 M88K Options.
  50738. -* zero-length arrays:                   Zero Length.
  50739. -* zero_extend:                          Conversions.
  50740. -* zero_extract:                         Bit Fields.
  50741. -* \:                                    Output Template.
  50742. -* __bb_init_func:                       Profiling.
  50743. -* __builtin_apply:                      Constructing Calls.
  50744. -* __builtin_apply_args:                 Constructing Calls.
  50745. -* __builtin_args_info:                  Varargs.
  50746. -* __builtin_classify_type:              Varargs.
  50747. -* __builtin_next_arg:                   Varargs.
  50748. -* __builtin_return:                     Constructing Calls.
  50749. -* __builtin_saveregs:                   Varargs.
  50750. -* __CTOR_LIST__:                        Initialization.
  50751. -* __DTOR_LIST__:                        Initialization.
  50752. -* __main:                               Collect2.
  50753. -
  50754. -
  50755. diff -rup --new-file baseline/fsf/gcc/gcc.info-3 amiga/fsf/gcc/gcc.info-3
  50756. --- baseline/fsf/gcc/gcc.info-3    Sat Jun 29 09:37:57 1996
  50757. +++ amiga/fsf/gcc/gcc.info-3    Wed Dec 31 17:00:00 1969
  50758. @@ -1,1212 +0,0 @@
  50759. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  50760. -file gcc.texi.
  50761. -
  50762. -   This file documents the use and the internals of the GNU compiler.
  50763. -
  50764. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  50765. -Boston, MA 02111-1307 USA
  50766. -
  50767. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  50768. -Foundation, Inc.
  50769. -
  50770. -   Permission is granted to make and distribute verbatim copies of this
  50771. -manual provided the copyright notice and this permission notice are
  50772. -preserved on all copies.
  50773. -
  50774. -   Permission is granted to copy and distribute modified versions of
  50775. -this manual under the conditions for verbatim copying, provided also
  50776. -that the sections entitled "GNU General Public License," "Funding for
  50777. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  50778. -included exactly as in the original, and provided that the entire
  50779. -resulting derived work is distributed under the terms of a permission
  50780. -notice identical to this one.
  50781. -
  50782. -   Permission is granted to copy and distribute translations of this
  50783. -manual into another language, under the above conditions for modified
  50784. -versions, except that the sections entitled "GNU General Public
  50785. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  50786. -`Look And Feel'", and this permission notice, may be included in
  50787. -translations approved by the Free Software Foundation instead of in the
  50788. -original English.
  50789. -
  50790. -
  50791. -File: gcc.info,  Node: Warning Options,  Next: Debugging Options,  Prev: C++ Dialect Options,  Up: Invoking GCC
  50792. -
  50793. -Options to Request or Suppress Warnings
  50794. -=======================================
  50795. -
  50796. -   Warnings are diagnostic messages that report constructions which are
  50797. -not inherently erroneous but which are risky or suggest there may have
  50798. -been an error.
  50799. -
  50800. -   You can request many specific warnings with options beginning `-W',
  50801. -for example `-Wimplicit' to request warnings on implicit declarations.
  50802. -Each of these specific warning options also has a negative form
  50803. -beginning `-Wno-' to turn off warnings; for example, `-Wno-implicit'.
  50804. -This manual lists only one of the two forms, whichever is not the
  50805. -default.
  50806. -
  50807. -   These options control the amount and kinds of warnings produced by
  50808. -GNU CC:
  50809. -
  50810. -`-fsyntax-only'
  50811. -     Check the code for syntax errors, but don't do anything beyond
  50812. -     that.
  50813. -
  50814. -`-pedantic'
  50815. -     Issue all the warnings demanded by strict ANSI standard C; reject
  50816. -     all programs that use forbidden extensions.
  50817. -
  50818. -     Valid ANSI standard C programs should compile properly with or
  50819. -     without this option (though a rare few will require `-ansi').
  50820. -     However, without this option, certain GNU extensions and
  50821. -     traditional C features are supported as well.  With this option,
  50822. -     they are rejected.
  50823. -
  50824. -     `-pedantic' does not cause warning messages for use of the
  50825. -     alternate keywords whose names begin and end with `__'.  Pedantic
  50826. -     warnings are also disabled in the expression that follows
  50827. -     `__extension__'.  However, only system header files should use
  50828. -     these escape routes; application programs should avoid them.
  50829. -     *Note Alternate Keywords::.
  50830. -
  50831. -     This option is not intended to be useful; it exists only to satisfy
  50832. -     pedants who would otherwise claim that GNU CC fails to support the
  50833. -     ANSI standard.
  50834. -
  50835. -     Some users try to use `-pedantic' to check programs for strict ANSI
  50836. -     C conformance.  They soon find that it does not do quite what they
  50837. -     want: it finds some non-ANSI practices, but not all--only those
  50838. -     for which ANSI C *requires* a diagnostic.
  50839. -
  50840. -     A feature to report any failure to conform to ANSI C might be
  50841. -     useful in some instances, but would require considerable
  50842. -     additional work and would be quite different from `-pedantic'.  We
  50843. -     recommend, rather, that users take advantage of the extensions of
  50844. -     GNU C and disregard the limitations of other compilers.  Aside
  50845. -     from certain supercomputers and obsolete small machines, there is
  50846. -     less and less reason ever to use any other C compiler other than
  50847. -     for bootstrapping GNU CC.
  50848. -
  50849. -`-pedantic-errors'
  50850. -     Like `-pedantic', except that errors are produced rather than
  50851. -     warnings.
  50852. -
  50853. -`-w'
  50854. -     Inhibit all warning messages.
  50855. -
  50856. -`-Wno-import'
  50857. -     Inhibit warning messages about the use of `#import'.
  50858. -
  50859. -`-Wchar-subscripts'
  50860. -     Warn if an array subscript has type `char'.  This is a common cause
  50861. -     of error, as programmers often forget that this type is signed on
  50862. -     some machines.
  50863. -
  50864. -`-Wcomment'
  50865. -     Warn whenever a comment-start sequence `/*' appears in a comment.
  50866. -
  50867. -`-Wformat'
  50868. -     Check calls to `printf' and `scanf', etc., to make sure that the
  50869. -     arguments supplied have types appropriate to the format string
  50870. -     specified.
  50871. -
  50872. -`-Wimplicit'
  50873. -     Warn whenever a function or parameter is implicitly declared.
  50874. -
  50875. -`-Wparentheses'
  50876. -     Warn if parentheses are omitted in certain contexts, such as when
  50877. -     there is an assignment in a context where a truth value is
  50878. -     expected, or when operators are nested whose precedence people
  50879. -     often get confused about.
  50880. -
  50881. -`-Wreturn-type'
  50882. -     Warn whenever a function is defined with a return-type that
  50883. -     defaults to `int'.  Also warn about any `return' statement with no
  50884. -     return-value in a function whose return-type is not `void'.
  50885. -
  50886. -`-Wswitch'
  50887. -     Warn whenever a `switch' statement has an index of enumeral type
  50888. -     and lacks a `case' for one or more of the named codes of that
  50889. -     enumeration.  (The presence of a `default' label prevents this
  50890. -     warning.)  `case' labels outside the enumeration range also
  50891. -     provoke warnings when this option is used.
  50892. -
  50893. -`-Wtrigraphs'
  50894. -     Warn if any trigraphs are encountered (assuming they are enabled).
  50895. -
  50896. -`-Wunused'
  50897. -     Warn whenever a variable is unused aside from its declaration,
  50898. -     whenever a function is declared static but never defined, whenever
  50899. -     a label is declared but not used, and whenever a statement
  50900. -     computes a result that is explicitly not used.
  50901. -
  50902. -     To suppress this warning for an expression, simply cast it to
  50903. -     void.  For unused variables and parameters, use the `unused'
  50904. -     attribute (*note Variable Attributes::.).
  50905. -
  50906. -`-Wuninitialized'
  50907. -     An automatic variable is used without first being initialized.
  50908. -
  50909. -     These warnings are possible only in optimizing compilation,
  50910. -     because they require data flow information that is computed only
  50911. -     when optimizing.  If you don't specify `-O', you simply won't get
  50912. -     these warnings.
  50913. -
  50914. -     These warnings occur only for variables that are candidates for
  50915. -     register allocation.  Therefore, they do not occur for a variable
  50916. -     that is declared `volatile', or whose address is taken, or whose
  50917. -     size is other than 1, 2, 4 or 8 bytes.  Also, they do not occur for
  50918. -     structures, unions or arrays, even when they are in registers.
  50919. -
  50920. -     Note that there may be no warning about a variable that is used
  50921. -     only to compute a value that itself is never used, because such
  50922. -     computations may be deleted by data flow analysis before the
  50923. -     warnings are printed.
  50924. -
  50925. -     These warnings are made optional because GNU CC is not smart
  50926. -     enough to see all the reasons why the code might be correct
  50927. -     despite appearing to have an error.  Here is one example of how
  50928. -     this can happen:
  50929. -
  50930. -          {
  50931. -            int x;
  50932. -            switch (y)
  50933. -              {
  50934. -              case 1: x = 1;
  50935. -                break;
  50936. -              case 2: x = 4;
  50937. -                break;
  50938. -              case 3: x = 5;
  50939. -              }
  50940. -            foo (x);
  50941. -          }
  50942. -
  50943. -     If the value of `y' is always 1, 2 or 3, then `x' is always
  50944. -     initialized, but GNU CC doesn't know this.  Here is another common
  50945. -     case:
  50946. -
  50947. -          {
  50948. -            int save_y;
  50949. -            if (change_y) save_y = y, y = new_y;
  50950. -            ...
  50951. -            if (change_y) y = save_y;
  50952. -          }
  50953. -
  50954. -     This has no bug because `save_y' is used only if it is set.
  50955. -
  50956. -     Some spurious warnings can be avoided if you declare all the
  50957. -     functions you use that never return as `noreturn'.  *Note Function
  50958. -     Attributes::.
  50959. -
  50960. -`-Wenum-clash'
  50961. -     Warn about conversion between different enumeration types.  (C++
  50962. -     only).
  50963. -
  50964. -`-Wreorder (C++ only)'
  50965. -     Warn when the order of member initializers given in the code does
  50966. -     not match the order in which they must be executed.  For instance:
  50967. -
  50968. -          struct A {
  50969. -            int i;
  50970. -            int j;
  50971. -            A(): j (0), i (1) { }
  50972. -          };
  50973. -
  50974. -     Here the compiler will warn that the member initializers for `i'
  50975. -     and `j' will be rearranged to match the declaration order of the
  50976. -     members.
  50977. -
  50978. -`-Wtemplate-debugging'
  50979. -     When using templates in a C++ program, warn if debugging is not yet
  50980. -     fully available (C++ only).
  50981. -
  50982. -`-Wall'
  50983. -     All of the above `-W' options combined.  These are all the options
  50984. -     which pertain to usage that we recommend avoiding and that we
  50985. -     believe is easy to avoid, even in conjunction with macros.
  50986. -
  50987. -   The remaining `-W...' options are not implied by `-Wall' because
  50988. -they warn about constructions that we consider reasonable to use, on
  50989. -occasion, in clean programs.
  50990. -
  50991. -`-W'
  50992. -     Print extra warning messages for these events:
  50993. -
  50994. -        * A nonvolatile automatic variable might be changed by a call to
  50995. -          `longjmp'.  These warnings as well are possible only in
  50996. -          optimizing compilation.
  50997. -
  50998. -          The compiler sees only the calls to `setjmp'.  It cannot know
  50999. -          where `longjmp' will be called; in fact, a signal handler
  51000. -          could call it at any point in the code.  As a result, you may
  51001. -          get a warning even when there is in fact no problem because
  51002. -          `longjmp' cannot in fact be called at the place which would
  51003. -          cause a problem.
  51004. -
  51005. -        * A function can return either with or without a value.
  51006. -          (Falling off the end of the function body is considered
  51007. -          returning without a value.)  For example, this function would
  51008. -          evoke such a warning:
  51009. -
  51010. -               foo (a)
  51011. -               {
  51012. -                 if (a > 0)
  51013. -                   return a;
  51014. -               }
  51015. -
  51016. -        * An expression-statement or the left-hand side of a comma
  51017. -          expression contains no side effects.  To suppress the
  51018. -          warning, cast the unused expression to void.  For example, an
  51019. -          expression such as `x[i,j]' will cause a warning, but
  51020. -          `x[(void)i,j]' will not.
  51021. -
  51022. -        * An unsigned value is compared against zero with `<' or `<='.
  51023. -
  51024. -        * A comparison like `x<=y<=z' appears; this is equivalent to
  51025. -          `(x<=y ? 1 : 0) <= z', which is a different interpretation
  51026. -          from that of ordinary mathematical notation.
  51027. -
  51028. -        * Storage-class specifiers like `static' are not the first
  51029. -          things in a declaration.  According to the C Standard, this
  51030. -          usage is obsolescent.
  51031. -
  51032. -        * If `-Wall' or `-Wunused' is also specified, warn about unused
  51033. -          arguments.
  51034. -
  51035. -        * An aggregate has a partly bracketed initializer.  For
  51036. -          example, the following code would evoke such a warning,
  51037. -          because braces are missing around the initializer for `x.h':
  51038. -
  51039. -               struct s { int f, g; };
  51040. -               struct t { struct s h; int i; };
  51041. -               struct t x = { 1, 2, 3 };
  51042. -
  51043. -`-Wtraditional'
  51044. -     Warn about certain constructs that behave differently in
  51045. -     traditional and ANSI C.
  51046. -
  51047. -        * Macro arguments occurring within string constants in the
  51048. -          macro body.  These would substitute the argument in
  51049. -          traditional C, but are part of the constant in ANSI C.
  51050. -
  51051. -        * A function declared external in one block and then used after
  51052. -          the end of the block.
  51053. -
  51054. -        * A `switch' statement has an operand of type `long'.
  51055. -
  51056. -`-Wshadow'
  51057. -     Warn whenever a local variable shadows another local variable.
  51058. -
  51059. -`-Wid-clash-LEN'
  51060. -     Warn whenever two distinct identifiers match in the first LEN
  51061. -     characters.  This may help you prepare a program that will compile
  51062. -     with certain obsolete, brain-damaged compilers.
  51063. -
  51064. -`-Wlarger-than-LEN'
  51065. -     Warn whenever an object of larger than LEN bytes is defined.
  51066. -
  51067. -`-Wpointer-arith'
  51068. -     Warn about anything that depends on the "size of" a function type
  51069. -     or of `void'.  GNU C assigns these types a size of 1, for
  51070. -     convenience in calculations with `void *' pointers and pointers to
  51071. -     functions.
  51072. -
  51073. -`-Wbad-function-cast'
  51074. -     Warn whenever a function call is cast to a non-matching type.  For
  51075. -     example, warn if `int malloc()' is cast to `anything *'.
  51076. -
  51077. -`-Wcast-qual'
  51078. -     Warn whenever a pointer is cast so as to remove a type qualifier
  51079. -     from the target type.  For example, warn if a `const char *' is
  51080. -     cast to an ordinary `char *'.
  51081. -
  51082. -`-Wcast-align'
  51083. -     Warn whenever a pointer is cast such that the required alignment
  51084. -     of the target is increased.  For example, warn if a `char *' is
  51085. -     cast to an `int *' on machines where integers can only be accessed
  51086. -     at two- or four-byte boundaries.
  51087. -
  51088. -`-Wwrite-strings'
  51089. -     Give string constants the type `const char[LENGTH]' so that
  51090. -     copying the address of one into a non-`const' `char *' pointer
  51091. -     will get a warning.  These warnings will help you find at compile
  51092. -     time code that can try to write into a string constant, but only
  51093. -     if you have been very careful about using `const' in declarations
  51094. -     and prototypes.  Otherwise, it will just be a nuisance; this is
  51095. -     why we did not make `-Wall' request these warnings.
  51096. -
  51097. -`-Wconversion'
  51098. -     Warn if a prototype causes a type conversion that is different
  51099. -     from what would happen to the same argument in the absence of a
  51100. -     prototype.  This includes conversions of fixed point to floating
  51101. -     and vice versa, and conversions changing the width or signedness
  51102. -     of a fixed point argument except when the same as the default
  51103. -     promotion.
  51104. -
  51105. -     Also, warn if a negative integer constant expression is implicitly
  51106. -     converted to an unsigned type.  For example, warn about the
  51107. -     assignment `x = -1' if `x' is unsigned.  But do not warn about
  51108. -     explicit casts like `(unsigned) -1'.
  51109. -
  51110. -`-Waggregate-return'
  51111. -     Warn if any functions that return structures or unions are defined
  51112. -     or called.  (In languages where you can return an array, this also
  51113. -     elicits a warning.)
  51114. -
  51115. -`-Wstrict-prototypes'
  51116. -     Warn if a function is declared or defined without specifying the
  51117. -     argument types.  (An old-style function definition is permitted
  51118. -     without a warning if preceded by a declaration which specifies the
  51119. -     argument types.)
  51120. -
  51121. -`-Wmissing-prototypes'
  51122. -     Warn if a global function is defined without a previous prototype
  51123. -     declaration.  This warning is issued even if the definition itself
  51124. -     provides a prototype.  The aim is to detect global functions that
  51125. -     fail to be declared in header files.
  51126. -
  51127. -`-Wmissing-declarations'
  51128. -     Warn if a global function is defined without a previous
  51129. -     declaration.  Do so even if the definition itself provides a
  51130. -     prototype.  Use this option to detect global functions that are
  51131. -     not declared in header files.
  51132. -
  51133. -`-Wredundant-decls'
  51134. -     Warn if anything is declared more than once in the same scope,
  51135. -     even in cases where multiple declaration is valid and changes
  51136. -     nothing.
  51137. -
  51138. -`-Wnested-externs'
  51139. -     Warn if an `extern' declaration is encountered within an function.
  51140. -
  51141. -`-Winline'
  51142. -     Warn if a function can not be inlined, and either it was declared
  51143. -     as inline, or else the `-finline-functions' option was given.
  51144. -
  51145. -`-Woverloaded-virtual'
  51146. -     Warn when a derived class function declaration may be an error in
  51147. -     defining a virtual function (C++ only).  In a derived class, the
  51148. -     definitions of virtual functions must match the type signature of a
  51149. -     virtual function declared in the base class.  With this option, the
  51150. -     compiler warns when you define a function with the same name as a
  51151. -     virtual function, but with a type signature that does not match any
  51152. -     declarations from the base class.
  51153. -
  51154. -`-Wsynth (C++ only)'
  51155. -     Warn when g++'s synthesis behavior does not match that of cfront.
  51156. -     For instance:
  51157. -
  51158. -          struct A {
  51159. -            operator int ();
  51160. -            A& operator = (int);
  51161. -          };
  51162. -          
  51163. -          main ()
  51164. -          {
  51165. -            A a,b;
  51166. -            a = b;
  51167. -          }
  51168. -
  51169. -     In this example, g++ will synthesize a default `A& operator =
  51170. -     (const A&);', while cfront will use the user-defined `operator ='.
  51171. -
  51172. -`-Werror'
  51173. -     Make all warnings into errors.
  51174. -
  51175. -
  51176. -File: gcc.info,  Node: Debugging Options,  Next: Optimize Options,  Prev: Warning Options,  Up: Invoking GCC
  51177. -
  51178. -Options for Debugging Your Program or GNU CC
  51179. -============================================
  51180. -
  51181. -   GNU CC has various special options that are used for debugging
  51182. -either your program or GCC:
  51183. -
  51184. -`-g'
  51185. -     Produce debugging information in the operating system's native
  51186. -     format (stabs, COFF, XCOFF, or DWARF).  GDB can work with this
  51187. -     debugging information.
  51188. -
  51189. -     On most systems that use stabs format, `-g' enables use of extra
  51190. -     debugging information that only GDB can use; this extra information
  51191. -     makes debugging work better in GDB but will probably make other
  51192. -     debuggers crash or refuse to read the program.  If you want to
  51193. -     control for certain whether to generate the extra information, use
  51194. -     `-gstabs+', `-gstabs', `-gxcoff+', `-gxcoff', `-gdwarf+', or
  51195. -     `-gdwarf' (see below).
  51196. -
  51197. -     Unlike most other C compilers, GNU CC allows you to use `-g' with
  51198. -     `-O'.  The shortcuts taken by optimized code may occasionally
  51199. -     produce surprising results: some variables you declared may not
  51200. -     exist at all; flow of control may briefly move where you did not
  51201. -     expect it; some statements may not be executed because they
  51202. -     compute constant results or their values were already at hand;
  51203. -     some statements may execute in different places because they were
  51204. -     moved out of loops.
  51205. -
  51206. -     Nevertheless it proves possible to debug optimized output.  This
  51207. -     makes it reasonable to use the optimizer for programs that might
  51208. -     have bugs.
  51209. -
  51210. -     The following options are useful when GNU CC is generated with the
  51211. -     capability for more than one debugging format.
  51212. -
  51213. -`-ggdb'
  51214. -     Produce debugging information in the native format (if that is
  51215. -     supported), including GDB extensions if at all possible.
  51216. -
  51217. -`-gstabs'
  51218. -     Produce debugging information in stabs format (if that is
  51219. -     supported), without GDB extensions.  This is the format used by
  51220. -     DBX on most BSD systems.  On MIPS, Alpha and System V Release 4
  51221. -     systems this option produces stabs debugging output which is not
  51222. -     understood by DBX or SDB.  On System V Release 4 systems this
  51223. -     option requires the GNU assembler.
  51224. -
  51225. -`-gstabs+'
  51226. -     Produce debugging information in stabs format (if that is
  51227. -     supported), using GNU extensions understood only by the GNU
  51228. -     debugger (GDB).  The use of these extensions is likely to make
  51229. -     other debuggers crash or refuse to read the program.
  51230. -
  51231. -`-gcoff'
  51232. -     Produce debugging information in COFF format (if that is
  51233. -     supported).  This is the format used by SDB on most System V
  51234. -     systems prior to System V Release 4.
  51235. -
  51236. -`-gxcoff'
  51237. -     Produce debugging information in XCOFF format (if that is
  51238. -     supported).  This is the format used by the DBX debugger on IBM
  51239. -     RS/6000 systems.
  51240. -
  51241. -`-gxcoff+'
  51242. -     Produce debugging information in XCOFF format (if that is
  51243. -     supported), using GNU extensions understood only by the GNU
  51244. -     debugger (GDB).  The use of these extensions is likely to make
  51245. -     other debuggers crash or refuse to read the program, and may cause
  51246. -     assemblers other than the GNU assembler (GAS) to fail with an
  51247. -     error.
  51248. -
  51249. -`-gdwarf'
  51250. -     Produce debugging information in DWARF format (if that is
  51251. -     supported).  This is the format used by SDB on most System V
  51252. -     Release 4 systems.
  51253. -
  51254. -`-gdwarf+'
  51255. -     Produce debugging information in DWARF format (if that is
  51256. -     supported), using GNU extensions understood only by the GNU
  51257. -     debugger (GDB).  The use of these extensions is likely to make
  51258. -     other debuggers crash or refuse to read the program.
  51259. -
  51260. -`-gLEVEL'
  51261. -`-ggdbLEVEL'
  51262. -`-gstabsLEVEL'
  51263. -`-gcoffLEVEL'
  51264. -`-gxcoffLEVEL'
  51265. -`-gdwarfLEVEL'
  51266. -     Request debugging information and also use LEVEL to specify how
  51267. -     much information.  The default level is 2.
  51268. -
  51269. -     Level 1 produces minimal information, enough for making backtraces
  51270. -     in parts of the program that you don't plan to debug.  This
  51271. -     includes descriptions of functions and external variables, but no
  51272. -     information about local variables and no line numbers.
  51273. -
  51274. -     Level 3 includes extra information, such as all the macro
  51275. -     definitions present in the program.  Some debuggers support macro
  51276. -     expansion when you use `-g3'.
  51277. -
  51278. -`-p'
  51279. -     Generate extra code to write profile information suitable for the
  51280. -     analysis program `prof'.  You must use this option when compiling
  51281. -     the source files you want data about, and you must also use it when
  51282. -     linking.
  51283. -
  51284. -`-pg'
  51285. -     Generate extra code to write profile information suitable for the
  51286. -     analysis program `gprof'.  You must use this option when compiling
  51287. -     the source files you want data about, and you must also use it when
  51288. -     linking.
  51289. -
  51290. -`-a'
  51291. -     Generate extra code to write profile information for basic blocks,
  51292. -     which will record the number of times each basic block is
  51293. -     executed, the basic block start address, and the function name
  51294. -     containing the basic block.  If `-g' is used, the line number and
  51295. -     filename of the start of the basic block will also be recorded.
  51296. -     If not overridden by the machine description, the default action is
  51297. -     to append to the text file `bb.out'.
  51298. -
  51299. -     This data could be analyzed by a program like `tcov'.  Note,
  51300. -     however, that the format of the data is not what `tcov' expects.
  51301. -     Eventually GNU `gprof' should be extended to process this data.
  51302. -
  51303. -`-dLETTERS'
  51304. -     Says to make debugging dumps during compilation at times specified
  51305. -     by LETTERS.  This is used for debugging the compiler.  The file
  51306. -     names for most of the dumps are made by appending a word to the
  51307. -     source file name (e.g.  `foo.c.rtl' or `foo.c.jump').  Here are the
  51308. -     possible letters for use in LETTERS, and their meanings:
  51309. -
  51310. -    `M'
  51311. -          Dump all macro definitions, at the end of preprocessing, and
  51312. -          write no output.
  51313. -
  51314. -    `N'
  51315. -          Dump all macro names, at the end of preprocessing.
  51316. -
  51317. -    `D'
  51318. -          Dump all macro definitions, at the end of preprocessing, in
  51319. -          addition to normal output.
  51320. -
  51321. -    `y'
  51322. -          Dump debugging information during parsing, to standard error.
  51323. -
  51324. -    `r'
  51325. -          Dump after RTL generation, to `FILE.rtl'.
  51326. -
  51327. -    `x'
  51328. -          Just generate RTL for a function instead of compiling it.
  51329. -          Usually used with `r'.
  51330. -
  51331. -    `j'
  51332. -          Dump after first jump optimization, to `FILE.jump'.
  51333. -
  51334. -    `s'
  51335. -          Dump after CSE (including the jump optimization that sometimes
  51336. -          follows CSE), to `FILE.cse'.
  51337. -
  51338. -    `L'
  51339. -          Dump after loop optimization, to `FILE.loop'.
  51340. -
  51341. -    `t'
  51342. -          Dump after the second CSE pass (including the jump
  51343. -          optimization that sometimes follows CSE), to `FILE.cse2'.
  51344. -
  51345. -    `f'
  51346. -          Dump after flow analysis, to `FILE.flow'.
  51347. -
  51348. -    `c'
  51349. -          Dump after instruction combination, to the file
  51350. -          `FILE.combine'.
  51351. -
  51352. -    `S'
  51353. -          Dump after the first instruction scheduling pass, to
  51354. -          `FILE.sched'.
  51355. -
  51356. -    `l'
  51357. -          Dump after local register allocation, to `FILE.lreg'.
  51358. -
  51359. -    `g'
  51360. -          Dump after global register allocation, to `FILE.greg'.
  51361. -
  51362. -    `R'
  51363. -          Dump after the second instruction scheduling pass, to
  51364. -          `FILE.sched2'.
  51365. -
  51366. -    `J'
  51367. -          Dump after last jump optimization, to `FILE.jump2'.
  51368. -
  51369. -    `d'
  51370. -          Dump after delayed branch scheduling, to `FILE.dbr'.
  51371. -
  51372. -    `k'
  51373. -          Dump after conversion from registers to stack, to
  51374. -          `FILE.stack'.
  51375. -
  51376. -    `a'
  51377. -          Produce all the dumps listed above.
  51378. -
  51379. -    `m'
  51380. -          Print statistics on memory usage, at the end of the run, to
  51381. -          standard error.
  51382. -
  51383. -    `p'
  51384. -          Annotate the assembler output with a comment indicating which
  51385. -          pattern and alternative was used.
  51386. -
  51387. -`-fpretend-float'
  51388. -     When running a cross-compiler, pretend that the target machine
  51389. -     uses the same floating point format as the host machine.  This
  51390. -     causes incorrect output of the actual floating constants, but the
  51391. -     actual instruction sequence will probably be the same as GNU CC
  51392. -     would make when running on the target machine.
  51393. -
  51394. -`-save-temps'
  51395. -     Store the usual "temporary" intermediate files permanently; place
  51396. -     them in the current directory and name them based on the source
  51397. -     file.  Thus, compiling `foo.c' with `-c -save-temps' would produce
  51398. -     files `foo.i' and `foo.s', as well as `foo.o'.
  51399. -
  51400. -`-print-file-name=LIBRARY'
  51401. -     Print the full absolute name of the library file LIBRARY that
  51402. -     would be used when linking--and don't do anything else.  With this
  51403. -     option, GNU CC does not compile or link anything; it just prints
  51404. -     the file name.
  51405. -
  51406. -`-print-prog-name=PROGRAM'
  51407. -     Like `-print-file-name', but searches for a program such as `cpp'.
  51408. -
  51409. -`-print-libgcc-file-name'
  51410. -     Same as `-print-file-name=libgcc.a'.
  51411. -
  51412. -     This is useful when you use `-nostdlib' or `-nodefaultlibs' but
  51413. -     you do want to link with `libgcc.a'.  You can do
  51414. -
  51415. -          gcc -nostdlib FILES... `gcc -print-libgcc-file-name`
  51416. -
  51417. -`-print-search-dirs'
  51418. -     Print the name of the configured installation directory and a list
  51419. -     of program and library directories gcc will search--and don't do
  51420. -     anything else.
  51421. -
  51422. -     This is useful when gcc prints the error message `installation
  51423. -     problem, cannot exec cpp: No such file or directory'.  To resolve
  51424. -     this you either need to put `cpp' and the other compiler
  51425. -     components where gcc expects to find them, or you can set the
  51426. -     environment variable `GCC_EXEC_PREFIX' to the directory where you
  51427. -     installed them.  Don't forget the trailing '/'.  *Note Environment
  51428. -     Variables::.
  51429. -
  51430. -
  51431. -File: gcc.info,  Node: Optimize Options,  Next: Preprocessor Options,  Prev: Debugging Options,  Up: Invoking GCC
  51432. -
  51433. -Options That Control Optimization
  51434. -=================================
  51435. -
  51436. -   These options control various sorts of optimizations:
  51437. -
  51438. -`-O'
  51439. -`-O1'
  51440. -     Optimize.  Optimizing compilation takes somewhat more time, and a
  51441. -     lot more memory for a large function.
  51442. -
  51443. -     Without `-O', the compiler's goal is to reduce the cost of
  51444. -     compilation and to make debugging produce the expected results.
  51445. -     Statements are independent: if you stop the program with a
  51446. -     breakpoint between statements, you can then assign a new value to
  51447. -     any variable or change the program counter to any other statement
  51448. -     in the function and get exactly the results you would expect from
  51449. -     the source code.
  51450. -
  51451. -     Without `-O', the compiler only allocates variables declared
  51452. -     `register' in registers.  The resulting compiled code is a little
  51453. -     worse than produced by PCC without `-O'.
  51454. -
  51455. -     With `-O', the compiler tries to reduce code size and execution
  51456. -     time.
  51457. -
  51458. -     When you specify `-O', the compiler turns on `-fthread-jumps' and
  51459. -     `-fdefer-pop' on all machines.  The compiler turns on
  51460. -     `-fdelayed-branch' on machines that have delay slots, and
  51461. -     `-fomit-frame-pointer' on machines that can support debugging even
  51462. -     without a frame pointer.  On some machines the compiler also turns
  51463. -     on other flags.
  51464. -
  51465. -`-O2'
  51466. -     Optimize even more.  GNU CC performs nearly all supported
  51467. -     optimizations that do not involve a space-speed tradeoff.  The
  51468. -     compiler does not perform loop unrolling or function inlining when
  51469. -     you specify `-O2'.  As compared to `-O', this option increases
  51470. -     both compilation time and the performance of the generated code.
  51471. -
  51472. -     `-O2' turns on all optional optimizations except for loop unrolling
  51473. -     and function inlining.  It also turns on the `-fforce-mem' option
  51474. -     on all machines and frame pointer elimination on machines where
  51475. -     doing so does not interfere with debugging.
  51476. -
  51477. -`-O3'
  51478. -     Optimize yet more.  `-O3' turns on all optimizations specified by
  51479. -     `-O2' and also turns on the `inline-functions' option.
  51480. -
  51481. -`-O0'
  51482. -     Do not optimize.
  51483. -
  51484. -     If you use multiple `-O' options, with or without level numbers,
  51485. -     the last such option is the one that is effective.
  51486. -
  51487. -   Options of the form `-fFLAG' specify machine-independent flags.
  51488. -Most flags have both positive and negative forms; the negative form of
  51489. -`-ffoo' would be `-fno-foo'.  In the table below, only one of the forms
  51490. -is listed--the one which is not the default.  You can figure out the
  51491. -other form by either removing `no-' or adding it.
  51492. -
  51493. -`-ffloat-store'
  51494. -     Do not store floating point variables in registers, and inhibit
  51495. -     other options that might change whether a floating point value is
  51496. -     taken from a register or memory.
  51497. -
  51498. -     This option prevents undesirable excess precision on machines such
  51499. -     as the 68000 where the floating registers (of the 68881) keep more
  51500. -     precision than a `double' is supposed to have.  For most programs,
  51501. -     the excess precision does only good, but a few programs rely on the
  51502. -     precise definition of IEEE floating point.  Use `-ffloat-store' for
  51503. -     such programs.
  51504. -
  51505. -`-fno-default-inline'
  51506. -     Do not make member functions inline by default merely because they
  51507. -     are defined inside the class scope (C++ only).  Otherwise, when
  51508. -     you specify `-O', member functions defined inside class scope are
  51509. -     compiled inline by default; i.e., you don't need to add `inline'
  51510. -     in front of the member function name.
  51511. -
  51512. -`-fno-defer-pop'
  51513. -     Always pop the arguments to each function call as soon as that
  51514. -     function returns.  For machines which must pop arguments after a
  51515. -     function call, the compiler normally lets arguments accumulate on
  51516. -     the stack for several function calls and pops them all at once.
  51517. -
  51518. -`-fforce-mem'
  51519. -     Force memory operands to be copied into registers before doing
  51520. -     arithmetic on them.  This produces better code by making all memory
  51521. -     references potential common subexpressions.  When they are not
  51522. -     common subexpressions, instruction combination should eliminate
  51523. -     the separate register-load.  The `-O2' option turns on this option.
  51524. -
  51525. -`-fforce-addr'
  51526. -     Force memory address constants to be copied into registers before
  51527. -     doing arithmetic on them.  This may produce better code just as
  51528. -     `-fforce-mem' may.
  51529. -
  51530. -`-fomit-frame-pointer'
  51531. -     Don't keep the frame pointer in a register for functions that
  51532. -     don't need one.  This avoids the instructions to save, set up and
  51533. -     restore frame pointers; it also makes an extra register available
  51534. -     in many functions.  *It also makes debugging impossible on some
  51535. -     machines.*
  51536. -
  51537. -     On some machines, such as the Vax, this flag has no effect, because
  51538. -     the standard calling sequence automatically handles the frame
  51539. -     pointer and nothing is saved by pretending it doesn't exist.  The
  51540. -     machine-description macro `FRAME_POINTER_REQUIRED' controls
  51541. -     whether a target machine supports this flag.  *Note Registers::.
  51542. -
  51543. -`-fno-inline'
  51544. -     Don't pay attention to the `inline' keyword.  Normally this option
  51545. -     is used to keep the compiler from expanding any functions inline.
  51546. -     Note that if you are not optimizing, no functions can be expanded
  51547. -     inline.
  51548. -
  51549. -`-finline-functions'
  51550. -     Integrate all simple functions into their callers.  The compiler
  51551. -     heuristically decides which functions are simple enough to be worth
  51552. -     integrating in this way.
  51553. -
  51554. -     If all calls to a given function are integrated, and the function
  51555. -     is declared `static', then the function is normally not output as
  51556. -     assembler code in its own right.
  51557. -
  51558. -`-fkeep-inline-functions'
  51559. -     Even if all calls to a given function are integrated, and the
  51560. -     function is declared `static', nevertheless output a separate
  51561. -     run-time callable version of the function.
  51562. -
  51563. -`-fno-function-cse'
  51564. -     Do not put function addresses in registers; make each instruction
  51565. -     that calls a constant function contain the function's address
  51566. -     explicitly.
  51567. -
  51568. -     This option results in less efficient code, but some strange hacks
  51569. -     that alter the assembler output may be confused by the
  51570. -     optimizations performed when this option is not used.
  51571. -
  51572. -`-ffast-math'
  51573. -     This option allows GCC to violate some ANSI or IEEE rules and/or
  51574. -     specifications in the interest of optimizing code for speed.  For
  51575. -     example, it allows the compiler to assume arguments to the `sqrt'
  51576. -     function are non-negative numbers and that no floating-point values
  51577. -     are NaNs.
  51578. -
  51579. -     This option should never be turned on by any `-O' option since it
  51580. -     can result in incorrect output for programs which depend on an
  51581. -     exact implementation of IEEE or ANSI rules/specifications for math
  51582. -     functions.
  51583. -
  51584. -   The following options control specific optimizations.  The `-O2'
  51585. -option turns on all of these optimizations except `-funroll-loops' and
  51586. -`-funroll-all-loops'.  On most machines, the `-O' option turns on the
  51587. -`-fthread-jumps' and `-fdelayed-branch' options, but specific machines
  51588. -may handle it differently.
  51589. -
  51590. -   You can use the following flags in the rare cases when "fine-tuning"
  51591. -of optimizations to be performed is desired.
  51592. -
  51593. -`-fstrength-reduce'
  51594. -     Perform the optimizations of loop strength reduction and
  51595. -     elimination of iteration variables.
  51596. -
  51597. -`-fthread-jumps'
  51598. -     Perform optimizations where we check to see if a jump branches to a
  51599. -     location where another comparison subsumed by the first is found.
  51600. -     If so, the first branch is redirected to either the destination of
  51601. -     the second branch or a point immediately following it, depending
  51602. -     on whether the condition is known to be true or false.
  51603. -
  51604. -`-fcse-follow-jumps'
  51605. -     In common subexpression elimination, scan through jump instructions
  51606. -     when the target of the jump is not reached by any other path.  For
  51607. -     example, when CSE encounters an `if' statement with an `else'
  51608. -     clause, CSE will follow the jump when the condition tested is
  51609. -     false.
  51610. -
  51611. -`-fcse-skip-blocks'
  51612. -     This is similar to `-fcse-follow-jumps', but causes CSE to follow
  51613. -     jumps which conditionally skip over blocks.  When CSE encounters a
  51614. -     simple `if' statement with no else clause, `-fcse-skip-blocks'
  51615. -     causes CSE to follow the jump around the body of the `if'.
  51616. -
  51617. -`-frerun-cse-after-loop'
  51618. -     Re-run common subexpression elimination after loop optimizations
  51619. -     has been performed.
  51620. -
  51621. -`-fexpensive-optimizations'
  51622. -     Perform a number of minor optimizations that are relatively
  51623. -     expensive.
  51624. -
  51625. -`-fdelayed-branch'
  51626. -     If supported for the target machine, attempt to reorder
  51627. -     instructions to exploit instruction slots available after delayed
  51628. -     branch instructions.
  51629. -
  51630. -`-fschedule-insns'
  51631. -     If supported for the target machine, attempt to reorder
  51632. -     instructions to eliminate execution stalls due to required data
  51633. -     being unavailable.  This helps machines that have slow floating
  51634. -     point or memory load instructions by allowing other instructions
  51635. -     to be issued until the result of the load or floating point
  51636. -     instruction is required.
  51637. -
  51638. -`-fschedule-insns2'
  51639. -     Similar to `-fschedule-insns', but requests an additional pass of
  51640. -     instruction scheduling after register allocation has been done.
  51641. -     This is especially useful on machines with a relatively small
  51642. -     number of registers and where memory load instructions take more
  51643. -     than one cycle.
  51644. -
  51645. -`-fcaller-saves'
  51646. -     Enable values to be allocated in registers that will be clobbered
  51647. -     by function calls, by emitting extra instructions to save and
  51648. -     restore the registers around such calls.  Such allocation is done
  51649. -     only when it seems to result in better code than would otherwise
  51650. -     be produced.
  51651. -
  51652. -     This option is enabled by default on certain machines, usually
  51653. -     those which have no call-preserved registers to use instead.
  51654. -
  51655. -`-funroll-loops'
  51656. -     Perform the optimization of loop unrolling.  This is only done for
  51657. -     loops whose number of iterations can be determined at compile time
  51658. -     or run time.  `-funroll-loop' implies both `-fstrength-reduce' and
  51659. -     `-frerun-cse-after-loop'.
  51660. -
  51661. -`-funroll-all-loops'
  51662. -     Perform the optimization of loop unrolling.  This is done for all
  51663. -     loops and usually makes programs run more slowly.
  51664. -     `-funroll-all-loops' implies `-fstrength-reduce' as well as
  51665. -     `-frerun-cse-after-loop'.
  51666. -
  51667. -`-fno-peephole'
  51668. -     Disable any machine-specific peephole optimizations.
  51669. -
  51670. -
  51671. -File: gcc.info,  Node: Preprocessor Options,  Next: Assembler Options,  Prev: Optimize Options,  Up: Invoking GCC
  51672. -
  51673. -Options Controlling the Preprocessor
  51674. -====================================
  51675. -
  51676. -   These options control the C preprocessor, which is run on each C
  51677. -source file before actual compilation.
  51678. -
  51679. -   If you use the `-E' option, nothing is done except preprocessing.
  51680. -Some of these options make sense only together with `-E' because they
  51681. -cause the preprocessor output to be unsuitable for actual compilation.
  51682. -
  51683. -`-include FILE'
  51684. -     Process FILE as input before processing the regular input file.
  51685. -     In effect, the contents of FILE are compiled first.  Any `-D' and
  51686. -     `-U' options on the command line are always processed before
  51687. -     `-include FILE', regardless of the order in which they are
  51688. -     written.  All the `-include' and `-imacros' options are processed
  51689. -     in the order in which they are written.
  51690. -
  51691. -`-imacros FILE'
  51692. -     Process FILE as input, discarding the resulting output, before
  51693. -     processing the regular input file.  Because the output generated
  51694. -     from FILE is discarded, the only effect of `-imacros FILE' is to
  51695. -     make the macros defined in FILE available for use in the main
  51696. -     input.
  51697. -
  51698. -     Any `-D' and `-U' options on the command line are always processed
  51699. -     before `-imacros FILE', regardless of the order in which they are
  51700. -     written.  All the `-include' and `-imacros' options are processed
  51701. -     in the order in which they are written.
  51702. -
  51703. -`-idirafter DIR'
  51704. -     Add the directory DIR to the second include path.  The directories
  51705. -     on the second include path are searched when a header file is not
  51706. -     found in any of the directories in the main include path (the one
  51707. -     that `-I' adds to).
  51708. -
  51709. -`-iprefix PREFIX'
  51710. -     Specify PREFIX as the prefix for subsequent `-iwithprefix' options.
  51711. -
  51712. -`-iwithprefix DIR'
  51713. -     Add a directory to the second include path.  The directory's name
  51714. -     is made by concatenating PREFIX and DIR, where PREFIX was
  51715. -     specified previously with `-iprefix'.  If you have not specified a
  51716. -     prefix yet, the directory containing the installed passes of the
  51717. -     compiler is used as the default.
  51718. -
  51719. -`-iwithprefixbefore DIR'
  51720. -     Add a directory to the main include path.  The directory's name is
  51721. -     made by concatenating PREFIX and DIR, as in the case of
  51722. -     `-iwithprefix'.
  51723. -
  51724. -`-isystem DIR'
  51725. -     Add a directory to the beginning of the second include path,
  51726. -     marking it as a system directory, so that it gets the same special
  51727. -     treatment as is applied to the standard system directories.
  51728. -
  51729. -`-nostdinc'
  51730. -     Do not search the standard system directories for header files.
  51731. -     Only the directories you have specified with `-I' options (and the
  51732. -     current directory, if appropriate) are searched.  *Note Directory
  51733. -     Options::, for information on `-I'.
  51734. -
  51735. -     By using both `-nostdinc' and `-I-', you can limit the include-file
  51736. -     search path to only those directories you specify explicitly.
  51737. -
  51738. -`-undef'
  51739. -     Do not predefine any nonstandard macros.  (Including architecture
  51740. -     flags).
  51741. -
  51742. -`-E'
  51743. -     Run only the C preprocessor.  Preprocess all the C source files
  51744. -     specified and output the results to standard output or to the
  51745. -     specified output file.
  51746. -
  51747. -`-C'
  51748. -     Tell the preprocessor not to discard comments.  Used with the `-E'
  51749. -     option.
  51750. -
  51751. -`-P'
  51752. -     Tell the preprocessor not to generate `#line' directives.  Used
  51753. -     with the `-E' option.
  51754. -
  51755. -`-M'
  51756. -     Tell the preprocessor to output a rule suitable for `make'
  51757. -     describing the dependencies of each object file.  For each source
  51758. -     file, the preprocessor outputs one `make'-rule whose target is the
  51759. -     object file name for that source file and whose dependencies are
  51760. -     all the `#include' header files it uses.  This rule may be a
  51761. -     single line or may be continued with `\'-newline if it is long.
  51762. -     The list of rules is printed on standard output instead of the
  51763. -     preprocessed C program.
  51764. -
  51765. -     `-M' implies `-E'.
  51766. -
  51767. -     Another way to specify output of a `make' rule is by setting the
  51768. -     environment variable `DEPENDENCIES_OUTPUT' (*note Environment
  51769. -     Variables::.).
  51770. -
  51771. -`-MM'
  51772. -     Like `-M' but the output mentions only the user header files
  51773. -     included with `#include "FILE"'.  System header files included
  51774. -     with `#include <FILE>' are omitted.
  51775. -
  51776. -`-MD'
  51777. -     Like `-M' but the dependency information is written to a file made
  51778. -     by replacing ".c" with ".d" at the end of the input file names.
  51779. -     This is in addition to compiling the file as specified--`-MD' does
  51780. -     not inhibit ordinary compilation the way `-M' does.
  51781. -
  51782. -     In Mach, you can use the utility `md' to merge multiple dependency
  51783. -     files into a single dependency file suitable for using with the
  51784. -     `make' command.
  51785. -
  51786. -`-MMD'
  51787. -     Like `-MD' except mention only user header files, not system
  51788. -     header files.
  51789. -
  51790. -`-MG'
  51791. -     Treat missing header files as generated files and assume they live
  51792. -     in the same directory as the source file.  If you specify `-MG',
  51793. -     you must also specify either `-M' or `-MM'.  `-MG' is not
  51794. -     supported with `-MD' or `-MMD'.
  51795. -
  51796. -`-H'
  51797. -     Print the name of each header file used, in addition to other
  51798. -     normal activities.
  51799. -
  51800. -`-AQUESTION(ANSWER)'
  51801. -     Assert the answer ANSWER for QUESTION, in case it is tested with a
  51802. -     preprocessing conditional such as `#if #QUESTION(ANSWER)'.  `-A-'
  51803. -     disables the standard assertions that normally describe the target
  51804. -     machine.
  51805. -
  51806. -`-DMACRO'
  51807. -     Define macro MACRO with the string `1' as its definition.
  51808. -
  51809. -`-DMACRO=DEFN'
  51810. -     Define macro MACRO as DEFN.  All instances of `-D' on the command
  51811. -     line are processed before any `-U' options.
  51812. -
  51813. -`-UMACRO'
  51814. -     Undefine macro MACRO.  `-U' options are evaluated after all `-D'
  51815. -     options, but before any `-include' and `-imacros' options.
  51816. -
  51817. -`-dM'
  51818. -     Tell the preprocessor to output only a list of the macro
  51819. -     definitions that are in effect at the end of preprocessing.  Used
  51820. -     with the `-E' option.
  51821. -
  51822. -`-dD'
  51823. -     Tell the preprocessing to pass all macro definitions into the
  51824. -     output, in their proper sequence in the rest of the output.
  51825. -
  51826. -`-dN'
  51827. -     Like `-dD' except that the macro arguments and contents are
  51828. -     omitted.  Only `#define NAME' is included in the output.
  51829. -
  51830. -`-trigraphs'
  51831. -     Support ANSI C trigraphs.  The `-ansi' option also has this effect.
  51832. -
  51833. -`-Wp,OPTION'
  51834. -     Pass OPTION as an option to the preprocessor.  If OPTION contains
  51835. -     commas, it is split into multiple options at the commas.
  51836. -
  51837. -
  51838. -File: gcc.info,  Node: Assembler Options,  Next: Link Options,  Prev: Preprocessor Options,  Up: Invoking GCC
  51839. -
  51840. -Passing Options to the Assembler
  51841. -================================
  51842. -
  51843. -   You can pass options to the assembler.
  51844. -
  51845. -`-Wa,OPTION'
  51846. -     Pass OPTION as an option to the assembler.  If OPTION contains
  51847. -     commas, it is split into multiple options at the commas.
  51848. -
  51849. -
  51850. -File: gcc.info,  Node: Link Options,  Next: Directory Options,  Prev: Assembler Options,  Up: Invoking GCC
  51851. -
  51852. -Options for Linking
  51853. -===================
  51854. -
  51855. -   These options come into play when the compiler links object files
  51856. -into an executable output file.  They are meaningless if the compiler is
  51857. -not doing a link step.
  51858. -
  51859. -`OBJECT-FILE-NAME'
  51860. -     A file name that does not end in a special recognized suffix is
  51861. -     considered to name an object file or library.  (Object files are
  51862. -     distinguished from libraries by the linker according to the file
  51863. -     contents.)  If linking is done, these object files are used as
  51864. -     input to the linker.
  51865. -
  51866. -`-c'
  51867. -`-S'
  51868. -`-E'
  51869. -     If any of these options is used, then the linker is not run, and
  51870. -     object file names should not be used as arguments.  *Note Overall
  51871. -     Options::.
  51872. -
  51873. -`-lLIBRARY'
  51874. -     Search the library named LIBRARY when linking.
  51875. -
  51876. -     It makes a difference where in the command you write this option;
  51877. -     the linker searches processes libraries and object files in the
  51878. -     order they are specified.  Thus, `foo.o -lz bar.o' searches
  51879. -     library `z' after file `foo.o' but before `bar.o'.  If `bar.o'
  51880. -     refers to functions in `z', those functions may not be loaded.
  51881. -
  51882. -     The linker searches a standard list of directories for the library,
  51883. -     which is actually a file named `libLIBRARY.a'.  The linker then
  51884. -     uses this file as if it had been specified precisely by name.
  51885. -
  51886. -     The directories searched include several standard system
  51887. -     directories plus any that you specify with `-L'.
  51888. -
  51889. -     Normally the files found this way are library files--archive files
  51890. -     whose members are object files.  The linker handles an archive
  51891. -     file by scanning through it for members which define symbols that
  51892. -     have so far been referenced but not defined.  But if the file that
  51893. -     is found is an ordinary object file, it is linked in the usual
  51894. -     fashion.  The only difference between using an `-l' option and
  51895. -     specifying a file name is that `-l' surrounds LIBRARY with `lib'
  51896. -     and `.a' and searches several directories.
  51897. -
  51898. -`-lobjc'
  51899. -     You need this special case of the `-l' option in order to link an
  51900. -     Objective C program.
  51901. -
  51902. -`-nostartfiles'
  51903. -     Do not use the standard system startup files when linking.  The
  51904. -     standard system libraries are used normally, unless `-nostdlib' or
  51905. -     `-nodefaultlibs' is used.
  51906. -
  51907. -`-nodefaultlibs'
  51908. -     Do not use the standard system libraries when linking.  Only the
  51909. -     libraries you specify will be passed to the linker.  The standard
  51910. -     startup files are used normally, unless `-nostartfiles' is used.
  51911. -
  51912. -`-nostdlib'
  51913. -     Do not use the standard system startup files or libraries when
  51914. -     linking.  No startup files and only the libraries you specify will
  51915. -     be passed to the linker.
  51916. -
  51917. -     One of the standard libraries bypassed by `-nostdlib' and
  51918. -     `-nodefaultlibs' is `libgcc.a', a library of internal subroutines
  51919. -     that GNU CC uses to overcome shortcomings of particular machines,
  51920. -     or special needs for some languages.  (*Note Interfacing to GNU CC
  51921. -     Output: Interface, for more discussion of `libgcc.a'.) In most
  51922. -     cases, you need `libgcc.a' even when you want to avoid other
  51923. -     standard libraries.  In other words, when you specify `-nostdlib'
  51924. -     or `-nodefaultlibs' you should usually specify `-lgcc' as well.
  51925. -     This ensures that you have no unresolved references to internal
  51926. -     GNU CC library subroutines.  (For example, `__main', used to
  51927. -     ensure C++ constructors will be called; *note `collect2':
  51928. -     Collect2..)
  51929. -
  51930. -`-s'
  51931. -     Remove all symbol table and relocation information from the
  51932. -     executable.
  51933. -
  51934. -`-static'
  51935. -     On systems that support dynamic linking, this prevents linking
  51936. -     with the shared libraries.  On other systems, this option has no
  51937. -     effect.
  51938. -
  51939. -`-shared'
  51940. -     Produce a shared object which can then be linked with other
  51941. -     objects to form an executable.  Only a few systems support this
  51942. -     option.
  51943. -
  51944. -`-symbolic'
  51945. -     Bind references to global symbols when building a shared object.
  51946. -     Warn about any unresolved references (unless overridden by the
  51947. -     link editor option `-Xlinker -z -Xlinker defs').  Only a few
  51948. -     systems support this option.
  51949. -
  51950. -`-Xlinker OPTION'
  51951. -     Pass OPTION as an option to the linker.  You can use this to
  51952. -     supply system-specific linker options which GNU CC does not know
  51953. -     how to recognize.
  51954. -
  51955. -     If you want to pass an option that takes an argument, you must use
  51956. -     `-Xlinker' twice, once for the option and once for the argument.
  51957. -     For example, to pass `-assert definitions', you must write
  51958. -     `-Xlinker -assert -Xlinker definitions'.  It does not work to write
  51959. -     `-Xlinker "-assert definitions"', because this passes the entire
  51960. -     string as a single argument, which is not what the linker expects.
  51961. -
  51962. -`-Wl,OPTION'
  51963. -     Pass OPTION as an option to the linker.  If OPTION contains
  51964. -     commas, it is split into multiple options at the commas.
  51965. -
  51966. -`-u SYMBOL'
  51967. -     Pretend the symbol SYMBOL is undefined, to force linking of
  51968. -     library modules to define it.  You can use `-u' multiple times with
  51969. -     different symbols to force loading of additional library modules.
  51970. -
  51971. diff -rup --new-file baseline/fsf/gcc/gcc.info-4 amiga/fsf/gcc/gcc.info-4
  51972. --- baseline/fsf/gcc/gcc.info-4    Sat Jun 29 09:37:57 1996
  51973. +++ amiga/fsf/gcc/gcc.info-4    Wed Dec 31 17:00:00 1969
  51974. @@ -1,1151 +0,0 @@
  51975. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  51976. -file gcc.texi.
  51977. -
  51978. -   This file documents the use and the internals of the GNU compiler.
  51979. -
  51980. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  51981. -Boston, MA 02111-1307 USA
  51982. -
  51983. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  51984. -Foundation, Inc.
  51985. -
  51986. -   Permission is granted to make and distribute verbatim copies of this
  51987. -manual provided the copyright notice and this permission notice are
  51988. -preserved on all copies.
  51989. -
  51990. -   Permission is granted to copy and distribute modified versions of
  51991. -this manual under the conditions for verbatim copying, provided also
  51992. -that the sections entitled "GNU General Public License," "Funding for
  51993. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  51994. -included exactly as in the original, and provided that the entire
  51995. -resulting derived work is distributed under the terms of a permission
  51996. -notice identical to this one.
  51997. -
  51998. -   Permission is granted to copy and distribute translations of this
  51999. -manual into another language, under the above conditions for modified
  52000. -versions, except that the sections entitled "GNU General Public
  52001. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  52002. -`Look And Feel'", and this permission notice, may be included in
  52003. -translations approved by the Free Software Foundation instead of in the
  52004. -original English.
  52005. -
  52006. -
  52007. -File: gcc.info,  Node: Directory Options,  Next: Target Options,  Prev: Link Options,  Up: Invoking GCC
  52008. -
  52009. -Options for Directory Search
  52010. -============================
  52011. -
  52012. -   These options specify directories to search for header files, for
  52013. -libraries and for parts of the compiler:
  52014. -
  52015. -`-IDIR'
  52016. -     Add the directory DIRECTORY to the head of the list of directories
  52017. -     to be searched for header files.  This can be used to override a
  52018. -     system header file, substituting your own version, since these
  52019. -     directories are searched before the system header file
  52020. -     directories.  If you use more than one `-I' option, the
  52021. -     directories are scanned in left-to-right order; the standard
  52022. -     system directories come after.
  52023. -
  52024. -`-I-'
  52025. -     Any directories you specify with `-I' options before the `-I-'
  52026. -     option are searched only for the case of `#include "FILE"'; they
  52027. -     are not searched for `#include <FILE>'.
  52028. -
  52029. -     If additional directories are specified with `-I' options after
  52030. -     the `-I-', these directories are searched for all `#include'
  52031. -     directives.  (Ordinarily *all* `-I' directories are used this way.)
  52032. -
  52033. -     In addition, the `-I-' option inhibits the use of the current
  52034. -     directory (where the current input file came from) as the first
  52035. -     search directory for `#include "FILE"'.  There is no way to
  52036. -     override this effect of `-I-'.  With `-I.' you can specify
  52037. -     searching the directory which was current when the compiler was
  52038. -     invoked.  That is not exactly the same as what the preprocessor
  52039. -     does by default, but it is often satisfactory.
  52040. -
  52041. -     `-I-' does not inhibit the use of the standard system directories
  52042. -     for header files.  Thus, `-I-' and `-nostdinc' are independent.
  52043. -
  52044. -`-LDIR'
  52045. -     Add directory DIR to the list of directories to be searched for
  52046. -     `-l'.
  52047. -
  52048. -`-BPREFIX'
  52049. -     This option specifies where to find the executables, libraries,
  52050. -     include files, and data files of the compiler itself.
  52051. -
  52052. -     The compiler driver program runs one or more of the subprograms
  52053. -     `cpp', `cc1', `as' and `ld'.  It tries PREFIX as a prefix for each
  52054. -     program it tries to run, both with and without `MACHINE/VERSION/'
  52055. -     (*note Target Options::.).
  52056. -
  52057. -     For each subprogram to be run, the compiler driver first tries the
  52058. -     `-B' prefix, if any.  If that name is not found, or if `-B' was
  52059. -     not specified, the driver tries two standard prefixes, which are
  52060. -     `/usr/lib/gcc/' and `/usr/local/lib/gcc-lib/'.  If neither of
  52061. -     those results in a file name that is found, the unmodified program
  52062. -     name is searched for using the directories specified in your
  52063. -     `PATH' environment variable.
  52064. -
  52065. -     `-B' prefixes that effectively specify directory names also apply
  52066. -     to libraries in the linker, because the compiler translates these
  52067. -     options into `-L' options for the linker.  They also apply to
  52068. -     includes files in the preprocessor, because the compiler
  52069. -     translates these options into `-isystem' options for the
  52070. -     preprocessor.  In this case, the compiler appends `include' to the
  52071. -     prefix.
  52072. -
  52073. -     The run-time support file `libgcc.a' can also be searched for using
  52074. -     the `-B' prefix, if needed.  If it is not found there, the two
  52075. -     standard prefixes above are tried, and that is all.  The file is
  52076. -     left out of the link if it is not found by those means.
  52077. -
  52078. -     Another way to specify a prefix much like the `-B' prefix is to use
  52079. -     the environment variable `GCC_EXEC_PREFIX'.  *Note Environment
  52080. -     Variables::.
  52081. -
  52082. -
  52083. -File: gcc.info,  Node: Target Options,  Next: Submodel Options,  Prev: Directory Options,  Up: Invoking GCC
  52084. -
  52085. -Specifying Target Machine and Compiler Version
  52086. -==============================================
  52087. -
  52088. -   By default, GNU CC compiles code for the same type of machine that
  52089. -you are using.  However, it can also be installed as a cross-compiler,
  52090. -to compile for some other type of machine.  In fact, several different
  52091. -configurations of GNU CC, for different target machines, can be
  52092. -installed side by side.  Then you specify which one to use with the
  52093. -`-b' option.
  52094. -
  52095. -   In addition, older and newer versions of GNU CC can be installed side
  52096. -by side.  One of them (probably the newest) will be the default, but
  52097. -you may sometimes wish to use another.
  52098. -
  52099. -`-b MACHINE'
  52100. -     The argument MACHINE specifies the target machine for compilation.
  52101. -     This is useful when you have installed GNU CC as a cross-compiler.
  52102. -
  52103. -     The value to use for MACHINE is the same as was specified as the
  52104. -     machine type when configuring GNU CC as a cross-compiler.  For
  52105. -     example, if a cross-compiler was configured with `configure
  52106. -     i386v', meaning to compile for an 80386 running System V, then you
  52107. -     would specify `-b i386v' to run that cross compiler.
  52108. -
  52109. -     When you do not specify `-b', it normally means to compile for the
  52110. -     same type of machine that you are using.
  52111. -
  52112. -`-V VERSION'
  52113. -     The argument VERSION specifies which version of GNU CC to run.
  52114. -     This is useful when multiple versions are installed.  For example,
  52115. -     VERSION might be `2.0', meaning to run GNU CC version 2.0.
  52116. -
  52117. -     The default version, when you do not specify `-V', is the last
  52118. -     version of GNU CC that you installed.
  52119. -
  52120. -   The `-b' and `-V' options actually work by controlling part of the
  52121. -file name used for the executable files and libraries used for
  52122. -compilation.  A given version of GNU CC, for a given target machine, is
  52123. -normally kept in the directory `/usr/local/lib/gcc-lib/MACHINE/VERSION'.
  52124. -
  52125. -   Thus, sites can customize the effect of `-b' or `-V' either by
  52126. -changing the names of these directories or adding alternate names (or
  52127. -symbolic links).  If in directory `/usr/local/lib/gcc-lib/' the file
  52128. -`80386' is a link to the file `i386v', then `-b 80386' becomes an alias
  52129. -for `-b i386v'.
  52130. -
  52131. -   In one respect, the `-b' or `-V' do not completely change to a
  52132. -different compiler: the top-level driver program `gcc' that you
  52133. -originally invoked continues to run and invoke the other executables
  52134. -(preprocessor, compiler per se, assembler and linker) that do the real
  52135. -work.  However, since no real work is done in the driver program, it
  52136. -usually does not matter that the driver program in use is not the one
  52137. -for the specified target and version.
  52138. -
  52139. -   The only way that the driver program depends on the target machine is
  52140. -in the parsing and handling of special machine-specific options.
  52141. -However, this is controlled by a file which is found, along with the
  52142. -other executables, in the directory for the specified version and
  52143. -target machine.  As a result, a single installed driver program adapts
  52144. -to any specified target machine and compiler version.
  52145. -
  52146. -   The driver program executable does control one significant thing,
  52147. -however: the default version and target machine.  Therefore, you can
  52148. -install different instances of the driver program, compiled for
  52149. -different targets or versions, under different names.
  52150. -
  52151. -   For example, if the driver for version 2.0 is installed as `ogcc'
  52152. -and that for version 2.1 is installed as `gcc', then the command `gcc'
  52153. -will use version 2.1 by default, while `ogcc' will use 2.0 by default.
  52154. -However, you can choose either version with either command with the
  52155. -`-V' option.
  52156. -
  52157. -
  52158. -File: gcc.info,  Node: Submodel Options,  Next: Code Gen Options,  Prev: Target Options,  Up: Invoking GCC
  52159. -
  52160. -Hardware Models and Configurations
  52161. -==================================
  52162. -
  52163. -   Earlier we discussed the standard option `-b' which chooses among
  52164. -different installed compilers for completely different target machines,
  52165. -such as Vax vs. 68000 vs. 80386.
  52166. -
  52167. -   In addition, each of these target machine types can have its own
  52168. -special options, starting with `-m', to choose among various hardware
  52169. -models or configurations--for example, 68010 vs 68020, floating
  52170. -coprocessor or none.  A single installed version of the compiler can
  52171. -compile for any model or configuration, according to the options
  52172. -specified.
  52173. -
  52174. -   Some configurations of the compiler also support additional special
  52175. -options, usually for compatibility with other compilers on the same
  52176. -platform.
  52177. -
  52178. -   These options are defined by the macro `TARGET_SWITCHES' in the
  52179. -machine description.  The default for the options is also defined by
  52180. -that macro, which enables you to change the defaults.
  52181. -
  52182. -* Menu:
  52183. -
  52184. -* M680x0 Options::
  52185. -* VAX Options::
  52186. -* SPARC Options::
  52187. -* Convex Options::
  52188. -* AMD29K Options::
  52189. -* ARM Options::
  52190. -* M88K Options::
  52191. -* RS/6000 and PowerPC Options::
  52192. -* RT Options::
  52193. -* MIPS Options::
  52194. -* i386 Options::
  52195. -* HPPA Options::
  52196. -* Intel 960 Options::
  52197. -* DEC Alpha Options::
  52198. -* Clipper Options::
  52199. -* H8/300 Options::
  52200. -* System V Options::
  52201. -
  52202. -
  52203. -File: gcc.info,  Node: M680x0 Options,  Next: VAX Options,  Up: Submodel Options
  52204. -
  52205. -M680x0 Options
  52206. ---------------
  52207. -
  52208. -   These are the `-m' options defined for the 68000 series.  The default
  52209. -values for these options depends on which style of 68000 was selected
  52210. -when the compiler was configured; the defaults for the most common
  52211. -choices are given below.
  52212. -
  52213. -`-m68000'
  52214. -`-mc68000'
  52215. -     Generate output for a 68000.  This is the default when the
  52216. -     compiler is configured for 68000-based systems.
  52217. -
  52218. -`-m68020'
  52219. -`-mc68020'
  52220. -     Generate output for a 68020.  This is the default when the
  52221. -     compiler is configured for 68020-based systems.
  52222. -
  52223. -`-m68881'
  52224. -     Generate output containing 68881 instructions for floating point.
  52225. -     This is the default for most 68020 systems unless `-nfp' was
  52226. -     specified when the compiler was configured.
  52227. -
  52228. -`-m68030'
  52229. -     Generate output for a 68030.  This is the default when the
  52230. -     compiler is configured for 68030-based systems.
  52231. -
  52232. -`-m68040'
  52233. -     Generate output for a 68040.  This is the default when the
  52234. -     compiler is configured for 68040-based systems.
  52235. -
  52236. -     This option inhibits the use of 68881/68882 instructions that have
  52237. -     to be emulated by software on the 68040.  If your 68040 does not
  52238. -     have code to emulate those instructions, use `-m68040'.
  52239. -
  52240. -`-m68020-40'
  52241. -     Generate output for a 68040, without using any of the new
  52242. -     instructions.  This results in code which can run relatively
  52243. -     efficiently on either a 68020/68881 or a 68030 or a 68040.  The
  52244. -     generated code does use the 68881 instructions that are emulated
  52245. -     on the 68040.
  52246. -
  52247. -`-mfpa'
  52248. -     Generate output containing Sun FPA instructions for floating point.
  52249. -
  52250. -`-msoft-float'
  52251. -     Generate output containing library calls for floating point.
  52252. -     *Warning:* the requisite libraries are not available for all m68k
  52253. -     targets.  Normally the facilities of the machine's usual C
  52254. -     compiler are used, but this can't be done directly in
  52255. -     cross-compilation.  You must make your own arrangements to provide
  52256. -     suitable library functions for cross-compilation.  The embedded
  52257. -     targets `m68k-*-aout' and `m68k-*-coff' do provide software
  52258. -     floating point support.
  52259. -
  52260. -`-mshort'
  52261. -     Consider type `int' to be 16 bits wide, like `short int'.
  52262. -
  52263. -`-mnobitfield'
  52264. -     Do not use the bit-field instructions.  The `-m68000' option
  52265. -     implies `-mnobitfield'.
  52266. -
  52267. -`-mbitfield'
  52268. -     Do use the bit-field instructions.  The `-m68020' option implies
  52269. -     `-mbitfield'.  This is the default if you use a configuration
  52270. -     designed for a 68020.
  52271. -
  52272. -`-mrtd'
  52273. -     Use a different function-calling convention, in which functions
  52274. -     that take a fixed number of arguments return with the `rtd'
  52275. -     instruction, which pops their arguments while returning.  This
  52276. -     saves one instruction in the caller since there is no need to pop
  52277. -     the arguments there.
  52278. -
  52279. -     This calling convention is incompatible with the one normally used
  52280. -     on Unix, so you cannot use it if you need to call libraries
  52281. -     compiled with the Unix compiler.
  52282. -
  52283. -     Also, you must provide function prototypes for all functions that
  52284. -     take variable numbers of arguments (including `printf'); otherwise
  52285. -     incorrect code will be generated for calls to those functions.
  52286. -
  52287. -     In addition, seriously incorrect code will result if you call a
  52288. -     function with too many arguments.  (Normally, extra arguments are
  52289. -     harmlessly ignored.)
  52290. -
  52291. -     The `rtd' instruction is supported by the 68010 and 68020
  52292. -     processors, but not by the 68000.
  52293. -
  52294. -
  52295. -File: gcc.info,  Node: VAX Options,  Next: SPARC Options,  Prev: M680x0 Options,  Up: Submodel Options
  52296. -
  52297. -VAX Options
  52298. ------------
  52299. -
  52300. -   These `-m' options are defined for the Vax:
  52301. -
  52302. -`-munix'
  52303. -     Do not output certain jump instructions (`aobleq' and so on) that
  52304. -     the Unix assembler for the Vax cannot handle across long ranges.
  52305. -
  52306. -`-mgnu'
  52307. -     Do output those jump instructions, on the assumption that you will
  52308. -     assemble with the GNU assembler.
  52309. -
  52310. -`-mg'
  52311. -     Output code for g-format floating point numbers instead of
  52312. -     d-format.
  52313. -
  52314. -
  52315. -File: gcc.info,  Node: SPARC Options,  Next: Convex Options,  Prev: VAX Options,  Up: Submodel Options
  52316. -
  52317. -SPARC Options
  52318. --------------
  52319. -
  52320. -   These `-m' switches are supported on the SPARC:
  52321. -
  52322. -`-mno-app-regs'
  52323. -`-mapp-regs'
  52324. -     Specify `-mapp-regs' to generate output using the global registers
  52325. -     2 through 4, which the SPARC SVR4 ABI reserves for applications.
  52326. -     This is the default.
  52327. -
  52328. -     To be fully SVR4 ABI compliant at the cost of some performance
  52329. -     loss, specify `-mno-app-regs'.  You should compile libraries and
  52330. -     system software with this option.
  52331. -
  52332. -`-mfpu'
  52333. -`-mhard-float'
  52334. -     Generate output containing floating point instructions.  This is
  52335. -     the default.
  52336. -
  52337. -`-mno-fpu'
  52338. -`-msoft-float'
  52339. -     Generate output containing library calls for floating point.
  52340. -     *Warning:* the requisite libraries are not available for all SPARC
  52341. -     targets.  Normally the facilities of the machine's usual C
  52342. -     compiler are used, but this cannot be done directly in
  52343. -     cross-compilation.  You must make your own arrangements to provide
  52344. -     suitable library functions for cross-compilation.  The embedded
  52345. -     targets `sparc-*-aout' and `sparclite-*-*' do provide software
  52346. -     floating point support.
  52347. -
  52348. -     `-msoft-float' changes the calling convention in the output file;
  52349. -     therefore, it is only useful if you compile *all* of a program with
  52350. -     this option.  In particular, you need to compile `libgcc.a', the
  52351. -     library that comes with GNU CC, with `-msoft-float' in order for
  52352. -     this to work.
  52353. -
  52354. -`-mhard-quad-float'
  52355. -     Generate output containing quad-word (long double) floating point
  52356. -     instructions.
  52357. -
  52358. -`-msoft-quad-float'
  52359. -     Generate output containing library calls for quad-word (long
  52360. -     double) floating point instructions.  The functions called are
  52361. -     those specified in the SPARC ABI.  This is the default.
  52362. -
  52363. -     As of this writing, there are no sparc implementations that have
  52364. -     hardware support for the quad-word floating point instructions.
  52365. -     They all invoke a trap handler for one of these instructions, and
  52366. -     then the trap handler emulates the effect of the instruction.
  52367. -     Because of the trap handler overhead, this is much slower than
  52368. -     calling the ABI library routines.  Thus the `-msoft-quad-float'
  52369. -     option is the default.
  52370. -
  52371. -`-mno-epilogue'
  52372. -`-mepilogue'
  52373. -     With `-mepilogue' (the default), the compiler always emits code for
  52374. -     function exit at the end of each function.  Any function exit in
  52375. -     the middle of the function (such as a return statement in C) will
  52376. -     generate a jump to the exit code at the end of the function.
  52377. -
  52378. -     With `-mno-epilogue', the compiler tries to emit exit code inline
  52379. -     at every function exit.
  52380. -
  52381. -`-mno-flat'
  52382. -`-mflat'
  52383. -     With `-mflat', the compiler does not generate save/restore
  52384. -     instructions and will use a "flat" or single register window
  52385. -     calling convention.  This model uses %i7 as the frame pointer and
  52386. -     is compatible with the normal register window model.  Code from
  52387. -     either may be intermixed although debugger support is still
  52388. -     incomplete.  The local registers and the input registers (0-5) are
  52389. -     still treated as "call saved" registers and will be saved on the
  52390. -     stack as necessary.
  52391. -
  52392. -     With `-mno-flat' (the default), the compiler emits save/restore
  52393. -     instructions (except for leaf functions) and is the normal mode of
  52394. -     operation.
  52395. -
  52396. -`-mno-unaligned-doubles'
  52397. -`-munaligned-doubles'
  52398. -     Assume that doubles have 8 byte alignment.  This is the default.
  52399. -
  52400. -     With `-munaligned-doubles', GNU CC assumes that doubles have 8 byte
  52401. -     alignment only if they are contained in another type, or if they
  52402. -     have an absolute address.  Otherwise, it assumes they have 4 byte
  52403. -     alignment.  Specifying this option avoids some rare compatibility
  52404. -     problems with code generated by other compilers.  It is not the
  52405. -     default because it results in a performance loss, especially for
  52406. -     floating point code.
  52407. -
  52408. -`-mv8'
  52409. -`-msparclite'
  52410. -     These two options select variations on the SPARC architecture.
  52411. -
  52412. -     By default (unless specifically configured for the Fujitsu
  52413. -     SPARClite), GCC generates code for the v7 variant of the SPARC
  52414. -     architecture.
  52415. -
  52416. -     `-mv8' will give you SPARC v8 code.  The only difference from v7
  52417. -     code is that the compiler emits the integer multiply and integer
  52418. -     divide instructions which exist in SPARC v8 but not in SPARC v7.
  52419. -
  52420. -     `-msparclite' will give you SPARClite code.  This adds the integer
  52421. -     multiply, integer divide step and scan (`ffs') instructions which
  52422. -     exist in SPARClite but not in SPARC v7.
  52423. -
  52424. -`-mcypress'
  52425. -`-msupersparc'
  52426. -     These two options select the processor for which the code is
  52427. -     optimised.
  52428. -
  52429. -     With `-mcypress' (the default), the compiler optimizes code for the
  52430. -     Cypress CY7C602 chip, as used in the SparcStation/SparcServer 3xx
  52431. -     series.  This is also appropriate for the older SparcStation 1, 2,
  52432. -     IPX etc.
  52433. -
  52434. -     With `-msupersparc' the compiler optimizes code for the SuperSparc
  52435. -     cpu, as used in the SparcStation 10, 1000 and 2000 series. This
  52436. -     flag also enables use of the full SPARC v8 instruction set.
  52437. -
  52438. -   In a future version of GCC, these options will very likely be
  52439. -renamed to `-mcpu=cypress' and `-mcpu=supersparc'.
  52440. -
  52441. -   These `-m' switches are supported in addition to the above on SPARC
  52442. -V9 processors:
  52443. -
  52444. -`-mmedlow'
  52445. -     Generate code for the Medium/Low code model: assume a 32 bit
  52446. -     address space.  Programs are statically linked, PIC is not
  52447. -     supported.  Pointers are still 64 bits.
  52448. -
  52449. -     It is very likely that a future version of GCC will rename this
  52450. -     option.
  52451. -
  52452. -`-mmedany'
  52453. -     Generate code for the Medium/Anywhere code model: assume a 32 bit
  52454. -     text segment starting at offset 0, and a 32 bit data segment
  52455. -     starting anywhere (determined at link time).  Programs are
  52456. -     statically linked, PIC is not supported.  Pointers are still 64
  52457. -     bits.
  52458. -
  52459. -     It is very likely that a future version of GCC will rename this
  52460. -     option.
  52461. -
  52462. -`-mint64'
  52463. -     Types long and int are 64 bits.
  52464. -
  52465. -`-mlong32'
  52466. -     Types long and int are 32 bits.
  52467. -
  52468. -`-mlong64'
  52469. -`-mint32'
  52470. -     Type long is 64 bits, and type int is 32 bits.
  52471. -
  52472. -`-mstack-bias'
  52473. -`-mno-stack-bias'
  52474. -     With `-mstack-bias', GNU CC assumes that the stack pointer, and
  52475. -     frame pointer if present, are offset by -2047 which must be added
  52476. -     back when making stack frame references.  Otherwise, assume no
  52477. -     such offset is present.
  52478. -
  52479. -
  52480. -File: gcc.info,  Node: Convex Options,  Next: AMD29K Options,  Prev: SPARC Options,  Up: Submodel Options
  52481. -
  52482. -Convex Options
  52483. ---------------
  52484. -
  52485. -   These `-m' options are defined for Convex:
  52486. -
  52487. -`-mc1'
  52488. -     Generate output for C1.  The code will run on any Convex machine.
  52489. -     The preprocessor symbol `__convex__c1__' is defined.
  52490. -
  52491. -`-mc2'
  52492. -     Generate output for C2.  Uses instructions not available on C1.
  52493. -     Scheduling and other optimizations are chosen for max performance
  52494. -     on C2.  The preprocessor symbol `__convex_c2__' is defined.
  52495. -
  52496. -`-mc32'
  52497. -     Generate output for C32xx.  Uses instructions not available on C1.
  52498. -     Scheduling and other optimizations are chosen for max performance
  52499. -     on C32.  The preprocessor symbol `__convex_c32__' is defined.
  52500. -
  52501. -`-mc34'
  52502. -     Generate output for C34xx.  Uses instructions not available on C1.
  52503. -     Scheduling and other optimizations are chosen for max performance
  52504. -     on C34.  The preprocessor symbol `__convex_c34__' is defined.
  52505. -
  52506. -`-mc38'
  52507. -     Generate output for C38xx.  Uses instructions not available on C1.
  52508. -     Scheduling and other optimizations are chosen for max performance
  52509. -     on C38.  The preprocessor symbol `__convex_c38__' is defined.
  52510. -
  52511. -`-margcount'
  52512. -     Generate code which puts an argument count in the word preceding
  52513. -     each argument list.  This is compatible with regular CC, and a few
  52514. -     programs may need the argument count word.  GDB and other
  52515. -     source-level debuggers do not need it; this info is in the symbol
  52516. -     table.
  52517. -
  52518. -`-mnoargcount'
  52519. -     Omit the argument count word.  This is the default.
  52520. -
  52521. -`-mvolatile-cache'
  52522. -     Allow volatile references to be cached.  This is the default.
  52523. -
  52524. -`-mvolatile-nocache'
  52525. -     Volatile references bypass the data cache, going all the way to
  52526. -     memory.  This is only needed for multi-processor code that does
  52527. -     not use standard synchronization instructions.  Making
  52528. -     non-volatile references to volatile locations will not necessarily
  52529. -     work.
  52530. -
  52531. -`-mlong32'
  52532. -     Type long is 32 bits, the same as type int.  This is the default.
  52533. -
  52534. -`-mlong64'
  52535. -     Type long is 64 bits, the same as type long long.  This option is
  52536. -     useless, because no library support exists for it.
  52537. -
  52538. -
  52539. -File: gcc.info,  Node: AMD29K Options,  Next: ARM Options,  Prev: Convex Options,  Up: Submodel Options
  52540. -
  52541. -AMD29K Options
  52542. ---------------
  52543. -
  52544. -   These `-m' options are defined for the AMD Am29000:
  52545. -
  52546. -`-mdw'
  52547. -     Generate code that assumes the `DW' bit is set, i.e., that byte and
  52548. -     halfword operations are directly supported by the hardware.  This
  52549. -     is the default.
  52550. -
  52551. -`-mndw'
  52552. -     Generate code that assumes the `DW' bit is not set.
  52553. -
  52554. -`-mbw'
  52555. -     Generate code that assumes the system supports byte and halfword
  52556. -     write operations.  This is the default.
  52557. -
  52558. -`-mnbw'
  52559. -     Generate code that assumes the systems does not support byte and
  52560. -     halfword write operations.  `-mnbw' implies `-mndw'.
  52561. -
  52562. -`-msmall'
  52563. -     Use a small memory model that assumes that all function addresses
  52564. -     are either within a single 256 KB segment or at an absolute
  52565. -     address of less than 256k.  This allows the `call' instruction to
  52566. -     be used instead of a `const', `consth', `calli' sequence.
  52567. -
  52568. -`-mnormal'
  52569. -     Use the normal memory model: Generate `call' instructions only when
  52570. -     calling functions in the same file and `calli' instructions
  52571. -     otherwise.  This works if each file occupies less than 256 KB but
  52572. -     allows the entire executable to be larger than 256 KB.  This is
  52573. -     the default.
  52574. -
  52575. -`-mlarge'
  52576. -     Always use `calli' instructions.  Specify this option if you expect
  52577. -     a single file to compile into more than 256 KB of code.
  52578. -
  52579. -`-m29050'
  52580. -     Generate code for the Am29050.
  52581. -
  52582. -`-m29000'
  52583. -     Generate code for the Am29000.  This is the default.
  52584. -
  52585. -`-mkernel-registers'
  52586. -     Generate references to registers `gr64-gr95' instead of to
  52587. -     registers `gr96-gr127'.  This option can be used when compiling
  52588. -     kernel code that wants a set of global registers disjoint from
  52589. -     that used by user-mode code.
  52590. -
  52591. -     Note that when this option is used, register names in `-f' flags
  52592. -     must use the normal, user-mode, names.
  52593. -
  52594. -`-muser-registers'
  52595. -     Use the normal set of global registers, `gr96-gr127'.  This is the
  52596. -     default.
  52597. -
  52598. -`-mstack-check'
  52599. -`-mno-stack-check'
  52600. -     Insert (or do not insert) a call to `__msp_check' after each stack
  52601. -     adjustment.  This is often used for kernel code.
  52602. -
  52603. -`-mstorem-bug'
  52604. -`-mno-storem-bug'
  52605. -     `-mstorem-bug' handles 29k processors which cannot handle the
  52606. -     separation of a mtsrim insn and a storem instruction (most 29000
  52607. -     chips to date, but not the 29050).
  52608. -
  52609. -`-mno-reuse-arg-regs'
  52610. -`-mreuse-arg-regs'
  52611. -     `-mno-reuse-arg-regs' tells the compiler to only use incoming
  52612. -     argument registers for copying out arguments.  This helps detect
  52613. -     calling a function with fewer arguments than it was declared with.
  52614. -
  52615. -`-msoft-float'
  52616. -     Generate output containing library calls for floating point.
  52617. -     *Warning:* the requisite libraries are not part of GNU CC.
  52618. -     Normally the facilities of the machine's usual C compiler are
  52619. -     used, but this can't be done directly in cross-compilation.  You
  52620. -     must make your own arrangements to provide suitable library
  52621. -     functions for cross-compilation.
  52622. -
  52623. -
  52624. -File: gcc.info,  Node: ARM Options,  Next: M88K Options,  Prev: AMD29K Options,  Up: Submodel Options
  52625. -
  52626. -ARM Options
  52627. ------------
  52628. -
  52629. -   These `-m' options are defined for Advanced RISC Machines (ARM)
  52630. -architectures:
  52631. -
  52632. -`-m2'
  52633. -`-m3'
  52634. -     These options are identical.  Generate code for the ARM2 and ARM3
  52635. -     processors.  This option is the default.  You should also use this
  52636. -     option to generate code for ARM6 processors that are running with a
  52637. -     26-bit program counter.
  52638. -
  52639. -`-m6'
  52640. -     Generate code for the ARM6 processor when running with a 32-bit
  52641. -     program counter.
  52642. -
  52643. -`-mapcs'
  52644. -     Generate a stack frame that is compliant with the ARM Procedure
  52645. -     Call Standard for all functions, even if this is not strictly
  52646. -     necessary for correct execution of the code.
  52647. -
  52648. -`-mbsd'
  52649. -     This option only applies to RISC iX.  Emulate the native BSD-mode
  52650. -     compiler.  This is the default if `-ansi' is not specified.
  52651. -
  52652. -`-mxopen'
  52653. -     This option only applies to RISC iX.  Emulate the native
  52654. -     X/Open-mode compiler.
  52655. -
  52656. -`-mno-symrename'
  52657. -     This option only applies to RISC iX.  Do not run the assembler
  52658. -     post-processor, `symrename', after code has been assembled.
  52659. -     Normally it is necessary to modify some of the standard symbols in
  52660. -     preparation for linking with the RISC iX C library; this option
  52661. -     suppresses this pass.  The post-processor is never run when the
  52662. -     compiler is built for cross-compilation.
  52663. -
  52664. -
  52665. -File: gcc.info,  Node: M88K Options,  Next: RS/6000 and PowerPC Options,  Prev: ARM Options,  Up: Submodel Options
  52666. -
  52667. -M88K Options
  52668. -------------
  52669. -
  52670. -   These `-m' options are defined for Motorola 88k architectures:
  52671. -
  52672. -`-m88000'
  52673. -     Generate code that works well on both the m88100 and the m88110.
  52674. -
  52675. -`-m88100'
  52676. -     Generate code that works best for the m88100, but that also runs
  52677. -     on the m88110.
  52678. -
  52679. -`-m88110'
  52680. -     Generate code that works best for the m88110, and may not run on
  52681. -     the m88100.
  52682. -
  52683. -`-mbig-pic'
  52684. -     Obsolete option to be removed from the next revision.  Use `-fPIC'.
  52685. -
  52686. -`-midentify-revision'
  52687. -     Include an `ident' directive in the assembler output recording the
  52688. -     source file name, compiler name and version, timestamp, and
  52689. -     compilation flags used.
  52690. -
  52691. -`-mno-underscores'
  52692. -     In assembler output, emit symbol names without adding an underscore
  52693. -     character at the beginning of each name.  The default is to use an
  52694. -     underscore as prefix on each name.
  52695. -
  52696. -`-mocs-debug-info'
  52697. -`-mno-ocs-debug-info'
  52698. -     Include (or omit) additional debugging information (about
  52699. -     registers used in each stack frame) as specified in the 88open
  52700. -     Object Compatibility Standard, "OCS".  This extra information
  52701. -     allows debugging of code that has had the frame pointer
  52702. -     eliminated.  The default for DG/UX, SVr4, and Delta 88 SVr3.2 is
  52703. -     to include this information; other 88k configurations omit this
  52704. -     information by default.
  52705. -
  52706. -`-mocs-frame-position'
  52707. -     When emitting COFF debugging information for automatic variables
  52708. -     and parameters stored on the stack, use the offset from the
  52709. -     canonical frame address, which is the stack pointer (register 31)
  52710. -     on entry to the function.  The DG/UX, SVr4, Delta88 SVr3.2, and
  52711. -     BCS configurations use `-mocs-frame-position'; other 88k
  52712. -     configurations have the default `-mno-ocs-frame-position'.
  52713. -
  52714. -`-mno-ocs-frame-position'
  52715. -     When emitting COFF debugging information for automatic variables
  52716. -     and parameters stored on the stack, use the offset from the frame
  52717. -     pointer register (register 30).  When this option is in effect,
  52718. -     the frame pointer is not eliminated when debugging information is
  52719. -     selected by the -g switch.
  52720. -
  52721. -`-moptimize-arg-area'
  52722. -`-mno-optimize-arg-area'
  52723. -     Control how function arguments are stored in stack frames.
  52724. -     `-moptimize-arg-area' saves space by optimizing them, but this
  52725. -     conflicts with the 88open specifications.  The opposite
  52726. -     alternative, `-mno-optimize-arg-area', agrees with 88open
  52727. -     standards.  By default GNU CC does not optimize the argument area.
  52728. -
  52729. -`-mshort-data-NUM'
  52730. -     Generate smaller data references by making them relative to `r0',
  52731. -     which allows loading a value using a single instruction (rather
  52732. -     than the usual two).  You control which data references are
  52733. -     affected by specifying NUM with this option.  For example, if you
  52734. -     specify `-mshort-data-512', then the data references affected are
  52735. -     those involving displacements of less than 512 bytes.
  52736. -     `-mshort-data-NUM' is not effective for NUM greater than 64k.
  52737. -
  52738. -`-mserialize-volatile'
  52739. -`-mno-serialize-volatile'
  52740. -     Do, or don't, generate code to guarantee sequential consistency of
  52741. -     volatile memory references.  By default, consistency is guaranteed.
  52742. -
  52743. -     The order of memory references made by the MC88110 processor does
  52744. -     not always match the order of the instructions requesting those
  52745. -     references.  In particular, a load instruction may execute before
  52746. -     a preceding store instruction.  Such reordering violates
  52747. -     sequential consistency of volatile memory references, when there
  52748. -     are multiple processors.   When consistency must be guaranteed,
  52749. -     GNU C generates special instructions, as needed, to force
  52750. -     execution in the proper order.
  52751. -
  52752. -     The MC88100 processor does not reorder memory references and so
  52753. -     always provides sequential consistency.  However, by default, GNU
  52754. -     C generates the special instructions to guarantee consistency even
  52755. -     when you use `-m88100', so that the code may be run on an MC88110
  52756. -     processor.  If you intend to run your code only on the MC88100
  52757. -     processor, you may use `-mno-serialize-volatile'.
  52758. -
  52759. -     The extra code generated to guarantee consistency may affect the
  52760. -     performance of your application.  If you know that you can safely
  52761. -     forgo this guarantee, you may use `-mno-serialize-volatile'.
  52762. -
  52763. -`-msvr4'
  52764. -`-msvr3'
  52765. -     Turn on (`-msvr4') or off (`-msvr3') compiler extensions related
  52766. -     to System V release 4 (SVr4).  This controls the following:
  52767. -
  52768. -       1. Which variant of the assembler syntax to emit.
  52769. -
  52770. -       2. `-msvr4' makes the C preprocessor recognize `#pragma weak'
  52771. -          that is used on System V release 4.
  52772. -
  52773. -       3. `-msvr4' makes GNU CC issue additional declaration directives
  52774. -          used in SVr4.
  52775. -
  52776. -     `-msvr4' is the default for the m88k-motorola-sysv4 and
  52777. -     m88k-dg-dgux m88k configurations. `-msvr3' is the default for all
  52778. -     other m88k configurations.
  52779. -
  52780. -`-mversion-03.00'
  52781. -     This option is obsolete, and is ignored.
  52782. -
  52783. -`-mno-check-zero-division'
  52784. -`-mcheck-zero-division'
  52785. -     Do, or don't, generate code to guarantee that integer division by
  52786. -     zero will be detected.  By default, detection is guaranteed.
  52787. -
  52788. -     Some models of the MC88100 processor fail to trap upon integer
  52789. -     division by zero under certain conditions.  By default, when
  52790. -     compiling code that might be run on such a processor, GNU C
  52791. -     generates code that explicitly checks for zero-valued divisors and
  52792. -     traps with exception number 503 when one is detected.  Use of
  52793. -     mno-check-zero-division suppresses such checking for code
  52794. -     generated to run on an MC88100 processor.
  52795. -
  52796. -     GNU C assumes that the MC88110 processor correctly detects all
  52797. -     instances of integer division by zero.  When `-m88110' is
  52798. -     specified, both `-mcheck-zero-division' and
  52799. -     `-mno-check-zero-division' are ignored, and no explicit checks for
  52800. -     zero-valued divisors are generated.
  52801. -
  52802. -`-muse-div-instruction'
  52803. -     Use the div instruction for signed integer division on the MC88100
  52804. -     processor.  By default, the div instruction is not used.
  52805. -
  52806. -     On the MC88100 processor the signed integer division instruction
  52807. -     div) traps to the operating system on a negative operand.  The
  52808. -     operating system transparently completes the operation, but at a
  52809. -     large cost in execution time.  By default, when compiling code
  52810. -     that might be run on an MC88100 processor, GNU C emulates signed
  52811. -     integer division using the unsigned integer division instruction
  52812. -     divu), thereby avoiding the large penalty of a trap to the
  52813. -     operating system.  Such emulation has its own, smaller, execution
  52814. -     cost in both time and space.  To the extent that your code's
  52815. -     important signed integer division operations are performed on two
  52816. -     nonnegative operands, it may be desirable to use the div
  52817. -     instruction directly.
  52818. -
  52819. -     On the MC88110 processor the div instruction (also known as the
  52820. -     divs instruction) processes negative operands without trapping to
  52821. -     the operating system.  When `-m88110' is specified,
  52822. -     `-muse-div-instruction' is ignored, and the div instruction is used
  52823. -     for signed integer division.
  52824. -
  52825. -     Note that the result of dividing INT_MIN by -1 is undefined.  In
  52826. -     particular, the behavior of such a division with and without
  52827. -     `-muse-div-instruction'  may differ.
  52828. -
  52829. -`-mtrap-large-shift'
  52830. -`-mhandle-large-shift'
  52831. -     Include code to detect bit-shifts of more than 31 bits;
  52832. -     respectively, trap such shifts or emit code to handle them
  52833. -     properly.  By default GNU CC makes no special provision for large
  52834. -     bit shifts.
  52835. -
  52836. -`-mwarn-passed-structs'
  52837. -     Warn when a function passes a struct as an argument or result.
  52838. -     Structure-passing conventions have changed during the evolution of
  52839. -     the C language, and are often the source of portability problems.
  52840. -     By default, GNU CC issues no such warning.
  52841. -
  52842. -
  52843. -File: gcc.info,  Node: RS/6000 and PowerPC Options,  Next: RT Options,  Prev: M88K Options,  Up: Submodel Options
  52844. -
  52845. -IBM RS/6000 and PowerPC Options
  52846. --------------------------------
  52847. -
  52848. -   These `-m' options are defined for the IBM RS/6000 and PowerPC:
  52849. -`-mpower'
  52850. -`-mno-power'
  52851. -`-mpower2'
  52852. -`-mno-power2'
  52853. -`-mpowerpc'
  52854. -`-mno-powerpc'
  52855. -`-mpowerpc-gpopt'
  52856. -`-mno-powerpc-gpopt'
  52857. -`-mpowerpc-gfxopt'
  52858. -`-mno-powerpc-gfxopt'
  52859. -     GNU CC supports two related instruction set architectures for the
  52860. -     RS/6000 and PowerPC.  The "POWER" instruction set are those
  52861. -     instructions supported by the `rios' chip set used in the original
  52862. -     RS/6000 systems and the "PowerPC" instruction set is the
  52863. -     architecture of the Motorola MPC6xx microprocessors.  The PowerPC
  52864. -     architecture defines 64-bit instructions, but they are not
  52865. -     supported by any current processors.
  52866. -
  52867. -     Neither architecture is a subset of the other.  However there is a
  52868. -     large common subset of instructions supported by both.  An MQ
  52869. -     register is included in processors supporting the POWER
  52870. -     architecture.
  52871. -
  52872. -     You use these options to specify which instructions are available
  52873. -     on the processor you are using.  The default value of these
  52874. -     options is determined when configuring GNU CC.  Specifying the
  52875. -     `-mcpu=CPU_TYPE' overrides the specification of these options.  We
  52876. -     recommend you use that option rather than these.
  52877. -
  52878. -     The `-mpower' option allows GNU CC to generate instructions that
  52879. -     are found only in the POWER architecture and to use the MQ
  52880. -     register.  Specifying `-mpower2' implies `-power' and also allows
  52881. -     GNU CC to generate instructions that are present in the POWER2
  52882. -     architecture but not the original POWER architecture.
  52883. -
  52884. -     The `-mpowerpc' option allows GNU CC to generate instructions that
  52885. -     are found only in the 32-bit subset of the PowerPC architecture.
  52886. -     Specifying `-mpowerpc-gpopt' implies `-mpowerpc' and also allows
  52887. -     GNU CC to use the optional PowerPC architecture instructions in the
  52888. -     General Purpose group, including floating-point square root.
  52889. -     Specifying `-mpowerpc-gfxopt' implies `-mpowerpc' and also allows
  52890. -     GNU CC to use the optional PowerPC architecture instructions in
  52891. -     the Graphics group, including floating-point select.
  52892. -
  52893. -     If you specify both `-mno-power' and `-mno-powerpc', GNU CC will
  52894. -     use only the instructions in the common subset of both
  52895. -     architectures plus some special AIX common-mode calls, and will
  52896. -     not use the MQ register.  Specifying both `-mpower' and `-mpowerpc'
  52897. -     permits GNU CC to use any instruction from either architecture and
  52898. -     to allow use of the MQ register; specify this for the Motorola
  52899. -     MPC601.
  52900. -
  52901. -`-mnew-mnemonics'
  52902. -`-mold-mnemonics'
  52903. -     Select which mnemonics to use in the generated assembler code.
  52904. -     `-mnew-mnemonics' requests output that uses the assembler mnemonics
  52905. -     defined for the PowerPC architecture, while `-mold-mnemonics'
  52906. -     requests the assembler mnemonics defined for the POWER
  52907. -     architecture.  Instructions defined in only one architecture have
  52908. -     only one mnemonic; GNU CC uses that mnemonic irrespective of which
  52909. -     of these options is specified.
  52910. -
  52911. -     PowerPC assemblers support both the old and new mnemonics, as will
  52912. -     later POWER assemblers.  Current POWER assemblers only support the
  52913. -     old mnemonics.  Specify `-mnew-mnemonics' if you have an assembler
  52914. -     that supports them, otherwise specify `-mold-mnemonics'.
  52915. -
  52916. -     The default value of these options depends on how GNU CC was
  52917. -     configured.  Specifying `-mcpu=CPU_TYPE' sometimes overrides the
  52918. -     value of these option.  Unless you are building a cross-compiler,
  52919. -     you should normally not specify either `-mnew-mnemonics' or
  52920. -     `-mold-mnemonics', but should instead accept the default.
  52921. -
  52922. -`-mcpu=CPU_TYPE'
  52923. -     Set architecture type, register usage, choice of mnemonics, and
  52924. -     instruction scheduling parameters for machine type CPU_TYPE.  By
  52925. -     default, CPU_TYPE is the target system defined when GNU CC was
  52926. -     configured.  Supported values for CPU_TYPE are `rios1', `rios2',
  52927. -     `rsc', `601', `603', `604', `power', `powerpc', `403', and
  52928. -     `common'.  `-mcpu=power' and `-mcpu=powerpc' specify generic POWER
  52929. -     and pure PowerPC (i.e., not MPC601) architecture machine types,
  52930. -     with an appropriate, generic processor model assumed for
  52931. -     scheduling purposes.
  52932. -
  52933. -     Specifying `-mcpu=rios1', `-mcpu=rios2', `-mcpu=rsc', or
  52934. -     `-mcpu=power' enables the `-mpower' option and disables the
  52935. -     `-mpowerpc' option; `-mcpu=601' enables both the `-mpower' and
  52936. -     `-mpowerpc' options; `-mcpu=603', `-mcpu=604', `-mcpu=403', and
  52937. -     `-mcpu=powerpc' enable the `-mpowerpc' option and disable the
  52938. -     `-mpower' option; `-mcpu=common' disables both the `-mpower' and
  52939. -     `-mpowerpc' options.
  52940. -
  52941. -     To generate code that will operate on all members of the RS/6000
  52942. -     and PowerPC families, specify `-mcpu=common'.  In that case, GNU CC
  52943. -     will use only the instructions in the common subset of both
  52944. -     architectures plus some special AIX common-mode calls, and will
  52945. -     not use the MQ register.  GNU CC assumes a generic processor model
  52946. -     for scheduling purposes.
  52947. -
  52948. -     Specifying `-mcpu=rios1', `-mcpu=rios2', `-mcpu=rsc', or
  52949. -     `-mcpu=power' also disables the `new-mnemonics' option.
  52950. -     Specifying `-mcpu=601', `-mcpu=603', `-mcpu=604', `403', or
  52951. -     `-mcpu=powerpc' also enables the `new-mnemonics' option.
  52952. -
  52953. -`-mfull-toc'
  52954. -`-mno-fp-in-toc'
  52955. -`-mno-sum-in-toc'
  52956. -`-mminimal-toc'
  52957. -     Modify generation of the TOC (Table Of Contents), which is created
  52958. -     for every executable file.  The `-mfull-toc' option is selected by
  52959. -     default.  In that case, GNU CC will allocate at least one TOC
  52960. -     entry for each unique non-automatic variable reference in your
  52961. -     program.  GNU CC will also place floating-point constants in the
  52962. -     TOC.  However, only 16,384 entries are available in the TOC.
  52963. -
  52964. -     If you receive a linker error message that saying you have
  52965. -     overflowed the available TOC space, you can reduce the amount of
  52966. -     TOC space used with the `-mno-fp-in-toc' and `-mno-sum-in-toc'
  52967. -     options.  `-mno-fp-in-toc' prevents GNU CC from putting
  52968. -     floating-point constants in the TOC and `-mno-sum-in-toc' forces
  52969. -     GNU CC to generate code to calculate the sum of an address and a
  52970. -     constant at run-time instead of putting that sum into the TOC.
  52971. -     You may specify one or both of these options.  Each causes GNU CC
  52972. -     to produce very slightly slower and larger code at the expense of
  52973. -     conserving TOC space.
  52974. -
  52975. -     If you still run out of space in the TOC even when you specify
  52976. -     both of these options, specify `-mminimal-toc' instead.  This
  52977. -     option causes GNU CC to make only one TOC entry for every file.
  52978. -     When you specify this option, GNU CC will produce code that is
  52979. -     slower and larger but which uses extremely little TOC space.  You
  52980. -     may wish to use this option only on files that contain less
  52981. -     frequently executed code.
  52982. -
  52983. -`-msoft-float'
  52984. -`-mhard-float'
  52985. -     Generate code that does not use (uses) the floating-point register
  52986. -     set.  Software floating point emulation is provided if you use the
  52987. -     `-msoft-float' option, and pass the option to GNU CC when linking.
  52988. -
  52989. -`-mmultiple'
  52990. -`-mno-multiple'
  52991. -     Generate code that uses (does not use) the load multiple word
  52992. -     instructions and the store multiple word instructions.  These
  52993. -     instructions are generated by default on POWER systems, and not
  52994. -     generated on PowerPC systems.  Do not use `-mmultiple' on little
  52995. -     endian PowerPC systems, since those instructions do not work when
  52996. -     the processor is in little endian mode.
  52997. -
  52998. -`-mstring'
  52999. -`-mno-string'
  53000. -     Generate code that uses (does not use) the load string
  53001. -     instructions and the store string word instructions to save
  53002. -     multiple registers and do small block moves.  These instructions
  53003. -     are generated by default on POWER systems, anod not generated on
  53004. -     PowerPC systems.  Do not use `-mstring' on little endian PowerPC
  53005. -     systems, since those instructions do not work when the processor
  53006. -     is in little endian mode.
  53007. -
  53008. -`-mno-bit-align'
  53009. -`-mbit-align'
  53010. -     On System V.4 and embedded PowerPC systems do not (do) force
  53011. -     structures and unions that contain bit fields to be aligned to the
  53012. -     base type of the bit field.
  53013. -
  53014. -     For example, by default a structure containing nothing but 8
  53015. -     `unsigned' bitfields of length 1 would be aligned to a 4 byte
  53016. -     boundary and have a size of 4 bytes.  By using `-mno-bit-align',
  53017. -     the structure would be aligned to a 1 byte boundary and be one
  53018. -     byte in size.
  53019. -
  53020. -`-mno-strict-align'
  53021. -`-mstrict-align'
  53022. -     On System V.4 and embedded PowerPC systems do not (do) assume that
  53023. -     unaligned memory references will be handled by the system.
  53024. -
  53025. -`-mrelocatable'
  53026. -`-mno-relocatable'
  53027. -     On embedded PowerPC systems generate code that allows (does not
  53028. -     allow) the program to be relocated to a different address at
  53029. -     runtime.
  53030. -
  53031. -`-mno-toc'
  53032. -`-mtoc'
  53033. -     On System V.4 and embedded PowerPC systems do not (do) assume that
  53034. -     register 2 contains a pointer to a global area pointing to the
  53035. -     addresses used in the program.
  53036. -
  53037. -`-mno-traceback'
  53038. -`-mtraceback'
  53039. -     On embedded PowerPC systems do not (do) generate a traceback tag
  53040. -     before the start of the function.  This tag can be used by the
  53041. -     debugger to identify where the start of a function is.
  53042. -
  53043. -`-mlittle'
  53044. -`-mlittle-endian'
  53045. -     On System V.4 and embedded PowerPC systems compile code for the
  53046. -     processor in little endian mode.  The `-mlittle-endian' option is
  53047. -     the same as `-mlittle'.
  53048. -
  53049. -`-mbig'
  53050. -`-mbig-endian'
  53051. -     On System V.4 and embedded PowerPC systems compile code for the
  53052. -     processor in big endian mode.  The `-mbig-endian' option is the
  53053. -     same as `-mbig'.
  53054. -
  53055. -`-mcall-sysv'
  53056. -     On System V.4 and embedded PowerPC systems compile code using
  53057. -     calling conventions that adheres to the March 1995 draft of the
  53058. -     System V Application Binary Interface, PowerPC processor
  53059. -     supplement.  This is the default unless you configured GCC using
  53060. -     `powerpc-*-eabiaix'.
  53061. -
  53062. -`-mcall-aix'
  53063. -     On System V.4 and embedded PowerPC systems compile code using
  53064. -     calling conventions that are similar to those used on AIX.  This
  53065. -     is the default if you configured GCC using `powerpc-*-eabiaix'.
  53066. -
  53067. -`-mprototype'
  53068. -`-mno-prototype'
  53069. -     On System V.4 and embedded PowerPC systems assume that all calls to
  53070. -     variable argument functions are properly prototyped.  Otherwise,
  53071. -     the compiler must insert an instruction before every non
  53072. -     prototyped call to set or clear bit 6 of the condition code
  53073. -     register (CR) to indicate whether floating point values were
  53074. -     passed in the floating point registers in case the function takes
  53075. -     a variable arguments.  With `-mprototype', only calls to
  53076. -     prototyped variable argument functions will set or clear the bit.
  53077. -
  53078. -
  53079. -File: gcc.info,  Node: RT Options,  Next: MIPS Options,  Prev: RS/6000 and PowerPC Options,  Up: Submodel Options
  53080. -
  53081. -IBM RT Options
  53082. ---------------
  53083. -
  53084. -   These `-m' options are defined for the IBM RT PC:
  53085. -
  53086. -`-min-line-mul'
  53087. -     Use an in-line code sequence for integer multiplies.  This is the
  53088. -     default.
  53089. -
  53090. -`-mcall-lib-mul'
  53091. -     Call `lmul$$' for integer multiples.
  53092. -
  53093. -`-mfull-fp-blocks'
  53094. -     Generate full-size floating point data blocks, including the
  53095. -     minimum amount of scratch space recommended by IBM.  This is the
  53096. -     default.
  53097. -
  53098. -`-mminimum-fp-blocks'
  53099. -     Do not include extra scratch space in floating point data blocks.
  53100. -     This results in smaller code, but slower execution, since scratch
  53101. -     space must be allocated dynamically.
  53102. -
  53103. -`-mfp-arg-in-fpregs'
  53104. -     Use a calling sequence incompatible with the IBM calling
  53105. -     convention in which floating point arguments are passed in
  53106. -     floating point registers.  Note that `varargs.h' and `stdargs.h'
  53107. -     will not work with floating point operands if this option is
  53108. -     specified.
  53109. -
  53110. -`-mfp-arg-in-gregs'
  53111. -     Use the normal calling convention for floating point arguments.
  53112. -     This is the default.
  53113. -
  53114. -`-mhc-struct-return'
  53115. -     Return structures of more than one word in memory, rather than in a
  53116. -     register.  This provides compatibility with the MetaWare HighC (hc)
  53117. -     compiler.  Use the option `-fpcc-struct-return' for compatibility
  53118. -     with the Portable C Compiler (pcc).
  53119. -
  53120. -`-mnohc-struct-return'
  53121. -     Return some structures of more than one word in registers, when
  53122. -     convenient.  This is the default.  For compatibility with the
  53123. -     IBM-supplied compilers, use the option `-fpcc-struct-return' or the
  53124. -     option `-mhc-struct-return'.
  53125. -
  53126. diff -rup --new-file baseline/fsf/gcc/gcc.info-5 amiga/fsf/gcc/gcc.info-5
  53127. --- baseline/fsf/gcc/gcc.info-5    Sat Jun 29 09:37:58 1996
  53128. +++ amiga/fsf/gcc/gcc.info-5    Wed Dec 31 17:00:00 1969
  53129. @@ -1,1027 +0,0 @@
  53130. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  53131. -file gcc.texi.
  53132. -
  53133. -   This file documents the use and the internals of the GNU compiler.
  53134. -
  53135. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  53136. -Boston, MA 02111-1307 USA
  53137. -
  53138. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  53139. -Foundation, Inc.
  53140. -
  53141. -   Permission is granted to make and distribute verbatim copies of this
  53142. -manual provided the copyright notice and this permission notice are
  53143. -preserved on all copies.
  53144. -
  53145. -   Permission is granted to copy and distribute modified versions of
  53146. -this manual under the conditions for verbatim copying, provided also
  53147. -that the sections entitled "GNU General Public License," "Funding for
  53148. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  53149. -included exactly as in the original, and provided that the entire
  53150. -resulting derived work is distributed under the terms of a permission
  53151. -notice identical to this one.
  53152. -
  53153. -   Permission is granted to copy and distribute translations of this
  53154. -manual into another language, under the above conditions for modified
  53155. -versions, except that the sections entitled "GNU General Public
  53156. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  53157. -`Look And Feel'", and this permission notice, may be included in
  53158. -translations approved by the Free Software Foundation instead of in the
  53159. -original English.
  53160. -
  53161. -
  53162. -File: gcc.info,  Node: MIPS Options,  Next: i386 Options,  Prev: RT Options,  Up: Submodel Options
  53163. -
  53164. -MIPS Options
  53165. -------------
  53166. -
  53167. -   These `-m' options are defined for the MIPS family of computers:
  53168. -
  53169. -`-mcpu=CPU TYPE'
  53170. -     Assume the defaults for the machine type CPU TYPE when scheduling
  53171. -     instructions.  The choices for CPU TYPE are `r2000', `r3000',
  53172. -     `r4000', `r4400', `r4600', and `r6000'.  While picking a specific
  53173. -     CPU TYPE will schedule things appropriately for that particular
  53174. -     chip, the compiler will not generate any code that does not meet
  53175. -     level 1 of the MIPS ISA (instruction set architecture) without the
  53176. -     `-mips2' or `-mips3' switches being used.
  53177. -
  53178. -`-mips1'
  53179. -     Issue instructions from level 1 of the MIPS ISA.  This is the
  53180. -     default.  `r3000' is the default CPU TYPE at this ISA level.
  53181. -
  53182. -`-mips2'
  53183. -     Issue instructions from level 2 of the MIPS ISA (branch likely,
  53184. -     square root instructions).  `r6000' is the default CPU TYPE at this
  53185. -     ISA level.
  53186. -
  53187. -`-mips3'
  53188. -     Issue instructions from level 3 of the MIPS ISA (64 bit
  53189. -     instructions).  `r4000' is the default CPU TYPE at this ISA level.
  53190. -     This option does not change the sizes of any of the C data types.
  53191. -
  53192. -`-mfp32'
  53193. -     Assume that 32 32-bit floating point registers are available.
  53194. -     This is the default.
  53195. -
  53196. -`-mfp64'
  53197. -     Assume that 32 64-bit floating point registers are available.
  53198. -     This is the default when the `-mips3' option is used.
  53199. -
  53200. -`-mgp32'
  53201. -     Assume that 32 32-bit general purpose registers are available.
  53202. -     This is the default.
  53203. -
  53204. -`-mgp64'
  53205. -     Assume that 32 64-bit general purpose registers are available.
  53206. -     This is the default when the `-mips3' option is used.
  53207. -
  53208. -`-mint64'
  53209. -     Types long, int, and pointer are 64 bits.  This works only if
  53210. -     `-mips3' is also specified.
  53211. -
  53212. -`-mlong64'
  53213. -     Types long and pointer are 64 bits, and type int is 32 bits.  This
  53214. -     works only if `-mips3' is also specified.
  53215. -
  53216. -`-mmips-as'
  53217. -     Generate code for the MIPS assembler, and invoke `mips-tfile' to
  53218. -     add normal debug information.  This is the default for all
  53219. -     platforms except for the OSF/1 reference platform, using the
  53220. -     OSF/rose object format.  If the either of the `-gstabs' or
  53221. -     `-gstabs+' switches are used, the `mips-tfile' program will
  53222. -     encapsulate the stabs within MIPS ECOFF.
  53223. -
  53224. -`-mgas'
  53225. -     Generate code for the GNU assembler.  This is the default on the
  53226. -     OSF/1 reference platform, using the OSF/rose object format.
  53227. -
  53228. -`-mrnames'
  53229. -`-mno-rnames'
  53230. -     The `-mrnames' switch says to output code using the MIPS software
  53231. -     names for the registers, instead of the hardware names (ie, A0
  53232. -     instead of $4).  The only known assembler that supports this option
  53233. -     is the Algorithmics assembler.
  53234. -
  53235. -`-mgpopt'
  53236. -`-mno-gpopt'
  53237. -     The `-mgpopt' switch says to write all of the data declarations
  53238. -     before the instructions in the text section, this allows the MIPS
  53239. -     assembler to generate one word memory references instead of using
  53240. -     two words for short global or static data items.  This is on by
  53241. -     default if optimization is selected.
  53242. -
  53243. -`-mstats'
  53244. -`-mno-stats'
  53245. -     For each non-inline function processed, the `-mstats' switch
  53246. -     causes the compiler to emit one line to the standard error file to
  53247. -     print statistics about the program (number of registers saved,
  53248. -     stack size, etc.).
  53249. -
  53250. -`-mmemcpy'
  53251. -`-mno-memcpy'
  53252. -     The `-mmemcpy' switch makes all block moves call the appropriate
  53253. -     string function (`memcpy' or `bcopy') instead of possibly
  53254. -     generating inline code.
  53255. -
  53256. -`-mmips-tfile'
  53257. -`-mno-mips-tfile'
  53258. -     The `-mno-mips-tfile' switch causes the compiler not postprocess
  53259. -     the object file with the `mips-tfile' program, after the MIPS
  53260. -     assembler has generated it to add debug support.  If `mips-tfile'
  53261. -     is not run, then no local variables will be available to the
  53262. -     debugger.  In addition, `stage2' and `stage3' objects will have
  53263. -     the temporary file names passed to the assembler embedded in the
  53264. -     object file, which means the objects will not compare the same.
  53265. -     The `-mno-mips-tfile' switch should only be used when there are
  53266. -     bugs in the `mips-tfile' program that prevents compilation.
  53267. -
  53268. -`-msoft-float'
  53269. -     Generate output containing library calls for floating point.
  53270. -     *Warning:* the requisite libraries are not part of GNU CC.
  53271. -     Normally the facilities of the machine's usual C compiler are
  53272. -     used, but this can't be done directly in cross-compilation.  You
  53273. -     must make your own arrangements to provide suitable library
  53274. -     functions for cross-compilation.
  53275. -
  53276. -`-mhard-float'
  53277. -     Generate output containing floating point instructions.  This is
  53278. -     the default if you use the unmodified sources.
  53279. -
  53280. -`-mabicalls'
  53281. -`-mno-abicalls'
  53282. -     Emit (or do not emit) the pseudo operations `.abicalls',
  53283. -     `.cpload', and `.cprestore' that some System V.4 ports use for
  53284. -     position independent code.
  53285. -
  53286. -`-mlong-calls'
  53287. -`-mno-long-calls'
  53288. -     Do all calls with the `JALR' instruction, which requires loading
  53289. -     up a function's address into a register before the call.  You need
  53290. -     to use this switch, if you call outside of the current 512
  53291. -     megabyte segment to functions that are not through pointers.
  53292. -
  53293. -`-mhalf-pic'
  53294. -`-mno-half-pic'
  53295. -     Put pointers to extern references into the data section and load
  53296. -     them up, rather than put the references in the text section.
  53297. -
  53298. -`-membedded-pic'
  53299. -`-mno-embedded-pic'
  53300. -     Generate PIC code suitable for some embedded systems.  All calls
  53301. -     are made using PC relative address, and all data is addressed
  53302. -     using the $gp register.  This requires GNU as and GNU ld which do
  53303. -     most of the work.
  53304. -
  53305. -`-membedded-data'
  53306. -`-mno-embedded-data'
  53307. -     Allocate variables to the read-only data section first if
  53308. -     possible, then next in the small data section if possible,
  53309. -     otherwise in data.  This gives slightly slower code than the
  53310. -     default, but reduces the amount of RAM required when executing,
  53311. -     and thus may be preferred for some embedded systems.
  53312. -
  53313. -`-msingle-float'
  53314. -`-mdouble-float'
  53315. -     The `-msingle-float' switch tells gcc to assume that the floating
  53316. -     point coprocessor only supports single precision operations, as on
  53317. -     the `r4650' chip.  The `-mdouble-float' switch permits gcc to use
  53318. -     double precision operations.  This is the default.
  53319. -
  53320. -`-mmad'
  53321. -`-mno-mad'
  53322. -     Permit use of the `mad', `madu' and `mul' instructions, as on the
  53323. -     `r4650' chip.
  53324. -
  53325. -`-m4650'
  53326. -     Turns on `-msingle-float', `-mmad', and, at least for now,
  53327. -     `-mcpu=r4650'.
  53328. -
  53329. -`-EL'
  53330. -     Compile code for the processor in little endian mode.  The
  53331. -     requisite libraries are assumed to exist.
  53332. -
  53333. -`-EB'
  53334. -     Compile code for the processor in big endian mode.  The requisite
  53335. -     libraries are assumed to exist.
  53336. -
  53337. -`-G NUM'
  53338. -     Put global and static items less than or equal to NUM bytes into
  53339. -     the small data or bss sections instead of the normal data or bss
  53340. -     section.  This allows the assembler to emit one word memory
  53341. -     reference instructions based on the global pointer (GP or $28),
  53342. -     instead of the normal two words used.  By default, NUM is 8 when
  53343. -     the MIPS assembler is used, and 0 when the GNU assembler is used.
  53344. -     The `-G NUM' switch is also passed to the assembler and linker.
  53345. -     All modules should be compiled with the same `-G NUM' value.
  53346. -
  53347. -`-nocpp'
  53348. -     Tell the MIPS assembler to not run it's preprocessor over user
  53349. -     assembler files (with a `.s' suffix) when assembling them.
  53350. -
  53351. -   These options are defined by the macro `TARGET_SWITCHES' in the
  53352. -machine description.  The default for the options is also defined by
  53353. -that macro, which enables you to change the defaults.
  53354. -
  53355. -
  53356. -File: gcc.info,  Node: i386 Options,  Next: HPPA Options,  Prev: MIPS Options,  Up: Submodel Options
  53357. -
  53358. -Intel 386 Options
  53359. ------------------
  53360. -
  53361. -   These `-m' options are defined for the i386 family of computers:
  53362. -
  53363. -`-m486'
  53364. -`-m386'
  53365. -     Control whether or not code is optimized for a 486 instead of an
  53366. -     386.  Code generated for an 486 will run on a 386 and vice versa.
  53367. -
  53368. -`-mieee-fp'
  53369. -`-mno-ieee-fp'
  53370. -     Control whether or not the compiler uses IEEE floating point
  53371. -     comparisons.  These handle correctly the case where the result of a
  53372. -     comparison is unordered.
  53373. -
  53374. -`-msoft-float'
  53375. -     Generate output containing library calls for floating point.
  53376. -     *Warning:* the requisite libraries are not part of GNU CC.
  53377. -     Normally the facilities of the machine's usual C compiler are
  53378. -     used, but this can't be done directly in cross-compilation.  You
  53379. -     must make your own arrangements to provide suitable library
  53380. -     functions for cross-compilation.
  53381. -
  53382. -     On machines where a function returns floating point results in the
  53383. -     80387 register stack, some floating point opcodes may be emitted
  53384. -     even if `-msoft-float' is used.
  53385. -
  53386. -`-mno-fp-ret-in-387'
  53387. -     Do not use the FPU registers for return values of functions.
  53388. -
  53389. -     The usual calling convention has functions return values of types
  53390. -     `float' and `double' in an FPU register, even if there is no FPU.
  53391. -     The idea is that the operating system should emulate an FPU.
  53392. -
  53393. -     The option `-mno-fp-ret-in-387' causes such values to be returned
  53394. -     in ordinary CPU registers instead.
  53395. -
  53396. -`-mno-fancy-math-387'
  53397. -     Some 387 emulators do not support the `sin', `cos' and `sqrt'
  53398. -     instructions for the 387.  Specify this option to avoid generating
  53399. -     those instructions. This option is the default on FreeBSD.  As of
  53400. -     revision 2.6.1, these instructions are not generated unless you
  53401. -     also use the `-ffast-math' switch.
  53402. -
  53403. -`-malign-double'
  53404. -`-mno-align-double'
  53405. -     Control whether GNU CC aligns `double', `long double', and `long
  53406. -     long' variables on a two word boundary or a one word boundary.
  53407. -     Aligning `double' variables on a two word boundary will produce
  53408. -     code that runs somewhat faster on a `Pentium' at the expense of
  53409. -     more memory.
  53410. -
  53411. -     *Warning:* if you use the `-malign-double' switch, structures
  53412. -     containing the above types will be aligned differently than the
  53413. -     published application binary interface specifications for the 386.
  53414. -
  53415. -`-msvr3-shlib'
  53416. -`-mno-svr3-shlib'
  53417. -     Control whether GNU CC places uninitialized locals into `bss' or
  53418. -     `data'.  `-msvr3-shlib' places these locals into `bss'.  These
  53419. -     options are meaningful only on System V Release 3.
  53420. -
  53421. -`-mno-wide-multiply'
  53422. -`-mwide-multiply'
  53423. -     Control whether GNU CC uses the `mul' and `imul' that produce 64
  53424. -     bit results in `eax:edx' from 32 bit operands to do `long long'
  53425. -     multiplies and 32-bit division by constants.
  53426. -
  53427. -`-mrtd'
  53428. -     Use a different function-calling convention, in which functions
  53429. -     that take a fixed number of arguments return with the `ret' NUM
  53430. -     instruction, which pops their arguments while returning.  This
  53431. -     saves one instruction in the caller since there is no need to pop
  53432. -     the arguments there.
  53433. -
  53434. -     You can specify that an individual function is called with this
  53435. -     calling sequence with the function attribute `stdcall'.  You can
  53436. -     also override the `-mrtd' option by using the function attribute
  53437. -     `cdecl'. *Note Function Attributes::
  53438. -
  53439. -     *Warning:* this calling convention is incompatible with the one
  53440. -     normally used on Unix, so you cannot use it if you need to call
  53441. -     libraries compiled with the Unix compiler.
  53442. -
  53443. -     Also, you must provide function prototypes for all functions that
  53444. -     take variable numbers of arguments (including `printf'); otherwise
  53445. -     incorrect code will be generated for calls to those functions.
  53446. -
  53447. -     In addition, seriously incorrect code will result if you call a
  53448. -     function with too many arguments.  (Normally, extra arguments are
  53449. -     harmlessly ignored.)
  53450. -
  53451. -`-mreg-alloc=REGS'
  53452. -     Control the default allocation order of integer registers.  The
  53453. -     string REGS is a series of letters specifying a register.  The
  53454. -     supported letters are: `a' allocate EAX; `b' allocate EBX; `c'
  53455. -     allocate ECX; `d' allocate EDX; `S' allocate ESI; `D' allocate
  53456. -     EDI; `B' allocate EBP.
  53457. -
  53458. -`-mregparm=NUM'
  53459. -     Control how many registers are used to pass integer arguments.  By
  53460. -     default, no registers are used to pass arguments, and at most 3
  53461. -     registers can be used.  You can control this behavior for a
  53462. -     specific function by using the function attribute `regparm'.
  53463. -     *Note Function Attributes::
  53464. -
  53465. -     *Warning:* if you use this switch, and NUM is nonzero, then you
  53466. -     must build all modules with the same value, including any
  53467. -     libraries.  This includes the system libraries and startup modules.
  53468. -
  53469. -`-malign-loops=NUM'
  53470. -     Align loops to a 2 raised to a NUM byte boundary.  If
  53471. -     `-malign-loops' is not specified, the default is 2.
  53472. -
  53473. -`-malign-jumps=NUM'
  53474. -     Align instructions that are only jumped to to a 2 raised to a NUM
  53475. -     byte boundary.  If `-malign-jumps' is not specified, the default is
  53476. -     2 if optimizing for a 386, and 4 if optimizing for a 486.
  53477. -
  53478. -`-malign-functions=NUM'
  53479. -     Align the start of functions to a 2 raised to NUM byte boundary.
  53480. -     If `-malign-jumps' is not specified, the default is 2 if optimizing
  53481. -     for a 386, and 4 if optimizing for a 486.
  53482. -
  53483. -
  53484. -File: gcc.info,  Node: HPPA Options,  Next: Intel 960 Options,  Prev: i386 Options,  Up: Submodel Options
  53485. -
  53486. -HPPA Options
  53487. -------------
  53488. -
  53489. -   These `-m' options are defined for the HPPA family of computers:
  53490. -
  53491. -`-mpa-risc-1-0'
  53492. -     Generate code for a PA 1.0 processor.
  53493. -
  53494. -`-mpa-risc-1-1'
  53495. -     Generate code for a PA 1.1 processor.
  53496. -
  53497. -`-mjump-in-delay'
  53498. -     Fill delay slots of function calls with unconditional jump
  53499. -     instructions by modifying the return pointer for the function call
  53500. -     to be the target of the conditional jump.
  53501. -
  53502. -`-mmillicode-long-calls'
  53503. -     Generate code which assumes millicode routines can not be reached
  53504. -     by the standard millicode call sequence, linker-generated
  53505. -     long-calls, or linker-modified millicode calls.  In practice this
  53506. -     should only be needed for dynamicly linked executables with
  53507. -     extremely large SHLIB_INFO sections.
  53508. -
  53509. -`-mdisable-fpregs'
  53510. -     Prevent floating point registers from being used in any manner.
  53511. -     This is necessary for compiling kernels which perform lazy context
  53512. -     switching of floating point registers.  If you use this option and
  53513. -     attempt to perform floating point operations, the compiler will
  53514. -     abort.
  53515. -
  53516. -`-mdisable-indexing'
  53517. -     Prevent the compiler from using indexing address modes.  This
  53518. -     avoids some rather obscure problems when compiling MIG generated
  53519. -     code under MACH.
  53520. -
  53521. -`-mfast-indirect-calls'
  53522. -     Generate code which performs faster indirect calls.  Such code is
  53523. -     suitable for kernels and for static linking.  The fast indirect
  53524. -     call code will fail miserably if it's part of a dynamically linked
  53525. -     executable and in the presense of nested functions.
  53526. -
  53527. -`-mportable-runtime'
  53528. -     Use the portable calling conventions proposed by HP for ELF
  53529. -     systems.
  53530. -
  53531. -`-mgas'
  53532. -     Enable the use of assembler directives only GAS understands.
  53533. -
  53534. -`-mschedule=CPU TYPE'
  53535. -     Schedule code according to the constraints for the machine type
  53536. -     CPU TYPE.  The choices for CPU TYPE are `700' for 7N0 machines,
  53537. -     `7100' for 7N5 machines, and `7100' for 7N2 machines.  `700' is
  53538. -     the default for CPU TYPE.
  53539. -
  53540. -     Note the `7100LC' scheduling information is incomplete and using
  53541. -     `7100LC' often leads to bad schedules.  For now it's probably best
  53542. -     to use `7100' instead of `7100LC' for the 7N2 machines.
  53543. -
  53544. -`-msoft-float'
  53545. -     Generate output containing library calls for floating point.
  53546. -     *Warning:* the requisite libraries are not available for all HPPA
  53547. -     targets.  Normally the facilities of the machine's usual C
  53548. -     compiler are used, but this cannot be done directly in
  53549. -     cross-compilation.  You must make your own arrangements to provide
  53550. -     suitable library functions for cross-compilation.  The embedded
  53551. -     target `hppa1.1-*-pro' does provide software floating point
  53552. -     support.
  53553. -
  53554. -     `-msoft-float' changes the calling convention in the output file;
  53555. -     therefore, it is only useful if you compile *all* of a program with
  53556. -     this option.  In particular, you need to compile `libgcc.a', the
  53557. -     library that comes with GNU CC, with `-msoft-float' in order for
  53558. -     this to work.
  53559. -
  53560. -
  53561. -File: gcc.info,  Node: Intel 960 Options,  Next: DEC Alpha Options,  Prev: HPPA Options,  Up: Submodel Options
  53562. -
  53563. -Intel 960 Options
  53564. ------------------
  53565. -
  53566. -   These `-m' options are defined for the Intel 960 implementations:
  53567. -
  53568. -`-mCPU TYPE'
  53569. -     Assume the defaults for the machine type CPU TYPE for some of the
  53570. -     other options, including instruction scheduling, floating point
  53571. -     support, and addressing modes.  The choices for CPU TYPE are `ka',
  53572. -     `kb', `mc', `ca', `cf', `sa', and `sb'.  The default is `kb'.
  53573. -
  53574. -`-mnumerics'
  53575. -`-msoft-float'
  53576. -     The `-mnumerics' option indicates that the processor does support
  53577. -     floating-point instructions.  The `-msoft-float' option indicates
  53578. -     that floating-point support should not be assumed.
  53579. -
  53580. -`-mleaf-procedures'
  53581. -`-mno-leaf-procedures'
  53582. -     Do (or do not) attempt to alter leaf procedures to be callable
  53583. -     with the `bal' instruction as well as `call'.  This will result in
  53584. -     more efficient code for explicit calls when the `bal' instruction
  53585. -     can be substituted by the assembler or linker, but less efficient
  53586. -     code in other cases, such as calls via function pointers, or using
  53587. -     a linker that doesn't support this optimization.
  53588. -
  53589. -`-mtail-call'
  53590. -`-mno-tail-call'
  53591. -     Do (or do not) make additional attempts (beyond those of the
  53592. -     machine-independent portions of the compiler) to optimize
  53593. -     tail-recursive calls into branches.  You may not want to do this
  53594. -     because the detection of cases where this is not valid is not
  53595. -     totally complete.  The default is `-mno-tail-call'.
  53596. -
  53597. -`-mcomplex-addr'
  53598. -`-mno-complex-addr'
  53599. -     Assume (or do not assume) that the use of a complex addressing
  53600. -     mode is a win on this implementation of the i960.  Complex
  53601. -     addressing modes may not be worthwhile on the K-series, but they
  53602. -     definitely are on the C-series.  The default is currently
  53603. -     `-mcomplex-addr' for all processors except the CB and CC.
  53604. -
  53605. -`-mcode-align'
  53606. -`-mno-code-align'
  53607. -     Align code to 8-byte boundaries for faster fetching (or don't
  53608. -     bother).  Currently turned on by default for C-series
  53609. -     implementations only.
  53610. -
  53611. -`-mic-compat'
  53612. -`-mic2.0-compat'
  53613. -`-mic3.0-compat'
  53614. -     Enable compatibility with iC960 v2.0 or v3.0.
  53615. -
  53616. -`-masm-compat'
  53617. -`-mintel-asm'
  53618. -     Enable compatibility with the iC960 assembler.
  53619. -
  53620. -`-mstrict-align'
  53621. -`-mno-strict-align'
  53622. -     Do not permit (do permit) unaligned accesses.
  53623. -
  53624. -`-mold-align'
  53625. -     Enable structure-alignment compatibility with Intel's gcc release
  53626. -     version 1.3 (based on gcc 1.37).  Currently this is buggy in that
  53627. -     `#pragma align 1' is always assumed as well, and cannot be turned
  53628. -     off.
  53629. -
  53630. -
  53631. -File: gcc.info,  Node: DEC Alpha Options,  Next: Clipper Options,  Prev: Intel 960 Options,  Up: Submodel Options
  53632. -
  53633. -DEC Alpha Options
  53634. ------------------
  53635. -
  53636. -   These `-m' options are defined for the DEC Alpha implementations:
  53637. -
  53638. -`-mno-soft-float'
  53639. -`-msoft-float'
  53640. -     Use (do not use) the hardware floating-point instructions for
  53641. -     floating-point operations.  When `-msoft-float' is specified,
  53642. -     functions in `libgcc1.c' will be used to perform floating-point
  53643. -     operations.  Unless they are replaced by routines that emulate the
  53644. -     floating-point operations, or compiled in such a way as to call
  53645. -     such emulations routines, these routines will issue floating-point
  53646. -     operations.   If you are compiling for an Alpha without
  53647. -     floating-point operations, you must ensure that the library is
  53648. -     built so as not to call them.
  53649. -
  53650. -     Note that Alpha implementations without floating-point operations
  53651. -     are required to have floating-point registers.
  53652. -
  53653. -`-mfp-reg'
  53654. -`-mno-fp-regs'
  53655. -     Generate code that uses (does not use) the floating-point register
  53656. -     set.  `-mno-fp-regs' implies `-msoft-float'.  If the floating-point
  53657. -     register set is not used, floating point operands are passed in
  53658. -     integer registers as if they were integers and floating-point
  53659. -     results are passed in $0 instead of $f0.  This is a non-standard
  53660. -     calling sequence, so any function with a floating-point argument
  53661. -     or return value called by code compiled with `-mno-fp-regs' must
  53662. -     also be compiled with that option.
  53663. -
  53664. -     A typical use of this option is building a kernel that does not
  53665. -     use, and hence need not save and restore, any floating-point
  53666. -     registers.
  53667. -
  53668. -
  53669. -File: gcc.info,  Node: Clipper Options,  Next: H8/300 Options,  Prev: DEC Alpha Options,  Up: Submodel Options
  53670. -
  53671. -Clipper Options
  53672. ----------------
  53673. -
  53674. -   These `-m' options are defined for the Clipper implementations:
  53675. -
  53676. -`-mc300'
  53677. -     Produce code for a C300 Clipper processor. This is the default.
  53678. -
  53679. -`-mc400'
  53680. -     Produce code for a C400 Clipper processor i.e. use floating point
  53681. -     registers f8..f15.
  53682. -
  53683. -
  53684. -File: gcc.info,  Node: H8/300 Options,  Next: System V Options,  Prev: Clipper Options,  Up: Submodel Options
  53685. -
  53686. -H8/300 Options
  53687. ---------------
  53688. -
  53689. -   These `-m' options are defined for the H8/300 implementations:
  53690. -
  53691. -`-mrelax'
  53692. -     Shorten some address references at link time, when possible; uses
  53693. -     the linker option `-relax'.  *Note `ld' and the H8/300:
  53694. -     (ld.info)H8/300, for a fuller description.
  53695. -
  53696. -`-mh'
  53697. -     Generate code for the H8/300H.
  53698. -
  53699. -
  53700. -File: gcc.info,  Node: System V Options,  Prev: H8/300 Options,  Up: Submodel Options
  53701. -
  53702. -Options for System V
  53703. ---------------------
  53704. -
  53705. -   These additional options are available on System V Release 4 for
  53706. -compatibility with other compilers on those systems:
  53707. -
  53708. -`-Qy'
  53709. -     Identify the versions of each tool used by the compiler, in a
  53710. -     `.ident' assembler directive in the output.
  53711. -
  53712. -`-Qn'
  53713. -     Refrain from adding `.ident' directives to the output file (this is
  53714. -     the default).
  53715. -
  53716. -`-YP,DIRS'
  53717. -     Search the directories DIRS, and no others, for libraries
  53718. -     specified with `-l'.
  53719. -
  53720. -`-Ym,DIR'
  53721. -     Look in the directory DIR to find the M4 preprocessor.  The
  53722. -     assembler uses this option.
  53723. -
  53724. -
  53725. -File: gcc.info,  Node: Code Gen Options,  Next: Environment Variables,  Prev: Submodel Options,  Up: Invoking GCC
  53726. -
  53727. -Options for Code Generation Conventions
  53728. -=======================================
  53729. -
  53730. -   These machine-independent options control the interface conventions
  53731. -used in code generation.
  53732. -
  53733. -   Most of them have both positive and negative forms; the negative form
  53734. -of `-ffoo' would be `-fno-foo'.  In the table below, only one of the
  53735. -forms is listed--the one which is not the default.  You can figure out
  53736. -the other form by either removing `no-' or adding it.
  53737. -
  53738. -`-fpcc-struct-return'
  53739. -     Return "short" `struct' and `union' values in memory like longer
  53740. -     ones, rather than in registers.  This convention is less
  53741. -     efficient, but it has the advantage of allowing intercallability
  53742. -     between GNU CC-compiled files and files compiled with other
  53743. -     compilers.
  53744. -
  53745. -     The precise convention for returning structures in memory depends
  53746. -     on the target configuration macros.
  53747. -
  53748. -     Short structures and unions are those whose size and alignment
  53749. -     match that of some integer type.
  53750. -
  53751. -`-freg-struct-return'
  53752. -     Use the convention that `struct' and `union' values are returned
  53753. -     in registers when possible.  This is more efficient for small
  53754. -     structures than `-fpcc-struct-return'.
  53755. -
  53756. -     If you specify neither `-fpcc-struct-return' nor its contrary
  53757. -     `-freg-struct-return', GNU CC defaults to whichever convention is
  53758. -     standard for the target.  If there is no standard convention, GNU
  53759. -     CC defaults to `-fpcc-struct-return', except on targets where GNU
  53760. -     CC is the principal compiler.  In those cases, we can choose the
  53761. -     standard, and we chose the more efficient register return
  53762. -     alternative.
  53763. -
  53764. -`-fshort-enums'
  53765. -     Allocate to an `enum' type only as many bytes as it needs for the
  53766. -     declared range of possible values.  Specifically, the `enum' type
  53767. -     will be equivalent to the smallest integer type which has enough
  53768. -     room.
  53769. -
  53770. -`-fshort-double'
  53771. -     Use the same size for `double' as for `float'.
  53772. -
  53773. -`-fshared-data'
  53774. -     Requests that the data and non-`const' variables of this
  53775. -     compilation be shared data rather than private data.  The
  53776. -     distinction makes sense only on certain operating systems, where
  53777. -     shared data is shared between processes running the same program,
  53778. -     while private data exists in one copy per process.
  53779. -
  53780. -`-fno-common'
  53781. -     Allocate even uninitialized global variables in the bss section of
  53782. -     the object file, rather than generating them as common blocks.
  53783. -     This has the effect that if the same variable is declared (without
  53784. -     `extern') in two different compilations, you will get an error
  53785. -     when you link them.  The only reason this might be useful is if
  53786. -     you wish to verify that the program will work on other systems
  53787. -     which always work this way.
  53788. -
  53789. -`-fno-ident'
  53790. -     Ignore the `#ident' directive.
  53791. -
  53792. -`-fno-gnu-linker'
  53793. -     Do not output global initializations (such as C++ constructors and
  53794. -     destructors) in the form used by the GNU linker (on systems where
  53795. -     the GNU linker is the standard method of handling them).  Use this
  53796. -     option when you want to use a non-GNU linker, which also requires
  53797. -     using the `collect2' program to make sure the system linker
  53798. -     includes constructors and destructors.  (`collect2' is included in
  53799. -     the GNU CC distribution.)  For systems which *must* use
  53800. -     `collect2', the compiler driver `gcc' is configured to do this
  53801. -     automatically.
  53802. -
  53803. -`-finhibit-size-directive'
  53804. -     Don't output a `.size' assembler directive, or anything else that
  53805. -     would cause trouble if the function is split in the middle, and the
  53806. -     two halves are placed at locations far apart in memory.  This
  53807. -     option is used when compiling `crtstuff.c'; you should not need to
  53808. -     use it for anything else.
  53809. -
  53810. -`-fverbose-asm'
  53811. -     Put extra commentary information in the generated assembly code to
  53812. -     make it more readable.  This option is generally only of use to
  53813. -     those who actually need to read the generated assembly code
  53814. -     (perhaps while debugging the compiler itself).
  53815. -
  53816. -`-fvolatile'
  53817. -     Consider all memory references through pointers to be volatile.
  53818. -
  53819. -`-fvolatile-global'
  53820. -     Consider all memory references to extern and global data items to
  53821. -     be volatile.
  53822. -
  53823. -`-fpic'
  53824. -     Generate position-independent code (PIC) suitable for use in a
  53825. -     shared library, if supported for the target machine.  Such code
  53826. -     accesses all constant addresses through a global offset table
  53827. -     (GOT).  If the GOT size for the linked executable exceeds a
  53828. -     machine-specific maximum size, you get an error message from the
  53829. -     linker indicating that `-fpic' does not work; in that case,
  53830. -     recompile with `-fPIC' instead.  (These maximums are 16k on the
  53831. -     m88k, 8k on the Sparc, and 32k on the m68k and RS/6000.  The 386
  53832. -     has no such limit.)
  53833. -
  53834. -     Position-independent code requires special support, and therefore
  53835. -     works only on certain machines.  For the 386, GNU CC supports PIC
  53836. -     for System V but not for the Sun 386i.  Code generated for the IBM
  53837. -     RS/6000 is always position-independent.
  53838. -
  53839. -     The GNU assembler does not fully support PIC.  Currently, you must
  53840. -     use some other assembler in order for PIC to work.  We would
  53841. -     welcome volunteers to upgrade GAS to handle this; the first part
  53842. -     of the job is to figure out what the assembler must do differently.
  53843. -
  53844. -`-fPIC'
  53845. -     If supported for the target machine, emit position-independent
  53846. -     code, suitable for dynamic linking and avoiding any limit on the
  53847. -     size of the global offset table.  This option makes a difference
  53848. -     on the m68k, m88k and the Sparc.
  53849. -
  53850. -     Position-independent code requires special support, and therefore
  53851. -     works only on certain machines.
  53852. -
  53853. -`-ffixed-REG'
  53854. -     Treat the register named REG as a fixed register; generated code
  53855. -     should never refer to it (except perhaps as a stack pointer, frame
  53856. -     pointer or in some other fixed role).
  53857. -
  53858. -     REG must be the name of a register.  The register names accepted
  53859. -     are machine-specific and are defined in the `REGISTER_NAMES' macro
  53860. -     in the machine description macro file.
  53861. -
  53862. -     This flag does not have a negative form, because it specifies a
  53863. -     three-way choice.
  53864. -
  53865. -`-fcall-used-REG'
  53866. -     Treat the register named REG as an allocatable register that is
  53867. -     clobbered by function calls.  It may be allocated for temporaries
  53868. -     or variables that do not live across a call.  Functions compiled
  53869. -     this way will not save and restore the register REG.
  53870. -
  53871. -     Use of this flag for a register that has a fixed pervasive role in
  53872. -     the machine's execution model, such as the stack pointer or frame
  53873. -     pointer, will produce disastrous results.
  53874. -
  53875. -     This flag does not have a negative form, because it specifies a
  53876. -     three-way choice.
  53877. -
  53878. -`-fcall-saved-REG'
  53879. -     Treat the register named REG as an allocatable register saved by
  53880. -     functions.  It may be allocated even for temporaries or variables
  53881. -     that live across a call.  Functions compiled this way will save
  53882. -     and restore the register REG if they use it.
  53883. -
  53884. -     Use of this flag for a register that has a fixed pervasive role in
  53885. -     the machine's execution model, such as the stack pointer or frame
  53886. -     pointer, will produce disastrous results.
  53887. -
  53888. -     A different sort of disaster will result from the use of this flag
  53889. -     for a register in which function values may be returned.
  53890. -
  53891. -     This flag does not have a negative form, because it specifies a
  53892. -     three-way choice.
  53893. -
  53894. -`-fpack-struct'
  53895. -     Pack all structure members together without holes.  Usually you
  53896. -     would not want to use this option, since it makes the code
  53897. -     suboptimal, and the offsets of structure members won't agree with
  53898. -     system libraries.
  53899. -
  53900. -`+e0'
  53901. -`+e1'
  53902. -     Control whether virtual function definitions in classes are used to
  53903. -     generate code, or only to define interfaces for their callers.
  53904. -     (C++ only).
  53905. -
  53906. -     These options are provided for compatibility with `cfront' 1.x
  53907. -     usage; the recommended alternative GNU C++ usage is in flux.
  53908. -     *Note Declarations and Definitions in One Header: C++ Interface.
  53909. -
  53910. -     With `+e0', virtual function definitions in classes are declared
  53911. -     `extern'; the declaration is used only as an interface
  53912. -     specification, not to generate code for the virtual functions (in
  53913. -     this compilation).
  53914. -
  53915. -     With `+e1', G++ actually generates the code implementing virtual
  53916. -     functions defined in the code, and makes them publicly visible.
  53917. -
  53918. -
  53919. -File: gcc.info,  Node: Environment Variables,  Next: Running Protoize,  Prev: Code Gen Options,  Up: Invoking GCC
  53920. -
  53921. -Environment Variables Affecting GNU CC
  53922. -======================================
  53923. -
  53924. -   This section describes several environment variables that affect how
  53925. -GNU CC operates.  They work by specifying directories or prefixes to use
  53926. -when searching for various kinds of files.
  53927. -
  53928. -   Note that you can also specify places to search using options such as
  53929. -`-B', `-I' and `-L' (*note Directory Options::.).  These take
  53930. -precedence over places specified using environment variables, which in
  53931. -turn take precedence over those specified by the configuration of GNU
  53932. -CC.  *Note Driver::.
  53933. -
  53934. -`TMPDIR'
  53935. -     If `TMPDIR' is set, it specifies the directory to use for temporary
  53936. -     files.  GNU CC uses temporary files to hold the output of one
  53937. -     stage of compilation which is to be used as input to the next
  53938. -     stage: for example, the output of the preprocessor, which is the
  53939. -     input to the compiler proper.
  53940. -
  53941. -`GCC_EXEC_PREFIX'
  53942. -     If `GCC_EXEC_PREFIX' is set, it specifies a prefix to use in the
  53943. -     names of the subprograms executed by the compiler.  No slash is
  53944. -     added when this prefix is combined with the name of a subprogram,
  53945. -     but you can specify a prefix that ends with a slash if you wish.
  53946. -
  53947. -     If GNU CC cannot find the subprogram using the specified prefix, it
  53948. -     tries looking in the usual places for the subprogram.
  53949. -
  53950. -     The default value of `GCC_EXEC_PREFIX' is `PREFIX/lib/gcc-lib/'
  53951. -     where PREFIX is the value of `prefix' when you ran the `configure'
  53952. -     script.
  53953. -
  53954. -     Other prefixes specified with `-B' take precedence over this
  53955. -     prefix.
  53956. -
  53957. -     This prefix is also used for finding files such as `crt0.o' that
  53958. -     are used for linking.
  53959. -
  53960. -     In addition, the prefix is used in an unusual way in finding the
  53961. -     directories to search for header files.  For each of the standard
  53962. -     directories whose name normally begins with
  53963. -     `/usr/local/lib/gcc-lib' (more precisely, with the value of
  53964. -     `GCC_INCLUDE_DIR'), GNU CC tries replacing that beginning with the
  53965. -     specified prefix to produce an alternate directory name.  Thus,
  53966. -     with `-Bfoo/', GNU CC will search `foo/bar' where it would
  53967. -     normally search `/usr/local/lib/bar'.  These alternate directories
  53968. -     are searched first; the standard directories come next.
  53969. -
  53970. -`COMPILER_PATH'
  53971. -     The value of `COMPILER_PATH' is a colon-separated list of
  53972. -     directories, much like `PATH'.  GNU CC tries the directories thus
  53973. -     specified when searching for subprograms, if it can't find the
  53974. -     subprograms using `GCC_EXEC_PREFIX'.
  53975. -
  53976. -`LIBRARY_PATH'
  53977. -     The value of `LIBRARY_PATH' is a colon-separated list of
  53978. -     directories, much like `PATH'.  When configured as a native
  53979. -     compiler, GNU CC tries the directories thus specified when
  53980. -     searching for special linker files, if it can't find them using
  53981. -     `GCC_EXEC_PREFIX'.  Linking using GNU CC also uses these
  53982. -     directories when searching for ordinary libraries for the `-l'
  53983. -     option (but directories specified with `-L' come first).
  53984. -
  53985. -`C_INCLUDE_PATH'
  53986. -`CPLUS_INCLUDE_PATH'
  53987. -`OBJC_INCLUDE_PATH'
  53988. -     These environment variables pertain to particular languages.  Each
  53989. -     variable's value is a colon-separated list of directories, much
  53990. -     like `PATH'.  When GNU CC searches for header files, it tries the
  53991. -     directories listed in the variable for the language you are using,
  53992. -     after the directories specified with `-I' but before the standard
  53993. -     header file directories.
  53994. -
  53995. -`DEPENDENCIES_OUTPUT'
  53996. -     If this variable is set, its value specifies how to output
  53997. -     dependencies for Make based on the header files processed by the
  53998. -     compiler.  This output looks much like the output from the `-M'
  53999. -     option (*note Preprocessor Options::.), but it goes to a separate
  54000. -     file, and is in addition to the usual results of compilation.
  54001. -
  54002. -     The value of `DEPENDENCIES_OUTPUT' can be just a file name, in
  54003. -     which case the Make rules are written to that file, guessing the
  54004. -     target name from the source file name.  Or the value can have the
  54005. -     form `FILE TARGET', in which case the rules are written to file
  54006. -     FILE using TARGET as the target name.
  54007. -
  54008. -
  54009. -File: gcc.info,  Node: Running Protoize,  Prev: Environment Variables,  Up: Invoking GCC
  54010. -
  54011. -Running Protoize
  54012. -================
  54013. -
  54014. -   The program `protoize' is an optional part of GNU C.  You can use it
  54015. -to add prototypes to a program, thus converting the program to ANSI C
  54016. -in one respect.  The companion program `unprotoize' does the reverse:
  54017. -it removes argument types from any prototypes that are found.
  54018. -
  54019. -   When you run these programs, you must specify a set of source files
  54020. -as command line arguments.  The conversion programs start out by
  54021. -compiling these files to see what functions they define.  The
  54022. -information gathered about a file FOO is saved in a file named `FOO.X'.
  54023. -
  54024. -   After scanning comes actual conversion.  The specified files are all
  54025. -eligible to be converted; any files they include (whether sources or
  54026. -just headers) are eligible as well.
  54027. -
  54028. -   But not all the eligible files are converted.  By default,
  54029. -`protoize' and `unprotoize' convert only source and header files in the
  54030. -current directory.  You can specify additional directories whose files
  54031. -should be converted with the `-d DIRECTORY' option.  You can also
  54032. -specify particular files to exclude with the `-x FILE' option.  A file
  54033. -is converted if it is eligible, its directory name matches one of the
  54034. -specified directory names, and its name within the directory has not
  54035. -been excluded.
  54036. -
  54037. -   Basic conversion with `protoize' consists of rewriting most function
  54038. -definitions and function declarations to specify the types of the
  54039. -arguments.  The only ones not rewritten are those for varargs functions.
  54040. -
  54041. -   `protoize' optionally inserts prototype declarations at the
  54042. -beginning of the source file, to make them available for any calls that
  54043. -precede the function's definition.  Or it can insert prototype
  54044. -declarations with block scope in the blocks where undeclared functions
  54045. -are called.
  54046. -
  54047. -   Basic conversion with `unprotoize' consists of rewriting most
  54048. -function declarations to remove any argument types, and rewriting
  54049. -function definitions to the old-style pre-ANSI form.
  54050. -
  54051. -   Both conversion programs print a warning for any function
  54052. -declaration or definition that they can't convert.  You can suppress
  54053. -these warnings with `-q'.
  54054. -
  54055. -   The output from `protoize' or `unprotoize' replaces the original
  54056. -source file.  The original file is renamed to a name ending with
  54057. -`.save'.  If the `.save' file already exists, then the source file is
  54058. -simply discarded.
  54059. -
  54060. -   `protoize' and `unprotoize' both depend on GNU CC itself to scan the
  54061. -program and collect information about the functions it uses.  So
  54062. -neither of these programs will work until GNU CC is installed.
  54063. -
  54064. -   Here is a table of the options you can use with `protoize' and
  54065. -`unprotoize'.  Each option works with both programs unless otherwise
  54066. -stated.
  54067. -
  54068. -`-B DIRECTORY'
  54069. -     Look for the file `SYSCALLS.c.X' in DIRECTORY, instead of the
  54070. -     usual directory (normally `/usr/local/lib').  This file contains
  54071. -     prototype information about standard system functions.  This option
  54072. -     applies only to `protoize'.
  54073. -
  54074. -`-c COMPILATION-OPTIONS'
  54075. -     Use  COMPILATION-OPTIONS as the options when running `gcc' to
  54076. -     produce the `.X' files.  The special option `-aux-info' is always
  54077. -     passed in addition, to tell `gcc' to write a `.X' file.
  54078. -
  54079. -     Note that the compilation options must be given as a single
  54080. -     argument to `protoize' or `unprotoize'.  If you want to specify
  54081. -     several `gcc' options, you must quote the entire set of
  54082. -     compilation options to make them a single word in the shell.
  54083. -
  54084. -     There are certain `gcc' arguments that you cannot use, because they
  54085. -     would produce the wrong kind of output.  These include `-g', `-O',
  54086. -     `-c', `-S', and `-o' If you include these in the
  54087. -     COMPILATION-OPTIONS, they are ignored.
  54088. -
  54089. -`-C'
  54090. -     Rename files to end in `.C' instead of `.c'.  This is convenient
  54091. -     if you are converting a C program to C++.  This option applies
  54092. -     only to `protoize'.
  54093. -
  54094. -`-g'
  54095. -     Add explicit global declarations.  This means inserting explicit
  54096. -     declarations at the beginning of each source file for each function
  54097. -     that is called in the file and was not declared.  These
  54098. -     declarations precede the first function definition that contains a
  54099. -     call to an undeclared function.  This option applies only to
  54100. -     `protoize'.
  54101. -
  54102. -`-i STRING'
  54103. -     Indent old-style parameter declarations with the string STRING.
  54104. -     This option applies only to `protoize'.
  54105. -
  54106. -     `unprotoize' converts prototyped function definitions to old-style
  54107. -     function definitions, where the arguments are declared between the
  54108. -     argument list and the initial `{'.  By default, `unprotoize' uses
  54109. -     five spaces as the indentation.  If you want to indent with just
  54110. -     one space instead, use `-i " "'.
  54111. -
  54112. -`-k'
  54113. -     Keep the `.X' files.  Normally, they are deleted after conversion
  54114. -     is finished.
  54115. -
  54116. -`-l'
  54117. -     Add explicit local declarations.  `protoize' with `-l' inserts a
  54118. -     prototype declaration for each function in each block which calls
  54119. -     the function without any declaration.  This option applies only to
  54120. -     `protoize'.
  54121. -
  54122. -`-n'
  54123. -     Make no real changes.  This mode just prints information about the
  54124. -     conversions that would have been done without `-n'.
  54125. -
  54126. -`-N'
  54127. -     Make no `.save' files.  The original files are simply deleted.
  54128. -     Use this option with caution.
  54129. -
  54130. -`-p PROGRAM'
  54131. -     Use the program PROGRAM as the compiler.  Normally, the name `gcc'
  54132. -     is used.
  54133. -
  54134. -`-q'
  54135. -     Work quietly.  Most warnings are suppressed.
  54136. -
  54137. -`-v'
  54138. -     Print the version number, just like `-v' for `gcc'.
  54139. -
  54140. -   If you need special compiler options to compile one of your program's
  54141. -source files, then you should generate that file's `.X' file specially,
  54142. -by running `gcc' on that source file with the appropriate options and
  54143. -the option `-aux-info'.  Then run `protoize' on the entire set of
  54144. -files.  `protoize' will use the existing `.X' file because it is newer
  54145. -than the source file.  For example:
  54146. -
  54147. -     gcc -Dfoo=bar file1.c -aux-info
  54148. -     protoize *.c
  54149. -
  54150. -You need to include the special files along with the rest in the
  54151. -`protoize' command, even though their `.X' files already exist, because
  54152. -otherwise they won't get converted.
  54153. -
  54154. -   *Note Protoize Caveats::, for more information on how to use
  54155. -`protoize' successfully.
  54156. -
  54157. diff -rup --new-file baseline/fsf/gcc/gcc.info-6 amiga/fsf/gcc/gcc.info-6
  54158. --- baseline/fsf/gcc/gcc.info-6    Sat Jun 29 09:37:58 1996
  54159. +++ amiga/fsf/gcc/gcc.info-6    Wed Dec 31 17:00:00 1969
  54160. @@ -1,468 +0,0 @@
  54161. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  54162. -file gcc.texi.
  54163. -
  54164. -   This file documents the use and the internals of the GNU compiler.
  54165. -
  54166. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  54167. -Boston, MA 02111-1307 USA
  54168. -
  54169. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  54170. -Foundation, Inc.
  54171. -
  54172. -   Permission is granted to make and distribute verbatim copies of this
  54173. -manual provided the copyright notice and this permission notice are
  54174. -preserved on all copies.
  54175. -
  54176. -   Permission is granted to copy and distribute modified versions of
  54177. -this manual under the conditions for verbatim copying, provided also
  54178. -that the sections entitled "GNU General Public License," "Funding for
  54179. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  54180. -included exactly as in the original, and provided that the entire
  54181. -resulting derived work is distributed under the terms of a permission
  54182. -notice identical to this one.
  54183. -
  54184. -   Permission is granted to copy and distribute translations of this
  54185. -manual into another language, under the above conditions for modified
  54186. -versions, except that the sections entitled "GNU General Public
  54187. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  54188. -`Look And Feel'", and this permission notice, may be included in
  54189. -translations approved by the Free Software Foundation instead of in the
  54190. -original English.
  54191. -
  54192. -
  54193. -File: gcc.info,  Node: Installation,  Next: C Extensions,  Prev: Invoking GCC,  Up: Top
  54194. -
  54195. -Installing GNU CC
  54196. -*****************
  54197. -
  54198. -* Menu:
  54199. -
  54200. -* Configurations::    Configurations Supported by GNU CC.
  54201. -* Other Dir::     Compiling in a separate directory (not where the source is).
  54202. -* Cross-Compiler::   Building and installing a cross-compiler.
  54203. -* Sun Install::   See below for installation on the Sun.
  54204. -* VMS Install::   See below for installation on VMS.
  54205. -* Collect2::      How `collect2' works; how it finds `ld'.
  54206. -* Header Dirs::   Understanding the standard header file directories.
  54207. -
  54208. -   Here is the procedure for installing GNU CC on a Unix system.  See
  54209. -*Note VMS Install::, for VMS systems.  In this section we assume you
  54210. -compile in the same directory that contains the source files; see *Note
  54211. -Other Dir::, to find out how to compile in a separate directory on Unix
  54212. -systems.
  54213. -
  54214. -   You cannot install GNU C by itself on MSDOS; it will not compile
  54215. -under any MSDOS compiler except itself.  You need to get the complete
  54216. -compilation package DJGPP, which includes binaries as well as sources,
  54217. -and includes all the necessary compilation tools and libraries.
  54218. -
  54219. -  1. If you have built GNU CC previously in the same directory for a
  54220. -     different target machine, do `make distclean' to delete all files
  54221. -     that might be invalid.  One of the files this deletes is
  54222. -     `Makefile'; if `make distclean' complains that `Makefile' does not
  54223. -     exist, it probably means that the directory is already suitably
  54224. -     clean.
  54225. -
  54226. -  2. On a System V release 4 system, make sure `/usr/bin' precedes
  54227. -     `/usr/ucb' in `PATH'.  The `cc' command in `/usr/ucb' uses
  54228. -     libraries which have bugs.
  54229. -
  54230. -  3. Specify the host, build and target machine configurations.  You do
  54231. -     this by running the file `configure'.
  54232. -
  54233. -     The "build" machine is the system which you are using, the "host"
  54234. -     machine is the system where you want to run the resulting compiler
  54235. -     (normally the build machine), and the "target" machine is the
  54236. -     system for which you want the compiler to generate code.
  54237. -
  54238. -     If you are building a compiler to produce code for the machine it
  54239. -     runs on (a native compiler), you normally do not need to specify
  54240. -     any operands to `configure'; it will try to guess the type of
  54241. -     machine you are on and use that as the build, host and target
  54242. -     machines.  So you don't need to specify a configuration when
  54243. -     building a native compiler unless `configure' cannot figure out
  54244. -     what your configuration is or guesses wrong.
  54245. -
  54246. -     In those cases, specify the build machine's "configuration name"
  54247. -     with the `--build' option; the host and target will default to be
  54248. -     the same as the build machine.  (If you are building a
  54249. -     cross-compiler, see *Note Cross-Compiler::.)
  54250. -
  54251. -     Here is an example:
  54252. -
  54253. -          ./configure --build=sparc-sun-sunos4.1
  54254. -
  54255. -     A configuration name may be canonical or it may be more or less
  54256. -     abbreviated.
  54257. -
  54258. -     A canonical configuration name has three parts, separated by
  54259. -     dashes.  It looks like this: `CPU-COMPANY-SYSTEM'.  (The three
  54260. -     parts may themselves contain dashes; `configure' can figure out
  54261. -     which dashes serve which purpose.)  For example,
  54262. -     `m68k-sun-sunos4.1' specifies a Sun 3.
  54263. -
  54264. -     You can also replace parts of the configuration by nicknames or
  54265. -     aliases.  For example, `sun3' stands for `m68k-sun', so
  54266. -     `sun3-sunos4.1' is another way to specify a Sun 3.  You can also
  54267. -     use simply `sun3-sunos', since the version of SunOS is assumed by
  54268. -     default to be version 4.  `sun3-bsd' also works, since `configure'
  54269. -     knows that the only BSD variant on a Sun 3 is SunOS.
  54270. -
  54271. -     You can specify a version number after any of the system types,
  54272. -     and some of the CPU types.  In most cases, the version is
  54273. -     irrelevant, and will be ignored.  So you might as well specify the
  54274. -     version if you know it.
  54275. -
  54276. -     See *Note Configurations::, for a list of supported configuration
  54277. -     names and notes on many of the configurations.  You should check
  54278. -     the notes in that section before proceeding any further with the
  54279. -     installation of GNU CC.
  54280. -
  54281. -     There are four additional options you can specify independently to
  54282. -     describe variant hardware and software configurations.  These are
  54283. -     `--with-gnu-as', `--with-gnu-ld', `--with-stabs' and `--nfp'.
  54284. -
  54285. -    `--with-gnu-as'
  54286. -          If you will use GNU CC with the GNU assembler (GAS), you
  54287. -          should declare this by using the `--with-gnu-as' option when
  54288. -          you run `configure'.
  54289. -
  54290. -          Using this option does not install GAS.  It only modifies the
  54291. -          output of GNU CC to work with GAS.  Building and installing
  54292. -          GAS is up to you.
  54293. -
  54294. -          Conversely, if you *do not* wish to use GAS and do not specify
  54295. -          `--with-gnu-as' when building GNU CC, it is up to you to make
  54296. -          sure that GAS is not installed.  GNU CC searches for a
  54297. -          program named `as' in various directories; if the program it
  54298. -          finds is GAS, then it runs GAS.  If you are not sure where
  54299. -          GNU CC finds the assembler it is using, try specifying `-v'
  54300. -          when you run it.
  54301. -
  54302. -          The systems where it makes a difference whether you use GAS
  54303. -          are
  54304. -          `hppa1.0-ANY-ANY', `hppa1.1-ANY-ANY', `i386-ANY-sysv',
  54305. -          `i386-ANY-isc',
  54306. -          `i860-ANY-bsd', `m68k-bull-sysv', `m68k-hp-hpux',
  54307. -          `m68k-sony-bsd',
  54308. -          `m68k-altos-sysv', `m68000-hp-hpux', `m68000-att-sysv',
  54309. -          `ANY-lynx-lynxos', and `mips-ANY').  On any other system,
  54310. -          `--with-gnu-as' has no effect.
  54311. -
  54312. -          On the systems listed above (except for the HP-PA, for ISC on
  54313. -          the 386, and for `mips-sgi-irix5.*'), if you use GAS, you
  54314. -          should also use the GNU linker (and specify `--with-gnu-ld').
  54315. -
  54316. -    `--with-gnu-ld'
  54317. -          Specify the option `--with-gnu-ld' if you plan to use the GNU
  54318. -          linker with GNU CC.
  54319. -
  54320. -          This option does not cause the GNU linker to be installed; it
  54321. -          just modifies the behavior of GNU CC to work with the GNU
  54322. -          linker.  Specifically, it inhibits the installation of
  54323. -          `collect2', a program which otherwise serves as a front-end
  54324. -          for the system's linker on most configurations.
  54325. -
  54326. -    `--with-stabs'
  54327. -          On MIPS based systems and on Alphas, you must specify whether
  54328. -          you want GNU CC to create the normal ECOFF debugging format,
  54329. -          or to use BSD-style stabs passed through the ECOFF symbol
  54330. -          table.  The normal ECOFF debug format cannot fully handle
  54331. -          languages other than C.  BSD stabs format can handle other
  54332. -          languages, but it only works with the GNU debugger GDB.
  54333. -
  54334. -          Normally, GNU CC uses the ECOFF debugging format by default;
  54335. -          if you prefer BSD stabs, specify `--with-stabs' when you
  54336. -          configure GNU CC.
  54337. -
  54338. -          No matter which default you choose when you configure GNU CC,
  54339. -          the user can use the `-gcoff' and `-gstabs+' options to
  54340. -          specify explicitly the debug format for a particular
  54341. -          compilation.
  54342. -
  54343. -          `--with-stabs' is meaningful on the ISC system on the 386,
  54344. -          also, if `--with-gas' is used.  It selects use of stabs
  54345. -          debugging information embedded in COFF output.  This kind of
  54346. -          debugging information supports C++ well; ordinary COFF
  54347. -          debugging information does not.
  54348. -
  54349. -          `--with-stabs' is also meaningful on 386 systems running
  54350. -          SVR4.  It selects use of stabs debugging information embedded
  54351. -          in ELF output.  The C++ compiler currently (2.6.0) does not
  54352. -          support the DWARF debugging information normally used on 386
  54353. -          SVR4 platforms; stabs provide a workable alternative.  This
  54354. -          requires gas and gdb, as the normal SVR4 tools can not
  54355. -          generate or interpret stabs.
  54356. -
  54357. -    `--nfp'
  54358. -          On certain systems, you must specify whether the machine has
  54359. -          a floating point unit.  These systems include
  54360. -          `m68k-sun-sunosN' and `m68k-isi-bsd'.  On any other system,
  54361. -          `--nfp' currently has no effect, though perhaps there are
  54362. -          other systems where it could usefully make a difference.
  54363. -
  54364. -     The `configure' script searches subdirectories of the source
  54365. -     directory for other compilers that are to be integrated into GNU
  54366. -     CC.  The GNU compiler for C++, called G++ is in a subdirectory
  54367. -     named `cp'.  `configure' inserts rules into `Makefile' to build
  54368. -     all of those compilers.
  54369. -
  54370. -     Here we spell out what files will be set up by `configure'.
  54371. -     Normally you need not be concerned with these files.
  54372. -
  54373. -        * A file named `config.h' is created that contains a `#include'
  54374. -          of the top-level config file for the machine you will run the
  54375. -          compiler on (*note Config::.).  This file is responsible for
  54376. -          defining information about the host machine.  It includes
  54377. -          `tm.h'.
  54378. -
  54379. -          The top-level config file is located in the subdirectory
  54380. -          `config'.  Its name is always `xm-SOMETHING.h'; usually
  54381. -          `xm-MACHINE.h', but there are some exceptions.
  54382. -
  54383. -          If your system does not support symbolic links, you might
  54384. -          want to set up `config.h' to contain a `#include' command
  54385. -          which refers to the appropriate file.
  54386. -
  54387. -        * A file named `tconfig.h' is created which includes the
  54388. -          top-level config file for your target machine.  This is used
  54389. -          for compiling certain programs to run on that machine.
  54390. -
  54391. -        * A file named `tm.h' is created which includes the
  54392. -          machine-description macro file for your target machine.  It
  54393. -          should be in the subdirectory `config' and its name is often
  54394. -          `MACHINE.h'.
  54395. -
  54396. -        * The command file `configure' also constructs the file
  54397. -          `Makefile' by adding some text to the template file
  54398. -          `Makefile.in'.  The additional text comes from files in the
  54399. -          `config' directory, named `t-TARGET' and `x-HOST'.  If these
  54400. -          files do not exist, it means nothing needs to be added for a
  54401. -          given target or host.
  54402. -
  54403. -  4. The standard directory for installing GNU CC is `/usr/local/lib'.
  54404. -     If you want to install its files somewhere else, specify
  54405. -     `--prefix=DIR' when you run `configure'.  Here DIR is a directory
  54406. -     name to use instead of `/usr/local' for all purposes with one
  54407. -     exception: the directory `/usr/local/include' is searched for
  54408. -     header files no matter where you install the compiler.  To override
  54409. -     this name, use the `--local-prefix' option below.
  54410. -
  54411. -  5. Specify `--local-prefix=DIR' if you want the compiler to search
  54412. -     directory `DIR/include' for locally installed header files
  54413. -     *instead* of `/usr/local/include'.
  54414. -
  54415. -     You should specify `--local-prefix' *only* if your site has a
  54416. -     different convention (not `/usr/local') for where to put
  54417. -     site-specific files.
  54418. -
  54419. -     *Do not* specify `/usr' as the `--local-prefix'!  The directory
  54420. -     you use for `--local-prefix' *must not* contain any of the
  54421. -     system's standard header files.  If it did contain them, certain
  54422. -     programs would be miscompiled (including GNU Emacs, on certain
  54423. -     targets), because this would override and nullify the header file
  54424. -     corrections made by the `fixincludes' script.
  54425. -
  54426. -  6. Make sure the Bison parser generator is installed.  (This is
  54427. -     unnecessary if the Bison output files `c-parse.c' and `cexp.c' are
  54428. -     more recent than `c-parse.y' and `cexp.y' and you do not plan to
  54429. -     change the `.y' files.)
  54430. -
  54431. -     Bison versions older than Sept 8, 1988 will produce incorrect
  54432. -     output for `c-parse.c'.
  54433. -
  54434. -  7. If you have chosen a configuration for GNU CC which requires other
  54435. -     GNU tools (such as GAS or the GNU linker) instead of the standard
  54436. -     system tools, install the required tools in the build directory
  54437. -     under the names `as', `ld' or whatever is appropriate.  This will
  54438. -     enable the compiler to find the proper tools for compilation of
  54439. -     the program `enquire'.
  54440. -
  54441. -     Alternatively, you can do subsequent compilation using a value of
  54442. -     the `PATH' environment variable such that the necessary GNU tools
  54443. -     come before the standard system tools.
  54444. -
  54445. -  8. Build the compiler.  Just type `make LANGUAGES=c' in the compiler
  54446. -     directory.
  54447. -
  54448. -     `LANGUAGES=c' specifies that only the C compiler should be
  54449. -     compiled.  The makefile normally builds compilers for all the
  54450. -     supported languages; currently, C, C++ and Objective C.  However,
  54451. -     C is the only language that is sure to work when you build with
  54452. -     other non-GNU C compilers.  In addition, building anything but C
  54453. -     at this stage is a waste of time.
  54454. -
  54455. -     In general, you can specify the languages to build by typing the
  54456. -     argument `LANGUAGES="LIST"', where LIST is one or more words from
  54457. -     the list `c', `c++', and `objective-c'.  If you have any
  54458. -     additional GNU compilers as subdirectories of the GNU CC source
  54459. -     directory, you may also specify their names in this list.
  54460. -
  54461. -     Ignore any warnings you may see about "statement not reached" in
  54462. -     `insn-emit.c'; they are normal.  Also, warnings about "unknown
  54463. -     escape sequence" are normal in `genopinit.c' and perhaps some
  54464. -     other files.  Likewise, you should ignore warnings about "constant
  54465. -     is so large that it is unsigned" in `insn-emit.c' and
  54466. -     `insn-recog.c' and a warning about a comparison always being zero
  54467. -     in `enquire.o'.  Any other compilation errors may represent bugs in
  54468. -     the port to your machine or operating system, and should be
  54469. -     investigated and reported (*note Bugs::.).
  54470. -
  54471. -     Some commercial compilers fail to compile GNU CC because they have
  54472. -     bugs or limitations.  For example, the Microsoft compiler is said
  54473. -     to run out of macro space.  Some Ultrix compilers run out of
  54474. -     expression space; then you need to break up the statement where
  54475. -     the problem happens.
  54476. -
  54477. -  9. If you are building a cross-compiler, stop here.  *Note
  54478. -     Cross-Compiler::.
  54479. -
  54480. - 10. Move the first-stage object files and executables into a
  54481. -     subdirectory with this command:
  54482. -
  54483. -          make stage1
  54484. -
  54485. -     The files are moved into a subdirectory named `stage1'.  Once
  54486. -     installation is complete, you may wish to delete these files with
  54487. -     `rm -r stage1'.
  54488. -
  54489. - 11. If you have chosen a configuration for GNU CC which requires other
  54490. -     GNU tools (such as GAS or the GNU linker) instead of the standard
  54491. -     system tools, install the required tools in the `stage1'
  54492. -     subdirectory under the names `as', `ld' or whatever is
  54493. -     appropriate.  This will enable the stage 1 compiler to find the
  54494. -     proper tools in the following stage.
  54495. -
  54496. -     Alternatively, you can do subsequent compilation using a value of
  54497. -     the `PATH' environment variable such that the necessary GNU tools
  54498. -     come before the standard system tools.
  54499. -
  54500. - 12. Recompile the compiler with itself, with this command:
  54501. -
  54502. -          make CC="stage1/xgcc -Bstage1/" CFLAGS="-g -O2"
  54503. -
  54504. -     This is called making the stage 2 compiler.
  54505. -
  54506. -     The command shown above builds compilers for all the supported
  54507. -     languages.  If you don't want them all, you can specify the
  54508. -     languages to build by typing the argument `LANGUAGES="LIST"'.  LIST
  54509. -     should contain one or more words from the list `c', `c++',
  54510. -     `objective-c', and `proto'.  Separate the words with spaces.
  54511. -     `proto' stands for the programs `protoize' and `unprotoize'; they
  54512. -     are not a separate language, but you use `LANGUAGES' to enable or
  54513. -     disable their installation.
  54514. -
  54515. -     If you are going to build the stage 3 compiler, then you might
  54516. -     want to build only the C language in stage 2.
  54517. -
  54518. -     Once you have built the stage 2 compiler, if you are short of disk
  54519. -     space, you can delete the subdirectory `stage1'.
  54520. -
  54521. -     On a 68000 or 68020 system lacking floating point hardware, unless
  54522. -     you have selected a `tm.h' file that expects by default that there
  54523. -     is no such hardware, do this instead:
  54524. -
  54525. -          make CC="stage1/xgcc -Bstage1/" CFLAGS="-g -O2 -msoft-float"
  54526. -
  54527. - 13. If you wish to test the compiler by compiling it with itself one
  54528. -     more time, install any other necessary GNU tools (such as GAS or
  54529. -     the GNU linker) in the `stage2' subdirectory as you did in the
  54530. -     `stage1' subdirectory, then do this:
  54531. -
  54532. -          make stage2
  54533. -          make CC="stage2/xgcc -Bstage2/" CFLAGS="-g -O2"
  54534. -
  54535. -     This is called making the stage 3 compiler.  Aside from the `-B'
  54536. -     option, the compiler options should be the same as when you made
  54537. -     the stage 2 compiler.  But the `LANGUAGES' option need not be the
  54538. -     same.  The command shown above builds compilers for all the
  54539. -     supported languages; if you don't want them all, you can specify
  54540. -     the languages to build by typing the argument `LANGUAGES="LIST"',
  54541. -     as described above.
  54542. -
  54543. -     If you do not have to install any additional GNU tools, you may
  54544. -     use the command
  54545. -
  54546. -          make bootstrap LANGUAGES=LANGUAGE-LIST BOOT_CFLAGS=OPTION-LIST
  54547. -
  54548. -     instead of making `stage1', `stage2', and performing the two
  54549. -     compiler builds.
  54550. -
  54551. - 14. Then compare the latest object files with the stage 2 object
  54552. -     files--they ought to be identical, aside from time stamps (if any).
  54553. -
  54554. -     On some systems, meaningful comparison of object files is
  54555. -     impossible; they always appear "different."  This is currently
  54556. -     true on Solaris and some systems that use ELF object file format.
  54557. -     On some versions of Irix on SGI machines and DEC Unix (OSF/1) on
  54558. -     Alpha systems, you will not be able to compare the files without
  54559. -     specifying `-save-temps'; see the description of individual
  54560. -     systems above to see if you get comparison failures.  You may have
  54561. -     similar problems on other systems.
  54562. -
  54563. -     Use this command to compare the files:
  54564. -
  54565. -          make compare
  54566. -
  54567. -     This will mention any object files that differ between stage 2 and
  54568. -     stage 3.  Any difference, no matter how innocuous, indicates that
  54569. -     the stage 2 compiler has compiled GNU CC incorrectly, and is
  54570. -     therefore a potentially serious bug which you should investigate
  54571. -     and report (*note Bugs::.).
  54572. -
  54573. -     If your system does not put time stamps in the object files, then
  54574. -     this is a faster way to compare them (using the Bourne shell):
  54575. -
  54576. -          for file in *.o; do
  54577. -          cmp $file stage2/$file
  54578. -          done
  54579. -
  54580. -     If you have built the compiler with the `-mno-mips-tfile' option on
  54581. -     MIPS machines, you will not be able to compare the files.
  54582. -
  54583. - 15. Install the compiler driver, the compiler's passes and run-time
  54584. -     support with `make install'.  Use the same value for `CC',
  54585. -     `CFLAGS' and `LANGUAGES' that you used when compiling the files
  54586. -     that are being installed.  One reason this is necessary is that
  54587. -     some versions of Make have bugs and recompile files gratuitously
  54588. -     when you do this step.  If you use the same variable values, those
  54589. -     files will be recompiled properly.
  54590. -
  54591. -     For example, if you have built the stage 2 compiler, you can use
  54592. -     the following command:
  54593. -
  54594. -          make install CC="stage2/xgcc -Bstage2/" CFLAGS="-g -O" LANGUAGES="LIST"
  54595. -
  54596. -     This copies the files `cc1', `cpp' and `libgcc.a' to files `cc1',
  54597. -     `cpp' and `libgcc.a' in the directory
  54598. -     `/usr/local/lib/gcc-lib/TARGET/VERSION', which is where the
  54599. -     compiler driver program looks for them.  Here TARGET is the target
  54600. -     machine type specified when you ran `configure', and VERSION is
  54601. -     the version number of GNU CC.  This naming scheme permits various
  54602. -     versions and/or cross-compilers to coexist.
  54603. -
  54604. -     This also copies the driver program `xgcc' into
  54605. -     `/usr/local/bin/gcc', so that it appears in typical execution
  54606. -     search paths.
  54607. -
  54608. -     On some systems, this command causes recompilation of some files.
  54609. -     This is usually due to bugs in `make'.  You should either ignore
  54610. -     this problem, or use GNU Make.
  54611. -
  54612. -     *Warning: there is a bug in `alloca' in the Sun library.  To avoid
  54613. -     this bug, be sure to install the executables of GNU CC that were
  54614. -     compiled by GNU CC.  (That is, the executables from stage 2 or 3,
  54615. -     not stage 1.)  They use `alloca' as a built-in function and never
  54616. -     the one in the library.*
  54617. -
  54618. -     (It is usually better to install GNU CC executables from stage 2
  54619. -     or 3, since they usually run faster than the ones compiled with
  54620. -     some other compiler.)
  54621. -
  54622. - 16. If you're going to use C++, it's likely that you need to also
  54623. -     install the libg++ distribution.  It should be available from the
  54624. -     same place where you got the GNU C distribution.  Just as GNU C
  54625. -     does not distribute a C runtime library, it also does not include
  54626. -     a C++ run-time library.  All I/O functionality, special class
  54627. -     libraries, etc., are available in the libg++ distribution.
  54628. -
  54629. diff -rup --new-file baseline/fsf/gcc/gcc.info-7 amiga/fsf/gcc/gcc.info-7
  54630. --- baseline/fsf/gcc/gcc.info-7    Sat Jun 29 09:37:59 1996
  54631. +++ amiga/fsf/gcc/gcc.info-7    Wed Dec 31 17:00:00 1969
  54632. @@ -1,1155 +0,0 @@
  54633. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  54634. -file gcc.texi.
  54635. -
  54636. -   This file documents the use and the internals of the GNU compiler.
  54637. -
  54638. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  54639. -Boston, MA 02111-1307 USA
  54640. -
  54641. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  54642. -Foundation, Inc.
  54643. -
  54644. -   Permission is granted to make and distribute verbatim copies of this
  54645. -manual provided the copyright notice and this permission notice are
  54646. -preserved on all copies.
  54647. -
  54648. -   Permission is granted to copy and distribute modified versions of
  54649. -this manual under the conditions for verbatim copying, provided also
  54650. -that the sections entitled "GNU General Public License," "Funding for
  54651. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  54652. -included exactly as in the original, and provided that the entire
  54653. -resulting derived work is distributed under the terms of a permission
  54654. -notice identical to this one.
  54655. -
  54656. -   Permission is granted to copy and distribute translations of this
  54657. -manual into another language, under the above conditions for modified
  54658. -versions, except that the sections entitled "GNU General Public
  54659. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  54660. -`Look And Feel'", and this permission notice, may be included in
  54661. -translations approved by the Free Software Foundation instead of in the
  54662. -original English.
  54663. -
  54664. -
  54665. -File: gcc.info,  Node: Configurations,  Next: Other Dir,  Up: Installation
  54666. -
  54667. -Configurations Supported by GNU CC
  54668. -==================================
  54669. -
  54670. -   Here are the possible CPU types:
  54671. -
  54672. -     1750a, a29k, alpha, arm, cN, clipper, dsp16xx, elxsi, h8300,
  54673. -     hppa1.0, hppa1.1, i370, i386, i486, i586, i860, i960, m68000, m68k,
  54674. -     m88k, mips, mipsel, mips64, mips64el, ns32k, powerpc, powerpcle,
  54675. -     pyramid, romp, rs6000, sh, sparc, sparclite, sparc64, vax, we32k.
  54676. -
  54677. -   Here are the recognized company names.  As you can see, customary
  54678. -abbreviations are used rather than the longer official names.
  54679. -
  54680. -     acorn, alliant, altos, apollo, att, bull, cbm, convergent, convex,
  54681. -     crds, dec, dg, dolphin, elxsi, encore, harris, hitachi, hp, ibm,
  54682. -     intergraph, isi, mips, motorola, ncr, next, ns, omron, plexus,
  54683. -     sequent, sgi, sony, sun, tti, unicom, wrs.
  54684. -
  54685. -   The company name is meaningful only to disambiguate when the rest of
  54686. -the information supplied is insufficient.  You can omit it, writing
  54687. -just `CPU-SYSTEM', if it is not needed.  For example, `vax-ultrix4.2'
  54688. -is equivalent to `vax-dec-ultrix4.2'.
  54689. -
  54690. -   Here is a list of system types:
  54691. -
  54692. -     386bsd, aix, acis, amigados, aos, aout, bosx, bsd, clix, coff,
  54693. -     ctix, cxux, dgux, dynix, ebmon, ecoff, elf, esix, freebsd, hms,
  54694. -     genix, gnu, gnu/linux, hiux, hpux, iris, irix, isc, luna, lynxos,
  54695. -     mach, minix, msdos, mvs, netbsd, newsos, nindy, ns, osf, osfrose,
  54696. -     ptx, riscix, riscos, rtu, sco, sim, solaris, sunos, sym, sysv,
  54697. -     udi, ultrix, unicos, uniplus, unos, vms, vsta, vxworks, winnt,
  54698. -     xenix.
  54699. -
  54700. -You can omit the system type; then `configure' guesses the operating
  54701. -system from the CPU and company.
  54702. -
  54703. -   You can add a version number to the system type; this may or may not
  54704. -make a difference.  For example, you can write `bsd4.3' or `bsd4.4' to
  54705. -distinguish versions of BSD.  In practice, the version number is most
  54706. -needed for `sysv3' and `sysv4', which are often treated differently.
  54707. -
  54708. -   If you specify an impossible combination such as `i860-dg-vms', then
  54709. -you may get an error message from `configure', or it may ignore part of
  54710. -the information and do the best it can with the rest.  `configure'
  54711. -always prints the canonical name for the alternative that it used.  GNU
  54712. -CC does not support all possible alternatives.
  54713. -
  54714. -   Often a particular model of machine has a name.  Many machine names
  54715. -are recognized as aliases for CPU/company combinations.  Thus, the
  54716. -machine name `sun3', mentioned above, is an alias for `m68k-sun'.
  54717. -Sometimes we accept a company name as a machine name, when the name is
  54718. -popularly used for a particular machine.  Here is a table of the known
  54719. -machine names:
  54720. -
  54721. -     3300, 3b1, 3bN, 7300, altos3068, altos, apollo68, att-7300,
  54722. -     balance, convex-cN, crds, decstation-3100, decstation, delta,
  54723. -     encore, fx2800, gmicro, hp7NN, hp8NN, hp9k2NN, hp9k3NN, hp9k7NN,
  54724. -     hp9k8NN, iris4d, iris, isi68, m3230, magnum, merlin, miniframe,
  54725. -     mmax, news-3600, news800, news, next, pbd, pc532, pmax, powerpc,
  54726. -     powerpcle, ps2, risc-news, rtpc, sun2, sun386i, sun386, sun3,
  54727. -     sun4, symmetry, tower-32, tower.
  54728. -
  54729. -Remember that a machine name specifies both the cpu type and the company
  54730. -name.  If you want to install your own homemade configuration files,
  54731. -you can use `local' as the company name to access them.  If you use
  54732. -configuration `CPU-local', the configuration name without the cpu prefix
  54733. -is used to form the configuration file names.
  54734. -
  54735. -   Thus, if you specify `m68k-local', configuration uses files
  54736. -`m68k.md', `local.h', `m68k.c', `xm-local.h', `t-local', and `x-local',
  54737. -all in the directory `config/m68k'.
  54738. -
  54739. -   Here is a list of configurations that have special treatment or
  54740. -special things you must know:
  54741. -
  54742. -`1750a-*-*'
  54743. -     MIL-STD-1750A processors.
  54744. -
  54745. -     Starting with GCC 2.6.1, the MIL-STD-1750A cross configuration no
  54746. -     longer supports the Tektronix Assembler, but instead produces
  54747. -     output for `as1750', an assembler/linker available under the GNU
  54748. -     Public License for the 1750A. Contact *kellogg@space.otn.dasa.de*
  54749. -     for more details on obtaining `as1750'.  A similarly licensed
  54750. -     simulator for the 1750A is available from same address.
  54751. -
  54752. -     You should ignore a fatal error during the building of libgcc
  54753. -     (libgcc is not yet implemented for the 1750A.)
  54754. -
  54755. -     The `as1750' assembler requires the file `ms1750.inc', which is
  54756. -     found in the directory `config/1750a'.
  54757. -
  54758. -     GNU CC produced the same sections as the Fairchild F9450 C
  54759. -     Compiler, namely:
  54760. -
  54761. -    `Normal'
  54762. -          The program code section.
  54763. -
  54764. -    `Static'
  54765. -          The read/write (RAM) data section.
  54766. -
  54767. -    `Konst'
  54768. -          The read-only (ROM) constants section.
  54769. -
  54770. -    `Init'
  54771. -          Initialization section (code to copy KREL to SREL).
  54772. -
  54773. -     The smallest addressable unit is 16 bits (BITS_PER_UNIT is 16).
  54774. -     This means that type `char' is represented with a 16-bit word per
  54775. -     character.  The 1750A's "Load/Store Upper/Lower Byte" instructions
  54776. -     are not used by GNU CC.
  54777. -
  54778. -`alpha-*-osf1'
  54779. -     Systems using processors that implement the DEC Alpha architecture
  54780. -     and are running the DEC Unix (OSF/1) operating system, for example
  54781. -     the DEC Alpha AXP systems.  (VMS on the Alpha is not currently
  54782. -     supported by GNU CC.)
  54783. -
  54784. -     GNU CC writes a `.verstamp' directive to the assembler output file
  54785. -     unless it is built as a cross-compiler.  It gets the version to
  54786. -     use from the system header file `/usr/include/stamp.h'.  If you
  54787. -     install a new version of DEC Unix, you should rebuild GCC to pick
  54788. -     up the new version stamp.
  54789. -
  54790. -     Note that since the Alpha is a 64-bit architecture,
  54791. -     cross-compilers from 32-bit machines will not generate code as
  54792. -     efficient as that generated when the compiler is running on a
  54793. -     64-bit machine because many optimizations that depend on being
  54794. -     able to represent a word on the target in an integral value on the
  54795. -     host cannot be performed.  Building cross-compilers on the Alpha
  54796. -     for 32-bit machines has only been tested in a few cases and may
  54797. -     not work properly.
  54798. -
  54799. -     `make compare' may fail on old versions of DEC Unix unless you add
  54800. -     `-save-temps' to `CFLAGS'.  On these systems, the name of the
  54801. -     assembler input file is stored in the object file, and that makes
  54802. -     comparison fail if it differs between the `stage1' and `stage2'
  54803. -     compilations.  The option `-save-temps' forces a fixed name to be
  54804. -     used for the assembler input file, instead of a randomly chosen
  54805. -     name in `/tmp'.  Do not add `-save-temps' unless the comparisons
  54806. -     fail without that option.  If you add `-save-temps', you will have
  54807. -     to manually delete the `.i' and `.s' files after each series of
  54808. -     compilations.
  54809. -
  54810. -     GNU CC now supports both the native (ECOFF) debugging format used
  54811. -     by DBX and GDB and an encapsulated STABS format for use only with
  54812. -     GDB.  See the discussion of the `--with-stabs' option of
  54813. -     `configure' above for more information on these formats and how to
  54814. -     select them.
  54815. -
  54816. -     There is a bug in DEC's assembler that produces incorrect line
  54817. -     numbers for ECOFF format when the `.align' directive is used.  To
  54818. -     work around this problem, GNU CC will not emit such alignment
  54819. -     directives while writing ECOFF format debugging information even
  54820. -     if optimization is being performed.  Unfortunately, this has the
  54821. -     very undesirable side-effect that code addresses when `-O' is
  54822. -     specified are different depending on whether or not `-g' is also
  54823. -     specified.
  54824. -
  54825. -     To avoid this behavior, specify `-gstabs+' and use GDB instead of
  54826. -     DBX.  DEC is now aware of this problem with the assembler and
  54827. -     hopes to provide a fix shortly.
  54828. -
  54829. -`arm'
  54830. -     Advanced RISC Machines ARM-family processors.  These are often
  54831. -     used in embedded applications.  There are no standard Unix
  54832. -     configurations.  This configuration corresponds to the basic
  54833. -     instruction sequences and will produce a.out format object modules.
  54834. -
  54835. -     You may need to make a variant of the file `arm.h' for your
  54836. -     particular configuration.
  54837. -
  54838. -`arm-*-riscix'
  54839. -     The ARM2 or ARM3 processor running RISC iX, Acorn's port of BSD
  54840. -     Unix.  If you are running a version of RISC iX prior to 1.2 then
  54841. -     you must specify the version number during configuration.  Note
  54842. -     that the assembler shipped with RISC iX does not support stabs
  54843. -     debugging information; a new version of the assembler, with stabs
  54844. -     support included, is now available from Acorn.
  54845. -
  54846. -`a29k'
  54847. -     AMD Am29k-family processors.  These are normally used in embedded
  54848. -     applications.  There are no standard Unix configurations.  This
  54849. -     configuration corresponds to AMD's standard calling sequence and
  54850. -     binary interface and is compatible with other 29k tools.
  54851. -
  54852. -     You may need to make a variant of the file `a29k.h' for your
  54853. -     particular configuration.
  54854. -
  54855. -`a29k-*-bsd'
  54856. -     AMD Am29050 used in a system running a variant of BSD Unix.
  54857. -
  54858. -`decstation-*'
  54859. -     DECstations can support three different personalities: Ultrix, DEC
  54860. -     OSF/1, and OSF/rose.  To configure GCC for these platforms use the
  54861. -     following configurations:
  54862. -
  54863. -    `decstation-ultrix'
  54864. -          Ultrix configuration.
  54865. -
  54866. -    `decstation-osf1'
  54867. -          Dec's version of OSF/1.
  54868. -
  54869. -    `decstation-osfrose'
  54870. -          Open Software Foundation reference port of OSF/1 which uses
  54871. -          the OSF/rose object file format instead of ECOFF.  Normally,
  54872. -          you would not select this configuration.
  54873. -
  54874. -     The MIPS C compiler needs to be told to increase its table size
  54875. -     for switch statements with the `-Wf,-XNg1500' option in order to
  54876. -     compile `cp/parse.c'.  If you use the `-O2' optimization option,
  54877. -     you also need to use `-Olimit 3000'.  Both of these options are
  54878. -     automatically generated in the `Makefile' that the shell script
  54879. -     `configure' builds.  If you override the `CC' make variable and
  54880. -     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit
  54881. -     3000'.
  54882. -
  54883. -`elxsi-elxsi-bsd'
  54884. -     The Elxsi's C compiler has known limitations that prevent it from
  54885. -     compiling GNU C.  Please contact `mrs@cygnus.com' for more details.
  54886. -
  54887. -`dsp16xx'
  54888. -     A port to the AT&T DSP1610 family of processors.
  54889. -
  54890. -`h8300-*-*'
  54891. -     The calling convention and structure layout has changed in release
  54892. -     2.6.  All code must be recompiled.  The calling convention now
  54893. -     passes the first three arguments in function calls in registers.
  54894. -     Structures are no longer a multiple of 2 bytes.
  54895. -
  54896. -`hppa*-*-*'
  54897. -     There are several variants of the HP-PA processor which run a
  54898. -     variety of operating systems.  GNU CC must be configured to use
  54899. -     the correct processor type and operating system, or GNU CC will
  54900. -     not function correctly.  The easiest way to handle this problem is
  54901. -     to *not* specify a target when configuring GNU CC, the `configure'
  54902. -     script will try to automatically determine the right processor
  54903. -     type and operating system.
  54904. -
  54905. -     `-g' does not work on HP-UX, since that system uses a peculiar
  54906. -     debugging format which GNU CC does not know about.  However, `-g'
  54907. -     will work if you also use GAS and GDB in conjunction with GCC.  We
  54908. -     highly recommend using GAS for all HP-PA configurations.
  54909. -
  54910. -     You should be using GAS-2.6 (or later) along with GDB-4.16 (or
  54911. -     later).  These can be retrieved from all the traditional GNU ftp
  54912. -     archive sites.
  54913. -
  54914. -     GAS will need to be installed into a directory before `/bin',
  54915. -     `/usr/bin', and `/usr/ccs/bin' in your search path.  You should
  54916. -     install GAS before you build GNU CC.
  54917. -
  54918. -     To enable debugging, you must configure GNU CC with the
  54919. -     `--with-gnu-as' option before building.
  54920. -
  54921. -`i370-*-*'
  54922. -     This port is very preliminary and has many known bugs.  We hope to
  54923. -     have a higher-quality port for this machine soon.
  54924. -
  54925. -`i386-*-linuxoldld'
  54926. -     Use this configuration to generate a.out binaries on Linux-based
  54927. -     GNU systems, if you do not have gas/binutils version 2.5.2 or later
  54928. -     installed.  This is an obsolete configuration.
  54929. -
  54930. -`i386-*-linuxaout'
  54931. -     Use this configuration to generate a.out binaries on Linux-based
  54932. -     GNU systems.  This configuration is being superseded.  You must use
  54933. -     gas/binutils version 2.5.2 or later.
  54934. -
  54935. -`i386-*-linux'
  54936. -     Use this configuration to generate ELF binaries on Linux-based GNU
  54937. -     systems.  You must use gas/binutils version 2.5.2 or later.
  54938. -
  54939. -`i386-*-sco'
  54940. -     Compilation with RCC is recommended.  Also, it may be a good idea
  54941. -     to link with GNU malloc instead of the malloc that comes with the
  54942. -     system.
  54943. -
  54944. -`i386-*-sco3.2v4'
  54945. -     Use this configuration for SCO release 3.2 version 4.
  54946. -
  54947. -`i386-*-isc'
  54948. -     It may be a good idea to link with GNU malloc instead of the
  54949. -     malloc that comes with the system.
  54950. -
  54951. -     In ISC version 4.1, `sed' core dumps when building `deduced.h'.
  54952. -     Use the version of `sed' from version 4.0.
  54953. -
  54954. -`i386-*-esix'
  54955. -     It may be good idea to link with GNU malloc instead of the malloc
  54956. -     that comes with the system.
  54957. -
  54958. -`i386-ibm-aix'
  54959. -     You need to use GAS version 2.1 or later, and and LD from GNU
  54960. -     binutils version 2.2 or later.
  54961. -
  54962. -`i386-sequent-bsd'
  54963. -     Go to the Berkeley universe before compiling.  In addition, you
  54964. -     probably need to create a file named `string.h' containing just
  54965. -     one line: `#include <strings.h>'.
  54966. -
  54967. -`i386-sequent-ptx1*'
  54968. -     Sequent DYNIX/ptx 1.x.
  54969. -
  54970. -`i386-sequent-ptx2*'
  54971. -     Sequent DYNIX/ptx 2.x.
  54972. -
  54973. -`i386-sun-sunos4'
  54974. -     You may find that you need another version of GNU CC to begin
  54975. -     bootstrapping with, since the current version when built with the
  54976. -     system's own compiler seems to get an infinite loop compiling part
  54977. -     of `libgcc2.c'.  GNU CC version 2 compiled with GNU CC (any
  54978. -     version) seems not to have this problem.
  54979. -
  54980. -     See *Note Sun Install::, for information on installing GNU CC on
  54981. -     Sun systems.
  54982. -
  54983. -`i[345]86-*-winnt3.5'
  54984. -     This version requires a GAS that has not let been released.  Until
  54985. -     it is, you can get a prebuilt binary version via anonymous ftp from
  54986. -     `cs.washington.edu:pub/gnat' or `cs.nyu.edu:pub/gnat'. You must
  54987. -     also use the Microsoft header files from the Windows NT 3.5 SDK.
  54988. -     Find these on the CDROM in the `/mstools/h' directory dated
  54989. -     9/4/94.  You must use a fixed version of Microsoft linker made
  54990. -     especially for NT 3.5, which is also is available on the NT 3.5
  54991. -     SDK CDROM.  If you do not have this linker, can you also use the
  54992. -     linker from Visual C/C++ 1.0 or 2.0.
  54993. -
  54994. -     Installing GNU CC for NT builds a wrapper linker, called `ld.exe',
  54995. -     which mimics the behaviour of Unix `ld' in the specification of
  54996. -     libraries (`-L' and `-l').  `ld.exe' looks for both Unix and
  54997. -     Microsoft named libraries.  For example, if you specify `-lfoo',
  54998. -     `ld.exe' will look first for `libfoo.a' and then for `foo.lib'.
  54999. -
  55000. -     You may install GNU CC for Windows NT in one of two ways,
  55001. -     depending on whether or not you have a Unix-like shell and various
  55002. -     Unix-like utilities.
  55003. -
  55004. -       1. If you do not have a Unix-like shell and few Unix-like
  55005. -          utilities, you will use a DOS style batch script called
  55006. -          `configure.bat'.  Invoke it as `configure winnt' from an
  55007. -          MSDOS console window or from the program manager dialog box.
  55008. -          `configure.bat' assumes you have already installed and have
  55009. -          in your path a Unix-like `sed' program which is used to
  55010. -          create a working `Makefile' from `Makefile.in'.
  55011. -
  55012. -          `Makefile' uses the Microsoft Nmake program maintenance
  55013. -          utility and the Visual C/C++ V8.00 compiler to build GNU CC.
  55014. -          You need only have the utilities `sed' and `touch' to use
  55015. -          this installation method, which only automatically builds the
  55016. -          compiler itself.  You must then examine what `fixinc.winnt'
  55017. -          does, edit the header files by hand and build `libgcc.a'
  55018. -          manually.
  55019. -
  55020. -       2. The second type of installation assumes you are running a
  55021. -          Unix-like shell, have a complete suite of Unix-like utilities
  55022. -          in your path, and have a previous version of GNU CC already
  55023. -          installed, either through building it via the above
  55024. -          installation method or acquiring a pre-built binary.  In this
  55025. -          case, use the `configure' script in the normal fashion.
  55026. -
  55027. -`i860-intel-osf1'
  55028. -     This is the Paragon.  If you have version 1.0 of the operating
  55029. -     system, see *Note Installation Problems::, for special things you
  55030. -     need to do to compensate for peculiarities in the system.
  55031. -
  55032. -`*-lynx-lynxos'
  55033. -     LynxOS 2.2 and earlier comes with GNU CC 1.x already installed as
  55034. -     `/bin/gcc'.  You should compile with this instead of `/bin/cc'.
  55035. -     You can tell GNU CC to use the GNU assembler and linker, by
  55036. -     specifying `--with-gnu-as --with-gnu-ld' when configuring.  These
  55037. -     will produce COFF format object files and executables;  otherwise
  55038. -     GNU CC will use the installed tools, which produce a.out format
  55039. -     executables.
  55040. -
  55041. -`m68000-hp-bsd'
  55042. -     HP 9000 series 200 running BSD.  Note that the C compiler that
  55043. -     comes with this system cannot compile GNU CC; contact
  55044. -     `law@cs.utah.edu' to get binaries of GNU CC for bootstrapping.
  55045. -
  55046. -`m68k-altos'
  55047. -     Altos 3068.  You must use the GNU assembler, linker and debugger.
  55048. -     Also, you must fix a kernel bug.  Details in the file
  55049. -     `README.ALTOS'.
  55050. -
  55051. -`m68k-att-sysv'
  55052. -     AT&T 3b1, a.k.a. 7300 PC.  Special procedures are needed to
  55053. -     compile GNU CC with this machine's standard C compiler, due to
  55054. -     bugs in that compiler.  You can bootstrap it more easily with
  55055. -     previous versions of GNU CC if you have them.
  55056. -
  55057. -     Installing GNU CC on the 3b1 is difficult if you do not already
  55058. -     have GNU CC running, due to bugs in the installed C compiler.
  55059. -     However, the following procedure might work.  We are unable to
  55060. -     test it.
  55061. -
  55062. -       1. Comment out the `#include "config.h"' line on line 37 of
  55063. -          `cccp.c' and do `make cpp'.  This makes a preliminary version
  55064. -          of GNU cpp.
  55065. -
  55066. -       2. Save the old `/lib/cpp' and copy the preliminary GNU cpp to
  55067. -          that file name.
  55068. -
  55069. -       3. Undo your change in `cccp.c', or reinstall the original
  55070. -          version, and do `make cpp' again.
  55071. -
  55072. -       4. Copy this final version of GNU cpp into `/lib/cpp'.
  55073. -
  55074. -       5. Replace every occurrence of `obstack_free' in the file
  55075. -          `tree.c' with `_obstack_free'.
  55076. -
  55077. -       6. Run `make' to get the first-stage GNU CC.
  55078. -
  55079. -       7. Reinstall the original version of `/lib/cpp'.
  55080. -
  55081. -       8. Now you can compile GNU CC with itself and install it in the
  55082. -          normal fashion.
  55083. -
  55084. -`m68k-bull-sysv'
  55085. -     Bull DPX/2 series 200 and 300 with BOS-2.00.45 up to BOS-2.01. GNU
  55086. -     CC works either with native assembler or GNU assembler. You can use
  55087. -     GNU assembler with native coff generation by providing
  55088. -     `--with-gnu-as' to the configure script or use GNU assembler with
  55089. -     dbx-in-coff encapsulation by providing `--with-gnu-as --stabs'.
  55090. -     For any problem with native assembler or for availability of the
  55091. -     DPX/2 port of GAS, contact `F.Pierresteguy@frcl.bull.fr'.
  55092. -
  55093. -`m68k-crds-unox'
  55094. -     Use `configure unos' for building on Unos.
  55095. -
  55096. -     The Unos assembler is named `casm' instead of `as'.  For some
  55097. -     strange reason linking `/bin/as' to `/bin/casm' changes the
  55098. -     behavior, and does not work.  So, when installing GNU CC, you
  55099. -     should install the following script as `as' in the subdirectory
  55100. -     where the passes of GCC are installed:
  55101. -
  55102. -          #!/bin/sh
  55103. -          casm $*
  55104. -
  55105. -     The default Unos library is named `libunos.a' instead of `libc.a'.
  55106. -     To allow GNU CC to function, either change all references to
  55107. -     `-lc' in `gcc.c' to `-lunos' or link `/lib/libc.a' to
  55108. -     `/lib/libunos.a'.
  55109. -
  55110. -     When compiling GNU CC with the standard compiler, to overcome bugs
  55111. -     in the support of `alloca', do not use `-O' when making stage 2.
  55112. -     Then use the stage 2 compiler with `-O' to make the stage 3
  55113. -     compiler.  This compiler will have the same characteristics as the
  55114. -     usual stage 2 compiler on other systems.  Use it to make a stage 4
  55115. -     compiler and compare that with stage 3 to verify proper
  55116. -     compilation.
  55117. -
  55118. -     (Perhaps simply defining `ALLOCA' in `x-crds' as described in the
  55119. -     comments there will make the above paragraph superfluous.  Please
  55120. -     inform us of whether this works.)
  55121. -
  55122. -     Unos uses memory segmentation instead of demand paging, so you
  55123. -     will need a lot of memory.  5 Mb is barely enough if no other
  55124. -     tasks are running.  If linking `cc1' fails, try putting the object
  55125. -     files into a library and linking from that library.
  55126. -
  55127. -`m68k-hp-hpux'
  55128. -     HP 9000 series 300 or 400 running HP-UX.  HP-UX version 8.0 has a
  55129. -     bug in the assembler that prevents compilation of GNU CC.  To fix
  55130. -     it, get patch PHCO_4484 from HP.
  55131. -
  55132. -     In addition, if you wish to use gas `--with-gnu-as' you must use
  55133. -     gas version 2.1 or later, and you must use the GNU linker version
  55134. -     2.1 or later.  Earlier versions of gas relied upon a program which
  55135. -     converted the gas output into the native HP/UX format, but that
  55136. -     program has not been kept up to date.  gdb does not understand
  55137. -     that native HP/UX format, so you must use gas if you wish to use
  55138. -     gdb.
  55139. -
  55140. -`m68k-sun'
  55141. -     Sun 3.  We do not provide a configuration file to use the Sun FPA
  55142. -     by default, because programs that establish signal handlers for
  55143. -     floating point traps inherently cannot work with the FPA.
  55144. -
  55145. -     See *Note Sun Install::, for information on installing GNU CC on
  55146. -     Sun systems.
  55147. -
  55148. -`m88k-*-svr3'
  55149. -     Motorola m88k running the AT&T/Unisoft/Motorola V.3 reference port.
  55150. -     These systems tend to use the Green Hills C, revision 1.8.5, as the
  55151. -     standard C compiler.  There are apparently bugs in this compiler
  55152. -     that result in object files differences between stage 2 and stage
  55153. -     3.  If this happens, make the stage 4 compiler and compare it to
  55154. -     the stage 3 compiler.  If the stage 3 and stage 4 object files are
  55155. -     identical, this suggests you encountered a problem with the
  55156. -     standard C compiler; the stage 3 and 4 compilers may be usable.
  55157. -
  55158. -     It is best, however, to use an older version of GNU CC for
  55159. -     bootstrapping if you have one.
  55160. -
  55161. -`m88k-*-dgux'
  55162. -     Motorola m88k running DG/UX.  To build 88open BCS native or cross
  55163. -     compilers on DG/UX, specify the configuration name as
  55164. -     `m88k-*-dguxbcs' and build in the 88open BCS software development
  55165. -     environment.  To build ELF native or cross compilers on DG/UX,
  55166. -     specify `m88k-*-dgux' and build in the DG/UX ELF development
  55167. -     environment.  You set the software development environment by
  55168. -     issuing `sde-target' command and specifying either `m88kbcs' or
  55169. -     `m88kdguxelf' as the operand.
  55170. -
  55171. -     If you do not specify a configuration name, `configure' guesses the
  55172. -     configuration based on the current software development
  55173. -     environment.
  55174. -
  55175. -`m88k-tektronix-sysv3'
  55176. -     Tektronix XD88 running UTekV 3.2e.  Do not turn on optimization
  55177. -     while building stage1 if you bootstrap with the buggy Green Hills
  55178. -     compiler.  Also, The bundled LAI System V NFS is buggy so if you
  55179. -     build in an NFS mounted directory, start from a fresh reboot, or
  55180. -     avoid NFS all together.  Otherwise you may have trouble getting
  55181. -     clean comparisons between stages.
  55182. -
  55183. -`mips-mips-bsd'
  55184. -     MIPS machines running the MIPS operating system in BSD mode.  It's
  55185. -     possible that some old versions of the system lack the functions
  55186. -     `memcpy', `memcmp', and `memset'.  If your system lacks these, you
  55187. -     must remove or undo the definition of `TARGET_MEM_FUNCTIONS' in
  55188. -     `mips-bsd.h'.
  55189. -
  55190. -     The MIPS C compiler needs to be told to increase its table size
  55191. -     for switch statements with the `-Wf,-XNg1500' option in order to
  55192. -     compile `cp/parse.c'.  If you use the `-O2' optimization option,
  55193. -     you also need to use `-Olimit 3000'.  Both of these options are
  55194. -     automatically generated in the `Makefile' that the shell script
  55195. -     `configure' builds.  If you override the `CC' make variable and
  55196. -     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit
  55197. -     3000'.
  55198. -
  55199. -`mips-mips-riscos*'
  55200. -     The MIPS C compiler needs to be told to increase its table size
  55201. -     for switch statements with the `-Wf,-XNg1500' option in order to
  55202. -     compile `cp/parse.c'.  If you use the `-O2' optimization option,
  55203. -     you also need to use `-Olimit 3000'.  Both of these options are
  55204. -     automatically generated in the `Makefile' that the shell script
  55205. -     `configure' builds.  If you override the `CC' make variable and
  55206. -     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit
  55207. -     3000'.
  55208. -
  55209. -     MIPS computers running RISC-OS can support four different
  55210. -     personalities: default, BSD 4.3, System V.3, and System V.4 (older
  55211. -     versions of RISC-OS don't support V.4).  To configure GCC for
  55212. -     these platforms use the following configurations:
  55213. -
  55214. -    `mips-mips-riscos`rev''
  55215. -          Default configuration for RISC-OS, revision `rev'.
  55216. -
  55217. -    `mips-mips-riscos`rev'bsd'
  55218. -          BSD 4.3 configuration for RISC-OS, revision `rev'.
  55219. -
  55220. -    `mips-mips-riscos`rev'sysv4'
  55221. -          System V.4 configuration for RISC-OS, revision `rev'.
  55222. -
  55223. -    `mips-mips-riscos`rev'sysv'
  55224. -          System V.3 configuration for RISC-OS, revision `rev'.
  55225. -
  55226. -     The revision `rev' mentioned above is the revision of RISC-OS to
  55227. -     use.  You must reconfigure GCC when going from a RISC-OS revision
  55228. -     4 to RISC-OS revision 5.  This has the effect of avoiding a linker
  55229. -     bug (see *Note Installation Problems::, for more details).
  55230. -
  55231. -`mips-sgi-*'
  55232. -     In order to compile GCC on an SGI running IRIX 4, the "c.hdr.lib"
  55233. -     option must be installed from the CD-ROM supplied from Silicon
  55234. -     Graphics.  This is found on the 2nd CD in release 4.0.1.
  55235. -
  55236. -     In order to compile GCC on an SGI running IRIX 5, the
  55237. -     "compiler_dev.hdr" subsystem must be installed from the IDO CD-ROM
  55238. -     supplied by Silicon Graphics.
  55239. -
  55240. -     `make compare' may fail on version 5 of IRIX unless you add
  55241. -     `-save-temps' to `CFLAGS'.  On these systems, the name of the
  55242. -     assembler input file is stored in the object file, and that makes
  55243. -     comparison fail if it differs between the `stage1' and `stage2'
  55244. -     compilations.  The option `-save-temps' forces a fixed name to be
  55245. -     used for the assembler input file, instead of a randomly chosen
  55246. -     name in `/tmp'.  Do not add `-save-temps' unless the comparisons
  55247. -     fail without that option.  If you do you `-save-temps', you will
  55248. -     have to manually delete the `.i' and `.s' files after each series
  55249. -     of compilations.
  55250. -
  55251. -     The MIPS C compiler needs to be told to increase its table size
  55252. -     for switch statements with the `-Wf,-XNg1500' option in order to
  55253. -     compile `cp/parse.c'.  If you use the `-O2' optimization option,
  55254. -     you also need to use `-Olimit 3000'.  Both of these options are
  55255. -     automatically generated in the `Makefile' that the shell script
  55256. -     `configure' builds.  If you override the `CC' make variable and
  55257. -     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit
  55258. -     3000'.
  55259. -
  55260. -     On Irix version 4.0.5F, and perhaps on some other versions as well,
  55261. -     there is an assembler bug that reorders instructions incorrectly.
  55262. -     To work around it, specify the target configuration
  55263. -     `mips-sgi-irix4loser'.  This configuration inhibits assembler
  55264. -     optimization.
  55265. -
  55266. -     In a compiler configured with target `mips-sgi-irix4', you can turn
  55267. -     off assembler optimization by using the `-noasmopt' option.  This
  55268. -     compiler option passes the option `-O0' to the assembler, to
  55269. -     inhibit reordering.
  55270. -
  55271. -     The `-noasmopt' option can be useful for testing whether a problem
  55272. -     is due to erroneous assembler reordering.  Even if a problem does
  55273. -     not go away with `-noasmopt', it may still be due to assembler
  55274. -     reordering--perhaps GNU CC itself was miscompiled as a result.
  55275. -
  55276. -     To enable debugging under Irix 5, you must use GNU as 2.5 or later,
  55277. -     and use the `--with-gnu-as' configure option when configuring gcc.
  55278. -     GNU as is distributed as part of the binutils package.
  55279. -
  55280. -`mips-sony-sysv'
  55281. -     Sony MIPS NEWS.  This works in NEWSOS 5.0.1, but not in 5.0.2
  55282. -     (which uses ELF instead of COFF).  Support for 5.0.2 will probably
  55283. -     be provided soon by volunteers.  In particular, the linker does
  55284. -     not like the code generated by GCC when shared libraries are
  55285. -     linked in.
  55286. -
  55287. -`ns32k-encore'
  55288. -     Encore ns32000 system.  Encore systems are supported only under
  55289. -     BSD.
  55290. -
  55291. -`ns32k-*-genix'
  55292. -     National Semiconductor ns32000 system.  Genix has bugs in `alloca'
  55293. -     and `malloc'; you must get the compiled versions of these from GNU
  55294. -     Emacs.
  55295. -
  55296. -`ns32k-sequent'
  55297. -     Go to the Berkeley universe before compiling.  In addition, you
  55298. -     probably need to create a file named `string.h' containing just
  55299. -     one line: `#include <strings.h>'.
  55300. -
  55301. -`ns32k-utek'
  55302. -     UTEK ns32000 system ("merlin").  The C compiler that comes with
  55303. -     this system cannot compile GNU CC; contact `tektronix!reed!mason'
  55304. -     to get binaries of GNU CC for bootstrapping.
  55305. -
  55306. -`romp-*-aos'
  55307. -`romp-*-mach'
  55308. -     The only operating systems supported for the IBM RT PC are AOS and
  55309. -     MACH.  GNU CC does not support AIX running on the RT.  We
  55310. -     recommend you compile GNU CC with an earlier version of itself; if
  55311. -     you compile GNU CC with `hc', the Metaware compiler, it will work,
  55312. -     but you will get mismatches between the stage 2 and stage 3
  55313. -     compilers in various files.  These errors are minor differences in
  55314. -     some floating-point constants and can be safely ignored; the stage
  55315. -     3 compiler is correct.
  55316. -
  55317. -`rs6000-*-aix'
  55318. -`powerpc-*-aix'
  55319. -     Various early versions of each release of the IBM XLC compiler
  55320. -     will not bootstrap GNU CC.  Symptoms include differences between
  55321. -     the stage2 and stage3 object files, and errors when compiling
  55322. -     `libgcc.a' or `enquire'.  Known problematic releases include:
  55323. -     xlc-1.2.1.8, xlc-1.3.0.0 (distributed with AIX 3.2.5), and
  55324. -     xlc-1.3.0.19.  Both xlc-1.2.1.28 and xlc-1.3.0.24 (PTF 432238) are
  55325. -     known to produce working versions of GNU CC, but most other recent
  55326. -     releases correctly bootstrap GNU CC.  Also, releases of AIX prior
  55327. -     to AIX 3.2.4 include a version of the IBM assembler which does not
  55328. -     accept debugging directives: assembler updates are available as
  55329. -     PTFs.  Also, if you are using AIX 3.2.5 or greater and the GNU
  55330. -     assembler, you must have a version modified after October 16th,
  55331. -     1995 in order for the GNU C compiler to build.  See the file
  55332. -     `README.RS6000' for more details on of these problems.
  55333. -
  55334. -     GNU CC does not yet support the 64-bit PowerPC instructions.
  55335. -
  55336. -     Objective C does not work on this architecture because it makes
  55337. -     assumptions that are incompatible with the calling conventions.
  55338. -
  55339. -     AIX on the RS/6000 provides support (NLS) for environments outside
  55340. -     of the United States.  Compilers and assemblers use NLS to support
  55341. -     locale-specific representations of various objects including
  55342. -     floating-point numbers ("." vs "," for separating decimal
  55343. -     fractions).  There have been problems reported where the library
  55344. -     linked with GNU CC does not produce the same floating-point
  55345. -     formats that the assembler accepts.  If you have this problem, set
  55346. -     the LANG environment variable to "C" or "En_US".
  55347. -
  55348. -     Due to changes in the way that GNU CC invokes the binder (linker)
  55349. -     for AIX 4.1, you may now receive warnings of duplicate symbols
  55350. -     from the link step that were not reported before.  The assembly
  55351. -     files generated by GNU CC for AIX have always included multiple
  55352. -     symbol definitions for certain global variable and function
  55353. -     declarations in the original program.  The warnings should not
  55354. -     prevent the linker from producing a correct library or runnable
  55355. -     executable.
  55356. -
  55357. -`powerpc-*-elf'
  55358. -`powerpc-*-sysv4'
  55359. -     PowerPC system in big endian mode, running System V.4.
  55360. -
  55361. -     This configuration is currently under development.
  55362. -
  55363. -`powerpc-*-eabiaix'
  55364. -     Embedded PowerPC system in big endian mode with -mcall-aix
  55365. -     selected as the default.  This system is currently under
  55366. -     development.
  55367. -
  55368. -`powerpc-*-eabisim'
  55369. -     Embedded PowerPC system in big endian mode for use in running
  55370. -     under the PSIM simulator.  This system is currently under
  55371. -     development.
  55372. -
  55373. -`powerpc-*-eabi'
  55374. -     Embedded PowerPC system in big endian mode.
  55375. -
  55376. -     This configuration is currently under development.
  55377. -
  55378. -`powerpcle-*-elf'
  55379. -`powerpcle-*-sysv4'
  55380. -     PowerPC system in little endian mode, running System V.4.
  55381. -
  55382. -     This configuration is currently under development.
  55383. -
  55384. -`powerpcle-*-sysv4'
  55385. -     Embedded PowerPC system in little endian mode.
  55386. -
  55387. -     This system is currently under development.
  55388. -
  55389. -`powerpcle-*-eabisim'
  55390. -     Embedded PowerPC system in little endian mode for use in running
  55391. -     under the PSIM simulator.
  55392. -
  55393. -     This system is currently under development.
  55394. -
  55395. -`powerpcle-*-eabi'
  55396. -     Embedded PowerPC system in little endian mode.
  55397. -
  55398. -     This configuration is currently under development.
  55399. -
  55400. -`vax-dec-ultrix'
  55401. -     Don't try compiling with Vax C (`vcc').  It produces incorrect code
  55402. -     in some cases (for example, when `alloca' is used).
  55403. -
  55404. -     Meanwhile, compiling `cp/parse.c' with pcc does not work because of
  55405. -     an internal table size limitation in that compiler.  To avoid this
  55406. -     problem, compile just the GNU C compiler first, and use it to
  55407. -     recompile building all the languages that you want to run.
  55408. -
  55409. -`sparc-sun-*'
  55410. -     See *Note Sun Install::, for information on installing GNU CC on
  55411. -     Sun systems.
  55412. -
  55413. -`vax-dec-vms'
  55414. -     See *Note VMS Install::, for details on how to install GNU CC on
  55415. -     VMS.
  55416. -
  55417. -`we32k-*-*'
  55418. -     These computers are also known as the 3b2, 3b5, 3b20 and other
  55419. -     similar names.  (However, the 3b1 is actually a 68000; see *Note
  55420. -     Configurations::.)
  55421. -
  55422. -     Don't use `-g' when compiling with the system's compiler.  The
  55423. -     system's linker seems to be unable to handle such a large program
  55424. -     with debugging information.
  55425. -
  55426. -     The system's compiler runs out of capacity when compiling `stmt.c'
  55427. -     in GNU CC.  You can work around this by building `cpp' in GNU CC
  55428. -     first, then use that instead of the system's preprocessor with the
  55429. -     system's C compiler to compile `stmt.c'.  Here is how:
  55430. -
  55431. -          mv /lib/cpp /lib/cpp.att
  55432. -          cp cpp /lib/cpp.gnu
  55433. -          echo '/lib/cpp.gnu -traditional ${1+"$@"}' > /lib/cpp
  55434. -          chmod +x /lib/cpp
  55435. -
  55436. -     The system's compiler produces bad code for some of the GNU CC
  55437. -     optimization files.  So you must build the stage 2 compiler without
  55438. -     optimization.  Then build a stage 3 compiler with optimization.
  55439. -     That executable should work.  Here are the necessary commands:
  55440. -
  55441. -          make LANGUAGES=c CC=stage1/xgcc CFLAGS="-Bstage1/ -g"
  55442. -          make stage2
  55443. -          make CC=stage2/xgcc CFLAGS="-Bstage2/ -g -O"
  55444. -
  55445. -     You may need to raise the ULIMIT setting to build a C++ compiler,
  55446. -     as the file `cc1plus' is larger than one megabyte.
  55447. -
  55448. -
  55449. -File: gcc.info,  Node: Other Dir,  Next: Cross-Compiler,  Prev: Configurations,  Up: Installation
  55450. -
  55451. -Compilation in a Separate Directory
  55452. -===================================
  55453. -
  55454. -   If you wish to build the object files and executables in a directory
  55455. -other than the one containing the source files, here is what you must
  55456. -do differently:
  55457. -
  55458. -  1. Make sure you have a version of Make that supports the `VPATH'
  55459. -     feature.  (GNU Make supports it, as do Make versions on most BSD
  55460. -     systems.)
  55461. -
  55462. -  2. If you have ever run `configure' in the source directory, you must
  55463. -     undo the configuration.  Do this by running:
  55464. -
  55465. -          make distclean
  55466. -
  55467. -  3. Go to the directory in which you want to build the compiler before
  55468. -     running `configure':
  55469. -
  55470. -          mkdir gcc-sun3
  55471. -          cd gcc-sun3
  55472. -
  55473. -     On systems that do not support symbolic links, this directory must
  55474. -     be on the same file system as the source code directory.
  55475. -
  55476. -  4. Specify where to find `configure' when you run it:
  55477. -
  55478. -          ../gcc/configure ...
  55479. -
  55480. -     This also tells `configure' where to find the compiler sources;
  55481. -     `configure' takes the directory from the file name that was used to
  55482. -     invoke it.  But if you want to be sure, you can specify the source
  55483. -     directory with the `--srcdir' option, like this:
  55484. -
  55485. -          ../gcc/configure --srcdir=../gcc OTHER OPTIONS
  55486. -
  55487. -     The directory you specify with `--srcdir' need not be the same as
  55488. -     the one that `configure' is found in.
  55489. -
  55490. -   Now, you can run `make' in that directory.  You need not repeat the
  55491. -configuration steps shown above, when ordinary source files change.  You
  55492. -must, however, run `configure' again when the configuration files
  55493. -change, if your system does not support symbolic links.
  55494. -
  55495. -
  55496. -File: gcc.info,  Node: Cross-Compiler,  Next: Sun Install,  Prev: Other Dir,  Up: Installation
  55497. -
  55498. -Building and Installing a Cross-Compiler
  55499. -========================================
  55500. -
  55501. -   GNU CC can function as a cross-compiler for many machines, but not
  55502. -all.
  55503. -
  55504. -   * Cross-compilers for the Mips as target using the Mips assembler
  55505. -     currently do not work, because the auxiliary programs
  55506. -     `mips-tdump.c' and `mips-tfile.c' can't be compiled on anything
  55507. -     but a Mips.  It does work to cross compile for a Mips if you use
  55508. -     the GNU assembler and linker.
  55509. -
  55510. -   * Cross-compilers between machines with different floating point
  55511. -     formats have not all been made to work.  GNU CC now has a floating
  55512. -     point emulator with which these can work, but each target machine
  55513. -     description needs to be updated to take advantage of it.
  55514. -
  55515. -   * Cross-compilation between machines of different word sizes is
  55516. -     somewhat problematic and sometimes does not work.
  55517. -
  55518. -   Since GNU CC generates assembler code, you probably need a
  55519. -cross-assembler that GNU CC can run, in order to produce object files.
  55520. -If you want to link on other than the target machine, you need a
  55521. -cross-linker as well.  You also need header files and libraries suitable
  55522. -for the target machine that you can install on the host machine.
  55523. -
  55524. -* Menu:
  55525. -
  55526. -* Steps of Cross::      Using a cross-compiler involves several steps
  55527. -                          that may be carried out on different machines.
  55528. -* Configure Cross::     Configuring a cross-compiler.
  55529. -* Tools and Libraries:: Where to put the linker and assembler, and the C library.
  55530. -* Cross Headers::       Finding and installing header files
  55531. -                          for a cross-compiler.
  55532. -* Cross Runtime::       Supplying arithmetic runtime routines (`libgcc1.a').
  55533. -* Build Cross::         Actually compiling the cross-compiler.
  55534. -
  55535. -
  55536. -File: gcc.info,  Node: Steps of Cross,  Next: Configure Cross,  Up: Cross-Compiler
  55537. -
  55538. -Steps of Cross-Compilation
  55539. ---------------------------
  55540. -
  55541. -   To compile and run a program using a cross-compiler involves several
  55542. -steps:
  55543. -
  55544. -   * Run the cross-compiler on the host machine to produce assembler
  55545. -     files for the target machine.  This requires header files for the
  55546. -     target machine.
  55547. -
  55548. -   * Assemble the files produced by the cross-compiler.  You can do this
  55549. -     either with an assembler on the target machine, or with a
  55550. -     cross-assembler on the host machine.
  55551. -
  55552. -   * Link those files to make an executable.  You can do this either
  55553. -     with a linker on the target machine, or with a cross-linker on the
  55554. -     host machine.  Whichever machine you use, you need libraries and
  55555. -     certain startup files (typically `crt....o') for the target
  55556. -     machine.
  55557. -
  55558. -   It is most convenient to do all of these steps on the same host
  55559. -machine, since then you can do it all with a single invocation of GNU
  55560. -CC.  This requires a suitable cross-assembler and cross-linker.  For
  55561. -some targets, the GNU assembler and linker are available.
  55562. -
  55563. -
  55564. -File: gcc.info,  Node: Configure Cross,  Next: Tools and Libraries,  Prev: Steps of Cross,  Up: Cross-Compiler
  55565. -
  55566. -Configuring a Cross-Compiler
  55567. -----------------------------
  55568. -
  55569. -   To build GNU CC as a cross-compiler, you start out by running
  55570. -`configure'.  Use the `--target=TARGET' to specify the target type.  If
  55571. -`configure' was unable to correctly identify the system you are running
  55572. -on, also specify the `--build=BUILD' option.  For example, here is how
  55573. -to configure for a cross-compiler that produces code for an HP 68030
  55574. -system running BSD on a system that `configure' can correctly identify:
  55575. -
  55576. -     ./configure --target=m68k-hp-bsd4.3
  55577. -
  55578. -
  55579. -File: gcc.info,  Node: Tools and Libraries,  Next: Cross Headers,  Prev: Configure Cross,  Up: Cross-Compiler
  55580. -
  55581. -Tools and Libraries for a Cross-Compiler
  55582. -----------------------------------------
  55583. -
  55584. -   If you have a cross-assembler and cross-linker available, you should
  55585. -install them now.  Put them in the directory `/usr/local/TARGET/bin'.
  55586. -Here is a table of the tools you should put in this directory:
  55587. -
  55588. -`as'
  55589. -     This should be the cross-assembler.
  55590. -
  55591. -`ld'
  55592. -     This should be the cross-linker.
  55593. -
  55594. -`ar'
  55595. -     This should be the cross-archiver: a program which can manipulate
  55596. -     archive files (linker libraries) in the target machine's format.
  55597. -
  55598. -`ranlib'
  55599. -     This should be a program to construct a symbol table in an archive
  55600. -     file.
  55601. -
  55602. -   The installation of GNU CC will find these programs in that
  55603. -directory, and copy or link them to the proper place to for the
  55604. -cross-compiler to find them when run later.
  55605. -
  55606. -   The easiest way to provide these files is to build the Binutils
  55607. -package and GAS.  Configure them with the same `--host' and `--target'
  55608. -options that you use for configuring GNU CC, then build and install
  55609. -them.  They install their executables automatically into the proper
  55610. -directory.  Alas, they do not support all the targets that GNU CC
  55611. -supports.
  55612. -
  55613. -   If you want to install libraries to use with the cross-compiler,
  55614. -such as a standard C library, put them in the directory
  55615. -`/usr/local/TARGET/lib'; installation of GNU CC copies all all the
  55616. -files in that subdirectory into the proper place for GNU CC to find
  55617. -them and link with them.  Here's an example of copying some libraries
  55618. -from a target machine:
  55619. -
  55620. -     ftp TARGET-MACHINE
  55621. -     lcd /usr/local/TARGET/lib
  55622. -     cd /lib
  55623. -     get libc.a
  55624. -     cd /usr/lib
  55625. -     get libg.a
  55626. -     get libm.a
  55627. -     quit
  55628. -
  55629. -The precise set of libraries you'll need, and their locations on the
  55630. -target machine, vary depending on its operating system.
  55631. -
  55632. -   Many targets require "start files" such as `crt0.o' and `crtn.o'
  55633. -which are linked into each executable; these too should be placed in
  55634. -`/usr/local/TARGET/lib'.  There may be several alternatives for
  55635. -`crt0.o', for use with profiling or other compilation options.  Check
  55636. -your target's definition of `STARTFILE_SPEC' to find out what start
  55637. -files it uses.  Here's an example of copying these files from a target
  55638. -machine:
  55639. -
  55640. -     ftp TARGET-MACHINE
  55641. -     lcd /usr/local/TARGET/lib
  55642. -     prompt
  55643. -     cd /lib
  55644. -     mget *crt*.o
  55645. -     cd /usr/lib
  55646. -     mget *crt*.o
  55647. -     quit
  55648. -
  55649. -
  55650. -File: gcc.info,  Node: Cross Runtime,  Next: Build Cross,  Prev: Cross Headers,  Up: Cross-Compiler
  55651. -
  55652. -`libgcc.a' and Cross-Compilers
  55653. -------------------------------
  55654. -
  55655. -   Code compiled by GNU CC uses certain runtime support functions
  55656. -implicitly.  Some of these functions can be compiled successfully with
  55657. -GNU CC itself, but a few cannot be.  These problem functions are in the
  55658. -source file `libgcc1.c'; the library made from them is called
  55659. -`libgcc1.a'.
  55660. -
  55661. -   When you build a native compiler, these functions are compiled with
  55662. -some other compiler-the one that you use for bootstrapping GNU CC.
  55663. -Presumably it knows how to open code these operations, or else knows how
  55664. -to call the run-time emulation facilities that the machine comes with.
  55665. -But this approach doesn't work for building a cross-compiler.  The
  55666. -compiler that you use for building knows about the host system, not the
  55667. -target system.
  55668. -
  55669. -   So, when you build a cross-compiler you have to supply a suitable
  55670. -library `libgcc1.a' that does the job it is expected to do.
  55671. -
  55672. -   To compile `libgcc1.c' with the cross-compiler itself does not work.
  55673. -The functions in this file are supposed to implement arithmetic
  55674. -operations that GNU CC does not know how to open code for your target
  55675. -machine.  If these functions are compiled with GNU CC itself, they will
  55676. -compile into infinite recursion.
  55677. -
  55678. -   On any given target, most of these functions are not needed.  If GNU
  55679. -CC can open code an arithmetic operation, it will not call these
  55680. -functions to perform the operation.  It is possible that on your target
  55681. -machine, none of these functions is needed.  If so, you can supply an
  55682. -empty library as `libgcc1.a'.
  55683. -
  55684. -   Many targets need library support only for multiplication and
  55685. -division.  If you are linking with a library that contains functions for
  55686. -multiplication and division, you can tell GNU CC to call them directly
  55687. -by defining the macros `MULSI3_LIBCALL', and the like.  These macros
  55688. -need to be defined in the target description macro file.  For some
  55689. -targets, they are defined already.  This may be sufficient to avoid the
  55690. -need for libgcc1.a; if so, you can supply an empty library.
  55691. -
  55692. -   Some targets do not have floating point instructions; they need other
  55693. -functions in `libgcc1.a', which do floating arithmetic.  Recent
  55694. -versions of GNU CC have a file which emulates floating point.  With a
  55695. -certain amount of work, you should be able to construct a floating
  55696. -point emulator that can be used as `libgcc1.a'.  Perhaps future
  55697. -versions will contain code to do this automatically and conveniently.
  55698. -That depends on whether someone wants to implement it.
  55699. -
  55700. -   Some embedded targets come with all the necessary `libgcc1.a'
  55701. -routines written in C or assembler.  These targets build `libgcc1.a'
  55702. -automatically and you do not need to do anything special for them.
  55703. -Other embedded targets do not need any `libgcc1.a' routines since all
  55704. -the necessary operations are supported by the hardware.
  55705. -
  55706. -   If your target system has another C compiler, you can configure GNU
  55707. -CC as a native compiler on that machine, build just `libgcc1.a' with
  55708. -`make libgcc1.a' on that machine, and use the resulting file with the
  55709. -cross-compiler.  To do this, execute the following on the target
  55710. -machine:
  55711. -
  55712. -     cd TARGET-BUILD-DIR
  55713. -     ./configure --host=sparc --target=sun3
  55714. -     make libgcc1.a
  55715. -
  55716. -And then this on the host machine:
  55717. -
  55718. -     ftp TARGET-MACHINE
  55719. -     binary
  55720. -     cd TARGET-BUILD-DIR
  55721. -     get libgcc1.a
  55722. -     quit
  55723. -
  55724. -   Another way to provide the functions you need in `libgcc1.a' is to
  55725. -define the appropriate `perform_...' macros for those functions.  If
  55726. -these definitions do not use the C arithmetic operators that they are
  55727. -meant to implement, you should be able to compile them with the
  55728. -cross-compiler you are building.  (If these definitions already exist
  55729. -for your target file, then you are all set.)
  55730. -
  55731. -   To build `libgcc1.a' using the perform macros, use
  55732. -`LIBGCC1=libgcc1.a OLDCC=./xgcc' when building the compiler.
  55733. -Otherwise, you should place your replacement library under the name
  55734. -`libgcc1.a' in the directory in which you will build the
  55735. -cross-compiler, before you run `make'.
  55736. -
  55737. -
  55738. -File: gcc.info,  Node: Cross Headers,  Next: Cross Runtime,  Prev: Tools and Libraries,  Up: Cross-Compiler
  55739. -
  55740. -Cross-Compilers and Header Files
  55741. ---------------------------------
  55742. -
  55743. -   If you are cross-compiling a standalone program or a program for an
  55744. -embedded system, then you may not need any header files except the few
  55745. -that are part of GNU CC (and those of your program).  However, if you
  55746. -intend to link your program with a standard C library such as `libc.a',
  55747. -then you probably need to compile with the header files that go with
  55748. -the library you use.
  55749. -
  55750. -   The GNU C compiler does not come with these files, because (1) they
  55751. -are system-specific, and (2) they belong in a C library, not in a
  55752. -compiler.
  55753. -
  55754. -   If the GNU C library supports your target machine, then you can get
  55755. -the header files from there (assuming you actually use the GNU library
  55756. -when you link your program).
  55757. -
  55758. -   If your target machine comes with a C compiler, it probably comes
  55759. -with suitable header files also.  If you make these files accessible
  55760. -from the host machine, the cross-compiler can use them also.
  55761. -
  55762. -   Otherwise, you're on your own in finding header files to use when
  55763. -cross-compiling.
  55764. -
  55765. -   When you have found suitable header files, put them in
  55766. -`/usr/local/TARGET/include', before building the cross compiler.  Then
  55767. -installation will run fixincludes properly and install the corrected
  55768. -versions of the header files where the compiler will use them.
  55769. -
  55770. -   Provide the header files before you build the cross-compiler, because
  55771. -the build stage actually runs the cross-compiler to produce parts of
  55772. -`libgcc.a'.  (These are the parts that *can* be compiled with GNU CC.)
  55773. -Some of them need suitable header files.
  55774. -
  55775. -   Here's an example showing how to copy the header files from a target
  55776. -machine.  On the target machine, do this:
  55777. -
  55778. -     (cd /usr/include; tar cf - .) > tarfile
  55779. -
  55780. -   Then, on the host machine, do this:
  55781. -
  55782. -     ftp TARGET-MACHINE
  55783. -     lcd /usr/local/TARGET/include
  55784. -     get tarfile
  55785. -     quit
  55786. -     tar xf tarfile
  55787. -
  55788. diff -rup --new-file baseline/fsf/gcc/gcc.info-8 amiga/fsf/gcc/gcc.info-8
  55789. --- baseline/fsf/gcc/gcc.info-8    Sat Jun 29 09:37:59 1996
  55790. +++ amiga/fsf/gcc/gcc.info-8    Wed Dec 31 17:00:00 1969
  55791. @@ -1,1225 +0,0 @@
  55792. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  55793. -file gcc.texi.
  55794. -
  55795. -   This file documents the use and the internals of the GNU compiler.
  55796. -
  55797. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  55798. -Boston, MA 02111-1307 USA
  55799. -
  55800. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  55801. -Foundation, Inc.
  55802. -
  55803. -   Permission is granted to make and distribute verbatim copies of this
  55804. -manual provided the copyright notice and this permission notice are
  55805. -preserved on all copies.
  55806. -
  55807. -   Permission is granted to copy and distribute modified versions of
  55808. -this manual under the conditions for verbatim copying, provided also
  55809. -that the sections entitled "GNU General Public License," "Funding for
  55810. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  55811. -included exactly as in the original, and provided that the entire
  55812. -resulting derived work is distributed under the terms of a permission
  55813. -notice identical to this one.
  55814. -
  55815. -   Permission is granted to copy and distribute translations of this
  55816. -manual into another language, under the above conditions for modified
  55817. -versions, except that the sections entitled "GNU General Public
  55818. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  55819. -`Look And Feel'", and this permission notice, may be included in
  55820. -translations approved by the Free Software Foundation instead of in the
  55821. -original English.
  55822. -
  55823. -
  55824. -File: gcc.info,  Node: Build Cross,  Prev: Cross Runtime,  Up: Cross-Compiler
  55825. -
  55826. -Actually Building the Cross-Compiler
  55827. -------------------------------------
  55828. -
  55829. -   Now you can proceed just as for compiling a single-machine compiler
  55830. -through the step of building stage 1.  If you have not provided some
  55831. -sort of `libgcc1.a', then compilation will give up at the point where
  55832. -it needs that file, printing a suitable error message.  If you do
  55833. -provide `libgcc1.a', then building the compiler will automatically
  55834. -compile and link a test program called `libgcc1-test'; if you get
  55835. -errors in the linking, it means that not all of the necessary routines
  55836. -in `libgcc1.a' are available.
  55837. -
  55838. -   You must provide the header file `float.h'.  One way to do this is
  55839. -to compile `enquire' and run it on your target machine.  The job of
  55840. -`enquire' is to run on the target machine and figure out by experiment
  55841. -the nature of its floating point representation.  `enquire' records its
  55842. -findings in the header file `float.h'.  If you can't produce this file
  55843. -by running `enquire' on the target machine, then you will need to come
  55844. -up with a suitable `float.h' in some other way (or else, avoid using it
  55845. -in your programs).
  55846. -
  55847. -   Do not try to build stage 2 for a cross-compiler.  It doesn't work to
  55848. -rebuild GNU CC as a cross-compiler using the cross-compiler, because
  55849. -that would produce a program that runs on the target machine, not on the
  55850. -host.  For example, if you compile a 386-to-68030 cross-compiler with
  55851. -itself, the result will not be right either for the 386 (because it was
  55852. -compiled into 68030 code) or for the 68030 (because it was configured
  55853. -for a 386 as the host).  If you want to compile GNU CC into 68030 code,
  55854. -whether you compile it on a 68030 or with a cross-compiler on a 386, you
  55855. -must specify a 68030 as the host when you configure it.
  55856. -
  55857. -   To install the cross-compiler, use `make install', as usual.
  55858. -
  55859. -
  55860. -File: gcc.info,  Node: Sun Install,  Next: VMS Install,  Prev: Cross-Compiler,  Up: Installation
  55861. -
  55862. -Installing GNU CC on the Sun
  55863. -============================
  55864. -
  55865. -   On Solaris (version 2.1), do not use the linker or other tools in
  55866. -`/usr/ucb' to build GNU CC.  Use `/usr/ccs/bin'.
  55867. -
  55868. -   Make sure the environment variable `FLOAT_OPTION' is not set when
  55869. -you compile `libgcc.a'.  If this option were set to `f68881' when
  55870. -`libgcc.a' is compiled, the resulting code would demand to be linked
  55871. -with a special startup file and would not link properly without special
  55872. -pains.
  55873. -
  55874. -   There is a bug in `alloca' in certain versions of the Sun library.
  55875. -To avoid this bug, install the binaries of GNU CC that were compiled by
  55876. -GNU CC.  They use `alloca' as a built-in function and never the one in
  55877. -the library.
  55878. -
  55879. -   Some versions of the Sun compiler crash when compiling GNU CC.  The
  55880. -problem is a segmentation fault in cpp.  This problem seems to be due to
  55881. -the bulk of data in the environment variables.  You may be able to avoid
  55882. -it by using the following command to compile GNU CC with Sun CC:
  55883. -
  55884. -     make CC="TERMCAP=x OBJS=x LIBFUNCS=x STAGESTUFF=x cc"
  55885. -
  55886. -
  55887. -File: gcc.info,  Node: VMS Install,  Next: Collect2,  Prev: Sun Install,  Up: Installation
  55888. -
  55889. -Installing GNU CC on VMS
  55890. -========================
  55891. -
  55892. -   The VMS version of GNU CC is distributed in a backup saveset
  55893. -containing both source code and precompiled binaries.
  55894. -
  55895. -   To install the `gcc' command so you can use the compiler easily, in
  55896. -the same manner as you use the VMS C compiler, you must install the VMS
  55897. -CLD file for GNU CC as follows:
  55898. -
  55899. -  1. Define the VMS logical names `GNU_CC' and `GNU_CC_INCLUDE' to
  55900. -     point to the directories where the GNU CC executables
  55901. -     (`gcc-cpp.exe', `gcc-cc1.exe', etc.) and the C include files are
  55902. -     kept respectively.  This should be done with the commands:
  55903. -
  55904. -          $ assign /system /translation=concealed -
  55905. -            disk:[gcc.] gnu_cc
  55906. -          $ assign /system /translation=concealed -
  55907. -            disk:[gcc.include.] gnu_cc_include
  55908. -
  55909. -     with the appropriate disk and directory names.  These commands can
  55910. -     be placed in your system startup file so they will be executed
  55911. -     whenever the machine is rebooted.  You may, if you choose, do this
  55912. -     via the `GCC_INSTALL.COM' script in the `[GCC]' directory.
  55913. -
  55914. -  2. Install the `GCC' command with the command line:
  55915. -
  55916. -          $ set command /table=sys$common:[syslib]dcltables -
  55917. -            /output=sys$common:[syslib]dcltables gnu_cc:[000000]gcc
  55918. -          $ install replace sys$common:[syslib]dcltables
  55919. -
  55920. -  3. To install the help file, do the following:
  55921. -
  55922. -          $ library/help sys$library:helplib.hlb gcc.hlp
  55923. -
  55924. -     Now you can invoke the compiler with a command like `gcc /verbose
  55925. -     file.c', which is equivalent to the command `gcc -v -c file.c' in
  55926. -     Unix.
  55927. -
  55928. -   If you wish to use GNU C++ you must first install GNU CC, and then
  55929. -perform the following steps:
  55930. -
  55931. -  1. Define the VMS logical name `GNU_GXX_INCLUDE' to point to the
  55932. -     directory where the preprocessor will search for the C++ header
  55933. -     files.  This can be done with the command:
  55934. -
  55935. -          $ assign /system /translation=concealed -
  55936. -            disk:[gcc.gxx_include.] gnu_gxx_include
  55937. -
  55938. -     with the appropriate disk and directory name.  If you are going to
  55939. -     be using libg++, this is where the libg++ install procedure will
  55940. -     install the libg++ header files.
  55941. -
  55942. -  2. Obtain the file `gcc-cc1plus.exe', and place this in the same
  55943. -     directory that `gcc-cc1.exe' is kept.
  55944. -
  55945. -     The GNU C++ compiler can be invoked with a command like `gcc /plus
  55946. -     /verbose file.cc', which is equivalent to the command `g++ -v -c
  55947. -     file.cc' in Unix.
  55948. -
  55949. -   We try to put corresponding binaries and sources on the VMS
  55950. -distribution tape.  But sometimes the binaries will be from an older
  55951. -version than the sources, because we don't always have time to update
  55952. -them.  (Use the `/version' option to determine the version number of
  55953. -the binaries and compare it with the source file `version.c' to tell
  55954. -whether this is so.)  In this case, you should use the binaries you get
  55955. -to recompile the sources.  If you must recompile, here is how:
  55956. -
  55957. -  1. Execute the command procedure `vmsconfig.com' to set up the files
  55958. -     `tm.h', `config.h', `aux-output.c', and `md.', and to create files
  55959. -     `tconfig.h' and `hconfig.h'.  This procedure also creates several
  55960. -     linker option files used by `make-cc1.com' and a data file used by
  55961. -     `make-l2.com'.
  55962. -
  55963. -          $ @vmsconfig.com
  55964. -
  55965. -  2. Setup the logical names and command tables as defined above.  In
  55966. -     addition, define the VMS logical name `GNU_BISON' to point at the
  55967. -     to the directories where the Bison executable is kept.  This
  55968. -     should be done with the command:
  55969. -
  55970. -          $ assign /system /translation=concealed -
  55971. -            disk:[bison.] gnu_bison
  55972. -
  55973. -     You may, if you choose, use the `INSTALL_BISON.COM' script in the
  55974. -     `[BISON]' directory.
  55975. -
  55976. -  3. Install the `BISON' command with the command line:
  55977. -
  55978. -          $ set command /table=sys$common:[syslib]dcltables -
  55979. -            /output=sys$common:[syslib]dcltables -
  55980. -            gnu_bison:[000000]bison
  55981. -          $ install replace sys$common:[syslib]dcltables
  55982. -
  55983. -  4. Type `@make-gcc' to recompile everything (alternatively, submit
  55984. -     the file `make-gcc.com' to a batch queue).  If you wish to build
  55985. -     the GNU C++ compiler as well as the GNU CC compiler, you must
  55986. -     first edit `make-gcc.com' and follow the instructions that appear
  55987. -     in the comments.
  55988. -
  55989. -  5. In order to use GCC, you need a library of functions which GCC
  55990. -     compiled code will call to perform certain tasks, and these
  55991. -     functions are defined in the file `libgcc2.c'.  To compile this
  55992. -     you should use the command procedure `make-l2.com', which will
  55993. -     generate the library `libgcc2.olb'.  `libgcc2.olb' should be built
  55994. -     using the compiler built from the same distribution that
  55995. -     `libgcc2.c' came from, and `make-gcc.com' will automatically do
  55996. -     all of this for you.
  55997. -
  55998. -     To install the library, use the following commands:
  55999. -
  56000. -          $ library gnu_cc:[000000]gcclib/delete=(new,eprintf)
  56001. -          $ library gnu_cc:[000000]gcclib/delete=L_*
  56002. -          $ library libgcc2/extract=*/output=libgcc2.obj
  56003. -          $ library gnu_cc:[000000]gcclib libgcc2.obj
  56004. -
  56005. -     The first command simply removes old modules that will be replaced
  56006. -     with modules from `libgcc2' under different module names.  The
  56007. -     modules `new' and `eprintf' may not actually be present in your
  56008. -     `gcclib.olb'--if the VMS librarian complains about those modules
  56009. -     not being present, simply ignore the message and continue on with
  56010. -     the next command.  The second command removes the modules that
  56011. -     came from the previous version of the library `libgcc2.c'.
  56012. -
  56013. -     Whenever you update the compiler on your system, you should also
  56014. -     update the library with the above procedure.
  56015. -
  56016. -  6. You may wish to build GCC in such a way that no files are written
  56017. -     to the directory where the source files reside.  An example would
  56018. -     be the when the source files are on a read-only disk.  In these
  56019. -     cases, execute the following DCL commands (substituting your
  56020. -     actual path names):
  56021. -
  56022. -          $ assign dua0:[gcc.build_dir.]/translation=concealed, -
  56023. -                   dua1:[gcc.source_dir.]/translation=concealed  gcc_build
  56024. -          $ set default gcc_build:[000000]
  56025. -
  56026. -     where the directory `dua1:[gcc.source_dir]' contains the source
  56027. -     code, and the directory `dua0:[gcc.build_dir]' is meant to contain
  56028. -     all of the generated object files and executables.  Once you have
  56029. -     done this, you can proceed building GCC as described above.  (Keep
  56030. -     in mind that `gcc_build' is a rooted logical name, and thus the
  56031. -     device names in each element of the search list must be an actual
  56032. -     physical device name rather than another rooted logical name).
  56033. -
  56034. -  7. *If you are building GNU CC with a previous version of GNU CC, you
  56035. -     also should check to see that you have the newest version of the
  56036. -     assembler*.  In particular, GNU CC version 2 treats global constant
  56037. -     variables slightly differently from GNU CC version 1, and GAS
  56038. -     version 1.38.1 does not have the patches required to work with GCC
  56039. -     version 2.  If you use GAS 1.38.1, then `extern const' variables
  56040. -     will not have the read-only bit set, and the linker will generate
  56041. -     warning messages about mismatched psect attributes for these
  56042. -     variables.  These warning messages are merely a nuisance, and can
  56043. -     safely be ignored.
  56044. -
  56045. -     If you are compiling with a version of GNU CC older than 1.33,
  56046. -     specify `/DEFINE=("inline=")' as an option in all the
  56047. -     compilations.  This requires editing all the `gcc' commands in
  56048. -     `make-cc1.com'.  (The older versions had problems supporting
  56049. -     `inline'.)  Once you have a working 1.33 or newer GNU CC, you can
  56050. -     change this file back.
  56051. -
  56052. -  8. If you want to build GNU CC with the VAX C compiler, you will need
  56053. -     to make minor changes in `make-cccp.com' and `make-cc1.com' to
  56054. -     choose alternate definitions of `CC', `CFLAGS', and `LIBS'.  See
  56055. -     comments in those files.  However, you must also have a working
  56056. -     version of the GNU assembler (GNU as, aka GAS) as it is used as
  56057. -     the back-end for GNU CC to produce binary object modules and is
  56058. -     not included in the GNU CC sources.  GAS is also needed to compile
  56059. -     `libgcc2' in order to build `gcclib' (see above); `make-l2.com'
  56060. -     expects to be able to find it operational in
  56061. -     `gnu_cc:[000000]gnu-as.exe'.
  56062. -
  56063. -     To use GNU CC on VMS, you need the VMS driver programs `gcc.exe',
  56064. -     `gcc.com', and `gcc.cld'.  They are distributed with the VMS
  56065. -     binaries (`gcc-vms') rather than the GNU CC sources.  GAS is also
  56066. -     included in `gcc-vms', as is Bison.
  56067. -
  56068. -     Once you have successfully built GNU CC with VAX C, you should use
  56069. -     the resulting compiler to rebuild itself.  Before doing this, be
  56070. -     sure to restore the `CC', `CFLAGS', and `LIBS' definitions in
  56071. -     `make-cccp.com' and `make-cc1.com'.  The second generation
  56072. -     compiler will be able to take advantage of many optimizations that
  56073. -     must be suppressed when building with other compilers.
  56074. -
  56075. -   Under previous versions of GNU CC, the generated code would
  56076. -occasionally give strange results when linked with the sharable
  56077. -`VAXCRTL' library.  Now this should work.
  56078. -
  56079. -   Even with this version, however, GNU CC itself should not be linked
  56080. -with the sharable `VAXCRTL'.  The version of `qsort' in `VAXCRTL' has a
  56081. -bug (known to be present in VMS versions V4.6 through V5.5) which
  56082. -causes the compiler to fail.
  56083. -
  56084. -   The executables are generated by `make-cc1.com' and `make-cccp.com'
  56085. -use the object library version of `VAXCRTL' in order to make use of the
  56086. -`qsort' routine in `gcclib.olb'.  If you wish to link the compiler
  56087. -executables with the shareable image version of `VAXCRTL', you should
  56088. -edit the file `tm.h' (created by `vmsconfig.com') to define the macro
  56089. -`QSORT_WORKAROUND'.
  56090. -
  56091. -   `QSORT_WORKAROUND' is always defined when GNU CC is compiled with
  56092. -VAX C, to avoid a problem in case `gcclib.olb' is not yet available.
  56093. -
  56094. -
  56095. -File: gcc.info,  Node: Collect2,  Next: Header Dirs,  Prev: VMS Install,  Up: Installation
  56096. -
  56097. -`collect2'
  56098. -==========
  56099. -
  56100. -   Many target systems do not have support in the assembler and linker
  56101. -for "constructors"--initialization functions to be called before the
  56102. -official "start" of `main'.  On such systems, GNU CC uses a utility
  56103. -called `collect2' to arrange to call these functions at start time.
  56104. -
  56105. -   The program `collect2' works by linking the program once and looking
  56106. -through the linker output file for symbols with particular names
  56107. -indicating they are constructor functions.  If it finds any, it creates
  56108. -a new temporary `.c' file containing a table of them, compiles it, and
  56109. -links the program a second time including that file.
  56110. -
  56111. -   The actual calls to the constructors are carried out by a subroutine
  56112. -called `__main', which is called (automatically) at the beginning of
  56113. -the body of `main' (provided `main' was compiled with GNU CC).  Calling
  56114. -`__main' is necessary, even when compiling C code, to allow linking C
  56115. -and C++ object code together.  (If you use `-nostdlib', you get an
  56116. -unresolved reference to `__main', since it's defined in the standard
  56117. -GCC library.  Include `-lgcc' at the end of your compiler command line
  56118. -to resolve this reference.)
  56119. -
  56120. -   The program `collect2' is installed as `ld' in the directory where
  56121. -the passes of the compiler are installed.  When `collect2' needs to
  56122. -find the *real* `ld', it tries the following file names:
  56123. -
  56124. -   * `real-ld' in the directories listed in the compiler's search
  56125. -     directories.
  56126. -
  56127. -   * `real-ld' in the directories listed in the environment variable
  56128. -     `PATH'.
  56129. -
  56130. -   * The file specified in the `REAL_LD_FILE_NAME' configuration macro,
  56131. -     if specified.
  56132. -
  56133. -   * `ld' in the compiler's search directories, except that `collect2'
  56134. -     will not execute itself recursively.
  56135. -
  56136. -   * `ld' in `PATH'.
  56137. -
  56138. -   "The compiler's search directories" means all the directories where
  56139. -`gcc' searches for passes of the compiler.  This includes directories
  56140. -that you specify with `-B'.
  56141. -
  56142. -   Cross-compilers search a little differently:
  56143. -
  56144. -   * `real-ld' in the compiler's search directories.
  56145. -
  56146. -   * `TARGET-real-ld' in `PATH'.
  56147. -
  56148. -   * The file specified in the `REAL_LD_FILE_NAME' configuration macro,
  56149. -     if specified.
  56150. -
  56151. -   * `ld' in the compiler's search directories.
  56152. -
  56153. -   * `TARGET-ld' in `PATH'.
  56154. -
  56155. -   `collect2' explicitly avoids running `ld' using the file name under
  56156. -which `collect2' itself was invoked.  In fact, it remembers up a list
  56157. -of such names--in case one copy of `collect2' finds another copy (or
  56158. -version) of `collect2' installed as `ld' in a second place in the
  56159. -search path.
  56160. -
  56161. -   `collect2' searches for the utilities `nm' and `strip' using the
  56162. -same algorithm as above for `ld'.
  56163. -
  56164. -
  56165. -File: gcc.info,  Node: Header Dirs,  Prev: Collect2,  Up: Installation
  56166. -
  56167. -Standard Header File Directories
  56168. -================================
  56169. -
  56170. -   `GCC_INCLUDE_DIR' means the same thing for native and cross.  It is
  56171. -where GNU CC stores its private include files, and also where GNU CC
  56172. -stores the fixed include files.  A cross compiled GNU CC runs
  56173. -`fixincludes' on the header files in `$(tooldir)/include'.  (If the
  56174. -cross compilation header files need to be fixed, they must be installed
  56175. -before GNU CC is built.  If the cross compilation header files are
  56176. -already suitable for ANSI C and GNU CC, nothing special need be done).
  56177. -
  56178. -   `GPLUS_INCLUDE_DIR' means the same thing for native and cross.  It
  56179. -is where `g++' looks first for header files.  `libg++' installs only
  56180. -target independent header files in that directory.
  56181. -
  56182. -   `LOCAL_INCLUDE_DIR' is used only for a native compiler.  It is
  56183. -normally `/usr/local/include'.  GNU CC searches this directory so that
  56184. -users can install header files in `/usr/local/include'.
  56185. -
  56186. -   `CROSS_INCLUDE_DIR' is used only for a cross compiler.  GNU CC
  56187. -doesn't install anything there.
  56188. -
  56189. -   `TOOL_INCLUDE_DIR' is used for both native and cross compilers.  It
  56190. -is the place for other packages to install header files that GNU CC will
  56191. -use.  For a cross-compiler, this is the equivalent of `/usr/include'.
  56192. -When you build a cross-compiler, `fixincludes' processes any header
  56193. -files in this directory.
  56194. -
  56195. -
  56196. -File: gcc.info,  Node: C Extensions,  Next: C++ Extensions,  Prev: Installation,  Up: Top
  56197. -
  56198. -Extensions to the C Language Family
  56199. -***********************************
  56200. -
  56201. -   GNU C provides several language features not found in ANSI standard
  56202. -C.  (The `-pedantic' option directs GNU CC to print a warning message if
  56203. -any of these features is used.)  To test for the availability of these
  56204. -features in conditional compilation, check for a predefined macro
  56205. -`__GNUC__', which is always defined under GNU CC.
  56206. -
  56207. -   These extensions are available in C and Objective C.  Most of them
  56208. -are also available in C++.  *Note Extensions to the C++ Language: C++
  56209. -Extensions, for extensions that apply *only* to C++.
  56210. -
  56211. -* Menu:
  56212. -
  56213. -* Statement Exprs::     Putting statements and declarations inside expressions.
  56214. -* Local Labels::        Labels local to a statement-expression.
  56215. -* Labels as Values::    Getting pointers to labels, and computed gotos.
  56216. -* Nested Functions::    As in Algol and Pascal, lexical scoping of functions.
  56217. -* Constructing Calls::    Dispatching a call to another function.
  56218. -* Naming Types::        Giving a name to the type of some expression.
  56219. -* Typeof::              `typeof': referring to the type of an expression.
  56220. -* Lvalues::             Using `?:', `,' and casts in lvalues.
  56221. -* Conditionals::        Omitting the middle operand of a `?:' expression.
  56222. -* Long Long::        Double-word integers--`long long int'.
  56223. -* Complex::             Data types for complex numbers.
  56224. -* Zero Length::         Zero-length arrays.
  56225. -* Variable Length::     Arrays whose length is computed at run time.
  56226. -* Macro Varargs::    Macros with variable number of arguments.
  56227. -* Subscripting::        Any array can be subscripted, even if not an lvalue.
  56228. -* Pointer Arith::       Arithmetic on `void'-pointers and function pointers.
  56229. -* Initializers::        Non-constant initializers.
  56230. -* Constructors::        Constructor expressions give structures, unions
  56231. -                         or arrays as values.
  56232. -* Labeled Elements::    Labeling elements of initializers.
  56233. -* Cast to Union::       Casting to union type from any member of the union.
  56234. -* Case Ranges::        `case 1 ... 9' and such.
  56235. -* Function Attributes:: Declaring that functions have no side effects,
  56236. -                         or that they can never return.
  56237. -* Function Prototypes:: Prototype declarations and old-style definitions.
  56238. -* C++ Comments::        C++ comments are recognized.
  56239. -* Dollar Signs::        Dollar sign is allowed in identifiers.
  56240. -* Character Escapes::   `\e' stands for the character ESC.
  56241. -* Variable Attributes::    Specifying attributes of variables.
  56242. -* Type Attributes::    Specifying attributes of types.
  56243. -* Alignment::           Inquiring about the alignment of a type or variable.
  56244. -* Inline::              Defining inline functions (as fast as macros).
  56245. -* Extended Asm::        Assembler instructions with C expressions as operands.
  56246. -                         (With them you can define "built-in" functions.)
  56247. -* Asm Labels::          Specifying the assembler name to use for a C symbol.
  56248. -* Explicit Reg Vars::   Defining variables residing in specified registers.
  56249. -* Alternate Keywords::  `__const__', `__asm__', etc., for header files.
  56250. -* Incomplete Enums::    `enum foo;', with details to follow.
  56251. -* Function Names::    Printable strings which are the name of the current
  56252. -             function.
  56253. -
  56254. -
  56255. -File: gcc.info,  Node: Statement Exprs,  Next: Local Labels,  Up: C Extensions
  56256. -
  56257. -Statements and Declarations in Expressions
  56258. -==========================================
  56259. -
  56260. -   A compound statement enclosed in parentheses may appear as an
  56261. -expression in GNU C.  This allows you to use loops, switches, and local
  56262. -variables within an expression.
  56263. -
  56264. -   Recall that a compound statement is a sequence of statements
  56265. -surrounded by braces; in this construct, parentheses go around the
  56266. -braces.  For example:
  56267. -
  56268. -     ({ int y = foo (); int z;
  56269. -        if (y > 0) z = y;
  56270. -        else z = - y;
  56271. -        z; })
  56272. -
  56273. -is a valid (though slightly more complex than necessary) expression for
  56274. -the absolute value of `foo ()'.
  56275. -
  56276. -   The last thing in the compound statement should be an expression
  56277. -followed by a semicolon; the value of this subexpression serves as the
  56278. -value of the entire construct.  (If you use some other kind of statement
  56279. -last within the braces, the construct has type `void', and thus
  56280. -effectively no value.)
  56281. -
  56282. -   This feature is especially useful in making macro definitions "safe"
  56283. -(so that they evaluate each operand exactly once).  For example, the
  56284. -"maximum" function is commonly defined as a macro in standard C as
  56285. -follows:
  56286. -
  56287. -     #define max(a,b) ((a) > (b) ? (a) : (b))
  56288. -
  56289. -But this definition computes either A or B twice, with bad results if
  56290. -the operand has side effects.  In GNU C, if you know the type of the
  56291. -operands (here let's assume `int'), you can define the macro safely as
  56292. -follows:
  56293. -
  56294. -     #define maxint(a,b) \
  56295. -       ({int _a = (a), _b = (b); _a > _b ? _a : _b; })
  56296. -
  56297. -   Embedded statements are not allowed in constant expressions, such as
  56298. -the value of an enumeration constant, the width of a bit field, or the
  56299. -initial value of a static variable.
  56300. -
  56301. -   If you don't know the type of the operand, you can still do this,
  56302. -but you must use `typeof' (*note Typeof::.) or type naming (*note
  56303. -Naming Types::.).
  56304. -
  56305. -
  56306. -File: gcc.info,  Node: Local Labels,  Next: Labels as Values,  Prev: Statement Exprs,  Up: C Extensions
  56307. -
  56308. -Locally Declared Labels
  56309. -=======================
  56310. -
  56311. -   Each statement expression is a scope in which "local labels" can be
  56312. -declared.  A local label is simply an identifier; you can jump to it
  56313. -with an ordinary `goto' statement, but only from within the statement
  56314. -expression it belongs to.
  56315. -
  56316. -   A local label declaration looks like this:
  56317. -
  56318. -     __label__ LABEL;
  56319. -
  56320. -or
  56321. -
  56322. -     __label__ LABEL1, LABEL2, ...;
  56323. -
  56324. -   Local label declarations must come at the beginning of the statement
  56325. -expression, right after the `({', before any ordinary declarations.
  56326. -
  56327. -   The label declaration defines the label *name*, but does not define
  56328. -the label itself.  You must do this in the usual way, with `LABEL:',
  56329. -within the statements of the statement expression.
  56330. -
  56331. -   The local label feature is useful because statement expressions are
  56332. -often used in macros.  If the macro contains nested loops, a `goto' can
  56333. -be useful for breaking out of them.  However, an ordinary label whose
  56334. -scope is the whole function cannot be used: if the macro can be
  56335. -expanded several times in one function, the label will be multiply
  56336. -defined in that function.  A local label avoids this problem.  For
  56337. -example:
  56338. -
  56339. -     #define SEARCH(array, target)                     \
  56340. -     ({                                               \
  56341. -       __label__ found;                                \
  56342. -       typeof (target) _SEARCH_target = (target);      \
  56343. -       typeof (*(array)) *_SEARCH_array = (array);     \
  56344. -       int i, j;                                       \
  56345. -       int value;                                      \
  56346. -       for (i = 0; i < max; i++)                       \
  56347. -         for (j = 0; j < max; j++)                     \
  56348. -           if (_SEARCH_array[i][j] == _SEARCH_target)  \
  56349. -             { value = i; goto found; }              \
  56350. -       value = -1;                                     \
  56351. -      found:                                           \
  56352. -       value;                                          \
  56353. -     })
  56354. -
  56355. -
  56356. -File: gcc.info,  Node: Labels as Values,  Next: Nested Functions,  Prev: Local Labels,  Up: C Extensions
  56357. -
  56358. -Labels as Values
  56359. -================
  56360. -
  56361. -   You can get the address of a label defined in the current function
  56362. -(or a containing function) with the unary operator `&&'.  The value has
  56363. -type `void *'.  This value is a constant and can be used wherever a
  56364. -constant of that type is valid.  For example:
  56365. -
  56366. -     void *ptr;
  56367. -     ...
  56368. -     ptr = &&foo;
  56369. -
  56370. -   To use these values, you need to be able to jump to one.  This is
  56371. -done with the computed goto statement(1), `goto *EXP;'.  For example,
  56372. -
  56373. -     goto *ptr;
  56374. -
  56375. -Any expression of type `void *' is allowed.
  56376. -
  56377. -   One way of using these constants is in initializing a static array
  56378. -that will serve as a jump table:
  56379. -
  56380. -     static void *array[] = { &&foo, &&bar, &&hack };
  56381. -
  56382. -   Then you can select a label with indexing, like this:
  56383. -
  56384. -     goto *array[i];
  56385. -
  56386. -Note that this does not check whether the subscript is in bounds--array
  56387. -indexing in C never does that.
  56388. -
  56389. -   Such an array of label values serves a purpose much like that of the
  56390. -`switch' statement.  The `switch' statement is cleaner, so use that
  56391. -rather than an array unless the problem does not fit a `switch'
  56392. -statement very well.
  56393. -
  56394. -   Another use of label values is in an interpreter for threaded code.
  56395. -The labels within the interpreter function can be stored in the
  56396. -threaded code for super-fast dispatching.
  56397. -
  56398. -   You can use this mechanism to jump to code in a different function.
  56399. -If you do that, totally unpredictable things will happen.  The best way
  56400. -to avoid this is to store the label address only in automatic variables
  56401. -and never pass it as an argument.
  56402. -
  56403. -   ---------- Footnotes ----------
  56404. -
  56405. -   (1)  The analogous feature in Fortran is called an assigned goto,
  56406. -but that name seems inappropriate in C, where one can do more than
  56407. -simply store label addresses in label variables.
  56408. -
  56409. -
  56410. -File: gcc.info,  Node: Nested Functions,  Next: Constructing Calls,  Prev: Labels as Values,  Up: C Extensions
  56411. -
  56412. -Nested Functions
  56413. -================
  56414. -
  56415. -   A "nested function" is a function defined inside another function.
  56416. -(Nested functions are not supported for GNU C++.)  The nested function's
  56417. -name is local to the block where it is defined.  For example, here we
  56418. -define a nested function named `square', and call it twice:
  56419. -
  56420. -     foo (double a, double b)
  56421. -     {
  56422. -       double square (double z) { return z * z; }
  56423. -     
  56424. -       return square (a) + square (b);
  56425. -     }
  56426. -
  56427. -   The nested function can access all the variables of the containing
  56428. -function that are visible at the point of its definition.  This is
  56429. -called "lexical scoping".  For example, here we show a nested function
  56430. -which uses an inherited variable named `offset':
  56431. -
  56432. -     bar (int *array, int offset, int size)
  56433. -     {
  56434. -       int access (int *array, int index)
  56435. -         { return array[index + offset]; }
  56436. -       int i;
  56437. -       ...
  56438. -       for (i = 0; i < size; i++)
  56439. -         ... access (array, i) ...
  56440. -     }
  56441. -
  56442. -   Nested function definitions are permitted within functions in the
  56443. -places where variable definitions are allowed; that is, in any block,
  56444. -before the first statement in the block.
  56445. -
  56446. -   It is possible to call the nested function from outside the scope of
  56447. -its name by storing its address or passing the address to another
  56448. -function:
  56449. -
  56450. -     hack (int *array, int size)
  56451. -     {
  56452. -       void store (int index, int value)
  56453. -         { array[index] = value; }
  56454. -     
  56455. -       intermediate (store, size);
  56456. -     }
  56457. -
  56458. -   Here, the function `intermediate' receives the address of `store' as
  56459. -an argument.  If `intermediate' calls `store', the arguments given to
  56460. -`store' are used to store into `array'.  But this technique works only
  56461. -so long as the containing function (`hack', in this example) does not
  56462. -exit.
  56463. -
  56464. -   If you try to call the nested function through its address after the
  56465. -containing function has exited, all hell will break loose.  If you try
  56466. -to call it after a containing scope level has exited, and if it refers
  56467. -to some of the variables that are no longer in scope, you may be lucky,
  56468. -but it's not wise to take the risk.  If, however, the nested function
  56469. -does not refer to anything that has gone out of scope, you should be
  56470. -safe.
  56471. -
  56472. -   GNU CC implements taking the address of a nested function using a
  56473. -technique called "trampolines".  A paper describing them is available
  56474. -from `maya.idiap.ch' in directory `pub/tmb', file `usenix88-lexic.ps.Z'.
  56475. -
  56476. -   A nested function can jump to a label inherited from a containing
  56477. -function, provided the label was explicitly declared in the containing
  56478. -function (*note Local Labels::.).  Such a jump returns instantly to the
  56479. -containing function, exiting the nested function which did the `goto'
  56480. -and any intermediate functions as well.  Here is an example:
  56481. -
  56482. -     bar (int *array, int offset, int size)
  56483. -     {
  56484. -       __label__ failure;
  56485. -       int access (int *array, int index)
  56486. -         {
  56487. -           if (index > size)
  56488. -             goto failure;
  56489. -           return array[index + offset];
  56490. -         }
  56491. -       int i;
  56492. -       ...
  56493. -       for (i = 0; i < size; i++)
  56494. -         ... access (array, i) ...
  56495. -       ...
  56496. -       return 0;
  56497. -     
  56498. -      /* Control comes here from `access'
  56499. -         if it detects an error.  */
  56500. -      failure:
  56501. -       return -1;
  56502. -     }
  56503. -
  56504. -   A nested function always has internal linkage.  Declaring one with
  56505. -`extern' is erroneous.  If you need to declare the nested function
  56506. -before its definition, use `auto' (which is otherwise meaningless for
  56507. -function declarations).
  56508. -
  56509. -     bar (int *array, int offset, int size)
  56510. -     {
  56511. -       __label__ failure;
  56512. -       auto int access (int *, int);
  56513. -       ...
  56514. -       int access (int *array, int index)
  56515. -         {
  56516. -           if (index > size)
  56517. -             goto failure;
  56518. -           return array[index + offset];
  56519. -         }
  56520. -       ...
  56521. -     }
  56522. -
  56523. -
  56524. -File: gcc.info,  Node: Constructing Calls,  Next: Naming Types,  Prev: Nested Functions,  Up: C Extensions
  56525. -
  56526. -Constructing Function Calls
  56527. -===========================
  56528. -
  56529. -   Using the built-in functions described below, you can record the
  56530. -arguments a function received, and call another function with the same
  56531. -arguments, without knowing the number or types of the arguments.
  56532. -
  56533. -   You can also record the return value of that function call, and
  56534. -later return that value, without knowing what data type the function
  56535. -tried to return (as long as your caller expects that data type).
  56536. -
  56537. -`__builtin_apply_args ()'
  56538. -     This built-in function returns a pointer of type `void *' to data
  56539. -     describing how to perform a call with the same arguments as were
  56540. -     passed to the current function.
  56541. -
  56542. -     The function saves the arg pointer register, structure value
  56543. -     address, and all registers that might be used to pass arguments to
  56544. -     a function into a block of memory allocated on the stack.  Then it
  56545. -     returns the address of that block.
  56546. -
  56547. -`__builtin_apply (FUNCTION, ARGUMENTS, SIZE)'
  56548. -     This built-in function invokes FUNCTION (type `void (*)()') with a
  56549. -     copy of the parameters described by ARGUMENTS (type `void *') and
  56550. -     SIZE (type `int').
  56551. -
  56552. -     The value of ARGUMENTS should be the value returned by
  56553. -     `__builtin_apply_args'.  The argument SIZE specifies the size of
  56554. -     the stack argument data, in bytes.
  56555. -
  56556. -     This function returns a pointer of type `void *' to data describing
  56557. -     how to return whatever value was returned by FUNCTION.  The data
  56558. -     is saved in a block of memory allocated on the stack.
  56559. -
  56560. -     It is not always simple to compute the proper value for SIZE.  The
  56561. -     value is used by `__builtin_apply' to compute the amount of data
  56562. -     that should be pushed on the stack and copied from the incoming
  56563. -     argument area.
  56564. -
  56565. -`__builtin_return (RESULT)'
  56566. -     This built-in function returns the value described by RESULT from
  56567. -     the containing function.  You should specify, for RESULT, a value
  56568. -     returned by `__builtin_apply'.
  56569. -
  56570. -
  56571. -File: gcc.info,  Node: Naming Types,  Next: Typeof,  Prev: Constructing Calls,  Up: C Extensions
  56572. -
  56573. -Naming an Expression's Type
  56574. -===========================
  56575. -
  56576. -   You can give a name to the type of an expression using a `typedef'
  56577. -declaration with an initializer.  Here is how to define NAME as a type
  56578. -name for the type of EXP:
  56579. -
  56580. -     typedef NAME = EXP;
  56581. -
  56582. -   This is useful in conjunction with the statements-within-expressions
  56583. -feature.  Here is how the two together can be used to define a safe
  56584. -"maximum" macro that operates on any arithmetic type:
  56585. -
  56586. -     #define max(a,b) \
  56587. -       ({typedef _ta = (a), _tb = (b);  \
  56588. -         _ta _a = (a); _tb _b = (b);     \
  56589. -         _a > _b ? _a : _b; })
  56590. -
  56591. -   The reason for using names that start with underscores for the local
  56592. -variables is to avoid conflicts with variable names that occur within
  56593. -the expressions that are substituted for `a' and `b'.  Eventually we
  56594. -hope to design a new form of declaration syntax that allows you to
  56595. -declare variables whose scopes start only after their initializers;
  56596. -this will be a more reliable way to prevent such conflicts.
  56597. -
  56598. -
  56599. -File: gcc.info,  Node: Typeof,  Next: Lvalues,  Prev: Naming Types,  Up: C Extensions
  56600. -
  56601. -Referring to a Type with `typeof'
  56602. -=================================
  56603. -
  56604. -   Another way to refer to the type of an expression is with `typeof'.
  56605. -The syntax of using of this keyword looks like `sizeof', but the
  56606. -construct acts semantically like a type name defined with `typedef'.
  56607. -
  56608. -   There are two ways of writing the argument to `typeof': with an
  56609. -expression or with a type.  Here is an example with an expression:
  56610. -
  56611. -     typeof (x[0](1))
  56612. -
  56613. -This assumes that `x' is an array of functions; the type described is
  56614. -that of the values of the functions.
  56615. -
  56616. -   Here is an example with a typename as the argument:
  56617. -
  56618. -     typeof (int *)
  56619. -
  56620. -Here the type described is that of pointers to `int'.
  56621. -
  56622. -   If you are writing a header file that must work when included in
  56623. -ANSI C programs, write `__typeof__' instead of `typeof'.  *Note
  56624. -Alternate Keywords::.
  56625. -
  56626. -   A `typeof'-construct can be used anywhere a typedef name could be
  56627. -used.  For example, you can use it in a declaration, in a cast, or
  56628. -inside of `sizeof' or `typeof'.
  56629. -
  56630. -   * This declares `y' with the type of what `x' points to.
  56631. -
  56632. -          typeof (*x) y;
  56633. -
  56634. -   * This declares `y' as an array of such values.
  56635. -
  56636. -          typeof (*x) y[4];
  56637. -
  56638. -   * This declares `y' as an array of pointers to characters:
  56639. -
  56640. -          typeof (typeof (char *)[4]) y;
  56641. -
  56642. -     It is equivalent to the following traditional C declaration:
  56643. -
  56644. -          char *y[4];
  56645. -
  56646. -     To see the meaning of the declaration using `typeof', and why it
  56647. -     might be a useful way to write, let's rewrite it with these macros:
  56648. -
  56649. -          #define pointer(T)  typeof(T *)
  56650. -          #define array(T, N) typeof(T [N])
  56651. -
  56652. -     Now the declaration can be rewritten this way:
  56653. -
  56654. -          array (pointer (char), 4) y;
  56655. -
  56656. -     Thus, `array (pointer (char), 4)' is the type of arrays of 4
  56657. -     pointers to `char'.
  56658. -
  56659. -
  56660. -File: gcc.info,  Node: Lvalues,  Next: Conditionals,  Prev: Typeof,  Up: C Extensions
  56661. -
  56662. -Generalized Lvalues
  56663. -===================
  56664. -
  56665. -   Compound expressions, conditional expressions and casts are allowed
  56666. -as lvalues provided their operands are lvalues.  This means that you
  56667. -can take their addresses or store values into them.
  56668. -
  56669. -   Standard C++ allows compound expressions and conditional expressions
  56670. -as lvalues, and permits casts to reference type, so use of this
  56671. -extension is deprecated for C++ code.
  56672. -
  56673. -   For example, a compound expression can be assigned, provided the last
  56674. -expression in the sequence is an lvalue.  These two expressions are
  56675. -equivalent:
  56676. -
  56677. -     (a, b) += 5
  56678. -     a, (b += 5)
  56679. -
  56680. -   Similarly, the address of the compound expression can be taken.
  56681. -These two expressions are equivalent:
  56682. -
  56683. -     &(a, b)
  56684. -     a, &b
  56685. -
  56686. -   A conditional expression is a valid lvalue if its type is not void
  56687. -and the true and false branches are both valid lvalues.  For example,
  56688. -these two expressions are equivalent:
  56689. -
  56690. -     (a ? b : c) = 5
  56691. -     (a ? b = 5 : (c = 5))
  56692. -
  56693. -   A cast is a valid lvalue if its operand is an lvalue.  A simple
  56694. -assignment whose left-hand side is a cast works by converting the
  56695. -right-hand side first to the specified type, then to the type of the
  56696. -inner left-hand side expression.  After this is stored, the value is
  56697. -converted back to the specified type to become the value of the
  56698. -assignment.  Thus, if `a' has type `char *', the following two
  56699. -expressions are equivalent:
  56700. -
  56701. -     (int)a = 5
  56702. -     (int)(a = (char *)(int)5)
  56703. -
  56704. -   An assignment-with-arithmetic operation such as `+=' applied to a
  56705. -cast performs the arithmetic using the type resulting from the cast,
  56706. -and then continues as in the previous case.  Therefore, these two
  56707. -expressions are equivalent:
  56708. -
  56709. -     (int)a += 5
  56710. -     (int)(a = (char *)(int) ((int)a + 5))
  56711. -
  56712. -   You cannot take the address of an lvalue cast, because the use of its
  56713. -address would not work out coherently.  Suppose that `&(int)f' were
  56714. -permitted, where `f' has type `float'.  Then the following statement
  56715. -would try to store an integer bit-pattern where a floating point number
  56716. -belongs:
  56717. -
  56718. -     *&(int)f = 1;
  56719. -
  56720. -   This is quite different from what `(int)f = 1' would do--that would
  56721. -convert 1 to floating point and store it.  Rather than cause this
  56722. -inconsistency, we think it is better to prohibit use of `&' on a cast.
  56723. -
  56724. -   If you really do want an `int *' pointer with the address of `f',
  56725. -you can simply write `(int *)&f'.
  56726. -
  56727. -
  56728. -File: gcc.info,  Node: Conditionals,  Next: Long Long,  Prev: Lvalues,  Up: C Extensions
  56729. -
  56730. -Conditionals with Omitted Operands
  56731. -==================================
  56732. -
  56733. -   The middle operand in a conditional expression may be omitted.  Then
  56734. -if the first operand is nonzero, its value is the value of the
  56735. -conditional expression.
  56736. -
  56737. -   Therefore, the expression
  56738. -
  56739. -     x ? : y
  56740. -
  56741. -has the value of `x' if that is nonzero; otherwise, the value of `y'.
  56742. -
  56743. -   This example is perfectly equivalent to
  56744. -
  56745. -     x ? x : y
  56746. -
  56747. -In this simple case, the ability to omit the middle operand is not
  56748. -especially useful.  When it becomes useful is when the first operand
  56749. -does, or may (if it is a macro argument), contain a side effect.  Then
  56750. -repeating the operand in the middle would perform the side effect
  56751. -twice.  Omitting the middle operand uses the value already computed
  56752. -without the undesirable effects of recomputing it.
  56753. -
  56754. -
  56755. -File: gcc.info,  Node: Long Long,  Next: Complex,  Prev: Conditionals,  Up: C Extensions
  56756. -
  56757. -Double-Word Integers
  56758. -====================
  56759. -
  56760. -   GNU C supports data types for integers that are twice as long as
  56761. -`long int'.  Simply write `long long int' for a signed integer, or
  56762. -`unsigned long long int' for an unsigned integer.  To make an integer
  56763. -constant of type `long long int', add the suffix `LL' to the integer.
  56764. -To make an integer constant of type `unsigned long long int', add the
  56765. -suffix `ULL' to the integer.
  56766. -
  56767. -   You can use these types in arithmetic like any other integer types.
  56768. -Addition, subtraction, and bitwise boolean operations on these types
  56769. -are open-coded on all types of machines.  Multiplication is open-coded
  56770. -if the machine supports fullword-to-doubleword a widening multiply
  56771. -instruction.  Division and shifts are open-coded only on machines that
  56772. -provide special support.  The operations that are not open-coded use
  56773. -special library routines that come with GNU CC.
  56774. -
  56775. -   There may be pitfalls when you use `long long' types for function
  56776. -arguments, unless you declare function prototypes.  If a function
  56777. -expects type `int' for its argument, and you pass a value of type `long
  56778. -long int', confusion will result because the caller and the subroutine
  56779. -will disagree about the number of bytes for the argument.  Likewise, if
  56780. -the function expects `long long int' and you pass `int'.  The best way
  56781. -to avoid such problems is to use prototypes.
  56782. -
  56783. -
  56784. -File: gcc.info,  Node: Complex,  Next: Zero Length,  Prev: Long Long,  Up: C Extensions
  56785. -
  56786. -Complex Numbers
  56787. -===============
  56788. -
  56789. -   GNU C supports complex data types.  You can declare both complex
  56790. -integer types and complex floating types, using the keyword
  56791. -`__complex__'.
  56792. -
  56793. -   For example, `__complex__ double x;' declares `x' as a variable
  56794. -whose real part and imaginary part are both of type `double'.
  56795. -`__complex__ short int y;' declares `y' to have real and imaginary
  56796. -parts of type `short int'; this is not likely to be useful, but it
  56797. -shows that the set of complex types is complete.
  56798. -
  56799. -   To write a constant with a complex data type, use the suffix `i' or
  56800. -`j' (either one; they are equivalent).  For example, `2.5fi' has type
  56801. -`__complex__ float' and `3i' has type `__complex__ int'.  Such a
  56802. -constant always has a pure imaginary value, but you can form any
  56803. -complex value you like by adding one to a real constant.
  56804. -
  56805. -   To extract the real part of a complex-valued expression EXP, write
  56806. -`__real__ EXP'.  Likewise, use `__imag__' to extract the imaginary part.
  56807. -
  56808. -   The operator `~' performs complex conjugation when used on a value
  56809. -with a complex type.
  56810. -
  56811. -   GNU CC can allocate complex automatic variables in a noncontiguous
  56812. -fashion; it's even possible for the real part to be in a register while
  56813. -the imaginary part is on the stack (or vice-versa).  None of the
  56814. -supported debugging info formats has a way to represent noncontiguous
  56815. -allocation like this, so GNU CC describes a noncontiguous complex
  56816. -variable as if it were two separate variables of noncomplex type.  If
  56817. -the variable's actual name is `foo', the two fictitious variables are
  56818. -named `foo$real' and `foo$imag'.  You can examine and set these two
  56819. -fictitious variables with your debugger.
  56820. -
  56821. -   A future version of GDB will know how to recognize such pairs and
  56822. -treat them as a single variable with a complex type.
  56823. -
  56824. -
  56825. -File: gcc.info,  Node: Zero Length,  Next: Variable Length,  Prev: Complex,  Up: C Extensions
  56826. -
  56827. -Arrays of Length Zero
  56828. -=====================
  56829. -
  56830. -   Zero-length arrays are allowed in GNU C.  They are very useful as
  56831. -the last element of a structure which is really a header for a
  56832. -variable-length object:
  56833. -
  56834. -     struct line {
  56835. -       int length;
  56836. -       char contents[0];
  56837. -     };
  56838. -     
  56839. -     {
  56840. -       struct line *thisline = (struct line *)
  56841. -         malloc (sizeof (struct line) + this_length);
  56842. -       thisline->length = this_length;
  56843. -     }
  56844. -
  56845. -   In standard C, you would have to give `contents' a length of 1, which
  56846. -means either you waste space or complicate the argument to `malloc'.
  56847. -
  56848. -
  56849. -File: gcc.info,  Node: Variable Length,  Next: Macro Varargs,  Prev: Zero Length,  Up: C Extensions
  56850. -
  56851. -Arrays of Variable Length
  56852. -=========================
  56853. -
  56854. -   Variable-length automatic arrays are allowed in GNU C.  These arrays
  56855. -are declared like any other automatic arrays, but with a length that is
  56856. -not a constant expression.  The storage is allocated at the point of
  56857. -declaration and deallocated when the brace-level is exited.  For
  56858. -example:
  56859. -
  56860. -     FILE *
  56861. -     concat_fopen (char *s1, char *s2, char *mode)
  56862. -     {
  56863. -       char str[strlen (s1) + strlen (s2) + 1];
  56864. -       strcpy (str, s1);
  56865. -       strcat (str, s2);
  56866. -       return fopen (str, mode);
  56867. -     }
  56868. -
  56869. -   Jumping or breaking out of the scope of the array name deallocates
  56870. -the storage.  Jumping into the scope is not allowed; you get an error
  56871. -message for it.
  56872. -
  56873. -   You can use the function `alloca' to get an effect much like
  56874. -variable-length arrays.  The function `alloca' is available in many
  56875. -other C implementations (but not in all).  On the other hand,
  56876. -variable-length arrays are more elegant.
  56877. -
  56878. -   There are other differences between these two methods.  Space
  56879. -allocated with `alloca' exists until the containing *function* returns.
  56880. -The space for a variable-length array is deallocated as soon as the
  56881. -array name's scope ends.  (If you use both variable-length arrays and
  56882. -`alloca' in the same function, deallocation of a variable-length array
  56883. -will also deallocate anything more recently allocated with `alloca'.)
  56884. -
  56885. -   You can also use variable-length arrays as arguments to functions:
  56886. -
  56887. -     struct entry
  56888. -     tester (int len, char data[len][len])
  56889. -     {
  56890. -       ...
  56891. -     }
  56892. -
  56893. -   The length of an array is computed once when the storage is allocated
  56894. -and is remembered for the scope of the array in case you access it with
  56895. -`sizeof'.
  56896. -
  56897. -   If you want to pass the array first and the length afterward, you can
  56898. -use a forward declaration in the parameter list--another GNU extension.
  56899. -
  56900. -     struct entry
  56901. -     tester (int len; char data[len][len], int len)
  56902. -     {
  56903. -       ...
  56904. -     }
  56905. -
  56906. -   The `int len' before the semicolon is a "parameter forward
  56907. -declaration", and it serves the purpose of making the name `len' known
  56908. -when the declaration of `data' is parsed.
  56909. -
  56910. -   You can write any number of such parameter forward declarations in
  56911. -the parameter list.  They can be separated by commas or semicolons, but
  56912. -the last one must end with a semicolon, which is followed by the "real"
  56913. -parameter declarations.  Each forward declaration must match a "real"
  56914. -declaration in parameter name and data type.
  56915. -
  56916. -
  56917. -File: gcc.info,  Node: Macro Varargs,  Next: Subscripting,  Prev: Variable Length,  Up: C Extensions
  56918. -
  56919. -Macros with Variable Numbers of Arguments
  56920. -=========================================
  56921. -
  56922. -   In GNU C, a macro can accept a variable number of arguments, much as
  56923. -a function can.  The syntax for defining the macro looks much like that
  56924. -used for a function.  Here is an example:
  56925. -
  56926. -     #define eprintf(format, args...)  \
  56927. -      fprintf (stderr, format , ## args)
  56928. -
  56929. -   Here `args' is a "rest argument": it takes in zero or more
  56930. -arguments, as many as the call contains.  All of them plus the commas
  56931. -between them form the value of `args', which is substituted into the
  56932. -macro body where `args' is used.  Thus, we have this expansion:
  56933. -
  56934. -     eprintf ("%s:%d: ", input_file_name, line_number)
  56935. -     ==>
  56936. -     fprintf (stderr, "%s:%d: " , input_file_name, line_number)
  56937. -
  56938. -Note that the comma after the string constant comes from the definition
  56939. -of `eprintf', whereas the last comma comes from the value of `args'.
  56940. -
  56941. -   The reason for using `##' is to handle the case when `args' matches
  56942. -no arguments at all.  In this case, `args' has an empty value.  In this
  56943. -case, the second comma in the definition becomes an embarrassment: if
  56944. -it got through to the expansion of the macro, we would get something
  56945. -like this:
  56946. -
  56947. -     fprintf (stderr, "success!\n" , )
  56948. -
  56949. -which is invalid C syntax.  `##' gets rid of the comma, so we get the
  56950. -following instead:
  56951. -
  56952. -     fprintf (stderr, "success!\n")
  56953. -
  56954. -   This is a special feature of the GNU C preprocessor: `##' before a
  56955. -rest argument that is empty discards the preceding sequence of
  56956. -non-whitespace characters from the macro definition.  (If another macro
  56957. -argument precedes, none of it is discarded.)
  56958. -
  56959. -   It might be better to discard the last preprocessor token instead of
  56960. -the last preceding sequence of non-whitespace characters; in fact, we
  56961. -may someday change this feature to do so.  We advise you to write the
  56962. -macro definition so that the preceding sequence of non-whitespace
  56963. -characters is just a single token, so that the meaning will not change
  56964. -if we change the definition of this feature.
  56965. -
  56966. -
  56967. -File: gcc.info,  Node: Subscripting,  Next: Pointer Arith,  Prev: Macro Varargs,  Up: C Extensions
  56968. -
  56969. -Non-Lvalue Arrays May Have Subscripts
  56970. -=====================================
  56971. -
  56972. -   Subscripting is allowed on arrays that are not lvalues, even though
  56973. -the unary `&' operator is not.  For example, this is valid in GNU C
  56974. -though not valid in other C dialects:
  56975. -
  56976. -     struct foo {int a[4];};
  56977. -     
  56978. -     struct foo f();
  56979. -     
  56980. -     bar (int index)
  56981. -     {
  56982. -       return f().a[index];
  56983. -     }
  56984. -
  56985. -
  56986. -File: gcc.info,  Node: Pointer Arith,  Next: Initializers,  Prev: Subscripting,  Up: C Extensions
  56987. -
  56988. -Arithmetic on `void'- and Function-Pointers
  56989. -===========================================
  56990. -
  56991. -   In GNU C, addition and subtraction operations are supported on
  56992. -pointers to `void' and on pointers to functions.  This is done by
  56993. -treating the size of a `void' or of a function as 1.
  56994. -
  56995. -   A consequence of this is that `sizeof' is also allowed on `void' and
  56996. -on function types, and returns 1.
  56997. -
  56998. -   The option `-Wpointer-arith' requests a warning if these extensions
  56999. -are used.
  57000. -
  57001. -
  57002. -File: gcc.info,  Node: Initializers,  Next: Constructors,  Prev: Pointer Arith,  Up: C Extensions
  57003. -
  57004. -Non-Constant Initializers
  57005. -=========================
  57006. -
  57007. -   As in standard C++, the elements of an aggregate initializer for an
  57008. -automatic variable are not required to be constant expressions in GNU C.
  57009. -Here is an example of an initializer with run-time varying elements:
  57010. -
  57011. -     foo (float f, float g)
  57012. -     {
  57013. -       float beat_freqs[2] = { f-g, f+g };
  57014. -       ...
  57015. -     }
  57016. -
  57017. diff -rup --new-file baseline/fsf/gcc/gcc.info-9 amiga/fsf/gcc/gcc.info-9
  57018. --- baseline/fsf/gcc/gcc.info-9    Sat Jun 29 09:38:00 1996
  57019. +++ amiga/fsf/gcc/gcc.info-9    Wed Dec 31 17:00:00 1969
  57020. @@ -1,1171 +0,0 @@
  57021. -This is Info file gcc.info, produced by Makeinfo-1.55 from the input
  57022. -file gcc.texi.
  57023. -
  57024. -   This file documents the use and the internals of the GNU compiler.
  57025. -
  57026. -   Published by the Free Software Foundation 59 Temple Place - Suite 330
  57027. -Boston, MA 02111-1307 USA
  57028. -
  57029. -   Copyright (C) 1988, 1989, 1992, 1993, 1994, 1995 Free Software
  57030. -Foundation, Inc.
  57031. -
  57032. -   Permission is granted to make and distribute verbatim copies of this
  57033. -manual provided the copyright notice and this permission notice are
  57034. -preserved on all copies.
  57035. -
  57036. -   Permission is granted to copy and distribute modified versions of
  57037. -this manual under the conditions for verbatim copying, provided also
  57038. -that the sections entitled "GNU General Public License," "Funding for
  57039. -Free Software," and "Protect Your Freedom--Fight `Look And Feel'" are
  57040. -included exactly as in the original, and provided that the entire
  57041. -resulting derived work is distributed under the terms of a permission
  57042. -notice identical to this one.
  57043. -
  57044. -   Permission is granted to copy and distribute translations of this
  57045. -manual into another language, under the above conditions for modified
  57046. -versions, except that the sections entitled "GNU General Public
  57047. -License," "Funding for Free Software," and "Protect Your Freedom--Fight
  57048. -`Look And Feel'", and this permission notice, may be included in
  57049. -translations approved by the Free Software Foundation instead of in the
  57050. -original English.
  57051. -
  57052. -
  57053. -File: gcc.info,  Node: Constructors,  Next: Labeled Elements,  Prev: Initializers,  Up: C Extensions
  57054. -
  57055. -Constructor Expressions
  57056. -=======================
  57057. -
  57058. -   GNU C supports constructor expressions.  A constructor looks like a
  57059. -cast containing an initializer.  Its value is an object of the type
  57060. -specified in the cast, containing the elements specified in the
  57061. -initializer.
  57062. -
  57063. -   Usually, the specified type is a structure.  Assume that `struct
  57064. -foo' and `structure' are declared as shown:
  57065. -
  57066. -     struct foo {int a; char b[2];} structure;
  57067. -
  57068. -Here is an example of constructing a `struct foo' with a constructor:
  57069. -
  57070. -     structure = ((struct foo) {x + y, 'a', 0});
  57071. -
  57072. -This is equivalent to writing the following:
  57073. -
  57074. -     {
  57075. -       struct foo temp = {x + y, 'a', 0};
  57076. -       structure = temp;
  57077. -     }
  57078. -
  57079. -   You can also construct an array.  If all the elements of the
  57080. -constructor are (made up of) simple constant expressions, suitable for
  57081. -use in initializers, then the constructor is an lvalue and can be
  57082. -coerced to a pointer to its first element, as shown here:
  57083. -
  57084. -     char **foo = (char *[]) { "x", "y", "z" };
  57085. -
  57086. -   Array constructors whose elements are not simple constants are not
  57087. -very useful, because the constructor is not an lvalue.  There are only
  57088. -two valid ways to use it: to subscript it, or initialize an array
  57089. -variable with it.  The former is probably slower than a `switch'
  57090. -statement, while the latter does the same thing an ordinary C
  57091. -initializer would do.  Here is an example of subscripting an array
  57092. -constructor:
  57093. -
  57094. -     output = ((int[]) { 2, x, 28 }) [input];
  57095. -
  57096. -   Constructor expressions for scalar types and union types are is also
  57097. -allowed, but then the constructor expression is equivalent to a cast.
  57098. -
  57099. -
  57100. -File: gcc.info,  Node: Labeled Elements,  Next: Cast to Union,  Prev: Constructors,  Up: C Extensions
  57101. -
  57102. -Labeled Elements in Initializers
  57103. -================================
  57104. -
  57105. -   Standard C requires the elements of an initializer to appear in a
  57106. -fixed order, the same as the order of the elements in the array or
  57107. -structure being initialized.
  57108. -
  57109. -   In GNU C you can give the elements in any order, specifying the array
  57110. -indices or structure field names they apply to.  This extension is not
  57111. -implemented in GNU C++.
  57112. -
  57113. -   To specify an array index, write `[INDEX]' or `[INDEX] =' before the
  57114. -element value.  For example,
  57115. -
  57116. -     int a[6] = { [4] 29, [2] = 15 };
  57117. -
  57118. -is equivalent to
  57119. -
  57120. -     int a[6] = { 0, 0, 15, 0, 29, 0 };
  57121. -
  57122. -The index values must be constant expressions, even if the array being
  57123. -initialized is automatic.
  57124. -
  57125. -   To initialize a range of elements to the same value, write `[FIRST
  57126. -... LAST] = VALUE'.  For example,
  57127. -
  57128. -     int widths[] = { [0 ... 9] = 1, [10 ... 99] = 2, [100] = 3 };
  57129. -
  57130. -Note that the length of the array is the highest value specified plus
  57131. -one.
  57132. -
  57133. -   In a structure initializer, specify the name of a field to initialize
  57134. -with `FIELDNAME:' before the element value.  For example, given the
  57135. -following structure,
  57136. -
  57137. -     struct point { int x, y; };
  57138. -
  57139. -the following initialization
  57140. -
  57141. -     struct point p = { y: yvalue, x: xvalue };
  57142. -
  57143. -is equivalent to
  57144. -
  57145. -     struct point p = { xvalue, yvalue };
  57146. -
  57147. -   Another syntax which has the same meaning is `.FIELDNAME ='., as
  57148. -shown here:
  57149. -
  57150. -     struct point p = { .y = yvalue, .x = xvalue };
  57151. -
  57152. -   You can also use an element label (with either the colon syntax or
  57153. -the period-equal syntax) when initializing a union, to specify which
  57154. -element of the union should be used.  For example,
  57155. -
  57156. -     union foo { int i; double d; };
  57157. -     
  57158. -     union foo f = { d: 4 };
  57159. -
  57160. -will convert 4 to a `double' to store it in the union using the second
  57161. -element.  By contrast, casting 4 to type `union foo' would store it
  57162. -into the union as the integer `i', since it is an integer.  (*Note Cast
  57163. -to Union::.)
  57164. -
  57165. -   You can combine this technique of naming elements with ordinary C
  57166. -initialization of successive elements.  Each initializer element that
  57167. -does not have a label applies to the next consecutive element of the
  57168. -array or structure.  For example,
  57169. -
  57170. -     int a[6] = { [1] = v1, v2, [4] = v4 };
  57171. -
  57172. -is equivalent to
  57173. -
  57174. -     int a[6] = { 0, v1, v2, 0, v4, 0 };
  57175. -
  57176. -   Labeling the elements of an array initializer is especially useful
  57177. -when the indices are characters or belong to an `enum' type.  For
  57178. -example:
  57179. -
  57180. -     int whitespace[256]
  57181. -       = { [' '] = 1, ['\t'] = 1, ['\h'] = 1,
  57182. -           ['\f'] = 1, ['\n'] = 1, ['\r'] = 1 };
  57183. -
  57184. -
  57185. -File: gcc.info,  Node: Case Ranges,  Next: Function Attributes,  Prev: Cast to Union,  Up: C Extensions
  57186. -
  57187. -Case Ranges
  57188. -===========
  57189. -
  57190. -   You can specify a range of consecutive values in a single `case'
  57191. -label, like this:
  57192. -
  57193. -     case LOW ... HIGH:
  57194. -
  57195. -This has the same effect as the proper number of individual `case'
  57196. -labels, one for each integer value from LOW to HIGH, inclusive.
  57197. -
  57198. -   This feature is especially useful for ranges of ASCII character
  57199. -codes:
  57200. -
  57201. -     case 'A' ... 'Z':
  57202. -
  57203. -   *Be careful:* Write spaces around the `...', for otherwise it may be
  57204. -parsed wrong when you use it with integer values.  For example, write
  57205. -this:
  57206. -
  57207. -     case 1 ... 5:
  57208. -
  57209. -rather than this:
  57210. -
  57211. -     case 1...5:
  57212. -
  57213. -
  57214. -File: gcc.info,  Node: Cast to Union,  Next: Case Ranges,  Prev: Labeled Elements,  Up: C Extensions
  57215. -
  57216. -Cast to a Union Type
  57217. -====================
  57218. -
  57219. -   A cast to union type is similar to other casts, except that the type
  57220. -specified is a union type.  You can specify the type either with `union
  57221. -TAG' or with a typedef name.  A cast to union is actually a constructor
  57222. -though, not a cast, and hence does not yield an lvalue like normal
  57223. -casts.  (*Note Constructors::.)
  57224. -
  57225. -   The types that may be cast to the union type are those of the members
  57226. -of the union.  Thus, given the following union and variables:
  57227. -
  57228. -     union foo { int i; double d; };
  57229. -     int x;
  57230. -     double y;
  57231. -
  57232. -both `x' and `y' can be cast to type `union' foo.
  57233. -
  57234. -   Using the cast as the right-hand side of an assignment to a variable
  57235. -of union type is equivalent to storing in a member of the union:
  57236. -
  57237. -     union foo u;
  57238. -     ...
  57239. -     u = (union foo) x  ==  u.i = x
  57240. -     u = (union foo) y  ==  u.d = y
  57241. -
  57242. -   You can also use the union cast as a function argument:
  57243. -
  57244. -     void hack (union foo);
  57245. -     ...
  57246. -     hack ((union foo) x);
  57247. -
  57248. -
  57249. -File: gcc.info,  Node: Function Attributes,  Next: Function Prototypes,  Prev: Case Ranges,  Up: C Extensions
  57250. -
  57251. -Declaring Attributes of Functions
  57252. -=================================
  57253. -
  57254. -   In GNU C, you declare certain things about functions called in your
  57255. -program which help the compiler optimize function calls and check your
  57256. -code more carefully.
  57257. -
  57258. -   The keyword `__attribute__' allows you to specify special attributes
  57259. -when making a declaration.  This keyword is followed by an attribute
  57260. -specification inside double parentheses.  Eight attributes, `noreturn',
  57261. -`const', `format', `section', `constructor', `destructor', `unused' and
  57262. -`weak' are currently defined for functions.  Other attributes, including
  57263. -`section' are supported for variables declarations (*note Variable
  57264. -Attributes::.) and for types (*note Type Attributes::.).
  57265. -
  57266. -   You may also specify attributes with `__' preceding and following
  57267. -each keyword.  This allows you to use them in header files without
  57268. -being concerned about a possible macro of the same name.  For example,
  57269. -you may use `__noreturn__' instead of `noreturn'.
  57270. -
  57271. -`noreturn'
  57272. -     A few standard library functions, such as `abort' and `exit',
  57273. -     cannot return.  GNU CC knows this automatically.  Some programs
  57274. -     define their own functions that never return.  You can declare them
  57275. -     `noreturn' to tell the compiler this fact.  For example,
  57276. -
  57277. -          void fatal () __attribute__ ((noreturn));
  57278. -          
  57279. -          void
  57280. -          fatal (...)
  57281. -          {
  57282. -            ... /* Print error message. */ ...
  57283. -            exit (1);
  57284. -          }
  57285. -
  57286. -     The `noreturn' keyword tells the compiler to assume that `fatal'
  57287. -     cannot return.  It can then optimize without regard to what would
  57288. -     happen if `fatal' ever did return.  This makes slightly better
  57289. -     code.  More importantly, it helps avoid spurious warnings of
  57290. -     uninitialized variables.
  57291. -
  57292. -     Do not assume that registers saved by the calling function are
  57293. -     restored before calling the `noreturn' function.
  57294. -
  57295. -     It does not make sense for a `noreturn' function to have a return
  57296. -     type other than `void'.
  57297. -
  57298. -     The attribute `noreturn' is not implemented in GNU C versions
  57299. -     earlier than 2.5.  An alternative way to declare that a function
  57300. -     does not return, which works in the current version and in some
  57301. -     older versions, is as follows:
  57302. -
  57303. -          typedef void voidfn ();
  57304. -          
  57305. -          volatile voidfn fatal;
  57306. -
  57307. -`const'
  57308. -     Many functions do not examine any values except their arguments,
  57309. -     and have no effects except the return value.  Such a function can
  57310. -     be subject to common subexpression elimination and loop
  57311. -     optimization just as an arithmetic operator would be.  These
  57312. -     functions should be declared with the attribute `const'.  For
  57313. -     example,
  57314. -
  57315. -          int square (int) __attribute__ ((const));
  57316. -
  57317. -     says that the hypothetical function `square' is safe to call fewer
  57318. -     times than the program says.
  57319. -
  57320. -     The attribute `const' is not implemented in GNU C versions earlier
  57321. -     than 2.5.  An alternative way to declare that a function has no
  57322. -     side effects, which works in the current version and in some older
  57323. -     versions, is as follows:
  57324. -
  57325. -          typedef int intfn ();
  57326. -          
  57327. -          extern const intfn square;
  57328. -
  57329. -     This approach does not work in GNU C++ from 2.6.0 on, since the
  57330. -     language specifies that the `const' must be attached to the return
  57331. -     value.
  57332. -
  57333. -     Note that a function that has pointer arguments and examines the
  57334. -     data pointed to must *not* be declared `const'.  Likewise, a
  57335. -     function that calls a non-`const' function usually must not be
  57336. -     `const'.  It does not make sense for a `const' function to return
  57337. -     `void'.
  57338. -
  57339. -`format (ARCHETYPE, STRING-INDEX, FIRST-TO-CHECK)'
  57340. -     The `format' attribute specifies that a function takes `printf' or
  57341. -     `scanf' style arguments which should be type-checked against a
  57342. -     format string.  For example, the declaration:
  57343. -
  57344. -          extern int
  57345. -          my_printf (void *my_object, const char *my_format, ...)
  57346. -                __attribute__ ((format (printf, 2, 3)));
  57347. -
  57348. -     causes the compiler to check the arguments in calls to `my_printf'
  57349. -     for consistency with the `printf' style format string argument
  57350. -     `my_format'.
  57351. -
  57352. -     The parameter ARCHETYPE determines how the format string is
  57353. -     interpreted, and should be either `printf' or `scanf'.  The
  57354. -     parameter STRING-INDEX specifies which argument is the format
  57355. -     string argument (starting from 1), while FIRST-TO-CHECK is the
  57356. -     number of the first argument to check against the format string.
  57357. -     For functions where the arguments are not available to be checked
  57358. -     (such as `vprintf'), specify the third parameter as zero.  In this
  57359. -     case the compiler only checks the format string for consistency.
  57360. -
  57361. -     In the example above, the format string (`my_format') is the second
  57362. -     argument of the function `my_print', and the arguments to check
  57363. -     start with the third argument, so the correct parameters for the
  57364. -     format attribute are 2 and 3.
  57365. -
  57366. -     The `format' attribute allows you to identify your own functions
  57367. -     which take format strings as arguments, so that GNU CC can check
  57368. -     the calls to these functions for errors.  The compiler always
  57369. -     checks formats for the ANSI library functions `printf', `fprintf',
  57370. -     `sprintf', `scanf', `fscanf', `sscanf', `vprintf', `vfprintf' and
  57371. -     `vsprintf' whenever such warnings are requested (using
  57372. -     `-Wformat'), so there is no need to modify the header file
  57373. -     `stdio.h'.
  57374. -
  57375. -`section ("section-name")'
  57376. -     Normally, the compiler places the code it generates in the `text'
  57377. -     section.  Sometimes, however, you need additional sections, or you
  57378. -     need certain particular functions to appear in special sections.
  57379. -     The `section' attribute specifies that a function lives in a
  57380. -     particular section.  For example, the declaration:
  57381. -
  57382. -          extern void foobar (void) __attribute__ ((section ("bar")));
  57383. -
  57384. -     puts the function `foobar' in the `bar' section.
  57385. -
  57386. -     Some file formats do not support arbitrary sections so the
  57387. -     `section' attribute is not available on all platforms.  If you
  57388. -     need to map the entire contents of a module to a particular
  57389. -     section, consider using the facilities of the linker instead.
  57390. -
  57391. -`constructor'
  57392. -`destructor'
  57393. -     The `constructor' attribute causes the function to be called
  57394. -     automatically before execution enters `main ()'.  Similarly, the
  57395. -     `destructor' attribute causes the function to be called
  57396. -     automatically after `main ()' has completed or `exit ()' has been
  57397. -     called.  Functions with these attributes are useful for
  57398. -     initializing data that will be used implicitly during the
  57399. -     execution of the program.
  57400. -
  57401. -     These attributes are not currently implemented for Objective C.
  57402. -
  57403. -`unused'
  57404. -     This attribute, attached to a function, means that the function is
  57405. -     meant to be possibly unused.  GNU CC will not produce a warning
  57406. -     for this function.
  57407. -
  57408. -`weak'
  57409. -     The `weak' attribute causes the declaration to be emitted as a weak
  57410. -     symbol rather than a global.  This is primarily useful in defining
  57411. -     library functions which can be overridden in user code, though it
  57412. -     can also be used with non-function declarations.  Weak symbols are
  57413. -     supported for ELF targets, and also for a.out targets when using
  57414. -     the GNU assembler and linker.
  57415. -
  57416. -`alias ("target")'
  57417. -     The `alias' attribute causes the declaration to be emitted as an
  57418. -     alias for another symbol, which must be specified.  For instance,
  57419. -
  57420. -          void __f () { /* do something */; }
  57421. -          void f () __attribute__ ((weak, alias ("__f")));
  57422. -
  57423. -     declares `f' to be a weak alias for `__f'.  In C++, the mangled
  57424. -     name for the target must be used.
  57425. -
  57426. -`regparm (NUMBER)'
  57427. -     On the Intel 386, the `regparm' attribute causes the compiler to
  57428. -     pass up to NUMBER integer arguments in registers EAX, EDX, and ECX
  57429. -     instead of on the stack.  Functions that take a variable number of
  57430. -     arguments will continue to be passed all of their arguments on the
  57431. -     stack.
  57432. -
  57433. -`stdcall'
  57434. -     On the Intel 386, the `stdcall' attribute causes the compiler to
  57435. -     assume that the called function will pop off the stack space used
  57436. -     to pass arguments, unless it takes a variable number of arguments.
  57437. -
  57438. -`cdecl'
  57439. -     On the Intel 386, the `cdecl' attribute causes the compiler to
  57440. -     assume that the called function will pop off the stack space used
  57441. -     to pass arguments, unless it takes a variable number of arguments.
  57442. -     This is useful to override the effects of the `-mrtd' switch.
  57443. -
  57444. -   You can specify multiple attributes in a declaration by separating
  57445. -them by commas within the double parentheses or by immediately
  57446. -following an attribute declaration with another attribute declaration.
  57447. -
  57448. -   Some people object to the `__attribute__' feature, suggesting that
  57449. -ANSI C's `#pragma' should be used instead.  There are two reasons for
  57450. -not doing this.
  57451. -
  57452. -  1. It is impossible to generate `#pragma' commands from a macro.
  57453. -
  57454. -  2. There is no telling what the same `#pragma' might mean in another
  57455. -     compiler.
  57456. -
  57457. -   These two reasons apply to almost any application that might be
  57458. -proposed for `#pragma'.  It is basically a mistake to use `#pragma' for
  57459. -*anything*.
  57460. -
  57461. -
  57462. -File: gcc.info,  Node: Function Prototypes,  Next: C++ Comments,  Prev: Function Attributes,  Up: C Extensions
  57463. -
  57464. -Prototypes and Old-Style Function Definitions
  57465. -=============================================
  57466. -
  57467. -   GNU C extends ANSI C to allow a function prototype to override a
  57468. -later old-style non-prototype definition.  Consider the following
  57469. -example:
  57470. -
  57471. -     /* Use prototypes unless the compiler is old-fashioned.  */
  57472. -     #if __STDC__
  57473. -     #define P(x) x
  57474. -     #else
  57475. -     #define P(x) ()
  57476. -     #endif
  57477. -     
  57478. -     /* Prototype function declaration.  */
  57479. -     int isroot P((uid_t));
  57480. -     
  57481. -     /* Old-style function definition.  */
  57482. -     int
  57483. -     isroot (x)   /* ??? lossage here ??? */
  57484. -          uid_t x;
  57485. -     {
  57486. -       return x == 0;
  57487. -     }
  57488. -
  57489. -   Suppose the type `uid_t' happens to be `short'.  ANSI C does not
  57490. -allow this example, because subword arguments in old-style
  57491. -non-prototype definitions are promoted.  Therefore in this example the
  57492. -function definition's argument is really an `int', which does not match
  57493. -the prototype argument type of `short'.
  57494. -
  57495. -   This restriction of ANSI C makes it hard to write code that is
  57496. -portable to traditional C compilers, because the programmer does not
  57497. -know whether the `uid_t' type is `short', `int', or `long'.  Therefore,
  57498. -in cases like these GNU C allows a prototype to override a later
  57499. -old-style definition.  More precisely, in GNU C, a function prototype
  57500. -argument type overrides the argument type specified by a later
  57501. -old-style definition if the former type is the same as the latter type
  57502. -before promotion.  Thus in GNU C the above example is equivalent to the
  57503. -following:
  57504. -
  57505. -     int isroot (uid_t);
  57506. -     
  57507. -     int
  57508. -     isroot (uid_t x)
  57509. -     {
  57510. -       return x == 0;
  57511. -     }
  57512. -
  57513. -   GNU C++ does not support old-style function definitions, so this
  57514. -extension is irrelevant.
  57515. -
  57516. -
  57517. -File: gcc.info,  Node: C++ Comments,  Next: Dollar Signs,  Prev: Function Prototypes,  Up: C Extensions
  57518. -
  57519. -C++ Style Comments
  57520. -==================
  57521. -
  57522. -   In GNU C, you may use C++ style comments, which start with `//' and
  57523. -continue until the end of the line.  Many other C implementations allow
  57524. -such comments, and they are likely to be in a future C standard.
  57525. -However, C++ style comments are not recognized if you specify `-ansi'
  57526. -or `-traditional', since they are incompatible with traditional
  57527. -constructs like `dividend//*comment*/divisor'.
  57528. -
  57529. -
  57530. -File: gcc.info,  Node: Dollar Signs,  Next: Character Escapes,  Prev: C++ Comments,  Up: C Extensions
  57531. -
  57532. -Dollar Signs in Identifier Names
  57533. -================================
  57534. -
  57535. -   In GNU C, you may use dollar signs in identifier names.  This is
  57536. -because many traditional C implementations allow such identifiers.
  57537. -
  57538. -   On some machines, dollar signs are allowed in identifiers if you
  57539. -specify `-traditional'.  On a few systems they are allowed by default,
  57540. -even if you do not use `-traditional'.  But they are never allowed if
  57541. -you specify `-ansi'.
  57542. -
  57543. -   There are certain ANSI C programs (obscure, to be sure) that would
  57544. -compile incorrectly if dollar signs were permitted in identifiers.  For
  57545. -example:
  57546. -
  57547. -     #define foo(a) #a
  57548. -     #define lose(b) foo (b)
  57549. -     #define test$
  57550. -     lose (test)
  57551. -
  57552. -
  57553. -File: gcc.info,  Node: Character Escapes,  Next: Variable Attributes,  Prev: Dollar Signs,  Up: C Extensions
  57554. -
  57555. -The Character ESC in Constants
  57556. -==============================
  57557. -
  57558. -   You can use the sequence `\e' in a string or character constant to
  57559. -stand for the ASCII character ESC.
  57560. -
  57561. -
  57562. -File: gcc.info,  Node: Alignment,  Next: Inline,  Prev: Type Attributes,  Up: C Extensions
  57563. -
  57564. -Inquiring on Alignment of Types or Variables
  57565. -============================================
  57566. -
  57567. -   The keyword `__alignof__' allows you to inquire about how an object
  57568. -is aligned, or the minimum alignment usually required by a type.  Its
  57569. -syntax is just like `sizeof'.
  57570. -
  57571. -   For example, if the target machine requires a `double' value to be
  57572. -aligned on an 8-byte boundary, then `__alignof__ (double)' is 8.  This
  57573. -is true on many RISC machines.  On more traditional machine designs,
  57574. -`__alignof__ (double)' is 4 or even 2.
  57575. -
  57576. -   Some machines never actually require alignment; they allow reference
  57577. -to any data type even at an odd addresses.  For these machines,
  57578. -`__alignof__' reports the *recommended* alignment of a type.
  57579. -
  57580. -   When the operand of `__alignof__' is an lvalue rather than a type,
  57581. -the value is the largest alignment that the lvalue is known to have.
  57582. -It may have this alignment as a result of its data type, or because it
  57583. -is part of a structure and inherits alignment from that structure.  For
  57584. -example, after this declaration:
  57585. -
  57586. -     struct foo { int x; char y; } foo1;
  57587. -
  57588. -the value of `__alignof__ (foo1.y)' is probably 2 or 4, the same as
  57589. -`__alignof__ (int)', even though the data type of `foo1.y' does not
  57590. -itself demand any alignment.
  57591. -
  57592. -   A related feature which lets you specify the alignment of an object
  57593. -is `__attribute__ ((aligned (ALIGNMENT)))'; see the following section.
  57594. -
  57595. -
  57596. -File: gcc.info,  Node: Variable Attributes,  Next: Type Attributes,  Prev: Character Escapes,  Up: C Extensions
  57597. -
  57598. -Specifying Attributes of Variables
  57599. -==================================
  57600. -
  57601. -   The keyword `__attribute__' allows you to specify special attributes
  57602. -of variables or structure fields.  This keyword is followed by an
  57603. -attribute specification inside double parentheses.  Eight attributes
  57604. -are currently defined for variables: `aligned', `mode', `nocommon',
  57605. -`packed', `section', `transparent_union', `unused', and `weak'.  Other
  57606. -attributes are available for functions (*note Function Attributes::.)
  57607. -and for types (*note Type Attributes::.).
  57608. -
  57609. -   You may also specify attributes with `__' preceding and following
  57610. -each keyword.  This allows you to use them in header files without
  57611. -being concerned about a possible macro of the same name.  For example,
  57612. -you may use `__aligned__' instead of `aligned'.
  57613. -
  57614. -`aligned (ALIGNMENT)'
  57615. -     This attribute specifies a minimum alignment for the variable or
  57616. -     structure field, measured in bytes.  For example, the declaration:
  57617. -
  57618. -          int x __attribute__ ((aligned (16))) = 0;
  57619. -
  57620. -     causes the compiler to allocate the global variable `x' on a
  57621. -     16-byte boundary.  On a 68040, this could be used in conjunction
  57622. -     with an `asm' expression to access the `move16' instruction which
  57623. -     requires 16-byte aligned operands.
  57624. -
  57625. -     You can also specify the alignment of structure fields.  For
  57626. -     example, to create a double-word aligned `int' pair, you could
  57627. -     write:
  57628. -
  57629. -          struct foo { int x[2] __attribute__ ((aligned (8))); };
  57630. -
  57631. -     This is an alternative to creating a union with a `double' member
  57632. -     that forces the union to be double-word aligned.
  57633. -
  57634. -     It is not possible to specify the alignment of functions; the
  57635. -     alignment of functions is determined by the machine's requirements
  57636. -     and cannot be changed.  You cannot specify alignment for a typedef
  57637. -     name because such a name is just an alias, not a distinct type.
  57638. -
  57639. -     As in the preceding examples, you can explicitly specify the
  57640. -     alignment (in bytes) that you wish the compiler to use for a given
  57641. -     variable or structure field.  Alternatively, you can leave out the
  57642. -     alignment factor and just ask the compiler to align a variable or
  57643. -     field to the maximum useful alignment for the target machine you
  57644. -     are compiling for.  For example, you could write:
  57645. -
  57646. -          short array[3] __attribute__ ((aligned));
  57647. -
  57648. -     Whenever you leave out the alignment factor in an `aligned'
  57649. -     attribute specification, the compiler automatically sets the
  57650. -     alignment for the declared variable or field to the largest
  57651. -     alignment which is ever used for any data type on the target
  57652. -     machine you are compiling for.  Doing this can often make copy
  57653. -     operations more efficient, because the compiler can use whatever
  57654. -     instructions copy the biggest chunks of memory when performing
  57655. -     copies to or from the variables or fields that you have aligned
  57656. -     this way.
  57657. -
  57658. -     The `aligned' attribute can only increase the alignment; but you
  57659. -     can decrease it by specifying `packed' as well.  See below.
  57660. -
  57661. -     Note that the effectiveness of `aligned' attributes may be limited
  57662. -     by inherent limitations in your linker.  On many systems, the
  57663. -     linker is only able to arrange for variables to be aligned up to a
  57664. -     certain maximum alignment.  (For some linkers, the maximum
  57665. -     supported alignment may be very very small.)  If your linker is
  57666. -     only able to align variables up to a maximum of 8 byte alignment,
  57667. -     then specifying `aligned(16)' in an `__attribute__' will still
  57668. -     only provide you with 8 byte alignment.  See your linker
  57669. -     documentation for further information.
  57670. -
  57671. -`mode (MODE)'
  57672. -     This attribute specifies the data type for the
  57673. -     declaration--whichever type corresponds to the mode MODE.  This in
  57674. -     effect lets you request an integer or floating point type
  57675. -     according to its width.
  57676. -
  57677. -     You may also specify a mode of `byte' or `__byte__' to indicate
  57678. -     the mode corresponding to a one-byte integer, `word' or `__word__'
  57679. -     for the mode of a one-word integer, and `pointer' or `__pointer__'
  57680. -     for the mode used to represent pointers.
  57681. -
  57682. -`nocommon'
  57683. -     This attribute specifies requests GNU CC not to place a variable
  57684. -     "common" but instead to allocate space for it directly.  If you
  57685. -     specify the `-fno-common' flag, GNU CC will do this for all
  57686. -     variables.
  57687. -
  57688. -     Specifying the `nocommon' attribute for a variable provides an
  57689. -     initialization of zeros.  A variable may only be initialized in one
  57690. -     source file.
  57691. -
  57692. -`packed'
  57693. -     The `packed' attribute specifies that a variable or structure field
  57694. -     should have the smallest possible alignment--one byte for a
  57695. -     variable, and one bit for a field, unless you specify a larger
  57696. -     value with the `aligned' attribute.
  57697. -
  57698. -     Here is a structure in which the field `x' is packed, so that it
  57699. -     immediately follows `a':
  57700. -
  57701. -          struct foo
  57702. -          {
  57703. -            char a;
  57704. -            int x[2] __attribute__ ((packed));
  57705. -          };
  57706. -
  57707. -`section ("section-name")'
  57708. -     Normally, the compiler places the objects it generates in sections
  57709. -     like `data' and `bss'.  Sometimes, however, you need additional
  57710. -     sections, or you need certain particular variables to appear in
  57711. -     special sections, for example to map to special hardware.  The
  57712. -     `section' attribute specifies that a variable (or function) lives
  57713. -     in a particular section.  For example, this small program uses
  57714. -     several specific section names:
  57715. -
  57716. -          struct duart a __attribute__ ((section ("DUART_A"))) = { 0 };
  57717. -          struct duart b __attribute__ ((section ("DUART_B"))) = { 0 };
  57718. -          char stack[10000] __attribute__ ((section ("STACK"))) = { 0 };
  57719. -          int init_data_copy __attribute__ ((section ("INITDATACOPY"))) = 0;
  57720. -          
  57721. -          main()
  57722. -          {
  57723. -            /* Initialize stack pointer */
  57724. -            init_sp (stack + sizeof (stack));
  57725. -          
  57726. -            /* Initialize initialized data */
  57727. -            memcpy (&init_data_copy, &data, &edata - &data);
  57728. -          
  57729. -            /* Turn on the serial ports */
  57730. -            init_duart (&a);
  57731. -            init_duart (&b);
  57732. -          }
  57733. -
  57734. -     Use the `section' attribute with an *initialized* definition of a
  57735. -     *global* variable, as shown in the example.  GNU CC issues a
  57736. -     warning and otherwise ignores the `section' attribute in
  57737. -     uninitialized variable declarations.
  57738. -
  57739. -     You may only use the `section' attribute with a fully initialized
  57740. -     global definition because of the way linkers work.  The linker
  57741. -     requires each object be defined once, with the exception that
  57742. -     uninitialized variables tentatively go in the `common' (or `bss')
  57743. -     section and can be multiply "defined".  You can force a variable
  57744. -     to be initialized with the `-fno-common' flag or the `nocommon'
  57745. -     attribute.
  57746. -
  57747. -     Some file formats do not support arbitrary sections so the
  57748. -     `section' attribute is not available on all platforms.  If you
  57749. -     need to map the entire contents of a module to a particular
  57750. -     section, consider using the facilities of the linker instead.
  57751. -
  57752. -`transparent_union'
  57753. -     This attribute, attached to a function argument variable which is a
  57754. -     union, means to pass the argument in the same way that the first
  57755. -     union member would be passed.  You can also use this attribute on a
  57756. -     `typedef' for a union data type; then it applies to all function
  57757. -     arguments with that type.
  57758. -
  57759. -`unused'
  57760. -     This attribute, attached to a variable, means that the variable is
  57761. -     meant to be possibly unused.  GNU CC will not produce a warning
  57762. -     for this variable.
  57763. -
  57764. -`weak'
  57765. -     The `weak' attribute is described in *Note Function Attributes::.
  57766. -
  57767. -   To specify multiple attributes, separate them by commas within the
  57768. -double parentheses: for example, `__attribute__ ((aligned (16),
  57769. -packed))'.
  57770. -
  57771. -
  57772. -File: gcc.info,  Node: Type Attributes,  Next: Alignment,  Prev: Variable Attributes,  Up: C Extensions
  57773. -
  57774. -Specifying Attributes of Types
  57775. -==============================
  57776. -
  57777. -   The keyword `__attribute__' allows you to specify special attributes
  57778. -of `struct' and `union' types when you define such types.  This keyword
  57779. -is followed by an attribute specification inside double parentheses.
  57780. -Three attributes are currently defined for types: `aligned', `packed',
  57781. -and `transparent_union'.  Other attributes are defined for functions
  57782. -(*note Function Attributes::.) and for variables (*note Variable
  57783. -Attributes::.).
  57784. -
  57785. -   You may also specify any one of these attributes with `__' preceding
  57786. -and following its keyword.  This allows you to use these attributes in
  57787. -header files without being concerned about a possible macro of the same
  57788. -name.  For example, you may use `__aligned__' instead of `aligned'.
  57789. -
  57790. -   You may specify the `aligned' and `transparent_union' attributes
  57791. -either in a `typedef' declaration or just past the closing curly brace
  57792. -of a complete enum, struct or union type *definition* and the `packed'
  57793. -attribute only past the closing brace of a definition.
  57794. -
  57795. -`aligned (ALIGNMENT)'
  57796. -     This attribute specifies a minimum alignment (in bytes) for
  57797. -     variables of the specified type.  For example, the declarations:
  57798. -
  57799. -          struct S { short f[3]; } __attribute__ ((aligned (8));
  57800. -          typedef int more_aligned_int __attribute__ ((aligned (8));
  57801. -
  57802. -     force the compiler to insure (as fas as it can) that each variable
  57803. -     whose type is `struct S' or `more_aligned_int' will be allocated
  57804. -     and aligned *at least* on a 8-byte boundary.  On a Sparc, having
  57805. -     all variables of type `struct S' aligned to 8-byte boundaries
  57806. -     allows the compiler to use the `ldd' and `std' (doubleword load and
  57807. -     store) instructions when copying one variable of type `struct S' to
  57808. -     another, thus improving run-time efficiency.
  57809. -
  57810. -     Note that the alignment of any given `struct' or `union' type is
  57811. -     required by the ANSI C standard to be at least a perfect multiple
  57812. -     of the lowest common multiple of the alignments of all of the
  57813. -     members of the `struct' or `union' in question.  This means that
  57814. -     you *can* effectively adjust the alignment of a `struct' or `union'
  57815. -     type by attaching an `aligned' attribute to any one of the members
  57816. -     of such a type, but the notation illustrated in the example above
  57817. -     is a more obvious, intuitive, and readable way to request the
  57818. -     compiler to adjust the alignment of an entire `struct' or `union'
  57819. -     type.
  57820. -
  57821. -     As in the preceding example, you can explicitly specify the
  57822. -     alignment (in bytes) that you wish the compiler to use for a given
  57823. -     `struct' or `union' type.  Alternatively, you can leave out the
  57824. -     alignment factor and just ask the compiler to align a type to the
  57825. -     maximum useful alignment for the target machine you are compiling
  57826. -     for.  For example, you could write:
  57827. -
  57828. -          struct S { short f[3]; } __attribute__ ((aligned));
  57829. -
  57830. -     Whenever you leave out the alignment factor in an `aligned'
  57831. -     attribute specification, the compiler automatically sets the
  57832. -     alignment for the type to the largest alignment which is ever used
  57833. -     for any data type on the target machine you are compiling for.
  57834. -     Doing this can often make copy operations more efficient, because
  57835. -     the compiler can use whatever instructions copy the biggest chunks
  57836. -     of memory when performing copies to or from the variables which
  57837. -     have types that you have aligned this way.
  57838. -
  57839. -     In the example above, if the size of each `short' is 2 bytes, then
  57840. -     the size of the entire `struct S' type is 6 bytes.  The smallest
  57841. -     power of two which is greater than or equal to that is 8, so the
  57842. -     compiler sets the alignment for the entire `struct S' type to 8
  57843. -     bytes.
  57844. -
  57845. -     Note that although you can ask the compiler to select a
  57846. -     time-efficient alignment for a given type and then declare only
  57847. -     individual stand-alone objects of that type, the compiler's
  57848. -     ability to select a time-efficient alignment is primarily useful
  57849. -     only when you plan to create arrays of variables having the
  57850. -     relevant (efficiently aligned) type.  If you declare or use arrays
  57851. -     of variables of an efficiently-aligned type, then it is likely
  57852. -     that your program will also be doing pointer arithmetic (or
  57853. -     subscripting, which amounts to the same thing) on pointers to the
  57854. -     relevant type, and the code that the compiler generates for these
  57855. -     pointer arithmetic operations will often be more efficient for
  57856. -     efficiently-aligned types than for other types.
  57857. -
  57858. -     The `aligned' attribute can only increase the alignment; but you
  57859. -     can decrease it by specifying `packed' as well.  See below.
  57860. -
  57861. -     Note that the effectiveness of `aligned' attributes may be limited
  57862. -     by inherent limitations in your linker.  On many systems, the
  57863. -     linker is only able to arrange for variables to be aligned up to a
  57864. -     certain maximum alignment.  (For some linkers, the maximum
  57865. -     supported alignment may be very very small.)  If your linker is
  57866. -     only able to align variables up to a maximum of 8 byte alignment,
  57867. -     then specifying `aligned(16)' in an `__attribute__' will still
  57868. -     only provide you with 8 byte alignment.  See your linker
  57869. -     documentation for further information.
  57870. -
  57871. -`packed'
  57872. -     This attribute, attached to an `enum', `struct', or `union' type
  57873. -     definition, specified that the minimum required memory be used to
  57874. -     represent the type.
  57875. -
  57876. -     Specifying this attribute for `struct' and `union' types is
  57877. -     equivalent to specifying the `packed' attribute on each of the
  57878. -     structure or union members.  Specifying the `-fshort-enums' flag
  57879. -     on the line is equivalent to specifying the `packed' attribute on
  57880. -     all `enum' definitions.
  57881. -
  57882. -     You may only specify this attribute after a closing curly brace on
  57883. -     an `enum' definition, not in a `typedef' declaration.
  57884. -
  57885. -`transparent_union'
  57886. -     This attribute, attached to a `union' type definition, indicates
  57887. -     that any variable having that union type should, if passed to a
  57888. -     function, be passed in the same way that the first union member
  57889. -     would be passed.  For example:
  57890. -
  57891. -          union foo
  57892. -          {
  57893. -            char a;
  57894. -            int x[2];
  57895. -          } __attribute__ ((transparent_union));
  57896. -
  57897. -   To specify multiple attributes, separate them by commas within the
  57898. -double parentheses: for example, `__attribute__ ((aligned (16),
  57899. -packed))'.
  57900. -
  57901. -
  57902. -File: gcc.info,  Node: Inline,  Next: Extended Asm,  Prev: Alignment,  Up: C Extensions
  57903. -
  57904. -An Inline Function is As Fast As a Macro
  57905. -========================================
  57906. -
  57907. -   By declaring a function `inline', you can direct GNU CC to integrate
  57908. -that function's code into the code for its callers.  This makes
  57909. -execution faster by eliminating the function-call overhead; in
  57910. -addition, if any of the actual argument values are constant, their known
  57911. -values may permit simplifications at compile time so that not all of the
  57912. -inline function's code needs to be included.  The effect on code size is
  57913. -less predictable; object code may be larger or smaller with function
  57914. -inlining, depending on the particular case.  Inlining of functions is an
  57915. -optimization and it really "works" only in optimizing compilation.  If
  57916. -you don't use `-O', no function is really inline.
  57917. -
  57918. -   To declare a function inline, use the `inline' keyword in its
  57919. -declaration, like this:
  57920. -
  57921. -     inline int
  57922. -     inc (int *a)
  57923. -     {
  57924. -       (*a)++;
  57925. -     }
  57926. -
  57927. -   (If you are writing a header file to be included in ANSI C programs,
  57928. -write `__inline__' instead of `inline'.  *Note Alternate Keywords::.)
  57929. -
  57930. -   You can also make all "simple enough" functions inline with the
  57931. -option `-finline-functions'.  Note that certain usages in a function
  57932. -definition can make it unsuitable for inline substitution.
  57933. -
  57934. -   Note that in C and Objective C, unlike C++, the `inline' keyword
  57935. -does not affect the linkage of the function.
  57936. -
  57937. -   GNU CC automatically inlines member functions defined within the
  57938. -class body of C++ programs even if they are not explicitly declared
  57939. -`inline'.  (You can override this with `-fno-default-inline'; *note
  57940. -Options Controlling C++ Dialect: C++ Dialect Options..)
  57941. -
  57942. -   When a function is both inline and `static', if all calls to the
  57943. -function are integrated into the caller, and the function's address is
  57944. -never used, then the function's own assembler code is never referenced.
  57945. -In this case, GNU CC does not actually output assembler code for the
  57946. -function, unless you specify the option `-fkeep-inline-functions'.
  57947. -Some calls cannot be integrated for various reasons (in particular,
  57948. -calls that precede the function's definition cannot be integrated, and
  57949. -neither can recursive calls within the definition).  If there is a
  57950. -nonintegrated call, then the function is compiled to assembler code as
  57951. -usual.  The function must also be compiled as usual if the program
  57952. -refers to its address, because that can't be inlined.
  57953. -
  57954. -   When an inline function is not `static', then the compiler must
  57955. -assume that there may be calls from other source files; since a global
  57956. -symbol can be defined only once in any program, the function must not
  57957. -be defined in the other source files, so the calls therein cannot be
  57958. -integrated.  Therefore, a non-`static' inline function is always
  57959. -compiled on its own in the usual fashion.
  57960. -
  57961. -   If you specify both `inline' and `extern' in the function
  57962. -definition, then the definition is used only for inlining.  In no case
  57963. -is the function compiled on its own, not even if you refer to its
  57964. -address explicitly.  Such an address becomes an external reference, as
  57965. -if you had only declared the function, and had not defined it.
  57966. -
  57967. -   This combination of `inline' and `extern' has almost the effect of a
  57968. -macro.  The way to use it is to put a function definition in a header
  57969. -file with these keywords, and put another copy of the definition
  57970. -(lacking `inline' and `extern') in a library file.  The definition in
  57971. -the header file will cause most calls to the function to be inlined.
  57972. -If any uses of the function remain, they will refer to the single copy
  57973. -in the library.
  57974. -
  57975. -   GNU C does not inline any functions when not optimizing.  It is not
  57976. -clear whether it is better to inline or not, in this case, but we found
  57977. -that a correct implementation when not optimizing was difficult.  So we
  57978. -did the easy thing, and turned it off.
  57979. -
  57980. -
  57981. -File: gcc.info,  Node: Extended Asm,  Next: Asm Labels,  Prev: Inline,  Up: C Extensions
  57982. -
  57983. -Assembler Instructions with C Expression Operands
  57984. -=================================================
  57985. -
  57986. -   In an assembler instruction using `asm', you can now specify the
  57987. -operands of the instruction using C expressions.  This means no more
  57988. -guessing which registers or memory locations will contain the data you
  57989. -want to use.
  57990. -
  57991. -   You must specify an assembler instruction template much like what
  57992. -appears in a machine description, plus an operand constraint string for
  57993. -each operand.
  57994. -
  57995. -   For example, here is how to use the 68881's `fsinx' instruction:
  57996. -
  57997. -     asm ("fsinx %1,%0" : "=f" (result) : "f" (angle));
  57998. -
  57999. -Here `angle' is the C expression for the input operand while `result'
  58000. -is that of the output operand.  Each has `"f"' as its operand
  58001. -constraint, saying that a floating point register is required.  The `='
  58002. -in `=f' indicates that the operand is an output; all output operands'
  58003. -constraints must use `='.  The constraints use the same language used
  58004. -in the machine description (*note Constraints::.).
  58005. -
  58006. -   Each operand is described by an operand-constraint string followed
  58007. -by the C expression in parentheses.  A colon separates the assembler
  58008. -template from the first output operand, and another separates the last
  58009. -output operand from the first input, if any.  Commas separate output
  58010. -operands and separate inputs.  The total number of operands is limited
  58011. -to ten or to the maximum number of operands in any instruction pattern
  58012. -in the machine description, whichever is greater.
  58013. -
  58014. -   If there are no output operands, and there are input operands, then
  58015. -there must be two consecutive colons surrounding the place where the
  58016. -output operands would go.
  58017. -
  58018. -   Output operand expressions must be lvalues; the compiler can check
  58019. -this.  The input operands need not be lvalues.  The compiler cannot
  58020. -check whether the operands have data types that are reasonable for the
  58021. -instruction being executed.  It does not parse the assembler
  58022. -instruction template and does not know what it means, or whether it is
  58023. -valid assembler input.  The extended `asm' feature is most often used
  58024. -for machine instructions that the compiler itself does not know exist.
  58025. -If the output expression cannot be directly addressed (for example, it
  58026. -is a bit field), your constraint must allow a register.  In that case,
  58027. -GNU CC will use the register as the output of the `asm', and then store
  58028. -that register into the output.
  58029. -
  58030. -   The output operands must be write-only; GNU CC will assume that the
  58031. -values in these operands before the instruction are dead and need not be
  58032. -generated.  Extended asm does not support input-output or read-write
  58033. -operands.  For this reason, the constraint character `+', which
  58034. -indicates such an operand, may not be used.
  58035. -
  58036. -   When the assembler instruction has a read-write operand, or an
  58037. -operand in which only some of the bits are to be changed, you must
  58038. -logically split its function into two separate operands, one input
  58039. -operand and one write-only output operand.  The connection between them
  58040. -is expressed by constraints which say they need to be in the same
  58041. -location when the instruction executes.  You can use the same C
  58042. -expression for both operands, or different expressions.  For example,
  58043. -here we write the (fictitious) `combine' instruction with `bar' as its
  58044. -read-only source operand and `foo' as its read-write destination:
  58045. -
  58046. -     asm ("combine %2,%0" : "=r" (foo) : "0" (foo), "g" (bar));
  58047. -
  58048. -The constraint `"0"' for operand 1 says that it must occupy the same
  58049. -location as operand 0.  A digit in constraint is allowed only in an
  58050. -input operand, and it must refer to an output operand.
  58051. -
  58052. -   Only a digit in the constraint can guarantee that one operand will
  58053. -be in the same place as another.  The mere fact that `foo' is the value
  58054. -of both operands is not enough to guarantee that they will be in the
  58055. -same place in the generated assembler code.  The following would not
  58056. -work:
  58057. -
  58058. -     asm ("combine %2,%0" : "=r" (foo) : "r" (foo), "g" (bar));
  58059. -
  58060. -   Various optimizations or reloading could cause operands 0 and 1 to
  58061. -be in different registers; GNU CC knows no reason not to do so.  For
  58062. -example, the compiler might find a copy of the value of `foo' in one
  58063. -register and use it for operand 1, but generate the output operand 0 in
  58064. -a different register (copying it afterward to `foo''s own address).  Of
  58065. -course, since the register for operand 1 is not even mentioned in the
  58066. -assembler code, the result will not work, but GNU CC can't tell that.
  58067. -
  58068. -   Some instructions clobber specific hard registers.  To describe
  58069. -this, write a third colon after the input operands, followed by the
  58070. -names of the clobbered hard registers (given as strings).  Here is a
  58071. -realistic example for the Vax:
  58072. -
  58073. -     asm volatile ("movc3 %0,%1,%2"
  58074. -                   : /* no outputs */
  58075. -                   : "g" (from), "g" (to), "g" (count)
  58076. -                   : "r0", "r1", "r2", "r3", "r4", "r5");
  58077. -
  58078. -   If you refer to a particular hardware register from the assembler
  58079. -code, then you will probably have to list the register after the third
  58080. -colon to tell the compiler that the register's value is modified.  In
  58081. -many assemblers, the register names begin with `%'; to produce one `%'
  58082. -in the assembler code, you must write `%%' in the input.
  58083. -
  58084. -   If your assembler instruction can alter the condition code register,
  58085. -add `cc' to the list of clobbered registers.  GNU CC on some machines
  58086. -represents the condition codes as a specific hardware register; `cc'
  58087. -serves to name this register.  On other machines, the condition code is
  58088. -handled differently, and specifying `cc' has no effect.  But it is
  58089. -valid no matter what the machine.
  58090. -
  58091. -   If your assembler instruction modifies memory in an unpredictable
  58092. -fashion, add `memory' to the list of clobbered registers.  This will
  58093. -cause GNU CC to not keep memory values cached in registers across the
  58094. -assembler instruction.
  58095. -
  58096. -   You can put multiple assembler instructions together in a single
  58097. -`asm' template, separated either with newlines (written as `\n') or with
  58098. -semicolons if the assembler allows such semicolons.  The GNU assembler
  58099. -allows semicolons and all Unix assemblers seem to do so.  The input
  58100. -operands are guaranteed not to use any of the clobbered registers, and
  58101. -neither will the output operands' addresses, so you can read and write
  58102. -the clobbered registers as many times as you like.  Here is an example
  58103. -of multiple instructions in a template; it assumes that the subroutine
  58104. -`_foo' accepts arguments in registers 9 and 10:
  58105. -
  58106. -     asm ("movl %0,r9;movl %1,r10;call _foo"
  58107. -          : /* no outputs */
  58108. -          : "g" (from), "g" (to)
  58109. -          : "r9", "r10");
  58110. -
  58111. -   Unless an output operand has the `&' constraint modifier, GNU CC may
  58112. -allocate it in the same register as an unrelated input operand, on the
  58113. -assumption that the inputs are consumed before the outputs are produced.
  58114. -This assumption may be false if the assembler code actually consists of
  58115. -more than one instruction.  In such a case, use `&' for each output
  58116. -operand that may not overlap an input.  *Note Modifiers::.
  58117. -
  58118. -   If you want to test the condition code produced by an assembler
  58119. -instruction, you must include a branch and a label in the `asm'
  58120. -construct, as follows:
  58121. -
  58122. -     asm ("clr %0;frob %1;beq 0f;mov #1,%0;0:"
  58123. -          : "g" (result)
  58124. -          : "g" (input));
  58125. -
  58126. -This assumes your assembler supports local labels, as the GNU assembler
  58127. -and most Unix assemblers do.
  58128. -
  58129. -   Speaking of labels, jumps from one `asm' to another are not
  58130. -supported.  The compiler's optimizers do not know about these jumps,
  58131. -and therefore they cannot take account of them when deciding how to
  58132. -optimize.
  58133. -
  58134. -   Usually the most convenient way to use these `asm' instructions is to
  58135. -encapsulate them in macros that look like functions.  For example,
  58136. -
  58137. -     #define sin(x)       \
  58138. -     ({ double __value, __arg = (x);   \
  58139. -        asm ("fsinx %1,%0": "=f" (__value): "f" (__arg));  \
  58140. -        __value; })
  58141. -
  58142. -Here the variable `__arg' is used to make sure that the instruction
  58143. -operates on a proper `double' value, and to accept only those arguments
  58144. -`x' which can convert automatically to a `double'.
  58145. -
  58146. -   Another way to make sure the instruction operates on the correct
  58147. -data type is to use a cast in the `asm'.  This is different from using a
  58148. -variable `__arg' in that it converts more different types.  For
  58149. -example, if the desired type were `int', casting the argument to `int'
  58150. -would accept a pointer with no complaint, while assigning the argument
  58151. -to an `int' variable named `__arg' would warn about using a pointer
  58152. -unless the caller explicitly casts it.
  58153. -
  58154. -   If an `asm' has output operands, GNU CC assumes for optimization
  58155. -purposes that the instruction has no side effects except to change the
  58156. -output operands.  This does not mean that instructions with a side
  58157. -effect cannot be used, but you must be careful, because the compiler
  58158. -may eliminate them if the output operands aren't used, or move them out
  58159. -of loops, or replace two with one if they constitute a common
  58160. -subexpression.  Also, if your instruction does have a side effect on a
  58161. -variable that otherwise appears not to change, the old value of the
  58162. -variable may be reused later if it happens to be found in a register.
  58163. -
  58164. -   You can prevent an `asm' instruction from being deleted, moved
  58165. -significantly, or combined, by writing the keyword `volatile' after the
  58166. -`asm'.  For example:
  58167. -
  58168. -     #define set_priority(x)  \
  58169. -     asm volatile ("set_priority %0": /* no outputs */ : "g" (x))
  58170. -
  58171. -An instruction without output operands will not be deleted or moved
  58172. -significantly, regardless, unless it is unreachable.
  58173. -
  58174. -   Note that even a volatile `asm' instruction can be moved in ways
  58175. -that appear insignificant to the compiler, such as across jump
  58176. -instructions.  You can't expect a sequence of volatile `asm'
  58177. -instructions to remain perfectly consecutive.  If you want consecutive
  58178. -output, use a single `asm'.
  58179. -
  58180. -   It is a natural idea to look for a way to give access to the
  58181. -condition code left by the assembler instruction.  However, when we
  58182. -attempted to implement this, we found no way to make it work reliably.
  58183. -The problem is that output operands might need reloading, which would
  58184. -result in additional following "store" instructions.  On most machines,
  58185. -these instructions would alter the condition code before there was time
  58186. -to test it.  This problem doesn't arise for ordinary "test" and
  58187. -"compare" instructions because they don't have any output operands.
  58188. -
  58189. -   If you are writing a header file that should be includable in ANSI C
  58190. -programs, write `__asm__' instead of `asm'.  *Note Alternate Keywords::.
  58191. -
  58192. diff -rup --new-file baseline/fsf/gcc/genconfig.c amiga/fsf/gcc/genconfig.c
  58193. --- baseline/fsf/gcc/genconfig.c    Thu Jun 15 04:40:18 1995
  58194. +++ amiga/fsf/gcc/genconfig.c    Sat Sep 28 00:00:00 1996
  58195. @@ -304,8 +304,10 @@ main (argc, argv)
  58196.    printf ("/* Generated automatically by the program `genconfig'\n\
  58197.  from the machine description file `md'.  */\n\n");
  58198.  
  58199. -  /* Allow at least 10 operands for the sake of asm constructs.  */
  58200. -  max_recog_operands = 9;  /* We will add 1 later.  */
  58201. +  /* Amiga note - this constant probably better be 15 in general, or a cross
  58202. +     compiling host might choke on some amigaos header files... */
  58203. +  /* Allow at least 15 operands for the sake of asm constructs.  */
  58204. +  max_recog_operands = 14;    /* We will add 1 later. */
  58205.    max_dup_operands = 1;
  58206.  
  58207.    /* Read the machine description.  */
  58208. diff -rup --new-file baseline/fsf/gcc/ginclude/stdarg.h amiga/fsf/gcc/ginclude/stdarg.h
  58209. --- baseline/fsf/gcc/ginclude/stdarg.h    Tue Sep 12 09:50:36 1995
  58210. +++ amiga/fsf/gcc/ginclude/stdarg.h    Sat Sep 28 00:00:00 1996
  58211. @@ -140,7 +140,7 @@ typedef __gnuc_va_list va_list;
  58212.     But on BSD NET2 we must not test or define or undef it.
  58213.     (Note that the comments in NET 2's ansi.h
  58214.     are incorrect for _VA_LIST_--see stdio.h!)  */
  58215. -#if !defined (_VA_LIST_) || defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(WINNT)
  58216. +#if !defined (_VA_LIST_) || defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(WINNT) || defined(__amigaos__)
  58217.  /* The macro _VA_LIST_DEFINED is used in Windows NT 3.5  */
  58218.  #ifndef _VA_LIST_DEFINED
  58219.  /* The macro _VA_LIST is used in SCO Unix 3.2.  */
  58220. @@ -151,7 +151,7 @@ typedef __gnuc_va_list va_list;
  58221.  #endif /* not _VA_LIST_T_H */
  58222.  #endif /* not _VA_LIST */
  58223.  #endif /* not _VA_LIST_DEFINED */
  58224. -#if !(defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__))
  58225. +#if !(defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(__amigaos__))
  58226.  #define _VA_LIST_
  58227.  #endif
  58228.  #ifndef _VA_LIST
  58229. diff -rup --new-file baseline/fsf/gcc/ginclude/stddef.h amiga/fsf/gcc/ginclude/stddef.h
  58230. --- baseline/fsf/gcc/ginclude/stddef.h    Sat Aug 19 13:39:22 1995
  58231. +++ amiga/fsf/gcc/ginclude/stddef.h    Sat Sep 28 00:00:00 1996
  58232. @@ -22,7 +22,7 @@
  58233.  
  58234.  /* On 4.3bsd-net2, make sure ansi.h is included, so we have
  58235.     one less case to deal with in the following.  */
  58236. -#if defined (__BSD_NET2__) || defined (____386BSD____) || defined (__FreeBSD__) || defined(__NetBSD__)
  58237. +#if defined (__BSD_NET2__) || defined (____386BSD____) || defined (__FreeBSD__) || defined(__NetBSD__) || defined (__amigaos__)
  58238.  #include <machine/ansi.h>
  58239.  #endif
  58240.  
  58241. diff -rup --new-file baseline/fsf/gcc/ginclude/varargs.h amiga/fsf/gcc/ginclude/varargs.h
  58242. --- baseline/fsf/gcc/ginclude/varargs.h    Sun Aug 13 15:18:55 1995
  58243. +++ amiga/fsf/gcc/ginclude/varargs.h    Sat Sep 28 00:00:00 1996
  58244. @@ -155,7 +155,7 @@ typedef __gnuc_va_list va_list;
  58245.  /* Michael Eriksson <mer@sics.se> at Thu Sep 30 11:00:57 1993:
  58246.     Sequent defines _VA_LIST_ in <machine/machtypes.h> to be the type to
  58247.     use for va_list (``typedef _VA_LIST_ va_list'') */
  58248. -#if !defined (_VA_LIST_) || defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(WINNT)
  58249. +#if !defined (_VA_LIST_) || defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(WINNT) || defined(__amigaos__)
  58250.  /* The macro _VA_LIST_DEFINED is used in Windows NT 3.5  */
  58251.  #ifndef _VA_LIST_DEFINED
  58252.  /* The macro _VA_LIST is used in SCO Unix 3.2.  */
  58253. @@ -166,7 +166,7 @@ typedef __gnuc_va_list va_list;
  58254.  #endif /* not _VA_LIST_T_H */
  58255.  #endif /* not _VA_LIST */
  58256.  #endif /* not _VA_LIST_DEFINED */
  58257. -#if !(defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__))
  58258. +#if !(defined (__BSD_NET2__) || defined (____386BSD____) || defined (__bsdi__) || defined (__sequent__) || defined (__FreeBSD__) || defined(__amigaos__))
  58259.  #define _VA_LIST_
  58260.  #endif
  58261.  #ifndef _VA_LIST
  58262. diff -rup --new-file baseline/fsf/gcc/install.texi amiga/fsf/gcc/install.texi
  58263. --- baseline/fsf/gcc/install.texi    Sat Jun 29 09:27:34 1996
  58264. +++ amiga/fsf/gcc/install.texi    Sat Sep 28 00:00:00 1996
  58265. @@ -533,7 +533,7 @@ just @samp{@var{cpu}-@var{system}}, if i
  58266.  Here is a list of system types:
  58267.  
  58268.  @quotation
  58269. -386bsd, aix, acis, amigados, aos, aout, bosx, bsd, clix, coff, ctix, cxux,
  58270. +386bsd, aix, acis, amigaos, aos, aout, bosx, bsd, clix, coff, ctix, cxux,
  58271.  dgux, dynix, ebmon, ecoff, elf, esix, freebsd, hms, genix, gnu, gnu/linux,
  58272.  hiux, hpux, iris, irix, isc, luna, lynxos, mach, minix, msdos, mvs,
  58273.  netbsd, newsos, nindy, ns, osf, osfrose, ptx, riscix, riscos, rtu, sco, sim,
  58274. diff -rup --new-file baseline/fsf/gcc/manifests/bin amiga/fsf/gcc/manifests/bin
  58275. --- baseline/fsf/gcc/manifests/bin    Wed Dec 31 17:00:00 1969
  58276. +++ amiga/fsf/gcc/manifests/bin    Sat Oct  5 13:36:38 1996
  58277. @@ -0,0 +1,91 @@
  58278. +COPYING
  58279. +COPYING.info
  58280. +bin/c++
  58281. +bin/cpp
  58282. +bin/g++
  58283. +bin/gcc
  58284. +bin/m68k-amigaos-gcc
  58285. +bin/protoize
  58286. +bin/unprotoize
  58287. +guide/cpp.guide
  58288. +guide/gcc.guide
  58289. +info/cpp.info
  58290. +info/cpp.info-1
  58291. +info/cpp.info-2
  58292. +info/cpp.info-3
  58293. +info/gcc.info
  58294. +info/gcc.info-1
  58295. +info/gcc.info-10
  58296. +info/gcc.info-11
  58297. +info/gcc.info-12
  58298. +info/gcc.info-13
  58299. +info/gcc.info-14
  58300. +info/gcc.info-15
  58301. +info/gcc.info-16
  58302. +info/gcc.info-17
  58303. +info/gcc.info-18
  58304. +info/gcc.info-19
  58305. +info/gcc.info-2
  58306. +info/gcc.info-20
  58307. +info/gcc.info-21
  58308. +info/gcc.info-22
  58309. +info/gcc.info-23
  58310. +info/gcc.info-24
  58311. +info/gcc.info-25
  58312. +info/gcc.info-3
  58313. +info/gcc.info-4
  58314. +info/gcc.info-5
  58315. +info/gcc.info-6
  58316. +info/gcc.info-7
  58317. +info/gcc.info-8
  58318. +info/gcc.info-9
  58319. +lib/gcc-lib/m68k-amigaos/2.7.2.1/SYSCALLS.c.X
  58320. +lib/gcc-lib/m68k-amigaos/2.7.2.1/cc1
  58321. +lib/gcc-lib/m68k-amigaos/2.7.2.1/cc1obj
  58322. +lib/gcc-lib/m68k-amigaos/2.7.2.1/cc1plus
  58323. +lib/gcc-lib/m68k-amigaos/2.7.2.1/cpp
  58324. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/README
  58325. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/curses.h
  58326. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/errno.h
  58327. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/fixed
  58328. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/float.h
  58329. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/iso646.h
  58330. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/limits.h
  58331. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/NXConstStr.h
  58332. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/Object.h
  58333. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/Protocol.h
  58334. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/encoding.h
  58335. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/hash.h
  58336. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/list.h
  58337. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/objc-api.h
  58338. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/objc.h
  58339. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/sarray.h
  58340. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/objc/typedstream.h
  58341. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/proto.h
  58342. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/stdarg.h
  58343. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/stddef.h
  58344. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/syslimits.h
  58345. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/unistd.h
  58346. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-alpha.h
  58347. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-clipper.h
  58348. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-h8300.h
  58349. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-i860.h
  58350. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-i960.h
  58351. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-m88k.h
  58352. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-mips.h
  58353. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-pa.h
  58354. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-ppc.h
  58355. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-pyr.h
  58356. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-sparc.h
  58357. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/va-spur.h
  58358. +lib/gcc-lib/m68k-amigaos/2.7.2.1/include/varargs.h
  58359. +lib/gcc-lib/m68k-amigaos/2.7.2.1/libb/libgcc.a
  58360. +lib/gcc-lib/m68k-amigaos/2.7.2.1/libb/libm020/libgcc.a
  58361. +lib/gcc-lib/m68k-amigaos/2.7.2.1/libgcc.a
  58362. +lib/gcc-lib/m68k-amigaos/2.7.2.1/libm020/libgcc.a
  58363. +lib/gcc-lib/m68k-amigaos/2.7.2.1/libobjc.a
  58364. +lib/gcc-lib/m68k-amigaos/2.7.2.1/specs
  58365. +m68k-amigaos/include/assert.h
  58366. +man/man1/cccp.0
  58367. +man/man1/g++.0
  58368. +man/man1/gcc.0
  58369. diff -rup --new-file baseline/fsf/gcc/manifests/src amiga/fsf/gcc/manifests/src
  58370. --- baseline/fsf/gcc/manifests/src    Wed Dec 31 17:00:00 1969
  58371. +++ amiga/fsf/gcc/manifests/src    Sat Sep 28 00:00:00 1996
  58372. @@ -0,0 +1,1010 @@
  58373. +fsf/gcc/.gdbinit
  58374. +fsf/gcc/BUGS
  58375. +fsf/gcc/COPYING
  58376. +fsf/gcc/COPYING.LIB
  58377. +fsf/gcc/ChangeLog
  58378. +fsf/gcc/ChangeLog.0
  58379. +fsf/gcc/ChangeLog.1
  58380. +fsf/gcc/ChangeLog.2
  58381. +fsf/gcc/ChangeLog.3
  58382. +fsf/gcc/ChangeLog.4
  58383. +fsf/gcc/ChangeLog.5
  58384. +fsf/gcc/ChangeLog.6
  58385. +fsf/gcc/ChangeLog.7
  58386. +fsf/gcc/ChangeLog.8
  58387. +fsf/gcc/ChangeLog.9
  58388. +fsf/gcc/INSTALL
  58389. +fsf/gcc/Makefile.in
  58390. +fsf/gcc/NEWS
  58391. +fsf/gcc/ORDERS
  58392. +fsf/gcc/PROBLEMS
  58393. +fsf/gcc/PROJECTS
  58394. +fsf/gcc/Product-Info
  58395. +fsf/gcc/README
  58396. +fsf/gcc/README-fixinc
  58397. +fsf/gcc/README.ACORN
  58398. +fsf/gcc/README.ALTOS
  58399. +fsf/gcc/README.APOLLO
  58400. +fsf/gcc/README.DWARF
  58401. +fsf/gcc/README.FRESCO
  58402. +fsf/gcc/README.NS32K
  58403. +fsf/gcc/README.RS6000
  58404. +fsf/gcc/README.TRAD
  58405. +fsf/gcc/README.X11
  58406. +fsf/gcc/SERVICE
  58407. +fsf/gcc/TESTS.FLUNK
  58408. +fsf/gcc/ada/lang-options.h
  58409. +fsf/gcc/ada/lang-specs.h
  58410. +fsf/gcc/alloca.c
  58411. +fsf/gcc/amigacpp.c
  58412. +fsf/gcc/assert.h
  58413. +fsf/gcc/basic-block.h
  58414. +fsf/gcc/bc-emit.c
  58415. +fsf/gcc/bc-emit.h
  58416. +fsf/gcc/bc-optab.c
  58417. +fsf/gcc/bc-optab.h
  58418. +fsf/gcc/bc-typecd.def
  58419. +fsf/gcc/bc-typecd.h
  58420. +fsf/gcc/bi-arity.c
  58421. +fsf/gcc/bi-defs.h
  58422. +fsf/gcc/bi-lexer.c
  58423. +fsf/gcc/bi-opcode.c
  58424. +fsf/gcc/bi-opname.c
  58425. +fsf/gcc/bi-parser.c
  58426. +fsf/gcc/bi-parser.h
  58427. +fsf/gcc/bi-parser.y
  58428. +fsf/gcc/bi-reverse.c
  58429. +fsf/gcc/bi-run.h
  58430. +fsf/gcc/build-make
  58431. +fsf/gcc/bytecode.def
  58432. +fsf/gcc/bytecode.h
  58433. +fsf/gcc/bytetypes.h
  58434. +fsf/gcc/c-aux-info.c
  58435. +fsf/gcc/c-common.c
  58436. +fsf/gcc/c-convert.c
  58437. +fsf/gcc/c-decl.c
  58438. +fsf/gcc/c-iterate.c
  58439. +fsf/gcc/c-lang.c
  58440. +fsf/gcc/c-lex.c
  58441. +fsf/gcc/c-lex.h
  58442. +fsf/gcc/c-parse.gperf
  58443. +fsf/gcc/c-parse.in
  58444. +fsf/gcc/c-pragma.c
  58445. +fsf/gcc/c-pragma.h
  58446. +fsf/gcc/c-tree.h
  58447. +fsf/gcc/c-typeck.c
  58448. +fsf/gcc/caller-save.c
  58449. +fsf/gcc/calls.c
  58450. +fsf/gcc/cccp.1
  58451. +fsf/gcc/cccp.c
  58452. +fsf/gcc/cexp.y
  58453. +fsf/gcc/collect2.c
  58454. +fsf/gcc/combine.c
  58455. +fsf/gcc/conditions.h
  58456. +fsf/gcc/config.guess
  58457. +fsf/gcc/config.sub
  58458. +fsf/gcc/config/1750a/1750a.c
  58459. +fsf/gcc/config/1750a/1750a.h
  58460. +fsf/gcc/config/1750a/1750a.md
  58461. +fsf/gcc/config/1750a/ms1750.inc
  58462. +fsf/gcc/config/1750a/xm-1750a.h
  58463. +fsf/gcc/config/README
  58464. +fsf/gcc/config/a29k/a29k-udi.h
  58465. +fsf/gcc/config/a29k/a29k.c
  58466. +fsf/gcc/config/a29k/a29k.h
  58467. +fsf/gcc/config/a29k/a29k.md
  58468. +fsf/gcc/config/a29k/t-a29k
  58469. +fsf/gcc/config/a29k/t-a29kbare
  58470. +fsf/gcc/config/a29k/t-vx29k
  58471. +fsf/gcc/config/a29k/unix.h
  58472. +fsf/gcc/config/a29k/vx29k.h
  58473. +fsf/gcc/config/a29k/x-unix
  58474. +fsf/gcc/config/a29k/xm-a29k.h
  58475. +fsf/gcc/config/a29k/xm-unix.h
  58476. +fsf/gcc/config/alpha/alpha.c
  58477. +fsf/gcc/config/alpha/alpha.h
  58478. +fsf/gcc/config/alpha/alpha.md
  58479. +fsf/gcc/config/alpha/config-nt.sed
  58480. +fsf/gcc/config/alpha/gdb-osf12.h
  58481. +fsf/gcc/config/alpha/gdb-osf2.h
  58482. +fsf/gcc/config/alpha/gdb.h
  58483. +fsf/gcc/config/alpha/osf12.h
  58484. +fsf/gcc/config/alpha/osf2.h
  58485. +fsf/gcc/config/alpha/win-nt.h
  58486. +fsf/gcc/config/alpha/x-alpha
  58487. +fsf/gcc/config/alpha/xm-alpha.h
  58488. +fsf/gcc/config/alpha/xm-winnt.h
  58489. +fsf/gcc/config/aoutos.h
  58490. +fsf/gcc/config/arm/arm.c
  58491. +fsf/gcc/config/arm/arm.h
  58492. +fsf/gcc/config/arm/arm.md
  58493. +fsf/gcc/config/arm/lib1funcs.asm
  58494. +fsf/gcc/config/arm/riscix.h
  58495. +fsf/gcc/config/arm/riscix1-1.h
  58496. +fsf/gcc/config/arm/rix-gas.h
  58497. +fsf/gcc/config/arm/semi.h
  58498. +fsf/gcc/config/arm/t-riscix
  58499. +fsf/gcc/config/arm/t-semi
  58500. +fsf/gcc/config/arm/x-riscix
  58501. +fsf/gcc/config/arm/xm-arm.h
  58502. +fsf/gcc/config/clipper/clipper.c
  58503. +fsf/gcc/config/clipper/clipper.h
  58504. +fsf/gcc/config/clipper/clipper.md
  58505. +fsf/gcc/config/clipper/clix.h
  58506. +fsf/gcc/config/clipper/x-clix
  58507. +fsf/gcc/config/clipper/xm-clix.h
  58508. +fsf/gcc/config/convex/convex.c
  58509. +fsf/gcc/config/convex/convex.h
  58510. +fsf/gcc/config/convex/convex.md
  58511. +fsf/gcc/config/convex/convex1.h
  58512. +fsf/gcc/config/convex/convex2.h
  58513. +fsf/gcc/config/convex/convex32.h
  58514. +fsf/gcc/config/convex/convex34.h
  58515. +fsf/gcc/config/convex/convex38.h
  58516. +fsf/gcc/config/convex/fixinc.convex
  58517. +fsf/gcc/config/convex/x-convex
  58518. +fsf/gcc/config/convex/xm-convex.h
  58519. +fsf/gcc/config/dsp16xx/dsp16xx.c
  58520. +fsf/gcc/config/dsp16xx/dsp16xx.h
  58521. +fsf/gcc/config/dsp16xx/dsp16xx.md
  58522. +fsf/gcc/config/dsp16xx/xm-dsp16xx.h
  58523. +fsf/gcc/config/elxsi/elxsi.c
  58524. +fsf/gcc/config/elxsi/elxsi.h
  58525. +fsf/gcc/config/elxsi/elxsi.md
  58526. +fsf/gcc/config/elxsi/x-elxsi
  58527. +fsf/gcc/config/elxsi/xm-elxsi.h
  58528. +fsf/gcc/config/fp-bit.c
  58529. +fsf/gcc/config/fx80/fx80.c
  58530. +fsf/gcc/config/fx80/fx80.h
  58531. +fsf/gcc/config/fx80/fx80.md
  58532. +fsf/gcc/config/fx80/xm-fx80.h
  58533. +fsf/gcc/config/gmicro/gmicro.c
  58534. +fsf/gcc/config/gmicro/gmicro.h
  58535. +fsf/gcc/config/gmicro/gmicro.md
  58536. +fsf/gcc/config/gnu.h
  58537. +fsf/gcc/config/gofast.h
  58538. +fsf/gcc/config/h8300/h8300.c
  58539. +fsf/gcc/config/h8300/h8300.h
  58540. +fsf/gcc/config/h8300/h8300.md
  58541. +fsf/gcc/config/h8300/lib1funcs.asm
  58542. +fsf/gcc/config/h8300/t-h8300
  58543. +fsf/gcc/config/h8300/xm-h8300.h
  58544. +fsf/gcc/config/i370/i370.md
  58545. +fsf/gcc/config/i370/mvs.h
  58546. +fsf/gcc/config/i370/mvs370.c
  58547. +fsf/gcc/config/i370/xm-mvs.h
  58548. +fsf/gcc/config/i386/386bsd.h
  58549. +fsf/gcc/config/i386/aix386.h
  58550. +fsf/gcc/config/i386/aix386ng.h
  58551. +fsf/gcc/config/i386/att.h
  58552. +fsf/gcc/config/i386/bsd.h
  58553. +fsf/gcc/config/i386/bsd386.h
  58554. +fsf/gcc/config/i386/config-nt.sed
  58555. +fsf/gcc/config/i386/freebsd.h
  58556. +fsf/gcc/config/i386/gas.h
  58557. +fsf/gcc/config/i386/gnu.h
  58558. +fsf/gcc/config/i386/go32.h
  58559. +fsf/gcc/config/i386/gstabs.h
  58560. +fsf/gcc/config/i386/i386-aout.h
  58561. +fsf/gcc/config/i386/i386-coff.h
  58562. +fsf/gcc/config/i386/i386.c
  58563. +fsf/gcc/config/i386/i386.h
  58564. +fsf/gcc/config/i386/i386.md
  58565. +fsf/gcc/config/i386/i386iscgas.h
  58566. +fsf/gcc/config/i386/isc.h
  58567. +fsf/gcc/config/i386/isccoff.h
  58568. +fsf/gcc/config/i386/iscdbx.h
  58569. +fsf/gcc/config/i386/linux-aout.h
  58570. +fsf/gcc/config/i386/linux-oldld.h
  58571. +fsf/gcc/config/i386/linux.h
  58572. +fsf/gcc/config/i386/lynx-ng.h
  58573. +fsf/gcc/config/i386/lynx.h
  58574. +fsf/gcc/config/i386/mach.h
  58575. +fsf/gcc/config/i386/netbsd.h
  58576. +fsf/gcc/config/i386/next.c
  58577. +fsf/gcc/config/i386/next.h
  58578. +fsf/gcc/config/i386/os2.h
  58579. +fsf/gcc/config/i386/osfelf.h
  58580. +fsf/gcc/config/i386/osfrose.h
  58581. +fsf/gcc/config/i386/perform.h
  58582. +fsf/gcc/config/i386/sco.h
  58583. +fsf/gcc/config/i386/sco4.h
  58584. +fsf/gcc/config/i386/sco4dbx.h
  58585. +fsf/gcc/config/i386/scodbx.h
  58586. +fsf/gcc/config/i386/seq-gas.h
  58587. +fsf/gcc/config/i386/seq-sysv3.h
  58588. +fsf/gcc/config/i386/seq2-sysv3.h
  58589. +fsf/gcc/config/i386/sequent.h
  58590. +fsf/gcc/config/i386/sol2-c1.asm
  58591. +fsf/gcc/config/i386/sol2-ci.asm
  58592. +fsf/gcc/config/i386/sol2-cn.asm
  58593. +fsf/gcc/config/i386/sol2.h
  58594. +fsf/gcc/config/i386/sun.h
  58595. +fsf/gcc/config/i386/sun386.h
  58596. +fsf/gcc/config/i386/svr3.ifile
  58597. +fsf/gcc/config/i386/svr3dbx.h
  58598. +fsf/gcc/config/i386/svr3gas.h
  58599. +fsf/gcc/config/i386/svr3z.ifile
  58600. +fsf/gcc/config/i386/sysv3.h
  58601. +fsf/gcc/config/i386/sysv4.h
  58602. +fsf/gcc/config/i386/sysv4gdb.h
  58603. +fsf/gcc/config/i386/t-crtpic
  58604. +fsf/gcc/config/i386/t-crtstuff
  58605. +fsf/gcc/config/i386/t-i386bare
  58606. +fsf/gcc/config/i386/t-iscscodbx
  58607. +fsf/gcc/config/i386/t-next
  58608. +fsf/gcc/config/i386/t-sol2
  58609. +fsf/gcc/config/i386/t-svr3dbx
  58610. +fsf/gcc/config/i386/t-vsta
  58611. +fsf/gcc/config/i386/t-winnt
  58612. +fsf/gcc/config/i386/unix.h
  58613. +fsf/gcc/config/i386/v3gas.h
  58614. +fsf/gcc/config/i386/vsta.h
  58615. +fsf/gcc/config/i386/win-nt.h
  58616. +fsf/gcc/config/i386/winnt.c
  58617. +fsf/gcc/config/i386/x-aix
  58618. +fsf/gcc/config/i386/x-freebsd
  58619. +fsf/gcc/config/i386/x-isc
  58620. +fsf/gcc/config/i386/x-isc3
  58621. +fsf/gcc/config/i386/x-ncr3000
  58622. +fsf/gcc/config/i386/x-next
  58623. +fsf/gcc/config/i386/x-osfrose
  58624. +fsf/gcc/config/i386/x-sco
  58625. +fsf/gcc/config/i386/x-sco4
  58626. +fsf/gcc/config/i386/x-sysv3
  58627. +fsf/gcc/config/i386/x-vsta
  58628. +fsf/gcc/config/i386/xm-aix.h
  58629. +fsf/gcc/config/i386/xm-bsd386.h
  58630. +fsf/gcc/config/i386/xm-dos.h
  58631. +fsf/gcc/config/i386/xm-freebsd.h
  58632. +fsf/gcc/config/i386/xm-gnu.h
  58633. +fsf/gcc/config/i386/xm-i386.h
  58634. +fsf/gcc/config/i386/xm-isc.h
  58635. +fsf/gcc/config/i386/xm-linux.h
  58636. +fsf/gcc/config/i386/xm-lynx.h
  58637. +fsf/gcc/config/i386/xm-netbsd.h
  58638. +fsf/gcc/config/i386/xm-next.h
  58639. +fsf/gcc/config/i386/xm-os2.h
  58640. +fsf/gcc/config/i386/xm-osf.h
  58641. +fsf/gcc/config/i386/xm-sco.h
  58642. +fsf/gcc/config/i386/xm-sun.h
  58643. +fsf/gcc/config/i386/xm-sysv3.h
  58644. +fsf/gcc/config/i386/xm-sysv4.h
  58645. +fsf/gcc/config/i386/xm-vsta.h
  58646. +fsf/gcc/config/i386/xm-winnt.h
  58647. +fsf/gcc/config/i860/bsd-gas.h
  58648. +fsf/gcc/config/i860/bsd.h
  58649. +fsf/gcc/config/i860/fx2800.h
  58650. +fsf/gcc/config/i860/i860.c
  58651. +fsf/gcc/config/i860/i860.h
  58652. +fsf/gcc/config/i860/i860.md
  58653. +fsf/gcc/config/i860/mach.h
  58654. +fsf/gcc/config/i860/paragon.h
  58655. +fsf/gcc/config/i860/sysv3.h
  58656. +fsf/gcc/config/i860/sysv4.h
  58657. +fsf/gcc/config/i860/t-fx2800
  58658. +fsf/gcc/config/i860/x-fx2800
  58659. +fsf/gcc/config/i860/x-sysv3
  58660. +fsf/gcc/config/i860/x-sysv4
  58661. +fsf/gcc/config/i860/xm-fx2800.h
  58662. +fsf/gcc/config/i860/xm-i860.h
  58663. +fsf/gcc/config/i860/xm-paragon.h
  58664. +fsf/gcc/config/i860/xm-sysv3.h
  58665. +fsf/gcc/config/i860/xm-sysv4.h
  58666. +fsf/gcc/config/i960/i960-coff.h
  58667. +fsf/gcc/config/i960/i960.c
  58668. +fsf/gcc/config/i960/i960.h
  58669. +fsf/gcc/config/i960/i960.md
  58670. +fsf/gcc/config/i960/t-960bare
  58671. +fsf/gcc/config/i960/t-vxworks960
  58672. +fsf/gcc/config/i960/vx960-coff.h
  58673. +fsf/gcc/config/i960/vx960.h
  58674. +fsf/gcc/config/i960/xm-i960.h
  58675. +fsf/gcc/config/linux-aout.h
  58676. +fsf/gcc/config/linux.h
  58677. +fsf/gcc/config/lynx-ng.h
  58678. +fsf/gcc/config/lynx.h
  58679. +fsf/gcc/config/m68k/3b1.h
  58680. +fsf/gcc/config/m68k/3b1g.h
  58681. +fsf/gcc/config/m68k/altos3068.h
  58682. +fsf/gcc/config/m68k/amigaos.c
  58683. +fsf/gcc/config/m68k/amigaos.h
  58684. +fsf/gcc/config/m68k/amix.h
  58685. +fsf/gcc/config/m68k/apollo68.h
  58686. +fsf/gcc/config/m68k/atari.h
  58687. +fsf/gcc/config/m68k/ccur-GAS.h
  58688. +fsf/gcc/config/m68k/coff.h
  58689. +fsf/gcc/config/m68k/crds.h
  58690. +fsf/gcc/config/m68k/ctix.h
  58691. +fsf/gcc/config/m68k/dpx2.h
  58692. +fsf/gcc/config/m68k/dpx2.ifile
  58693. +fsf/gcc/config/m68k/dpx2cdbx.h
  58694. +fsf/gcc/config/m68k/dpx2g.h
  58695. +fsf/gcc/config/m68k/fpgnulib.c
  58696. +fsf/gcc/config/m68k/hp2bsd.h
  58697. +fsf/gcc/config/m68k/hp310.h
  58698. +fsf/gcc/config/m68k/hp310g.h
  58699. +fsf/gcc/config/m68k/hp320.h
  58700. +fsf/gcc/config/m68k/hp320g.h
  58701. +fsf/gcc/config/m68k/hp3bsd.h
  58702. +fsf/gcc/config/m68k/hp3bsd44.h
  58703. +fsf/gcc/config/m68k/hpux7.h
  58704. +fsf/gcc/config/m68k/isi-nfp.h
  58705. +fsf/gcc/config/m68k/isi.h
  58706. +fsf/gcc/config/m68k/lb1sf68.asm
  58707. +fsf/gcc/config/m68k/linux-aout.h
  58708. +fsf/gcc/config/m68k/linux.h
  58709. +fsf/gcc/config/m68k/lynx-ng.h
  58710. +fsf/gcc/config/m68k/lynx.h
  58711. +fsf/gcc/config/m68k/m68k-aout.h
  58712. +fsf/gcc/config/m68k/m68k-coff.h
  58713. +fsf/gcc/config/m68k/m68k-none.h
  58714. +fsf/gcc/config/m68k/m68k.c
  58715. +fsf/gcc/config/m68k/m68k.h
  58716. +fsf/gcc/config/m68k/m68k.md
  58717. +fsf/gcc/config/m68k/m68kemb.h
  58718. +fsf/gcc/config/m68k/m68kv4.h
  58719. +fsf/gcc/config/m68k/mot3300.h
  58720. +fsf/gcc/config/m68k/mot3300g.h
  58721. +fsf/gcc/config/m68k/netbsd.h
  58722. +fsf/gcc/config/m68k/news.h
  58723. +fsf/gcc/config/m68k/news3.h
  58724. +fsf/gcc/config/m68k/news3gas.h
  58725. +fsf/gcc/config/m68k/newsgas.h
  58726. +fsf/gcc/config/m68k/next.c
  58727. +fsf/gcc/config/m68k/next.h
  58728. +fsf/gcc/config/m68k/next21.h
  58729. +fsf/gcc/config/m68k/pbb.h
  58730. +fsf/gcc/config/m68k/plexus.h
  58731. +fsf/gcc/config/m68k/sgs.h
  58732. +fsf/gcc/config/m68k/sun2.h
  58733. +fsf/gcc/config/m68k/sun2o4.h
  58734. +fsf/gcc/config/m68k/sun3.h
  58735. +fsf/gcc/config/m68k/sun3mach.h
  58736. +fsf/gcc/config/m68k/sun3n.h
  58737. +fsf/gcc/config/m68k/sun3n3.h
  58738. +fsf/gcc/config/m68k/sun3o3.h
  58739. +fsf/gcc/config/m68k/t-amigaos
  58740. +fsf/gcc/config/m68k/t-linux
  58741. +fsf/gcc/config/m68k/t-lynx
  58742. +fsf/gcc/config/m68k/t-m68kbare
  58743. +fsf/gcc/config/m68k/t-next
  58744. +fsf/gcc/config/m68k/t-vxworks68
  58745. +fsf/gcc/config/m68k/tower-as.h
  58746. +fsf/gcc/config/m68k/tower.h
  58747. +fsf/gcc/config/m68k/vxm68k.h
  58748. +fsf/gcc/config/m68k/x-alloca-c
  58749. +fsf/gcc/config/m68k/x-amigaos
  58750. +fsf/gcc/config/m68k/x-amix
  58751. +fsf/gcc/config/m68k/x-apollo68
  58752. +fsf/gcc/config/m68k/x-ccur
  58753. +fsf/gcc/config/m68k/x-crds
  58754. +fsf/gcc/config/m68k/x-dpx2
  58755. +fsf/gcc/config/m68k/x-hp2bsd
  58756. +fsf/gcc/config/m68k/x-hp320
  58757. +fsf/gcc/config/m68k/x-hp320g
  58758. +fsf/gcc/config/m68k/x-hp3bsd44
  58759. +fsf/gcc/config/m68k/x-mot3300
  58760. +fsf/gcc/config/m68k/x-next
  58761. +fsf/gcc/config/m68k/x-tower
  58762. +fsf/gcc/config/m68k/xm-3b1.h
  58763. +fsf/gcc/config/m68k/xm-altos3068.h
  58764. +fsf/gcc/config/m68k/xm-amigaos.h
  58765. +fsf/gcc/config/m68k/xm-amix.h
  58766. +fsf/gcc/config/m68k/xm-atari.h
  58767. +fsf/gcc/config/m68k/xm-crds.h
  58768. +fsf/gcc/config/m68k/xm-hp320.h
  58769. +fsf/gcc/config/m68k/xm-linux.h
  58770. +fsf/gcc/config/m68k/xm-lynx.h
  58771. +fsf/gcc/config/m68k/xm-m68k.h
  58772. +fsf/gcc/config/m68k/xm-m68kv.h
  58773. +fsf/gcc/config/m68k/xm-mot3300.h
  58774. +fsf/gcc/config/m68k/xm-netbsd.h
  58775. +fsf/gcc/config/m68k/xm-next.h
  58776. +fsf/gcc/config/m68k/xm-plexus.h
  58777. +fsf/gcc/config/m68k/xm-tower.h
  58778. +fsf/gcc/config/m88k/dgux.h
  58779. +fsf/gcc/config/m88k/dgux.ld
  58780. +fsf/gcc/config/m88k/dguxbcs.h
  58781. +fsf/gcc/config/m88k/dolph.h
  58782. +fsf/gcc/config/m88k/dolphin.ld
  58783. +fsf/gcc/config/m88k/luna.h
  58784. +fsf/gcc/config/m88k/m88k-aout.h
  58785. +fsf/gcc/config/m88k/m88k-coff.h
  58786. +fsf/gcc/config/m88k/m88k-move.sh
  58787. +fsf/gcc/config/m88k/m88k.c
  58788. +fsf/gcc/config/m88k/m88k.h
  58789. +fsf/gcc/config/m88k/m88k.md
  58790. +fsf/gcc/config/m88k/sysv3.h
  58791. +fsf/gcc/config/m88k/sysv4.h
  58792. +fsf/gcc/config/m88k/t-bug
  58793. +fsf/gcc/config/m88k/t-dgux
  58794. +fsf/gcc/config/m88k/t-dgux-gas
  58795. +fsf/gcc/config/m88k/t-luna
  58796. +fsf/gcc/config/m88k/t-luna-gas
  58797. +fsf/gcc/config/m88k/t-m88k
  58798. +fsf/gcc/config/m88k/t-m88k-gas
  58799. +fsf/gcc/config/m88k/t-sysv4
  58800. +fsf/gcc/config/m88k/tekXD88.h
  58801. +fsf/gcc/config/m88k/tekXD88.ld
  58802. +fsf/gcc/config/m88k/x-dgux
  58803. +fsf/gcc/config/m88k/x-dguxbcs
  58804. +fsf/gcc/config/m88k/x-dolph
  58805. +fsf/gcc/config/m88k/x-sysv3
  58806. +fsf/gcc/config/m88k/x-sysv4
  58807. +fsf/gcc/config/m88k/x-tekXD88
  58808. +fsf/gcc/config/m88k/xm-m88k.h
  58809. +fsf/gcc/config/m88k/xm-sysv3.h
  58810. +fsf/gcc/config/mips/abi64.h
  58811. +fsf/gcc/config/mips/bsd-4-gdb.h
  58812. +fsf/gcc/config/mips/bsd-4.h
  58813. +fsf/gcc/config/mips/bsd-5-gdb.h
  58814. +fsf/gcc/config/mips/bsd-5.h
  58815. +fsf/gcc/config/mips/cross64.h
  58816. +fsf/gcc/config/mips/dec-bsd.h
  58817. +fsf/gcc/config/mips/dec-gosf1.h
  58818. +fsf/gcc/config/mips/dec-osf1.h
  58819. +fsf/gcc/config/mips/ecoff-gdb.h
  58820. +fsf/gcc/config/mips/ecoff.h
  58821. +fsf/gcc/config/mips/ecoffl-gdb.h
  58822. +fsf/gcc/config/mips/ecoffl.h
  58823. +fsf/gcc/config/mips/elf.h
  58824. +fsf/gcc/config/mips/elf64.h
  58825. +fsf/gcc/config/mips/elfl.h
  58826. +fsf/gcc/config/mips/elfl64.h
  58827. +fsf/gcc/config/mips/elflorion.h
  58828. +fsf/gcc/config/mips/elforion.h
  58829. +fsf/gcc/config/mips/gnu.h
  58830. +fsf/gcc/config/mips/iris3-gdb.h
  58831. +fsf/gcc/config/mips/iris3.h
  58832. +fsf/gcc/config/mips/iris4-gdb.h
  58833. +fsf/gcc/config/mips/iris4.h
  58834. +fsf/gcc/config/mips/iris4gl.h
  58835. +fsf/gcc/config/mips/iris4loser.h
  58836. +fsf/gcc/config/mips/iris5.h
  58837. +fsf/gcc/config/mips/iris5gas.h
  58838. +fsf/gcc/config/mips/iris5gdb.h
  58839. +fsf/gcc/config/mips/iris6.h
  58840. +fsf/gcc/config/mips/mips-4-gdb.h
  58841. +fsf/gcc/config/mips/mips-5-gdb.h
  58842. +fsf/gcc/config/mips/mips-5.h
  58843. +fsf/gcc/config/mips/mips.c
  58844. +fsf/gcc/config/mips/mips.h
  58845. +fsf/gcc/config/mips/mips.md
  58846. +fsf/gcc/config/mips/netbsd.h
  58847. +fsf/gcc/config/mips/news4-gdb.h
  58848. +fsf/gcc/config/mips/news4.h
  58849. +fsf/gcc/config/mips/news5-gdb.h
  58850. +fsf/gcc/config/mips/news5.h
  58851. +fsf/gcc/config/mips/nws3250v4.h
  58852. +fsf/gcc/config/mips/osfrose.h
  58853. +fsf/gcc/config/mips/svr3-4-gdb.h
  58854. +fsf/gcc/config/mips/svr3-4.h
  58855. +fsf/gcc/config/mips/svr3-5-gdb.h
  58856. +fsf/gcc/config/mips/svr3-5.h
  58857. +fsf/gcc/config/mips/svr4-4-gdb.h
  58858. +fsf/gcc/config/mips/svr4-4.h
  58859. +fsf/gcc/config/mips/svr4-5-gdb.h
  58860. +fsf/gcc/config/mips/svr4-5.h
  58861. +fsf/gcc/config/mips/svr4-t-gdb.h
  58862. +fsf/gcc/config/mips/svr4-t.h
  58863. +fsf/gcc/config/mips/t-bsd
  58864. +fsf/gcc/config/mips/t-bsd-gas
  58865. +fsf/gcc/config/mips/t-cross64
  58866. +fsf/gcc/config/mips/t-ecoff
  58867. +fsf/gcc/config/mips/t-iris6
  58868. +fsf/gcc/config/mips/t-mips
  58869. +fsf/gcc/config/mips/t-mips-gas
  58870. +fsf/gcc/config/mips/t-osfrose
  58871. +fsf/gcc/config/mips/t-svr3
  58872. +fsf/gcc/config/mips/t-svr3-gas
  58873. +fsf/gcc/config/mips/t-svr4
  58874. +fsf/gcc/config/mips/t-svr4-gas
  58875. +fsf/gcc/config/mips/t-ultrix
  58876. +fsf/gcc/config/mips/ultrix-gdb.h
  58877. +fsf/gcc/config/mips/ultrix.h
  58878. +fsf/gcc/config/mips/x-dec-osf1
  58879. +fsf/gcc/config/mips/x-iris
  58880. +fsf/gcc/config/mips/x-iris3
  58881. +fsf/gcc/config/mips/x-iris6
  58882. +fsf/gcc/config/mips/x-mips
  58883. +fsf/gcc/config/mips/x-netbsd
  58884. +fsf/gcc/config/mips/x-nws3250v4
  58885. +fsf/gcc/config/mips/x-osfrose
  58886. +fsf/gcc/config/mips/x-sony
  58887. +fsf/gcc/config/mips/x-sysv
  58888. +fsf/gcc/config/mips/x-ultrix
  58889. +fsf/gcc/config/mips/xm-iris3.h
  58890. +fsf/gcc/config/mips/xm-iris4.h
  58891. +fsf/gcc/config/mips/xm-iris5.h
  58892. +fsf/gcc/config/mips/xm-iris6.h
  58893. +fsf/gcc/config/mips/xm-mips.h
  58894. +fsf/gcc/config/mips/xm-netbsd.h
  58895. +fsf/gcc/config/mips/xm-news.h
  58896. +fsf/gcc/config/mips/xm-nws3250v4.h
  58897. +fsf/gcc/config/mips/xm-sysv.h
  58898. +fsf/gcc/config/mips/xm-sysv4.h
  58899. +fsf/gcc/config/msdos/configur.bat
  58900. +fsf/gcc/config/msdos/libgcc.mak
  58901. +fsf/gcc/config/msdos/mklibgcc.c
  58902. +fsf/gcc/config/msdos/top.sed
  58903. +fsf/gcc/config/netbsd.h
  58904. +fsf/gcc/config/nextstep.c
  58905. +fsf/gcc/config/nextstep.h
  58906. +fsf/gcc/config/nextstep21.h
  58907. +fsf/gcc/config/ns32k/encore.h
  58908. +fsf/gcc/config/ns32k/genix.h
  58909. +fsf/gcc/config/ns32k/merlin.h
  58910. +fsf/gcc/config/ns32k/netbsd.h
  58911. +fsf/gcc/config/ns32k/ns32k.c
  58912. +fsf/gcc/config/ns32k/ns32k.h
  58913. +fsf/gcc/config/ns32k/ns32k.md
  58914. +fsf/gcc/config/ns32k/pc532-mach.h
  58915. +fsf/gcc/config/ns32k/pc532-min.h
  58916. +fsf/gcc/config/ns32k/pc532.h
  58917. +fsf/gcc/config/ns32k/sequent.h
  58918. +fsf/gcc/config/ns32k/tek6000.h
  58919. +fsf/gcc/config/ns32k/tek6100.h
  58920. +fsf/gcc/config/ns32k/tek6200.h
  58921. +fsf/gcc/config/ns32k/x-genix
  58922. +fsf/gcc/config/ns32k/xm-genix.h
  58923. +fsf/gcc/config/ns32k/xm-netbsd.h
  58924. +fsf/gcc/config/ns32k/xm-ns32k.h
  58925. +fsf/gcc/config/ns32k/xm-pc532-min.h
  58926. +fsf/gcc/config/pa/lib2funcs.asm
  58927. +fsf/gcc/config/pa/pa-ghiux.h
  58928. +fsf/gcc/config/pa/pa-ghpux.h
  58929. +fsf/gcc/config/pa/pa-ghpux9.h
  58930. +fsf/gcc/config/pa/pa-gux7.h
  58931. +fsf/gcc/config/pa/pa-hiux.h
  58932. +fsf/gcc/config/pa/pa-hpux.h
  58933. +fsf/gcc/config/pa/pa-hpux7.h
  58934. +fsf/gcc/config/pa/pa-hpux9.h
  58935. +fsf/gcc/config/pa/pa-oldas.h
  58936. +fsf/gcc/config/pa/pa-osf.h
  58937. +fsf/gcc/config/pa/pa.c
  58938. +fsf/gcc/config/pa/pa.h
  58939. +fsf/gcc/config/pa/pa.md
  58940. +fsf/gcc/config/pa/pa1-ghiux.h
  58941. +fsf/gcc/config/pa/pa1-ghpux.h
  58942. +fsf/gcc/config/pa/pa1-ghpux9.h
  58943. +fsf/gcc/config/pa/pa1-hiux.h
  58944. +fsf/gcc/config/pa/pa1-hpux.h
  58945. +fsf/gcc/config/pa/pa1-hpux9.h
  58946. +fsf/gcc/config/pa/pa1-oldas.h
  58947. +fsf/gcc/config/pa/pa1-osf.h
  58948. +fsf/gcc/config/pa/pa1.h
  58949. +fsf/gcc/config/pa/t-pa
  58950. +fsf/gcc/config/pa/x-pa
  58951. +fsf/gcc/config/pa/x-pa-hpux
  58952. +fsf/gcc/config/pa/xm-pa.h
  58953. +fsf/gcc/config/pa/xm-pahpux.h
  58954. +fsf/gcc/config/pdp11/2bsd.h
  58955. +fsf/gcc/config/pdp11/pdp11.c
  58956. +fsf/gcc/config/pdp11/pdp11.h
  58957. +fsf/gcc/config/pdp11/pdp11.md
  58958. +fsf/gcc/config/pdp11/t-pdp11
  58959. +fsf/gcc/config/pdp11/xm-pdp11.h
  58960. +fsf/gcc/config/pyr/pyr.c
  58961. +fsf/gcc/config/pyr/pyr.h
  58962. +fsf/gcc/config/pyr/pyr.md
  58963. +fsf/gcc/config/pyr/x-pyr
  58964. +fsf/gcc/config/pyr/xm-pyr.h
  58965. +fsf/gcc/config/romp/romp.c
  58966. +fsf/gcc/config/romp/romp.h
  58967. +fsf/gcc/config/romp/romp.md
  58968. +fsf/gcc/config/romp/x-mach
  58969. +fsf/gcc/config/romp/x-romp
  58970. +fsf/gcc/config/romp/xm-romp.h
  58971. +fsf/gcc/config/rs6000/aix31.h
  58972. +fsf/gcc/config/rs6000/aix3newas.h
  58973. +fsf/gcc/config/rs6000/aix41.h
  58974. +fsf/gcc/config/rs6000/aix41ppc.h
  58975. +fsf/gcc/config/rs6000/amigaos.h
  58976. +fsf/gcc/config/rs6000/eabi-ctors.c
  58977. +fsf/gcc/config/rs6000/eabi.asm
  58978. +fsf/gcc/config/rs6000/eabi.h
  58979. +fsf/gcc/config/rs6000/eabiaix.h
  58980. +fsf/gcc/config/rs6000/eabile.h
  58981. +fsf/gcc/config/rs6000/eabilesim.h
  58982. +fsf/gcc/config/rs6000/eabisim.h
  58983. +fsf/gcc/config/rs6000/lynx.h
  58984. +fsf/gcc/config/rs6000/mach.h
  58985. +fsf/gcc/config/rs6000/milli.exp
  58986. +fsf/gcc/config/rs6000/netware.h
  58987. +fsf/gcc/config/rs6000/powerpc.h
  58988. +fsf/gcc/config/rs6000/rs6000.c
  58989. +fsf/gcc/config/rs6000/rs6000.h
  58990. +fsf/gcc/config/rs6000/rs6000.md
  58991. +fsf/gcc/config/rs6000/sysv4.h
  58992. +fsf/gcc/config/rs6000/sysv4le.h
  58993. +fsf/gcc/config/rs6000/t-amigaos
  58994. +fsf/gcc/config/rs6000/t-eabi
  58995. +fsf/gcc/config/rs6000/t-eabiaix
  58996. +fsf/gcc/config/rs6000/t-eabigas
  58997. +fsf/gcc/config/rs6000/t-eabilegas
  58998. +fsf/gcc/config/rs6000/t-eabisim
  58999. +fsf/gcc/config/rs6000/t-newas
  59000. +fsf/gcc/config/rs6000/t-ppc
  59001. +fsf/gcc/config/rs6000/t-ppcgas
  59002. +fsf/gcc/config/rs6000/t-ppclegas
  59003. +fsf/gcc/config/rs6000/t-rs6000
  59004. +fsf/gcc/config/rs6000/x-aix31
  59005. +fsf/gcc/config/rs6000/x-amigaos
  59006. +fsf/gcc/config/rs6000/x-lynx
  59007. +fsf/gcc/config/rs6000/x-mach
  59008. +fsf/gcc/config/rs6000/x-rs6000
  59009. +fsf/gcc/config/rs6000/x-sysv4
  59010. +fsf/gcc/config/rs6000/xm-amigaos.h
  59011. +fsf/gcc/config/rs6000/xm-lynx.h
  59012. +fsf/gcc/config/rs6000/xm-mach.h
  59013. +fsf/gcc/config/rs6000/xm-rs6000.h
  59014. +fsf/gcc/config/rs6000/xm-sysv4.h
  59015. +fsf/gcc/config/sh/lib1funcs.asm
  59016. +fsf/gcc/config/sh/sh.c
  59017. +fsf/gcc/config/sh/sh.h
  59018. +fsf/gcc/config/sh/sh.md
  59019. +fsf/gcc/config/sh/t-sh
  59020. +fsf/gcc/config/sh/xm-sh.h
  59021. +fsf/gcc/config/sparc/bsd.h
  59022. +fsf/gcc/config/sparc/gmon-sol2.c
  59023. +fsf/gcc/config/sparc/lb1spc.asm
  59024. +fsf/gcc/config/sparc/lb1spl.asm
  59025. +fsf/gcc/config/sparc/lite.h
  59026. +fsf/gcc/config/sparc/litecoff.h
  59027. +fsf/gcc/config/sparc/lynx-ng.h
  59028. +fsf/gcc/config/sparc/lynx.h
  59029. +fsf/gcc/config/sparc/netbsd.h
  59030. +fsf/gcc/config/sparc/pbd.h
  59031. +fsf/gcc/config/sparc/sol2-c1.asm
  59032. +fsf/gcc/config/sparc/sol2-ci.asm
  59033. +fsf/gcc/config/sparc/sol2-cn.asm
  59034. +fsf/gcc/config/sparc/sol2.h
  59035. +fsf/gcc/config/sparc/sp64-aout.h
  59036. +fsf/gcc/config/sparc/sp64-elf.h
  59037. +fsf/gcc/config/sparc/sparc-aout.h
  59038. +fsf/gcc/config/sparc/sparc.c
  59039. +fsf/gcc/config/sparc/sparc.h
  59040. +fsf/gcc/config/sparc/sparc.md
  59041. +fsf/gcc/config/sparc/sun4o3.h
  59042. +fsf/gcc/config/sparc/sunos4.h
  59043. +fsf/gcc/config/sparc/sysv4.h
  59044. +fsf/gcc/config/sparc/t-sol2
  59045. +fsf/gcc/config/sparc/t-sp64
  59046. +fsf/gcc/config/sparc/t-sparcbare
  59047. +fsf/gcc/config/sparc/t-sparclite
  59048. +fsf/gcc/config/sparc/t-sunos40
  59049. +fsf/gcc/config/sparc/t-sunos41
  59050. +fsf/gcc/config/sparc/t-vxsparc
  59051. +fsf/gcc/config/sparc/vxsparc.h
  59052. +fsf/gcc/config/sparc/x-sysv4
  59053. +fsf/gcc/config/sparc/xm-lynx.h
  59054. +fsf/gcc/config/sparc/xm-netbsd.h
  59055. +fsf/gcc/config/sparc/xm-pbd.h
  59056. +fsf/gcc/config/sparc/xm-sol2.h
  59057. +fsf/gcc/config/sparc/xm-sparc.h
  59058. +fsf/gcc/config/sparc/xm-sysv4.h
  59059. +fsf/gcc/config/spur/spur.c
  59060. +fsf/gcc/config/spur/spur.h
  59061. +fsf/gcc/config/spur/spur.md
  59062. +fsf/gcc/config/spur/xm-spur.h
  59063. +fsf/gcc/config/svr3.h
  59064. +fsf/gcc/config/svr4.h
  59065. +fsf/gcc/config/t-libc-ok
  59066. +fsf/gcc/config/t-svr4
  59067. +fsf/gcc/config/tahoe/harris.h
  59068. +fsf/gcc/config/tahoe/tahoe.c
  59069. +fsf/gcc/config/tahoe/tahoe.h
  59070. +fsf/gcc/config/tahoe/tahoe.md
  59071. +fsf/gcc/config/tahoe/xm-tahoe.h
  59072. +fsf/gcc/config/vax/netbsd.h
  59073. +fsf/gcc/config/vax/ultrix.h
  59074. +fsf/gcc/config/vax/vax.c
  59075. +fsf/gcc/config/vax/vax.h
  59076. +fsf/gcc/config/vax/vax.md
  59077. +fsf/gcc/config/vax/vaxv.h
  59078. +fsf/gcc/config/vax/vms.h
  59079. +fsf/gcc/config/vax/x-vax
  59080. +fsf/gcc/config/vax/xm-netbsd.h
  59081. +fsf/gcc/config/vax/xm-vax.h
  59082. +fsf/gcc/config/vax/xm-vaxv.h
  59083. +fsf/gcc/config/vax/xm-vms.h
  59084. +fsf/gcc/config/we32k/we32k.c
  59085. +fsf/gcc/config/we32k/we32k.h
  59086. +fsf/gcc/config/we32k/we32k.md
  59087. +fsf/gcc/config/we32k/x-we32k
  59088. +fsf/gcc/config/we32k/xm-we32k.h
  59089. +fsf/gcc/config/winnt/config-nt.bat
  59090. +fsf/gcc/config/winnt/config-nt.sed
  59091. +fsf/gcc/config/winnt/dirent.c
  59092. +fsf/gcc/config/winnt/dirent.h
  59093. +fsf/gcc/config/winnt/fixinc-nt.c
  59094. +fsf/gcc/config/winnt/headers.mak
  59095. +fsf/gcc/config/winnt/ld.c
  59096. +fsf/gcc/config/winnt/libgcc.mak
  59097. +fsf/gcc/config/winnt/mklibgcc.c
  59098. +fsf/gcc/config/winnt/oldnames.c
  59099. +fsf/gcc/config/winnt/spawnv.c
  59100. +fsf/gcc/config/winnt/win-nt.h
  59101. +fsf/gcc/config/winnt/x-winnt
  59102. +fsf/gcc/config/winnt/xm-winnt.h
  59103. +fsf/gcc/config/x-linux
  59104. +fsf/gcc/config/x-lynx
  59105. +fsf/gcc/config/x-netbsd
  59106. +fsf/gcc/config/x-svr4
  59107. +fsf/gcc/config/xm-freebsd.h
  59108. +fsf/gcc/config/xm-gnu.h
  59109. +fsf/gcc/config/xm-linux.h
  59110. +fsf/gcc/config/xm-lynx.h
  59111. +fsf/gcc/config/xm-netbsd.h
  59112. +fsf/gcc/config/xm-svr3.h
  59113. +fsf/gcc/config/xm-svr4.h
  59114. +fsf/gcc/configure
  59115. +fsf/gcc/configure.bat
  59116. +fsf/gcc/convert.c
  59117. +fsf/gcc/convert.h
  59118. +fsf/gcc/cp/ChangeLog
  59119. +fsf/gcc/cp/Make-lang.in
  59120. +fsf/gcc/cp/Makefile.in
  59121. +fsf/gcc/cp/call.c
  59122. +fsf/gcc/cp/class.c
  59123. +fsf/gcc/cp/class.h
  59124. +fsf/gcc/cp/config-lang.in
  59125. +fsf/gcc/cp/cp-tree.h
  59126. +fsf/gcc/cp/cvt.c
  59127. +fsf/gcc/cp/decl.c
  59128. +fsf/gcc/cp/decl.h
  59129. +fsf/gcc/cp/decl2.c
  59130. +fsf/gcc/cp/edsel.c
  59131. +fsf/gcc/cp/errfn.c
  59132. +fsf/gcc/cp/error.c
  59133. +fsf/gcc/cp/except.c
  59134. +fsf/gcc/cp/expr.c
  59135. +fsf/gcc/cp/g++.1
  59136. +fsf/gcc/cp/g++.c
  59137. +fsf/gcc/cp/gc.c
  59138. +fsf/gcc/cp/gpcompare.texi
  59139. +fsf/gcc/cp/gxx.gperf
  59140. +fsf/gcc/cp/gxxint.texi
  59141. +fsf/gcc/cp/init.c
  59142. +fsf/gcc/cp/input.c
  59143. +fsf/gcc/cp/lang-options.h
  59144. +fsf/gcc/cp/lang-specs.h
  59145. +fsf/gcc/cp/lex.c
  59146. +fsf/gcc/cp/lex.h
  59147. +fsf/gcc/cp/method.c
  59148. +fsf/gcc/cp/parse.y
  59149. +fsf/gcc/cp/pt.c
  59150. +fsf/gcc/cp/ptree.c
  59151. +fsf/gcc/cp/reno.texi
  59152. +fsf/gcc/cp/repo.c
  59153. +fsf/gcc/cp/search.c
  59154. +fsf/gcc/cp/sig.c
  59155. +fsf/gcc/cp/spew.c
  59156. +fsf/gcc/cp/templates.texi
  59157. +fsf/gcc/cp/tree.c
  59158. +fsf/gcc/cp/tree.def
  59159. +fsf/gcc/cp/typeck.c
  59160. +fsf/gcc/cp/typeck2.c
  59161. +fsf/gcc/cp/xref.c
  59162. +fsf/gcc/cplus-dem.c
  59163. +fsf/gcc/cpp.1
  59164. +fsf/gcc/cpp.aux
  59165. +fsf/gcc/cpp.cps
  59166. +fsf/gcc/cpp.fns
  59167. +fsf/gcc/cpp.texi
  59168. +fsf/gcc/cppalloc.c
  59169. +fsf/gcc/cpperror.c
  59170. +fsf/gcc/cppexp.c
  59171. +fsf/gcc/cpphash.c
  59172. +fsf/gcc/cpphash.h
  59173. +fsf/gcc/cpplib.c
  59174. +fsf/gcc/cpplib.h
  59175. +fsf/gcc/cppmain.c
  59176. +fsf/gcc/cross-make
  59177. +fsf/gcc/crtstuff.c
  59178. +fsf/gcc/cse.c
  59179. +fsf/gcc/dbxout.c
  59180. +fsf/gcc/dbxstclass.h
  59181. +fsf/gcc/defaults.h
  59182. +fsf/gcc/demangle.h
  59183. +fsf/gcc/doschk.c
  59184. +fsf/gcc/dostage2
  59185. +fsf/gcc/dostage3
  59186. +fsf/gcc/dwarf.h
  59187. +fsf/gcc/dwarfout.c
  59188. +fsf/gcc/emit-rtl.c
  59189. +fsf/gcc/enquire.c
  59190. +fsf/gcc/explow.c
  59191. +fsf/gcc/expmed.c
  59192. +fsf/gcc/expr.c
  59193. +fsf/gcc/expr.h
  59194. +fsf/gcc/extend.texi
  59195. +fsf/gcc/f/lang-options.h
  59196. +fsf/gcc/f/lang-specs.h
  59197. +fsf/gcc/final.c
  59198. +fsf/gcc/fix-header.c
  59199. +fsf/gcc/fixcpp
  59200. +fsf/gcc/fixinc-nt.sed
  59201. +fsf/gcc/fixinc.dgux
  59202. +fsf/gcc/fixinc.ptx
  59203. +fsf/gcc/fixinc.sco
  59204. +fsf/gcc/fixinc.svr4
  59205. +fsf/gcc/fixinc.winnt
  59206. +fsf/gcc/fixincludes
  59207. +fsf/gcc/fixproto
  59208. +fsf/gcc/flags.h
  59209. +fsf/gcc/floatlib.c
  59210. +fsf/gcc/flow.c
  59211. +fsf/gcc/fold-const.c
  59212. +fsf/gcc/function.c
  59213. +fsf/gcc/function.h
  59214. +fsf/gcc/gbl-ctors.h
  59215. +fsf/gcc/gcc.1
  59216. +fsf/gcc/gcc.aux
  59217. +fsf/gcc/gcc.c
  59218. +fsf/gcc/gcc.cps
  59219. +fsf/gcc/gcc.hlp
  59220. +fsf/gcc/gcc.texi
  59221. +fsf/gcc/gen-protos.c
  59222. +fsf/gcc/genattr.c
  59223. +fsf/gcc/genattrtab.c
  59224. +fsf/gcc/gencodes.c
  59225. +fsf/gcc/genconfig.c
  59226. +fsf/gcc/genemit.c
  59227. +fsf/gcc/genextract.c
  59228. +fsf/gcc/genflags.c
  59229. +fsf/gcc/genmultilib
  59230. +fsf/gcc/genopinit.c
  59231. +fsf/gcc/genoutput.c
  59232. +fsf/gcc/genpeep.c
  59233. +fsf/gcc/genrecog.c
  59234. +fsf/gcc/getopt.c
  59235. +fsf/gcc/getopt.h
  59236. +fsf/gcc/getopt1.c
  59237. +fsf/gcc/getpwd.c
  59238. +fsf/gcc/ginclude/iso646.h
  59239. +fsf/gcc/ginclude/math-3300.h
  59240. +fsf/gcc/ginclude/math-68881.h
  59241. +fsf/gcc/ginclude/proto.h
  59242. +fsf/gcc/ginclude/stdarg.h
  59243. +fsf/gcc/ginclude/stddef.h
  59244. +fsf/gcc/ginclude/va-alpha.h
  59245. +fsf/gcc/ginclude/va-clipper.h
  59246. +fsf/gcc/ginclude/va-h8300.h
  59247. +fsf/gcc/ginclude/va-i860.h
  59248. +fsf/gcc/ginclude/va-i960.h
  59249. +fsf/gcc/ginclude/va-m88k.h
  59250. +fsf/gcc/ginclude/va-mips.h
  59251. +fsf/gcc/ginclude/va-pa.h
  59252. +fsf/gcc/ginclude/va-ppc.h
  59253. +fsf/gcc/ginclude/va-pyr.h
  59254. +fsf/gcc/ginclude/va-sparc.h
  59255. +fsf/gcc/ginclude/va-spur.h
  59256. +fsf/gcc/ginclude/varargs.h
  59257. +fsf/gcc/glimits.h
  59258. +fsf/gcc/global.c
  59259. +fsf/gcc/gmon.c
  59260. +fsf/gcc/gstab.h
  59261. +fsf/gcc/gsyms.h
  59262. +fsf/gcc/gsyslimits.h
  59263. +fsf/gcc/halfpic.c
  59264. +fsf/gcc/halfpic.h
  59265. +fsf/gcc/hard-reg-set.h
  59266. +fsf/gcc/input.h
  59267. +fsf/gcc/install.sh
  59268. +fsf/gcc/install.texi
  59269. +fsf/gcc/integrate.c
  59270. +fsf/gcc/integrate.h
  59271. +fsf/gcc/invoke.texi
  59272. +fsf/gcc/jump.c
  59273. +fsf/gcc/just-fixinc
  59274. +fsf/gcc/libgcc1-test.c
  59275. +fsf/gcc/libgcc1.c
  59276. +fsf/gcc/libgcc2.c
  59277. +fsf/gcc/limitx.h
  59278. +fsf/gcc/limity.h
  59279. +fsf/gcc/listing
  59280. +fsf/gcc/local-alloc.c
  59281. +fsf/gcc/longlong.h
  59282. +fsf/gcc/loop.c
  59283. +fsf/gcc/loop.h
  59284. +fsf/gcc/machmode.def
  59285. +fsf/gcc/machmode.h
  59286. +fsf/gcc/make-cc1.com
  59287. +fsf/gcc/make-cccp.com
  59288. +fsf/gcc/make-gcc.com
  59289. +fsf/gcc/make-l2.com
  59290. +fsf/gcc/manifests/bin
  59291. +fsf/gcc/manifests/src
  59292. +fsf/gcc/md.texi
  59293. +fsf/gcc/mips-tdump.c
  59294. +fsf/gcc/mips-tfile.c
  59295. +fsf/gcc/modemap.def
  59296. +fsf/gcc/move-if-change
  59297. +fsf/gcc/objc-act.c
  59298. +fsf/gcc/objc-act.h
  59299. +fsf/gcc/objc-tree.def
  59300. +fsf/gcc/objc/Makefile
  59301. +fsf/gcc/objc/NXConstStr.h
  59302. +fsf/gcc/objc/NXConstStr.m
  59303. +fsf/gcc/objc/Object.h
  59304. +fsf/gcc/objc/Object.m
  59305. +fsf/gcc/objc/Protocol.h
  59306. +fsf/gcc/objc/Protocol.m
  59307. +fsf/gcc/objc/README
  59308. +fsf/gcc/objc/archive.c
  59309. +fsf/gcc/objc/class.c
  59310. +fsf/gcc/objc/encoding.c
  59311. +fsf/gcc/objc/encoding.h
  59312. +fsf/gcc/objc/hash.c
  59313. +fsf/gcc/objc/hash.h
  59314. +fsf/gcc/objc/init.c
  59315. +fsf/gcc/objc/list.h
  59316. +fsf/gcc/objc/makefile.dos
  59317. +fsf/gcc/objc/misc.c
  59318. +fsf/gcc/objc/objc-api.h
  59319. +fsf/gcc/objc/objc.h
  59320. +fsf/gcc/objc/objects.c
  59321. +fsf/gcc/objc/runtime.h
  59322. +fsf/gcc/objc/sarray.c
  59323. +fsf/gcc/objc/sarray.h
  59324. +fsf/gcc/objc/selector.c
  59325. +fsf/gcc/objc/sendmsg.c
  59326. +fsf/gcc/objc/typedstream.h
  59327. +fsf/gcc/obstack.c
  59328. +fsf/gcc/obstack.h
  59329. +fsf/gcc/optabs.c
  59330. +fsf/gcc/output.h
  59331. +fsf/gcc/pcp.h
  59332. +fsf/gcc/print-rtl.c
  59333. +fsf/gcc/print-tree.c
  59334. +fsf/gcc/protoize.c
  59335. +fsf/gcc/pself.c
  59336. +fsf/gcc/pself1.c
  59337. +fsf/gcc/pself2.c
  59338. +fsf/gcc/pself3.c
  59339. +fsf/gcc/real.c
  59340. +fsf/gcc/real.h
  59341. +fsf/gcc/recog.c
  59342. +fsf/gcc/recog.h
  59343. +fsf/gcc/reg-stack.c
  59344. +fsf/gcc/regclass.c
  59345. +fsf/gcc/regs.h
  59346. +fsf/gcc/reload.c
  59347. +fsf/gcc/reload.h
  59348. +fsf/gcc/reload1.c
  59349. +fsf/gcc/reorg.c
  59350. +fsf/gcc/rtl.c
  59351. +fsf/gcc/rtl.def
  59352. +fsf/gcc/rtl.h
  59353. +fsf/gcc/rtl.texi
  59354. +fsf/gcc/rtlanal.c
  59355. +fsf/gcc/scan-decls.c
  59356. +fsf/gcc/scan-types.sh
  59357. +fsf/gcc/scan.c
  59358. +fsf/gcc/scan.h
  59359. +fsf/gcc/sched.c
  59360. +fsf/gcc/sdbout.c
  59361. +fsf/gcc/sort-protos
  59362. +fsf/gcc/stab.def
  59363. +fsf/gcc/stack.h
  59364. +fsf/gcc/stmt.c
  59365. +fsf/gcc/stor-layout.c
  59366. +fsf/gcc/stupid.c
  59367. +fsf/gcc/sys-protos.h
  59368. +fsf/gcc/sys-types.h
  59369. +fsf/gcc/texinfo.tex
  59370. +fsf/gcc/tm.texi
  59371. +fsf/gcc/toplev.c
  59372. +fsf/gcc/tree.c
  59373. +fsf/gcc/tree.def
  59374. +fsf/gcc/tree.h
  59375. +fsf/gcc/typeclass.h
  59376. +fsf/gcc/unprotoize.c
  59377. +fsf/gcc/unroll.c
  59378. +fsf/gcc/varasm.c
  59379. +fsf/gcc/version.c
  59380. +fsf/gcc/vmsconfig.com
  59381. +fsf/gcc/xcoffout.c
  59382. +fsf/gcc/xcoffout.h
  59383. diff -rup --new-file baseline/fsf/gcc/objc-act.c amiga/fsf/gcc/objc-act.c
  59384. --- baseline/fsf/gcc/objc-act.c    Mon Aug 28 03:25:19 1995
  59385. +++ amiga/fsf/gcc/objc-act.c    Sat Sep 28 00:00:00 1996
  59386. @@ -2897,18 +2897,22 @@ build_tmp_function_decl ()
  59387.    /* struct objc_object *objc_xxx (id, SEL, ...); */
  59388.    pushlevel (0);
  59389.    decl_specs = build_tree_list (NULL_TREE, objc_object_reference);
  59390. +  /* Amiga-specific support for explicit register specification for
  59391. +     parameters. KI 7.04.1996 */
  59392.    push_parm_decl (build_tree_list
  59393.            (build_tree_list (decl_specs,
  59394.                      build1 (INDIRECT_REF, NULL_TREE,
  59395.                          NULL_TREE)),
  59396. -           build_tree_list (NULL_TREE, NULL_TREE)));
  59397. +           build_tree_list (NULL_TREE, NULL_TREE)), NULL_TREE);
  59398.  
  59399.    decl_specs = build_tree_list (NULL_TREE, xref_tag (RECORD_TYPE,
  59400.                        get_identifier (TAG_SELECTOR)));
  59401.    expr_decl = build1 (INDIRECT_REF, NULL_TREE, NULL_TREE);
  59402.  
  59403. +  /* Amiga-specific support for explicit register specification for
  59404. +     parameters. KI 7.04.1996 */
  59405.    push_parm_decl (build_tree_list (build_tree_list (decl_specs, expr_decl),
  59406. -                   build_tree_list (NULL_TREE, NULL_TREE)));
  59407. +                   build_tree_list (NULL_TREE, NULL_TREE)), NULL_TREE);
  59408.    parms = get_parm_info (0);
  59409.    poplevel (0, 0, 0);
  59410.  
  59411. @@ -6774,24 +6778,30 @@ start_method_def (method)
  59412.         assign to self, which changes its type midstream.  */
  59413.      decl_specs = build_tree_list (NULL_TREE, objc_object_reference);
  59414.  
  59415. +  /* Amiga-specific support for explicit register specification for
  59416. +     parameters. KI 7.04.1996 */
  59417.    push_parm_decl (build_tree_list
  59418.            (build_tree_list (decl_specs,
  59419.                      build1 (INDIRECT_REF, NULL_TREE, self_id)),
  59420. -           build_tree_list (unused_list, NULL_TREE)));
  59421. +           build_tree_list (unused_list, NULL_TREE)), NULL_TREE);
  59422.  
  59423.  #ifdef OBJC_INT_SELECTORS
  59424.    decl_specs = build_tree_list (NULL_TREE, ridpointers[(int) RID_UNSIGNED]);
  59425.    decl_specs = tree_cons (NULL_TREE, ridpointers[(int) RID_INT], decl_specs);
  59426. +  /* Amiga-specific support for explicit register specification for
  59427. +     parameters. KI 7.04.1996 */
  59428.    push_parm_decl (build_tree_list (build_tree_list (decl_specs, ucmd_id),
  59429. -                   build_tree_list (unused_list, NULL_TREE)));
  59430. +                   build_tree_list (unused_list, NULL_TREE)), NULL_TREE);
  59431.  #else /* not OBJC_INT_SELECTORS */
  59432.    decl_specs = build_tree_list (NULL_TREE,
  59433.                  xref_tag (RECORD_TYPE,
  59434.                        get_identifier (TAG_SELECTOR)));
  59435. +  /* Amiga-specific support for explicit register specification for
  59436. +     parameters. KI 7.04.1996 */
  59437.    push_parm_decl (build_tree_list
  59438.            (build_tree_list (decl_specs,
  59439.                      build1 (INDIRECT_REF, NULL_TREE, ucmd_id)),
  59440. -           build_tree_list (unused_list, NULL_TREE)));
  59441. +           build_tree_list (unused_list, NULL_TREE)), NULL_TREE);
  59442.  #endif /* not OBJC_INT_SELECTORS */
  59443.  
  59444.    /* Generate argument declarations if a keyword_decl. */
  59445. @@ -6809,19 +6819,23 @@ start_method_def (method)
  59446.  
  59447.            /* Unite the abstract decl with its name. */
  59448.            TREE_OPERAND (last_expr, 0) = KEYWORD_ARG_NAME (arglist);
  59449. +          /* Amiga-specific support for explicit register specification
  59450. +         for parameters. KI 7.04.1996 */
  59451.            push_parm_decl (build_tree_list
  59452.                    (build_tree_list (arg_spec, arg_decl),
  59453. -                   build_tree_list (NULL_TREE, NULL_TREE)));
  59454. +                   build_tree_list (NULL_TREE, NULL_TREE)), NULL_TREE);
  59455.  
  59456.            /* Unhook: restore the abstract declarator. */
  59457.            TREE_OPERAND (last_expr, 0) = NULL_TREE;
  59458.          }
  59459.  
  59460.        else
  59461. +        /* Amiga-specific support for explicit register specification for
  59462. +           parameters. KI 7.04.1996 */
  59463.          push_parm_decl (build_tree_list
  59464.                  (build_tree_list (arg_spec,
  59465.                            KEYWORD_ARG_NAME (arglist)),
  59466. -                 build_tree_list (NULL_TREE, NULL_TREE)));
  59467. +                 build_tree_list (NULL_TREE, NULL_TREE)), NULL_TREE);
  59468.  
  59469.        arglist = TREE_CHAIN (arglist);
  59470.      }
  59471. diff -rup --new-file baseline/fsf/gcc/objc-parse.c amiga/fsf/gcc/objc-parse.c
  59472. --- baseline/fsf/gcc/objc-parse.c    Sat Sep 23 09:23:10 1995
  59473. +++ amiga/fsf/gcc/objc-parse.c    Wed Dec 31 17:00:00 1969
  59474. @@ -1,4918 +0,0 @@
  59475. -
  59476. -/*  A Bison parser, made from objc-parse.y with Bison version GNU Bison version 1.22
  59477. -  */
  59478. -
  59479. -#define YYBISON 1  /* Identify Bison output.  */
  59480. -
  59481. -#define    IDENTIFIER    258
  59482. -#define    TYPENAME    259
  59483. -#define    SCSPEC    260
  59484. -#define    TYPESPEC    261
  59485. -#define    TYPE_QUAL    262
  59486. -#define    CONSTANT    263
  59487. -#define    STRING    264
  59488. -#define    ELLIPSIS    265
  59489. -#define    SIZEOF    266
  59490. -#define    ENUM    267
  59491. -#define    STRUCT    268
  59492. -#define    UNION    269
  59493. -#define    IF    270
  59494. -#define    ELSE    271
  59495. -#define    WHILE    272
  59496. -#define    DO    273
  59497. -#define    FOR    274
  59498. -#define    SWITCH    275
  59499. -#define    CASE    276
  59500. -#define    DEFAULT    277
  59501. -#define    BREAK    278
  59502. -#define    CONTINUE    279
  59503. -#define    RETURN    280
  59504. -#define    GOTO    281
  59505. -#define    ASM_KEYWORD    282
  59506. -#define    TYPEOF    283
  59507. -#define    ALIGNOF    284
  59508. -#define    ATTRIBUTE    285
  59509. -#define    EXTENSION    286
  59510. -#define    LABEL    287
  59511. -#define    REALPART    288
  59512. -#define    IMAGPART    289
  59513. -#define    ASSIGN    290
  59514. -#define    OROR    291
  59515. -#define    ANDAND    292
  59516. -#define    EQCOMPARE    293
  59517. -#define    ARITHCOMPARE    294
  59518. -#define    LSHIFT    295
  59519. -#define    RSHIFT    296
  59520. -#define    UNARY    297
  59521. -#define    PLUSPLUS    298
  59522. -#define    MINUSMINUS    299
  59523. -#define    HYPERUNARY    300
  59524. -#define    POINTSAT    301
  59525. -#define    INTERFACE    302
  59526. -#define    IMPLEMENTATION    303
  59527. -#define    END    304
  59528. -#define    SELECTOR    305
  59529. -#define    DEFS    306
  59530. -#define    ENCODE    307
  59531. -#define    CLASSNAME    308
  59532. -#define    PUBLIC    309
  59533. -#define    PRIVATE    310
  59534. -#define    PROTECTED    311
  59535. -#define    PROTOCOL    312
  59536. -#define    OBJECTNAME    313
  59537. -#define    CLASS    314
  59538. -#define    ALIAS    315
  59539. -#define    OBJC_STRING    316
  59540. -
  59541. -#line 32 "objc-parse.y"
  59542. -
  59543. -#include <stdio.h>
  59544. -#include <errno.h>
  59545. -#include <setjmp.h>
  59546. -
  59547. -#include "config.h"
  59548. -#include "tree.h"
  59549. -#include "input.h"
  59550. -#include "c-lex.h"
  59551. -#include "c-tree.h"
  59552. -#include "flags.h"
  59553. -
  59554. -#ifdef MULTIBYTE_CHARS
  59555. -#include <stdlib.h>
  59556. -#include <locale.h>
  59557. -#endif
  59558. -
  59559. -#include "objc-act.h"
  59560. -
  59561. -/* Since parsers are distinct for each language, put the language string
  59562. -   definition here.  */
  59563. -char *language_string = "GNU Obj-C";
  59564. -
  59565. -#ifndef errno
  59566. -extern int errno;
  59567. -#endif
  59568. -
  59569. -void yyerror ();
  59570. -
  59571. -/* Like YYERROR but do call yyerror.  */
  59572. -#define YYERROR1 { yyerror ("syntax error"); YYERROR; }
  59573. -
  59574. -/* Cause the `yydebug' variable to be defined.  */
  59575. -#define YYDEBUG 1
  59576. -
  59577. -#line 70 "objc-parse.y"
  59578. -typedef union {long itype; tree ttype; enum tree_code code;
  59579. -    char *filename; int lineno; int ends_in_label; } YYSTYPE;
  59580. -#line 194 "objc-parse.y"
  59581. -
  59582. -/* Number of statements (loosely speaking) seen so far.  */
  59583. -static int stmt_count;
  59584. -
  59585. -/* Input file and line number of the end of the body of last simple_if;
  59586. -   used by the stmt-rule immediately after simple_if returns.  */
  59587. -static char *if_stmt_file;
  59588. -static int if_stmt_line;
  59589. -
  59590. -/* List of types and structure classes of the current declaration.  */
  59591. -static tree current_declspecs;
  59592. -static tree prefix_attributes = NULL_TREE;
  59593. -
  59594. -/* Stack of saved values of current_declspecs and prefix_attributes.  */
  59595. -static tree declspec_stack;
  59596. -
  59597. -/* 1 if we explained undeclared var errors.  */
  59598. -static int undeclared_variable_notice;
  59599. -
  59600. -/* Objective-C specific information */
  59601. -
  59602. -tree objc_interface_context;
  59603. -tree objc_implementation_context;
  59604. -tree objc_method_context;
  59605. -tree objc_ivar_chain;
  59606. -tree objc_ivar_context;
  59607. -enum tree_code objc_inherit_code;
  59608. -int objc_receiver_context;
  59609. -int objc_public_flag;
  59610. -
  59611. -
  59612. -/* Tell yyparse how to print a token's value, if yydebug is set.  */
  59613. -
  59614. -#define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL)
  59615. -extern void yyprint ();
  59616. -
  59617. -#ifndef YYLTYPE
  59618. -typedef
  59619. -  struct yyltype
  59620. -    {
  59621. -      int timestamp;
  59622. -      int first_line;
  59623. -      int first_column;
  59624. -      int last_line;
  59625. -      int last_column;
  59626. -      char *text;
  59627. -   }
  59628. -  yyltype;
  59629. -
  59630. -#define YYLTYPE yyltype
  59631. -#endif
  59632. -
  59633. -#include <stdio.h>
  59634. -
  59635. -#ifndef __cplusplus
  59636. -#ifndef __STDC__
  59637. -#define const
  59638. -#endif
  59639. -#endif
  59640. -
  59641. -
  59642. -
  59643. -#define    YYFINAL        915
  59644. -#define    YYFLAG        -32768
  59645. -#define    YYNTBASE    84
  59646. -
  59647. -#define YYTRANSLATE(x) ((unsigned)(x) <= 316 ? yytranslate[x] : 294)
  59648. -
  59649. -static const char yytranslate[] = {     0,
  59650. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59651. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59652. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59653. -     2,     2,    80,     2,     2,     2,    52,    43,     2,    59,
  59654. -    76,    50,    48,    81,    49,    58,    51,     2,     2,     2,
  59655. -     2,     2,     2,     2,     2,     2,     2,    38,    77,     2,
  59656. -    36,     2,    37,     2,     2,     2,     2,     2,     2,     2,
  59657. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59658. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59659. -    60,     2,    83,    42,     2,     2,     2,     2,     2,     2,
  59660. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59661. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59662. -     2,     2,    82,    41,    78,    79,     2,     2,     2,     2,
  59663. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59664. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59665. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59666. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59667. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59668. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59669. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59670. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59671. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59672. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59673. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59674. -     2,     2,     2,     2,     2,     2,     2,     2,     2,     2,
  59675. -     2,     2,     2,     2,     2,     1,     2,     3,     4,     5,
  59676. -     6,     7,     8,     9,    10,    11,    12,    13,    14,    15,
  59677. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  59678. -    26,    27,    28,    29,    30,    31,    32,    33,    34,    35,
  59679. -    39,    40,    44,    45,    46,    47,    53,    54,    55,    56,
  59680. -    57,    61,    62,    63,    64,    65,    66,    67,    68,    69,
  59681. -    70,    71,    72,    73,    74,    75
  59682. -};
  59683. -
  59684. -#if YYDEBUG != 0
  59685. -static const short yyprhs[] = {     0,
  59686. -     0,     1,     3,     4,     7,     8,    12,    14,    16,    18,
  59687. -    24,    28,    33,    38,    41,    44,    47,    50,    52,    53,
  59688. -    54,    62,    67,    68,    69,    77,    82,    83,    84,    91,
  59689. -    95,    97,    99,   101,   103,   105,   107,   109,   111,   113,
  59690. -   115,   117,   119,   120,   122,   124,   128,   130,   133,   134,
  59691. -   138,   141,   144,   147,   152,   155,   160,   163,   166,   168,
  59692. -   173,   174,   182,   184,   188,   192,   196,   200,   204,   208,
  59693. -   212,   216,   220,   224,   228,   232,   236,   240,   246,   250,
  59694. -   254,   256,   258,   260,   264,   268,   269,   274,   279,   284,
  59695. -   288,   292,   295,   298,   300,   302,   304,   306,   308,   310,
  59696. -   313,   315,   318,   319,   321,   324,   328,   330,   332,   335,
  59697. -   338,   343,   348,   351,   354,   358,   360,   362,   365,   368,
  59698. -   369,   370,   375,   380,   384,   388,   391,   394,   397,   401,
  59699. -   402,   405,   408,   410,   412,   415,   418,   421,   425,   426,
  59700. -   429,   431,   433,   435,   438,   441,   446,   451,   453,   455,
  59701. -   457,   459,   463,   465,   469,   470,   475,   476,   483,   487,
  59702. -   488,   495,   499,   500,   502,   504,   507,   514,   516,   520,
  59703. -   521,   523,   528,   535,   540,   542,   544,   546,   548,   550,
  59704. -   551,   556,   558,   559,   562,   564,   568,   570,   571,   576,
  59705. -   578,   579,   584,   585,   591,   592,   593,   599,   600,   601,
  59706. -   607,   609,   611,   615,   619,   624,   628,   632,   636,   638,
  59707. -   640,   644,   649,   653,   657,   661,   663,   667,   671,   675,
  59708. -   680,   684,   688,   690,   691,   699,   705,   708,   709,   717,
  59709. -   723,   726,   727,   736,   737,   745,   748,   749,   751,   752,
  59710. -   754,   756,   759,   760,   764,   767,   772,   776,   778,   782,
  59711. -   784,   786,   788,   792,   797,   804,   810,   812,   816,   818,
  59712. -   820,   824,   827,   830,   831,   833,   835,   838,   839,   842,
  59713. -   846,   850,   853,   857,   862,   866,   869,   873,   876,   880,
  59714. -   882,   884,   887,   890,   891,   893,   896,   897,   898,   900,
  59715. -   902,   905,   909,   911,   914,   917,   924,   930,   936,   939,
  59716. -   942,   947,   948,   953,   954,   955,   959,   964,   968,   970,
  59717. -   972,   974,   976,   979,   980,   985,   987,   991,   992,   993,
  59718. -  1001,  1007,  1010,  1011,  1012,  1013,  1026,  1027,  1034,  1037,
  59719. -  1040,  1043,  1047,  1054,  1063,  1074,  1087,  1091,  1096,  1098,
  59720. -  1100,  1101,  1108,  1112,  1118,  1121,  1124,  1125,  1127,  1128,
  59721. -  1130,  1131,  1133,  1135,  1139,  1144,  1146,  1150,  1151,  1154,
  59722. -  1157,  1158,  1163,  1166,  1167,  1169,  1171,  1175,  1177,  1181,
  59723. -  1186,  1191,  1196,  1201,  1206,  1207,  1210,  1212,  1215,  1217,
  59724. -  1221,  1223,  1227,  1229,  1231,  1233,  1235,  1237,  1239,  1241,
  59725. -  1245,  1249,  1254,  1255,  1256,  1267,  1268,  1275,  1276,  1277,
  59726. -  1290,  1291,  1300,  1301,  1308,  1311,  1312,  1321,  1326,  1327,
  59727. -  1337,  1343,  1344,  1351,  1352,  1356,  1360,  1362,  1364,  1366,
  59728. -  1368,  1369,  1373,  1376,  1380,  1384,  1386,  1387,  1389,  1393,
  59729. -  1395,  1399,  1402,  1403,  1404,  1405,  1413,  1414,  1415,  1416,
  59730. -  1424,  1425,  1426,  1429,  1431,  1433,  1436,  1437,  1441,  1443,
  59731. -  1445,  1446,  1447,  1453,  1454,  1455,  1461,  1466,  1468,  1474,
  59732. -  1477,  1478,  1481,  1482,  1484,  1486,  1488,  1491,  1494,  1499,
  59733. -  1502,  1505,  1507,  1511,  1514,  1517,  1520,  1521,  1524,  1525,
  59734. -  1529,  1531,  1533,  1536,  1538,  1540,  1542,  1544,  1546,  1548,
  59735. -  1550,  1552,  1554,  1556,  1558,  1560,  1562,  1564,  1566,  1568,
  59736. -  1570,  1572,  1574,  1576,  1578,  1580,  1582,  1584,  1586,  1593,
  59737. -  1597,  1603,  1606,  1608,  1610,  1612,  1615,  1617,  1621,  1624,
  59738. -  1626,  1628,  1629,  1630,  1637,  1639,  1641,  1643,  1646,  1649,
  59739. -  1651,  1656,  1661
  59740. -};
  59741. -
  59742. -static const short yyrhs[] = {    -1,
  59743. -    85,     0,     0,    86,    88,     0,     0,    85,    87,    88,
  59744. -     0,    90,     0,    89,     0,   226,     0,    27,    59,    99,
  59745. -    76,    77,     0,   117,   128,    77,     0,   122,   117,   128,
  59746. -    77,     0,   120,   117,   127,    77,     0,   122,    77,     0,
  59747. -   120,    77,     0,     1,    77,     0,     1,    78,     0,    77,
  59748. -     0,     0,     0,   120,   117,   154,    91,   111,    92,   185,
  59749. -     0,   120,   117,   154,     1,     0,     0,     0,   122,   117,
  59750. -   157,    93,   111,    94,   185,     0,   122,   117,   157,     1,
  59751. -     0,     0,     0,   117,   157,    95,   111,    96,   185,     0,
  59752. -   117,   157,     1,     0,     3,     0,     4,     0,    72,     0,
  59753. -    67,     0,    43,     0,    49,     0,    48,     0,    54,     0,
  59754. -    55,     0,    79,     0,    80,     0,   101,     0,     0,   101,
  59755. -     0,   106,     0,   101,    81,   106,     0,   107,     0,    50,
  59756. -   104,     0,     0,    31,   103,   104,     0,    98,   104,     0,
  59757. -    40,    97,     0,    11,   102,     0,    11,    59,   172,    76,
  59758. -     0,    29,   102,     0,    29,    59,   172,    76,     0,    33,
  59759. -   104,     0,    34,   104,     0,   102,     0,    59,   172,    76,
  59760. -   104,     0,     0,    59,   172,    76,    82,   105,   142,    78,
  59761. -     0,   104,     0,   106,    48,   106,     0,   106,    49,   106,
  59762. -     0,   106,    50,   106,     0,   106,    51,   106,     0,   106,
  59763. -    52,   106,     0,   106,    46,   106,     0,   106,    47,   106,
  59764. -     0,   106,    45,   106,     0,   106,    44,   106,     0,   106,
  59765. -    43,   106,     0,   106,    41,   106,     0,   106,    42,   106,
  59766. -     0,   106,    40,   106,     0,   106,    39,   106,     0,   106,
  59767. -    37,   209,    38,   106,     0,   106,    36,   106,     0,   106,
  59768. -    35,   106,     0,     3,     0,     8,     0,   109,     0,    59,
  59769. -    99,    76,     0,    59,     1,    76,     0,     0,    59,   108,
  59770. -   186,    76,     0,   107,    59,   100,    76,     0,   107,    60,
  59771. -    99,    83,     0,   107,    58,    97,     0,   107,    57,    97,
  59772. -     0,   107,    54,     0,   107,    55,     0,   285,     0,   291,
  59773. -     0,   292,     0,   293,     0,   110,     0,     9,     0,   109,
  59774. -     9,     0,    75,     0,   110,    75,     0,     0,   113,     0,
  59775. -   113,    10,     0,   191,   192,   114,     0,   112,     0,   180,
  59776. -     0,   113,   112,     0,   112,   180,     0,   120,   117,   127,
  59777. -    77,     0,   122,   117,   128,    77,     0,   120,    77,     0,
  59778. -   122,    77,     0,   191,   192,   119,     0,   115,     0,   180,
  59779. -     0,   116,   115,     0,   115,   180,     0,     0,     0,   120,
  59780. -   117,   127,    77,     0,   122,   117,   128,    77,     0,   120,
  59781. -   117,   148,     0,   122,   117,   151,     0,   120,    77,     0,
  59782. -   122,    77,     0,   125,   121,     0,   122,   125,   121,     0,
  59783. -     0,   121,   126,     0,   121,     5,     0,     7,     0,     5,
  59784. -     0,   122,     7,     0,   122,     5,     0,   125,   124,     0,
  59785. -   174,   125,   124,     0,     0,   124,   126,     0,     6,     0,
  59786. -   158,     0,     4,     0,    67,   242,     0,    72,   242,     0,
  59787. -    28,    59,    99,    76,     0,    28,    59,   172,    76,     0,
  59788. -     6,     0,     7,     0,   158,     0,   130,     0,   127,    81,
  59789. -   130,     0,   132,     0,   128,    81,   130,     0,     0,    27,
  59790. -    59,   109,    76,     0,     0,   154,   129,   134,    36,   131,
  59791. -   140,     0,   154,   129,   134,     0,     0,   157,   129,   134,
  59792. -    36,   133,   140,     0,   157,   129,   134,     0,     0,   135,
  59793. -     0,   136,     0,   135,   136,     0,    30,    59,    59,   137,
  59794. -    76,    76,     0,   138,     0,   137,    81,   138,     0,     0,
  59795. -   139,     0,   139,    59,     3,    76,     0,   139,    59,     3,
  59796. -    81,   101,    76,     0,   139,    59,   100,    76,     0,    97,
  59797. -     0,     5,     0,     6,     0,     7,     0,   106,     0,     0,
  59798. -    82,   141,   142,    78,     0,     1,     0,     0,   143,   163,
  59799. -     0,   144,     0,   143,    81,   144,     0,   106,     0,     0,
  59800. -    82,   145,   142,    78,     0,     1,     0,     0,    97,    38,
  59801. -   146,   144,     0,     0,    58,    97,    36,   147,   144,     0,
  59802. -     0,     0,   154,   149,   111,   150,   186,     0,     0,     0,
  59803. -   157,   152,   111,   153,   186,     0,   155,     0,   157,     0,
  59804. -    59,   155,    76,     0,   155,    59,   221,     0,   155,    60,
  59805. -    99,    83,     0,   155,    60,    83,     0,    50,   175,   155,
  59806. -     0,   135,   118,   155,     0,     4,     0,    72,     0,   156,
  59807. -    59,   221,     0,   156,    60,    99,    83,     0,   156,    60,
  59808. -    83,     0,    50,   175,   156,     0,   135,   118,   156,     0,
  59809. -     4,     0,   157,    59,   221,     0,    59,   157,    76,     0,
  59810. -    50,   175,   157,     0,   157,    60,    99,    83,     0,   157,
  59811. -    60,    83,     0,   135,   118,   157,     0,     3,     0,     0,
  59812. -    13,    97,    82,   159,   165,    78,   134,     0,    13,    82,
  59813. -   165,    78,   134,     0,    13,    97,     0,     0,    14,    97,
  59814. -    82,   160,   165,    78,   134,     0,    14,    82,   165,    78,
  59815. -   134,     0,    14,    97,     0,     0,    12,    97,    82,   161,
  59816. -   170,   164,    78,   134,     0,     0,    12,    82,   162,   170,
  59817. -   164,    78,   134,     0,    12,    97,     0,     0,    81,     0,
  59818. -     0,    81,     0,   166,     0,   166,   167,     0,     0,   166,
  59819. -   167,    77,     0,   166,    77,     0,    65,    59,    67,    76,
  59820. -     0,   123,   117,   168,     0,   123,     0,   174,   117,   168,
  59821. -     0,   174,     0,     1,     0,   169,     0,   168,    81,   169,
  59822. -     0,   191,   192,   154,   134,     0,   191,   192,   154,    38,
  59823. -   106,   134,     0,   191,   192,    38,   106,   134,     0,   171,
  59824. -     0,   170,    81,   171,     0,     1,     0,    97,     0,    97,
  59825. -    36,   106,     0,   123,   173,     0,   174,   173,     0,     0,
  59826. -   176,     0,     7,     0,   174,     7,     0,     0,   175,     7,
  59827. -     0,    59,   176,    76,     0,    50,   175,   176,     0,    50,
  59828. -   175,     0,   176,    59,   214,     0,   176,    60,    99,    83,
  59829. -     0,   176,    60,    83,     0,    59,   214,     0,    60,    99,
  59830. -    83,     0,    60,    83,     0,   135,   118,   176,     0,   178,
  59831. -     0,   194,     0,   178,   194,     0,   178,   180,     0,     0,
  59832. -   177,     0,     1,    77,     0,     0,     0,   183,     0,   184,
  59833. -     0,   183,   184,     0,    32,   225,    77,     0,   186,     0,
  59834. -     1,   186,     0,    82,    78,     0,    82,   181,   182,   116,
  59835. -   179,    78,     0,    82,   181,   182,     1,    78,     0,    82,
  59836. -   181,   182,   177,    78,     0,   188,   193,     0,   188,     1,
  59837. -     0,    15,    59,    99,    76,     0,     0,    18,   190,   193,
  59838. -    17,     0,     0,     0,   191,   192,   196,     0,   191,   192,
  59839. -   207,   193,     0,   191,   192,   195,     0,   196,     0,   207,
  59840. -     0,   186,     0,   204,     0,    99,    77,     0,     0,   187,
  59841. -    16,   197,   193,     0,   187,     0,   187,    16,     1,     0,
  59842. -     0,     0,    17,   198,    59,    99,    76,   199,   193,     0,
  59843. -   189,    59,    99,    76,    77,     0,   189,     1,     0,     0,
  59844. -     0,     0,    19,    59,   209,    77,   200,   209,    77,   201,
  59845. -   209,    76,   202,   193,     0,     0,    20,    59,    99,    76,
  59846. -   203,   193,     0,    23,    77,     0,    24,    77,     0,    25,
  59847. -    77,     0,    25,    99,    77,     0,    27,   208,    59,    99,
  59848. -    76,    77,     0,    27,   208,    59,    99,    38,   210,    76,
  59849. -    77,     0,    27,   208,    59,    99,    38,   210,    38,   210,
  59850. -    76,    77,     0,    27,   208,    59,    99,    38,   210,    38,
  59851. -   210,    38,   213,    76,    77,     0,    26,    97,    77,     0,
  59852. -    26,    50,    99,    77,     0,    77,     0,   205,     0,     0,
  59853. -    19,    59,   107,    76,   206,   193,     0,    21,   106,    38,
  59854. -     0,    21,   106,    10,   106,    38,     0,    22,    38,     0,
  59855. -    97,    38,     0,     0,     7,     0,     0,    99,     0,     0,
  59856. -   211,     0,   212,     0,   211,    81,   212,     0,     9,    59,
  59857. -    99,    76,     0,   109,     0,   213,    81,   109,     0,     0,
  59858. -   215,   216,     0,   218,    76,     0,     0,   219,    77,   217,
  59859. -   216,     0,     1,    76,     0,     0,    10,     0,   219,     0,
  59860. -   219,    81,    10,     0,   220,     0,   219,    81,   220,     0,
  59861. -   120,   117,   156,   134,     0,   120,   117,   157,   134,     0,
  59862. -   120,   117,   173,   134,     0,   122,   117,   157,   134,     0,
  59863. -   122,   117,   173,   134,     0,     0,   222,   223,     0,   216,
  59864. -     0,   224,    76,     0,     3,     0,   224,    81,     3,     0,
  59865. -    97,     0,   225,    81,    97,     0,   230,     0,   228,     0,
  59866. -   229,     0,   240,     0,   249,     0,    63,     0,    97,     0,
  59867. -   227,    81,    97,     0,    73,   227,    77,     0,    74,    97,
  59868. -    97,    77,     0,     0,     0,    61,    97,   242,    82,   231,
  59869. -   243,    78,   232,   256,    63,     0,     0,    61,    97,   242,
  59870. -   233,   256,    63,     0,     0,     0,    61,    97,    38,    97,
  59871. -   242,    82,   234,   243,    78,   235,   256,    63,     0,     0,
  59872. -    61,    97,    38,    97,   242,   236,   256,    63,     0,     0,
  59873. -    62,    97,    82,   237,   243,    78,     0,    62,    97,     0,
  59874. -     0,    62,    97,    38,    97,    82,   238,   243,    78,     0,
  59875. -    62,    97,    38,    97,     0,     0,    61,    97,    59,    97,
  59876. -    76,   242,   239,   256,    63,     0,    62,    97,    59,    97,
  59877. -    76,     0,     0,    71,    97,   242,   241,   256,    63,     0,
  59878. -     0,    45,   227,    45,     0,   243,   244,   245,     0,   245,
  59879. -     0,    69,     0,    70,     0,    68,     0,     0,   245,   246,
  59880. -    77,     0,   245,    77,     0,   123,   117,   247,     0,   174,
  59881. -   117,   247,     0,     1,     0,     0,   248,     0,   247,    81,
  59882. -   248,     0,   154,     0,   154,    38,   106,     0,    38,   106,
  59883. -     0,     0,     0,     0,    48,   250,   266,   251,   267,   252,
  59884. -   185,     0,     0,     0,     0,    49,   253,   266,   254,   267,
  59885. -   255,   185,     0,     0,     0,   257,   258,     0,   261,     0,
  59886. -    89,     0,   258,   261,     0,     0,   258,   259,    89,     0,
  59887. -    77,     0,     1,     0,     0,     0,    48,   262,   266,   263,
  59888. -   260,     0,     0,     0,    49,   264,   266,   265,   260,     0,
  59889. -    59,   172,    76,   275,     0,   275,     0,    59,   172,    76,
  59890. -   276,   273,     0,   276,   273,     0,     0,    77,   268,     0,
  59891. -     0,   269,     0,   270,     0,   180,     0,   269,   270,     0,
  59892. -   270,   180,     0,   120,   117,   271,    77,     0,   120,    77,
  59893. -     0,   122,    77,     0,   272,     0,   271,    81,   272,     0,
  59894. -   156,   134,     0,   157,   134,     0,   173,   134,     0,     0,
  59895. -    81,    10,     0,     0,    81,   274,   218,     0,   277,     0,
  59896. -   279,     0,   276,   279,     0,     3,     0,     4,     0,    72,
  59897. -     0,   278,     0,    12,     0,    13,     0,    14,     0,    15,
  59898. -     0,    16,     0,    17,     0,    18,     0,    19,     0,    20,
  59899. -     0,    21,     0,    22,     0,    23,     0,    24,     0,    25,
  59900. -     0,    26,     0,    27,     0,    11,     0,    28,     0,    29,
  59901. -     0,     6,     0,     7,     0,   277,    38,    59,   172,    76,
  59902. -    97,     0,   277,    38,    97,     0,    38,    59,   172,    76,
  59903. -    97,     0,    38,    97,     0,   277,     0,   281,     0,   283,
  59904. -     0,   281,   283,     0,   101,     0,   277,    38,   282,     0,
  59905. -    38,   282,     0,    99,     0,    67,     0,     0,     0,    60,
  59906. -   286,   284,   287,   280,    83,     0,   277,     0,   289,     0,
  59907. -   290,     0,   289,   290,     0,   277,    38,     0,    38,     0,
  59908. -    64,    59,   288,    76,     0,    71,    59,    97,    76,     0,
  59909. -    66,    59,   172,    76,     0
  59910. -};
  59911. -
  59912. -#endif
  59913. -
  59914. -#if YYDEBUG != 0
  59915. -static const short yyrline[] = { 0,
  59916. -   232,   237,   251,   253,   253,   254,   256,   258,   259,   260,
  59917. -   270,   281,   286,   291,   293,   295,   296,   297,   302,   309,
  59918. -   311,   316,   321,   327,   329,   334,   339,   345,   347,   352,
  59919. -   359,   361,   362,   363,   366,   368,   370,   372,   374,   376,
  59920. -   378,   382,   386,   389,   392,   395,   399,   401,   404,   407,
  59921. -   410,   414,   442,   447,   449,   451,   453,   455,   459,   461,
  59922. -   464,   468,   495,   497,   499,   501,   503,   505,   507,   509,
  59923. -   511,   513,   515,   517,   519,   521,   523,   525,   527,   530,
  59924. -   536,   696,   697,   699,   705,   707,   721,   744,   746,   748,
  59925. -   760,   774,   776,   778,   780,   782,   784,   786,   791,   793,
  59926. -   799,   801,   805,   807,   808,   818,   823,   825,   826,   827,
  59927. -   830,   836,   841,   844,   852,   857,   859,   860,   861,   868,
  59928. -   878,   882,   888,   893,   898,   903,   905,   913,   916,   920,
  59929. -   922,   924,   935,   939,   941,   944,   957,   960,   964,   966,
  59930. -   974,   975,   976,   980,   982,   984,   986,   992,   993,   994,
  59931. -   997,   999,  1002,  1004,  1007,  1010,  1016,  1023,  1025,  1032,
  59932. -  1039,  1042,  1049,  1052,  1056,  1059,  1063,  1068,  1071,  1075,
  59933. -  1078,  1080,  1082,  1084,  1091,  1093,  1094,  1095,  1100,  1102,
  59934. -  1107,  1115,  1120,  1124,  1127,  1129,  1134,  1137,  1139,  1141,
  59935. -  1145,  1148,  1148,  1151,  1153,  1164,  1172,  1176,  1187,  1195,
  59936. -  1202,  1204,  1209,  1212,  1217,  1219,  1221,  1223,  1225,  1226,
  59937. -  1234,  1240,  1242,  1244,  1246,  1248,  1254,  1260,  1262,  1264,
  59938. -  1266,  1268,  1270,  1273,  1278,  1280,  1284,  1286,  1288,  1290,
  59939. -  1294,  1296,  1299,  1302,  1305,  1308,  1312,  1314,  1317,  1319,
  59940. -  1323,  1326,  1331,  1333,  1335,  1339,  1363,  1370,  1375,  1381,
  59941. -  1386,  1390,  1392,  1396,  1400,  1404,  1414,  1416,  1421,  1426,
  59942. -  1429,  1433,  1436,  1440,  1443,  1446,  1449,  1453,  1456,  1460,
  59943. -  1464,  1466,  1468,  1470,  1472,  1474,  1476,  1478,  1480,  1488,
  59944. -  1496,  1498,  1500,  1504,  1506,  1509,  1512,  1525,  1527,  1532,
  59945. -  1534,  1537,  1551,  1554,  1557,  1559,  1567,  1575,  1586,  1591,
  59946. -  1594,  1607,  1615,  1619,  1623,  1627,  1633,  1637,  1642,  1645,
  59947. -  1650,  1653,  1654,  1671,  1676,  1679,  1691,  1693,  1703,  1713,
  59948. -  1714,  1722,  1725,  1737,  1741,  1758,  1768,  1777,  1782,  1787,
  59949. -  1792,  1796,  1800,  1811,  1818,  1825,  1832,  1843,  1847,  1850,
  59950. -  1855,  1878,  1912,  1937,  1966,  1981,  1992,  1996,  2000,  2003,
  59951. -  2008,  2010,  2013,  2015,  2019,  2024,  2027,  2033,  2038,  2043,
  59952. -  2045,  2054,  2055,  2061,  2063,  2073,  2075,  2079,  2082,  2088,
  59953. -  2098,  2107,  2116,  2126,  2140,  2145,  2150,  2152,  2161,  2164,
  59954. -  2169,  2172,  2178,  2180,  2181,  2182,  2183,  2184,  2198,  2201,
  59955. -  2205,  2211,  2217,  2224,  2229,  2235,  2242,  2248,  2254,  2259,
  59956. -  2265,  2272,  2278,  2284,  2290,  2298,  2304,  2310,  2318,  2325,
  59957. -  2331,  2340,  2347,  2355,  2360,  2369,  2371,  2374,  2376,  2377,
  59958. -  2380,  2385,  2386,  2403,  2410,  2416,  2420,  2423,  2424,  2427,
  59959. -  2435,  2441,  2450,  2460,  2467,  2471,  2476,  2485,  2492,  2496,
  59960. -  2506,  2508,  2509,  2511,  2513,  2514,  2515,  2516,  2518,  2520,
  59961. -  2523,  2529,  2534,  2534,  2539,  2543,  2545,  2551,  2556,  2561,
  59962. -  2570,  2572,  2578,  2580,  2583,  2585,  2586,  2587,  2590,  2596,
  59963. -  2598,  2602,  2605,  2612,  2618,  2623,  2630,  2635,  2640,  2645,
  59964. -  2652,  2656,  2659,  2665,  2667,  2668,  2669,  2672,  2674,  2675,
  59965. -  2676,  2677,  2678,  2679,  2680,  2681,  2682,  2683,  2684,  2685,
  59966. -  2686,  2687,  2688,  2689,  2690,  2691,  2692,  2692,  2695,  2701,
  59967. -  2706,  2711,  2717,  2719,  2722,  2724,  2731,  2743,  2748,  2754,
  59968. -  2756,  2762,  2766,  2767,  2773,  2775,  2778,  2780,  2786,  2791,
  59969. -  2797,  2804,  2813
  59970. -};
  59971. -
  59972. -static const char * const yytname[] = {   "$","error","$illegal.","IDENTIFIER",
  59973. -"TYPENAME","SCSPEC","TYPESPEC","TYPE_QUAL","CONSTANT","STRING","ELLIPSIS","SIZEOF",
  59974. -"ENUM","STRUCT","UNION","IF","ELSE","WHILE","DO","FOR","SWITCH","CASE","DEFAULT",
  59975. -"BREAK","CONTINUE","RETURN","GOTO","ASM_KEYWORD","TYPEOF","ALIGNOF","ATTRIBUTE",
  59976. -"EXTENSION","LABEL","REALPART","IMAGPART","ASSIGN","'='","'?'","':'","OROR",
  59977. -"ANDAND","'|'","'^'","'&'","EQCOMPARE","ARITHCOMPARE","LSHIFT","RSHIFT","'+'",
  59978. -"'-'","'*'","'/'","'%'","UNARY","PLUSPLUS","MINUSMINUS","HYPERUNARY","POINTSAT",
  59979. -"'.'","'('","'['","INTERFACE","IMPLEMENTATION","END","SELECTOR","DEFS","ENCODE",
  59980. -"CLASSNAME","PUBLIC","PRIVATE","PROTECTED","PROTOCOL","OBJECTNAME","CLASS","ALIAS",
  59981. -"OBJC_STRING","')'","';'","'}'","'~'","'!'","','","'{'","']'","program","extdefs",
  59982. -"@1","@2","extdef","datadef","fndef","@3","@4","@5","@6","@7","@8","identifier",
  59983. -"unop","expr","exprlist","nonnull_exprlist","unary_expr","@9","cast_expr","@10",
  59984. -"expr_no_commas","primary","@11","string","objc_string","xdecls","lineno_datadecl",
  59985. -"datadecls","datadecl","lineno_decl","decls","setspecs","setattrs","decl","typed_declspecs",
  59986. -"reserved_declspecs","declmods","typed_typespecs","reserved_typespecquals","typespec",
  59987. -"typespecqual_reserved","initdecls","notype_initdecls","maybeasm","initdcl",
  59988. -"@12","notype_initdcl","@13","maybe_attribute","attributes","attribute","attribute_list",
  59989. -"attrib","any_word","init","@14","initlist_maybe_comma","initlist1","initelt",
  59990. -"@15","@16","@17","nested_function","@18","@19","notype_nested_function","@20",
  59991. -"@21","declarator","after_type_declarator","parm_declarator","notype_declarator",
  59992. -"structsp","@22","@23","@24","@25","maybecomma","maybecomma_warn","component_decl_list",
  59993. -"component_decl_list2","component_decl","components","component_declarator",
  59994. -"enumlist","enumerator","typename","absdcl","nonempty_type_quals","type_quals",
  59995. -"absdcl1","stmts","lineno_stmt_or_labels","xstmts","errstmt","pushlevel","maybe_label_decls",
  59996. -"label_decls","label_decl","compstmt_or_error","compstmt","simple_if","if_prefix",
  59997. -"do_stmt_start","@26","save_filename","save_lineno","lineno_labeled_stmt","lineno_stmt_or_label",
  59998. -"stmt_or_label","stmt","@27","@28","@29","@30","@31","@32","@33","all_iter_stmt",
  59999. -"all_iter_stmt_simple","@34","label","maybe_type_qual","xexpr","asm_operands",
  60000. -"nonnull_asm_operands","asm_operand","asm_clobbers","parmlist","@35","parmlist_1",
  60001. -"@36","parmlist_2","parms","parm","parmlist_or_identifiers","@37","parmlist_or_identifiers_1",
  60002. -"identifiers","identifiers_or_typenames","objcdef","identifier_list","classdecl",
  60003. -"aliasdecl","classdef","@38","@39","@40","@41","@42","@43","@44","@45","@46",
  60004. -"protocoldef","@47","protocolrefs","ivar_decl_list","visibility_spec","ivar_decls",
  60005. -"ivar_decl","ivars","ivar_declarator","methoddef","@48","@49","@50","@51","@52",
  60006. -"@53","methodprotolist","@54","methodprotolist2","@55","semi_or_error","methodproto",
  60007. -"@56","@57","@58","@59","methoddecl","optarglist","myxdecls","mydecls","mydecl",
  60008. -"myparms","myparm","optparmlist","@60","unaryselector","keywordselector","selector",
  60009. -"reservedwords","keyworddecl","messageargs","keywordarglist","keywordexpr","keywordarg",
  60010. -"receiver","objcmessageexpr","@61","@62","selectorarg","keywordnamelist","keywordname",
  60011. -"objcselectorexpr","objcprotocolexpr","objcencodeexpr",""
  60012. -};
  60013. -#endif
  60014. -
  60015. -static const short yyr1[] = {     0,
  60016. -    84,    84,    86,    85,    87,    85,    88,    88,    88,    88,
  60017. -    89,    89,    89,    89,    89,    89,    89,    89,    91,    92,
  60018. -    90,    90,    93,    94,    90,    90,    95,    96,    90,    90,
  60019. -    97,    97,    97,    97,    98,    98,    98,    98,    98,    98,
  60020. -    98,    99,   100,   100,   101,   101,   102,   102,   103,   102,
  60021. -   102,   102,   102,   102,   102,   102,   102,   102,   104,   104,
  60022. -   105,   104,   106,   106,   106,   106,   106,   106,   106,   106,
  60023. -   106,   106,   106,   106,   106,   106,   106,   106,   106,   106,
  60024. -   107,   107,   107,   107,   107,   108,   107,   107,   107,   107,
  60025. -   107,   107,   107,   107,   107,   107,   107,   107,   109,   109,
  60026. -   110,   110,   111,   111,   111,   112,   113,   113,   113,   113,
  60027. -   114,   114,   114,   114,   115,   116,   116,   116,   116,   117,
  60028. -   118,   119,   119,   119,   119,   119,   119,   120,   120,   121,
  60029. -   121,   121,   122,   122,   122,   122,   123,   123,   124,   124,
  60030. -   125,   125,   125,   125,   125,   125,   125,   126,   126,   126,
  60031. -   127,   127,   128,   128,   129,   129,   131,   130,   130,   133,
  60032. -   132,   132,   134,   134,   135,   135,   136,   137,   137,   138,
  60033. -   138,   138,   138,   138,   139,   139,   139,   139,   140,   141,
  60034. -   140,   140,   142,   142,   143,   143,   144,   145,   144,   144,
  60035. -   146,   144,   147,   144,   149,   150,   148,   152,   153,   151,
  60036. -   154,   154,   155,   155,   155,   155,   155,   155,   155,   155,
  60037. -   156,   156,   156,   156,   156,   156,   157,   157,   157,   157,
  60038. -   157,   157,   157,   159,   158,   158,   158,   160,   158,   158,
  60039. -   158,   161,   158,   162,   158,   158,   163,   163,   164,   164,
  60040. -   165,   165,   166,   166,   166,   166,   167,   167,   167,   167,
  60041. -   167,   168,   168,   169,   169,   169,   170,   170,   170,   171,
  60042. -   171,   172,   172,   173,   173,   174,   174,   175,   175,   176,
  60043. -   176,   176,   176,   176,   176,   176,   176,   176,   176,   177,
  60044. -   178,   178,   178,   179,   179,   180,   181,   182,   182,   183,
  60045. -   183,   184,   185,   185,   186,   186,   186,   186,   187,   187,
  60046. -   188,   190,   189,   191,   192,   193,   193,   194,   195,   195,
  60047. -   196,   196,   196,   197,   196,   196,   196,   198,   199,   196,
  60048. -   196,   196,   200,   201,   202,   196,   203,   196,   196,   196,
  60049. -   196,   196,   196,   196,   196,   196,   196,   196,   196,   204,
  60050. -   206,   205,   207,   207,   207,   207,   208,   208,   209,   209,
  60051. -   210,   210,   211,   211,   212,   213,   213,   215,   214,   216,
  60052. -   217,   216,   216,   218,   218,   218,   218,   219,   219,   220,
  60053. -   220,   220,   220,   220,   222,   221,   223,   223,   224,   224,
  60054. -   225,   225,   226,   226,   226,   226,   226,   226,   227,   227,
  60055. -   228,   229,   231,   232,   230,   233,   230,   234,   235,   230,
  60056. -   236,   230,   237,   230,   230,   238,   230,   230,   239,   230,
  60057. -   230,   241,   240,   242,   242,   243,   243,   244,   244,   244,
  60058. -   245,   245,   245,   246,   246,   246,   247,   247,   247,   248,
  60059. -   248,   248,   250,   251,   252,   249,   253,   254,   255,   249,
  60060. -   256,   257,   256,   258,   258,   258,   259,   258,   260,   260,
  60061. -   262,   263,   261,   264,   265,   261,   266,   266,   266,   266,
  60062. -   267,   267,   268,   268,   269,   269,   269,   269,   270,   270,
  60063. -   270,   271,   271,   272,   272,   272,   273,   273,   274,   273,
  60064. -   275,   276,   276,   277,   277,   277,   277,   278,   278,   278,
  60065. -   278,   278,   278,   278,   278,   278,   278,   278,   278,   278,
  60066. -   278,   278,   278,   278,   278,   278,   278,   278,   279,   279,
  60067. -   279,   279,   280,   280,   281,   281,   282,   283,   283,   284,
  60068. -   284,   286,   287,   285,   288,   288,   289,   289,   290,   290,
  60069. -   291,   292,   293
  60070. -};
  60071. -
  60072. -static const short yyr2[] = {     0,
  60073. -     0,     1,     0,     2,     0,     3,     1,     1,     1,     5,
  60074. -     3,     4,     4,     2,     2,     2,     2,     1,     0,     0,
  60075. -     7,     4,     0,     0,     7,     4,     0,     0,     6,     3,
  60076. -     1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
  60077. -     1,     1,     0,     1,     1,     3,     1,     2,     0,     3,
  60078. -     2,     2,     2,     4,     2,     4,     2,     2,     1,     4,
  60079. -     0,     7,     1,     3,     3,     3,     3,     3,     3,     3,
  60080. -     3,     3,     3,     3,     3,     3,     3,     5,     3,     3,
  60081. -     1,     1,     1,     3,     3,     0,     4,     4,     4,     3,
  60082. -     3,     2,     2,     1,     1,     1,     1,     1,     1,     2,
  60083. -     1,     2,     0,     1,     2,     3,     1,     1,     2,     2,
  60084. -     4,     4,     2,     2,     3,     1,     1,     2,     2,     0,
  60085. -     0,     4,     4,     3,     3,     2,     2,     2,     3,     0,
  60086. -     2,     2,     1,     1,     2,     2,     2,     3,     0,     2,
  60087. -     1,     1,     1,     2,     2,     4,     4,     1,     1,     1,
  60088. -     1,     3,     1,     3,     0,     4,     0,     6,     3,     0,
  60089. -     6,     3,     0,     1,     1,     2,     6,     1,     3,     0,
  60090. -     1,     4,     6,     4,     1,     1,     1,     1,     1,     0,
  60091. -     4,     1,     0,     2,     1,     3,     1,     0,     4,     1,
  60092. -     0,     4,     0,     5,     0,     0,     5,     0,     0,     5,
  60093. -     1,     1,     3,     3,     4,     3,     3,     3,     1,     1,
  60094. -     3,     4,     3,     3,     3,     1,     3,     3,     3,     4,
  60095. -     3,     3,     1,     0,     7,     5,     2,     0,     7,     5,
  60096. -     2,     0,     8,     0,     7,     2,     0,     1,     0,     1,
  60097. -     1,     2,     0,     3,     2,     4,     3,     1,     3,     1,
  60098. -     1,     1,     3,     4,     6,     5,     1,     3,     1,     1,
  60099. -     3,     2,     2,     0,     1,     1,     2,     0,     2,     3,
  60100. -     3,     2,     3,     4,     3,     2,     3,     2,     3,     1,
  60101. -     1,     2,     2,     0,     1,     2,     0,     0,     1,     1,
  60102. -     2,     3,     1,     2,     2,     6,     5,     5,     2,     2,
  60103. -     4,     0,     4,     0,     0,     3,     4,     3,     1,     1,
  60104. -     1,     1,     2,     0,     4,     1,     3,     0,     0,     7,
  60105. -     5,     2,     0,     0,     0,    12,     0,     6,     2,     2,
  60106. -     2,     3,     6,     8,    10,    12,     3,     4,     1,     1,
  60107. -     0,     6,     3,     5,     2,     2,     0,     1,     0,     1,
  60108. -     0,     1,     1,     3,     4,     1,     3,     0,     2,     2,
  60109. -     0,     4,     2,     0,     1,     1,     3,     1,     3,     4,
  60110. -     4,     4,     4,     4,     0,     2,     1,     2,     1,     3,
  60111. -     1,     3,     1,     1,     1,     1,     1,     1,     1,     3,
  60112. -     3,     4,     0,     0,    10,     0,     6,     0,     0,    12,
  60113. -     0,     8,     0,     6,     2,     0,     8,     4,     0,     9,
  60114. -     5,     0,     6,     0,     3,     3,     1,     1,     1,     1,
  60115. -     0,     3,     2,     3,     3,     1,     0,     1,     3,     1,
  60116. -     3,     2,     0,     0,     0,     7,     0,     0,     0,     7,
  60117. -     0,     0,     2,     1,     1,     2,     0,     3,     1,     1,
  60118. -     0,     0,     5,     0,     0,     5,     4,     1,     5,     2,
  60119. -     0,     2,     0,     1,     1,     1,     2,     2,     4,     2,
  60120. -     2,     1,     3,     2,     2,     2,     0,     2,     0,     3,
  60121. -     1,     1,     2,     1,     1,     1,     1,     1,     1,     1,
  60122. -     1,     1,     1,     1,     1,     1,     1,     1,     1,     1,
  60123. -     1,     1,     1,     1,     1,     1,     1,     1,     6,     3,
  60124. -     5,     2,     1,     1,     1,     2,     1,     3,     2,     1,
  60125. -     1,     0,     0,     6,     1,     1,     1,     2,     2,     1,
  60126. -     4,     4,     4
  60127. -};
  60128. -
  60129. -static const short yydefact[] = {     3,
  60130. -     5,     0,     0,     0,   143,   134,   141,   133,     0,     0,
  60131. -     0,     0,     0,   433,   437,     0,     0,   388,   414,     0,
  60132. -   414,     0,     0,    18,     4,     8,     7,     0,   120,   120,
  60133. -   130,   142,     9,   384,   385,   383,   386,   387,     6,    16,
  60134. -    17,    31,    32,    34,    33,   234,   236,   243,   227,   243,
  60135. -   231,     0,     0,     0,     0,   414,   405,     0,   144,   414,
  60136. -   145,   389,     0,     0,   223,     0,   268,     0,     0,   153,
  60137. -   121,   165,     0,    15,     0,   136,   135,    14,     0,   130,
  60138. -   128,     0,   232,     0,     0,     0,   224,     0,   228,    81,
  60139. -    82,    99,     0,     0,    49,     0,     0,     0,    35,    37,
  60140. -    36,     0,    38,    39,     0,   522,     0,     0,     0,   101,
  60141. -    40,    41,     0,     0,    42,    59,    63,    45,    47,    83,
  60142. -    98,    94,    95,    96,    97,   266,     0,   264,   139,     0,
  60143. -   264,   484,   485,   507,   508,   504,   488,   489,   490,   491,
  60144. -   492,   493,   494,   495,   496,   497,   498,   499,   500,   501,
  60145. -   502,   503,   505,   506,     0,     0,   486,   434,   458,   477,
  60146. -   481,   487,   482,   438,     0,     0,   396,     0,     0,   403,
  60147. -     0,   412,   391,     0,     0,     0,     0,     0,    11,     0,
  60148. -     0,   166,    30,     0,   375,     0,     0,   163,   209,   268,
  60149. -     0,   210,     0,   151,   121,     0,   201,   202,     0,     0,
  60150. -   129,   132,   148,   149,   131,   150,   259,   260,   239,   257,
  60151. -     0,     0,   163,   251,   245,   120,   242,   120,   243,   163,
  60152. -   243,     0,    53,     0,    55,     0,    57,    58,    52,    48,
  60153. -     0,     0,     0,     0,     0,     0,     0,     0,    51,     0,
  60154. -     0,     0,     0,   349,     0,     0,     0,     0,     0,     0,
  60155. -     0,     0,     0,     0,     0,     0,     0,     0,    92,    93,
  60156. -     0,     0,    43,     0,   100,   102,   146,   268,   358,     0,
  60157. -   121,   262,   265,   137,   147,   267,   139,   263,     0,   512,
  60158. -     0,   461,   479,   460,     0,   483,     0,   461,   414,     0,
  60159. -   393,   442,   408,     0,   421,   415,   442,   390,   392,   170,
  60160. -   269,   219,   218,   154,   155,   222,     0,   217,     0,   221,
  60161. -     0,     0,    28,     0,   304,   108,   305,   162,   164,     0,
  60162. -     0,    13,     0,     0,    22,     0,   163,   375,     0,    12,
  60163. -    26,     0,     0,   240,     0,   239,     0,   226,   304,   244,
  60164. -   304,     0,   230,     0,     0,     0,    50,    85,    84,   287,
  60165. -     0,     0,   521,   520,   523,   530,   525,     0,   526,   527,
  60166. -     0,     0,    10,    46,    80,    79,   350,     0,    77,    76,
  60167. -    74,    75,    73,    72,    71,    69,    70,    64,    65,    66,
  60168. -    67,    68,    91,    90,     0,    44,     0,   272,     0,   276,
  60169. -     0,   278,     0,     0,   358,     0,   140,   138,     0,     0,
  60170. -     0,   435,   478,   364,     0,   510,   439,   401,   414,   421,
  60171. -     0,     0,   406,   411,     0,     0,     0,   176,   177,   178,
  60172. -   175,     0,   168,   171,     0,     0,   379,   365,   120,   120,
  60173. -   377,     0,   366,   368,   376,     0,   220,   286,     0,   110,
  60174. -   105,   109,     0,   160,   207,   203,   152,   208,    20,   159,
  60175. -   204,   206,     0,    24,   261,   258,   163,     0,   246,   247,
  60176. -   252,   305,   249,   163,   163,    54,    56,   295,   288,    87,
  60177. -    61,    60,     0,   529,   531,     0,   528,   533,   532,     0,
  60178. -    88,    89,   271,   270,   359,   277,   279,   273,   275,     0,
  60179. -     0,   457,   477,   120,     0,   466,   462,   464,     0,     0,
  60180. -   480,   366,     0,     0,   398,   442,   409,     0,   397,   451,
  60181. -   454,   445,     0,   120,   120,   447,   444,   421,   420,   418,
  60182. -   419,   404,   421,   426,   423,   120,   120,     0,   413,     0,
  60183. -   170,    43,   156,   363,   264,   264,   360,   361,     0,   378,
  60184. -     0,     0,    29,   293,   106,   120,   120,     0,     0,   157,
  60185. -   205,     0,   235,   163,   304,     0,   225,   229,     0,     0,
  60186. -   289,   290,     0,     0,   513,     0,   514,   515,    78,   274,
  60187. -   511,   459,   470,   264,   471,   467,   468,   436,     0,   440,
  60188. -   421,     0,   442,   394,     0,     0,   155,     0,     0,     0,
  60189. -   446,     0,     0,   427,   427,   422,   167,   169,    81,     0,
  60190. -   216,   268,   358,   121,   163,   163,   163,   268,   121,   163,
  60191. -   163,     0,   367,   369,   380,   294,   113,     0,   114,     0,
  60192. -   182,   180,   179,   161,    21,     0,    25,   233,   253,     0,
  60193. -   163,   381,     0,     0,     0,   304,     0,     0,   117,   305,
  60194. -   281,   291,   190,    81,     0,   188,     0,   187,     0,   237,
  60195. -   185,   517,   519,     0,   524,     0,   516,   163,   163,   163,
  60196. -     0,   472,   509,     0,   402,     0,   442,   452,   455,   448,
  60197. -   407,     0,   430,   424,   428,   425,   172,     0,   174,   272,
  60198. -     0,   375,     0,   370,   371,   372,   272,     0,   373,   374,
  60199. -   362,     0,     0,     0,   158,   163,     0,   254,   292,     0,
  60200. -   297,   119,   118,   285,     0,   298,   283,   305,   282,     0,
  60201. -     0,     0,   191,    62,     0,   184,   518,   474,   475,   476,
  60202. -   469,   264,   399,   410,     0,     0,     0,   432,     0,     0,
  60203. -     0,   214,   215,   211,   213,     0,   111,   112,     0,   256,
  60204. -   163,   382,   296,     0,   143,     0,   318,   302,     0,     0,
  60205. -     0,     0,     0,     0,     0,     0,   347,   414,   414,   339,
  60206. -     0,     0,   115,   120,   120,   311,   316,     0,     0,   308,
  60207. -   309,   312,   340,   310,   193,     0,     0,   186,   473,   442,
  60208. -   395,   450,   449,   453,   456,   431,   429,   173,   212,   181,
  60209. -   255,     0,     0,   304,   349,     0,     0,   345,   329,   330,
  60210. -   331,     0,     0,     0,   348,     0,   346,   313,   126,     0,
  60211. -   127,     0,     0,   300,   305,   299,   322,     0,     0,   189,
  60212. -   192,     0,     0,     0,     0,    47,     0,     0,     0,   343,
  60213. -   332,     0,   337,     0,     0,   124,   195,     0,   125,   198,
  60214. -   317,   304,     0,     0,   194,   400,   301,     0,   303,   341,
  60215. -   323,   327,     0,   338,     0,   122,     0,   123,     0,   315,
  60216. -   306,   304,     0,   319,   304,   349,   304,   344,   351,     0,
  60217. -   196,   199,   307,   321,   304,   342,     0,   328,     0,     0,
  60218. -   352,   353,   333,     0,     0,   320,   324,     0,   351,     0,
  60219. -     0,   197,   200,   349,     0,     0,   334,   354,     0,   355,
  60220. -     0,     0,   325,   356,     0,   335,   304,     0,     0,   326,
  60221. -   336,   357,     0,     0,     0
  60222. -};
  60223. -
  60224. -static const short yydefgoto[] = {   913,
  60225. -     1,     2,     3,    25,    26,    27,   326,   549,   332,   552,
  60226. -   187,   439,   647,   113,   367,   385,   115,   116,   226,   117,
  60227. -   563,   118,   119,   233,   120,   121,   313,   314,   315,   545,
  60228. -   635,   636,    28,   181,   763,   429,    81,   430,   128,   274,
  60229. -    31,   205,   193,    69,   188,   194,   626,    70,   548,   318,
  60230. -   319,    72,   422,   423,   424,   624,   694,   649,   650,   651,
  60231. -   712,   777,   819,   836,   857,   884,   839,   859,   885,   305,
  60232. -   197,   658,   198,    32,   219,   221,   211,    82,   716,   335,
  60233. -    85,    86,   217,   460,   461,   209,   210,   130,   660,   131,
  60234. -   177,   273,   637,   638,   705,   316,   469,   560,   561,   562,
  60235. -   543,   544,   767,   768,   769,   794,   815,   443,   816,   641,
  60236. -   770,   771,   842,   793,   875,   866,   894,   907,   867,   772,
  60237. -   773,   865,   774,   806,   368,   880,   881,   882,   905,   390,
  60238. -   391,   431,   612,   432,   433,   434,   308,   309,   435,   436,
  60239. -   633,    33,    63,    34,    35,    36,   410,   667,   292,   581,
  60240. -   780,   506,   295,   518,   583,    37,   297,    59,   415,   523,
  60241. -   416,   528,   674,   675,    38,    54,   282,   500,    55,   288,
  60242. -   504,   411,   412,   516,   590,   784,   517,   585,   726,   586,
  60243. -   727,   158,   402,   497,   498,   499,   661,   662,   284,   404,
  60244. -   159,   160,   161,   162,   163,   566,   567,   653,   568,   355,
  60245. -   122,   235,   473,   358,   359,   360,   123,   124,   125
  60246. -};
  60247. -
  60248. -static const short yypact[] = {    94,
  60249. -    97,  2746,  2746,   129,-32768,-32768,-32768,-32768,    76,   213,
  60250. -   226,    57,    86,-32768,-32768,   327,   327,-32768,   102,   327,
  60251. -   102,   327,   327,-32768,-32768,-32768,-32768,    71,    27,  2946,
  60252. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  60253. --32768,-32768,-32768,-32768,-32768,-32768,    70,   104,   115,   104,
  60254. -   118,  2455,  2293,  3046,  3046,    61,   186,   327,-32768,   102,
  60255. --32768,-32768,   173,   327,-32768,   156,-32768,    71,   222,-32768,
  60256. -   195,-32768,   757,-32768,   351,-32768,-32768,-32768,    71,-32768,
  60257. -   813,   107,-32768,   176,   165,   235,-32768,   179,-32768,-32768,
  60258. --32768,-32768,  2509,  2563,-32768,  2455,  2455,   327,-32768,-32768,
  60259. --32768,  2455,-32768,-32768,  1255,-32768,   192,   201,   211,-32768,
  60260. --32768,-32768,  2455,   203,   224,-32768,-32768,  3369,   789,   318,
  60261. -   240,-32768,-32768,-32768,-32768,-32768,   270,   214,-32768,   277,
  60262. -  1720,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  60263. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  60264. --32768,-32768,-32768,-32768,   199,  3255,-32768,-32768,-32768,  2265,
  60265. -   340,-32768,-32768,-32768,   327,   327,   303,   327,   327,-32768,
  60266. -    45,-32768,-32768,   327,   311,   334,   421,   280,-32768,   351,
  60267. -    71,-32768,-32768,   337,-32768,  1734,   623,   195,-32768,-32768,
  60268. -   351,-32768,   268,-32768,   195,  1658,   316,   395,   331,  1579,
  60269. -   813,-32768,-32768,-32768,-32768,-32768,-32768,   362,   325,-32768,
  60270. -   107,   342,   195,-32768,-32768,   401,   339,  2929,   104,   195,
  60271. -   104,  1255,-32768,  1255,-32768,  2455,-32768,-32768,-32768,-32768,
  60272. -   343,   353,   370,   391,  2347,  3108,  3255,   327,-32768,   399,
  60273. -  2455,  2455,  2455,  2455,  2455,  2455,  2455,  2455,  2455,  2455,
  60274. -  2455,  2455,  2455,  2455,  2455,  2455,  2455,  2455,-32768,-32768,
  60275. -   327,   327,  2455,  2455,-32768,-32768,-32768,-32768,   214,  1793,
  60276. -   195,-32768,   443,   718,-32768,-32768,-32768,-32768,  3255,-32768,
  60277. -   416,   412,   485,-32768,   340,-32768,   333,   412,   102,   423,
  60278. --32768,   442,   428,   438,-32768,-32768,   442,-32768,-32768,   319,
  60279. --32768,   395,-32768,-32768,   493,   395,   519,-32768,  2899,-32768,
  60280. -   450,   463,-32768,  1677,    68,-32768,-32768,   508,   195,   458,
  60281. -   358,-32768,   351,   351,-32768,   623,   195,-32768,  1852,-32768,
  60282. --32768,   623,  2455,   327,   457,   325,   474,-32768,-32768,-32768,
  60283. --32768,   489,-32768,   494,   495,   498,-32768,-32768,-32768,   497,
  60284. -   501,  2185,-32768,-32768,-32768,-32768,   549,   510,  3108,-32768,
  60285. -   517,   525,-32768,  3369,  3369,  3369,-32768,   557,  1230,  1386,
  60286. -  1465,  1666,  2264,  1706,   753,   838,   838,   554,   554,-32768,
  60287. --32768,-32768,-32768,-32768,   533,   224,   530,   548,   372,-32768,
  60288. -  2918,-32768,   534,   214,-32768,  1911,-32768,   718,   542,  3136,
  60289. -   708,-32768,-32768,  3199,  3255,-32768,-32768,   541,   102,-32768,
  60290. -   563,  2821,-32768,-32768,   273,  2694,   569,-32768,-32768,-32768,
  60291. --32768,    22,-32768,   561,    59,   558,-32768,-32768,-32768,  3227,
  60292. --32768,   566,   359,-32768,-32768,   128,-32768,-32768,    85,-32768,
  60293. --32768,-32768,  3244,-32768,   316,-32768,-32768,   316,-32768,   589,
  60294. --32768,-32768,   555,-32768,  3369,-32768,   195,   570,-32768,   568,
  60295. --32768,-32768,   568,   195,   195,-32768,-32768,-32768,   620,-32768,
  60296. --32768,-32768,  3172,-32768,-32768,   549,-32768,-32768,-32768,  2455,
  60297. --32768,-32768,   443,-32768,-32768,-32768,   443,-32768,-32768,   567,
  60298. -   327,-32768,  2265,   576,  2974,-32768,-32768,  3244,  1694,    85,
  60299. --32768,   575,   583,    85,-32768,   442,-32768,   511,-32768,-32768,
  60300. --32768,-32768,    71,    27,  2946,   285,-32768,-32768,-32768,-32768,
  60301. --32768,-32768,-32768,-32768,-32768,-32768,  3272,   588,-32768,   587,
  60302. -   319,  2617,-32768,-32768,   562,   237,-32768,-32768,  3210,-32768,
  60303. -   663,   370,-32768,-32768,-32768,   592,  3015,  1570,    85,-32768,
  60304. --32768,    85,-32768,   195,-32768,   538,-32768,-32768,   327,   935,
  60305. -   620,-32768,  1335,  2455,   635,   595,  3172,-32768,  1308,-32768,
  60306. --32768,-32768,-32768,   562,-32768,-32768,-32768,-32768,   327,-32768,
  60307. --32768,   619,   442,-32768,  3046,  3046,    69,   351,    71,  2849,
  60308. --32768,   602,  2711,   651,   651,-32768,-32768,-32768,   202,   609,
  60309. --32768,-32768,   237,   195,    58,   232,   195,-32768,   195,   232,
  60310. -   195,  2918,-32768,-32768,-32768,-32768,-32768,   351,-32768,    71,
  60311. --32768,-32768,  3369,-32768,-32768,  1570,-32768,-32768,-32768,  2455,
  60312. -   106,-32768,   365,   470,   851,   613,   615,  1015,-32768,-32768,
  60313. --32768,-32768,-32768,   659,   327,-32768,   660,  3369,   621,   625,
  60314. --32768,   224,-32768,  2455,-32768,   635,-32768,    58,   232,   195,
  60315. -   376,-32768,-32768,   618,-32768,   637,   442,-32768,-32768,-32768,
  60316. --32768,  2455,   669,   627,-32768,   627,-32768,  2455,-32768,   791,
  60317. -   562,-32768,  1970,-32768,-32768,-32768,    82,   237,-32768,-32768,
  60318. --32768,   389,   392,  1335,-32768,  3333,  2455,-32768,-32768,   327,
  60319. --32768,-32768,-32768,-32768,   633,-32768,-32768,-32768,-32768,  2051,
  60320. -   680,  1335,-32768,-32768,  1415,-32768,-32768,-32768,-32768,-32768,
  60321. --32768,   562,-32768,-32768,   664,    56,    56,  3369,  2455,   651,
  60322. -   233,   499,   499,-32768,-32768,   645,-32768,-32768,   655,-32768,
  60323. -  3333,-32768,-32768,  2131,   691,   675,-32768,-32768,   682,   684,
  60324. -  2455,   709,   671,   672,  2401,   234,   746,    62,   153,-32768,
  60325. -   716,   678,-32768,   683,  3026,-32768,   743,  1095,    64,-32768,
  60326. --32768,-32768,-32768,-32768,-32768,   687,  1495,-32768,-32768,   442,
  60327. --32768,-32768,-32768,-32768,-32768,  3369,-32768,-32768,-32768,-32768,
  60328. --32768,  2455,   714,-32768,  2455,  2455,  3310,-32768,-32768,-32768,
  60329. --32768,   690,  2455,   699,-32768,   719,-32768,-32768,-32768,   351,
  60330. --32768,    71,  1175,-32768,-32768,-32768,-32768,  2455,  1495,-32768,
  60331. --32768,   705,   701,  2455,   762,   586,   704,   707,  2455,-32768,
  60332. --32768,   712,-32768,  2455,   410,-32768,   420,   413,-32768,   944,
  60333. --32768,-32768,  2131,   710,-32768,-32768,-32768,   720,-32768,-32768,
  60334. --32768,-32768,  3351,-32768,    43,-32768,   623,-32768,   623,-32768,
  60335. --32768,-32768,   730,-32768,-32768,  2455,-32768,-32768,   788,   732,
  60336. --32768,-32768,-32768,-32768,-32768,-32768,   734,-32768,   755,    46,
  60337. -   731,-32768,-32768,   370,   370,-32768,-32768,  2455,   788,   738,
  60338. -   788,-32768,-32768,  2455,   747,    49,-32768,-32768,   754,-32768,
  60339. -   519,   745,-32768,   318,   306,-32768,-32768,   756,   519,-32768,
  60340. --32768,   318,   832,   835,-32768
  60341. -};
  60342. -
  60343. -static const short yypgoto[] = {-32768,
  60344. --32768,-32768,-32768,   837,  -367,-32768,-32768,-32768,-32768,-32768,
  60345. --32768,-32768,    -6,-32768,   -52,   310,  -243,   468,-32768,   -41,
  60346. --32768,   116,    66,-32768,  -298,-32768,  -314,   577,-32768,-32768,
  60347. -   217,-32768,    -8,  -166,-32768,    25,   801,    29,   -56,   606,
  60348. -     9,  -220,  -584,   -60,  -190,  -139,-32768,-32768,-32768,  -147,
  60349. -    -4,   -58,-32768,   364,-32768,   271,-32768,  -603,-32768,  -638,
  60350. --32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,   -73,
  60351. -  -131,  -486,   -20,   -46,-32768,-32768,-32768,-32768,-32768,   560,
  60352. -     1,-32768,-32768,   571,   347,   692,   564,    -3,   -91,   -36,
  60353. -  -175,  -206,   272,-32768,-32768,  -288,-32768,-32768,-32768,   346,
  60354. -  -214,  -210,-32768,-32768,-32768,-32768,  -140,  -426,  -711,   266,
  60355. --32768,    73,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  60356. --32768,-32768,    77,-32768,  -728,    20,-32768,    23,-32768,   518,
  60357. --32768,  -353,-32768,   515,   520,   382,  -303,-32768,-32768,-32768,
  60358. --32768,-32768,   867,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
  60359. --32768,-32768,-32768,-32768,-32768,-32768,-32768,   -14,  -328,-32768,
  60360. -   404,-32768,   356,   204,-32768,-32768,-32768,-32768,-32768,-32768,
  60361. --32768,  -254,-32768,-32768,-32768,   205,   449,-32768,-32768,-32768,
  60362. --32768,   -22,   649,-32768,-32768,   469,-32768,   248,   479,-32768,
  60363. -   573,   579,   -90,-32768,  -116,-32768,-32768,   322,   414,-32768,
  60364. --32768,-32768,-32768,-32768,-32768,   628,-32768,-32768,-32768
  60365. -};
  60366. -
  60367. -
  60368. -#define    YYLAST        3421
  60369. -
  60370. -
  60371. -static const short yytable[] = {   114,
  60372. -   127,   196,    47,    49,    51,   327,    61,    73,   425,    56,
  60373. -    57,   449,   182,    60,   320,    62,    64,   454,   199,   386,
  60374. -    75,    79,   351,    71,   451,   440,    29,    29,   324,   216,
  60375. -    30,    30,   164,   692,   206,   556,   272,   485,    80,   278,
  60376. -   304,   167,   417,   286,   512,   172,   317,   178,   605,   218,
  60377. -    88,    62,   232,   397,   227,   228,   782,   175,   200,   321,
  60378. -   230,   129,   389,    71,   817,   338,   827,   265,  -104,   285,
  60379. -   195,   239,   343,    65,    71,   208,   778,   441,    42,    43,
  60380. -   869,   508,   825,   889,    65,   542,   901,    66,   301,   296,
  60381. -   739,   229,   388,    -1,   129,   184,    -2,   530,   165,   -34,
  60382. -    66,   234,   531,    74,   394,    58,    58,   207,   776,    42,
  60383. -    43,    66,   496,   129,   327,    52,   682,   683,   870,   166,
  60384. -    67,   890,   818,   271,   902,   174,   271,   185,   186,    68,
  60385. -   860,   608,   783,   311,   533,    66,   182,   877,   821,   277,
  60386. -   603,   270,    44,   697,    53,   357,    58,    45,   280,  -104,
  60387. -   873,    83,   281,   876,   206,   878,   302,    46,   289,   290,
  60388. -   306,   293,   294,   886,   129,   899,   350,   298,    84,   232,
  60389. -   178,   232,    71,    44,   317,   195,    71,   397,    45,   450,
  60390. -   845,   483,   354,   447,   347,   317,   195,   487,   445,   592,
  60391. -   -33,   317,   448,   732,   733,   910,    87,    58,   462,    89,
  60392. -   462,    42,    43,   540,   208,    40,    41,   339,   541,   341,
  60393. -   577,   387,   182,   710,   176,    42,    43,   393,   345,   342,
  60394. -   346,   344,   670,   168,    66,   835,   277,   206,    42,    43,
  60395. -   129,   362,   129,   361,   212,   214,    42,    43,     5,    65,
  60396. -     7,   126,   213,    66,   169,   129,     9,    10,    11,   173,
  60397. -   236,   582,   664,   174,   383,   384,   220,   279,   691,   237,
  60398. -   182,    66,    13,   268,   271,    44,    66,   170,   476,   238,
  60399. -    45,   639,   269,   270,   408,   399,   453,   677,   240,    44,
  60400. -   406,   744,   678,   803,    45,   578,   608,   129,   386,   580,
  60401. -   185,   186,    44,   421,    48,   603,   270,    45,   179,   302,
  60402. -    44,    19,   180,   306,   241,    45,    21,    50,   788,   553,
  60403. -   472,   215,  -241,   241,   266,   195,   557,   558,   195,   195,
  60404. -   652,    42,    43,   418,   419,   420,   265,   208,   666,    42,
  60405. -    43,   616,   510,   511,   625,    42,    43,   627,   185,   186,
  60406. -   519,   520,   521,   490,   322,   267,   702,  -443,   323,   707,
  60407. -   522,   206,   275,    65,   189,   303,   364,   365,   366,   526,
  60408. -   369,   370,   371,   372,   373,   374,   375,   376,   377,   378,
  60409. -   379,   380,   381,   382,   328,   329,   286,   287,   734,   527,
  60410. -    66,   908,   565,   271,   291,    44,   909,   299,   843,   271,
  60411. -    45,   405,   300,    44,   507,   307,   389,   333,    45,    44,
  60412. -   190,   503,   285,   513,    45,   334,   628,   330,   337,   191,
  60413. -   652,   180,   725,   129,   462,   340,   328,   329,   348,   640,
  60414. -   535,   536,   192,    65,   129,   494,   680,   301,   349,   495,
  60415. -   395,   396,   687,   446,   731,   538,   514,   681,    80,   539,
  60416. -   515,   699,   688,   607,   611,   700,   184,   484,   455,  -155,
  60417. -    66,   350,   721,   185,   186,  -155,   722,   684,   685,   686,
  60418. -    65,   189,   689,   690,   301,   737,   352,   546,   738,   323,
  60419. -    67,   547,   180,   483,   487,   363,   656,  -248,  -248,    68,
  60420. -   483,   487,   631,   698,   571,   574,   856,    66,   401,   858,
  60421. -   323,   400,   587,   180,   403,   640,  -155,   708,   409,   766,
  60422. -  -155,   395,   396,    80,  -441,   588,   589,   190,    71,   413,
  60423. -   718,   719,   720,   414,   606,   610,   191,   594,   595,   184,
  60424. -   673,   673,   494,    80,   421,   822,   495,    92,   199,   192,
  60425. -   604,   609,   437,   766,   457,   277,   526,   618,   620,   438,
  60426. -    65,   189,   871,   444,   872,   182,   438,   701,   740,   459,
  60427. -   182,   195,   632,   659,   301,    80,   527,   682,   683,   693,
  60428. -   223,   225,   668,   669,    65,   601,   464,    66,   587,   604,
  60429. -   466,   465,   663,   467,   468,   630,   470,    66,   519,   520,
  60430. -   521,   513,   178,   195,    71,   475,   474,   190,   584,   195,
  60431. -   195,    66,   478,   791,   480,   569,   191,   268,   609,   587,
  60432. -   479,   129,   904,   256,   257,   258,   269,   270,   481,   192,
  60433. -   912,   602,   482,   195,   514,    71,   486,   491,   515,   532,
  60434. -   603,   270,   505,   312,   550,   509,  -304,  -304,  -304,  -304,
  60435. -   736,   529,   766,   534,  -304,  -304,  -304,   551,   711,   259,
  60436. -   260,   537,   261,   262,   263,   264,   327,   554,   555,   570,
  60437. -  -304,   559,   573,    65,   189,   539,   673,   762,   579,   302,
  60438. -   306,   850,   597,   623,   596,   615,   302,   306,   617,   519,
  60439. -   520,   521,   654,   892,   893,   604,   604,   655,   648,   671,
  60440. -    66,   665,   609,   609,   679,   519,   520,   521,   672,  -304,
  60441. -  -284,   762,   706,   742,  -304,   723,   -31,   713,   714,   724,
  60442. -   190,   659,   802,   761,  -103,   715,   729,   730,   312,   191,
  60443. -   743,     5,     6,     7,     8,   775,   317,   604,   317,     9,
  60444. -    10,    11,   192,   203,   204,   195,   781,   789,   -32,     9,
  60445. -    10,    11,   790,   792,   764,    13,   837,   761,   765,   823,
  60446. -   795,   623,   796,   828,    61,   696,   798,   799,   800,   804,
  60447. -   832,   838,   805,   807,   808,   810,   812,   183,   813,   809,
  60448. -   -27,   -27,   -27,   -27,   820,   844,   831,   846,   -27,   -27,
  60449. -   -27,   848,   824,    80,    19,   833,   847,   834,   849,    21,
  60450. -   851,   855,   852,   184,   -27,   863,  -155,   728,   854,  -463,
  60451. -   762,   840,  -155,    65,   601,   864,   879,   301,   252,   253,
  60452. -   254,   255,   256,   257,   258,   195,   874,    71,   883,   648,
  60453. -   887,   891,   741,   888,   897,   185,   186,   202,   203,   204,
  60454. -    66,   906,   900,   -27,     9,    10,    11,   648,   -27,   903,
  60455. -   648,   914,   911,  -155,   915,   895,   761,  -155,   -27,    39,
  60456. -   602,   600,   259,   260,   786,   261,   262,   263,   264,   603,
  60457. -   270,   312,   703,  -116,  -116,  -116,  -116,  -116,  -116,  -116,
  60458. -   826,  -116,  -116,  -116,  -116,  -116,   797,  -116,  -116,  -116,
  60459. -  -116,  -116,  -116,  -116,  -116,  -116,  -116,  -116,  -116,  -116,
  60460. -   201,  -116,   398,  -116,  -116,   254,   255,   256,   257,   258,
  60461. -  -116,   442,   648,  -116,   598,   458,   695,   456,  -116,  -116,
  60462. -  -116,   629,   336,   709,  -116,  -116,   642,   704,   896,  -116,
  60463. -  -116,   463,   488,   898,  -116,   861,  -116,  -116,   501,   862,
  60464. -   614,  -116,  -116,   502,   171,  -116,   593,  -116,  -116,  -116,
  60465. -  -116,   785,  -116,   787,   648,   634,   407,  -304,  -304,  -304,
  60466. -  -304,  -304,  -304,  -304,   853,  -304,  -304,  -304,  -304,  -304,
  60467. -   676,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,
  60468. -  -304,  -304,  -304,  -304,   591,  -304,   576,  -304,  -304,   779,
  60469. -   184,   572,   492,  -155,  -304,   717,     0,  -304,   493,  -155,
  60470. -   657,     0,  -304,  -304,  -304,     0,   477,     0,  -304,  -304,
  60471. -     0,     0,     0,  -304,  -304,     0,     0,     0,  -304,     0,
  60472. -  -304,  -304,   185,   186,     0,  -304,  -304,     0,     0,  -304,
  60473. -     0,  -304,     0,  -304,  -304,   312,  -304,  -304,  -304,     0,
  60474. -  -155,     0,  -304,  -304,  -155,  -304,     0,     0,     0,  -304,
  60475. -     0,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,
  60476. -  -304,  -304,     0,  -304,     0,  -304,     0,  -304,  -304,     0,
  60477. -     0,     0,     0,     0,  -304,     0,     0,  -304,     0,     0,
  60478. -     0,     0,  -304,  -304,  -304,     0,     0,     0,  -304,  -304,
  60479. -     0,     0,     0,  -304,  -304,     0,     0,     0,  -304,     0,
  60480. -  -304,  -304,     0,     0,     0,  -304,  -304,     0,     0,  -304,
  60481. -     0,  -304,  -280,  -304,  -304,   814,  -304,  -304,  -304,     0,
  60482. -     0,     0,  -304,  -304,     0,  -304,     0,     0,     0,  -304,
  60483. -     0,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,  -304,
  60484. -  -304,  -304,     0,  -304,     0,  -304,     0,  -304,  -304,     0,
  60485. -     0,     0,     0,     0,  -304,     0,     0,  -304,     0,     0,
  60486. -     0,     0,  -304,  -304,  -304,     0,     0,     0,  -304,  -304,
  60487. -     0,     0,     0,  -304,  -304,     0,     0,     0,  -304,     0,
  60488. -  -304,  -304,     0,     0,     0,  -304,  -304,     0,     0,  -304,
  60489. -     0,  -304,     0,  -304,  -304,   841,  -304,  -314,  -314,     0,
  60490. -     0,     0,  -314,  -314,     0,  -314,     0,     0,     0,  -314,
  60491. -     0,  -314,  -314,  -314,  -314,  -314,  -314,  -314,  -314,  -314,
  60492. -  -314,  -314,     0,  -314,     0,  -314,     0,  -314,  -314,     0,
  60493. -     0,     0,     0,     0,  -314,     0,     0,  -314,     0,     0,
  60494. -     0,     0,  -314,  -314,  -314,     0,     0,     0,  -314,  -314,
  60495. -     0,     0,     0,  -314,  -314,     0,     0,     0,  -314,     0,
  60496. -  -314,  -314,     0,     0,     0,  -314,  -314,     0,     0,  -314,
  60497. -     0,  -314,     0,  -314,  -314,   231,  -314,    90,     5,     0,
  60498. -     7,   126,    91,    92,     0,    93,     9,    10,    11,   246,
  60499. -   247,   248,   249,   250,   251,   252,   253,   254,   255,   256,
  60500. -   257,   258,    13,    94,     0,    95,     0,    96,    97,     0,
  60501. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60502. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60503. -     0,     0,     0,   105,   106,     0,     0,     0,   107,     0,
  60504. -   108,    19,     0,     0,     0,   109,    21,     0,     0,   110,
  60505. -     0,     0,     0,   111,   112,   643,   -86,   644,    43,     0,
  60506. -     0,     0,    91,    92,   244,    93,   245,   246,   247,   248,
  60507. -   249,   250,   251,   252,   253,   254,   255,   256,   257,   258,
  60508. -     0,     0,     0,    94,     0,    95,     0,    96,    97,     0,
  60509. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60510. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60511. -     0,     0,   645,   105,   106,     0,     0,     0,   107,     0,
  60512. -   108,    44,     0,     0,     0,   109,    45,     0,     0,   110,
  60513. -     0,     0,  -183,   111,   112,   643,   646,   644,    43,     0,
  60514. -     0,     0,    91,    92,     0,    93,   247,   248,   249,   250,
  60515. -   251,   252,   253,   254,   255,   256,   257,   258,     0,     0,
  60516. -     0,     0,     0,    94,     0,    95,     0,    96,    97,     0,
  60517. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60518. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60519. -     0,     0,   645,   105,   106,     0,     0,     0,   107,     0,
  60520. -   108,    44,     0,     0,     0,   109,    45,     0,     0,   110,
  60521. -     0,     0,  -238,   111,   112,   643,   646,   644,    43,     0,
  60522. -     0,     0,    91,    92,     0,    93,   248,   249,   250,   251,
  60523. -   252,   253,   254,   255,   256,   257,   258,     0,     0,     0,
  60524. -     0,     0,     0,    94,     0,    95,     0,    96,    97,     0,
  60525. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60526. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60527. -     0,     0,   645,   105,   106,     0,     0,     0,   107,     0,
  60528. -   108,    44,     0,     0,     0,   109,    45,     0,     0,   110,
  60529. -   621,     0,    90,   111,   112,     0,   646,    91,    92,   331,
  60530. -    93,     0,   -23,   -23,   -23,   -23,     0,     0,     0,     0,
  60531. -   -23,   -23,   -23,     0,     0,     0,     0,     0,    94,     0,
  60532. -    95,     0,    96,    97,     0,   184,   -23,     0,  -155,    98,
  60533. -     0,     0,    99,     0,  -155,     0,     0,   100,   101,   102,
  60534. -     0,     0,     0,   103,   104,     0,     0,     0,   105,   106,
  60535. -     0,     0,     0,   107,     0,   108,     0,   185,   186,     0,
  60536. -   109,     0,     0,     0,   110,   -23,     0,     0,   111,   112,
  60537. -   -23,   622,     0,     0,     0,  -155,     0,     0,   325,  -155,
  60538. -   -23,   -19,   -19,   -19,   -19,     0,     0,     0,     0,   -19,
  60539. -   -19,   -19,     0,     0,     0,     0,     0,   312,     0,     0,
  60540. -  -107,  -107,  -107,  -107,   184,   -19,  -107,  -155,  -107,  -107,
  60541. -  -107,     0,     0,  -155,   312,     0,     0,  -465,  -465,  -465,
  60542. -  -465,     0,     0,     0,  -107,  -465,  -465,  -465,   249,   250,
  60543. -   251,   252,   253,   254,   255,   256,   257,   258,     0,     0,
  60544. -     0,  -465,     0,     5,   -19,     7,   276,     0,     0,   -19,
  60545. -     0,     9,    10,    11,  -155,     0,    90,     0,  -155,   -19,
  60546. -     0,    91,    92,  -107,    93,     0,     0,    13,  -107,    66,
  60547. -   251,   252,   253,   254,   255,   256,   257,   258,  -107,     0,
  60548. -  -465,     0,    94,     0,    95,  -465,    96,    97,     0,   268,
  60549. -     0,     0,     0,    98,     0,  -465,    99,     0,   269,   270,
  60550. -     0,   100,   101,   102,     0,     0,    19,   103,   104,     0,
  60551. -     0,    21,   105,   106,     0,    90,     0,   107,     0,   108,
  60552. -    91,    92,     0,    93,   109,     0,     0,     0,   110,     0,
  60553. -     0,     0,   111,   112,     0,     0,   310,     0,     0,     0,
  60554. -     0,    94,     0,    95,     0,    96,    97,     0,     0,     0,
  60555. -     0,     0,    98,     0,     0,    99,     0,     0,     0,     0,
  60556. -   100,   101,   102,     0,     0,     0,   103,   104,     0,     0,
  60557. -     0,   105,   106,     0,    90,     0,   107,     0,   108,    91,
  60558. -    92,     0,    93,   109,     0,     0,     0,   110,     0,     0,
  60559. -     0,   111,   112,     0,     0,   392,     0,     0,     0,     0,
  60560. -    94,     0,    95,     0,    96,    97,     0,     0,     0,     0,
  60561. -     0,    98,     0,     0,    99,     0,     0,     0,     0,   100,
  60562. -   101,   102,     0,     0,     0,   103,   104,     0,     0,     0,
  60563. -   105,   106,     0,    90,     0,   107,     0,   108,    91,    92,
  60564. -     0,    93,   109,     0,     0,     0,   110,     0,     0,     0,
  60565. -   111,   112,     0,     0,   452,     0,     0,     0,     0,    94,
  60566. -     0,    95,     0,    96,    97,     0,     0,     0,     0,     0,
  60567. -    98,     0,     0,    99,     0,     0,     0,     0,   100,   101,
  60568. -   102,     0,     0,     0,   103,   104,     0,     0,     0,   105,
  60569. -   106,     0,    90,     0,   107,     0,   108,    91,    92,     0,
  60570. -    93,   109,     0,     0,     0,   110,     0,     0,     0,   111,
  60571. -   112,     0,     0,   489,     0,     0,     0,     0,    94,     0,
  60572. -    95,     0,    96,    97,     0,     0,     0,     0,     0,    98,
  60573. -     0,     0,    99,     0,     0,     0,     0,   100,   101,   102,
  60574. -     0,     0,     0,   103,   104,     0,     0,     0,   105,   106,
  60575. -     0,     0,     0,   107,     0,   108,     0,     0,     0,     0,
  60576. -   109,     0,     0,     0,   110,     0,     0,     0,   111,   112,
  60577. -     0,     0,   735,   644,   745,     6,     7,     8,    91,    92,
  60578. -     0,    93,     9,    10,    11,   746,     0,   747,   748,   749,
  60579. -   750,   751,   752,   753,   754,   755,   756,   757,    13,    94,
  60580. -     0,    95,     0,    96,    97,     0,     0,     0,     0,     0,
  60581. -    98,     0,     0,    99,     0,     0,     0,     0,   100,   101,
  60582. -   102,     0,     0,     0,   103,   104,     0,     0,     0,   105,
  60583. -   106,     0,     0,     0,   107,     0,   108,   758,     0,     0,
  60584. -     0,   109,   759,     0,     0,   110,     0,   760,     0,   111,
  60585. -   112,     0,   350,   644,    43,     0,     0,     0,    91,    92,
  60586. -     0,    93,     0,     0,     0,   746,     0,   747,   748,   749,
  60587. -   750,   751,   752,   753,   754,   755,   756,   757,     0,    94,
  60588. -     0,    95,     0,    96,    97,     0,     0,     0,     0,     0,
  60589. -    98,     0,     0,    99,     0,     0,     0,     0,   100,   101,
  60590. -   102,     0,     0,     0,   103,   104,     0,    90,     0,   105,
  60591. -   106,     0,    91,    92,   107,    93,   108,    44,     0,     0,
  60592. -     0,   109,    45,     0,     0,   110,     0,   760,     0,   111,
  60593. -   112,     0,   350,    94,     0,    95,     0,    96,    97,     0,
  60594. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60595. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60596. -     0,     0,     0,   105,   106,     0,     0,     0,   107,     0,
  60597. -   108,     0,     0,     0,     0,   109,     0,     0,     0,   110,
  60598. -     0,     0,     0,   111,   112,     0,   471,   132,   133,     0,
  60599. -   134,   135,     0,     0,     0,   136,   137,   138,   139,   140,
  60600. -   141,   142,   143,   144,   145,   146,   147,   148,   149,   150,
  60601. -   151,   152,   153,   154,     0,    90,     5,     0,     7,   126,
  60602. -    91,    92,   155,    93,     9,    10,    11,   250,   251,   252,
  60603. -   253,   254,   255,   256,   257,   258,     0,     0,     0,     0,
  60604. -    13,    94,     0,    95,     0,    96,    97,     0,     0,     0,
  60605. -     0,     0,    98,     0,     0,    99,   157,     0,     0,     0,
  60606. -   100,   101,   102,     0,     0,   283,   103,   104,     0,    90,
  60607. -     0,   105,   106,     0,    91,    92,   107,    93,   108,    19,
  60608. -     0,     0,     0,   109,    21,     0,     0,   110,     0,     0,
  60609. -     0,   111,   112,     0,     0,    94,     0,    95,     0,    96,
  60610. -    97,     0,     0,     0,     0,     0,    98,     0,     0,    99,
  60611. -     0,     0,     0,     0,   100,   101,   102,     0,     0,     0,
  60612. -   103,   104,     0,    90,     0,   105,   106,     0,    91,    92,
  60613. -   107,    93,   108,   353,     0,     0,     0,   109,     0,     0,
  60614. -     0,   110,     0,     0,     0,   111,   112,     0,     0,    94,
  60615. -     0,    95,     0,    96,    97,     0,     0,     0,     0,     0,
  60616. -    98,     0,     0,    99,     0,     0,     0,     0,   100,   101,
  60617. -   102,     0,     0,     0,   103,   104,     0,    90,     0,   105,
  60618. -   106,     0,    91,    92,   107,    93,   108,     0,     0,     0,
  60619. -     0,   109,     0,     0,     0,   110,     0,   801,     0,   111,
  60620. -   112,     0,     0,    94,     0,    95,     0,    96,    97,     0,
  60621. -     0,     0,     0,     0,    98,     0,     0,    99,     0,     0,
  60622. -     0,     0,   100,   101,   102,     0,     0,     0,   103,   104,
  60623. -     0,    90,     0,   105,   106,     0,    91,    92,   107,    93,
  60624. -   108,     0,     0,     0,     0,   109,     0,     0,     0,   110,
  60625. -     0,     0,     0,   111,   112,     0,     0,    94,     0,    95,
  60626. -     0,    96,    97,     0,     0,     0,     0,     0,    98,     0,
  60627. -     0,    99,     0,     0,     0,     0,   100,   101,   102,     0,
  60628. -     0,     0,   103,   104,     0,    90,     0,   222,   106,     0,
  60629. -    91,    92,   107,    93,   108,     0,     0,     0,     0,   109,
  60630. -     0,     0,     0,   110,     0,     0,     0,   111,   112,     0,
  60631. -     0,    94,     0,    95,     0,    96,    97,     0,     0,     0,
  60632. -     0,     0,    98,     0,     0,    99,     0,     0,     0,     0,
  60633. -   100,   101,   102,     0,     0,     0,   103,   104,     0,   599,
  60634. -     0,   224,   106,     0,    91,    92,   107,    93,   108,     0,
  60635. -     0,     0,     0,   109,     0,     0,     0,   110,     0,     0,
  60636. -     0,   111,   112,     0,     0,    94,     0,    95,     0,    96,
  60637. -    97,     0,     0,     0,     0,     0,    98,     0,     0,    99,
  60638. -     0,     0,     0,     0,   100,   101,   102,     0,     0,     0,
  60639. -   103,   104,     0,     0,     0,   105,   106,     0,     0,     0,
  60640. -   107,     0,   108,     0,     0,     0,     0,   109,     0,     0,
  60641. -     0,   110,     0,     0,   524,   111,   112,     5,     0,     7,
  60642. -   126,     0,     0,     0,     0,     9,    10,    11,     0,     0,
  60643. -     0,   524,     0,     0,     5,     0,     7,   126,     0,     0,
  60644. -     0,    13,     9,    10,    11,     0,     0,     0,     0,     0,
  60645. -     0,     0,     0,     0,     0,     0,     0,     0,    13,     0,
  60646. -     0,     0,     0,     0,     0,     0,     4,     0,  -120,     5,
  60647. -     6,     7,     8,     0,     0,     0,     0,     9,    10,    11,
  60648. -    19,  -417,  -417,  -417,     0,    21,     0,     0,     0,     0,
  60649. -   525,  -417,    12,    13,     0,  -120,     0,    19,  -416,  -416,
  60650. -  -416,     0,    21,     0,     0,     0,     0,   525,  -416,     0,
  60651. -     0,     0,     0,    14,    15,  -120,     0,     0,     0,     0,
  60652. -     0,     0,     0,     0,  -120,     0,    16,    17,    18,     0,
  60653. -     0,     0,    19,     0,     0,     0,    20,    21,    22,    23,
  60654. -     0,     4,    24,  -120,     5,     6,     7,     8,     0,     0,
  60655. -     0,     0,     9,    10,    11,     0,     0,     0,     0,     0,
  60656. -     0,     0,     0,     0,     0,     0,     0,     0,    13,     4,
  60657. -  -120,  -120,     5,     6,     7,     8,     0,     0,     0,     0,
  60658. -     9,    10,    11,     0,     0,     0,     0,     0,   510,   511,
  60659. -  -120,     0,     0,     0,     0,     0,    13,     0,  -120,  -120,
  60660. -     0,     0,     0,     0,     0,     0,     0,    19,     0,     0,
  60661. -     0,     0,    21,     0,     0,     0,     0,    24,  -120,   426,
  60662. -     0,   427,     5,     6,     7,     8,     0,  -120,   428,     0,
  60663. -     9,    10,    11,     0,     0,    19,     0,     0,   426,     0,
  60664. -    21,     5,     6,     7,     8,    24,    13,   428,     0,     9,
  60665. -    10,    11,     5,     0,     7,   276,     0,     0,     0,     0,
  60666. -     9,    10,    11,     0,     0,    13,     0,     0,     0,     5,
  60667. -    76,     7,    77,     0,     0,     0,    13,     9,    10,    11,
  60668. -     0,     0,     0,     0,     0,    19,     0,     0,     0,     0,
  60669. -    21,     0,     0,    13,  -364,     0,     0,     5,    76,     7,
  60670. -    77,     0,     0,     0,    19,     9,    10,    11,     0,    21,
  60671. -     0,     0,     0,  -364,     0,    19,     0,     0,     0,     0,
  60672. -    21,    13,     0,     0,     0,  -250,  -250,     0,     0,     0,
  60673. -     0,     0,    19,     0,     0,     0,     0,    21,     5,    76,
  60674. -     7,    77,    78,     0,     0,     0,     9,    10,    11,     5,
  60675. -    76,     7,    77,     0,     0,     0,     0,     9,    10,    11,
  60676. -    19,     0,    13,     0,     0,    21,     0,     0,   132,   133,
  60677. -   575,   134,   135,    13,     0,     0,   136,   137,   138,   139,
  60678. -   140,   141,   142,   143,   144,   145,   146,   147,   148,   149,
  60679. -   150,   151,   152,   153,   154,     0,     0,     0,     0,     0,
  60680. -     0,    19,     0,   155,     0,     0,    21,     0,     0,     0,
  60681. -     0,   619,    19,     0,     0,     0,     0,    21,     0,     0,
  60682. -     0,     0,   811,     0,   156,     0,     0,     0,     0,     0,
  60683. -   132,   133,     0,   134,   135,     0,     0,   157,   136,   137,
  60684. -   138,   139,   140,   141,   142,   143,   144,   145,   146,   147,
  60685. -   148,   149,   150,   151,   152,   153,   154,     0,   132,   133,
  60686. -     0,   134,   135,     0,     0,   356,   136,   137,   138,   139,
  60687. -   140,   141,   142,   143,   144,   145,   146,   147,   148,   149,
  60688. -   150,   151,   152,   153,   154,     0,     0,     0,     0,     0,
  60689. -     0,     0,     0,   155,   132,   133,     0,   134,   135,   157,
  60690. -     0,     0,   136,   137,   138,   139,   140,   141,   142,   143,
  60691. -   144,   145,   146,   147,   148,   149,   150,   151,   152,   153,
  60692. -   154,     0,     5,     6,     7,     8,     0,   157,   428,   564,
  60693. -     9,    10,    11,     5,     6,     7,     8,     0,     0,   613,
  60694. -     0,     9,    10,    11,     0,     0,    13,     0,     0,     0,
  60695. -     5,    76,     7,    77,     0,     0,     0,    13,     9,    10,
  60696. -    11,     0,     0,   157,     0,     0,     0,     5,     6,     7,
  60697. -     8,     0,     0,     0,    13,     9,    10,    11,     5,     0,
  60698. -     7,   126,     0,     0,     0,    19,     9,    10,    11,     0,
  60699. -    21,    13,     0,     0,     0,     5,    19,     7,   276,     0,
  60700. -     0,    21,    13,     9,    10,    11,     0,     0,     0,     0,
  60701. -     0,     0,     0,    19,     0,     0,     0,     0,    21,    13,
  60702. -     0,     0,     0,     0,     0,     0,     0,     0,     0,     0,
  60703. -    19,     0,     0,     0,     0,    21,     0,     0,     0,   829,
  60704. -     0,    19,     0,     0,     0,     0,    21,     0,     0,     0,
  60705. -     0,     0,     0,     0,     0,     0,     0,     0,    19,     0,
  60706. -     0,     0,     0,    21,   242,   243,   244,   830,   245,   246,
  60707. -   247,   248,   249,   250,   251,   252,   253,   254,   255,   256,
  60708. -   257,   258,    66,     0,     0,     0,     0,   242,   243,   244,
  60709. -     0,   245,   246,   247,   248,   249,   250,   251,   252,   253,
  60710. -   254,   255,   256,   257,   258,   242,   243,   244,   868,   245,
  60711. -   246,   247,   248,   249,   250,   251,   252,   253,   254,   255,
  60712. -   256,   257,   258,   242,   243,   244,     0,   245,   246,   247,
  60713. -   248,   249,   250,   251,   252,   253,   254,   255,   256,   257,
  60714. -   258
  60715. -};
  60716. -
  60717. -static const short yycheck[] = {    52,
  60718. -    53,    75,     9,    10,    11,   196,    21,    28,   307,    16,
  60719. -    17,   326,    71,    20,   190,    22,    23,   332,    79,   263,
  60720. -    29,    30,   233,    28,   328,   314,     2,     3,   195,    86,
  60721. -     2,     3,    55,   618,    81,   462,   128,   391,    30,   131,
  60722. -   180,    56,   297,   160,   412,    60,   187,    68,   535,    86,
  60723. -    50,    58,   105,   274,    96,    97,     1,    64,    79,   191,
  60724. -   102,    53,   269,    68,     1,   213,   795,     9,     1,   160,
  60725. -    75,   113,   220,     3,    79,    82,   715,    10,     3,     4,
  60726. -    38,   410,   794,    38,     3,     1,    38,    30,     7,    45,
  60727. -   694,    98,   268,     0,    86,    27,     0,    76,    38,    38,
  60728. -    30,   105,    81,    77,   271,    45,    45,     1,   712,     3,
  60729. -     4,    30,   401,   105,   305,    59,    59,    60,    76,    59,
  60730. -    50,    76,    59,   128,    76,    81,   131,    59,    60,    59,
  60731. -   842,    50,    77,   186,    76,    30,   195,   866,   777,   131,
  60732. -    59,    60,    67,    38,    59,   236,    45,    72,   155,    82,
  60733. -   862,    82,   156,   865,   201,   867,   177,    82,   165,   166,
  60734. -   181,   168,   169,   875,   156,   894,    82,   174,    65,   222,
  60735. -   191,   224,   177,    67,   315,   180,   181,   398,    72,   327,
  60736. -   819,   388,   235,   323,   226,   326,   191,   394,   320,   518,
  60737. -    38,   332,   324,   680,   681,   907,    82,    45,   339,    82,
  60738. -   341,     3,     4,    76,   211,    77,    78,   216,    81,   218,
  60739. -   499,   264,   271,   640,    59,     3,     4,   270,   222,   219,
  60740. -   224,   221,   590,    38,    30,   810,   218,   274,     3,     4,
  60741. -   222,   238,   224,   237,    59,     1,     3,     4,     4,     3,
  60742. -     6,     7,    78,    30,    59,   237,    12,    13,    14,    77,
  60743. -    59,   506,   581,    81,   261,   262,    78,    59,   612,    59,
  60744. -   319,    30,    28,    50,   269,    67,    30,    82,   359,    59,
  60745. -    72,   560,    59,    60,   289,   279,   329,    76,    76,    67,
  60746. -   287,   708,    81,    50,    72,   500,    50,   279,   532,   504,
  60747. -    59,    60,    67,   300,    82,    59,    60,    72,    77,   320,
  60748. -    67,    67,    81,   324,    81,    72,    72,    82,    76,   457,
  60749. -   352,    77,    78,    81,    75,   320,   464,   465,   323,   324,
  60750. -   564,     3,     4,     5,     6,     7,     9,   334,   583,     3,
  60751. -     4,   542,    48,    49,   549,     3,     4,   552,    59,    60,
  60752. -    68,    69,    70,   396,    77,    76,   635,    63,    81,   638,
  60753. -    78,   398,    76,     3,     4,    76,   241,   242,   243,   416,
  60754. -   245,   246,   247,   248,   249,   250,   251,   252,   253,   254,
  60755. -   255,   256,   257,   258,    59,    60,   493,    38,   682,   416,
  60756. -    30,    76,   473,   388,    82,    67,    81,    77,   815,   394,
  60757. -    72,    59,    59,    67,   409,    59,   603,    36,    72,    67,
  60758. -    50,   405,   493,   412,    72,    81,   554,    77,    67,    59,
  60759. -   654,    81,   667,   405,   555,    77,    59,    60,    76,   560,
  60760. -   429,   430,    72,     3,   416,   401,   602,     7,    76,   401,
  60761. -    59,    60,   608,    76,   678,    77,   412,   604,   430,    81,
  60762. -   412,    77,   609,   535,   536,    81,    27,    76,   333,    30,
  60763. -    30,    82,    77,    59,    60,    36,    81,   605,   606,   607,
  60764. -     3,     4,   610,   611,     7,    77,    76,   443,    77,    81,
  60765. -    50,   443,    81,   680,   681,    77,   567,    77,    78,    59,
  60766. -   687,   688,   556,   631,   491,   494,    77,    30,    77,    77,
  60767. -    81,    76,   513,    81,    10,   636,    77,   638,    76,   710,
  60768. -    81,    59,    60,   495,    63,   514,   515,    50,   513,    82,
  60769. -   658,   659,   660,    76,   535,   536,    59,   526,   527,    27,
  60770. -   594,   595,   498,   515,   531,   780,   498,     9,   589,    72,
  60771. -   535,   536,    83,   744,    78,   527,   593,   546,   547,    77,
  60772. -     3,     4,   857,    36,   859,   604,    77,    78,   696,    76,
  60773. -   609,   556,   559,   574,     7,   547,   593,    59,    60,   620,
  60774. -    93,    94,   585,   586,     3,     4,    78,    30,   589,   574,
  60775. -    76,    78,   579,    76,    78,    38,    76,    30,    68,    69,
  60776. -    70,   590,   603,   588,   589,    76,    38,    50,    78,   594,
  60777. -   595,    30,    76,   741,    38,   480,    59,    50,   603,   620,
  60778. -    76,   593,   901,    50,    51,    52,    59,    60,    76,    72,
  60779. -   909,    50,    83,   618,   590,   620,    83,    76,   590,    59,
  60780. -    59,    60,    82,     1,    36,    63,     4,     5,     6,     7,
  60781. -   683,    63,   843,    76,    12,    13,    14,    83,   645,    54,
  60782. -    55,    76,    57,    58,    59,    60,   837,    78,    81,    83,
  60783. -    28,    32,    77,     3,     4,    81,   730,   710,    76,   680,
  60784. -   681,    76,    76,   548,    77,     3,   687,   688,    77,    68,
  60785. -    69,    70,    38,   884,   885,   680,   681,    83,   563,    78,
  60786. -    30,    63,   687,   688,    76,    68,    69,    70,    38,    67,
  60787. -    78,   744,    78,   700,    72,    78,    38,    38,    78,    63,
  60788. -    50,   722,   755,   710,    82,    81,    38,    81,     1,    59,
  60789. -    78,     4,     5,     6,     7,    36,   857,   722,   859,    12,
  60790. -    13,    14,    72,     6,     7,   730,    63,    83,    38,    12,
  60791. -    13,    14,    78,    59,   710,    28,   810,   744,   710,   792,
  60792. -    59,   626,    59,   796,   759,   630,    38,    77,    77,   756,
  60793. -   803,   812,     7,    38,    77,   764,   765,     1,    16,    77,
  60794. -     4,     5,     6,     7,    78,   818,    77,    63,    12,    13,
  60795. -    14,   824,    59,   765,    67,    77,    76,    59,    17,    72,
  60796. -    77,   834,    76,    27,    28,    76,    30,   672,    77,    82,
  60797. -   843,   812,    36,     3,     4,    76,     9,     7,    46,    47,
  60798. -    48,    49,    50,    51,    52,   810,    77,   812,    77,   694,
  60799. -    77,    81,   697,    59,    77,    59,    60,     5,     6,     7,
  60800. -    30,    77,    76,    67,    12,    13,    14,   712,    72,    76,
  60801. -   715,     0,    77,    77,     0,   888,   843,    81,    82,     3,
  60802. -    50,   532,    54,    55,   729,    57,    58,    59,    60,    59,
  60803. -    60,     1,   636,     3,     4,     5,     6,     7,     8,     9,
  60804. -   795,    11,    12,    13,    14,    15,   751,    17,    18,    19,
  60805. -    20,    21,    22,    23,    24,    25,    26,    27,    28,    29,
  60806. -    80,    31,   277,    33,    34,    48,    49,    50,    51,    52,
  60807. -    40,   315,   777,    43,   531,   336,   626,   334,    48,    49,
  60808. -    50,   555,   211,   638,    54,    55,   561,   636,   889,    59,
  60809. -    60,   341,   395,   891,    64,   843,    66,    67,   404,   843,
  60810. -   539,    71,    72,   404,    58,    75,   523,    77,    78,    79,
  60811. -    80,   727,    82,   730,   819,     1,   288,     3,     4,     5,
  60812. -     6,     7,     8,     9,   829,    11,    12,    13,    14,    15,
  60813. -   595,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  60814. -    26,    27,    28,    29,   516,    31,   498,    33,    34,   722,
  60815. -    27,   493,   400,    30,    40,   654,    -1,    43,   400,    36,
  60816. -   567,    -1,    48,    49,    50,    -1,   359,    -1,    54,    55,
  60817. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60818. -    66,    67,    59,    60,    -1,    71,    72,    -1,    -1,    75,
  60819. -    -1,    77,    -1,    79,    80,     1,    82,     3,     4,    -1,
  60820. -    77,    -1,     8,     9,    81,    11,    -1,    -1,    -1,    15,
  60821. -    -1,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  60822. -    26,    27,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60823. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60824. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60825. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60826. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60827. -    -1,    77,    78,    79,    80,     1,    82,     3,     4,    -1,
  60828. -    -1,    -1,     8,     9,    -1,    11,    -1,    -1,    -1,    15,
  60829. -    -1,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  60830. -    26,    27,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60831. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60832. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60833. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60834. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60835. -    -1,    77,    -1,    79,    80,     1,    82,     3,     4,    -1,
  60836. -    -1,    -1,     8,     9,    -1,    11,    -1,    -1,    -1,    15,
  60837. -    -1,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  60838. -    26,    27,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60839. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60840. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60841. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60842. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60843. -    -1,    77,    -1,    79,    80,     1,    82,     3,     4,    -1,
  60844. -     6,     7,     8,     9,    -1,    11,    12,    13,    14,    40,
  60845. -    41,    42,    43,    44,    45,    46,    47,    48,    49,    50,
  60846. -    51,    52,    28,    29,    -1,    31,    -1,    33,    34,    -1,
  60847. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60848. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60849. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60850. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60851. -    -1,    -1,    -1,    79,    80,     1,    82,     3,     4,    -1,
  60852. -    -1,    -1,     8,     9,    37,    11,    39,    40,    41,    42,
  60853. -    43,    44,    45,    46,    47,    48,    49,    50,    51,    52,
  60854. -    -1,    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60855. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60856. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60857. -    -1,    -1,    58,    59,    60,    -1,    -1,    -1,    64,    -1,
  60858. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60859. -    -1,    -1,    78,    79,    80,     1,    82,     3,     4,    -1,
  60860. -    -1,    -1,     8,     9,    -1,    11,    41,    42,    43,    44,
  60861. -    45,    46,    47,    48,    49,    50,    51,    52,    -1,    -1,
  60862. -    -1,    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60863. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60864. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60865. -    -1,    -1,    58,    59,    60,    -1,    -1,    -1,    64,    -1,
  60866. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60867. -    -1,    -1,    78,    79,    80,     1,    82,     3,     4,    -1,
  60868. -    -1,    -1,     8,     9,    -1,    11,    42,    43,    44,    45,
  60869. -    46,    47,    48,    49,    50,    51,    52,    -1,    -1,    -1,
  60870. -    -1,    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60871. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60872. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60873. -    -1,    -1,    58,    59,    60,    -1,    -1,    -1,    64,    -1,
  60874. -    66,    67,    -1,    -1,    -1,    71,    72,    -1,    -1,    75,
  60875. -     1,    -1,     3,    79,    80,    -1,    82,     8,     9,     1,
  60876. -    11,    -1,     4,     5,     6,     7,    -1,    -1,    -1,    -1,
  60877. -    12,    13,    14,    -1,    -1,    -1,    -1,    -1,    29,    -1,
  60878. -    31,    -1,    33,    34,    -1,    27,    28,    -1,    30,    40,
  60879. -    -1,    -1,    43,    -1,    36,    -1,    -1,    48,    49,    50,
  60880. -    -1,    -1,    -1,    54,    55,    -1,    -1,    -1,    59,    60,
  60881. -    -1,    -1,    -1,    64,    -1,    66,    -1,    59,    60,    -1,
  60882. -    71,    -1,    -1,    -1,    75,    67,    -1,    -1,    79,    80,
  60883. -    72,    82,    -1,    -1,    -1,    77,    -1,    -1,     1,    81,
  60884. -    82,     4,     5,     6,     7,    -1,    -1,    -1,    -1,    12,
  60885. -    13,    14,    -1,    -1,    -1,    -1,    -1,     1,    -1,    -1,
  60886. -     4,     5,     6,     7,    27,    28,    10,    30,    12,    13,
  60887. -    14,    -1,    -1,    36,     1,    -1,    -1,     4,     5,     6,
  60888. -     7,    -1,    -1,    -1,    28,    12,    13,    14,    43,    44,
  60889. -    45,    46,    47,    48,    49,    50,    51,    52,    -1,    -1,
  60890. -    -1,    28,    -1,     4,    67,     6,     7,    -1,    -1,    72,
  60891. -    -1,    12,    13,    14,    77,    -1,     3,    -1,    81,    82,
  60892. -    -1,     8,     9,    67,    11,    -1,    -1,    28,    72,    30,
  60893. -    45,    46,    47,    48,    49,    50,    51,    52,    82,    -1,
  60894. -    67,    -1,    29,    -1,    31,    72,    33,    34,    -1,    50,
  60895. -    -1,    -1,    -1,    40,    -1,    82,    43,    -1,    59,    60,
  60896. -    -1,    48,    49,    50,    -1,    -1,    67,    54,    55,    -1,
  60897. -    -1,    72,    59,    60,    -1,     3,    -1,    64,    -1,    66,
  60898. -     8,     9,    -1,    11,    71,    -1,    -1,    -1,    75,    -1,
  60899. -    -1,    -1,    79,    80,    -1,    -1,    83,    -1,    -1,    -1,
  60900. -    -1,    29,    -1,    31,    -1,    33,    34,    -1,    -1,    -1,
  60901. -    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,
  60902. -    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,    -1,
  60903. -    -1,    59,    60,    -1,     3,    -1,    64,    -1,    66,     8,
  60904. -     9,    -1,    11,    71,    -1,    -1,    -1,    75,    -1,    -1,
  60905. -    -1,    79,    80,    -1,    -1,    83,    -1,    -1,    -1,    -1,
  60906. -    29,    -1,    31,    -1,    33,    34,    -1,    -1,    -1,    -1,
  60907. -    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,
  60908. -    49,    50,    -1,    -1,    -1,    54,    55,    -1,    -1,    -1,
  60909. -    59,    60,    -1,     3,    -1,    64,    -1,    66,     8,     9,
  60910. -    -1,    11,    71,    -1,    -1,    -1,    75,    -1,    -1,    -1,
  60911. -    79,    80,    -1,    -1,    83,    -1,    -1,    -1,    -1,    29,
  60912. -    -1,    31,    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,
  60913. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  60914. -    50,    -1,    -1,    -1,    54,    55,    -1,    -1,    -1,    59,
  60915. -    60,    -1,     3,    -1,    64,    -1,    66,     8,     9,    -1,
  60916. -    11,    71,    -1,    -1,    -1,    75,    -1,    -1,    -1,    79,
  60917. -    80,    -1,    -1,    83,    -1,    -1,    -1,    -1,    29,    -1,
  60918. -    31,    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,    40,
  60919. -    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,
  60920. -    -1,    -1,    -1,    54,    55,    -1,    -1,    -1,    59,    60,
  60921. -    -1,    -1,    -1,    64,    -1,    66,    -1,    -1,    -1,    -1,
  60922. -    71,    -1,    -1,    -1,    75,    -1,    -1,    -1,    79,    80,
  60923. -    -1,    -1,    83,     3,     4,     5,     6,     7,     8,     9,
  60924. -    -1,    11,    12,    13,    14,    15,    -1,    17,    18,    19,
  60925. -    20,    21,    22,    23,    24,    25,    26,    27,    28,    29,
  60926. -    -1,    31,    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,
  60927. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  60928. -    50,    -1,    -1,    -1,    54,    55,    -1,    -1,    -1,    59,
  60929. -    60,    -1,    -1,    -1,    64,    -1,    66,    67,    -1,    -1,
  60930. -    -1,    71,    72,    -1,    -1,    75,    -1,    77,    -1,    79,
  60931. -    80,    -1,    82,     3,     4,    -1,    -1,    -1,     8,     9,
  60932. -    -1,    11,    -1,    -1,    -1,    15,    -1,    17,    18,    19,
  60933. -    20,    21,    22,    23,    24,    25,    26,    27,    -1,    29,
  60934. -    -1,    31,    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,
  60935. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  60936. -    50,    -1,    -1,    -1,    54,    55,    -1,     3,    -1,    59,
  60937. -    60,    -1,     8,     9,    64,    11,    66,    67,    -1,    -1,
  60938. -    -1,    71,    72,    -1,    -1,    75,    -1,    77,    -1,    79,
  60939. -    80,    -1,    82,    29,    -1,    31,    -1,    33,    34,    -1,
  60940. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60941. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60942. -    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,    64,    -1,
  60943. -    66,    -1,    -1,    -1,    -1,    71,    -1,    -1,    -1,    75,
  60944. -    -1,    -1,    -1,    79,    80,    -1,    82,     3,     4,    -1,
  60945. -     6,     7,    -1,    -1,    -1,    11,    12,    13,    14,    15,
  60946. -    16,    17,    18,    19,    20,    21,    22,    23,    24,    25,
  60947. -    26,    27,    28,    29,    -1,     3,     4,    -1,     6,     7,
  60948. -     8,     9,    38,    11,    12,    13,    14,    44,    45,    46,
  60949. -    47,    48,    49,    50,    51,    52,    -1,    -1,    -1,    -1,
  60950. -    28,    29,    -1,    31,    -1,    33,    34,    -1,    -1,    -1,
  60951. -    -1,    -1,    40,    -1,    -1,    43,    72,    -1,    -1,    -1,
  60952. -    48,    49,    50,    -1,    -1,    81,    54,    55,    -1,     3,
  60953. -    -1,    59,    60,    -1,     8,     9,    64,    11,    66,    67,
  60954. -    -1,    -1,    -1,    71,    72,    -1,    -1,    75,    -1,    -1,
  60955. -    -1,    79,    80,    -1,    -1,    29,    -1,    31,    -1,    33,
  60956. -    34,    -1,    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,
  60957. -    -1,    -1,    -1,    -1,    48,    49,    50,    -1,    -1,    -1,
  60958. -    54,    55,    -1,     3,    -1,    59,    60,    -1,     8,     9,
  60959. -    64,    11,    66,    67,    -1,    -1,    -1,    71,    -1,    -1,
  60960. -    -1,    75,    -1,    -1,    -1,    79,    80,    -1,    -1,    29,
  60961. -    -1,    31,    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,
  60962. -    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,    48,    49,
  60963. -    50,    -1,    -1,    -1,    54,    55,    -1,     3,    -1,    59,
  60964. -    60,    -1,     8,     9,    64,    11,    66,    -1,    -1,    -1,
  60965. -    -1,    71,    -1,    -1,    -1,    75,    -1,    77,    -1,    79,
  60966. -    80,    -1,    -1,    29,    -1,    31,    -1,    33,    34,    -1,
  60967. -    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,
  60968. -    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    54,    55,
  60969. -    -1,     3,    -1,    59,    60,    -1,     8,     9,    64,    11,
  60970. -    66,    -1,    -1,    -1,    -1,    71,    -1,    -1,    -1,    75,
  60971. -    -1,    -1,    -1,    79,    80,    -1,    -1,    29,    -1,    31,
  60972. -    -1,    33,    34,    -1,    -1,    -1,    -1,    -1,    40,    -1,
  60973. -    -1,    43,    -1,    -1,    -1,    -1,    48,    49,    50,    -1,
  60974. -    -1,    -1,    54,    55,    -1,     3,    -1,    59,    60,    -1,
  60975. -     8,     9,    64,    11,    66,    -1,    -1,    -1,    -1,    71,
  60976. -    -1,    -1,    -1,    75,    -1,    -1,    -1,    79,    80,    -1,
  60977. -    -1,    29,    -1,    31,    -1,    33,    34,    -1,    -1,    -1,
  60978. -    -1,    -1,    40,    -1,    -1,    43,    -1,    -1,    -1,    -1,
  60979. -    48,    49,    50,    -1,    -1,    -1,    54,    55,    -1,     3,
  60980. -    -1,    59,    60,    -1,     8,     9,    64,    11,    66,    -1,
  60981. -    -1,    -1,    -1,    71,    -1,    -1,    -1,    75,    -1,    -1,
  60982. -    -1,    79,    80,    -1,    -1,    29,    -1,    31,    -1,    33,
  60983. -    34,    -1,    -1,    -1,    -1,    -1,    40,    -1,    -1,    43,
  60984. -    -1,    -1,    -1,    -1,    48,    49,    50,    -1,    -1,    -1,
  60985. -    54,    55,    -1,    -1,    -1,    59,    60,    -1,    -1,    -1,
  60986. -    64,    -1,    66,    -1,    -1,    -1,    -1,    71,    -1,    -1,
  60987. -    -1,    75,    -1,    -1,     1,    79,    80,     4,    -1,     6,
  60988. -     7,    -1,    -1,    -1,    -1,    12,    13,    14,    -1,    -1,
  60989. -    -1,     1,    -1,    -1,     4,    -1,     6,     7,    -1,    -1,
  60990. -    -1,    28,    12,    13,    14,    -1,    -1,    -1,    -1,    -1,
  60991. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    28,    -1,
  60992. -    -1,    -1,    -1,    -1,    -1,    -1,     1,    -1,     3,     4,
  60993. -     5,     6,     7,    -1,    -1,    -1,    -1,    12,    13,    14,
  60994. -    67,    68,    69,    70,    -1,    72,    -1,    -1,    -1,    -1,
  60995. -    77,    78,    27,    28,    -1,    30,    -1,    67,    68,    69,
  60996. -    70,    -1,    72,    -1,    -1,    -1,    -1,    77,    78,    -1,
  60997. -    -1,    -1,    -1,    48,    49,    50,    -1,    -1,    -1,    -1,
  60998. -    -1,    -1,    -1,    -1,    59,    -1,    61,    62,    63,    -1,
  60999. -    -1,    -1,    67,    -1,    -1,    -1,    71,    72,    73,    74,
  61000. -    -1,     1,    77,     3,     4,     5,     6,     7,    -1,    -1,
  61001. -    -1,    -1,    12,    13,    14,    -1,    -1,    -1,    -1,    -1,
  61002. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    28,     1,
  61003. -    30,     3,     4,     5,     6,     7,    -1,    -1,    -1,    -1,
  61004. -    12,    13,    14,    -1,    -1,    -1,    -1,    -1,    48,    49,
  61005. -    50,    -1,    -1,    -1,    -1,    -1,    28,    -1,    30,    59,
  61006. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    67,    -1,    -1,
  61007. -    -1,    -1,    72,    -1,    -1,    -1,    -1,    77,    50,     1,
  61008. -    -1,     3,     4,     5,     6,     7,    -1,    59,    10,    -1,
  61009. -    12,    13,    14,    -1,    -1,    67,    -1,    -1,     1,    -1,
  61010. -    72,     4,     5,     6,     7,    77,    28,    10,    -1,    12,
  61011. -    13,    14,     4,    -1,     6,     7,    -1,    -1,    -1,    -1,
  61012. -    12,    13,    14,    -1,    -1,    28,    -1,    -1,    -1,     4,
  61013. -     5,     6,     7,    -1,    -1,    -1,    28,    12,    13,    14,
  61014. -    -1,    -1,    -1,    -1,    -1,    67,    -1,    -1,    -1,    -1,
  61015. -    72,    -1,    -1,    28,    76,    -1,    -1,     4,     5,     6,
  61016. -     7,    -1,    -1,    -1,    67,    12,    13,    14,    -1,    72,
  61017. -    -1,    -1,    -1,    76,    -1,    67,    -1,    -1,    -1,    -1,
  61018. -    72,    28,    -1,    -1,    -1,    77,    78,    -1,    -1,    -1,
  61019. -    -1,    -1,    67,    -1,    -1,    -1,    -1,    72,     4,     5,
  61020. -     6,     7,    77,    -1,    -1,    -1,    12,    13,    14,     4,
  61021. -     5,     6,     7,    -1,    -1,    -1,    -1,    12,    13,    14,
  61022. -    67,    -1,    28,    -1,    -1,    72,    -1,    -1,     3,     4,
  61023. -    77,     6,     7,    28,    -1,    -1,    11,    12,    13,    14,
  61024. -    15,    16,    17,    18,    19,    20,    21,    22,    23,    24,
  61025. -    25,    26,    27,    28,    29,    -1,    -1,    -1,    -1,    -1,
  61026. -    -1,    67,    -1,    38,    -1,    -1,    72,    -1,    -1,    -1,
  61027. -    -1,    77,    67,    -1,    -1,    -1,    -1,    72,    -1,    -1,
  61028. -    -1,    -1,    77,    -1,    59,    -1,    -1,    -1,    -1,    -1,
  61029. -     3,     4,    -1,     6,     7,    -1,    -1,    72,    11,    12,
  61030. -    13,    14,    15,    16,    17,    18,    19,    20,    21,    22,
  61031. -    23,    24,    25,    26,    27,    28,    29,    -1,     3,     4,
  61032. -    -1,     6,     7,    -1,    -1,    38,    11,    12,    13,    14,
  61033. -    15,    16,    17,    18,    19,    20,    21,    22,    23,    24,
  61034. -    25,    26,    27,    28,    29,    -1,    -1,    -1,    -1,    -1,
  61035. -    -1,    -1,    -1,    38,     3,     4,    -1,     6,     7,    72,
  61036. -    -1,    -1,    11,    12,    13,    14,    15,    16,    17,    18,
  61037. -    19,    20,    21,    22,    23,    24,    25,    26,    27,    28,
  61038. -    29,    -1,     4,     5,     6,     7,    -1,    72,    10,    38,
  61039. -    12,    13,    14,     4,     5,     6,     7,    -1,    -1,    10,
  61040. -    -1,    12,    13,    14,    -1,    -1,    28,    -1,    -1,    -1,
  61041. -     4,     5,     6,     7,    -1,    -1,    -1,    28,    12,    13,
  61042. -    14,    -1,    -1,    72,    -1,    -1,    -1,     4,     5,     6,
  61043. -     7,    -1,    -1,    -1,    28,    12,    13,    14,     4,    -1,
  61044. -     6,     7,    -1,    -1,    -1,    67,    12,    13,    14,    -1,
  61045. -    72,    28,    -1,    -1,    -1,     4,    67,     6,     7,    -1,
  61046. -    -1,    72,    28,    12,    13,    14,    -1,    -1,    -1,    -1,
  61047. -    -1,    -1,    -1,    67,    -1,    -1,    -1,    -1,    72,    28,
  61048. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,
  61049. -    67,    -1,    -1,    -1,    -1,    72,    -1,    -1,    -1,    10,
  61050. -    -1,    67,    -1,    -1,    -1,    -1,    72,    -1,    -1,    -1,
  61051. -    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    67,    -1,
  61052. -    -1,    -1,    -1,    72,    35,    36,    37,    38,    39,    40,
  61053. -    41,    42,    43,    44,    45,    46,    47,    48,    49,    50,
  61054. -    51,    52,    30,    -1,    -1,    -1,    -1,    35,    36,    37,
  61055. -    -1,    39,    40,    41,    42,    43,    44,    45,    46,    47,
  61056. -    48,    49,    50,    51,    52,    35,    36,    37,    38,    39,
  61057. -    40,    41,    42,    43,    44,    45,    46,    47,    48,    49,
  61058. -    50,    51,    52,    35,    36,    37,    -1,    39,    40,    41,
  61059. -    42,    43,    44,    45,    46,    47,    48,    49,    50,    51,
  61060. -    52
  61061. -};
  61062. -/* -*-C-*-  Note some compilers choke on comments on `#line' lines.  */
  61063. -#line 3 "/usr/local/lib/bison.simple"
  61064. -
  61065. -/* Skeleton output parser for bison,
  61066. -   Copyright (C) 1984, 1989, 1990 Bob Corbett and Richard Stallman
  61067. -
  61068. -   This program is free software; you can redistribute it and/or modify
  61069. -   it under the terms of the GNU General Public License as published by
  61070. -   the Free Software Foundation; either version 1, or (at your option)
  61071. -   any later version.
  61072. -
  61073. -   This program is distributed in the hope that it will be useful,
  61074. -   but WITHOUT ANY WARRANTY; without even the implied warranty of
  61075. -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  61076. -   GNU General Public License for more details.
  61077. -
  61078. -   You should have received a copy of the GNU General Public License
  61079. -   along with this program; if not, write to the Free Software
  61080. -   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  61081. -
  61082. -
  61083. -#ifndef alloca
  61084. -#ifdef __GNUC__
  61085. -#define alloca __builtin_alloca
  61086. -#else /* not GNU C.  */
  61087. -#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi)
  61088. -#include <alloca.h>
  61089. -#else /* not sparc */
  61090. -#if defined (MSDOS) && !defined (__TURBOC__)
  61091. -#include <malloc.h>
  61092. -#else /* not MSDOS, or __TURBOC__ */
  61093. -#if defined(_AIX)
  61094. -#include <malloc.h>
  61095. - #pragma alloca
  61096. -#else /* not MSDOS, __TURBOC__, or _AIX */
  61097. -#ifdef __hpux
  61098. -#ifdef __cplusplus
  61099. -extern "C" {
  61100. -void *alloca (unsigned int);
  61101. -};
  61102. -#else /* not __cplusplus */
  61103. -void *alloca ();
  61104. -#endif /* not __cplusplus */
  61105. -#endif /* __hpux */
  61106. -#endif /* not _AIX */
  61107. -#endif /* not MSDOS, or __TURBOC__ */
  61108. -#endif /* not sparc.  */
  61109. -#endif /* not GNU C.  */
  61110. -#endif /* alloca not defined.  */
  61111. -
  61112. -/* This is the parser code that is written into each bison parser
  61113. -  when the %semantic_parser declaration is not specified in the grammar.
  61114. -  It was written by Richard Stallman by simplifying the hairy parser
  61115. -  used when %semantic_parser is specified.  */
  61116. -
  61117. -/* Note: there must be only one dollar sign in this file.
  61118. -   It is replaced by the list of actions, each action
  61119. -   as one case of the switch.  */
  61120. -
  61121. -#define yyerrok        (yyerrstatus = 0)
  61122. -#define yyclearin    (yychar = YYEMPTY)
  61123. -#define YYEMPTY        -2
  61124. -#define YYEOF        0
  61125. -#define YYACCEPT    return(0)
  61126. -#define YYABORT     return(1)
  61127. -#define YYERROR        goto yyerrlab1
  61128. -/* Like YYERROR except do call yyerror.
  61129. -   This remains here temporarily to ease the
  61130. -   transition to the new meaning of YYERROR, for GCC.
  61131. -   Once GCC version 2 has supplanted version 1, this can go.  */
  61132. -#define YYFAIL        goto yyerrlab
  61133. -#define YYRECOVERING()  (!!yyerrstatus)
  61134. -#define YYBACKUP(token, value) \
  61135. -do                                \
  61136. -  if (yychar == YYEMPTY && yylen == 1)                \
  61137. -    { yychar = (token), yylval = (value);            \
  61138. -      yychar1 = YYTRANSLATE (yychar);                \
  61139. -      YYPOPSTACK;                        \
  61140. -      goto yybackup;                        \
  61141. -    }                                \
  61142. -  else                                \
  61143. -    { yyerror ("syntax error: cannot back up"); YYERROR; }    \
  61144. -while (0)
  61145. -
  61146. -#define YYTERROR    1
  61147. -#define YYERRCODE    256
  61148. -
  61149. -#ifndef YYPURE
  61150. -#define YYLEX        yylex()
  61151. -#endif
  61152. -
  61153. -#ifdef YYPURE
  61154. -#ifdef YYLSP_NEEDED
  61155. -#define YYLEX        yylex(&yylval, &yylloc)
  61156. -#else
  61157. -#define YYLEX        yylex(&yylval)
  61158. -#endif
  61159. -#endif
  61160. -
  61161. -/* If nonreentrant, generate the variables here */
  61162. -
  61163. -#ifndef YYPURE
  61164. -
  61165. -int    yychar;            /*  the lookahead symbol        */
  61166. -YYSTYPE    yylval;            /*  the semantic value of the        */
  61167. -                /*  lookahead symbol            */
  61168. -
  61169. -#ifdef YYLSP_NEEDED
  61170. -YYLTYPE yylloc;            /*  location data for the lookahead    */
  61171. -                /*  symbol                */
  61172. -#endif
  61173. -
  61174. -int yynerrs;            /*  number of parse errors so far       */
  61175. -#endif  /* not YYPURE */
  61176. -
  61177. -#if YYDEBUG != 0
  61178. -int yydebug;            /*  nonzero means print parse trace    */
  61179. -/* Since this is uninitialized, it does not stop multiple parsers
  61180. -   from coexisting.  */
  61181. -#endif
  61182. -
  61183. -/*  YYINITDEPTH indicates the initial size of the parser's stacks    */
  61184. -
  61185. -#ifndef    YYINITDEPTH
  61186. -#define YYINITDEPTH 200
  61187. -#endif
  61188. -
  61189. -/*  YYMAXDEPTH is the maximum size the stacks can grow to
  61190. -    (effective only if the built-in stack extension method is used).  */
  61191. -
  61192. -#if YYMAXDEPTH == 0
  61193. -#undef YYMAXDEPTH
  61194. -#endif
  61195. -
  61196. -#ifndef YYMAXDEPTH
  61197. -#define YYMAXDEPTH 10000
  61198. -#endif
  61199. -
  61200. -/* Prevent warning if -Wstrict-prototypes.  */
  61201. -#ifdef __GNUC__
  61202. -int yyparse (void);
  61203. -#endif
  61204. -
  61205. -#if __GNUC__ > 1        /* GNU C and GNU C++ define this.  */
  61206. -#define __yy_bcopy(FROM,TO,COUNT)    __builtin_memcpy(TO,FROM,COUNT)
  61207. -#else                /* not GNU C or C++ */
  61208. -#ifndef __cplusplus
  61209. -
  61210. -/* This is the most reliable way to avoid incompatibilities
  61211. -   in available built-in functions on various systems.  */
  61212. -static void
  61213. -__yy_bcopy (from, to, count)
  61214. -     char *from;
  61215. -     char *to;
  61216. -     int count;
  61217. -{
  61218. -  register char *f = from;
  61219. -  register char *t = to;
  61220. -  register int i = count;
  61221. -
  61222. -  while (i-- > 0)
  61223. -    *t++ = *f++;
  61224. -}
  61225. -
  61226. -#else /* __cplusplus */
  61227. -
  61228. -/* This is the most reliable way to avoid incompatibilities
  61229. -   in available built-in functions on various systems.  */
  61230. -static void
  61231. -__yy_bcopy (char *from, char *to, int count)
  61232. -{
  61233. -  register char *f = from;
  61234. -  register char *t = to;
  61235. -  register int i = count;
  61236. -
  61237. -  while (i-- > 0)
  61238. -    *t++ = *f++;
  61239. -}
  61240. -
  61241. -#endif
  61242. -#endif
  61243. -
  61244. -#line 184 "/usr/local/lib/bison.simple"
  61245. -
  61246. -/* The user can define YYPARSE_PARAM as the name of an argument to be passed
  61247. -   into yyparse.  The argument should have type void *.
  61248. -   It should actually point to an object.
  61249. -   Grammar actions can access the variable by casting it
  61250. -   to the proper pointer type.  */
  61251. -
  61252. -#ifdef YYPARSE_PARAM
  61253. -#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM;
  61254. -#else
  61255. -#define YYPARSE_PARAM
  61256. -#define YYPARSE_PARAM_DECL
  61257. -#endif
  61258. -
  61259. -int
  61260. -yyparse(YYPARSE_PARAM)
  61261. -     YYPARSE_PARAM_DECL
  61262. -{
  61263. -  register int yystate;
  61264. -  register int yyn;
  61265. -  register short *yyssp;
  61266. -  register YYSTYPE *yyvsp;
  61267. -  int yyerrstatus;    /*  number of tokens to shift before error messages enabled */
  61268. -  int yychar1 = 0;        /*  lookahead token as an internal (translated) token number */
  61269. -
  61270. -  short    yyssa[YYINITDEPTH];    /*  the state stack            */
  61271. -  YYSTYPE yyvsa[YYINITDEPTH];    /*  the semantic value stack        */
  61272. -
  61273. -  short *yyss = yyssa;        /*  refer to the stacks thru separate pointers */
  61274. -  YYSTYPE *yyvs = yyvsa;    /*  to allow yyoverflow to reallocate them elsewhere */
  61275. -
  61276. -#ifdef YYLSP_NEEDED
  61277. -  YYLTYPE yylsa[YYINITDEPTH];    /*  the location stack            */
  61278. -  YYLTYPE *yyls = yylsa;
  61279. -  YYLTYPE *yylsp;
  61280. -
  61281. -#define YYPOPSTACK   (yyvsp--, yyssp--, yylsp--)
  61282. -#else
  61283. -#define YYPOPSTACK   (yyvsp--, yyssp--)
  61284. -#endif
  61285. -
  61286. -  int yystacksize = YYINITDEPTH;
  61287. -
  61288. -#ifdef YYPURE
  61289. -  int yychar;
  61290. -  YYSTYPE yylval;
  61291. -  int yynerrs;
  61292. -#ifdef YYLSP_NEEDED
  61293. -  YYLTYPE yylloc;
  61294. -#endif
  61295. -#endif
  61296. -
  61297. -  YYSTYPE yyval;        /*  the variable used to return        */
  61298. -                /*  semantic values from the action    */
  61299. -                /*  routines                */
  61300. -
  61301. -  int yylen;
  61302. -
  61303. -#if YYDEBUG != 0
  61304. -  if (yydebug)
  61305. -    fprintf(stderr, "Starting parse\n");
  61306. -#endif
  61307. -
  61308. -  yystate = 0;
  61309. -  yyerrstatus = 0;
  61310. -  yynerrs = 0;
  61311. -  yychar = YYEMPTY;        /* Cause a token to be read.  */
  61312. -
  61313. -  /* Initialize stack pointers.
  61314. -     Waste one element of value and location stack
  61315. -     so that they stay on the same level as the state stack.
  61316. -     The wasted elements are never initialized.  */
  61317. -
  61318. -  yyssp = yyss - 1;
  61319. -  yyvsp = yyvs;
  61320. -#ifdef YYLSP_NEEDED
  61321. -  yylsp = yyls;
  61322. -#endif
  61323. -
  61324. -/* Push a new state, which is found in  yystate  .  */
  61325. -/* In all cases, when you get here, the value and location stacks
  61326. -   have just been pushed. so pushing a state here evens the stacks.  */
  61327. -yynewstate:
  61328. -
  61329. -  *++yyssp = yystate;
  61330. -
  61331. -  if (yyssp >= yyss + yystacksize - 1)
  61332. -    {
  61333. -      /* Give user a chance to reallocate the stack */
  61334. -      /* Use copies of these so that the &'s don't force the real ones into memory. */
  61335. -      YYSTYPE *yyvs1 = yyvs;
  61336. -      short *yyss1 = yyss;
  61337. -#ifdef YYLSP_NEEDED
  61338. -      YYLTYPE *yyls1 = yyls;
  61339. -#endif
  61340. -
  61341. -      /* Get the current used size of the three stacks, in elements.  */
  61342. -      int size = yyssp - yyss + 1;
  61343. -
  61344. -#ifdef yyoverflow
  61345. -      /* Each stack pointer address is followed by the size of
  61346. -     the data in use in that stack, in bytes.  */
  61347. -#ifdef YYLSP_NEEDED
  61348. -      /* This used to be a conditional around just the two extra args,
  61349. -     but that might be undefined if yyoverflow is a macro.  */
  61350. -      yyoverflow("parser stack overflow",
  61351. -         &yyss1, size * sizeof (*yyssp),
  61352. -         &yyvs1, size * sizeof (*yyvsp),
  61353. -         &yyls1, size * sizeof (*yylsp),
  61354. -         &yystacksize);
  61355. -#else
  61356. -      yyoverflow("parser stack overflow",
  61357. -         &yyss1, size * sizeof (*yyssp),
  61358. -         &yyvs1, size * sizeof (*yyvsp),
  61359. -         &yystacksize);
  61360. -#endif
  61361. -
  61362. -      yyss = yyss1; yyvs = yyvs1;
  61363. -#ifdef YYLSP_NEEDED
  61364. -      yyls = yyls1;
  61365. -#endif
  61366. -#else /* no yyoverflow */
  61367. -      /* Extend the stack our own way.  */
  61368. -      if (yystacksize >= YYMAXDEPTH)
  61369. -    {
  61370. -      yyerror("parser stack overflow");
  61371. -      return 2;
  61372. -    }
  61373. -      yystacksize *= 2;
  61374. -      if (yystacksize > YYMAXDEPTH)
  61375. -    yystacksize = YYMAXDEPTH;
  61376. -      yyss = (short *) alloca (yystacksize * sizeof (*yyssp));
  61377. -      __yy_bcopy ((char *)yyss1, (char *)yyss, size * sizeof (*yyssp));
  61378. -      yyvs = (YYSTYPE *) alloca (yystacksize * sizeof (*yyvsp));
  61379. -      __yy_bcopy ((char *)yyvs1, (char *)yyvs, size * sizeof (*yyvsp));
  61380. -#ifdef YYLSP_NEEDED
  61381. -      yyls = (YYLTYPE *) alloca (yystacksize * sizeof (*yylsp));
  61382. -      __yy_bcopy ((char *)yyls1, (char *)yyls, size * sizeof (*yylsp));
  61383. -#endif
  61384. -#endif /* no yyoverflow */
  61385. -
  61386. -      yyssp = yyss + size - 1;
  61387. -      yyvsp = yyvs + size - 1;
  61388. -#ifdef YYLSP_NEEDED
  61389. -      yylsp = yyls + size - 1;
  61390. -#endif
  61391. -
  61392. -#if YYDEBUG != 0
  61393. -      if (yydebug)
  61394. -    fprintf(stderr, "Stack size increased to %d\n", yystacksize);
  61395. -#endif
  61396. -
  61397. -      if (yyssp >= yyss + yystacksize - 1)
  61398. -    YYABORT;
  61399. -    }
  61400. -
  61401. -#if YYDEBUG != 0
  61402. -  if (yydebug)
  61403. -    fprintf(stderr, "Entering state %d\n", yystate);
  61404. -#endif
  61405. -
  61406. -  goto yybackup;
  61407. - yybackup:
  61408. -
  61409. -/* Do appropriate processing given the current state.  */
  61410. -/* Read a lookahead token if we need one and don't already have one.  */
  61411. -/* yyresume: */
  61412. -
  61413. -  /* First try to decide what to do without reference to lookahead token.  */
  61414. -
  61415. -  yyn = yypact[yystate];
  61416. -  if (yyn == YYFLAG)
  61417. -    goto yydefault;
  61418. -
  61419. -  /* Not known => get a lookahead token if don't already have one.  */
  61420. -
  61421. -  /* yychar is either YYEMPTY or YYEOF
  61422. -     or a valid token in external form.  */
  61423. -
  61424. -  if (yychar == YYEMPTY)
  61425. -    {
  61426. -#if YYDEBUG != 0
  61427. -      if (yydebug)
  61428. -    fprintf(stderr, "Reading a token: ");
  61429. -#endif
  61430. -      yychar = YYLEX;
  61431. -    }
  61432. -
  61433. -  /* Convert token to internal form (in yychar1) for indexing tables with */
  61434. -
  61435. -  if (yychar <= 0)        /* This means end of input. */
  61436. -    {
  61437. -      yychar1 = 0;
  61438. -      yychar = YYEOF;        /* Don't call YYLEX any more */
  61439. -
  61440. -#if YYDEBUG != 0
  61441. -      if (yydebug)
  61442. -    fprintf(stderr, "Now at end of input.\n");
  61443. -#endif
  61444. -    }
  61445. -  else
  61446. -    {
  61447. -      yychar1 = YYTRANSLATE(yychar);
  61448. -
  61449. -#if YYDEBUG != 0
  61450. -      if (yydebug)
  61451. -    {
  61452. -      fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]);
  61453. -      /* Give the individual parser a way to print the precise meaning
  61454. -         of a token, for further debugging info.  */
  61455. -#ifdef YYPRINT
  61456. -      YYPRINT (stderr, yychar, yylval);
  61457. -#endif
  61458. -      fprintf (stderr, ")\n");
  61459. -    }
  61460. -#endif
  61461. -    }
  61462. -
  61463. -  yyn += yychar1;
  61464. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1)
  61465. -    goto yydefault;
  61466. -
  61467. -  yyn = yytable[yyn];
  61468. -
  61469. -  /* yyn is what to do for this token type in this state.
  61470. -     Negative => reduce, -yyn is rule number.
  61471. -     Positive => shift, yyn is new state.
  61472. -       New state is final state => don't bother to shift,
  61473. -       just return success.
  61474. -     0, or most negative number => error.  */
  61475. -
  61476. -  if (yyn < 0)
  61477. -    {
  61478. -      if (yyn == YYFLAG)
  61479. -    goto yyerrlab;
  61480. -      yyn = -yyn;
  61481. -      goto yyreduce;
  61482. -    }
  61483. -  else if (yyn == 0)
  61484. -    goto yyerrlab;
  61485. -
  61486. -  if (yyn == YYFINAL)
  61487. -    YYACCEPT;
  61488. -
  61489. -  /* Shift the lookahead token.  */
  61490. -
  61491. -#if YYDEBUG != 0
  61492. -  if (yydebug)
  61493. -    fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]);
  61494. -#endif
  61495. -
  61496. -  /* Discard the token being shifted unless it is eof.  */
  61497. -  if (yychar != YYEOF)
  61498. -    yychar = YYEMPTY;
  61499. -
  61500. -  *++yyvsp = yylval;
  61501. -#ifdef YYLSP_NEEDED
  61502. -  *++yylsp = yylloc;
  61503. -#endif
  61504. -
  61505. -  /* count tokens shifted since error; after three, turn off error status.  */
  61506. -  if (yyerrstatus) yyerrstatus--;
  61507. -
  61508. -  yystate = yyn;
  61509. -  goto yynewstate;
  61510. -
  61511. -/* Do the default action for the current state.  */
  61512. -yydefault:
  61513. -
  61514. -  yyn = yydefact[yystate];
  61515. -  if (yyn == 0)
  61516. -    goto yyerrlab;
  61517. -
  61518. -/* Do a reduction.  yyn is the number of a rule to reduce with.  */
  61519. -yyreduce:
  61520. -  yylen = yyr2[yyn];
  61521. -  if (yylen > 0)
  61522. -    yyval = yyvsp[1-yylen]; /* implement default value of the action */
  61523. -
  61524. -#if YYDEBUG != 0
  61525. -  if (yydebug)
  61526. -    {
  61527. -      int i;
  61528. -
  61529. -      fprintf (stderr, "Reducing via rule %d (line %d), ",
  61530. -           yyn, yyrline[yyn]);
  61531. -
  61532. -      /* Print the symbols being reduced, and their result.  */
  61533. -      for (i = yyprhs[yyn]; yyrhs[i] > 0; i++)
  61534. -    fprintf (stderr, "%s ", yytname[yyrhs[i]]);
  61535. -      fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]);
  61536. -    }
  61537. -#endif
  61538. -
  61539. -
  61540. -  switch (yyn) {
  61541. -
  61542. -case 1:
  61543. -#line 233 "objc-parse.y"
  61544. -{ if (pedantic)
  61545. -            pedwarn ("ANSI C forbids an empty source file");
  61546. -          finish_file ();
  61547. -        ;
  61548. -    break;}
  61549. -case 2:
  61550. -#line 238 "objc-parse.y"
  61551. -{
  61552. -          /* In case there were missing closebraces,
  61553. -             get us back to the global binding level.  */
  61554. -          while (! global_bindings_p ())
  61555. -            poplevel (0, 0, 0);
  61556. -          finish_file ();
  61557. -        ;
  61558. -    break;}
  61559. -case 3:
  61560. -#line 252 "objc-parse.y"
  61561. -{yyval.ttype = NULL_TREE; ;
  61562. -    break;}
  61563. -case 5:
  61564. -#line 253 "objc-parse.y"
  61565. -{yyval.ttype = NULL_TREE; ;
  61566. -    break;}
  61567. -case 10:
  61568. -#line 261 "objc-parse.y"
  61569. -{ STRIP_NOPS (yyvsp[-2].ttype);
  61570. -          if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR
  61571. -               && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST)
  61572. -              || TREE_CODE (yyvsp[-2].ttype) == STRING_CST)
  61573. -            assemble_asm (yyvsp[-2].ttype);
  61574. -          else
  61575. -            error ("argument of `asm' is not a constant string"); ;
  61576. -    break;}
  61577. -case 11:
  61578. -#line 272 "objc-parse.y"
  61579. -{ if (pedantic)
  61580. -            error ("ANSI C forbids data definition with no type or storage class");
  61581. -          else if (!flag_traditional)
  61582. -            warning ("data definition has no type or storage class"); 
  61583. -
  61584. -          current_declspecs = TREE_VALUE (declspec_stack);
  61585. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61586. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61587. -          resume_momentary (yyvsp[-2].itype); ;
  61588. -    break;}
  61589. -case 12:
  61590. -#line 282 "objc-parse.y"
  61591. -{ current_declspecs = TREE_VALUE (declspec_stack);
  61592. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61593. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61594. -          resume_momentary (yyvsp[-2].itype); ;
  61595. -    break;}
  61596. -case 13:
  61597. -#line 287 "objc-parse.y"
  61598. -{ current_declspecs = TREE_VALUE (declspec_stack);
  61599. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61600. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61601. -          resume_momentary (yyvsp[-2].itype);  ;
  61602. -    break;}
  61603. -case 14:
  61604. -#line 292 "objc-parse.y"
  61605. -{ pedwarn ("empty declaration"); ;
  61606. -    break;}
  61607. -case 15:
  61608. -#line 294 "objc-parse.y"
  61609. -{ shadow_tag (yyvsp[-1].ttype); ;
  61610. -    break;}
  61611. -case 18:
  61612. -#line 298 "objc-parse.y"
  61613. -{ if (pedantic)
  61614. -            pedwarn ("ANSI C does not allow extra `;' outside of a function"); ;
  61615. -    break;}
  61616. -case 19:
  61617. -#line 304 "objc-parse.y"
  61618. -{ if (! start_function (yyvsp[-2].ttype, yyvsp[0].ttype, prefix_attributes,
  61619. -                    NULL_TREE, 0))
  61620. -            YYERROR1;
  61621. -          reinit_parse_for_function (); ;
  61622. -    break;}
  61623. -case 20:
  61624. -#line 309 "objc-parse.y"
  61625. -{ store_parm_decls (); ;
  61626. -    break;}
  61627. -case 21:
  61628. -#line 311 "objc-parse.y"
  61629. -{ finish_function (0); 
  61630. -          current_declspecs = TREE_VALUE (declspec_stack);
  61631. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61632. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61633. -          resume_momentary (yyvsp[-5].itype); ;
  61634. -    break;}
  61635. -case 22:
  61636. -#line 317 "objc-parse.y"
  61637. -{ current_declspecs = TREE_VALUE (declspec_stack);
  61638. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61639. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61640. -          resume_momentary (yyvsp[-2].itype); ;
  61641. -    break;}
  61642. -case 23:
  61643. -#line 322 "objc-parse.y"
  61644. -{ if (! start_function (yyvsp[-2].ttype, yyvsp[0].ttype, prefix_attributes,
  61645. -                    NULL_TREE, 0))
  61646. -            YYERROR1;
  61647. -          reinit_parse_for_function (); ;
  61648. -    break;}
  61649. -case 24:
  61650. -#line 327 "objc-parse.y"
  61651. -{ store_parm_decls (); ;
  61652. -    break;}
  61653. -case 25:
  61654. -#line 329 "objc-parse.y"
  61655. -{ finish_function (0); 
  61656. -          current_declspecs = TREE_VALUE (declspec_stack);
  61657. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61658. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61659. -          resume_momentary (yyvsp[-5].itype); ;
  61660. -    break;}
  61661. -case 26:
  61662. -#line 335 "objc-parse.y"
  61663. -{ current_declspecs = TREE_VALUE (declspec_stack);
  61664. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61665. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61666. -          resume_momentary (yyvsp[-2].itype); ;
  61667. -    break;}
  61668. -case 27:
  61669. -#line 340 "objc-parse.y"
  61670. -{ if (! start_function (NULL_TREE, yyvsp[0].ttype,
  61671. -                    prefix_attributes, NULL_TREE, 0))
  61672. -            YYERROR1;
  61673. -          reinit_parse_for_function (); ;
  61674. -    break;}
  61675. -case 28:
  61676. -#line 345 "objc-parse.y"
  61677. -{ store_parm_decls (); ;
  61678. -    break;}
  61679. -case 29:
  61680. -#line 347 "objc-parse.y"
  61681. -{ finish_function (0); 
  61682. -          current_declspecs = TREE_VALUE (declspec_stack);
  61683. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61684. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61685. -          resume_momentary (yyvsp[-5].itype); ;
  61686. -    break;}
  61687. -case 30:
  61688. -#line 353 "objc-parse.y"
  61689. -{ current_declspecs = TREE_VALUE (declspec_stack);
  61690. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  61691. -          declspec_stack = TREE_CHAIN (declspec_stack);
  61692. -          resume_momentary (yyvsp[-2].itype); ;
  61693. -    break;}
  61694. -case 35:
  61695. -#line 367 "objc-parse.y"
  61696. -{ yyval.code = ADDR_EXPR; ;
  61697. -    break;}
  61698. -case 36:
  61699. -#line 369 "objc-parse.y"
  61700. -{ yyval.code = NEGATE_EXPR; ;
  61701. -    break;}
  61702. -case 37:
  61703. -#line 371 "objc-parse.y"
  61704. -{ yyval.code = CONVERT_EXPR; ;
  61705. -    break;}
  61706. -case 38:
  61707. -#line 373 "objc-parse.y"
  61708. -{ yyval.code = PREINCREMENT_EXPR; ;
  61709. -    break;}
  61710. -case 39:
  61711. -#line 375 "objc-parse.y"
  61712. -{ yyval.code = PREDECREMENT_EXPR; ;
  61713. -    break;}
  61714. -case 40:
  61715. -#line 377 "objc-parse.y"
  61716. -{ yyval.code = BIT_NOT_EXPR; ;
  61717. -    break;}
  61718. -case 41:
  61719. -#line 379 "objc-parse.y"
  61720. -{ yyval.code = TRUTH_NOT_EXPR; ;
  61721. -    break;}
  61722. -case 42:
  61723. -#line 383 "objc-parse.y"
  61724. -{ yyval.ttype = build_compound_expr (yyvsp[0].ttype); ;
  61725. -    break;}
  61726. -case 43:
  61727. -#line 388 "objc-parse.y"
  61728. -{ yyval.ttype = NULL_TREE; ;
  61729. -    break;}
  61730. -case 45:
  61731. -#line 394 "objc-parse.y"
  61732. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  61733. -    break;}
  61734. -case 46:
  61735. -#line 396 "objc-parse.y"
  61736. -{ chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  61737. -    break;}
  61738. -case 48:
  61739. -#line 402 "objc-parse.y"
  61740. -{ yyval.ttype = build_indirect_ref (yyvsp[0].ttype, "unary *"); ;
  61741. -    break;}
  61742. -case 49:
  61743. -#line 405 "objc-parse.y"
  61744. -{ yyvsp[0].itype = pedantic;
  61745. -          pedantic = 0; ;
  61746. -    break;}
  61747. -case 50:
  61748. -#line 408 "objc-parse.y"
  61749. -{ yyval.ttype = yyvsp[0].ttype;
  61750. -          pedantic = yyvsp[-2].itype; ;
  61751. -    break;}
  61752. -case 51:
  61753. -#line 411 "objc-parse.y"
  61754. -{ yyval.ttype = build_unary_op (yyvsp[-1].code, yyvsp[0].ttype, 0);
  61755. -          overflow_warning (yyval.ttype); ;
  61756. -    break;}
  61757. -case 52:
  61758. -#line 415 "objc-parse.y"
  61759. -{ tree label = lookup_label (yyvsp[0].ttype);
  61760. -          if (pedantic)
  61761. -            pedwarn ("ANSI C forbids `&&'");
  61762. -          if (label == 0)
  61763. -            yyval.ttype = null_pointer_node;
  61764. -          else
  61765. -            {
  61766. -              TREE_USED (label) = 1;
  61767. -              yyval.ttype = build1 (ADDR_EXPR, ptr_type_node, label);
  61768. -              TREE_CONSTANT (yyval.ttype) = 1;
  61769. -            }
  61770. -        ;
  61771. -    break;}
  61772. -case 53:
  61773. -#line 443 "objc-parse.y"
  61774. -{ if (TREE_CODE (yyvsp[0].ttype) == COMPONENT_REF
  61775. -              && DECL_BIT_FIELD (TREE_OPERAND (yyvsp[0].ttype, 1)))
  61776. -            error ("`sizeof' applied to a bit-field");
  61777. -          yyval.ttype = c_sizeof (TREE_TYPE (yyvsp[0].ttype)); ;
  61778. -    break;}
  61779. -case 54:
  61780. -#line 448 "objc-parse.y"
  61781. -{ yyval.ttype = c_sizeof (groktypename (yyvsp[-1].ttype)); ;
  61782. -    break;}
  61783. -case 55:
  61784. -#line 450 "objc-parse.y"
  61785. -{ yyval.ttype = c_alignof_expr (yyvsp[0].ttype); ;
  61786. -    break;}
  61787. -case 56:
  61788. -#line 452 "objc-parse.y"
  61789. -{ yyval.ttype = c_alignof (groktypename (yyvsp[-1].ttype)); ;
  61790. -    break;}
  61791. -case 57:
  61792. -#line 454 "objc-parse.y"
  61793. -{ yyval.ttype = build_unary_op (REALPART_EXPR, yyvsp[0].ttype, 0); ;
  61794. -    break;}
  61795. -case 58:
  61796. -#line 456 "objc-parse.y"
  61797. -{ yyval.ttype = build_unary_op (IMAGPART_EXPR, yyvsp[0].ttype, 0); ;
  61798. -    break;}
  61799. -case 60:
  61800. -#line 462 "objc-parse.y"
  61801. -{ tree type = groktypename (yyvsp[-2].ttype);
  61802. -          yyval.ttype = build_c_cast (type, yyvsp[0].ttype); ;
  61803. -    break;}
  61804. -case 61:
  61805. -#line 465 "objc-parse.y"
  61806. -{ start_init (NULL_TREE, NULL, 0);
  61807. -          yyvsp[-2].ttype = groktypename (yyvsp[-2].ttype);
  61808. -          really_start_incremental_init (yyvsp[-2].ttype); ;
  61809. -    break;}
  61810. -case 62:
  61811. -#line 469 "objc-parse.y"
  61812. -{ char *name;
  61813. -          tree result = pop_init_level (0);
  61814. -          tree type = yyvsp[-5].ttype;
  61815. -          finish_init ();
  61816. -
  61817. -          if (pedantic)
  61818. -            pedwarn ("ANSI C forbids constructor expressions");
  61819. -          if (TYPE_NAME (type) != 0)
  61820. -            {
  61821. -              if (TREE_CODE (TYPE_NAME (type)) == IDENTIFIER_NODE)
  61822. -            name = IDENTIFIER_POINTER (TYPE_NAME (type));
  61823. -              else
  61824. -            name = IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type)));
  61825. -            }
  61826. -          else
  61827. -            name = "";
  61828. -          yyval.ttype = result;
  61829. -          if (TREE_CODE (type) == ARRAY_TYPE && TYPE_SIZE (type) == 0)
  61830. -            {
  61831. -              int failure = complete_array_type (type, yyval.ttype, 1);
  61832. -              if (failure)
  61833. -            abort ();
  61834. -            }
  61835. -        ;
  61836. -    break;}
  61837. -case 64:
  61838. -#line 498 "objc-parse.y"
  61839. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61840. -    break;}
  61841. -case 65:
  61842. -#line 500 "objc-parse.y"
  61843. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61844. -    break;}
  61845. -case 66:
  61846. -#line 502 "objc-parse.y"
  61847. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61848. -    break;}
  61849. -case 67:
  61850. -#line 504 "objc-parse.y"
  61851. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61852. -    break;}
  61853. -case 68:
  61854. -#line 506 "objc-parse.y"
  61855. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61856. -    break;}
  61857. -case 69:
  61858. -#line 508 "objc-parse.y"
  61859. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61860. -    break;}
  61861. -case 70:
  61862. -#line 510 "objc-parse.y"
  61863. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61864. -    break;}
  61865. -case 71:
  61866. -#line 512 "objc-parse.y"
  61867. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61868. -    break;}
  61869. -case 72:
  61870. -#line 514 "objc-parse.y"
  61871. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61872. -    break;}
  61873. -case 73:
  61874. -#line 516 "objc-parse.y"
  61875. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61876. -    break;}
  61877. -case 74:
  61878. -#line 518 "objc-parse.y"
  61879. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61880. -    break;}
  61881. -case 75:
  61882. -#line 520 "objc-parse.y"
  61883. -{ yyval.ttype = parser_build_binary_op (yyvsp[-1].code, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61884. -    break;}
  61885. -case 76:
  61886. -#line 522 "objc-parse.y"
  61887. -{ yyval.ttype = parser_build_binary_op (TRUTH_ANDIF_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61888. -    break;}
  61889. -case 77:
  61890. -#line 524 "objc-parse.y"
  61891. -{ yyval.ttype = parser_build_binary_op (TRUTH_ORIF_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61892. -    break;}
  61893. -case 78:
  61894. -#line 526 "objc-parse.y"
  61895. -{ yyval.ttype = build_conditional_expr (yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  61896. -    break;}
  61897. -case 79:
  61898. -#line 528 "objc-parse.y"
  61899. -{ yyval.ttype = build_modify_expr (yyvsp[-2].ttype, NOP_EXPR, yyvsp[0].ttype);
  61900. -          C_SET_EXP_ORIGINAL_CODE (yyval.ttype, MODIFY_EXPR); ;
  61901. -    break;}
  61902. -case 80:
  61903. -#line 531 "objc-parse.y"
  61904. -{ yyval.ttype = build_modify_expr (yyvsp[-2].ttype, yyvsp[-1].code, yyvsp[0].ttype);
  61905. -          /* This inhibits warnings in truthvalue_conversion.  */
  61906. -          C_SET_EXP_ORIGINAL_CODE (yyval.ttype, ERROR_MARK); ;
  61907. -    break;}
  61908. -case 81:
  61909. -#line 538 "objc-parse.y"
  61910. -{
  61911. -          yyval.ttype = lastiddecl;
  61912. -          if (!yyval.ttype || yyval.ttype == error_mark_node)
  61913. -            {
  61914. -              if (yychar == YYEMPTY)
  61915. -            yychar = YYLEX;
  61916. -              if (yychar == '(')
  61917. -            {
  61918. -              tree decl;
  61919. -
  61920. -              if (objc_receiver_context
  61921. -                  && ! (objc_receiver_context
  61922. -                    && strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super")))
  61923. -                /* we have a message to super */
  61924. -                yyval.ttype = get_super_receiver ();
  61925. -              else if (objc_method_context
  61926. -                   && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype)))
  61927. -                {
  61928. -                  if (is_private (decl))
  61929. -                yyval.ttype = error_mark_node;
  61930. -                  else
  61931. -                yyval.ttype = build_ivar_reference (yyvsp[0].ttype);
  61932. -                }
  61933. -              else
  61934. -                {
  61935. -                  /* Ordinary implicit function declaration.  */
  61936. -                  yyval.ttype = implicitly_declare (yyvsp[0].ttype);
  61937. -                  assemble_external (yyval.ttype);
  61938. -                  TREE_USED (yyval.ttype) = 1;
  61939. -                }
  61940. -            }
  61941. -              else if (current_function_decl == 0)
  61942. -            {
  61943. -              error ("`%s' undeclared here (not in a function)",
  61944. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  61945. -              yyval.ttype = error_mark_node;
  61946. -            }
  61947. -              else
  61948. -            {
  61949. -              tree decl;
  61950. -
  61951. -                  if (objc_receiver_context
  61952. -                  && ! strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super"))
  61953. -                /* we have a message to super */
  61954. -                yyval.ttype = get_super_receiver ();
  61955. -              else if (objc_method_context
  61956. -                   && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype)))
  61957. -                {
  61958. -                  if (is_private (decl))
  61959. -                yyval.ttype = error_mark_node;
  61960. -                  else
  61961. -                yyval.ttype = build_ivar_reference (yyvsp[0].ttype);
  61962. -                }
  61963. -              else
  61964. -                {
  61965. -                  if (IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) != error_mark_node
  61966. -                  || IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) != current_function_decl)
  61967. -                {
  61968. -                  error ("`%s' undeclared (first use this function)",
  61969. -                     IDENTIFIER_POINTER (yyvsp[0].ttype));
  61970. -
  61971. -                  if (! undeclared_variable_notice)
  61972. -                    {
  61973. -                      error ("(Each undeclared identifier is reported only once");
  61974. -                      error ("for each function it appears in.)");
  61975. -                      undeclared_variable_notice = 1;
  61976. -                    }
  61977. -                }
  61978. -                  yyval.ttype = error_mark_node;
  61979. -                  /* Prevent repeated error messages.  */
  61980. -                  IDENTIFIER_GLOBAL_VALUE (yyvsp[0].ttype) = error_mark_node;
  61981. -                  IDENTIFIER_ERROR_LOCUS (yyvsp[0].ttype) = current_function_decl;
  61982. -                }
  61983. -            }
  61984. -            }
  61985. -          else if (TREE_TYPE (yyval.ttype) == error_mark_node)
  61986. -            yyval.ttype = error_mark_node;
  61987. -          else if (C_DECL_ANTICIPATED (yyval.ttype))
  61988. -            {
  61989. -              /* The first time we see a build-in function used,
  61990. -             if it has not been declared.  */
  61991. -              C_DECL_ANTICIPATED (yyval.ttype) = 0;
  61992. -              if (yychar == YYEMPTY)
  61993. -            yychar = YYLEX;
  61994. -              if (yychar == '(')
  61995. -            {
  61996. -              /* Omit the implicit declaration we
  61997. -                 would ordinarily do, so we don't lose
  61998. -                 the actual built in type.
  61999. -                 But print a diagnostic for the mismatch.  */
  62000. -              if (objc_method_context
  62001. -                  && is_ivar (objc_ivar_chain, yyvsp[0].ttype))
  62002. -                error ("Instance variable `%s' implicitly declared as function",
  62003. -                   IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  62004. -              else
  62005. -                if (TREE_CODE (yyval.ttype) != FUNCTION_DECL)
  62006. -                  error ("`%s' implicitly declared as function",
  62007. -                     IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  62008. -              else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE (yyval.ttype)))
  62009. -                    != TYPE_MODE (integer_type_node))
  62010. -                   && (TREE_TYPE (TREE_TYPE (yyval.ttype))
  62011. -                       != void_type_node))
  62012. -                pedwarn ("type mismatch in implicit declaration for built-in function `%s'",
  62013. -                     IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  62014. -              /* If it really returns void, change that to int.  */
  62015. -              if (TREE_TYPE (TREE_TYPE (yyval.ttype)) == void_type_node)
  62016. -                TREE_TYPE (yyval.ttype)
  62017. -                  = build_function_type (integer_type_node,
  62018. -                             TYPE_ARG_TYPES (TREE_TYPE (yyval.ttype)));
  62019. -            }
  62020. -              else
  62021. -            pedwarn ("built-in function `%s' used without declaration",
  62022. -                 IDENTIFIER_POINTER (DECL_NAME (yyval.ttype)));
  62023. -
  62024. -              /* Do what we would ordinarily do when a fn is used.  */
  62025. -              assemble_external (yyval.ttype);
  62026. -              TREE_USED (yyval.ttype) = 1;
  62027. -            }
  62028. -          else
  62029. -            {
  62030. -              assemble_external (yyval.ttype);
  62031. -              TREE_USED (yyval.ttype) = 1;
  62032. -              /* we have a definition - still check if iVariable */
  62033. -
  62034. -              if (!objc_receiver_context
  62035. -              || (objc_receiver_context
  62036. -                  && strcmp (IDENTIFIER_POINTER (yyvsp[0].ttype), "super")))
  62037. -                        {
  62038. -              tree decl;
  62039. -
  62040. -              if (objc_method_context
  62041. -                  && (decl = is_ivar (objc_ivar_chain, yyvsp[0].ttype)))
  62042. -                            {
  62043. -                              if (IDENTIFIER_LOCAL_VALUE (yyvsp[0].ttype))
  62044. -                                warning ("local declaration of `%s' hides instance variable",
  62045. -                                     IDENTIFIER_POINTER (yyvsp[0].ttype));
  62046. -                              else
  62047. -                 {
  62048. -                   if (is_private (decl))
  62049. -                     yyval.ttype = error_mark_node;
  62050. -                   else
  62051. -                     yyval.ttype = build_ivar_reference (yyvsp[0].ttype);
  62052. -                 }
  62053. -                            }
  62054. -            }
  62055. -                      else /* we have a message to super */
  62056. -                yyval.ttype = get_super_receiver ();
  62057. -            }
  62058. -
  62059. -          if (TREE_CODE (yyval.ttype) == CONST_DECL)
  62060. -            {
  62061. -              yyval.ttype = DECL_INITIAL (yyval.ttype);
  62062. -              /* This is to prevent an enum whose value is 0
  62063. -             from being considered a null pointer constant.  */
  62064. -              yyval.ttype = build1 (NOP_EXPR, TREE_TYPE (yyval.ttype), yyval.ttype);
  62065. -              TREE_CONSTANT (yyval.ttype) = 1;
  62066. -            }
  62067. -        ;
  62068. -    break;}
  62069. -case 83:
  62070. -#line 698 "objc-parse.y"
  62071. -{ yyval.ttype = combine_strings (yyvsp[0].ttype); ;
  62072. -    break;}
  62073. -case 84:
  62074. -#line 700 "objc-parse.y"
  62075. -{ char class = TREE_CODE_CLASS (TREE_CODE (yyvsp[-1].ttype));
  62076. -          if (class == 'e' || class == '1'
  62077. -              || class == '2' || class == '<')
  62078. -            C_SET_EXP_ORIGINAL_CODE (yyvsp[-1].ttype, ERROR_MARK);
  62079. -          yyval.ttype = yyvsp[-1].ttype; ;
  62080. -    break;}
  62081. -case 85:
  62082. -#line 706 "objc-parse.y"
  62083. -{ yyval.ttype = error_mark_node; ;
  62084. -    break;}
  62085. -case 86:
  62086. -#line 708 "objc-parse.y"
  62087. -{ if (current_function_decl == 0)
  62088. -            {
  62089. -              error ("braced-group within expression allowed only inside a function");
  62090. -              YYERROR;
  62091. -            }
  62092. -          /* We must force a BLOCK for this level
  62093. -             so that, if it is not expanded later,
  62094. -             there is a way to turn off the entire subtree of blocks
  62095. -             that are contained in it.  */
  62096. -          keep_next_level ();
  62097. -          push_iterator_stack ();
  62098. -          push_label_level ();
  62099. -          yyval.ttype = expand_start_stmt_expr (); ;
  62100. -    break;}
  62101. -case 87:
  62102. -#line 722 "objc-parse.y"
  62103. -{ tree rtl_exp;
  62104. -          if (pedantic)
  62105. -            pedwarn ("ANSI C forbids braced-groups within expressions");
  62106. -          pop_iterator_stack ();
  62107. -          pop_label_level ();
  62108. -          rtl_exp = expand_end_stmt_expr (yyvsp[-2].ttype);
  62109. -          /* The statements have side effects, so the group does.  */
  62110. -          TREE_SIDE_EFFECTS (rtl_exp) = 1;
  62111. -
  62112. -          if (TREE_CODE (yyvsp[-1].ttype) == BLOCK)
  62113. -            {
  62114. -              /* Make a BIND_EXPR for the BLOCK already made.  */
  62115. -              yyval.ttype = build (BIND_EXPR, TREE_TYPE (rtl_exp),
  62116. -                  NULL_TREE, rtl_exp, yyvsp[-1].ttype);
  62117. -              /* Remove the block from the tree at this point.
  62118. -             It gets put back at the proper place
  62119. -             when the BIND_EXPR is expanded.  */
  62120. -              delete_block (yyvsp[-1].ttype);
  62121. -            }
  62122. -          else
  62123. -            yyval.ttype = yyvsp[-1].ttype;
  62124. -        ;
  62125. -    break;}
  62126. -case 88:
  62127. -#line 745 "objc-parse.y"
  62128. -{ yyval.ttype = build_function_call (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62129. -    break;}
  62130. -case 89:
  62131. -#line 747 "objc-parse.y"
  62132. -{ yyval.ttype = build_array_ref (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62133. -    break;}
  62134. -case 90:
  62135. -#line 749 "objc-parse.y"
  62136. -{
  62137. -                  if (doing_objc_thang)
  62138. -                    {
  62139. -              if (is_public (yyvsp[-2].ttype, yyvsp[0].ttype))
  62140. -            yyval.ttype = build_component_ref (yyvsp[-2].ttype, yyvsp[0].ttype);
  62141. -              else
  62142. -            yyval.ttype = error_mark_node;
  62143. -            }
  62144. -                  else
  62145. -            yyval.ttype = build_component_ref (yyvsp[-2].ttype, yyvsp[0].ttype);
  62146. -        ;
  62147. -    break;}
  62148. -case 91:
  62149. -#line 761 "objc-parse.y"
  62150. -{
  62151. -                  tree expr = build_indirect_ref (yyvsp[-2].ttype, "->");
  62152. -
  62153. -                  if (doing_objc_thang)
  62154. -                    {
  62155. -              if (is_public (expr, yyvsp[0].ttype))
  62156. -            yyval.ttype = build_component_ref (expr, yyvsp[0].ttype);
  62157. -              else
  62158. -            yyval.ttype = error_mark_node;
  62159. -            }
  62160. -                  else
  62161. -                    yyval.ttype = build_component_ref (expr, yyvsp[0].ttype);
  62162. -        ;
  62163. -    break;}
  62164. -case 92:
  62165. -#line 775 "objc-parse.y"
  62166. -{ yyval.ttype = build_unary_op (POSTINCREMENT_EXPR, yyvsp[-1].ttype, 0); ;
  62167. -    break;}
  62168. -case 93:
  62169. -#line 777 "objc-parse.y"
  62170. -{ yyval.ttype = build_unary_op (POSTDECREMENT_EXPR, yyvsp[-1].ttype, 0); ;
  62171. -    break;}
  62172. -case 94:
  62173. -#line 779 "objc-parse.y"
  62174. -{ yyval.ttype = build_message_expr (yyvsp[0].ttype); ;
  62175. -    break;}
  62176. -case 95:
  62177. -#line 781 "objc-parse.y"
  62178. -{ yyval.ttype = build_selector_expr (yyvsp[0].ttype); ;
  62179. -    break;}
  62180. -case 96:
  62181. -#line 783 "objc-parse.y"
  62182. -{ yyval.ttype = build_protocol_expr (yyvsp[0].ttype); ;
  62183. -    break;}
  62184. -case 97:
  62185. -#line 785 "objc-parse.y"
  62186. -{ yyval.ttype = build_encode_expr (yyvsp[0].ttype); ;
  62187. -    break;}
  62188. -case 98:
  62189. -#line 787 "objc-parse.y"
  62190. -{ yyval.ttype = build_objc_string_object (yyvsp[0].ttype); ;
  62191. -    break;}
  62192. -case 100:
  62193. -#line 794 "objc-parse.y"
  62194. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62195. -    break;}
  62196. -case 102:
  62197. -#line 802 "objc-parse.y"
  62198. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62199. -    break;}
  62200. -case 105:
  62201. -#line 810 "objc-parse.y"
  62202. -{ c_mark_varargs ();
  62203. -          if (pedantic)
  62204. -            pedwarn ("ANSI C does not permit use of `varargs.h'"); ;
  62205. -    break;}
  62206. -case 106:
  62207. -#line 820 "objc-parse.y"
  62208. -{ ;
  62209. -    break;}
  62210. -case 111:
  62211. -#line 832 "objc-parse.y"
  62212. -{ current_declspecs = TREE_VALUE (declspec_stack);
  62213. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62214. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62215. -          resume_momentary (yyvsp[-2].itype); ;
  62216. -    break;}
  62217. -case 112:
  62218. -#line 837 "objc-parse.y"
  62219. -{ current_declspecs = TREE_VALUE (declspec_stack);    
  62220. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62221. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62222. -          resume_momentary (yyvsp[-2].itype); ;
  62223. -    break;}
  62224. -case 113:
  62225. -#line 842 "objc-parse.y"
  62226. -{ shadow_tag_warned (yyvsp[-1].ttype, 1);
  62227. -          pedwarn ("empty declaration"); ;
  62228. -    break;}
  62229. -case 114:
  62230. -#line 845 "objc-parse.y"
  62231. -{ pedwarn ("empty declaration"); ;
  62232. -    break;}
  62233. -case 115:
  62234. -#line 854 "objc-parse.y"
  62235. -{ ;
  62236. -    break;}
  62237. -case 120:
  62238. -#line 869 "objc-parse.y"
  62239. -{ yyval.itype = suspend_momentary ();
  62240. -          pending_xref_error ();
  62241. -          declspec_stack = tree_cons (prefix_attributes,
  62242. -                          current_declspecs,
  62243. -                          declspec_stack);
  62244. -          current_declspecs = yyvsp[0].ttype; 
  62245. -          prefix_attributes = NULL_TREE; ;
  62246. -    break;}
  62247. -case 121:
  62248. -#line 879 "objc-parse.y"
  62249. -{ prefix_attributes = chainon (prefix_attributes, yyvsp[0].ttype); ;
  62250. -    break;}
  62251. -case 122:
  62252. -#line 884 "objc-parse.y"
  62253. -{ current_declspecs = TREE_VALUE (declspec_stack);
  62254. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62255. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62256. -          resume_momentary (yyvsp[-2].itype); ;
  62257. -    break;}
  62258. -case 123:
  62259. -#line 889 "objc-parse.y"
  62260. -{ current_declspecs = TREE_VALUE (declspec_stack);
  62261. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62262. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62263. -          resume_momentary (yyvsp[-2].itype); ;
  62264. -    break;}
  62265. -case 124:
  62266. -#line 894 "objc-parse.y"
  62267. -{ current_declspecs = TREE_VALUE (declspec_stack);
  62268. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62269. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62270. -          resume_momentary (yyvsp[-1].itype); ;
  62271. -    break;}
  62272. -case 125:
  62273. -#line 899 "objc-parse.y"
  62274. -{ current_declspecs = TREE_VALUE (declspec_stack);
  62275. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62276. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62277. -          resume_momentary (yyvsp[-1].itype); ;
  62278. -    break;}
  62279. -case 126:
  62280. -#line 904 "objc-parse.y"
  62281. -{ shadow_tag (yyvsp[-1].ttype); ;
  62282. -    break;}
  62283. -case 127:
  62284. -#line 906 "objc-parse.y"
  62285. -{ pedwarn ("empty declaration"); ;
  62286. -    break;}
  62287. -case 128:
  62288. -#line 915 "objc-parse.y"
  62289. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62290. -    break;}
  62291. -case 129:
  62292. -#line 917 "objc-parse.y"
  62293. -{ yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ;
  62294. -    break;}
  62295. -case 130:
  62296. -#line 921 "objc-parse.y"
  62297. -{ yyval.ttype = NULL_TREE; ;
  62298. -    break;}
  62299. -case 131:
  62300. -#line 923 "objc-parse.y"
  62301. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  62302. -    break;}
  62303. -case 132:
  62304. -#line 925 "objc-parse.y"
  62305. -{ if (extra_warnings)
  62306. -            warning ("`%s' is not at beginning of declaration",
  62307. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  62308. -          yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  62309. -    break;}
  62310. -case 133:
  62311. -#line 937 "objc-parse.y"
  62312. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE);
  62313. -          TREE_STATIC (yyval.ttype) = 1; ;
  62314. -    break;}
  62315. -case 134:
  62316. -#line 940 "objc-parse.y"
  62317. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  62318. -    break;}
  62319. -case 135:
  62320. -#line 942 "objc-parse.y"
  62321. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype);
  62322. -          TREE_STATIC (yyval.ttype) = 1; ;
  62323. -    break;}
  62324. -case 136:
  62325. -#line 945 "objc-parse.y"
  62326. -{ if (extra_warnings && TREE_STATIC (yyvsp[-1].ttype))
  62327. -            warning ("`%s' is not at beginning of declaration",
  62328. -                 IDENTIFIER_POINTER (yyvsp[0].ttype));
  62329. -          yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype);
  62330. -          TREE_STATIC (yyval.ttype) = TREE_STATIC (yyvsp[-1].ttype); ;
  62331. -    break;}
  62332. -case 137:
  62333. -#line 959 "objc-parse.y"
  62334. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62335. -    break;}
  62336. -case 138:
  62337. -#line 961 "objc-parse.y"
  62338. -{ yyval.ttype = chainon (yyvsp[0].ttype, tree_cons (NULL_TREE, yyvsp[-1].ttype, yyvsp[-2].ttype)); ;
  62339. -    break;}
  62340. -case 139:
  62341. -#line 965 "objc-parse.y"
  62342. -{ yyval.ttype = NULL_TREE; ;
  62343. -    break;}
  62344. -case 140:
  62345. -#line 967 "objc-parse.y"
  62346. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  62347. -    break;}
  62348. -case 143:
  62349. -#line 977 "objc-parse.y"
  62350. -{ /* For a typedef name, record the meaning, not the name.
  62351. -             In case of `foo foo, bar;'.  */
  62352. -          yyval.ttype = lookup_name (yyvsp[0].ttype); ;
  62353. -    break;}
  62354. -case 144:
  62355. -#line 981 "objc-parse.y"
  62356. -{ yyval.ttype = get_static_reference (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62357. -    break;}
  62358. -case 145:
  62359. -#line 983 "objc-parse.y"
  62360. -{ yyval.ttype = get_object_reference (yyvsp[0].ttype); ;
  62361. -    break;}
  62362. -case 146:
  62363. -#line 985 "objc-parse.y"
  62364. -{ yyval.ttype = TREE_TYPE (yyvsp[-1].ttype); ;
  62365. -    break;}
  62366. -case 147:
  62367. -#line 987 "objc-parse.y"
  62368. -{ yyval.ttype = groktypename (yyvsp[-1].ttype); ;
  62369. -    break;}
  62370. -case 155:
  62371. -#line 1009 "objc-parse.y"
  62372. -{ yyval.ttype = NULL_TREE; ;
  62373. -    break;}
  62374. -case 156:
  62375. -#line 1011 "objc-parse.y"
  62376. -{ if (TREE_CHAIN (yyvsp[-1].ttype)) yyvsp[-1].ttype = combine_strings (yyvsp[-1].ttype);
  62377. -          yyval.ttype = yyvsp[-1].ttype;
  62378. -        ;
  62379. -    break;}
  62380. -case 157:
  62381. -#line 1018 "objc-parse.y"
  62382. -{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1,
  62383. -                      yyvsp[-1].ttype, prefix_attributes);
  62384. -          start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ;
  62385. -    break;}
  62386. -case 158:
  62387. -#line 1023 "objc-parse.y"
  62388. -{ finish_init ();
  62389. -          finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ;
  62390. -    break;}
  62391. -case 159:
  62392. -#line 1026 "objc-parse.y"
  62393. -{ tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0,
  62394. -                       yyvsp[0].ttype, prefix_attributes);
  62395. -          finish_decl (d, NULL_TREE, yyvsp[-1].ttype); 
  62396. -                ;
  62397. -    break;}
  62398. -case 160:
  62399. -#line 1034 "objc-parse.y"
  62400. -{ yyval.ttype = start_decl (yyvsp[-3].ttype, current_declspecs, 1,
  62401. -                      yyvsp[-1].ttype, prefix_attributes);
  62402. -          start_init (yyval.ttype, yyvsp[-2].ttype, global_bindings_p ()); ;
  62403. -    break;}
  62404. -case 161:
  62405. -#line 1039 "objc-parse.y"
  62406. -{ finish_init ();
  62407. -          decl_attributes (yyvsp[-1].ttype, yyvsp[-3].ttype, prefix_attributes);
  62408. -          finish_decl (yyvsp[-1].ttype, yyvsp[0].ttype, yyvsp[-4].ttype); ;
  62409. -    break;}
  62410. -case 162:
  62411. -#line 1043 "objc-parse.y"
  62412. -{ tree d = start_decl (yyvsp[-2].ttype, current_declspecs, 0,
  62413. -                       yyvsp[0].ttype, prefix_attributes);
  62414. -          finish_decl (d, NULL_TREE, yyvsp[-1].ttype); ;
  62415. -    break;}
  62416. -case 163:
  62417. -#line 1051 "objc-parse.y"
  62418. -{ yyval.ttype = NULL_TREE; ;
  62419. -    break;}
  62420. -case 164:
  62421. -#line 1053 "objc-parse.y"
  62422. -{ yyval.ttype = yyvsp[0].ttype; ;
  62423. -    break;}
  62424. -case 165:
  62425. -#line 1058 "objc-parse.y"
  62426. -{ yyval.ttype = yyvsp[0].ttype; ;
  62427. -    break;}
  62428. -case 166:
  62429. -#line 1060 "objc-parse.y"
  62430. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62431. -    break;}
  62432. -case 167:
  62433. -#line 1065 "objc-parse.y"
  62434. -{ yyval.ttype = yyvsp[-2].ttype; ;
  62435. -    break;}
  62436. -case 168:
  62437. -#line 1070 "objc-parse.y"
  62438. -{ yyval.ttype = yyvsp[0].ttype; ;
  62439. -    break;}
  62440. -case 169:
  62441. -#line 1072 "objc-parse.y"
  62442. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  62443. -    break;}
  62444. -case 170:
  62445. -#line 1077 "objc-parse.y"
  62446. -{ yyval.ttype = NULL_TREE; ;
  62447. -    break;}
  62448. -case 171:
  62449. -#line 1079 "objc-parse.y"
  62450. -{ yyval.ttype = build_tree_list (yyvsp[0].ttype, NULL_TREE); ;
  62451. -    break;}
  62452. -case 172:
  62453. -#line 1081 "objc-parse.y"
  62454. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, build_tree_list (NULL_TREE, yyvsp[-1].ttype)); ;
  62455. -    break;}
  62456. -case 173:
  62457. -#line 1083 "objc-parse.y"
  62458. -{ yyval.ttype = build_tree_list (yyvsp[-5].ttype, tree_cons (NULL_TREE, yyvsp[-3].ttype, yyvsp[-1].ttype)); ;
  62459. -    break;}
  62460. -case 174:
  62461. -#line 1085 "objc-parse.y"
  62462. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62463. -    break;}
  62464. -case 180:
  62465. -#line 1103 "objc-parse.y"
  62466. -{ really_start_incremental_init (NULL_TREE);
  62467. -          /* Note that the call to clear_momentary
  62468. -             is in process_init_element.  */
  62469. -          push_momentary (); ;
  62470. -    break;}
  62471. -case 181:
  62472. -#line 1108 "objc-parse.y"
  62473. -{ yyval.ttype = pop_init_level (0);
  62474. -          if (yyval.ttype == error_mark_node
  62475. -              && ! (yychar == STRING || yychar == CONSTANT))
  62476. -            pop_momentary ();
  62477. -          else
  62478. -            pop_momentary_nofree (); ;
  62479. -    break;}
  62480. -case 182:
  62481. -#line 1116 "objc-parse.y"
  62482. -{ yyval.ttype = error_mark_node; ;
  62483. -    break;}
  62484. -case 183:
  62485. -#line 1122 "objc-parse.y"
  62486. -{ if (pedantic)
  62487. -            pedwarn ("ANSI C forbids empty initializer braces"); ;
  62488. -    break;}
  62489. -case 187:
  62490. -#line 1136 "objc-parse.y"
  62491. -{ process_init_element (yyvsp[0].ttype); ;
  62492. -    break;}
  62493. -case 188:
  62494. -#line 1138 "objc-parse.y"
  62495. -{ push_init_level (0); ;
  62496. -    break;}
  62497. -case 189:
  62498. -#line 1140 "objc-parse.y"
  62499. -{ process_init_element (pop_init_level (0)); ;
  62500. -    break;}
  62501. -case 191:
  62502. -#line 1146 "objc-parse.y"
  62503. -{ set_init_label (yyvsp[-1].ttype); ;
  62504. -    break;}
  62505. -case 193:
  62506. -#line 1149 "objc-parse.y"
  62507. -{ set_init_label (yyvsp[-1].ttype); ;
  62508. -    break;}
  62509. -case 195:
  62510. -#line 1155 "objc-parse.y"
  62511. -{ push_c_function_context ();
  62512. -          if (! start_function (current_declspecs, yyvsp[0].ttype,
  62513. -                    prefix_attributes, NULL_TREE, 1))
  62514. -            {
  62515. -              pop_c_function_context ();
  62516. -              YYERROR1;
  62517. -            }
  62518. -          reinit_parse_for_function (); ;
  62519. -    break;}
  62520. -case 196:
  62521. -#line 1164 "objc-parse.y"
  62522. -{ store_parm_decls (); ;
  62523. -    break;}
  62524. -case 197:
  62525. -#line 1172 "objc-parse.y"
  62526. -{ finish_function (1);
  62527. -          pop_c_function_context (); ;
  62528. -    break;}
  62529. -case 198:
  62530. -#line 1178 "objc-parse.y"
  62531. -{ push_c_function_context ();
  62532. -          if (! start_function (current_declspecs, yyvsp[0].ttype,
  62533. -                    prefix_attributes, NULL_TREE, 1))
  62534. -            {
  62535. -              pop_c_function_context ();
  62536. -              YYERROR1;
  62537. -            }
  62538. -          reinit_parse_for_function (); ;
  62539. -    break;}
  62540. -case 199:
  62541. -#line 1187 "objc-parse.y"
  62542. -{ store_parm_decls (); ;
  62543. -    break;}
  62544. -case 200:
  62545. -#line 1195 "objc-parse.y"
  62546. -{ finish_function (1);
  62547. -          pop_c_function_context (); ;
  62548. -    break;}
  62549. -case 203:
  62550. -#line 1211 "objc-parse.y"
  62551. -{ yyval.ttype = yyvsp[-1].ttype; ;
  62552. -    break;}
  62553. -case 204:
  62554. -#line 1213 "objc-parse.y"
  62555. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  62556. -    break;}
  62557. -case 205:
  62558. -#line 1218 "objc-parse.y"
  62559. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62560. -    break;}
  62561. -case 206:
  62562. -#line 1220 "objc-parse.y"
  62563. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  62564. -    break;}
  62565. -case 207:
  62566. -#line 1222 "objc-parse.y"
  62567. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62568. -    break;}
  62569. -case 208:
  62570. -#line 1224 "objc-parse.y"
  62571. -{ yyval.ttype = yyvsp[0].ttype; ;
  62572. -    break;}
  62573. -case 211:
  62574. -#line 1236 "objc-parse.y"
  62575. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  62576. -    break;}
  62577. -case 212:
  62578. -#line 1241 "objc-parse.y"
  62579. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62580. -    break;}
  62581. -case 213:
  62582. -#line 1243 "objc-parse.y"
  62583. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  62584. -    break;}
  62585. -case 214:
  62586. -#line 1245 "objc-parse.y"
  62587. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62588. -    break;}
  62589. -case 215:
  62590. -#line 1247 "objc-parse.y"
  62591. -{ yyval.ttype = yyvsp[0].ttype; ;
  62592. -    break;}
  62593. -case 217:
  62594. -#line 1256 "objc-parse.y"
  62595. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  62596. -    break;}
  62597. -case 218:
  62598. -#line 1261 "objc-parse.y"
  62599. -{ yyval.ttype = yyvsp[-1].ttype; ;
  62600. -    break;}
  62601. -case 219:
  62602. -#line 1263 "objc-parse.y"
  62603. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62604. -    break;}
  62605. -case 220:
  62606. -#line 1265 "objc-parse.y"
  62607. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62608. -    break;}
  62609. -case 221:
  62610. -#line 1267 "objc-parse.y"
  62611. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  62612. -    break;}
  62613. -case 222:
  62614. -#line 1269 "objc-parse.y"
  62615. -{ yyval.ttype = yyvsp[0].ttype; ;
  62616. -    break;}
  62617. -case 224:
  62618. -#line 1275 "objc-parse.y"
  62619. -{ yyval.ttype = start_struct (RECORD_TYPE, yyvsp[-1].ttype);
  62620. -          /* Start scope of tag before parsing components.  */
  62621. -        ;
  62622. -    break;}
  62623. -case 225:
  62624. -#line 1279 "objc-parse.y"
  62625. -{ yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  62626. -    break;}
  62627. -case 226:
  62628. -#line 1281 "objc-parse.y"
  62629. -{ yyval.ttype = finish_struct (start_struct (RECORD_TYPE, NULL_TREE),
  62630. -                      yyvsp[-2].ttype, yyvsp[0].ttype);
  62631. -        ;
  62632. -    break;}
  62633. -case 227:
  62634. -#line 1285 "objc-parse.y"
  62635. -{ yyval.ttype = xref_tag (RECORD_TYPE, yyvsp[0].ttype); ;
  62636. -    break;}
  62637. -case 228:
  62638. -#line 1287 "objc-parse.y"
  62639. -{ yyval.ttype = start_struct (UNION_TYPE, yyvsp[-1].ttype); ;
  62640. -    break;}
  62641. -case 229:
  62642. -#line 1289 "objc-parse.y"
  62643. -{ yyval.ttype = finish_struct (yyvsp[-3].ttype, yyvsp[-2].ttype, yyvsp[0].ttype); ;
  62644. -    break;}
  62645. -case 230:
  62646. -#line 1291 "objc-parse.y"
  62647. -{ yyval.ttype = finish_struct (start_struct (UNION_TYPE, NULL_TREE),
  62648. -                      yyvsp[-2].ttype, yyvsp[0].ttype);
  62649. -        ;
  62650. -    break;}
  62651. -case 231:
  62652. -#line 1295 "objc-parse.y"
  62653. -{ yyval.ttype = xref_tag (UNION_TYPE, yyvsp[0].ttype); ;
  62654. -    break;}
  62655. -case 232:
  62656. -#line 1297 "objc-parse.y"
  62657. -{ yyvsp[0].itype = suspend_momentary ();
  62658. -          yyval.ttype = start_enum (yyvsp[-1].ttype); ;
  62659. -    break;}
  62660. -case 233:
  62661. -#line 1300 "objc-parse.y"
  62662. -{ yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), yyvsp[0].ttype);
  62663. -          resume_momentary (yyvsp[-5].itype); ;
  62664. -    break;}
  62665. -case 234:
  62666. -#line 1303 "objc-parse.y"
  62667. -{ yyvsp[0].itype = suspend_momentary ();
  62668. -          yyval.ttype = start_enum (NULL_TREE); ;
  62669. -    break;}
  62670. -case 235:
  62671. -#line 1306 "objc-parse.y"
  62672. -{ yyval.ttype = finish_enum (yyvsp[-4].ttype, nreverse (yyvsp[-3].ttype), yyvsp[0].ttype);
  62673. -          resume_momentary (yyvsp[-5].itype); ;
  62674. -    break;}
  62675. -case 236:
  62676. -#line 1309 "objc-parse.y"
  62677. -{ yyval.ttype = xref_tag (ENUMERAL_TYPE, yyvsp[0].ttype); ;
  62678. -    break;}
  62679. -case 240:
  62680. -#line 1320 "objc-parse.y"
  62681. -{ if (pedantic) pedwarn ("comma at end of enumerator list"); ;
  62682. -    break;}
  62683. -case 241:
  62684. -#line 1325 "objc-parse.y"
  62685. -{ yyval.ttype = yyvsp[0].ttype; ;
  62686. -    break;}
  62687. -case 242:
  62688. -#line 1327 "objc-parse.y"
  62689. -{ yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype);
  62690. -          pedwarn ("no semicolon at end of struct or union"); ;
  62691. -    break;}
  62692. -case 243:
  62693. -#line 1332 "objc-parse.y"
  62694. -{ yyval.ttype = NULL_TREE; ;
  62695. -    break;}
  62696. -case 244:
  62697. -#line 1334 "objc-parse.y"
  62698. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[-1].ttype); ;
  62699. -    break;}
  62700. -case 245:
  62701. -#line 1336 "objc-parse.y"
  62702. -{ if (pedantic)
  62703. -            pedwarn ("extra semicolon in struct or union specified"); ;
  62704. -    break;}
  62705. -case 246:
  62706. -#line 1340 "objc-parse.y"
  62707. -{
  62708. -          tree interface = lookup_interface (yyvsp[-1].ttype);
  62709. -
  62710. -          if (interface)
  62711. -            yyval.ttype = get_class_ivars (interface);
  62712. -          else
  62713. -            {
  62714. -              error ("Cannot find interface declaration for `%s'",
  62715. -                 IDENTIFIER_POINTER (yyvsp[-1].ttype));
  62716. -              yyval.ttype = NULL_TREE;
  62717. -            }
  62718. -        ;
  62719. -    break;}
  62720. -case 247:
  62721. -#line 1365 "objc-parse.y"
  62722. -{ yyval.ttype = yyvsp[0].ttype;
  62723. -          current_declspecs = TREE_VALUE (declspec_stack);
  62724. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62725. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62726. -          resume_momentary (yyvsp[-1].itype); ;
  62727. -    break;}
  62728. -case 248:
  62729. -#line 1371 "objc-parse.y"
  62730. -{ if (pedantic)
  62731. -            pedwarn ("ANSI C forbids member declarations with no members");
  62732. -          shadow_tag(yyvsp[0].ttype);
  62733. -          yyval.ttype = NULL_TREE; ;
  62734. -    break;}
  62735. -case 249:
  62736. -#line 1376 "objc-parse.y"
  62737. -{ yyval.ttype = yyvsp[0].ttype;
  62738. -          current_declspecs = TREE_VALUE (declspec_stack);
  62739. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  62740. -          declspec_stack = TREE_CHAIN (declspec_stack);
  62741. -          resume_momentary (yyvsp[-1].itype); ;
  62742. -    break;}
  62743. -case 250:
  62744. -#line 1382 "objc-parse.y"
  62745. -{ if (pedantic)
  62746. -            pedwarn ("ANSI C forbids member declarations with no members");
  62747. -          shadow_tag(yyvsp[0].ttype);
  62748. -          yyval.ttype = NULL_TREE; ;
  62749. -    break;}
  62750. -case 251:
  62751. -#line 1387 "objc-parse.y"
  62752. -{ yyval.ttype = NULL_TREE; ;
  62753. -    break;}
  62754. -case 253:
  62755. -#line 1393 "objc-parse.y"
  62756. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  62757. -    break;}
  62758. -case 254:
  62759. -#line 1398 "objc-parse.y"
  62760. -{ yyval.ttype = grokfield (yyvsp[-3].filename, yyvsp[-2].lineno, yyvsp[-1].ttype, current_declspecs, NULL_TREE);
  62761. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  62762. -    break;}
  62763. -case 255:
  62764. -#line 1402 "objc-parse.y"
  62765. -{ yyval.ttype = grokfield (yyvsp[-5].filename, yyvsp[-4].lineno, yyvsp[-3].ttype, current_declspecs, yyvsp[-1].ttype);
  62766. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  62767. -    break;}
  62768. -case 256:
  62769. -#line 1405 "objc-parse.y"
  62770. -{ yyval.ttype = grokfield (yyvsp[-4].filename, yyvsp[-3].lineno, NULL_TREE, current_declspecs, yyvsp[-1].ttype);
  62771. -          decl_attributes (yyval.ttype, yyvsp[0].ttype, prefix_attributes); ;
  62772. -    break;}
  62773. -case 258:
  62774. -#line 1417 "objc-parse.y"
  62775. -{ if (yyvsp[-2].ttype == error_mark_node)
  62776. -            yyval.ttype = yyvsp[-2].ttype;
  62777. -          else
  62778. -            yyval.ttype = chainon (yyvsp[0].ttype, yyvsp[-2].ttype); ;
  62779. -    break;}
  62780. -case 259:
  62781. -#line 1422 "objc-parse.y"
  62782. -{ yyval.ttype = error_mark_node; ;
  62783. -    break;}
  62784. -case 260:
  62785. -#line 1428 "objc-parse.y"
  62786. -{ yyval.ttype = build_enumerator (yyvsp[0].ttype, NULL_TREE); ;
  62787. -    break;}
  62788. -case 261:
  62789. -#line 1430 "objc-parse.y"
  62790. -{ yyval.ttype = build_enumerator (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  62791. -    break;}
  62792. -case 262:
  62793. -#line 1435 "objc-parse.y"
  62794. -{ yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62795. -    break;}
  62796. -case 263:
  62797. -#line 1437 "objc-parse.y"
  62798. -{ yyval.ttype = build_tree_list (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62799. -    break;}
  62800. -case 264:
  62801. -#line 1442 "objc-parse.y"
  62802. -{ yyval.ttype = NULL_TREE; ;
  62803. -    break;}
  62804. -case 266:
  62805. -#line 1448 "objc-parse.y"
  62806. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  62807. -    break;}
  62808. -case 267:
  62809. -#line 1450 "objc-parse.y"
  62810. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  62811. -    break;}
  62812. -case 268:
  62813. -#line 1455 "objc-parse.y"
  62814. -{ yyval.ttype = NULL_TREE; ;
  62815. -    break;}
  62816. -case 269:
  62817. -#line 1457 "objc-parse.y"
  62818. -{ yyval.ttype = tree_cons (NULL_TREE, yyvsp[0].ttype, yyvsp[-1].ttype); ;
  62819. -    break;}
  62820. -case 270:
  62821. -#line 1462 "objc-parse.y"
  62822. -{ yyval.ttype = yyvsp[-1].ttype; ;
  62823. -    break;}
  62824. -case 271:
  62825. -#line 1465 "objc-parse.y"
  62826. -{ yyval.ttype = make_pointer_declarator (yyvsp[-1].ttype, yyvsp[0].ttype); ;
  62827. -    break;}
  62828. -case 272:
  62829. -#line 1467 "objc-parse.y"
  62830. -{ yyval.ttype = make_pointer_declarator (yyvsp[0].ttype, NULL_TREE); ;
  62831. -    break;}
  62832. -case 273:
  62833. -#line 1469 "objc-parse.y"
  62834. -{ yyval.ttype = build_nt (CALL_EXPR, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE); ;
  62835. -    break;}
  62836. -case 274:
  62837. -#line 1471 "objc-parse.y"
  62838. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  62839. -    break;}
  62840. -case 275:
  62841. -#line 1473 "objc-parse.y"
  62842. -{ yyval.ttype = build_nt (ARRAY_REF, yyvsp[-2].ttype, NULL_TREE); ;
  62843. -    break;}
  62844. -case 276:
  62845. -#line 1475 "objc-parse.y"
  62846. -{ yyval.ttype = build_nt (CALL_EXPR, NULL_TREE, yyvsp[0].ttype, NULL_TREE); ;
  62847. -    break;}
  62848. -case 277:
  62849. -#line 1477 "objc-parse.y"
  62850. -{ yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, yyvsp[-1].ttype); ;
  62851. -    break;}
  62852. -case 278:
  62853. -#line 1479 "objc-parse.y"
  62854. -{ yyval.ttype = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); ;
  62855. -    break;}
  62856. -case 279:
  62857. -#line 1481 "objc-parse.y"
  62858. -{ yyval.ttype = yyvsp[0].ttype; ;
  62859. -    break;}
  62860. -case 280:
  62861. -#line 1490 "objc-parse.y"
  62862. -{
  62863. -          if (pedantic && yyvsp[0].ends_in_label)
  62864. -            pedwarn ("ANSI C forbids label at end of compound statement");
  62865. -        ;
  62866. -    break;}
  62867. -case 282:
  62868. -#line 1499 "objc-parse.y"
  62869. -{ yyval.ends_in_label = yyvsp[0].ends_in_label; ;
  62870. -    break;}
  62871. -case 283:
  62872. -#line 1501 "objc-parse.y"
  62873. -{ yyval.ends_in_label = 0; ;
  62874. -    break;}
  62875. -case 287:
  62876. -#line 1513 "objc-parse.y"
  62877. -{ emit_line_note (input_filename, lineno);
  62878. -          pushlevel (0);
  62879. -          clear_last_expr ();
  62880. -          push_momentary ();
  62881. -          expand_start_bindings (0);
  62882. -          if (objc_method_context)
  62883. -            add_objc_decls ();
  62884. -        ;
  62885. -    break;}
  62886. -case 289:
  62887. -#line 1528 "objc-parse.y"
  62888. -{ if (pedantic)
  62889. -            pedwarn ("ANSI C forbids label declarations"); ;
  62890. -    break;}
  62891. -case 292:
  62892. -#line 1539 "objc-parse.y"
  62893. -{ tree link;
  62894. -          for (link = yyvsp[-1].ttype; link; link = TREE_CHAIN (link))
  62895. -            {
  62896. -              tree label = shadow_label (TREE_VALUE (link));
  62897. -              C_DECLARED_LABEL_FLAG (label) = 1;
  62898. -              declare_nonlocal_label (label);
  62899. -            }
  62900. -        ;
  62901. -    break;}
  62902. -case 293:
  62903. -#line 1553 "objc-parse.y"
  62904. -{;
  62905. -    break;}
  62906. -case 295:
  62907. -#line 1558 "objc-parse.y"
  62908. -{ yyval.ttype = convert (void_type_node, integer_zero_node); ;
  62909. -    break;}
  62910. -case 296:
  62911. -#line 1560 "objc-parse.y"
  62912. -{ emit_line_note (input_filename, lineno);
  62913. -          expand_end_bindings (getdecls (), 1, 0);
  62914. -          yyval.ttype = poplevel (1, 1, 0);
  62915. -          if (yychar == CONSTANT || yychar == STRING)
  62916. -            pop_momentary_nofree ();
  62917. -          else
  62918. -            pop_momentary (); ;
  62919. -    break;}
  62920. -case 297:
  62921. -#line 1568 "objc-parse.y"
  62922. -{ emit_line_note (input_filename, lineno);
  62923. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  62924. -          yyval.ttype = poplevel (kept_level_p (), 0, 0);
  62925. -          if (yychar == CONSTANT || yychar == STRING)
  62926. -            pop_momentary_nofree ();
  62927. -          else
  62928. -            pop_momentary (); ;
  62929. -    break;}
  62930. -case 298:
  62931. -#line 1576 "objc-parse.y"
  62932. -{ emit_line_note (input_filename, lineno);
  62933. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  62934. -          yyval.ttype = poplevel (kept_level_p (), 0, 0);
  62935. -          if (yychar == CONSTANT || yychar == STRING)
  62936. -            pop_momentary_nofree ();
  62937. -          else
  62938. -            pop_momentary (); ;
  62939. -    break;}
  62940. -case 301:
  62941. -#line 1596 "objc-parse.y"
  62942. -{ emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  62943. -          expand_start_cond (truthvalue_conversion (yyvsp[-1].ttype), 0);
  62944. -          yyval.itype = stmt_count;
  62945. -          if_stmt_file = yyvsp[-5].filename;
  62946. -          if_stmt_line = yyvsp[-4].lineno;
  62947. -          position_after_white_space (); ;
  62948. -    break;}
  62949. -case 302:
  62950. -#line 1609 "objc-parse.y"
  62951. -{ stmt_count++;
  62952. -          emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno);
  62953. -          /* See comment in `while' alternative, above.  */
  62954. -          emit_nop ();
  62955. -          expand_start_loop_continue_elsewhere (1);
  62956. -          position_after_white_space (); ;
  62957. -    break;}
  62958. -case 303:
  62959. -#line 1616 "objc-parse.y"
  62960. -{ expand_loop_continue_here (); ;
  62961. -    break;}
  62962. -case 304:
  62963. -#line 1620 "objc-parse.y"
  62964. -{ yyval.filename = input_filename; ;
  62965. -    break;}
  62966. -case 305:
  62967. -#line 1624 "objc-parse.y"
  62968. -{ yyval.lineno = lineno; ;
  62969. -    break;}
  62970. -case 306:
  62971. -#line 1629 "objc-parse.y"
  62972. -{ ;
  62973. -    break;}
  62974. -case 307:
  62975. -#line 1634 "objc-parse.y"
  62976. -{ ;
  62977. -    break;}
  62978. -case 308:
  62979. -#line 1639 "objc-parse.y"
  62980. -{ yyval.ends_in_label = yyvsp[0].ends_in_label; ;
  62981. -    break;}
  62982. -case 309:
  62983. -#line 1644 "objc-parse.y"
  62984. -{ yyval.ends_in_label = 0; ;
  62985. -    break;}
  62986. -case 310:
  62987. -#line 1646 "objc-parse.y"
  62988. -{ yyval.ends_in_label = 1; ;
  62989. -    break;}
  62990. -case 311:
  62991. -#line 1652 "objc-parse.y"
  62992. -{ stmt_count++; ;
  62993. -    break;}
  62994. -case 313:
  62995. -#line 1655 "objc-parse.y"
  62996. -{ stmt_count++;
  62997. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  62998. -/* It appears that this should not be done--that a non-lvalue array
  62999. -   shouldn't get an error if the value isn't used.
  63000. -   Section 3.2.2.1 says that an array lvalue gets converted to a pointer
  63001. -   if it appears as a top-level expression,
  63002. -   but says nothing about non-lvalue arrays.  */
  63003. -#if 0
  63004. -          /* Call default_conversion to get an error
  63005. -             on referring to a register array if pedantic.  */
  63006. -          if (TREE_CODE (TREE_TYPE (yyvsp[-1].ttype)) == ARRAY_TYPE
  63007. -              || TREE_CODE (TREE_TYPE (yyvsp[-1].ttype)) == FUNCTION_TYPE)
  63008. -            yyvsp[-1].ttype = default_conversion (yyvsp[-1].ttype);
  63009. -#endif
  63010. -          iterator_expand (yyvsp[-1].ttype);
  63011. -          clear_momentary (); ;
  63012. -    break;}
  63013. -case 314:
  63014. -#line 1672 "objc-parse.y"
  63015. -{ expand_start_else ();
  63016. -          yyvsp[-1].itype = stmt_count;
  63017. -          position_after_white_space (); ;
  63018. -    break;}
  63019. -case 315:
  63020. -#line 1676 "objc-parse.y"
  63021. -{ expand_end_cond ();
  63022. -          if (extra_warnings && stmt_count == yyvsp[-3].itype)
  63023. -            warning ("empty body in an else-statement"); ;
  63024. -    break;}
  63025. -case 316:
  63026. -#line 1680 "objc-parse.y"
  63027. -{ expand_end_cond ();
  63028. -          /* This warning is here instead of in simple_if, because we
  63029. -             do not want a warning if an empty if is followed by an
  63030. -             else statement.  Increment stmt_count so we don't
  63031. -             give a second error if this is a nested `if'.  */
  63032. -          if (extra_warnings && stmt_count++ == yyvsp[0].itype)
  63033. -            warning_with_file_and_line (if_stmt_file, if_stmt_line,
  63034. -                        "empty body in an if-statement"); ;
  63035. -    break;}
  63036. -case 317:
  63037. -#line 1692 "objc-parse.y"
  63038. -{ expand_end_cond (); ;
  63039. -    break;}
  63040. -case 318:
  63041. -#line 1694 "objc-parse.y"
  63042. -{ stmt_count++;
  63043. -          emit_line_note (yyvsp[-2].filename, yyvsp[-1].lineno);
  63044. -          /* The emit_nop used to come before emit_line_note,
  63045. -             but that made the nop seem like part of the preceding line.
  63046. -             And that was confusing when the preceding line was
  63047. -             inside of an if statement and was not really executed.
  63048. -             I think it ought to work to put the nop after the line number.
  63049. -             We will see.  --rms, July 15, 1991.  */
  63050. -          emit_nop (); ;
  63051. -    break;}
  63052. -case 319:
  63053. -#line 1704 "objc-parse.y"
  63054. -{ /* Don't start the loop till we have succeeded
  63055. -             in parsing the end test.  This is to make sure
  63056. -             that we end every loop we start.  */
  63057. -          expand_start_loop (1);
  63058. -          emit_line_note (input_filename, lineno);
  63059. -          expand_exit_loop_if_false (NULL_PTR,
  63060. -                         truthvalue_conversion (yyvsp[-1].ttype));
  63061. -          position_after_white_space (); ;
  63062. -    break;}
  63063. -case 320:
  63064. -#line 1713 "objc-parse.y"
  63065. -{ expand_end_loop (); ;
  63066. -    break;}
  63067. -case 321:
  63068. -#line 1716 "objc-parse.y"
  63069. -{ emit_line_note (input_filename, lineno);
  63070. -          expand_exit_loop_if_false (NULL_PTR,
  63071. -                         truthvalue_conversion (yyvsp[-2].ttype));
  63072. -          expand_end_loop ();
  63073. -          clear_momentary (); ;
  63074. -    break;}
  63075. -case 322:
  63076. -#line 1723 "objc-parse.y"
  63077. -{ expand_end_loop ();
  63078. -          clear_momentary (); ;
  63079. -    break;}
  63080. -case 323:
  63081. -#line 1727 "objc-parse.y"
  63082. -{ stmt_count++;
  63083. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  63084. -          /* See comment in `while' alternative, above.  */
  63085. -          emit_nop ();
  63086. -          if (yyvsp[-1].ttype) c_expand_expr_stmt (yyvsp[-1].ttype);
  63087. -          /* Next step is to call expand_start_loop_continue_elsewhere,
  63088. -             but wait till after we parse the entire for (...).
  63089. -             Otherwise, invalid input might cause us to call that
  63090. -             fn without calling expand_end_loop.  */
  63091. -        ;
  63092. -    break;}
  63093. -case 324:
  63094. -#line 1739 "objc-parse.y"
  63095. -{ yyvsp[0].lineno = lineno;
  63096. -          yyval.filename = input_filename; ;
  63097. -    break;}
  63098. -case 325:
  63099. -#line 1742 "objc-parse.y"
  63100. -{ 
  63101. -          /* Start the loop.  Doing this after parsing
  63102. -             all the expressions ensures we will end the loop.  */
  63103. -          expand_start_loop_continue_elsewhere (1);
  63104. -          /* Emit the end-test, with a line number.  */
  63105. -          emit_line_note (yyvsp[-2].filename, yyvsp[-3].lineno);
  63106. -          if (yyvsp[-4].ttype)
  63107. -            expand_exit_loop_if_false (NULL_PTR,
  63108. -                           truthvalue_conversion (yyvsp[-4].ttype));
  63109. -          /* Don't let the tree nodes for $9 be discarded by
  63110. -             clear_momentary during the parsing of the next stmt.  */
  63111. -          push_momentary ();
  63112. -          yyvsp[-3].lineno = lineno;
  63113. -          yyvsp[-2].filename = input_filename;
  63114. -          position_after_white_space (); ;
  63115. -    break;}
  63116. -case 326:
  63117. -#line 1758 "objc-parse.y"
  63118. -{ /* Emit the increment expression, with a line number.  */
  63119. -          emit_line_note (yyvsp[-4].filename, yyvsp[-5].lineno);
  63120. -          expand_loop_continue_here ();
  63121. -          if (yyvsp[-3].ttype)
  63122. -            c_expand_expr_stmt (yyvsp[-3].ttype);
  63123. -          if (yychar == CONSTANT || yychar == STRING)
  63124. -            pop_momentary_nofree ();
  63125. -          else
  63126. -            pop_momentary ();
  63127. -          expand_end_loop (); ;
  63128. -    break;}
  63129. -case 327:
  63130. -#line 1769 "objc-parse.y"
  63131. -{ stmt_count++;
  63132. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  63133. -          c_expand_start_case (yyvsp[-1].ttype);
  63134. -          /* Don't let the tree nodes for $3 be discarded by
  63135. -             clear_momentary during the parsing of the next stmt.  */
  63136. -          push_momentary ();
  63137. -          position_after_white_space (); ;
  63138. -    break;}
  63139. -case 328:
  63140. -#line 1777 "objc-parse.y"
  63141. -{ expand_end_case (yyvsp[-3].ttype);
  63142. -          if (yychar == CONSTANT || yychar == STRING)
  63143. -            pop_momentary_nofree ();
  63144. -          else
  63145. -            pop_momentary (); ;
  63146. -    break;}
  63147. -case 329:
  63148. -#line 1783 "objc-parse.y"
  63149. -{ stmt_count++;
  63150. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  63151. -          if ( ! expand_exit_something ())
  63152. -            error ("break statement not within loop or switch"); ;
  63153. -    break;}
  63154. -case 330:
  63155. -#line 1788 "objc-parse.y"
  63156. -{ stmt_count++;
  63157. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  63158. -          if (! expand_continue_loop (NULL_PTR))
  63159. -            error ("continue statement not within a loop"); ;
  63160. -    break;}
  63161. -case 331:
  63162. -#line 1793 "objc-parse.y"
  63163. -{ stmt_count++;
  63164. -          emit_line_note (yyvsp[-3].filename, yyvsp[-2].lineno);
  63165. -          c_expand_return (NULL_TREE); ;
  63166. -    break;}
  63167. -case 332:
  63168. -#line 1797 "objc-parse.y"
  63169. -{ stmt_count++;
  63170. -          emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno);
  63171. -          c_expand_return (yyvsp[-1].ttype); ;
  63172. -    break;}
  63173. -case 333:
  63174. -#line 1801 "objc-parse.y"
  63175. -{ stmt_count++;
  63176. -          emit_line_note (yyvsp[-7].filename, yyvsp[-6].lineno);
  63177. -          STRIP_NOPS (yyvsp[-2].ttype);
  63178. -          if ((TREE_CODE (yyvsp[-2].ttype) == ADDR_EXPR
  63179. -               && TREE_CODE (TREE_OPERAND (yyvsp[-2].ttype, 0)) == STRING_CST)
  63180. -              || TREE_CODE (yyvsp[-2].ttype) == STRING_CST)
  63181. -            expand_asm (yyvsp[-2].ttype);
  63182. -          else
  63183. -            error ("argument of `asm' is not a constant string"); ;
  63184. -    break;}
  63185. -case 334:
  63186. -#line 1812 "objc-parse.y"
  63187. -{ stmt_count++;
  63188. -          emit_line_note (yyvsp[-9].filename, yyvsp[-8].lineno);
  63189. -          c_expand_asm_operands (yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE, NULL_TREE,
  63190. -                     yyvsp[-6].ttype == ridpointers[(int)RID_VOLATILE],
  63191. -                     input_filename, lineno); ;
  63192. -    break;}
  63193. -case 335:
  63194. -#line 1819 "objc-parse.y"
  63195. -{ stmt_count++;
  63196. -          emit_line_note (yyvsp[-11].filename, yyvsp[-10].lineno);
  63197. -          c_expand_asm_operands (yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype, NULL_TREE,
  63198. -                     yyvsp[-8].ttype == ridpointers[(int)RID_VOLATILE],
  63199. -                     input_filename, lineno); ;
  63200. -    break;}
  63201. -case 336:
  63202. -#line 1827 "objc-parse.y"
  63203. -{ stmt_count++;
  63204. -          emit_line_note (yyvsp[-13].filename, yyvsp[-12].lineno);
  63205. -          c_expand_asm_operands (yyvsp[-8].ttype, yyvsp[-6].ttype, yyvsp[-4].ttype, yyvsp[-2].ttype,
  63206. -                     yyvsp[-10].ttype == ridpointers[(int)RID_VOLATILE],
  63207. -                     input_filename, lineno); ;
  63208. -    break;}
  63209. -case 337:
  63210. -#line 1833 "objc-parse.y"
  63211. -{ tree decl;
  63212. -          stmt_count++;
  63213. -          emit_line_note (yyvsp[-4].filename, yyvsp[-3].lineno);
  63214. -          decl = lookup_label (yyvsp[-1].ttype);
  63215. -          if (decl != 0)
  63216. -            {
  63217. -              TREE_USED (decl) = 1;
  63218. -              expand_goto (decl);
  63219. -            }
  63220. -        ;
  63221. -    break;}
  63222. -case 338:
  63223. -#line 1844 "objc-parse.y"
  63224. -{ stmt_count++;
  63225. -          emit_line_note (yyvsp[-5].filename, yyvsp[-4].lineno);
  63226. -          expand_computed_goto (convert (ptr_type_node, yyvsp[-1].ttype)); ;
  63227. -    break;}
  63228. -case 341:
  63229. -#line 1857 "objc-parse.y"
  63230. -{
  63231. -        /* The value returned by this action is  */
  63232. -        /*      1 if everything is OK */ 
  63233. -        /*      0 in case of error or already bound iterator */
  63234. -
  63235. -        yyval.itype = 0;
  63236. -        if (TREE_CODE (yyvsp[-1].ttype) != VAR_DECL)
  63237. -          error ("invalid `for (ITERATOR)' syntax");
  63238. -        else if (! ITERATOR_P (yyvsp[-1].ttype))
  63239. -          error ("`%s' is not an iterator",
  63240. -             IDENTIFIER_POINTER (DECL_NAME (yyvsp[-1].ttype)));
  63241. -        else if (ITERATOR_BOUND_P (yyvsp[-1].ttype))
  63242. -          error ("`for (%s)' inside expansion of same iterator",
  63243. -             IDENTIFIER_POINTER (DECL_NAME (yyvsp[-1].ttype)));
  63244. -        else
  63245. -          {
  63246. -        yyval.itype = 1;
  63247. -        iterator_for_loop_start (yyvsp[-1].ttype);
  63248. -          }
  63249. -      ;
  63250. -    break;}
  63251. -case 342:
  63252. -#line 1878 "objc-parse.y"
  63253. -{
  63254. -        if (yyvsp[-1].itype)
  63255. -          iterator_for_loop_end (yyvsp[-3].ttype);
  63256. -      ;
  63257. -    break;}
  63258. -case 343:
  63259. -#line 1913 "objc-parse.y"
  63260. -{ register tree value = check_case_value (yyvsp[-1].ttype);
  63261. -          register tree label
  63262. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  63263. -
  63264. -          stmt_count++;
  63265. -
  63266. -          if (value != error_mark_node)
  63267. -            {
  63268. -              tree duplicate;
  63269. -              int success = pushcase (value, convert_and_check,
  63270. -                          label, &duplicate);
  63271. -              if (success == 1)
  63272. -            error ("case label not within a switch statement");
  63273. -              else if (success == 2)
  63274. -            {
  63275. -              error ("duplicate case value");
  63276. -              error_with_decl (duplicate, "this is the first entry for that value");
  63277. -            }
  63278. -              else if (success == 3)
  63279. -            warning ("case value out of range");
  63280. -              else if (success == 5)
  63281. -            error ("case label within scope of cleanup or variable array");
  63282. -            }
  63283. -          position_after_white_space (); ;
  63284. -    break;}
  63285. -case 344:
  63286. -#line 1938 "objc-parse.y"
  63287. -{ register tree value1 = check_case_value (yyvsp[-3].ttype);
  63288. -          register tree value2 = check_case_value (yyvsp[-1].ttype);
  63289. -          register tree label
  63290. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  63291. -
  63292. -          stmt_count++;
  63293. -
  63294. -          if (value1 != error_mark_node && value2 != error_mark_node)
  63295. -            {
  63296. -              tree duplicate;
  63297. -              int success = pushcase_range (value1, value2,
  63298. -                            convert_and_check, label,
  63299. -                            &duplicate);
  63300. -              if (success == 1)
  63301. -            error ("case label not within a switch statement");
  63302. -              else if (success == 2)
  63303. -            {
  63304. -              error ("duplicate case value");
  63305. -              error_with_decl (duplicate, "this is the first entry for that value");
  63306. -            }
  63307. -              else if (success == 3)
  63308. -            warning ("case value out of range");
  63309. -              else if (success == 4)
  63310. -            warning ("empty case range");
  63311. -              else if (success == 5)
  63312. -            error ("case label within scope of cleanup or variable array");
  63313. -            }
  63314. -          position_after_white_space (); ;
  63315. -    break;}
  63316. -case 345:
  63317. -#line 1967 "objc-parse.y"
  63318. -{
  63319. -          tree duplicate;
  63320. -          register tree label
  63321. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  63322. -          int success = pushcase (NULL_TREE, 0, label, &duplicate);
  63323. -          stmt_count++;
  63324. -          if (success == 1)
  63325. -            error ("default label not within a switch statement");
  63326. -          else if (success == 2)
  63327. -            {
  63328. -              error ("multiple default labels in one switch");
  63329. -              error_with_decl (duplicate, "this is the first default label");
  63330. -            }
  63331. -          position_after_white_space (); ;
  63332. -    break;}
  63333. -case 346:
  63334. -#line 1982 "objc-parse.y"
  63335. -{ tree label = define_label (input_filename, lineno, yyvsp[-1].ttype);
  63336. -          stmt_count++;
  63337. -          emit_nop ();
  63338. -          if (label)
  63339. -            expand_label (label);
  63340. -          position_after_white_space (); ;
  63341. -    break;}
  63342. -case 347:
  63343. -#line 1994 "objc-parse.y"
  63344. -{ emit_line_note (input_filename, lineno);
  63345. -          yyval.ttype = NULL_TREE; ;
  63346. -    break;}
  63347. -case 348:
  63348. -#line 1997 "objc-parse.y"
  63349. -{ emit_line_note (input_filename, lineno); ;
  63350. -    break;}
  63351. -case 349:
  63352. -#line 2002 "objc-parse.y"
  63353. -{ yyval.ttype = NULL_TREE; ;
  63354. -    break;}
  63355. -case 351:
  63356. -#line 2009 "objc-parse.y"
  63357. -{ yyval.ttype = NULL_TREE; ;
  63358. -    break;}
  63359. -case 354:
  63360. -#line 2016 "objc-parse.y"
  63361. -{ yyval.ttype = chainon (yyvsp[-2].ttype, yyvsp[0].ttype); ;
  63362. -    break;}
  63363. -case 355:
  63364. -#line 2021 "objc-parse.y"
  63365. -{ yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype); ;
  63366. -    break;}
  63367. -case 356:
  63368. -#line 2026 "objc-parse.y"
  63369. -{ yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), NULL_TREE); ;
  63370. -    break;}
  63371. -case 357:
  63372. -#line 2028 "objc-parse.y"
  63373. -{ yyval.ttype = tree_cons (NULL_TREE, combine_strings (yyvsp[0].ttype), yyvsp[-2].ttype); ;
  63374. -    break;}
  63375. -case 358:
  63376. -#line 2034 "objc-parse.y"
  63377. -{ pushlevel (0);
  63378. -          clear_parm_order ();
  63379. -          declare_parm_level (0); ;
  63380. -    break;}
  63381. -case 359:
  63382. -#line 2038 "objc-parse.y"
  63383. -{ yyval.ttype = yyvsp[0].ttype;
  63384. -          parmlist_tags_warning ();
  63385. -          poplevel (0, 0, 0); ;
  63386. -    break;}
  63387. -case 361:
  63388. -#line 2046 "objc-parse.y"
  63389. -{ tree parm;
  63390. -          if (pedantic)
  63391. -            pedwarn ("ANSI C forbids forward parameter declarations");
  63392. -          /* Mark the forward decls as such.  */
  63393. -          for (parm = getdecls (); parm; parm = TREE_CHAIN (parm))
  63394. -            TREE_ASM_WRITTEN (parm) = 1;
  63395. -          clear_parm_order (); ;
  63396. -    break;}
  63397. -case 362:
  63398. -#line 2054 "objc-parse.y"
  63399. -{ yyval.ttype = yyvsp[0].ttype; ;
  63400. -    break;}
  63401. -case 363:
  63402. -#line 2056 "objc-parse.y"
  63403. -{ yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); ;
  63404. -    break;}
  63405. -case 364:
  63406. -#line 2062 "objc-parse.y"
  63407. -{ yyval.ttype = get_parm_info (0); ;
  63408. -    break;}
  63409. -case 365:
  63410. -#line 2064 "objc-parse.y"
  63411. -{ yyval.ttype = get_parm_info (0);
  63412. -          /* Gcc used to allow this as an extension.  However, it does
  63413. -             not work for all targets, and thus has been disabled.
  63414. -             Also, since func (...) and func () are indistinguishable,
  63415. -             it caused problems with the code in expand_builtin which
  63416. -             tries to verify that BUILT_IN_NEXT_ARG is being used
  63417. -             correctly.  */
  63418. -          error ("ANSI C requires a named argument before `...'");
  63419. -        ;
  63420. -    break;}
  63421. -case 366:
  63422. -#line 2074 "objc-parse.y"
  63423. -{ yyval.ttype = get_parm_info (1); ;
  63424. -    break;}
  63425. -case 367:
  63426. -#line 2076 "objc-parse.y"
  63427. -{ yyval.ttype = get_parm_info (0); ;
  63428. -    break;}
  63429. -case 368:
  63430. -#line 2081 "objc-parse.y"
  63431. -{ push_parm_decl (yyvsp[0].ttype); ;
  63432. -    break;}
  63433. -case 369:
  63434. -#line 2083 "objc-parse.y"
  63435. -{ push_parm_decl (yyvsp[0].ttype); ;
  63436. -    break;}
  63437. -case 370:
  63438. -#line 2090 "objc-parse.y"
  63439. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63440. -                             yyvsp[-1].ttype),
  63441. -                    build_tree_list (prefix_attributes,
  63442. -                             yyvsp[0].ttype));
  63443. -          current_declspecs = TREE_VALUE (declspec_stack);
  63444. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63445. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63446. -          resume_momentary (yyvsp[-2].itype); ;
  63447. -    break;}
  63448. -case 371:
  63449. -#line 2099 "objc-parse.y"
  63450. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63451. -                             yyvsp[-1].ttype),
  63452. -                    build_tree_list (prefix_attributes,
  63453. -                             yyvsp[0].ttype)); 
  63454. -          current_declspecs = TREE_VALUE (declspec_stack);
  63455. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63456. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63457. -          resume_momentary (yyvsp[-2].itype); ;
  63458. -    break;}
  63459. -case 372:
  63460. -#line 2108 "objc-parse.y"
  63461. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63462. -                             yyvsp[-1].ttype),
  63463. -                    build_tree_list (prefix_attributes,
  63464. -                             yyvsp[0].ttype));
  63465. -          current_declspecs = TREE_VALUE (declspec_stack);
  63466. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63467. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63468. -          resume_momentary (yyvsp[-2].itype); ;
  63469. -    break;}
  63470. -case 373:
  63471. -#line 2117 "objc-parse.y"
  63472. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63473. -                             yyvsp[-1].ttype),
  63474. -                    build_tree_list (prefix_attributes,
  63475. -                             yyvsp[0].ttype));
  63476. -          current_declspecs = TREE_VALUE (declspec_stack);
  63477. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63478. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63479. -          resume_momentary (yyvsp[-2].itype);  ;
  63480. -    break;}
  63481. -case 374:
  63482. -#line 2127 "objc-parse.y"
  63483. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63484. -                             yyvsp[-1].ttype),
  63485. -                    build_tree_list (prefix_attributes,
  63486. -                             yyvsp[0].ttype));
  63487. -          current_declspecs = TREE_VALUE (declspec_stack);
  63488. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63489. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63490. -          resume_momentary (yyvsp[-2].itype);  ;
  63491. -    break;}
  63492. -case 375:
  63493. -#line 2141 "objc-parse.y"
  63494. -{ pushlevel (0);
  63495. -          clear_parm_order ();
  63496. -          declare_parm_level (1); ;
  63497. -    break;}
  63498. -case 376:
  63499. -#line 2145 "objc-parse.y"
  63500. -{ yyval.ttype = yyvsp[0].ttype;
  63501. -          parmlist_tags_warning ();
  63502. -          poplevel (0, 0, 0); ;
  63503. -    break;}
  63504. -case 378:
  63505. -#line 2153 "objc-parse.y"
  63506. -{ tree t;
  63507. -          for (t = yyvsp[-1].ttype; t; t = TREE_CHAIN (t))
  63508. -            if (TREE_VALUE (t) == NULL_TREE)
  63509. -              error ("`...' in old-style identifier list");
  63510. -          yyval.ttype = tree_cons (NULL_TREE, NULL_TREE, yyvsp[-1].ttype); ;
  63511. -    break;}
  63512. -case 379:
  63513. -#line 2163 "objc-parse.y"
  63514. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  63515. -    break;}
  63516. -case 380:
  63517. -#line 2165 "objc-parse.y"
  63518. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  63519. -    break;}
  63520. -case 381:
  63521. -#line 2171 "objc-parse.y"
  63522. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  63523. -    break;}
  63524. -case 382:
  63525. -#line 2173 "objc-parse.y"
  63526. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  63527. -    break;}
  63528. -case 388:
  63529. -#line 2185 "objc-parse.y"
  63530. -{
  63531. -          if (objc_implementation_context)
  63532. -                    {
  63533. -              finish_class (objc_implementation_context);
  63534. -              objc_ivar_chain = NULL_TREE;
  63535. -              objc_implementation_context = NULL_TREE;
  63536. -            }
  63537. -          else
  63538. -            warning ("`@end' must appear in an implementation context");
  63539. -        ;
  63540. -    break;}
  63541. -case 389:
  63542. -#line 2200 "objc-parse.y"
  63543. -{ yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype); ;
  63544. -    break;}
  63545. -case 390:
  63546. -#line 2202 "objc-parse.y"
  63547. -{ yyval.ttype = chainon (yyvsp[-2].ttype, build_tree_list (NULL_TREE, yyvsp[0].ttype)); ;
  63548. -    break;}
  63549. -case 391:
  63550. -#line 2207 "objc-parse.y"
  63551. -{
  63552. -          objc_declare_class (yyvsp[-1].ttype);
  63553. -        ;
  63554. -    break;}
  63555. -case 392:
  63556. -#line 2213 "objc-parse.y"
  63557. -{
  63558. -          objc_declare_alias (yyvsp[-2].ttype, yyvsp[-1].ttype);
  63559. -        ;
  63560. -    break;}
  63561. -case 393:
  63562. -#line 2219 "objc-parse.y"
  63563. -{
  63564. -          objc_interface_context = objc_ivar_context
  63565. -            = start_class (CLASS_INTERFACE_TYPE, yyvsp[-2].ttype, NULL_TREE, yyvsp[-1].ttype);
  63566. -                  objc_public_flag = 0;
  63567. -        ;
  63568. -    break;}
  63569. -case 394:
  63570. -#line 2225 "objc-parse.y"
  63571. -{
  63572. -                  continue_class (objc_interface_context);
  63573. -        ;
  63574. -    break;}
  63575. -case 395:
  63576. -#line 2230 "objc-parse.y"
  63577. -{
  63578. -          finish_class (objc_interface_context);
  63579. -          objc_interface_context = NULL_TREE;
  63580. -        ;
  63581. -    break;}
  63582. -case 396:
  63583. -#line 2236 "objc-parse.y"
  63584. -{
  63585. -          objc_interface_context
  63586. -            = start_class (CLASS_INTERFACE_TYPE, yyvsp[-1].ttype, NULL_TREE, yyvsp[0].ttype);
  63587. -                  continue_class (objc_interface_context);
  63588. -        ;
  63589. -    break;}
  63590. -case 397:
  63591. -#line 2243 "objc-parse.y"
  63592. -{
  63593. -          finish_class (objc_interface_context);
  63594. -          objc_interface_context = NULL_TREE;
  63595. -        ;
  63596. -    break;}
  63597. -case 398:
  63598. -#line 2249 "objc-parse.y"
  63599. -{
  63600. -          objc_interface_context = objc_ivar_context
  63601. -            = start_class (CLASS_INTERFACE_TYPE, yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[-1].ttype);
  63602. -                  objc_public_flag = 0;
  63603. -        ;
  63604. -    break;}
  63605. -case 399:
  63606. -#line 2255 "objc-parse.y"
  63607. -{
  63608. -                  continue_class (objc_interface_context);
  63609. -        ;
  63610. -    break;}
  63611. -case 400:
  63612. -#line 2260 "objc-parse.y"
  63613. -{
  63614. -          finish_class (objc_interface_context);
  63615. -          objc_interface_context = NULL_TREE;
  63616. -        ;
  63617. -    break;}
  63618. -case 401:
  63619. -#line 2266 "objc-parse.y"
  63620. -{
  63621. -          objc_interface_context
  63622. -            = start_class (CLASS_INTERFACE_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
  63623. -                  continue_class (objc_interface_context);
  63624. -        ;
  63625. -    break;}
  63626. -case 402:
  63627. -#line 2273 "objc-parse.y"
  63628. -{
  63629. -          finish_class (objc_interface_context);
  63630. -          objc_interface_context = NULL_TREE;
  63631. -        ;
  63632. -    break;}
  63633. -case 403:
  63634. -#line 2279 "objc-parse.y"
  63635. -{
  63636. -          objc_implementation_context = objc_ivar_context
  63637. -            = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-1].ttype, NULL_TREE, NULL_TREE);
  63638. -                  objc_public_flag = 0;
  63639. -        ;
  63640. -    break;}
  63641. -case 404:
  63642. -#line 2285 "objc-parse.y"
  63643. -{
  63644. -                  objc_ivar_chain
  63645. -            = continue_class (objc_implementation_context);
  63646. -        ;
  63647. -    break;}
  63648. -case 405:
  63649. -#line 2291 "objc-parse.y"
  63650. -{
  63651. -          objc_implementation_context
  63652. -            = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[0].ttype, NULL_TREE, NULL_TREE);
  63653. -                  objc_ivar_chain
  63654. -            = continue_class (objc_implementation_context);
  63655. -        ;
  63656. -    break;}
  63657. -case 406:
  63658. -#line 2299 "objc-parse.y"
  63659. -{
  63660. -          objc_implementation_context = objc_ivar_context
  63661. -            = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE);
  63662. -                  objc_public_flag = 0;
  63663. -        ;
  63664. -    break;}
  63665. -case 407:
  63666. -#line 2305 "objc-parse.y"
  63667. -{
  63668. -                  objc_ivar_chain
  63669. -            = continue_class (objc_implementation_context);
  63670. -        ;
  63671. -    break;}
  63672. -case 408:
  63673. -#line 2311 "objc-parse.y"
  63674. -{
  63675. -          objc_implementation_context
  63676. -            = start_class (CLASS_IMPLEMENTATION_TYPE, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE);
  63677. -                  objc_ivar_chain
  63678. -            = continue_class (objc_implementation_context);
  63679. -        ;
  63680. -    break;}
  63681. -case 409:
  63682. -#line 2319 "objc-parse.y"
  63683. -{
  63684. -          objc_interface_context
  63685. -            = start_class (CATEGORY_INTERFACE_TYPE, yyvsp[-4].ttype, yyvsp[-2].ttype, yyvsp[0].ttype);
  63686. -                  continue_class (objc_interface_context);
  63687. -        ;
  63688. -    break;}
  63689. -case 410:
  63690. -#line 2326 "objc-parse.y"
  63691. -{
  63692. -          finish_class (objc_interface_context);
  63693. -          objc_interface_context = NULL_TREE;
  63694. -        ;
  63695. -    break;}
  63696. -case 411:
  63697. -#line 2332 "objc-parse.y"
  63698. -{
  63699. -          objc_implementation_context
  63700. -            = start_class (CATEGORY_IMPLEMENTATION_TYPE, yyvsp[-3].ttype, yyvsp[-1].ttype, NULL_TREE);
  63701. -                  objc_ivar_chain
  63702. -            = continue_class (objc_implementation_context);
  63703. -        ;
  63704. -    break;}
  63705. -case 412:
  63706. -#line 2342 "objc-parse.y"
  63707. -{
  63708. -          remember_protocol_qualifiers ();
  63709. -          objc_interface_context
  63710. -            = start_protocol(PROTOCOL_INTERFACE_TYPE, yyvsp[-1].ttype, yyvsp[0].ttype);
  63711. -        ;
  63712. -    break;}
  63713. -case 413:
  63714. -#line 2348 "objc-parse.y"
  63715. -{
  63716. -          forget_protocol_qualifiers();
  63717. -          finish_protocol(objc_interface_context);
  63718. -          objc_interface_context = NULL_TREE;
  63719. -        ;
  63720. -    break;}
  63721. -case 414:
  63722. -#line 2357 "objc-parse.y"
  63723. -{
  63724. -          yyval.ttype = NULL_TREE;
  63725. -        ;
  63726. -    break;}
  63727. -case 415:
  63728. -#line 2361 "objc-parse.y"
  63729. -{
  63730. -          if (yyvsp[-2].code == LT_EXPR && yyvsp[0].code == GT_EXPR)
  63731. -            yyval.ttype = yyvsp[-1].ttype;
  63732. -          else
  63733. -            YYERROR1;
  63734. -        ;
  63735. -    break;}
  63736. -case 418:
  63737. -#line 2375 "objc-parse.y"
  63738. -{ objc_public_flag = 2; ;
  63739. -    break;}
  63740. -case 419:
  63741. -#line 2376 "objc-parse.y"
  63742. -{ objc_public_flag = 0; ;
  63743. -    break;}
  63744. -case 420:
  63745. -#line 2377 "objc-parse.y"
  63746. -{ objc_public_flag = 1; ;
  63747. -    break;}
  63748. -case 421:
  63749. -#line 2382 "objc-parse.y"
  63750. -{
  63751. -                  yyval.ttype = NULL_TREE;
  63752. -                ;
  63753. -    break;}
  63754. -case 423:
  63755. -#line 2387 "objc-parse.y"
  63756. -{
  63757. -                  if (pedantic)
  63758. -            pedwarn ("extra semicolon in struct or union specified");
  63759. -                ;
  63760. -    break;}
  63761. -case 424:
  63762. -#line 2405 "objc-parse.y"
  63763. -{ yyval.ttype = yyvsp[0].ttype;
  63764. -          current_declspecs = TREE_VALUE (declspec_stack);
  63765. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63766. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63767. -          resume_momentary (yyvsp[-1].itype); ;
  63768. -    break;}
  63769. -case 425:
  63770. -#line 2411 "objc-parse.y"
  63771. -{ yyval.ttype = yyvsp[0].ttype;
  63772. -          current_declspecs = TREE_VALUE (declspec_stack);
  63773. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63774. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63775. -          resume_momentary (yyvsp[-1].itype); ;
  63776. -    break;}
  63777. -case 426:
  63778. -#line 2417 "objc-parse.y"
  63779. -{ yyval.ttype = NULL_TREE; ;
  63780. -    break;}
  63781. -case 427:
  63782. -#line 2422 "objc-parse.y"
  63783. -{ yyval.ttype = NULL_TREE; ;
  63784. -    break;}
  63785. -case 430:
  63786. -#line 2429 "objc-parse.y"
  63787. -{
  63788. -          yyval.ttype = add_instance_variable (objc_ivar_context,
  63789. -                          objc_public_flag,
  63790. -                          yyvsp[0].ttype, current_declspecs,
  63791. -                          NULL_TREE);
  63792. -                ;
  63793. -    break;}
  63794. -case 431:
  63795. -#line 2436 "objc-parse.y"
  63796. -{
  63797. -          yyval.ttype = add_instance_variable (objc_ivar_context,
  63798. -                          objc_public_flag,
  63799. -                          yyvsp[-2].ttype, current_declspecs, yyvsp[0].ttype);
  63800. -                ;
  63801. -    break;}
  63802. -case 432:
  63803. -#line 2442 "objc-parse.y"
  63804. -{
  63805. -          yyval.ttype = add_instance_variable (objc_ivar_context,
  63806. -                          objc_public_flag,
  63807. -                          NULL_TREE,
  63808. -                          current_declspecs, yyvsp[0].ttype);
  63809. -                ;
  63810. -    break;}
  63811. -case 433:
  63812. -#line 2452 "objc-parse.y"
  63813. -{
  63814. -          remember_protocol_qualifiers ();
  63815. -          if (objc_implementation_context)
  63816. -            objc_inherit_code = CLASS_METHOD_DECL;
  63817. -                  else
  63818. -            fatal ("method definition not in class context");
  63819. -        ;
  63820. -    break;}
  63821. -case 434:
  63822. -#line 2460 "objc-parse.y"
  63823. -{
  63824. -          forget_protocol_qualifiers ();
  63825. -          add_class_method (objc_implementation_context, yyvsp[0].ttype);
  63826. -          start_method_def (yyvsp[0].ttype);
  63827. -          objc_method_context = yyvsp[0].ttype;
  63828. -        ;
  63829. -    break;}
  63830. -case 435:
  63831. -#line 2467 "objc-parse.y"
  63832. -{
  63833. -          continue_method_def ();
  63834. -        ;
  63835. -    break;}
  63836. -case 436:
  63837. -#line 2471 "objc-parse.y"
  63838. -{
  63839. -          finish_method_def ();
  63840. -          objc_method_context = NULL_TREE;
  63841. -        ;
  63842. -    break;}
  63843. -case 437:
  63844. -#line 2477 "objc-parse.y"
  63845. -{
  63846. -          remember_protocol_qualifiers ();
  63847. -          if (objc_implementation_context)
  63848. -            objc_inherit_code = INSTANCE_METHOD_DECL;
  63849. -                  else
  63850. -            fatal ("method definition not in class context");
  63851. -        ;
  63852. -    break;}
  63853. -case 438:
  63854. -#line 2485 "objc-parse.y"
  63855. -{
  63856. -          forget_protocol_qualifiers ();
  63857. -          add_instance_method (objc_implementation_context, yyvsp[0].ttype);
  63858. -          start_method_def (yyvsp[0].ttype);
  63859. -          objc_method_context = yyvsp[0].ttype;
  63860. -        ;
  63861. -    break;}
  63862. -case 439:
  63863. -#line 2492 "objc-parse.y"
  63864. -{
  63865. -          continue_method_def ();
  63866. -        ;
  63867. -    break;}
  63868. -case 440:
  63869. -#line 2496 "objc-parse.y"
  63870. -{
  63871. -          finish_method_def ();
  63872. -          objc_method_context = NULL_TREE;
  63873. -        ;
  63874. -    break;}
  63875. -case 442:
  63876. -#line 2508 "objc-parse.y"
  63877. -{yyval.ttype = NULL_TREE; ;
  63878. -    break;}
  63879. -case 447:
  63880. -#line 2515 "objc-parse.y"
  63881. -{yyval.ttype = NULL_TREE; ;
  63882. -    break;}
  63883. -case 451:
  63884. -#line 2525 "objc-parse.y"
  63885. -{
  63886. -          objc_inherit_code = CLASS_METHOD_DECL;
  63887. -        ;
  63888. -    break;}
  63889. -case 452:
  63890. -#line 2529 "objc-parse.y"
  63891. -{
  63892. -          add_class_method (objc_interface_context, yyvsp[0].ttype);
  63893. -        ;
  63894. -    break;}
  63895. -case 454:
  63896. -#line 2535 "objc-parse.y"
  63897. -{
  63898. -          objc_inherit_code = INSTANCE_METHOD_DECL;
  63899. -        ;
  63900. -    break;}
  63901. -case 455:
  63902. -#line 2539 "objc-parse.y"
  63903. -{
  63904. -          add_instance_method (objc_interface_context, yyvsp[0].ttype);
  63905. -        ;
  63906. -    break;}
  63907. -case 457:
  63908. -#line 2547 "objc-parse.y"
  63909. -{
  63910. -          yyval.ttype = build_method_decl (objc_inherit_code, yyvsp[-2].ttype, yyvsp[0].ttype, NULL_TREE);
  63911. -        ;
  63912. -    break;}
  63913. -case 458:
  63914. -#line 2552 "objc-parse.y"
  63915. -{
  63916. -          yyval.ttype = build_method_decl (objc_inherit_code, NULL_TREE, yyvsp[0].ttype, NULL_TREE);
  63917. -        ;
  63918. -    break;}
  63919. -case 459:
  63920. -#line 2557 "objc-parse.y"
  63921. -{
  63922. -          yyval.ttype = build_method_decl (objc_inherit_code, yyvsp[-3].ttype, yyvsp[-1].ttype, yyvsp[0].ttype);
  63923. -        ;
  63924. -    break;}
  63925. -case 460:
  63926. -#line 2562 "objc-parse.y"
  63927. -{
  63928. -          yyval.ttype = build_method_decl (objc_inherit_code, NULL_TREE, yyvsp[-1].ttype, yyvsp[0].ttype);
  63929. -        ;
  63930. -    break;}
  63931. -case 469:
  63932. -#line 2592 "objc-parse.y"
  63933. -{ current_declspecs = TREE_VALUE (declspec_stack);
  63934. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  63935. -          declspec_stack = TREE_CHAIN (declspec_stack);
  63936. -          resume_momentary (yyvsp[-2].itype); ;
  63937. -    break;}
  63938. -case 470:
  63939. -#line 2597 "objc-parse.y"
  63940. -{ shadow_tag (yyvsp[-1].ttype); ;
  63941. -    break;}
  63942. -case 471:
  63943. -#line 2599 "objc-parse.y"
  63944. -{ pedwarn ("empty declaration"); ;
  63945. -    break;}
  63946. -case 472:
  63947. -#line 2604 "objc-parse.y"
  63948. -{ push_parm_decl (yyvsp[0].ttype); ;
  63949. -    break;}
  63950. -case 473:
  63951. -#line 2606 "objc-parse.y"
  63952. -{ push_parm_decl (yyvsp[0].ttype); ;
  63953. -    break;}
  63954. -case 474:
  63955. -#line 2614 "objc-parse.y"
  63956. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63957. -                             yyvsp[-1].ttype),
  63958. -                    build_tree_list (prefix_attributes,
  63959. -                             yyvsp[0].ttype)); ;
  63960. -    break;}
  63961. -case 475:
  63962. -#line 2619 "objc-parse.y"
  63963. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63964. -                             yyvsp[-1].ttype),
  63965. -                    build_tree_list (prefix_attributes,
  63966. -                             yyvsp[0].ttype)); ;
  63967. -    break;}
  63968. -case 476:
  63969. -#line 2624 "objc-parse.y"
  63970. -{ yyval.ttype = build_tree_list (build_tree_list (current_declspecs,
  63971. -                             yyvsp[-1].ttype),
  63972. -                    build_tree_list (prefix_attributes,
  63973. -                             yyvsp[0].ttype)); ;
  63974. -    break;}
  63975. -case 477:
  63976. -#line 2632 "objc-parse.y"
  63977. -{
  63978. -              yyval.ttype = NULL_TREE;
  63979. -        ;
  63980. -    break;}
  63981. -case 478:
  63982. -#line 2636 "objc-parse.y"
  63983. -{
  63984. -          /* oh what a kludge! */
  63985. -          yyval.ttype = (tree)1;
  63986. -        ;
  63987. -    break;}
  63988. -case 479:
  63989. -#line 2641 "objc-parse.y"
  63990. -{
  63991. -          pushlevel (0);
  63992. -        ;
  63993. -    break;}
  63994. -case 480:
  63995. -#line 2645 "objc-parse.y"
  63996. -{
  63997. -            /* returns a tree list node generated by get_parm_info */
  63998. -          yyval.ttype = yyvsp[0].ttype;
  63999. -          poplevel (0, 0, 0);
  64000. -        ;
  64001. -    break;}
  64002. -case 483:
  64003. -#line 2660 "objc-parse.y"
  64004. -{
  64005. -          yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype);
  64006. -        ;
  64007. -    break;}
  64008. -case 488:
  64009. -#line 2673 "objc-parse.y"
  64010. -{ yyval.ttype = get_identifier (token_buffer); ;
  64011. -    break;}
  64012. -case 489:
  64013. -#line 2674 "objc-parse.y"
  64014. -{ yyval.ttype = get_identifier (token_buffer); ;
  64015. -    break;}
  64016. -case 490:
  64017. -#line 2675 "objc-parse.y"
  64018. -{ yyval.ttype = get_identifier (token_buffer); ;
  64019. -    break;}
  64020. -case 491:
  64021. -#line 2676 "objc-parse.y"
  64022. -{ yyval.ttype = get_identifier (token_buffer); ;
  64023. -    break;}
  64024. -case 492:
  64025. -#line 2677 "objc-parse.y"
  64026. -{ yyval.ttype = get_identifier (token_buffer); ;
  64027. -    break;}
  64028. -case 493:
  64029. -#line 2678 "objc-parse.y"
  64030. -{ yyval.ttype = get_identifier (token_buffer); ;
  64031. -    break;}
  64032. -case 494:
  64033. -#line 2679 "objc-parse.y"
  64034. -{ yyval.ttype = get_identifier (token_buffer); ;
  64035. -    break;}
  64036. -case 495:
  64037. -#line 2680 "objc-parse.y"
  64038. -{ yyval.ttype = get_identifier (token_buffer); ;
  64039. -    break;}
  64040. -case 496:
  64041. -#line 2681 "objc-parse.y"
  64042. -{ yyval.ttype = get_identifier (token_buffer); ;
  64043. -    break;}
  64044. -case 497:
  64045. -#line 2682 "objc-parse.y"
  64046. -{ yyval.ttype = get_identifier (token_buffer); ;
  64047. -    break;}
  64048. -case 498:
  64049. -#line 2683 "objc-parse.y"
  64050. -{ yyval.ttype = get_identifier (token_buffer); ;
  64051. -    break;}
  64052. -case 499:
  64053. -#line 2684 "objc-parse.y"
  64054. -{ yyval.ttype = get_identifier (token_buffer); ;
  64055. -    break;}
  64056. -case 500:
  64057. -#line 2685 "objc-parse.y"
  64058. -{ yyval.ttype = get_identifier (token_buffer); ;
  64059. -    break;}
  64060. -case 501:
  64061. -#line 2686 "objc-parse.y"
  64062. -{ yyval.ttype = get_identifier (token_buffer); ;
  64063. -    break;}
  64064. -case 502:
  64065. -#line 2687 "objc-parse.y"
  64066. -{ yyval.ttype = get_identifier (token_buffer); ;
  64067. -    break;}
  64068. -case 503:
  64069. -#line 2688 "objc-parse.y"
  64070. -{ yyval.ttype = get_identifier (token_buffer); ;
  64071. -    break;}
  64072. -case 504:
  64073. -#line 2689 "objc-parse.y"
  64074. -{ yyval.ttype = get_identifier (token_buffer); ;
  64075. -    break;}
  64076. -case 505:
  64077. -#line 2690 "objc-parse.y"
  64078. -{ yyval.ttype = get_identifier (token_buffer); ;
  64079. -    break;}
  64080. -case 506:
  64081. -#line 2691 "objc-parse.y"
  64082. -{ yyval.ttype = get_identifier (token_buffer); ;
  64083. -    break;}
  64084. -case 509:
  64085. -#line 2697 "objc-parse.y"
  64086. -{
  64087. -          yyval.ttype = build_keyword_decl (yyvsp[-5].ttype, yyvsp[-2].ttype, yyvsp[0].ttype);
  64088. -        ;
  64089. -    break;}
  64090. -case 510:
  64091. -#line 2702 "objc-parse.y"
  64092. -{
  64093. -          yyval.ttype = build_keyword_decl (yyvsp[-2].ttype, NULL_TREE, yyvsp[0].ttype);
  64094. -        ;
  64095. -    break;}
  64096. -case 511:
  64097. -#line 2707 "objc-parse.y"
  64098. -{
  64099. -          yyval.ttype = build_keyword_decl (NULL_TREE, yyvsp[-2].ttype, yyvsp[0].ttype);
  64100. -        ;
  64101. -    break;}
  64102. -case 512:
  64103. -#line 2712 "objc-parse.y"
  64104. -{
  64105. -          yyval.ttype = build_keyword_decl (NULL_TREE, NULL_TREE, yyvsp[0].ttype);
  64106. -        ;
  64107. -    break;}
  64108. -case 516:
  64109. -#line 2725 "objc-parse.y"
  64110. -{
  64111. -          yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype);
  64112. -        ;
  64113. -    break;}
  64114. -case 517:
  64115. -#line 2733 "objc-parse.y"
  64116. -{
  64117. -          if (TREE_CHAIN (yyvsp[0].ttype) == NULL_TREE)
  64118. -            /* just return the expr., remove a level of indirection */
  64119. -            yyval.ttype = TREE_VALUE (yyvsp[0].ttype);
  64120. -                  else
  64121. -            /* we have a comma expr., we will collapse later */
  64122. -            yyval.ttype = yyvsp[0].ttype;
  64123. -        ;
  64124. -    break;}
  64125. -case 518:
  64126. -#line 2745 "objc-parse.y"
  64127. -{
  64128. -          yyval.ttype = build_tree_list (yyvsp[-2].ttype, yyvsp[0].ttype);
  64129. -        ;
  64130. -    break;}
  64131. -case 519:
  64132. -#line 2749 "objc-parse.y"
  64133. -{
  64134. -          yyval.ttype = build_tree_list (NULL_TREE, yyvsp[0].ttype);
  64135. -        ;
  64136. -    break;}
  64137. -case 521:
  64138. -#line 2757 "objc-parse.y"
  64139. -{
  64140. -          yyval.ttype = get_class_reference (yyvsp[0].ttype);
  64141. -        ;
  64142. -    break;}
  64143. -case 522:
  64144. -#line 2764 "objc-parse.y"
  64145. -{ objc_receiver_context = 1; ;
  64146. -    break;}
  64147. -case 523:
  64148. -#line 2766 "objc-parse.y"
  64149. -{ objc_receiver_context = 0; ;
  64150. -    break;}
  64151. -case 524:
  64152. -#line 2768 "objc-parse.y"
  64153. -{
  64154. -          yyval.ttype = build_tree_list (yyvsp[-3].ttype, yyvsp[-1].ttype);
  64155. -        ;
  64156. -    break;}
  64157. -case 528:
  64158. -#line 2781 "objc-parse.y"
  64159. -{
  64160. -          yyval.ttype = chainon (yyvsp[-1].ttype, yyvsp[0].ttype);
  64161. -        ;
  64162. -    break;}
  64163. -case 529:
  64164. -#line 2788 "objc-parse.y"
  64165. -{
  64166. -          yyval.ttype = build_tree_list (yyvsp[-1].ttype, NULL_TREE);
  64167. -        ;
  64168. -    break;}
  64169. -case 530:
  64170. -#line 2792 "objc-parse.y"
  64171. -{
  64172. -          yyval.ttype = build_tree_list (NULL_TREE, NULL_TREE);
  64173. -        ;
  64174. -    break;}
  64175. -case 531:
  64176. -#line 2799 "objc-parse.y"
  64177. -{
  64178. -          yyval.ttype = yyvsp[-1].ttype;
  64179. -        ;
  64180. -    break;}
  64181. -case 532:
  64182. -#line 2806 "objc-parse.y"
  64183. -{
  64184. -          yyval.ttype = yyvsp[-1].ttype;
  64185. -        ;
  64186. -    break;}
  64187. -case 533:
  64188. -#line 2815 "objc-parse.y"
  64189. -{
  64190. -          yyval.ttype = groktypename (yyvsp[-1].ttype);
  64191. -        ;
  64192. -    break;}
  64193. -}
  64194. -   /* the action file gets copied in in place of this dollarsign */
  64195. -#line 480 "/usr/local/lib/bison.simple"
  64196. -
  64197. -  yyvsp -= yylen;
  64198. -  yyssp -= yylen;
  64199. -#ifdef YYLSP_NEEDED
  64200. -  yylsp -= yylen;
  64201. -#endif
  64202. -
  64203. -#if YYDEBUG != 0
  64204. -  if (yydebug)
  64205. -    {
  64206. -      short *ssp1 = yyss - 1;
  64207. -      fprintf (stderr, "state stack now");
  64208. -      while (ssp1 != yyssp)
  64209. -    fprintf (stderr, " %d", *++ssp1);
  64210. -      fprintf (stderr, "\n");
  64211. -    }
  64212. -#endif
  64213. -
  64214. -  *++yyvsp = yyval;
  64215. -
  64216. -#ifdef YYLSP_NEEDED
  64217. -  yylsp++;
  64218. -  if (yylen == 0)
  64219. -    {
  64220. -      yylsp->first_line = yylloc.first_line;
  64221. -      yylsp->first_column = yylloc.first_column;
  64222. -      yylsp->last_line = (yylsp-1)->last_line;
  64223. -      yylsp->last_column = (yylsp-1)->last_column;
  64224. -      yylsp->text = 0;
  64225. -    }
  64226. -  else
  64227. -    {
  64228. -      yylsp->last_line = (yylsp+yylen-1)->last_line;
  64229. -      yylsp->last_column = (yylsp+yylen-1)->last_column;
  64230. -    }
  64231. -#endif
  64232. -
  64233. -  /* Now "shift" the result of the reduction.
  64234. -     Determine what state that goes to,
  64235. -     based on the state we popped back to
  64236. -     and the rule number reduced by.  */
  64237. -
  64238. -  yyn = yyr1[yyn];
  64239. -
  64240. -  yystate = yypgoto[yyn - YYNTBASE] + *yyssp;
  64241. -  if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp)
  64242. -    yystate = yytable[yystate];
  64243. -  else
  64244. -    yystate = yydefgoto[yyn - YYNTBASE];
  64245. -
  64246. -  goto yynewstate;
  64247. -
  64248. -yyerrlab:   /* here on detecting error */
  64249. -
  64250. -  if (! yyerrstatus)
  64251. -    /* If not already recovering from an error, report this error.  */
  64252. -    {
  64253. -      ++yynerrs;
  64254. -
  64255. -#ifdef YYERROR_VERBOSE
  64256. -      yyn = yypact[yystate];
  64257. -
  64258. -      if (yyn > YYFLAG && yyn < YYLAST)
  64259. -    {
  64260. -      int size = 0;
  64261. -      char *msg;
  64262. -      int x, count;
  64263. -
  64264. -      count = 0;
  64265. -      /* Start X at -yyn if nec to avoid negative indexes in yycheck.  */
  64266. -      for (x = (yyn < 0 ? -yyn : 0);
  64267. -           x < (sizeof(yytname) / sizeof(char *)); x++)
  64268. -        if (yycheck[x + yyn] == x)
  64269. -          size += strlen(yytname[x]) + 15, count++;
  64270. -      msg = (char *) malloc(size + 15);
  64271. -      if (msg != 0)
  64272. -        {
  64273. -          strcpy(msg, "parse error");
  64274. -
  64275. -          if (count < 5)
  64276. -        {
  64277. -          count = 0;
  64278. -          for (x = (yyn < 0 ? -yyn : 0);
  64279. -               x < (sizeof(yytname) / sizeof(char *)); x++)
  64280. -            if (yycheck[x + yyn] == x)
  64281. -              {
  64282. -            strcat(msg, count == 0 ? ", expecting `" : " or `");
  64283. -            strcat(msg, yytname[x]);
  64284. -            strcat(msg, "'");
  64285. -            count++;
  64286. -              }
  64287. -        }
  64288. -          yyerror(msg);
  64289. -          free(msg);
  64290. -        }
  64291. -      else
  64292. -        yyerror ("parse error; also virtual memory exceeded");
  64293. -    }
  64294. -      else
  64295. -#endif /* YYERROR_VERBOSE */
  64296. -    yyerror("parse error");
  64297. -    }
  64298. -
  64299. -  goto yyerrlab1;
  64300. -yyerrlab1:   /* here on error raised explicitly by an action */
  64301. -
  64302. -  if (yyerrstatus == 3)
  64303. -    {
  64304. -      /* if just tried and failed to reuse lookahead token after an error, discard it.  */
  64305. -
  64306. -      /* return failure if at end of input */
  64307. -      if (yychar == YYEOF)
  64308. -    YYABORT;
  64309. -
  64310. -#if YYDEBUG != 0
  64311. -      if (yydebug)
  64312. -    fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]);
  64313. -#endif
  64314. -
  64315. -      yychar = YYEMPTY;
  64316. -    }
  64317. -
  64318. -  /* Else will try to reuse lookahead token
  64319. -     after shifting the error token.  */
  64320. -
  64321. -  yyerrstatus = 3;        /* Each real token shifted decrements this */
  64322. -
  64323. -  goto yyerrhandle;
  64324. -
  64325. -yyerrdefault:  /* current state does not do anything special for the error token. */
  64326. -
  64327. -#if 0
  64328. -  /* This is wrong; only states that explicitly want error tokens
  64329. -     should shift them.  */
  64330. -  yyn = yydefact[yystate];  /* If its default is to accept any token, ok.  Otherwise pop it.*/
  64331. -  if (yyn) goto yydefault;
  64332. -#endif
  64333. -
  64334. -yyerrpop:   /* pop the current state because it cannot handle the error token */
  64335. -
  64336. -  if (yyssp == yyss) YYABORT;
  64337. -  yyvsp--;
  64338. -  yystate = *--yyssp;
  64339. -#ifdef YYLSP_NEEDED
  64340. -  yylsp--;
  64341. -#endif
  64342. -
  64343. -#if YYDEBUG != 0
  64344. -  if (yydebug)
  64345. -    {
  64346. -      short *ssp1 = yyss - 1;
  64347. -      fprintf (stderr, "Error: state stack now");
  64348. -      while (ssp1 != yyssp)
  64349. -    fprintf (stderr, " %d", *++ssp1);
  64350. -      fprintf (stderr, "\n");
  64351. -    }
  64352. -#endif
  64353. -
  64354. -yyerrhandle:
  64355. -
  64356. -  yyn = yypact[yystate];
  64357. -  if (yyn == YYFLAG)
  64358. -    goto yyerrdefault;
  64359. -
  64360. -  yyn += YYTERROR;
  64361. -  if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR)
  64362. -    goto yyerrdefault;
  64363. -
  64364. -  yyn = yytable[yyn];
  64365. -  if (yyn < 0)
  64366. -    {
  64367. -      if (yyn == YYFLAG)
  64368. -    goto yyerrpop;
  64369. -      yyn = -yyn;
  64370. -      goto yyreduce;
  64371. -    }
  64372. -  else if (yyn == 0)
  64373. -    goto yyerrpop;
  64374. -
  64375. -  if (yyn == YYFINAL)
  64376. -    YYACCEPT;
  64377. -
  64378. -#if YYDEBUG != 0
  64379. -  if (yydebug)
  64380. -    fprintf(stderr, "Shifting error token, ");
  64381. -#endif
  64382. -
  64383. -  *++yyvsp = yylval;
  64384. -#ifdef YYLSP_NEEDED
  64385. -  *++yylsp = yylloc;
  64386. -#endif
  64387. -
  64388. -  yystate = yyn;
  64389. -  goto yynewstate;
  64390. -}
  64391. -#line 2820 "objc-parse.y"
  64392. -
  64393. diff -rup --new-file baseline/fsf/gcc/objc-parse.y amiga/fsf/gcc/objc-parse.y
  64394. --- baseline/fsf/gcc/objc-parse.y    Sat Sep 23 09:23:00 1995
  64395. +++ amiga/fsf/gcc/objc-parse.y    Wed Dec 31 17:00:00 1969
  64396. @@ -1,2820 +0,0 @@
  64397. -/* YACC parser for C syntax and for Objective C.  -*-c-*-
  64398. -   Copyright (C) 1987, 88, 89, 92, 93, 94, 1995 Free Software Foundation, Inc.
  64399. -
  64400. -This file is part of GNU CC.
  64401. -
  64402. -GNU CC is free software; you can redistribute it and/or modify
  64403. -it under the terms of the GNU General Public License as published by
  64404. -the Free Software Foundation; either version 2, or (at your option)
  64405. -any later version.
  64406. -
  64407. -GNU CC is distributed in the hope that it will be useful,
  64408. -but WITHOUT ANY WARRANTY; without even the implied warranty of
  64409. -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  64410. -GNU General Public License for more details.
  64411. -
  64412. -You should have received a copy of the GNU General Public License
  64413. -along with GNU CC; see the file COPYING.  If not, write to
  64414. -the Free Software Foundation, 59 Temple Place - Suite 330,
  64415. -Boston, MA 02111-1307, USA.  */
  64416. -
  64417. -/* This file defines the grammar of C and that of Objective C.
  64418. -   ifobjc ... end ifobjc  conditionals contain code for Objective C only.
  64419. -   ifc ... end ifc  conditionals contain code for C only.
  64420. -   Sed commands in Makefile.in are used to convert this file into
  64421. -   c-parse.y and into objc-parse.y.  */
  64422. -
  64423. -/* To whomever it may concern: I have heard that such a thing was once
  64424. -   written by AT&T, but I have never seen it.  */
  64425. -
  64426. -%expect 48
  64427. -
  64428. -%{
  64429. -#include <stdio.h>
  64430. -#include <errno.h>
  64431. -#include <setjmp.h>
  64432. -
  64433. -#include "config.h"
  64434. -#include "tree.h"
  64435. -#include "input.h"
  64436. -#include "c-lex.h"
  64437. -#include "c-tree.h"
  64438. -#include "flags.h"
  64439. -
  64440. -#ifdef MULTIBYTE_CHARS
  64441. -#include <stdlib.h>
  64442. -#include <locale.h>
  64443. -#endif
  64444. -
  64445. -#include "objc-act.h"
  64446. -
  64447. -/* Since parsers are distinct for each language, put the language string
  64448. -   definition here.  */
  64449. -char *language_string = "GNU Obj-C";
  64450. -
  64451. -#ifndef errno
  64452. -extern int errno;
  64453. -#endif
  64454. -
  64455. -void yyerror ();
  64456. -
  64457. -/* Like YYERROR but do call yyerror.  */
  64458. -#define YYERROR1 { yyerror ("syntax error"); YYERROR; }
  64459. -
  64460. -/* Cause the `yydebug' variable to be defined.  */
  64461. -#define YYDEBUG 1
  64462. -%}
  64463. -
  64464. -%start program
  64465. -
  64466. -%union {long itype; tree ttype; enum tree_code code;
  64467. -    char *filename; int lineno; int ends_in_label; }
  64468. -
  64469. -/* All identifiers that are not reserved words
  64470. -   and are not declared typedefs in the current block */
  64471. -%token IDENTIFIER
  64472. -
  64473. -/* All identifiers that are declared typedefs in the current block.
  64474. -   In some contexts, they are treated just like IDENTIFIER,
  64475. -   but they can also serve as typespecs in declarations.  */
  64476. -%token TYPENAME
  64477. -
  64478. -/* Reserved words that specify storage class.
  64479. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  64480. -%token SCSPEC
  64481. -
  64482. -/* Reserved words that specify type.
  64483. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  64484. -%token TYPESPEC
  64485. -
  64486. -/* Reserved words that qualify type: "const" or "volatile".
  64487. -   yylval contains an IDENTIFIER_NODE which indicates which one.  */
  64488. -%token TYPE_QUAL
  64489. -
  64490. -/* Character or numeric constants.
  64491. -   yylval is the node for the constant.  */
  64492. -%token CONSTANT
  64493. -
  64494. -/* String constants in raw form.
  64495. -   yylval is a STRING_CST node.  */
  64496. -%token STRING
  64497. -
  64498. -/* "...", used for functions with variable arglists.  */
  64499. -%token ELLIPSIS
  64500. -
  64501. -/* the reserved words */
  64502. -/* SCO include files test "ASM", so use something else. */
  64503. -%token SIZEOF ENUM STRUCT UNION IF ELSE WHILE DO FOR SWITCH CASE DEFAULT
  64504. -%token BREAK CONTINUE RETURN GOTO ASM_KEYWORD TYPEOF ALIGNOF
  64505. -%token ATTRIBUTE EXTENSION LABEL
  64506. -%token REALPART IMAGPART
  64507. -
  64508. -/* Add precedence rules to solve dangling else s/r conflict */
  64509. -%nonassoc IF
  64510. -%nonassoc ELSE
  64511. -
  64512. -/* Define the operator tokens and their precedences.
  64513. -   The value is an integer because, if used, it is the tree code
  64514. -   to use in the expression made from the operator.  */
  64515. -
  64516. -%right <code> ASSIGN '='
  64517. -%right <code> '?' ':'
  64518. -%left <code> OROR
  64519. -%left <code> ANDAND
  64520. -%left <code> '|'
  64521. -%left <code> '^'
  64522. -%left <code> '&'
  64523. -%left <code> EQCOMPARE
  64524. -%left <code> ARITHCOMPARE
  64525. -%left <code> LSHIFT RSHIFT
  64526. -%left <code> '+' '-'
  64527. -%left <code> '*' '/' '%'
  64528. -%right <code> UNARY PLUSPLUS MINUSMINUS
  64529. -%left HYPERUNARY
  64530. -%left <code> POINTSAT '.' '(' '['
  64531. -
  64532. -/* The Objective-C keywords.  These are included in C and in
  64533. -   Objective C, so that the token codes are the same in both.  */
  64534. -%token INTERFACE IMPLEMENTATION END SELECTOR DEFS ENCODE
  64535. -%token CLASSNAME PUBLIC PRIVATE PROTECTED PROTOCOL OBJECTNAME CLASS ALIAS
  64536. -
  64537. -/* Objective-C string constants in raw form.
  64538. -   yylval is an OBJC_STRING_CST node.  */
  64539. -%token OBJC_STRING
  64540. -
  64541. -
  64542. -%type <code> unop
  64543. -
  64544. -%type <ttype> identifier IDENTIFIER TYPENAME CONSTANT expr nonnull_exprlist exprlist
  64545. -%type <ttype> expr_no_commas cast_expr unary_expr primary string STRING
  64546. -%type <ttype> typed_declspecs reserved_declspecs
  64547. -%type <ttype> typed_typespecs reserved_typespecquals
  64548. -%type <ttype> declmods typespec typespecqual_reserved
  64549. -%type <ttype> SCSPEC TYPESPEC TYPE_QUAL nonempty_type_quals maybe_type_qual
  64550. -%type <ttype> initdecls notype_initdecls initdcl notype_initdcl
  64551. -%type <ttype> init maybeasm
  64552. -%type <ttype> asm_operands nonnull_asm_operands asm_operand asm_clobbers
  64553. -%type <ttype> maybe_attribute attributes attribute attribute_list attrib
  64554. -%type <ttype> any_word
  64555. -
  64556. -%type <ttype> compstmt
  64557. -
  64558. -%type <ttype> declarator
  64559. -%type <ttype> notype_declarator after_type_declarator
  64560. -%type <ttype> parm_declarator
  64561. -
  64562. -%type <ttype> structsp component_decl_list component_decl_list2
  64563. -%type <ttype> component_decl components component_declarator
  64564. -%type <ttype> enumlist enumerator
  64565. -%type <ttype> typename absdcl absdcl1 type_quals
  64566. -%type <ttype> xexpr parms parm identifiers
  64567. -
  64568. -%type <ttype> parmlist parmlist_1 parmlist_2
  64569. -%type <ttype> parmlist_or_identifiers parmlist_or_identifiers_1
  64570. -%type <ttype> identifiers_or_typenames
  64571. -
  64572. -%type <itype> setspecs
  64573. -
  64574. -%type <ends_in_label> lineno_stmt_or_label lineno_stmt_or_labels stmt_or_label
  64575. -
  64576. -%type <filename> save_filename
  64577. -%type <lineno> save_lineno
  64578. -
  64579. -/* the Objective-C nonterminals */
  64580. -
  64581. -%type <ttype> ivar_decl_list ivar_decls ivar_decl ivars ivar_declarator
  64582. -%type <ttype> methoddecl unaryselector keywordselector selector
  64583. -%type <ttype> keyworddecl receiver objcmessageexpr messageargs
  64584. -%type <ttype> keywordexpr keywordarglist keywordarg
  64585. -%type <ttype> myparms myparm optparmlist reservedwords objcselectorexpr
  64586. -%type <ttype> selectorarg keywordnamelist keywordname objcencodeexpr
  64587. -%type <ttype> objc_string protocolrefs identifier_list objcprotocolexpr
  64588. -%type <ttype> CLASSNAME OBJC_STRING OBJECTNAME
  64589. -
  64590. -%{
  64591. -/* Number of statements (loosely speaking) seen so far.  */
  64592. -static int stmt_count;
  64593. -
  64594. -/* Input file and line number of the end of the body of last simple_if;
  64595. -   used by the stmt-rule immediately after simple_if returns.  */
  64596. -static char *if_stmt_file;
  64597. -static int if_stmt_line;
  64598. -
  64599. -/* List of types and structure classes of the current declaration.  */
  64600. -static tree current_declspecs;
  64601. -static tree prefix_attributes = NULL_TREE;
  64602. -
  64603. -/* Stack of saved values of current_declspecs and prefix_attributes.  */
  64604. -static tree declspec_stack;
  64605. -
  64606. -/* 1 if we explained undeclared var errors.  */
  64607. -static int undeclared_variable_notice;
  64608. -
  64609. -/* Objective-C specific information */
  64610. -
  64611. -tree objc_interface_context;
  64612. -tree objc_implementation_context;
  64613. -tree objc_method_context;
  64614. -tree objc_ivar_chain;
  64615. -tree objc_ivar_context;
  64616. -enum tree_code objc_inherit_code;
  64617. -int objc_receiver_context;
  64618. -int objc_public_flag;
  64619. -
  64620. -
  64621. -/* Tell yyparse how to print a token's value, if yydebug is set.  */
  64622. -
  64623. -#define YYPRINT(FILE,YYCHAR,YYLVAL) yyprint(FILE,YYCHAR,YYLVAL)
  64624. -extern void yyprint ();
  64625. -%}
  64626. -
  64627. -%%
  64628. -program: /* empty */
  64629. -        { if (pedantic)
  64630. -            pedwarn ("ANSI C forbids an empty source file");
  64631. -          finish_file ();
  64632. -        }
  64633. -    | extdefs
  64634. -        {
  64635. -          /* In case there were missing closebraces,
  64636. -             get us back to the global binding level.  */
  64637. -          while (! global_bindings_p ())
  64638. -            poplevel (0, 0, 0);
  64639. -          finish_file ();
  64640. -        }
  64641. -    ;
  64642. -
  64643. -/* the reason for the strange actions in this rule
  64644. - is so that notype_initdecls when reached via datadef
  64645. - can find a valid list of type and sc specs in $0. */
  64646. -
  64647. -extdefs:
  64648. -    {$<ttype>$ = NULL_TREE; } extdef
  64649. -    | extdefs {$<ttype>$ = NULL_TREE; } extdef
  64650. -    ;
  64651. -
  64652. -extdef:
  64653. -    fndef
  64654. -    | datadef
  64655. -    | objcdef
  64656. -    | ASM_KEYWORD '(' expr ')' ';'
  64657. -        { STRIP_NOPS ($3);
  64658. -          if ((TREE_CODE ($3) == ADDR_EXPR
  64659. -               && TREE_CODE (TREE_OPERAND ($3, 0)) == STRING_CST)
  64660. -              || TREE_CODE ($3) == STRING_CST)
  64661. -            assemble_asm ($3);
  64662. -          else
  64663. -            error ("argument of `asm' is not a constant string"); }
  64664. -    ;
  64665. -
  64666. -datadef:
  64667. -      setspecs notype_initdecls ';'
  64668. -        { if (pedantic)
  64669. -            error ("ANSI C forbids data definition with no type or storage class");
  64670. -          else if (!flag_traditional)
  64671. -            warning ("data definition has no type or storage class"); 
  64672. -
  64673. -          current_declspecs = TREE_VALUE (declspec_stack);
  64674. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64675. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64676. -          resume_momentary ($1); }
  64677. -        | declmods setspecs notype_initdecls ';'
  64678. -        { current_declspecs = TREE_VALUE (declspec_stack);
  64679. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64680. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64681. -          resume_momentary ($2); }
  64682. -    | typed_declspecs setspecs initdecls ';'
  64683. -        { current_declspecs = TREE_VALUE (declspec_stack);
  64684. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64685. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64686. -          resume_momentary ($2);  }
  64687. -        | declmods ';'
  64688. -      { pedwarn ("empty declaration"); }
  64689. -    | typed_declspecs ';'
  64690. -      { shadow_tag ($1); }
  64691. -    | error ';'
  64692. -    | error '}'
  64693. -    | ';'
  64694. -        { if (pedantic)
  64695. -            pedwarn ("ANSI C does not allow extra `;' outside of a function"); }
  64696. -    ;
  64697. -
  64698. -fndef:
  64699. -      typed_declspecs setspecs declarator
  64700. -        { if (! start_function ($1, $3, prefix_attributes,
  64701. -                    NULL_TREE, 0))
  64702. -            YYERROR1;
  64703. -          reinit_parse_for_function (); }
  64704. -      xdecls
  64705. -        { store_parm_decls (); }
  64706. -      compstmt_or_error
  64707. -        { finish_function (0); 
  64708. -          current_declspecs = TREE_VALUE (declspec_stack);
  64709. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64710. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64711. -          resume_momentary ($2); }
  64712. -    | typed_declspecs setspecs declarator error
  64713. -        { current_declspecs = TREE_VALUE (declspec_stack);
  64714. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64715. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64716. -          resume_momentary ($2); }
  64717. -    | declmods setspecs notype_declarator
  64718. -        { if (! start_function ($1, $3, prefix_attributes,
  64719. -                    NULL_TREE, 0))
  64720. -            YYERROR1;
  64721. -          reinit_parse_for_function (); }
  64722. -      xdecls
  64723. -        { store_parm_decls (); }
  64724. -      compstmt_or_error
  64725. -        { finish_function (0); 
  64726. -          current_declspecs = TREE_VALUE (declspec_stack);
  64727. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64728. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64729. -          resume_momentary ($2); }
  64730. -    | declmods setspecs notype_declarator error
  64731. -        { current_declspecs = TREE_VALUE (declspec_stack);
  64732. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64733. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64734. -          resume_momentary ($2); }
  64735. -    | setspecs notype_declarator
  64736. -        { if (! start_function (NULL_TREE, $2,
  64737. -                    prefix_attributes, NULL_TREE, 0))
  64738. -            YYERROR1;
  64739. -          reinit_parse_for_function (); }
  64740. -      xdecls
  64741. -        { store_parm_decls (); }
  64742. -      compstmt_or_error
  64743. -        { finish_function (0); 
  64744. -          current_declspecs = TREE_VALUE (declspec_stack);
  64745. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64746. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64747. -          resume_momentary ($1); }
  64748. -    | setspecs notype_declarator error
  64749. -        { current_declspecs = TREE_VALUE (declspec_stack);
  64750. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  64751. -          declspec_stack = TREE_CHAIN (declspec_stack);
  64752. -          resume_momentary ($1); }
  64753. -    ;
  64754. -
  64755. -identifier:
  64756. -    IDENTIFIER
  64757. -    | TYPENAME
  64758. -    | OBJECTNAME
  64759. -        | CLASSNAME
  64760. -    ;
  64761. -
  64762. -unop:     '&'
  64763. -        { $$ = ADDR_EXPR; }
  64764. -    | '-'
  64765. -        { $$ = NEGATE_EXPR; }
  64766. -    | '+'
  64767. -        { $$ = CONVERT_EXPR; }
  64768. -    | PLUSPLUS
  64769. -        { $$ = PREINCREMENT_EXPR; }
  64770. -    | MINUSMINUS
  64771. -        { $$ = PREDECREMENT_EXPR; }
  64772. -    | '~'
  64773. -        { $$ = BIT_NOT_EXPR; }
  64774. -    | '!'
  64775. -        { $$ = TRUTH_NOT_EXPR; }
  64776. -    ;
  64777. -
  64778. -expr:    nonnull_exprlist
  64779. -        { $$ = build_compound_expr ($1); }
  64780. -    ;
  64781. -
  64782. -exprlist:
  64783. -      /* empty */
  64784. -        { $$ = NULL_TREE; }
  64785. -    | nonnull_exprlist
  64786. -    ;
  64787. -
  64788. -nonnull_exprlist:
  64789. -    expr_no_commas
  64790. -        { $$ = build_tree_list (NULL_TREE, $1); }
  64791. -    | nonnull_exprlist ',' expr_no_commas
  64792. -        { chainon ($1, build_tree_list (NULL_TREE, $3)); }
  64793. -    ;
  64794. -
  64795. -unary_expr:
  64796. -    primary
  64797. -    | '*' cast_expr   %prec UNARY
  64798. -        { $$ = build_indirect_ref ($2, "unary *"); }
  64799. -    /* __extension__ turns off -pedantic for following primary.  */
  64800. -    | EXTENSION
  64801. -        { $<itype>1 = pedantic;
  64802. -          pedantic = 0; }
  64803. -      cast_expr      %prec UNARY
  64804. -        { $$ = $3;
  64805. -          pedantic = $<itype>1; }
  64806. -    | unop cast_expr  %prec UNARY
  64807. -        { $$ = build_unary_op ($1, $2, 0);
  64808. -          overflow_warning ($$); }
  64809. -    /* Refer to the address of a label as a pointer.  */
  64810. -    | ANDAND identifier
  64811. -        { tree label = lookup_label ($2);
  64812. -          if (pedantic)
  64813. -            pedwarn ("ANSI C forbids `&&'");
  64814. -          if (label == 0)
  64815. -            $$ = null_pointer_node;
  64816. -          else
  64817. -            {
  64818. -              TREE_USED (label) = 1;
  64819. -              $$ = build1 (ADDR_EXPR, ptr_type_node, label);
  64820. -              TREE_CONSTANT ($$) = 1;
  64821. -            }
  64822. -        }
  64823. -/* This seems to be impossible on some machines, so let's turn it off.
  64824. -   You can use __builtin_next_arg to find the anonymous stack args.
  64825. -    | '&' ELLIPSIS
  64826. -        { tree types = TYPE_ARG_TYPES (TREE_TYPE (current_function_decl));
  64827. -          $$ = error_mark_node;
  64828. -          if (TREE_VALUE (tree_last (types)) == void_type_node)
  64829. -            error ("`&...' used in function with fixed number of arguments");
  64830. -          else
  64831. -            {
  64832. -              if (pedantic)
  64833. -            pedwarn ("ANSI C forbids `&...'");
  64834. -              $$ = tree_last (DECL_ARGUMENTS (current_function_decl));
  64835. -              $$ = build_unary_op (ADDR_EXPR, $$, 0);
  64836. -            } }
  64837. -*/
  64838. -    | SIZEOF unary_expr  %prec UNARY
  64839. -        { if (TREE_CODE ($2) == COMPONENT_REF
  64840. -              && DECL_BIT_FIELD (TREE_OPERAND ($2, 1)))
  64841. -            error ("`sizeof' applied to a bit-field");
  64842. -          $$ = c_sizeof (TREE_TYPE ($2)); }
  64843. -    | SIZEOF '(' typename ')'  %prec HYPERUNARY
  64844. -        { $$ = c_sizeof (groktypename ($3)); }
  64845. -    | ALIGNOF unary_expr  %prec UNARY
  64846. -        { $$ = c_alignof_expr ($2); }
  64847. -    | ALIGNOF '(' typename ')'  %prec HYPERUNARY
  64848. -        { $$ = c_alignof (groktypename ($3)); }
  64849. -    | REALPART cast_expr %prec UNARY
  64850. -        { $$ = build_unary_op (REALPART_EXPR, $2, 0); }
  64851. -    | IMAGPART cast_expr %prec UNARY
  64852. -        { $$ = build_unary_op (IMAGPART_EXPR, $2, 0); }
  64853. -    ;
  64854. -
  64855. -cast_expr:
  64856. -    unary_expr
  64857. -    | '(' typename ')' cast_expr  %prec UNARY
  64858. -        { tree type = groktypename ($2);
  64859. -          $$ = build_c_cast (type, $4); }
  64860. -    | '(' typename ')' '{' 
  64861. -        { start_init (NULL_TREE, NULL, 0);
  64862. -          $2 = groktypename ($2);
  64863. -          really_start_incremental_init ($2); }
  64864. -      initlist_maybe_comma '}'  %prec UNARY
  64865. -        { char *name;
  64866. -          tree result = pop_init_level (0);
  64867. -          tree type = $2;
  64868. -          finish_init ();
  64869. -
  64870. -          if (pedantic)
  64871. -            pedwarn ("ANSI C forbids constructor expressions");
  64872. -          if (TYPE_NAME (type) != 0)
  64873. -            {
  64874. -              if (TREE_CODE (TYPE_NAME (type)) == IDENTIFIER_NODE)
  64875. -            name = IDENTIFIER_POINTER (TYPE_NAME (type));
  64876. -              else
  64877. -            name = IDENTIFIER_POINTER (DECL_NAME (TYPE_NAME (type)));
  64878. -            }
  64879. -          else
  64880. -            name = "";
  64881. -          $$ = result;
  64882. -          if (TREE_CODE (type) == ARRAY_TYPE && TYPE_SIZE (type) == 0)
  64883. -            {
  64884. -              int failure = complete_array_type (type, $$, 1);
  64885. -              if (failure)
  64886. -            abort ();
  64887. -            }
  64888. -        }
  64889. -    ;
  64890. -
  64891. -expr_no_commas:
  64892. -      cast_expr
  64893. -    | expr_no_commas '+' expr_no_commas
  64894. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64895. -    | expr_no_commas '-' expr_no_commas
  64896. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64897. -    | expr_no_commas '*' expr_no_commas
  64898. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64899. -    | expr_no_commas '/' expr_no_commas
  64900. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64901. -    | expr_no_commas '%' expr_no_commas
  64902. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64903. -    | expr_no_commas LSHIFT expr_no_commas
  64904. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64905. -    | expr_no_commas RSHIFT expr_no_commas
  64906. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64907. -    | expr_no_commas ARITHCOMPARE expr_no_commas
  64908. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64909. -    | expr_no_commas EQCOMPARE expr_no_commas
  64910. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64911. -    | expr_no_commas '&' expr_no_commas
  64912. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64913. -    | expr_no_commas '|' expr_no_commas
  64914. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64915. -    | expr_no_commas '^' expr_no_commas
  64916. -        { $$ = parser_build_binary_op ($2, $1, $3); }
  64917. -    | expr_no_commas ANDAND expr_no_commas
  64918. -        { $$ = parser_build_binary_op (TRUTH_ANDIF_EXPR, $1, $3); }
  64919. -    | expr_no_commas OROR expr_no_commas
  64920. -        { $$ = parser_build_binary_op (TRUTH_ORIF_EXPR, $1, $3); }
  64921. -    | expr_no_commas '?' xexpr ':' expr_no_commas
  64922. -        { $$ = build_conditional_expr ($1, $3, $5); }
  64923. -    | expr_no_commas '=' expr_no_commas
  64924. -        { $$ = build_modify_expr ($1, NOP_EXPR, $3);
  64925. -          C_SET_EXP_ORIGINAL_CODE ($$, MODIFY_EXPR); }
  64926. -    | expr_no_commas ASSIGN expr_no_commas
  64927. -        { $$ = build_modify_expr ($1, $2, $3);
  64928. -          /* This inhibits warnings in truthvalue_conversion.  */
  64929. -          C_SET_EXP_ORIGINAL_CODE ($$, ERROR_MARK); }
  64930. -    ;
  64931. -
  64932. -primary:
  64933. -    IDENTIFIER
  64934. -        {
  64935. -          $$ = lastiddecl;
  64936. -          if (!$$ || $$ == error_mark_node)
  64937. -            {
  64938. -              if (yychar == YYEMPTY)
  64939. -            yychar = YYLEX;
  64940. -              if (yychar == '(')
  64941. -            {
  64942. -              tree decl;
  64943. -
  64944. -              if (objc_receiver_context
  64945. -                  && ! (objc_receiver_context
  64946. -                    && strcmp (IDENTIFIER_POINTER ($1), "super")))
  64947. -                /* we have a message to super */
  64948. -                $$ = get_super_receiver ();
  64949. -              else if (objc_method_context
  64950. -                   && (decl = is_ivar (objc_ivar_chain, $1)))
  64951. -                {
  64952. -                  if (is_private (decl))
  64953. -                $$ = error_mark_node;
  64954. -                  else
  64955. -                $$ = build_ivar_reference ($1);
  64956. -                }
  64957. -              else
  64958. -                {
  64959. -                  /* Ordinary implicit function declaration.  */
  64960. -                  $$ = implicitly_declare ($1);
  64961. -                  assemble_external ($$);
  64962. -                  TREE_USED ($$) = 1;
  64963. -                }
  64964. -            }
  64965. -              else if (current_function_decl == 0)
  64966. -            {
  64967. -              error ("`%s' undeclared here (not in a function)",
  64968. -                 IDENTIFIER_POINTER ($1));
  64969. -              $$ = error_mark_node;
  64970. -            }
  64971. -              else
  64972. -            {
  64973. -              tree decl;
  64974. -
  64975. -                  if (objc_receiver_context
  64976. -                  && ! strcmp (IDENTIFIER_POINTER ($1), "super"))
  64977. -                /* we have a message to super */
  64978. -                $$ = get_super_receiver ();
  64979. -              else if (objc_method_context
  64980. -                   && (decl = is_ivar (objc_ivar_chain, $1)))
  64981. -                {
  64982. -                  if (is_private (decl))
  64983. -                $$ = error_mark_node;
  64984. -                  else
  64985. -                $$ = build_ivar_reference ($1);
  64986. -                }
  64987. -              else
  64988. -                {
  64989. -                  if (IDENTIFIER_GLOBAL_VALUE ($1) != error_mark_node
  64990. -                  || IDENTIFIER_ERROR_LOCUS ($1) != current_function_decl)
  64991. -                {
  64992. -                  error ("`%s' undeclared (first use this function)",
  64993. -                     IDENTIFIER_POINTER ($1));
  64994. -
  64995. -                  if (! undeclared_variable_notice)
  64996. -                    {
  64997. -                      error ("(Each undeclared identifier is reported only once");
  64998. -                      error ("for each function it appears in.)");
  64999. -                      undeclared_variable_notice = 1;
  65000. -                    }
  65001. -                }
  65002. -                  $$ = error_mark_node;
  65003. -                  /* Prevent repeated error messages.  */
  65004. -                  IDENTIFIER_GLOBAL_VALUE ($1) = error_mark_node;
  65005. -                  IDENTIFIER_ERROR_LOCUS ($1) = current_function_decl;
  65006. -                }
  65007. -            }
  65008. -            }
  65009. -          else if (TREE_TYPE ($$) == error_mark_node)
  65010. -            $$ = error_mark_node;
  65011. -          else if (C_DECL_ANTICIPATED ($$))
  65012. -            {
  65013. -              /* The first time we see a build-in function used,
  65014. -             if it has not been declared.  */
  65015. -              C_DECL_ANTICIPATED ($$) = 0;
  65016. -              if (yychar == YYEMPTY)
  65017. -            yychar = YYLEX;
  65018. -              if (yychar == '(')
  65019. -            {
  65020. -              /* Omit the implicit declaration we
  65021. -                 would ordinarily do, so we don't lose
  65022. -                 the actual built in type.
  65023. -                 But print a diagnostic for the mismatch.  */
  65024. -              if (objc_method_context
  65025. -                  && is_ivar (objc_ivar_chain, $1))
  65026. -                error ("Instance variable `%s' implicitly declared as function",
  65027. -                   IDENTIFIER_POINTER (DECL_NAME ($$)));
  65028. -              else
  65029. -                if (TREE_CODE ($$) != FUNCTION_DECL)
  65030. -                  error ("`%s' implicitly declared as function",
  65031. -                     IDENTIFIER_POINTER (DECL_NAME ($$)));
  65032. -              else if ((TYPE_MODE (TREE_TYPE (TREE_TYPE ($$)))
  65033. -                    != TYPE_MODE (integer_type_node))
  65034. -                   && (TREE_TYPE (TREE_TYPE ($$))
  65035. -                       != void_type_node))
  65036. -                pedwarn ("type mismatch in implicit declaration for built-in function `%s'",
  65037. -                     IDENTIFIER_POINTER (DECL_NAME ($$)));
  65038. -              /* If it really returns void, change that to int.  */
  65039. -              if (TREE_TYPE (TREE_TYPE ($$)) == void_type_node)
  65040. -                TREE_TYPE ($$)
  65041. -                  = build_function_type (integer_type_node,
  65042. -                             TYPE_ARG_TYPES (TREE_TYPE ($$)));
  65043. -            }
  65044. -              else
  65045. -            pedwarn ("built-in function `%s' used without declaration",
  65046. -                 IDENTIFIER_POINTER (DECL_NAME ($$)));
  65047. -
  65048. -              /* Do what we would ordinarily do when a fn is used.  */
  65049. -              assemble_external ($$);
  65050. -              TREE_USED ($$) = 1;
  65051. -            }
  65052. -          else
  65053. -            {
  65054. -              assemble_external ($$);
  65055. -              TREE_USED ($$) = 1;
  65056. -              /* we have a definition - still check if iVariable */
  65057. -
  65058. -              if (!objc_receiver_context
  65059. -              || (objc_receiver_context
  65060. -                  && strcmp (IDENTIFIER_POINTER ($1), "super")))
  65061. -                        {
  65062. -              tree decl;
  65063. -
  65064. -              if (objc_method_context
  65065. -                  && (decl = is_ivar (objc_ivar_chain, $1)))
  65066. -                            {
  65067. -                              if (IDENTIFIER_LOCAL_VALUE ($1))
  65068. -                                warning ("local declaration of `%s' hides instance variable",
  65069. -                                     IDENTIFIER_POINTER ($1));
  65070. -                              else
  65071. -                 {
  65072. -                   if (is_private (decl))
  65073. -                     $$ = error_mark_node;
  65074. -                   else
  65075. -                     $$ = build_ivar_reference ($1);
  65076. -                 }
  65077. -                            }
  65078. -            }
  65079. -                      else /* we have a message to super */
  65080. -                $$ = get_super_receiver ();
  65081. -            }
  65082. -
  65083. -          if (TREE_CODE ($$) == CONST_DECL)
  65084. -            {
  65085. -              $$ = DECL_INITIAL ($$);
  65086. -              /* This is to prevent an enum whose value is 0
  65087. -             from being considered a null pointer constant.  */
  65088. -              $$ = build1 (NOP_EXPR, TREE_TYPE ($$), $$);
  65089. -              TREE_CONSTANT ($$) = 1;
  65090. -            }
  65091. -        }
  65092. -    | CONSTANT
  65093. -    | string
  65094. -        { $$ = combine_strings ($1); }
  65095. -    | '(' expr ')'
  65096. -        { char class = TREE_CODE_CLASS (TREE_CODE ($2));
  65097. -          if (class == 'e' || class == '1'
  65098. -              || class == '2' || class == '<')
  65099. -            C_SET_EXP_ORIGINAL_CODE ($2, ERROR_MARK);
  65100. -          $$ = $2; }
  65101. -    | '(' error ')'
  65102. -        { $$ = error_mark_node; }
  65103. -    | '('
  65104. -        { if (current_function_decl == 0)
  65105. -            {
  65106. -              error ("braced-group within expression allowed only inside a function");
  65107. -              YYERROR;
  65108. -            }
  65109. -          /* We must force a BLOCK for this level
  65110. -             so that, if it is not expanded later,
  65111. -             there is a way to turn off the entire subtree of blocks
  65112. -             that are contained in it.  */
  65113. -          keep_next_level ();
  65114. -          push_iterator_stack ();
  65115. -          push_label_level ();
  65116. -          $<ttype>$ = expand_start_stmt_expr (); }
  65117. -      compstmt ')'
  65118. -        { tree rtl_exp;
  65119. -          if (pedantic)
  65120. -            pedwarn ("ANSI C forbids braced-groups within expressions");
  65121. -          pop_iterator_stack ();
  65122. -          pop_label_level ();
  65123. -          rtl_exp = expand_end_stmt_expr ($<ttype>2);
  65124. -          /* The statements have side effects, so the group does.  */
  65125. -          TREE_SIDE_EFFECTS (rtl_exp) = 1;
  65126. -
  65127. -          if (TREE_CODE ($3) == BLOCK)
  65128. -            {
  65129. -              /* Make a BIND_EXPR for the BLOCK already made.  */
  65130. -              $$ = build (BIND_EXPR, TREE_TYPE (rtl_exp),
  65131. -                  NULL_TREE, rtl_exp, $3);
  65132. -              /* Remove the block from the tree at this point.
  65133. -             It gets put back at the proper place
  65134. -             when the BIND_EXPR is expanded.  */
  65135. -              delete_block ($3);
  65136. -            }
  65137. -          else
  65138. -            $$ = $3;
  65139. -        }
  65140. -    | primary '(' exprlist ')'   %prec '.'
  65141. -        { $$ = build_function_call ($1, $3); }
  65142. -    | primary '[' expr ']'   %prec '.'
  65143. -        { $$ = build_array_ref ($1, $3); }
  65144. -    | primary '.' identifier
  65145. -        {
  65146. -                  if (doing_objc_thang)
  65147. -                    {
  65148. -              if (is_public ($1, $3))
  65149. -            $$ = build_component_ref ($1, $3);
  65150. -              else
  65151. -            $$ = error_mark_node;
  65152. -            }
  65153. -                  else
  65154. -            $$ = build_component_ref ($1, $3);
  65155. -        }
  65156. -    | primary POINTSAT identifier
  65157. -        {
  65158. -                  tree expr = build_indirect_ref ($1, "->");
  65159. -
  65160. -                  if (doing_objc_thang)
  65161. -                    {
  65162. -              if (is_public (expr, $3))
  65163. -            $$ = build_component_ref (expr, $3);
  65164. -              else
  65165. -            $$ = error_mark_node;
  65166. -            }
  65167. -                  else
  65168. -                    $$ = build_component_ref (expr, $3);
  65169. -        }
  65170. -    | primary PLUSPLUS
  65171. -        { $$ = build_unary_op (POSTINCREMENT_EXPR, $1, 0); }
  65172. -    | primary MINUSMINUS
  65173. -        { $$ = build_unary_op (POSTDECREMENT_EXPR, $1, 0); }
  65174. -    | objcmessageexpr
  65175. -        { $$ = build_message_expr ($1); }
  65176. -    | objcselectorexpr
  65177. -        { $$ = build_selector_expr ($1); }
  65178. -    | objcprotocolexpr
  65179. -        { $$ = build_protocol_expr ($1); }
  65180. -    | objcencodeexpr
  65181. -        { $$ = build_encode_expr ($1); }
  65182. -    | objc_string
  65183. -        { $$ = build_objc_string_object ($1); }
  65184. -    ;
  65185. -
  65186. -/* Produces a STRING_CST with perhaps more STRING_CSTs chained onto it.  */
  65187. -string:
  65188. -      STRING
  65189. -    | string STRING
  65190. -        { $$ = chainon ($1, $2); }
  65191. -    ;
  65192. -
  65193. -/* Produces an OBJC_STRING_CST with perhaps more OBJC_STRING_CSTs chained
  65194. -   onto it.  */
  65195. -objc_string:
  65196. -      OBJC_STRING
  65197. -    | objc_string OBJC_STRING
  65198. -        { $$ = chainon ($1, $2); }
  65199. -    ;
  65200. -
  65201. -xdecls:
  65202. -    /* empty */
  65203. -    | datadecls
  65204. -    | datadecls ELLIPSIS
  65205. -        /* ... is used here to indicate a varargs function.  */
  65206. -        { c_mark_varargs ();
  65207. -          if (pedantic)
  65208. -            pedwarn ("ANSI C does not permit use of `varargs.h'"); }
  65209. -    ;
  65210. -
  65211. -/* The following are analogous to lineno_decl, decls and decl
  65212. -   except that they do not allow nested functions.
  65213. -   They are used for old-style parm decls.  */
  65214. -lineno_datadecl:
  65215. -      save_filename save_lineno datadecl
  65216. -        { }
  65217. -    ;
  65218. -
  65219. -datadecls:
  65220. -    lineno_datadecl
  65221. -    | errstmt
  65222. -    | datadecls lineno_datadecl
  65223. -    | lineno_datadecl errstmt
  65224. -    ;
  65225. -
  65226. -datadecl:
  65227. -    typed_declspecs setspecs initdecls ';'
  65228. -        { current_declspecs = TREE_VALUE (declspec_stack);
  65229. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65230. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65231. -          resume_momentary ($2); }
  65232. -    | declmods setspecs notype_initdecls ';'
  65233. -        { current_declspecs = TREE_VALUE (declspec_stack);    
  65234. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65235. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65236. -          resume_momentary ($2); }
  65237. -    | typed_declspecs ';'
  65238. -        { shadow_tag_warned ($1, 1);
  65239. -          pedwarn ("empty declaration"); }
  65240. -    | declmods ';'
  65241. -        { pedwarn ("empty declaration"); }
  65242. -    ;
  65243. -
  65244. -/* This combination which saves a lineno before a decl
  65245. -   is the normal thing to use, rather than decl itself.
  65246. -   This is to avoid shift/reduce conflicts in contexts
  65247. -   where statement labels are allowed.  */
  65248. -lineno_decl:
  65249. -      save_filename save_lineno decl
  65250. -        { }
  65251. -    ;
  65252. -
  65253. -decls:
  65254. -    lineno_decl
  65255. -    | errstmt
  65256. -    | decls lineno_decl
  65257. -    | lineno_decl errstmt
  65258. -    ;
  65259. -
  65260. -/* records the type and storage class specs to use for processing
  65261. -   the declarators that follow.
  65262. -   Maintains a stack of outer-level values of current_declspecs,
  65263. -   for the sake of parm declarations nested in function declarators.  */
  65264. -setspecs: /* empty */
  65265. -        { $$ = suspend_momentary ();
  65266. -          pending_xref_error ();
  65267. -          declspec_stack = tree_cons (prefix_attributes,
  65268. -                          current_declspecs,
  65269. -                          declspec_stack);
  65270. -          current_declspecs = $<ttype>0; 
  65271. -          prefix_attributes = NULL_TREE; }
  65272. -    ;
  65273. -
  65274. -setattrs: /* empty */
  65275. -        { prefix_attributes = chainon (prefix_attributes, $<ttype>0); }
  65276. -    ;
  65277. -
  65278. -decl:
  65279. -    typed_declspecs setspecs initdecls ';'
  65280. -        { current_declspecs = TREE_VALUE (declspec_stack);
  65281. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65282. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65283. -          resume_momentary ($2); }
  65284. -    | declmods setspecs notype_initdecls ';'
  65285. -        { current_declspecs = TREE_VALUE (declspec_stack);
  65286. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65287. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65288. -          resume_momentary ($2); }
  65289. -    | typed_declspecs setspecs nested_function
  65290. -        { current_declspecs = TREE_VALUE (declspec_stack);
  65291. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65292. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65293. -          resume_momentary ($2); }
  65294. -    | declmods setspecs notype_nested_function
  65295. -        { current_declspecs = TREE_VALUE (declspec_stack);
  65296. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65297. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65298. -          resume_momentary ($2); }
  65299. -    | typed_declspecs ';'
  65300. -        { shadow_tag ($1); }
  65301. -    | declmods ';'
  65302. -        { pedwarn ("empty declaration"); }
  65303. -    ;
  65304. -
  65305. -/* Declspecs which contain at least one type specifier or typedef name.
  65306. -   (Just `const' or `volatile' is not enough.)
  65307. -   A typedef'd name following these is taken as a name to be declared.  */
  65308. -
  65309. -typed_declspecs:
  65310. -      typespec reserved_declspecs
  65311. -        { $$ = tree_cons (NULL_TREE, $1, $2); }
  65312. -    | declmods typespec reserved_declspecs
  65313. -        { $$ = chainon ($3, tree_cons (NULL_TREE, $2, $1)); }
  65314. -    ;
  65315. -
  65316. -reserved_declspecs:  /* empty */
  65317. -        { $$ = NULL_TREE; }
  65318. -    | reserved_declspecs typespecqual_reserved
  65319. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  65320. -    | reserved_declspecs SCSPEC
  65321. -        { if (extra_warnings)
  65322. -            warning ("`%s' is not at beginning of declaration",
  65323. -                 IDENTIFIER_POINTER ($2));
  65324. -          $$ = tree_cons (NULL_TREE, $2, $1); }
  65325. -    ;
  65326. -
  65327. -/* List of just storage classes and type modifiers.
  65328. -   A declaration can start with just this, but then it cannot be used
  65329. -   to redeclare a typedef-name.  */
  65330. -
  65331. -declmods:
  65332. -      TYPE_QUAL
  65333. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE);
  65334. -          TREE_STATIC ($$) = 1; }
  65335. -    | SCSPEC
  65336. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE); }
  65337. -    | declmods TYPE_QUAL
  65338. -        { $$ = tree_cons (NULL_TREE, $2, $1);
  65339. -          TREE_STATIC ($$) = 1; }
  65340. -    | declmods SCSPEC
  65341. -        { if (extra_warnings && TREE_STATIC ($1))
  65342. -            warning ("`%s' is not at beginning of declaration",
  65343. -                 IDENTIFIER_POINTER ($2));
  65344. -          $$ = tree_cons (NULL_TREE, $2, $1);
  65345. -          TREE_STATIC ($$) = TREE_STATIC ($1); }
  65346. -    ;
  65347. -
  65348. -
  65349. -/* Used instead of declspecs where storage classes are not allowed
  65350. -   (that is, for typenames and structure components).
  65351. -   Don't accept a typedef-name if anything but a modifier precedes it.  */
  65352. -
  65353. -typed_typespecs:
  65354. -      typespec reserved_typespecquals
  65355. -        { $$ = tree_cons (NULL_TREE, $1, $2); }
  65356. -    | nonempty_type_quals typespec reserved_typespecquals
  65357. -        { $$ = chainon ($3, tree_cons (NULL_TREE, $2, $1)); }
  65358. -    ;
  65359. -
  65360. -reserved_typespecquals:  /* empty */
  65361. -        { $$ = NULL_TREE; }
  65362. -    | reserved_typespecquals typespecqual_reserved
  65363. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  65364. -    ;
  65365. -
  65366. -/* A typespec (but not a type qualifier).
  65367. -   Once we have seen one of these in a declaration,
  65368. -   if a typedef name appears then it is being redeclared.  */
  65369. -
  65370. -typespec: TYPESPEC
  65371. -    | structsp
  65372. -    | TYPENAME
  65373. -        { /* For a typedef name, record the meaning, not the name.
  65374. -             In case of `foo foo, bar;'.  */
  65375. -          $$ = lookup_name ($1); }
  65376. -    | CLASSNAME protocolrefs
  65377. -        { $$ = get_static_reference ($1, $2); }
  65378. -    | OBJECTNAME protocolrefs
  65379. -        { $$ = get_object_reference ($2); }
  65380. -    | TYPEOF '(' expr ')'
  65381. -        { $$ = TREE_TYPE ($3); }
  65382. -    | TYPEOF '(' typename ')'
  65383. -        { $$ = groktypename ($3); }
  65384. -    ;
  65385. -
  65386. -/* A typespec that is a reserved word, or a type qualifier.  */
  65387. -
  65388. -typespecqual_reserved: TYPESPEC
  65389. -    | TYPE_QUAL
  65390. -    | structsp
  65391. -    ;
  65392. -
  65393. -initdecls:
  65394. -    initdcl
  65395. -    | initdecls ',' initdcl
  65396. -    ;
  65397. -
  65398. -notype_initdecls:
  65399. -    notype_initdcl
  65400. -    | notype_initdecls ',' initdcl
  65401. -    ;
  65402. -
  65403. -maybeasm:
  65404. -      /* empty */
  65405. -        { $$ = NULL_TREE; }
  65406. -    | ASM_KEYWORD '(' string ')'
  65407. -        { if (TREE_CHAIN ($3)) $3 = combine_strings ($3);
  65408. -          $$ = $3;
  65409. -        }
  65410. -    ;
  65411. -
  65412. -initdcl:
  65413. -      declarator maybeasm maybe_attribute '='
  65414. -        { $<ttype>$ = start_decl ($1, current_declspecs, 1,
  65415. -                      $3, prefix_attributes);
  65416. -          start_init ($<ttype>$, $2, global_bindings_p ()); }
  65417. -      init
  65418. -/* Note how the declaration of the variable is in effect while its init is parsed! */
  65419. -        { finish_init ();
  65420. -          finish_decl ($<ttype>5, $6, $2); }
  65421. -    | declarator maybeasm maybe_attribute
  65422. -        { tree d = start_decl ($1, current_declspecs, 0,
  65423. -                       $3, prefix_attributes);
  65424. -          finish_decl (d, NULL_TREE, $2); 
  65425. -                }
  65426. -    ;
  65427. -
  65428. -notype_initdcl:
  65429. -      notype_declarator maybeasm maybe_attribute '='
  65430. -        { $<ttype>$ = start_decl ($1, current_declspecs, 1,
  65431. -                      $3, prefix_attributes);
  65432. -          start_init ($<ttype>$, $2, global_bindings_p ()); }
  65433. -      init
  65434. -/* Note how the declaration of the variable is in effect while its init is parsed! */
  65435. -        { finish_init ();
  65436. -          decl_attributes ($<ttype>5, $3, prefix_attributes);
  65437. -          finish_decl ($<ttype>5, $6, $2); }
  65438. -    | notype_declarator maybeasm maybe_attribute
  65439. -        { tree d = start_decl ($1, current_declspecs, 0,
  65440. -                       $3, prefix_attributes);
  65441. -          finish_decl (d, NULL_TREE, $2); }
  65442. -    ;
  65443. -/* the * rules are dummies to accept the Apollo extended syntax
  65444. -   so that the header files compile. */
  65445. -maybe_attribute:
  65446. -      /* empty */
  65447. -          { $$ = NULL_TREE; }
  65448. -    | attributes
  65449. -        { $$ = $1; }
  65450. -    ;
  65451. -attributes:
  65452. -      attribute
  65453. -        { $$ = $1; }
  65454. -    | attributes attribute
  65455. -        { $$ = chainon ($1, $2); }
  65456. -    ;
  65457. -
  65458. -attribute:
  65459. -      ATTRIBUTE '(' '(' attribute_list ')' ')'
  65460. -        { $$ = $4; }
  65461. -    ;
  65462. -
  65463. -attribute_list:
  65464. -      attrib
  65465. -        { $$ = $1; }
  65466. -    | attribute_list ',' attrib
  65467. -        { $$ = chainon ($1, $3); }
  65468. -    ;
  65469. -attrib:
  65470. -    /* empty */
  65471. -        { $$ = NULL_TREE; }
  65472. -    | any_word
  65473. -        { $$ = build_tree_list ($1, NULL_TREE); }
  65474. -    | any_word '(' IDENTIFIER ')'
  65475. -        { $$ = build_tree_list ($1, build_tree_list (NULL_TREE, $3)); }
  65476. -    | any_word '(' IDENTIFIER ',' nonnull_exprlist ')'
  65477. -        { $$ = build_tree_list ($1, tree_cons (NULL_TREE, $3, $5)); }
  65478. -    | any_word '(' exprlist ')'
  65479. -        { $$ = build_tree_list ($1, $3); }
  65480. -    ;
  65481. -
  65482. -/* This still leaves out most reserved keywords,
  65483. -   shouldn't we include them?  */
  65484. -
  65485. -any_word:
  65486. -      identifier
  65487. -    | SCSPEC
  65488. -    | TYPESPEC
  65489. -    | TYPE_QUAL
  65490. -    ;
  65491. -
  65492. -/* Initializers.  `init' is the entry point.  */
  65493. -
  65494. -init:
  65495. -    expr_no_commas
  65496. -    | '{'
  65497. -        { really_start_incremental_init (NULL_TREE);
  65498. -          /* Note that the call to clear_momentary
  65499. -             is in process_init_element.  */
  65500. -          push_momentary (); }
  65501. -      initlist_maybe_comma '}'
  65502. -        { $$ = pop_init_level (0);
  65503. -          if ($$ == error_mark_node
  65504. -              && ! (yychar == STRING || yychar == CONSTANT))
  65505. -            pop_momentary ();
  65506. -          else
  65507. -            pop_momentary_nofree (); }
  65508. -
  65509. -    | error
  65510. -        { $$ = error_mark_node; }
  65511. -    ;
  65512. -
  65513. -/* `initlist_maybe_comma' is the guts of an initializer in braces.  */
  65514. -initlist_maybe_comma:
  65515. -      /* empty */
  65516. -        { if (pedantic)
  65517. -            pedwarn ("ANSI C forbids empty initializer braces"); }
  65518. -    | initlist1 maybecomma
  65519. -    ;
  65520. -
  65521. -initlist1:
  65522. -      initelt
  65523. -    | initlist1 ',' initelt
  65524. -    ;
  65525. -
  65526. -/* `initelt' is a single element of an initializer.
  65527. -   It may use braces.  */
  65528. -initelt:
  65529. -    expr_no_commas
  65530. -        { process_init_element ($1); }
  65531. -    | '{' 
  65532. -        { push_init_level (0); }
  65533. -      initlist_maybe_comma '}'
  65534. -        { process_init_element (pop_init_level (0)); }
  65535. -    | error
  65536. -    /* These are for labeled elements.  The syntax for an array element
  65537. -       initializer conflicts with the syntax for an Objective-C message,
  65538. -       so don't include these productions in the Objective-C grammar.  */
  65539. -    | identifier ':'
  65540. -        { set_init_label ($1); }
  65541. -      initelt
  65542. -    | '.' identifier '='
  65543. -        { set_init_label ($2); }
  65544. -      initelt
  65545. -    ;
  65546. -
  65547. -nested_function:
  65548. -      declarator
  65549. -        { push_c_function_context ();
  65550. -          if (! start_function (current_declspecs, $1,
  65551. -                    prefix_attributes, NULL_TREE, 1))
  65552. -            {
  65553. -              pop_c_function_context ();
  65554. -              YYERROR1;
  65555. -            }
  65556. -          reinit_parse_for_function (); }
  65557. -       xdecls
  65558. -        { store_parm_decls (); }
  65559. -/* This used to use compstmt_or_error.
  65560. -   That caused a bug with input `f(g) int g {}',
  65561. -   where the use of YYERROR1 above caused an error
  65562. -   which then was handled by compstmt_or_error.
  65563. -   There followed a repeated execution of that same rule,
  65564. -   which called YYERROR1 again, and so on.  */
  65565. -      compstmt
  65566. -        { finish_function (1);
  65567. -          pop_c_function_context (); }
  65568. -    ;
  65569. -
  65570. -notype_nested_function:
  65571. -      notype_declarator
  65572. -        { push_c_function_context ();
  65573. -          if (! start_function (current_declspecs, $1,
  65574. -                    prefix_attributes, NULL_TREE, 1))
  65575. -            {
  65576. -              pop_c_function_context ();
  65577. -              YYERROR1;
  65578. -            }
  65579. -          reinit_parse_for_function (); }
  65580. -      xdecls
  65581. -        { store_parm_decls (); }
  65582. -/* This used to use compstmt_or_error.
  65583. -   That caused a bug with input `f(g) int g {}',
  65584. -   where the use of YYERROR1 above caused an error
  65585. -   which then was handled by compstmt_or_error.
  65586. -   There followed a repeated execution of that same rule,
  65587. -   which called YYERROR1 again, and so on.  */
  65588. -      compstmt
  65589. -        { finish_function (1);
  65590. -          pop_c_function_context (); }
  65591. -    ;
  65592. -
  65593. -/* Any kind of declarator (thus, all declarators allowed
  65594. -   after an explicit typespec).  */
  65595. -
  65596. -declarator:
  65597. -      after_type_declarator
  65598. -    | notype_declarator
  65599. -    ;
  65600. -
  65601. -/* A declarator that is allowed only after an explicit typespec.  */
  65602. -
  65603. -after_type_declarator:
  65604. -      '(' after_type_declarator ')'
  65605. -        { $$ = $2; }
  65606. -    | after_type_declarator '(' parmlist_or_identifiers  %prec '.'
  65607. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  65608. -/*    | after_type_declarator '(' error ')'  %prec '.'
  65609. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  65610. -          poplevel (0, 0, 0); }  */
  65611. -    | after_type_declarator '[' expr ']'  %prec '.'
  65612. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  65613. -    | after_type_declarator '[' ']'  %prec '.'
  65614. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  65615. -    | '*' type_quals after_type_declarator  %prec UNARY
  65616. -        { $$ = make_pointer_declarator ($2, $3); }
  65617. -    | attributes setattrs after_type_declarator
  65618. -        { $$ = $3; }
  65619. -    | TYPENAME
  65620. -    | OBJECTNAME
  65621. -    ;
  65622. -
  65623. -/* Kinds of declarator that can appear in a parameter list
  65624. -   in addition to notype_declarator.  This is like after_type_declarator
  65625. -   but does not allow a typedef name in parentheses as an identifier
  65626. -   (because it would conflict with a function with that typedef as arg).  */
  65627. -
  65628. -parm_declarator:
  65629. -      parm_declarator '(' parmlist_or_identifiers  %prec '.'
  65630. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  65631. -/*    | parm_declarator '(' error ')'  %prec '.'
  65632. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  65633. -          poplevel (0, 0, 0); }  */
  65634. -    | parm_declarator '[' expr ']'  %prec '.'
  65635. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  65636. -    | parm_declarator '[' ']'  %prec '.'
  65637. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  65638. -    | '*' type_quals parm_declarator  %prec UNARY
  65639. -        { $$ = make_pointer_declarator ($2, $3); }
  65640. -    | attributes setattrs parm_declarator
  65641. -        { $$ = $3; }
  65642. -    | TYPENAME
  65643. -    ;
  65644. -
  65645. -/* A declarator allowed whether or not there has been
  65646. -   an explicit typespec.  These cannot redeclare a typedef-name.  */
  65647. -
  65648. -notype_declarator:
  65649. -      notype_declarator '(' parmlist_or_identifiers  %prec '.'
  65650. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  65651. -/*    | notype_declarator '(' error ')'  %prec '.'
  65652. -        { $$ = build_nt (CALL_EXPR, $1, NULL_TREE, NULL_TREE);
  65653. -          poplevel (0, 0, 0); }  */
  65654. -    | '(' notype_declarator ')'
  65655. -        { $$ = $2; }
  65656. -    | '*' type_quals notype_declarator  %prec UNARY
  65657. -        { $$ = make_pointer_declarator ($2, $3); }
  65658. -    | notype_declarator '[' expr ']'  %prec '.'
  65659. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  65660. -    | notype_declarator '[' ']'  %prec '.'
  65661. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  65662. -    | attributes setattrs notype_declarator
  65663. -        { $$ = $3; }
  65664. -    | IDENTIFIER
  65665. -    ;
  65666. -
  65667. -structsp:
  65668. -      STRUCT identifier '{'
  65669. -        { $$ = start_struct (RECORD_TYPE, $2);
  65670. -          /* Start scope of tag before parsing components.  */
  65671. -        }
  65672. -      component_decl_list '}' maybe_attribute 
  65673. -        { $$ = finish_struct ($<ttype>4, $5, $7); }
  65674. -    | STRUCT '{' component_decl_list '}' maybe_attribute
  65675. -        { $$ = finish_struct (start_struct (RECORD_TYPE, NULL_TREE),
  65676. -                      $3, $5);
  65677. -        }
  65678. -    | STRUCT identifier
  65679. -        { $$ = xref_tag (RECORD_TYPE, $2); }
  65680. -    | UNION identifier '{'
  65681. -        { $$ = start_struct (UNION_TYPE, $2); }
  65682. -      component_decl_list '}' maybe_attribute
  65683. -        { $$ = finish_struct ($<ttype>4, $5, $7); }
  65684. -    | UNION '{' component_decl_list '}' maybe_attribute
  65685. -        { $$ = finish_struct (start_struct (UNION_TYPE, NULL_TREE),
  65686. -                      $3, $5);
  65687. -        }
  65688. -    | UNION identifier
  65689. -        { $$ = xref_tag (UNION_TYPE, $2); }
  65690. -    | ENUM identifier '{'
  65691. -        { $<itype>3 = suspend_momentary ();
  65692. -          $$ = start_enum ($2); }
  65693. -      enumlist maybecomma_warn '}' maybe_attribute
  65694. -        { $$ = finish_enum ($<ttype>4, nreverse ($5), $8);
  65695. -          resume_momentary ($<itype>3); }
  65696. -    | ENUM '{'
  65697. -        { $<itype>2 = suspend_momentary ();
  65698. -          $$ = start_enum (NULL_TREE); }
  65699. -      enumlist maybecomma_warn '}' maybe_attribute
  65700. -        { $$ = finish_enum ($<ttype>3, nreverse ($4), $7);
  65701. -          resume_momentary ($<itype>2); }
  65702. -    | ENUM identifier
  65703. -        { $$ = xref_tag (ENUMERAL_TYPE, $2); }
  65704. -    ;
  65705. -
  65706. -maybecomma:
  65707. -      /* empty */
  65708. -    | ','
  65709. -    ;
  65710. -
  65711. -maybecomma_warn:
  65712. -      /* empty */
  65713. -    | ','
  65714. -        { if (pedantic) pedwarn ("comma at end of enumerator list"); }
  65715. -    ;
  65716. -
  65717. -component_decl_list:
  65718. -      component_decl_list2
  65719. -        { $$ = $1; }
  65720. -    | component_decl_list2 component_decl
  65721. -        { $$ = chainon ($1, $2);
  65722. -          pedwarn ("no semicolon at end of struct or union"); }
  65723. -    ;
  65724. -
  65725. -component_decl_list2:    /* empty */
  65726. -        { $$ = NULL_TREE; }
  65727. -    | component_decl_list2 component_decl ';'
  65728. -        { $$ = chainon ($1, $2); }
  65729. -    | component_decl_list2 ';'
  65730. -        { if (pedantic)
  65731. -            pedwarn ("extra semicolon in struct or union specified"); }
  65732. -    /* foo(sizeof(struct{ @defs(ClassName)})); */
  65733. -    | DEFS '(' CLASSNAME ')'
  65734. -        {
  65735. -          tree interface = lookup_interface ($3);
  65736. -
  65737. -          if (interface)
  65738. -            $$ = get_class_ivars (interface);
  65739. -          else
  65740. -            {
  65741. -              error ("Cannot find interface declaration for `%s'",
  65742. -                 IDENTIFIER_POINTER ($3));
  65743. -              $$ = NULL_TREE;
  65744. -            }
  65745. -        }
  65746. -    ;
  65747. -
  65748. -/* There is a shift-reduce conflict here, because `components' may
  65749. -   start with a `typename'.  It happens that shifting (the default resolution)
  65750. -   does the right thing, because it treats the `typename' as part of
  65751. -   a `typed_typespecs'.
  65752. -
  65753. -   It is possible that this same technique would allow the distinction
  65754. -   between `notype_initdecls' and `initdecls' to be eliminated.
  65755. -   But I am being cautious and not trying it.  */
  65756. -
  65757. -component_decl:
  65758. -      typed_typespecs setspecs components
  65759. -        { $$ = $3;
  65760. -          current_declspecs = TREE_VALUE (declspec_stack);
  65761. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65762. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65763. -          resume_momentary ($2); }
  65764. -    | typed_typespecs
  65765. -        { if (pedantic)
  65766. -            pedwarn ("ANSI C forbids member declarations with no members");
  65767. -          shadow_tag($1);
  65768. -          $$ = NULL_TREE; }
  65769. -    | nonempty_type_quals setspecs components
  65770. -        { $$ = $3;
  65771. -          current_declspecs = TREE_VALUE (declspec_stack);
  65772. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  65773. -          declspec_stack = TREE_CHAIN (declspec_stack);
  65774. -          resume_momentary ($2); }
  65775. -    | nonempty_type_quals
  65776. -        { if (pedantic)
  65777. -            pedwarn ("ANSI C forbids member declarations with no members");
  65778. -          shadow_tag($1);
  65779. -          $$ = NULL_TREE; }
  65780. -    | error
  65781. -        { $$ = NULL_TREE; }
  65782. -    ;
  65783. -
  65784. -components:
  65785. -      component_declarator
  65786. -    | components ',' component_declarator
  65787. -        { $$ = chainon ($1, $3); }
  65788. -    ;
  65789. -
  65790. -component_declarator:
  65791. -      save_filename save_lineno declarator maybe_attribute
  65792. -        { $$ = grokfield ($1, $2, $3, current_declspecs, NULL_TREE);
  65793. -          decl_attributes ($$, $4, prefix_attributes); }
  65794. -    | save_filename save_lineno
  65795. -      declarator ':' expr_no_commas maybe_attribute
  65796. -        { $$ = grokfield ($1, $2, $3, current_declspecs, $5);
  65797. -          decl_attributes ($$, $6, prefix_attributes); }
  65798. -    | save_filename save_lineno ':' expr_no_commas maybe_attribute
  65799. -        { $$ = grokfield ($1, $2, NULL_TREE, current_declspecs, $4);
  65800. -          decl_attributes ($$, $5, prefix_attributes); }
  65801. -    ;
  65802. -
  65803. -/* We chain the enumerators in reverse order.
  65804. -   They are put in forward order where enumlist is used.
  65805. -   (The order used to be significant, but no longer is so.
  65806. -   However, we still maintain the order, just to be clean.)  */
  65807. -
  65808. -enumlist:
  65809. -      enumerator
  65810. -    | enumlist ',' enumerator
  65811. -        { if ($1 == error_mark_node)
  65812. -            $$ = $1;
  65813. -          else
  65814. -            $$ = chainon ($3, $1); }
  65815. -    | error
  65816. -        { $$ = error_mark_node; }
  65817. -    ;
  65818. -
  65819. -
  65820. -enumerator:
  65821. -      identifier
  65822. -        { $$ = build_enumerator ($1, NULL_TREE); }
  65823. -    | identifier '=' expr_no_commas
  65824. -        { $$ = build_enumerator ($1, $3); }
  65825. -    ;
  65826. -
  65827. -typename:
  65828. -    typed_typespecs absdcl
  65829. -        { $$ = build_tree_list ($1, $2); }
  65830. -    | nonempty_type_quals absdcl
  65831. -        { $$ = build_tree_list ($1, $2); }
  65832. -    ;
  65833. -
  65834. -absdcl:   /* an absolute declarator */
  65835. -    /* empty */
  65836. -        { $$ = NULL_TREE; }
  65837. -    | absdcl1
  65838. -    ;
  65839. -
  65840. -nonempty_type_quals:
  65841. -      TYPE_QUAL
  65842. -        { $$ = tree_cons (NULL_TREE, $1, NULL_TREE); }
  65843. -    | nonempty_type_quals TYPE_QUAL
  65844. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  65845. -    ;
  65846. -
  65847. -type_quals:
  65848. -      /* empty */
  65849. -        { $$ = NULL_TREE; }
  65850. -    | type_quals TYPE_QUAL
  65851. -        { $$ = tree_cons (NULL_TREE, $2, $1); }
  65852. -    ;
  65853. -
  65854. -absdcl1:  /* a nonempty absolute declarator */
  65855. -      '(' absdcl1 ')'
  65856. -        { $$ = $2; }
  65857. -      /* `(typedef)1' is `int'.  */
  65858. -    | '*' type_quals absdcl1  %prec UNARY
  65859. -        { $$ = make_pointer_declarator ($2, $3); }
  65860. -    | '*' type_quals  %prec UNARY
  65861. -        { $$ = make_pointer_declarator ($2, NULL_TREE); }
  65862. -    | absdcl1 '(' parmlist  %prec '.'
  65863. -        { $$ = build_nt (CALL_EXPR, $1, $3, NULL_TREE); }
  65864. -    | absdcl1 '[' expr ']'  %prec '.'
  65865. -        { $$ = build_nt (ARRAY_REF, $1, $3); }
  65866. -    | absdcl1 '[' ']'  %prec '.'
  65867. -        { $$ = build_nt (ARRAY_REF, $1, NULL_TREE); }
  65868. -    | '(' parmlist  %prec '.'
  65869. -        { $$ = build_nt (CALL_EXPR, NULL_TREE, $2, NULL_TREE); }
  65870. -    | '[' expr ']'  %prec '.'
  65871. -        { $$ = build_nt (ARRAY_REF, NULL_TREE, $2); }
  65872. -    | '[' ']'  %prec '.'
  65873. -        { $$ = build_nt (ARRAY_REF, NULL_TREE, NULL_TREE); }
  65874. -    | attributes setattrs absdcl1
  65875. -        { $$ = $3; }
  65876. -    ;
  65877. -
  65878. -/* at least one statement, the first of which parses without error.  */
  65879. -/* stmts is used only after decls, so an invalid first statement
  65880. -   is actually regarded as an invalid decl and part of the decls.  */
  65881. -
  65882. -stmts:
  65883. -    lineno_stmt_or_labels
  65884. -        {
  65885. -          if (pedantic && $1)
  65886. -            pedwarn ("ANSI C forbids label at end of compound statement");
  65887. -        }
  65888. -    ;
  65889. -
  65890. -lineno_stmt_or_labels:
  65891. -      lineno_stmt_or_label
  65892. -    | lineno_stmt_or_labels lineno_stmt_or_label
  65893. -        { $$ = $2; }
  65894. -    | lineno_stmt_or_labels errstmt
  65895. -        { $$ = 0; }
  65896. -    ;
  65897. -
  65898. -xstmts:
  65899. -    /* empty */
  65900. -    | stmts
  65901. -    ;
  65902. -
  65903. -errstmt:  error ';'
  65904. -    ;
  65905. -
  65906. -pushlevel:  /* empty */
  65907. -        { emit_line_note (input_filename, lineno);
  65908. -          pushlevel (0);
  65909. -          clear_last_expr ();
  65910. -          push_momentary ();
  65911. -          expand_start_bindings (0);
  65912. -          if (objc_method_context)
  65913. -            add_objc_decls ();
  65914. -        }
  65915. -    ;
  65916. -
  65917. -/* Read zero or more forward-declarations for labels
  65918. -   that nested functions can jump to.  */
  65919. -maybe_label_decls:
  65920. -      /* empty */
  65921. -    | label_decls
  65922. -        { if (pedantic)
  65923. -            pedwarn ("ANSI C forbids label declarations"); }
  65924. -    ;
  65925. -
  65926. -label_decls:
  65927. -      label_decl
  65928. -    | label_decls label_decl
  65929. -    ;
  65930. -
  65931. -label_decl:
  65932. -      LABEL identifiers_or_typenames ';'
  65933. -        { tree link;
  65934. -          for (link = $2; link; link = TREE_CHAIN (link))
  65935. -            {
  65936. -              tree label = shadow_label (TREE_VALUE (link));
  65937. -              C_DECLARED_LABEL_FLAG (label) = 1;
  65938. -              declare_nonlocal_label (label);
  65939. -            }
  65940. -        }
  65941. -    ;
  65942. -
  65943. -/* This is the body of a function definition.
  65944. -   It causes syntax errors to ignore to the next openbrace.  */
  65945. -compstmt_or_error:
  65946. -      compstmt
  65947. -        {}
  65948. -    | error compstmt
  65949. -    ;
  65950. -
  65951. -compstmt: '{' '}'
  65952. -        { $$ = convert (void_type_node, integer_zero_node); }
  65953. -    | '{' pushlevel maybe_label_decls decls xstmts '}'
  65954. -        { emit_line_note (input_filename, lineno);
  65955. -          expand_end_bindings (getdecls (), 1, 0);
  65956. -          $$ = poplevel (1, 1, 0);
  65957. -          if (yychar == CONSTANT || yychar == STRING)
  65958. -            pop_momentary_nofree ();
  65959. -          else
  65960. -            pop_momentary (); }
  65961. -    | '{' pushlevel maybe_label_decls error '}'
  65962. -        { emit_line_note (input_filename, lineno);
  65963. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  65964. -          $$ = poplevel (kept_level_p (), 0, 0);
  65965. -          if (yychar == CONSTANT || yychar == STRING)
  65966. -            pop_momentary_nofree ();
  65967. -          else
  65968. -            pop_momentary (); }
  65969. -    | '{' pushlevel maybe_label_decls stmts '}'
  65970. -        { emit_line_note (input_filename, lineno);
  65971. -          expand_end_bindings (getdecls (), kept_level_p (), 0);
  65972. -          $$ = poplevel (kept_level_p (), 0, 0);
  65973. -          if (yychar == CONSTANT || yychar == STRING)
  65974. -            pop_momentary_nofree ();
  65975. -          else
  65976. -            pop_momentary (); }
  65977. -    ;
  65978. -
  65979. -/* Value is number of statements counted as of the closeparen.  */
  65980. -simple_if:
  65981. -      if_prefix lineno_labeled_stmt
  65982. -/* Make sure expand_end_cond is run once
  65983. -   for each call to expand_start_cond.
  65984. -   Otherwise a crash is likely.  */
  65985. -    | if_prefix error
  65986. -    ;
  65987. -
  65988. -if_prefix:
  65989. -      IF '(' expr ')'
  65990. -        { emit_line_note ($<filename>-1, $<lineno>0);
  65991. -          expand_start_cond (truthvalue_conversion ($3), 0);
  65992. -          $<itype>$ = stmt_count;
  65993. -          if_stmt_file = $<filename>-1;
  65994. -          if_stmt_line = $<lineno>0;
  65995. -          position_after_white_space (); }
  65996. -    ;
  65997. -
  65998. -/* This is a subroutine of stmt.
  65999. -   It is used twice, once for valid DO statements
  66000. -   and once for catching errors in parsing the end test.  */
  66001. -do_stmt_start:
  66002. -      DO
  66003. -        { stmt_count++;
  66004. -          emit_line_note ($<filename>-1, $<lineno>0);
  66005. -          /* See comment in `while' alternative, above.  */
  66006. -          emit_nop ();
  66007. -          expand_start_loop_continue_elsewhere (1);
  66008. -          position_after_white_space (); }
  66009. -      lineno_labeled_stmt WHILE
  66010. -        { expand_loop_continue_here (); }
  66011. -    ;
  66012. -
  66013. -save_filename:
  66014. -        { $$ = input_filename; }
  66015. -    ;
  66016. -
  66017. -save_lineno:
  66018. -        { $$ = lineno; }
  66019. -    ;
  66020. -
  66021. -lineno_labeled_stmt:
  66022. -      save_filename save_lineno stmt
  66023. -        { }
  66024. -/*    | save_filename save_lineno error
  66025. -        { }
  66026. -*/
  66027. -    | save_filename save_lineno label lineno_labeled_stmt
  66028. -        { }
  66029. -    ;
  66030. -
  66031. -lineno_stmt_or_label:
  66032. -      save_filename save_lineno stmt_or_label
  66033. -        { $$ = $3; }
  66034. -    ;
  66035. -
  66036. -stmt_or_label:
  66037. -      stmt
  66038. -        { $$ = 0; }
  66039. -    | label
  66040. -        { $$ = 1; }
  66041. -    ;
  66042. -
  66043. -/* Parse a single real statement, not including any labels.  */
  66044. -stmt:
  66045. -      compstmt
  66046. -        { stmt_count++; }
  66047. -        | all_iter_stmt 
  66048. -    | expr ';'
  66049. -        { stmt_count++;
  66050. -          emit_line_note ($<filename>-1, $<lineno>0);
  66051. -/* It appears that this should not be done--that a non-lvalue array
  66052. -   shouldn't get an error if the value isn't used.
  66053. -   Section 3.2.2.1 says that an array lvalue gets converted to a pointer
  66054. -   if it appears as a top-level expression,
  66055. -   but says nothing about non-lvalue arrays.  */
  66056. -#if 0
  66057. -          /* Call default_conversion to get an error
  66058. -             on referring to a register array if pedantic.  */
  66059. -          if (TREE_CODE (TREE_TYPE ($1)) == ARRAY_TYPE
  66060. -              || TREE_CODE (TREE_TYPE ($1)) == FUNCTION_TYPE)
  66061. -            $1 = default_conversion ($1);
  66062. -#endif
  66063. -          iterator_expand ($1);
  66064. -          clear_momentary (); }
  66065. -    | simple_if ELSE
  66066. -        { expand_start_else ();
  66067. -          $<itype>1 = stmt_count;
  66068. -          position_after_white_space (); }
  66069. -      lineno_labeled_stmt
  66070. -        { expand_end_cond ();
  66071. -          if (extra_warnings && stmt_count == $<itype>1)
  66072. -            warning ("empty body in an else-statement"); }
  66073. -    | simple_if %prec IF
  66074. -        { expand_end_cond ();
  66075. -          /* This warning is here instead of in simple_if, because we
  66076. -             do not want a warning if an empty if is followed by an
  66077. -             else statement.  Increment stmt_count so we don't
  66078. -             give a second error if this is a nested `if'.  */
  66079. -          if (extra_warnings && stmt_count++ == $<itype>1)
  66080. -            warning_with_file_and_line (if_stmt_file, if_stmt_line,
  66081. -                        "empty body in an if-statement"); }
  66082. -/* Make sure expand_end_cond is run once
  66083. -   for each call to expand_start_cond.
  66084. -   Otherwise a crash is likely.  */
  66085. -    | simple_if ELSE error
  66086. -        { expand_end_cond (); }
  66087. -    | WHILE
  66088. -        { stmt_count++;
  66089. -          emit_line_note ($<filename>-1, $<lineno>0);
  66090. -          /* The emit_nop used to come before emit_line_note,
  66091. -             but that made the nop seem like part of the preceding line.
  66092. -             And that was confusing when the preceding line was
  66093. -             inside of an if statement and was not really executed.
  66094. -             I think it ought to work to put the nop after the line number.
  66095. -             We will see.  --rms, July 15, 1991.  */
  66096. -          emit_nop (); }
  66097. -      '(' expr ')'
  66098. -        { /* Don't start the loop till we have succeeded
  66099. -             in parsing the end test.  This is to make sure
  66100. -             that we end every loop we start.  */
  66101. -          expand_start_loop (1);
  66102. -          emit_line_note (input_filename, lineno);
  66103. -          expand_exit_loop_if_false (NULL_PTR,
  66104. -                         truthvalue_conversion ($4));
  66105. -          position_after_white_space (); }
  66106. -      lineno_labeled_stmt
  66107. -        { expand_end_loop (); }
  66108. -    | do_stmt_start
  66109. -      '(' expr ')' ';'
  66110. -        { emit_line_note (input_filename, lineno);
  66111. -          expand_exit_loop_if_false (NULL_PTR,
  66112. -                         truthvalue_conversion ($3));
  66113. -          expand_end_loop ();
  66114. -          clear_momentary (); }
  66115. -/* This rule is needed to make sure we end every loop we start.  */
  66116. -    | do_stmt_start error
  66117. -        { expand_end_loop ();
  66118. -          clear_momentary (); }
  66119. -    | FOR
  66120. -      '(' xexpr ';'
  66121. -        { stmt_count++;
  66122. -          emit_line_note ($<filename>-1, $<lineno>0);
  66123. -          /* See comment in `while' alternative, above.  */
  66124. -          emit_nop ();
  66125. -          if ($3) c_expand_expr_stmt ($3);
  66126. -          /* Next step is to call expand_start_loop_continue_elsewhere,
  66127. -             but wait till after we parse the entire for (...).
  66128. -             Otherwise, invalid input might cause us to call that
  66129. -             fn without calling expand_end_loop.  */
  66130. -        }
  66131. -      xexpr ';'
  66132. -        /* Can't emit now; wait till after expand_start_loop...  */
  66133. -        { $<lineno>7 = lineno;
  66134. -          $<filename>$ = input_filename; }
  66135. -      xexpr ')'
  66136. -        { 
  66137. -          /* Start the loop.  Doing this after parsing
  66138. -             all the expressions ensures we will end the loop.  */
  66139. -          expand_start_loop_continue_elsewhere (1);
  66140. -          /* Emit the end-test, with a line number.  */
  66141. -          emit_line_note ($<filename>8, $<lineno>7);
  66142. -          if ($6)
  66143. -            expand_exit_loop_if_false (NULL_PTR,
  66144. -                           truthvalue_conversion ($6));
  66145. -          /* Don't let the tree nodes for $9 be discarded by
  66146. -             clear_momentary during the parsing of the next stmt.  */
  66147. -          push_momentary ();
  66148. -          $<lineno>7 = lineno;
  66149. -          $<filename>8 = input_filename;
  66150. -          position_after_white_space (); }
  66151. -      lineno_labeled_stmt
  66152. -        { /* Emit the increment expression, with a line number.  */
  66153. -          emit_line_note ($<filename>8, $<lineno>7);
  66154. -          expand_loop_continue_here ();
  66155. -          if ($9)
  66156. -            c_expand_expr_stmt ($9);
  66157. -          if (yychar == CONSTANT || yychar == STRING)
  66158. -            pop_momentary_nofree ();
  66159. -          else
  66160. -            pop_momentary ();
  66161. -          expand_end_loop (); }
  66162. -    | SWITCH '(' expr ')'
  66163. -        { stmt_count++;
  66164. -          emit_line_note ($<filename>-1, $<lineno>0);
  66165. -          c_expand_start_case ($3);
  66166. -          /* Don't let the tree nodes for $3 be discarded by
  66167. -             clear_momentary during the parsing of the next stmt.  */
  66168. -          push_momentary ();
  66169. -          position_after_white_space (); }
  66170. -      lineno_labeled_stmt
  66171. -        { expand_end_case ($3);
  66172. -          if (yychar == CONSTANT || yychar == STRING)
  66173. -            pop_momentary_nofree ();
  66174. -          else
  66175. -            pop_momentary (); }
  66176. -    | BREAK ';'
  66177. -        { stmt_count++;
  66178. -          emit_line_note ($<filename>-1, $<lineno>0);
  66179. -          if ( ! expand_exit_something ())
  66180. -            error ("break statement not within loop or switch"); }
  66181. -    | CONTINUE ';'
  66182. -        { stmt_count++;
  66183. -          emit_line_note ($<filename>-1, $<lineno>0);
  66184. -          if (! expand_continue_loop (NULL_PTR))
  66185. -            error ("continue statement not within a loop"); }
  66186. -    | RETURN ';'
  66187. -        { stmt_count++;
  66188. -          emit_line_note ($<filename>-1, $<lineno>0);
  66189. -          c_expand_return (NULL_TREE); }
  66190. -    | RETURN expr ';'
  66191. -        { stmt_count++;
  66192. -          emit_line_note ($<filename>-1, $<lineno>0);
  66193. -          c_expand_return ($2); }
  66194. -    | ASM_KEYWORD maybe_type_qual '(' expr ')' ';'
  66195. -        { stmt_count++;
  66196. -          emit_line_note ($<filename>-1, $<lineno>0);
  66197. -          STRIP_NOPS ($4);
  66198. -          if ((TREE_CODE ($4) == ADDR_EXPR
  66199. -               && TREE_CODE (TREE_OPERAND ($4, 0)) == STRING_CST)
  66200. -              || TREE_CODE ($4) == STRING_CST)
  66201. -            expand_asm ($4);
  66202. -          else
  66203. -            error ("argument of `asm' is not a constant string"); }
  66204. -    /* This is the case with just output operands.  */
  66205. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ')' ';'
  66206. -        { stmt_count++;
  66207. -          emit_line_note ($<filename>-1, $<lineno>0);
  66208. -          c_expand_asm_operands ($4, $6, NULL_TREE, NULL_TREE,
  66209. -                     $2 == ridpointers[(int)RID_VOLATILE],
  66210. -                     input_filename, lineno); }
  66211. -    /* This is the case with input operands as well.  */
  66212. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ':' asm_operands ')' ';'
  66213. -        { stmt_count++;
  66214. -          emit_line_note ($<filename>-1, $<lineno>0);
  66215. -          c_expand_asm_operands ($4, $6, $8, NULL_TREE,
  66216. -                     $2 == ridpointers[(int)RID_VOLATILE],
  66217. -                     input_filename, lineno); }
  66218. -    /* This is the case with clobbered registers as well.  */
  66219. -    | ASM_KEYWORD maybe_type_qual '(' expr ':' asm_operands ':'
  66220. -        asm_operands ':' asm_clobbers ')' ';'
  66221. -        { stmt_count++;
  66222. -          emit_line_note ($<filename>-1, $<lineno>0);
  66223. -          c_expand_asm_operands ($4, $6, $8, $10,
  66224. -                     $2 == ridpointers[(int)RID_VOLATILE],
  66225. -                     input_filename, lineno); }
  66226. -    | GOTO identifier ';'
  66227. -        { tree decl;
  66228. -          stmt_count++;
  66229. -          emit_line_note ($<filename>-1, $<lineno>0);
  66230. -          decl = lookup_label ($2);
  66231. -          if (decl != 0)
  66232. -            {
  66233. -              TREE_USED (decl) = 1;
  66234. -              expand_goto (decl);
  66235. -            }
  66236. -        }
  66237. -    | GOTO '*' expr ';'
  66238. -        { stmt_count++;
  66239. -          emit_line_note ($<filename>-1, $<lineno>0);
  66240. -          expand_computed_goto (convert (ptr_type_node, $3)); }
  66241. -    | ';'
  66242. -    ;
  66243. -
  66244. -all_iter_stmt:
  66245. -      all_iter_stmt_simple
  66246. -/*    | all_iter_stmt_with_decl */
  66247. -    ;
  66248. -
  66249. -all_iter_stmt_simple:
  66250. -      FOR '(' primary ')' 
  66251. -      {
  66252. -        /* The value returned by this action is  */
  66253. -        /*      1 if everything is OK */ 
  66254. -        /*      0 in case of error or already bound iterator */
  66255. -
  66256. -        $<itype>$ = 0;
  66257. -        if (TREE_CODE ($3) != VAR_DECL)
  66258. -          error ("invalid `for (ITERATOR)' syntax");
  66259. -        else if (! ITERATOR_P ($3))
  66260. -          error ("`%s' is not an iterator",
  66261. -             IDENTIFIER_POINTER (DECL_NAME ($3)));
  66262. -        else if (ITERATOR_BOUND_P ($3))
  66263. -          error ("`for (%s)' inside expansion of same iterator",
  66264. -             IDENTIFIER_POINTER (DECL_NAME ($3)));
  66265. -        else
  66266. -          {
  66267. -        $<itype>$ = 1;
  66268. -        iterator_for_loop_start ($3);
  66269. -          }
  66270. -      }
  66271. -      lineno_labeled_stmt
  66272. -      {
  66273. -        if ($<itype>5)
  66274. -          iterator_for_loop_end ($3);
  66275. -      }
  66276. -
  66277. -/*  This really should allow any kind of declaration,
  66278. -    for generality.  Fix it before turning it back on.
  66279. -
  66280. -all_iter_stmt_with_decl:
  66281. -      FOR '(' ITERATOR pushlevel setspecs iterator_spec ')' 
  66282. -      {
  66283. -*/        /* The value returned by this action is  */
  66284. -        /*      1 if everything is OK */ 
  66285. -        /*      0 in case of error or already bound iterator */
  66286. -/*
  66287. -        iterator_for_loop_start ($6);
  66288. -      }
  66289. -      lineno_labeled_stmt
  66290. -      {
  66291. -        iterator_for_loop_end ($6);
  66292. -        emit_line_note (input_filename, lineno);
  66293. -        expand_end_bindings (getdecls (), 1, 0);
  66294. -        $<ttype>$ = poplevel (1, 1, 0);
  66295. -        if (yychar == CONSTANT || yychar == STRING)
  66296. -          pop_momentary_nofree ();
  66297. -        else
  66298. -          pop_momentary ();        
  66299. -      }
  66300. -*/
  66301. -
  66302. -/* Any kind of label, including jump labels and case labels.
  66303. -   ANSI C accepts labels only before statements, but we allow them
  66304. -   also at the end of a compound statement.  */
  66305. -
  66306. -label:      CASE expr_no_commas ':'
  66307. -        { register tree value = check_case_value ($2);
  66308. -          register tree label
  66309. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  66310. -
  66311. -          stmt_count++;
  66312. -
  66313. -          if (value != error_mark_node)
  66314. -            {
  66315. -              tree duplicate;
  66316. -              int success = pushcase (value, convert_and_check,
  66317. -                          label, &duplicate);
  66318. -              if (success == 1)
  66319. -            error ("case label not within a switch statement");
  66320. -              else if (success == 2)
  66321. -            {
  66322. -              error ("duplicate case value");
  66323. -              error_with_decl (duplicate, "this is the first entry for that value");
  66324. -            }
  66325. -              else if (success == 3)
  66326. -            warning ("case value out of range");
  66327. -              else if (success == 5)
  66328. -            error ("case label within scope of cleanup or variable array");
  66329. -            }
  66330. -          position_after_white_space (); }
  66331. -    | CASE expr_no_commas ELLIPSIS expr_no_commas ':'
  66332. -        { register tree value1 = check_case_value ($2);
  66333. -          register tree value2 = check_case_value ($4);
  66334. -          register tree label
  66335. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  66336. -
  66337. -          stmt_count++;
  66338. -
  66339. -          if (value1 != error_mark_node && value2 != error_mark_node)
  66340. -            {
  66341. -              tree duplicate;
  66342. -              int success = pushcase_range (value1, value2,
  66343. -                            convert_and_check, label,
  66344. -                            &duplicate);
  66345. -              if (success == 1)
  66346. -            error ("case label not within a switch statement");
  66347. -              else if (success == 2)
  66348. -            {
  66349. -              error ("duplicate case value");
  66350. -              error_with_decl (duplicate, "this is the first entry for that value");
  66351. -            }
  66352. -              else if (success == 3)
  66353. -            warning ("case value out of range");
  66354. -              else if (success == 4)
  66355. -            warning ("empty case range");
  66356. -              else if (success == 5)
  66357. -            error ("case label within scope of cleanup or variable array");
  66358. -            }
  66359. -          position_after_white_space (); }
  66360. -    | DEFAULT ':'
  66361. -        {
  66362. -          tree duplicate;
  66363. -          register tree label
  66364. -            = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
  66365. -          int success = pushcase (NULL_TREE, 0, label, &duplicate);
  66366. -          stmt_count++;
  66367. -          if (success == 1)
  66368. -            error ("default label not within a switch statement");
  66369. -          else if (success == 2)
  66370. -            {
  66371. -              error ("multiple default labels in one switch");
  66372. -              error_with_decl (duplicate, "this is the first default label");
  66373. -            }
  66374. -          position_after_white_space (); }
  66375. -    | identifier ':'
  66376. -        { tree label = define_label (input_filename, lineno, $1);
  66377. -          stmt_count++;
  66378. -          emit_nop ();
  66379. -          if (label)
  66380. -            expand_label (label);
  66381. -          position_after_white_space (); }
  66382. -    ;
  66383. -
  66384. -/* Either a type-qualifier or nothing.  First thing in an `asm' statement.  */
  66385. -
  66386. -maybe_type_qual:
  66387. -    /* empty */
  66388. -        { emit_line_note (input_filename, lineno);
  66389. -          $$ = NULL_TREE; }
  66390. -    | TYPE_QUAL
  66391. -        { emit_line_note (input_filename, lineno); }
  66392. -    ;
  66393. -
  66394. -xexpr:
  66395. -    /* empty */
  66396. -        { $$ = NULL_TREE; }
  66397. -    | expr
  66398. -    ;
  66399. -
  66400. -/* These are the operands other than the first string and colon
  66401. -   in  asm ("addextend %2,%1": "=dm" (x), "0" (y), "g" (*x))  */
  66402. -asm_operands: /* empty */
  66403. -        { $$ = NULL_TREE; }
  66404. -    | nonnull_asm_operands
  66405. -    ;
  66406. -
  66407. -nonnull_asm_operands:
  66408. -      asm_operand
  66409. -    | nonnull_asm_operands ',' asm_operand
  66410. -        { $$ = chainon ($1, $3); }
  66411. -    ;
  66412. -
  66413. -asm_operand:
  66414. -      STRING '(' expr ')'
  66415. -        { $$ = build_tree_list ($1, $3); }
  66416. -    ;
  66417. -
  66418. -asm_clobbers:
  66419. -      string
  66420. -        { $$ = tree_cons (NULL_TREE, combine_strings ($1), NULL_TREE); }
  66421. -    | asm_clobbers ',' string
  66422. -        { $$ = tree_cons (NULL_TREE, combine_strings ($3), $1); }
  66423. -    ;
  66424. -
  66425. -/* This is what appears inside the parens in a function declarator.
  66426. -   Its value is a list of ..._TYPE nodes.  */
  66427. -parmlist:
  66428. -        { pushlevel (0);
  66429. -          clear_parm_order ();
  66430. -          declare_parm_level (0); }
  66431. -      parmlist_1
  66432. -        { $$ = $2;
  66433. -          parmlist_tags_warning ();
  66434. -          poplevel (0, 0, 0); }
  66435. -    ;
  66436. -
  66437. -parmlist_1:
  66438. -      parmlist_2 ')'
  66439. -    | parms ';'
  66440. -        { tree parm;
  66441. -          if (pedantic)
  66442. -            pedwarn ("ANSI C forbids forward parameter declarations");
  66443. -          /* Mark the forward decls as such.  */
  66444. -          for (parm = getdecls (); parm; parm = TREE_CHAIN (parm))
  66445. -            TREE_ASM_WRITTEN (parm) = 1;
  66446. -          clear_parm_order (); }
  66447. -      parmlist_1
  66448. -        { $$ = $4; }
  66449. -    | error ')'
  66450. -        { $$ = tree_cons (NULL_TREE, NULL_TREE, NULL_TREE); }
  66451. -    ;
  66452. -
  66453. -/* This is what appears inside the parens in a function declarator.
  66454. -   Is value is represented in the format that grokdeclarator expects.  */
  66455. -parmlist_2:  /* empty */
  66456. -        { $$ = get_parm_info (0); }
  66457. -    | ELLIPSIS
  66458. -        { $$ = get_parm_info (0);
  66459. -          /* Gcc used to allow this as an extension.  However, it does
  66460. -             not work for all targets, and thus has been disabled.
  66461. -             Also, since func (...) and func () are indistinguishable,
  66462. -             it caused problems with the code in expand_builtin which
  66463. -             tries to verify that BUILT_IN_NEXT_ARG is being used
  66464. -             correctly.  */
  66465. -          error ("ANSI C requires a named argument before `...'");
  66466. -        }
  66467. -    | parms
  66468. -        { $$ = get_parm_info (1); }
  66469. -    | parms ',' ELLIPSIS
  66470. -        { $$ = get_parm_info (0); }
  66471. -    ;
  66472. -
  66473. -parms:
  66474. -    parm
  66475. -        { push_parm_decl ($1); }
  66476. -    | parms ',' parm
  66477. -        { push_parm_decl ($3); }
  66478. -    ;
  66479. -
  66480. -/* A single parameter declaration or parameter type name,
  66481. -   as found in a parmlist.  */
  66482. -parm:
  66483. -      typed_declspecs setspecs parm_declarator maybe_attribute
  66484. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  66485. -                             $3),
  66486. -                    build_tree_list (prefix_attributes,
  66487. -                             $4));
  66488. -          current_declspecs = TREE_VALUE (declspec_stack);
  66489. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66490. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66491. -          resume_momentary ($2); }
  66492. -    | typed_declspecs setspecs notype_declarator maybe_attribute
  66493. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  66494. -                             $3),
  66495. -                    build_tree_list (prefix_attributes,
  66496. -                             $4)); 
  66497. -          current_declspecs = TREE_VALUE (declspec_stack);
  66498. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66499. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66500. -          resume_momentary ($2); }
  66501. -    | typed_declspecs setspecs absdcl maybe_attribute
  66502. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  66503. -                             $3),
  66504. -                    build_tree_list (prefix_attributes,
  66505. -                             $4));
  66506. -          current_declspecs = TREE_VALUE (declspec_stack);
  66507. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66508. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66509. -          resume_momentary ($2); }
  66510. -    | declmods setspecs notype_declarator maybe_attribute
  66511. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  66512. -                             $3),
  66513. -                    build_tree_list (prefix_attributes,
  66514. -                             $4));
  66515. -          current_declspecs = TREE_VALUE (declspec_stack);
  66516. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66517. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66518. -          resume_momentary ($2);  }
  66519. -
  66520. -    | declmods setspecs absdcl maybe_attribute
  66521. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  66522. -                             $3),
  66523. -                    build_tree_list (prefix_attributes,
  66524. -                             $4));
  66525. -          current_declspecs = TREE_VALUE (declspec_stack);
  66526. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66527. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66528. -          resume_momentary ($2);  }
  66529. -    ;
  66530. -
  66531. -/* This is used in a function definition
  66532. -   where either a parmlist or an identifier list is ok.
  66533. -   Its value is a list of ..._TYPE nodes or a list of identifiers.  */
  66534. -parmlist_or_identifiers:
  66535. -        { pushlevel (0);
  66536. -          clear_parm_order ();
  66537. -          declare_parm_level (1); }
  66538. -      parmlist_or_identifiers_1
  66539. -        { $$ = $2;
  66540. -          parmlist_tags_warning ();
  66541. -          poplevel (0, 0, 0); }
  66542. -    ;
  66543. -
  66544. -parmlist_or_identifiers_1:
  66545. -      parmlist_1
  66546. -    | identifiers ')'
  66547. -        { tree t;
  66548. -          for (t = $1; t; t = TREE_CHAIN (t))
  66549. -            if (TREE_VALUE (t) == NULL_TREE)
  66550. -              error ("`...' in old-style identifier list");
  66551. -          $$ = tree_cons (NULL_TREE, NULL_TREE, $1); }
  66552. -    ;
  66553. -
  66554. -/* A nonempty list of identifiers.  */
  66555. -identifiers:
  66556. -    IDENTIFIER
  66557. -        { $$ = build_tree_list (NULL_TREE, $1); }
  66558. -    | identifiers ',' IDENTIFIER
  66559. -        { $$ = chainon ($1, build_tree_list (NULL_TREE, $3)); }
  66560. -    ;
  66561. -
  66562. -/* A nonempty list of identifiers, including typenames.  */
  66563. -identifiers_or_typenames:
  66564. -    identifier
  66565. -        { $$ = build_tree_list (NULL_TREE, $1); }
  66566. -    | identifiers_or_typenames ',' identifier
  66567. -        { $$ = chainon ($1, build_tree_list (NULL_TREE, $3)); }
  66568. -    ;
  66569. -
  66570. -/* Objective-C productions.  */
  66571. -
  66572. -objcdef:
  66573. -      classdef
  66574. -    | classdecl
  66575. -    | aliasdecl
  66576. -    | protocoldef
  66577. -    | methoddef
  66578. -    | END
  66579. -        {
  66580. -          if (objc_implementation_context)
  66581. -                    {
  66582. -              finish_class (objc_implementation_context);
  66583. -              objc_ivar_chain = NULL_TREE;
  66584. -              objc_implementation_context = NULL_TREE;
  66585. -            }
  66586. -          else
  66587. -            warning ("`@end' must appear in an implementation context");
  66588. -        }
  66589. -    ;
  66590. -
  66591. -/* A nonempty list of identifiers.  */
  66592. -identifier_list:
  66593. -    identifier
  66594. -        { $$ = build_tree_list (NULL_TREE, $1); }
  66595. -    | identifier_list ',' identifier
  66596. -        { $$ = chainon ($1, build_tree_list (NULL_TREE, $3)); }
  66597. -    ;
  66598. -
  66599. -classdecl:
  66600. -      CLASS identifier_list ';'
  66601. -        {
  66602. -          objc_declare_class ($2);
  66603. -        }
  66604. -
  66605. -aliasdecl:
  66606. -      ALIAS identifier identifier ';'
  66607. -        {
  66608. -          objc_declare_alias ($2, $3);
  66609. -        }
  66610. -
  66611. -classdef:
  66612. -      INTERFACE identifier protocolrefs '{'
  66613. -        {
  66614. -          objc_interface_context = objc_ivar_context
  66615. -            = start_class (CLASS_INTERFACE_TYPE, $2, NULL_TREE, $3);
  66616. -                  objc_public_flag = 0;
  66617. -        }
  66618. -      ivar_decl_list '}'
  66619. -        {
  66620. -                  continue_class (objc_interface_context);
  66621. -        }
  66622. -      methodprotolist
  66623. -      END
  66624. -        {
  66625. -          finish_class (objc_interface_context);
  66626. -          objc_interface_context = NULL_TREE;
  66627. -        }
  66628. -
  66629. -    | INTERFACE identifier protocolrefs
  66630. -        {
  66631. -          objc_interface_context
  66632. -            = start_class (CLASS_INTERFACE_TYPE, $2, NULL_TREE, $3);
  66633. -                  continue_class (objc_interface_context);
  66634. -        }
  66635. -      methodprotolist
  66636. -      END
  66637. -        {
  66638. -          finish_class (objc_interface_context);
  66639. -          objc_interface_context = NULL_TREE;
  66640. -        }
  66641. -
  66642. -    | INTERFACE identifier ':' identifier protocolrefs '{'
  66643. -        {
  66644. -          objc_interface_context = objc_ivar_context
  66645. -            = start_class (CLASS_INTERFACE_TYPE, $2, $4, $5);
  66646. -                  objc_public_flag = 0;
  66647. -        }
  66648. -      ivar_decl_list '}'
  66649. -        {
  66650. -                  continue_class (objc_interface_context);
  66651. -        }
  66652. -      methodprotolist
  66653. -      END
  66654. -        {
  66655. -          finish_class (objc_interface_context);
  66656. -          objc_interface_context = NULL_TREE;
  66657. -        }
  66658. -
  66659. -    | INTERFACE identifier ':' identifier protocolrefs
  66660. -        {
  66661. -          objc_interface_context
  66662. -            = start_class (CLASS_INTERFACE_TYPE, $2, $4, $5);
  66663. -                  continue_class (objc_interface_context);
  66664. -        }
  66665. -      methodprotolist
  66666. -      END
  66667. -        {
  66668. -          finish_class (objc_interface_context);
  66669. -          objc_interface_context = NULL_TREE;
  66670. -        }
  66671. -
  66672. -    | IMPLEMENTATION identifier '{'
  66673. -        {
  66674. -          objc_implementation_context = objc_ivar_context
  66675. -            = start_class (CLASS_IMPLEMENTATION_TYPE, $2, NULL_TREE, NULL_TREE);
  66676. -                  objc_public_flag = 0;
  66677. -        }
  66678. -      ivar_decl_list '}'
  66679. -        {
  66680. -                  objc_ivar_chain
  66681. -            = continue_class (objc_implementation_context);
  66682. -        }
  66683. -
  66684. -    | IMPLEMENTATION identifier
  66685. -        {
  66686. -          objc_implementation_context
  66687. -            = start_class (CLASS_IMPLEMENTATION_TYPE, $2, NULL_TREE, NULL_TREE);
  66688. -                  objc_ivar_chain
  66689. -            = continue_class (objc_implementation_context);
  66690. -        }
  66691. -
  66692. -    | IMPLEMENTATION identifier ':' identifier '{'
  66693. -        {
  66694. -          objc_implementation_context = objc_ivar_context
  66695. -            = start_class (CLASS_IMPLEMENTATION_TYPE, $2, $4, NULL_TREE);
  66696. -                  objc_public_flag = 0;
  66697. -        }
  66698. -      ivar_decl_list '}'
  66699. -        {
  66700. -                  objc_ivar_chain
  66701. -            = continue_class (objc_implementation_context);
  66702. -        }
  66703. -
  66704. -    | IMPLEMENTATION identifier ':' identifier
  66705. -        {
  66706. -          objc_implementation_context
  66707. -            = start_class (CLASS_IMPLEMENTATION_TYPE, $2, $4, NULL_TREE);
  66708. -                  objc_ivar_chain
  66709. -            = continue_class (objc_implementation_context);
  66710. -        }
  66711. -
  66712. -    | INTERFACE identifier '(' identifier ')' protocolrefs
  66713. -        {
  66714. -          objc_interface_context
  66715. -            = start_class (CATEGORY_INTERFACE_TYPE, $2, $4, $6);
  66716. -                  continue_class (objc_interface_context);
  66717. -        }
  66718. -      methodprotolist
  66719. -      END
  66720. -        {
  66721. -          finish_class (objc_interface_context);
  66722. -          objc_interface_context = NULL_TREE;
  66723. -        }
  66724. -
  66725. -    | IMPLEMENTATION identifier '(' identifier ')'
  66726. -        {
  66727. -          objc_implementation_context
  66728. -            = start_class (CATEGORY_IMPLEMENTATION_TYPE, $2, $4, NULL_TREE);
  66729. -                  objc_ivar_chain
  66730. -            = continue_class (objc_implementation_context);
  66731. -        }
  66732. -    ;
  66733. -
  66734. -protocoldef:
  66735. -      PROTOCOL identifier protocolrefs
  66736. -        {
  66737. -          remember_protocol_qualifiers ();
  66738. -          objc_interface_context
  66739. -            = start_protocol(PROTOCOL_INTERFACE_TYPE, $2, $3);
  66740. -        }
  66741. -      methodprotolist END
  66742. -        {
  66743. -          forget_protocol_qualifiers();
  66744. -          finish_protocol(objc_interface_context);
  66745. -          objc_interface_context = NULL_TREE;
  66746. -        }
  66747. -    ;
  66748. -
  66749. -protocolrefs:
  66750. -      /* empty */
  66751. -        {
  66752. -          $$ = NULL_TREE;
  66753. -        }
  66754. -    | ARITHCOMPARE identifier_list ARITHCOMPARE
  66755. -        {
  66756. -          if ($1 == LT_EXPR && $3 == GT_EXPR)
  66757. -            $$ = $2;
  66758. -          else
  66759. -            YYERROR1;
  66760. -        }
  66761. -    ;
  66762. -
  66763. -ivar_decl_list:
  66764. -          ivar_decl_list visibility_spec ivar_decls
  66765. -        | ivar_decls
  66766. -        ;
  66767. -
  66768. -visibility_spec:
  66769. -      PRIVATE { objc_public_flag = 2; }
  66770. -    | PROTECTED { objc_public_flag = 0; }
  66771. -    | PUBLIC { objc_public_flag = 1; }
  66772. -    ;
  66773. -
  66774. -ivar_decls:
  66775. -          /* empty */
  66776. -        {
  66777. -                  $$ = NULL_TREE;
  66778. -                }
  66779. -    | ivar_decls ivar_decl ';'
  66780. -    | ivar_decls ';'
  66781. -        {
  66782. -                  if (pedantic)
  66783. -            pedwarn ("extra semicolon in struct or union specified");
  66784. -                }
  66785. -    ;
  66786. -
  66787. -
  66788. -/* There is a shift-reduce conflict here, because `components' may
  66789. -   start with a `typename'.  It happens that shifting (the default resolution)
  66790. -   does the right thing, because it treats the `typename' as part of
  66791. -   a `typed_typespecs'.
  66792. -
  66793. -   It is possible that this same technique would allow the distinction
  66794. -   between `notype_initdecls' and `initdecls' to be eliminated.
  66795. -   But I am being cautious and not trying it.  */
  66796. -
  66797. -ivar_decl:
  66798. -    typed_typespecs setspecs ivars
  66799. -            { $$ = $3;
  66800. -          current_declspecs = TREE_VALUE (declspec_stack);
  66801. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66802. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66803. -          resume_momentary ($2); }
  66804. -    | nonempty_type_quals setspecs ivars
  66805. -        { $$ = $3;
  66806. -          current_declspecs = TREE_VALUE (declspec_stack);
  66807. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66808. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66809. -          resume_momentary ($2); }
  66810. -    | error
  66811. -        { $$ = NULL_TREE; }
  66812. -    ;
  66813. -
  66814. -ivars:
  66815. -      /* empty */
  66816. -        { $$ = NULL_TREE; }
  66817. -    | ivar_declarator
  66818. -    | ivars ',' ivar_declarator
  66819. -    ;
  66820. -
  66821. -ivar_declarator:
  66822. -      declarator
  66823. -        {
  66824. -          $$ = add_instance_variable (objc_ivar_context,
  66825. -                          objc_public_flag,
  66826. -                          $1, current_declspecs,
  66827. -                          NULL_TREE);
  66828. -                }
  66829. -    | declarator ':' expr_no_commas
  66830. -        {
  66831. -          $$ = add_instance_variable (objc_ivar_context,
  66832. -                          objc_public_flag,
  66833. -                          $1, current_declspecs, $3);
  66834. -                }
  66835. -    | ':' expr_no_commas
  66836. -        {
  66837. -          $$ = add_instance_variable (objc_ivar_context,
  66838. -                          objc_public_flag,
  66839. -                          NULL_TREE,
  66840. -                          current_declspecs, $2);
  66841. -                }
  66842. -    ;
  66843. -
  66844. -methoddef:
  66845. -      '+'
  66846. -        {
  66847. -          remember_protocol_qualifiers ();
  66848. -          if (objc_implementation_context)
  66849. -            objc_inherit_code = CLASS_METHOD_DECL;
  66850. -                  else
  66851. -            fatal ("method definition not in class context");
  66852. -        }
  66853. -      methoddecl
  66854. -        {
  66855. -          forget_protocol_qualifiers ();
  66856. -          add_class_method (objc_implementation_context, $3);
  66857. -          start_method_def ($3);
  66858. -          objc_method_context = $3;
  66859. -        }
  66860. -      optarglist
  66861. -        {
  66862. -          continue_method_def ();
  66863. -        }
  66864. -      compstmt_or_error
  66865. -        {
  66866. -          finish_method_def ();
  66867. -          objc_method_context = NULL_TREE;
  66868. -        }
  66869. -
  66870. -    | '-'
  66871. -        {
  66872. -          remember_protocol_qualifiers ();
  66873. -          if (objc_implementation_context)
  66874. -            objc_inherit_code = INSTANCE_METHOD_DECL;
  66875. -                  else
  66876. -            fatal ("method definition not in class context");
  66877. -        }
  66878. -      methoddecl
  66879. -        {
  66880. -          forget_protocol_qualifiers ();
  66881. -          add_instance_method (objc_implementation_context, $3);
  66882. -          start_method_def ($3);
  66883. -          objc_method_context = $3;
  66884. -        }
  66885. -      optarglist
  66886. -        {
  66887. -          continue_method_def ();
  66888. -        }
  66889. -      compstmt_or_error
  66890. -        {
  66891. -          finish_method_def ();
  66892. -          objc_method_context = NULL_TREE;
  66893. -        }
  66894. -    ;
  66895. -
  66896. -/* the reason for the strange actions in this rule
  66897. - is so that notype_initdecls when reached via datadef
  66898. - can find a valid list of type and sc specs in $0. */
  66899. -
  66900. -methodprotolist:
  66901. -      /* empty  */
  66902. -    | {$<ttype>$ = NULL_TREE; } methodprotolist2
  66903. -    ;
  66904. -
  66905. -methodprotolist2:         /* eliminates a shift/reduce conflict */
  66906. -       methodproto
  66907. -    |  datadef
  66908. -    | methodprotolist2 methodproto
  66909. -    | methodprotolist2 {$<ttype>$ = NULL_TREE; } datadef
  66910. -    ;
  66911. -
  66912. -semi_or_error:
  66913. -      ';'
  66914. -    | error
  66915. -    ;
  66916. -
  66917. -methodproto:
  66918. -      '+'
  66919. -        {
  66920. -          objc_inherit_code = CLASS_METHOD_DECL;
  66921. -        }
  66922. -      methoddecl
  66923. -        {
  66924. -          add_class_method (objc_interface_context, $3);
  66925. -        }
  66926. -      semi_or_error
  66927. -
  66928. -    | '-'
  66929. -        {
  66930. -          objc_inherit_code = INSTANCE_METHOD_DECL;
  66931. -        }
  66932. -      methoddecl
  66933. -        {
  66934. -          add_instance_method (objc_interface_context, $3);
  66935. -        }
  66936. -      semi_or_error
  66937. -    ;
  66938. -
  66939. -methoddecl:
  66940. -      '(' typename ')' unaryselector
  66941. -        {
  66942. -          $$ = build_method_decl (objc_inherit_code, $2, $4, NULL_TREE);
  66943. -        }
  66944. -
  66945. -    | unaryselector
  66946. -        {
  66947. -          $$ = build_method_decl (objc_inherit_code, NULL_TREE, $1, NULL_TREE);
  66948. -        }
  66949. -
  66950. -    | '(' typename ')' keywordselector optparmlist
  66951. -        {
  66952. -          $$ = build_method_decl (objc_inherit_code, $2, $4, $5);
  66953. -        }
  66954. -
  66955. -    | keywordselector optparmlist
  66956. -        {
  66957. -          $$ = build_method_decl (objc_inherit_code, NULL_TREE, $1, $2);
  66958. -        }
  66959. -    ;
  66960. -
  66961. -/* "optarglist" assumes that start_method_def has already been called...
  66962. -   if it is not, the "xdecls" will not be placed in the proper scope */
  66963. -
  66964. -optarglist:
  66965. -      /* empty */
  66966. -    | ';' myxdecls
  66967. -    ;
  66968. -
  66969. -/* to get around the following situation: "int foo (int a) int b; {}" that
  66970. -   is synthesized when parsing "- a:a b:b; id c; id d; { ... }" */
  66971. -
  66972. -myxdecls:
  66973. -      /* empty */
  66974. -    | mydecls
  66975. -    ;
  66976. -
  66977. -mydecls:
  66978. -    mydecl
  66979. -    | errstmt
  66980. -    | mydecls mydecl
  66981. -    | mydecl errstmt
  66982. -    ;
  66983. -
  66984. -mydecl:
  66985. -    typed_declspecs setspecs myparms ';'
  66986. -        { current_declspecs = TREE_VALUE (declspec_stack);
  66987. -          prefix_attributes = TREE_PURPOSE (declspec_stack);
  66988. -          declspec_stack = TREE_CHAIN (declspec_stack);
  66989. -          resume_momentary ($2); }
  66990. -    | typed_declspecs ';'
  66991. -        { shadow_tag ($1); }
  66992. -    | declmods ';'
  66993. -        { pedwarn ("empty declaration"); }
  66994. -    ;
  66995. -
  66996. -myparms:
  66997. -    myparm
  66998. -        { push_parm_decl ($1); }
  66999. -    | myparms ',' myparm
  67000. -        { push_parm_decl ($3); }
  67001. -    ;
  67002. -
  67003. -/* A single parameter declaration or parameter type name,
  67004. -   as found in a parmlist. DOES NOT ALLOW AN INITIALIZER OR ASMSPEC */
  67005. -
  67006. -myparm:
  67007. -      parm_declarator maybe_attribute
  67008. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  67009. -                             $1),
  67010. -                    build_tree_list (prefix_attributes,
  67011. -                             $2)); }
  67012. -    | notype_declarator maybe_attribute
  67013. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  67014. -                             $1),
  67015. -                    build_tree_list (prefix_attributes,
  67016. -                             $2)); }
  67017. -    | absdcl maybe_attribute
  67018. -        { $$ = build_tree_list (build_tree_list (current_declspecs,
  67019. -                             $1),
  67020. -                    build_tree_list (prefix_attributes,
  67021. -                             $2)); }
  67022. -    ;
  67023. -
  67024. -optparmlist:
  67025. -      /* empty */
  67026. -        {
  67027. -              $$ = NULL_TREE;
  67028. -        }
  67029. -    | ',' ELLIPSIS
  67030. -        {
  67031. -          /* oh what a kludge! */
  67032. -          $$ = (tree)1;
  67033. -        }
  67034. -    | ','
  67035. -        {
  67036. -          pushlevel (0);
  67037. -        }
  67038. -      parmlist_2
  67039. -        {
  67040. -            /* returns a tree list node generated by get_parm_info */
  67041. -          $$ = $3;
  67042. -          poplevel (0, 0, 0);
  67043. -        }
  67044. -    ;
  67045. -
  67046. -unaryselector:
  67047. -      selector
  67048. -    ;
  67049. -
  67050. -keywordselector:
  67051. -      keyworddecl
  67052. -
  67053. -    | keywordselector keyworddecl
  67054. -        {
  67055. -          $$ = chainon ($1, $2);
  67056. -        }
  67057. -    ;
  67058. -
  67059. -selector:
  67060. -      IDENTIFIER
  67061. -        | TYPENAME
  67062. -      | OBJECTNAME
  67063. -    | reservedwords
  67064. -    ;
  67065. -
  67066. -reservedwords:
  67067. -      ENUM { $$ = get_identifier (token_buffer); }
  67068. -    | STRUCT { $$ = get_identifier (token_buffer); }
  67069. -    | UNION { $$ = get_identifier (token_buffer); }
  67070. -    | IF { $$ = get_identifier (token_buffer); }
  67071. -    | ELSE { $$ = get_identifier (token_buffer); }
  67072. -    | WHILE { $$ = get_identifier (token_buffer); }
  67073. -    | DO { $$ = get_identifier (token_buffer); }
  67074. -    | FOR { $$ = get_identifier (token_buffer); }
  67075. -    | SWITCH { $$ = get_identifier (token_buffer); }
  67076. -    | CASE { $$ = get_identifier (token_buffer); }
  67077. -    | DEFAULT { $$ = get_identifier (token_buffer); }
  67078. -    | BREAK { $$ = get_identifier (token_buffer); }
  67079. -    | CONTINUE { $$ = get_identifier (token_buffer); }
  67080. -    | RETURN  { $$ = get_identifier (token_buffer); }
  67081. -    | GOTO { $$ = get_identifier (token_buffer); }
  67082. -    | ASM_KEYWORD { $$ = get_identifier (token_buffer); }
  67083. -        | SIZEOF { $$ = get_identifier (token_buffer); }
  67084. -    | TYPEOF { $$ = get_identifier (token_buffer); }
  67085. -    | ALIGNOF { $$ = get_identifier (token_buffer); }
  67086. -    | TYPESPEC | TYPE_QUAL
  67087. -    ;
  67088. -
  67089. -keyworddecl:
  67090. -      selector ':' '(' typename ')' identifier
  67091. -        {
  67092. -          $$ = build_keyword_decl ($1, $4, $6);
  67093. -        }
  67094. -
  67095. -    | selector ':' identifier
  67096. -        {
  67097. -          $$ = build_keyword_decl ($1, NULL_TREE, $3);
  67098. -        }
  67099. -
  67100. -    | ':' '(' typename ')' identifier
  67101. -        {
  67102. -          $$ = build_keyword_decl (NULL_TREE, $3, $5);
  67103. -        }
  67104. -
  67105. -    | ':' identifier
  67106. -        {
  67107. -          $$ = build_keyword_decl (NULL_TREE, NULL_TREE, $2);
  67108. -        }
  67109. -    ;
  67110. -
  67111. -messageargs:
  67112. -      selector
  67113. -        | keywordarglist
  67114. -    ;
  67115. -
  67116. -keywordarglist:
  67117. -      keywordarg
  67118. -    | keywordarglist keywordarg
  67119. -        {
  67120. -          $$ = chainon ($1, $2);
  67121. -        }
  67122. -    ;
  67123. -
  67124. -
  67125. -keywordexpr:
  67126. -      nonnull_exprlist
  67127. -        {
  67128. -          if (TREE_CHAIN ($1) == NULL_TREE)
  67129. -            /* just return the expr., remove a level of indirection */
  67130. -            $$ = TREE_VALUE ($1);
  67131. -                  else
  67132. -            /* we have a comma expr., we will collapse later */
  67133. -            $$ = $1;
  67134. -        }
  67135. -    ;
  67136. -
  67137. -keywordarg:
  67138. -      selector ':' keywordexpr
  67139. -        {
  67140. -          $$ = build_tree_list ($1, $3);
  67141. -        }
  67142. -    | ':' keywordexpr
  67143. -        {
  67144. -          $$ = build_tree_list (NULL_TREE, $2);
  67145. -        }
  67146. -    ;
  67147. -
  67148. -receiver:
  67149. -      expr
  67150. -    | CLASSNAME
  67151. -        {
  67152. -          $$ = get_class_reference ($1);
  67153. -        }
  67154. -    ;
  67155. -
  67156. -objcmessageexpr:
  67157. -      '['
  67158. -        { objc_receiver_context = 1; }
  67159. -      receiver
  67160. -        { objc_receiver_context = 0; }
  67161. -      messageargs ']'
  67162. -        {
  67163. -          $$ = build_tree_list ($3, $5);
  67164. -        }
  67165. -    ;
  67166. -
  67167. -selectorarg:
  67168. -      selector
  67169. -        | keywordnamelist
  67170. -    ;
  67171. -
  67172. -keywordnamelist:
  67173. -      keywordname
  67174. -    | keywordnamelist keywordname
  67175. -        {
  67176. -          $$ = chainon ($1, $2);
  67177. -        }
  67178. -    ;
  67179. -
  67180. -keywordname:
  67181. -      selector ':'
  67182. -        {
  67183. -          $$ = build_tree_list ($1, NULL_TREE);
  67184. -        }
  67185. -    | ':'
  67186. -        {
  67187. -          $$ = build_tree_list (NULL_TREE, NULL_TREE);
  67188. -        }
  67189. -    ;
  67190. -
  67191. -objcselectorexpr:
  67192. -      SELECTOR '(' selectorarg ')'
  67193. -        {
  67194. -          $$ = $3;
  67195. -        }
  67196. -    ;
  67197. -
  67198. -objcprotocolexpr:
  67199. -      PROTOCOL '(' identifier ')'
  67200. -        {
  67201. -          $$ = $3;
  67202. -        }
  67203. -    ;
  67204. -
  67205. -/* extension to support C-structures in the archiver */
  67206. -
  67207. -objcencodeexpr:
  67208. -      ENCODE '(' typename ')'
  67209. -        {
  67210. -          $$ = groktypename ($3);
  67211. -        }
  67212. -    ;
  67213. -
  67214. -%%
  67215. diff -rup --new-file baseline/fsf/gcc/protoize.c amiga/fsf/gcc/protoize.c
  67216. --- baseline/fsf/gcc/protoize.c    Mon Oct  9 09:37:32 1995
  67217. +++ amiga/fsf/gcc/protoize.c    Sat Sep 28 00:00:00 1996
  67218. @@ -883,8 +883,13 @@ in_system_include_dir (path)
  67219.  {
  67220.    struct default_include *p;
  67221.  
  67222. +#ifdef FILE_NAME_ABSOLUTE_P
  67223. +  if (! FILE_NAME_ABSOLUTE_P (path))
  67224. +    abort ();
  67225. +#else
  67226.    if (path[0] != '/')
  67227.      abort ();        /* Must be an absolutized filename.  */
  67228. +#endif
  67229.  
  67230.    for (p = include_defaults; p->fname; p++)
  67231.      if (!strncmp (path, p->fname, strlen (p->fname))
  67232. @@ -1311,7 +1316,11 @@ abspath (cwd, rel_filename)
  67233.    {
  67234.      const char *src_p;
  67235.  
  67236. +#ifdef FILE_NAME_ABSOLUTE_P
  67237. +    if (! FILE_NAME_ABSOLUTE_P (rel_filename))
  67238. +#else
  67239.      if (rel_filename[0] != '/')
  67240. +#endif
  67241.        {
  67242.          src_p = cwd2;
  67243.          while (*endp++ = *src_p++)
  67244. @@ -1574,6 +1583,25 @@ find_corresponding_lparen (p)
  67245.    return ++q;
  67246.  }
  67247.  
  67248. +/* Use this macro to advance a char * over the filename part in a line
  67249. +   read from an aux-info file. */
  67250. +
  67251. +#ifndef __amigaos__
  67252. +/* Version for file systems where the colon has no special meaning */
  67253. +#define ADVANCE_PAST_FILENAME(CP) \
  67254. +  while (* (CP) != ':') (CP)++
  67255. +#else
  67256. +/* Have to heuristically decide whether the colon is part of the filename
  67257. +   or whether it serves to delimit the filename from the line number. If
  67258. +   it's the latter case, then the character following the colon *must*
  67259. +   be a digit. Note that this heuristic fails if the filename starts
  67260. +   with a digit. */
  67261. +#define ADVANCE_PAST_FILENAME(CP) \
  67262. +    while ((CP)[0] != ':' || !isdigit ((CP)[1])) \
  67263. +      (CP)++;
  67264. +#endif
  67265. +
  67266. +
  67267.  /* Given a line from  an aux info file, and a time at which the aux info
  67268.     file it came from was created, check to see if the item described in
  67269.     the line comes from a file which has been modified since the aux info
  67270. @@ -1595,8 +1623,7 @@ referenced_file_is_newer (l, aux_info_mt
  67271.    {
  67272.      const char *filename_start = p = l + 3;
  67273.  
  67274. -    while (*p != ':')
  67275. -      p++;
  67276. +    ADVANCE_PAST_FILENAME (p);
  67277.      filename = (char *) alloca ((size_t) (p - filename_start) + 1);
  67278.      strncpy (filename, filename_start, (size_t) (p - filename_start));
  67279.      filename[p-filename_start] = '\0';
  67280. @@ -1653,8 +1680,7 @@ save_def_or_dec (l, is_syscalls)
  67281.      const char *filename_start = p = l + 3;
  67282.      char *filename;
  67283.  
  67284. -    while (*p != ':')
  67285. -      p++;
  67286. +    ADVANCE_PAST_FILENAME (p);
  67287.      filename = (char *) alloca ((size_t) (p - filename_start) + 1);
  67288.      strncpy (filename, filename_start, (size_t) (p - filename_start));
  67289.      filename[p-filename_start] = '\0';
  67290. @@ -2381,7 +2407,9 @@ start_over: ;
  67291.    {
  67292.      char *p = aux_info_base;
  67293.  
  67294. -    while (*p != ':')
  67295. +    /* have to make sure at least one space is following the colon to make
  67296. +       sure the colon is not part of the filename */
  67297. +    while (*p != ':' && p[1] != ' ')
  67298.        p++;
  67299.      p++;
  67300.      while (*p == ' ')
  67301. @@ -2395,7 +2423,11 @@ start_over: ;
  67302.        continue;
  67303.      aux_info_second_line = p;
  67304.      aux_info_relocated_name = 0;
  67305. -    if (invocation_filename[0] != '/')
  67306. +#ifdef FILE_NAME_ABSOLUTE_P
  67307. +    if (! FILE_NAME_ABSOLUTE_P (invocation_filename))
  67308. +#else
  67309. +      if (invocation_filename[0] != '/')
  67310. +#endif
  67311.        {
  67312.      /* INVOCATION_FILENAME is relative;
  67313.         append it to BASE_SOURCE_FILENAME's dir.  */
  67314. @@ -2484,7 +2516,7 @@ start_over: ;
  67315.  #ifndef UNPROTOIZE
  67316.  
  67317.  /* Check an individual filename for a .c suffix.  If the filename has this
  67318. -   suffix, rename the file such that its suffix is changed to .C.  This
  67319. +   suffix, rename the file such that its suffix is changed to .cc.  This
  67320.     function implements the -C option.  */
  67321.  
  67322.  static void
  67323. @@ -2493,7 +2525,7 @@ rename_c_file (hp)
  67324.  {
  67325.    const char *filename = hp->symbol;
  67326.    int last_char_index = strlen (filename) - 1;
  67327. -  char *const new_filename = (char *) alloca (strlen (filename) + 1);
  67328. +  char *const new_filename = (char *) alloca (strlen (filename) + 2);
  67329.  
  67330.    /* Note that we don't care here if the given file was converted or not.  It
  67331.       is possible that the given file was *not* converted, simply because there
  67332. @@ -2505,8 +2537,25 @@ rename_c_file (hp)
  67333.      return;
  67334.  
  67335.    strcpy (new_filename, filename);
  67336. -  new_filename[last_char_index] = 'C';
  67337. +  strcat (new_filename + last_char_index, "cc");
  67338. +  
  67339. +  /* use rename(2) if available !! Update config files to include HAVE_RENAME
  67340. +     if the used OS provides it. Advantages are: it's atomic, it's one
  67341. +     system call compared to two. */
  67342.  
  67343. +#ifdef HAVE_RENAME
  67344. +  /* if the mentioned systems (POSIX 1003.1-1988) have rename(2), this has
  67345. +     to be changed to `my_rename' as well. */
  67346. +
  67347. +  if (rename (filename, new_filename) == -1)
  67348. +    {
  67349. +      fprintf (stderr, "%s: warning: can't rename file `%s' to `%s': %s\n",
  67350. +           pname, shortpath (NULL, filename),
  67351. +           shortpath (NULL, new_filename), my_strerror(errno));
  67352. +      errors++;
  67353. +      return;
  67354. +    }
  67355. +#else
  67356.    if (my_link (filename, new_filename) == -1)
  67357.      {
  67358.        fprintf (stderr, "%s: warning: can't link file `%s' to `%s': %s\n",
  67359. @@ -2523,6 +2572,7 @@ rename_c_file (hp)
  67360.        errors++;
  67361.        return;
  67362.      }
  67363. +#endif
  67364.  }
  67365.  
  67366.  #endif /* !defined (UNPROTOIZE) */
  67367. diff -rup --new-file baseline/fsf/gcc/real.c amiga/fsf/gcc/real.c
  67368. --- baseline/fsf/gcc/real.c    Tue Aug 15 14:57:18 1995
  67369. +++ amiga/fsf/gcc/real.c    Sat Sep 28 00:00:00 1996
  67370. @@ -4429,9 +4429,15 @@ etoasc (x, string, ndigs)
  67371.    if (y[NE - 1] == 0x7fff)
  67372.      {
  67373.        if (sign)
  67374. +#ifdef TARGET_AMIGAOS
  67375.      sprintf (wstring, " -Infinity ");
  67376.        else
  67377.      sprintf (wstring, " Infinity ");
  67378. +#else
  67379. +    sprintf (wstring, " -NaN ");
  67380. +      else
  67381. +    sprintf (wstring, " NaN ");
  67382. +#endif
  67383.        goto bxit;
  67384.      }
  67385.  
  67386. diff -rup --new-file baseline/fsf/gcc/rtl.def amiga/fsf/gcc/rtl.def
  67387. --- baseline/fsf/gcc/rtl.def    Thu Jun 15 05:03:32 1995
  67388. +++ amiga/fsf/gcc/rtl.def    Sat Sep 28 00:00:00 1996
  67389. @@ -704,8 +704,10 @@ DEF_RTL_EXPR(TRUNCATE, "truncate", "e", 
  67390.  DEF_RTL_EXPR(FLOAT_EXTEND, "float_extend", "e", '1')
  67391.  DEF_RTL_EXPR(FLOAT_TRUNCATE, "float_truncate", "e", '1')
  67392.  
  67393. +#ifndef SUPPRESS_RTL_FLOAT_DEFINITION    /* Amiga hack - avoid clash with <exec/types.h> typedef */
  67394.  /* Conversion of fixed point operand to floating point value.  */
  67395.  DEF_RTL_EXPR(FLOAT, "float", "e", '1')
  67396. +#endif
  67397.  
  67398.  /* With fixed-point machine mode:
  67399.     Conversion of floating point operand to fixed point value.
  67400. diff -rup --new-file baseline/fsf/gcc/scan-types.sh amiga/fsf/gcc/scan-types.sh
  67401. --- baseline/fsf/gcc/scan-types.sh    Mon Apr 18 00:07:12 1994
  67402. +++ amiga/fsf/gcc/scan-types.sh    Sat Sep 28 00:00:00 1996
  67403. @@ -1,4 +1,4 @@
  67404. -#! /bin/sh
  67405. +#!/bin/sh
  67406.  # Deduce values of standard ANSI and POSIX types (e.g. size_t, pid_t).
  67407.  # Emits macros definitions for these, and some other types.
  67408.  # Intended to be used to massage the sys-protos.h file.
  67409. diff -rup --new-file baseline/fsf/gcc/toplev.c amiga/fsf/gcc/toplev.c
  67410. --- baseline/fsf/gcc/toplev.c    Fri Oct 20 14:56:35 1995
  67411. +++ amiga/fsf/gcc/toplev.c    Sat Sep 28 00:00:00 1996
  67412. @@ -55,6 +55,10 @@ Boston, MA 02111-1307, USA.  */
  67413.  
  67414.  #include "input.h"
  67415.  #include "tree.h"
  67416. +#ifdef __amigaos__
  67417. +#define SUPPRESS_RTL_FLOAT_DEFINITION    /* Avoid <exec/types.h> and rtl.def typedef clash for "float" */
  67418. +#include <stdlib.h>
  67419. +#endif
  67420.  #include "rtl.h"
  67421.  #include "flags.h"
  67422.  #include "insn-attr.h"
  67423. @@ -145,6 +149,13 @@ static char *decl_name ();
  67424.  extern char *sbrk ();
  67425.  #endif
  67426.  
  67427. +#ifdef __amigaos__
  67428. +/* Phil.B: 03-Oct-94 Flag indicating process priority */
  67429. +static int amiga_priority = -1;
  67430. +#include <proto/exec.h>
  67431. +struct Task *amiga_task;
  67432. +#endif /* __amigaos__ */
  67433. +
  67434.  /* Name of program invoked, sans directories.  */
  67435.  
  67436.  char *progname;
  67437. @@ -543,6 +554,7 @@ struct { char *string; int *variable; in
  67438.    {"unroll-all-loops", &flag_unroll_all_loops, 1},
  67439.    {"writable-strings", &flag_writable_strings, 1},
  67440.    {"peephole", &flag_no_peephole, 0},
  67441. +  {"large-baserel", &flag_pic, 4},
  67442.    {"force-mem", &flag_force_mem, 1},
  67443.    {"force-addr", &flag_force_addr, 1},
  67444.    {"function-cse", &flag_no_function_cse, 0},
  67445. @@ -561,6 +573,7 @@ struct { char *string; int *variable; in
  67446.    {"schedule-insns2", &flag_schedule_insns_after_reload, 1},
  67447.    {"pic", &flag_pic, 1},
  67448.    {"PIC", &flag_pic, 2},
  67449. +  {"baserel", &flag_pic, 3},
  67450.    {"fast-math", &flag_fast_math, 1},
  67451.    {"common", &flag_no_common, 0},
  67452.    {"inhibit-size-directive", &flag_inhibit_size_directive, 1},
  67453. @@ -1905,6 +1918,9 @@ output_file_directive (asm_file, input_n
  67454.       FILE *asm_file;
  67455.       char *input_name;
  67456.  {
  67457. +#ifdef FILE_NAME_NONDIRECTORY
  67458. +  char *na = FILE_NAME_NONDIRECTORY (input_name);
  67459. +#else
  67460.    int len = strlen (input_name);
  67461.    char *na = input_name + len;
  67462.  
  67463. @@ -1915,6 +1931,7 @@ output_file_directive (asm_file, input_n
  67464.      break;
  67465.        na--;
  67466.      }
  67467. +#endif
  67468.  
  67469.  #ifdef ASM_OUTPUT_MAIN_SOURCE_FILENAME
  67470.    ASM_OUTPUT_MAIN_SOURCE_FILENAME (asm_file, na);
  67471. @@ -3310,6 +3327,9 @@ main (argc, argv, envp)
  67472.  #ifdef DIR_SEPARATOR
  67473.       && p[-1] != DIR_SEPARATOR
  67474.  #endif
  67475. +#ifdef VOL_SEPARATOR
  67476. +     && p[-1] != VOL_SEPARATOR
  67477. +#endif
  67478.       )
  67479.      --p;
  67480.    progname = p;
  67481. @@ -3326,6 +3346,15 @@ main (argc, argv, envp)
  67482.    }
  67483.  #endif /* RLIMIT_STACK */
  67484.  
  67485. +#ifdef __amigaos__
  67486. +  {
  67487. +    char *envstr;
  67488. +
  67489. +    if (envstr = getenv("GCCPRIORITY"))
  67490. +      if (((i = atoi(envstr)) > -20) && (i < 20)) amiga_priority = i;
  67491. +  }
  67492. +#endif /* __amigaos__ */
  67493. +
  67494.    signal (SIGFPE, float_signal);
  67495.  
  67496.  #ifdef SIGPIPE
  67497. @@ -3571,6 +3600,19 @@ main (argc, argv, envp)
  67498.          pedantic = 1;
  67499.        else if (!strcmp (str, "pedantic-errors"))
  67500.          flag_pedantic_errors = pedantic = 1;
  67501. +#ifdef __amigaos__
  67502. +      else if (!strcmp (str, "priority"))
  67503. +        {
  67504. +          char *p = str + 1;
  67505. +
  67506. +          if (*p)
  67507. +        amiga_priority = atoi (p);
  67508. +              if (amiga_priority < -25)
  67509. +            amiga_priority = -25;
  67510. +              else if (amiga_priority > 25)
  67511. +            amiga_priority = 25;
  67512. +        }
  67513. +#endif /* __amigaos__ */
  67514.        else if (!strcmp (str, "quiet"))
  67515.          quiet_flag = 1;
  67516.        else if (!strcmp (str, "version"))
  67517. @@ -3821,6 +3863,13 @@ You Lose!  You must define PREFERRED_DEB
  67518.      filename = argv[i];
  67519.      }
  67520.  
  67521. +#ifdef __amigaos__
  67522. +  Forbid();
  67523. +  amiga_task = FindTask(NULL);
  67524. +  Permit();
  67525. +  SetTaskPri(amiga_task, amiga_priority);
  67526. +#endif /* __amigaos__ */
  67527. +
  67528.    /* Initialize for bytecode output.  A good idea to do this as soon as
  67529.       possible after the "-f" options have been parsed. */
  67530.    if (output_bytecode)
  67531. @@ -3907,7 +3956,7 @@ You Lose!  You must define PREFERRED_DEB
  67532.  
  67533.    compile_file (filename);
  67534.  
  67535. -#if !defined(OS2) && !defined(VMS) && !defined(_WIN32)
  67536. +#if !defined(OS2) && !defined(VMS) && !defined(_WIN32) && !defined (__amigaos__)
  67537.    if (flag_print_mem)
  67538.      {
  67539.        char *lim = (char *) sbrk (0);
  67540. @@ -3922,7 +3971,7 @@ You Lose!  You must define PREFERRED_DEB
  67541.        system ("ps v");
  67542.  #endif /* not USG */
  67543.      }
  67544. -#endif /* not OS2 and not VMS and not _WIN32 */
  67545. +#endif /* not OS2 and not VMS and not _WIN32 and not __amigaos__ */
  67546.  
  67547.    if (errorcount)
  67548.      exit (FATAL_EXIT_CODE);
  67549.