aboutsummaryrefslogtreecommitdiff
path: root/qfloat.c
diff options
context:
space:
mode:
authorAurelien Jarno <aurelien@aurel32.net>2012-09-11 12:31:21 +0200
committerAurelien Jarno <aurelien@aurel32.net>2012-09-22 15:10:21 +0200
commite590d4e6b3c73b38a9d9ed10c898f73ed8a29f1d (patch)
tree0d5439a680e4fbb3524c9ae1cac6309943fe9314 /qfloat.c
parentb80bb016d8c8e9d74345a90ab6dac1cb547904e0 (diff)
downloadqemu-e590d4e6b3c73b38a9d9ed10c898f73ed8a29f1d.zip
qemu-e590d4e6b3c73b38a9d9ed10c898f73ed8a29f1d.tar.gz
qemu-e590d4e6b3c73b38a9d9ed10c898f73ed8a29f1d.tar.bz2
tcg/optimize: rework copy progagation
The copy propagation pass tries to keep track what is a copy of what and what has copy of what, and in addition it keep a circular list of of all the copies. Unfortunately this doesn't fully work: a mov from a temp which has a state "COPY" changed it into a state "HAS_COPY". Later when this temp is used again, it is considered has not having copy and thus no propagation is done. This patch fixes that by removing the hiearchy between copies, and thus only keeping a "COPY" state both meaning "is a copy" and "has a copy". The decision of which copy to use is deferred to the actual temp replacement. At this stage there is not one best choice to do, but only better choices than others. For doing the best choice the operation would have to be parsed in reversed to know if a temp is going to be used later or not. That what is done by the liveness analysis. At this stage it is known that globals will be always live, that local temps will be dead at the end of the translation block, and that the temps will be dead at the end of the basic block. This means that this stage should try to replace temps by local temps or globals and local temps by globals. Reviewed-by: Richard Henderson <rth@twiddle.net> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
Diffstat (limited to 'qfloat.c')
0 files changed, 0 insertions, 0 deletions