http://gcc.gnu.org/bugzilla/show_bug.cgi?id=51895

--- Comment #4 from Jakub Jelinek <jakub at gcc dot gnu.org> 2012-01-19 
10:16:07 UTC ---
(In reply to comment #3)
> >                 bftype = TREE_TYPE (base);
> >                 if (TYPE_MODE (TREE_TYPE (exp)) != BLKmode)
> >                   bftype = TREE_TYPE (exp);
> >                 return expand_expr (build3 (BIT_FIELD_REF, bftype,
> >                                             base,
> >                                             TYPE_SIZE (TREE_TYPE (exp)),
> >                                             bit_offset),
> >                                     target, tmode, modifier);
> > base here is TImode (x PARM_DECL), but exp is BLKmode, so this returns a 
> > TImode
> > pseudo.  Shouldn't it store it into a BLKmode temporary and return that MEM
> > instead?
> 
> Using a BIT_FIELD_REF looked most convenient.  Using extract_bit_field
> may also be an option (which I suppose is what the above ends up doing?)

I think if exp is BLKmode, then we don't want to do a BIT_FIELD_REF nor
extract_bit_field.  We IMHO need to store base into a temporary and just adjust
the MEM.  Or extract the bit field and then store it into a temporary and
adjust, but the former looks easier.

Reply via email to