forked from mit-plv/koika
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLoweredSyntax.v
54 lines (49 loc) · 1.81 KB
/
LoweredSyntax.v
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
(*! Language | Lowered ASTs (weakly-typed) !*)
Require Export Koika.Common Koika.Environments Koika.Types Koika.Primitives.
Import PrimTyped CircuitSignatures.
Section Syntax.
Context {pos_t var_t rule_name_t reg_t ext_fn_t: Type}.
Context {R: reg_t -> nat}.
Context {Sigma: ext_fn_t -> CExternalSignature}.
Inductive action : lsig -> nat -> Type :=
| Fail {sig} sz : action sig sz
| Var {sig} (k: var_t) {sz: nat}
(m: member sz sig) : action sig sz
| Const {sig} {sz: nat}
(cst: bits sz) : action sig sz
| Assign {sig} (k: var_t) {sz: nat}
(m: member sz sig) (ex: action sig sz) : action sig 0
| Seq {sig sz}
(r1: action sig 0)
(r2: action sig sz) : action sig sz
| Bind {sig} (k: var_t) {sz sz'}
(ex: action sig sz)
(body: action (List.cons sz sig) sz') : action sig sz'
| If {sig sz}
(cond: action sig 1)
(tbranch fbranch: action sig sz) : action sig sz
| Read {sig}
(port: Port)
(idx: reg_t): action sig (R idx)
| Write {sig}
(port: Port) (idx: reg_t)
(value: action sig (R idx)) : action sig 0
| Unop {sig}
(fn: fbits1)
(arg1: action sig (arg1Sig (CSigma1 fn)))
: action sig (retSig (CSigma1 fn))
| Binop {sig}
(fn: fbits2)
(arg1: action sig (arg1Sig (CSigma2 fn)))
(arg2: action sig (arg2Sig (CSigma2 fn)))
: action sig (retSig (CSigma2 fn))
| ExternalCall {sig}
(fn: ext_fn_t)
(arg: action sig (arg1Sig (Sigma fn)))
: action sig (retSig (Sigma fn))
| APos {sig sz} (pos: pos_t) (a: action sig sz)
: action sig sz.
Definition rule := action nil 0.
End Syntax.
Arguments rule pos_t var_t {reg_t ext_fn_t} R Sigma : assert.
Arguments action pos_t var_t {reg_t ext_fn_t} R Sigma sig sz : assert.