1. 27 May, 2012 2 commits
  2. 26 May, 2012 8 commits
  3. 25 May, 2012 20 commits
  4. 24 May, 2012 10 commits
    • runtime: Make runtime.Stack actually work. · bac564c5
      From-SVN: r187854
      Ian Lance Taylor committed
    • PR bootstrap/53459 - unused local typedef when building on altivec · 27c53c0c
      libcpp/
      
      	PR bootstrap/53459
      	* lex.c (search_line_fast): Remove unused typedef check_count.
      
      From-SVN: r187853
      Dodji Seketeli committed
    • runtime: Correct definition of __go_file_line to match declaration. · 9e65cec2
      From Rainer Orth.
      
      From-SVN: r187851
      Ian Lance Taylor committed
    • runtime: Copy runtime_printf from other Go library. · 41f9e675
      From-SVN: r187850
      Ian Lance Taylor committed
    • runtime: Copy runtime_printf from other Go library. · 86ba147f
      From-SVN: r187848
      Ian Lance Taylor committed
    • rs6000.c (rs6000_option_override_internal): Change rs6000_sched_costly_dep… · 6fac31b4
      rs6000.c (rs6000_option_override_internal): Change rs6000_sched_costly_dep default to true_store_to_load_dep_costly.
      
      	* config/rs6000/rs6000.c (rs6000_option_override_internal): Change
      	rs6000_sched_costly_dep default to true_store_to_load_dep_costly.
      	(adjacent_mem_locations): Move some code to and call...
      	(get_memref_parts): ...new function.
      	(mem_locations_overlap): New function.
      	(rs6000_adjust_priority): Adjust calls to is_load_insn/is_store_insn.
      	(is_mem_ref): Rename to...
      	(find_mem_ref): ...this. Return MEM rtx.
      	(get_store_dest): Remove function.
      	(is_load_insn1, is_load_insn, is_store_insn1, is_store_insn): Add
      	new parameter and adjust calls.
      	(rs6000_is_costly_dependence): Update calls for extra arg. Make sure
      	mem refs overlap for true_store_to_load_dep_costly.
      	(rs6000_sched_reorder2): Update calls for extra arg. Adjust args
      	passed to adjacent_mem_locations.
      	(is_costly_group): Walk resolved dependency list.
      	(force_new_group): Emit group ending nop for Power6/Power7.
      	* config/rs6000/rs6000.md (UNSPEC_GRP_END_NOP): New enum value.
      	(group_ending_nop): New define_insn.
      
      	* gcc.target/powerpc/lhs-1.c: New.
      	* gcc.target/powerpc/lhs-2.c: New.
      	* gcc.target/powerpc/lhs-3.c: New.
      
      From-SVN: r187847
      Pat Haugen committed
    • PR 53456 CPU timing fallback using clock_gettime. · 44813fe0
      2012-05-24  Janne Blomqvist  <jb@gcc.gnu.org>
      
      	PR fortran/53456
      	* intrinsics/time_1.h (gf_cputime): Fallback for clock_gettime.
      
      From-SVN: r187846
      Janne Blomqvist committed
    • Make unwound macro expansion trace less redundant · 165ca58d
      As discussed previously, the unwinder for macro expansion is quite
      verbose [1].  This patch proposes to address that shortcoming.
      
      Consider this test case:
      
          $ cat -n test.c
      	 1	#define MYMAX(A,B) __extension__ ({ __typeof__(A) __a = (A); \
      	 2	 __typeof__(B) __b = (B); __a < __b ? __b : __a; })
      	 3
      	 4	struct mystruct {};
      	 5	void
      	 6	foo()
      	 7	{
      	 8	  struct mystruct p;
      	 9	  float f = 0.0;
      	10	  MYMAX (p, f);
      	11	}
          $
      
      The output of the compiler from trunk yields:
      
          $ cc1 -quiet ./test.c
          ./test.c: In function ‘foo’:
          ./test.c:2:31: error: invalid operands to binary < (have ‘struct mystruct’ and ‘float’)
            __typeof__(B) __b = (B); __a < __b ? __b : __a; })
      				   ^
          ./test.c:2:31: note: in expansion of macro 'MYMAX'
            __typeof__(B) __b = (B); __a < __b ? __b : __a; })
      				   ^
          ./test.c:10:3: note: expanded from here
             MYMAX (p, f);
             ^
          $
      
      After this patch, the compiler yields:
      
          $ ./cc1 -quiet ./test.c
          ./test.c: In function ‘foo’:
          ./test.c:2:31: error: invalid operands to binary < (have ‘struct mystruct’ and ‘float’)
            __typeof__(B) __b = (B); __a < __b ? __b : __a; })
      				   ^
          ./test.c:10:3: note: in expansion of macro 'MYMAX'
             MYMAX (p, f);
             ^
          $
      
      The gotcha is, in the general case, we cannot simply eliminate the
      context of the macro definition.  That is, the line from the first
      output that is redundant with the first diagnostic line that has
      line/column number:
      
          ./test.c:2:31: note: in expansion of macro 'MYMAX'
            __typeof__(B) __b = (B); __a < __b ? __b : __a; })
                                         ^
      
      We cannot simply eliminate that context of macro definition because
      there are cases where the first diagnostic that has a line/column
      number doesn't point to a location inside the definition of the macro
      where the relevant token is used.  For instance:
      
          $ cat -n test2.c
      	 1	#define OPERATE(OPRD1, OPRT, OPRD2) \
      	 2	  OPRD1 OPRT OPRD2;
      	 3
      	 4	#define SHIFTL(A,B) \
      	 5	  OPERATE (A,<<,B)
      	 6
      	 7	#define MULT(A) \
      	 8	  SHIFTL (A,1)
      	 9
      	10	void
      	11	g ()
      	12	{
      	13	  MULT (1.0);// 1.0 << 1; <-- so this is an error.
      	14	}
          $
      
      Which yields without the patch:
      
          $ cc1 -quiet ./test2.c
          ./test2.c: In function ‘g’:
          ./test2.c:5:14: error: invalid operands to binary << (have ‘double’ and ‘int’)
             OPERATE (A,<<,B)
      		  ^
          ./test2.c:2:9: note: in expansion of macro 'OPERATE'
             OPRD1 OPRT OPRD2;
      	     ^
          ./test2.c:5:3: note: expanded from here
             OPERATE (A,<<,B)
             ^
          ./test2.c:5:14: note: in expansion of macro 'SHIFTL'
             OPERATE (A,<<,B)
      		  ^
          ./test2.c:8:3: note: expanded from here
             SHIFTL (A,1)
             ^
          ./test2.c:8:3: note: in expansion of macro 'MULT'
             SHIFTL (A,1)
             ^
          ./test2.c:13:3: note: expanded from here
             MULT (1.0);// 1.0 << 1; <-- so this is an error.
             ^
          $
      
      Here, the line that has the context of macro definition:
      
          ./test2.c:2:9: note: in expansion of macro 'OPERATE'
             OPRD1 OPRT OPRD2;
      	     ^
      is useful, because the first diagnostic that has line/column number
      wasn't pointing into the definition of the macro OPERATE, where the
      token '<<' is used.
      
          ./test2.c:5:14: error: invalid operands to binary << (have ‘double’ and ‘int’)
             OPERATE (A,<<,B)
      		  ^
      So in this this case, displaying the macro definition context is not
      redundant.  I think it is even desirable.
      
      The patch changes the output in that case to be:
      
          ./test2.c: In function ‘g’:
          ./test2.c:5:14: erreur: invalid operands to binary << (have ‘double’ and ‘int’)
             OPERATE (A,<<,B)
      		  ^
          ./test2.c:2:9: note: in definition of macro 'OPERATE'
             OPRD1 OPRT OPRD2;
      	     ^
          ./test2.c:8:3: note: in expansion of macro 'SHIFTL'
             SHIFTL (A,1)
             ^
          ./test2.c:13:3: note: in expansion of macro 'MULT'
             MULT (1.0);// 1.0 << 1; <-- so this is an error.
             ^
          $
      
      It's shorter, but I believe it has all the information that was
      present before the patch.
      
      [1]: http://gcc.gnu.org/ml/gcc-patches/2012-05/msg00321.html
      
      Bootstrapped and tested on x86_64-unknown-linux-gnu against trunk.
      
      gcc/
      
      	Make unwound macro expansion trace less redundant
      	* tree-diagnostic.c (maybe_unwind_expanded_macro_loc): Don't print
      	context of macro definition in the trace, when it's redundant.
      	Update comments.
      
      gcc/testsuite/
      
      	Make unwound macro expansion trace less redundant
      	* gcc.dg/cpp/macro-exp-tracking-1.c: Adjust.
      	* gcc.dg/cpp/macro-exp-tracking-2.c: Likewise.
      	* gcc.dg/cpp/macro-exp-tracking-3.c: Likewise.
      	* gcc.dg/cpp/macro-exp-tracking-4.c: Likewise.
      	* gcc.dg/cpp/macro-exp-tracking-5.c: Likewise.
      	* gcc.dg/cpp/pragma-diagnostic-2.c: Likewise.
      
      From-SVN: r187845
      Dodji Seketeli committed
    • re PR c++/53464 (Invalid default value for non-type template parameter is accepted) · a5dedb5e
      2012-05-24  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/53464
      	* g++.dg/cpp0x/constexpr-default1.C: New.
      
      From-SVN: r187842
      Paolo Carlini committed
    • Fix typo in latest ChangeLog entry addition. · 73fb7630
      From-SVN: r187840
      Olivier Hainque committed