PR middle-end/50161 * simplify-rtx.c (simplify_const_unary_operation): If op is CONST_INT, don't look at op_mode, but use instead mode. * optabs.c (add_equal_note): For FFS, CLZ, CTZ, CLRSB, POPCOUNT, PARITY and BSWAP use operand mode for operation and TRUNCATE/ZERO_EXTEND if needed. * doc/rtl.texi (ffs, clrsb, clz, ctz, popcount, parity, bswap): Document that operand mode must be same as operation mode, or VOIDmode. * config/avr/avr.md (paritysi2, *parityqihi2.libgcc, *paritysihi2.libgcc, popcountsi2, *popcountsi2.libgcc, *popcountqihi2.libgcc, clzsi2, *clzsihi2.libgcc, ctzsi2, *ctzsihi2.libgcc, ffssi2, *ffssihi2.libgcc): For unary ops use the mode of operand for the operation and add truncate or zero_extend around if needed. * config/c6x/c6x.md (ctzdi2): Likewise. * config/bfin/bfin.md (clrsbsi2, signbitssi2): Likewise. * gcc.dg/pr50161.c: New test. From-SVN: r177991
| Name |
Last commit
|
Last update |
|---|---|---|
| .. | ||
| bfin-modes.def | Loading commit data... | |
| bfin-opts.h | Loading commit data... | |
| bfin-protos.h | Loading commit data... | |
| bfin.c | Loading commit data... | |
| bfin.h | Loading commit data... | |
| bfin.md | Loading commit data... | |
| bfin.opt | Loading commit data... | |
| constraints.md | Loading commit data... | |
| crti.s | Loading commit data... | |
| crtlibid.s | Loading commit data... | |
| crtn.s | Loading commit data... | |
| elf.h | Loading commit data... | |
| lib1funcs.asm | Loading commit data... | |
| libgcc-bfin.ver | Loading commit data... | |
| linux.h | Loading commit data... | |
| predicates.md | Loading commit data... | |
| print-sysroot-suffix.sh | Loading commit data... | |
| rtems.h | Loading commit data... | |
| sync.md | Loading commit data... | |
| t-bfin | Loading commit data... | |
| t-bfin-elf | Loading commit data... | |
| t-bfin-linux | Loading commit data... | |
| t-bfin-uclinux | Loading commit data... | |
| t-rtems | Loading commit data... | |
| uclinux.h | Loading commit data... |