1. 04 Jul, 2014 8 commits
    • Preparation of nds32-pipelines-auxiliary.c module for future implementation. · c65cef10
      gcc/
      	* config/nds32/nds32-pipelines-auxiliary.c: Add comment to describe
      	the purpose of this file.
      
      Co-Authored-By: Ling-Hua Tseng <uranus@tinlans.org>
      
      From-SVN: r212285
      Chung-Ju Wu committed
    • Move cost calculation to nds32-cost.c module. · 89a4b547
      gcc/
      	* config/nds32/nds32.c (nds32_rtx_costs): Move implementation to ...
      	(nds32_address_cost): Move implementation to ...
      	* config/nds32/nds32-cost.c: ... here.
      	* config/nds32/nds32-protos.h (nds32_rtx_costs_impl): Declare.
      	(nds32_address_cost_impl): Declare.
      
      Co-Authored-By: Kito Cheng <kito@0xlab.org>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r212284
      Chung-Ju Wu committed
    • Move some helper functions of predicates and constraints to nds32-predicates.c module. · 6a2a98b1
      gcc/
      	* config/nds32/nds32.c
      	(nds32_consecutive_registers_load_store_p): Move to ...
      	(nds32_valid_multiple_load_store): Move to ...
      	(nds32_valid_stack_push_pop): Move to ...
      	(nds32_can_use_bclr_p): Move to ...
      	(nds32_can_use_bset_p): Move to ...
      	(nds32_can_use_btgl_p): Move to ...
      	(nds32_can_use_bitci_p): Move to ...
      	* config/nds32/nds32-predicates.c: ... here.
      
      Co-Authored-By: Kito Cheng <kito@0xlab.org>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r212283
      Chung-Ju Wu committed
    • Move builtin functions implementation to nds32-intrinsic.c module. · aaa44d2d
      gcc/
      	* config/nds32/nds32.c
      	(nds32_expand_builtin_null_ftype_reg): Move to ...
      	(nds32_expand_builtin_reg_ftype_imm): Move to ...
      	(nds32_expand_builtin_null_ftype_reg_imm): Move to ...
      	(nds32_init_builtins): Move implementation to ...
      	(nds32_expand_builtin): Move implementation to ...
      	* config/nds32/nds32-intrinsic.c: ... here.
      	* config/nds32/nds32-protos.h (nds32_init_builtins_impl): Declare.
      	(nds32_expand_builtin_impl): Declare.
      
      Co-Authored-By: Kito Cheng <kito@0xlab.org>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r212282
      Chung-Ju Wu committed
    • Move ISR impelentation to nds32-isr.c module. · c23a919b
      gcc/
      	* config/nds32/nds32.c (nds32_emit_section_head_template): Move to ...
      	(nds32_emit_section_tail_template): Move to ...
      	(nds32_emit_isr_jmptbl_section): Move to ...
      	(nds32_emit_isr_vector_section): Move to ...
      	(nds32_emit_isr_reset_conten): Move to ...
      	(nds32_check_isr_attrs_conflict): Move to ...
      	(nds32_construct_isr_vectors_information): Move to ...
      	(nds32_asm_file_start): Move implementation to ...
      	(nds32_asm_file_end): Move implementation to ...
      	* config/nds32/nds32-isr.c: ... here.
      	* config/nds32/nds32-protos.h
      	(nds32_check_isr_attrs_conflict): Declare.
      	(nds32_construct_isr_vectors_information): Declare.
      	(nds32_asm_file_start_for_isr): Declare.
      	(nds32_asm_file_end_for_isr): Declare.
      
      Co-Authored-By: Kito Cheng <kito@0xlab.org>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r212281
      Chung-Ju Wu committed
    • Add several new files for preparation of providing modules · c0c935b5
      that are going to be separated from nds32.c source.
      
      gcc/
      	* config.gcc (nds32*): Add new modules to extra_objs.
      	(nds32le-*-*): Use t-nds32 makefile fragment for new modules.
      	(nds32be-*-*): Likewise.
      	* config/nds32/nds32-cost.c: New file.
      	* config/nds32/nds32-fp-as-gp.c: New file.
      	* config/nds32/nds32-intrinsic.c: New file.
      	* config/nds32/nds32-isr.c: New file.
      	* config/nds32/nds32-md-auxiliary.c: New file.
      	* config/nds32/nds32-memory-manipulation.c: New file.
      	* config/nds32/nds32-pipelines-auxiliary.c: New file.
      	* config/nds32/nds32-predicates.c: New file.
      	* config/nds32/t-nds32: New file.
      
      Co-Authored-By: Kito Cheng <kito@0xlab.org>
      Co-Authored-By: Monk Chiang <sh.chiang04@gmail.com>
      
      From-SVN: r212280
      Chung-Ju Wu committed
    • Normalize interface for all *-dg-runtest. · a03bd005
      	gcc/testsuite/
      	* lib/g++-dg.exp (g++-dg-runtest): Change interface to match
      	dg-runtest's.  Adapt all callers.
      	* lib/gcc-dg.exp (gcc-dg-runtest): Likewise.
      	* lib/gfortran-dg.exp (gfortran-dg-runtest): Likewise.
      	* lib/go-dg.exp (go-dg-runtest): Likewise.
      	* lib/obj-c++-dg.exp (obj-c++-dg-runtest): Likewise.
      	* lib/objc-dg.exp (objc-dg-runtest): Likewise.
      	libffi/
      	* testsuite/lib/libffi.exp (libffi-dg-runtest): Change interface
      	match to dg-runtest's.
      
      From-SVN: r212278
      Thomas Schwinge committed
    • Daily bump. · 01ffe74d
      From-SVN: r212277
      GCC Administrator committed
  2. 03 Jul, 2014 12 commits
  3. 02 Jul, 2014 16 commits
    • Only transform rotate to rotatert and v.v. if target has both · 4ed3092f
      Many targets do not have both rotate and rotatert.  Of the 47 targets
      in the tree, 17 have both, 9 have only rotate, 2 have only rotatert, and
      19 have neither (this is based on "grep -wil" so it can be slightly off).
      
      rs6000 has only rotate, and mips has only rotatert.  For such targets
      simplifying rotate to rotatert and vice versa is not simplifying things
      at all.  rs6000 has already way too many rotate patterns (some days it
      seems like two thousand, but it is somewhat less in reality still); I
      would prefer not to double that again.
      
      So, this patch makes genrecog define HAVE_rotate and HAVE_rotatert if
      those RTL codes are mentioned anywhere in the machine description, and
      then does the transformation in simplify-rtx.c only if both these flags
      are set.
      
      From-SVN: r212239
      Segher Boessenkool committed
    • * config/fpu-sysv.h (void set_fpu): Remove stalled comment. · 1680a432
      From-SVN: r212235
      Uros Bizjak committed
    • c-decl.c (duplicate_decls): CLear DECL_STRUCT_FUNCTION before releasing symbol. · 22e1cf1c
      	* c-decl.c (duplicate_decls): CLear DECL_STRUCT_FUNCTION before
      	releasing symbol.
      
      	* gcc.c-torture/compile/section.c: New testcase.
      
      Co-Authored-By: Chen Gang <gang.chen.5i5j@gmail.com>
      
      From-SVN: r212234
      Jan Hubicka committed
    • re PR go/61620 (FAIL: go.test/test/fixedbugs/bug242.go execution, -O2 -g) · 9490fda6
      	PR go/61620
      
      runtime: Don't free tiny blocks in map deletion.
      
      The memory allocator now has a special case for tiny blocks
      (smaller than 16 bytes) and they can not be explicitly freed.
      
      From-SVN: r212233
      Ian Lance Taylor committed
    • add bugzilla links · 513c5c74
      From-SVN: r212232
      Christian Bruel committed
    • add test · cbee452f
      From-SVN: r212231
      Christian Bruel committed
    • Support mode toggle. · cbb1e3d9
      * mode-switching.c (struct bb_info): Add mode_out, mode_in caches.
      (make_preds_opaque): Delete.
      (clear_mode_bit, mode_bit_p, set_mode_bit): New macros.
      (commit_mode_sets): New function.
      (optimize_mode_switching): Handle current_mode to mode_switching_emit.
      Process all modes at once.
      * basic-block.h (pre_edge_lcm_avs): Declare.
      * lcm.c (pre_edge_lcm_avs): Renamed from pre_edge_lcm.
      Call clear_aux_for_edges. Fix comments.
      (pre_edge_lcm): New wrapper function to call pre_edge_lcm_avs.
      (pre_edge_rev_lcm): Idem.
      * config/epiphany/epiphany.c (emit_set_fp_mode): Add prev_mode parameter.
      * config/epiphany/epiphany-protos.h (emit_set_fp_mode): Idem.
      * config/epiphany/resolve-sw-modes.c (pass_resolve_sw_modes::execute): Idem.
      * config/i386/i386.c (x96_emit_mode_set): Idem.
      * config/sh/sh.c (sh_emit_mode_set): Likewise. Handle PR toggle.
      * config/sh/sh.md (toggle_pr): 	Defined if TARGET_FPU_SINGLE.
      (fpscr_toggle) Disallow from delay slot.
      * target.def (emit_mode_set): Add prev_mode parameter.
      * doc/tm.texi: Regenerate.
      
      From-SVN: r212230
      Christian Bruel committed
    • decl.c (variable_decl): Reject old style initialization for derived type components. · b18f1efc
      	* decl.c (variable_decl): Reject old style initialization
      	for derived type components.
      
      	* gfortran.dg/oldstyle_5.f: New test.
      
      Co-Authored-By: Fritz Reese <Reese-Fritz@zai.com>
      
      From-SVN: r212227
      Jakub Jelinek committed
    • [AArch64] Removed unused variable i in aarch64_expand_vec_perm · c9d1a16a
      	* config/aarch64/aarch64.c (aarch64_expand_vec_perm): Delete unused
      	variable i.
      
      From-SVN: r212225
      Kyrylo Tkachov committed
    • configure.host (ieee_flags): Add -mieee for alpha*. · 5b0936da
      libgfortran/ChangeLog:
      
      	* configure.host (ieee_flags): Add -mieee for alpha*.
      
      	* config/fpu-glibc.h (support_fpu_rounding_mode): Correctly handle
      	GFC_FPE_UPWARD, GFC_FPE_DOWNWARD and GFC_FPE_TOWARDZERO.
      	* config/fpu-aix.h (support_fpu_rounding_mode): Ditto.
      
      testsuite/ChangeLog:
      
      	* gfortran.dg/ieee/ieee_1.F90 (dg-additional-options): Remove -O0.
      	* gfortran.dg/ieee/ieee_rounding_1.f90 (dg-additional-options): Add.
      
      From-SVN: r212224
      Uros Bizjak committed
    • pt.c (convert_template_argument): Use inform instead of error in three places. · bca23ca2
      /cp
      2014-07-02  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* pt.c (convert_template_argument): Use inform instead of error in
      	three places.
      
      /testsuite
      2014-07-02  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	* g++.dg/cpp0x/variadic-ex10.C: Adjust for inform instead of error.
      	* g++.dg/cpp0x/variadic-ex14.C: Likewise.
      	* g++.dg/parse/error11.C: Likewise.
      	* g++.old-deja/g++.brendan/template17.C: Likewise.
      
      From-SVN: r212223
      Paolo Carlini committed
    • ipa-utils.h (method_class_type, [...]): Constify. · d570d364
      
      	* ipa-utils.h (method_class_type, vtable_pointer_value_to_binfo,
      	vtable_pointer_value_to_vtable): Constify.
      	(contains_polymorphic_type_p): Declare.
      	* ipa-devirt.c (method_class_type, vtable_pointer_value_to_binfo,
      	vtable_pointer_value_to_vtable): Constify.
      	(contains_polymorphic_type_p): New predicate.
      	* ipa-prop.c (ipa_set_jf_known_type): Allow types containing
      	polymorphic types.
      	(ipa_set_ancestor_jf): Likewise.
      	(detect_type_change): Return false in easy cases.
      	(compute_complex_assign_jump_func): Require type to contain
      	polymorphic type.
      	(compute_known_type_jump_func): Likewise.
      
      From-SVN: r212222
      Jan Hubicka committed
    • get_array.f90: Add missing SYNC ALL. · a90532fd
      2014-07-02  Tobias Burnus  <burnus@net-b.de>
      
              * gfortran.dg/coarray/get_array.f90: Add missing SYNC ALL.
              * gfortran.dg/coarray/send_array.f90: Ditto.
              * gfortran.dg/coarray/sendget_array.f90: Ditto.
      
      From-SVN: r212220
      Tobias Burnus committed
    • tree.c (decls_same_for_odr, [...]): Remove. · 549bcbd1
      
      	* tree.c (decls_same_for_odr, decls_same_for_odr,
      	types_same_for_odr): Remove.
      	(type_in_anonymous_namespace_p): Constify argument.
      	* tree.h (types_same_for_odr, type_in_anonymous_namespace_p):
      	Constify.
      	* ipa-devirt.c (odr_type_d): Add ODR_VIOLATED field.
      	(main_odr_variant): New function.
      	(hash_type_name): Make static; update assert; do not ICE on
      	non-records.
      	(types_same_for_odr): Bring here from tree.c; simplify
      	and remove old structural comparing code that doesn't work
      	for templates.
      	(odr_hasher::equal): Update assert.
      	(add_type_duplicate): Return true when bases should be computed;
      	replace incomplete loader by complete; do not output duplicated
      	warnings; do not ICE on non-records; set odr_violated flag.
      	(get_odr_type): Be ready to replace incomplete type by complete
      	one; work on ODR variants instead of main variants; reorder item
      	in array so bases have still smaller indexes.
      	(dump_type_inheritance_graph): Be ready for holdes in odr_types
      	array.
      	(possible_polymorphic_call_targets): Do not ICE when BINFO is NULL.
      
      From-SVN: r212218
      Jan Hubicka committed
    • Daily bump. · 5656ccd7
      From-SVN: r212217
      GCC Administrator committed
  4. 01 Jul, 2014 4 commits
    • runtime: introduce build targets for running benchmarks · ffa98da4
      This introduces the "bench" build target, which can be used to run
      all benchmarks.
      
      It is also possible to run subsets of benchmarks with the
      "package/check" build targets by setting GOBENCH to a matching regex.
      
      From-SVN: r212212
      Ian Lance Taylor committed
    • This patch fixes a couple of ICEs when using -gsplit-dwarf. · 25eff60d
      When compiling a small-enough compilation unit that has no address table
      entries, but complex enough that -freorder-blocks-and-partition produces
      location lists, dwarf2out_finish does not call index_location_lists, but
      optimize_location_lists will later assume that the addr_index_table has
      been indexed.
      Google ref: b/15417905
      
      When resolve_addr_in_expr replaces a CONST_STRING rtx, it directly
      updates the pointer to the old expression with the new one. In the
      case of a DW_OP_GNU_addr_index or DW_OP_GNU_const_index, that pointer
      may be in an address table entry, which is keyed by the rtx. Instead
      of directly replacing the pointer, we need to remove the old address
      table entry (i.e., decrement its reference count), and add a new one.
      Google ref: b/15957101
      
      gcc/
      	* dwarf2out.c (remove_addr_table_entry): Remove unnecessary hash table
              lookup.
      	(resolve_addr_in_expr): When replacing the rtx in a location list
              entry, get a new address table entry.
      	(dwarf2out_finish): Call index_location_lists even if there are no
              addr_index_table entries yet.
      
      From-SVN: r212211
      Cary Coutant committed
    • gcc/testsuite/ · 454a17a3
      	* gcc.target/aarch64/aapcs64/aapcs64.exp:
      	(additional_flags_for_func_ret): New variable based on $additional_flags
      	with -fno-use-caller-save.
      	(func-ret-*.c): Use the new variable.
      
      Co-Authored-By: Yufeng Zhang <yufeng.zhang@arm.com>
      
      From-SVN: r212206
      James Greenhalgh committed
    • re PR c++/59637 ([c++11] ICE with decltype and destructor call in template) · 2a4141aa
      2014-07-01  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/59637
      	* g++.dg/cpp0x/decltype60.C: New.
      
      From-SVN: r212205
      Paolo Carlini committed