------- Comment #2 from steven at gcc dot gnu dot org 2009-07-09 09:59 -------
Maybe we can fix this in expand instead: if we see (x & CONST) and CONST is a
masking constant that isn't a legitimate constant for the the target, then see
if the sum of the rtx_cost of expressing the mask as shifts is less than the
rtx_cost of a load and an AND.
I think (but I'm not sure...) that if you do this with a peephole, you're too
late to avoid the constant pool.
Is this also a size issue?
--
steven at gcc dot gnu dot org changed:
What |Removed |Added
----------------------------------------------------------------------------
Status|UNCONFIRMED |NEW
Ever Confirmed|0 |1
Last reconfirmed|0000-00-00 00:00:00 |2009-07-09 09:59:30
date| |
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=40697