Recognition of combined operations, addressing modes and conditions
during the CSE phase.
Require Import FunInd.
Require Import Coqlib.
Require Import AST.
Require Import Integers.
Require Import Values.
Require Import Memory.
Require Import Op.
Require Import Registers.
Require Import RTL.
Require Import CSEdomain.
Require Import CombineOp.
Section COMBINE.
Variable ge:
genv.
Variable sp:
val.
Variable m:
mem.
Variable get:
valnum ->
option rhs.
Variable valu:
valuation.
Hypothesis get_sound:
forall v rhs,
get v =
Some rhs ->
rhs_eval_to valu ge sp m rhs (
valu v).
Lemma get_op_sound:
forall v op vl,
get v =
Some (
Op op vl) ->
eval_operation ge sp op (
map valu vl)
m =
Some (
valu v).
Proof.
intros.
exploit get_sound;
eauto.
intros REV;
inv REV;
auto.
Qed.
Ltac UseGetSound :=
match goal with
| [
H:
get _ =
Some _ |- _ ] =>
let x :=
fresh "EQ" in (
generalize (
get_op_sound _ _ _
H);
intros x;
simpl in x;
FuncInv)
end.
Lemma combine_compimm_ne_0_sound:
forall x cond args,
combine_compimm_ne_0 get x =
Some(
cond,
args) ->
eval_condition cond (
map valu args)
m =
Val.cmp_bool Cne (
valu x) (
Vint Int.zero) /\
eval_condition cond (
map valu args)
m =
Val.cmpu_bool (
Mem.valid_pointer m)
Cne (
valu x) (
Vint Int.zero).
Proof.
intros until args.
functional induction (
combine_compimm_ne_0 get x);
intros EQ;
inv EQ.
UseGetSound.
rewrite <-
H.
destruct (
eval_condition cond (
map valu args)
m);
simpl;
auto.
destruct b;
auto.
UseGetSound.
rewrite <-
H.
destruct v;
simpl;
auto.
UseGetSound.
rewrite <-
H.
destruct v;
simpl;
auto.
rewrite Int.xor_is_zero;
auto.
Qed.
Lemma combine_compimm_eq_0_sound:
forall x cond args,
combine_compimm_eq_0 get x =
Some(
cond,
args) ->
eval_condition cond (
map valu args)
m =
Val.cmp_bool Ceq (
valu x) (
Vint Int.zero) /\
eval_condition cond (
map valu args)
m =
Val.cmpu_bool (
Mem.valid_pointer m)
Ceq (
valu x) (
Vint Int.zero).
Proof.
Lemma combine_compimm_eq_1_sound:
forall x cond args,
combine_compimm_eq_1 get x =
Some(
cond,
args) ->
eval_condition cond (
map valu args)
m =
Val.cmp_bool Ceq (
valu x) (
Vint Int.one) /\
eval_condition cond (
map valu args)
m =
Val.cmpu_bool (
Mem.valid_pointer m)
Ceq (
valu x) (
Vint Int.one).
Proof.
Lemma combine_compimm_ne_1_sound:
forall x cond args,
combine_compimm_ne_1 get x =
Some(
cond,
args) ->
eval_condition cond (
map valu args)
m =
Val.cmp_bool Cne (
valu x) (
Vint Int.one) /\
eval_condition cond (
map valu args)
m =
Val.cmpu_bool (
Mem.valid_pointer m)
Cne (
valu x) (
Vint Int.one).
Proof.
Theorem combine_cond_sound:
forall cond args cond' args',
combine_cond get cond args =
Some(
cond',
args') ->
eval_condition cond' (
map valu args')
m =
eval_condition cond (
map valu args)
m.
Proof.
Theorem combine_cond'_sound:
forall cond args res res',
combine_cond' cond args =
Some res' ->
eval_condition cond (
map valu args)
m =
Some res ->
res =
res'.
Proof.
Theorem combine_addr_sound:
forall addr args addr' args',
combine_addr get addr args =
Some(
addr',
args') ->
eval_addressing ge sp addr' (
map valu args') =
eval_addressing ge sp addr (
map valu args).
Proof.
intros.
functional inversion H;
subst.
UseGetSound.
simpl;
rewrite <-
H0.
rewrite Val.add_assoc.
auto.
Qed.
Theorem combine_op_sound:
forall op args op' args' r,
combine_op get op args =
Some(
op',
args') ->
eval_operation ge sp op (
map valu args)
m =
Some r ->
exists r',
eval_operation ge sp op' (
map valu args')
m =
Some r' /\
Val.lessdef r r'.
Proof.
intros.
functional inversion H;
subst.
-
UseGetSound;
simpl.
econstructor.
rewrite <-
H0.
split.
simpl.
rewrite <-
H1.
rewrite Val.add_assoc.
auto.
auto.
-
Opaque Val.sub.
UseGetSound;
simpl.
econstructor;
split.
rewrite <-
H0.
simpl.
change (
Vint (
Int.add m0 n))
with (
Val.add (
Vint m0) (
Vint n)).
rewrite Val.sub_add_l.
rewrite H1.
auto.
auto.
-
UseGetSound;
simpl.
econstructor;
split.
rewrite <-
H0.
Transparent Val.sub.
simpl.
rewrite <-
H1.
destruct v;
simpl;
auto.
repeat rewrite Int.sub_add_opp.
rewrite Int.add_assoc.
rewrite Int.neg_add_distr.
decEq.
decEq.
decEq.
apply Int.add_commut.
auto.
-
UseGetSound;
simpl.
exists r;
split.
rewrite <-
H1.
generalize (
Int.eq_spec p m0).
intros.
rewrite <-
H0.
simpl.
rewrite <-
H1.
rewrite Val.and_assoc.
simpl.
fold p.
rewrite H1.
auto.
UseGetSound;
simpl.
rewrite <-
H1.
rewrite H8 in H2.
rewrite H2.
reflexivity.
auto.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
generalize (
Int.eq_spec p m0);
intros.
destruct v;
simpl;
auto.
rewrite Int.and_assoc.
fold p.
reflexivity.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
destruct v;
simpl;
auto.
unfold Int.rolm.
rewrite Int.and_assoc.
generalize (
Int.eq_spec p m0).
intros.
rewrite H8 in H2.
rewrite <-
H2.
unfold p.
rewrite Int.and_assoc.
rewrite Int.and_idem.
reflexivity.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
destruct v;
simpl;
auto.
unfold Int.rolm.
rewrite Int.and_assoc.
reflexivity.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
rewrite Val.or_assoc.
auto.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
rewrite Val.xor_assoc.
auto.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
rewrite <-
Val.rolm_zero.
rewrite Val.rolm_rolm.
rewrite (
Int.add_commut Int.zero).
rewrite Int.add_zero.
auto.
-
UseGetSound;
simpl.
exists r;
split;
auto.
rewrite <-
H0.
simpl.
rewrite <-
H1.
rewrite Val.rolm_rolm.
auto.
-
exists Vtrue;
split;
auto.
inv H0.
destruct (
eval_condition cond (
map valu args)
m)
eqn:?;
auto.
rewrite (
combine_cond'_sound cond args b true);
eauto.
-
exists Vfalse;
split;
auto.
inv H0.
destruct (
eval_condition cond (
map valu args)
m)
eqn:?;
auto.
rewrite (
combine_cond'_sound cond args b false);
eauto.
-
exists r;
split;
auto.
decEq;
decEq.
simpl.
erewrite combine_cond_sound;
eauto.
-
exists (
valu x).
simpl in H0.
destruct (
eval_condition cond (
map valu args1)
m)
eqn:?;
simpl;
split;
auto;
inv H0;
auto.
rewrite (
combine_cond'_sound cond args1 b true);
eauto.
destruct (
valu x),
ty;
auto.
-
exists (
valu y).
simpl in H0.
destruct (
eval_condition cond (
map valu args1)
m)
eqn:?;
simpl;
split;
auto;
inv H0;
auto.
rewrite (
combine_cond'_sound cond args1 b false);
eauto.
destruct (
valu y),
ty;
auto.
-
exists (
valu y);
split;
auto.
inv H0.
destruct (
eval_condition cond (
map valu args1)
m);
auto.
simpl.
destruct b, (
valu y),
ty;
auto.
-
exists r;
split;
auto.
rewrite <-
H0.
simpl.
erewrite combine_cond_sound;
eauto.
Qed.
End COMBINE.