Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Open sidebar
Iris
Fairis
Commits
c62bf902
Commit
c62bf902
authored
Mar 15, 2016
by
Robbert Krebbers
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Formalize one_shot example program.
The proof is not pretty, though...
parent
21ceb92f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
139 additions
and
0 deletions
+139
-0
_CoqProject
_CoqProject
+1
-0
heap_lang/one_shot.v
heap_lang/one_shot.v
+138
-0
No files found.
_CoqProject
View file @
c62bf902
...
@@ -88,6 +88,7 @@ heap_lang/par.v
...
@@ -88,6 +88,7 @@ heap_lang/par.v
heap_lang/tests.v
heap_lang/tests.v
heap_lang/substitution.v
heap_lang/substitution.v
heap_lang/assert.v
heap_lang/assert.v
heap_lang/one_shot.v
barrier/barrier.v
barrier/barrier.v
barrier/specification.v
barrier/specification.v
barrier/protocol.v
barrier/protocol.v
...
...
heap_lang/one_shot.v
0 → 100644
View file @
c62bf902
From
iris
.
algebra
Require
Import
one_shot
dec_agree
.
From
iris
.
heap_lang
Require
Import
heap
assert
wp_tactics
notation
.
Import
uPred
.
Definition
one_shot_example
:
val
:=
λ
:
<>
,
let:
"x"
:=
ref
(
InjL
#
0
)
in
(
(
*
tryset
*
)
(
λ
:
"n"
,
CAS
'
"x"
(
InjL
#
0
)
(
InjR
'
"n"
)),
(
*
check
*
)
(
λ
:
<>
,
let:
"y"
:=
!
'
"x"
in
λ
:
<>
,
match:
'
"y"
with
InjL
<>
=>
#()
|
InjR
"n"
=>
match:
!
'
"x"
with
InjL
<>
=>
Assert
#
false
|
InjR
"m"
=>
Assert
(
'
"n"
=
'
"m"
)
end
end
)).
Class
one_shotG
Σ
:=
OneShotG
{
one_shot_inG
:>
inG
heap_lang
Σ
(
one_shotR
(
dec_agreeR
Z
))
}
.
Definition
one_shotGF
:
gFunctorList
:=
[
GFunctor
(
constRF
(
one_shotR
(
dec_agreeR
Z
)))].
Instance
inGF_one_shotG
Σ
:
inGFs
heap_lang
Σ
one_shotGF
→
one_shotG
Σ
.
Proof
.
intros
[
?
_
];
split
;
apply
:
inGF_inG
.
Qed
.
Section
proof
.
Context
{
Σ
:
gFunctors
}
`
{!
heapG
Σ
,
!
one_shotG
Σ
}
.
Context
(
heapN
N
:
namespace
)
(
HN
:
heapN
⊥
N
).
Local
Notation
iProp
:=
(
iPropG
heap_lang
Σ
).
Definition
one_shot_inv
(
γ
:
gname
)
(
l
:
loc
)
:
iProp
:=
(
l
↦
InjLV
#
0
★
own
γ
OneShotPending
∨
∃
n
:
Z
,
l
↦
InjRV
#
n
★
own
γ
(
Shot
(
DecAgree
n
)))
%
I
.
Lemma
wp_one_shot
(
Φ
:
val
→
iProp
)
:
(
heap_ctx
heapN
★
∀
f1
f2
:
val
,
(
∀
n
:
Z
,
WP
f1
#
n
{{
λ
w
,
w
=
#
true
∨
w
=
#
false
}}
)
★
WP
f2
#()
{{
λ
g
,
WP
g
#()
{{
λ
_
,
True
}}
}}
-
★
Φ
(
f1
,
f2
)
%
V
)
⊢
WP
one_shot_example
#()
{{
Φ
}}
.
Proof
.
wp_let
.
wp
eapply
wp_alloc
;
eauto
with
I
.
apply
forall_intro
=>
l
;
apply
wand_intro_l
.
eapply
sep_elim_True_l
;
first
by
apply
(
own_alloc
OneShotPending
).
rewrite
!
pvs_frame_r
;
apply
wp_strip_pvs
.
rewrite
!
sep_exist_r
;
apply
exist_elim
=>
γ
.
(
*
TODO
:
this
is
horrible
*
)
trans
(
heap_ctx
heapN
★
(
|==>
inv
N
(
one_shot_inv
γ
l
))
★
(
∀
f1
f2
:
val
,
(
∀
n
:
Z
,
WP
f1
#
n
{{
λ
w
,
w
=
#
true
∨
w
=
#
false
}}
)
★
WP
f2
#()
{{
λ
g
,
WP
g
#()
{{
λ
_
,
True
}}
}}
-
★
Φ
(
f1
,
f2
)
%
V
))
%
I
.
{
ecancel
[
heap_ctx
_
;
∀
_
,
_
]
%
I
.
rewrite
-
inv_alloc
// -later_intro.
apply
or_intro_l
'
.
solve_sep_entails
.
}
rewrite
pvs_frame_r
pvs_frame_l
;
apply
wp_strip_pvs
;
wp_let
.
rewrite
!
assoc
2
!
forall_elim
;
eapply
wand_apply_r
'
;
first
done
.
rewrite
(
always_sep_dup
(
_
★
_
));
apply
sep_mono
.
-
apply
forall_intro
=>
n
.
wp_let
.
eapply
(
wp_inv_timeless
_
_
_
(
one_shot_inv
γ
l
));
rewrite
/=
?
to_of_val
;
eauto
10
with
I
.
rewrite
(
True_intro
(
inv
_
_
))
right_id
.
apply
wand_intro_r
;
rewrite
sep_or_l
;
apply
or_elim
.
+
rewrite
-
wp_pvs
.
wp
eapply
wp_cas_suc
;
rewrite
/=
?
to_of_val
;
eauto
with
I
ndisj
.
rewrite
(
True_intro
(
heap_ctx
_
))
left_id
.
ecancel
[
l
↦
_
]
%
I
;
apply
wand_intro_l
.
rewrite
(
own_update
);
(
*
FIXME
:
canonical
structures
are
not
working
*
)
last
by
apply
(
one_shot_update_shoot
(
DecAgree
n
:
dec_agreeR
_
)).
rewrite
pvs_frame_l
;
apply
pvs_mono
,
sep_intro_True_r
;
eauto
with
I
.
rewrite
-
later_intro
/
one_shot_inv
-
or_intro_r
-
(
exist_intro
n
).
solve_sep_entails
.
+
rewrite
sep_exist_l
;
apply
exist_elim
=>
m
.
eapply
wp_cas_fail
with
(
v
'
:=
InjRV
#
m
)
(
q
:=
1
%
Qp
);
rewrite
/=
?
to_of_val
;
eauto
with
I
ndisj
;
strip_later
.
ecancel
[
l
↦
_
]
%
I
;
apply
wand_intro_l
,
sep_intro_True_r
;
eauto
with
I
.
rewrite
-
later_intro
/
one_shot_inv
-
or_intro_r
-
(
exist_intro
m
).
solve_sep_entails
.
-
wp_seq
.
wp_focus
(
Load
(
%
l
))
%
I
.
eapply
(
wp_inv_timeless
_
_
_
(
one_shot_inv
γ
l
));
rewrite
/=
?
to_of_val
;
eauto
10
with
I
.
apply
wand_intro_r
.
trans
(
heap_ctx
heapN
★
inv
N
(
one_shot_inv
γ
l
)
★
∃
v
,
l
↦
v
★
((
v
=
InjLV
#
0
★
own
γ
OneShotPending
)
∨
∃
n
:
Z
,
v
=
InjRV
#
n
★
own
γ
(
Shot
(
DecAgree
n
))))
%
I
.
{
rewrite
assoc
.
apply
sep_mono_r
,
or_elim
.
+
rewrite
-
(
exist_intro
(
InjLV
#
0
)).
rewrite
-
or_intro_l
const_equiv
//.
solve_sep_entails
.
+
apply
exist_elim
=>
n
.
rewrite
-
(
exist_intro
(
InjRV
#
n
))
-
(
exist_intro
n
).
apply
sep_mono_r
,
or_intro_r
'
,
sep_intro_True_l
;
eauto
with
I
.
}
rewrite
!
sep_exist_l
;
apply
exist_elim
=>
w
.
eapply
wp_load
with
(
q
:=
1
%
Qp
)
(
v
:=
w
);
eauto
with
I
ndisj
.
rewrite
-
later_intro
;
cancel
[
l
↦
w
]
%
I
.
rewrite
-
later_intro
;
apply
wand_intro_l
;
rewrite
-
later_intro
.
trans
(
heap_ctx
heapN
★
inv
N
(
one_shot_inv
γ
l
)
★
one_shot_inv
γ
l
★
(
w
=
InjLV
#
0
∨
(
∃
n
:
Z
,
w
=
InjRV
#
n
★
own
γ
(
Shot
(
DecAgree
n
)))))
%
I
.
{
cancel
[
heap_ctx
heapN
].
rewrite
!
sep_or_l
;
apply
or_elim
.
+
rewrite
-
or_intro_l
.
ecancel
[
inv
_
_
]
%
I
.
rewrite
[(
_
★
_
)
%
I
]
comm
-
assoc
.
apply
const_elim_sep_l
=>->
.
rewrite
const_equiv
// right_id /one_shot_inv -or_intro_l .
solve_sep_entails
.
+
rewrite
-
or_intro_r
!
sep_exist_l
;
apply
exist_elim
=>
n
.
rewrite
-
(
exist_intro
n
).
ecancel
[
inv
_
_
]
%
I
.
rewrite
[(
_
★
_
)
%
I
]
comm
-
assoc
.
apply
const_elim_sep_l
=>->
.
rewrite
const_equiv
// left_id /one_shot_inv -or_intro_r.
rewrite
-
(
exist_intro
n
).
rewrite
-
(
dec_agree_core_id
(
DecAgree
n
))
-
(
Shot_core
(
DecAgree
n
:
dec_agreeR
_
))
{
1
}
(
always_sep_dup
(
own
_
_
)).
solve_sep_entails
.
}
cancel
[
one_shot_inv
γ
l
].
(
*
FIXME
:
why
aren
'
t
laters
stripped
?
*
)
wp_let
.
rewrite
-
later_intro
.
wp_seq
.
rewrite
-
later_intro
.
rewrite
!
sep_or_l
;
apply
or_elim
.
{
rewrite
assoc
.
apply
const_elim_sep_r
=>->
.
wp_case
;
wp_seq
;
eauto
with
I
.
}
rewrite
!
sep_exist_l
;
apply
exist_elim
=>
n
.
rewrite
[(
w
=
_
★
_
)
%
I
]
comm
!
assoc
;
apply
const_elim_sep_r
=>->
.
(
*
FIXME
:
why
do
we
need
to
fold
?
*
)
wp_case
;
fold
of_val
.
wp_let
.
wp_focus
(
Load
(
%
l
))
%
I
.
eapply
(
wp_inv_timeless
_
_
_
(
one_shot_inv
γ
l
));
rewrite
/=
?
to_of_val
;
eauto
10
with
I
.
rewrite
(
True_intro
(
inv
_
_
))
right_id
.
apply
wand_intro_r
;
rewrite
sep_or_l
;
apply
or_elim
.
+
rewrite
(
True_intro
(
heap_ctx
_
))
(
True_intro
(
l
↦
_
))
!
left_id
.
rewrite
-
own_op
own_valid_l
one_shot_validI
/=
left_absorb
.
apply
False_elim
.
+
rewrite
!
sep_exist_l
;
apply
exist_elim
=>
m
.
eapply
wp_load
with
(
q
:=
1
%
Qp
)
(
v
:=
InjRV
#
m
);
eauto
with
I
ndisj
;
strip_later
.
cancel
[
l
↦
InjRV
#
m
]
%
I
.
apply
wand_intro_r
.
rewrite
(
True_intro
(
heap_ctx
heapN
))
left_id
.
rewrite
-
own_op
own_valid_l
one_shot_validI
Shot_op
/=
discrete_valid
.
rewrite
-
assoc
.
apply
const_elim_sep_l
=>
/
dec_agree_op_inv
[
->
].
rewrite
dec_agree_idemp
-
later_intro
.
apply
sep_intro_True_r
.
{
rewrite
/
one_shot_inv
-
or_intro_r
-
(
exist_intro
m
).
solve_sep_entails
.
}
wp_case
;
fold
of_val
.
wp_let
.
rewrite
-
wp_assert
'
.
wp_op
;
by
eauto
using
later_intro
with
I
.
Qed
.
End
proof
.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment