[vta] temporary work around for major DF fwprop limitation

Alexandre Oliva aoliva@redhat.com
Mon Nov 5 07:56:00 GMT 2007


The use of DF data structures in fwprop has caused it to miss several
optimizations.  For example, if we have something like:

  (set (reg A) (op (reg B) (reg C)))

and we could fwprop both B and C, the current code will only fwprop
one of them.  The problem is that op will be re-gen()-ed when we
replace B, and therefore the LOC of the use of C present in the DF
structures won't match any more.  This causes the code to refrain from
attempting to fwprop C.  Oops.

This patch does *not* fix this problem.  It just works around it to
avoid codegen changes caused by debug insns that do reference multiple
fwprop-able registers, but that end up not having all fwprop-able
occurrences replaced because of the rtx copying and DF structures
out-of-dateness.  If fwprop succeeds in all active (non-debug)
occurrences of the fwprop-able register, but references in debug insns
remain, the DEF wouldn't die at the expected point, and codegen
differences may arise.

This patch avoids such differences, at the expense, in the location
expressions, of missing rtl simplifications that might be possible and
of wrapping CONST_INTs with CONSTs to give them a mode.

I hope to revert this once fwprop is improved, possibly by myself,
such that it doesn't depend on unchanging LOCs to function.

-------------- next part --------------
A non-text attachment was scrubbed...
Name: vta-fwprop-loc-mode.patch
Type: text/x-patch
Size: 759 bytes
Desc: not available
URL: <http://gcc.gnu.org/pipermail/gcc-patches/attachments/20071105/8a2f2111/attachment.bin>
-------------- next part --------------

-- 
Alexandre Oliva         http://www.lsd.ic.unicamp.br/~oliva/
FSF Latin America Board Member         http://www.fsfla.org/
Red Hat Compiler Engineer   aoliva@{redhat.com, gcc.gnu.org}
Free Software Evangelist  oliva@{lsd.ic.unicamp.br, gnu.org}


More information about the Gcc-patches mailing list