2011-09-02 Richard Guenther <rguenther@suse.de>
PR tree-optimization/27460
PR middle-end/29269
* doc/md.texi (vcond): Document.
* genopinit.c (optabs): Turn vcond{,u}_optab into a conversion
optab with two modes.
* optabs.h (enum convert_optab_index): Add COI_vcond, COI_vcondu.
(enum direct_optab_index): Remove DOI_vcond, DOI_vcondu.
(vcond_optab): Adjust.
(vcondu_optab): Likewise.
(expand_vec_cond_expr_p): Adjust prototype.
* optabs.c (get_vcond_icode): Adjust.
(expand_vec_cond_expr_p): Likewise.
(expand_vec_cond_expr): Likewise.
* tree-vect-stmts.c (vect_is_simple_cond): Return the comparison
vector type.
(vectorizable_condition): Allow differing types for comparison
and result.
* config/i386/i386.c (ix86_expand_sse_cmp): Use proper mode
for the comparison.
* config/i386/sse.md (vcond<mode>): Split to
vcond<V_256:mode><VF_256:mode>, vcond<V_128:mode><VF_128:mode>,
vcond<V_128:mode><VI124_128:mode> and
vcondu<V_128:mode><VI124_128:mode>.
(vcondv2di): Change to vcond<VI8F_128:mode>v2di.
(vconduv2di): Likewise.
* config/arm/neon.md (vcond<mode>): Change to vcond*<mode><mode>.
(vcondu<mode>): Likewise.
* config/ia64/vect.md (vcond<mode>): Likewise.
(vcondu<mode>): Likewise.
(vcondv2sf): Likewise.
* config/mips/mips-ps-3d.md (vcondv2sf): Likewise.
* config/rs6000/paired.md (vcondv2sf): Likewise.
* config/rs6000/vector.md (vcond<mode>): Likewise.
(vcondu<mode>): Likewise.
* config/spu/spu.md (vcond<mode>): Likewise.
(vcondu<mode>): Likewise.
* gcc.dg/vect/vect-cond-7.c: New testcase.
From-SVN: r178480
| Name |
Last commit
|
Last update |
|---|---|---|
| .. | ||
| constraints.md | Loading commit data... | |
| crtbegin.asm | Loading commit data... | |
| crtend.asm | Loading commit data... | |
| crti.asm | Loading commit data... | |
| crtn.asm | Loading commit data... | |
| div.md | Loading commit data... | |
| elf.h | Loading commit data... | |
| freebsd.h | Loading commit data... | |
| hpux-unix2003.h | Loading commit data... | |
| hpux.h | Loading commit data... | |
| ia64-c.c | Loading commit data... | |
| ia64-modes.def | Loading commit data... | |
| ia64-opts.h | Loading commit data... | |
| ia64-protos.h | Loading commit data... | |
| ia64.c | Loading commit data... | |
| ia64.h | Loading commit data... | |
| ia64.md | Loading commit data... | |
| ia64.opt | Loading commit data... | |
| ia64intrin.h | Loading commit data... | |
| ilp32.opt | Loading commit data... | |
| itanium2.md | Loading commit data... | |
| lib1funcs.asm | Loading commit data... | |
| libgcc-glibc.ver | Loading commit data... | |
| libgcc-ia64.ver | Loading commit data... | |
| linux.h | Loading commit data... | |
| predicates.md | Loading commit data... | |
| quadlib.c | Loading commit data... | |
| sync.md | Loading commit data... | |
| sysv4.h | Loading commit data... | |
| t-glibc | Loading commit data... | |
| t-hpux | Loading commit data... | |
| t-ia64 | Loading commit data... | |
| t-vms | Loading commit data... | |
| vect.md | Loading commit data... | |
| vms-crtinit.asm | Loading commit data... | |
| vms.h | Loading commit data... | |
| vms.opt | Loading commit data... | |
| vms64.h | Loading commit data... | |
| vms_symvec_libgcc_s.opt | Loading commit data... |