-
Notifications
You must be signed in to change notification settings - Fork 108
/
Copy pathUMM_termstypes.ML
178 lines (141 loc) · 5.38 KB
/
UMM_termstypes.ML
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
(*
* Copyright 2020, Data61, CSIRO (ABN 41 687 119 230)
*
* SPDX-License-Identifier: BSD-2-Clause
*)
signature UMM_TERMS_TYPES =
sig
val typ_tag_ty : typ
val mk_tag_type : typ -> typ
val empty_tag_tm : typ -> string -> term
val heap_desc_ty : typ
val heap_raw_ty : typ
val typ_name_ty : typ
val mk_aux_guard_t : term
val mk_aux_heap_desc_t : term
val mk_auxupd_ty : typ -> typ
val mk_hrs_htd_update_t : term
val mk_hrs_mem_t : term
val mk_hrs_htd_t : term
val mk_hrs_mem_update_t : term
val mk_ptr_safe : term -> term -> term
val mk_field_lookup : typ * string -> term
val mk_field_lookup_nofs : typ * string -> term
val mk_fg_cons_tm : typ -> typ -> string -> theory -> term
val mk_sizetd : term -> term
val mk_aligntd : term -> term
val mk_typ_info_tm : typ -> term
val mk_typ_info_of : typ -> term
val mk_typ_name_of : typ -> term
val mk_td_names : term -> term
val mk_sizeof : term -> term
val mk_tag_pad_tm : typ -> typ -> string -> theory -> term
val final_pad_tm : typ -> term
end
structure UMM_TermsTypes : UMM_TERMS_TYPES =
struct
open TermsTypes
fun field_desc_ty ty =
Type(@{type_name "CTypesDefs.field_desc_ext"}, [ty, unit])
fun mk_typ_desc_ty ty = Type(@{type_name "CTypesDefs.typ_desc"}, [ty])
fun mk_tag_type ty = mk_typ_desc_ty (field_desc_ty ty)
val normalisor_ty = mk_list_type word8 --> mk_list_type word8
val typ_tag_ty = mk_typ_desc_ty normalisor_ty
val tag_rung_ty = bool
val heap_desc_ty = addr_ty --> (mk_prod_ty (bool,nat --> mk_option_ty (mk_prod_ty (typ_tag_ty,tag_rung_ty))))
val heap_raw_ty = mk_prod_ty (heap_ty, heap_desc_ty)
val mk_auxupd_val_ty = mk_prod_ty (bool, heap_desc_ty --> heap_desc_ty)
fun mk_auxupd_ty ty = ty --> mk_auxupd_val_ty
val mk_aux_guard_t = Const(@{const_name "fst"}, mk_auxupd_val_ty --> bool)
val mk_aux_heap_desc_t = Const(@{const_name "snd"}, mk_auxupd_val_ty --> heap_desc_ty
--> heap_desc_ty)
val mk_hrs_htd_update_t = @{const "HeapRawState.hrs_htd_update"}
val mk_hrs_mem_t = @{const "HeapRawState.hrs_mem"}
val mk_hrs_htd_t = @{const "HeapRawState.hrs_htd"}
val mk_hrs_mem_update_t = @{const "HeapRawState.hrs_mem_update"}
val typ_name_ty = string_ty
fun mk_typ_name_tm ty =
Const("CTypesDefs.typ_name", mk_tag_type ty --> typ_name_ty)
fun empty_tag_tm ty nm =
Const(@{const_name "empty_typ_info"}, string_ty --> mk_tag_type ty) $
mk_string nm
fun final_pad_tm ty =
Const(@{const_name "final_pad"}, mk_tag_type ty --> mk_tag_type ty)
fun field_access_tm recty ty nm thy = let
val recname = case recty of Type(rn, []) => rn
| _ => raise Fail "field_access_tm: Record type \
\looks unlikely"
val access_ty = recty --> ty
val fldnm = Sign.intern_const thy (recname ^ "." ^ nm)
in
Const(fldnm, access_ty)
end
fun field_update_tm recty ty nm thy = let
val recname = case recty of Type(rn, []) => rn
| _ => raise Fail "field_access_tm: Record type \
\looks unlikely"
fun tytr ty = ty --> ty
val update_ty = ty --> tytr recty
val field_update_ty = tytr ty --> tytr recty
val fldnm = Sign.intern_const thy (recname ^ "." ^ nm)
val field_update = Const (suffix Record.updateN fldnm,
field_update_ty)
val K_rec_ty = ty --> tytr ty
in
Const(@{const_name "Fun.comp"}, field_update_ty --> K_rec_ty --> update_ty) $
field_update $ K_rec ty
end
fun mk_tag_pad_tm recty ty nm thy = let
fun tytr ty = ty --> ty
val access_ty = recty --> ty
val update_ty = ty --> tytr recty
val tag_ty = mk_tag_type recty
val tag_pad_combine = Const(@{const_name "CompoundCTypes.ti_typ_pad_combine"},
mk_itself_type ty --> access_ty --> update_ty --> field_name_ty -->
tytr tag_ty)
val field_access = field_access_tm recty ty nm thy
val field_update = field_update_tm recty ty nm thy
in
tag_pad_combine $ mk_TYPE ty $ field_access $ field_update $ mk_string nm
end
fun mk_fg_cons_tm recty ty nm thy =
Const(@{const_name "fg_cons"}, (recty --> ty) --> (ty --> recty --> recty)
--> bool) $
field_access_tm recty ty nm thy $
field_update_tm recty ty nm thy
fun mk_td_names tm =
Const(@{const_name "td_names"}, type_of tm --> mk_set_type string_ty) $ tm
fun mk_sizetd tm = let
val ty = type_of tm
in
Const(@{const_name "size_td"}, ty --> nat) $ tm
end
fun mk_aligntd tm = let
val ty = type_of tm
in
Const(@{const_name "align_td"}, ty --> nat) $ tm
end
fun mk_typ_info_tm ty =
Const("CTypesDefs.typ_info_t", mk_itself_type ty --> mk_tag_type ty)
fun mk_typ_info_of ty = mk_typ_info_tm ty $ mk_TYPE ty
fun mk_field_lookup (ty,f) =
Const(@{const_name "CTypesDefs.field_lookup"},
mk_tag_type ty --> qualified_field_name_ty -->
nat --> mk_option_ty (mk_prod_ty (mk_tag_type ty, nat))) $
mk_typ_info_of ty $
mk_list_cons (mk_string f, Free("fs", qualified_field_name_ty)) $
Free("m", nat)
fun mk_field_lookup_nofs (ty,f) =
Const(@{const_name "CTypesDefs.field_lookup"},
mk_tag_type ty --> qualified_field_name_ty -->
nat --> mk_option_ty (mk_prod_ty (mk_tag_type ty, nat))) $
mk_typ_info_of ty $
mk_list_singleton (mk_string f) $
mk_nat_numeral 0
fun mk_typ_name_of ty = mk_typ_name_tm ty $ mk_typ_info_of ty
fun mk_ptr_safe t d = let
val ptrty = type_of t
in
Const(@{const_name "ptr_safe"}, ptrty --> heap_desc_ty --> bool) $ t $ d
end
end