+2017-12-21 James Greenhalgh <james.greenhalgh@arm.com>
+
+ * combine.c (simplify_set): Do not transform subregs to zero_extends
+ if the destination is not a scalar int mode.
+
2017-12-21 Eric Botcazou <ebotcazou@adacore.com>
PR c++/82872
/* If we have (set FOO (subreg:M (mem:N BAR) 0)) with M wider than N, this
would require a paradoxical subreg. Replace the subreg with a
zero_extend to avoid the reload that would otherwise be required.
- Don't do this for vector modes, as the transformation is incorrect. */
+ Don't do this unless we have a scalar integer mode, otherwise the
+ transformation is incorrect. */
enum rtx_code extend_op;
if (paradoxical_subreg_p (src)
&& MEM_P (SUBREG_REG (src))
- && !VECTOR_MODE_P (GET_MODE (src))
+ && SCALAR_INT_MODE_P (GET_MODE (src))
&& (extend_op = load_extend_op (GET_MODE (SUBREG_REG (src)))) != UNKNOWN)
{
SUBST (SET_SRC (x),