1. 04 Jul, 2002 3 commits
  2. 03 Jul, 2002 16 commits
    • mangle6.C: Run for mipsisa64*-*-* targets. · a6a5beb1
      2002-07-03  Chris Demetriou  <cgd@broadcom.com>
      
              * g++.dg/abi/mangle6.C: Run for mipsisa64*-*-* targets.
              * gcc.dg/20020620-1.c: Likewise.
      
      From-SVN: r55228
      Chris Demetriou committed
    • * configure.in: Make --without-x work. · 423ce3eb
      From-SVN: r55226
      Nathanael Nerode committed
    • re PR libstdc++/3946 (auto_ptr_ref constructor allows dangerous conversion) · 16ad69a1
      2002-07-03  Jack Reeves  <jackw_reeves@hotmail.com>
                  Kenny Simpson  <theonetruekenny@yahoo.com>
                  Phil Edwards  <pme@gcc.gnu.org>
      
      	PR libstdc++/3946
      	* testsuite/20_util/auto_ptr.cc (test08):  New test.
      	* include/std/std_memory.h (auto_ref_ptr):  Make constructor explicit.
      	(auto_ptr::operator auto_ptr_ref):  Fix typo.
      	General reformatting and doxygenating of the whole file.
      
      Co-Authored-By: Kenny Simpson <theonetruekenny@yahoo.com>
      Co-Authored-By: Phil Edwards <pme@gcc.gnu.org>
      
      From-SVN: r55223
      Jack Reeves committed
    • darwin.h (APPLE_CC): Remove, not meaningful in FSF GCC. · 6f0361e3
              * config/darwin.h (APPLE_CC): Remove, not meaningful in FSF GCC.
              (STRINGIFY_THIS, REALLY_STRINGIFY): Remove.
              (CPP_SPEC): Remove insertion of APPLE_CC definition.
      
      From-SVN: r55222
      Stan Shebs committed
    • combine.c (struct_undo): Change types of recorded substitutions to be either "int" or "rtx"... · 3129af4c
      
      	* combine.c (struct_undo): Change types of recorded substitutions
      	to be either "int" or "rtx", instead of "unsigned int" and "rtx".
      	(do_SUBST_INT): Change types of the substitution from unsigned int
      	to int, to avoid compilation warning from SUBST_INT's only caller.
      
      	(make_extraction): Add cast to avoid compilation warning.
      	(force_to_mode): Remove cast to avoid compilation warning.
      
      From-SVN: r55221
      Roger Sayle committed
    • re PR libstdc++/7097 (_GLIBCPP_HAVE_MBSTATE_T breaks non-GLIB systems) · fcad420e
      
      2002-07-03  Benjamin Kosnik  <bkoz@redhat.com>
      
      	PR libstdc++/7097
      	* include/c/std_cwchar.h: Fix.
      
      From-SVN: r55216
      Benjamin Kosnik committed
    • i386.md (length_immediate attribute): Fix typo. · c7375e61
              * i386.md (length_immediate attribute): Fix typo.
              (length_address attribute): Likewise.
              (modrm attribute): Set it to 0 for immediate call instructions.
              (jcc_1 pattern): Set modrm attribute to 0.
              (jcc_2 pattern ): Likewise.
              (jump pattern): Likewise.
              (doloop_end_internal pattern): Explicitly set length.
              (leave pattern): Fix typo.
              (leave_rex64 pattern): Likewise.
      
      Co-Authored-By: Jeff Law <law@redhat.com>
      
      From-SVN: r55215
      Eric Botcazou committed
    • re PR c++/6944 (missing feature on default copy-constructor for class with multi-dim arrays) · b2153b98
      	PR c++/6944
      	* init.c (build_aggr_init): Remove qualifiers of init before calling
      	build_vec_init.
      	(build_vec_init): Flatten multi-dimensional array during cleanup.
      	(build_vec_delete_1): Abort if the type of each element is array.
      
      	* g++.dg/init/array4.C: New test.
      	* g++.dg/init/array5.C: New test.
      
      From-SVN: r55214
      Kriang Lerdsuwanakij committed
    • rs6000.md (fix_truncdfsi2_internal): Ignore DImode in FPR as preference. · 61c07d3c
              * config/rs6000/rs6000.md (fix_truncdfsi2_internal): Ignore DImode
              in FPR as preference.
              (fctiwz): Same.
              (floatdidf2, fix_truncdfdi2): Same.
              (floatdisf2, floatditf2, fix_trunctfdi2): Same.
              (floatditf2): Same.
              (floatsitf2, fix_trunctfsi2): SImode in GPR.
              (ctrdi): Remove FPR alternative and splitter.
      
      From-SVN: r55212
      David Edelsohn committed
    • i386.c (x86_integer_DFmode_moves): Disable for PPro. · 77966be3
      2002-07-02  Will Cohen <wcohen@redhat.com>
      
      	* config/i386/i386.c (x86_integer_DFmode_moves): Disable for PPro.
      
      From-SVN: r55211
      Will Cohen committed
    • * pt.c (instantiate_class_template): Fix typo. · 492ff760
      From-SVN: r55210
      Graham Stott committed
    • optabs.c (expand_vector_binop): Don't store using a SUBREG smaller than UNITS_PER_WORD... · 34a80643
      gcc:
      	* optabs.c (expand_vector_binop): Don't store using a SUBREG smaller
      	than UNITS_PER_WORD, unless this is little endian and the first unit
      	in this word.  Let extract_bit_field decide how to load an element.
      	Force arguments to matching mode.
      	(expand_vector_unop): Likewise.
      
      	* simplify-rtx.c (simplify_subreg): Don't assume that all vectors
      	consist of word_mode elements.
      	* c-typeck.c (build_binary_op): Allow vector types for BIT_AND_EXPR,
      	BIT_ANDTC_EXPR, BIT_IOR_EXPR and BIT_XOR_EXPR.
      	(build_unary_op): Allow vector types for BIT_NOT_EPR.
      	* emit-rtl.c (gen_lowpart_common): Use simplify_gen_subreg for
      	CONST_VECTOR.
      	* optabs.c (expand_vector_binop): Try to perform operation in
      	smaller vector modes with same inner size.  Add handling of AND, IOR
      	and XOR.  Reject expansion to inner-mode sized scalars when using
      	OPTAB_DIRECT.  Use simplify_gen_subreg on constants.
      	(expand_vector_unop): Try to perform operation in smaller vector
      	modes with same inner size.  Add handling of one's complement.
      	When there is no vector negate operation, try a vector subtract
      	operation.  Use simplify_gen_subreg on constants.
      	* simplify-rtx.c (simplify_subreg): Add capability to convert vector
      	constants into smaller vectors with same inner mode, and to
      	integer CONST_DOUBLEs.
      
      gcc/testsuite:
      	* gcc.c-torture/execute/simd-1.c (main): Also test &, |, ^, ~.
      	* gcc.c-torture/execute/simd-2.c (main): Likewise.
      
      From-SVN: r55209
      J"orn Rennecke committed
    • Daily bump. · 032b2b29
      From-SVN: r55208
      GCC Administrator committed
    • re PR libstdc++/6410 (Trouble with non-Ascii monetary symbols and wchar_t) · fdf7e809
      
      2002-07-02  Benjamin Kosnik  <bkoz@redhat.com>
      
      	PR libstdc++/6410
      	* include/bits/locale_facets.h (moneypunct::moneypunct): Add const
      	char* name parameter.
      	* config/locale/gnu/monetary_members.cc: Use it.
      	* config/locale/generic/monetary_members.cc: Same.
      	* src/localename.cc (_Impl::_Impl(const char*, size_t)): Use it.
      
      	* include/backward/strstream.h: Update date.
      
      From-SVN: r55203
      Benjamin Kosnik committed
    • c-parse.in (parsing_iso_function_signature): New variable. · 622d3731
      gcc:
      	* c-parse.in (parsing_iso_function_signature): New variable.
      	(extdef_1): New, copied from...
      	(extdef): ... here.  Reset parsing_iso_function_signature.
      	(old_style_parm_decls):  Reset parsing_iso_function_signature.
      	(old_style_parm_decls_1): New, copied from old_style_parm_decls.
      	Warn about ISO C style function definitions.
      	(nested_function, notype_nested_function): Reset
      	parsing_iso_function_signature.
      	(parmlist_2): Set parsing_iso_function_signature.
      
      	* doc/invoke.texi (-Wtraditional): Document new behavior.
      
      gcc/testsuite:
      	* gcc.dg/cpp/tr-warn2.c: Use traditional C style function definitions.
      	* gcc.dg/wtr-aggr-init-1.c: Likewise.
      	* gcc.dg/wtr-conversion-1.c: Likewise.
      	* gcc.dg/wtr-escape-1.c: Likewise.
      	* gcc.dg/wtr-int-type-1.c: Likewise.
      	* gcc.dg/wtr-label-1.c: Likewise.
      	* gcc.dg/wtr-static-1.c: Likewise.
      	* gcc.dg/wtr-strcat-1.c: Likewise.
      	* gcc.dg/wtr-suffix-1.c: Likewise.
      	* gcc.dg/wtr-switch-1.c: Likewise.
      	* gcc.dg/wtr-unary-plus-1.c: Likewise.
      	* gcc.dg/wtr-union-init-1.c: Likewise.
      	* gcc.dg/wtr-union-init-2.c: Likewise.
      	* gcc.dg/wtr-union-init-3.c: Likewise.
      
      	* gcc.dg/wtr-func-def-1.c: New test.
      
      From-SVN: r55201
      Kaveh R. Ghazi committed
  3. 02 Jul, 2002 21 commits
    • config.gcc (mips*el-*-*): Use tm_defines to set TARGET_ENDIAN_DEFAULT, rather… · 9bb46191
      config.gcc (mips*el-*-*): Use tm_defines to set TARGET_ENDIAN_DEFAULT, rather than including mips/little.h.
      
      2002-07-02  Chris Demetriou  <cgd@broadcom.com>
      
              * config.gcc (mips*el-*-*): Use tm_defines to set
              TARGET_ENDIAN_DEFAULT, rather than including mips/little.h.
              * config/mips/little.h: Remove.
      
      From-SVN: r55200
      Chris Demetriou committed
    • further fix formatting of previous ChangeLog entry · 31e25abd
      From-SVN: r55199
      Chris Demetriou committed
    • fix formatting of previous ChangeLog entry · e1c2dd26
      From-SVN: r55198
      Chris Demetriou committed
    • objc-act.c (adjust_type_for_id_default): Do not allow an object as parameter. · c40da518
      
            * objc/objc-act.c (adjust_type_for_id_default): Do not allow an
              object as parameter. Prevent something like 'NSObject' to be
              used as the type for a method argument.
      
            testsuite:
            * objc.dg/param-1.m: New test.
      
      From-SVN: r55197
      Devang Patel committed
    • cpptrad.c: Update comment. · 0879540b
      	* cpptrad.c: Update comment.
      testsuite:
      	* gcc.dg/cpp/trad/directive.c: Add test.
      	* gcc.dg/cpp/trad/macroargs.c: Add test.
      	* gcc.dg/cpp/trad/recurse-3.c: Add tests.
      
      From-SVN: r55196
      Neil Booth committed
    • cppinit.c (cpp_handle_option): Suppress warnings with an implicit "-w" for "-M" and "-MM". · ba57a9c0
      	* cppinit.c (cpp_handle_option):  Suppress warnings with an
      	implicit "-w" for "-M" and "-MM".
      
      From-SVN: r55195
      Neil Booth committed
    • cpp.texi: Update for traditional preprocessing changes. · b6fb43ab
      	* doc/cpp.texi: Update for traditional preprocessing changes.
      	* goc/cppopts.texi: Similarly.
      
      From-SVN: r55194
      Neil Booth committed
    • * Forgotten to apply. · c680d2b6
      From-SVN: r55193
      Neil Booth committed
    • c-parse.in (designator): Enable designated initializers if ObjC. · c1c5187c
      2002-07-02  Ziemowit Laski  <zlaski@apple.com>
      
      	* c-parse.in (designator): Enable designated initializers if ObjC.
      	(objcmessageexpr): Remove references to objc_receiver_context.
      	* objc/objc-act.h (objc_receiver_context): Remove decl.
      	* objc/objc-act.c (objc_receiver_context): Remove.
      	(lookup_objc_ivar): Test objc_method_context instead of
      	objc_receiver_context.
      
      2002-07-02  Ziemowit Laski  <zlaski@apple.com>
      
      	* objc.dg/desig-init-1.m: New test.
      
      From-SVN: r55192
      Ziemowit Laski committed
    • 2002-07-02 Tom Tromey <tromey@redhat.com> · aa5661e6
                  David Hovemeyer  <daveho@cs.umd.edu>
      
      	* java/text/ChoiceFormat.java
      	(format(double,StringBuffer,FieldPosition)): Fix fencepost error
      	in check loop.
      	* java/text/MessageFormat.java
      	(format(Object[],StringBuffer,FieldPosition): Pass all arguments
      	to MessageFormat.
      
      Co-Authored-By: David Hovemeyer <daveho@cs.umd.edu>
      
      From-SVN: r55191
      Tom Tromey committed
    • encoding.h: Fix formatting. · 40165636
      2002-07-02  Rodney Brown  <rbrown64@csc.com.au>
      
      	* objc/encoding.h: Fix formatting.
      	* objc/hash.h: Likewise.
      	* objc/objc-api.h: Likewise.
      	* objc/runtime.h: Likewise.
      	* objc/thr.h: Likewise.
      	* archive.c: Likewise.
      	* class.c: Likewise.
      	* encoding.c: Likewise.
      	* gc.c: Likewise.
      	* hash.c: Likewise.
      	* init.c: Likewise.
      	* misc.c: Likewise.
      	* nil_method.c: Likewise.
      	* objects.c: Likewise.
      	* sarray.c: Likewise.
      	* selector.c: Likewise.
      	* sendmsg.c: Likewise.
      	* thr-mach.c: Likewise.
      	* thr.c: Likewise.
      
      From-SVN: r55190
      Rodney Brown committed
    • sh.c (print_operand, case 'N'): Allow zero vector. · 52702ae1
      Tue Jul  2 18:45:45 2002  J"orn Rennecke <joern.rennecke@superh.com>
      
      	* sh.c (print_operand, case 'N'): Allow zero vector.
      	(arith_reg_or_0_operand): Likewise.
      	(zero_vec_operand): Check for CONST_VECTOR, not PARALLEL.
      	* sh.h (CONST_COSTS): 0 has 0 cost.  Check OUTER_CODE for
      	IOR, XOR, PLUS and SET and take their respective constant
      	ranges into account.
      	(PREDICATE_CODES, arith_reg_or_0_operand): Can be CONST_VECTOR.
      	* sh.md (subdi3, subdi3_media): Allow zero operand.
      	(movv8qi_i+3): Only vector that is not split is the zero vector.
      	Fix operand 3 to simplify_subreg.
      	(movv2si_i): Split alternative 1.
      	(mshfhi_l_di_rev+1): New splitter.
      
      Index: config/sh/sh.c
      ===================================================================
      RCS file: /cvs/gcc/gcc/gcc/config/sh/sh.c,v
      retrieving revision 1.155
      diff -p -r1.155 sh.c
      *** config/sh/sh.c	2 Jul 2002 04:01:04 -0000	1.155
      --- config/sh/sh.c	2 Jul 2002 17:45:37 -0000
      *************** print_operand (stream, x, code)
      *** 434,440 ****
              break;
      
            case 'N':
      !       if (x == const0_rtx)
        	{
        	  fprintf ((stream), "r63");
        	  break;
      --- 434,441 ----
              break;
      
            case 'N':
      !       if (x == const0_rtx
      ! 	  || (GET_CODE (x) == CONST_VECTOR && zero_vec_operand (x, VOIDmode)))
        	{
        	  fprintf ((stream), "r63");
        	  break;
      *************** arith_reg_or_0_operand (op, mode)
      *** 5940,5946 ****
          if (arith_reg_operand (op, mode))
            return 1;
      
      !   if (GET_CODE (op) == CONST_INT && CONST_OK_FOR_N (INTVAL (op)))
            return 1;
      
          return 0;
      --- 5941,5947 ----
          if (arith_reg_operand (op, mode))
            return 1;
      
      !   if (EXTRA_CONSTRAINT_U (op))
            return 1;
      
          return 0;
      *************** zero_vec_operand (v, mode)
      *** 6222,6228 ****
        {
          int i;
      
      !   if (GET_CODE (v) != PARALLEL
              || (GET_MODE (v) != mode && mode != VOIDmode))
            return 0;
          for (i = XVECLEN (v, 0) - 1; i >= 0; i--)
      --- 6223,6229 ----
        {
          int i;
      
      !   if (GET_CODE (v) != CONST_VECTOR
              || (GET_MODE (v) != mode && mode != VOIDmode))
            return 0;
          for (i = XVECLEN (v, 0) - 1; i >= 0; i--)
      Index: config/sh/sh.h
      ===================================================================
      RCS file: /cvs/gcc/gcc/gcc/config/sh/sh.h,v
      retrieving revision 1.154
      diff -p -r1.154 sh.h
      *** config/sh/sh.h	1 Jul 2002 19:41:53 -0000	1.154
      --- config/sh/sh.h	2 Jul 2002 17:45:37 -0000
      *************** while (0)
      *** 2689,2698 ****
          case CONST_INT:				\
            if (TARGET_SHMEDIA)				\
              {						\
        	if ((OUTER_CODE) == AND && and_operand ((RTX), DImode)) \
        	  return 0;				\
        	if (CONST_OK_FOR_J (INTVAL (RTX)))	\
      !           return COSTS_N_INSNS (1);		\
        	else if (CONST_OK_FOR_J (INTVAL (RTX) >> 16)) \
        	  return COSTS_N_INSNS (2);		\
        	else if (CONST_OK_FOR_J ((INTVAL (RTX) >> 16) >> 16)) \
      --- 2689,2704 ----
          case CONST_INT:				\
            if (TARGET_SHMEDIA)				\
              {						\
      + 	if (INTVAL (RTX) == 0)			\
      + 	  return 0;				\
        	if ((OUTER_CODE) == AND && and_operand ((RTX), DImode)) \
        	  return 0;				\
      + 	if (((OUTER_CODE) == IOR || (OUTER_CODE) == XOR \
      + 	     || (OUTER_CODE) == PLUS) \
      + 	    && CONST_OK_FOR_P (INTVAL (RTX)))	\
      + 	  return 0;				\
        	if (CONST_OK_FOR_J (INTVAL (RTX)))	\
      !           return COSTS_N_INSNS ((OUTER_CODE) != SET);		\
        	else if (CONST_OK_FOR_J (INTVAL (RTX) >> 16)) \
        	  return COSTS_N_INSNS (2);		\
        	else if (CONST_OK_FOR_J ((INTVAL (RTX) >> 16) >> 16)) \
      *************** extern int rtx_equal_function_value_matt
      *** 3225,3231 ****
          {"arith_operand", {SUBREG, REG, CONST_INT}},				\
          {"arith_reg_dest", {SUBREG, REG}},					\
          {"arith_reg_operand", {SUBREG, REG}},					\
      !   {"arith_reg_or_0_operand", {SUBREG, REG, CONST_INT}},			\
          {"binary_float_operator", {PLUS, MULT}},				\
          {"commutative_float_operator", {PLUS, MULT}},				\
          {"extend_reg_operand", {SUBREG, REG, TRUNCATE}},			\
      --- 3231,3237 ----
          {"arith_operand", {SUBREG, REG, CONST_INT}},				\
          {"arith_reg_dest", {SUBREG, REG}},					\
          {"arith_reg_operand", {SUBREG, REG}},					\
      !   {"arith_reg_or_0_operand", {SUBREG, REG, CONST_INT, CONST_VECTOR}},	\
          {"binary_float_operator", {PLUS, MULT}},				\
          {"commutative_float_operator", {PLUS, MULT}},				\
          {"extend_reg_operand", {SUBREG, REG, TRUNCATE}},			\
      Index: config/sh/sh.md
      ===================================================================
      RCS file: /cvs/gcc/gcc/gcc/config/sh/sh.md,v
      retrieving revision 1.107
      diff -p -r1.107 sh.md
      *** config/sh/sh.md	1 Jul 2002 19:41:54 -0000	1.107
      --- config/sh/sh.md	2 Jul 2002 17:45:38 -0000
      ***************
      *** 546,552 ****
        ;; There is no way to model this with gcc's function units.  This problem is
        ;; actually mentioned in md.texi.  Tackling this problem requires first that
        ;; it is possible to speak about the target in an open discussion.
      ! ;;
        ;; However, simple double-precision operations always conflict.
      
        (define_function_unit "fp"    1 0
      --- 546,552 ----
        ;; There is no way to model this with gcc's function units.  This problem is
        ;; actually mentioned in md.texi.  Tackling this problem requires first that
        ;; it is possible to speak about the target in an open discussion.
      ! ;;
        ;; However, simple double-precision operations always conflict.
      
        (define_function_unit "fp"    1 0
      ***************
      *** 1048,1054 ****
          "@
        	addz.l	%1, %2, %0
        	addz.l	%1, r63, %0")
      !
        (define_insn "adddi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(plus:DI (match_operand:DI 1 "arith_reg_operand" "%0")
      --- 1048,1054 ----
          "@
        	addz.l	%1, %2, %0
        	addz.l	%1, r63, %0")
      !
        (define_insn "adddi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(plus:DI (match_operand:DI 1 "arith_reg_operand" "%0")
      ***************
      *** 1122,1128 ****
          "@
        	add.l	%1, %2, %0
        	addi.l	%1, %2, %0")
      !
        (define_insn "*addsi3_compact"
          [(set (match_operand:SI 0 "arith_reg_operand" "=r")
        	(plus:SI (match_operand:SI 1 "arith_operand" "%0")
      --- 1122,1128 ----
          "@
        	add.l	%1, %2, %0
        	addi.l	%1, %2, %0")
      !
        (define_insn "*addsi3_compact"
          [(set (match_operand:SI 0 "arith_reg_operand" "=r")
        	(plus:SI (match_operand:SI 1 "arith_operand" "%0")
      ***************
      *** 1138,1162 ****
      
        (define_expand "subdi3"
          [(set (match_operand:DI 0 "arith_reg_operand" "")
      ! 	(minus:DI (match_operand:DI 1 "arith_reg_operand" "")
        		  (match_operand:DI 2 "arith_reg_operand" "")))]
          ""
          "
        {
          if (TARGET_SH1)
            {
              emit_insn (gen_subdi3_compact (operands[0], operands[1], operands[2]));
              DONE;
            }
        }")
      !
        (define_insn "*subdi3_media"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
      ! 	(minus:DI (match_operand:DI 1 "arith_reg_operand" "r")
        		  (match_operand:DI 2 "arith_reg_operand" "r")))]
          "TARGET_SHMEDIA"
      !   "sub	%1, %2, %0")
      !
        (define_insn "subdi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(minus:DI (match_operand:DI 1 "arith_reg_operand" "0")
      --- 1138,1163 ----
      
        (define_expand "subdi3"
          [(set (match_operand:DI 0 "arith_reg_operand" "")
      ! 	(minus:DI (match_operand:DI 1 "arith_reg_or_0_operand" "")
        		  (match_operand:DI 2 "arith_reg_operand" "")))]
          ""
          "
        {
          if (TARGET_SH1)
            {
      +       operands[1] = force_reg (DImode, operands[1]);
              emit_insn (gen_subdi3_compact (operands[0], operands[1], operands[2]));
              DONE;
            }
        }")
      !
        (define_insn "*subdi3_media"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
      ! 	(minus:DI (match_operand:DI 1 "arith_reg_or_0_operand" "rN")
        		  (match_operand:DI 2 "arith_reg_operand" "r")))]
          "TARGET_SHMEDIA"
      !   "sub	%N1, %2, %0")
      !
        (define_insn "subdi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(minus:DI (match_operand:DI 1 "arith_reg_operand" "0")
      ***************
      *** 1558,1564 ****
        					   : \"__sdivsi3\")));
      
              if (TARGET_SHMEDIA)
      ! 	last = gen_divsi3_i1_media (operands[0],
        				    Pmode == DImode
        				    ? operands[3]
        				    : gen_rtx_SUBREG (DImode, operands[3],
      --- 1559,1565 ----
        					   : \"__sdivsi3\")));
      
              if (TARGET_SHMEDIA)
      ! 	last = gen_divsi3_i1_media (operands[0],
        				    Pmode == DImode
        				    ? operands[3]
        				    : gen_rtx_SUBREG (DImode, operands[3],
      ***************
      *** 1771,1777 ****
        		 (sign_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
          "TARGET_SHMEDIA"
          "muls.l	%1, %2, %0")
      !
        (define_insn "mulsidi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(mult:DI
      --- 1772,1778 ----
        		 (sign_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
          "TARGET_SHMEDIA"
          "muls.l	%1, %2, %0")
      !
        (define_insn "mulsidi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(mult:DI
      ***************
      *** 1841,1847 ****
        		 (zero_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
          "TARGET_SHMEDIA"
          "mulu.l	%1, %2, %0")
      !
        (define_insn "umulsidi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(mult:DI
      --- 1842,1848 ----
        		 (zero_extend:DI (match_operand:SI 2 "arith_reg_operand" "r"))))]
          "TARGET_SHMEDIA"
          "mulu.l	%1, %2, %0")
      !
        (define_insn "umulsidi3_compact"
          [(set (match_operand:DI 0 "arith_reg_operand" "=r")
        	(mult:DI
      ***************
      *** 3440,3446 ****
           (set_attr "type" "pcload,move,load,store,move,pcload,move,move")])
      
        ;; If the output is a register and the input is memory or a register, we have
      ! ;; to be careful and see which word needs to be loaded first.
      
        (define_split
          [(set (match_operand:DI 0 "general_movdst_operand" "")
      --- 3441,3447 ----
           (set_attr "type" "pcload,move,load,store,move,pcload,move,move")])
      
        ;; If the output is a register and the input is memory or a register, we have
      ! ;; to be careful and see which word needs to be loaded first.
      
        (define_split
          [(set (match_operand:DI 0 "general_movdst_operand" "")
      ***************
      *** 4195,4201 ****
        }")
      
        ;; If the output is a register and the input is memory or a register, we have
      ! ;; to be careful and see which word needs to be loaded first.
      
        (define_split
          [(set (match_operand:DF 0 "general_movdst_operand" "")
      --- 4196,4202 ----
        }")
      
        ;; If the output is a register and the input is memory or a register, we have
      ! ;; to be careful and see which word needs to be loaded first.
      
        (define_split
          [(set (match_operand:DF 0 "general_movdst_operand" "")
      ***************
      *** 4392,4398 ****
          DONE;
        }"
          [(set_attr "length" "8")])
      !
        (define_expand "movv4sf"
          [(set (match_operand:V4SF 0 "nonimmediate_operand" "=f,f,m")
        	(match_operand:V4SF 1 "nonimmediate_operand" "f,m,f"))]
      --- 4393,4399 ----
          DONE;
        }"
          [(set_attr "length" "8")])
      !
        (define_expand "movv4sf"
          [(set (match_operand:V4SF 0 "nonimmediate_operand" "=f,f,m")
        	(match_operand:V4SF 1 "nonimmediate_operand" "f,m,f"))]
      ***************
      *** 4444,4450 ****
          DONE;
        }"
          [(set_attr "length" "32")])
      !
        (define_expand "movv16sf"
          [(set (match_operand:V16SF 0 "nonimmediate_operand" "=f,f,m")
        	(match_operand:V16SF 1 "nonimmediate_operand" "f,m,f"))]
      --- 4445,4451 ----
          DONE;
        }"
          [(set_attr "length" "32")])
      !
        (define_expand "movv16sf"
          [(set (match_operand:V16SF 0 "nonimmediate_operand" "=f,f,m")
        	(match_operand:V16SF 1 "nonimmediate_operand" "f,m,f"))]
      ***************
      *** 4499,4505 ****
          REAL_VALUE_FROM_CONST_DOUBLE (value, operands[1]);
          REAL_VALUE_TO_TARGET_SINGLE (value, values);
          operands[2] = GEN_INT (values);
      !
          operands[3] = gen_rtx_REG (DImode, true_regnum (operands[0]));
        }")
      
      --- 4500,4506 ----
          REAL_VALUE_FROM_CONST_DOUBLE (value, operands[1]);
          REAL_VALUE_TO_TARGET_SINGLE (value, values);
          operands[2] = GEN_INT (values);
      !
          operands[3] = gen_rtx_REG (DImode, true_regnum (operands[0]));
        }")
      
      ***************
      *** 5410,5416 ****
        	  if (! SYMBOL_REF_FLAG (operands[0]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      emit_insn (gen_symGOTPLT2reg (reg, operands[0]));
        	      operands[0] = reg;
        	    }
      --- 5411,5417 ----
        	  if (! SYMBOL_REF_FLAG (operands[0]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      emit_insn (gen_symGOTPLT2reg (reg, operands[0]));
        	      operands[0] = reg;
        	    }
      ***************
      *** 5634,5640 ****
        	  if (! SYMBOL_REF_FLAG (operands[1]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      emit_insn (gen_symGOTPLT2reg (reg, operands[1]));
        	      operands[1] = reg;
        	    }
      --- 5635,5641 ----
        	  if (! SYMBOL_REF_FLAG (operands[1]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      emit_insn (gen_symGOTPLT2reg (reg, operands[1]));
        	      operands[1] = reg;
        	    }
      ***************
      *** 5841,5847 ****
        	  if (! SYMBOL_REF_FLAG (operands[0]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      /* We must not use GOTPLT for sibcalls, because PIC_REG
        		 must be restored before the PLT code gets to run.  */
        	      emit_insn (gen_symGOT2reg (reg, operands[0]));
      --- 5842,5848 ----
        	  if (! SYMBOL_REF_FLAG (operands[0]))
        	    {
        	      rtx reg = gen_reg_rtx (Pmode);
      !
        	      /* We must not use GOTPLT for sibcalls, because PIC_REG
        		 must be restored before the PLT code gets to run.  */
        	      emit_insn (gen_symGOT2reg (reg, operands[0]));
      ***************
      *** 6167,6173 ****
           (use (label_ref (match_operand 1 "" "")))]
          "TARGET_SHMEDIA"
          "blink	%0, r63")
      !
        ;; Call subroutine returning any type.
        ;; ??? This probably doesn't work.
      
      --- 6168,6174 ----
           (use (label_ref (match_operand 1 "" "")))]
          "TARGET_SHMEDIA"
          "blink	%0, r63")
      !
        ;; Call subroutine returning any type.
        ;; ??? This probably doesn't work.
      
      ***************
      *** 6284,6290 ****
        	tr = gen_rtx_SUBREG (GET_MODE (operands[0]), tr, 0);
      
              insn = emit_move_insn (operands[0], tr);
      !
              REG_NOTES (insn) = gen_rtx_EXPR_LIST (REG_EQUAL, equiv,
        					    REG_NOTES (insn));
      
      --- 6285,6291 ----
        	tr = gen_rtx_SUBREG (GET_MODE (operands[0]), tr, 0);
      
              insn = emit_move_insn (operands[0], tr);
      !
              REG_NOTES (insn) = gen_rtx_EXPR_LIST (REG_EQUAL, equiv,
        					    REG_NOTES (insn));
      
      ***************
      *** 6370,6379 ****
          if (TARGET_SHMEDIA)
            {
              rtx reg = operands[2];
      !
              if (GET_MODE (reg) != DImode)
        	reg = gen_rtx_SUBREG (DImode, reg, 0);
      !
              if (flag_pic > 1)
        	emit_insn (gen_movdi_const_32bit (reg, operands[1]));
              else
      --- 6371,6380 ----
          if (TARGET_SHMEDIA)
            {
              rtx reg = operands[2];
      !
              if (GET_MODE (reg) != DImode)
        	reg = gen_rtx_SUBREG (DImode, reg, 0);
      !
              if (flag_pic > 1)
        	emit_insn (gen_movdi_const_32bit (reg, operands[1]));
              else
      ***************
      *** 6391,6397 ****
          REG_NOTES (insn) = gen_rtx_EXPR_LIST (REG_EQUAL, XVECEXP (XEXP (operands[1],
        								  0), 0, 0),
        					REG_NOTES (insn));
      !
          DONE;
        }")
      
      --- 6392,6398 ----
          REG_NOTES (insn) = gen_rtx_EXPR_LIST (REG_EQUAL, XVECEXP (XEXP (operands[1],
        								  0), 0, 0),
        					REG_NOTES (insn));
      !
          DONE;
        }")
      
      ***************
      *** 7231,7237 ****
        				    (match_dup 2))))
        	      (set (reg:SI T_REG)
        		   (ne:SI (ior:SI (match_dup 1) (match_dup 2))
      ! 			  (const_int 0)))])]
          ""
          "
        {
      --- 7232,7238 ----
        				    (match_dup 2))))
        	      (set (reg:SI T_REG)
        		   (ne:SI (ior:SI (match_dup 1) (match_dup 2))
      ! 			  (const_int 0)))])]
          ""
          "
        {
      ***************
      *** 7282,7288 ****
        				    (match_dup 2))))
        	      (set (reg:SI T_REG)
        		   (ne:SI (ior:SI (match_operand 1 "" "") (match_dup 2))
      ! 			  (const_int 0)))])]
          "TARGET_SH1"
          "operands[2] = gen_reg_rtx (SImode);")
      
      --- 7283,7289 ----
        				    (match_dup 2))))
        	      (set (reg:SI T_REG)
        		   (ne:SI (ior:SI (match_operand 1 "" "") (match_dup 2))
      ! 			  (const_int 0)))])]
          "TARGET_SH1"
          "operands[2] = gen_reg_rtx (SImode);")
      
      ***************
      *** 8279,8285 ****
        ;;   "#"
        ;;   [(set_attr "length" "4")
        ;;    (set_attr "fp_mode" "double")])
      ! ;;
        ;; (define_split
        ;;   [(set (match_operand:SI 0 "arith_reg_operand" "=r")
        ;; 	(fix:SI (match_operand:DF 1 "arith_reg_operand" "f")))
      --- 8280,8286 ----
        ;;   "#"
        ;;   [(set_attr "length" "4")
        ;;    (set_attr "fp_mode" "double")])
      ! ;;
        ;; (define_split
        ;;   [(set (match_operand:SI 0 "arith_reg_operand" "=r")
        ;; 	(fix:SI (match_operand:DF 1 "arith_reg_operand" "f")))
      ***************
      *** 8320,8326 ****
          "* return output_ieee_ccmpeq (insn, operands);"
          [(set_attr "length" "4")
           (set_attr "fp_mode" "double")])
      !
        (define_insn "cmpeqdf_media"
          [(set (match_operand:DI 0 "register_operand" "=r")
        	(eq:DI (match_operand:DF 1 "fp_arith_reg_operand" "f")
      --- 8321,8327 ----
          "* return output_ieee_ccmpeq (insn, operands);"
          [(set_attr "length" "4")
           (set_attr "fp_mode" "double")])
      !
        (define_insn "cmpeqdf_media"
          [(set (match_operand:DI 0 "register_operand" "=r")
        	(eq:DI (match_operand:DF 1 "fp_arith_reg_operand" "f")
      ***************
      *** 8806,8815 ****
          "TARGET_SHMEDIA && reload_completed
           && GET_MODE (operands[0]) == GET_MODE (operands[1])
           && VECTOR_MODE_SUPPORTED_P (GET_MODE (operands[0]))
      !    && XVECEXP (operands[1], 0, 0) != const0_rtx
      !    && (HOST_BITS_PER_WIDE_INT >= 64
      !        || HOST_BITS_PER_WIDE_INT >= GET_MODE_BITSIZE (GET_MODE (operands[0]))
      !        || sh_1el_vec (operands[1], VOIDmode))"
          [(set (match_dup 0) (match_dup 1))]
          "
        {
      --- 8807,8813 ----
          "TARGET_SHMEDIA && reload_completed
           && GET_MODE (operands[0]) == GET_MODE (operands[1])
           && VECTOR_MODE_SUPPORTED_P (GET_MODE (operands[0]))
      !    && ! zero_vec_operand (operands[1], VOIDmode)"
          [(set (match_dup 0) (match_dup 1))]
          "
        {
      ***************
      *** 8819,8825 ****
      
          operands[0] = gen_rtx_REG (new_mode, true_regnum (operands[0]));
          operands[1]
      !     = simplify_subreg (new_mode, operands[1], GET_MODE (operands[0]), 0);
        }")
      
        (define_expand "movv2hi"
      --- 8817,8823 ----
      
          operands[0] = gen_rtx_REG (new_mode, true_regnum (operands[0]));
          operands[1]
      !     = simplify_subreg (new_mode, operands[1], GET_MODE (operands[1]), 0);
        }")
      
        (define_expand "movv2hi"
      ***************
      *** 8878,8884 ****
               || register_operand (operands[1], V2SImode))"
          "@
        	add	%1, r63, %0
      ! 	movi	%1, %0
        	#
        	ld%M1.q	%m1, %0
        	st%M0.q	%m0, %1"
      --- 8876,8882 ----
               || register_operand (operands[1], V2SImode))"
          "@
        	add	%1, r63, %0
      ! 	#
        	#
        	ld%M1.q	%m1, %0
        	st%M0.q	%m0, %1"
      ***************
      *** 9641,9647 ****
        /* These are useful to expand ANDs and as combiner patterns.  */
        (define_insn "mshfhi_l_di"
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
      ! 	(ior:DI (lshiftrt:DI (match_operand:DI 1 "arith_reg_or_0_operand" "rU")
                                     (const_int 32))
        		(and:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rU")
        			(const_int -4294967296))))]
      --- 9639,9645 ----
        /* These are useful to expand ANDs and as combiner patterns.  */
        (define_insn "mshfhi_l_di"
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
      ! 	(ior:DI (lshiftrt:DI (match_operand:DI 1 "arith_reg_or_0_operand" "rU")
                                     (const_int 32))
        		(and:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rU")
        			(const_int -4294967296))))]
      ***************
      *** 9653,9663 ****
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
        	(ior:DI (and:DI (match_operand:DI 1 "arith_reg_or_0_operand" "rU")
        			(const_int -4294967296))
      ! 		(lshiftrt:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rU")
                                     (const_int 32))))]
          "TARGET_SHMEDIA"
          "mshfhi.l	%N2, %N1, %0"
          [(set_attr "type" "arith_media")])
      
        (define_insn "mshflo_l_di"
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
      --- 9651,9680 ----
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
        	(ior:DI (and:DI (match_operand:DI 1 "arith_reg_or_0_operand" "rU")
        			(const_int -4294967296))
      ! 		(lshiftrt:DI (match_operand:DI 2 "arith_reg_or_0_operand" "rU")
                                     (const_int 32))))]
          "TARGET_SHMEDIA"
          "mshfhi.l	%N2, %N1, %0"
          [(set_attr "type" "arith_media")])
      +
      + (define_split
      +   [(set (match_operand:DI 0 "arith_reg_dest" "")
      + 	(ior:DI (zero_extend:DI (match_operand:SI 1
      + 					      "extend_reg_or_0_operand" ""))
      + 		(and:DI (match_operand:DI 2 "arith_reg_or_0_operand" "")
      + 			(const_int -4294967296))))
      +    (clobber (match_operand:DI 3 "arith_reg_dest" ""))]
      +   "TARGET_SHMEDIA"
      +   [(const_int 0)]
      +   "
      + {
      +   emit_insn (gen_ashldi3_media (operands[3],
      + 				simplify_gen_subreg (DImode, operands[1],
      + 						     SImode, 0),
      + 				GEN_INT (32)));
      +   emit_insn (gen_mshfhi_l_di (operands[0], operands[3], operands[2]));
      +   DONE;
      + }")
      
        (define_insn "mshflo_l_di"
          [(set (match_operand:DI 0 "arith_reg_dest" "=r")
      
      From-SVN: r55189
      J"orn Rennecke committed
    • re PR libstdc++/6642 (Constness prevents substraction of iterators) · d16ecaec
      2002-07-02  Paolo Carlini  <pcarlini@unitus.it>
      
      	PR libstdc++/6642
      	* include/bits/stl_iterator.h
      	(__normal_iterator::operator-(const __normal_iterator&)):
      	Make non-member, as already happens for the comparison
      	operators in accord with DR179 (Ready).
      	* testsuite/24_iterators/iterator.cc: Add test from the PR.
      
      From-SVN: r55188
      Paolo Carlini committed
    • Makefile.in: Don't try to build gdbtest, tgas, ispell, inet, or cvs[src]. · 98186934
      	* Makefile.in: Don't try to build gdbtest, tgas, ispell, inet, or
      	cvs[src].
      	* configure.in: Ditto.
      
      (also fix obvious typo in ChangeLog)
      
      From-SVN: r55187
      Nathanael Nerode committed
    • inline.java: New file. · 6ac0c1e3
      2002-07-02  Andrew Haley  <aph@redhat.com>
      
              * libjava.lang/inline.java: New file.
              * libjava.lang/inline.out: Likewise.
      
              * libjava.lang/Array_3.java: Add another case.
      
      From-SVN: r55186
      Andrew Haley committed
    • cppinit.c (cpp_handle_option): Suppress warnings with an implicit "-w" for "-M" and "-MM". · 49e7b251
      
      	* cppinit.c (cpp_handle_option):  Suppress warnings with an
      	implicit "-w" for "-M" and "-MM".
      doc:
      	* cppopts.texi: Update.
      testsuite:
      	* gcc.dg/cpp/cmdlne-M.c: New test.
      
      From-SVN: r55185
      Neil Booth committed
    • Correct changed function name. · 06728f70
      From-SVN: r55184
      Kriang Lerdsuwanakij committed
    • typeck2.c (incomplete_type_error): Fix typo caused by CVS conflict in my last patch. · 04c4491d
      	* typeck2.c (incomplete_type_error): Fix typo caused by
      	CVS conflict in my last patch.
      
      From-SVN: r55183
      Kriang Lerdsuwanakij committed
    • re PR c++/6716 (loop and fill ram during compiling) · 17f29637
      	PR c++/6716
      	* pt.c (can_complete_type_without_circularity): New function.
      	(instantiate_class_template): Use it.
      	* typeck2.c (incomplete_type_error): Improve error message
      	due to incomplete fields.
      
      	* g++.dg/template/instantiate1.C: New test.
      
      From-SVN: r55182
      Kriang Lerdsuwanakij committed
    • Daily bump. · 7c1c5cce
      From-SVN: r55179
      GCC Administrator committed
    • re PR libstdc++/7173 (_GLIBCPP_VERSION ="" on the 3.1 branch) · 2f235b6d
      2002-07-02  Phil Edwards  <pme@gcc.gnu.org>
      
      	PR libstdc++/7173
      	* acinclude.m4:  Simplify determination of gcc_version, and move
      	up to GLIBCPP_CONFIGURE.
      	* configure.in (release_VERSION):  Really remove.
      	(AM_INIT_AUTOMAKE, AM_CONFIG_HEADER):  Move after GLIBCPP_CONFIGURE.
      	* aclocal.m4, configure:  Regenerate.
      
      From-SVN: r55174
      Phil Edwards committed