1. 15 Jan, 2015 15 commits
    • Ensure options incompatible with micromips imply -mno-micromips · 3387e614
      gcc/testsuite/
      
      	* gcc.target/mips/mips.exp (mips-dg-options): -mips3d requires
      	-mno-micromips.  MIPS32R1 and below require -mno-micromips.
      	-march=loongson* and -march=octeon* require -mno-micromips.
      
      From-SVN: r219641
      Matthew Fortune committed
    • Update the call-saved tests for micromips output · 63ecaca0
      gcc/testsuite/
      
      	* gcc.target/mips/call-saved-4.c (foo): Add NOCOMPRESSION.
      	* gcc.target/mips/call-saved-5.c (foo): Likewise.
      	* gcc.target/mips/call-saved-6.c (foo): Likewise.
      	* gcc.target/mips/call-saved-7.c: New file.
      	* gcc.target/mips/call-saved-8.c: New file.
      	* gcc.target/mips/call-saved-9.c: New file.
      
      Co-Authored-By: Matthew Fortune <matthew.fortune@imgtec.com>
      
      From-SVN: r219640
      Andrew Bennett committed
    • [MIPS] Remove all excess parallel constructs · 2c3bcf47
      gcc/
      
      	* config/mips/micromips.md (*swp): Remove explicit parallel.
      	(jraddiusp, *movep<MOVEP1:mode><MOVEP2:mode>): Likewise.
      	* config/mips/mips-dsp.md (add<DSPV:mode>3): Likewise.
      	(mips_add<DSP:dspfmt1>_s_<DSP:dspfmt2>, sub<DSPV:mode>3): Likewise.
      	(mips_sub<DSP:dspfmt1>_s_<DSP:dspfmt2>, mips_addsc): Likewise.
      	(mips_addwc, mips_absq_s_<DSPQ:dspfmt2>): Likewise.
      	(mips_precrq_rs_ph_w, mips_precrqu_s_qb_ph): Likewise.
      	(mips_shll_<DSPV:dspfmt2>, mips_shll_s_<DSPQ:dspfmt2>): Likewise.
      	(mips_muleu_s_ph_qbl, mips_muleu_s_ph_qbr): Likewise.
      	(mips_mulq_rs_ph, mips_muleq_s_w_phl, mips_muleq_s_w_phr): Likewise.
      	(mips_dpaq_s_w_ph, mips_dpsq_s_w_ph, mips_mulsaq_s_w_ph): Likewise.
      	(mips_dpaq_sa_l_w, mips_dpsq_sa_l_w, mips_maq_s_w_phl): Likewise.
      	(mips_maq_s_w_phr, mips_maq_sa_w_phl, mips_maq_sa_w_phr): Likewise.
      	(mips_extr_w, mips_extr_r_w, mips_extr_rs_w): Likewise.
      	(mips_extr_s_h, mips_extp, mips_extpdp, mips_mthlip): Likewise.
      	(mips_wrdsp): Likewise.
      	* config/mips/mips-dspr2.md (mips_absq_s_qb): Remove explicit
      	parallel.
      	(mips_addu_ph, mips_addu_s_ph, mips_cmpgdu_eq_qb): Likewise.
      	(mips_cmpgdu_lt_qb, mips_cmpgdu_le_qb, mulv2hi3): Likewise.
      	(mips_mul_s_ph, mips_mulq_rs_w, mips_mulq_s_ph): Likewise.
      	(mips_mulq_s_w, mips_subu_ph, mips_subu_s_ph): Likewise.
      	(mips_dpaqx_s_w_ph, mips_dpaqx_sa_w_ph): Likewise.
      	(mips_dpsqx_s_w_ph, mips_dpsqx_sa_w_ph): Likewise.
      	* config/mips/mips-fixed.md (usadd<mode>3): Remove explicit parallel.
      	(ssadd<mode>3, ussub<mode>3, sssub<mode>3, ssmul<mode>3): Likewise.
      	(ssmaddsqdq4, ssmsubsqdq4): Likewise.
      
      From-SVN: r219639
      Matthew Fortune committed
    • Add support for the R6 LSA and DLSA instructions · 954bdd58
      gcc/
      
      	* config/mips/mips.c (mips_rtx_costs): Set costs for LSA/DLSA.
      	(mips_print_operand): Support 'y' to print exact log2 in decimal
      	of a const_int.
      	* config/mips/mips.h (ISA_HAS_LSA): New define.
      	(ISA_HAS_DLSA): Likewise.
      	* config/mips/mips.md (<GPR:d>lsa): New define_insn.
      	* config/mips/predicates.md (const_immlsa_operand): New predicate.
      
      gcc/testsuite/
      
      	* gcc.target/mips/lsa.c: New file.
      	* gcc.target/mips/mips64-lsa.c: Likewise.
      	* gcc.target/mips/mulsize-2.c: Require !HAS_LSA.
      	* gcc.target/mips/mulsize-4.c: Likewise.
      	* gcc.target/mips/mulsize-5.c: New file.
      	* gcc.target/mips/mulsize-6.c: Likewise.
      	* gcc.target/mips/mips.exp (mips_option_groups): Support HAS_LSA
      	and !HAS_LSA as ghost options.
      	(mips-dg-options): Require rev 6 for HAS_LSA. Downgrade to rev 5
      	for !HAS_LSA.
      
      From-SVN: r219638
      Matthew Fortune committed
    • Fix oversized bitfield warning. · 953bcfa6
      testsuite/
      2015-01-15  Matthew Wahab  <matthew.wahab@arm.com>
      
      	* g++.dg/torture/20141013.C: Set -fno-short-enums.
      
      From-SVN: r219637
      Matthew Wahab committed
    • Target optimization nodes: add support for arrays. · 5e306f6e
      	PR target/64377
      	* optc-save-gen.awk: Add support for array types.
      
      From-SVN: r219636
      Martin Liska committed
    • re PR tree-optimization/64365 (Predictive commoning after loop vectorization… · d679e96b
      re PR tree-optimization/64365 (Predictive commoning after loop vectorization produces incorrect code.)
      
      2015-01-15  Richard Biener  <rguenther@suse.de>
      
      	PR middle-end/64365
      	* tree-data-ref.c (dr_analyze_indices): Make sure that accesses
      	for MEM_REF access functions with the same base can never partially
      	overlap.
      
      	* gcc.dg/torture/pr64365.c: New testcase.
      
      From-SVN: r219634
      Richard Biener committed
    • common.opt: New option -fstack-protector-explicit. · 5434dc07
      2015-01-14  Marcos Diaz <marcos.diaz@tallertechnologies.com>
      
      	* common.opt: New option -fstack-protector-explicit.
      	* cfgexpand.c (SPCT_FLAG_EXPLICIT): New enum.
      	(stack_protect_decl_phase): Handle stack_protect attribute for
      	explicit stack protection requests.
      	(expand_used_vars): Similarly.
      	* doc/cpp.texi (__SSP_EXPLICIT__): Document predefined macro.
      	* doc/extend.texi: Add documentation for "stack_protect" attribute.
      	* doc/invoke.texi: Add documentation for -fstack-protector-explicit.
      
      	* c-cppbuiltin.c (c_cpp_builtins): New cpp define __SSP_EXPLICIT__
      	for the new option fstack-protector_explicit.
      	* c-common.c (c_common_attribute_table): Add stack_protect attribute.
      	(handle_stack_protect_attribute): New function.
      
      	* gcc.dg/stackprotectexplicit1.c: New test.
      	* g++.dg/stackprotectexplicit2.c: New test.
      
      From-SVN: r219633
      Marcos Diaz committed
    • re PR fortran/61933 (Inquire on internal units) · 1a0c6983
      2015-01-14  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR target/61933
      	* gfortran.dg/inquire_internal.f90: New.
      	* gfortran.dg/negative_unit_check.f90: New.
      
      From-SVN: r219632
      Jerry DeLisle committed
    • re PR fortran/61933 (Inquire on internal units) · 351b4432
      2015-01-14  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR libgfortran/61933
      	* io/inquire.c (inquire_via_unit): Set existing to true if a
      	gfc_unit stucture was found for the given unit number.
      	* runtime/error.c (translate_error): Add case for
      	LIBERROR_INQUIRE_INTERNAL_UNIT.
      
      From-SVN: r219631
      Jerry DeLisle committed
    • re PR fortran/61933 (Inquire on internal units) · 2da229cb
      2015-01-14  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
      
      	PR fortran/61933
      	* io.c (gfc_match_inquire): Generate error if unit number in
      	inquire statement is a constant -1.  All other values allowed.
      	* trans-io.c (gfc_trans_inquire): Delete dummy iostat variable.
      	(create_dummy_iostat): Delete function no longer used.
      
      From-SVN: r219630
      Jerry DeLisle committed
    • libgo: Bump version number in libgo configure script. · d5d9c650
      From-SVN: r219629
      Ian Lance Taylor committed
    • libgo, compiler: Upgrade libgo to Go 1.4, except for runtime. · f8d9fa9e
      This upgrades all of libgo other than the runtime package to
      the Go 1.4 release.  In Go 1.4 much of the runtime was
      rewritten into Go.  Merging that code will take more time and
      will not change the API, so I'm putting it off for now.
      
      There are a few runtime changes anyhow, to accomodate other
      packages that rely on minor modifications to the runtime
      support.
      
      The compiler changes slightly to add a one-bit flag to each
      type descriptor kind that is stored directly in an interface,
      which for gccgo is currently only pointer types.  Another
      one-bit flag (gcprog) is reserved because it is used by the gc
      compiler, but gccgo does not currently use it.
      
      There is another error check in the compiler since I ran
      across it during testing.
      
      gotools/:
      	* Makefile.am (go_cmd_go_files): Sort entries.  Add generate.go.
      	* Makefile.in: Rebuild.
      
      From-SVN: r219627
      Ian Lance Taylor committed
    • Daily bump. · 6bd3f109
      From-SVN: r219626
      GCC Administrator committed
  2. 14 Jan, 2015 25 commits