@@ -241,6 +241,15 @@ Proof.
241
241
destruct ty, (preg_of src); inv H; TailNoLabel.
242
242
Qed .
243
243
244
+ Remark save_lr_label:
245
+ forall ofs k, tail_nolabel k (save_lr ofs k).
246
+ Proof .
247
+ unfold save_lr; intros.
248
+ destruct (Int.eq (Ptrofs.to_int ofs) (mk_immed_mem_word (Ptrofs.to_int ofs))).
249
+ TailNoLabel.
250
+ eapply tail_nolabel_trans; TailNoLabel.
251
+ Qed .
252
+
244
253
Remark transl_cond_label:
245
254
forall cond args k c, transl_cond cond args k = OK c -> tail_nolabel k c.
246
255
Proof .
@@ -338,7 +347,7 @@ Lemma transl_find_label:
338
347
end .
339
348
Proof .
340
349
intros. monadInv H. destruct (zlt Ptrofs.max_unsigned (list_length_z (fn_code x))); inv EQ0.
341
- monadInv EQ. simpl.
350
+ monadInv EQ. simpl. erewrite tail_nolabel_find_label by (apply save_lr_label). simpl.
342
351
eapply transl_code_label; eauto.
343
352
Qed .
344
353
@@ -382,7 +391,8 @@ Proof.
382
391
destruct i; try (intros [A B]; apply A). intros. subst c0. repeat constructor.
383
392
- intros. monadInv H0.
384
393
destruct (zlt Ptrofs.max_unsigned (list_length_z (fn_code x))); inv EQ0. monadInv EQ.
385
- exists x; exists true; split; auto. repeat constructor.
394
+ exists x; exists (save_lr_preserves_R12 (fn_retaddr_ofs f0)); split; auto.
395
+ constructor. eapply is_tail_trans. 2: apply tail_nolabel_is_tail; apply save_lr_label. repeat constructor.
386
396
- exact transf_function_no_overflow.
387
397
Qed .
388
398
@@ -854,7 +864,10 @@ Opaque loadind.
854
864
generalize EQ; intros EQ'. monadInv EQ'.
855
865
destruct (zlt Ptrofs.max_unsigned (list_length_z (fn_code x0))); inversion EQ1. clear EQ1. subst x0.
856
866
monadInv EQ0.
857
- set (tfbody := Pallocframe (fn_stacksize f) (fn_link_ofs f) :: Pstr IR14 IR13 (SOimm (Ptrofs.to_int (fn_retaddr_ofs f))) :: x0) in *.
867
+ set (ra_ofs := fn_retaddr_ofs f) in *.
868
+ set (ra_ofs' := Ptrofs.to_int ra_ofs) in *.
869
+ set (tfbody := Pallocframe (fn_stacksize f) (fn_link_ofs f) ::
870
+ save_lr ra_ofs (Pcfi_rel_offset ra_ofs' :: x0)) in *.
858
871
set (tf := {| fn_sig := Mach.fn_sig f; fn_code := tfbody |}) in *.
859
872
unfold store_stack in *.
860
873
exploit Mem.alloc_extends. eauto. eauto. apply Zle_refl. apply Zle_refl.
@@ -865,32 +878,40 @@ Opaque loadind.
865
878
intros [m3' [P Q]].
866
879
(* Execution of function prologue *)
867
880
set (rs2 := nextinstr (rs0#IR12 <- (parent_sp s) #IR13 <- (Vptr stk Ptrofs.zero))).
868
- set (rs3 := nextinstr rs2).
881
+ edestruct (save_lr_correct tge tf ra_ofs (Pcfi_rel_offset ra_ofs' :: x0) rs2) as (rs3 & X & Y & Z).
882
+ change (rs2 IR13) with sp. change (rs2 IR14) with (rs0 IR14). rewrite ATLR. eexact P.
883
+ set (rs4 := nextinstr rs3).
869
884
assert (EXEC_PROLOGUE:
870
885
exec_straight tge tf
871
886
(fn_code tf) rs0 m'
872
- x0 rs3 m3').
887
+ x0 rs4 m3').
888
+ {
873
889
change (fn_code tf) with tfbody; unfold tfbody.
874
- apply exec_straight_two with rs2 m2'.
890
+ eapply exec_straight_trans with (rs2 := rs2) (m2 := m2').
891
+ apply exec_straight_one.
875
892
unfold exec_instr. rewrite C. fold sp.
876
893
rewrite <- (sp_val _ _ _ AG). unfold Tptr, chunk_of_type, Archi.ptr64 in F. rewrite F. auto.
877
- simpl. auto.
878
- simpl. unfold exec_store. change (rs2 IR14) with (rs0 IR14).
879
- rewrite Ptrofs.add_zero_l. simpl. unfold Tptr, chunk_of_type, Archi.ptr64 in P. simpl in P.
880
- rewrite Ptrofs.add_zero_l in P. rewrite ATLR. rewrite Ptrofs.of_int_to_int by auto.
881
- rewrite P. auto. auto. auto.
882
- left; exists (State rs3 m3'); split.
894
+ auto.
895
+ eapply exec_straight_trans with (rs2 := rs3) (m2 := m3').
896
+ eexact X.
897
+ apply exec_straight_one.
898
+ simpl; reflexivity. reflexivity.
899
+ }
900
+ (* After the function prologue is the code for the function body *)
901
+ exploit exec_straight_steps_2; eauto using functions_transl. omega. constructor.
902
+ intros (ofsbody & U & V).
903
+ (* Conclusions *)
904
+ left; exists (State rs4 m3'); split.
883
905
eapply exec_straight_steps_1; eauto. omega. constructor.
884
- econstructor; eauto.
885
- change (rs3 PC) with (Val.offset_ptr (Val.offset_ptr (rs0 PC) Ptrofs.one) Ptrofs.one).
886
- rewrite ATPC. simpl. constructor; eauto.
887
- eapply code_tail_next_int. omega.
888
- eapply code_tail_next_int. omega. constructor.
889
- unfold rs3, rs2.
890
- apply agree_nextinstr. apply agree_nextinstr.
906
+ econstructor; eauto. rewrite U. econstructor; eauto.
907
+ apply agree_nextinstr.
908
+ apply agree_undef_regs2 with rs2.
909
+ apply agree_nextinstr.
891
910
eapply agree_change_sp.
892
911
apply agree_undef_regs with rs0; eauto.
893
- intros. Simpl. congruence.
912
+ intros; Simpl.
913
+ congruence.
914
+ intros; apply Y; eauto with asmgen.
894
915
895
916
- (* external function *)
896
917
exploit functions_translated; eauto.
0 commit comments