1. 01 Apr, 2003 15 commits
    • real.h (EXP_BITS): Make room for... · fe0002ee
      * real.h (EXP_BITS): Make room for...
      (struct real_value): ... added canonical bit.
      (struct real_format): Added pnan.
      (mips_single_format, mips_double_format, mips_extended_format,
      mips_quad_format): New.
      * real.c: Copy p to pnan in all formats.
      (get_canonical_qnan, get_canonical_snan): Set canonical bit.
      (real_nan): Use pnan to compute significand's shift.
      (real_identical): Disregard significand in canonical
      NaNs.
      (real_hash): Likewise.  Take signalling into account.
      (encode_ieee_single, encode_ieee_double, encode_ieee_quad):
      Disregard significand bits in canonical NaNs.  Set all bits of
      canonical NaN if !qnan_msb_set.
      (encode_ibm_extended, decode_ibm_extended): Likewise.  Use
      qnan_msb_set to tell the base double format.
      (ibm_extended_format): Use 53 as pnan.
      (mips_single_format, mips_double_format, mips_extended_format,
      mips_quad_format): Copied from the corresponding ieee/ibm
      formats, with qnan_msb_set false.
      * config/mips/iris6.h (MIPS_TFMODE_FORMAT): Use mips_extended_format.
      * config/mips/linux64.h (MIPS_TFMODE_FORMAT): Use mips_quad_format.
      * config/mips/mips.c (override_options): Use mips_single_format
      and mips_double_format.  Default TFmode to mips_quad_format.
      * config/mips/t-linux64 (tp-bit.c): Define QUIET_NAN_NEGATED.
      * config/mips/t-irix6: Likewise.
      * config/mips/t-mips (fp-bit.c, dp-bit.c): Likewise.
      * config/fp-bit.c (pack_d, unpack_d): Obey it.
      
      From-SVN: r65146
      Alexandre Oliva committed
    • unwind-dw2-fde-darwin.c (DESTRUCTOR_MAY_BE_CALLED_LIVE): New. · 481a8181
      	* unwind-dw2-fde-darwin.c (DESTRUCTOR_MAY_BE_CALLED_LIVE): New.
      	(live_image_destructor): Reset image to initial state.
      	(examine_objects): Set DESTRUCTOR_MAY_BE_CALLED_LIVE.
      
      From-SVN: r65145
      Geoffrey Keating committed
    • sparc.c (input_operand): Accept bare CONSTANT_P_RTX operands. · 375ffbe6
      	* config/sparc/sparc.c (input_operand): Accept bare
      	CONSTANT_P_RTX operands.
      
      From-SVN: r65143
      Eric Botcazou committed
    • config-lang.in (gtfiles): add \$(srcdir)/cp/name-lookup.c after \$(srcdir)/cp/name-lookup.h. · 28ea4c88
      2003-04-01  Andrew Pinski  <pinskia@physics.uc.edu>
      
              * config-lang.in (gtfiles): add \$(srcdir)/cp/name-lookup.c
              after \$(srcdir)/cp/name-lookup.h.
              * name-lookup.c: (cxx_binding_make): Use ggc_alloc_clearedinstead
              of ggc_alloc.  Include gt-cp-name-lookup.h at the end of the file.
              * Make-lang.in: (gt-cp-name-lookup.h): is generated by the gtype.
              (cp/name-lookup.o): depends on gt-cp-name-lookup.h.
      
      From-SVN: r65142
      Andrew Pinski committed
    • gcse.c (struct ls_expr): Added pattern_regs field. · 47a3dae1
      	* gcse.c (struct ls_expr): Added pattern_regs field.
      	(ldst_entry): Initialize it.
      	(extract_mentioned_regs, extract_mentioned_regs_helper): New.
      	(store_ops_ok): Use regs precomputed by them.
      	(find_loads, store_killed_in_insn, load_kills_store): Change return
      	type to bool.
      	(store_killed_before, store_killed_after): Take position of register
      	set in account.
      	(reg_set_info): Store position of the setter.
      	(gcse_main): Enable store motion.
      	(mems_conflict_for_gcse_p): Enable load motion of non-symbol mems.
      	(pre_insert_copy_insn, update_ld_motion_stores, insert_store): Prevent rtl
      	sharing.
      	(simple_mem): Enable store motion of non-symbol mems.
      	(regvec): Type changed.
      	(LAST_AVAIL_CHECK_FAILURE): New.
      	(compute_store_table_current_insn): New.
      	(build_store_vectors): Computation of availability and anticipatability
      	moved ...
      	(compute_store_table, find_moveable_store): ... here.
      	(delete_store): Remove senseless comment.
      	(store_motion): Reorganize.
      
      From-SVN: r65141
      Zdenek Dvorak committed
    • Fix a typo in ChangeLog. · 63855aa6
      From-SVN: r65140
      Kazu Hirata committed
    • mips.c (override_options): Provide mappings for HI_REGNUM and LO_REGNUM. · 77d4f3a4
      	* config/mips/mips.c (override_options): Provide mappings for
      	HI_REGNUM and LO_REGNUM.
      	* config/mips/mips.h (MD_DBX_FIRST): Define.
      
      From-SVN: r65139
      Kevin Buettner committed
    • simd-1.C: New. · 705412b0
      2003-04-01  Aldy Hernandez  <aldyh@redhat.com>
      
              * g++.dg/eh/simd-1.C: New.
      
              * g++.dg/eh/simd-2.C: New.
      
      From-SVN: r65138
      Aldy Hernandez committed
    • combine.c (merge_outer_ops): Fix typo. · 7d4444ea
      	2003-04-01  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
      
      	* combine.c (merge_outer_ops): Fix typo.
      
      	* varasm.c (make_decl_one_only): Revert 2003-03-09 patch.
      
      From-SVN: r65136
      Franz Sirl committed
    • {40x.md,603.md,6xx.md,7450.md,7xx.md,mpc.md, [...]: Change mult_compare to imul_compare. · 9259f3b0
              * config/rs6000/{40x.md,603.md,6xx.md,7450.md,7xx.md,mpc.md,
              power4.md,rios1.md,rios2.md,rs64.md}: Change mult_compare to
              imul_compare.  Add lmul_compare.
              * config/rs6000/power4.md: Bump some latencies.  Model extra cycle
              in second pair of dispatch slots.  Model stores more accurately.
              Tweak multiply model.  Add bypasses for CR instructions dependent
              on complicated compares.
              * config/rs6000/rs6000.md (mulsi3): Name imul_compare patterns.
              (muldi3): Add lmul_compare patterns.
              * config/rs6000/rs6000.c (rs6000_variable_issue): Move FPLOAD_UX
              and FPSTORE_UX to split instructions and add COMPARE,
              DELAYED_COMPARE, IMUL_COMPARE, LMUL_COMPARE, IDIV, LDIV.
              (rs6000_adjust_cost): Add IMUL_COMPARE and LMUL_COMPARE.
              (rs6000_rtx_costs): Separate POWER4 multiply case.
      
      From-SVN: r65135
      David Edelsohn committed
    • s390.c (s390_fixup_clobbered_return_reg): Do nothing if __builtin_return_address was not used. · 7fe317e4
      	* config/s390/s390.c (s390_fixup_clobbered_return_reg):
      	Do nothing if __builtin_return_address was not used.
      
      From-SVN: r65133
      Ulrich Weigand committed
    • * i386.md (test patterns): Allow memory operand in operand1. · e1fea6ee
      From-SVN: r65132
      Jan Hubicka committed
    • simd-3.c: New. · d744e06e
              * testsuite/gcc.c-torture/execute/simd-3.c: New.
      
              * expr.c (expand_expr): Handle VECTOR_CST.
              (const_vector_from_tree): New.
      
              * varasm.c (output_constant): Handle VECTOR_CST.
      
              * c-typeck.c (digest_init): Build a vector constant from a
              VECTOR_TYPE.
      
              * config/rs6000/rs6000.c: Remove prototype for
              easy_vector_constant.
              (easy_vector_constant): Add mode parameter.  Rewrite to handle
              more easy constants.
              (rs6000_emit_move): Pass mode to easy_vector_constant.
              Call emit_easy_vector_insn for SPE V2SI vector constant moves.
              (emit_easy_vector_insn): New.
              (easy_vector_same): New.
              (EASY_VECTOR_15): New macro.
              (EASY_VECTOR_15_ADD_SELF): New macro.
              (bdesc_2arg): Rename to xorv2si3.
              (easy_vector_constant_add_self): New.
              (input_operand): Allow vector constants.
      
              * config/rs6000/rs6000.h (PREDICATE_CODES): Add
              easy_vector_constant, easy_vector_constant_add_self.
              (EXTRA_CONSTRAINT): Add 'W'.
      
              * config/rs6000/rs6000-protos.h: Add prototype for
              easy_vector_constant, emit_easy_vector_insn.
      
              * config/rs6000/altivec.md (xorv8hi3): New.
              (xorv16qi3): New.
              Remove all _const0 patterns.
              (movv4si_internal): Rewrite to use code.  Add vector constant to
              vector alternative.  Add splitter.
              (movv8hi_internal): Same.
              (movv16qi_internal): Same.
              (movv4sf_internal): Same.
              Change the unspecs for vspltis* to use constants.
      
              * config/rs6000/spe.md ("xorv4hi3"): New.
              ("spe_evxor"): Rename to xorv2si3.
              ("xorv1di3"): New.
              Remove all _const0 patterns.
              (movv2si_internal): Rewrite to use code.  Add vector constant to
              alternatives.  Add splitter.
              (movv4hi_internal): Add vector constant to alternatives.
              (movv1di_internal): Same.
              (movv2sf_internal): Same.
      
      From-SVN: r65130
      Aldy Hernandez committed
    • re PR middle-end/9936 (ICE with local function and variable-length 2d array) · 46e33d43
      	PR c/9936
      	* c-decl.c (grokdeclarator): Clear SAVE_EXPR_CONTEXT for
      	variably-sized arrays in parameters.
      	(set_save_expr_context): New function.
      	(c_expand_body): Use it, via walk_tree.
      
      	PR c/9936
      	* gcc.dg/20030331-2.c: New test.
      
      From-SVN: r65128
      Mark Mitchell committed
    • Daily bump. · 6fa91a1d
      From-SVN: r65125
      GCC Administrator committed
  2. 31 Mar, 2003 25 commits