From: Richard Kenner Date: Sat, 3 May 2003 14:30:07 +0000 (+0000) Subject: expr.c (expand_expr, [...]): Don't use gen_lowpart on non-integer modes. X-Git-Tag: releases/gcc-3.4.0~6837 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=13cf99ece09fb65a20160ae963bae51372bdada3;p=thirdparty%2Fgcc.git expr.c (expand_expr, [...]): Don't use gen_lowpart on non-integer modes. * expr.c (expand_expr, case VIEW_CONVERT_EXPR): Don't use gen_lowpart on non-integer modes. From-SVN: r66430 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 58469126a53f..f307619a02c7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -19,6 +19,9 @@ 2003-05-03 Richard Kenner + * expr.c (expand_expr, case VIEW_CONVERT_EXPR): Don't use + gen_lowpart on non-integer modes. + * stor-layout.c (place_field): When adjusting offset_align, use desired_align, not DECL_ALIGN. diff --git a/gcc/expr.c b/gcc/expr.c index b64319a08a70..7fd347be3b1d 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -7959,12 +7959,14 @@ expand_expr (exp, target, tmode, modifier) op0 = expand_expr (TREE_OPERAND (exp, 0), NULL_RTX, mode, modifier); /* If the input and output modes are both the same, we are done. - Otherwise, if neither mode is BLKmode and both are within a word, we - can use gen_lowpart. If neither is true, make sure the operand is - in memory and convert the MEM to the new mode. */ + Otherwise, if neither mode is BLKmode and both are integral and within + a word, we can use gen_lowpart. If neither is true, make sure the + operand is in memory and convert the MEM to the new mode. */ if (TYPE_MODE (type) == GET_MODE (op0)) ; else if (TYPE_MODE (type) != BLKmode && GET_MODE (op0) != BLKmode + && GET_MODE_CLASS (GET_MODE (op0)) == MODE_INT + && GET_MODE_CLASS (TYPE_MODE (type)) == MODE_INT && GET_MODE_SIZE (TYPE_MODE (type)) <= UNITS_PER_WORD && GET_MODE_SIZE (GET_MODE (op0)) <= UNITS_PER_WORD) op0 = gen_lowpart (TYPE_MODE (type), op0);