From: Richard Sandiford Date: Mon, 19 Dec 2011 21:19:13 +0000 (+0000) Subject: lower-subreg.c (can_decompose_p): Check every word of a hard register. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=488c8379f425d9cfefa65eb2e393ca71f1cf65c0;p=gcc.git lower-subreg.c (can_decompose_p): Check every word of a hard register. gcc/ * lower-subreg.c (can_decompose_p): Check every word of a hard register. From-SVN: r182500 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 02c8dce7e3e..37509933734 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2011-12-19 Richard Sandiford + + * lower-subreg.c (can_decompose_p): Check every word of a hard + register. + 2011-12-19 Sandra Loosemore Tom de Vries diff --git a/gcc/lower-subreg.c b/gcc/lower-subreg.c index 85aa29891bf..779cc5f40de 100644 --- a/gcc/lower-subreg.c +++ b/gcc/lower-subreg.c @@ -634,8 +634,15 @@ can_decompose_p (rtx x) unsigned int regno = REGNO (x); if (HARD_REGISTER_NUM_P (regno)) - return (validate_subreg (word_mode, GET_MODE (x), x, UNITS_PER_WORD) - && HARD_REGNO_MODE_OK (regno, word_mode)); + { + unsigned int byte, num_bytes; + + num_bytes = GET_MODE_SIZE (GET_MODE (x)); + for (byte = 0; byte < num_bytes; byte += UNITS_PER_WORD) + if (simplify_subreg_regno (regno, GET_MODE (x), byte, word_mode) < 0) + return false; + return true; + } else return !bitmap_bit_p (subreg_context, regno); }