diff options
Diffstat (limited to 'gcc/ChangeLog.9')
-rw-r--r-- | gcc/ChangeLog.9 | 9968 |
1 files changed, 9968 insertions, 0 deletions
diff --git a/gcc/ChangeLog.9 b/gcc/ChangeLog.9 new file mode 100644 index 0000000..9cd8cdf --- /dev/null +++ b/gcc/ChangeLog.9 @@ -0,0 +1,9968 @@ +Tue Feb 28 16:36:58 1995 Michael Meissner <meissner@cygnus.com> + + * rs6000/eabi.asm (__eabi): Correctly reload r30 in the case where + the GOT pointers have to be relocated. + + * rs6000/rs6000.md (floatsidf2, floatunssidf2): Add + TARGET_SOFT_FLOAT conditional dropped in the last change. + (movdf insns): Add -msoft-float varients that do not use 'f' register + constraints. + (movti): On PowerPC, don't clobber the MQ register, since it doesn't + exist. Add abort to default switch case. + (store_multiple, load_multiple): Test for TARGET_POWER instead + of !TARGET_POWERPC to determine whether the MQ register exists. + +Tue Feb 28 14:46:48 1995 Doug Evans <dje@cygnus.com> + + * configure (extra_headers): Renamed from header_files. + + * toplev.c (rest_of_compilation): Defer output of static inlines + even if not optimizing, they may never be referenced. + +Mon Feb 27 17:06:47 1995 Doug Evans <dje@cygnus.com> + + * cccp.c (do_include): Check for redundant file before opening in + relative path case. Don't call fstat unnecessarily. + +Mon Feb 27 11:20:29 1995 Jim Wilson <wilson@chestnut.cygnus.com> + + * mips.md (muldi3_internal): Change dmul to dmult. + +Mon Feb 27 02:30:54 1995 Jeffrey A. Law <law@mole.gnu.ai.mit.edu> + + * pa.c (hppa_expand_prologue): Don't save the PIC register into + the stack for functions which have no stack of their own. + +Mon Feb 27 00:43:32 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/gnu.h (ASM_SPEC): Macro removed. + +Sun Feb 26 20:21:52 1995 Doug Evans <dje@cygnus.com> + + * reload.c (find_reloads_address): Fix typo in reg+const case. + +Sat Feb 25 10:21:13 1995 Doug Evans <dje@cygnus.com> + + * gcc.c (print_search_dirs): New variable. + (build_search_list): New function. + (putenv_from_prefixes): Call it. + (option_map): New option --print-search-dirs. + (process_command): Handle it. + (main): Print installation directory and exec/startfile_prefixes if + --print-search-dirs given. + + * Makefile.in (Makefile): Delete config.run afterwards. + (distclean): Delete config.run. + +Sat Feb 25 08:36:40 1995 David Mosberger-Tang (davidm@cs.arizona.edu) + + * alpha.h (ASM_SPEC): Pass -pg to assembler. + (FUNCTION_PROFILER): Do nothing; the assembler does it for us. + +Sat Feb 25 08:24:27 1995 H.J. Lu (hjl@nynexst.com) + + * configure (native_prefix): New; lets some hosts put + files in /usr instead of /usr/local if no --prefix specified. + +Sat Feb 25 08:07:56 1995 David Edelsohn <edelsohn@mhpcc.edu> + + * rs6000.h (RTX_COSTS): Add cost of FFS. + +Sat Feb 25 06:52:22 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * mips.c (mips_fill_delay_slot): Fix typo in call to FP_REG_P. + + * cse.c (simplify_unary_operation): If operand mode is VOIDmode + for UNSIGNED_FLOAT and operand looks negative, can't simplify. + + * rs6000.c (low_32_bit_operand): New function. + * rs6000.h (PREDICATE_CODES): Add low_32_bit_operand. + * rs6000.md: Remove unneeded tests on HOST_BITS_PER_INT from + some extra conditions. + Use low_32_bit_operand for (plus:DI (zero_extend:DI ..) ..) cases. + +Sat Feb 25 00:49:29 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/xm-gnu.h (POSIX): Define this macro. + + * config/gnu.h (GNU_CPP_PREDEFINES): Add missing backslash. + +Fri Feb 24 19:17:29 1995 Jeffrey A. Law <law@snake.cs.utah.edu> + + * configure (hppa1.?-hp-hpux9*): Use hpux9 configuration files. + * pa-hpux9.h, pa-ghpux9.h, pa1-hpux9.h, pa1-ghpux9.h: New + configuration files. + +Fri Feb 24 15:55:33 1995 Jim Wilson <wilson@cygnus.com> + + * reorg.c (relax_delay_slots): When searching for next CODE_LABEL, + use next_real_insn not next_active_insn. + + * stdarg.h, va-*.h, varargs.h (va_end): Expand to a void expression + instead of nothing. + + * sh.h (PACKSTRUCT_BIT, TARGET_PACKSTRUCT): Change to PADSTRUCT. + Add comment saying that the option is not useful. + (TARGET_SWITCHES): Change -mpackstruct option to -mpadstruct. + (STRUCTURE_SIZE_BOUNDARY): Change PACKSTRUCT to PADSTRUCT changing + default value from 32 to 8. + + * dwarfout.c (PUSHSECTION_FORMAT): Add a leading tab. + + * expr.c (expand_expr, case COMPONENT_REF): Don't fetch unaligned + field if we only want its address. + + * i960.c (fp_literal_one, fp_literal_zero): Don't accept VOIDmode. + (i960_output_ldconst): In DFmode code, delete code to handle FP_REG_P + target. In DFmode and SFmode code, delete test for HOST_FLOAT_FORMAT + == TARGET_FLOAT_FORMAT. + * i960.h (REAL_ARITHMETIC): Define. + (LEGITIMATE_CONSTANT_P): Pass argument mode not VOIDmode to fp_literal. + + * i960.h (CC1_SPEC): Don't output implicit -gstabs or -gcoff option + if user gave an explicit one. + * vx960-coff.h (CC1_SPEC): Likewise. + + * dbxout.c (GDB_INV_REF_REGPARM_STABS_LETTER): New macro. + (dbxout_parms): For gdb, output use GDB_INV_REF_REGPARM_STABS_LETTER + for parameters passed by invisible reference in registers. + + * mips.c (mips_secondary_reload_class): Also handle SUBREGs. + * mips.md (madsi): Don't use '+' constraint in a clobber. + (madsi_highpart, umadsi_highpart): Delete. + + * dbxout.c (dbxout_parms): For parameters passed in memory, delete + obsolete code to handle parameters converted and stored back to + the stack slot where they were passed in. + (dbxout_reg_parms): Delete obsolete ifdefed out code. Combine + redundant PARM_PASSED_IN_MEMORY tests. For case where parameter + lives in memory, output stab if it doesn't live where it was passed. + + * sh.c: Correct typos and formatting problems. + (add_constant, current_function_pretend_args_size, + flag_traditional, table_lab): Delete unnecessary declarations. + (sh_cpu): Change type from attr_cpu to processor_type. + (need_slot, output_shift, lshiftrt_insns, howshift, + pop_operand): Delete. + (print_operand, output_branch): Delete calls to need_slot. + (synth_constant): Comment that it doesn't work. + (output_movedouble): Handle PRE_DEC dest not POST_INC dest. + (output_options): Don't use flag_traditional. + (shift_insns): Correct numbers to optimal sequences. + (shift_amounts): New table. + (shift_insns_rtx): New function. + (shiftinsns): Combine LSHIFTRT and ASHIFT cases. + (shiftcosts): Return true costs of shifts instead of estimate of 1. + (gen_ashift): Handle negative shift amounts. Call gen_lshrsi3_m + for single bit LSHIFTRT, and gen_lshrisi3_k for multiple bit shifts. + (gen_shifty_op): Handle negative shift amounts at top. Generate + optimal sequences for ASHIFT and LSHIFTRT. + (find_barrier): Correct pattern for matching mova instructions. + (general_movsrc_operand): Delete redundant test for (MEM LABEL_REF). + Don't reject POST_INC address for size > 4. + (general_movdst_operand): Don't reject PRE_DEC address for size > 4. + * sh.h: Correct typos and formatting problems. + (MODE_DISP_OK_[12]): Delete. + (GO_IF_LEGITIMATE_INDEX): Delete uses of MODE_DISP_OK_[12]. + (RTX_COSTS): Add LSHIFTRT. + (table_lab): Delete declaration. + (enum processor_type): New enum. + (sh_cpu_attr): New macro. + (sh_cpu): Change type to enum processor_type to avoid incomplete + enum type. + * sh.md: Correct typos and formatting problems. + (cpu): Use sh_cpu_attr not sh_cpu. + (adddi3, subdi3, udivsi3-1, divsi3-1, mulsi3_call-1, ashrsi2_16, + ashrsi2_31, dect, casesi_worker): Use arith_reg_operand not + register_operand. + (ashlsi3_n, lshrsi3_n): Enable pattern. Set length correctly. + Use '#' to output it. + (ashlsi3_n+1, lshrsi3_n+1): New patterns to split shifts. + (ashlsi3, lshrsi3): Use shiftby_operand instead of gen_shifty_op. + (lshlsi3_m): New pattern for single bit shifts. + (lshlsi3_k): Only handle multiple bit shifts. + (negc): Use IOR not PLUS to set carry bit. + (push+2, pop+2, movsi_pi, movdi-2, movdf_k-1, movsf_i-1): Delete. + (movsi_i, movqi_i, movhi_i): Delete redundant < and > constraints. + (movsf_i): Delete incorrect < and > constraints. + +Fri Feb 24 13:07:55 1995 Stephen L Moshier <moshier@world.std.com> + + * i386/i386.md (sinxf2, cosxf2): Define. + +Thu Feb 23 14:14:20 1995 Mike Stump <mrs@cygnus.com> + + * rs6000.h/rs6000.h (RETURN_ADDR_RTX): Add definition to support + __builtin_return_address and __builtin_frame_address on the + rs6000. This is necessary to support exception handling in g++ on + the rs6000. + +Thu Feb 23 15:23:26 1995 Michael Meissner <meissner@cygnus.com> + + * rs6000/rs6000.h (TARGET_SWITCHES): All -mpower switches set + -mmultiple by default. Rename -mno-fp-regs to -msoft-float and + -mfp-regs to -mhard-float. + (TARGET_NO_FPR): Rename all occurances of macro to be either + TARGET_HARD_FLOAT or TARGET_SOFT_FLOAT. + (FUNCTION_VALUE): If -msoft-float, floating point gets returned in + register 3. + (LIBCALL_VALUE): Ditto. + (USE_FP_FOR_ARG_P): Don't use floating point registers if + -msoft-float. + (MOVE_MAX): Use TARGET_MUTIPLE instead of TARGET_POWER to decide + to move 16 bytes at a time. + (GO_IF_LEGITIMATE_ADDRESS): Don't allow index + base register + addresses for DF's if -msoft-float. + + * rs6000/rs6000.c (POWER_MASKS): Or in MASK_MULTIPLE. + (processor_target_table): Set MASK_MULTIPLE for Power CPUs and + don't set it for PowerPC CPUs. + (output_prolog): If -mrelocatable and a GOT pool is used, mark the link + register as being live. Load the GOT address via a bl instruction. + (output_toc): If V.4 semantics, make the TOC label be the difference + from the start of the TOC section, rather a label the assembler has to + recognize as being an offset. + + * rs6000/rs6000.md (all floating point ops): For all operations, + check if floating point is allowed. + (movti): Use TARGET_MULTIPLE to decide whether to expand movti + instead of TARGET_POWER. + + * rs6000/sysv4.h (SUBTARGET_SWITCHES): Move here from eabi.h, so the + various macro overrides don't have to be recoded for eabi as well + as System V.4. Add -mstrict-align to set STRICT_ALIGNMENT to 1. + Add -mrelocatable to specify that that the data/text sections may + be copied elsewhere, but not true V.4 style PIC. + (TOC_SECTION_FUNCTION): Handle TARGET_RELOCATABLE. + (TOC_SECTION_ASM_OP): Put quotes around ".got". + (MINIMAL_TOC_SECTION_ASM_OP): Put quotes around ".got1". + + * rs6000/eabi.h (SUBTARGET_SWITCHES): Move to rs6000/sysv4.h. + (MINIMAL_TOC_SECTION_ASM_OP): Use ".got2" section if + -mrelocatable. + + * rs6000/eabi.asm: New file to load up register 2 or relocate the .got2 + addresses. Called from main. + + * rs6000/t-rs6000: Build two libgcc.a's, one for normal use, and one + used when compiling with -msoft-float. + + * rs6000/t-eabi: New file, build two libgcc.a's, one for normal use, + and one used when compiling with -msoft-float. Add support for eabi + module to relocate the .GOT2 section to support -mmultiple. + + * configure (powerpc-*-eabi*): Use t-eabi, not t-rs6000. + +Thu Feb 23 06:58:46 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Makefile.in (ld): Add missing backslash to make continuation line. + + * i386/winnt.c (gen_stdcall_suffix): Deleted. + * winnt/winnt.h (MODIFY_ASSEMBLER_NAME): Deleted. + (VALID_MACHINE_DECL_ATTRIBUTES): Deleted. + * varasm.c (make_decl_rtl): Remove reference to MODIFY_ASSEMBLER_NAME. + + * alpha.h (RTX_COSTS): Update costs for FP operations. + +Thu Feb 23 00:13:05 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * c-typeck.c (build_binary_op): Warn if, in a comparison, a signed + operand that might be negative is converted to unsigned. + +Wed Feb 22 21:32:48 1995 Peter Schauer (Peter.Schauer@regent.e-technik.tu-muenchen.de) + + * config/svr4.h (DBX_OUTPUT_MAIN_SOURCE_FILE_END): New macro. + +Wed Feb 22 20:29:31 1995 J.T. Conklin <jtc@netbsd.org> + + * configure (*-*-netbsd*): Set tmake_file to t-libc-ok. + + * config/xm-netbsd.h, i386/xm-netbsd.h, m68k/xm-netbsd.h: New files. + * sparc/xm-netbsd.h: New file. + * ns32k/xm-netbsd.h: Changed to use config/xm-netbsd.h and + ns32k/xm-ns32k.h. + * configure (i386-*-netbsd*): Use i386/xm-netbsd.h. + (m68k-*-netbsd*): Use m68k/xm-netbsd.h. + (sparc-*-netbsd*): Use sparc/xm-netbsd.h. + + * cppp.c, collect2.c: Removed __NetBSD__ from conditional. + * collect2.c: Declare strerror if HAVE_STRERROR is defined; + otherwise declare sys_errlist and sys_nerr. + +Wed Feb 22 19:07:08 1995 Niklas Hallqvist (niklas@appli.se) + + * Makefile.in (libgcc1.a): Run ranlib. + +Wed Feb 22 18:46:50 1995 Yury Shevchuk (sizif@botik.yaroslavl.su) + + * explow.c (memory_address): Add missing "else". + +Wed Feb 22 15:29:58 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * collect2.c (libselect): New function for passing to scandir. + (libcompare): Ditto. + (locatelib): Use scandir to look for libraries with matching version + numbers. + +Wed Feb 22 18:27:14 1995 Paul Eggert <eggert@twinsun.com> + + * cccp.c (enum sharp_token_type): New type. + (stringify, raw_before, raw_after): Use this type instead of char. + (collect_expansion, dump_single_macro): Keep track of white space + after # and around ## tokens, since the C Standard requires a + diagnostic if the white space doesn't match during a redefinition. + (sharp_token, sharp_sharp_token): Labels renamed from hash_token and + hash_hash_token for naming consistency. + +Wed Feb 22 17:37:12 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * gcc.c (SWITCH_TAKES_ARG): Add `x'. + (process_command): -Wl, -Xlinker, and -lm values always go to + linker even if -x was specified. + +Wed Feb 22 09:33:36 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * fold-const.c (fold): Support folding CLEANUP_POINT_EXPRs into + arithmetic expressions. + +Wed Feb 22 08:40:30 1995 David Edelsohn <edelsohn@mhpcc.edu> + + * rs6000.c (print_operand, case 'H', 'S'): Delete unused. + + * rs6000.md (ffssi2): Use gpc_reg_operand predicate. + (Some maskir patterns): Likewise. + (ffsdi2): Likewise. + + * rs6000.md (movsfcc, movdfcc): New standard patterns. + (fselsfsf4, fseldfsf4, fseldfdf4, fselsfdf4): Name and create + variants of existing anonymous patterns for movsfcc and movdfcc. + +Wed Feb 22 08:10:36 1995 Philippe De Muyter (phdm@info.ucl.ac.be) + + * final.c (output_asm_name): New function, using code taken + from output_asm_insn. + (output_asm_insn): If flag_print_asm_name, print the comment + after the first assembler instruction even in multi-instruction + templates. + +Wed Feb 22 07:04:25 1995 Ian Lance Taylor (ian@cygnus.com) + + * real.c (REAL_WORDS_BIG_ENDIAN): New macro. Define as either + FLOAT_WORDS_BIG_ENDIAN or HOST_FLOAT_WORDS_BIG_ENDIAN. Use it + instead of FLOAT_WORDS_BIG_ENDIAN. + +Wed Feb 22 07:03:39 1995 Stephen L Moshier (moshier@world.std.com) + + * final.c (split_double): Handle CONST_INT that holds both words. + * i386.c (output_move_double): Let split_double extract any + constant in op 1; take size from op 0. + + * real.c (m16m, edivm, emulm): Change `short' to `EMUSHORT', and `long' + to `EMULONG'. + Clean up comments. + +Wed Feb 22 00:52:40 1995 Jeffrey A. Law <law@mole.gnu.ai.mit.edu> + + * pa.h (ASM_DECLARE_FUNCTION_NAME): Handle invisible reference + arguments passed in registers. + +Tue Feb 21 19:03:09 1995 Douglas Rupp (drupp@cs.washington.edu) + + * Makefile.in ($exeext, $objext, $oldobjext): New macros. + * Makefile.in: Copy config.status to config.run and then execute. + * configure, Makefile.in: Try a "cp" if "ln" fails. + * objc/Makefile: Added {} around file variable. + + * c-parse.in: New rules to allow attributes in a prefix position. + * c-tree.h (decl_attributes): Added argument. + * c-decl.c (grokdeclarator): Added code to support machine attributes. + * c-common.c (decl_attributes): Add third argument prefix_attributes. + (valid_machine_attribute): Deleted; moved to tree.c. + * tree.h (union tree_decl): New field MACHINE_ATTRIBUTES. + (DECL_MACHINE_ATTRIBUTES): New macro. + * c-decl.c (duplicate_decls): Pass DECL_MACHINE_ATTRIBUTES to + descendent typedef; make duplicate typedefs that are identical + generate a warning if they are both in system header files. + (redeclaration_error_message): Make duplicate typedefs that + are identical not an error if they are both in system header files. + * print-tree.c (print_node{,_brief}): Print machine attributes. + + * calls.c (emit_call_1): Added function declaration node argument + passed to RETURN_POPS_ARGS; also effects calls to emit_call_1. + * function.c (assign_parms): Added arg to RETURN_POPS_ARGS. + * 1750a.h, a29k.h, alpha.h, arm.h, clipper.h, convex.h: Likewise. + * dsp16xx.h, elxsi.h, fx80.h, gmicro.h, h8300.h, i370/mvs.h: Likewise. + * i386.h, i386/isc.h, i386/next.h, i386/sco.h: Likewise. + * i386/scodbx.h, i860.h, i960.h, m68k.h, m88k.h, mips.h: Likewise. + * ns32k.h, pa.h, pdp11.h, pyr.h, romp.h, rs6000.h, sh.h: Likewise. + * sparc.h, spur.h, tahoe.h, vax.h, we32k.h: Likewise. + + * cccp.c (main): Don't set "Include" environment variable for NT. + * protoize.c: Added #ifdef's WINNT. + * toplev.c (get_run_time): Return an approximate value for NT. + * gbl-ctors.h, libgcc2.c (atexit): Prototype now works with NT. + * gcc.c (fix_argv): Rewrite. + + * i386/winnt.c: New file + * winnt/ld.c (expand_lib): Look for both libfoo.a and foo.lib. + Modified to support linking with Windows NT graphics libraries. + * i386/winnt.h, x-winnt: Support NT Graphics programs; also bug fixes. + * winnt/winnt.h (CPP_SPEC): Accept c++ style comments. + * winnt/xm-winnt.h: Reflect features/functions available in NT. + + * fixinc.winnt: New file. + * configure (i[345]86-*-winnt): Add fixincludes and extra_objs. + * config-nt.bat: Deleted. + * configure.bat: Take arg specifying msdos or winnt batch file config. + * i386/config-nt.{bat,sed}: Updated to Windows NT 3.5. + + * ginclude/stdarg.h, ginclude/varasgs.h: Test _VA_LIST_DEFINED macro. + * ginclude/stddef.h: Test _SIZE_T_DEFINED and _WCHAR_T_DEFINED. + * ginclude/varargs.h: Modifed to work with Windows NT. Needed a + _VA_LIST_DEFINED macro. + + * tree.c: (chain_member_value, decl_attribute_variant): New functions. + (valid_machine_attribute): Moved here from c-common.c. + + * varasm.c (make_decl_rtl): Call MODIFY_ASSEMBLER_NAME if defined. + +Tue Feb 21 12:40:05 1995 Jeffrey A. Law <law@snake.cs.utah.edu> + + * local-alloc.c (block_alloc): Stop looping over the input + operands once we find an input/output register pair which can + be combined into a single qty. + + * integrate.c (finish_inline): Don't set DECL_INLINE. + +Tue Feb 21 10:19:51 1995 Michael Meissner <meissner@cygnus.com> + + * toplev.c (lang_options): Move fortran switches here, fixing bad + patch. + +Tue Feb 21 07:30:11 1995 Stephen L Moshier (moshier@world.std.com) + + * rs6000.c (output_toc): Use REAL_VALUE_* macros. + * rs6000.h (REAL_ARITHMETIC): Define. + +Tue Feb 21 06:48:41 1995 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * stmt.c (expand_value_return): Make function static. + +Tue Feb 21 06:42:33 1995 Paul Eggert <eggert@twinsun.com> + + Add support for ISO Normative Addendum 1 to the C Standard. + * ginclude/iso646.h: New file. + * Makefile.in (USER_H): Add iso646.h. + * c-lex.c (yylex): Add support for <: :> <% %> digraphs. + * cccp.c (rescan): Add support for %: and %:%: digraphs. + (collect_expansion, skip_if_group, dump_single_macro): Likewise. + (union hashval): Remove ival member; it doesn't suffice for `199409L'. + (special_symbol): Use cpval instead of ival for T_CONST macros. + (install): Remove ivalue argument, since string value now suffices. + All callers changed. + (initialize_builtins): Switch from int to string values for T_CONST. + If not traditional, initialize __STDC_VERSION__ to 199409L. + (STDC_VALUE): Remove no-longer-used configuration macro. + +Tue Feb 21 06:16:37 1995 Franz Korntner (fkorntne@bazis.nl) + + * gcc.c (read_specs): Use length read when inserting zero. + + * c-lex.c (yylex): For float, build constant in long double. + +Tue Feb 21 05:57:42 1995 Craig Burley (burley@gnu.ai.mit.edu) + + * toplev.c (lang_options): Add options for Fortran. + + * gcc.c (default_compilers): Add entries for .f and .F. + +Tue Feb 21 05:37:21 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * gcc.c (default_compilers): Remove rule for ".ada". + Pass .ads or .adb suffix to -dumpbase, depending on input filename. + + * toplev.c (compile_file): Initialize input_file_stack before + calling lang_init, not after. + * c-lex.c (check_newline): Give warning if unrecognized data on #line. + (yylex): Give error for unterminated string constant. + +Mon Feb 20 14:46:56 1995 Per Bothner <bothner@kalessin.cygnus.com> + + * varasm.c (output_constant): Strip NOP_EXPRs for SET_TYPE too, + by using AGGREGATE_TYPE_P macro. + +Mon Feb 20 14:39:57 1995 Per Bothner <bothner@kalessin.cygnus.com> + + * config/svr4.h (ASM_OUTPUT_SOURCE_LINE): Use assemble_name. + +Mon Feb 20 15:26:05 1995 Doug Evans <dje@cygnus.com> + + * config.sub (sun4sol2): Alias for sparc-sun-solaris2. + +Sat Feb 18 16:15:33 1995 Mike Stump <mrs@cygnus.com> + + * libgcc2.c (__unwind_function): New function to support stack + unwinding on rs6000 for g++ exception handling. + +Sat Feb 18 13:55:02 1995 Per Bothner <bothner@kalessin.cygnus.com> + + * tree.h (get_set_constructor_bytes): Fix prototype. + * varasm.c (output_constructor): Fix typo byte_size -> size. + +Sat Feb 18 12:36:12 1995 Doug Evans <dje@cygnus.com> + + Lynx patches from various Cygnus people. + * config.sub: Recognize lynx* as lynxos. + * configure (i386-lynx): Set xm_file to i386/xm-lynx.h + Set tmake_file to i386/t-i386bare. + (m68k-lynx): Set xm_file to m68k/xm-lynx.h. + Set tmake_file to m68k/t-lynx. + (rs6000-lynxos*): New target. + (sparc-lynxos*): Set xm_file to sparc/xm-lynx.h. + Set tmake_file to sparc/t-sunos41. + * config/lynx.h (LIB_SPEC, STARTFILE_SPEC): Update to LynxOS 2.2.2. + (FUNCTION_PROFILE): Undef. + * config/xm-lynx.h (HOST_BITS_PER_CHAR): Delete. + (HOST_BITS_PER_{SHORT,INT,LONG,LONGLONG}): Likewise. + (mktemp): Provide our own, lynx's definition isn't standard. + * i386/t-i386bare (LIBGCC1): Define to empty instead of libgcc1.null. + (CROSS_LIBGCC1): Likewise. + * i386/xm-lynx.h: New file. + * m68k/lynx.h (FUNCTION_VALUE): Redefine. + (LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P, NEEDS_UNTYPED_CALL): Likewise. + * m68k/t-lynx: New file. + * m68k/xm-lynx.h: New file. + * rs6000/lynx.h: New file. + * rs6000/rs6000.h (SUBTARGET_OVERRIDE_OPTIONS): Define. + (OVERRIDE_OPTIONS): Call it. + * rs6000/x-lynx: New file. + * rs6000/xm-lynx.h: New file. + * sparc/xm-lynx.h: New file. + +Thu Feb 16 17:02:51 1995 Ian Lance Taylor <ian@cygnus.com> + + * config/mips/mips.h (enum processor_type): Add PROCESSOR_R4650. + * config/mips/mips.c (override_options): Use PROCESSOR_R4650 for + the 4650, not PROCESSOR_R4600. Check for it when doublechecking + mips_isa level. + * config/mips/mips.md: Add r4650 to cpu attr. Update functional + units for r4650. + (mulsi3): If TARGET_MAD, generate mulsi3_r4650. + (mulsi3_r4650): New instruction, mul directly to register file, + supported on r4650. + +Thu Feb 16 11:44:51 1995 Michael Meissner <meissner@cygnus.com> + + * rs6000/eabi.h (SUBTARGET_SWITCHES): Add support for + -mstrict-align to control whether STRICT_ALIGNMENT is 1 or 0. + (STRICT_ALIGNMENT): Redefine, to be 1 if -mstrict-align used. + +Wed Feb 15 13:03:38 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * libgcc2.c: Repair botch in application of patch. + +Tue Feb 14 16:00:52 1995 Per Bothner <bothner@kalessin.cygnus.com> + + * tree.c (get_set_constructor_bytes): New function. Replaces ... + (get_set_constructor_words): ... removed old function. + * tree.h: get_set_constructor_words -> get_set_constructor_bytes. + * expr.c (store_constructor): Don't use get_set_constructor_words. + * varasm.c (const_hash): Add support for SET_TYPE constructors. + (record_constant_1): Likewise. + (copy_constant): Likewise. + (output_constant): Likewise. (Also SET_TYPE INTEGER_CSTs.) + +Tue Feb 14 08:05:07 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tree.c (stabilize_reference_1): No longer static. + * tree.h (stabilize_reference_1): Add declaration. + +Mon Feb 13 19:37:15 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/mips/gnu.h: Rewritten to use ELF object format. + * config/gnu.h (GNU_CPP_PREDEFINES): New macro. + * config/i386/gnu.h (CPP_PREDEFINES): Use GNU_CPP_PREDEFINES macro. + * config/i386/gnuelf.h: Likewise. + +Mon Feb 13 14:06:04 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * libgcc2.c (__default_new_handler): Don't call write if + inhibit_libc is defined. + (__pure_virtual): Ditto. + +Mon Feb 13 16:42:38 1995 Doug Evans <dje@cygnus.com> + + * a29k/a29k-udi.h (DBX_DEBUGGING_INFO): Define. + (PREFERRED_DEBUGGING_TYPE): Define. + + * expmed.c (store_split_bit_field): If value is VOIDmode, + pass word_mode to force_reg. + + * varasm.c (function_section): New function. + (assemble_start_function): Call it. + * output.h (function_section): Declare it. + * final.c (final_scan_insn): Call function_section instead of + text_section. + * dwarfout.c (dwarfout_begin_block): Likewise. + (dwarfout_end_block): Likewise. + (dwarfout_label): Likewise. + (dwarfout_begin_function): Likewise. + (dwarfout_end_function): Likewise. + (dwarfout_line): Likewise. + + * flow.c (find_basic_blocks): Revise calculation of when to + make another pass. + + * libgcc2.c (exit): Don't call __do_global_dtors if + INIT_SECTION_ASM_OP and OBJECT_FORMAT_ELF. + + * Makefile.in (libgcc1.S): New target. + +Mon Feb 13 12:45:11 1995 Per Bothner <bothner@kalessin.cygnus.com> + + * tree.c (permanent_allocation): Pop function_maybepermanent_obstack, + not hardwired &maybepermanent_obstack. + +Mon Feb 13 12:10:31 1995 J.T. Conklin <jtc@netbsd.org> + + * config/netbsd.h: Changed so that macro definitions used when gcc + is integrated into the NetBSD source tree are not defined unless + NETBSD_NATIVE is defined too. + + * configure (*-netbsd-*): Rename netbsd config files so that they don't + have the machine type in them. + * i386/netbsd.h: Renamed from i386/netbsd-i386.h. + * m68k/netbsd.h: Renamed from m68k/netbsd-m68k.h. + * ns32k/netbsd.h: Renamed from ns32k/netbsd32k.h. + +Mon Feb 13 15:05:09 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * collect2.c (main): Remember all the .o files specified on the + command line, and scan them directly if COLLECT_SCAN_OBJECTS. + * rs6000/rs6000.h (COLLECT_SCAN_OBJECTS): Define. + + * stmt.c (warn_if_unused_value): Don't warn about dereferenced + references. + +Mon Feb 13 14:00:51 1995 Jim Wilson <wilson@mole.gnu.ai.mit.edu> + + * m68k.h (RTX_COSTS): Fix typo from last change. + + * reload1.c (last_spill_reg): Move definition to top of file. + Don't initialize here. + (reload): Intialize here to -1. + +Mon Feb 13 09:29:49 1995 Paul Eggert <eggert@twinsun.com> + + * fixinc.svr4 (longlong_t, u_longlong_t): + Work around bug in Solaris 2.4 <sys/types.h>. + +Mon Feb 13 08:31:18 1995 David Edelsohn <edelsohn@mhpcc.edu> + + * rs6000.h, powerpc.h (CPP_SPEC): Define _POSIX_SOURCE if -posix. + + * rs6000.md (extendsfdf2): Undo 30 Nov 94 change. Use float_extend + instead of SUBREG and restore fmr instruction for differing FPRs. + +Mon Feb 13 05:25:09 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * convert.c (convert_to_{pointer,real,integer,complex}): + Handle references. + +Mon Feb 13 08:14:10 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-parse.in (ALIGN): Remove unused token. + + * loop.c (mark_loop_jump): Remove bogus assignments to LABEL_ + fields in default case. + +Mon Feb 13 07:55:30 1995 Torbjorn Granlund (tege@tiny.cygnus.com) + + * a29k.h (TARGET_MULTM): New #define. + (TARGET_SWITCHES): Recognize "-mno-multm". + * a29k.md (smulsi3_highpart, umulsi3_highpart, mulsidi3, umulsidi3): + Make these conditional on TARGET_MULTM. + + * a29k.md (multm matcher): Delete. + (multmu matcher): Delete. + (mulsidi3 DEFINE_SPLIT): Generate RTL for smulsi3_highpart instead of + for deleted pattern. Fix typo in preparation code. + (umulsidi3 DEFINE_SPLIT): Analogous change. + +Mon Feb 13 07:09:02 1995 Peter Flass (FLASS@LBDRSCS.BITNET) + + * i370/mvs.h (ASM_OUTPUT_ASCII): Don't duplicate first char. + +Mon Feb 13 06:51:07 1995 Samuel A. Figueroa (figueroa@CS.NYU.EDU) + + * i386/os2.h (OBJECT_SUFFIX): New macro. + (LIB_SPEC, STARTFILE_SPEC): Adjust to include better set of libs. + + * i386/xm-os2.h (DIR_SEPARATOR): Define if not already. + (strcasecmp): New definition. + + * toplev.c (main): Look at DIR_SEPARATOR for finding last component. + * cccp.c (do_include, is_system_include, open_include_file): + Handle DIR_SEPARATOR. + +Sun Feb 12 20:20:28 1995 Brendan Kehoe (brendan@lisa.cygnus.com) + + * config/sparc/sysv4.h (ASM_OUTPUT_SECTION_NAME): Check to make + sure DECL is non-null before trying to reference it. + * config/mips/elf64.h (ASM_OUTPUT_SECTION_NAME): Likewise. + +Sun Feb 12 19:55:45 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * calls.c (expand_call): Add missing paren in last change. + +Sat Feb 11 18:09:27 1995 Jim Wilson <wilson@cygnus.com> + + * libgcc2.c (L_fixunsxfsi, L_fixunsdfsi, L_fixunssfsi): Undef + normal types before including limits.h. + + * calls.c (expand_call): When setting n_named_args, depend on new + macro STRICT_ARGUMENT_NAMING. + + * expr.c (expand_builtin, case BUILT_IN_NEXT_ARG): Don't warn when + no argument if this is a varargs routine. + +Sat Feb 11 16:08:13 1995 Samuel A. Figueroa (figueroa@CS.NYU.EDU) + + * gcc.c (specs): Use %O instead of "o" for object file suffix. + (do_spec_1, case 'O'): New option. + +Sat Feb 11 14:58:19 1995 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k/mot3300.h (RETURN_IN_MEMORY): Fix error in last change. + +Sat Feb 11 13:09:28 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cexp.y (%union): Delete VOIDVAL and SVAL; unused. + + * c-decl.c (grokdeclarator): Use NAME, not IDENTIFIER_POINTER + of DECLARATOR for error messages; DECLARATOR might be null. + + * expmed.c (expand_divmod): Always call expand_twoval_binop with + psuedos as targets. + +Fri Feb 10 14:55:05 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * caller-save.c: Replace MAX_UNITS_PER_WORD with MIN_UNITS_PER_WORD. + * h8300.h, mips.h, rs6000.h, sparc.h: Likewise. + + * alpha.c (direct_return): Can't if have outgoing args. + + * expr.c (store_constructor, ARRAY_TYPE): Use code for + non-integer INDEX for non-integer ELTTYPE size. + Allow INDEX to be zero in code and divide size by BITS_PER_UNIT. + + * fold-const.c (fold): Don't modify tree with newly-allocated + nodes; instead make new tree in those cases. + +Wed Feb 8 15:13:49 1995 Doug Evans <dje@cygnus.com> + + * sparc/sparc.c (v9_regcmp_p): New function. + (v9_regcmp_op): Call it. + * sparc/sparc.md (movsicc): New pattern. + (movdicc, movsfcc, movdfcc, movtfcc): Likewise. + + * sparc/sparc.c (sparc64_initialize_trampoline): Use gen_flush + instead of knowing what pattern looks like. + + * sparc/sparc.md (nonlocal_goto): Use Pmode instead of SImode. + +Wed Feb 8 10:05:11 1995 David J. MacKenzie <djm@geech.gnu.ai.mit.edu> + + * config.sub: Add a blank in the #! line for 4.2BSD, Dynix, etc. + +Wed Feb 8 02:52:21 1995 Jeffrey A. Law <law@mole.gnu.ai.mit.edu> + + * pa.md (call, call_value): Emit save of the PIC register + with "emit_insn" before emitting the call insn itself. + +Tue Feb 7 15:19:40 1995 Jim Wilson <wilson@cygnus.com> + + * sh.c (prepare_scc_operands, from_compare): Force constant 0 into + register for unsigned comparisons. + + * sh.c: Correct errors in comments. + (calc_live_regs, expand_acall): Delete TARGET_SMALLCALL support. + (need_slot): Add comment. Delete test of INSN_ANNULLED_BRANCH_P. + (print_operand_address): Delete '*', '^', '!' support. + (synth_constant): Call zero_extend* instead of and*. Call ashlsi3_k + instead of ashlsi3_n. + (prepare_scc_operands): Abort for NE case. + (output_move_double, output_far_jump, output_branch): Delete commented + out code. Don't output assembler comments. + (gen_ashift): Don't call addsi3. + (fixit): Delete redundant test for QImode constants. + (hi_const): Delete TARGET_SHORTADDR support. + (find_barrier): Don't put constant pool between mova and its label. + (add_function, seen_function, bsr_operand, mac_operand, + fake_shift): Delete. + (sh_expand_prologue, expand_acall): Delete TARGET_BSR support. + (general_movsrc_operand): Don't reject non-I CONST_INT. + * sh.h: Correct errors in comments. + (CONDITIONAL_REGISTER_USAGE): Delete TARGET_NOSAVE support. + (TARGET_MAC, TARGET_TRYR0, TARGET_NOSAVE, TARGET_SMALLCALL, + TARGET_PARANOID, TARGET_RETR2, TARGET_SHORTADDR, TARGET_BSR): Delete. + (TARGET_SWITCHES): Delete above options. + (OVERRIDE_OPTIONS): Delete TARGET_BSR support. + (FUNCTION_BOUNDARY): Use 32 bit alignment when not TARGET_SMALLCODE. + (FIRST_RET_REG): Delete TARGET_RETR2 support. + (MODE_DISP_OK_[21]): Delete TARGET_TRYR0 support. + (EXTRA_CONSTRAINT_U): Delete. + (CONST_COSTS): For logical operations, give L constants cost 1. + (PRINT_OPERAND_PUNCT_VALID_P): Delete '*', '^', '!'. + * sh.md: Correct errors in comments. Delete all assembler comments. + Delete commented out patterns. Delete all peepholes but two. + Delete all define_splits but one. Delete all `combiner' patterns. + (mpy): Correct multiply latencies. + (needs_delay_slot, hit_stack, interrupt_function, in_delay_slot, + define_delay): Correct and/or simplify all reorg related definitions. + (addsi3_real): Delete. + (addsi3): Use arith_operand for argument 1. + (mulhisi3): Use arith_reg_operand not mac_operand. + (and_ffff, and_ff): Delete. + (andsi3): Handle constant 255 specially. + (rot*): Correct and/or simplify all rotate patterns. + (ashlsi3_k): Delete clobber of T bit. Output add for 1 bit shift. + (ashlsi3_n, lshrsi3_n): Delete use of fake_shift. + (negc): Correct pattern by adding set of T bit. + (extend*): Delete 'u' and 'U' constraint cases. + (pop): Separate 'l' and 'x' constraint cases. + (movsi-1): Better code for move to T bit case. + (bsr, bsr_value, mac): Delete. + +Tue Feb 7 14:23:52 1995 Doug Evans <dje@cygnus.com> + + * sparc/sparc.md (*): Give names to all anonymous patterns. + +Mon Feb 6 23:41:09 1995 Stephen L Moshier <moshier@world.std.com> + + * sparc/sysv4.h (ASM_OUTPUT_FLOAT, ASM_OUTPUT_DOUBLE): Remove + tests for host == target format and endianness. + +Mon Feb 6 16:52:38 1995 Torbjorn Granlund (tege@tiny.cygnus.com) + + * i386.h (RTX_COSTS): Rewrite. + + * m68k/lb1sf68.asm (__udivsi3, __divsi3, __umodsi3, __modsi3): + Rewrite to actually work for more than a few small operands, + and to be reasonably small. + (__mulsi3): Eliminate usage of link register (i.e. a6). + (shift patterns): Delete. + (__umulsi3): Delete. + * t-m68kbare (LIB1ASMFUNCS): Remove _umulsi3. + * t-vxworks68: Likewise. + +Mon Feb 6 15:22:39 1995 Jim Wilson <wilson@cygnus.com> + + * ginclude/va-i960.h (va_start): Add __builtin_next_arg call. + + * sh/sh.c (sh_function_arg): Don't reject unaligned structures. + (sh_function_arg_partial_nregs): Likewise. + + * sparc/sparc.md (movsf-1, movdf-1, movtf-1): Use 'F' not 'E'. + + * sparc/sol2.h (STARTFILE_SPEC): Delete explicit /usr/ccs/lib/ + pathnames. + + * reload1.c (alter_reg): New variable stack_slot. Apply anti + BYTES_BIG_ENDIAN correction to stack slot address stored in + spill_stack_slot. + + * jump.c (jump_optimize): When searching for a LOOP_END note to move, + stop if we find a LOOP_BEG note first. + +Mon Feb 6 15:03:35 1995 Doug Evans <dje@cygnus.com> + + * i386/sysv3.h (DBX_DEBUGGING_INFO): Define. + (PREFERRED_DEBUGGING_TYPE): Define. + +Mon Feb 6 11:56:14 1995 Jeffrey A. Law <law@mole.gnu.ai.mit.edu> + + * pa.md: Replace "misc" attribute with "multi" in recentlyadded + soft-float code. + + * pa-osf.h (TARGET_DEFAULT): Protect definition. + +Mon Feb 6 11:52:25 1995 Ian Lance Taylor <ian@cygnus.com> + + * fixincludes: When changing <assert.h> to include <stdio.h> or + <stdlib.h>, make it include them only for C++. + +Sun Feb 5 21:39:41 1995 Torbjorn Granlund <tege@cygnus.com> + + * pa.c (globally): Use GEN_INT. + (emit_move_sequence): Use expand_inc instead of plus_constant + (generates less rtl). + * pa.md (globally): Use GEN_INT. + + * pa.h (PREDICATE_CODES): Fix many errors. Enable. + + * m68k.h (RTX_COSTS): Add special cases for a plain 68000. + + * expmed.c (mul_cost, div_cost): New variables. + (mul_widen_cost, mul_highpart_cost): New variables. + (init_expmed): Init new variables. + (expand_mult_highpart): New argument, MAX_COST. + Use new argument in several places. Simplify code that tries + widening multiply variants. + (expand_divmod): New variables MAX_COST, EXTRA_COST. + Initialize MAX_COST dependent on REM_FLAG. + Calculate and pass cost in all calls of expand_mult_highpart. + +Sat Feb 4 13:19:29 1995 Jim Wilson <wilson@cygnus.com> + + * mips/abi64.h, mips/cross64.h, mips/iris6.h: New files. + * mips/iris5.h (TARGET_DEFAULT): Add #ifndef/#endif around define. + * mips/mips.c (mips_isa_string): Add mips4 to comment. + (large_int): Delete code for handling 64 bit constants. + (mips_const_double_ok): For irix6, reject all floating point constants. + (mips_move_2words): Use dli not li for 64 bit constants. + Use dla not la for 64 bit addresses. + (output_block_move): Likewise. + (function_arg): Add support for 64bit ABI. + (override_options): Add support for mips4 and R8000. + (print_operand): Handle new modifiers 'B', 'b', 'T', 't'. + Make 'X' case work for 64 bit host. + (mips_output_filename): Use ASM_OUTPUT_FILENAME. + (mips_asm_file_start): Go to text section for 64bit ABI. + (compure_frame_size, save_restore_insns, function_prologue, + mips_expand_prologue, function_epilogue): Add support for 64 bit ABI. + (type_dependent_reg, mips_function_value): New functions. + * mips/mips.h (__PTR_TO_INT, __INT_TO_PTR): Delete. + (enum processor_type): Add R8000. + (mips_isa_string, CC1_SPEC): Add mips4 to comment. + (CONDITIONAL_REGISTER_USAGE): Use SUBTARGET_CONDITIONAL_REGISTER_USAGE. + (SUBTARGET_CONDITIONAL_REGISTER_USAGE): New macro. + (ASM_SPEC, LINK_SPEC, CPP_SPEC): Add mips4 support. + (MIPS_TEMP[12]_REGNUM): Change to avoid clobbering 64bit abi + parameter registers. + (SMALL_INT, SMALL_INT_UNSIGNED, CONST_OK_FOR_LETTER_P): Fix for 64 + bit host. + (ABI_64BIT): New macro. + (REG_PARM_STACK_SPACE): Use UNITS_PER_WORD not 4. + (GO_IF_LEGITIMATE_ADDRESS, CONSTANT_ADDRESS_P, LEGITIMATE_CONSTANT, + LEGITIMIZE_ADDRESS): Don't allow CONST addresses for Irix6. + (ASM_OUTPUT_FILENAME): New macro. + (ASM_OUTPUT_ADDR_DIFF_ELT): Add 64 bit ABI support. + * mips/mips.md (type attribute): Add fmadd. + (cpu attribute): Add r8000. + (umaddi+1, ..., umadddi+8): Add pattern for multiply accumulate. + (movdi): Legitimize addresses, just like movsi does. + (loadgp): New pattern for 64 bit ABI. + (shift patterns): Use INTVAL instead of XINT for constants. + (jump, tablejump_interal[12]): Add 64 bit ABI support. + (movsicc-8, ..., movsicc): Add patterns for conditional moves. + * mips/t-cross64, mips/t-iris6, mips/x-iris6, mips/xm-iris6.h: + New files. + * configure: Add irix6 and irix5cross64 configurations. + * ginclude/va-mips.h (*): Change __mips==3 to __mips>=3. + (sgidefs.h): Include if _MIPS_SIM is defined. + (va_start): Add support for 64 bit ABI. + +Sat Feb 4 10:31:37 1995 Doug Evans <dje@cygnus.com> + + * dbxout.c (dbxout_source_file): Don't switch to text section if + in function with section attribute. Print Ltext label to correct + file (important on mips). + +Fri Feb 3 14:43:23 1995 Michael Meissner (meissner@cygnus.com) + + * rs6000/rs6000.md (call, call_value): If building for System V.4 + or eABI, function pointers are just pointers, not pointers to a + three word area. + +Thu Feb 2 15:50:26 1995 Ian Lance Taylor <ian@cygnus.com> + + * fixincludes: When fixing bool in <curses.h>, permit whitespace + before the semicolon. Needed on AIX 3.2.5. + +Thu Feb 2 12:06:12 1995 David Edelsohn <edelsohn@mhpcc.edu> + + * rs6000.md (smax:SF define_split): Change match_operand typo to + match_dup. + (smin:SF define_split): Likewise. + (smax:DF define_split): Likewise. + (smin:DF define_split): Likewise. + +Wed Feb 1 16:50:18 1995 Michael Meissner (meissner@cygnus.com) + + * config.sub: Add support for powerpc-*-{elf,svr4,eabi}. + * configure: Ditto. + + * rs6000/xm-sysv4.h: New file, to support building GCC for a + System V.4 PowerPC system. + * rs6000/sysv4.h: Ditto. + * rs6000/x-sysv4: Ditto. + + * rs6000/eabi.h: New file, to support building GCC for an embedded + PowerPC system. + + * rs6000/rs6000.h (TARGET_SWITCHES): Add -mmultiple, -mno-multiple + to control emitting load/store multiple instructions. On the + power, this is on by default, and on the powerpc it is off. + (SUBTARGET_SWITCHES): New macro, which defaults to nothing to + allow a subtarget to add new switches. + (SAVE_FP_*, RESTORE_FP_*): New macros that give the prefix and + suffix to use for the functions that save and restore the floating + point registers. + + * rs6000/rs6000.c (output_prolog): Use TARGET_MULTIPLE instead of + TARGET_POWER to control whether to emitt load/store multiple + instructions. Use the SAVE_FP_*/RESTORE_FP_* macros instead of + using the hardwired AIX names for the functions to save and + restore the floating point registers. + (output_epilog): Likewise. + (print_operand_address): Do not prepend a '.' for %z when using + the ELF object file format. + (svr4_traceback): New function to emit the word before the + procedure prologue that System V.4 expects to do tracebacks. + (output_prolog): Call svr4_traceback under ELF systems. + (output_epilog): Omit AIX style traceback tables for ELF systems. + (output_function_profiler): Abort for now in the ELF case. + + * rs6000/rs6000.md (load_multiple, store_multiple): Test against + TARGET_MULTIPLE instead of TARGET_POWER. + +Tue Jan 31 19:27:43 1995 Torbjorn Granlund <tege@cygnus.com> + + * pa.h (REAL_ARITHMETIC): Define. + (ASM_OUTPUT_DOUBLE): Rewrite. + (ASM_OUTPUT_FLOAT): Rewrite. + * pa.md (SF and DF move): Use constraint 'E' instead of 'F'. + * pa.c (singlemove_string): Make case with SFmode CONST_DOUBLE abort. + (print_operand): #ifdef out CONST_DOUBLE cases. + +Tue Jan 31 19:27:43 1995 Jim Wilson <wilson@chestnut.cygnus.com> + + * pa/pa.h (TARGET_SOFT_FLOAT): New macro. + (TARGET_SWITCHES, CPP_SPEC, CONDITIONAL_REGISTER_USAGE, FUNCTION_VALUE, + LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P, FUNCTION_ARG_REGNO_P, + FUNCTION_ARG, ASM_DECLARE_FUNCTION_NAME, GO_IF_LEGITIMATE_ADDRESS, + RTX_COSTS): Use TARGET_SOFT_FLOAT. + * pa/pa.md (*sf*, *df*, etc): Make all floating point patterns depend + on ! TARGET_SOFT_FLOAT. + (movsi, movdi, movsf, movdf): Add patterns for TARGET_SOFT_FLOAT. + +Tue Jan 31 15:53:04 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * toplev.c (lang_options): Add -f{no-,}check-new. + +Tue Jan 31 13:55:37 1995 Doug Evans <dje@cygnus.com> + + * mips/mips.h (ASM_DECLARE_FUNCTION_NAME): Ensure section is .text if + no section attribute. + * mips/elf64.h (ASM_OUTPUT_SECTION_NAME): Use asm_out_text_file for + functions. + +Tue Jan 31 13:26:42 1995 Ian Lance Taylor <ian@cygnus.com> + + * libgcc2.c: Include <limits.h>, not "glimits.h". + +Mon Jan 30 16:34:24 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * c-common.c (type_for_size): Try to match on int before other + types (which might be the same size). + (type_for_mode): Ditto. + +Sat Jan 28 16:28:15 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/sparc/sysv4.h (ASM_OUTPUT_SECTION_NAME): #undef before + defining. + +Sat Jan 28 13:54:23 1995 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.md (call, call_value): Always save the PIC register before + a call. + +Sat Jan 28 07:31:26 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-typeck.c (c_expand_return): Refine check for returning pointer + to local variable to allow subtracting a pointer from it. + + * calls.c (expand_call): When emitting queue for each arg, + call protect_from_queue; put in initial_value so EXPR_LIST in + is_const case won't have QUEUED. + +Sat Jan 28 04:36:46 1995 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.md (call_internal_reg): Use an even faster sequence for + TARGET_FAST_INDIRECT_CALLS. + (call_value_internal_reg): Likewise. + +Fri Jan 27 21:28:51 1995 Ronald F. Guilmette (rfg@segfault.us.com) + + * config.sub (unixware, svr4): Treat as synonyms for sysv4. + +Fri Jan 27 19:36:13 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/i386/gnuelf.h: New file. + +Fri Jan 27 16:55:05 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * libgcc1.c (perform_lshlsi3, __lshlsi3): Deleted. + * libgcc2.c (__lshldi3): Deleted. + * Makefile.in (LIB1FUNCS): Delete _lshlsi3. + (LIB2FUNCS): Delete _lshldi3. + + * expr.c (expand_expr, case MINUS_EXPR): Remove bogus operand swap. + + * optabs.c (expand_binop): Add missing test for VOIDmode + before calling convert_to_mode. + + * final.c (high_{block,function}_linenum): New variables. + (final_start_function): Initialize them. + (final_end_function): Pass highest line number to function end + debugging routines. + (final_scan_insn): Pass highest line number in block to block end + debugging function. + (output_source_line): Update highest line in block and function. + +Thu Jan 26 03:46:35 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * configure (i[345]86-*linux*): Set $extra_parts if $elf. + (*-*-gnu*): Likewise. + +Wed Jan 25 18:11:19 1995 Jim Wilson <wilson@cygnus.com> + + * sh.c (prepare_scc_operands): Force sh_compare_op1 to a register if + it is an invalid constant. + (output_branch): Add cases for 4, 8, and 18. Correct branch offsets + in comments. + (find_barrier): Correct test for move instructions that need to be + fixed by verifying that the set source is a bad constant. + (arith_reg_or_0_operand): New function. + * sh.h (CONST_OK_FOR_LETTER_P): Add case for 'N'. Correct comment. + (ADJUST_INSN_LENGTH, SHORTEN_WITH_AJUST_INSN_LENGTH): New macros. + * sh.md (define_attr type): Combine pcloadsi and pcloadhi into pcload. + (*): Likewise for all patterns that use them. + (define_attr length): Delete cases for pcloadsi and pcloadhi. + Modify branch offsets and lengths to be correct. Correct comment. + (*): Correct length attributes for all patterns. + (in_delay_slot): Delete maybe value. Change default case from yes to + no. Delete case for lengths of 4, 6, 8, 10, and 12. + (cmpeq_0, cmpeq_0-1, cmpeq_0-2): Delete patterns. + (cmpeqsi_t): Delete case with constant as first operand. + (cmpgtsi_t, cmpgesi_t): Use arith_reg_or_0_operand not arith_operand. + Put register cases first. + (cmpgeusi_t, cmpgtusi_t): Delete cases for comparing against zero. + (jump): Call output_far_jump if insn length >= 14 instead of == 14. + (casesi): Use arith_reg_operand not arith_operand for operand 2. + + * fixincludes (strings.h): Fix return type of strlen. + + * expr.c (expand_expr, case MIN_EXPR): If must emit multiple + instructions, then don't allow a MEM target. + +Wed Jan 25 17:07:47 1995 Pat Rankin (rankin@eql.caltech.edu) + + * cccp.c (do_include): For VMS, don't attempt to + treat `#include X' as `#include <X.h>' unless `X' has already been + macro expanded. + (main): For VMS, do a better job of picking out the base name from + argv[0]'s absolute name. + * vax/xm-vms.h (FAILURE_EXIT_CODE): Define. + +Wed Jan 25 14:50:45 1995 David S. Miller (davem@nadzieja.rutgers.edu) + + * genattrtab.c (check_attr_value): Change error message text. + (simplify_test_exp): Likewise. + * stmt.c (expand_asm, expand_asm_operands): Likewise. + * mips.c (print_operand, print_operand_address): Likewise. + * dsp16xx.c (dsp16xx_reg_class_from_letter): Likewise. + (limit_reload_class, double_reg_to_memory): Likewise. + (print_operand_address, emit_1600_core_shift): Likewise. + (gen_tst_reg, gen_compare_reg): Likewise. + * dsp16xx.md (compare): Likewise. + * unroll.c (find_splittable_givs): Likewise. + +Wed Jan 25 13:21:10 1995 Matthias Pfaller (leo@marco.de) + + * configure (ns32k-pc532-netbsd): Use netbsd32k.h instead of netbsd.h. + * ns32k/netbsd32k.h: Renamed from netbsd.h. + Don't include ansi.h. + Include config/netbsd.h and delete definitions included from it. + * ns32k/xm-netbsd.h (HAVE_ATEXIT): Deleted. + +Wed Jan 25 12:53:40 1995 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k/mot3300.h (DEFAULT_PCC_STRUCT_RETURN): Define as zero. + (RETURN_IN_MEMORY): Small aggregates are to be returned in d0. + +Wed Jan 25 12:48:43 1995 Paul Eggert <eggert@twinsun.com> + + * cccp.c (handle_directive): Fix typo: '\' caused next char to + be copied blindly, which was an error if !traditional and if + the next char was newline or one of <\'"/. + +Wed Jan 25 08:15:49 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * jump.c: Include expr.h after insn-config.h and insn-flags.h. + +Tue Jan 24 23:19:28 1995 Doug Evans <dje@cygnus.com> + + Improved conditional move support from Richard Earnshaw. + * optabs.c (movcc_gen_code): New variable. + (init_optabs): Initialize it. + (emit_conditional_move): New function. + (can_conditionally_move_p): New function. + * combine.c (simplify_set): Call it. + * expr.h: (emit_conditional_move): Declare it. + (can_conditionally_move_p): Likewise. + (movcc_gen_code): Likewise. + * genopinit.c (optabs): Add entry for movcc_gen_code. + * genconfig.c (main): Delete #ifndef around HAVE_conditional_move. + * jump.c (jump_optimize): Try to emit a conditional move insn before + trying a store-flag insn. + * alpha.md (movsicc): New named pattern. + (movdicc, movsfcc, movdfcc): Likewise. + (SImode conditional move): New matcher. + * sparc.h (HAVE_conditional_move): Delete. + + * configure: Recognize and ignore --x-* options. + +Mon Jan 23 23:23:33 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/svr4.h (ASM_OUTPUT_SECTION_NAME): Renamed from + ASM_OUTPUT_SECTION. The old name was a typo. + (ASM_OUTPUT_SECTION_NAME): Take proper number of args. + +Mon Jan 23 18:51:38 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * collect2.c (main): Check LD_INIT_SWITCH and LD_FINI_SWITCH + separately. + (scan_prog_file): Don't add shared library initializers or + finalizers to list if LD_INIT_SWITCH or LD_FINI_SWITCH are + defined, respectively. + +Mon Jan 23 18:45:13 1995 Ian Lance Taylor <ian@cygnus.com> + + * config/mips/mips.c (override_options): Permit any small integral + mode in the HI/LO registers. + +Mon Jan 23 15:41:10 1995 Steve Chamberlain <sac@cygnus.com> + + * h8300.md (table_jump_h8300, table_jump_h8300h): Constrain + operand to use register. + +Sat Jan 21 00:01:08 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * configure (*-*-gnuelf*): Set elf=yes. + (*-*-gnu*): Use ${cpu_type}/gnuelf.h under --with-elf. + +Fri Jan 20 20:11:17 1995 Jim Wilson <wilson@cygnus.com> + + * combine.c (num_sign_bit_copies): Can handle paradoxical subreg only + if LOAD_EXTEND_OP is defined to SIGN_EXTEND. + + * loop.c (record_giv): Initialize new field same_insn. + * loop.h (structure induction): Add new field same_insn. + * unroll.c (copy_loop_body): When check for shared address givs, use + new same_insn field. + (find_splittable_givs): New variable v2. Scan givs to set new + same_insn field. Use same_insn to indentify address givs to be + shared. + + * flow.c (find_basic_blocks): No longer need to check for deleted + nonlocal_labels. + * function.c (delete_handlers): When clear LABEL_PRESERVE_P, + also remove label from nonlocal_label list. + * integrate.c (save_for_inline_copying): Add comment that + nonlocal_label list should be updated if it ever can be nonzero. + + * sdbout.c (syms.h): Don't include under Linux. + + * loop.c (scan_loop): For the replace_rtx call, copy the rtx that is + being substituted in before the call. + + * sh.c (machine_dependent_reorg): When remove SUBREG, add in + SUBREG_WORD to new register number. + + * sh.c (multcosts): Do not compute cost of constant power-of-two + multiplies as if they were shifts. Reduce multiply cost from 5 to 3. + Delete variable insn_cost. + +Fri Jan 20 14:21:49 1995 Mike Stump <mrs@cygnus.com> + + * stmt.c (expand_cleanups): Add 4th argument to indicate if code + needs to be expanded for the cleanup. + (expand_goto_internal): Ditto. + (bc_expand_goto_internal): Ditto. + (fixup_gotos): Ditto. + (expand_end_bindings): Ditto. We now always call expand_cleanups, + even after BARRIERs, so that the call to the exception handling + routines is always done. + +Thu Jan 19 18:39:14 1995 Ian Lance Taylor <ian@cygnus.com> + + * config/mips/mips.h (MASK_SINGLE_FLOAT): Define. + (MASK_MAD): Define. + (TARGET_SINGLE_FLOAT, TARGET_DOUBLE_FLOAT): Define. + (TARGET_MAD): Define. + (TARGET_SWITCHES): Add single-float, double-float, mad, no-mad, + 4650. + (ASM_SPEC): For gas, pass down -m4650, and pass -m4650 if -mmad is + used. + (CC1_SPEC): If -mips3 is used, only set -mfp64 if neither + -msingle-float nor -m4650 are used. Don't permit both -mfp64 and + -msingle-float, or both -mfp64 and -m4650. If -m4650 is used, + pass down -mcpu=r4650. + (FIXED_REGISTERS): Change HI and LO to not be fixed. + (HARD_REGNO_NREGS): If TARGET_SINGLE_FLOAT, use floating point + registers in 4 byte units, not 8 byte units. + (SECONDARY_RELOAD_CLASS): Define. + (mips_secondary_reload_class): Declare. + (LIBCALL_VALUE): If TARGET_SINGLE_FLOAT, only use FP_RETURN if the + mode size is <= 4. + (REGISTER_MOVE_COST): Use a cost of 12 when moving HI or LO to + anything other than a general register. + * config/mips/mips.c (function_arg): If TARGET_SINGLE_FLOAT, pass + DFmode arguments in general registers. + (override_options): Accept 4650 as a cpu type. If + TARGET_SINGLE_FLOAT, permit only small floating point modes in + floating point registers. Always permit SImode modes in HI/LO + registers. + (compute_frame_size): If TARGET_SINGLE_FLOAT, only save 4 bytes + per floating point register. Align the floating point register + save space to an eight byte boundary. + (save_restore_insns): If TARGET_SINGLE_FLOAT, save floating point + regisers in single precision. + (mips_secondary_reload_class): New function. + * config/mips/mips.md: Require TARGET_DOUBLE_FLOAT for all double + precision floating point insns. Change the multiplication insns + to be single instructions which set a register of class l or h or + x, as appropriate, rather than explicitly setting HI and/or LO. + Use define_expand to avoid generating a shift near a multiply on + the r4000. Use match_scratch in the division insns to clobber HI + and LO, rather than mentioning them explicitly. Add support for + r4650 mad and madu insns. + * config/mips/t-ecoff (MULTILIB_OPTIONS): Add mips1/mips3. + (MULTILIB_DIRNAMES): Add mips1 mips3. + +Wed Jan 18 07:43:53 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tree.c (stabilize_reference): Fix typo in last change. + * expr.c (get_inner_reference): Don't ignore CONVERT_EXPR from + non-UNION_TYPE to UNION_TYPE. + (expand_expr, case CONVERT_EXPR): Check for conversion to union + before checking for not changing mode. + +Tue Jan 17 22:33:27 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tree.c (stabilize_reference, case RTL_EXPR): New case. + +Tue Jan 17 18:42:44 1995 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.c (emit_move_sequence): Also handle displacements which + do not fit in 14 bits for fp load/store secondary reloads. + +Tue Jan 17 13:34:22 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + Avoid bogus errors for C++ lvalues. + * c-decl.c (init_decl_processing): Set pedantic_lvalues to pedantic. + * fold-const.c (pedantic_non_lvalue): Only force a non-lvalue if + pedantic_lvalues is set. + * tree.h: Declare pedantic_lvalues. + + Generalize shared truthvalue code to allow for C++ bool. + * c-tree.h: Declare boolean_{type,true,false}_node. + * c-decl.c (init_decl_processing): Set up + boolean_{type,true,false}_node to equal + integer_{type,one,zero}_node. + * c-common.c (truthvalue_conversion): Use + boolean_{type,true,false}_node instead of + integer_{type,one,zero}_node. + (shorten_compare): Ditto. + +Mon Jan 16 07:11:50 1995 Paul Eggert <eggert@twinsun.com> + + * cccp.c (rescan): Fix typo that caused tokens to be glued + together improperly. + +Sun Jan 15 21:00:24 1995 Doug Evans (dje@cygnus.com) + + * configure (vintmsg): Delete. + +Sat Jan 14 17:50:06 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (get_inner_reference): Only treat offset of PLUS_EXPR + as special if second arg is integer constant. + +Sat Jan 14 01:28:15 1995 Doug Evans (dje@cygnus.com) + + * expmed.c (extract_bit_field, fields bigger than word case): Count + subwords in target. Zero remaining upper bits if unsigned. + + * c-common.c (decl_attributes): Fix typo in packed ignored warning. + Fix unrecognized mode warning. Make string comparisons consistent. + Support machine attributes with arguments. Make noreturn/volatile + warnings consistent with others. + + * a29k.h (INIT_CUMULATIVE_INCOMING_ARGS): Reserve two regs for + caller's lr0,lr1. + * a29k.c (incoming_reg): Keep regstack aligned to even boundary. + +Fri Jan 13 20:29:30 1995 Philippe De Muyter (phdm@info.ucl.ac.be) + + * sdbout.c (plain_type_1): For LONG_LONG_TYPE_SIZE, return T_[U]LONG + instead of 0 (i.e. T_VOID). + + * optabs.c (expand_binop): Do not force constant shift-count to + a register, to allow possible widening; do not convert_to_mode + mode{1,2} or copy_to_mode_reg if mode{1,2} is VOIDmode. + * m68k.md (zero_extendsidi2): New pattern. + (extendqidi2, extendhidi2, extendsidi2, extendplussidi): New patterns. + (adddia_sexthishl32, adddid_sexthishl32): New patterns. + (adddi_dilshr32, adddi_dishl32, adddi_mem): New patterns. + (adddi3, subdi3): Allow more alternatives. + (subdia_sexthishl32, subdid_sexthishl32): New patterns. + (subdi_dishl32, subdi_mem): New patterns. + (negdi2): New pattern. + (ashldi_sexthi, ashldi_const32, ashldi_const, ashldi3): New patterns. + (subreg1ashrdi_const32, ashrdi_const32): New patterns. + (ashrdi_const32_mem, ashrdi_const, ashrdi3): New patterns. + (subreg1lshrdi_const32, lshrdi_const32, lshrdi_const, lshrdi3): Ditto. + (lshrsi_31): New pattern. + (lshrsi_16, lshrsi_17_24): New names for old unnamed patterns. + + * m68k.c (use_movqi, const_method): New functions. + (const_int_cost, output_move_const_into_data_reg): Likewise. + (singlemove_string): Call output_move_const_into_data_reg. + * m68k.md (fullword move): Likewise. + * m68k.h (CONST_COSTS): Call const_int_cost. + +Fri Jan 13 20:17:55 1995 Oliver Kellogg (okellogg@salyko.cube.net) + + * 1750a.h, 1750a.c: Remove use of function prototypes. + +Fri Jan 13 15:53:33 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * tree.h (DECL_STATIC_CONSTRUCTOR): New macro. + (DECL_STATIC_DESTRUCTOR): New macro. + (tree_decl): Add static_ctor_flag and static_dtor_flag. + + * objc-act.c (finish_file): Renamed from objc_finish. + + * c-parse.in (program): Call finish_file. + + * c-decl.c (duplicate_decls): Propagate DECL_STATIC_{CON,DE}STRUCTOR. + (finish_function): Handle DECL_STATIC_{CON,DE}STRUCTOR. + + * c-lang.c (finish_file): New function to emit code for calling + static constructor and destructor functions as necessary. + + * c-common.c (decl_attributes): Support __attribute__s + "constructor" and "destructor". + +Fri Jan 13 19:38:08 1995 Paul Eggert <eggert@twinsun.com> + + * gcc.c (execute): Don't wait for just any N subprocesses, + since we may have started with some subprocesses before we + started executing. Wait just for _our_ N subprocesses. + +Fri Jan 13 18:08:17 1995 John F Carr <jfc@mit.edu> + + * gencodes.c, genemit.c, genflags.c (gen_insn): Ignore insns whose + names begin with '*'. + * genoutput.c (output_epilogue): Do not reference gen_ functions for + insns whose names begin with '*'. + +Fri Jan 13 17:54:42 1995 Wolfgang Formann (wolfi@exner.tgm.ac.at) + + * i386/isc.h (ASM_FILE_START): New macro. + +Fri Jan 13 15:01:59 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-parse.in (unary_expr): If -pedantic, give error for &&. + + * fold-const.c (fold, case COND_EXPR): Properly swap args 1 and 2. + Strip nops from ARG2, just like ARG1. + Make {MIN,MAX}_EXPR properly when type of result different than args. + + * function.c (optimize_bit_field): Don't remove a SUBREG that + changes mode class. + + * Makefile.in (stmp-multilib*): Pass CC and CFLAGS to recursive make. + + * alpha/osf12.h (LINK_SPEC): Add missing "\". + +Thu Jan 12 13:37:13 1995 Jim Wilson <wilson@cygnus.com> + + * i960/t-* (LIBGCC1, CROSS_LIBGCC1): Define to empty instead of + to libgcc1.null. + * mips/t-*, sparc/t-*: Likewise. + +Thu Jan 12 08:13:55 1995 Steve Chamberlain (sac@wombat.gnu.ai.mit.edu) + + * libgcc2.c (__lshldi3, __lshrdi3, __ashldi3, __ashrdi3): + Shift count comes as a word, not as an SI. Keep temporary in + a word. + (__moddi3, __divdi3): Make negate flag `c' have word_type for + efficiency. + +Thu Jan 12 07:18:09 1995 Stephen L Moshier (moshier@world.std.com) + + * real.c (toe64): Use Intel bit pattern for little-endian XFmode Inf. + (e64toe): Likewise; also check the exponent field properly. + +Wed Jan 11 14:24:55 1995 Jason Merrill <jason@phydeaux.cygnus.com> + + * toplev.c (lang_options): Add -f{no-,}gnu-keywords, + -f{no-,}operator-names. + +Tue Jan 10 19:16:07 1995 David Edelsohn <edelsohn@mhpcc.edu> + + * rs6000.h (REGISTER_MOVE_COST): Add LINK_OR_CTR_REGS class to + expensive moves. + +Tue Jan 10 19:07:36 1995 Jonathan Beimel (jbeimel@gomez.sc.intel.com) + + * combine.c (simplify_if_then_else): Fix typo: "|" should be "||". + +Tue Jan 10 05:49:25 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (fold): Avoid infinite recursion caused by last change. + +Mon Jan 9 17:08:56 1995 Michael Meissner (meissner@cygnus.com) + + * configure: All AIX versions [456789].* use the AIX 4.1 support. + +Mon Jan 9 13:21:07 1995 David Edelsohn <edelsohn@npac.syr.edu> + + * rs6000/aix41ppc.h: New file. + + * configure (powerpc-ibm-aix4.1*): Add support AIX version 4.1 on + the powerpc. + +Sat Jan 7 08:51:29 1995 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * sparc.c (order_regs_for_local_alloc): Add casts to bcopy call. + (print_operand, case 'f'): New case. + (sparc_initialize_trampoline): Use gen_flush instead of knowing + what pattern looks like. + Use MEM instead of address in flush insn, so virtual reg + instantiation can update. + Ensure address in flush insn is valid. + * sparc.md (flush): Change to using a MEM instead of address. + + * reorg.c (dbr_schedule): Add missing casts in bzero call. + + * fold-const.c (fold, case CONVERT_EXPR): Don't remove an + integer conversion when outer is FP unless it doesn't change + signedness; rework code in this area to be clearer. + +Sat Jan 7 02:58:21 1995 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (enum processor_type): New enumeration describing the + processor to schedule for (700, 7100, 7100LC). + (pa_cpu_attr, TARGET_OPTIONS, OVERRIDE_OPTIONS): Define. + (pa_cpu_string, pa_cpu): Provide extern decls. + * pa.c (pa_cpu, pa_cpu_string): Provide definitions. + (override_options): New function. + (pa_adjust_cost): Handle PROCESSOR_7100 and PROCESSOR_7100LC + scheduling. Handle anti-dependendy cases involving fp division + and sqrt. Handle output dependencies correctly. Break TYPE_FPMUL + into TYPE_FPMULSGL and TYPE_FPMULDBL. + * pa.md (cpu attribute): New attribute. + Clean up comments for PROCESSOR_700 scheduling info. Slightly + simplify. Make conditional on PROCESSOR_700. + Add comments and scheduling information for PROCESSOR_7100 and + PROCESSOR_7100LC. Set types for instructions which use the shifter + to "shift". Explicitly set lengths and types for all instructions. + Break type "fpmul" into "fmulsgl" and "fpmuldbl". + +Fri Jan 6 17:50:48 1995 Jim Wilson <wilson@chestnut.cygnus.com> + + * sh/sh.h (DO_GLOBAL_CTORS_BODY): Run constructors from right to + left not left to right. + * h8300/h8300.h: Likewise. + +Thu Jan 5 12:37:26 1995 Doug Evans <dje@cygnus.com> + + * loop.c (get_condition): Use CONST0_RTX instead of const0_rtx. + +Wed Jan 4 04:26:23 1995 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.md (call expander): Use emit_insn_before to emit an insn to + save the PIC register before a function call. + (call_value expander): Likewise. + +Tue Jan 3 15:23:49 1995 Jim Wilson <wilson@cygnus.com> + + * va-mips.h (va_arg, mips3 case): Use __PTRDIFF_TYPE__ not int in + casts. + + * c-decl.c (duplicate_decls): Push to correct obstack before + creating new function types. + +Fri Dec 30 16:12:52 1994 Ian Lance Taylor <ian@cygnus.com> + + * fixinc.svr4: Remove special patch for <netinet/in.h>. + +Fri Dec 30 08:00:53 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * varasm.c: Include output.h. + Add prototyes for all static functions; remove forward declarations + of non-static functions. + (assemble_variable): Add missing arg decl. + (bc_make_decl_rtl, const_hash, const_hash_rtx): Now static. + (output_addressed_constants, output_constructor): Likewise. + (bc_output_constructor): Add missing argument. + (output_byte_asm): Delete, unused. + * output.h: Add decls of functions in varasm.c. + Allow to be included when rtl.h is not. + * function.h ({save_restore}_varasm_status): Add decls. + * c-decl.c, c-typeck.c, toplev.c: Include output.h. + * Makefie.in (c-decl.o, c-typeck.o, toplev.o, varasm.o): Likewise. + +Thu Dec 29 21:48:03 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * calls.c (expand_call): Set MEM_IN_STRUCT_P as needed on return + value from assign_stack_temp. + (store_one_arg): Likewise. + * expr.c (save_noncopied_parts): Likewise. + (expand_expr): Likewise. + * function.c (assign_parms): Likewise. + * integrate.c (expand_inline_function): Likewise. + * stmt.c (expand_decl): Likewise. + +Thu Dec 29 14:06:34 1994 Jim Wilson <wilson@cygnus.com> + + * cse.c (simplify_unary_operation): Cast constant 1 to HOST_WIDE_INT + before shifting left to form mask. + * gcc.c (print_multilib_info): Initialize last_path_len to 0. + * varasm.c (output_constructor): Change type of variable value to + HOST_WIDE_INT. + + * expmed.c (expand_mult_highpart): Use convert_modes instead of + gen_lowpart to do conversions. + +Thu Dec 29 13:42:08 1994 Mike Stump <mrs@cygnus.com> + + * toplev.c (lang_options): Add -frtti flag for rtti support in C++. + +Wed Dec 28 22:04:42 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * config/pa/lib2funcs.asm: New file. + * config/pa/t-pa (LIB2FUNCS_EXTRA): Define. + * config/pa/pa.h (DO_GLOBAL_DTORS_BODY): Define. Include a + reference to __gcc_plt_call so __gcc_plt_call always appears in + executables which reference __main. + +Wed Dec 28 21:18:26 1994 Jim Wilson <wilson@cygnus.com> + + * mips.md (truncdiqi2+[123]): Add patterns to optimize DImode to + SImode truncation. + + * reorg.c (fill_simple_delay_slots): For the epilogue case, set needed + to include frame pointer and stack pointer, don't include all of + end_of_function_needs. Reject insn if it sets a previously set + resource. + + * sh.c (sh_expand_prologue): Clear extra_push at start. Clear + current_function_anonymous_args if set. Clear shiftsyms array. + (sh_expand_epilogue): Don't clear extra_push, + current_function_pretend_args_size, current_function_anonymous_args, + and shiftsyms array. + + * reload.c (find_equiv_reg): Exclude registers clobbered in the + CALL_INSN_FUNCTION_USAGE field of a CALL_INSN. + +Tue Dec 27 19:22:35 1994 Mike Stump <mrs@cygnus.com> + + * stmt.c (expand_cleanups): Add third parameter so that we can + avoid marking a cleanup region if this cleanup is part of a fixup + style goto. + (expand_goto_internal): Pass a 1 to expand_cleanups. + (bc_expand_goto_internal): Ditto. + (fixup_gotos): Ditto. + (expand_end_bindings): Pass a 0 to expand_cleanups. + +Tue Dec 27 15:45:18 1994 Jeffrey A. Law <law@snake.cs.utah.edu> + + * pa.c (output_movb): Fix ttypo. + +Tue Dec 27 15:11:42 1994 Ian Lance Taylor <ian@cygnus.com> + + * config/i960/i960.c (i960_output_double): Print hex constants if + REAL_VALUE_TO_TARGET_DOUBLE is defined. + (i960_output_float): Likewise with REAL_VALUE_TO_TARGET_SINGLE. + +Sun Dec 25 07:22:30 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * convert.c (convert_to_pointer): Eliminate ref to null_pointer_node. + +Thu Dec 22 12:51:31 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * limitx.h (syslimits.h): Find syslimits.h in the same directory. + + * limity.h (_GCC_NEXT_LIMITS_H): If macro defined, recurse down + to real limits.h. + + * gsyslimits.h (_GCC_NEXT_LIMITS_H): Define macro and start recursing + down to the real limits.h. + +Thu Dec 22 12:17:11 1994 Ian Lance Taylor <ian@cygnus.com> + + * Makefile.in (LIMITS_H_TEST): New variable. + (xlimits.h): Use LIMITS_H_TEST. + * config/m68k/t-next (LIMITS_H_TEST): Define. + * config/i386/t-next (LIMITS_H_TEST): Define. + +Wed Dec 21 15:56:13 1994 Holger Teutsch (teutsch@sw017.ffm-iw.Degussa.DE) + + * clipper.h (TRAMPOLINE_TEMPLATE): Specify some code as explicit hex + words. Shorten template. + (TRAMPOLINE_SIZE,INITIALIZE_TRAMPOLINE): Update accordingly. + (FUNCTION_ARG,FUNCTION_ARG_ADVANCE): Aggregates are ALWAYS passed + on the stack. + * va-clipper.h (__va_rounded_size): Delete. + (__va_round): Args have at least PARM_BOUNDARY (=32) alignment. + +Wed Dec 21 15:36:46 1994 Stephen L Moshier (moshier@world.std.com) + + * m68k.md (sqrtsf2, sinsf2, sindf2, sinxf2): Define. + (cossf2, cosdf2, cosxf2): Likewise. + (sqrtxf2): Operand 1 now XFmode. + +Wed Dec 21 14:39:46 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k.md (adddi3, subdi3): New patterns. + +Wed Dec 21 13:56:08 1994 Michael Gschwind <mike@vlsivie.tuwien.ac.at> + + * pdp11.md (mulhisi3): Add truncate to mulhisi3 to fix bug and + change from define_insn to define_expand to survive register + presssure. + +Wed Dec 21 12:51:10 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stmt.c (expand_asm_operands): Make sure input operands are + valid constants if they are constants. + + * toplev.c (rest_of_compilation): Adjust tests for when to + inline and when to defer. + * calls.c (expand_call): Only inline if DECL_INLINE; don't + call function_cannot_inline_p here. + + * stmt.c (expand_expr_stmt): If want values for statements, + convert function to address-of-function. + +Wed Dec 21 00:02:33 1994 Ian Lance Taylor <ian@cygnus.com> + + * combine.c (simplify_shift_const): Always copy flags to new MEM. + +Tue Dec 20 14:15:58 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * rs6000/aix41.h (LINK_SPEC): Add case for -shared, just like rs6000.h. + +Tue Dec 20 09:14:00 1994 DJ Delorie (dj@ctron.com) + + * i386/go32.h: support #pragma pack(). + + * msdos/configur.bat: add libgcc.a target. + * msdos/mklibgcc.c: new file, helps build libgcc.a. + * msdos/libgcc.mak: new file, makefile fragment for libgcc.a. + * msdos/top.sed: change Makefile to be able to build libgcc.a. + +Mon Dec 19 20:52:13 1994 Jim Wilson <wilson@cygnus.com> + + * mips/x-sysv (CLIB): Add -L/usr/lib/cmplrs/cc3.11. + + * dsp16xx/dsp16xx.h (HAVE_VPRINTF): Delete. + + * flow.c (mark_set_1): For multi-reg hard register, clear all + reg_next_use entries. + +Mon Dec 19 17:49:59 1994 Doug Evans <dje@cygnus.com> + + * Makefile.in (stmp-multilib): Check recursive make's return code. + (.PHONY): Tell GNU make the various LANGUAGES are phony targets. + +Mon Dec 19 17:07:41 1994 Ian Lance Taylor <ian@cygnus.com> + + * config/mips/mips.c (print_operand): Don't print a CONST_DOUBLE + as a floating point value if it is not MODE_FLOAT. + +Mon Dec 19 15:27:42 1994 Jim Wilson <wilson@cygnus.com> + + * fp-bit.c (fpadd_parts): Adding infinities with opposite signs + yields a NaN. + + * loop.c (invariant_p): Reject const volatile references. + +Sun Dec 18 21:55:26 1994 Jeffrey A. Law <law@snake.cs.utah.edu> + + * pa.md (pic2_highpart): Accept readonly operands. + +Sun Dec 18 16:29:20 1994 Jim Wilson <wilson@cygnus.com> + + * mips/dec-bsd.h (CPP_PREDEFINES): Change _MIPSEB to _MIPSEL. + + * cccp.c (macarg1): Count newline at end of C++ comment. + +Sun Dec 18 06:54:34 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stor-layout.c (layout_decl): Allow DECL_BIT_FIELD for any type. + +Sat Dec 17 03:43:24 1994 Jeffrey A. Law <law@snake.cs.utah.edu> + + * pa.h (readonly_section): During PIC code generation, put + readonly data into the standard data section. + + * pa.c (pic_label_operand): Disallow SYMBOL_REFs (constant data). + +Fri Dec 16 06:44:40 1994 Jim Wilson <wilson@chestnut.cygnus.com> + + * sparc/litecoff.h (DBX_BLOCKS_FUNCTION_RELATIVE, DBX_FUNCTION_FIRST, + DBX_OUTPUT_MAIN_SOURCE_FILE_END): Define. + (ASM_OUTPUT_SOURCE_LINE): Modify it to output function relative stabs. + + * sh/lib1funcs.asm (ashiftrt_r4_1): Delete useless or instruction. + Add nop to rts delay slot. + + * combine.c (distribute_notes): When output an insn to hold a REG_DEAD + note, update basic_block_head if necessary. + +Thu Dec 15 15:22:46 1994 Jeffrey A. Law <law@snake.cs.utah.edu) + + * pa.h (DBX_OUTPUT_MAIN_SOURCE_FILE_END): Don't emit a ".text" + pseudo-op, we already make sure we're in the right space/subspace. + +Thu Dec 15 07:49:36 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (store_constructor): Properly get constant part of + bit position when DECL_FIELD_BITPOS is a PLUS_EXPR. + +Wed Dec 14 19:01:32 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (get_inner_reference): Use EXACT_DIV_EXPR to + compute byte offset from bit offset. + +Wed Dec 14 11:41:21 1994 Ian Lance Taylor <ian@cygnus.com> + + * fixincludes: Fix non const atof parameter on NEWS-OS 4.2R. + +Tue Dec 13 18:39:09 1994 Doug Evans <dje@cygnus.com> + + * h8300.c (handle_pragma): Only print warning once. + + * function.c (instantiate_virtual_regs_1, case PLUS): If offset is + zero, make sure register replacement is still validated. + +Tue Dec 13 07:51:20 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tower-as.h (FUNCTION_EXTRA_EPILOGUE): Fix typo in mov.l opcode. + * tower.h (IMMEDIATE_PREFIX): Really define. + + * expr.c (expand_expr, case MINUS_EXPR): Properly handle case + when the NEGATE overflows. + +Mon Dec 12 17:22:19 1994 der Mouse (mouse@collatz.mcrcim.mcgill.edu) + + * reload.c (debug_reload): Use GET_MODE_NAME to avoid warning. + +Mon Dec 12 13:15:04 1994 Doug Evans <dje@cygnus.com> + + * function.c (locate_and_pad_parm): Don't call pad_below for BLKmode + parms in regs. + + * expmed.c (emit_store_flag): Set mode after canonicalizing op0/op1 + so op1 is constant. + +Mon Dec 12 08:04:33 1994 Pat Rankin (rankin@eql.caltech.edu) + + * cccp.c, toplev.c (vms_fopen): Call `fopen' through an indirect + pointer to inhibit checking argument list against its prototype. + Increase RMS multi-block count from 16 to 32. + +Sat Dec 10 17:03:59 1994 H.J. Lu (hjl@nynexst.com) + + * cccp.c (do_include): Avoid dynamic initialization of aggregate. + +Sat Dec 10 16:57:50 1994 Andreas Luik (luik@isa.de) + + * m68k.md (cmpsi): Make this into a define_expand; legitimize + PIC addresses if necessary. + Old cmpsi code now unnamed define_insn pattern. + +Sat Dec 10 16:06:03 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (pedantic_omit_one_operand): New function. + (fold, case COND_EXPR): Use it instead of calling + pedantic_non_lvalue on the result of omit_one_operand. + +Fri Dec 9 15:53:35 1994 Steve Chamberlain (sac@wombat.gnu.ai.mit.edu) + + * reload.c (find_reloads_address_1): Handle TRUNCATE and + ZERO_EXTEND in same way as SIGN_EXTEND. + +Fri Dec 9 14:52:41 1994 Jason Merrill <jason@phydeaux.cygnus.com> + + * rs6000/rs6000.h (LINK_SPEC): Add %{shared:-bM:SRE}. + (LINK_LIBGCC_SPECIAL_1): Use LIBGCC_SPEC instead. + +Fri Dec 9 14:24:02 1994 Per Bothner <bothner@kalessin.cygnus.com> + + * gcc.c (default_compilers): Add support for Chill (.ch and .chi). + +Fri Dec 9 17:31:46 1994 Jason Merrill <jason@phydeaux.cygnus.com> + + * fixinc.svr4 (sys/byteorder.h): Turn extern inlines back into + static inlines for targets (such as SPARC/Solaris) that don't + supply these functions in the C library. + +Fri Dec 9 17:19:44 1994 David Edelsohn <edelsohn@npac.syr.edu> + + * rs6000.h (MASK_NO_FPR, TARGET_NO_FPR): Define. + (TARGET_SWITCHES): Add "fp-regs" and "no-fp-regs". + (CONDITIONAL_REGISTER_USAGE): Set FPRs fixed and call_used if + TARGET_NO_FPR. + +Fri Dec 9 16:06:23 1994 Doug Evans <dje@cygnus.com> + + * fold-const.c (fold): Call real_zerop for real constants. + +Thu Dec 8 17:28:57 1994 Jason Merrill <jason@phydeaux.cygnus.com> + + * dbxout.c (dbxout_type_method_1): Don't try to look at the first + argument of non-methods (which might not have a first argument). + +Thu Dec 8 16:07:27 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * configure (mips-*-gnu*): Recognize this configuration. + * config/mips/gnu.h: New file. + +Thu Dec 8 15:41:32 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k.c (extend_operator): New predicate. + * m68k.md (bsetmemqi, bclrmemqi): New patterns to set bit in memory + byte with bit number dynamic (use bclr/bset instructions). + +Thu Dec 8 14:13:45 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (do_include): Don't turn newline markers into spaces + when expanding an include file name. + + * cccp.c (discard_comments): If traditional, replace a comment + with nothing instead of with a space. + + * cccp.c (char_name): New var. + (initialize_char_syntax): Initialize it. + (handle_directive): Use it to simplify printing of diagnostics. + Warn about '\r' too. + (create_definition, do_pragma, do_endif, make_assertion): Be consistent + about skipping all horizontal white space, not just space and tab. + +Thu Dec 8 13:54:38 1994 H.J. Lu (hjl@nynexst.com) + + * i386/linuxelf.h: Modified for stabs-in-ELF. + (PREFERRED_DEBUGGING_TYPE): Defined as DBX_DEBUG. + (FUNCTION_PROFILER): Use mcount instead of _mount. + (CPP_PREDEFINES): Add -D__ELF__. + (CPP_SPEC): Add -D__PIC__ -D__pic__ for -fPIC or -fpic. + (LIB_SPEC): Don't use any default library if -shared. + (LIBGCC_SPEC, LINK_SPEC, STARTFILE_SPEC, ENDFILE_SPEC): New specs. + * configure (gxx_include_dir): Set default to '$(prefix)/include/g++' + (i[345]86-*-linuxelf): New platform for ELF. + * crtstuff.c (CRT_END): Add dummy refs to ___brk_addr, __environ + and atexit if __linux__ and __PIC__ defined. + +Thu Dec 8 12:58:34 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * config/xm-freebsd.h, i386/xm-freebsd.h: New files. + * configure (i[345]86-*-freebsd*): Use i386/xm-freebsd.h. + +Wed Dec 7 16:51:56 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k.md: New pattern for ior between SImode target and zero_extended + value. + +Wed Dec 7 16:42:46 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * combine.c (distribute_notes): If can't find place for REG_DEAD + note, add an INSN with a USE to hold it. + + * tree.c (preserve_momentary): New function. + +Wed Dec 7 15:59:00 1994 Doug Evans <dje@cygnus.com> + + * function.c (locate_and_pad_parm): Do padding before rounding + so pad_below knows how much is needed. + +Tue Dec 6 17:53:37 1994 Steve Chamberlain (sac@wombat.gnu.ai.mit.edu) + + * sh.md (ashrsi2_16): New pattern doesn't clobber reg 18. + (ashrsi2_31): Fix. + +Tue Dec 6 19:11:36 1994 Stephen L Moshier (moshier@world.std.com) + + * c-decl.c (init_decl_processing): Implement built-in functions + fabsf, sqrtf, sinf, cosf, fabsl, sqrtl, sinl, cosl. + +Tue Dec 6 18:42:15 1994 Pat Rankin (rankin@eql.caltech.edu) + + * make-gcc.com: Eliminate `set symbol/scope=noGlobal'. + + * vax/vms.h (CPP_PREDEFINES): Set __GNUC_MINOR__ to 7. + +Tue Dec 6 15:10:37 1994 Jason Merrill <jason@phydeaux.cygnus.com> + + * sparc/t-sol2 (CRTSTUFF_T_CFLAGS): Don't use PIC if + cross-compiling, use the native assembler otherwise. + +Tue Dec 6 05:48:32 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * configure (i[345]86-*-gnu*): Just set cpu_type=i386 here. + (*-*-gnu*): Match this in second case stmt and set other vars based on + $cpu_type. + * config/gnu.h: New file. + * config/i386/gnu.h: Include "gnu.h". + +Mon Dec 5 16:59:39 1994 Doug Evans <dje@cygnus.com> + + * sparc/t-sparcbare (LIB2FUNCS_EXTRA): Compile fp-bit.c. + +Mon Dec 5 14:48:53 1994 Jim Wilson <wilson@mole.gnu.ai.mit.edu> + + * unroll.c (copy_loop_body): Reformat CODE_LABEL_NUMBER macro call + to avoid HPUX compiler bug. + +Mon Dec 5 13:53:45 1994 Doug Evans <dje@cygnus.com> + + * m68k.md (negsf2): Flip sign bit if software floating point. + (negdf2,negxf2): Likewise. + (abssf2): Zero sign bit if software floating point. + (absdf2,absxf2): Likewise. + +Mon Dec 5 13:00:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.h (EXTRA_CONSTRAINT, case 'R'): Fix error in last change. + +Mon Dec 5 00:40:11 1994 Doug Evans <dje@cygnus.com> + + * Makefile.in (c-parse.h): Split away from c-parse.c for parallel + makes. + (bi-parser.h): Likewise with bi-parser.c. + +Sun Dec 4 21:04:40 1994 Doug Evans <dje@cygnus.com> + + Delete this patch: + * reorg.c (fill_slots_from_thread): Create a USE insn for any + redundant insn we pretend to fill a delay slot with. Continue + searching for a suitable delay slot insn at the new USE insn. + +Fri Dec 2 11:29:41 1994 Per Bothner <bothner@kalessin.cygnus.com> + + * expr.c (store_constructor): Add support for SET_TYPE. + +Fri Dec 2 18:14:09 1994 David Edelsohn <edelsohn@npac.syr.edu> + + * rs6000.h (MASK_64BIT, TARGET_64BIT, SHORT_TYPE_SIZE): Define. + (INT_TYPE_SIZE, MAX_INT_TYPE_SIZE, LONG_TYPE_SIZE): Define. + (MAX_LONG_TYPE_SIZE, LONG_LONG_TYPE_SIZE, CHAR_TYPE_SIZE): Define. + (FLOAT_TYPE_SIZE, DOUBLE_TYPE_SIZE, LONG_DOUBLE_TYPE_SIZE): Define. + (POINTER_SIZE, PARM_BOUNDARY): Depend on TARGET_64BIT. + (BIGGEST_ALIGNMENT, STARTING_FRAME_OFFSET): Likewise. + (FIRST_PARM_OFFSET, REG_PARM_STACK_SPACE): Likewise. + (STACK_POINTER_OFFSET, Pmode, FUNCTION_MODE): TARGET_64BIT dependent. + * xcoffout.c (xcoff_output_standard_types): Add TARGET_64BIT + dependencies. Add "wchar", "long long int", and "long long + unsigned int" built-in C types. + +Fri Dec 2 18:08:16 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * integrate.c (subst_constant): Don't treat all virtual regs as + constants, just those that are off FP and AP, but not SP. + (expand_inline_function): If called function calls alloca, save and + restore SP around its call. + + * rs6000.c (input_operand): Correctly check for SYMBOL_REF + referring to the TOC. + * rs6000.h (EXTRA_CONSTRAINT): Likewise. + +Wed Nov 30 20:42:57 1994 Jeffrey A. Law <law@snake.cs.utah.edu) + + * reorg.c (fill_slots_from_thread): Create a USE insn for any + redundant insn we pretend to fill a delay slot with. Continue + searching for a suitable delay slot insn at the new USE insn. + +Wed Nov 30 19:02:49 1994 Jim Wilson <wilson@chestnut.cygnus.com> + + * combine.c (record_dead_and_set_regs_1): Handle SUBREGs. + + * expr.c (convert_move): When emit multiword conversion, force FROM + into a new pseudo-reg if it overlaps TO. + + * fold-const.c (fold_truthop): Delete BIT_AND_EXPR of constants + with masks. + +Wed Nov 30 18:22:31 1994 David Edelsohn <edelsohn@npac.syr.edu> + + * rs6000.h (BITS_PER_WORD): TARGET_POWERPC64 dependent. + (MAX_BITS_PER_WORD): Define. + (UNITS_PER_WORD): TARGET_POWERPC64 dependent. + (MAX_UNITS_PER_WORD): Define. + (UNITS_PER_FP_WORD): Define. + (HARD_REGNO_NREGS): Use MAX_UNITS_PER_FP_WORD. + (HARD_REGNO_MODE_OK): Likewise. + (CLASS_MAX_NREGS): Likewise. + (MOVE_MAX): TARGET_POWER and TARGET_POWERPC64 dependent. + (MAX_MOVE_MAX): Define. + * rs6000.md (floatsidf2): Test BITS_PER_WORD in pattern condition + not during build. Fail if TARGET_POWERPC64. + (floatunssidf2): Likewise. + + * rs6000.md (extendsidi2): Use lwa_operand predicate. + (sign_extend load with update): New PowerPC64 pattern. + * rs6000.c (lwa_operand): New predicate. + * rs6000.h (PREDICATE_CODES): Add lwa_operand. + +Wed Nov 30 18:19:08 1994 Will Athanasiou (will@westford.ccur.com) + + * rs6000.md (extendsfdf2): SFmode and DFmode register format + identical so use define_expand with paradoxical subreg no-op and + accompanying new define_split. + +Wed Nov 30 18:05:03 1994 Michael Collison (collison@sw.stratus.com) + + * reload.c (combine_reloads): If using reg dying in this insn as + reload reg, ensure it can't be a secondary output reload reg. + +Wed Nov 30 15:48:29 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (emit_block_move): Only use movstr if size is + small enough constant or MODE is at least BITS_PER_WORD. + + * c-common.c (decl_attribute): Allow special names (e.g, `word') + for mode attribute. + * libgcc2.c (word_type): Use __attribute__ ((mode (__word__))). + +Tue Nov 29 16:50:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expmed.c (expand_shift): Open-code rotate even if by a variable. + * optabs.c (init_optabs): Don't set functions for rotl and rotr. + +Tue Nov 29 00:39:56 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (DEFAULT_PCC_STRUCT_RETURN): Define as zero. + (RETURN_IN_MEMORY): Only large structs (>8 bytes) and addressable + structs should be returned in memory. + * calls.c (expand_call): Handle returning BLKmode values in + registers. Do not try to promote BLKmode. + * expr.c (expand_assignment): For BLKmode structure returns, + copy the return value from registers into the target memory + locations. + * integrate.c (function_cannot_inline_p): Do not inline functions + which return a BLKmode value in registers. + * stmt.c (expand_return): For BLKmode structure returns, copy + the return value from memory into the return registers. Use + an integer mode rather than BLKmode for returning structures + in registers. + * explow.c (hard_function_value): Change a register in BLKmode + to a register in a sufficiently wide integer mode. + + * calls.c (expand_call): Do not set is_integrable if the + function is not inlineable according to function_cannot_inline_p. + +Mon Nov 28 18:53:06 1994 Dave Love (d.love@dl.ac.uk) + + * Makefile.in (FLAGS_TO_PASS): Fix typo in GCC_FOR_TARGET. + +Mon Nov 28 18:15:58 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * configure (lang): Really fix the quoting bug in bash 1.12. + +Mon Nov 28 18:03:48 1994 Jim Wilson (wilson@cygnus.com) + + * expmed.c (store_bit_field, extract_bit_field): Consistently use + SLOW_UNALIGNED_ACCESS instead of STRICT_ALIGNMENT. + * expr.c (move_by_pieces, move_by_pieces_ninsns, emit_push_insn, + expand_assignment, store_field, expand_expr): Likewise. + (SLOW_UNALIGNED_ACCESS): Default to STRICT_ALIGNMENT, not zero. + + * cccp.c (create_definition): Error if comma not followed by an + identifier. + (collect_expansion): Error if # used in macro with no arguments. + + * c-decl.c (finish_decl): Use DECL_CONTEXT instead of + current_binding_level to identify file-scope variables. + +Wed Nov 23 19:44:25 1994 Steve Chamberlain (sac@jonny.cygnus.com) + + * sh.c (MSW, LSW): New macros. + (print_operand_address): Added 'T' and 'S'. Modified + to support alternate endianness. + (output_movedouble): Support both byte orders. + (output_options): Tell assembler when in little endian mode. + (shiftinsns): New function to calculate shift cost more + accurately. + (gen_shifty_op): Use new function. + * sh.h (CPP_SPEC, ASM_SPEC, LINK_SPEC, LIBGCC2_WORDS_BIG_ENDIAN): New. + (TARGET_SWITCHES, WORDS_BIG_ENDIAN, BYTES_BIG_ENDIAN, ): Support + both byte orders. + * sh.md (addi3, subdi3, ashrdi3, ashldi3, extendsidi2, movdi, movdf): + Support both byte orders. + (ashrsi2_16, ashrsi2_31): New. + t-sh: Support both byte orders. + +Wed Nov 23 17:25:43 1994 Ian Dall (dall@hfrd.dsto.gov.au) + + * config/ns32k/{ns32k.c,ns32k.h}: Add -mhimem to + support linking above 0x20000000 boundary. + + * config/ns32k/{netbsd.h,pc532.h, ns32k.c}: Fix meaning + of BASE_REG_NEEDED. + +Wed Nov 23 17:24:24 1994 Matthias Pfaller (leo@marco.de) + + * configure (ns32k-pc532-netbsd): No need for fixincludes + and libgcc1. + * ns32k/ns32k.h (CONST_COSTS): Correct range is -0x1fff to 0x2000. + * ns32k/ns32k.md (everywhere): Correct range is -0x1fffffff + to 0x20000000, others have to be loaded with movd. + Shortcircuit with TARGET_32532 as early as possible. + (movsi): Use movd to load unknown symbol values. to allow + * ns32k/ns32k.c (print_operand): Removed dead code. + * ns32k/pc532.h (TARGET_DEFAULT): Forbid usage of bitfield + instructions. + +Wed Nov 23 14:09:42 1994 Jim Wilson (wilson@cygnus.com) + + * mips.c (mips_output_external): Exclude __builtin_next_arg from list + of used external functions. + + * sh.c (arith_reg_operand): Disallow MACH_REG and MACL_REG. + + * sparc.h (SECONDARY_MEMORY_NEEDED_RTX, SECONDARY_MEMORY_NEEDED_MODE): + Use MODE not mode. + +Wed Nov 23 13:30:52 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (emit_move_insn): If splitting up into individual words + and X is a push_operand, do the push and reference top of stack. + +Tue Nov 22 21:39:52 1994 Doug Evans (dje@cygnus.com) + + * mips/elf64.h (ASM_OUTPUT_SECTION_NAME): Define. + +Tue Nov 22 06:29:21 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (fold_convert): Don't fold conversion if it would + produce constant larger than we can support. + * emit-rtl.c (gen_lowpart_common): Do nothing if size is + greater than twice host wordsize, not just if equal. + + * optabs.c (emit_no_conflict_block): Just emit the insns if + the block contains something not an INSN or has an embedded block. + + * emit-rtl.c (init_emit): Set REGNO_POINTER_FLAG + for HARD_FRAME_POINTER_REGNUM. + + * machmode.h (ptr_mode): Add declaration. + * emit-rtl.c (ptr_mode): Add definition. + (init_emit_once): Initialize ptr_mode. + * stor-layout.c (layout_type): Use ptr_mode instead of equivalent + call to mode_for_size. + +Mon Nov 21 18:41:42 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * varasm.c (output_constant): When eliminating conversions, + treat ARRAY_TYPE like a record. + + * m68k.md (movqi): Fix typo in push/pop case. + +Mon Nov 21 18:11:55 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * genopinit.c (gen_insn): Use GET_MODE_WIDER_MODE macro instead of + directly accessing the array. + +Mon Nov 21 17:59:07 1994 David Edelsohn <edelsohn@npac.syr.edu> + + * aix41.h (LINK_SPEC): New overriding defintion. + +Mon Nov 21 17:44:01 1994 John F Carr (jfc@mit.edu) + + * rs6000.c (input_operand): Allow a SYMBOL_REF referring to a + symbol in the TOC. + +Mon Nov 21 14:39:13 1994 Doug Evans (dje@cygnus.com) + + * mips/t-ecoff (dp-bit.c): Fix typos. + +Mon Nov 21 14:06:29 1994 Jim Wilson (wilson@cygnus.com) + + * emit-rtl.c (operand_subword): For CONST_DOUBLE, add case to + handle BITS_PER_WORD of 16. + + * reload1.c (reload): When decrement max_groups of superclass, can + only do so if the group_size is smaller than the current group. + + * c-lex.c (yylex): Do warn about floating point out of range if + target floating-point format is IEEE. Use warning instead of + pedwarn to avoid getting errors. + +Mon Nov 21 13:37:03 1994 Doug Evans (dje@cygnus.com) + + * m88k/m88k-aout.h (CPP_PREDEFINES): Add -Acpu and -Amachine. + * m88k/m88k-coff.h (CPP_PREDEFINES): Likewise. + (DBX_DEBUGGING_INFO): Define. + + * m68k/t-m68kbare (MULTILIB_MATCHES): Treat m68302/m68332 like m68000. + +Mon Nov 21 00:58:36 1994 Jeffrey A. Law (law@mole.gnu.ai.mit.edu) + + * pa.c (output_call): When emitting an inline long-call, use LP% + and RP% prefixes to get the function's address. + +Sun Nov 20 07:00:25 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Makefile.in (objc-parse.y): Fix typo. + + * t-svr3: Deleted. + * t-svr4 (EXTRA_PARTS): Deleted. + * i386/t-crtstuff, i386/t-crtpic: New files. + * i386/t-svr3dbx (EXTRA_PARTS): Deleted. + * configure: Replace use of t-svr3 with extra_parts definition. + Add extra_parts to t-svr4 users; likewise for i386/t-svr3dbx. + (i386 configurations): Add t-crtstuff if can't build crtstuff.c + with -fomit-frame-pointer; use t-crtpic if also must build with -fpic. + +Sat Nov 19 17:14:54 1994 Jim Wilson (wilson@cygnus.com) + + * m68k/lb1sf68.asm (addsf3): After using swap for 16 bit rotate, + branch back only if count still greater than 0. + + * c-typeck.c (build_binary_op): Can shorten shift only if shift count + is less than size in bits of arg0. + * expmed.c (expand_shift): Re-enable truncation of immediate shift + count. + + * mips.c (mips_const_double_ok): Accept VOIDmode not DImode. + (mips_move_1word): Accept VOIDmode CONST_DOUBLE. + +Sat Nov 19 05:36:35 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.c (print_operand, case 'c', case 'd'): New cases. + * alpha.md (sign_extend): Disable pattern with explicit SUBREG. + (cmov): Allow first operand of comparison to be zero, 2nd reg. + + * a29k/unix.h (DEFAULT_PCC_STRUCT_RETURN): Define as 0. + * a29k/x-unix (CLIB): Remove -lsysv. + +Fri Nov 18 22:37:26 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * m88k/mot-sysv4.h: Remove, no longer needed. + * configure: Remove m88k-mot*-sysv4* special case. + + * collect2.c: Make various functions static. + + * sparc/sysv4.h ([CD]TORS_SECTION_ASM_OP): Remove #execinstr. + + * svr4.h, i386/sol2.h, m88k/dgux.h, sparc/sol2.h + (LINK_SPEC): Pass -z text when -shared or -symbolic. + * svr4.h (LIBGCC_SPEC): Don't pass -lgcc when -symbolic. + + * crtstuff.c: Fix comments. + +Fri Nov 18 22:36:26 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * pa/pa-hpux.h (LDD_SUFFIX): Move to pa.h. + (PARSE_LDD_OUTPUT): Ditto. + * pa/pa.h: (LDD_SUFFIX): Move from pa-hpux.h. + (PARSE_LDD_OUTPUT): Ditto. + (LINK_SPEC): Pass -b if -shared. Don't pass -u main if -shared. + * pa/pa1-osf.h: Reduce code duplication. + +Fri Nov 18 22:35:26 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * Makefile.in (crt{begin,end}.o): Pass $(CRTSTUFF_T_CFLAGS). + (CRTSTUFF_T_CFLAGS): New variable. + + * svr4.h, m88k/sysv4.h, sparc/sysv4.h (FINI_SECTION_ASM_OP): Define. + * i386/sol2.h (FORCE_FINI_SECTION_ALIGN): Define to + FORCE_INIT_SECTION_ALIGN. + * m88k/dgux.h, m88k/mot-sysv4.h, sparc/sysv4.h + (INIT_SECTION_PREAMBLE): Remove. + * svr4.h, sparc/sol2.h (STARTFILE_SPEC): Include crti.o and + values-X?.o when building a shared lib. + * svr4.h, i386/sol2.h, sparc/sol2.h (LIB_SPEC): Remove endfiles. + (ENDFILE_SPEC): Handle endfiles. + + * libgcc2.c (__do_global_dtors): Don't define if + INIT_SECTION_ASM_OP and OBJECT_FORMAT_ELF. + (L_[cd]tor_list): Lose unused pieces. + + * crtstuff.c (__[CD]TOR_{LIST,END}__): static if OBJECT_FORMAT_ELF. + (__do_global_ctors_aux): In .text if OBJECT_FORMAT_ELF. + (__do_global_dtors_aux): Ditto. + (init_dummy): Dummy function to stick a call to __do_global_ctors_aux + into the .init section if OBJECT_FORMAT_ELF. + (fini_dummy): Similarly. + Remove reference to INIT_SECTION_PREAMBLE. + + * mips/iris5.h (HAS_INIT_SECTION): Define. + (LINK_SPEC): Pass -u __main -init __main if not -shared. + (STARTFILE_SPEC): Don't include these when -shared. + (LIB_SPEC): Don't include these when -shared. + (ENDFILE_SPEC): Define. + (LD_INIT_SWITCH): Define. + (LD_FINI_SWITCH): Define. + + * alpha/alpha.h (LD_INIT_SWITCH): Define. + (LD_FINI_SWITCH): Define. + (INIT_NAME_FORMAT): Lose. + (FINI_NAME_FORMAT): Lose. + +Fri Nov 18 22:34:26 1994 Ronald F. Guilmette (rfg@segfault.us.com) + + * crtstuff.c, svr4.h, i860/sysv4.h, m88k/sysv4.h, sparc/sysv4.h + (CTORS_SECTION_ASM_OP): Remove @progbits, add SHF_WRITE. + (DTORS_SECTION_ASM_OP): Ditto. + + * t-svr4, i386/t-sol2, m88k/t-sysv4, sparc/t-sol2 + (CRTSTUFF_T_CFLAGS): Define to -fpic. + +Fri Nov 18 22:33:26 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * gcc.c (LIBGCC_SPEC): New spec. + (link_command_spec): Use LIBGCC_SPEC. + (set_spec): Handle LIBGCC_SPEC. + (process_command): Ditto. + (do_spec_1): %G is LIBGCC_SPEC. + (validate_all_switches): Also validate LIBGCC_SPEC. + + * alpha/alpha.h (LIBGCC_SPEC): Do include libgcc when + creating a shared library. + +Fri Nov 18 22:32:26 1994 Steve Dum (steve_dum@mentorg.com) + + * collect2.c (SUNOS4_SHARED_LIBRARIES): Support scanning the + _DYNAMIC field of SunOS 4 shared libraries directly. + +Fri Nov 18 22:31:26 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * collect2.c (main): For shared libraries, link in stubs even if + there are no constructors or destructors so that static objects + can be added without re-linking everything that uses the library. + (write_c_file_stat): Tweak. + + * configure: Use sunos4.h instead of sparc.h for SunOS 4 targets. + + * sparc/sunos4.h: New file for SunOS 4-specific things. + (SUNOS4_SHARED_LIBRARIES): Define to 1. + * sparc/sparc.h: (LINK_SPEC): Support -shared. + (LIB_SPEC): Ditto. + + * pa/pa-hpux.h (LDD_SUFFIX): New macro. + (PARSE_LDD_OUTPUT): New macro. + (LINK_SPEC): Pass -b if -shared. Don't pass -u main if -shared. + (LIB_SPEC): Don't include if -shared. + + * collect2.c (scan_prog_file): Ignore undefined symbols. + +Fri Nov 18 22:30:26 1994 Steve Dum (steve_dum@mentorg.com) + + * collect2.c (enum pass): Add PASS_LIB. + (is_ctor_dtor): Check for shared library constructor and destructor + functions, too. + (main): Add o_file after any link libraries, too. + Create a shared object if COLLECT_GCC_OPTIONS contains -shared. + Also scan shared libraries for constructors and destructors if + LDD_SUFFIX is defined. + (write_c_file_stat): New function to write out file for a shared + object. + (write_c_file_glob): Renamed from write_c_file. + (write_c_file): Calls one of write_c_file_{stat,glob}. + (scan_prog_file): Update to deal with shared libraries. + (scan_libraries): New function to scan shared libraries for + constructors and destructors. + +Fri Nov 18 19:16:19 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.c (addrs_ok_for_quad_peep): New function. + (output_prolog): Use liu mnemonic. + (registers_ok_for_quad_peep): New function. + * rs6000.md (peepholes for two DF load/store): New peepholes. + +Fri Nov 18 19:10:24 1994 Kresten Krab Thorup (krab@next.com) + + * objc/object.c (class_create_instance): Replace memchr + with memset. + +Fri Nov 18 19:06:15 1994 Doug Evans (dje@cygnus.com) + + * sparc/lite.h: #include "gofast.h" + (INIT_SUBTARGET_OPTABS): Define. + +Fri Nov 18 19:01:51 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * Makefile.in (extraclean): Remove *.ps. + +Fri Nov 18 18:53:57 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * cccp.c (create_definition): Allow carriage-return ('\r') + as white space in simple or empty expansion. + +Fri Nov 18 18:30:40 1994 Douglas Rupp (drupp@cs.washington.edu) + + * winnt/ld.c (main): Fix off-by-one error allocating sdbuff. + +Fri Nov 18 18:23:54 1994 Mike Collison (collison@sw.stratus.com) + + * regclass.c (record_reg_classes): For single SET between hard reg + alone in a class and pseudo, ensure reg is the only member of class. + +Fri Nov 18 15:15:27 1994 Jim Wilson (wilson@cygnus.com) + + * sol2.h (MD_STARTFILE_PREFIX): Delete. + +Fri Nov 18 14:16:04 1994 Chris Huey (cah@tactix.rain.com) + + * Makefile.in (objc-parse.y, mostlyclean): Rename temp file + for objc-parse.y to be under 14 characters. + +Thu Nov 17 20:46:15 1994 Doug Evans <dje@cygnus.com> + + VxWorks support from various people at Cygnus. + * config.sub: Vendor for vxworks is wrs. + * configure (i960-wrs-vxworks*): New target. + (m68k-wrs-vxworks*): New target. + (sparc-wrs-vxworks*, sparclite-wrs-vxworks*): New targets. + * i960/t-vxworks960, i960/vx960-coff.h, i960/vx960.h: New files. + * m68k/t-vxworks68, m68k/vxm68k.h: New files. + * sparc/t-vxsparc, sparc/vxsparc.h: New files. + + * h8300/h8300.h (DBX_DEBUGGING_INFO): Define. + (PREFERRED_DEBUGGING_TYPE): Define to SDB_DEBUG. + + * configure (--program-prefix, --program-suffix, + --program-transform-name, -v, -verbose): New arguments. + (as): If gas is in build tree, use it. + (ld, real-ld): Likewise but watch for use_collect. + (program_transform_name): Update Makefile if + --program-transform-name given. + (program_transform_cross_name): Likewise. + * Makefile.in (program_transform_name): Define. + (program_transform_cross_name): Define. + (GCC_INSTALL_NAME, GCC_CROSS_NAME): Define. + (install-common): Use them. + (install-man): Likewise. + (distclean): Delete *.asm. + (stage*, risky-stage*): If as/ld/real-ld exist, copy them to stage dir. + + Embedded target support from various Cygnus people. + * config.sub (sparc): Recognize as a cpu. + (ecoff*, vsta, udi): Recognize as os's. + (udi29k): New alias. + * configure: (a29k-*-udi): New target. + (i[345]86-*-aout*): New target. + (i[345]86-*-coff*): New target. + (i[345]86-*-vsta): New target. + (m68k-*-aout*): New target. + (m68k-*-coff*): New target. + (m88k-*-aout*): New target. + (m88k-*-coff*): New target. + (mipsel-*-ecoff*): New target. + (mips-*-ecoff*): New target. + (mipsel-*-elf*): New target. + (mips-*-elf*): New target. + (mips64el-*-elf*): New target. + (mips64orionel-*-elf*): New target. + (mips64-*-elf*): New target. + (mips64orion-*-elf*): New target. + (sparc-*-aout*): New target. + (sparclite-*-coff*): New target. + (sparclite-*-*): Set tmake_file to sparc/t-sparclite. + (mips*-*-*): Changed from mips-*-*. + * optabs.c (expand_unop): Try subtraction from zero if there isn't a + negate library function. + * config/gofast.h: New file. + * a29k/a29k-udi.h, a29k/t-a29kbare: New files. + * i386/i386-aout.h, i386/i386-coff.h, i386/t-i386bare: New files. + * i386/vsta.h, i386/t-vsta, i386/x-vsta, i386/xm-vsta.h: New files. + * m68k/coff.h: New file (renamed from m68k-coff.h). + * m68k/lynx-ng.h, m68k/lynx.h: Include it. + * m68k/fpgnulib.c, m68k/lb1sf68.asm, m68k/m68kemb.h: New files. + * m68k/m68k-aout.h, m68k/m68k-coff.h, m68k/m68k-none.h: New files. + * m68k/t-m68kbare: New file. + * m88k/m88k-aout.h, m88k/m88k-coff.h, m88k/t-bug: New files. + * mips/ecoff-gdb.h, mips/ecoff.h, mips/ecoffl-gdb.h: New files. + * mips/ecoffl.h, mips/elf.h, mips/elf64.h, mips/elfl.h: New files. + * mips/elfl64.h, mips/elflorion.h, mips/elforion.h: New files. + * mips/t-ecoff: New files. + * sparc/lb1spc.asm, sparc/lb1spl.asm, sparc/litecoff.h: New files. + * sparc/sparc-aout.h, sparc/t-sparcbare, sparc/t-sparclite: New files. + +Thu Nov 17 18:32:24 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * cse.c (simplify_binary_operation): Do (x - (x & y)) -> (x & ~y). + +Thu Nov 17 17:26:02 1994 Mark P. Gooderum (mark@good.com) + + * stddef.h: Include <machine/ansi.h> on NetBSD. + Check for _BSD_XXX_T_ as well as _XXX_T_. + Add _BSD_XXX_T_ to list of defines to check and define for a given + type for SIZE_T, PTRDIFF_T, and WCHAR_T. + +Thu Nov 17 11:11:50 1994 Mike Collison (collison@sw.stratus.com) + + * dsp16xx.c (notice_update_cc): Removed reference to obsolete LSHIFT. + * dsp16xx.h (RTX_COSTS): Likewise. + +Thu Nov 17 11:06:43 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.c (some_operand): New function. + * alpha.h (PREDICATE_CODES): Add `some_operand'. + * alpha.md (addsi3, adddi3): For patterns valid only + during reload, allow operand 1 to be `some_operand'. + + * flow.c (find_auto_inc): Insert missing "return" statement. + + * c-common.c (print_char_table): Allow `L' for `u'. + +Thu Nov 17 10:15:50 1994 Richard Stallman <rms@mole.gnu.ai.mit.edu> + + * config.sub: Accept -domain as OS, and make it default for Apollo. + +Wed Nov 16 19:28:46 1994 Jim Wilson (wilson@chestnut.cygnus.com) + + * loop.c (move_movables): For move_insn case, skip notes when deleting + instructions. + +Wed Nov 16 16:13:48 1994 Ian Lance Taylor (ian@cygnus.com) + + * bi-run.h: Always check BITS_BIG_ENDIAN, BYTES_BIG_ENDIAN, and + WORDS_BIG_ENDIAN at run time, never at compile time. + * bytecode.h, combine.c, cse.c, dbxout.c, dwarfout.c: Likewise. + * expmed.c, expr.h, final.c, fold-const.c, function.c: Likewise. + * jump.c, objc-act.c, real.c, real.h, recog.c, reload.c: Likewise. + * reload1.c, sdbout.c, tree.c, varasm.c: Likewise. + * real.c: Replace uses of MIEEE and IBMPC with a compile time + check of IEEE and a runtime check of FLOAT_WORDS_BIG_ENDIAN. + * libgcc.2 (LIBGCC2_WORDS_BIG_ENDIAN): If not defined, define to + WORDS_BIG_ENDIAN. Use it instead of WORDS_BIG_ENDIAN. + * mips-tfile.c (init_file): Initialize fBigendian field based on + HOST_WORDS_BIG_ENDIAN, not BYTES_BIG_ENDIAN. + * config/mips/mips.h (MASK_BIG_ENDIAN): Define, replacing + MASK_UNUSED4. + (TARGET_BIG_ENDIAN): Define. + (TARGET_SWITCHES): Add eb and el. Include TARGET_ENDIAN_DEFAULT + in default value. + (TARGET_ENDIAN_DEFAULT): Define if not defined, based on + DECSTATION. + (CC1_SPEC): Convert -EB to -meb, convert -EL to -mel, and warn if + -EB and -EL are both used. + (CPP_SPEC): If -EB is seen, undefine MIPSEL, _MIPSEL, __MIPSEL and + __MIPSEL__, and define _MIPSEB, __MIPSEB, __MIPSEB__ and MIPSEB + (the last only if -ansi was not seen). Similarly if -EL is seen. + (REAL_ARITHMETIC): Define. + (BYTES_BIG_ENDIAN, WORDS_BIG_ENDIAN): Base on TARGET_BIG_ENDIAN. + (LIBGCC2_WORDS_BIG_ENDIAN): Define. + (CONST_COSTS): Use split_double in CONST_DOUBLE case. + * config/mips/mips.c (mips_move_2words): Use split_double rather + than CONST_DOUBLE_LOW and CONST_DOUBLE_HIGH. + (output_block_move): Check BYTES_BIG_ENDIAN at run time, not + compile time. + (print_operand): Check WORDS_BIG_ENDIAN, rather than using + MOST_SIGNIFICANT_WORD and LEAST_SIGNIFICANT_WORD. + * config/mips/t-mips (MULTILIB_OPTIONS, MULTILIB_DIRNAMES, + MULTILIB_MATCHES, LIBGCC, INSTALL_LIBGCC): Define to build both + big and little endian versions of libgcc.a. + * config/mips/t-mips-gas: LIkewise. + * config/mips/dec-bsd.h (CPP_SPEC): Same change as in mips.h. + * config/mips/dec-osf1.h (CPP_SPEC): Likewise. + * config/mips/iris3.h (CPP_SPEC): Likewise. + * config/mips/iris5.h (CPP_SPEC): Likewise. + * config/mips/osfrose.h (CPP_SPEC): Likewise. + (CC1_SPEC): Same change as in mips.h. + +Wed Nov 16 16:04:21 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (rescan): Remove unnecessary comparisons of ibp to limit. + +Wed Nov 16 07:48:17 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * regclass.c (record_reg_classes): Handle case of single SET + between a hard register alone in a class and a pseudo. + + * tree.c (integer_{zero,one,all_ones,pow2}p): Handle COMPLEX_CST. + (real_{zero,one,two}p): Likewise. + + * gcc.c (main): For -V output, give both driver and compiler + versions, if they differ. + + * toplev.c (rest_of_compilation): Always rerun jump_optimize + after CSE if -O2. + + * fold-const.c (fold): If moved conversion into COND_EXPR, + leave it there if it is an integral conversion to word or narrower. + (fold, case NOP_EXPR): Ignore conversion to same type as operand. + (fold, case COND_EXPR): Make third operand the simplest. + + * expr.c (convert_move): Don't put FROM in a register if it + is a SUBREG. + (store_expr): If don't want a value and storing into promoted + variable, do conversion at tree level; don't copy volatile MEM + unless want value, as comment says. + +Tue Nov 15 20:02:34 1994 Doug Evans (dje@cygnus.com) + + * varasm.c (named_section): New argument decl, all callers changed. + * h8300/h8300.h, sh/sh.h, sparc/sysv4.h (ASM_OUTPUT_SECTION_NAME): + New arg DECL. + +Mon Nov 14 15:07:19 1994 Jason Merrill <jason@phydeaux.cygnus.com> + + * tree.h (POINTER_TYPE_P): New macro. + * m68k/m68kv4.h, m68k/mot3300.h (FUNCTION_VALUE): Use + POINTER_TYPE_P rather than checking the type against + POINTER_TYPE (to include references). + * function.c (init_function_start): Ditto. + + * alpha/alpha.h (FUNCTION_VALUE): Use INTEGRAL_MODE_P rather than + checking the type against various integral and pointer types. + + * m68k/{3b1,3b1g,crds,mot3300}.h: Don't define __PTR_TO_INT and + __INT_TO_PTR. + * m68k/xm-{3b1,crds,mot3300}.h: Define __PTR_TO_INT and __INT_TO_PTR. + +Tue Nov 15 19:29:04 1994 Per Bothner <bothner@kalessin.cygnus.com> + + * tree.c (staticp): A non-nested function is always static. + +Tue Nov 15 19:12:03 1994 Jim Meyering (meyering@comco.com) + + * Makefile.in (specs, float.h-cross, xlimits.h): Use temporary instead + of redirecting output directly to make target. + ($(MD_FILE), xsys-protos.h): Likewise. + (mostlyclean): Remove any of these temporaries. + (libgcc2.a): Add missing semicolon in commented code that could cause + a /bin/sh syntax error if uncommented. + +Tue Nov 15 19:07:00 1994 Warner Losh (imp@village.org) + + * i386/freebsd.h (NO_IMPLICIT_EXTERN_C): Define. + +Tue Nov 15 19:00:55 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * reorg.c (redundant_insn): Renamed from redundant_insn_p; all + callers changed. + +Tue Nov 15 18:57:46 1994 Jim Wilson (wilson@chestnut.cygnus.com) + + * reorg.c (relax_delay_slots): When invert a conditional jump over a + single unconditional jump, invert the INSN_FROM_TARGET_P bit of insns + in the delay slots. + + * reorg.c (redundant_insn_p): Change return type to rtx. Return the + redundant insn instead of true. + (update_reg_unused_notes): New function. + (fill_slots_from_thread): Call update_reg_unused_notes after one of + the redundant_insn_p calls. + +Tue Nov 15 18:39:33 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * expmed.c (expand_divmod, case ROUND_DIV_EXPR): Implement. + * expr.c (do_jump_by_parts_greater_rtx): No longer static. + (expand_expr): Delete code for plain `abs'. + * optabs.c (expand_abs): New function, code moved from expand_expr. + * expr.h: Declare expand_abs. + +Tue Nov 15 12:11:26 1994 Jeffrey A. Law (law@mole.gnu.ai.mit.edu) + + * pa.c (output_cbranch): Improve code for short backwards branch + with an unfilled delay slot. + (output_bb, output_dbra, output_movb): Likewise. + +Tue Nov 15 09:55:31 1994 Doug Evans (dje@cygnus.com) + + * jump.c (delete_insn): Delete labels in ADDR_VECs and + ADDR_DIFF_VECs if their use count becomes zero. + * flow.c (flow_delete_insn): New function. + (find_basic_blocks): Call it to physically delete insns in + unreachable blocks. When scanning blocks after dead ones, + start scanning after the dead one (not at the dead one). + If there are lots of unreachable blocks, make another pass to squeeze + them out (this reduces memory usage in some pathalogical cases by a + significant amount without resorting to sparse matrices). + (propagate_block): Make code a bit more efficient (for example, + no need to test `loop_depth' for each insn, just notes). + +Tue Nov 15 09:42:31 1994 Lynn Shumaker (shumaker@saifr00.ateng.az.honeywell.com) + + * function.c (assign_stack_temp): Compute size of slot after + assign_stack_local has accounted for alignment. + +Mon Nov 14 23:47:20 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * pa.h (GO_IF_LEGITIMATE_ADDRESS): Allow + (lo_sum (reg) (unspec (symref))). + + * pa.md (pic2_lo_sum): New pattern matching when -fPIC using UNSPEC. + * pa.c (legitimize_pic_address): Generate an insn matching + pic2_lo_sum when -fPIC. + + * pa.md (pic_highpart): Add missing mode for PLUS. + (add_high_const): Likewise. + + * pa.md (matcher for plain lo_sum): Call abort if this happens + when generating pic or PIC. + +Mon Nov 14 23:47:20 1994 Jeffrey A. Law (snake.cs.utah.edu) + + * Automatic generation of inline long call sequences when needed. + * pa.h (TARGET_LONG_CALLS): Delete. Replace all uses of with + TARGET_PORTABLE_RUNTIME. + (TARGET_MILLICODE_LONG_CALLS): New target flag. + * pa.c (output_function_prologue): Keep track of the total number + of code bytes emitted for each source file. + (output_call): Handle TARGET_PORTABLE_RUNTIME and millicode calls + for TARGET_MILLICODE_LONG_CALLS. Emit an inline long-call if + needed. If emitting an inline long-call, perform argument relocations + before the call if they are needed, unfill the delay slot of the + call if necessary. + * pa.md (define_delay for millicode): Disable the delay slot if + TARGET_MILLICODE_LONG_CALLS. + (millicode insns and indirect calls): Properly compute length for + both TARGET_PORTABLE_RUNTIME and TARGET_MILLICODE_LONG_CALLS. + (call_internal_symref): Properly compute the length when more + than 240000 bytes of code have already been output. Take + TARGET_MILLICODE_LONG_CALLS into account in the length + computation. + + * pa.h (DBX_OUTPUT_MAIN_SOURCE_FILE_END): Define. + (ASM_FILE_END): Delete unneeded definition. + + * Fast indirect call support. + * pa.h (TARGET_FAST_INDIRECT_CALLS): New target switch. + (TARGET_SWITCHES): Add "fast-indirect-calls" and inverse. + * pa.md (call_internal_reg, call_value_internal_reg): Generate + appropriate code for TARGET_FAST_INDIRECT_CALLS. + + * PA PIC support. + * pa.c (secondary_reload_class): Refine. Readonly data needs a + secondary reload only during PIC generation. Loading a floating + point register with a constant requires a register from R1_REGS + during -fPIC code generation. + (read_only_operand): Constant pool entries are no longer read only + during PIC code generation. + (hppa_legitimize_address): If flag_pic is nonzero, then + immediately call legitimize_pic_address. + (emit_move_sequence): Call legitimize_pic_address to handle + constant data. Handle secondary reloads for PIC. Use + pic_label_operand rather than open coding the test. Handle + loading a LABEL_REF when generating PIC. + (legitimzie_pic_address): Handle constant data addressing for PIC + here. Fix loading of symbolic addresses for -fPIC generation. + (pic_label_operand): Renamed from pic_operand. Handle any read + only operand (such as constant data). Reject function addresses, + Accept SYMBOL_REF with the read-only bit set. Generalize to + handle (const (plus (reg) (int))). + (finalize_pic): Delete unused function. + (check_pic): Delete function. + (pic_pc_rtx): Delete variable definition. + (current_function_uses_pic_offset_table): Delete extern decl. + (force_reg, validize_mem): Likewise. + (output_global_address): Don't tack on "-$global$" when generating + PIC code. + (finalize_pic): Don't emit code for initialization of + hppa_save_pic_table_rtx here. Don't claim we USE + pic_offset_table_rtx at function end. + * pa.h (SELECT_RTX_SECTION): Define. During PIC generation + everything (in the constant pool) goes into the data space. + (PRINT_OPERAND_ADDRESS): Handle CONST_INTs during PIC + generation. Handle LO_SUM address during -fPIC generation. + (LEGITIMATE_CONSTANT_P): Reject function labels when generating + PIC code. + (GO_IF_LEGITIMATE_ADDRESS): Only accept pic_reg + SYMBOL_REF for + -fpic. + (EXTRA_SECTION_FUNCTIONS): For -fpic, use the TEXT section for + constants to avoid GAS lossage. + (OVERRIDE_OPTIONS): Delete. + (PIC_OFFSET_TABLE_REG_CALL_CLOBBERED): Define. + (FINALIZE_PIC): Delete definition. + (INIT_EXPANDERS): Define. Clear hppa_save_pic_table_rtx here. + * pa.md: Use !flag_pic rather than calling check_pic. + (HImode high and lo_sum): Only accept const_int_operands. + (pic_load_label): Force output to be in %r1. + (pic_highpart): New pattern. Output must go into %r1. More + linker trickery. + (symbolic high and lo_sum): Disallow during PIC generation if + source is a symbolic operand. Handle CONST_INT LO_SUM during PIC + generation. Simplify. + (define_split for symbolic_operand load): Do not accept a symbolic + operand that is a pic_label_operand. + (pic_load_label): Name this pattern. Mask least significant bits + and optimize when a simple label is within reach of an ldo. + (call, call_value): Emit new-style USE information for + pic_offset_table_rtx. Emit code for initialization of + hppa_save_pic_table_rtx and wrap it into push_topmost_sequence() + and pop_topmost_sequence() calls. + + * Various PA configuration cleanups. + * configure (hppa*-*-h[pi]ux): Use xm-pahpux.h and x-pa-hpux instead + of the redundant hiux files. Likewise for t-pa instead of t-pa-hpux. + * config/pa/xm-pahiux.h: Delete. It's identical to xm-pahpux.h. + * config/pa/x-pa-hiux: Delete. It's idential to x-pa-hpux. + * config/pa/x-pa (TAROUTOPTS): Delete. It was an HPUX host + conditional, and x-pa is a BSD host target fragment. + (INSTALL_HEADERS): Define. + (STMP_FIXPROTO): Define. + * config/pa/t-pa (INSTALLED_H): Delete. + * config/pa/t-pa-hpux: Delete, it's identical to t-pa. + * config/pa/pa-hiux.h: Include "pa/pa-hpux.h" and just override + the CPP predefines. + (CPP_PREDEFINES): Add -A assertions. + * config/pa/{pa1-hiux.h, pa-ghiux.h, pa1-ghiux.h}: Likewise. + * config/pa/pa-ghpux.h: Simplify by including pa-hpux.h. + (DBX_DEBUGGING_INFO): Define. + (DEFAULT_GDB_EXTENSIONS): Define. + +Mon Nov 14 19:16:00 1994 Dennis Glatting <war04!dennisg@kerby.ocsg.com> + + * fixincludes: Fixes for NextStep 3.2. Remove ``__const__'' from + sin and cos prototypes in ansi/math.h. Remove keyword ``template'' + from bfd/libc.h. Remove ``volatile'' from abort in bsd/libc.h + and abort and exit in ansi/stdlib.h. + +Mon Nov 14 18:54:28 1994 Douglas Rupp (drupp@cs.washington.edu) + + * i386/x-winnt (EXTRA_PROGRAM): Match target name. + +Mon Nov 14 18:48:21 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * freebsd.h (INCLUDE_DEFAULTS): Move definition beyond + FREEBSD_NATIVE conditional. + (FUNCTION_PROFILER): Move down to make file more similar to + netbsd-i386.h. + (DEFAULT_TARGET_MACHINE, etc): Comment our this braindamage! + +Mon Nov 14 18:46:18 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * calls.c (expand_call): If IS_CONST and VALREG == 0, end our + sequence and emit the insns. + +Sat Nov 12 06:35:42 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * Version 2.6.2 released. + +Sat Nov 12 06:35:21 1994 Torbjorn Granlund (tege@cygnus.com) + + * expmed.c (expand_divmod, case TRUNC_DIV_EXPR): Promote signed + division by 0x80000000 to unsigned. + +Fri Nov 11 17:07:35 1994 Michael Meissner (meissner@osf.org) + + * c-common.c (decl_attributes): Add double-underscore version of + printf and scanf for format type. + +Fri Nov 11 16:38:04 1994 Jim Wilson (wilson@chestnut.cygnus.com) + + * mips-tdump.c: Include <time.h>. Delete ctime prototype. + +Fri Nov 11 14:16:00 1994 Holger Teutsch <holger@hotbso.rhein-main.de> + + * clipper.md (movsi+1): Allow r->m move during reloading. + +Fri Nov 11 12:40:51 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * c-decl.c (duplicate_decls): Properly merge decls with + differing DECL_CONTEXT. + + * function.c (preserve_rtl_expr_result): find_temp_slot_from_address + now used. + Don't bring the temp slot to an inner level than it was. + (assign_stack_temp): Always initialize p->rtl_expr. + + * m68k/mot3300g.h (SPACE_AFTER_L_OPTION): Deleted. + +Thu Nov 10 18:50:52 1994 Kresten Krab Thorup (krab@next.com) + + * objc/list.h: Add ifndef/define for repeated inclusion. + +Thu Nov 10 18:02:58 1994 Michael Meissner <meissner@pasta.osf.org> + + * c-common.c (decl_attributes): Check for attributes with leading + and trailing double underscores. + +Thu Nov 10 17:55:07 1994 Chris Metcalf (metcalf@catfish.lcs.mit.edu) + + * fixincludes: Make argument type const for popen and tempnam in + stdio.h and for strdup in string.h, for OSF/1 V3.0. + + * va-alpha.h (va_arg): Add cast to void * to suppress warning. + +Thu Nov 10 17:48:21 1994 Walter Misar (hrz.th-darmstadt.de) + + * m68k/hp320.h (FUNCTION_{PRO,EPI}LOGUE): Don't define. + (IMMEDIATE_PREFIX, REGISTER_PREFIX): Define. + +Thu Nov 10 15:04:57 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * m68k/crds.h (FUNCTION_{PRO,EPI}LOGUE): Add code to adjust stack + when no frame pointer. + * m68k.c (output_function_epilogue): Use a1 as scratch, not a0. + * m68k/tower-as.h (FUNCTION_{PRO,EPI}LOGUE): No longer defined. + (FUNCTION_EXTRA_EPILOGUE): Define. + * m68k/tower.h (REGISTER_PREFIX, IMMEDIATE_PREFIX): Define. + + * i386/x-sco, i386/x-sco4 (CLIB): Add -lPW. + (ALLOCA): Delete. + + * c-common.c ({print,scan}_char_table): Allow `L' modifier + for integer output formats. + (check_format_info): Treat `ll' like `q'. + + * rs6000.md (movsi): In TOC symbol case, use "la" for PowerPC. + (movdi): Handle TOC symbol just like movsi. + + * objc-act.c (init_objc): Add missing casts to args of bcopy. + (lang_init): Ensure line number is 0, not -1. + +Tue Nov 8 07:51:53 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (dump_single_macro, dump_defn_1): If -traditional, + dump macros in traditional style. This also avoids a bogus error + message if the macro uses traditional stringizing. + +Mon Nov 7 21:28:13 1994 Michael I Bushnell <mib@geech.gnu.ai.mit.edu> + + * protoize.c [!POSIX]: Only define O_RDONLY and O_WRONLY if not + already defined. + +Mon Nov 7 19:33:31 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * combine.c (try_combine): Update split_code after converting MULT + to ASHIFT. + +Mon Nov 7 12:26:24 1994 Torbjorn Granlund <tege@cygnus.com> + + * rs6000.md (DImode load-with-update matcher): Fix typo in MEM mode. + (compare patterns): Fix several typos, SImode => CCmode. + * sh.md (subdi3): Delete % from constraints. + * 1750a.md (subqi3): Likewise. + * clipper.md (subdi3): Likewise. + * i370.md (subqi3): Likewise. + (anonymous subqi3 matcher): Likewise. + * i860.md (subdi3): Likewise. + * dsp16xx.md (mulqi3): Fix typo in MULT mode. + * elxsi.md (one_cmplsi2): Fix typo in NOT mode. + +Mon Nov 7 12:47:37 1994 Ian Lance Taylor <ian@cygnus.com> + + * m68kv4.h (ASM_IDENTIFY_GCC): Use proper definition for SGS assembler. + +Mon Nov 7 11:02:25 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * gcc.c (process_command): Ignore LIBRARY_PATH and LPATH if + cross-compiler. + +Sun Nov 6 07:23:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cross-test.c (foo): Return value for BU in range for shifts. + +Sat Nov 5 14:25:36 1994 Jim Wilson (wilson@chestnut.cygnus.com) + + * m68k.h (PREFERRED_RELOAD_CLASS): FP constants rejected by 'G' + are OK for class FP_REGS. + +Sat Nov 5 14:08:31 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * calls.c (store_one_arg): Preserve any temp slots whose address + may have been taken. + + * real.c (GET_REAL, PUT_REAL): Cast args to bcopy to char *. + * reload1.c (reload): Likewise. + * i386.c ({save,restore}_386_machine_status): Likewise. + * reg-stack.c (subst_asm_stack_regs): Likewise. + (BLOCK_NUM): Rework to avoid cast of abort to int *. + (find_blocks): Don't use BLOCK_NUM on lhs. + (reg_to_stack, record_arg_reg_life): Cast arg to bzero to char *. + +Sat Nov 5 08:29:45 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (rescan): Do not preserve newlines after macro name + if rescanning a macro expansion. Instead, preserve them if + not outputting marks. + +Fri Nov 4 17:25:29 1994 John David Anglin (dave@hiauly1.hia.nrc.ca) + + * vax.c: Include tree.h and VMS-specific functions #ifdef VMS_TARGET. + * vms.h (VMS_TARGET): Define. + +Fri Nov 4 17:19:30 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * bi-arity.c (main): Cast enum to char in output. + * bc-emit.c (bc_emit_bytecode): Add missing cast. + +Thu Nov 3 14:17:22 1994 Mike Stump <mrs@cygnus.com> + + * libgcc2.c (__register_exceptions): Find max ending of a segment for + end, not min. + * libgcc2.c (__unwind_function): New function to support stack + unwinding on i[34]86 for g++ exception handling. + +Thu Nov 3 18:55:42 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Makefile.in (c-parse.o, c-lex.o): c-parse.h is in $(srcdir). + +Thu Nov 3 18:11:56 1994 John F Carr (jfc@mit.edu) + + * rs6000.md (movsi): New alternative for SYMBOL_REF source operand. + * rs6000.c (print_operand): New code '*' to print TOC register number. + * rs6000.h (EXTRA_CONSTRAINT): 'R' matches a SYMBOL_REF for TOC entry. + (PRINT_OPERAND_PUNCT_VALID_P): Recognize '*'. + (PREDICATE_CODES): input_operand can now match SYMBOL_REF. + +Thu Nov 3 18:03:24 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * cccp.c: TOOL_INCLUDE_DIR is not C++-aware. + +Thu Nov 3 17:23:30 1994 Jim Wilson (wilson@chestnut.cygnus.com) + + * mips.c (mips_output_external): Exclude alloca from list of + used external functions. + +Tue Nov 1 19:19:41 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Version 2.6.1 released. + +Tue Nov 1 18:51:00 1994 Torbjorn Granlund (tege@cygnus.com) + + * pa.md (add_high_const): Add missing mode for PLUS. + +Tue Nov 1 18:39:53 1994 Stephen L Moshier (moshier@world.std.com) + + * cse.c (simplify_unary_operation, case TRUNCATE): Set LV and HV. + +Tue Nov 1 18:36:23 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax.c (struct extern_list): Put code back outside of #ifdef VMS. + (vms_check_external, vms_flush_pending_externals): Likewise. + +Mon Oct 31 16:18:12 1994 Michael Meissner <meissner@pasta.osf.org> + + * i386/i386.md (movsf, movdf, movxf): If we are moving floating + point constants to a non-memory location that aren't 0 or 1, + assume we need the pic register if -fpic. + +Mon Oct 31 13:26:45 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * sparc.h (GO_IF_LEGITIMATE_ADDRESS): Don't allow TFmode LO_SUM. + * sparc.md (movtf+3): Disable pattern. + +Mon Oct 31 08:11:47 1994 Doug Evans <dje@canuck.cygnus.com> + + * expr.c (expand_expr, COND_EXPR case): Don't use original target as + a temp if it's a volatile mem ref. Finish previous patch (don't + expand "X ? A & 1 : A" as "A & (X != 0)"). + +Mon Oct 31 08:07:09 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax.c: Include tree.h #ifdef VMS. + (struct extern_list): Move inside #ifdef VMS; add SIZE and IN_CONST + fields; make `extern_head' static; add second list head. + (vms_check_external): Move inside #ifdef VMS; give new args; maintain + list of both pending external symbols and previously defined ones. + (vms_flush_pending_externals): New function. + * vax/vms.h (ASM_GLOBALIZE_LABEL): Pass new args to vms_check_external. + (ASM_OUTPUT_EXTERNAL): Just call vms_check_external. + (ASM_{,FINISH_}DECLARE_OBJECT_NAME, ASM_FILE_END): Define. + +Mon Oct 31 08:00:59 1994 Michael Gschwind (mike@vlsivie.tuwien.ac.at) + + * pdp11.h (TARGET_SWITCHES): Add -split and -no-split. + (TARGET_SPLIT, TARGET_NOSPLIT): New macros. + (TRAMPOLINE_TEMPLATE, INITIALIZE_TRAMPOLINE): Abort if -split. + +Mon Oct 31 07:53:34 1994 Warner Losh <imp@village.org> + + * i386/x-freebsd (CLIB): Add definition. + +Mon Oct 31 07:49:17 1994 Jeffrey A Law <law@snake.cs.utah.edu> + + * reorg.c (mark_set_resources): Properly handle SUBREGs. + +Mon Oct 31 07:24:32 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (expand_expr, case COMPONENT_REF): Don't extract + field from a CONSTRUCTOR if it already has a TREE_CST_RTL. + (expand_expr, case ADDR_EXPR): Call mark_temp_addr_taken + on the temporary made when operand needs to be stored into memory. + * function.c (preserve_temp_slots): Preserve anything whose + address was taken when X is zero. + +Sun Oct 30 15:11:51 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * msdos/top.sed, i386/config-nt.sed: Update version to 2.6.1. + * pa/t-pa-hpux: Add missing newline at end. + +Sat Oct 29 21:16:29 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * emit-rtl.c (operand_subword): Fix typo: HOST_BITS_PER_INT + should be HOST_BITS_PER_WIDE_INT. + +Fri Oct 28 19:13:13 1994 Andrew McCallum (mccallum@vein.cs.rochester.edu) + + * objc/misc.c (__objc_xcalloc): Use calloc instead malloc/bzero. + +Fri Oct 28 19:07:53 1994 Michael Gschwind (mike@vlsivie.tuwien.ac.at) + + * pdp11.h (TRAMPOLINE_SIZE): Install real implementation. + (INITIALIZE_TRAMPOLINE, TRAMPOLINE_TEMPLATE): Likewise. + +Fri Oct 28 19:01:27 1994 Craig Burley (burley@gnu.ai.mit.edu) + + * Makefile.in (stage?-start): Add semicolon between fi and done. + +Fri Oct 28 17:12:26 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (cse_insn): Don't record a DEST if paradoxical SUBREG + and SRC is a SIGN_EXTEND or ZERO_EXTEND. + + * alpha.md (reload_outqi): Correctly handle scratch assignments + for unaligned case when ADDR is a REG. + +Fri Oct 28 07:55:40 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.md (adddi3): Fixup code in case operands[0] is equal + to operands[2]. + +Thu Oct 27 18:58:39 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (count_possible_groups): Fix typo in setting + counted_for_groups. + +Thu Oct 27 15:30:41 1994 Per Bothner <bothner@kalessin.cygnus.com> + + * c-typeck.c (process_init_element): In the case of + [LO .. HI] = VALUE, use save_expr to only evaluate VALUE once. + +Thu Oct 27 15:15:25 1994 Torbjorn Granlund (tege@rtl.cygnus.com) + + * gcc.c (process_command): Don't forget to split -Wl arguments at + commas. + + * gcc.c (process_command): Handle -Wl, and -Xlinker similar to -l, + i.e., preserve their order with respect to linker input files. + +Thu Oct 27 13:11:16 1994 Douglas Rupp (drupp@cs.washington.edu) + + * configure (i[345]86-*-winnt3*): Allow any version 3.x. + Don't use a t-winnt file and move x-winnt to config/i386. + * i386/x-winnt: Build ld-winnt.exe only on host. + * winnt/t-winnt: Deleted. + +Thu Oct 27 13:05:16 1994 Mike Collison (collison@chianti.sw.stratus.com) + + * reload.c (debug_reload): New function to print reload info + set up by find_reloads. + +Wed Oct 26 18:27:03 1994 David Mosberger-Tang <davidm@piston.cs.arizona.edu> + + * alpha.h (FUNCTION_PROFILER): Use $28 instead of $27. + (LINK_SPEC): Pass -pg to linker. + (LIB_SPEC): Link in -lprof1 with -pg, not -lprof2. + (STARTFILE_SPEC): USe gcrt0.o if -pg, not mcrt0.o. + +Wed Oct 26 18:22:34 1994 Doug Evans (dje@cygnus.com) + + * expr.c (expand_expr, COND_EXPR case): Don't expand + "X ? A & 1 : A" as "A & (X != 0)". + +Wed Oct 26 18:06:52 1994 Douglas Rupp (drupp@cs.washington.edu) + + * winnt/ld.c (expand_lib, main): Fix off-by-one bugs in several + calls to malloc. + +Wed Oct 26 22:00:09 1994 Richard Kenner <kenner@vlsi1.ultra.nyu.edu> + + * winnt/t-winnt: Remove some spurious blank lines. + +Wed Oct 26 14:14:39 1994 Michael Meissner (meissner@osf.org) + + * i386/osfrose.h (REAL_NM_FILE_NAME): Use /usr/ccs/gcc/bfd-nm + instead of /usr/ccs/bin/nm, since the GNU nm does not output stab + symbols by default. + +Wed Oct 26 13:47:06 1994 Michael Gschwind (mike@vlsivie.tuwien.ac.at) + + * config.sub (pdp11): New machine name. + * configure (pdp11-*-*): New configuration. + * pdp11.c, pdp11.h, pdp11.md, xm-pdp11.h: New files. + +Wed Oct 26 07:33:40 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * flow.c (find_basic_blocks): Ensure each live basic block is + actually reachable. + (life_analysis): Clean up handling of basic_block_drops_in. + +Tue Oct 25 18:40:12 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (rescan): ".." no longer terminates a preprocessing + number, since that's incompatible with the C standard. + +Tue Oct 25 16:16:40 1994 Michael Dobson (dobson@info.usuhs.mil) + + * we32k.h (CPP_PREDEFINES): Define u3b2, not u3b. + +Tue Oct 25 16:15:27 1994 Jim Wilson (wilson@cygnus.com) + + * reorg.c (fill_slots_from_thread): Update THREAD if it is split. + +Mon Oct 24 00:12:46 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * toplev.c (lang_options): Add -f{no-,}access-control. + +Mon Oct 24 06:14:03 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * arm/arm.md (peepholes for call followed by branch): Disable. + +Sun Oct 23 08:54:27 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * arm/x-riscix (INSTALL): Invoke install.sh with -c flag. + +Fri Oct 21 00:42:08 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * Makefile.in (LIB2FUNCS): Add _pure. + + * libgcc2.c (__pure_virtual): New function to go into vtable + entries for pure virtual methods instead of abort. + +Thu Oct 20 18:40:36 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.md (define_split comparison op with power of two minus 1): + Fix typo. + +Thu Oct 20 13:14:24 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * collect2.c (add_to_list): Check for duplicates. + + * alpha/alpha.h (LINK_SPEC): Pass -shared through; don't + pass -init __main if -shared. + (STARTFILE_SPEC): Wrap startfiles in %{!shared:}. + (INIT_NAME_FORMAT): Define. + (FINI_NAME_FORMAT): Define. + * alpha/osf12.h (LINK_SPEC): Ditto. + * alpha/gdb-osf12.h: #include osf12.h instead of alpha.h + + * gcc.c (STARTFILE_SPEC): Wrap startfiles in %{!shared:}. + +Thu Oct 20 16:07:46 1994 Jim Wilson (wilson@cygnus.com) + + * unroll.c (loop_iterations): Move all failure exits after the + computation of final_value. + + * mips.md (movdf_internal2+1): Disable when TARGET_64BIT. + + * i960.c (VARARGS_STDARG_FUNCTION): New macro. + (i960_function_name_declare, output_function_profiler, + i960_function_epilogue, i960_output_call_insn, i960_output_ret_insn, + i960_reg_parm_stack_space): Use it. + (compute_frame_size): Don't use current_function_pretend_args_size. + (i960_function_arg_advance, i960_function_arg): Don't use parameter + named. + (i960_setup_incoming_varargs): No need to adjust first_reg_offset + after setting it. Don't save last named argument to stack. + Don't set pretend_size. + * i960.h (SIGNED_CHAR_SPEC): Use #if instead of ?:. + * va-i960.h (va_start): Use builtin_arts_info instead of + builtin_next_arg. + + * cse.c (merge_equiv_classes, cse_insn): Call rehash_using_reg + after insert_regs. + (canon_hash): Don't use qty_const to compute hash code for a + register. + +Thu Oct 20 09:41:51 1994 Richard Kenner (kenner@vlsi1.ultra.nyu) + + * stor-layout.c (variable_size): Return SIZE if it contains + a PLACEHOLDER_EXPR. + +Tue Oct 18 19:51:24 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * collect2.c (main): Check REAL_*_FILE_NAME first. + +Wed Oct 19 15:55:15 1994 David J. MacKenzie <djm@duality.gnu.ai.mit.edu> + + * config.sub: Add licensing exception for Autoconf. + +Wed Oct 19 06:43:46 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.h (FUNCTION_BLOCK_PROFILER): Don't bother preserving + eax if -fpic, since it is a call clobbered register anyway. Fix -fpic + code so that it is correct. + +Tue Oct 18 18:00:23 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.h (FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): Move + macros here from osfrose, netbsd, and freebsd ports. Remove + assumptions that the assembler is gas. Rewrite and fix the + instructions produced with -fpic. + + * i386/osfrose.h (FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): Delete. + * i386/freebsd.h (FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): Delete. + * i386/netbsd-i386.h (FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): + Delete. + +Tue Oct 18 20:27:29 1994 Doug Evans (dje@cygnus.com) + + * sparc.h (FRAME_POINTER_REQUIRED): Require frame pointer if + non-leaf flat function. + * sparc.c (sparc_frame_info): Combine members gp_sp_offset and + fp_sp_offset into reg_offset. All uses changed. + (RETURN_ADDR_REGNUM): New macro. + (RETURN_ADDR_MASK, FRAME_POINTER_MASK): New macros. + (sparc_flat_compute_frame_info): Rename local mask to gmask. + Only ensure reg save area is 8 byte aligned if necessary. + (sparc_flat_save_restore): New arguments base_reg, offset, gmask, + and fmask. All callers changed. No longer use %g2 to save regs + in big stack frames. + (sparc_flat_output_function_prologue): Delete local tsize. + Reorder storing of previous frame pointer and return address reg to + make it easier for gdb to identify flat functions. Decrement %sp + twice when saving call-saved regs in big frames. + Count fp regs as 4 bytes in assembler comment. + (sparc_flat_output_function_epilogue): Likewise when restoring + call-saved regs. + +Tue Oct 18 19:33:55 1994 Mike Collison (collison@sw.stratus.com) + + * reload1.c (reload): Correctly compute group additional needs when + the return register cannot be used as a spill register. + +Tue Oct 18 16:17:26 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * mips.h (ASM_SPEC): Pass -mcpu= option to GNU as. + +Tue Oct 18 08:39:49 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * flow.c (propagate_block): Call mark_used_regs to show global regs + used by call. + * combine.c (can_combine_p): Don't combine into CALL_INSN where + DEST is a global reg. + + * c-decl.c (start_function): Save immediate_size_expand + and initialize it to zero in case nested function. + + * pa.c (non_hard_reg_operand): New function. + * pa.md (reload_{in,out}*): Replace general_operand with + non_hard_reg_operand. + +Fri Oct 14 18:35:30 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * gcc.c (default_compilers): Treat files with an extension of .c++ + as C++ code. + +Mon Oct 17 19:21:57 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * configure (rs6000-ibm-aix4.1*): New configuration. + * rs6000/aix41.h: New file. + +Mon Oct 17 19:15:14 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * va-mips.h (va_arg): Add little endian mips3 support. + + * sparc.h (RETURN_IN_MEMORY): Return true for TCmode values. + + * README.IRIX5: Delete. + * install.texi: Update Irix 5 debugging info. + + * mips.c (function_prologue): Only emit line number when SDB_DEBUG. + + * configure: Delete new argument, --noguess. Default build from + host if host specified, otherwise guess build. Fix typo in + setting build from host. + +Mon Oct 17 15:54:56 1994 Per Bothner <bothner@kalessin.cygnus.com> + + * calls.c (expand_call, emit_library_call, emit_library_call_value): + Allways adjust current_function_outgoing_args_size, even #ifndef + ACCUMULATE_OUTGOING_ARGS. (Useful for stack overflow checking.) + * function.c (current_function_outgoing_args_size): Update comment. + +Mon Oct 17 18:49:01 1994 Paul Eggert <eggert@twinsun.com> + + * cccp.c (rescan): Preserve newlines after macro names at the top level + since this is more likely to do the right thing with line numbers. + +Mon Oct 17 11:31:42 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (gen_reload): Renamed from gen_input_reload. + (emit_reload_insns): Delete SECONDARY_MEM_NEEDED case for input + reloads that can't happen and doesn't work. + Fix errors in use of reload_outxx insns. + Simplify output reload code by using gen_reload. + * reload.h (gen_reload): Renamed from gen_input_reload. + +Mon Oct 17 09:26:57 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * unroll.c (copy_loop_body, case JUMP_INSN): Don't abort if invert_exp + fails. Instead, redirect the jump around an unconditional branch. + +Sun Oct 16 05:02:23 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * emit-rtl.c (add_insn_{before,after}): Don't abort because AFTER was + deleted when not optimizing. + +Fri Oct 14 19:26:28 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.c (emit_move_sequence): Handle secondary reload when loading + a constant into SAR. + +Fri Oct 14 10:29:31 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * fixincludes: Fix X11/Intrinsic.h for RISCiX to remove ___type from + XtOffset. + Add all files that receive special attention to REQUIRED, so that + dependent copies are done if necessary. + + * getpwd.c: Always use getwd if HAVE_GETWD is defined. + * arm/xm-arm.h: Define HAVE_GETWD. + + * arm/x-riscix, arm/t-riscix: New files + * configure (arm-*-riscix*): Use them. + +Thu Oct 13 17:12:27 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * i960.md (call, call_internal, call_value, call_value_internal): + Use memory_operand not general_operand. + + * optabs.c (expand_fix): Correct typo with FIX/UNSIGNED_FIX + REG_NOTES. + +Thu Oct 13 10:44:32 1994 Ian Lance Taylor (ian@cygnus.com) + + * genattrtab.c (optimize_attrs): Don't do anything if + num_insn_ents is zero. + +Wed Oct 12 19:06:48 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * mips/mips.c (mips_expand_prologue): Handle types that need + constructing. Rename TYPE to PASSED_TYPE and use consistently. + +Wed Oct 12 11:32:05 1994 Ian Lance Taylor (ian@cygnus.com) + + * genattrtab.c (num_insn_ents): New static variable. + (remove_insn_ent): Decrement num_insn_ents. + (insert_insn_ent): Increment num_insn_ents. + (optimize_attrs): Use xmalloc to allocate all the attr_value_list + structures at once, rather than using alloca for each one. + +Wed Oct 12 09:17:34 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * optabs.c (??hf2_libfunc): Define like ??sf2_libfunc. + (emit_float_lib_cmp): Call HFmode library functions. + (init_optabs): Set names for HFmode comparison functions. + * expr.h (??hf2_libfunc): Add declarations, like ??sf2_libfunc. + +Tue Oct 11 19:20:48 1994 Douglas Rupp (drupp@cs.washington.edu) + + * winnt/ld.c (main): Pass -debug:full -debugtype:coff. + * winnt/t-winnt: Rework rules for ld. + * i386/config-nt.bat: Renamed from config/i386/config-winnt.bat. + Make specific for x86, not all winnt; change filenames. + * i386/config-nt.sed: Remove -g from CFLAGS. + Reflect changes to t-winnt and other minor changes. + * i386/x-winnt: Renamed from winnt/x-winnt. + * i386/config-nt.sed: Renamed from config/winnt/top.sed. + +Tue Oct 11 18:40:41 1994 Peter Schauer (Peter.Schauer@regent.e-technik.tu-muenchen.de) + + * rs6000.h (ASM_DECLARE_FUNCTION_NAME): Always put out .lglobl + for static functions. + +Mon Oct 10 19:19:51 1994 Alex T. Ramos (ramos@engr.latech.edu) + + * expr.c (convert_move): Add TImode conversions. + +Mon Oct 10 18:46:44 1994 Alex Dreyzen (alex@alex.jf.intel.com) + + * optabs.c (expand_float): Copy TEMP to TARGET when + making recursive call and adjusting. + +Mon Oct 10 07:10:25 1994 Michael Meissner (meissner@osf.org) + + * i386/linux.h (DEFAULT_PCC_STRUCT_RETURN): Do not define as 0 if + LINUX_ELF is defined. + (perform.h): Include perform.h to define asm statements to use for + libgcc1.a builds. + + * i386/linuxelf.h (DEFAULT_PCC_STRUCT_RETURN): Define as 1. + (RETURN_IN_MEMORY): Don't define. + +Sun Oct 9 11:49:20 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.md (movsf_mem): Add & constraint, so that the scratch + register does not clobber the destination address. + +Sun Oct 9 12:40:43 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * arm.md (reload_outdf): Don't call gen_addsi3 if the address is just + a register. + +Sat Oct 8 11:16:50 1994 Doug Evans (dje@cygnus.com) + + * objc/archive.c (__objc_free): New function. + (__objc_finish_read_root_object): Use it. + +Fri Oct 7 19:23:03 1994 J.T. Conklin (jtc@cygnus.com) + + * ginclude/stddef.h: Netware uses _SIZE_T_DEFINED_, _WCHAR_T_DEFINED_. + +Fri Oct 7 12:45:43 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.c (legitimate_address_p): Disable SUBREGs as either + the index or base register. + +Fri Oct 7 08:24:44 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * i386/gnu.h (CPP_PREDEFINES): Define __HURD__. + + * collect2.c (my_strerror): If HAVE_STRERROR defined, call strerror. + * xm-gnu.h (HAVE_STRERROR): Define. + + * function.c (preserve_temp_slots): If X cannot be a temp + slot, preserve all things whose address was taken at the + present level. + + * function.c (assign_stack_temp): Abort if SIZE == -1. + + * expr.c (safe_from_p): If EXP has a variable size, assume safe. + (preexpand_calls): Don't preexpand a call that returns a variable- + sized object. + + * emit-rtl.c (add_insn_{after,before}): Fix error in last change. + +Thu Oct 6 09:18:28 1994 Kresten Krab Thorup (krab@next.com) + + Adam Fedor (fedor@hopper.colorado.edu) + * objc/archive.c (__objc_finish_read_root_object): Delay freeing + of back-patch list. + + Andrew McCallum (mccallum@cs.rochester.edu) + * objc/objc.h (BOOL): Changed from char to unsigned char. + +Thu Oct 6 08:17:04 1994 Stan Cox (coxs@dg-rtp.dg.com) + + * m88k/m88k.c (emit_move_sequence): If operand1 is an invalid PIC + address, then legitimize it before doing anything else. + +Thu Oct 6 06:54:03 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (cse_insn): Don't call force_const_mem on (const (truncate)). + + * expr.c (store_expr): Don't clobber TEMP with address. + + * reorg.c (try_merge_delay_insns): Update THREAD if it is split. + + * function.c (struct temp_slot): New field addr_taken. + (assign_stack_temp): Initialize it. + (mark_temp_addr_taken): New function. + (preserve_temp_slots): Decrement level of things at same level + but whose address has been taken. + * expr.c (expand_expr, case ADDR_EXPR): Call mark_temp_addr_taken. + +Wed Oct 5 14:17:39 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * fold-const.c (fold, COMPONENT_REF): Don't die if the CONSTRUCTOR + doesn't initialize the field we want. + +Wed Oct 5 11:38:48 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.c (legitimize_pic_address): Changes to support + LABEL_REF references when using -fpic. + (output_pic_addr_const): Ditto. + (print_operand_address): Ditto. + + * i386/i386.md (movsi insn): Changes to support LABEL_REF + references when using -fpic. + (movsi_lea): Name insn supporting lea instruction so it shows up + more clearly when doing -dp. + +Wed Oct 5 06:56:36 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reorg.c (try_merge_delay_insns): Update THREAD if deleting first + insn in it. + +Wed Oct 5 01:19:14 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * configure (i[345]86-*-gnu*): Set xm_file=i386/xm-gnu.h. + * config/i386/xm-gnu.h: New file. + * config/xm-gnu.h: New file. + * config/i386/gnu.h: Move #include <fcntl.h> out of here, into + config/xm-gnu.h. + +Tue Oct 4 23:19:28 1994 Michael Meissner <meissner@pasta.osf.org> + + * protoize.c (POSIX includes): If POSIX is defined, include + sys/wait.h to get WIFSIGNALED, WTERMSIG, WIFEXITED, and + WEXITSTATUS. + +Tue Oct 4 21:48:02 1994 Michael I Bushnell <mib@churchy.gnu.ai.mit.edu> + + * config/i386/gnu.h: Include <fcntl.h> to get O_RDONLY definition. + * gcc.c (O_RDONLY): Define macro iff not already defined. + (read_specs): Second arg to open should be O_RDONLY, not constant 0. + +Tue Oct 4 19:06:38 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (do_jump_for_compare): Properly scan insns when + branch is at start of sequence. + +Tue Oct 4 16:53:54 1994 Ian Lance Taylor (ian@cygnus.com) + + * gcc.c, collect2.c, protoize.c (WIFSIGNALED): Define if not + already defined. + (WTERMSIG, WIFEXITED, WEXITSTATUS): Likewise. + * gcc.c (execute): Use them. + * collect2.c (do_wait): Likewise. + * protoize.c (gen_aux_info_file): Likewise. + +Tue Oct 4 16:38:06 1994 Michael Meissner <meissner@pasta.osf.org> + + * i386/i386.h (RETURN_IN_MEMORY): Define so that large types such + as complex double values get returned like structures do, and + don't overwrite %ebx. + +Tue Oct 4 15:58:21 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * lynx-ng.h, lynx.h (PREFERRED_DEBUGGING_INFO): Add undef before + define. + +Tue Oct 4 05:12:02 1994 Richard Stallman <rms@mole.gnu.ai.mit.edu> + + * config.sub: Translate -gnu/linux* to -linux*. + +Mon Oct 3 11:43:45 1994 Ian Lance Taylor (ian@cygnus.com) + + * config.sub: Add support for MIPS variants: mips64, mipsel, + mips64el, mips64orion, mips64orionel, mips3*. + +Sun Oct 2 18:26:34 1994 Jason Merrill (jason@phydeaux.cygnus.com) + + * function.c (push_function_context_to): Renamed from + push_function_context, adds argument to indicate that the new + function is not a nested function. + (push_function_context): Call it. + (pop_function_context{,_from}): Similarly. + + * tree.c (save_tree_status): Add argument to indicate that the new + function is not a nested function. + (restore_tree_status): Ditto. + +Sun Oct 2 18:05:37 1994 Doug Evans (dje@cygnus.com) + + * configure (i[34]86-*): Change to i[345]86-*. + (target_cpu_default): Treat i586 as an i486 (for now). + +Sun Oct 2 10:25:51 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * arm.md (movsf): If reloading, create a scratch from the target for + loading a constant into integer regs. + (movdf): Likewise. + + Support for variants that fault on unaligned addrs: + * arm.h (TARGET_SHORT_BY_BYTES): New macro. + (TARGET_SWITCHES): Recognize switches -m[no-]short-load-bytes. + (TARGET_DEFAULT): Only define if not already done so. + (PROMOTE_MODE): Promote HImode unsigned if TARGET_SHORT_BY_BYTES. + (SECONDARY_INPUT_RELOAD_CLASS): Need a scratch for reloading HImode if + TARGET_SHORT_BY_BYTES. + * arm.c (arm_reload_in_hi): New function. + * arm.md (zero_extendhisi2, extendhisi2): Expand to suitable byte + sequence when TARGET_SHORT_BYTES and loading a mem. + (movhi_bytes, extendhisi2_mem): New expands. + (movhi): Call movhi_bytes to load a short from memory if + TARGET_SHORT_BY_BYTES. + (all matchers loading a short from memory): Don't match if + TARGET_SHORT_BY_BYTES. + (matcher for movhi when TARGET_SHORT_BY_BYTES): New pattern to cover + remaining valid cases. + +Sun Oct 2 08:54:30 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reg-stack.c (subst_stack_regs): Check for NOTE to see if insn was + deleted. + + * reorg.c (fill_slots_from_thread): Update THREAD if deleting + its first insn. + + * reg-stack.c (delete_insn_for_stacker): Don't set INSN_DELETED_P + on NOTE_INSN_DELETED. + +Sat Oct 1 20:42:33 1994 Chip Salzenberg <chip@fin.uucp> + + * sco4.h (CPP_PREDEFINES): Remove i386, unix. + (CPP_SPEC): Add them here, so that they're undefined if -ansi. + Also add _i386 and _unix, which are always defined. + * x-sco (CLIB): Add "-lmalloc". + (ALLOCA): Define as "-lPW". + * x-sco4 (CC, OLDCC, RCCFLAGS, CCLIBFLAGS, CLIB, ALLOCA): From x-sco. + (X_CFLAGS): Remove. + +Sat Oct 1 14:27:45 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.md (movsf_push386): Rename to movsf_push_nomove. + (movdf_normal): Prefer to use float registers rather than general + purpose registers. + +Sat Oct 1 07:01:10 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * c-decl.c (shadow_label): Emit an error if the label is already + declared at this label scope. + +Sat Oct 1 06:44:58 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * emit-rtl.c (add_insn_{before,after}): Abort if insertion point is + a deleted insn. + * jump.c (jump_optimize): When deleting a jump, properly set NEXT. + (duplicate_loop_exit_test): Don't insert NOTE_INSN_LOOP_VTOP + before deleted insn; insert first, then delete. + + * gcc.c: Install omitted hunk from last diff. + +Fri Sep 30 18:26:11 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * emit-rtl.c (add_insn_after): Abort if can't find AFTER and it + has no NEXT_INSN. + (add_insn_before): New function. + (emit_{insn,insns,jump_insn,call_insn,barrier,note}_before): Call it. + +Fri Sep 30 17:33:41 1994 Douglas Rupp (drupp@cs.washington.edu) + + * config.sub (windowsnt): Alias for winnt. + (winnt): New OS name. + * configure (extra_programs): New, like extra_parts. + (i[34]86-*-winnt3.1): New configuration. + * genattr.c (atoi): Remove declaration. + * getpwd.c: #ifdef WINNT, include direct.h. + * sdbout.c: Don't include syms.h for winnt. + * toplev.c: Don't include times.h for winnt. + (get_run_time): Just return zero for winnt. + (main): Don't print memory usage for OS/2 or winnt. + * cccp.c (main): Use DIR_SEPARATOR if defined. + Use "Include" environment variable instead of CPATH for winnt. + * gcc.c: Don't include sys/file.h for winnt; use process.h instead. + (concat): Now just concats two things; all callers changed. + (concat[346]): New functions. + (dir_separator_str): New variable. + (exec_prefixes, startfile_prefixes, include_prefixes): Renamed + from same names without plural; all users changed. + (find_a_file, process_command, do_spec_1): Use DIR_SEPARATOR. + (find_file, is_directory, main): Likewise. + (lookup_compiler): If OS/2, do case-independent search. + (fix_argv): New function on winnt. + (FIX_ARGV): New macro for some systems; use instead of argv. + * i386/unix.h: Treat ALMOST_STDC like __STDC__. + (AS2C): New macro. + * i386.c (output_387_binary_op): Use AS2C instead of AS2 with + null first arg. + * config/winnt/config-nt.bat, config/winnt/ld.c: New files. + * config/winnt/{[tx]-winnt, config/winnt/top.sed: New files. + * config/winnt/winnt.h, config/winnt/xm-winnt: New files. + * i386/winnt.h, i386/xm-winnt.h: New files. + +Thu Sep 29 19:53:14 1994 Jim Wilson (wilson@cygnus.com) + + * sparc.md (movdf+3): Handle overlapping registers in define_split. + + * gcc.c (default_compilers): Add %Z to all cpp specs. + (n_preprocessor_options, preprocessor_options): New variables. + (process_command): Handle -Wp option. + (do_spec_1): Handle %Z spec. + + * i960/i960-coff.h: New file. + * t-960bare: New file. + * config.sub (os): Accept coff as an OS. + * configure (i960-*-coff): New configuration. + + * expr.c (result_vector): Use INCOMING_REGNO when !savep instead + of when savep. + * sparc.md (call): Use struct value pattern is struct size is not + equal to zero instead of greater than zero. + (call+7, call+8): New patterns for untyped calls. + (untyped_call): Revise to emit explicit rtl for all operation. + Delete four old patterns that matched the unexpanded untyped_call + pattern. + (blockage): New pattern. + (flush_register_windows): Modify from 0 to 1. + (goto_handler_and_restore): Modify from 1 to 2. + (flush): Modify from 2 to 3. + * sparc.c (sparc_initialize_trampoline): FLUSH is now 3 not 2. + + * calls.c (emit_library_call): For FUNCTION_ARG_PASS_BY_REFERENCE, + pass address through force_operand before using it. + + * i960.c (i960_setup_incoming_varargs): Store parameter registers + at proper offset in argument block. + +Thu Sep 29 16:39:32 1994 Mike Stump <mrs@cygnus.com> + + * stmt.c (expand_return): We have to be careful of cleanups that can + be generated when expanding the return value, as they might otherwise + wipe out the return value. + +Thu Sep 29 13:35:24 1994 Mike Stump <mrs@cygnus.com> + + * expr.c (do_jump): Handle cleanups in TRUTH_ANDIF_EXPR and + TRUTH_ORIF_EXPR. + +Thu Sep 29 13:23:56 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * gcc.c (struct option_map): Sort in alphabetical order. + (translate_options): Ignore option once an error occurs. + Fix error with reversed 'a' and 'o'. + Give error if specified abbreviation is unambiguous. + + * c-typeck.c (convert_for_assignment): When converting object + to union, allow converting the constant zero into a pointer + member of the union. + +Wed Sep 28 19:33:01 1994 Alex T Ramos (ramos@engr.latech.edu) + + * machmode.def (PSImode): Widens to PDImode. + * expr.c (convert_move): Added handling of PDImode conversions. + +Wed Sep 28 19:24:17 1994 H.J. Lu (hjl@nynexst.com) + + * configure: Don't make objc-runtime if cross-compiling gcc. + * build-make (FIXINCLUDES): Set to Makefile.in. + +Wed Sep 28 19:18:19 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * function.c (trampoline_address): Add missing call to + round_trampoline. + +Wed Sep 28 18:34:13 1994 Michael Meissner (meissner@osf.org) + + * config/svr4.h (ESCAPES): Print \v in octal rather than as '\v', + since some older versions of gas didn't accept it. + +Wed Sep 28 14:29:20 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Comment out loop which handles symbolic links to + files. It appears to not work, and to be unnecessary. + +Tue Sep 27 19:27:56 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.h (ENCODE_SECTION_INFO): Only calls may go through the + PLT. All address loads, even function address loads, have to + go through the GOT or function addresses will not be unique. + +Tue Sep 27 19:20:12 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (newline_fix, name_newline_fix): Don't treat \r + specially here; it only causes bugs. This undoes the + May 14 16:01:13 1990 change to newline_fix and name_newline_fix. + +Tue Sep 27 19:02:55 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * m88k.h (ASM_OUTPUT_SOURCE_LINE): Add missing #undef. + +Tue Sep 27 18:32:17 1994 William J. Eaton (wje@hoffman.rstnu.bcm.tmc.edu) + + * function.c (optimize_bit_field): Put any insns made by + change_address in front of INSN. + (expand_function_end): Don't pass DECL_INITIAL to setjmp_protect + if it is error_mark_node. + + * genoutput.c, reload.c (n_occurrences): Make arg int, not char. + * objc-act.c (warn_with_method): Likewise. + + * optabs.c (expand_fix): Call emit_library_call_value. + +Tue Sep 27 12:39:10 1994 Mike Stump (mrs@cygnus.com) + + * Makefile.in, libgcc2.c (L_eh): some support routines for C++. + +Mon Sep 26 06:45:20 1994 Michael Meissner (meissner@osf.org) + + * 386/i386.md (adddi3, subdi3): Rewrite to add a clobber of a + scratch variable, so that memory/memoroy adds and subtracts can be + done using just one scratch register. Also, don't require op1 to + be the same as op0. + +Fri Sep 23 19:03:09 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/i386/gnu.h (LIB_SPEC): Remove macro. + +Fri Sep 23 16:11:26 1994 Michael Meissner (meissner@osf.org) + + * i386/lynx-ng.h (CALL_USED_REGISTERS): Copy definition from + i386/lynx.h that makes ebx be a call clobbered register, since + some system calls evidently trash it. + +Fri Sep 23 15:54:53 1994 Jim Wilson (wilson@cygnus.com) + + * configure (mips-*riscos*): Changed to mips-*-riscos*. + (mips-*-riscos*-*): Deleted. + + * cse.c (invalidate): New parameter FULL_MODE. All callers + changed. + (set_nonvarying_address_components): Modify initial comment. + (cse_insn): When call invalidate for dest, use the actual dest not + inner_dest. + +Thu Sep 22 18:56:19 1994 Torbjorn Granlund (tege@cygnus.com) + + * expmed.c (expand_divmod): Special case for signed CEIL_DIV_EXPR + when divisor is power of 2. + +Thu Sep 22 12:28:53 1994 Jason Merrill (jason@deneb.cygnus.com) + + * fixinc.svr4: Fix size_t, ptrdiff_t and wchar_t like fixincludes + does. Use extern inline rather than static inline in byteorder.h. + +Thu Sep 22 12:22:03 1994 Steve Dum (steve_dum@mentorg.com) + + * collect2.c (main): Discard the first executable once we've + exploited it. + +Thu Sep 22 11:38:34 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Tweaks for LynxOS 2.2.2: accept spaces after # when + removing #define void int in curses.h; change prototype of fnctl + in fcntl.h to match POSIX.1. + +Thu Sep 22 07:18:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * configure: Consistently put specified manufacturer names ahead + of entries with wildcard manufacturers. + + * calls.c (emit_call_1): Fix typo in last change. + +Wed Sep 21 21:32:56 1994 Chris Smith (csmith@convex.com) + + * config.guess: Add convex c3* and c4* guesses. + * configure: Don't run fixincludes on convex. + +Wed Sep 21 15:59:12 1994 Ashley Saulsbury (ans@sics.se) + + * alpha.h (ASM_FILE_START): Write .set volatile. + +Wed Sep 21 14:45:45 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * calls.c (emit_call_1): Properly add a CLOBBER for sp + to CALL_INSN_FUNCTION_USAGE. + + * c-typeck.c (mark_addressable): Give different error if trying + to put object with volatile fields into register; don't use DECL_NAME. + +Wed Sep 21 14:02:10 1994 Jim Wilson (wilson@cygnus.com) + + * reload1.c (eliminate_regs): Make test in LOAD_EXTEND_OP case + more precise. + +Wed Sep 21 11:34:12 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Don't try to remove empty directories until after + removing DONE files. + +Wed Sep 21 05:52:49 1994 Uwe Seimet (seimet@chemie.uni-kl.de) + + * m68k/atari.h (NO_{DOLLAR,DOT}_IN_LABEL): Define. + +Tue Sep 20 20:06:08 1994 Doug Evans (dje@cygnus.com) + + * final.c (asm_insn_count): Handle ASM_INPUTs too. + +Tue Sep 20 19:32:10 1994 Oliver Kellogg (okellogg@salyko.cube.net) + + * 1750a.h, 1750a.c, 1750a.md: New files, to use as1750. + * 1750a/m1750.inc: File deleted. + * 1750a/ms1750.inc: New file. + +Tue Sep 20 17:55:50 1994 Hallvard B Furuseth (hbf@durin.uio.no) + + * cccp.c (make_definition): Enable `-D' with macro arguments. + +Tue Sep 20 17:49:47 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cexp.y (HOST_WIDE_INT, HOST_BITS_PER_WIDE_INT): New macros. + (expression_value): Now HOST_WIDE_INT. + (parse_c_expression): Now returns HOST_WIDE_INT. + * cccp.c (eval_if_expression): Likewise. + (do_if, do_elif): Reflect new return value of functions. + + * alpha.c (mode_mask_operand): Always return a value. + + * function.c (pop_function_context): Clear reg_renumber. + + * gcc.c (process_command): Add new switch, -dumpmachine. + +Tue Sep 20 15:57:40 1994 Jim Wilson (wilson@cygnus.com) + + * sched.c (sched_analyze_insn): Parameter loop_note type changed + to rtx, and name changed to loop_notes. Code adding it to + REG_NOTES modified to account for type change. + (sched_analyze): Variable loop_note type changed to rtx, and name + changed to loop_notes. Store LOOP_* REG_DEAD notes in it instead + of LOOP_* NOTE_LINE_NUMBER. + (schedule_block): Pass last not insn to emit_note_before call. + + * iris5.h (ASM_OUTPUT_UNDEF_FUNCTION): Define. + (ASM_OUTPUT_EXTERNAL_LIBCALL): Define. + (ASM_DECLARE_FUNCTION_SIZE): Define. + * mips.c (mips_output_external): Use ASM_OUTPUT_UNDEF_FUNCTION. + (mips_output_external_libcall): New function. + (mips_asm_file_end): Handle ASM_OUTPUT_UNDEF_FUNCTION. + * README.IRIX5: Update. + +Tue Sep 20 14:39:37 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.h (output_move_memory): Add declaration. + (output_move_pushmem): Ditto. + + * i386/i386.c (output_move_pushmem): New function to handle + pushing bytes from memory onto the stack, possibily using + temporary registers. + (output_move_memory): New function to handle moving bytes from + memory to memory via temporary registers. + + * i386/i386.md (movsi insn): If -fpic and the value we are moving + is a constant pool address, emit a leal instruction instead of + movl. + (movsf_push): Allow pushes from memory. + (SF, DF, XF, DI pushes): Move most of the code to the common + function output_move_pushmem. + (SF, DF, XF, DI memory->memory moves): Move most of the code to + the common function output_move_memory. + (DI move patterns): Combine DI patterns into two, one for pushes, + and one for everything else, so that the combiner will combine a + load with a store into a memory->memory move. + (untyped_call): Replace non-working code with m68k version that + emits a regular call, then breaks the parallel moves into separate + moves, and then issue a blockage instruction. + (blockage): New unspec_volatile insn to block insns from being + moved across this point. + (untyped_return): Delete. + (update_return): Delete. + + * objc/sendmsg.c (get_imp): Allow __inline__ on x86 platforms. + +Tue Sep 20 12:21:12 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Handle the case of a symlink to root/* from a + subdirectory of another symlink to root/*. + +Mon Sep 19 20:30:21 1994 Jason Merrill (jason@deneb.cygnus.com) + + * fold-const.c (fold): Handle COMPONENT_REFs involving CONSTRUCTORs. + +Mon Sep 19 20:25:38 1994 Will Athanasiou (will@westford.ccur.com) + + * rs6000.md (load sf with update): Fix RTL typo. + +Mon Sep 19 08:46:46 1994 Charles M. Hannum (mycroft@duality.gnu.ai.mit.edu) + + * c-common.c (check_format_info): Enable checking of format + specifiers using the `q' (quad) length modifier. + (format_char_info): Add `qlen'. + (print_char_table, scan_char_table): Add appropriate entries for + qlen. + +Sat Sep 17 12:48:57 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * stmt.c (mark_seen_cases): Don't call fatal (or do anything + else) if case index out of range. Warning is given later. + +Fri Sep 16 19:22:46 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * global.c (global_alloc): Mark regs assigned to SCRATCH as used by + more than just local alloc. + +Thu Sep 15 14:36:59 1994 Michael Meissner <meissner@pasta.osf.org> + + * i386/i386.c (order_regs_for_local_alloc): Instead of using + flag_cse_follow_jumps and not leaf_function_p to determine whether + to allocate EDX, and ECX before EAX, use whether or not a DImode + variable was used in the compilation. DImode variables seem to + cause spill failures if EAX is allocated first, while smaller code + is generated if EAX is allocated first, assuming no spill failure. + + * i386/i386.md (SF, DF, XF, and DI moves and pushes): Eliminate + special patterns for TARGET_386 that allow direct pushes from + memory, and instead allow direct pushes from memory as the last + alternative in case no scratch registers could be allocated. + (movxf_mem): Remove inadvertent !TARGET_386 condition. + (addsi3): Allow generation of lea on 486, since the single + instruction lea is at least as fast as the mov and add it + replaces. + (zero extend patterns): Replace !TARGET_486 with TARGET_386. + (bit extracts): Ditto. + + * i386/osfrose.h (LONG_DOUBLE_TYPE_SIZE): Don't redefine to be 64 + unless NO_LONG_DOUBLE is defined. + +Thu Sep 15 13:46:05 1994 Jim Wilson (wilson@cygnus.com) + + * expmed.c (store_split_bit_field): Use number of bits in arg not + BITS_PER_WORD to adjust arg in BYTES_BIG_ENDIAN case. + +Thu Sep 15 09:19:12 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * optabs.c (expand_binop, multi-word shifts): Generate rtl + free of conflicts for shifts less than one word. + +Thu Sep 15 05:29:58 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * gcc.c: Rework last change so it's done like collect2.c. + + * cse.c (cse_around_loop): Don't invalidate SUBREG unless + it's a SUBREG of a REG. + + * sched.c (sched_analyze_insn): Don't set SCHED_GROUP_P for previous + INSN a USE unless it's a USE of a REG. + +Wed Sep 14 10:08:58 1994 Michael I Bushnell <mib@churchy.gnu.ai.mit.edu> + + * gcc.c: Include <sys/errno.h> in case `errno' is really a macro + as permitted by ANSI C. + + * getpwd.c (GUESSPATHLEN): If there is no definition of + MAXPATHLEN, then set GUESSPATHLEN to be 100. (It's used + as a starting point, not a limit, so this is harmless.) + +Tue Sep 13 15:02:19 1994 Michael Meissner <meissner@pasta.osf.org> + + * i386/i386.md (movxf_mem): Fix typo with memory/memory moves + of XFmode variables, where the store actually did a load, ie, the + source and destination operands were fixed. + (fixuns_trunc patterns): Revert to the old code. + (movdf_push486, movxf_push486, movdi_push486): If an address is + based on the stack pointer, account for the stack pointer changing + due to the intermediate pushes generated. + +Tue Sep 13 14:11:16 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * collect2.c (fatal_perror, fatal, error): Declare all args as char *. + +Tue Sep 13 12:40:39 1994 Jeffrey A. Law (snake.cs.utah.edu) + + * pa.c (emit_move_sequence): Handle secondary FP load/store + reloads of the form (subreg (mem (plus (reg) (disp)))). + (secondary_reload_class): A secondary register is needed to handle + out-of-range FP loads and stores. + * pa.md (reload_indf, reload_outdf): New expanders. + (reload_insf, reload_outsf): Likewise. + +Mon Sep 12 18:15:48 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * t-pa (ADA_CFLAGS): New override. + * pa/t-pa-hpux: New file. + * configure (hppa*-*-hpux*): Use t-pa-hpux instead of t-libc-ok. + +Mon Sep 12 14:52:17 1994 Jim Wilson (wilson@cygnus.com) + + * function.c (assign_parms): Set RTX_UNCHANGING_P on stack_parm + for const parameter before calling move_block_from_reg. + +Mon Sep 12 14:27:58 1994 Doug Evans (dje@cygnus.com) + + * config/fp-bit.c (FLO_union_type): Add packed attribute to `bits'. + +Sat Sep 10 09:50:41 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (invalidate_for_call): Properly set IN_TABLE. + +Sat Sep 10 06:46:24 1994 Bill Burton (billb@progress.com) + + * Added improved support for Sequent DYNIX/ptx 1.x and 2.x: + * fixinc.ptx: New file. + * i386/seq-sysv3.h (HAVE_ATEXIT): No longer defined. + * i386/seq2-sysv3.h: New file. + * configure (i[34]86-sequent-ptx[12]*): New configurations. + (i[34]86-sequent-sysv*, i[34]84-sequent-ptx): Deleted configurations. + * config.sub (ptx): New OS; use for Sequent. + +Fri Sep 9 21:48:48 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (rescan, handle_directive): Backslash no longer suppresses the + specialness of the following char unless -traditional. + (rescan): Remove backslash-newline only if at top level, since + backslash-newline-space can be encountered during macro processing. + (collect_expansion): Remove special hack for \# inside a #define; + it's not compatible with the C Standard. + +Thu Sep 9 17:36:03 1994 Jason Merrill (jason@deneb.cygnus.com) + + * Utilize OSF/1's limited .init support. + * alpha/alpha.h (HAS_INIT_SECTION): Define. + (LINK_SPEC): Add '-init __main'. + * alpha/osf12.h (LINK_SPEC): Ditto. + + * function.c (expand_main_function): Don't call __main if + HAS_INIT_SECTION is defined. + +Fri Sep 9 16:36:46 1994 Mike Stump (mrs@cygnus.com) + + * tree.c (decl_function_context): Don't treat C++ member + functions of classes declared in a function, as nested functions. + +Fri Sep 9 16:10:25 1994 Steve Chamberlain (sac@jonny.cygnus.com) + + * sh/sh.c (prepare_move_operands): Generate better DI constant + code. + (fake_shift): New function. + * sh/sh.md (ashlsi3_n, lshrsi3_n): Only recognise if fake_shift + enabled. + * sh/{lib1funcs.asm, ashlsi3.c, lshrsi3.c, ashrsi3.c} : New files. + * sh/t-sh : Build new files. + +Fri Sep 9 15:52:54 1994 Hallvard B Furuseth (h.b.furuseth@usit.uio.no) + + * cccp.c: Correct unprototyped pointer args from `0' to `NULL_PTR' + +Fri Sep 9 15:17:52 1994 Matthew Green (mrg@splode.mame.mu.oz.au) + + * configure (sparc-*-netbsd): New configuration. + * sparc/netbsd.h: New file. + +Fri Sep 9 15:15:48 1994 Jim Wilson (wilson@cygnus.com) + + * mips.md (truncdisi2): Change from define_expand to define_insn. + (truncdihi2, truncdiqi2): Likewise. + + * sparc.h (SQRTTF2_LIBCALL): Delete. + (INIT_TARGET_OPTABS): Define. + (INIT_SUBTARGET_OPTABS): Define. + + * stmt.c (check_for_full_enumeration_handling): Cast malloc result + to `unsigned char *' not `char *'. + + * dbxout.c (dbxout_symbol_location): Handle error_mark_node in + DECL_INITIAL for C++. + + * mips.md (memory): Add missing !r4600 to first define_function_unit. + + * sparc.md (negsi2): Use register_operand not general_operand for + output. + +Fri Sep 9 14:52:58 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * config/netbsd.h: Add #undef for everything we define; a few were + missing. + + * reload.c (find_reloads, case 'p'): Operand is BASE_REG_CLASS. + +Fri Sep 9 14:00:28 1994 Mike Collison (collison@world.std.com) + + * configure (dsp16xx-*): New configuration. + * config.sub (dsp16xx): New basic machine. + * dsp16xx.c, dsp16xx.md, dsp16xx.h, xm-dsp16xx.h: New files. + +Fri Sep 9 12:47:00 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.md (All SF, DF, XF, DI 486 push patterns): Merge the + memory and nonmemory push patterns together. + +Fri Sep 9 00:53:36 1994 Richard Stallman <rms@mole.gnu.ai.mit.edu> + + * config.sub: Accept i586 like i386. + Do not use SCO as a default for i386-*. + +Thu Sep 8 18:49:35 1994 Steve Chamberlain (sac@cygnus.com) + + * config/fp-bit.c (_fpmul_parts): Perform optimized + 64bit*64bit multiply correctly. + * sh/sh.c (synth_constant): Ensure DI mode constants get their + high part zeroed. + (add_constant): Entabled constants are only identical if their + sizes are the same. + +Thu Sep 8 14:40:31 1994 Jim Wilson (wilson@cygnus.com) + + * flow.c (mark_used_regs, case REG): Correct typo, use GET_MODE + not GET_CODE. + * sched.c (attach_deaths): Likewise. + +Tue Sep 6 23:33:41 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * tree.c (get_set_constructor_bits, get_set_constructor_words): + New functions. Extract bits or words from SET_TYPE CONSTRUCTOR. + * tree.h: Declare above new functions. + +Thu Sep 8 14:02:05 1994 Michael Meissner (meissner@osf.org) + + * 386/i386.h (TARGET_OPTIONS): New macro to define -mreg-alloc= + switch to allow users to override the register allocation order. + (OVERRIDE_OPTIONS): Call the function override_options. + (REG_ALLOC_ORDER): Define to allocate in the natural order, this + is needed for ORDER_REGS_FOR_LOCAL_ALLOC to work. + (ORDER_REGS_FOR_LOCAL_ALLOC): Define to call the function + order_regs_for_local_alloc. + (regclass_map): Move declaration to end of file. + (i386_compare_op0, i386_compare_op1): Ditto. + (CLASS_LIKELY_SPILLED_P): Define, return 1 for AD_REGS in addition + to all of the single register classes, since AD_REGS is only used + to allocate EAX:EDX. + (override_options, order_regs_for_local_alloc): Add declarations. + (hi_reg_name): Add declaration. + (qi_reg_name): Ditto. + (qi_high_reg_name): Ditto. + (i386_reg_alloc_order): Add declaration for TARGET_OPTIONS to use. + + * i386/i386.c (i386_compare_op0, i386_compare_op1): Initialize + with NULL_RTX. + (i386_reg_alloc_order): Provide global variable definition. + (regs_allocated): Static array to note whether a register is noted + via -mreg-alloc=<xxx>. + (override_options): Provide checking for registers declared with + -mreg-alloc=<xxx>. + (order_regs_for_local_alloc): If -mreg-alloc=<xxx> was used, + allocate registers mentioned in order, and then allocate all other + registers in the normal register order. If -mreg-alloc=<xxx> was + not used, allocate registers in natural order except for non-leaf + functions with CSE following jumps, allocate EAX after EDX and + ECX, to allow the function return to be CSE'd, and perl 4.036's + perly.y to be compiled without aborting due to not being able to + find a spill register. + (movsf, movdf, movdi): Rewrite all patterns to provide effecient + memory to memory moves, including pushes for i386 and i486. Fixes + problems in compiling motif+ without optimization. + (swapsf): Add, like swapdf and swapxf. + (fixuns_truncsfsi2, fixuns_truncdfsi2): Use general_operand + instead of register_operand for define_expand, since the operand + is copied to a new pseudo register as part of the expansion. + (fix_truncxfdi2, fix_truncdfdi2, fix_truncsfdi2): Rewrite to call + the more primitive generator functions instead of knowing how many + clobbers of match_scratchs they do. + + * Makefile.in (aux_output.o): Define TARGET_CPU_DEFAULT if + specified when compiling aux_output.o to allow the machine C file + access to this if it wants it. + +Thu Sep 8 07:15:29 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (movsi matcher): Merge TARGET_POWER and !TARGET_POWER + cases. Rationalize mnemonics. + (movhi and movqi matchers): Likewise. + (movsf matcher): Correct length attribute for stfs which no longer + includes frsp. + +Thu Sep 8 07:06:31 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.h (REGISTER_MOVE_COST): Fix typo in last change. + +Wed Sep 7 19:31:52 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (handle_directive): In `#include <xxx>' directives, + remove backslash-newline properly. Don't allow any other newlines. + +Wed Sep 7 18:11:29 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.h (REGISTER_MOVE_COST): Moving between special registers + is expensive. + + * combine.c (simplify_comparison): Convert comparison to unsigned + when stripping off a ZERO_EXTEND. + + * combine.c (simplify_set): Only convert IF_THEN_ELSE to logical + expression if mode of object being compared is result mode. + +Wed Sep 7 18:09:17 1994 David J. MacKenzie (djm@geech.gnu.ai.mit.edu) + + * configure: Ignore --help, --version, --program-prefix, + --program-suffix, --cache-file, --quiet, --silent. + +Wed Sep 7 13:29:50 1994 Doug Evans (dje@cygnus.com) + + * stmt.c (expand_asm_operands): Move test for misspelled registers + higher so all cases caught. + +Wed Sep 7 09:54:14 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * configure: Touch Makefile.ll before appending subdir stuff. + (Needed if there are no subdirs.) + +Wed Sep 7 11:19:18 1994 Kresten Krab Thorup (krab@akvavit.next.com) + + * objc/init.c (__objc_init_protocols): Remove assertion. + * objc/Object.m (conformsTo:): Make lookup allways happen in + the class object. + +Tue Sep 6 17:47:39 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * configure: Rename *-next-ns[23] to *-next-nextstep[23]. + * config.sub: Cleanup NeXT support to emit nextstep*. + +Tue Sep 6 18:38:02 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload.c (find_reloads_address): Don't reorder the operands of a + PLUS when fixing up index. + +Tue Sep 6 18:24:50 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.md (stackadjust/push peepholes): For the adjust/push/push + pattern one offset was wrong. + Don't use addr for register and and MEM refs. + +Tue Sep 6 11:24:06 1994 Steve Chamberlain (sac@jonny.cygnus.com) + + * sh/sh.c (push, pop): Generate REG_NOTES. + (synth_constant): Correct one of the patterns. + (output_file_start): Bump version number. + * sh/sh.h (EXIT_IGNORE_STACK): Now 1. + * sh/sh.md (adddi3, subdi3): Simplify. + (casesi_worker): Use TARGET_BIGTABLE. + +Mon Sep 5 12:29:15 1994 Ian Lance Taylor (ian@cygnus.com) + + * ginclude/math-68881.h: Change inline functions from static to + extern. + + * configure (i[34]86-*-sysv4*): If --with-stabs, set tm_file to + i386/sysv4gdb.h. + * config/i386/sysv4gdb.h: New file; sets PREFERRED_DEBUGGING_TYPE. + +Sun Sep 4 08:40:02 1994 Chris Smith (csmith@convex.com) + + * convex.h (VTABLE_USES_MASK, VINDEX_MAX, SET_DECL_VINDEX): + delete, no longer used. + (target_flags): delete cexp.c hack, no longer needed. + * convex.md (decr-and-set-cc0): fix HImode to use halfword + insns. + (cmpqi patterns): fix constraints not to use A regs + +Sat Sep 3 14:12:11 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.md (DImode move and push insns): Eliminate movdi + wrapper that made a DI temp register to do a memory to memory + move because it creates too much register pressure, especially + when not optimizing. On the 486, allocate and use 1-2 scratch + registers to push a DImode value. + +Fri Sep 2 15:11:59 1994 Jason Merrill (jason@deneb.cygnus.com) + + * c-decl.c (min_precision): Move from here. + * c-common.c: To here. + +Fri Sep 2 13:16:38 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * tree.h (maximum_field_alignment, set_alignment): New declarations. + +Fri Sep 2 14:25:36 1994 Ian Lance Taylor (ian@cygnus.com) + + * config/svr4.h (DBX_DEBUGGING_INFO, PREFERRED_DEBUGGING_TYPE, + DBX_BLOCKS_FUNCTION_RELATIVE, ASM_IDENTIFY_GCC, + ASM_IDENTIFY_GCC_AFTER_SOURCE, ASM_OUTPUT_SOURCE_LINE, + DBX_FUNCTION_FIRST): Define. This adds support for -gstabs for + SVR4 configurations. -gstabs requires gas and gdb. + * config/sparc/sol2.h (DBX_DEBUGGING_INFO, + DBX_BLOCKS_FUNCTION_RELATIVE, ASM_IDENTIFY_GCC, + ASM_IDENTIFY_GCC_AFTER_SOURCE, ASM_OUTPUT_SOURCE_LINE, + DBX_FUNCTION_FIRST): Don't define. Now defined by config/svr4.h. + (PREFERRED_DEBUGGING_TYPE): Undefine before defining. + * config/sparc/sysv4.h (DBX_DEBUGGING_INFO): Don't bother to + undefine before including svr4.h. + (ASM_OUTPUT_SOURCE_LINE): Undefine before including svr4.h. + +Thu Sep 1 22:02:02 1994 Michael Meissner (meissner@osf.org) + + * toplev.c (fatal_insn): Move most of the code from + fatal_insns_not_found here, and add an argument to give the error + message. + (fatal_insn_not_found): Call fatal_insn. + * rtl.h (fatal_insn, fatal_insn_not_found): Add prototypes. + * genextra.c (main): Don't declare fatal_insn_not_found in + insn-extract.c. + * reload1.c (reload): Call fatal_insn where appropriate to print + an error message instead of calling abort. + (spill_failure): Ditto. + (reload_as_needed): Ditto. + (allocate_reload_reg): Ditto. + (emit_reload_insns): Ditto. + +Thu Sep 1 19:34:26 1994 Jason Merrill (jason@deneb.cygnus.com) + + * tree.c (type_list_equal): If the types of the default arguments + differ, the lists do not match. + +Thu Sep 1 19:29:58 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.md (stack-adjust/push peepholes): Addresses are + moved with "addr", not with "movd". + +Thu Sep 1 19:17:55 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (make_definition): Don't dump core when given an + unterminated string in a -D option. + +Thu Sep 1 19:13:35 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-typeck.c (convert_arguments): Give proper warnings when + converting COMPLEX_TYPE; widen check to include all integral types. + +Wed Aug 31 20:38:53 1994 Per Bothner (bothner@spiff.gnu.ai.mit.edu) + + * fixproto: Define FIX_HEADER (needed by Aug 19 change). + Use FIX_HEADER instead of $original_dir/fix-header (twice). + +Wed Aug 31 16:56:15 1994 Jason Merrill (jason@deneb.cygnus.com) + + * stmt.c (warn_if_unused_value): Extend special case for casted + MODIFY_EXPRs to apply to INIT_EXPRs as well. + +Wed Aug 31 16:30:09 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * stor-layout.c (set_alignment): New global. + (layout-type): Add support for SET_TYPE. + + * expmed.c (store_bit_field): Semi-revert Aug 25 change: + Make it apply only for BLKmode, not integral modes. + + * stmt.c (all_cases_count, mark_seen_cases): New functions. + (BITARRAY_TEST, BITARRAY_SET): New macros. Used (mainly by + Chill) to check all cases are covered (for enums and ranges). + (check_for_full_enumeration_handling): Re-write to use the + new functions, now that we have them. + +Wed Aug 31 19:19:29 1994 Richard Earnshaw (rwe@pegasus.esprit.ec.org) + + * combine.c (nonzero_bits, cases DIV, MOD, UDIV, UMOD): Declare + op0_maybe_minusp and op1_maybe_minusp as HOST_WIDE_INT. + +Wed Aug 31 18:54:54 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expmed.c (store_split_bit_field): Always adjust arg to + extract_fixed_bit_field in BYTES_BIG_ENDIAN case. + +Wed Aug 31 02:49:34 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/i386/gnu.h (LIB_SPEC): New macro. + +Tue Aug 30 16:35:23 1994 Jason Merrill (jason@deneb.cygnus.com) + + * toplev.c (lang_options): Add -W{no-,}reorder. + +Tue Aug 30 13:55:58 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * combine.c (simplify_comparison, case GEU): Add missing break. + +Mon Aug 29 17:50:55 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * vax.md (extv, extzv): Don't use ROTL when field is outside + boundaries of a word. + +Mon Aug 29 11:43:18 1994 Kresten Krab Thorup (krab@akvavit.next.com) + + * objc/sendmsg.c (get_imp): Don't inline on 386. + +Sun Aug 28 18:56:03 1994 Andrew McCallum (mccallum@cs.rochester.edu) + + * objc/class.c (objc_get_meta_class): New function. + +Sat Aug 27 23:13:53 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.c (legitimate_address_p): If index register is either + the arg pointer or the stack pointer, and there is no scale + factor, swap with the base register. + + * i386/i386.h (REG_CLASS_CONTENTS): Don't allow the arg pointer + register as an index register, since the frame could be omitted, + and the stack pointer is not valid as an index. + + * i386/i386.md (mov*, movstrict*): Don't create pushes of memory + values when creating insns, let the combiner create a push of a + memory value if -m386. In particular, pushes of byte values was + broken because there is no pattern to recognize such a push. + +Fri Aug 26 16:03:09 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.h (MASK_*): Add masks for all of the switches. + (TARGET_*): Use appropriate MASK_* instead of a number. Add + -mdebug-addr switch to debug GO_IF_LEGITIMATE_ADDRESS, + -mno-wide-multiply to turn off widening multiplies, and -mno-move + to allow integer move insns to generate direct memory to memory + copies, which reload will fix up. Add TARGET_386 which is not of + TARGET_486. + (REG_ALLOC_ORDER): Go to the order used in 2.5.8, eax, edx, ecx, ... + Add a comment describing the tradeoffs. + (REG_OK*): Add strict and non-strict versions of the macros that + are always present, and REG_OK_STRICT chooses between the two + inner macros. + (GO_IF_LEGIMATE_ADDRESS): Move processing to legitimate_address_p + function. + (LEGITIMIZE_ADDRESS): Move processing to legitimize_address + function. + (function declarations): Add function declarations for all extern + functions in i386.c. + + * i386/i386.c (asm_add): Add support in case adding by 1 or -1 to + use inc/dec. + (various): Change TARGET_486 -> !TARGET_386. + (legitimate_address_p): Move GO_IF_LEGITIMATE_ADDRESS processing + here from i386.h. Combine OSF/rose support from osfrose.h through + the use of conditional macros. Only recognize addresses in + canonical formats, code adapted from the i960 port. Add tracing + if -mdebug-addr. + (legitimize_address): Move LEGITIMIZE_ADDRESS here from i386.h, + and add adaptations from the i960 port. + (convert_387_op): Remove unused function. + + * i386/i386.md (various): Remove cast to char * of output + functions, since i386.h now declares them all properly. Change + TARGET_486 tests to !TARGET_386 and !TARGET_486 to TARGET_386. + (movsi, movstricthi, movhi, movstrictqi, movqi, movdi): Add + define_expand wrappers to prevent memory<->memory moves from being + generated unless -mno-move is used. On 486's do not allow push of + memory insns to be generated unless -mno-move. + (movdi): For movdi patterns, add 2 (clobber (match_scratch...)) + declarations to allow memory<->memory moves with non-contigous + registers, so that reload don't abort if it can't make a DI + register. + (umulsidi3, mulsidi3): Don't allow pattern if -mno-wide-multiply. + (smultsi3_highpart, umultsi3_highpart): Add patterns to make + division by constants generate better code. + + * i386/osfrose.h (MASK_*): Use octal to define bitmasks, not hex, + for compatibility with i386.h. + (NO_IMPLICIT_EXTERN_C): Define. + (LONG_DOUBLE_TYPE_SIZE): Explicitly define to be 64 instead of + just #undef'ing it. + (GO_IF_LEGITIMATE_ADDRESS): Delete, merged with common i386 code. + (ASM_FILE_END): Print -fschedule-insns and -fschedule-insns2 in + ident string if those options are used. + (REAL_LD_FILE_NAME): Delete. + (ASM_OUTPUT_DOUBLE): Delete, use the common macros. + (ASM_OUTPUT_FLOAT): Ditto. + (ASM_OUTPUT_LONG_DOUBLE): Ditto. + +Thu Aug 25 17:15:18 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * expmed.c (store_bit_field): Always store into multi-word + bitfields starting with low addresses. (Old code was + incompatible with operand_subword_force on big-endian targets.) + +Thu Aug 25 18:31:20 1994 Antti Miettinen (amiettin@ntc.nokia.com) + + * m68k/lynx.h (CALL_USED_REGS): Add d2 and d3 as call-used. + +Thu Aug 25 11:30:44 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (record_jump_cond): Don't do anything if OP0 and OP1 + are already equivalent. + + * rtlanal.c (may_trap_p, case EXPR_LIST): New case. + + * c-common.c (shorten_compare): Don't issue warning if both + operands constants and the signedness doesn't affect the + comparison results. + + * configure: Refine handling and error-checking of positional args. + + * print-tree.c (print_node): Print more flags for types and decls. + + * c-typeck.c (type_lists_compatible_p): Treat transparent unions + just like unnamed ones. + +Wed Aug 24 19:34:52 1994 Charles Hannum (mycroft@duality.gnu.ai.mit.edu) + + * configure: Rearrange handling of NetBSD ports to use the standard + `cpu-vendor-os' format. + * config.sub: Recognize names of NetBSD ports that do not correspond + to a CPU name. + +Wed Aug 24 18:43:30 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * print-tree.c (print_node_brief, print_node): Use assignment instead + of initialization for aggregate local variable REAL_VALUE_TYPE d. + +Wed Aug 24 18:28:52 1994 Ian Lance Taylor (ian@cygnus.com) + + * config/svr4.h (ASM_OUTPUT_SECTION_NAME): Define. + * config/sparc/sysv4.h (ASM_OUTPUT_SECTION_NAME): Output #alloc to + set SHF_ALLOC in section flags. + +Wed Aug 24 17:45:19 1994 Jim Wilson (wilson@sphagnum.cygnus.com) + + * c-parse.in (parmlist_2): Give error for function with only + ELLIPSIS as an argument. + +Wed Aug 24 17:36:22 1994 H.J. Lu (hjl@nynexst.com) + + * i386/linux.h (STARTFILE_SPEC): Add %{static:-static}. + +Wed Aug 24 14:34:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * calls.c (expand_call): Check for variable-sized return value + in proper place. + + * c-typeck.c (default_conversion): Don't substitute constant + value if array since will return address. + + * configure (LANG_MAKEFILE): Include lang/Makefile.in in list. + + * alpha.h (EXTRA_CONSTRAINT): Add new letter, `R'. + (ENCODE_SECTION_INFO): Don't check TREE_ASM_WRITTEN. + (PREDICATE_COSTS): Add call_operand. + * alpha.c (call_operand): New function. + (output_epilog): Don't set SYMBOL_REF_FLAG of current function. + * alpha.md (call): Rework to use macro version of jsr. + * osf2.h (LINK_SPEC): Don't define; should never have been. + + * c-typeck.c (push_init_level): Don't blow up if construct_type + is null (can happen with missing brace). + +Wed Aug 24 10:49:35 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.h (REG_ALLOC_ORDER): Restore previous version which + allocates edx first, then ecx, eax, ... This is because perl + doesn't build when the order is eax, ecx, edx... + +Tue Aug 23 09:20:16 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * configure: Restore old behavior of positional arguments. + Add new argument, --noguess. + config.guess now guesses BUILD, not HOST; HOST defaults from BUILD. + Always compare canonical names, not user-specified names. + Numerous minor changes in the messages output to make the + configuration chosen clearer. + +Tue Aug 23 02:01:42 1994 Richard Stallman <rms@mole.gnu.ai.mit.edu> + + * config.sub: Move m68k-ccur handling to proper part of file. + Canonicalize cpu type pentium into i486. (Change it to i586 later.) + +Mon Aug 22 18:41:59 1994 Steve Chamberlain (sac@jonny.cygnus.com) + + * sh/sh.c (find_barrier): Calculate the size of larger than + SI moves correctly. + (general_movsrc_operand): Allow label_refs plus const. + (sh_function_arg_partial_nregs, sh_function_arg): Pass BLKmode + objects in partial regs. + * sh.h (TARGET_DEFAULT): Turn off BIGTABLE_BIT. + (EXTRA_CONSTRAINT_Q): Allow label_refs plus const. + (READONLY_DATA_SECTION_ASM_OP, EXTRA_SECTIONS, rdata_section): + Delete rdata section and refs. + * sh.md (dimode split): Don't allow a Q constraint source. + +Sun Aug 21 23:15:35 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (FUNCTION_ARG): Use indirect calling conventions when + TARGET_LONG_CALLS is in effect. + +Sat Aug 20 13:31:34 1994 Jim Wilson (wilson@cygnus.com) + + * sched.c (sched_analyze_insn): Add new parameter loop_note. + If loop_note set, then serialize on this insn. + (sched_analyze): New variable loop_note. Pass to + sched_analyze_insn. Set it if we pass a NOTE_INSN_LOOP_BEG or + NOTE_INSN_LOOP_END. + (unlink_notes): Don't save away NOTE_INSN_LOOP_BEG or + NOTE_INSN_LOOP_END notes. + (schedule_block): Generalize code that looks for magic REG_DEAD + notes and converts them to notes. + +Sat Aug 20 12:47:21 1994 Michael Meissner (meissner@osf.org) + + * i386.h (REG_ALLOC_ORDER): Allocate eax first, then ecx, edx, and + then do the nromal allocation order for the remaining registers. + +Fri Aug 19 20:14:35 1994 Jim Wilson (wilson@cygnus.com) + + * tree.c (build_type_variant): Only return existing type if it + also has the same TYPE_NAME. + + * irix5.h (NO_IMPLICIT_EXTERN_C): Comment out. + +Fri Aug 19 16:41:43 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * fixproto: Use $FIX_HEADER macro instead of calling + fix-header directly in 2nd location. + +Fri Aug 19 17:34:19 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (emit_move_insn_1): Never make a no-conflict block. + + * tree.h (struct tree_type): New field transparent_union_flag. + (struct tree_decl): New field transparent_union. + ({DECL,TYPE}_TRANSPARENT_UNION): New macros. + * c-common.c (decl_attribute): Handle "transparent_union" attribute. + * function.c (assign_parms): If parm is transparent union, use + type of first field. + * calls.c (expand_call): Likewise. + * integrate.c (function_cannot_inline): Don't inline if any + parm is a transparent union. + +Fri Aug 19 12:01:11 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Canonicalize ${INPUT} to avoid automounter + problems. + +Fri Aug 19 11:31:24 1994 Kresten Krab Thorup (krab@akvavit.next.com) + + * objc-act.c (build_selector_translation_table): Reset + current_function_decl after hack_function_prototype build it. + (build_module_descriptor): Return constructor name from functions + decl_rtl. + +Thu Aug 18 17:23:18 1994 Per Bothner (bothner@spiff.gnu.ai.mit.edu) + + * README.FRESCO: New file. Notes about compiling the Fresco + toolkit with g++. + +Thu Aug 18 14:10:22 1994 Jim Wilson (wilson@cygnus.com) + + * combine.c (distribute_notes, case REG_UNUSED): Ignore notes when + from_insn != i3 only if the notes would remain as REG_UNUSED notes. + +Wed Aug 17 18:31:43 1994 Holger Teutsch (holger@hotbso.rhein-main.de) + + * clipper.h (CLIPPER_ARG_SIZE): Return size in bytes. + (FUNCTION_ARG_ADVANCE): Fix argument alignment processing. + +Wed Aug 17 18:03:54 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fx80.md (casesi_2): Operand 0 is HImode; add SIGN_EXTEND + when adding to pc. + (casesi): Operand 0 is HImode. + (unnamed PC addition pattern): Add SIGN_EXTEND to add HImode + offset to SImode PC. + * m68k.md (tablejump): Add SIGN_EXTEND to HImode offset + so can add to SImode PC. + Likewise for matching pattern. + * cse.c (fold_rtx): When folding tablejump, allow LABEL_REF + to be in arg0; also allow other arg to be MINUS, not just be + equivalent to it. + +Mon Aug 15 19:19:11 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (index0): New function. + (trigraph_pcp): Use index0 instead of index, so that a null + byte doesn't suppress further trigraph preprocessing. + + * cccp.c (rescan, do_ident): Pass more accurate size request + to check_expand. + + * cccp.c (main): Don't dump core if given -pcp, -MD, or -MMD + without following arg. + +Mon Aug 15 17:56:38 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stmt.c (expand_elseif): New function. + +Mon Aug 15 14:16:18 1994 Ian Lance Taylor (ian@cygnus.com) + + * configure: If the host is guessed, and the target name is a + prefix of the host name, then use the target name as the host + name. + +Mon Aug 15 13:35:24 1994 Stan Shebs (shebs@andros.cygnus.com) + + * m68k/m68k-coff.h: New file. + +Sun Aug 14 00:28:15 1994 Andrew McCallum (mccallum@vein.cs.rochester.edu) + + * objc/encoding.c (objc_sizeof_type): Assign from ROUND, + don't increment. Remove ; after while to fix infinite loop. + Add float and double cases. + (objc_alignof_type): Add float and double cases. + * objc/selector.c (): Use __objc_selector_names, not + __objc_selector_array. + (sel_types_match): New function. + (sel_get_typed_uid): Use sel_types_match. Change strcmp to !strcmp. + +Sun Aug 14 21:54:29 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (ASM_OUTPUT_ALIGNED_COMMON, ASM_OUTPUT_ALIGNED_LOCAL): + Define. + (ASM_OUTPUT_COMMON, ASM_OUTPUT_LOCAL): Delete. + + * pa.c (hppa_expand_prologue): Avoid writing outside the current + stack boundary in code to handle large stack frames. + +Sun Aug 14 18:55:51 1994 Jim Wilson (wilson@cygnus.com) + + * unroll.c (loop_iterations): Use PREV_INSN not prev_nonnote_insn. + + * bsd-5.h (ASM_OUTPUT_NEWLINE): Delete. + (ASM_OUTPUT_ASCII): Define. + * mips-5.h, svr3-5.h, svr4-5.h: Likewise. + * mips.h (ASM_OUTPUT_NEWLINE): Delete. + (ASM_OUTPUT_ASCII): Don't use ASM_OUTPUT_NEWLINE. + + * va-mips.h (va_start): Add cast to __gnuc_va_list type. + + * flow.c (mark_used_regs): When adding REG_DEAD notes, check for + the case where a multiple register hard reg overlaps a register + set by the insn. + * sched.c (attach_deaths): Likewise. + * combine.c (distribute_notes, case REG_DEAD): Add another + find_reg_fusage call. + + * unroll.c (calculate_giv_inc): Handle constants loaded with IOR. + +Sun Aug 14 16:40:04 1994 Richard Stallman <rms@mole.gnu.ai.mit.edu> + + * cccp.c (skip_if_group): New arg op. All callers changed. + If output_conditionals is true, output text of failed conditionals. + (conditional_skip): New arg op. All callers changed. + (main): Handle -ifoutput option. + +Sun Aug 14 05:49:29 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * print-tree.c (print_node{,_brief}): Use REAL_VALUE_TO_DECIMAL + to print REAL_CST ifdef REAL_ARITHMETIC. + + * reload1.c (count_possible_groups) Pass CLASS as arg and only + try to find groups of that class. + + * configure: If config.guess fails and target specified, use as host. + Print a message when making a cross-compiler. + +Sat Aug 13 17:12:30 1994 Jim Wilson (wilson@cygnus.com) + + * configure (sparc-*-sunos4.0*): New configuration. + * t-sunos4: Rename file to t-sunos41. + * t-sunos40: New file. + +Sat Aug 13 13:50:22 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * reload1.c (emit_reload_insns): Handle a secondary input reload + which needs to use secondary memory too. + +Fri Aug 12 18:53:24 1994 Ian Lance Taylor (ian@cygnus.com) + + * mips/mips.c (override_options): If neither -mcpu= nor -mipsN was + used, and MIPS_CPU_DEFAULT is defined, set mips_cpu to + MIPS_CPU_DEFAULT and set mips_cpu_string to + MIPS_CPU_STRING_DEFAULT. + +Fri Aug 12 10:54:35 1994 Stan Cox (coxs@dg-rtp.dg.com) + + * m88k/dgux.h, m88k/dguxbcs.h (ASM_SPEC,CPP_SPEC): + Made -pipe work for -msvr4. Added -D*_TARGET definitions. + + * m88k.c (emit_bcnd): Improved code generated by changing cmp/bbx + instruction pair to single bcnd instruction + +Fri Aug 12 07:52:20 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (set_nonvarying_address_components): If BASE is CONST_INT, + add value to start and set BASE to const0_rtx. + (refers_to_mem_p): Don't do it here. + + * function.c (expand_function_start): Add redundant copy to + static_chain_incoming_rtx if SMALL_REGISTER_CLASS so inlining + works properly. + * integrate.c (expand_inline_function): Use single_set when + appropriate. + Delete insn that sets static_chain_incoming_rtx before its use. + (subst_constants): Treat virtual reg as constant. + + * flow.c (mark_used_regs): Only show changes size if one mode is + integral. + * stupid.c (stupid_mark_refs): Likewise. + * combine.c (simplify_rtx, case FLOAT_TRUNCATE): Remove + redundant float_truncate. + * rs6000.md (movsf): Don't truncate if not register; clean up. + + * c-decl.c (duplicate_decls): Suppress -Wredundant-decls warning + if we have already given an error. + +Thu Aug 11 18:44:25 1994 Jason Merrill (jason@deneb.cygnus.com) + + * stmt.c (expand_anon_union_decl): Fix up the alignment and mode + of the member VAR_DECLs. + +Thu Aug 11 13:36:14 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * tree.c (stabilize_reference): Handle COMPOUND_EXPR. + + * fix-header.c (write_rbrac): If NO_IMPLICIT_EXTERN_C is defined, + add extern "C" { ... } to added prototypes. (Needed for hpux.) + +Thu Aug 11 14:23:59 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (rescan): Fix botches with `-lint': the output buffer + pointer was not recached properly, leading to lost output. + Also, buffer overrun was possible. + + * cccp.c (dump_defn_1): Skip newlines and strings correctly. + +Thu Aug 11 14:13:17 1994 Niklas Hallqvist (niklas@appli.se) + + * configure (m68k-*-netbsd*): New target, like others. + +Thu Aug 11 14:09:23 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu) + + * alpha.h (FUNCTION_PROFILER): Load global pointer from $27, not $26. e + +Thu Aug 11 13:52:15 1994 Walter Misar (misar@rbg.informatik.th-darmstadt.de) + + * m68k/hp320.h (NO_DOT_IN_LABEL): Define if HPUX_ASM. + +Thu Aug 11 13:12:12 1994 David Mosberger-Tang (davidm@cs.arizona.edu) + + * alpha.h (BLOCK_PROFILER): Use $26 and $27 instead of $0 and $1. + +Thu Aug 11 13:09:36 1994 Antti Miettinen (amiettin@trshp.trs.ntc.nokia.com) + + * config/lynx.h (ASM_OUTPUT_SOURCE_LINE): Call assemble_name. + +Thu Aug 11 12:57:22 1994 Stephen L Moshier (moshier@world.std.com) + + * expr.c (expand_builtin): Relegate sin and cos to ffast-math. + +Thu Aug 11 12:45:20 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * flow.c (find_auto_inc): Ensure that all proposed changes to + insns are valid before commiting to the auto-inc. + + * calls.c (expand_call): Ensure we call force_operand on + structure_value_addr. + + * configure: Use config.guess to get default value for host, + not target. + +Thu Aug 11 12:43:24 1994 Robert Wilhelm (Robert.Wilhelm@physik.tu-muenchen.de) + + * Makefile.in (mostlyclean): Add missing -f. + +Tue Aug 9 02:02:07 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.md (default set high): Do not accept function label arithmetic + as a valid operand. + (default lo_sum): Likewise. + * pa.c (hppa_legitimize_address): Do nothing with function label + arithmetic. + (emit_move_sequence): Split up function label arithmetic so that + function's address is loaded first, then constant part is added to + the function's address. + (is_function_label_plus_const): New function. + +Mon Aug 8 19:57:05 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.md (all patterns that use ins/inss and ext/exts): + Disallow use of these instructions when -mnobitfield is + specified. + * ns32k.h (TARGET_BITFIELD): New macro. + (TARGET_SWITCHES): Support for TARGET_BITFIELD. + * ns32k/netbsd.h (TARGET_DEFAULT): Added -mnobitfield. + (CPP_PREDEFINES): Added -Dpc532. + (WCHAR_{TYPE, UNSIGNED, TYPE_SIZE}): Changed to match new definition + in NetBSD 1.0. + * ns32k.c (print_operand_address): A patch for 2.5.8 ended up at the + wrong place. Moved. + +Mon Aug 8 19:42:09 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (create_definition): Warn about `#define a@', since a + diagnostic is now required (see ISO TC1's addition to + subclause 6.8). Also warn about `#define is-empty(x) (!x)'. + +Mon Aug 8 16:32:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fix-header.c (write_rbrac): Set up to use fixed headers + if __USE_FIXED_HEADERS__ is defined. + + * reload1.c (emit_reload_insns): Always clear new_spill_reg_store. + + * reload.c (find_reloads): Force reload for paradoxical SUBREG + of MEM if BYTES_BIG_ENDIAN. + + * m68k/hp320.h (READONLY_DATA_SECTION): Remove definition. + + * function.c (expand_function_start): Only use + static_chain_incoming_rtx once if it is a REG and we + have SMALL_REGISTER_CLASSES. + + * local-alloc.c (find_free_reg): Fix typo in last change. + * rs6000.h (CLASS_CANNOT_CHANGE_SIZE): New macro. + +Sun Aug 7 08:54:42 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * regs.h (reg_changes_size): Add declaration. + * flow.c (reg_changes_size): New variable. + (allocate_for_life_analysis): Allocate and initialize it. + (mark_used_regs, case SUBREG): Set it. + * local-alloc.c (qty_changes_size): New variable. + (alloc_qty{,_for_scratch}, update_qty_class): Set it. + (local_alloc): Allocate it. + (find_free_reg): If CLASS_CANNOT_CHANGE_SIZE, avoid its registers + if qty_changes_size. + * global.c (find_reg) If CLASS_CANNOT_CHANGE_SIZE, avoid its + registers if reg_changes_size. + * stupid.c (regs_change_size): New variable. + (stupid_life_analysis): Alloc, init and pass it to stupid_free_reg. + (stupid_mark_regs): Set it. + (stupid_find_reg): New arg, CHANGES_SIZE; avoid regs + in CLASS_CANNOT_CHANGE_SIZE if defined and CHANGES_SIZE nonzero. + * reload.c (push_reload): Make test in LOAD_EXTEND_OP case more + precise; handle CLASS_CANNOT_CHANGE_SIZE. + (find_relods): When setting force_reloads, make LOAD_EXTEND_OP + case more precise. + * alpha.h (CLASS_CANNOT_CHANGE_SIZE): New macro. + + * reload1.c (eliminate_regs, case SUBREG): Add USE of pseudo + so we don't improperly delete an output reload. + +Fri Aug 5 15:08:39 1994 Jason Merrill (jason@deneb.cygnus.com) + + * expr.c (expand_expr, COND_EXPR case): Use truthvalue_conversion + to make the condition for running cleanups acceptable to + invert_truthvalue. + +Fri Aug 5 12:29:42 1994 Jim Wilson (wilson@cygnus.com) + + * expmed.c (expand_mult): Accept DImode for synth_mult only if + CONST_DOUBLE_HIGH is zero. Reject negative values for synth_mult + if the mode is larger than HOST_BITS_PER_INT. Don't do the + negate_variant if the mode is larger than HOST_BITS_PER_INT. + +Fri Aug 5 12:23:17 1994 Stephen L Moshier (moshier@world.std.com) + + * gbl-ctors.h (DO_GLOBAL_CTORS_BODY): Use long instead of + HOST_WIDE_INT. + +Fri Aug 5 12:18:18 1994 Kaveh R. Ghazi (ghazi@caip.rutgers.edu) + + * configure: In subdirectories, make link to include directory. + * Makefile.in (distclean): Delete it. + +Thu Aug 4 17:21:02 1994 Jason Merrill (jason@deneb.cygnus.com) + + * expr.c (defer_cleanups_to): Put back line which was mistakenly + removed. + +Wed Aug 3 21:37:31 1994 Doug Evans (dje@cygnus.com) + + * sparc.c (v9 sparc_builtin_saveregs): Save quadword fp regs on + 16 byte boundaries. Handle non-zero number of named fp args. + * va-sparc.h (v9 va_start): Pass an arg to __builtin_next_arg. + (v9 va_arg): Advance over float's. + +Wed Aug 3 11:10:32 1994 Ian Lance Taylor (ian@mole.gnu.ai.mit.edu) + + * fixincludes: Changes for glibc. In the main loop, don't fix + files which contain the string ``This file is part of the GNU C + Library''. Don't include <stdarg.h> in <stdio.h> if <stdio.h> + contains the string ``__need___va_list''. In <stdio.h>, don't + change GNUC_VA_LIST to GNUC_DUMMY_VA_LIST. Don't add extern "C" + to <assert.h> if it contains the string ``__BEGIN_DECLS''. Don't + add multiple inclusion protection to <time.h> or <sys/time.h> if + they contain the string ``#ifndef''. + +Tue Aug 2 18:38:46 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (simplify_unary_operation): Clean up some mode and + size checks with CONST_DOUBLEs; TRUNCATE should do nothing. + + * combine.c (subst_prev_insn): Remove variable and all uses. + +Tue Aug 2 14:42:29 1994 Doug Evans (dje@canuck.cygnus.com) + + * sparc.h (V9_SWITCHES): Add -mmedlow, -mmedany. + (TARGET_OPTIONS): Delete. + (CONDITIONAL_REGISTER_USAGE): Don't unfix %g4 if -mmedany. + * sparc.c (sparc_code_model): Delete. + (sparc_override_options): Code model flags only useable with v9. + + * sparc.h (enum reg_class): New values EXTRA_FP_REGS, + GENERAL_OR_EXTRA_FP_REGS for the v9 case. + (REG_CLASS_NAMES): Likewise. + (REG_CLASS_CONTENTS): Likewise. + (REGNO_REG_CLASS): Handle EXTRA_FP_REGS. + (REG_CLASS_FROM_LETTER): Likewise, as `e'. + Treat `e' like `f' in v8 case. + (FP_REG_CLASS_P): New macro. + (PREFERRED_RELOAD_CLASS): Use it. + (SECONDARY_INPUT_RELOAD_CLASS, SECONDARY_OUTPUT_RELOAD_CLASS, + SECONDARY_MEMORY_NEEDED, CLASS_MAX_NREGS, REGISTER_MOVE_COST): + Likewise. + * sparc.md (all DF/TFmode patterns): Use `e' in contraint field + instead of `f'. + +Mon Aug 1 20:05:51 1994 Roland McGrath <roland@churchy.gnu.ai.mit.edu> + + * config/i386/gnu.h: New file. + * configure (i[34]86-*-gnu*): Deal with this on its own, not like + i[34]86-*-mach*. Use i386/gnu.h and t-libc-ok; set gnu_ld and + gas, and disable fixincludes. + +Mon Aug 1 19:27:44 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tree.c (permanent_allocation): When freeing to + momentary_function_firstobj, set momentary_firstobj to be + the next available location (i.e., momentary_function_firstobj). + +Mon Aug 1 18:52:40 1994 Chris Arthur (csa@gnu.ai.mit.edu) + + * stddef.h: Handle _BSD_WCHAR_T_ like _WCHAR_T_, since + at least BSD/386 1.1 uses the former instead of the latter. + If _BSD_RUNE_T_ is defined, then define rune_t when we define + wchar_t. Test definedness of _GCC_SIZE_T as well as + _GCC_SIZE_T_; likewise for _GCC_PTRDIFF_T and _GCC_WCHAR_T. + +Mon Aug 1 05:20:44 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa-ghpux.h, pa-hpux.h (LINK_SPEC): Any -g argument implies + static linking. + +Sun Jul 31 17:19:37 1994 Jason Merrill (jason@deneb.cygnus.com) + + * integrate.c (expand_inline_function): Don't fall down trying to + pass things by invisible reference. + +Sun Jul 31 06:56:46 1994 Pat Rankin (rankin@eql.caltech.edu) + + * cccp.c (my_strerror): New function. + (error_from_errno, perror_with_name): Use it. + +Sat Jul 30 12:59:01 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (fold_truthop): Apply masks to constants. + + * print-tree.c (print_node{,_brief}): Use correct printf code to + print INTEGER_CST if HOST_WIDE_INT is wider than int. + + * expmed.c ({store,extract}_bit_field): Don't use bitfield insn + if OP0 is register and bitfield spans it. + + * m88k.c (arith64_operand): Integer CONST_DOUBLE is not DImode. + * sparc.c (reg_or_0_operand): Likewise. + * ns32k.c, pa.c (print_operand): Likewise. + * fx80.h, gmicro.h, ns32/{genix,merlin}.h (PRINT_OPERAND): Likewise. + * m68k/crds.h, m68k/news.h, pyr.h (PRINT_OPERAND): Likewise. + + * alpha.h (CASE_VECTOR_PC_RELATIVE): Define. + (ASM_OUTPUT_ADDR_VEC_ELT): Abort. + (ASM_OUTPUT_ADDR_DIFF_ELT): Now what used to be previous definition. + * alpha.md (tablejump): Rework to look like normal add but verify + that label is for next insn and is tablejump; look for ADDR_DIFF_ELT. + * cse.c (fold_rtx, case MEM): Surround TRUNCATE for jump table + entry with a CONST. + (fold_rtx, case '1'): Handle operand 0 of a CONST. + (fold_rtx, case PLUS): Handle (const (minus (label_ref) (label_ref))). + +Fri Jul 29 19:27:17 1994 Lee Iverson (leei@ai.sri.com) + + * c-decl.c (finish_decl): Preserve initialializer if iterator. + +Fri Jul 29 19:07:23 1994 Hallvard B Furuseth (h.b.furuseth@usit.uio.no) + + * libgcc2.c: Add declaration of ctime. + * bc-emit.c (bc_sym_write): Change %d to %lu in printf calls. + * fix-header.c (write_{l,r}brac): Specify return type of int. + * tree.c (change_main_variant): Return type now void. + * varasm.c (bc_output_constructor): Return type now rtx. + +Fri Jul 29 18:33:48 1994 Ken Duda (kjd@cache.crc.ricoh.com) + + * c-typeck.c (build_unary_op, case *INCREMENT_EXPR): + Add size in bytes, not value of sizeof. + +Fri Jul 29 17:36:38 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * function.c (expand_function_start): Initialize VALUE_ADDRESS. + + * romp.md (tst?f): Use CONST0_RTX instead of incorrect call + to immed_real_const_1. + + * expr.c (move_block_to_reg): Do nothing if NREGS == 0. + +Fri Jul 29 17:17:18 1994 Tom Tromey (tromey@busco.lanl.gov) + + * cccp.c (special_symbol, do_xifdef): Don't access value.defn + of a T_CONST. + +Thu Jul 28 17:19:32 1994 Jason Merrill (jason@deneb.cygnus.com) + + * gbl-ctors.h (DO_GLOBAL_CTORS_BODY): Reverse order of execution + of constuctor lists. + * config/svr3.h (DO_GLOBAL_CTORS_BODY): Ditto. + + * libgcc2.c (__do_global_dtors): Reverse order of execution of + destructor lists. + +Thu Jul 28 19:56:30 1994 Jim Pendergraft (jimp@dg-rtp.dg.com) + + * dwarfout.c (output_decl, case FUNCTION_DECL): Corrected + and simplified code that determined when to generate + varargs or ANSI stdargs variable length parameter list + DWARF information. + +Thu Jul 28 19:38:57 1994 Andreas Schwab (schwab@issan.informatik.uni-dortmund.de) + + * m68k.md (extv, extzv): In patterns that will use movb and + movw, ensure size is 8 or 16. + +Thu Jul 28 19:28:31 1994 David Robinson (drtr@mail.ast.cam.ac.uk) + + * expr.c (expand_expr, case CONJ_EXPR): Use correct mode for + parts of a complex expression. + + * optabs.c (expand_binop, case MULT [complex]) Fix typo. + +Thu Jul 28 19:21:38 1994 Uwe Seimet (seimet@chemie.uni-kl.de) + + * am68k/atari.h (FUNCTION_VALUE): New override. + +Thu Jul 28 17:27:38 1994 Paul Eggert (eggert@twinsun.com) + + * Makefile.in (c-lex.o, distdir-start): + Depend on $(srcdir)/c-gperf.h, not c-gperf.h. + +Thu Jul 28 15:14:33 1994 Oliver Kellogg (okellogg@salyko.cube.net) + + * m1750.inc (DNR.M): Add missing macro. + +Thu Jul 28 13:02:56 1994 Kresten Krab Thorup (krab@akvavit) + + * objc/misc.c (__objc_xcalloc): Remove declaration of bzero. + +Thu Jul 28 07:29:52 1994 Markus Wild (mw@eunet.ch) + + * c-common.c (decl_attributes): Correct string check for "format" + to include unsigned and signed char. + +Thu Jul 28 07:11:36 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (compare_spill_regs): Simplify and return zero if + registers are the same. + + * c-decl.c (finish_struct): Don't look at alignment of error_mark_node. + + * combine.c (try_combine): Don't make a MULT if none of the insns + in our input had one. + +Wed Jul 27 19:06:53 1994 R Bowler (rbowler@cix.compulink.co.uk) + + * i370/mvs.h (ASM_OUTPUT_ASCII): Fix bug when first character + of string constant is single quote. + +Wed Jul 27 22:44:32 1994 Jason Merrill (jason@deneb.cygnus.com) + + * m68k/next.h: #undef PCC_STATIC_STRUCT_RETURN. + + * alpha/alpha.h: #define NO_IMPLICIT_EXTERN_C. + +Wed Jul 27 14:06:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expmed.c (expand_mult): Properly set ADD_TARGET for add_variant. + + * alpha.h (INITIAL_ELIMINATION_OFFSET): Properly compute offset + between AP and SP when get_frame_size and + current_function_pretend_args_size are not a multiple of 16 bytes. + + * expmed.c (expand_divmod): Don't make REG_NOTE if last insn's + destination isn't QUOTIENT. + +Tue Jul 26 19:45:54 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.c (expand_expr, case ARRAY_REF): Don't fold L"foo"[2]. + +Tue Jul 26 14:10:52 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * config.sub: Refer to NeXT's operating system as nextstep. + +Tue Jul 26 13:50:37 1994 Jim Wilson (wilson@cygnus.com) + + * c-typeck.c (process_init_element): Do not call push_init_level + if the value is error_mark_node. + + * iris5.h (NO_IMPLICIT_EXTERN_C): Define. + +Mon Jul 25 00:20:36 1994 Chris Arthur (csa@gnu.ai.mit.edu) + + * configure (canon_target): add cases to recognize BSD/386 + specifically, so we can use a tm_file that will cause __bsdi__ + to get defined (since emacs, among other things, needs it). + + * config/i386/bsd386.h: New. Use 386bsd.h, and just override + CPP_PREDEFINES (add -Dbsdi) and WCHAR stuff. + +Sat Jul 23 16:30:12 1994 Kaveh R. Ghazi (ghazi@caip.rutgers.edu) + + * fixinc.svr4: Change i860 in #if to __i860__, as with other CPUs. + +Fri Jul 22 14:33:59 1994 Doug Evans (dje@cygnus.com) + + * h8300.md (andhi3, iorhi3, xorhi3): Change constraint on + operand 2 from `i' to `n'. + +Fri Jul 22 09:30:39 1994 DJ Delorie (dj@ctron.com) + + * configure.bat: move code to config/msdos/* (simplification) + + * config/msdos/configure.bat [new file]: moved most processing + here so that as things get more complicated with the language + breakouts, the top directory won't get too messy. Sed script + broken out to simplify processing and avoid quoting errors. + * config/msdos/top.sed [new file]: sed script to change Makefile.in + to Makefile in top directory (currently used for cp directory also) + sed commands changed to handle language breakout + + * gcc.c (pexecute): use spawn*() for djgpp to ensure that quotes + are properly preserved. Response file code left for 16-bit + compilers, which can't handle the long command lines that gcc + may generate. + + * config/i386/go32.h: define NO_IMPLICIT_EXTERN_C. + +Thu Jul 21 23:19:03 1994 Steve Chamberlain (sac@wombat.gnu.ai.mit.edu) + + * sh/sh.h (TARGET_SWITCHES, PACKSTRUCT_BIT, STRUCTURE_SIZE_BOUNDARY): + parse and handle new option. + (LEGITIMATE_CONSTANT_P): LABEL_REFs are no longer illegal. + (WCHAR_TYPE, WCHAR_TYPE_SIZE): New definitions. + (HANDLE_PRAGMA): Has return. + + * sh/sh.c (add_function, seen_function): Experimental code to + generate bsrs. + (handle_pragma): Return final char. + (expand_acall): Handle TARGET_BSR. + (general_movdst_operand, general_movsrc_operand): Allow ok + autoinc/dec. + (bsr_operand): New function. + (fixit): Need to fix LABEL_REFs. + + * sh/sh.md (addc): Simplify. + (adddi3, subdi3, negdi3): Use operand_subword. + (subc, negc): New pattern. + (shifts): Fix constraints. + +Thu Jul 21 17:59:43 1994 Jim Wilson (wilson@cygnus.com) + + * objc-act.c (build_module_descriptor): Don't set DECL_EXTERNAL on + current_function_decl. + + * combine.c (simplify_rtx): For (not (xor X C)) generate new rtx + instead of modifying old rtx. + + * c-decl.c (start_function): If old_decl is NULL, then set it to + the implicit decl if any. Delete superfluous test from warn missing + prototypes code. For warn missing declarations code, only warn if + previous decl is implicit. + +Thu Jul 21 17:47:05 1994 Paul Eggert (eggert@twinsun.com) + + * fold-const.c (fold): Don't fold X-X to 0 if X is floating point + and !flag_fast_math. + +Thu Jul 21 02:07:45 1994 Charles Levert (charles@comm.polymtl.ca) + + * Makefile.in (stmp-multilib): Rework to handle make -n. + (stmp-multilib-sub): New target. + +Tue Jul 19 23:14:42 1994 Larry Jones (larry.jones@sdrc.com) + + * configure (i[34]86-*-isc*): Treat isc4 like isc3. + Remove references to nonexistant files and add extra_parts + when needed. + (i[34]86-*-solaris2*): Remove reference to nonexistant + t-sco and use extra_parts instead. + (i[34]86-*-sysv*, i860-*-sysv3*, m68k-*-sysv3*, m68k-ncr-sysv*): + Replace t-svr3 with extra_parts. + +Tue Jul 19 20:31:34 1994 Doug Evans (dje@cygnus.com) + + * configure (find lang subdirs loop): Try to work around an + apparent bug in bash 1.12 on linux. + + * Makefile.in (clean): Remove multilib build dirs. + + * h8300.c (print_operand, default case): Handle SFmode regs. + +Mon Jul 18 22:02:53 1994 Jim Wilson (wilson@cygnus.com) + + * sparc.c (call_operand): Use symbolic_operand not CONSTANT_P. + (call_operand_address): Likewise. + * sparc.md (call*): Use symbolic_operand not immediate_operand. + Use 's' constraint not 'i' constraint. + + * toplev.c (rest_of_compilation): Clear DECL_ABSTRACT_ORIGIN if + clear DECL_INLINE. + + * global.c (find_reg): Store divide results in temporary variables. + + * gcc.c (process_command): When have -BstageN option, pass include + not stageN/../include to preprocessor. + +Mon Jul 18 21:58:27 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * loop.c (move_movables): Aviod lossage when CALL_INSN_FUNCTION_USAGE + is NULL. + +Mon Jul 18 20:53:54 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Rework required loop to avoid crash on decstation. + +Thu Jul 14 09:42:23 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Version 2.6.0 released. + + * explow.c (force_reg): Don't make a REG_EQUAL note for an insn + that doesn't set TEMP. + +Wed Jul 13 17:00:35 1994 Torbjorn Granlund (tege@rtl.cygnus.com) + + * expmed.c (expand_divmod, case CEIL_DIV_EXPR): + Handle emit_store_flag returning 0. + +Wed Jul 13 16:35:57 1994 Jim Wilson (wilson@cygnus.com) + + * expr.c (store_field): Set MEM_IN_STRUCT_P on object and + blk_object. + +Wed Jul 13 08:40:11 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * Makefile.in (distdir-start): Make tmp/ginclude and copy its files. + (distdir-finish): Don't use -f Makefile.in. + (gcc.xtar.gz): Add --best. + + * fold-const.c (decode_field_reference): Merge operand of + a BIT_AND_EXPR with the mask made from the description of the field. + + * fold-const.c (fold, case MULT_EXPR): Remove last change. + +Wed Jul 13 07:12:32 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * xm-pa.h, xm-pahpux.h, xm-pahiux.h (USE_C_ALLOCA): Define. + +Wed Jul 13 03:30:36 1994 Jason Merrill (jason@deneb.cygnus.com) + + * tree.h (TYPE_NEEDS_CONSTRUCTING): New macro. + (tree_type): Add needs_constructing_flag. + * function.c (assign_parms): If TYPE_NEEDS_CONSTRUCTING, pass by + invisible reference. + * calls.c (expand_call): Ditto. + +Wed Jul 13 06:49:05 1994 Simon Cooper (scooper@hardees.rutgers.edu) + + * objc/Object.m: Include stdarg.h before stdio.h. + +Tue Jul 12 21:31:59 1994 Jim Wilson (wilson@cygnus.com) + + * c-decl.c (pushdecl): Don't call lookup_name_current_level_global + when traditional. When doing checks against + IDENTIFIER_LIMBO_VALUE, also do check against + INDENTIFIER_GLOBAL_VALUE when traditional. + + * final.c (getpwd): Declare. + +Tue Jul 12 16:24:10 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (GO_IF_LEGITIMATE_ADDRESS): Only allow immediate addressing + using 5 bits to avoid losing with FP loads and stores on page zero. + +Tue Jul 12 16:20:09 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (ashlsi3, lshrsi3, ashrsi3): Only output low-order five + bits for !TARGET_POWER case. + +Tue Jul 12 13:06:14 1994 Jim Wilson (wilson@cygnus.com) + + * combine.c (record_dead_and_set_regs_1): Can only handle SUBREG + if the register is smaller or equal to BITS_PER_WORD. + + * sparc/sysv4.h (FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): Define. + + * final.c (end_final): Store full path name in .d file not just + the filename. + + * README.IRIX5: New file. + +Tue Jul 12 10:55:14 1994 Michael Meissner (meissner@osf.org) + + * i386/osfrose.h (CC1_SPEC): If both -pic-extern/-pic-lib and + -pic-none, use -pic-extern win, instead of -pic-none. + + * i386/osfelf.h (CC1_SPEC): Ditto. + +Tue Jul 12 09:08:06 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload.c (find_reloads): Don't try to call force_const_mem on + a HIGH. + + * fold-const.c (fold, case MULT_EXPR): If arg is an unsigned + CEIL_DIV_EXPR, convert to TRUNC_DIV_EXPR of a PLUS_EXPR in some cases. + + * alpha.md (ashldi3): Update pattern for (sign_extend (ashift ..)) + to match the current canonicalization. + + * explow.c (round_push, allocate_dynamic_stack_space): Avoid + using CEIL_DIV_EXPR; add adjustment and use TRUNC_DIV_EXPR instead. + +Tue Jul 12 08:12:04 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * dbxout.c (dbxout_source_file): Increment source_label_number outside + of macro expansion. + + * arm.c (reversible_cc_register): New function. + (final_prescan_insn): Don't try to conditionalize jumps with JUMP_CLOB + attribute. + * arm.h (PREDICATE_CODES): Add reversible_cc_register. + * arm.md (matcher for SFmode inequality comparison): Use cmfe, not cfm. + (matchers for {store-flag, not-store-flag, neg-store-flag}): Output + if-false instruction first before if-true instruction. + (matcher for (AND store-flag x)): Only match if reversible_cc_register. + (matcher for (IF-THEN-ELSE reg (NOT reg))): Likewise. + + * arm.h (FRAME_POINTER_REQUIRED): Always true if the function has + nonlocal labels. + * arm.md ({save,restore}_stack_nonlocal): Delete. + +Mon Jul 11 19:29:15 1994 Oliver Kellogg (okellogg@salyko.cube.net) + + * machmode.def (TQFmode): New mode. + * expr.c (convert_move): Add some conversions for TQFmode. + * varasm.c (assemble_real): Handle TQFmode output. + * config.sub (basic_machine): Add 1750a. + * configure (1750a-*-*): New configuration. + * 1750a.c, 1750a.h, 1750a.md, m1750a.inc: New files. + +Mon Jul 11 18:38:42 1994 Doug Evans (dje@cygnus.com) + + Add support for the h8/300h cpu. + * config/h8300/lib1funcs.asm: New file. + * h8300/t-h8300 (CROSS_LIBGCC1): Use libgcc1-asm.a. + (LIB1ASMSRC, LIB1ASMFUNCS, LIB2FUNCS_EXTRA, MULTILIB_OPTIONS, + MULTILIB_DIRNAMES, LIBGCC, INSTALL_LIBGCC): Define. + (fp-bit.c): Build it. + * h8300/h8300.h (CPP_PREDEFINES, CPP_SPEC, LIB_SPEC, TARGET_SWITCHES, + BITS_PER_WORD, MAX_BITS_PER_WORD, UNITS_PER_WORD, MAX_UNITS_PER_WORD, + POINTER_SIZE, PARM_BOUNDARY, BIGGEST_ALIGNMENT, + BIGGEST_FIELD_ALIGNMENT, STACK_BOUNDARY, HARD_REGNO_NREGS, + HARD_REGNO_MODE_OK, REG_CLASS_NAMES, REG_CLASS_CONTENTS, + REGNO_REG_CLASS, PUSH_ROUNDING, FUNCTION_ARG_ADVANCE, + TRAMPOLINE_TEMPLATE, TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE, + CONSTANT_ADDRESS, MOVE_MAX, Pmode, SIZE_TYPE, PTRDIFF_TYPE): + Add h8/300h support. + (LINK_SPEC, TARGET_RTL_DUMP, TARGET_H8300, TARGET_H8300H, + REAL_ARITHMETIC, SETUP_INCOMING_VARARGS, HAVE_POST_INCREMENT, + HAVE_PRE_DECREMENT, MAX_MOVE_MAX, NO_BUILTIN_SIZE_TYPE, + NO_BUILTIN_PTRDIFF_TYPE, WCHAR_TYPE, WCHAR_TYPE_SIZE, + MAX_WCHAR_TYPE_SIZE, ASM_WORD_OP, INIT_SECTION_ASM_OP, + CTORS_SECTION_ASM_OP, DTORS_SECTION_ASM_OP, EXTRA_SECTIONS, + EXTRA_SECTION_FUNCTIONS, ASM_OUTPUT_CONSTRUCTOR, ASM_OUTPUT_DESTRUCTOR, + DO_GLOBAL_CTORS_BODY, DO_GLOBAL_DTORS_BODY, INIT_TARGET_OPTABS): + Define. + (CAN_DEBUG_WITHOUT_FP, PCC_STATIC_STRUCT_RETURN, STRUCT_VALUE_REGNUM, + STRUCT_VALUE_INCOMING, STRUCTURE_SIZE_BOUNDARY): Undefine. + (enum reg_class): Add h8/300h support. + (emit_a_shift): Declare. + (TARGET_DEFAULT): Set default to -mquickcall. + (DOUBLE_TYPE_SIZE): Fix at 32. DFmode support doesn't exist. + (CALL_USED_REGISTERS, REG_ALLOC_ORDER): Swap registers 2,3 with 4,5. + Registers 0,1 contain function result, allocate after 2,3. + (STATIC_CHAIN_REGNUM): Use reg 4. + (CONST_OK_FOR_LETTER_P): 'O' is ok_for_bclr, 'P' is small_power_of_two. + (FUNCTION_PROFILER, FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER): First + attempt at an implementation. + (CONST_COSTS): Move code into function const_costs. + (BRANCH_COST): Set to 0. + (NOTICE_UPDATE_CC): Move code into function notice_update_cc. + (ASM_FILE_START): Move code into function asm_file_start. + (ASM_FILE_END): Move code into function asm_file_end. + (ASM_OUTPUT_DOUBLE, ASM_OUTPUT_FLOAT): Use REAL_VALUE_TO_DECIMAL. + * h8300/h8300.c (cpu_type, names_extended, names_upper_extended, + h8_reg_names, h8_push_ops, h8_pop_ops, h8_mov_ops, h8_push_op, + h8_pop_op, h8_mov_op, current_function_anonymous_args, extra_pop, + hand_list): New variables. + (h8300_init_once, asm_file_start, asm_file_end, ok_for_bclr, o_operand, + p_operand, call_insn_operand, jump_address_operand, bit_operand, + eq_operator, const_costs, notice_update_cc, bit_operator, + nshift_operator, expand_a_shift, get_shift_alg, emit_a_shift, + fix_bit_operand): New functions. + (shift_alg, shift_type, shift_mode): New enums. + (shift_insn): New struct. + (shift_n_bits, can_shift): Deleted. + (shift_one, rotate_one): New variables. + (WORD_REG_USED): New macro (was function word_reg_used). + (dosize, function_prologue, function_epilogue, print_operand_address): + Add h8/300h support. + (small_power_of_two): Renamed from potl8. + (potg8): Deleted. + (general_operand_src): Fix POST_INC case. + (general_operand_dst): Fix PRE_DEC case. + (function_arg): 3 regs of args are passed if -mquickcall. + 4 regs of args are passed to handwritten assembler routines. + (print_operand): New cases 'A', 'P', 'S', 'U', 'W', 'b', 'c', 'd', 'g'. + Delete case 'O'. Sort cases. Add h8/300h support. + (do_movsi): Renamed from domovsi. + Handle reload_in_progress and reload_completed. + (initial_offset): Renamed from io. Add h8/300h support. + * h8300/h8300.md (cpu): New attribute. + (attribute length): Add h8/300h support. + (attribute cc): New value `cbit'. + (all anonymous insns): Give them names. + (move insns): Add h8/300h support. + (tstqi, tsthi): Use btst insn if able. + (arithmetic insns): Add h8/300h support. + (boolean insns): Likewise. + (negate insns): Likewise. + (branch insns): Likewise. + (call_value): Use call_insn_operand for operand 1. + (shift insns): Completely rewritten. Add h8/300h support. + (zero/sign extension insns): Add h8/300h support. + (extv): Deleted. + (insv, extzv): Only use for h8/300. + (bitfield insns): Completely rewritten. + (fancyb*): New insns for speeding up bit accesses. + + * optabs.c (init_optabs): Allow target specific libcalls + with INIT_TARGET_OPTABS. + +Mon Jul 11 18:32:42 1994 Steve Chamberlain (sac@cygnus.com) + + * config/fp-bit.c: New file. Provides simple fp emulation library. + +Mon Jul 11 18:27:42 1994 Ian Lance Taylor (ian@cygnus.com) + + * Makefile.in (libgcc1-asm.a): New target for building libgcc1.a + in cross compilers. + +Mon Jul 11 17:00:45 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (movsi matcher): Add nop for moving special register + to itself for !TARGET_POWER. + (movhi and movqi matcher): Likewise and add mtjmpr attribute. + Separate MQ from CTR and LR target registers for TARGET_POWER. + + * powerpc.h (CPP_SPEC): Fix typo. + +Mon Jul 11 16:50:29 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-parse.in (stmt): Don't give more than one error message if a + nested `if' has an empty body. + + * a29k.md (movqi): Call loadhi, not loadqi. + +Mon Jul 11 16:46:09 1994 Jeffrey A. Law (law@mole.gnu.ai.mit.edu) + + * pa.h (DEBUGGER_ARG_OFFSET): Define. If no frame pointer + is available, then adjust the offset by the size of the + current frame. + +Mon Jul 11 16:34:14 1994 Stan Shebs (shebs@andros.cygnus.com) + + * configure (*-*-lynxos*): Always run fixincludes, and if not using + gas, set tm_file to lynx-ng.h. + * config/x-lynx: Always run fixproto. + * config/lynx.h, i386/lynx.h, m68k/lynx.h, sparc/lynx.h: Rewrite + to work with gas producing coff files. + * config/lynx-ng.h, i386/lynx-ng.h, m68k/lynx-ng.h, + sparc/lynx-ng.h: New files. + +Mon Jul 11 15:16:28 1994 Pat Rankin (rankin@eql.caltech.edu) + + * make-cc1.com: Compile most of cc1plus in the `cp' subdirectory. + * vmsconfig.com: When setting up tm.h, convert "vax/vax.h" into + "config-vax.h" rather than "[.config.vax]vax.h" for #include so + it will work from [.cp] subdirectory; copy vax.h to config-vax.h + as part of configuration setup. Also, manually include cc1plus + in the list of buildable compilers (a temporary measure; it + should process cp/Makefile.in like it does for primary makefile). + + * make-cc1.com: Use `=' rather than `:=' when setting up CC, + so that `gcc' can be defined as a foreign command if necessary; + eliminate `set symbol/scope=noGlobal' for same reason; use `=' + with all other symbols, for consistency; add explicit .obj + extension to some lists of object files passed to the linker; + general cleanup of the command text echoed during execution. + * make-cccp.com: Revise to be more consistent with make-cc1.com + for symbol setup & usage and for echoing command execution. + +Mon Jul 11 15:03:23 1994 Charles Hannum (mycroft@duality.gnu.ai.mit.edu) + + * configure: Recognize m68k-*-netbsd* and i[345]86-*-netbsd*. + * cccp.c, collect2.c, gcc.c, protoize.c, cp/g++.c (sys_errlist) + [bsd4_4]: Do this for __NetBSD__ also. + +Mon Jul 11 14:16:28 1994 Kresten Krab Thorup (krab@spiff.gnu.ai.mit.edu) + + * mips/mips.h (STRUCT_VALUE): Change definition from `(rtx)0' to + just `0' so it is a valid expression for the pre-processor. + +Mon Jul 11 10:54:35 1994 Stan Cox (coxs@dg-rtp.dg.com) + + * configure (m88k-dg-dguxbcs): New configuration. m88k-dg-dgux + Now builds an elf compiler. Both targets will create bcs or elf. + + * m88k/dgux.h (ASM_SPEC,STARTFILE_SPEC,LIB_SPEC): svr4 default. + + * m88k/dguxbcs.h (ASM_SPEC,STARTFILE_SPEC,LIB_SPEC): + New target for svr3. + + * m88k/x-dgux, m88k/t-dgux, m88k/x-dguxbcs: + Changed for svr4/svr4/svr3 respectively. + + * m88k/m88k.h (TARGET_SVR3): New target switch. + +Wed Jun 29 19:23:27 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu) + + * alpha.h (LIB_SPEC): If -pg, add -lprof2. + +Mon Jul 11 13:17:38 1994 Ian Lance Taylor (ian@cygnus.com) + + * combine.c (simplify_set): Only turn IF_THEN_ELSE into AND if + MODE_INT. + +Sun Jul 10 06:03:12 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (eliminate_regs_in_insn): Handle special case of + assignment from hard frame pointer to frame pointer (for + nonlocal goto). + * function.c (instantiate_virtual_regs_1): Remove last change. + * stmt.c (expand_end_bindings): When adjusting FP, set it + from hard_frame_pointer_rtx. + + * expr.c (expand_builtin, case BUILT_IN_FSQRT): Don't use + asterisk in name of `errno'. + +Fri Jul 8 22:07:32 1994 Jim Wilson (wilson@cygnus.com) + + * stdarg.h: Delete include of <stdarg.h> when not gcc. + * varargs.h: Delete include of <varargs.h> when not gcc. + +Fri Jul 8 18:45:56 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k/mot3300.h (FUNCTION_EXTRA_EPILOGUE): Copy a0 to d0, not + the other way. + +Fri Jul 8 17:41:39 1994 Jim Wilson (wilson@cygnus.com) + + * expr.c (get_inner_unaligned_p): New function. + (expand_assignment, expand_expr): Use it. + +Fri Jul 8 17:16:25 1994 Doug Evans (dje@cygnus.com) + + * expmed.c (extract_split_bit_field): Set UNIT to BITS_PER_WORD for + register values. + (store_split_bit_field): Likewise. Call operand_subword_force. + +Fri Jul 8 13:48:23 1994 Mike Stump (mrs@cygnus.com) + + * expr.c (target_temp_slot_level): New variable to keep track of + the current stack level for temporaries created by TARGET_EXPRs. + * expr.h (target_temp_slot_level): Declare it. + * expr.c (expand_expr): Add code to maintain the new temporary + stack for TARGET_EXPRs to the CLEANUP_POINT_EXPR code and change + the allocation of temporaries for TARGET_EXPRs to be from the new + stack, so that they may live longer, and only be reused after they + are no longer in use. + * function.c (assign_stack_temp): KEEP can now also be 2, to + indicate allocation from the longer term frontend controlled + temporary stack. + * function.c (init_function_start): Initialize + target_temp_slot_level to zero. + +Fri Jul 8 16:52:38 1994 Jim Wilson (wilson@cygnus.com) + + * combine.c (distribute_notes, REG_DEAD case): When check to see + if insn uses register, also call find_regno_fusage. + + * sparc.h (SECONDARY_MEMORY_NEEDED_RTX): Call assign_stack_local + if the frame has zero size. + +Fri Jul 8 11:46:50 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * varasm.c (record_constant_rtx, force_const_mem): Ensure everything + is in saveable_obstack, not current_obstack. + + * combine.c (force_to_mode): OP_MODE must be MODE if MODE and + mode of X are of different classes. + (nonzero_bits, num_sign_bit_copies): Say nothing known for + floating-point modes. + + * function.c (instantiate_virtual_regs_1, case SET): + If DEST is virtual_stack_vars_rtx, replace with hardware + frame pointer. + + * expr.c (expand_expr, case CONVERT_EXPR): If changing signedness + and we have a promoted SUBREG, clear the promotion flag. + + * c-decl.c (finish_decl): Put RTL and other stuff in + permanent_obstack if DECL is. + + * combine.c (gen_unary): Add new arg, OP0_MODE. + All callers changed. + +Thu Jul 7 19:58:35 1994 Jason Merrill (jason@deneb.cygnus.com) + + * varasm.c (assemble_variable): Do set TREE_ASM_WRITTEN on + erroneous incomplete decls. + +Thu Jul 7 17:59:46 1994 Joseph Arceneaux (jla@gnu.ai.mit.edu) + + * configure (m68k-motorola-sysv*): Use mot3300g.h for gas. + * m68k/mot3300g.h: New file. + +Thu Jul 7 17:42:21 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k/mot3300.h (FUNCTION_EXTRA_EPILOGUE): Fix typo in last change. + +Thu Jul 7 17:36:26 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expmed.c (expand_mult_highpart): Build constant forms of CNST1 + in MODE or WIDE_MODE, as appropriate. + + * optabs.c (expand_binop, case DIV [complex]): Fix typo in last change. + + * alpha.md (reload_inqi): Make operand[2] be TImode and + pass register number that differs to unaligned_loadqi. + (reload_outqi): Change overlap in temps to unaligned_storeqi. + * alpha.c ({un,}aligned_memory_operand): Check against + hard_frame_pointer_rtx, not frame_pointer_rtx. + +Thu Jul 7 01:39:33 1994 Doug Evans (dje@cygnus.com) + + * combine.c (make_compound_operation, AND case): Do extraction in + desired result mode. + + * flow.c (mark_set_1): Record explicit hard registers in their + raw mode. + (mark_used_regs): Likewise. + * combine.c (distribute_notes): Likewise. + +Wed Jul 6 14:45:08 1994 Pat Rankin (rankin@eql.caltech.edu) + + * longlong.h (vax sdiv_qrnnd): Fix typo. + +Wed Jul 6 19:59:12 1994 Mike Stump (mrs@cygnus.com) + + * expr.c (expand_expr, defer_cleanups_to, expand_cleanups_to): All + cleanups have to be protected by interim exception handling code. + * stmt.c (expand_decl_cleanup, expand_cleanups): Ditto. + * toplev.c (interim_eh_hook): Hook for interim exception handling. + * toplev.c (interim_eh): Default implementation for exception + handling that does nothing. + * toplev.c (main): Set default for interim_eh_hook. + +Wed Jul 6 17:56:37 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.c (output_prolog): Start memory probing with $2. + +Wed Jul 6 14:21:14 1994 Jim Wilson (wilson@cygnus.com) + + * stmt.c (struct nesting): Add new field alt_end_label. + (expand_start_loop): Initialize it to zero. + (expand_end_loop): Reorder loop if find either a jump to end_label + or a jump to alt_end_label. + (expand_exit_loop_if_false): Set alt_end_label. + +Wed Jul 6 05:07:31 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * c-common.c (decl_attributes): If TREE_TYPE for the DECL is updated, + then update TYPE as well. + + * longlong.h (arm umul_ppmm): Fix use of uninitialized register. + Eliminate clobbers of hard registers. + +Wed Jul 6 03:22:04 1994 Torbjorn Granlund (tege@rtl.cygnus.com) + + * expmed.c (expand_divmod): Clear out TARGET also if OP1 is a + constant, when TARGET == OP0. + +Tue Jul 5 18:58:28 1994 Torbjorn Granlund (tege@rtl.cygnus.com) + + * Makefile.in (c-parse.y): Redirect through tmp file. + (objc-parse.y): Likewise. + (c-gperf.h): Likewise. + (mostlyclean): Delete the new tmp files. + + * expmed.c (expand_divmod): Fix typo setting op1_is_pow2. + (expand_divmod): Handle powers-of-two specifically for unsigned + CEIL_*_EXPR. + + * longlong.h: Really fix the test for _IBMR2. Change test of + __powerpc__ to _ARCH_PPC. + +Tue Jul 5 17:00:19 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * combine.c (try_combine): Don't check for replacing + arg of function here. + (can_combine_p): Do it here. + + * expr.c (expand_increment): If pre-incrementing a promoted + variable, don't adjust OP0 since the result won't be used. + + * jump.c (duplicate_loop_exit_test): Handle SUBREG in SET_DEST + of loop exit test statements. + + * combine.c (try_combine): If I2DEST was used in I2SRC, it isn't + unused just because there is no SET for I2 anymore. + +Mon Jul 4 11:15:13 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.h (RS6000_OUTPUT_BASENAME): Always call assembler_name + and pass the actual symbol name. + + * varasm.c (assemble_name): Call STRIP_NAME_ENCODING. + + * cse.c (canon_hash, exp_equiv_p): Refer to string in SYMBOL_REF + with XSTR, not XEXP. + +Sat Jul 2 18:53:19 1994 Jim Wilson (wilson@cygnus.com) + + * mips.md (smuldi3_highpart, smuldi3_highpart_internal, + umuldi3_highpart, umuldi3_highpart_internal): New patterns. + + * unroll.c (loop_iterations): Only use REG_EQUAL note value if it + is constant. + + * dbxout.c (dbxout_type_methods): Enable debugging info for + template classes. + + * c-lex.c (yylex): Reject imaginary numbers when pedantic. + + * c-decl.c (duplicate_decls): When make void* match char*, set + DECL_IN_SYSTEM_HEADER. + + * Makefile.in (clean): Delete LIB2FUNCS_EXTRA. + + * alpha.h (FUNCTION_PROFILER, FUNCTION_BLOCK_PROFILER, + BLOCK_PROFILER): Use multiple fputs/fprintf calls instead of ANSI + C concatenated strings. + (PREDICATE_CODES): Add cint8_operand. + + * gcc.c (DEFAULT_WORD_SWITCH_TAKES_ARG): Add -isystem. + +Sat Jul 2 09:34:20 1994 Torbjorn Granlund (tege@rtl.cygnus.com) + + * expmed.c (expand_divmod): Always return gen_lowpart (mode, ...). + +Fri Jul 1 19:28:39 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * reorg.c (make_return_insns): Make sure redirecting a jump to + a RETURN insn does not invalidate the delay slots of the jump. + +Fri Jul 1 16:32:58 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * longlong.h: (arm umul_ppmm): Fix typos in last change. Mark + hard-coded registers with "%|". + +Fri Jul 1 10:08:47 1994 Jason Merrill (jason@deneb.cygnus.com) + + * toplev.c (compile_file): Pass through static consts and inlines + multiple times in case they reference each other. + +Fri Jul 1 07:41:19 1994 Torbjorn Granlund (tege@tiny.cygnus.com) + + * longlong.h: Test for _AM29K and _IBMR2, not ___AM29K__ + and ___IBMR2__. + (arm umul_ppmm): New definition. + (clipper umul_ppmm, smul_ppmm, __umulsidi3): New definitions. + (hppa count_leading_zeros): New definition. + (i960 umul_ppmm, __umulsidi3): New definitions. + (mc68000 umul_ppmm): Use %. before size suffixes. + (mc88110 umul_ppmm, udiv_qrnnd): Rewrite, + (mc88000): Get UMUL_TIME and UDIV_TIME right. + (mips): Get UMUL_TIME right. + (ns32000 umul_ppmm): New definition. + (ns32000 udiv_qrnnd): Rename from bogus div_qrnnd, rewrite. + (powerpc umul_ppmm, smul_ppmm): New definitions. + (_IBMR2/powerpc add_ssaaaa, sub_ddmmss): Improve. + (pyr umul_ppmm): Fix typo. + (sparc add_ssaaaa, sub_ddmmss): Match constant 0 for all inputs. + (vax sdiv_qrnnd): New definition. + + * expmed.c (expand_divmod): Put OP0 in a register when computing + remainder, or when OP1 is constant. + +Fri Jul 1 06:46:09 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * jump.c (jump_optimize): Don't convert if (foo) x++ into an + add of an scc unless X has no side effects and can't trap. + + * c-parse.in (initelt): The equal sign is optional when + positioning to a single element of an array. + + * c-typeck.c (push_init_level): If not at "unfilled" position, + set constructor_incremental to 0; likewise for range. + + * xm-alpha.h: If GNUC, include alloca.h, else declare alloca. + + * m68k/mot3300.h (FUNCTION_EXTRA_EPILOGUE): New macro. + + * expmed.c (expand_divmod): Don't set REG_NOTES unless we generated + a quotient. + +Thu Jun 30 18:25:52 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * gcc.c (do_spec_1, case 'P'): Don't add underscores to macros + starting with '_[A-Z]'. + +Thu Jun 30 18:16:36 1994 Will Athanasiou (will@guardian.westford.ccur.com) + + * m68k.md (umulsi3_highpart, smulsi3_highpart): Fix constraint + for operand 0 in define_insn. + +Thu Jun 30 16:07:33 1994 Kaveh R. Ghazi (ghazi@noc.rutgers.edu) + + * fixincludes: Put wrappers around <time.h> and <sys/time.h> to + avoid multiple inclusion errors on m88k-tektronix-sysv3. + +Thu Jun 30 12:08:48 1994 Kresten Krab Thorup (krab@spiff.gnu.ai.mit.edu) + + * objc-act.c, objc/init.c (OBJC_VERSION): Incremented to 6. + + * objc/sendmsg.c (INVISIBLE_STRUCT_RETURN): New macro. + (__objc_block_forward): Declare depending on the above. + + * objc/class.c (objc_next_class): New function. + * objc/objc-api.h (objc_next_class): New function. + + * objc-act.c (get_proto_encoding, build_typed_selector_reference): + New fucnctions. (UTAG_PROTOCOL): New define. + (objc_selector_template, flag_typed_selectors): New variables. + (objc_init): set flag_typed_selectors if -fgnu-runtime. + (synth_module_prologue): Change declaration of + _OBJC_SELECTOR_TABLE when flag_typed_selectors is non-null. + (build_module_descriptor): Make sure the generated constructor + function is declared public. + (build_selector): Only cast to SEL when not doing typed selectors. + (build_selector_translation_table): Rewrite initialization. + (build_tmp_function_decl): Make up new name when called, since it + may now be called multiple times. + (hack_method_prototype): Use init_function_start to reinit args + machinery. Also set current_function_decl before calling + assign_parms. + (generate_protocols): Don't generate encoding twice. + (build_selector_template): New function. + (build_method_list_template): Generate (void*)0 as first element, + not (int)0. + (build_message_expr): move the call to build_selector_reference + towards the end, where we have determined the function prototype. + + * objc/Object.h, objc/Object.m (read:, write:, streamVersion:): + Un-disable for alpha. (forward::, performv::): Declare and fix to + return retval_t. + * objc/archive.c: Completely rewritten to handle 64 bit longs and + pointers. + * objc/class.c (class_pose_as): Rewritten. + * objc/encoding.c: use new ROUND macro for alignment rounding. + * objc/init.c, objc/selector.c, objc/sendmsg.c: Rewritten to + handle new selectors. + +Thu Jun 30 07:49:50 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.h (INITIAL_ELIMINATION_OFFSET): Check frame_pointer_needed when + eliminating the arg pointer into the stack pointer. + +Thu Jun 30 06:25:50 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-common.c (c_build_type_variant): Remove last change; instead, + copy TYPE if not in old obstack. + +Wed Jun 29 21:51:52 1994 Jason Merrill (jason@deneb.cygnus.com) + + * toplev.c (lang_options): Add -W{no-,}non-virtual-dtor. + +Wed Jun 29 19:23:27 1994 David Mosberger-Tang (davidm@piston.cs.arizona.edu) + + * final.c (end_final,profile_function): Profiling variables are + size of pointer, not int. + * alpha.h (LIB_SPEC): If -pg, add -lprof2. + (STARTFILE_SPEC, {FUNCTION,BLOCK,FUNCTION_BLOCK}_PROFILER): New macros. + +Wed Jun 29 15:52:45 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * loop.c (basic_induction_var, case REG): Allow previous + insn to set a SUBREG of X. + + * alpha.c (alpha_sa_size): Round size to 16-byte boundary. + (add_long_const): Add new arg, TEMP_REG. + (output_{pro,epi}log): Rework to put save area between outgoing + args and local variables. + * alpha.h (FRAME_POINTER_REGNUM): Now register 63. + (HARD_FRAME_POINTER_REGNUM): New macro. + (CONDITIONAL_REGISTER_USAGE, REG_CLASS_CONTENTS, REGNO_REG_CLASS): + Show register 63 is not an FP register. + (REGHNO_OK_FOR_BASE_P, REG_OK_FOR_BASE_P, REGISTER_NAMES): Likewise. + (ALPHA_ROUND): New macro. + (STARTING_FRAME_OFFSET, ELIMINABLE_REGS, INITIAL_ELIMINATION_OFFSET): + Modify to reflect save area between outgoing args and local vars. + * alpha.md: Add new pattern for double-add when have + reg + frame pointer. + Slight changes to all such patterns and add define_splits for them. + + * global.c (global_alloc): Make a more accurate attempt to see + if the frame pointer will be used. + If it is, show HARD_FRAME_POINTER_REGNUM used if its not + the same as FRAME_POINTER_REGNUM. + * reload1.c (reload): Can't eliminate if frame pointer needed + and TO is stack pointer. + Spill HARD_FRAME_POINTER_REGNUM if not FRAME_POINTER_REGNUM + and frame pointer is needed. + (spill_hard_reg): If CANT_ELIMINATE, set regs_ever_live; + no longer done by callers. + + * a29k.md (movqi): Add missing `DONE'. + +Wed Jun 29 15:44:18 1994 Doug Evans (dje@canuck.cygnus.com) + + * sparc/sparc.h (CPP_SPEC): Split up v9/non-v9 stuff. + Move -Acpu and -Amachine from here. + (CPP_PREDEFINES): To here. + (NO_BUILTIN_PTRDIFF_TYPE): Undefine. + (NO_BUILTIN_SIZE_TYPE): Likewise. + (PTRDIFF_TYPE): Split up v9/non-v9 definitions. + (SIZE_TYPE): Likewise. + * sparc/sp64-elf: (PTRDIFF_TYPE): Remove dependence on POINTER_SIZE. + (SIZE_TYPE): Likewise. + +Wed Jun 29 15:28:17 1994 Michael Meissner (meissner@osf.org) + + * cccp.c (collect_expansion): Always put 1 space after the macro + expansion in ANSI mode to fix regression from June 24th. + +Tue Jun 28 22:41:52 1994 Doug Evans (dje@cygnus.com) + + * combine.c (simplify_set): Evaluate HAVE_conditional_move at runtime. + +Tue Jun 28 20:27:08 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * optab.c (expand_binop): Convert OP0 to mode for library calls. + + Changes to optimize division-by-constants, and make ceil and floor + rounding work correctly: + * expmed.c (expand_mult): Generalize to call synth_mult also + for OP1 - 1. + (ceil_log2): New function. + (choose_multiplier): New function. + (invert_mod2n): New function. + (expand_mult_highpart_adjust): New function. + (expand_mult_highpart): New function. + (EXACT_POWER_OF_2_OR_ZERO_P): New macro. + (expand_divmod): Almost completely rewritten. + (expand_shift): Don't truncate immediate shift count, it doesn't work + for types smaller than int. + * expr.h (smul_highpart_optab, umul_highpart_optab): New variables. + * genopinit.c (optabs): Add [us]mul_highpart_optab. + * optabs.c (smul_highpart_optab, umul_highpart_optab): New variables. + (expand_binop): Handle [us]mul_highpart_optab as commutative. + (init_optabs): Initialize [us]mul_highpart_optab. + * fold-const.c (div_and_round_double): Make it globally accessible. + * a29k.md (smulsi3_highpart, umulsi3_highpart): New patterns. + * alpha.md (umuldi3_highpart): New expander and matcher. + * alpha.c (cint8_operand): New predicate. + * m68k.md (umulsi3_highpart, const_umulsi3_highpart): + New expander and matcher. + (smulsi3_highpart, const_smulsi3_highpart): Likewise. + +Tue Jun 28 13:42:10 1994 Jim Wilson (wilson@cygnus.com) + + * sol2.h (CPP_SPEC): Handle -msupersparc. + * sparc.c (cpu_type, sparc_cpu_type): Rename to arch_type and + sparc_arch_type. Fix all users. + (supersparc_adjust_cost): New function. + * sparc.h (cpu_type, sparc_cpu_type): Rename to arch_type and + sparc_arch_type. + (CPP_SPEC): Handle -msupersparc. + (MASK_SUPERSPARC, TARGET_SUPERSPARC): New macros. + (TARGET_SWITCHES): Add -msupersparc and -mcypress. + (ADJUST_COST): New macro. + * sparc.md (cpu attribute): Rename to arch attribute. Add a new + cpu attribute. Fix all users. + (type attribute): Add ialu, shift, imul, fpdivs, and fpdivd. + Delete fpdiv. + (function units): Add Cypress and Supersparc versions of each. + (addsi3, subsi3, andsi3, iorsi3, xorsi3): Add ialu type attribute. + (mulsi3): Add imul type attribute. + (divtf3, divdf3): Use fpdivd not fpdiv type attribute. + (divsf3); Use fpdivs not fpdiv type attribute. + (ashlsi3, ashrsi3, lshrsi3): Add shift type attribute. + + * i960.md (andsi3+6): Replace bad clrbit pattern with two working + ones. + +Tue Jun 28 13:31:31 1994 Uwe Seimet (seimet@iris1.chemie.uni-kl.de) + + * configure (m68k-atari-sysv4*): New configuration. + * m68k/atari.h, m68k/xm-atari.h: New files. + +Tue Jun 28 12:41:32 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.md (define_split for (plus (reg) (large_constant))): Treat + large_constant as signed. + +Tue Jun 28 05:46:55 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (eliminate_regs_in_insn): When checking for moves + and adds, use single_set. + + * reload1.c (reloads_conflict): Handle R1_TYPE of RELOAD_OTHER. + + * expr.c (do_jump, case BIT_AND_EXPR): Only narrow to a type + that corresponds to a mode. + +Tue Jun 28 05:41:29 1994 Will R. Athanasiou (will@westford.ccur.com) + + * rs6000.h (MEMORY_MOVE_COST): Make processor-dependent. + * rs6000.md (movsf): Emit frsp if storing to memory and not PowerPC. + (movsf matcher): Remove explicit frsp. + (store sf with update): Likewise. + * rs6000.c: Include ctype.h. + +Tue Jun 28 05:40:44 1994 Mike Collison (collison@chianti.sw.stratus.com) + + * real.c: Treat HFmode like SFmode, for now. + +Mon Jun 27 19:16:49 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * optabs.c (expand_binop, multi-words shifts and rotates): + Fix errors in last change. + +Mon Jun 27 11:29:18 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c: Include "expr.h". + (arm_fpu): New variable. + (arm_gen_movstrqi): Fix typo. + * arm.h: (enum floating_point_type): New enumeration type. + (arm_fpu): New declaration. + * arm.md: (function_unit fpa): Add more accurate scheduling + information. + (all floating point patterns): Add more detailed instruction type + information to attributes. + * riscix.h: (STARTFILE_SPEC,SIZE_TYPE,PTRDIFF_TYPE): Fix typos. + (ASM_FINAL_SPEC): Only reject -mbsd and -mxopen when -pedantic. + +Sun Jun 26 05:37:26 1994 Pat Rankin (rankin@eql.caltech.edu) + + * toplev.c (v_message_with_decl): Avoid fwrite for stderr; mixing + it with fprintf and fputs can cause strange results under VMS. + +Sat Jun 25 06:07:56 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * combine.c (distribute_notes, case REG_DEAD): If a call uses a + hard reg, then this is where it dies. + +Fri Jun 24 19:09:33 1994 Chip Salzenberg (chip@fin.uucp) + + * cccp.c (create_definition): Eliminate whitespace before and + after macro definitions. + +Fri Jun 24 16:19:27 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * c-decl.c (lang_decode_option): Set warn_bad_function_cast + for -Wbad-function-cast. + * c-typeck.c (build_c_cast): Issue a warning for non-matching cast + from a function call (like malloc without proto). + * c-tree.h: Declare warn_bad_function_cast. + * toplev.c (lang_options): Add -W[no]-bad-function-cast. + +Fri Jun 24 16:09:12 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax.h (ASM_IDENTIFY_LANGUAGE): New macro. + +Fri Jun 24 15:36:37 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * jump.c (jump_optimize): If we reverse "if (foo) bar else break;" + and there follows a NOTE_INSN_LOOP_END, move the note before "bar". + + * arm.md (movstrsi): Delete. + (movstrqi): New expand. + * arm.h (arm_gen_movstrqi): New function. + +Fri Jun 24 14:43:46 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.c (alpha_builtin_saveregs): Fix typo in computing value + for __base. + + * vax.md (zero_extract patterns): Don't allow constants in + the first operand of ZERO_EXTRACT since the recognizer + function forces them to match the mode of the match_operand. + + * c-typeck.c (decl_constant_value): Test for const and + not iterator. + (default_conversion, digest_init): Remove redundant checks + before calling decl_constant_value. + (convert_for_assignment): See if RHS has a constant value. + + * m68k.md (ashrsi3, lshrsh3): Remove patterns using bfext[su]. + + * reg-stack.c (goto_block_pat): Ignore undefined label. + +Thu Jun 23 22:07:42 1994 Doug Evans (dje@cygnus.com) + + * sparc/sp64-elf.h (LINK_SPEC): Fix typo. + (PTRDIFF_TYPE): Likewise. + +Thu Jun 23 19:15:36 1994 Jason Merrill (jason@deneb.cygnus.com) + + * tree.h (TREE_SYMBOL_REFERENCED): New macro. + * varasm.c (assemble_name): Set TREE_SYMBOL_REFERENCED on the + identifier for `name'. + * toplev.c (compile_file): Use TREE_SYMBOL_REFERENCED instead of + TREE_USED and TREE_ADDRESSABLE where appropriate. + +Thu Jun 23 19:06:05 1994 Randy Wright (rwright@dhostwo.convex.com) + + * cse.c (simplify_unary_operation, case UNSIGNED_FLOAT): Add + missing cast to unsigned. + +Thu Jun 23 19:00:18 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (fix_truncdfsi2, movsf, movdi): Use assign_stack_temp. + (mulsidi3): Add earlyclobber constraint modifier to PowerPC + version and !TARGET_POWERPC64 to final condition. + + * rs6000.h (CPP_PREDEFINES): Define _POWER (alias for _IBMR2). + (CPP_SPEC): New macro. + * powerpc.h (ASM_SPEC): Use PowerPC mode, not 601 mode. + (CPP_SPEC): New macro. + (TARGET_DEFAULT): Generate pure PowerPC code, not 601-specific. + +Thu Jun 23 18:09:23 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax.h (CPP_PREDEFINES): Add `__vax__'. + * vax/vms.h (CPP_PREDEFINES): Add `__vax__', `__vms__', and `__VMS__'; + update __GNUC_MINOR__ to 6. + +Thu Jun 23 17:59:41 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * toplev.c (compile_file): Don't try to write function if we + didn't save insns for it. + + * reload.c (find_reloads): Don't rejecting non-const due to value + of PREFERRED_RELOAD_CLASS if no regs were valid for alternative. + +Thu Jun 23 17:45:55 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.c (output_move_double): If the dest is register pair and both + regs are used in src address, use ADDR to compute src address, not + ADDD, which throws away scaled index. + +Thu Jun 23 17:40:06 1994 Craig Burley (burley@gnu.ai.mit.edu) + + * c-decl.c (clear_binding_level): Add missing fields in initializer. + (c_decode_option): Correct misspelling of -fno-dollars-in-identifiers. + +Thu Jun 23 13:47:23 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Fix return type of sbrk in <unistd.h> on Alpha + OSF/1 V2.0. Also, redirect grep errors to /dev/null in <assert.h> + fix. + +Thu Jun 23 12:08:23 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c: Include tree.h. + (const_ok_for_arm): Add fast return for 0 or just one non-zero bit. + (const_ok_for_op, arm_split_constant): New functions. + (arm_rtx_costs, reg_or_int_operand): New functions. + (shift_operator): Accept ROTATERT. + (multi_register_push): New function. + (shift_op): Don't abort if a constant is outside the acceptable range, + but convert the whole shift expression into something legal. If the + shift is zero, then return NULL. + (output_return_instruction): Output a call to abort if the function is + volatile. + (arm_volatile_func): New function. + (get_prologue_size): Remove all adjustments for insns that are now + output as rtx. + (output_func_prologue): Remove all code that outputs instructions, + just print a few comments. + (output_func_epilogue): Output a call to abort if a volatile function + tries to return. + (emit_multi_reg_push): New function. + (arm_expand_prologue): New function. Don't bother to push call-saved + regs if we will never return. + (arm_print_operand, case 'S'): If shift_op returns NULL, then no shift + is required. + * arm.h (TARGET_WHEN_DEBUGGING): Delete. + (MODES_TIEABLE_P): All modes of the same class are tieable. + (CONST_OK_FOR_LETTER_P): Add 'M' for constants valid in a shift. + (FUNCTION_PROFILER): Don't call arm_increase_location. + (INITIAL_ELIMINATION_OFFSET): Call saved regs are no-longer pushed for + functions that don't return. + (LEGITIMIZE_ADDRESS): Push constants that will never be legitimate -- + symbols and labels -- into registers. Handle DImode better. + (DEFAULT_SIGNED_CHAR): Use unsigned unless already defined. + (RTX_COSTS): Call arm_rtx_costs. + (ADDRESS_COST): Since most operations have the same rtx cost, make the + more complex addresses cheaper. + (PREDICATE_CODES): Add ROTATERT to shift_operator; and new predicates + for reg_or_int_operand and multi_register_push. + (DBX_CONTIN_LENGTH): Only define if not already done. + (PRINT_OPERAND_ADDRESS): Let arm_print operand output the ", " for + shifts. + * arm.md (addsi3, subsi3, andsi3, iorsi3, ashlsi3, ashrsi3, lshrsi3, + rotrsi3): Rewrite as expand patterns. + (rotlsi3): New expand. + (matchers, and split patterns for above): New. + (all patterns with shifts): Let arm_print_operand output the ", " + before a shift if it is needed. + (zero_extendqihi2): Delete. + (zero_extendqisi2): Expand to (and ...) if not memory. + (movsi): Call arm_split_constant to generate a constant. + (movqi): Only force a MEM into a register if not reloading. + (movsf, movdf): If loading a non-immediate floating point value, or + loading and floating point immediate into integer regs, push the + constant straight into the pool. + (movdf): Get rid of the scratch register. + (reload_outdf): Rewrite to expand to the two required insns. + (matcher for movdf): Remove alternative that used scratch register for + storing. + (movxf): rewrite as expand. + (matcher for movxf): Recognize even when XFmode code is disabled, so + that prologue insns can be generated. + (Matcher for reversed conditional jump): Don't match if the mode of the + CC register is not reversible. + (prologue): New expand. + (matcher for multi_register_push insn): New. + * riscix.h: Delete some dead code. + (STARTFILE_SPEC): Look in the correct places for start files. + (LIB_SPEC): Define. + (LINK_SPEC): Define. + (TARGET_WHEN_DEBUGGING): Delete. + (DEFAULT_SIGNED_CHAR): Set to unsigned. + (SIZE_TYPE, PTRDIFF_TYPE, TARGET_EDOM): Define. + * rix-gas.h (DBX_CONTIN_LENGTH): Set to 80. + (DEFAULT_GDB_EXTENSIONS, DBX_NO_XREFS): Don't try to pander to dbx, it + is just to broken to use. + +Wed Jun 22 20:13:03 1994 Will Athanasiou (will@westford.ccur.com) + + * configure (m68k-ccur-rtu): New configuration. + * config.sub (m68k-ccur): New system. + * protoize.c: Include <dirent.h>, not <sys/dir.h> on Concurrent. + * ccur-GAS.h, x-ccur: New files. + +Wed Jun 22 18:49:17 1994 Walter Misar (misar@rbg.informatik.th-darmstadt.de) + + * m68k/hp320.h (LINK_SPEC): New macro. + +Wed Jun 22 18:43:51 1994 Ian Lance Taylor (ian@cygnus.com) + + * configure: For target alpha-*-*, if using gas, set + target_cpu_default to 4. + * config/alpha/alpha.h (TARGET_SWITCHES): Include + TARGET_CPU_DEFAULT in default value. + (TARGET_CPU_DEFAULT): Define as 0 if not already defined. + (ASM_FINAL_SPEC): Include TARGET_CPU_DEFAULT in test for which + version to define. + +Wed Jun 22 18:15:41 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * loop.c (strength_reduce): When replacing DEST_ADDR givs, make + sure resulting insn is valid. + + * optabs.c (expand_binop): New variable next_methods; pass to + most recursive calls when trying to avoid libcalls. + Always check for a return value of zero in recursive calls. + (expand_float): Ensure TARGET has proper mode. + Pass OPTAB_LIB_WIDEN to expand_binop calls. + +Tue Jun 21 14:35:38 1994 Doug Evans (dje@cygnus.com) + + * cccp.c (skip_to_end_of_comment): Catch unterminated comments. + +Sat Jun 18 17:49:41 1994 Jason Merrill (jason@deneb.cygnus.com) + + * fixproto: Move hacking of assert.h from here. + * fixincludes: To here. + +Sat Jun 18 16:42:31 1994 Jim Wilson (wilson@cygnus.com) + + * c-typeck.c (process_init_element): For fieldtype, don't access + TYPE_MAIN_VARIANT field if the type is error_mark_node. + + * jump.c (duplicate_loop_exit_test): Initialize copy to zero. + Emit jump to end lable if copy is still zero. + + * mips.md (truncdisi2): Change from define_insn to define_expand. + (truncdihi2, truncdiqi2, extendsidi2): Likewise. + (extendsidi2_internal): New pattern. + + * loop.c (move_movables): Copy CALL_INSN_FUNCTION_USAGE field. + + * sdbout.c (sdbout_one_type): Use DECL_ASSEMBLER_NAME if + DECL_LANG_SPECIFIC is set. Use DECL_ASSEMBLER_NAME not + DECL_NAME for child_type that is a template type. + (sdbout_symbol): Use DECL_ASSEMBLER_NAME if DECL_LANG_SPECIFIC + is set. + +Sat Jun 18 16:39:03 1994 Kung Hsu (kung@mexican.cygnus.com) + + * dbxout.c (dbxout_symbol): Replace DECL_IGNORED_P with + TYPE_DECL_SUPPRESS_DEBUG. + +Sat Jun 18 10:21:44 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expmed.c (expand_shift): Don't try extzv for lshr. + + * vax.md (lshrsi3): New define_expand. + + * optabs.c: Pass NULL_RTX for TARGET in calls to expand_{un,bin}op. + (expand_float): Use expand_shift instead of expand_binop. + +Fri Jun 17 15:05:58 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Correct math.h on Lynx handling again. + +Fri Jun 17 10:52:41 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * cse.c (simplify_binary_operation, case MINUS): Check mode of op0, + instead of op1, before calling plus_constant. + +Fri Jun 17 01:42:37 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (DEBUGGER_AUTO_OFFSET): Define. If no frame pointer + is available, then adjust the offset by the size of the current + frame. + +Thu Jun 16 16:35:12 1994 Jason Merrill (jason@deneb.cygnus.com) + + * tree.h (DECL_DEFER_OUTPUT): New macro. + * toplev.c (compile_file): Unset DECL_DEFER_OUTPUT on decls + considered at end of file. + * integrate.c (output_inline_function): Unset DECL_DEFER_OUTPUT on + fndecl. + * toplev.c (rest_of_compilation): Also postpone compilation of + inlines with DECL_DEFER_OUTPUT set. + (compile_file): Always emit postponed inlines if + -fkeep-inline-functions. + +Thu Jun 16 11:00:14 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Fix argument type for ffs in <string.h> on Alpha + OSF/1 V2.0. + +Thu Jun 16 06:49:03 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (reload_reg_free_p, case RELOAD_OTHER): Allowed + to conflict with RELOAD_FOR_OTHER_ADDRESS. + + * cse.c (set_nonvarying_address_components): Rework and also + handle an AND used for non-aligned accesses. + +Thu Jun 16 06:36:49 1994 Chip Salzenberg (chip@fin.uucp) + + * i386.h (REG_ALLOC_ORDER): Prefer registers listed in + CALL_USED_REGISTERS. + +Wed Jun 15 20:45:14 1994 Jason Merrill (jason@deneb.cygnus.com) + + * tree.h (TREE_NO_UNUSED_WARNING): Note that this can be applied + to COMPOUND_EXPRs, too. + + * stmt.c (warn_if_unused_value): Handle TREE_NO_UNUSED_WARNING for + COMPOUND_EXPRs, too. + +Wed Jun 15 20:35:21 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (divsi3): Fix divide by 2^N with compare RTL. + + * rs6000.md (maxsf3, minsf3, maxdf3, mindf3): Fix predicate of + define_split. + (muldi3): Fix predicate. + (movdf matcher): Allow update and indexed for lfd instruction. + +Wed Jun 15 19:24:23 1994 Doug Evans (dje@cygnus.com) + + * dbxout.c (dbxout_type): Fix call to bzero. + +Wed Jun 15 19:20:34 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (simplify_unary_operation): Fix typo in last change. + +Wed Jun 15 15:20:54 1994 Per Bothner (bothner@cygnus.com) + + * dbxout.c (dbxout_range_type): Handle the case that an array + range is neither an integer nor a sub-range. (In Pascal or + Chill it could be a Boolean, character, or enumeral type.) + +Wed Jun 15 04:00:42 1994 Ian Lance Taylor (ian@cygnus.com) + + * genmultilib: New shell script to generate multiple library + information. + * Makefile.in (multilib.h, stmp-multilib, install-multilib): New + targets. + (gcc.o): Depend on multilib.h. + (clean): Remove multilib.h and tmpmultilib*. + * gcc.c: Include multilib.h. + (print_multi_lib, print_multi_directory, multilib_select, + multilib_dir): New static variables. + (option_map): Added --print-multi-lib and --print-multi-directory. + (set_spec): Get multilib_select from specs file. + (process_command): Dump multilib_select into specs file. Handle + -print-multi-lib and -print-multi-directory. + (do_spec_1): Try multilib_dir for %D case. + (find_file): Try multilib_dir. + (main): Call set_multilib_dir. Handle print_multi_lib and + print_multi_directory. + (used_arg, set_multilib_dir, print_multilib_info): New functions. + * configure (sparc-*-sunos4*): Use target fragment sparc/t-sunos4. + * sparc/t-sunos4: New file. + +Wed Jun 15 03:54:32 1994 Doug Evans (dje@cygnus.com) + + Add support for the SPARC V9 cpu. + * configure (sparc64-*-aout): New target. + (sparc64-*-elf): New target. + * config.sub (sparc64): New cpu. + (aout, elf): New os's. + * genconfig.c (main): Allow targets to override HAVE_conditional_move. + * jump.c (jump_optimize): Use it at run-time. + * sparc/t-sp64: New file. + * sparc/sp64-aout.h: New file. + * sparc/sp64-elf.h: New file. + * sparc/sysv4.h (ASM_OUTPUT_CASE_LABEL): Handle 64 bit pointers. + * sparc/sparc.h (cpu_type): New enum. + (CPP_PREDEFINES,CPP_SPEC): Add v9 support. + (NO_BUILTIN_PTRDIFF_TYPE, NO_BUILTIN_SIZE_TYPE, MAX_WCHAR_TYPE_SIZE, + SHORT_TYPE_SIZE, INT_TYPE_SIZE, LONG_TYPE_SIZE, LONG_LONG_TYPE_SIZE, + FLOAT_TYPE_SIZE, DOUBLE_TYPE_SIZE, MAX_INT_TYPE_SIZE, + MAX_LONG_TYPE_SIZE): Define. + (PTRDIFF_TYPE, SIZE_TYPE, BITS_PER_WORD, MAX_BITS_PER_WORD, + UNITS_PER_WORD, MAX_UNITS_PER_WORD, LONG_DOUBLE_TYPE_SIZE, + POINTER_SIZE, PARM_BOUNDARY, STACK_BOUNDARY, SPARC_STACK_ALIGN, + EMPTY_FIELD_BOUNDARY, BIGGEST_ALIGNMENT, FIRST_PSEUDO_REGISTER, + FIXED_REGISTERS, CALL_USED_REGISTERS, CONDITIONAL_REGISTER_USAGE): + Add v9 support. + (sparc_override_options, sparc_code_model): Declare. + (OVERRIDE_OPTIONS): Call it. + (MASK_*): Define bits set by target flags. + (TARGET_*): Use them. + ({MASK,TARGET}_{V9,INT64,LONG64,PTR64,ENV32,STACK_BIAS, + MEDLOW,MEDANY,FULLANY}): Define. + (MEDANY_BASE_REG): Define. + (V9_SWITCHES, TARGET_OPTIONS): Define. + (TARGET_SWITCHES, TARGET_DEFAULT): Use MASK_*. + (SPARC_STACK_BIAS, SECONDARY_MEMORY_NEEDED_MODE): Define. + (SECONDARY_MEMORY_NEEDED): Simplify. + (hard_regno_mode_class, sparc_mode_class, sparc_cpu_type): Declare. + (REG_PARM_STACK_SPACE): Do not define if v9. + (HARD_REGNO_NREGS, HARD_REGNO_MODE_OK, MODES_TIEABLE_P, + RETURN_IN_MEMORY, STRUCT_VALUE, STRUCT_VALUE_INCOMING, reg_class, + REG_CLASS_NAMES, REG_CLASS_CONTENTS, REGNO_REG_CLASS, REG_ALLOC_ORDER, + REG_LEAF_ALLOC_ORDER, LEAF_REGISTERS, REG_CLASS_FROM_LETTER, + CLASS_MAX_NREGS, STARTING_FRAME_OFFSET, FIRST_PARM_OFFSET, + BASE_RETURN_VALUE_REG, BASE_OUTGOING_VALUE_REG, BASE_PASSING_ARG_REG, + BASE_INCOMING_ARG_REG, FUNCTION_ARG_REGNO_P): Add v9 support. + (sparc_arg_class): New enum (v9 only). + (sparc_args): New struct to record v9 arguments. + (CUMULATIVE_ARGS): Use it (v9 only). + (GET_SPARC_ARG_CLASS): Define. + (sparc_arg_count, sparc_n_named_args): Declare. + (PASS_IN_REG_P): Define. + (ROUND_REG, ROUND_ADVANCE, INIT_CUMULATIVE_ARGS, FUNCTION_ARG_ADVANCE, + FUNCTION_ARG, FUNCTION_INCOMING_ARG, FUNCTION_ARG_PARTIAL_NREGS, + FUNCTION_ARG_PASS_BY_REFERENCE, FUNCTION_ARG_CALLEE_COPIES): + Add v9 support. + (sparc64_init_expanders, sparc64_fpconv_stack_temp): Declare. + (INIT_EXPANDERS): Define (v9 only). + (gen_v9_scc, output_v9branch): Declare. + (HAVE_conditional_move): Define. + (FUNCTION_PROFILER, FUNCTION_BLOCK_PROFILER, BLOCK_PROFILER, + DYNAMIC_CHAIN_ADDRESS, RETURN_ADDR_RTX, REGNO_OK_FOR_FP_P, + REG_OK_FOR_INDEX_P, REG_OK_FOR_BASE_P, EXTRA_CONSTRAINT, + CASE_VECTOR_MODE, Pmode, EXTRA_CC_MODES, EXTRA_CC_NAMES, + SELECT_CC_MODE, REGISTER_NAMES): Add v9 support. + (REGNO_OK_FOR_CCFP_P): Define. + (sparc_initialize_trampoline, sparc64_initialize_trampoline): Declare. + (INITIALIZE_TRAMPOLINE): Call them. + (ENCODE_SECTION_INFO): Mark functions in v9. + (RTX_COSTS): Assume MULT costs the same for v9 as v8. + (ASM_LONGLONG, ASM_FLOAT): Define. + (ASM_OUTPUT_ADDR_VEC_ELT, ASM_OUTPUT_ADDR_DIFF_ELT): Add v9 support. + * sparc/sparc.c (SKIP_CALLERS_UNIMP_P): Define. + (sparc_cpu_type, sparc_arg_count, sparc_n_named_args, + frame_base_offset, fpconv_stack_temp): New globals. + (leaf_reg_remap): Add additional registers for v9. + (sparc_override_options, sparc64_init_expanders, + sparc64_fpconv_stack_temp, intreg_operand, ccfp_reg_operand, + data_segment_operand, text_segment_operand, v9_regcmp_op, + arith11_operand, arith10_operand, arith11_double_operand, + arith10_double_operand, gen_v9_scc, emit_v9_brxx_insn, + sparc_init_modes, build_big_number, output_v9branch, + sparc_initialize_trampoline, sparc64_initialize_trampoline): + New functions. + (arith_double_operand, gen_compare_reg, finalize_pic, + emit_move_sequence, mem_aligned_8, output_move_double, + output_move_quad, output_fp_move_double, output_fp_move_quad, + output_block_move, save_regs, restore_regs): Add v9 support. + (sparc_mode_class): New enum. + (*_MODES): Redefine to use it. + (hard_32bit_mode_classes): Renamed from hard_regno_mode_ok. + (hard_regno_mode_classes, hard_64bit_mode_classes, + sparc_mode_class): New globals. + (num_gfregs): Renamed from num_fregs. + (compute_frame_size): Add v9 support. Simplify calculations. + (output_function_prologue): Call build_big_number to compute stack + size in %g1, then adjust %sp. + Fix saving of call saved registers. Handle new v9 registers. + (output_function_epilogue): Fix restoration of call saved registers. + Handle new v9 registers. + Use SKIP_CALLERS_UNIMP_P to see if unimp insn is at return address. + (sparc_builtin_saveregs): Define v9 version. + (output_cbranch): New argument fp_cond_reg. All callers changed. + Add v9 support. + (output_return): Use SKIP_CALLERS_UNIMP_P. + (print_operand): New codes '_', '@', 'C', 'D'. + (output_double_int): Handle LABEL_REF and MINUS for v9. + Use ASM_LONGLONG if assembler can handle it. + * sparc/sparc.md (cpu): New attribute. + (type attribute): New value cmove (conditional moves). + (cmpdi): New pattern for v9. + (seq*, sne*): Add v9 support. + (sgt,slt,sge,sle): Explicitly restrict operand 0 to the integer + registers. Try emitting a conditional move for v9. + (sgtu,sltu,sgeu,sleu): Likewise. + (comparison insns): Add v9 versions. + (scc insns): Add DImode versions for v9. + (beq, bne, bgt, blt, bge, ble): If comparing DImode with 0 on v9, + use brxx insns. Use emit_jump_insn, not emit_insn, as the latter + mishandles brxx insns. + (branch insns): Update calls to output_cbranch. + Add v9 versions to support multiple floating point condition code regs. + Add v9 versions to support brxx insns. + (lo_sum, high, pic): Add v9 support. + (symbolic move patterns): Disable for v9. + (DImode, DFmode, TFmode moves): Add v9 support. + (conditional move insns): Define for v9. + (zero_extendqidi2, extendqidi2, zero_extendhidi2, extendhidi2, + zero_extendsidi2, extendsidi2, floatdisf2, floatdidf2, floatditf2, + fix_truncsfdi2, fix_truncdfdi2, fix_trunctfdi2, muldi3, divdi3, + udivdi3, ashldi3, ashrdi3, lshrdi3, ffsdi2): New patterns for v9. + (bitfield compare insn): Add DImode version for v9. + (adddi3, subdi3, negdi2, anddi3, iordi3, xordi3, one_cmpldi2, + mixed mode fp mult insns, negdf2, negtf2, absdf2, abstf2, tablejump, + call, call_value, untyped_call, untyped_return, indirect_jump, + flush_register_windows, flush): Add v9 support. + (ldd peep holes): Disable for v9. + (set/compare peep hole): Define DImode version for v9. + (sign extend/compare peep hole): Likewise. + (return peep holes): Add v9 support. + (call/jump peep holes): Add v9 support. + * ginclude/va-sparc.h: Add v9 support. + +Tue Jun 14 22:44:52 1994 Michael Meissner (meissner@osf.org) + + * config/i386/i386.h (reg_class): Add AD_REGS that match %eax and + %edx to allow %eax:%edx to be specified as one DI register. + (REG_CLASS_NAMES): Ditto. + (REG_CLASS_CONTENTS): Ditto. + (REG_CLASS_FROM_LETTER): 'A' specifies AD_REGS. + + * config/i386/i386.md (umulqihi3): Name the insn with the standard + name. + (mulqihi3, umulsidi3, mulsidi3): Add new widening multiply + patterns. + +Tue Jun 14 22:25:16 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * fold-const.c (encode, decode): Use 4 HOST_WIDE_INTs for encoded + value with HOST_BITS_PER_WIDE_INT/2 bits in each. + (LOWPART, HIGHPART): New macros. + (BASE): Move definition outside of div_and_round_double. + (add_double, mul_double, lshift_double, rshift_double): Rewrite. + (lrotate_double): Use LOWPART, HIGHPART, and BASE. + (rrotate_double): Likewise. + (div_and_round_double): Major changes to code for general case. + Now it actually produces non-garbage results for large operands. + (div_and_round_double): Simplify condition for special code used when + divisor < BASE. + (const_binop): Delete special cases for multiplying by 0, 1, 2, 4, 8. + (fold, case *_DIV_EXPR): Don't try to optimize for overflow. + * machmode.h (MAX_SHORTS): Deleted. + + * m68k.md: Trivial simplification of many patterns. + (subsi3): Don't handle CONST_INT for operand 2. + (ashiftrt, op2 > 8): New pattern. + (lshiftrt, op2 > 8): New pattern. + + * a29k.md (logical patterns): Tune to give better code for immediate + values. + * a29k.c (cmplsrcb_operand): New predicate. + * a29k.h (PREDICATE_CODES): Add cmplsrcb_operand. + +Tue Jun 14 17:52:10 1994 Tor Egge (tegge@flipper.pvv.unit.no) + + * m88k/sysv3.h (DO_GLOBAL_CTORS_BODY): Call __builtin_alloca + with a non-zero argument, forcing a frame pointer to be needed. + +Tue Jun 14 17:37:41 1994 Mike Collison (collison@sw.stratus.com) + + * reload.h (RELOAD_FOR_OPADDR_ADDR): New reload class. + * reload.c (find_reloads): Change secondary reloads of class + RELOAD_FOR_OPERAND_ADDRESS to RELOAD_FOR_OPADDR_ADDR. + * reload1.c (reload): Process and accumulate needs for + RELOAD_FOR_OPADDR_ADDR reloads. + When determining if needs are nongroup needs, ignore + inactive or optional reloads. + (reload_reg_used_in_op_addr_reload): New variable to indicate + when reloads of class RELOAD_FOR_OPADDR_ADDR are in use. + (mark_reload_reg_in_use, clear_reload_reg_in_use): + Process reloads of class RELOAD_FOR_OPADDR_ADDR. + (reload_reg_free_p, reload_reg_free_before_p, reloads_conflict): + Likewise. + (choose_reload_regs): Support RELOAD_FOR_OPADDR_ADDR reloads. + (emit_reload_insns): Output RELOAD_FOR_OPADDR_ADDR reloads. + +Tue Jun 14 17:29:53 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cccp.c, toplev.c, tree.c, print-tree.c, fold-const.c: + Cast pointer operands to bzero, bcopy, and bcmp to (char *). + * function.c, stmt.c, expmed.c, varasm.c, emit-rtl.c: Likewise. + * dbxout.c, integrate.c, jump.c, real.h, calls.c, cse.c: Likewise. + * loop.c, unroll.c, flow.c, stupid.c, combine.c, regclass.c: Likewise. + * local-alloc.c, global.c, reload.c, reload1.c, sched.c: Likewise. + * genattrtab.c, bc-emit.c, gcc.c, collect2.c: Likewise. + + * c-decl.c (min_precision): New function. + (finish_enum): Rewrite code to determine precision required + for enumeral type. + + * cse.c (simplify_unary_operation): Correctly and consistently + handle CONST_INT cases for FLOAT and UNSIGNED_FLOAT. + + * xm-alpha.h (sbrk): Don't declare here. + + * alpha.h (CONST_COSTS, case CONST_INT): Fix typo. + + * tree.c (staticp, case FUNCTION_DECL): A nested function isn't static. + + * i386/linux.h (STARTFILE_SPEC): Don't force -static for -g. + + * gcc.c (find_a_file): Try EXECUTABLE_SUFFIX first, then file + without the suffix. + + * jump.c (jump_optimize): Don't delete dead insn if it has a + REG_RETVAL note. + + * fix-header.c (xstrdup): Renamed from strdup. + (check_protection): Call xstrdup, not strdup. + +Tue Jun 14 17:26:08 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.h (TARGET_SWITCHES): Remove -mpowerpc64 and -mno-powerpc64. + * rs6000.c (rs6000_override_options): Remove MPC620 cpu variants. + + * rs6000.c (output_prolog): Fix error in loading size of large + stack frames. + +Tue Jun 14 17:24:09 1994 Chip Salzenberg (chip@fin.uucp) + + * reload1.c (reload_as_needed): Clear spill_reg_store at start. + (emit_reload_insns): Omit erroneous predicate of reload + deletion -- reload_spill_index is not indexed by regno. + +Tue Jun 14 15:59:55 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Wrap assert.h in extern "C" { } to avoid problem on + HP/UX, which uses NO_IMPLICIT_EXTERN_C. Also fix 12 May 94 + change. + +Tue Jun 14 15:12:50 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * jump.c (condjump_in_parallel_p): New function to detect + conditional jumps within PARALLEL insns. + (jump_optimize): Allow for some simple optimizations involving + conditional jumps within PARALLEL insns. + * reorg.c (get_jump_flags): Handle conditional jumps in PARALLEL + insns. + (get_branch_condition, fill_simple_delay_slots): Likewise. + (fill_eager_delay_slots, relax_delay_slots, dbr_schedule): Likewise. + + * pa-osf.h (SIZE_TYPE): Define as "long unsigned int" to be + compatable with system include files. + * pa1-osf.h (SIZE_TYPE): Likewise. + + * pa1-osf.h (WCHAR_TYPE): Define as "short unsigned int". + (WCHAR_TYPE_SIZE): Define as 16 bits. + + * pa.c (output_arg_descriptor): Restore old behavior for SImode + USE insns of FP registers (used by untyped call support). + +Mon Jun 6 09:15:43 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c (arm_reload_out_hi): Rewrite. Add support for processors + running in big-endian mode. + (fp_immediate_constant): Fix typo in argument declaration. + * arm.h (PROMOTE_MODE): Promote HImode integers as signed. + (BYTES_BIG_ENDIAN): Allow OS description to override default. + (LOAD_EXTEND_OP): When big-endian, HImode loads are sign extended. + * arm.md (storehi_bigend): New expansion pattern. + (storeinthi): Rework to generate better code, add big-endian support. + (movhi): Add support for processors running in big-endian mode. + (movhi_bigend): New expansion pattern. + (matcher for movhi): Remove incorrect alternative for storing HImode to + memory. Only match when little endian. + (matcher for big-endian movhi): New pattern. + (matchers/peepholes for extended pre/post increment HImode loads): Only + match when little-endian. + (matcher for operating on adjacent memory locations): Load operation + into arith operands. + (peepholes for extended pre-increment byte loads): New patterns. + +Sat Jun 4 21:06:29 1994 Kaveh R. Ghazi (ghazi@noc.rutgers.edu) + + * sys-types.h (__gnuc_va_list): Use instead of va_list. + * sys-protos.h (*): Use __gnuc_va_list, not va_list. + +Sat Jun 4 07:19:39 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c (print_multi_reg, output_call, output_call_mem, + output_mov_long_double_fpu_from_arm, + output_mov_long_double_arm_from_fpu, + output_mov_double_fpu_from_arm, output_mov_double_arm_from_fpu, + output_return_instruction, output_func_{prologue,epilogue}, + arm_print_operand, output_load_symbol): Print the register prefix + before each register name. + (output_func_prologue, output_lcomm_directive): Output the target + dependent comment char for asm comments. + * arm.h (FUNCTION_PROFILER): Delete duplicate definition. + (FUNCTION_PROFILER, TRAMPOLINE_TEMPLATE, ASM_FILE_START, + ASM_OUTPUT_REG_{PUSH,POP}, PRINT_OPERAND_ADDRESS): Output register + prefix before any explicit register name. + (ASM_OUTPUT_LONG_DOUBLE, ASM_OUTPUT_DOUBLE, ASM_OUTPUT_FLOAT, + ASM_OUTPUT_COMMON): Output the target dependent comment char. + (ASM_FILE_START): Output register alias for r10. + (REGISTER_NAMES): Output "r9" now for r9, not "rfp". + (ADDITIONAL_REGISTER_NAMES): New macro. + * arm.md (all patterns explicitly mentioning register names): Output + the target dependent prefix before the register name. + (all patterns with asm comments): Output the target dependent comment + character. + +Fri Jun 3 18:14:07 1994 Doug Evans (dje@cygnus.com) + + * c-common.c (decl_attributes): Fix section attributes. + * varasm.c (make_decl_rtl): If section attribute is being ignored, + really ignore it. + +Fri Jun 3 15:53:57 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * pa.h (FP_REGNO_P): New macro for intra file usage. + (REGNO_OK_FOR_FP_P): Use FP_REGNO_P. + (FUNCTION_VALUE_REGNO_P): Revert last change. + * pa.md (mulsi3): Use MATCH_DUP for op3, not MATCH_OPERAND. + + * pa.h (CONDITIONAL_REGISTER_USAGE): Partially revert last changes; + Make non-existing 1.0 fp regs fixed, including odd-numbered regs. + (enum reg_class): Get rid of SNAKE_FP_REGS, GENERAL_OR_SNAKE_FP_REGS, + and NON_SHIFT_REGS. + (REG_CLASS_NAMES): Likewise. + (REG_CLASS_CONTENTS): Likewise. + (REGNO_REG_CLASS): Likewise. + (HARD_REGNO_MODE_OK): Corresponding changes. Don't force 1.0 fpregs + to even regno here; fixed_regs does the job better. + (FP_REG_CLASS_P): Get rid of SNAKE_FP_REGS. + (REG_CLASS_FROM_LETTER, case 'z'): Deleted. + (HARD_REGNO_NREGS): Partially revert last change. + (CLASS_MAX_NREGS): Partially revert last change. + * pa.md (globally): Delete 'x' constraint or change it to 'f', + as apropriate. + +Fri Jun 3 09:18:55 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.h (CONST_OK_FOR_LETTER_P): Only allow constants that are valid + when inverted for 'K'. Only allow constants that are valid when + negated for 'L'. + * arm.md (all patterns): Update instruction generation to reflect new + meanings of constraints 'K' and 'L'. Use output type 'B' to + generate an inverted constant. Use output type 'N' to generate a + negated floating point constant. + +Thu Jun 2 22:43:58 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (TARGET_SWITCHES): Enable TARGET_LONG_CALLS when + TARGET_PORTABLE_RUNTIME is enabled. + * pa.c (output_call): If TARGET_LONG_CALLS is enabled, then emit + an inline long-call sequence. + * pa.md (millicode define_delay): Disable delay slots if + TARGET_LONG_CALLS. + (call_internal_reg, call_value_internal_reg): If TARGET_LONG_CALLS + is enabled, then emit an inline long-call sequence. Fix length + computation for TARGET_LONG_CALLS. + (millicode calls): Fix length computation for TARGET_LONG_CALLS. + + * pa.h (ASM_DECLARE_FUNCTION_NAME): Fix typo. + +Thu Jun 2 18:28:07 1994 Jason Merrill (jason@deneb.cygnus.com) + + * stmt.c (expand_end_bindings): Don't bother emitting cleanups + after a barrier. + +Thu Jun 2 18:10:36 1994 Stephen L Moshier (moshier@world.std.com) + + * libgcc2.c (__floatdisf): Protect against double-rounding error. + +Thu Jun 2 17:47:54 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.h (MASK_PPCFPX): Delete. + (MASK_PPC_GPOPT, MASK_PPC_GFXOPT, TARGET_PPC_GPOPT, TARGET_PPC_GFXOPT): + New Macros. + (TARGET_SWITCHES): Remove -mpowerpc-fpx; add -mpowerpc-gpopt + and -mpowerpc-gfxopt. + * rs6000.c (processor_target_table): Use new macros. + * rs6000.md (define_function_unit): Remove ppc604 from sqrt list. + (divsi3, udivsi3): Remove spaces from PowerPC output templates. + (sqrtsf2, maxsf3, minsf3, sqrtdf2, maxdf3, mindf3): Use new macros. + (floatdidf2, fix_truncdfdi2, ffsdi2, muldi3): New patterns. + ({s,u}muldi3_highpart, divdi3, udivdi3, rotldi3): Likewise. + (movdi): Handle moves between FPRs and GPRs. + (scc insn): Correct swapped compare and delayed_compare attributes. + +Thu Jun 2 14:45:04 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c (arm_condition_code): Move to start of file. + (const_pool_offset): Correct typo. + (fp_const_from_val): New function. + (all instruction generators): mark position where conditionalization + should be with '%?'. + (output_move_double): Use new '%m' output type to simplify load/store + multiple generation. + (shift_instr): Delete. + (shift_op): New function. + (output_arithmetic): Delete. + (output_arithmetic_with_shift): Delete. + (output_arithmetic_with_immediate_multiply): Delete. + (output_shifted_move): Delete. + (output_shift_compare): Delete. + (arm_print_operand): New function. + * arm.h (output_func_{prologue,epilogue}): Change declarations from + output_{prologue,epilogue}. + (arm_output_llc, arithmetic_instr, + output_arithmetic_with_immediate_mulitply, + output_arithmetic_with_shift, shift_instr): Delete function + definitions. + (ASM_OUTPUT_OPCODE): Delete. + (PRINT_OPERAND): Call arm_print_operand, instead of doing it directly. + (ARM_COMMENT_CHAR): New macro. + (ARM_REG_PREFIX): New macro. + (ARM_SIGN_EXTEND): New macro. + (PRINT_OPERAND_ADDRESS): Delete variable 'shift'. Change type of + variable 'offset' to HOST_WIDE_INT. Use arm_print_operand to handle + shifts in addresses. + * arm.md (all output patterns): Use new capabilities of + arm_print_operand to simplify output sequences. Mark position of + condition code with '%?'. + + * riscix.h (ASM_FINAL_SPEC [CROSS_COMPILE]): Correct typo. + +Thu Jun 2 08:14:00 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-common.c (c_build_type_variant): Don't change TYPE_MAIN_VARIANT + of new type. + + * expr.c (expand_expr, case ADDR_EXPR): If result is ignored, + just return const0_rtx. + +Wed Jun 1 13:52:01 1994 Jason Merrill (jason@deneb.cygnus.com) + + * i386/sco4.h: #define NO_IMPLICIT_EXTERN_C. + +Wed Jun 1 04:55:06 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * arm.c: General tidy up. + #include <string.h>. + Declare some prototypes. + (output_memory_reference_mode): Change type to enum machine_mode. + (arm_const_nmoves): Delete. + (adjacent_mem_locations, {load,store}_multiple_operation): Explicitly + declare to return int. + ({load,store}_multiple_operation): Change type of 'count', 'base' and + 'i' to HOST_WIDE_INT. + (output_add_immediate): Change type of 'n' to HOST_WIDE_INT. + (output_multi_immediate): Change type of Argument 'n' to + HOST_WIDE_INT, if wider than 32 bits, mask out the high bits. + (output_arithmetic_with_immediate_multiply): Change type of 'shift' + to HOST_WIDE_INT. + (output_func_{prologue,epilogue}): Renamed from + output_{prologue,epilogue}. Check all registers to see if they are + live, but only push/pop them if they are not in call_used_regs. + * arm.h: Delete some dead code. + (FUNCTION_{PROLOGUE,EPILOGUE}): Call output_func_{prologue,epilogue}. + (INITIAL_ELIMINATION_OFFSET): Inspect all registers, but only add + those that are not in call_used_regs. + (GO_IF_LEGITIMATE_INDEX): Change type of variable 'range' to + HOST_WIDE_INT; change type of variable 'code' to enum rtx_code. + (REVERSIBLE_CC_MODE): New macro. + + * arm.c (const_pool_offset): New function. + (get_prologue_size): New function. + (output_func_prologue): Eliminate variable code_size. + (output_func_epilogue): Only call arm_increase_location when + optimizing; also add the size of the function just compiled, and the + size of the prologue. + (arm_output_asm_insn): Delete. All callers changed to use + output_asm_insn. + (arm_output_llc): Delete. + (output_load_symbol): New first parameter 'insn'. Rewrite so that + assembler can detect whether we made a mistake. + * arm.h (arm_output_asm_insn): Delete declaration. + (EXTRA_CONSTAINT): New constraint 'R' to match a constant pool label. + Make constraint 'S' never match when not optimizing. + (CONSTANT_ADDRESS_P): Only accept symbols marked with SYMBOL_REF_FLAG + when optimizing. + (ENCODE_SECTION_INFO): Don't mark any symbols when not optimizing. + (ASM_OUTPUT_REG_{PUSH,POP}: Don't call arm_increase_location. + (ASM_OUTPUT_ADDR_VEC_ELT): Likewise. + * arm.md (all insn and peephole patterns): Rewrite without using + arm_output_asm_insn. + (matcher for movsi): New alternative to load symbol directly into a + register. Add new parameter in call to output_load_symbol. + + * arm.md (all patterns): Length attribute now describes length in + bytes. + * arm.c (short_branch): Convert length calculations to bytes. + +Tue May 31 20:35:39 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * pa.c (emit_move_sequence): Add missing argument to symbolic_operand. + (output_block_move): Prefer addl to add. + (print_operand): Print fp regs with L suffix when appropriate. + (output_arg_descriptor): Rewrite to accomodate new convention for + USE information. + + * pa.h (SECONDARY_MEMORY_NEEDED): Simplify. + (ADDITIONAL_REGISTER_NAMES): Define. + (CONDITIONAL_REGISTER_USAGE): Make PIC_OFFSET_TABLE_REGNUM fixed + again. + + Changes to combine fp registers for 1.0 and 1.1 architectures. + (Make explicit clobbers of fp registers work.) + * pa.h (FIRST_PSEUDO_REGISTER): Now 89. + (FIXED_REGISTERS): Delete 1.0 fp registers, + (CALL_USED_REGISTERS): Likewise. + (CONDITIONAL_REGISTER_USAGE): Almost deleted. + (REG_ALLOC_ORDER): Update register numbers. + (HARD_REGNO_NREGS): Delete special case for 1.0 fp registers. + (HARD_REGNO_MODE_OK): Rewrite. Don't allow use of odd fp registers + (enum reg_class): Delete HI_SNAKE_FP_REGS and FP_OR_SNAKE_FP_REGS. + (REG_CLASS_NAMES): Corresponding change. + (REG_CLASS_CONTENTS): Delete HI_SNAKE_FP_REGS and + FP_OR_SNAKE_FP_REGS. Make SNAKE_FP_REGS class contain all fp + registers. Update all values for changed register numbering. + (REGNO_REG_CLASS): Corresponding changes. + (REG_CLASS_FROM_LETTER): Delete 'y'. + (FP_REG_CLASS_P): No longer test HI_SNAKE_FP_REGS. + (CLASS_MAX_NREGS): Delete special case for 1.1 fp registers. + (FUNCTION_VALUE): Remove TARGET_SNAKE conditionals. + (LIBCALL_VALUE): Likewise. + (FUNCTION_ARG_REGNO_P): Likewise. + (FUNCTION_VALUE_REGNO_P): Likewise. Add registers 29 and 33. + (FUNCTION_ARG): Remove TARGET_SNAKE conditionals. Update register + numbers. + (REGNO_OK_FOR_FP_P): Update register number. + (REGISTER_NAMES): Delete special entries for 1.0 fp registers. + (DBX_REGISTER_NUMBER): Likewise. + * pa.c (compute_frame_size): Update for changed register numbers. + Simplify loops over general registers to stop at register 4. + (hppa_expand_prologue): Likewise. + (hppa_expand_epilogue): Likewise. + +Tue May 31 19:32:18 1994 Jim Wilson (wilson@cygnus.com) + + * mips.md (movesi_unaligned, movsi_ulw, movsi_usw): Delete. + (extv, extzv, insv, movsi_ulw, movsi_usw): New patterns. + + * dbxout.c (dbxout_type): Always emit cross-references if + use_gnu_debug_info_extensions set. + + * final.c (output_source_line): Call xcoffout_source_line. + * xcoffout.c (xcoff_lastfile): New variable. + (ABS_OR_RELATIVE_LINENO, ASM_OUTPUT_SOURCE_LINE): Define here. + (xcoffout_source_file, xcoffout_source_line): New functions. + (xcoffout_declare_function): Use xcoffout_source_file. + * xcoffout.h (xcoff_lastfile): Declare. + (DBX_OUTPUT_MAIN_SOURCE_FILENAME): Clean up. Set xcoff_lastfile. + (ABS_OR_RELATIVE_LINENO, ASM_OUTPUT_SOURCE_LINE): Delete here. + (DBX_OUTPUT_SOURCE_FILENAME): Delete. + + * unroll.c (copy_loop_body): Copy CALL_INSN_FUNCTION_USAGE field. + + * sparc.h (ASM_SPEC): Don't pass -k when -pg or -p given. + (OVERRIDE_OPTIONS): Warn when disabling -fpic. + + * mips-tdump.c (print_global_hdr): Remove "l" from printf format + for flags. + (print_sym_hdr): Add missing "l" to printf formats. + (print_symbol, print_file_desc): Likewise. + + * i960.h (PUT_SDB_TYPE): Adjust value for compatibility with GNU960 + toolchain. + + * sparc.h (LIB_SPEC): Don't link in /usr/lib/bb_link.o with -a. + (CONDITIONAL_REGISTER_USAGE): When -a, make %g1 and %g2 fixed. + + * mips/iris5gas.h, mips/iris5gdb.h: New files. + * configure (mips-sgi-irix5): Use iris5gas.h and iris5gdb.h. + +Tue May 31 19:21:44 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * pa.md (movsi matcher): Use ldi for moving of 0 to a reg. + (movhi matcher): Likewise. + (movqi matcher): Likewise. + (many patterns): Prefer addl to add, and shNaddl to shNadd. + (define_split for (plus (reg) (large_constant))): Cleanup. + (divsi3): Use match_dup for operand 3, not match_operand. + (udivsi3): Likewise. + (modsi3): Likewise. + (umodsi3): Likewise. + +Tue May 31 19:15:31 1994 Doug Evans (dje@cygnus.com) + + * toplev.c (v_pedwarn_with_decl): Don't even issue warnings from + pedantic errors in system header files. + +Tue May 31 17:16:41 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (extendqidi2, extendqisi2, extendqihi2): Remove + non-existent lba instruction. + (ashrdi3): Undo previous change. + +Tue May 31 12:30:00 1994 Jason Merrill (jason@deneb.cygnus.com) + + * toplev.c (lang_options): Add -f{no-,}implicit-templates. + (compile_file): Don't output SDB debugging info for + externals. + +Tue May 31 07:20:18 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stmt.c (expand_asm_operands): Make MEM with BLKmode for clobber + of "memory". + * loop.c (note_addr_stored): A SET or CLOBBER of a BLKmode MEM means + that all memory is clobbered. + +Mon May 30 14:01:48 1994 Doug Evans (dje@cygnus.com) + + * gcc.c (default_compilers): Pass -MG to cpp if present. + (option_map): New option --print-missing-file-dependencies/-MG. + * cccp.c (print_deps_missing_files): New global. + (main): New argument -MG. Treat missing include files as + generated files and output dependencies for them. + +Mon May 30 10:42:14 1994 Frederic Pierresteguy (F.Pierresteguy@frcl.bull.fr) + + * m68k/dpx2cdbx.h (PREFERRED_DEBUGGING_TYPE): Define as SDB_DEBUG. + * m68k/dpx2g.h: Disable code that manages gcc.ifile. + +Mon May 30 10:35:49 1994 Stephen L Moshier (moshier@world.std.com) + + * optabs.c (expand_float): Avoid double-rounding when float is + is narrower than int. + * real.c (significand_size): New function. + * real.h (significand_size): Declare. + +Sun May 29 15:58:21 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * jump.c (jump_optimize): When deleting unneeded stack adjusts + or mem-mem copies, use delete_computation. + + * combine.c (force_to_mode): NEXT_SELECT is true for NEG. + Only exit quickly if X is narrower than MODE and MASK has all + bits in X's mode set. + (force_to_mode, case SUBREG): Don't check for WORD_REGISTER_OPERATIONS. + (force_to_mode, case NEG): Special-case test for low-order bit. + + * rtlanal.c (volatile_insn_p): Call ourselves in recursive scan. + +Sat May 28 19:03:23 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-parse.in (init, compstmt, stmt, all_iter_stmt_with_decl): + If the lookahead token is a constant and we need to pop the + momentary obstack, don't free it. + + * stmt.c (expand_end_case): Have INDEX_TYPE track conversions done + to INDEX_EXPR. + +Sat May 28 06:25:40 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * pa.md (call): Force address into register in non-symbol case. + (call_value): Likewise. + +Fri May 27 19:29:30 1994 Doug Evans (dje@cygnus.com) + + * toplev.c (compile_file): Call init_regs after `word_mode' is valid. + * regclass.c (init_reg_modes): If choose_hard_reg_mode can't find a + valid mode, fall back to word_mode. + + * expr.c (use_reg): Fix recording of USE information. + (use_regs): Likewise. + Delete argument `reg'. All callers changed. + * expr.h (use_regs): Update prototype. + * calls.c (expand_call): Update call to use_regs. Call use_reg + if parm is wholly in registers. + + * configure: If compiling in separate dir, add subdirs to .gdbinit. + +Fri May 27 18:18:23 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (zero_extendqidi2, zero_extendhidi2): Use rldicl + instruction. + * rs6000.h (RTX_COSTS): Update PPC603 and PPC604 values. + +Fri May 27 17:56:07 1994 Douglas Rupp (drupp@cs.washington.edu) + + * i386/xm-dos.h (DIR_SEPARATOR): New macro. + +Fri May 27 17:45:08 1994 Holger Teutsch (teutsch@ffm-iw.Degussa.DE) + + * clipper.h (PCC_STATIC_STRUCT_RETURN): No longer defined. + +Fri May 27 17:36:53 1994 Pat Rankin (rankin@eql.caltech.edu) + + * make-l2.com: Update to handle `ginclude' subdirectory + when compiling libgcc2. + +Fri May 27 17:30:37 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.c (print_operand_address): print_operand_address + creates PLUS-rtls for internal use, so it has to handle them. + +Fri May 27 16:13:53 1994 Chris Torek (torek@elf.bsdi.com) + + * function.c (assign_parms): Set REG_USERVAR_P when parm + is passed by invisible reference but can live in register. + +Fri May 27 06:03:11 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload.c (find_reloads): Revert to old code and change secondary + reloads to RELOAD_FOR_OPERAND_ADDRESS too. + + * combine.c (try_combine): Don't make complemented XOR for + constant out of range. + + * alpha.c (or_operand): Renamed from ior_operand. + * alpha.h (PREDICATE_CODES): Likewise. + * alpha.md (iordi3): Likewise. + (xordi3): Use or_operand and add second alternative. + (eqv): Only accept registers. + + * expr.c (expand_expr, case CONSTRUCTOR): If constant and large + enough for memcpy to be used, build constructor into static memory. + + * alpha.md: Add define_split for sign-extended PLUS of a MULT + of an SImode comparison. + + * combine.c (simplify_comparison): Narrow comparison for AND's + that are ZERO_EXTENDs. + Can widen for all comparisons if inputs are both sign extended. + + * reload1.c (reload_as_needed): Update spill_reg_order once we sort + spill_regs. + + * alpha.md: Add define_split for sign-extended PLUS of an SImode + comparison; change comparison to DImode. + + * stmt.c (expand_end_case): Use old type of INDEX_EXPR when making + a constant. + + * local-alloc.c (requires_inout): Renamed from requires_inout_p and + returns number of alternatives that require a match. + (block_alloc): Use new function and handle case where all + alternatives have some operand that must match operand 0. + + * local-alloc.c (qty_phys_num{,_copy}_sugg): New variables. + (qty_phys_has{,_copy}_sugg): Deleted. + (qty_sugg_compare{,_1}): New functions. + (local_alloc): Allocate and init new vars instead of deleted ones. + (block_alloc): Update and use new vars. + Order quantities using new functions when allocating quantities + with suggested registers. + (combine_regs, find_free_reg): Use new vars to count number + of suggestions. + +Thu May 26 11:55:44 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * jump.c (jump_optimize): When looking for an `if' statement + that takes two insns to compute a result using a temporary, + allow the temporary to be a SUBREG. + + * combine.c (simplify_comparison): Call CANONICALIZE_COMPARISON, + if defined. + * alpha.h (CANONICALIZE_COMPARISON): New macro. + + * combine.c (simplify_if_then_else): Don't make (mult (cond)) + in simple case; leave as IF_THEN_ELSE instead. + + * expmed.c (expand_divmod): Correctly set CAN_CLOBBER_OP0 when we've + converted OP0 to COMPUTE_MODE. + +Thu May 26 11:41:58 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Protect bool in curses.h with #ifndef __cplusplus, + since g++ now defines bool as a basic type. + + * fixinc.svr4: Protect definition of __P used in Solaris math.h + and floatingpoint.h to avoid future fixproto conflicts. + + * Makefile.in (stmp-fixinc): Don't pass ${srcdir} argument to + $(FIXINCLUDES); no longer needed, and always problematical for + binary only installations. + * fixincludes: Remove initialization of ${SRCDIR}. Don't + explicitly copy over multimedia/audio_errno.h; should be handled + by Oct 11, 1993 change. + * fixinc.svr4: Remove initialization of ${SRCDIR}. + * fixinc.sco, fixinc.dgux: Likewise. + +Fri May 20 12:48:24 1994 Jim Wilson (wilson@cygnus.com) + + * stmt.c (expand_exit_loop_if_false): Emit conditional jump around + unconditional loop exit instead of conditional loop exit. + + * rs6000.c (output_prolog): Use multiple fputs calls instead of + one call with multiple strings. + + * iris4.h (STARTFILE_SPEC, LIB_SPEC): Define. + + * xcoffout.c (MAKE_LINE_SAFE): Delete. + (ASM_OUTPUT_LBB, ASM_OUTPUT_LBE): Don't use MAKE_LINE_SAFE. + +Fri May 20 01:18:30 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * config.sub (basic_machine): Accept cxux*. + +Thu May 19 19:12:41 1994 Mike Stump (mrs@cygnus.com) + + * calls.c (expand_call): Only destroy temps here, if -fshort-temps + is given. + +Thu May 19 19:07:59 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * config.sub: Fix unrecognized os error message. + +Thu May 19 17:46:55 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (emit_reload_insns): When seeing if an equivalent + register can have it's output reload deleted, check for REG_DEAD + notes for reload_in instead of calling dead_or_set_p. + +Thu May 19 16:38:32 1994 Stephen L Moshier (moshier@world.std.com) + + * emit-rtl.c (operand_subword): Fix arg of REAL_VALUE_TO_TARGET_SINGLE + and .._DOUBLE. Permit float subword extraction when host's word + width is wider than target's. + +Thu May 19 15:09:21 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Make OSF/1 getopt.h fix work on AIX also. + +Wed May 18 15:34:10 1994 Jason Merrill (jason@deneb.cygnus.com) + + * fixincludes: Add forward declaration of struct exception to + SunOS 4 math.h. + +Wed May 18 12:46:46 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * stor-layout.c (layout_decl): Allow any integral types + for bit fields. (Specifically, C++ now has a 'bool' type.) + +Wed May 18 16:32:40 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (compare_spill_regs): Fix typo in declaration. + +Wed May 18 10:39:00 1994 Brendan Kehoe (brendan@lisa.cygnus.com) + + * fixinc.svr4: Avoid the SVR4 typedef of bool in curses.h when + compiling for C++, since g++ now supports it as an official typename. + +Tue May 17 18:06:32 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.md: Don't use the extsd/extd instructions on the ns32532. + +Tue May 17 17:44:38 1994 Pat Rankin (rankin@eql.caltech.edu) + + * make-cc1.com (CFLAGS): Separate include file handling; for + stage 1, CFLAGS1 is appended to CFLAGS, otherwise CFLAGS2. + +Tue May 17 16:35:22 1994 Jason Merrill (jason@deneb.cygnus.com) + + * convert.c (convert_to_real): Accept boolean values. + + * config/m68k/hp320.h: #define NO_IMPLICIT_EXTERN_C + +Tue May 17 15:52:05 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * libgcc2.c (__umoddi3): Correct type of variable `w'. + + * combine.c (simplify_set): Move call to make_field_assignment + to end; if SRC or DEST is a (clobber (const_int 0)), return it. + (force_to_mode): If X is a CALL, just return it. + + * reload.c (find_reloads): Properly account for cost when + constant is forced to memory to ensure same alternative chosen later. + +Tue May 17 11:30:19 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * combine.c (simplify_set): Use rtx_equal_p to compare cc_use and its + setter. + (make_extraction): Don't put a subreg around a register if it is + already in the correct mode. + + * reload1.c (compare_spill_regs): New function. + (reload_as_needed): Sort the spilled regs. + (allocate_reload_reg): If we have group needs and failure would be + fatal, do not try to do round-robin allocation of the spill regs. + +Mon May 16 18:58:10 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (zero_extendqidi2): Fix omission of TARGET_POWERPC64 + test in previous change. + +Mon May 16 14:59:25 1994 Per Bothner (bothner@cygnus.com) + + * dbxout.c (dbxout_type): When emitting an ENUMERAL_TYPE, if + the precision is different from the default precision (perhaps + because of -fshort-enums), write out the precision. + +Mon May 16 17:44:49 1994 Stephen L Moshier (moshier@world.std.com) + + * real.c (ereal_from_int, ereal_to_int, etarsingle): Correct + signed/unsigned discrepancies. + (ereal_from_double): Avoid "right shift count too big" warning + in previous change. + * final.c (split_double): Fix arg of REAL_VALUE_TO_TARGET_DOUBLE. + + * real.h (REAL_VALUE_FROM_TARGET_SINGLE, .._DOUBLE): Change + arg from long to HOST_WIDE_INT. + * real.c (ereal_from_float, .._double): Likewise, and unpack + the HOST_WIDE_INTs. + +Mon May 16 16:16:32 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * flow.c (try_pre_increment_1): Don't try to create a pre-increment + expression if the register dies in the succeeding insn. + + * expr.c: Use #ifdef TARGET_EDOM, not #if. + + * expr.c (convert_move): When {zero,sign}_extending, allow a wider + intermediate than to_mode if truncation is a no-op. + +Mon May 16 11:49:28 1994 Doug Evans (dje@cygnus.com) + + * m68k/apollo68.h (REGISTER_PREFIX_MD): Delete. + +Mon May 16 08:11:57 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.c (rs6000_convert_preincs): Delete. + * rs6000.h (FINAL_PRESCAN_INSN): Delete. + + * c-typeck.c (initializer_constant_valid_p): Rework to use + precision, not size. + Allow conversions from integer to pointer if int is wide enough. + + * c-decl.c (finish_enum): Handle VALUES being an ERROR_MARK. + + * rs6000.md: Replace bogus "andil" opcode with rlinm. + +Sat May 14 21:26:05 1994 Doug Evans (dje@cygnus.com) + + * hard-reg-set.h (GO_IF_HARD_REG_EQUAL): Fix typo. + + * jump.c (find_cross_jump): Two CALL_INSNs only compare equal if + their CALL_INSN_FUNCTION_USAGEs are the same as well. + + * stupid.c (stupid_life_analysis): Make sure a function result reg + is still live if it contains an argument. + +Fri May 13 22:17:48 1994 Doug Evans (dje@cygnus.com) + + * reorg.c (mark_referenced_resources): Fix typo. + +Fri May 13 18:54:38 1994 Jason Merrill (jason@deneb.cygnus.com) + + * integrate.c (integrate_decl_tree): Use copy_node to make a copy + of the decl. Also call copy_lang_decl to copy the + language-specific bits. + * tree.h: Declare copy_lang_decl. + * c-decl.c (copy_lang_decl): No-op function that will never + actually be called. + +Fri May 13 15:12:20 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cse.c (cse_insn): Correctly check for two modes being the + same number of words. + +Fri May 13 05:03:51 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * c-parse.in (enumlist): Add error alternative. + +Thu May 12 23:25:38 1994 Jason Merrill (jason@deneb.cygnus.com) + + * c-common.c (truthvalue_conversion): If expr is a BIT_AND_EXPR + where one of the operands is integer_onep, just return expr. + +Thu May 12 20:08:49 1994 Mike Stump (mrs@cygnus.com) + + Fixup lifetime of temporaries. + + * calls.c (expand_call): Only destroy temporaries at the end + of function calls, if flag_short_temps is set. + * expr.c (safe_from_p, expand_expr): Handle CLEANUP_POINT_EXPRs. + * expr.c (expand_expr): Improve handling of temporaries inside + COND_EXPRs, cures call to sorry. + * expr.c (defer_cleanups_to): New routine to handle the deferral + of cleanups. + * flags.h (flag_short_temps): New flag, to allow better control + over the lifetime of temporaries. + * toplev.c (flag_short_temps, lang_options): Ditto. + * tree.def (CLEANUP_POINT_EXPR): Add, to allow better control over + the lifetime of temporaries. + +Thu May 12 19:33:54 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (function units): Numerous cycle count change. + (zero_extendqidi2, extendqidi2, zero_extendhidi2): New patterns. + (extendhidi2, zero_extendsidi2, extendsidi2): Likewise. + (zero_extendqisi2, zero_extendqihi2, zero_extendhisi2): Use + andil/andi instead of rlinm/rlwinm. + (zero_extendqihi2): Add condition register variants. + (extendqisi2, extendqihi2): Use extsb for PowerPC. + (adddi3, subdi3, negdi2, ashrdi3): Emulate only if !TARGET_POWERPC64. + (movdf, movdi, movti): New PowerPC64 versions. + (load/store with update): New PowerPC64 patterns. + +Thu May 12 18:50:55 1994 Stephen L Moshier (moshier@world.std.com) + + * real.c (m16m): Change first arg to int; all callers changed. + +Thu May 12 18:46:26 1994 Bill Cox (bill@cygnus.com) + + * fixincludes: Add definition of DBL_MAX to math.h for Lynx math.h. + Correct return type of strlen in Lynx string.h. + Delete definition of 'void' as 'int' from Lynx curses.h. + +Thu May 12 18:11:33 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload.c (find_reloads): Don't change a secondary reload + to RELOAD_FOR_OPERAND_ADDRESS. + + * function.c (assign_parms): Fix typo in previous change. + +Thu May 12 15:48:54 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * c-common.c (decl_attributes): Revert to identifiers for + mode attributes. + * libgcc2.c: Likewise. + +Thu May 12 15:41:38 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax/xm-vms.h (lookup_name_current_level_global): New macro. + +Wed May 11 17:44:47 1994 Jim Wilson (wilson@cygnus.com) + + * cse.c (cse_insn): Set src_eqv if the dest is a STRICT_LOW_PART. + + * expmed.c (store_fixed_bit_field): Delete code to handle + MODE_FLOAT values here. + (store_bit_field): Put it here instead. + +Wed May 11 16:18:21 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * a29k.c (a29k_clobbers_to): New function. + * a29k.md (clobbers_to): Deleted. + (call_internal, call_value_internal): New patterns. + (call, call_value): Just call new patterns and a29k_clobbers_to. + + * stor-layout.c (layout_type): Use POINTER_SIZE, instead of width + of Pmode, when appropriate. + + * calls.c (emit_call_1): Put new function usage data at end of + any data already there. + * expr.c (expand_builtin_apply): Likewise. + + * sched.c (sched_analyze_insn): Fix typo in last change. + +Wed May 11 14:45:12 1994 Doug Evans (dje@cygnus.com) + + * configure: Fix handing case of no language subdirs. + +Wed May 11 12:11:40 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixincludes: Don't recursively search symlinks to `.'. + +Tue May 10 17:49:57 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * configure: Include stage4 in the list. + + * gcc.c (process_command): Kludge in stageN/../include instead of + include. + +Mon May 9 21:04:19 1994 Jim Wilson (wilson@cygnus.com) + + * sparc.h (*TF*_LIBCALL): Delete `*' from libcall name. + +Mon May 9 18:42:10 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.c (output_move_dconst): Fix errors on ranges. + +Mon May 9 18:33:16 1994 Chris Torek (torek@bsdi.com) + + * gcc.c (delete_if_ordinary): New function. + (delete_temp_files, delete_failure_queue): Call it. + +Sat May 7 12:12:58 1994 Andreas Neubacher (aneubach@risc.uni-linz.ac.at) + + * i386/seq-sysv3.h (LIB_SPEC): Support -fshared-data. + (CPP_SPEC): Set _SEQUENT_ to 1. + (SHARED_SECTION_ASM_OP, ASM_OUTPUT_SHARED_COMMON): Supply new macros. + (SHARED_BSS_SECTION_ASM_OP, BSS_SECTION_FUNCTION): Likewise. + +Sat May 7 10:09:49 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reorg.c (mark_{referenced,set}_resources): Fix typos in last change. + + * reload1.c (emit_reload_insns): Don't try to delete output reload + if there isn't one. + + * i386.h (REG_ALLOC_ORDER): New macro. + + * sched.c (sched_analyze_insn, attach_deaths_insn): Look at + CALL_INSN_FUNCTION_USAGE. + + * reload1.c (choose_reload_regs): Remove previous change. + +Fri May 6 20:32:22 1994 Doug Evans (dje@canuck.cygnus.com) + + * sparc.c (leaf_reg_backmap): Delete. + (sparc_flat_compute_frame_size): Renamed from + sparc_frw_compute_frame_size. All callers changed. + (sparc_flat_save_restore): Likewise. + (sparc_flat_output_function_prologue): Likewise. + Delete decl of call_used_regs. + Delete reference to frame_base_name, use frame pointer explicitly. + Print prologue end marker. + (sparc_flat_output_function_epilogue): Likewise (renaming). + Delete decls of asm_out_data_file, asm_out_file, call_used_regs. + Print epilogue start marker. + (sparc_flat_epilogue_delay_slots): Likewise (renaming). + (sparc_flat_eligible_for_epilogue_delay): Likewise. + * sparc.h (TARGET_FRW): Add note saying this option is deprecated. + (TARGET_FLAT): Renamed from TARGET_FRW_COMPAT. + (TARGET_SWITCHES): Delete references to -mfrw, -mfrw-compat. + Add -mflat. + (CONDITIONAL_REGISTER_USAGE): If -mflat, fix %i7, rename "%fp" + to "%i7", and make %g7 a global_reg. + (FRAME_POINTER_REQUIRED): Handle -mflat. + (INITIAL_FRAME_POINTER_OFFSET): Likewise. + (ARG_POINTER_REGNUM): Explicitly say it's the frame pointer. + (LEAF_REGISTERS): Make %g7 not a leaf register. + (leaf_reg_backmap): Delete. + (LEAF_REG_BACKMAP): Likewise. + (FUNCTION_PROLOGUE): Handle -mflat. + (FUNCTION_EPILOGUE): Likewise. + (DELAY_SLOTS_FOR_EPILOGUE): Likewise. + (ELIGIBLE_FOR_EPILOGUE_DELAY): Likewise. + +Fri May 6 14:05:00 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * tree.h (TYPE_ATTRIBUTES): New macro. + (struct tree_type): attributes, new field. + (precision): Move this field up for better alignment. + (attribute_list_{equal,contained}): Prototype for new functions. + (build_type_attribute_variant): Prototype for new function. + * c-parse.in: Rewrite attribute parsing; update the expected + conflicts and state numbers. + * tree.c (TYPE_HASH): Move definition to top of file. + (make_node): Add support for SET_DEFAULT_TYPE_ATTRIBUTES. + (build_type_attribute_variant): New function. + (type_hash_lookup): Check if the attributes match. + (attribute_list_{equal,contained}): New functions. + * c-typeck.c (common_type): Add attribute merging. + (comp_types): Use COMP_TYPE_ATTRIBUTES macro. + * print-tree.c (print_node): Print attributes. + * c-common.c (decl_attributes): Move the attribute + recognition and rejection here from c-parse.in. + (decl_attributes): Use VALID_MACHINE_ATTRIBUTE macro. + + * regclass.c (init_reg_sets_1): Eliminate several permanent + call_fixed_regs. + + * rtl.def (CALL_INSN): Define new CALL_INSN_FUNCTION_USAGE field. + * rtl.h (CALL_INSN_FUNCTION_USAGE): New macro. + (find_reg{,no}_fusage): Prototype for new function. + * rtlanal.c (reg_used_between_p): Check usage exprs on CALL_INSNs. + (reg_referenced_between_p, reg_set_p, dead_or_set_regno_p): Likewise. + (find_reg{,no}_fusage): New functions. + * combine.c (try_combine): Restrict combining on CALL_INSNs. + (distribute_{notes,links}): Look at CALL_INSN_FUNCTION_USAGE. + * cse.c (cse_insn): Invalidate CLOBBERed registers. + (count_reg_usage): Count registers in USE rtls on CALL_INSNs. + * emit-rtl.c (make_call_insn_raw): New function. + (emit_call_insn{,_before}): Use make_call_insn_raw. + * calls.c (prepare_call_address, emit_call_1, expand_call): Change + from USE and CLOBBER insns to using CALL_INSN_FUNCTION_USAGE. + (emit_library_call{,_value}): Likewise. + * expr.c (use_regs, expand_builtin_apply): Likewise. + * expr.h (use_regs): Likewise. + * flow.c (flow_analysis, find_basic_blocks): Likewise. + * caller-save.c (insert_save_restore): Likewise. + * function.c (fixup_var_refs_insns): Likewise. + * jump.c (find_cross_jump, get_label_{before,after}): Likewise. + * reload1.c (emit_reload_insns): Likewise. + * reorg.c (mark_referenced_resources, mark_set_resources): Likewise. + * integrate.c (save_for_inline_copying, expand_inline_function): + Copy CALL_INSN_FUNCTION_USAGE field. + * reload1.c (choose_reload_regs): Ban filled argument registers. + * caller-save.c (save_call_clobbered_regs): CALL_INSN_FUNCTION_USAGE + requires a sharper liveliness check. + * flow.c (propagate_block): Mark all registers mentioned in USE + usage expressions on a CALL_INSN as used. + * jump.c (find_cross_jump): If STACK_REGS is defined two + CALL_INSNs only compare equal if their USE usage rtls are + the same as well. + * stupid.c (stupid_life_analysis): Check the usage information + on CALL_INSNs. + + * function.c (assign_parms): Spread out the REG_EQUIV notes + on CONCATs. + +Fri May 6 12:43:10 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload.c (find_reloads): Ignore alternatives that will + not be reloadable due to PREFERRED_RELOAD_CLASS. + + * explow.c (allocate_dynamic_stack_space): Just return + virtual_stack_dynamic_rtx if asking for zero bytes. + Set current_function_calls_alloca here and also record new + stack level for nonlocal gotos. + * expr.c (expand_builtin, case BUILT_IN_ALLOCA): Don't + set current_function_calls_alloca here nor record new + stack level for nonlocal gotos. + * stmt.c (expand_decl): Likewise. + + * function.c (assign_parms): Use expr_size when appropriate. + + * c-typeck.c (comptypes): An enum type is compatible with type of + same signedness as well as precision. + + * alpha.h (CONST_COSTS): Revise all costs. + * alpha.md (addsi3, subsi3): Add define_expand to make + adddi3/subdi3; old pattern is now anonymous. + + * combine.c (simplify_rtx, case MULT): Don't convert MULT to + shift here. + (simplify_logical, case IOR): Convert back to PLUS if valid and + it will combine with another PLUS. + (extract_left_shift): New function. + (make_compound_operation, case ASHIFTRT): Simplify by calling it. + (force_to_mode): Don't ignore if X is a SUBREG. + (force_to_mode, case AND): Try to turn unchecked bits on + instead of just off and see which is cheaper. + +Fri May 6 11:22:23 1994 Ian Lance Taylor (ian@cygnus.com) + + * Makefile.in (libgcc1.a, libgcc2.a): Don't ignore errors in for + loops over $(LIB[12]FUNCS_EXTRA). + +Fri May 6 06:14:56 1994 Mike Stump (mrs@cygnus.com) + + * expr.c (expand_cleanups_to): Tell expand_expr that we are going + to ignore the result of the cleanup. + +Thu May 5 17:45:02 1994 Stan Shebs (shebs@andros.cygnus.com) + + * gcc.c (do_spec_1): If -save-temps, always clear the deletion flag. + +Thu May 5 13:39:35 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * combine.c (simplify_rtx, case SUBREG): Don't call force_to_mode. + (simplify_set): Call force_to_mode here. + + * m68k.md (movhi): Simplify code involving jump-table + reference. + (load_address): Handle case of jump-table reference; output + required label. + +Thu May 5 12:28:16 1994 Ian Lance Taylor (ian@cygnus.com) + + * cccp.c (main): Include source file name in dependency output. + +Wed May 4 18:45:07 1994 Doug Evans (dje@cygnus.com) + + * config.sub: Remove duplicate -freebsd* entry. + +Wed May 4 18:03:34 1994 Jason Merrill (jason@deneb.cygnus.com) + + * cccp.c (special_symbol): Don't copy simple strings, use wchar_type. + (main): Setup wchar_type for C++ if needed. + (initialize_builtins): Use wchar_type. + +Wed May 4 17:19:34 1994 Mike Collison (collison@sw.stratus.com) + + * reload.c (push_secondary_reload): Use TYPE for secondary type + if it is RELOAD_FOR_{INPUT,OUTPUT}_ADDRESS. + +Wed May 4 16:35:49 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * configure (i386-gnu): New, same as i386-mach. + + * global.c (find_reg): When looking for locally-allocated hard + regs to reclaim, use REG_ALLOC_ORDER to find least used. + + * reload1.c (emit_reload_insns): Add another way to delete an + output reload. + + * reload1.c (reload, reload_as_needed): Check for use of return + register with reg_referenced_p, not reg_mentioned_p. + +Wed May 4 14:23:51 1994 Jim Wilson (wilson@cygnus.com) + + * mips.c (override_options): Delete TARGET_LLONG128 references. + * mips.h (MASK_LLONG128, TARGET_LLONG128): Delete. + (TARGET_SWITCHES): Delete -mlonglong128 option. + (LONG_LONG_TYPE_SIZE): Delete TARGET_LLONG128 reference. + + * mips/bsd-4.h, mips/bsd-5.h, mips/news4.h, mips/news5.h, + mips/nws3250v4.h, mips/svr3-4.h, mips/svr3-5.h, mips/svr4-4.h, + mips/svr4-5.h (CPP_SPEC): Delete. + * mips/dec-bsd.h (CPP_SPEC): Define __SIZE_TYPE__, + __PTRDIFF_TYPE__, and __mips. + (SIZE_TYPE): Delete. + * mips/dec-osf1.h (PTRDIFF_TYPE): Delete. + (CPP_SPEC): Define, overriding ultrix.h version. + * mips/iris5.h (CPP_SPEC): Define __SIZE_TYPE__, __PTRDIFF_TYPE__, + and __mips. + * mips/osfrose.h (CPP_SPEC): Define __PTRDIFF_TYPE__ and __mips. + (PTRDIFF_TYPE): Delete. + (SIZE_TYPE): Define. + (SET_ASM_OP): Define. + * config/mips/ultrix.h (CPP_SPEC): Delete. + (SIZE_TYPE): Delete. + +Tue May 3 19:04:43 1994 Jason Merrill (jason@deneb.cygnus.com) + + * Makefile.in (stamp-objlist): Depend on OBJS and BC_OBJS so that + subdir makes will know to re-link. + +Mon May 2 16:05:05 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * toplev.c (compile_file): If static consts haven't been written + out yet, don't do it just because TREE_USED is set (if we're + optimizing). (This wins for C++, which uses static consts a lot.) + +Mon May 2 16:42:59 1994 Jim Wilson (wilson@cygnus.com) + + * stmt.c (expand_end_case): Make sure gen_casesi operands are + valid by passing them through copy_to_mode_reg if necessary. + * mips.md (casesi): Delete force_reg calls. + + * ns32k.c (output_move_double): Always use split_double for the + CNSTOP case. + + * gcc.c (translate_options): For options that take an argument, + don't skip the argument if it doesn't exist. + + * c-decl.c (pushdecl): Use lookup_name_current_level_global instead + of lookup_name for extern references. Don't return duplicate decl + if it came from the global binding level, and there exists a + conflicting decl in an intervening block. + (lookup_name_current_level_global); New function. + * c-tree.h (lookup_name_current_level_global): Declare. + + * sys-protos.h (read, write): Last parm is size_t not unsigned int. + + * unroll.c (remap_split_bivs): New function. + (unroll_loop): When remapping split bivs in the last instruction, + handle JUMP_INSNs in addition to INSNs. + +Mon May 2 12:53:57 1994 Jason Merrill (jason@deneb.cygnus.com) + + * config/nextstep.h (INCLUDE_DEFAULTS): Add cxx_aware field. + * config/vax/xm-vms.h (INCLUDE_DEFAULTS): Ditto. + +Fri Apr 29 18:30:38 1994 Kung Hsu (kung@cygnus.com) + + * tree.h (TYPE_DECL_SUPPRESS_DEBUG): new macro to support + suppressing of detail type infos into stabs. + * dbxout.c (dbxout_type): check the above flag to generate cross + reference in stabs. + +Fri Apr 29 01:01:45 1994 Doug Evans (dje@cygnus.com) + + * Makefile.in (stamp-objlist): New target. + +Thu Apr 28 22:17:15 1994 Doug Evans (dje@cygnus.com) + + * Makefile.in (USE_ALLOCA): Rearrange "'s. + (FLAGS_TO_PASS): Delete CLIB, MALLOC, OBSTACK. + +Thu Apr 28 19:04:17 1994 Jim Wilson (wilson@cygnus.com) + + * stmt.c (expand_end_case): Correct test for sign extending + unsigned constant index when creating index_expr. + + * cccp.c (macroexpand): Use start_line for line number of the new + instack level pushed at the end. + +Thu Apr 28 18:59:17 1994 Mike Stump (mrs@cygnus.com) + + * stmt.c: Remove old exception handling support from the backend. + +Thu Apr 28 18:59:53 1994 Torbjorn Granlund (tege@adder.cygnus.com) + + * sparc.c (arith_double_operand): Modify to accept all possible constants. + * sparc.md (adddi3, subdi3, anddi3, iordi3, xordi3): Corresponding changes. + (one_cmpldi3): Don't allow constants for operand 1. + +Thu Apr 28 18:10:18 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (addsi3): Prefer add without carry instructions and + flag input operands as commutative for condition register variant. + (subsi3): Define PowerPC patterns using subtract without carry. + (numerous): Flag input operands as commutative for condition + register variant. + (mov* matchers): Use mr instruction in ! TARGET_POWERPC case as + well and mr. in condition register variant. + * rs6000.c (output_prolog): Use mr, lis, and li instructions. + Use subf instruction if TARGET_POWERPC. + (output_epilog): Use cal/addi instruction. + +Thu Apr 28 12:48:59 1994 Andreas Neubacher (aneubach@risc.uni-linz.ac.at) + + * i386/seq-sysv3.h (SHARED_SECTION_ASM_OP): Defined. + +Thu Apr 28 12:40:28 1994 Doug Evans (dje@cygnus.com) + + * expr.c (expand_builtin): Fix typo in previous patch + (allow __builtin_next_arg in varargs functions). + +Tue Apr 26 16:31:44 1994 Per Bothner (bothner@cygnus.com) + + * tree.h (AGGREGATE_TYPE_P): New macro. + * calls.c, expr.c, function.c, stmt.c, varasm.c: Use + new macro AGGREGATE_TYPE_P. + +Mon Apr 25 18:45:28 1994 John Hassey (hassey@dg-rtp.dg.com) + + * varasm.c (copy_constant, case CONSTRUCTOR): Fix typo; copied list + was placed on old CONSTRUCTOR, not new one. + +Mon Apr 25 15:04:53 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-decl.c (grokdeclarator): Never warn about `long long' in + system header. + + * c-decl.c (finish_decl): Redo last change. + + * Makefile.in (*compare*): Add missing semicolons. + +Mon Apr 25 15:02:31 1994 Doug Evans (dje@cygnus.com) + + * configure (m68k-hp-hpux): t-hp320g no longer needed as of gas 2.1. + * m68k/t-hp320g: Deleted. + +Mon Apr 25 14:23:18 1994 Poul-Henning Kamp (phk@login.dkuug.dk) + + * config.sub, configure: Recognize FreeBSD. + * i386/freebsd.h, x-freebsd: New files. + * i386/x-freebsd: New file. + * i386.h (TARGET_NO_FANCY_MATH_387): New option. + * i386.md (TARGET_NO_FANCY_MATH_387): Implement new option. + * ginclude/stdarg.h, ginclude/stddef.h, ginclude/varargs.h: + Recognize __FreeBSD__. + * gcc.c (link_command_spec): Add -Z argument for ZMAGIC's on FreeBSD. + +Mon Apr 25 14:08:26 1994 Doug Evans (dje@cygnus.com) + + * configure (language search loop): Correct test for no languages. + (CC): Use single quotes to avoid shell expansion of $(CC). + +Mon Apr 25 13:10:07 1994 Andreas Stolcke (stolcke@icsi.berkeley.edu) + + * Makefile.in (install-common): Install EXTRA_PARTS with + INSTALL_DATA, not INSTALL_PROGRAM. + +Mon Apr 25 06:34:00 1994 Stephen L Moshier (moshier@world.std.com) + + * fold-const.c (fold-convert): Use assignment, instead of + initializing, aggregate local variable REAL_VALUE_TYPE. + +Sun Apr 24 11:17:20 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reorg.c (redirect_with_delay_list_safe_p): Fix off-by-one error. + + * real.c (etoe53, etoe24): Make all occurrences static. + + * emit-rtl.c (try_split): Don't try to recursively split deleted insn. + + * rs6000.md (movti): Adjust constraints to avoid impossible reload. + + * expr.c (expand_expr, case SAVE_EXPR): Fix error in last change. + +Sat Apr 23 06:45:50 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (reloads_conflict, case RELOAD_FOR_OUTPUT): Fix typo. + +Fri Apr 22 18:43:08 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * configure (alpha-dec-osf): Fix typo. + +Fri Apr 22 15:02:22 1994 Hallvard B Furuseth (h.b.furuseth@usit.uio.no) + + * gcc.c (handle_braces, check_live_switch): Refine previous change. + +Fri Apr 22 03:27:26 1994 Doug Evans (dje@cygnus.com) + + * configure: Sort machines. + + * Language directory reorganization. + * configure: Auto-configure each language subdirectory by looking + for */config-lang.in. + Add language makefile fragments (Make-lang.in) to top level makefile, + and hook them in via lang.* targets. + Configure each language subdirectory. On hosts that support them, + create stage[123] symlinks in each subdirectory. + If there is a configure script in the subdirectory, run it. + * Makefile.in (LANGUAGES): Remove c++. + (SUBDIRS): New variable. + (LEX, LEXFLAGS): Ditto. + (MAKEOVERRIDES): Ditto. + (COMPILERS): Remove cc1plus. + (LANG_MAKEFILES, LANG_STAGESTUFF, LANG_DIFF_EXCLUDES, FLAGS_TO_PASS): + New variables. + (CPLUS_OBJS, CPLUS_TREE_H, C++, c++, g++, g++-cross, cc1plus, + cp-*.o, g++.o, gplus.info): Deleted. + (STAGESTUFF): Remove g++, g++-cross, cc1plus. Add $(LANG_STAGESTUFF). + (Makefile): Depend on $(LANG_MAKEFILES). + (####language hooks, ####language fragments): New spots for sed + to insert things. + (all.cross, all.build, start.encap, rest.encap, info, dvi, + install-normal, install-common, install-info, install-man, + uninstall, distdir, mostlyclean, clean, distclean, extraclean, + realclean, stage1, stage2, stage3, stage4): Depend on lang.foo. + (mostlyclean, clean, distclean, extraclean, realclean): Clean as + much of the language subdirectories as we can. + (install-common): Remove g++ installation. + (install-man): Remove g++.1 installation. + (uninstall): Remove g++ reference. + (TAGS): Remove cp-parse.? reference. + (distdir): Ditto. + (distdir-start, distdir-finish): New targets. + (diff): Remove cp-parse.? reference. Add $(LANG_DIFF_EXCLUDES). + (compare, compare3, gnucompare, gnucompare3): Compare language + subdirectories too. + (stage1-start, stage2-start, stage3-start, stage4-start): New targets. + Ensure stage subdirectory exists before processing language + dependent part. + * cp/Makefile.in: New file, makefile for c++ subdirectory. + * cp/Make-lang.in: New file, c++ language makefile fragment. + This file provides c++ specific support to the top level makefile via + several well defined targets: c++.all.build, c++.all.cross, + c++.start.encap, c++.rest.encap, c++.info, c++.dvi, + c++.install-normal, c++.install-common, c++.install-info, + c++.install-man, c++.uninstall, c++.distdir, c++.mostlyclean, + c++.clean, c++.distclean, c++.extraclean, c++.realclean, + c++.stage1, c++.stage2, c++.stage3, c++.stage4. + * cp/config-lang.in: New file, defines language name and other + configuration parameters for the c++ language: compilers, stagestuff, + and diff_excludes. + * g++.c: Move into cp subdirectory. + * g++.1: Ditto. + * g++int.texi: Ditto. + * cp-*: Ditto, remove "cp-" prefix except for cp-tree.h. + +Thu Apr 21 15:47:01 1994 Jim Wilson (wilson@cygnus.com) + + * sparc.c (mem_aligned_8): Don't assume addresses with + MEM_IN_STRUCT_P set are 8 byte aligned. + + * iris5.h (CPP_SPEC): Define _LANGUAGE_C for Objective C also. + + * unroll.c (find_splittable_givs): Share dest_reg for multiple + address givs within a single instruction. + (copy_loop_body): Only update psuedo-reg for shared giv once. + + * sparc.c (sparc_type_code): Don't put more than 30 bits of info + into the variable qualifiers. + + * expr.c (store_expr): Don't check the TYPE_MODE of an ERROR_MARK. + +Thu Apr 21 15:34:11 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * calls.c (calls_function_1): A language-specific code must + be assumed to call a function and also call alloca. + Check for inlined functions that call alloca. + + * reload1.c (reload): Clear forbidden_regs earlier. + (new_spill_reg): Mention in error message that asm clauses can also + cause the compiler to run out of spill regs. + (scan_paradoxical_regs): If SMALL_REGISTER_CLASSES, forbid + hard regs used in explicit user variables. + + * combine.c (can_combine_p, combinable_i3pat, try_combine): Allow + combination involving hard regs if the hard reg is a user variable. + + * gcc.c (default_compilers): If -E and the file is (e.g.) x.s, + don't run the assembler; similarly for .i, .ii, .adb, etc. + + * Cleanups related to adding prototypes to many declarations. + * rtl.h: If TREE_CODE undefined, make an incomplete union for tree. + (STDIO_PROTO): Define here if not already defined. + (read_rtx): Use STDIO_PROTO. + (output_constant_def, immed_real_const): Use "union tree_node *". + (immed_real_const_1): Move declaration to real.h. + (rtx_to_tree_code): Supply prototype. + * tree.h: If RTX_CODE undefined, make an incomplete struct for rtx. + Add some missing declarations of functions in stmt.c. + (STDIO_PROTO): Define here if not already defined. + * real.h: Add prototypes to declarations of functions in real.c. + (immed_real_const_1): Move declaration from rtl.h. + * output.h: Add missing declarations of functions in final.c. + (STDIO_PROTO): Don't define here. + * c-tree.h (STDIO_PROTO): Likewise. + * reload.h (PROTO, STDIO_PROTO): Likewise. + * bi-opcode.c (main): Don't write overly-long line. + * cse.c, emit-rtl.c: Use CONST_DOUBLE_FROM_REAL_VALUE macro for immed + real_const_1. + * expmed.c: Add prototypes for static functions. + * expr.c (bc_expand_expr): Call expand_decl and expand_decl_init, + not the bc_ versions. + * final.c: Include stdio.h and ctype.h early. + Add prototypes for static functions. + * function.c: Add prototypes for static functions. + (bc_expand_function_end, expand_function_end): Call new + expand_fixups instead of old fixup_gotos. + * global.c, local-alloc.c: Add prototypes for static functions. + * integrate.c: Likewise. + Use CONST_DOUBLE_FROM_REAL_VALUE macro for immed_real_const_1. + * optabs.c: Likewise. + * real.c: Make most functions static and add prototypes for + all static functions. + (GET_REAL, PUT_REAL): Cast parameter to proper pointer type in + some cases; use unsigned array. + * stmt.c: Add prototypes for static functions. + (expand_fixups): New function. + (fixup_gotos): Now static. + Don't call bc_fixup_gotos with wrong type (but now probably wrong + value). + (bc_*): Now static. + (expand_exit_loop_if_false): Call bc_expand_goto_internal with + proper null pointer. + (expand_decl_init): Call bc_expand_decl_init if writing bytecode. + +Thu Apr 21 14:21:56 1994 Ian Lance Taylor (ian@cygnus.com) + + Support taking the address of a text segment symbol when using + MIPS -membedded-pic. + * mips.h (embedded_pic_fnaddr_rtx): Declare. + (embedded_pic_offset): Declare. + (mips_finalize_pic): Declare. + (FINALIZE_PIC): Define. + (GO_IF_LEGITIMATE_ADDRESS): When using -membedded-pic, reject + combining an embedded PIC text reference with a register. + (ENCODE_SECTION_INFO): Under -membedded-pic set SYMBOL_REF_FLAG to + 0 for text segment symbols, 1 for data segment symbols. + * mips.c (embedded_pic_fnaddr_rtx): New variable. + (embedded_pic_offset): New function. + (mips_finalize_pic): New function. + (mips_select_section): When using -membedded-pic and not using + -fwritable-strings, put strings in the text section, not the read + only data section. + * mips.md (movsi): When using -membedded-pic, add special code + when loading a symbol directly to use an offset from the start of + the current function. + (get_fnaddr): New insn to get address of current function. + +Wed Apr 20 19:38:38 1994 Doug Evans (dje@cygnus.com) + + * regclass.c (init_reg_sets_1): Make static. + (init_reg_modes): New function. + (init_regs): Likewise. + * toplev.c (compile_file): Call init_regs after init_rtl. + (main): Delete call to init_reg_sets_1. + +Wed Apr 20 15:06:35 1994 Steve Chamberlain (sac@cygnus.com) + + * sh.c (REG_ODD): Allow DIs and DFs into odd registers. + (print_operand): New command char '@', change nop insn. + (synth_constant): Don't allocate temp reg during reload. + (expand_block_move): Don't expand if TARGET_SMALLCODE. + (prepare_split_double_ops): Deleted. + (howshift, multcosts): Work out costs exactly. + (dump_table): Emit a label before the align. + (hi_const): TARGET_SHORTADDR makes more things HI consts. + (machine_dependent_reorg): Look through SUBREGS. + (from_compare): Get better code when relational args are loaded + into regs now. + (expand_acall): Cope with TARGET_BSR. + (general_movdst_operand): Don't allow illegal autoincs. + (mac_operand): New function. + (sh_function_arg, sh_function_partial_nregs): From sh.h + * sh.h (PARANOID_BIT, RETR2_BIT, CONSTLEN0_BIT, BSR_BIT, + SHORTADDR_BIT, TARGET_PARANOID, TARGET_RETR2, TARGET_CONSTLEN0, + TARGET_BSR, TARGET_SHORTADDR, TARGET_SWITCHES): New options. + (OVERRIDE_OPTIONS): No function_cse when TARGET_BSR. + (FIRST_RET_REG): Depends on TARGET_RETR2. + (FUNCTION_ARG, FUNCTION_ARG_PARTIAL_NREGS): Moved to sh.c + (HAVE_POST_INCREMENT, HAVE_PRE_DECREMENT): Define. + (MODE_DISP_OK_8): Define. + (REG_OK_FOR_PRE_POST_P): Allow a pseudoreg. + (GO_IF_LEGITIMATE_ADDRESS): Allow DI addressing modes. + (MOVE_RATIO): Depends on TARGET_SMALLCODE. + * sh.md (interrupt_function): New attr. + (define_delay): Account for interrupt functions. + (addc): Describe pattern better. + (adddi3): Expanded better. + (peepholes): Deleted many obsolete patterns. + +Wed Apr 20 13:37:58 1994 Jason Merrill (jason@deneb.cygnus.com) + + * expr.c (expand_expr): Don't force ignore when expanding the + subexpression of a WITH_CLEANUP_EXPR. Don't check ignore when + deciding whether or not to expand the cleanup for a TARGET_EXPR. + +Wed Apr 20 12:20:16 1994 Doug Evans (dje@cygnus.com) + + * h8300/h8300.h (RTX_COSTS): Remove LSHIFT. + * h8300/h8300.md (lshrhi3_eight): Fix name. + (lshrhi3): Use it. + * i860/i860.c (safe_insn_src_p): Remove LSHIFT. + (single_insn_src_p): Likewise. + * i960/i960.c (i960_expr_alignment): Remove LSHIFT. + * sh/sh.c (output_shift, ASHIFTRT case): Do opposite shift as ASHIFT. + Delete LSHIFT case. + * sh/sh.h (RTX_COSTS): Remove LSHIFT, add LSHIFTRT. + * spur/spur.md (lshlsi3): Delete. + +Wed Apr 20 06:40:15 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * c-lex.c (check_newline): Avoid unreachable statement when + HANDLE_SYSV_PRAGMA defined. + +Wed Apr 20 01:52:24 1994 Steve Chamberlain (sac@mole.gnu.ai.mit.edu) + + * flow.c (find_auto_inc, try_pre_increment): Make sure + that insertion of autoinc addressing mode would yield a valid + instructon. + +Tue Apr 19 23:41:14 1994 Doug Evans (dje@cygnus.com) + + * Makefile.in (expr.o): Depend on regs.h. + * rtl.h (choose_hard_reg_mode): Declare. + * regs.h (reg_raw_mode): Declare. + * caller-save.c (choose_hard_reg_mode): Delete from here. + * regclass.c (choose_hard_reg_mode): Define here. + (reg_raw_mode): Define. + (init_reg_sets_1): Initialize reg_raw_mode. + * expr.c: #include regs.h. + (use_regs): Use reg_raw_mode. + * reload1.c (emit_reload_insns): Record additional spill registers + in their intrinsic mode. + * combine.c (move_deaths): Record death information of remaining + registers in their intrinsic mode. + * sched.c (attach_deaths): Create partial register dead notes using + register's intrinsic mode. + +Tue Apr 19 21:40:57 1994 Mike Stump (mrs@cygnus.com) + + * toplev.c (lang_options): Add -fhandle-signatures for C++ + frontend. + +Tue Apr 19 19:00:30 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cccp.c (do_error): Don't terminate. + +Tue Apr 19 17:48:41 1994 Hallvard B Furuseth (hbf@durin.uio.no) + + * gcc.c: Add new options -print-file-name= and -print-prog-name=. + + * gcc.c (struct switchstr): New field LIVE_COND. + (process_command): Initialize it. + (check_live_switch): New function. + (handle_braces): Call it. + +Mon Apr 18 19:22:25 1994 Lee Iverson (leei@ai.sri.com) + + * mips.h (RTX_COSTS): Remove LSHIFT. + +Mon Apr 18 17:56:22 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * c-decl.c (duplicate_decls): Always warn when const declaration + follows non-const one for variables. + +Mon Apr 18 16:38:30 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * calls.c (prepare_call_address): New arg REG_PARM_SEEN. + All callers changed. + (expand_call): Pre-load args if small reg classes and reg parms. + * expr.h (prepare_call_address): Extend prototype. + * expr.c (expand_builtin_apply): Pass new arg to prepare_call_address. + +Mon Apr 18 14:53:14 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (const_binop): If arg is NaN, just return it + (fold_convert): Handle NaN in real->int and real->real cases. + + * c-lex.c (yylex): If FP value is NaN, use value of zero. + + * expr.h (PROMOTE_MODE): Don't supply default here. + (promote_mode): Add declaration. + * explow.c (promote_mode): New function. + * calls.c (expand_call): Use it. + * function.c (assign_parms, promoted_input_arg, expand_function_start): + Likewise. + * expr.c (expand_expr, case VAR_DECL, SAVE_EXPR): Likewise. + * stmt.c (expand_value_return, expand_decl): Likewise. + +Mon Apr 18 11:36:04 1994 Jason Merrill (jason@deneb.cygnus.com) + + * Makefile.in (LIB2FUNCS): Change _op_vec_delete to _op_vec_del. + * libgcc2.c: Ditto. + +Mon Apr 18 11:19:07 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * reorg.c (redirect_with_delay_list_safe_p): New function, + similar to redirect_with_delay_slots_safe_p. + (fill_slots_from_thread): Do not redirect a jump if doing + so would invalidate the delay list for the jump. + +Mon Apr 18 03:09:30 1994 Doug Evans (dje@cygnus.com) + + * scan-types.sh: Fix program's name in error message. + Rename dummy.c to avoid collisions in parallel makes. + +Sun Apr 17 18:29:00 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.h (PROCESSOR_COMMON, PROCESSOR_POWER, PROCESSOR_POWERPC): + New macros. + * rs6000.c (processor_target_table): Change "all" to "common". + Add "power" and "powerpc" generic processors. Explicitly turn off + new mnemonics for all members of the POWER architecture family. + +Sun Apr 17 10:04:18 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * tree.h (DECL_PRINT_NAME): Deleted. + (struct tree_decl): Field print_name deleted. + +Sun Apr 17 06:59:58 1994 Pat Rankin (rankin@eql.caltech.edu) + + * vax.h (RTX_COSTS), vax.c (vax_rtx_cost): Remove LSHIFT case. + +Sun Apr 17 01:15:27 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * function.c (locate_and_pad_parm): For ARGS_GROW_DOWNWARD, + Round sizetree for both upward and downward padding, nuke + the (now unnecessary) call to pad_below for arg_size_ptr. + +Sat Apr 16 21:05:40 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (one_cmplsi2): Always use nor instruction; + remove extraneous minus sign from condition register set constraint. + +Sat Apr 16 17:12:40 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k.c (print_operand): 'x' and 'y' mode letters only + if SUPPORT_SUN_FPA. + (print_operand_address): If (new) ASM_OUTPUT_CASE_FETCH defined, + use it to emit the address for the insn before a tablejump. + * m68k/mot3300.h (FUNCTION_ARG_PADDING, FUNCTION_PROLOGUE): Deleted. + (FUNCTION_EPILOGUE, PRINT_OPERAND, PRINT_OPERAND_ADDRESS): Deleted. + (SGS_SWITCH_TABLES, ASM_OUTPUT_CASE_END): Deleted. + (ASM_OUTPUT_FLOAT_OPERAND, ASM_OUTPUT_DOUBLE_OPERAND): Deleted. + (SGS_NO_LI, ASM_OUTPUT_CASE_FETCH, ASM_RETURN_CASE_JUMP): Defined. + + * configure (header_files): Use ${srcdir} instead of $(srcdir). + +Sat Apr 16 16:51:15 1994 DJ Delorie (dj@ctron.com) + + * objc/makefile.dos (OBJC_O): Add encoding.o. + +Sat Apr 16 16:38:32 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-lex.c (yylex): Turn off overflow flag when fixing up large + traditional hex constants. + + * c-decl.c (finish_decl): If asmspec_tree, clear DECL_BUILT_IN + for function and DECL_RTL always. + +Wed Apr 13 13:08:10 1994 Per Bothner (bothner@cygnus.com) + + * toplev.c (compile_file): Never warn about unused static consts, + since it is reasonable to have those in header files. + +Wed Apr 13 12:25:21 1994 Jason Merrill (jason@deneb.cygnus.com) + + * varasm.c (contains_pointers_p): When examining a RECORD_TYPE, + only look at the FIELD_DECLs. + +Tue Apr 12 18:14:42 1994 Jason Merrill (jason@deneb.cygnus.com) + + * Makefile.in (LIB2FUNCS): Add _op_vec_{delete,new}. + + * libgcc2.c (__builtin_vec_{delete,new}): New functions per the + latest C++ working paper. + (__default_new_handler): No longer static. + (__set_new_handler): Lose. + + * cccp.c: Don't implicitly wrap LOCAL_INCLUDE_DIR. + (struct default_include): Add cxx_aware field. + (include_defaults_array): Ditto. + (main): Use cxx_aware field. + +Tue Apr 12 16:13:10 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * config.sub (next): Fix typo in m68k-next-ns3 alternative. + +Tue Apr 12 07:41:17 1994 Michael Meissner (meissner@osf.org) + + * i386/i386.c (notice_update_cc): Remove LSHIFT case, since there + is no LSHIFT rtl code any more. + + * halfpic.h (NO_STDIO_H): Do not include stdio.h if this is defined. + +Mon Apr 11 17:24:46 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * scan.c (get_token): Correctly increment lineno after + encountering #ident (or other #-directive). + +Mon Apr 11 13:22:51 1994 Jim Wilson (wilson@cygnus.com) + + * reorg.c (try_merge_delay_insns): Account for resources set/used + by a filled insn before trying to simplify insns in delay slots. + + * x-iris, x-iris3, x-mips, x-sony, x-sysv (OLDCC): Change -XNh1500 + to -XNh2000. + + * c-decl.c (finish_decl): Don't preserve initializer if it is + error_mark_node. + + * reorg.c (try_merge_delay_insns): Move next_trial update + immediately after the try_split call. + + * mips.c (mips_select_rtx_section, mips_select_section): New + functions. Prefer rdata when TARGET_EMBEDDED_DATA, and prefer + sdata otherwise. + * mips.h (MASK_EMBEDDED_DATA, TARGET_EMBEDDED_DATA): New macros. + (TARGET_SWITCHED): Add new option -membedded-data. + (SELECT_RTX_SECTION, SELECT_SECTION): Call function in mips.c. + + * Makefile.in (all.cross, rest.encap): Delete objc-runtime and + SYSCALLS.c.X. + (OBJC, OBJECTIVE-C): Add objc-runtime. + (proto): Add SYSCALLS.c.X. + (libgcc2.ready, libobjc.a, sublibobjc.a, SYSCALLS.c.X): Add + dependence on stmp-int-hdrs. + + * cccp.c (rescan): Don't look for C++ // comment before directive. + Handle \-newline inside a C++ // comment. + (skip_if_group): Likewise. + (handle_directive): Also handle C++ // comment after #. Point + ip->bufp after the comment start before calling + skip_to_end_of_comment. + (validate_else): Handle \-newline inside a C++ // comment. + (skip_to_end_of_comment, macarg1, discard_comments): Likewise. + + * varasm.c (immed_double_const): Sign-extend constants when they + have the most significant bit set for the target. + +Mon Apr 11 06:20:56 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (reload): When accumulating needs, use nested + structures to simplify and speed up the code. + + * alpha.md (compare define_split): Fix bugs in last addition. + + * calls.c (expand_call, emit_library_call{,_value}, store_one_arg): + Use convert_modes instead of convert_to_mode. + + * tree.h (frame_size): Now a union. + (DECL_ALIGN, DECL_FRAME_SIZE, DECL_FUNCTION_CODE): Access proper + field of frame_size union. + (DECL_SET_FUNCTION_CODE): Simplified; retained for compatibility. + * c-decl.c (duplicate_decls, pushdecl, builtin_function): + Use DECL_FUNCTION_CODE instead of DECL_SET_FUNCTION_CODE. + +Mon Apr 11 05:50:26 1994 Peter Schauer (pes@regent.e-technik.tu-muenchen.de) + + * mips-tfile.c (update_headers): Do not copy stStatic symbols that + result from internal labels. + +Sun Apr 10 07:13:24 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rtl.def (LSHIFT): Deleted. + * combine.c, cse.c, function.c: No longer handle LSHIFT. + * genattrtab.c, loop.c, reload1.c: Likewise. + * expr.h (lshl_optab): Deleted. + * optabs.c (lshl_optab): Deleted. + (expand_binop, init_optabs): No longer reference it. + * genopinit.c, expmed.c (expand_shift): Likewise. + + * arm.c, arm.h, arm.md: Remove references to LSHIFT and lshlsi3. + * clipper.h, clipper.md, convex.h, convex.md, elxsi.md: Likewise. + * fx80.h, fx80.md, gmicro.md, i370.md: Likewise. + * m68k.c, m68k.h, m68k.md, m88k.c, m88k.md, ns32k.md: Likewise. + * rs6000.md, tahoe.md: Likewise. + + * combine.c (simplify_shift_count, case EQ): LSHIFT should be + LSHIFTRT. + +Sun Apr 10 04:48:37 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa-ghiux.h (LIB_SPEC): Remove last change until we've got the + go ahead from HP to distribute /usr/lib/end.o. + * pa-ghpux.h, pa-hiux.h, pa-ghiux.h: Likewise. + +Sat Apr 9 15:06:22 1994 Christian Kranz (kranz@sent5.uni-duisburg.de) + + * config.sub: Add ns* as operating systems; default to ns2 for NeXT. + * configure (m68k-next-ns2*): New configuration. + * libgcc2.c: Include <mach.h>, not <mach/mach.h> for NeXTStep 2.1. + * config/nextstep21.h, m68k/next21.h: New files. + +Sat Apr 9 10:56:06 1994 Randy Wright (rwright@convex.com) + + * combine.c (force_to_mode, case ROTATE): Don't assume + simplify_binary_operation always returns CONST_INT. + (simplify_shift_const, case IOR, PLUS): Likewise. + +Sat Apr 9 09:13:10 1994 Peter Schauer (pes@regent.e-technik.tu-muenchen.de) + + * i386/sequent.h (STRUCT_VALUE{,_INCOMING,_REGNUM}): + Redefine for calling conventions of native cc. + +Sat Apr 9 08:25:43 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * rs6000.h (FINAL_PRESCAN_INSN): Define. + * rs6000.c (rs6000_convert_preincs): New function. + + * i386.md (mulhi3): Use SImode for MULT RTL. + + * fold-const.c (fold): Avoid exponential work when simplifying + conditional expressions; don't recurse twice if ARG1 is constant. + + * function.c (unitialized_vars_warning, setjmp_args_warning): + Reword warning to be less ambiguous. + + * c-typeck.c (convert_arguments): Truncate and reextend + for PROMOTE_PROTOTYPES so we can give error on overflow. + + * reload1.c (reload_conflicts): Rewrite to clean up and fix + numerous bugs; move to later in file. + + * c-decl.c (duplicate_decls): Put new type in same obstack as + old ones, or permanent if old ones in different obstacks. + +Fri Apr 8 18:18:18 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * fold-const.c (fold, case GT_EXPR): Simplify X < (1 << Y) + into X >> Y == 0. + +Fri Apr 8 11:23:51 1994 Ian Lance Taylor (ian@cygnus.com) + + Add support for -membedded-pic to MIPS backend, to create + genuinely position independent code without using a global offset + table. Requires GNU as and ld. + * mips.h (MASK_EMBEDDED_PIC): Define. + (TARGET_EMBEDDED_PIC): Define. + (TARGET_SWITCHES): Add embedded-pic and no-embedded-pic. + (ASM_SPEC): Pass -membedded-pic to assembler. + (ASM_OUTPUT_ADDR_DIFF_ELT): If TARGET_EMBEDDED_PIC output a + difference, rather than using .gpword. + (ASM_OUTPUT_CASE_LABEL): Define. + * mips.md (casesi, casesi_internal): New instructions, used only + for TARGET_EMBEDDED_PIC. + * mips.c (override_options): For TARGET_EMBEDDED_PIC warn + if -mabicalls or -G were used, and set flag_pic and + mips_section_threshold. + (print_operand): Handle 'S' by printing a label with a leading LS. + +Thu Apr 7 22:20:09 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * calls.c (emit_library_call_value): Move is_const set after ifdef. + +Wed Apr 6 21:34:17 1994 Pat Rankin (rankin@eql.caltech.edu) + + * expr.c (expand_builtin, case BUILT_IN_NEXT_ARG): Test whether + an argunment has been passed to __builtin_next_arg; warn if not. + +Wed Apr 6 17:28:44 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * toplev.c (lang_options): Add -f[no-]vtable-thunks (for C++). + +Wed Apr 6 15:35:42 1994 Jim Wilson (wilson@cygnus.com) + + * cccp.c (discard_comments): Replace comments with a single space. + + * Makefile.in (USER_H): Add $(srcdir)/ before every ginclude use. + + * calls.c (emit_library_call_value): New variable is_const. Clear + it for functions that return an aggregate in memory. + + * configure (header_files): Prepend $(srcdir)/ginclude/ to each + element before substituting into the Makefile. Delete ginclude/ + at each point where we set header_files. + + * c-decl.c (finish_decl): Correct typo in use of tree_int_cst_sgn. + +Wed Apr 6 07:39:47 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.md: Add define_split to simplify "(unsigned) x > 0xffffff". + + * toplev.c (lang_options): Group and alphabetize some options. + +Wed Apr 6 07:03:13 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * function.c (push_function_context): Use current_function_varargs. + (pop_function_context): Likewise. + (assign_parms): Respect current_function_varargs. + Save args_so_far in any case. + * expr.c (expand_builtin): Allow builtin_next_arg for varargs + functions as well. + * function.h (struct function): New field for current_function_varargs. + * integrate.c (function_cannot_inline_p): Use current_function_varargs. + * va-alpha.h, va-m88k.h, va-sparc.h (va_dcl): Add ... to + set current_function_varargs. + + * c-decl.c (warn_missing_declarations): New variable. + (c_decode_option): -Wmissing-declarations. + (start_function): Actually do the checking. + * toplev.c (lang_options): Add -Wmissing-declarations. + + * function.c (expand_function_start): Delay copying static chain. + + * calls.c (emit_library_call): Move the invocation of + prepare_call_address before the assignments of the function arguments. + (emit_library_call_value): Likewise. + + * i386.h (DEBUG_PRINT_REG): Fix printing of coprocessor regs in QImode. + +Wed Apr 6 06:42:50 1994 Peter Schauer (pes@regent.e-technik.tu-muenchen.de) + + * mips-tfile.c (update_headers): Copy stStatic symbols from the old + local symbol table to the new local symbol table if they did not get + added via debugging psuedo ops. + +Wed Apr 6 06:36:05 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * stdarg.h, varargs.h (__va_rounded_size): Round to multiple + of sizeof (short) on sysV68. + + * m68k.c (output_function_prologue): pea/move: Fix typos. + asm_fprintf("add%.[wl] ...): Undo previous change. + +Tue Apr 5 20:05:10 1994 Doug Evans (dje@cygnus.com) + + * gcc.c (process_command): Add "include" prefix for [foo/]stageN. + +Tue Apr 5 01:22:08 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa-ghiux.h (LIB_SPEC): Link in /usr/lib/end.o + * pa-ghpux.h, pa-hiux.h, pa-hpux.h (LIB_SPEC): Likewise. + +Mon Apr 4 17:36:55 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * final.c (final_scan_insn): Pass new arg, block num, to + sdbout_end_block. + * sdbout.c (sdbout_begin_block): Don't output block for function + level scope unless MIPS_DEBUGGING_INFO is defined. + (sdbout_end_block): Likewise. Add new parameter n for the block + number. + + * calls.c (expand_call): If PCC_STATIC_STRUCT_RETURN defined, mark + function as addressable same time as we clear is_integrable. + +Mon Apr 4 17:11:17 1994 Jason Merrill (jason@deneb.cygnus.com) + + * Makefile.in (xsys-protos.h): Undefine __*_TYPE when + preprocessing fixtmp.c. + * fixincludes: Fix ptrdiff_t and wchar_t in system headers like we + do size_t. + * scan-types.sh: Use __WCHAR_TYPE__, __PTRDIFF_TYPE__, and + __SIZE_TYPE__. Still deduce size_t so that it can be used for + ssize_t if necessary. + * stddef.h (wchar_t): Always define as __WCHAR_TYPE__. + * cccp.c (special_symbol, case T_WCHAR_TYPE): Output "__wchar_t" + for C++. + +Sat Apr 2 08:14:02 1994 Michael Meissner (meissner@osf.org) + + * i386/osfrose.h (FUNCTION_PROLOGUE, FUNCTION_PROFILER): Correct + code for -fpic ELF case. + +Fri Apr 1 17:33:35 1994 Jason Merrill (jason@deneb.cygnus.com) + + * fixproto: Add strncpy, strpbrk, strrchr, strspn, strstr, strtok + and strxfrm to the required list for string.h. + +Fri Apr 1 01:05:53 1994 Jim Wilson (wilson@cygnus.com) + + * configure: Change math-68881.h to ginclude/math-68881.h. + (EXTRA_HEADERS): Use | not / in sed command. + * math-68881.h, math-3300.h: Move to ginclude directory. + + * libgcc2.c: Modify all uses of __attribute__ mode to use new + syntax. + + * Makefile.in (USER_H): Files in ginclude now. Add stdarg.h, + stddef.h, varargs.h. + (all.cross, rest.encap): Move LIBGCC after stmp-headers. Add + objc-runtime, and SYSCALLS.c.X. + (for-bootstrap): Delete. + (OBJC, OBJECTIVE-C): Delete objc-runtime. + (proto): Delete SYSCALLS.c.X. + (*.o): Delete gvarargs.h dependencies. + (stmp-int-hdrs): Delete gvarargs.h, gstdarg.h, gstddef.h deps, and + code to copy them. + + * bc-emit.c: Change <gvarargs.h> to <varargs.h>. + * enquire.c, libgcc2.c, sys-types.h: Change "gstddef.h" to <stddef.h>. + * gcc.c: Change "gstdarg.h" to <stdarg.h> and "gvarargs.h" to + <varargs.h>. + * objc/Object.m: Change "gstdarg.h" to <stdarg.h>. + * objc/runtime.h, scan-types.sh: Change "gstddef.h" to <stddef.h>. + Change "gstdarg.h" to <stdarg.h>. + * objc/hash.h, objc/objc.h, objc/sarry.h: Delete use of IN_GCC to + control stddef.h/gstddef.h include. + * cccp.c (pcfinclude): Modify comment referring to gstddef.h. + * sparc/sparc.h (CPP_PREDEFINES): Update GCC_NEW_VARARGS comment. + * i386/x-next, m68k/x-next (libgcc2.a, stdarg.h): Delete rules. + * fixincludes: Modify comment referring to gvarargs.h. + * cp/Makefile.in: Modify comments that refer to gvarargs.h and + gstddef.h. + + * gstdarg.h, gstddef.h, gvarargs.h: Move to ginclude directory + and strip off initial `g'. + * va-*.h, proto.h: Move to ginclude directory. + +Thu Mar 31 19:49:17 1994 Jim Wilson (wilson@cygnus.com) + + * sparc.h (SPARC_STACK_ALIGN): Use ~7 not 0xfffffff8 for portability. + + * xcoffout.h (DBX_OUTPUT_MAIN_SOURCE_FILENAME): Disable. + + * sol2.h: Delete ifdefed out section defining *_SECTION_ASM_OP + macros. + ({CTORS,DTORS}_SECTION_ASM_OP) Delete definitions. + * sysv4.h (INIT_SECTION_ASM_OP): Don't set the alloc flag. + ({CTORS,DTORS}_SECTION_ASM_OP): Set execinstr flag. + + * dbxout.c (dbxout_type): Re-enable debugging output for anonymous + structures. Change all three places that refer to xrefs to use + exactly the same condition. + + * c-typeck.c (pop_init_level): Correct typo in use of + tree_int_cst_sgn. + + * mips.c (mips_rtx_classify, md_register_operand, + fpsw_register_operand, cmp2_op, uns_cmp_op, fcmp_op): Delete. + (mips_const_double_ok, mips_fill_delay_slot, output_block_move, + print_operand, function_epilogue): Don't treat gas differently + than native assembler. + (equality_op, cmp_op): Delete use of classify_op. + (override_options): Delete uses of mips_rtx_classify. + (final_prescan_insn): Simplify based on other changes. + * mips.h (mips_rtx_classify, cmp2_op, fcmp_op, + fpsw_register_operand, md_register_operand, uns_cmp_op, + classify_op, additive_op, divmod_op, unsigned_op, CLASS_*_OP, + NOTICE_UPDATE_CC): Delete. + (RTX_COSTS): Use different numbers for R3000/R6000/R4000. + (REGISTER_MOVE_COST): Use cost of 2 within same register class, 4 + for FP to GR copy, 6 otherwise. + (ADJUST_COST): Give anti and output dependencies zero cost. + (PREDICATE_CODES): Delete obsolete functions from list. + * mips.md (addsi3_internal): Don't output subtract. + (subsi3_internal): Don't output add. + (smulsi3_highpart, umulsi3_highpart): Add missing third operand to + mips_move_1word call. + +Thu Mar 31 12:09:42 1994 Ian Lance Taylor (ian@cygnus.com) + + * longlong.h: Change RS/6000 macros to use PowerPC mnemonics when + using -mnew-mnemonics. + +Wed Mar 30 17:37:16 1994 Frederic Pierresteguy (F.Pierresteguy@frcl.bull.fr) + + * m68k/dpx2.h (NO_ASM_FMOVECR): Defined. + * m68k.c (standard_68881_constant_p): Return 0 if NO_ASM_FMOVECR + defined. + + * configure: Add case for rs6000-bull-bosx. + +Wed Mar 30 17:31:24 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.c (global_symbolic_reference_mentioned_p): New parameter F. + (print_operand_address): When generating pic baseregisters are + only allowed if offset is CONST_INT. For {SYMBOL,LABEL}_REF + a indexregister has to be used instead. (sb) is no longer + emitted for constant absolute addresses. + (output_move_double): Use CONSTANT_P instead of CONSTANT_ADDRESS_P. + * ns32k.h (FUNCTION_PROLOGUE): use __GLOBAL_OFFSET_TABLE_, + not _GLOBAL_OFFSET_TABLE_. + (LEGITIMATE_CONSTANT_P, LEGITIMATE_PIC_OPERAND_P): Use + LEGITIMATE_PIC_OPERAND_P, not LEGITIMATE_CONSTANT_P, + to set current_function_uses_pic_offset_table. + (INDIRECTABLE_1_ADDRESS_P): Baseregisters are not legal + for {LABEL,SYMBOL}_REFS when emitting pic. + (GO_IF_INDEXABLE_ADDRESS): INDIRECTABLE_1_ADDRESSes are indexable too. + * ns32k/netbsd.h, ns32k/xm-netbsd.h: New files. + * configure (ns32k-pc532-netbsd*): New case, to use new files. + +Wed Mar 30 16:39:24 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (reload): Fix typo in previous change. + + * gcc.c (process_command, case 'B'): If name is "stageN/", + add "include" to system include prefix. + + * bc-emit.c, calls.c, combine.c, emit-rtl.c, final.c, g++.c: + Include <stdarg.h> instead of "gstdarg.h"; similarly for varargs. + * genattrtab.c, mips-tfile.c, protoize.c, toplev.c, tree.c: Likewise. + + * fold-const.c (strip_compound_expr): New function. + (fold): Call it; avoid exponential work when simplifying + binary op over a COND_EXPR. + + * cse.c (cse_insn): Add missing definition of var TEM; clean up + shadowed uses. + + * sparc.c (sparc_type_code): Revise so it supports non-C types. + +Wed Mar 30 14:52:26 1994 Jim Wilson (wilson@mole.gnu.ai.mit.edu) + + * xm-alpha.h (string.h): Don't include when inhibit_libc is defined. + +Wed Mar 30 10:37:51 1994 Stan Coxs (coxs@dg-rtp.dg.com) + + * m88k.md (movdf): Do not consider extended registers when doing + define_split. + +Wed Mar 30 01:49:06 1994 Torbjorn Granlund (tege@cygnus.com) + + * config/m68k/m68k.c (output_move_double): Use `%.' where appropriate. + +Tue Mar 29 10:46:18 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (ASM_OUTPUT_LABEL): TARGET_GAS no longer needs trailing colons. + (ASM_OUTPUT_INTERNAL_LABEL, ASM_OUTPUT_COMMON): Likewise. + + * pa.h (TARGET_PORTABLE_RUNTIME): Define. + (TARGET_SWITCHES): Add -mportable-runtime and -mno-portable-runtime. + (CUMULATIVE_ARGS): Now a "struct hppa_args" rathern than an int. + All references changed. + (INIT_CUMULATIVE_ARGS): Also initialize nargs_prototype. + (INIT_CUMULATIVE_INCOMING_ARGS): Define. + (FUNCTION_ARG_ADVANCE): Decrement nargs_prototype for each arg seen. + (FUNCTION_ARG): Handle TARGET_PORTABLE_RUNTIME. + (ASM_DECLARE_FUNCTION_NAME): Explicitly disallow argument relocations + for TARGET_PORTABLE_RUNTIME. + (ASM_OUTPUT_INT): Do not use a P% prefix for function references + if TARGET_PORTABLE_RUNTIME. + + * pa.md (high and lo_sum for function addresses): Provide alternate + definitions for TARGET_PORTABLE_RUNTIME. + + * pa.c (output_arg_descriptor): Explicitly disallow argument + relocations for TARGET_PORTABLE_RUNTIME. + +Tue Mar 29 07:45:44 1994 Chris Smith (csmith@convex.com) + + * convex.h (check_float_value): fix return type in extern. + +Mon Mar 28 18:36:56 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k/mot3300.h (ASM_IDENTIFY_GCC): Define to be non-null. + +Sun Mar 27 20:26:36 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * c-parse.in (attrib): Handle string args as expressions, + merging the two rules. `mode' attribute now takes a string arg. + Delete the rule for an identifier as arg. + * c-common.c (decl_attributes): `mode' attribute now takes string arg. + +Sun Mar 27 14:42:39 1994 Doug Evans (dje@cygnus.com) + + * c-parse.in (attrib): Back out last patch. + +Fri Mar 25 17:52:44 1994 Walter Misar (misar@rbg.informatik.th-darmstadt.de) + + * m68k.md (movsi): New strategy for moving small constants into dregs, + if it can't be done with moveq. + * m68k.h (CONST_COSTS): Reflect the change in m68k.md. + +Fri Mar 25 14:30:47 1994 Philippe De Muyter (phdm@info.ucl.ac.be) + + * m68k.md (call): If (new) MOTOROLA_BSR defined, try to emit 'bsr'. + * m68k/mot3300.h (MOTOROLA_BSR): Defined. + + * m68k.c (output_function_prologue): Use link.w on 68040; + emit pea fp + movl sp,fp instead of linkw 0 for 68040. + +Fri Mar 25 14:21:06 1994 Jim Meyering (meyering@idefix.comco.com) + + * bc-emit.c (bc_emit_bytecode): Remove decl of unused variable NPUSHES. + (bc_emit_instruction): Remove decl of unused variable LITERAL. + * c-aux-info.c (gen_decl): Remove decl of unused variable. + * c-common.c (truthvalue_conversion): Remove decl of unused CODE. + * c-decl.c (push_parm_decl): Move decl of unused variable OLDDECL + into #if 0 block. + (finish_enum): Remove decls of unused variables I and TEMPORARY. + * c-parse.in (primary): Remove decl of unused variable CONTEXT. + * c-typeck.c (convert_arguments): Remove decls of unused variables. + * collect2.c (putenv): Remove decl of unused variable STR_LEN. + (main): Remove decls of unused variables LEN and CLEN. + * combine.c (try_combine): Remove decls of unused variables. + (subst): Remove decls of unused variables ORIG_CODE. + (simplify_if_then_else): Remove decl of unused variable C2. + (make_compound_operation): Remove decl of unused variable COUNT. + (known_cond): Remove decl of unused variable NEW. + (make_field_assignment): Remove decl of unused variable OURDEST. + (simplify_and_const_int): Remove decls of unused variables. + (simplify_shift_const): Remove decl of unused variable INNER. + * cse.c (cse_insn): Remove decl of unused variable TEM. + * dbxout.c (dbxout_symbol): Remove decls of unused variables. + * emit-rtl.c (reset_used_flags): Remove decl of unused variable. + (gen_sequence): Remove decl of unused variable NEWVEC. + * enquire.c (f_rep): Remove decl of unused variable F1. + * final.c (output_source_line): Remove decl of unused variable. + * fix-header.c (read_scan_file): Remove decl of unused variable RPTR. + (write_rbrac): Remove decl of unused variable PARTIAL. + (main): Likewise. + * g++.c (main): Remove decl of unused variable FN. + * genattr.c (main): Remove decl of unused variable MAX_ISSUE_TIME. + * genattrtab.c (expand_units): Remove decl of unused variable. + * genrecog.c (break_out_subroutines): Remove decl of unused variable. + * global.c (global_conflicts): Move decl of unused variable I into + #if 0 block. + * integrate.c (save_for_inline_nocopy): Remove decls of unused vars. + (expand_inline_function): Remove two block-scope decls of unused + variable COPY. + * jump.c (invert_jump): Remove decl of unused variable OLABEL. + * loop.c (init_loop): Remove decls of unused variables. + (loop_optimize): Remove decl of unused variable END. + (combine_movables): Remove decls of unused variables. + (check_final_value): Remove decl of unused variable TEM. + (check_dbra_loop): Remove decls of unused variables. + (maybe_eliminate_biv): Remove decls of unused variables SET and V. + * reload.c (find_reloads_address): Remove two block-scope decls of + unused variable OLDREF. + * rtl.c (read_rtx): Remove decl of unused variable STRINGBUFSIZE. + * scan.c (get_token): Remove decl of unused variable QUOTE. + (get_token): Remove unused label AGAIN. + * sched.c (clear_units): Remove decl of unused variable UNIT. + (actual_hazard_this_instance): Remove decl of unused variable I. + (actual_hazard): Remove two block-scope decls of unused variable BEST. + (sched_analyze_1): Remove decls of unused variables OFFSET and BIT. + (sched_analyze): Remove decl of unused variable DEST. + (sched_note_set): Remove decl of unused variable J. + (create_reg_dead_note): Remove decl of unused variable BACKLINK. + (new_sometimes_live): Remove decl of unused variable I. + (schedule_block): Remove decls of unused variables LAST_NOTE and REGNO. + (schedule_insns): Remove decls of unused variables I and INSNS. + * sdbout.c (sdbout_symbol): Remove decl of unused variable LETTER. + (sdbout_type): Remove decl of unused variable TEM. + * toplev.c (compile_file): Remove unused label. + * tree.c (stabilize_reference_1): Remove decl of unused variable. + * unroll.c (unroll_loop): Remove decl of unused variable V. + (precondition_loop_p): Remove decls of unused variables. + (final_giv_value): Remove decl of unused variable CODE. + +Fri Mar 25 13:40:05 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (DBX_REGISTER_NUMBER): Fix numerous bugs in handling + of FP registers and the SAR register. + +Fri Mar 25 12:46:56 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * i386.md (movhi, movqi): Properly recognize unsigned forms of -1 + for dec[bw] insns. + + * expr.c (expand_expr, case ADDR_EXPR): Return const0_rtx if + taking address of an ERROR_MARK; also do some minor cleanup. + + * calls.c (expand_call): Don't require both -W and -Winline to say + that call can't be inlined. + Warn if inlining is tried but fails. + + * cccp.c (for_lint): Variable renamed from `lint'. + + * expr.c (expand_expr, case ABS_EXPR): Compare with 0 of proper mode. + + * fold-const.c (fold, case *_DIV_EXPR): Correct result when + product of constants overflows. + + * alpha.c (output_prolog): Correctly compute floating-reg save + area offset. + + * stmt.c (init_stmt_for_function): Clear stack_block_stack. + + * reload1.c (reload): Fix error in last change; only check + against group reloads and check all reloads. + +Thu Mar 24 13:19:43 1994 Doug Evans (dje@cygnus.com) + + * toplev.c (v_pedwarn_with_decl): Don't cause compilation to fail + from pedantic errors in system header files. + +Thu Mar 24 03:01:05 1994 Frederic Pierresteguy (F.Pierresteguy@frcl.bull.fr) + + * config.sub: Add case for Bull dpx20. + + * config/m68k/dpx2.h (CPP_PREDEFINES): Fix typo. + +Wed Mar 23 17:29:56 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * reload1.c (reload): Fix error in last change; compute MODE before + it's used. + + * loop.c (get_condition): Exit if we don't recognize SET_SRC of + a SET that modifies OP0. + + * combine.c (simplify_rtx, case FLOAT_TRUNCATE): Simplify + case of (float_truncate (abs (float_extend X))). + +Wed Mar 23 17:20:54 1994 Jim Wilson (wilson@cygnus.com) + + * dbxout.c (dbxout_parms): For parameter living in psuedo-reg that + was optimized away, use declared type instead of passed type. + + * mips.c (mips_asm_file_start): Add comment on TARGET_GP_OPT code. + + * c-decl.c (init_decl_processing): Change builtin_next_arg type so + that it accepts any parameter instead of none. + * cp/decl.c (init_decl_processing): Likewise. + * expr.c (expand_builtin, BUILT_IN_NEXT_ARG case): Verify that + parameter is last named argument. + * gstdarg.h (va_start): Pass LASTARG as a parameter to + builtin_next_arg. + * va-h8300.h, va-i860.h, va-i960.h, va-mips.h, va-sparc.h + (va_start): Likewise. + * va-alpha.h (va_start): Add call to builtin_next_arg. + * va-clipper.h, va-m88k.h, va-pa.h, va-sparc.h (va_start): + Likewise. + +Tue Mar 22 18:57:54 1994 Jim Wilson (wilson@cygnus.com) + + * iris5.h (MIPS_DEFAULT_GVALUE): Define to zero. + * mips.c (pic_address_needs_scratch): New function. + (override_options): Set flag_pic when TARGET_ABICALLS. + * mips.h (GO_IF_LEGITIMATE_ADDRESS): Also pretend that we have REG + plus CONST_INT addresses by deleting an else. + (CONSTANT_ADDRESS_P): When pic, don't accept addresses which are + symbol_ref plus a large integer. + (LEGITIMATE_PIC_OPERAND_P): Likewise. + (LEGITIMIZE_ADDRESS): When pic, convert addresses which are + symbol_reg plus a large integer, to reg plus a large integer. + (ASM_OUTPUT_ADDR_DIFF_ELT): Use .gpword instead of subtracting + labels. + * mips.md (movsi): Add special handling for constants which are + illegal addresses when pic. + (tablejump_internal1, tablejump_internal2): Emit .cpadd when + TARGET_ABICALLS. Adjust length to include .cpadd. + + * mips.h (TRAMPOLINE_TEMPLATE): Add `move $25,$3' for when + TARGET_ABICALLS. Delete padding for 64 bit case. Adjust offsets. + (TRAMPOLINE_SIZE): Increase from 9 to 10 words for 32 bit case. + (INITIALIZE_TRAMPOLINE): Increase offsets by 4 bytes for 32 bit case. + +Tue Mar 22 15:46:42 1994 Michael Meissner (meissner@osf.org) + + * i386/osfrose.h (HANDLE_PRAGMA_WEAK): Define in terms of + TARGET_ELF. + (ASM_OUTPUT_DEF): Provide a definition. + +Mon Mar 21 15:56:58 1994 Per Bothner (bothner@cygnus.com) + + * fix-header.c: Make sstring buf extern (rather than "common"). + +Mon Mar 21 17:45:56 1994 Doug Evans (dje@cygnus.com) + + * configure: Accept and ignore --without-*. + +Mon Mar 21 17:05:25 1994 Jim Wilson (wilson@cygnus.com) + + * dbxout.c (source_label_number): New variable. + (dbxout_source_file): Use it. Output an Ltext label. + + * c-decl.c (duplicate_decls): When pedantic, warn when any static + declaraction follows a non-static. + + * sparc.md (seq, sne, sgt, slt, sge, sle): Add support + for !TARGET_HARD_QUAD. + +Mon Mar 21 16:59:02 1994 Mike Collison (collison@chianti.sw.stratus.com) + + * reload1.c (reload): More accurately compute nongroup needs. + (reloads_conflict): New function. + +Mon Mar 21 16:21:07 1994 Doug Evans (dje@cygnus.com) + + * libgcc2.c (__builtin_saveregs): Fix return type. + +Mon Mar 21 07:37:13 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * function.c (preserve_temp_slots): If argument is REG, see if it + is address of a temp slot we know about. + * expr.c (expand_expr, case ADDR_EXPR): Update temp slot address + if we put it in a register; mark result as pointer. + + * cse.c (FIXED_REGNO_P): Treate global regs as fixed. + (CHEAP_REGNO): Renamed from CHEAP_REG. + (CHEAP_REG): New macro; user var in hard reg is cheap. + (COST): Pass RTL to CHEAP_REG, not regno. + (rtx_cost, case REG): Likewise. + +Sun Mar 20 19:38:44 1994 Stephen L Moshier (moshier@world.std.com) + + * m68k/news.h (PRINT_OPERAND): Print float infinity + and NaN's as +/-99e999. + +Sun Mar 20 17:42:09 1994 Peter Schauer (pes@regent.e-technik.tu-muenchen.de) + + * mips-tfile.c (update_headers): Align symbol table sections, + using ALIGN_SYMTABLE_OFFSET. Provide a default definition which + does no alignment. + * alpha.h (ALIGN_SYMTABLE_OFFSET): New macro. + +Sun Mar 20 06:38:41 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * emit_rtl.c (try_split): Rename third parameter as LAST. + Recursively call try_split for each new insn created. + + * combine.c (mark_used_regs_combine): Correct typo. + +Sun Mar 20 06:28:23 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * vax.h (CHECK_FLOAT_VALUE): Add missing continuation character. + * tree.c (build_real): Add `overflow' var; pass to CHECK_FLOAT_VALUE. + +Sat Mar 19 17:44:14 1994 Jim Wilson (wilson@cygnus.com) + + * expr.c (expand_expr, case ABS_EXPR): Fix typo in last change. + +Sat Mar 19 17:13:47 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * combine.c (newpat_used_regs): New variable. + (mark_used_regs_combine): New function. + (try_combine): Use them. + (reg_dead_at_p): Registers marked in newpat_used_regs must always be + considered to be live. + +Sat Mar 19 06:29:38 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * c-parse.in (attrib): Use `identifier' instead of `IDENTIFIER' + since names that are (e.g.) typedef names are still OK. + + * m68k/next.h (GO_IF_INDEXABLE_BASE): Make compatible with m68k.h. + + * genoutput.c (output_epilogue, insn_names): Write correct names + for patterns before first named pattern. + + * nextstep.h (SELECT_SECTION): Fix typo (arg names) in last change. + + * c-decl.c (grokdeclarator): Use signed version of `sizetype' for + type of array index. + +Sat Mar 19 06:25:39 1994 Stephen L Moshier (moshier@world.std.com) + + * fold-const.c (const_binop): Avoid initialized aggregate + local variables, for antique compilers. + +Fri Mar 18 18:43:28 1994 Jim Wilson (wilson@cygnus.com) + + * i386/osfrose.h (SELECT_SECTION): Variables go in readonly data + only if the initializer is constant. + * i386/svr3gas.h, m88k/m88k.h, mips/mips.h, nexstep.h, + rs6000/rs6000.h, sparc/sparc.h, svr3.h, svr4.h, vax/vms.h + (SELECT_SECTION): Likewise. + * varasm.c (assemble_variable): Likewise. + +Fri Mar 18 17:54:12 1994 David Edelsohn (edelsohn@npac.syr.edu) + + * rs6000.md (divmodsi4, udivsi3, divsi3, udivmodsi4): Add AIX + common-mode cases. + (mulh_call, mull_call, divss_call, divus_call, quoss_call, quous_call): + AIX common-mode call patterns. + (ashlsi3): More TARGET_POWERPC to ! TARGET_POWER changes. + (addsf3, subsf3, mulsf3, divsf3, etc.): Change TARGET_POWER + to ! TARGET_POWERPC. + (fix_truncdfsi2): Use POWER/2 and PowerPC FP convert instruction. + (fpcvtsi): New pattern. + (mulsidi3): Add AIX common-mode case, add imul attribute to POWER + pattern, add PowerPC pattern, flag input operands as commutative. + (smulsi3_highpart): Add AIX common-mode case. + (movsi matcher): Add mtjmpr attribute to ! TARGET_POWER case. + (movsf): Clean up load from memory or integer register test. + (movdi matcher): Add FP register support. + + * rs6000.c (common_mode_defined): New variable. + (output_prolog): Define external common-mode calls. + + * rs6000.h (HARD_REGNO_MODE_OK): Allow DImode in FP registers. + (CONDITIONAL_REGISTER_USAGE): Delete ppcas mention from comment. + (RTX_COSTS): Costs based upon processor_type enum. + +Fri Mar 18 17:53:35 1994 Torbjorn Granlund (tege@cygnus.com) + + * rs6000.md (smulsi3_highpart): New patterns. + (umulsi3_highpart_power): New pattern. + +Fri Mar 18 15:26:56 1994 Jim Wilson (wilson@cygnus.com) + + * sol2.h (SELECT_RTX_SECTION): Delete. + * sysv4.h (SELECT_RTX_SECTION): Add. + (ASM_SPEC): Pass -K to assembler when PIC. + + * cccp.c (before_system, last_before_system): New variables. + (main): Handle -isystem option. Insert -isystem directories in + search chain at first_system_include. + * gcc.c (include_prefix): New variable. + (process_command): Add path/include to include_prefix when see a + -Bpath option. + (do_spec_1, case 'I'): Pass include_prefix directories to cpp with + the -isystem option. + + * loop.c (scan_loop): New variable loop_depth. Increment and + decrement on LOOP_BEG and LOOP_END notes. Only use LOOP_VTOP note + if loop_depth is zero. + (strength_reduce): Likewise. + + * sparc/sparc.h (FIXUNS_TRUNCTFSI2_LIBCALL): Define. + * optabs.c (init_optabs): Use FIXUNS_TRUNCTFSI2_LIBCALL macro. + +Thu Mar 17 13:13:46 1994 Per Bothner (bothner@kalessin.cygnus.com) + + * stor-layout.c (layout_type, case BOOLEAN_TYPE): + Set TREE_UNSIGNED unless TYPE_MIN_VALUE is negative. + +Thu Mar 17 18:36:34 1994 Jim Wilson (wilson@cygnus.com) + + * c-common.c (shorten_compare): When simplify compare against + zero, check for restype_ptr unsigned instead of primop0 unsigned. + + * calls.c (expand_call): Undo Feb 27 change. Set nregs to -1 for + normal case. + +Thu Mar 17 17:43:28 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixinc.svr4: Define BYTE_ORDER in <sys/byteorder.h> as on + UnixWare 1.1. + +Thu Mar 17 06:02:24 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stor-layout.c (layout_type, case INTEGER_TYPE): Properly test for + nonnegative lower bound. + +Wed Mar 16 12:41:19 1994 Ian Lance Taylor (ian@cygnus.com) + + * tree.c (build_nt, build_parse_node): Don't declare last + parameter to be register, since it is used in VA_START, which + may take its address. + * genattrtab.c (attr_printf): Likewise. + +Wed Mar 16 12:00:40 1994 Jeffrey A. Law (law@snake.cs.utah.edu) + + * pa.h (INITIALIZE_TRAMPOLINE): Do not mask off high + bits of address passed to icacheflush. + + * pa.h (WCHAR_TYPE): Use "unsigned int" by default. + (WCHAR_TYPE_SIZE): Change appropriately. + * pa-ghiux.h, pa-ghpux.h, pa-gux7.h, pa-hiux.h, pa-hpux.h, + pa-hpux7.h (WCHAR_TYPE): Delete definition. + (WCHAR_TYPE_SIZE): Likewise. + * pa-osf.h (WCHAR_TYPE): Override appropriately for OSF1. + (WCHAR_TYPE_SIZE): Likewise. + + * pa.md (DImode lo_sum): Add earlyclobber for alternative one. + + * pa.h (ASM_OUTPUT_ADDR_DIFF_ELT): Rewrite to match + ASM_OUTPUT_ADDR_VEC_ELT which is PIC-safe. + +Wed Mar 16 09:07:34 1994 Matthias Pfaller (leo@marco.de) + + * ns32k.c (global_symbolic_reference_mentioned_p): Recurse only + if GET_CODE (op) == CONST. + + * ns32k.h (FUNCTION_PROLOGUE): Load sb through r0 if TARGET_REGPARM + is false. + +Wed Mar 16 06:57:45 1994 Richard Kenner (kenner@vlsi1.ultra.nyu) + + * emit-rtl.c (gen_lowpart_common, gen_highpart, operand_subword): + Test input against RTX for FP, AP, and SP, not same register number. + + * expr.c (expand_expr): Update comments and fix formatting. + (expand_expr, case VAR_DECL, STRING_CST, CONSTRUCTOR): If + flag_force_addr, put address in register unless REG. + (expand_expr, case CONSTRUCTOR, CONVERT_EXPR): Make TARGET with + TMODE, if specified. + (expand_expr, case IN_EXPR): Clean up. Allow INDEX to be an + unsigned type. Always evaluate SET and INDEX in case of side effects. + (expand_expr, case CONVERT_EXPR): Use convert_modes to handle consts. + (expand_expr, case ABS_EXPR): Simplify processing of COMPLEX. + Compare with zero word-by-word if required. + (expand_expr, case ABS_EXPR, MIN_EXPR, COND_EXPR): Don't use TARGET + if not MODE. + (expand_expr, case TRUTH_*_EXPR): Modes of input and output must agree. + (expand_expr, case CONJ_EXPR): Remove redundant def of MODE. + + * stor-layout.c (layout_record): If the place where we were going + to put a field changed, lay it out again. + +Tue Mar 15 07:53:36 1994 Paul A Vixie (paul@vix.com) + + * Makefile.in (stmp-fixproto): Add missing "-" in front of "if". + (install-headers-tar, gcc.xtar): Use "-" in front of tar options. + +Mon Mar 14 16:28:16 1994 Paul Eggert (eggert@twinsun.com) + + * fixincludes: Insert newlines just before the end of 'sed' + command strings if the last 'sed' command is 'a' or 'i'; + BSDI 1.1 'sed' needs this. + +Mon Mar 14 15:46:29 1994 Ian Lance Taylor (ian@cygnus.com) + + * fixinc.svr4: Don't name variables in mmap prototype. + +Mon Mar 14 15:16:38 1994 Doug Evans (dje@cygnus.com) + + * objc/Makefile (*.o): Add explicit dependencies for Sun's VPATH. + +Mon Mar 14 05:11:42 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * function.c (assign_parms, expand_function_start): Properly + set MEM_IN_STRUCT_P for DECL_RTL of function result. + + * c-decl.c (grokdeclarator): Convert to sizetype when manipulating + size of array and use care to avoid mixed-type operations. + + * expr.c (expand_expr): Don't call bc_expand_expr + if EXPAND_INITIALIZER. + * bc-optab.c (bc_expand_{binary,unary}_operation): Add missing + args to call to expand_expr. + * stmt.c (bc_expand_start_cond): Set exit_label if not EXITFLAG. + (bc_expand_end_bindings): Only define exit_label if set. + Don't pop nesting_stack. + * varasm.c (output_constant_def): Do hashing and make label + even if bytecode. + * bc-emit.c (bc_seg_write): Don't make unaligned reference to + seg->data. + * toplev.c (compile_file): Call bc_write_file here and pass + asm_out_file, not stdout. + (main): Don't call bc_write_file here. + Fix wording on error if -fbytecode specified on unsupported target. + + * fold-const.c (fold, associate): If -ffast-math, associate FP mults. + (fold, case RDIV_EXPR): Split case; ignore division by 1. + If -ffast-math, convert to multply by reciprocal. + (fold, case *_DIV_EXPR): Simplify A/C1/C2. + + * tree.h (tree_int_cst_sgn): New declaration. + * tree.c (tree_int_cst_sgn): New function. + * c-decl.c (finish_{decl,struct,enum}): Call it. + * c-typeck.c (build_binary_op, pop_init_level): Likewise. + (output_pending_init_elements): Likewise. + * expr.c (expand_builtin, case BUILT_IN_RETURN_ADDRESS): Likewise. + * fold-const.c (fold): Likewise. + (fold, case *_DIV_EXPR): Add missing conversion. + * convert.c (convert_to_integer): Convert integer_one_node to + proper type before tree_int_cst_lt call. + +Sun Mar 13 06:46:13 1994 Wolfgang Stukenbrock (wgstuken@immd4.informatik.uni-erlangen.de) + + * gcc.c (do_spec_1): Don't duplicate a macro starting with '__'. + +Sun Mar 13 05:54:00 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * convert.c (convert_to_integer): When changing type of truthvalue + operation, change types of inputs too. + * c-common.c (TRUTH_*_EXPR): Convert to integer_type_node. + + * tree.c: Include setjmp.h. + (build_real_from_int_cst): Propagate overflow flags and + establish float handler. + (build_complex): Propagate overflow flags. + * cse.c (simplify_binary_operation): Protect real_value_truncate + inside handler. + * fold-const.c (force_fit_value): Operate on REAL_CST as well. + (real_value_truncate): Don't use its own handler. + (const_binop): Set overflow on FP error and call force_fit_type. + (fold_convert): Likewise. + * c-common.c (constant_expression_warning, overflow_warning): + Handle REAL_CST and COMPLEX_CST. + * convex.h, convex.c, fx80.h, tahoe.h, vax.h, vax.c: Add OVERFLOW + operand to CHECK_FLOAT_VALUE. + + * jump.c (rtx_equal_for_thread_p): Correct error in previous + change; add missing arg in recursive call. + +Sat Mar 12 19:42:03 1994 H.J. Lu (hjl@nynexst.com) + + * configure (gxx-include-dir): Replacement for gxx-prefix. + * Makefile.in (gxx_include_dir): Likewise, for gxx_prefix. + + * i386/linux.h (NO_IMPLICIT_EXTERN_C): Defined. + +Sat Mar 12 07:42:12 1994 Paul Eggert (eggert@twinsun.com) + + * Makefile.in (stmp-fixproto): Work around a `make' bug in BSDI 1.1. + +Sat Mar 12 07:38:08 1994 Klaus Kaempf (kkaempf@didymus.rmi.de) + + * bi-run.h: Properly test BYTES_BIG_ENDIAN. + * bytecode.h: Likewise for WORDS_BIG_ENDIAN. + + * cccp.c (do_include, hack-vms_include_specification): Change handling + of '#include filename' to be compatible with VAX-C. + + * genemit.c (gen_exp): Added \n to printf to shorten line for VAX-C. + +Sat Mar 12 06:42:38 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * expr.h (emit_float_lib_cmp): Add declaration here. + * optabs.c: Don't define emit_float_lib_cmp now that no longer static. + + * jump.c: Add prototypes for static functions. + (jump_optimize, delete_insn): Use GET_RTX_CLASS to test for insns. + (mark_jump_label): Delete dead code. + (delete_computation, redirect_tablejump): No longer static. + +Fri Mar 11 14:40:40 1994 Jim Wilson (wilson@cygnus.com) + + * lite.h (TARGET_DEFAULT): Use parentheses. + * sparc.h (TARGET_HARD_QUAD): New macro. + (TARGET_SWITCHES): Add hard-quad-float, soft-quad-float. + (TARGET_DEFAULT): Use parentheses. + ({ADDTF3,SUBTF3,MULTF3,DIVTF3,SQRTTF2,FLOATSITF2,FIX_TRUNCTFSI2, + EXTENDSFTF2,TRUNCTFSF2,EXTENDDFTF2,TRUNCTFDF2,EQTF2,NETF2,GTTF2, + GETF2,LTTF2,LETF2}_LIBCALL): New macros. + * sparc.md (sleu+4, sleu+7, extendsftf2, extenddftf2, trunctfsf2, + trunctfdf2, floatsitf2, fix_trunctfsi2, addtf3, subtf3, multf3, + divtf3, sqrttf2): Disable when -msoft-quad-float. + (beq, bne, bgt, blt, bge, ble): When -msoft-quad-float, account + for return value of SPARC ABI routines that differs from libgcc. + * flow.c (libcall_dead_p): Fail not abort for libcall that returns + value via invisible pointer. + * optabs.c (emit_float_lib_cmp): Make non static. + (init_optabs): Use {ADDTF3,SUBTF3,MULTF3,DIVTF3,SQRTTF2,FLOATSITF2, + FIX_TRUNCTFSI2,EXTENDSFTF2,TRUNCTFSF2,EXTENDDFTF2,TRUNCTFDF2,EQTF2, + NETF2,GTTF2,GETF2,LTTF2,LETF2}_LIBCALL macros. + + * sparc/sparc.h (STARTING_FRAME_OFFSET): Depend on + LONG_DOUBLE_TYPE_SIZE. + +Fri Mar 11 08:01:54 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * rtl.h, tree.h, g++.c, gcc.c (PVPROTO): New macro. + * combine.c, expr.h, rtl.h, tree.h, gcc.c: Use it for varargs protos.. + * genattrtab.c, mips-tfile.c, output.h, toplev.c: Likewise. + +Fri Mar 11 07:21:36 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * emit-rtl.c (copy_rtx_if_shared, case LABEL_REF): Can't share. + * jump.c (jump_optimize): Delete REG_LABEL note if label no + longer in insn. + + * c-decl.c (finish_decl): When preserving an initializer, ensure + its type is on a good obstack. + +Thu Mar 10 15:32:42 1994 Mike Collison (collison@sw.stratus.com) + + * reload1.c (emit_reload_insns): When clearing reg_last_reload_reg, + clear all hard regs in reload_out. + +Thu Mar 10 15:23:10 1994 Hallvard B Furuseth (hbf@durin.uio.no) + + * collect2.c (dup2): Catch `dup' failure. Return correct value. + +Thu Mar 10 15:18:08 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * gcc.c ([__MSDOS__]): Use #ifdef, not #if. + * collect2.c ([__MSDOS__]): Likewise. + +Thu Mar 10 15:03:01 1994 Paul Eggert (eggert@twinsun.com) + + * cccp.c (main, finclude, check_precompiled): When safe_read + returns a partial buffer, this means EOF has been reached; + don't try to read any more. + +Wed Mar 9 18:47:29 1994 Paul Eggert (eggert@twinsun.com) + + * real.c (target_negative): -0 counts as negative. + +Wed Mar 9 15:32:01 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * m68k.md (movqi): Disable special-case of stack push if operand + one is an address register. + + * c-typeck.c (pointer_int_sum): Multiplication should be + done signed. + (pointer_diff): Likewise the division. + * fold-const.c (fold, case MULT_EXPR): Simplify MULT_EXPR of an + EXACT_DIV_EXPR with the same divisor as our multiplicand. + + * jump.c (rtx_equal_for_thread_p): Commutative operations + are identical if the operands match in the opposite order. + * sched.c (rtx_equal_for_memref_p): Likewise. + +Wed Mar 9 12:07:29 1994 Richard Earnshaw (rwe11@cl.cam.ac.uk) + + * cse.c (simplify_relational_operation): Fix typos; use + ARG_POINTER_REGNUM and FRAME_POINTER_REGNUM in condtionals. + +Tue Mar 8 16:12:07 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * explow.c (break_out_memory_refs): Don't call mark_reg_pointer + here. + (memory_address): Call it here if X changed and is now a REG + or REG + CONST_INT. + +Tue Mar 8 15:57:29 1994 Jim Wilson (wilson@cygnus.com) + + * c-decl.c (finish_decl): When saving/discarding initializers, + don't check TREE_PERMANENT and TREE_STATIC. + (finish_decl, finish_function): Pass new argument to + permanent_allocation. + * cp/decl.c (finish_function): Likewise. + * cp/decl2.c (write_vtable_entries, finish_file): Likewise. + * toplev.c (compile_file): Likewise. + * function.h (struct function): Add momentary_function_firstobj + field. + * tree.c (momentary_function_firstobj): New variable. + (init_obstack): Set it. + (save_tree_status): Save it and set it. + (restore_tree_status): Use it and restore it. + (permanent_allocation): New parameter function_end. Clear + momentary_obstack to momentary_function_firstobj if true. + (preserve_initializer): Set base field of every momentary + level on the momentary stack to new momentary_firstobj. + (pop_momentary): Only free back to previous base. + * tree.h (permanent_allocation): Add prototype. + +Mon Mar 7 20:10:56 1994 Jim Wilson (wilson@cygnus.com) + + * iris4gl.h: Rewrite. Include iris4loser.h not iris4-gdb.h. + Define PREFERRED_DEBUGGING_TYPE not ASM_SPEC. + + * bsd-4.h (LINK_SPEC): Do not depend on gas. Don't interpret -EB + and -EL options, but do pass them. + * bsd-5.h (LINK_SPEC): Likewise. + * decl-osf1.h (LINK_SPEC): Likewise. + * iris5.h (LINK_SPEC): Likewise. + * mips-5.h (LINK_SPEC): Likewise. + * mips.h (LINK_SPEC): Likewise. + * svr3-4.h (LINK_SPEC): Likewise. + * svr3-5.h (LINK_SPEC): Likewise. + * svr4-4.h (LINK_SPEC): Likewise. + * svr4-5.h (LINK_SPEC): Likewise. + + * dec-bsd.h (LINK_SPEC): Pass all normal linker options to gld. + (ASM_SPEC): Pass all normal assembler options to gas. + * osfrose.h (LINK_SPEC): Likewise. + (ASM_SPEC): Likewise. + + * mips.h (ASM_SPEC): Make definition depend on whether or + not the default assembler is gas. Pass all normal assembler + options to gas. + * iris4loser.h (ASM_SPEC): Likewise. Pass -O0 if the assembler is + not gas. + + * iris3.h (ASM_SPEC, LINK_SPEC): Delete. + * news4.h (ASM_SPEC, LINK_SPEC): Delete. + * news5.h (LINK_SPEC): Delete. + * nws3250v4.h (ASM_SPEC, LINK_SPEC): Delete. + * ultrix.h (ASM_SPEC, LINK_SPEC): Delete. + + * mips.h (ASM_FINAL_SPEC): Cross compiling does not presume gas. + + * osfrose.h (SIZE_TYPE): Delete. + (MAX_WCHAR_TYPE_SIZE): Define. + + * calls.c (expand_call): For pcc_struct_value case, set + MEM_IN_STRUCT_P correctly on target. + + * Makefile.in (mostlyclean): Don't explicitly delete ld. + +Mon Mar 7 20:06:38 1994 Ian Lance Taylor (ian@cygnus.com) + + * mips-tdump.c (print_symbol): The index field of a global symbol + is the symbol table index of the corresponding local symbol, not + an index into the aux table. + (print_file_desc): Print out size of line number information + rather than repeating line number count. The cbLineOffset field + of a PDR is relative to the cbLineOffset field of the FDR. Also, + when computing line_end of the last PDR, use cbLineOffset, not + ilineBase. + +Mon Mar 7 17:42:35 1994 H.J. Lu (hjl@nynexst.com) + + * Makefile.in (gxx_prefix): New; default to $(libdir). + (GPLUSPLUS_INCLUDE_DIR): Change to $(gxx_prefix)/g++-include. + * configure (gxx_prefix): New; default to $(libdir). + + * i386/linux.h (GPLUSPLUS_INCLUDE_DIR): Deleted. + (STARTFILE_SPEC): Remove "-nojump". + +Mon Mar 7 17:06:08 1994 Stephen R. van den Berg (berg@pool.informatik.rwth-aachen.de) + + * i386/xm-linux.h (malloc): Remove disabled code. + +Mon Mar 7 13:27:09 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * cccp.c (no_record_file): New variable. + (main): Set it for -imacros and -include files. + (do_endif): Don't call record_control_macro for -include or -imacros + files or files included from -imacros. + +Sun Mar 6 21:48:51 1994 Richard Stallman (rms@mole.gnu.ai.mit.edu) + + * config.sub: Accept freebsd as OS. + +Sun Mar 6 14:40:00 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * stupid.c: Add prototypes for static functions. + (last_{jump,label}_suid): Deleted; all uses deleted. + (reg_crosses_blocks): Likewise. + (stupid_life_analysis): Only allocate MAX_SUID entries + of after_insn_hard_regs. + Use GET_RTX_CLASS when possible. + Initialize all of reg_renumber. + Use reg_alternate_class when reg not available in preferred class. + (stupid_find_reg): Delete argument CROSSES_BLOCKS. + + * stupid.c (stupid_mark_refs): If setting reg_where_dead, set + regs_live so we don't later clobber it. + + * recog.c (constrain_operands): Properly handle '#' in constraint. + + * combine.c (subst): Split into five functions. + (simplify_{rtx,if_then_else,set,logical}): New functions. + +Sun Mar 6 13:12:48 1994 James Van Artsdalen (james at bigtex.cactus.org) + + * reg-stack.c (find_blocks): Undo previous change to block + delineation algorithm. + (reg_to_stack): Make algorithm identical to that in find_blocks. + +Sat Mar 5 16:27:58 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * genattrtab.c (attr_printf): Remove `register' from decl of FMT. + * tree.c (build_nt, build_parse_node): Remove `register' from decl + of CODE. + + * reload.c (get_secondary_mem): Call SECONDARY_MEMORY_NEEDED_MODE + if it is defined. + * alpha.h (SECONDARY_MEMORY_NEEDED_MODE): New macro. + * alpha.c (output_{pro,epi}log): Round var size to quadword boundary. + + * alpha.md (unaligned_{load,store}hi): Clear low bit of + address before using as operand to extwl, mskwl, and inswl. + (movhi, reload_inhi, reload_outhi): Pass extra scratch value. + +Fri Mar 4 17:16:23 1994 Leonard Norrgard (vinsci@nic.funet.fi) + + * c-lex.c: Delete gperf-generated source from here. + * c-gperf.h: New file; contains just gperf output. + * Makefile.in (c-gperf.h): New rule. + (c-lex.o): Depends on c-gperf.h. + (realclean): Delete c-gperf.h. + (distdir): Build c-gperf.h. + (diff): Omit differences in c-gperf.h. + +Fri Mar 4 06:35:26 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * svr4.h, m88k.h (ASM_FINISH_DECLARE_OBJECT): Set + size_directive_output to 1. + + * reload1.c (emit_reload_insns): Don't call gen_input_reload if + src and dest are identical. + +Thu Mar 3 15:32:55 1994 Richard Kenner (kenner@vlsi1.ultra.nyu.edu) + + * alpha.md (mskXl): Add missing NOT in patterns. + + * t-m88k: Remove added realclean rule. + +See ChangeLog.8 for earlier changes. |