1. 08 Jun, 2013 10 commits
  2. 07 Jun, 2013 23 commits
  3. 06 Jun, 2013 7 commits
    • p8vector-builtin-1.c: New test to test power8 builtin functions. · a9afa216
      2013-06-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
      	    Pat Haugen <pthaugen@us.ibm.com>
      	    Peter Bergner <bergner@vnet.ibm.com>
      
      	* gcc.target/powerpc/p8vector-builtin-1.c: New test to test
      	power8 builtin functions.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-2.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-3.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-4.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-5.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-6.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-builtin-7.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-vectorize-1.c: New
      	tests to test power8 auto-vectorization.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-vectorize-2.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-vectorize-3.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-vectorize-4.c: Likewise.
      	* gcc/testsuite/gcc.target/powerpc/p8vector-vectorize-5.c: Likewise.
      
      
      Co-Authored-By: Pat Haugen <pthaugen@us.ibm.com>
      Co-Authored-By: Peter Bergner <bergner@vnet.ibm.com>
      
      From-SVN: r199768
      Michael Meissner committed
    • extend.texi (PowerPC AltiVec/VSX Built-in Functions): Document new power8 builtins. · 0bd62dca
      [gcc]
      2013-06-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
      	    Pat Haugen <pthaugen@us.ibm.com>
      	    Peter Bergner <bergner@vnet.ibm.com>
      
      	* doc/extend.texi (PowerPC AltiVec/VSX Built-in Functions):
      	Document new power8 builtins.
      
      	* config/rs6000/vector.md (and<mode>3): Add a clobber/scratch of a
      	condition code register, to allow 128-bit logical operations to be
      	done in the VSX or GPR registers.
      	(nor<mode>3): Use the canonical form for nor.
      	(eqv<mode>3): Add expanders for power8 xxleqv, xxlnand, xxlorc,
      	vclz*, and vpopcnt* vector instructions.
      	(nand<mode>3): Likewise.
      	(orc<mode>3): Likewise.
      	(clz<mode>2): LIkewise.
      	(popcount<mode>2): Likewise.
      
      	* config/rs6000/predicates.md (int_reg_operand): Rework tests so
      	that only the GPRs are recognized.
      
      	* config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add
      	support for new power8 builtins.
      
      	* config/rs6000/rs6000-builtin.def (xscvspdpn): Add new power8
      	builtin functions.
      	(xscvdpspn): Likewise.
      	(vclz): Likewise.
      	(vclzb): Likewise.
      	(vclzh): Likewise.
      	(vclzw): Likewise.
      	(vclzd): Likewise.
      	(vpopcnt): Likewise.
      	(vpopcntb): Likewise.
      	(vpopcnth): Likewise.
      	(vpopcntw): Likewise.
      	(vpopcntd): Likewise.
      	(vgbbd): Likewise.
      	(vmrgew): Likewise.
      	(vmrgow): Likewise.
      	(eqv): Likewise.
      	(eqv_v16qi3): Likewise.
      	(eqv_v8hi3): Likewise.
      	(eqv_v4si3): Likewise.
      	(eqv_v2di3): Likewise.
      	(eqv_v4sf3): Likewise.
      	(eqv_v2df3): Likewise.
      	(nand): Likewise.
      	(nand_v16qi3): Likewise.
      	(nand_v8hi3): Likewise.
      	(nand_v4si3): Likewise.
      	(nand_v2di3): Likewise.
      	(nand_v4sf3): Likewise.
      	(nand_v2df3): Likewise.
      	(orc): Likewise.
      	(orc_v16qi3): Likewise.
      	(orc_v8hi3): Likewise.
      	(orc_v4si3): Likewise.
      	(orc_v2di3): Likewise.
      	(orc_v4sf3): Likewise.
      	(orc_v2df3): Likewise.
      
      	* config/rs6000/rs6000.c (rs6000_option_override_internal): Only
      	allow power8 quad mode in 64-bit.
      	(rs6000_builtin_vectorized_function): Add support to vectorize
      	ISA 2.07 count leading zeros, population count builtins.
      	(rs6000_expand_vector_init): On ISA 2.07 use xscvdpspn to form
      	V4SF vectors instead of xscvdpsp to avoid IEEE related traps.
      	(builtin_function_type): Add vgbbd builtin function which takes an
      	unsigned argument.
      	(altivec_expand_vec_perm_const): Add support for new power8 merge
      	instructions.
      
      	* config/rs6000/vsx.md (VSX_L2): New iterator for 128-bit types,
      	that does not include TImdoe for use with 32-bit.
      	(UNSPEC_VSX_CVSPDPN): Support for power8 xscvdpspn and xscvspdpn
      	instructions.
      	(UNSPEC_VSX_CVDPSPN): Likewise.
      	(vsx_xscvdpspn): Likewise.
      	(vsx_xscvspdpn): Likewise.
      	(vsx_xscvdpspn_scalar): Likewise.
      	(vsx_xscvspdpn_directmove): Likewise.
      	(vsx_and<mode>3): Split logical operations into 32-bit and
      	64-bit. Add support to do logical operations on TImode as well as
      	VSX vector types.  Allow logical operations to be done in either
      	VSX registers or in general purpose registers in 64-bit mode.  Add
      	splitters if GPRs were used. For AND, add clobber of CCmode to
      	allow use of ANDI on GPRs.  Rewrite nor to use the canonical RTL
      	encoding.
      	(vsx_and<mode>3_32bit): Likewise.
      	(vsx_and<mode>3_64bit): Likewise.
      	(vsx_ior<mode>3): Likewise.
      	(vsx_ior<mode>3_32bit): Likewise.
      	(vsx_ior<mode>3_64bit): Likewise.
      	(vsx_xor<mode>3): Likewise.
      	(vsx_xor<mode>3_32bit): Likewise.
      	(vsx_xor<mode>3_64bit): Likewise.
      	(vsx_one_cmpl<mode>2): Likewise.
      	(vsx_one_cmpl<mode>2_32bit): Likewise.
      	(vsx_one_cmpl<mode>2_64bit): Likewise.
      	(vsx_nor<mode>3): Likewise.
      	(vsx_nor<mode>3_32bit): Likewise.
      	(vsx_nor<mode>3_64bit): Likewise.
      	(vsx_andc<mode>3): Likewise.
      	(vsx_andc<mode>3_32bit): Likewise.
      	(vsx_andc<mode>3_64bit): Likewise.
      	(vsx_eqv<mode>3_32bit): Add support for power8 xxleqv, xxlnand,
      	and xxlorc instructions.
      	(vsx_eqv<mode>3_64bit): Likewise.
      	(vsx_nand<mode>3_32bit): Likewise.
      	(vsx_nand<mode>3_64bit): Likewise.
      	(vsx_orc<mode>3_32bit): Likewise.
      	(vsx_orc<mode>3_64bit): Likewise.
      
      	* config/rs6000/rs6000.h (VLOGICAL_REGNO_P): Update comment.
      
      	* config/rs6000/altivec.md (UNSPEC_VGBBD): Add power8 vgbbd
      	instruction.
      	(p8_vmrgew): Add power8 vmrgew and vmrgow instructions.
      	(p8_vmrgow): Likewise.
      	(altivec_and<mode>3): Add clobber of CCmode to allow AND using
      	GPRs to be split under VSX.
      	(p8v_clz<mode>2): Add power8 count leading zero support.
      	(p8v_popcount<mode>2): Add power8 population count support.
      	(p8v_vgbbd): Add power8 gather bits by bytes by doubleword
      	support.
      
      	* config/rs6000/rs6000.md (eqv<mode>3): Add support for powerp eqv
      	instruction.
      
      	* config/rs6000/altivec.h (vec_eqv): Add defines to export power8
      	builtin functions.
      	(vec_nand): Likewise.
      	(vec_vclz): Likewise.
      	(vec_vclzb): Likewise.
      	(vec_vclzd): Likewise.
      	(vec_vclzh): Likewise.
      	(vec_vclzw): Likewise.
      	(vec_vgbbd): Likewise.
      	(vec_vmrgew): Likewise.
      	(vec_vmrgow): Likewise.
      	(vec_vpopcnt): Likewise.
      	(vec_vpopcntb): Likewise.
      	(vec_vpopcntd): Likewise.
      	(vec_vpopcnth): Likewise.
      	(vec_vpopcntw): Likewise.
      
      [gcc/testsuite]
      2013-06-06  Michael Meissner  <meissner@linux.vnet.ibm.com>
      	    Pat Haugen <pthaugen@us.ibm.com>
      	    Peter Bergner <bergner@vnet.ibm.com>
      
      	* gcc.target/powerpc/crypto-builtin-1.c: Use effective target
      	powerpc_p8vector_ok instead of powerpc_vsx_ok.
      
      	* gcc.target/powerpc/bool.c: New file, add eqv, nand, nor tests.
      
      	* lib/target-supports.exp (check_p8vector_hw_available) Add power8
      	support.
      	(check_effective_target_powerpc_p8vector_ok): Likewise.
      	(is-effective-target): Likewise.
      	(check_vect_support_and_set_flags): Likewise.
      
      
      
      Co-Authored-By: Pat Haugen <pthaugen@us.ibm.com>
      Co-Authored-By: Peter Bergner <bergner@vnet.ibm.com>
      
      From-SVN: r199767
      Michael Meissner committed
    • validate_failures.py: Fix handling of summary lines with "|" characters or empty… · 76ba1222
      validate_failures.py: Fix handling of summary lines with "|" characters or empty description fields.
      
      * testsuite-management/validate_failures.py: Fix handling of
      summary lines with "|" characters or empty description fields.
      
      From-SVN: r199765
      Brooks Moses committed
    • re PR rtl-optimization/57468 (26% performance drop on important benchmark after r199298.) · 37684c46
      2013-06-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	PR rtl-optimization/57468
      	* config/i386/i386.c (inline_secondary_memory_needed): Ignore
      	spilled pseudos.
      
      From-SVN: r199764
      Vladimir Makarov committed
    • re PR c++/43652 (wrong column number for duplicate qualifier) · a322ed0c
      2013-06-06  Paolo Carlini  <paolo.carlini@oracle.com>
      
      	PR c++/43652
      	* g++.dg/parse/error53.C: New.
      
      From-SVN: r199763
      Paolo Carlini committed
    • re PR rtl-optimization/57459 (LRA inheritance bug) · d89ae27c
      2013-06-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	PR rtl-optimization/57459
      	* lra-constraints.c (update_ebb_live_info): Fix typo for operand
      	type when setting live regs.
      
      2013-06-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	PR rtl-optimization/57459
      	* gcc.target/i386/pr57459.c: New test.
      
      From-SVN: r199762
      Vladimir Makarov committed
    • s390.opt (mlra): New option. · 3597e113
      2013-06-06  Vladimir Makarov  <vmakarov@redhat.com>
      
      	* config/s390/s390.opt (mlra): New option.
      	* config/s390/s390.c (s390_decompose_address): Check displacement
      	for all registers for LRA.
      	(s390_secondary_reload): Don't used secondary reloads for LRA.
      	(s390_lra_p): New function.
      	(TARGET_LRA_P): Define.
      	* config/s390/s390.md (*movmem_short, *clrmem_short): Change value
      	of attribute cpu_facility to zarch for the last alternative.
      	(*cmpmem_short): Ditto.
      
      From-SVN: r199754
      Vladimir Makarov committed