specification.v 1.12 KB
Newer Older
1
From iris.program_logic Require Export hoare.
Ralf Jung's avatar
Ralf Jung committed
2 3
From iris.heap_lang.lib.barrier Require Export barrier.
From iris.heap_lang.lib.barrier Require Import proof.
Robbert Krebbers's avatar
Robbert Krebbers committed
4
From iris.heap_lang Require Import proofmode.
5 6 7
Import uPred.

Section spec.
8
Context `{!heapG Σ} `{!barrierG Σ}.
9

10
Lemma barrier_spec (N : namespace) :
11
   recv send : loc  iProp Σ -n> iProp Σ,
12
    ( P, {{ True }} newbarrier #()
Ralf Jung's avatar
Ralf Jung committed
13
                     {{ v,  l : loc, v = #l  recv l P  send l P }}) 
14
    ( l P, {{ send l P  P }} signal #l {{ _, True }}) 
15
    ( l P, {{ recv l P }} wait #l {{ _, P }}) 
16
    ( l P Q, recv l (P  Q) ={N}=> recv l P  recv l Q) 
17
    ( l P Q, (P - Q) - recv l P - recv l Q).
18
Proof.
19
  exists (λ l, CofeMor (recv N l)), (λ l, CofeMor (send N l)).
20
  split_and?; simpl.
21
  - iIntros (P) "!# _". iApply (newbarrier_spec _ P with "[]"); [done..|].
Ralf Jung's avatar
Ralf Jung committed
22 23 24
    iNext. eauto.
  - iIntros (l P) "!# [Hl HP]". iApply (signal_spec with "[$Hl $HP]"). by eauto.
  - iIntros (l P) "!# Hl". iApply (wait_spec with "Hl"). eauto.
25
  - iIntros (l P Q) "!#". by iApply recv_split.
Robbert Krebbers's avatar
Robbert Krebbers committed
26
  - apply recv_weaken.
27 28
Qed.
End spec.