aboutsummaryrefslogtreecommitdiff
path: root/gcc/genopinit.c
diff options
context:
space:
mode:
authorJon Grimm <jgrimm2@us.ibm.com>2005-12-18 21:40:47 +0000
committerBen Elliston <bje@gcc.gnu.org>2005-12-19 08:40:47 +1100
commit15ed7b52cb0be60cd8f845648a265b2cffe4f963 (patch)
tree7e005c5de55a867524e5bf6183ab854c96880e3c /gcc/genopinit.c
parent5a575f77fde8efa894e6eefa20ca7e96881fe0e1 (diff)
downloadgcc-15ed7b52cb0be60cd8f845648a265b2cffe4f963.zip
gcc-15ed7b52cb0be60cd8f845648a265b2cffe4f963.tar.gz
gcc-15ed7b52cb0be60cd8f845648a265b2cffe4f963.tar.bz2
optabs.c (init_floating_libfuncs): Handle decimal float modes.
* optabs.c (init_floating_libfuncs): Handle decimal float modes. (init_optabs): Handle libfuncs for decimal float. * genopinit.c (gen_insn): Handle MODE_DECIMAL_FLOAT. * stor-layout.c (int_mode_for_mode): Likewise. * simplify-rtx.c (simplify_immed_subreg): Likewise. (simplify_unary_operation_1): Skip optimisations for decimal float modes. * varasm.c (output_constant_pool_2): Handle MODE_DECIMAL_FLOAT. * emit-rtl.c (gen_const_vector): Add assertion check. (init_emit_once): Populate const_tiny_rtx with constants in each decimal float mode. * expmed.c (extract_high_half, expand_mult_highpart_optab, expand_mult_highpart): Assert that mode is not a scalar float mode. * expr.c (convert_move): Handle conversion between decimal and binary floats of the same size. * convert.c (convert_to_real): Consider decimal float types when folding. * dwarf2out.c (base_type_die): Use DW_ATE_decimal_float to describe decimal floating point types. Co-Authored-By: Ben Elliston <bje@au.ibm.com> Co-Authored-By: Janis Johnson <janis187@us.ibm.com> From-SVN: r108762
Diffstat (limited to 'gcc/genopinit.c')
-rw-r--r--gcc/genopinit.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/genopinit.c b/gcc/genopinit.c
index 0c4a397..ec8076b 100644
--- a/gcc/genopinit.c
+++ b/gcc/genopinit.c
@@ -304,7 +304,9 @@ gen_insn (rtx insn)
|| mode_class[i] == MODE_INT
|| mode_class[i] == MODE_PARTIAL_INT
|| mode_class[i] == MODE_VECTOR_INT)
- && (! force_float || mode_class[i] == MODE_FLOAT
+ && (! force_float
+ || mode_class[i] == MODE_FLOAT
+ || mode_class[i] == MODE_DECIMAL_FLOAT
|| mode_class[i] == MODE_COMPLEX_FLOAT
|| mode_class[i] == MODE_VECTOR_FLOAT))
break;