extend.texi (PowerPC Built-in Functions): Document new powerpc extended divide, bcd, pack/unpack 128-bit, builtin functions. [gcc] 2014-04-24 Michael Meissner <meissner@linux.vnet.ibm.com> * doc/extend.texi (PowerPC Built-in Functions): Document new powerpc extended divide, bcd, pack/unpack 128-bit, builtin functions. (PowerPC AltiVec/VSX Built-in Functions): Likewise. * config/rs6000/predicates.md (const_0_to_3_operand): New predicate to match 0..3 integer constants. * config/rs6000/rs6000-builtin.def (BU_DFP_MISC_1): Add new macros to support adding miscellaneous builtin functions. (BU_DFP_MISC_2): Likewise. (BU_P7_MISC_1): Likewise. (BU_P7_MISC_2): Likewise. (BU_P8V_MISC_3): Likewise. (BU_MISC_1): Likewise. (BU_MISC_2): Likewise. (DIVWE): Add extended divide builtin functions. (DIVWEO): Likewise. (DIVWEU): Likewise. (DIVWEUO): Likewise. (DIVDE): Likewise. (DIVDEO): Likewise. (DIVDEU): Likewise. (DIVDEUO): Likewise. (DXEX): Add decimal floating-point builtin functions. (DXEXQ): Likewise. (DDEDPD): Likewise. (DDEDPDQ): Likewise. (DENBCD): Likewise. (DENBCDQ): Likewise. (DIEX): Likewise. (DIEXQ): Likewise. (DSCLI): Likewise. (DSCLIQ): Likewise. (DSCRI): Likewise. (DSCRIQ): Likewise. (CDTBCD): Add new BCD builtin functions. (CBCDTD): Likewise. (ADDG6S): Likewise. (BCDADD): Likewise. (BCDADD_LT): Likewise. (BCDADD_EQ): Likewise. (BCDADD_GT): Likewise. (BCDADD_OV): Likewise. (BCDSUB): Likewise. (BCDSUB_LT): Likewise. (BCDSUB_EQ): Likewise. (BCDSUB_GT): Likewise. (BCDSUB_OV): Likewise. (PACK_TD): Add new pack/unpack 128-bit type builtin functions. (UNPACK_TD): Likewise. (PACK_TF): Likewise. (UNPACK_TF): Likewise. (UNPACK_TF_0): Likewise. (UNPACK_TF_1): Likewise. (PACK_V1TI): Likewise. (UNPACK_V1TI): Likewise. * config/rs6000/rs6000.c (rs6000_builtin_mask_calculate): Add support for decimal floating point builtin functions. (rs6000_expand_ternop_builtin): Add checks for the new builtin functions that take constant arguments. (rs6000_invalid_builtin): Add decimal floating point builtin support. (rs6000_init_builtins): Setup long double, _Decimal64, and _Decimal128 types for new builtin functions. (builtin_function_type): Set the unsigned flags appropriately for the new builtin functions. (rs6000_opt_masks): Add support for decimal floating point builtin functions. * config/rs6000/rs6000.h (RS6000_BTM_DFP): Add support for decimal floating point builtin functions. (RS6000_BTM_COMMON): Likewise. (RS6000_BTI_long_double): Likewise. (RS6000_BTI_dfloat64): Likewise. (RS6000_BTI_dfloat128): Likewise. (long_double_type_internal_node): Likewise. (dfloat64_type_internal_node): Likewise. (dfloat128_type_internal_node): Likewise. * config/rs6000/altivec.h (UNSPEC_BCDADD): Add support for ISA 2.07 bcd arithmetic instructions. (UNSPEC_BCDSUB): Likewise. (UNSPEC_BCD_OVERFLOW): Likewise. (UNSPEC_BCD_ADD_SUB): Likewise. (bcd_add_sub): Likewise. (BCD_TEST): Likewise. (bcd<bcd_add_sub>): Likewise. (bcd<bcd_add_sub>_test): Likewise. (bcd<bcd_add_sub>_test2): Likewise. (bcd<bcd_add_sub>_<code>): Likewise. (peephole2 for combined bcd ops): Likewise. * config/rs6000/dfp.md (UNSPEC_DDEDPD): Add support for new decimal floating point builtin functions. (UNSPEC_DENBCD): Likewise. (UNSPEC_DXEX): Likewise. (UNSPEC_DIEX): Likewise. (UNSPEC_DSCLI): Likewise. (UNSPEC_DSCRI): Likewise. (D64_D128): Likewise. (dfp_suffix): Likewise. (dfp_ddedpd_<mode>): Likewise. (dfp_denbcd_<mode>): Likewise. (dfp_dxex_<mode>): Likewise. (dfp_diex_<mode>): Likewise. (dfp_dscli_<mode>): Likewise. (dfp_dscri_<mode>): Likewise. * config/rs6000/rs6000.md (UNSPEC_ADDG6S): Add support for new BCD builtin functions. (UNSPEC_CDTBCD): Likewise. (UNSPEC_CBCDTD): Likewise. (UNSPEC_DIVE): Add support for new extended divide builtin functions. (UNSPEC_DIVEO): Likewise. (UNSPEC_DIVEU): Likewise. (UNSPEC_DIVEUO): Likewise. (UNSPEC_UNPACK_128BIT): Add support for new builtin functions to pack/unpack 128-bit types. (UNSPEC_PACK_128BIT): Likewise. (idiv_ldiv): New mode attribute to set the 32/64-bit divide type. (udiv<mode>3): Use idiv_ldiv mode attribute. (div<mode>3): Likewise. (addg6s): Add new BCD builtin functions. (cdtbcd): Likewise. (cbcdtd): Likewise. (UNSPEC_DIV_EXTEND): Add support for new extended divide instructions. (div_extend): Likewise. (div<div_extend>_<mode>"): Likewise. (FP128_64): Add support for new builtin functions to pack/unpack 128-bit types. (unpack<mode>): Likewise. (unpacktf_0): Likewise. (unpacktf_1): Likewise. (unpack<mode>_dm): Likewise. (unpack<mode>_nodm): Likewise. (pack<mode>): Likewise. (unpackv1ti): Likewise. (packv1ti): Likewise. [gcc/testsuite] 2014-04-24 Michael Meissner <meissner@linux.vnet.ibm.com> * gcc.target/powerpc/pack01.c: New test to test the new pack and unpack builtin functionss for 128-bit types. * gcc.target/powerpc/pack02.c: Likewise. * gcc.target/powerpc/pack03.c: Likewise. * gcc.target/powerpc/extend-divide-1.c: New test to test extended divide builtin functionss. * gcc.target/powerpc/extend-divide-2.c: Likewise. * gcc.target/powerpc/bcd-1.c: New test for the new BCD builtin functions. * gcc.target/powerpc/bcd-2.c: Likewise. * gcc.target/powerpc/bcd-3.c: Likewise. * gcc.target/powerpc/dfp-builtin-1.c: New test for the new DFP builtin functionss. * gcc.target/powerpc/dfp-builtin-2.c: Likewise. From-SVN: r209768
| Name |
Last commit
|
Last update |
|---|---|---|
| .. | ||
| 40x.md | Loading commit data... | |
| 440.md | Loading commit data... | |
| 476.h | Loading commit data... | |
| 476.md | Loading commit data... | |
| 476.opt | Loading commit data... | |
| 601.md | Loading commit data... | |
| 603.md | Loading commit data... | |
| 6xx.md | Loading commit data... | |
| 7450.md | Loading commit data... | |
| 750cl.h | Loading commit data... | |
| 7xx.md | Loading commit data... | |
| 8540.md | Loading commit data... | |
| a2.md | Loading commit data... | |
| aix-stdint.h | Loading commit data... | |
| aix.h | Loading commit data... | |
| aix43.h | Loading commit data... | |
| aix51.h | Loading commit data... | |
| aix52.h | Loading commit data... | |
| aix53.h | Loading commit data... | |
| aix61.h | Loading commit data... | |
| aix64.opt | Loading commit data... | |
| altivec.h | Loading commit data... | |
| altivec.md | Loading commit data... | |
| biarch64.h | Loading commit data... | |
| cell.md | Loading commit data... | |
| constraints.md | Loading commit data... | |
| crypto.md | Loading commit data... | |
| darwin.h | Loading commit data... | |
| darwin.md | Loading commit data... | |
| darwin.opt | Loading commit data... | |
| darwin64.h | Loading commit data... | |
| darwin7.h | Loading commit data... | |
| darwin8.h | Loading commit data... | |
| default64.h | Loading commit data... | |
| dfp.md | Loading commit data... | |
| driver-rs6000.c | Loading commit data... | |
| e300c2c3.md | Loading commit data... | |
| e500.h | Loading commit data... | |
| e500mc.md | Loading commit data... | |
| e500mc64.md | Loading commit data... | |
| e5500.md | Loading commit data... | |
| e6500.md | Loading commit data... | |
| eabi.h | Loading commit data... | |
| eabialtivec.h | Loading commit data... | |
| eabisim.h | Loading commit data... | |
| eabispe.h | Loading commit data... | |
| freebsd.h | Loading commit data... | |
| freebsd64.h | Loading commit data... | |
| genopt.sh | Loading commit data... | |
| host-darwin.c | Loading commit data... | |
| host-ppc64-darwin.c | Loading commit data... | |
| htm.md | Loading commit data... | |
| htmintrin.h | Loading commit data... | |
| htmxlintrin.h | Loading commit data... | |
| linux.h | Loading commit data... | |
| linux64.h | Loading commit data... | |
| linux64.opt | Loading commit data... | |
| linuxaltivec.h | Loading commit data... | |
| linuxspe.h | Loading commit data... | |
| lynx.h | Loading commit data... | |
| milli.exp | Loading commit data... | |
| mpc.md | Loading commit data... | |
| netbsd.h | Loading commit data... | |
| option-defaults.h | Loading commit data... | |
| paired.h | Loading commit data... | |
| paired.md | Loading commit data... | |
| power4.md | Loading commit data... | |
| power5.md | Loading commit data... | |
| power6.md | Loading commit data... | |
| power7.md | Loading commit data... | |
| power8.md | Loading commit data... | |
| ppc-asm.h | Loading commit data... | |
| ppu_intrinsics.h | Loading commit data... | |
| predicates.md | Loading commit data... | |
| rs6000-builtin.def | Loading commit data... | |
| rs6000-c.c | Loading commit data... | |
| rs6000-cpus.def | Loading commit data... | |
| rs6000-linux.c | Loading commit data... | |
| rs6000-modes.def | Loading commit data... | |
| rs6000-opts.h | Loading commit data... | |
| rs6000-protos.h | Loading commit data... | |
| rs6000-tables.opt | Loading commit data... | |
| rs6000.c | Loading commit data... | |
| rs6000.h | Loading commit data... | |
| rs6000.md | Loading commit data... | |
| rs6000.opt | Loading commit data... | |
| rs64.md | Loading commit data... | |
| rtems.h | Loading commit data... | |
| secureplt.h | Loading commit data... | |
| si2vmx.h | Loading commit data... | |
| singlefp.h | Loading commit data... | |
| spe.h | Loading commit data... | |
| spe.md | Loading commit data... | |
| spu2vmx.h | Loading commit data... | |
| sync.md | Loading commit data... | |
| sysv4.h | Loading commit data... | |
| sysv4.opt | Loading commit data... | |
| sysv4le.h | Loading commit data... | |
| t-aix43 | Loading commit data... | |
| t-aix52 | Loading commit data... | |
| t-darwin64 | Loading commit data... | |
| t-darwin8 | Loading commit data... | |
| t-fprules | Loading commit data... | |
| t-freebsd64 | Loading commit data... | |
| t-linux | Loading commit data... | |
| t-linux64 | Loading commit data... | |
| t-linux64bele | Loading commit data... | |
| t-linux64le | Loading commit data... | |
| t-linux64lebe | Loading commit data... | |
| t-lynx | Loading commit data... | |
| t-netbsd | Loading commit data... | |
| t-ppccomm | Loading commit data... | |
| t-ppcendian | Loading commit data... | |
| t-ppcgas | Loading commit data... | |
| t-ppcos | Loading commit data... | |
| t-rs6000 | Loading commit data... | |
| t-rtems | Loading commit data... | |
| t-spe | Loading commit data... | |
| t-vxworks | Loading commit data... | |
| t-vxworksae | Loading commit data... | |
| t-xilinx | Loading commit data... | |
| titan.md | Loading commit data... | |
| vec_types.h | Loading commit data... | |
| vector.md | Loading commit data... | |
| vsx.md | Loading commit data... | |
| vxworks.h | Loading commit data... | |
| x-aix | Loading commit data... | |
| x-darwin | Loading commit data... | |
| x-darwin64 | Loading commit data... | |
| x-linux-relax | Loading commit data... | |
| x-rs6000 | Loading commit data... | |
| xcoff.h | Loading commit data... | |
| xfpu.h | Loading commit data... | |
| xfpu.md | Loading commit data... | |
| xilinx.h | Loading commit data... | |
| xilinx.opt | Loading commit data... |