-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathHeap.agda
59 lines (46 loc) · 2.38 KB
/
Heap.agda
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
module Memory.Heap (Term : Set) (Value : Term → Set) where
open import Data.Nat using (ℕ; _≟_)
open import Data.List
open import Data.Maybe
open import Data.Product using (_×_; ∃; ∃-syntax; Σ; Σ-syntax) renaming (_,_ to ⟨_,_⟩)
open import Relation.Binary.PropositionalEquality using (_≡_; refl)
open import Common.Utils
open import Common.SecurityLabels
open import Memory.Addr public
{- n ↦ V
We use an association list that is split into low- and high- halves to represent the heap.
-}
data Cell : Set where
_&_ : (V : Term) → .(Value V) → Cell
HalfHeap = List (RawAddr × Cell)
Heap = HalfHeap {- low -} × HalfHeap {- high -}
lookup-μ : Heap → Addr → Maybe Cell
lookup-μ ⟨ μᴸ , μᴴ ⟩ (a⟦ low ⟧ n) = find _≟_ μᴸ n
lookup-μ ⟨ μᴸ , μᴴ ⟩ (a⟦ high ⟧ n) = find _≟_ μᴴ n
cons-μ : Addr → (V : Term) → Value V → Heap → Heap
cons-μ (a⟦ low ⟧ n) V v ⟨ μᴸ , μᴴ ⟩ = ⟨ ⟨ n , V & v ⟩ ∷ μᴸ , μᴴ ⟩
cons-μ (a⟦ high ⟧ n) V v ⟨ μᴸ , μᴴ ⟩ = ⟨ μᴸ , ⟨ n , V & v ⟩ ∷ μᴴ ⟩
infix 10 _FreshIn_
_FreshIn_ : Addr → Heap → Set
a⟦ low ⟧ n FreshIn ⟨ μᴸ , μᴴ ⟩ = n ≡ length μᴸ
a⟦ high ⟧ n FreshIn ⟨ μᴸ , μᴴ ⟩ = n ≡ length μᴴ
{- Generate a fresh address for heap μ -}
gen-fresh : ∀ μ {ℓ} → ∃[ n ] (a⟦ ℓ ⟧ n FreshIn μ)
gen-fresh ⟨ μᴸ , μᴴ ⟩ {low } = ⟨ length μᴸ , refl ⟩
gen-fresh ⟨ μᴸ , μᴴ ⟩ {high} = ⟨ length μᴴ , refl ⟩
SizeEq : Heap → Heap → Set
SizeEq ⟨ μᴸ , μᴴ ⟩ ⟨ μᴸ′ , μᴴ′ ⟩ = length μᴸ ≡ length μᴸ′ × length μᴴ ≡ length μᴴ′
size-eq-fresh : ∀ {μ μ′} {n ℓ}
→ SizeEq μ μ′
→ a⟦ ℓ ⟧ n FreshIn μ′
-------------------------------------------------------------------------
→ a⟦ ℓ ⟧ n FreshIn μ
size-eq-fresh {ℓ = low} ⟨ eq-low , _ ⟩ fresh rewrite eq-low = fresh
size-eq-fresh {ℓ = high} ⟨ _ , eq-high ⟩ fresh rewrite eq-high = fresh
size-eq-fresh-back : ∀ {μ μ′} {n ℓ}
→ SizeEq μ μ′
→ a⟦ ℓ ⟧ n FreshIn μ
-------------------------------------------------------------------------
→ a⟦ ℓ ⟧ n FreshIn μ′
size-eq-fresh-back {ℓ = low} ⟨ eq-low , _ ⟩ fresh rewrite eq-low = fresh
size-eq-fresh-back {ℓ = high} ⟨ _ , eq-high ⟩ fresh rewrite eq-high = fresh