Correctness proof for the branch tunneling optimization.
.
.
.
.
.
).
}.
}.
}.
.
}.
}.
.
.
.
.
).
).
.
.
.
The proof of semantic preservation is a simulation argument
based on diagrams of the following form:
st1 --------------- st2
| |
t| ?|t
| |
v v
st1'--------------- st2'
The
match_states predicate, defined below, captures the precondition
between states
st1 and
st2, as well as the postcondition between
st1' and
st2'. One transition in the source code (left) can correspond
to zero or one transition in the transformed code (right). The
"zero transition" case occurs when executing a
Lgoto instruction
in the source code that has been removed by tunneling.
In the definition of
match_states, what changes between the original and
transformed codes is mainly the control-flow
(in particular, the current program point
pc), but also some values
and memory states, since some
Vundef values can become more defined
as a consequence of eliminating useless
Lcond instructions.
).
).
.
).
.
).
).
).
).
).
).
).
).
To preserve non-terminating behaviours, we show that the transformed
code cannot take an infinity of "zero transition" cases.
We use the following measure function over source states,
which decreases strictly in the "zero transition" case.
).
.
.
.
).