On this page:
exprs-lang-v7
exprs-lang-v7?
interp-exprs-lang-v7
exprs-unique-lang-v7
exprs-unique-lang-v7?
interp-exprs-unique-lang-v7
exprs-unsafe-data-lang-v7
exprs-unsafe-data-lang-v7?
interp-exprs-unsafe-data-lang-v7
exprs-bits-lang-v7
exprs-bits-lang-v7?
interp-exprs-bits-lang-v7
exprs-bits-lang-v7/  contexts
exprs-bits-lang-v7/  contexts?
interp-exprs-bits-lang-v7/  contexts
values-bits-lang-v7
values-bits-lang-v7?
interp-values-bits-lang-v7
imp-mf-lang-v7
imp-mf-lang-v7?
interp-imp-mf-lang-v7
proc-imp-cmf-lang-v7
proc-imp-cmf-lang-v7?
interp-proc-imp-cmf-lang-v7
imp-cmf-lang-v7
imp-cmf-lang-v7?
interp-imp-cmf-lang-v7
asm-pred-lang-v7
asm-pred-lang-v7?
interp-asm-pred-lang-v7
asm-pred-lang-v7/  locals
asm-pred-lang-v7/  locals?
interp-asm-pred-lang-v7/  locals
asm-pred-lang-v7/  undead
asm-pred-lang-v7/  undead?
interp-asm-pred-lang-v7/  undead
asm-pred-lang-v7/  conflicts
asm-pred-lang-v7/  conflicts?
interp-asm-pred-lang-v7/  conflicts
asm-pred-lang-v7/  pre-framed
asm-pred-lang-v7/  pre-framed?
interp-asm-pred-lang-v7/  pre-framed
asm-pred-lang-v7/  framed
asm-pred-lang-v7/  framed?
interp-asm-pred-lang-v7/  framed
asm-pred-lang-v7/  spilled
asm-pred-lang-v7/  spilled?
interp-asm-pred-lang-v7/  spilled
asm-pred-lang-v7/  assignments
asm-pred-lang-v7/  assignments?
interp-asm-pred-lang-v7/  assignments
nested-asm-lang-fvars-v7
nested-asm-lang-fvars-v7?
interp-nested-asm-lang-fvars-v7
nested-asm-lang-v7
nested-asm-lang-v7?
interp-nested-asm-lang-v7
block-pred-lang-v7
block-pred-lang-v7?
interp-block-pred-lang-v7
block-asm-lang-v7
block-asm-lang-v7?
interp-block-asm-lang-v7
para-asm-lang-v7
para-asm-lang-v7?
interp-para-asm-lang-v7
paren-x64-v7
paren-x64-v7?
interp-paren-x64-v7
paren-x64-rt-v7
paren-x64-rt-v7?
interp-paren-x64-rt-v7
8.10
3.1.9 v7 Languages

 (require cpsc411/langs/v7) package: cpsc411-lib

exprs-lang-v7 : grammar?

  p ::= (module (define x (lambda (x ...) value)) ... value)
     
  value ::= triv
  | (let ([x value] ...) value)
  | (if value value value)
  | (call value value ...)
     
  triv ::= x
  | fixnum
  | #t
  | #f
  | empty
  | (void)
  | (error uint8)
  | ascii-char-literal
     
  x ::= name?
  | prim-f
     
  prim-f ::= binop
  | unop
     
  binop ::= *
  | +
  | -
  | eq?
  | <
  | <=
  | >
  | >=
     
  unop ::= fixnum?
  | boolean?
  | empty?
  | void?
  | ascii-char?
  | error?
  | not
     
  fixnum ::= int61?
     
  uint8 ::= uint8?
     
  ascii-char-literal ::= ascii-char-literal?

procedure

(exprs-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the exprs-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-exprs-lang-v7 a)  any/c

  a : exprs-lang-v7?
Evaluates a exprs-lang-v7 program to a value.
  p ::= (module (define label (lambda (aloc ...) value)) ... value)
     
  value ::= triv
  | (call value value ...)
  | (let ([aloc value] ...) value)
  | (if value value value)
     
  triv ::= aloc
  | label
  | prim-f
  | fixnum
  | #t
  | #f
  | empty
  | (void)
  | (error uint8)
  | ascii-char-literal
     
  prim-f ::= binop
  | unop
     
  binop ::= *
  | +
  | -
  | <
  | eq?
  | <=
  | >
  | >=
     
  unop ::= fixnum?
  | boolean?
  | empty?
  | void?
  | ascii-char?
  | error?
  | not
     
  aloc ::= aloc?
     
  label ::= label?
     
  fixnum ::= int61?
     
  uint8 ::= uint8?
     
  ascii-char-literal ::= ascii-char-literal?

procedure

(exprs-unique-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the exprs-unique-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a exprs-unique-lang-v7 program to a value.
  p ::= (module (define label (lambda (aloc ...) value)) ... value)
     
  value ::= triv
  | (primop value ...)
  | (call value value ...)
  | (let ([aloc value] ...) value)
  | (if value value value)
     
  triv ::= aloc
  | label
  | fixnum
  | #t
  | #f
  | empty
  | (void)
  | (error uint8)
  | ascii-char-literal
     
  primop ::= binop
  | unop
     
  binop ::= unsafe-fx*
  | unsafe-fx+
  | unsafe-fx-
  | eq?
  | unsafe-fx<
  | unsafe-fx<=
  | unsafe-fx>
  | unsafe-fx>=
     
  unop ::= fixnum?
  | boolean?
  | empty?
  | void?
  | ascii-char?
  | error?
  | not
     
  aloc ::= aloc?
     
  label ::= label?
     
  fixnum ::= int61?
     
  uint8 ::= uint8?
     
  ascii-char-literal ::= ascii-char-literal?

procedure

(exprs-unsafe-data-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the exprs-unsafe-data-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a exprs-unsafe-data-lang-v7 program to a value.

exprs-bits-lang-v7 : grammar?

  p ::= (module (define label (lambda (aloc ...) value)) ... value)
     
  pred ::= (relop value value)
  | (true)
  | (false)
  | (not pred)
  | (let ([aloc value] ...) pred)
  | (if pred pred pred)
     
  value ::= triv
  | (binop value value)
  | (call value value ...)
  | (let ([aloc value] ...) value)
  | (if pred value value)
     
  triv ::= aloc
  | label
  | int64
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  aloc ::= aloc?
     
  label ::= label?
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?

procedure

(exprs-bits-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the exprs-bits-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a exprs-bits-lang-v7 program to a value.
  p ::= (module b ... tail)
     
  b ::= (define label (lambda (aloc ...) tail))
     
  pred ::= (relop value value)
  | (true)
  | (false)
  | (not pred)
  | (let ([aloc value] ...) pred)
  | (if pred pred pred)
     
  tail ::= value
  | (let ([aloc value] ...) tail)
  | (if pred tail tail)
     
  value ::= triv
  | (binop value value)
  | (call value value ...)
  | (let ([aloc value] ...) value)
  | (if pred value value)
     
  triv ::= aloc
  | label
  | int64
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  aloc ::= aloc?
     
  label ::= label?
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?

procedure

(exprs-bits-lang-v7/contexts? a)  boolean?

  a : any/c
Decides whether a is a valid program in the exprs-bits-lang-v7/contexts grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a exprs-bits-lang-v7/contexts program to a value.

values-bits-lang-v7 : grammar?

  p ::= (module (define label (lambda (aloc ...) tail)) ... tail)
     
  pred ::= (relop opand opand)
  | (true)
  | (false)
  | (not pred)
  | (let ([aloc value] ...) pred)
  | (if pred pred pred)
     
  tail ::= value
  | (let ([aloc value] ...) tail)
  | (if pred tail tail)
  | (call triv opand ...)
     
  value ::= triv
  | (binop opand opand)
  | (let ([aloc value] ...) value)
  | (if pred value value)
  | (call triv opand ...)
     
  opand ::= aloc
  | int64
     
  triv ::= opand
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  aloc ::= aloc?
     
  label ::= label?
     
  int64 ::= int64?

procedure

(values-bits-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the values-bits-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a values-bits-lang-v7 program to a value.

imp-mf-lang-v7 : grammar?

  p ::= (module (define label (lambda (aloc ...) tail)) ... tail)
     
  pred ::= (relop opand opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= value
  | (call triv opand ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  value ::= triv
  | (call triv opand ...)
  | (binop opand opand)
  | (begin effect ... value)
  | (if pred value value)
     
  effect ::= (set! aloc value)
  | (begin effect ... effect)
  | (if pred effect effect)
     
  opand ::= aloc
  | int64
     
  triv ::= opand
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  aloc ::= aloc?
     
  label ::= label?
     
  int64 ::= int64?

procedure

(imp-mf-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the imp-mf-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-imp-mf-lang-v7 a)  any/c

  a : imp-mf-lang-v7?
Evaluates a imp-mf-lang-v7 program to a value.
  p ::= 
(module (define label (lambda (aloc ...) entry)) ...
  entry)
     
  entry ::= tail
     
  pred ::= (relop opand opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= value
  | (call triv opand ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  value ::= triv
  | (binop opand opand)
  | (call triv opand ...)
     
  effect ::= (set! aloc value)
  | (begin effect ... effect)
  | (if pred effect effect)
     
  opand ::= aloc
  | int64
     
  triv ::= opand
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  aloc ::= aloc?
     
  label ::= label?
     
  int64 ::= int64?

procedure

(proc-imp-cmf-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the proc-imp-cmf-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a proc-imp-cmf-lang-v7 program to a value.

imp-cmf-lang-v7 : grammar?

  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop opand opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  value ::= triv
  | (binop opand opand)
     
  effect ::= (set! loc value)
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?
     
  int64 ::= int64?

procedure

(imp-cmf-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the imp-cmf-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-imp-cmf-lang-v7 a)  any/c

  a : imp-cmf-lang-v7?
Evaluates a imp-cmf-lang-v7 program to a value.

asm-pred-lang-v7 : grammar?

  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-asm-pred-lang-v7 a)  any/c

  a : asm-pred-lang-v7?
Evaluates a asm-pred-lang-v7 program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...)) (locals (aloc ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/locals? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/locals grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/locals program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...)) (locals (aloc ...)) (call-undead (loc ...)) (undead-out undead-set-tree/rloc?)))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/undead? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/undead grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/undead program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...)) (locals (aloc ...)) (call-undead (loc ...)) (conflicts ((loc (loc ...)) ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/conflicts? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/conflicts grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/conflicts program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (new-frames (frame ...)) (locals (aloc ...)) (call-undead (loc ...)) (conflicts ((loc (loc ...)) ...)) (assignment ((aloc loc) ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/pre-framed? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/pre-framed grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/pre-framed program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (locals (aloc ...)) (conflicts ((loc (loc ...)) ...)) (assignment ((aloc loc) ...))))
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/framed? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/framed grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/framed program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (locals (aloc ...)) (conflicts ((loc (loc ...)) ...)) (assignment ((aloc loc) ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/spilled? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/spilled grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/spilled program to a value.
  p ::= (module info (define label info tail) ... tail)
     
  info ::= (#:from-contract (info/c (assignment ((aloc loc) ...))))
     
  frame ::= (aloc ...)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg loc ...)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  opand ::= loc
  | int64
     
  triv ::= opand
  | label
     
  loc ::= rloc
  | aloc
     
  trg ::= loc
  | label
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  label ::= label?
     
  rloc ::= register?
  | fvar?

procedure

(asm-pred-lang-v7/assignments? a)  boolean?

  a : any/c
Decides whether a is a valid program in the asm-pred-lang-v7/assignments grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a asm-pred-lang-v7/assignments program to a value.
  p ::= (module (define label tail) ... tail)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  triv ::= opand
  | label
     
  opand ::= loc
  | int64
     
  trg ::= loc
  | label
     
  loc ::= reg
  | fvar
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r12
  | r13
  | r14
  | r15
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  fvar ::= fvar?
     
  label ::= label?

procedure

(nested-asm-lang-fvars-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the nested-asm-lang-fvars-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a nested-asm-lang-fvars-v7 program to a value.

nested-asm-lang-v7 : grammar?

  p ::= (module (define label tail) ... tail)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
  | (begin effect ... pred)
  | (if pred pred pred)
     
  tail ::= (jump trg)
  | (begin effect ... tail)
  | (if pred tail tail)
     
  effect ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (begin effect ... effect)
  | (if pred effect effect)
  | (return-point label tail)
     
  triv ::= opand
  | label
     
  opand ::= loc
  | int64
     
  trg ::= loc
  | label
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r12
  | r13
  | r14
  | r15
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  dispoffset ::= dispoffset?
     
  label ::= label?

procedure

(nested-asm-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the nested-asm-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a nested-asm-lang-v7 program to a value.

block-pred-lang-v7 : grammar?

  p ::= (module b ... b)
     
  b ::= (define label tail)
     
  pred ::= (relop loc opand)
  | (true)
  | (false)
  | (not pred)
     
  tail ::= (jump trg)
  | (begin s ... tail)
  | (if pred (jump trg) (jump trg))
     
  s ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
     
  triv ::= opand
  | label
     
  opand ::= loc
  | int64
     
  trg ::= loc
  | label
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r12
  | r13
  | r14
  | r15
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  dispoffset ::= dispoffset?
     
  label ::= label?

procedure

(block-pred-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the block-pred-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a block-pred-lang-v7 program to a value.

block-asm-lang-v7 : grammar?

  p ::= (module b ... b)
     
  b ::= (define label tail)
     
  tail ::= (jump trg)
  | (begin s ... tail)
  | (if (relop loc opand) (jump trg) (jump trg))
     
  s ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
     
  triv ::= opand
  | label
     
  opand ::= loc
  | int64
     
  trg ::= loc
  | label
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r12
  | r13
  | r14
  | r15
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  aloc ::= aloc?
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  dispoffset ::= dispoffset?
     
  label ::= label?

procedure

(block-asm-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the block-asm-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.
Evaluates a block-asm-lang-v7 program to a value.

para-asm-lang-v7 : grammar?

  p ::= (begin s ...)
     
  s ::= (set! loc triv)
  | (set! loc_1 (binop loc_1 opand))
  | (with-label label s)
  | (jump trg)
  | (compare loc opand)
  | (jump-if relop trg)
     
  trg ::= loc
  | label
     
  triv ::= opand
  | label
     
  opand ::= loc
  | int64
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r12
  | r13
  | r14
  | r15
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  label ::= label?
     
  dispoffset ::= dispoffset?

procedure

(para-asm-lang-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the para-asm-lang-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-para-asm-lang-v7 a)  any/c

  a : para-asm-lang-v7?
Evaluates a para-asm-lang-v7 program to a value.

paren-x64-v7 : grammar?

  p ::= (begin s ...)
     
  s ::= (set! addr int32)
  | (set! addr trg)
  | (set! reg loc)
  | (set! reg triv)
  | (set! reg_1 (binop reg_1 int32))
  | (set! reg_1 (binop reg_1 loc))
  | (with-label label s)
  | (jump trg)
  | (compare reg opand)
  | (jump-if relop label)
     
  trg ::= reg
  | label
     
  triv ::= trg
  | int64
     
  opand ::= reg
  | int64
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r10
  | r11
  | r12
  | r13
  | r14
  | r15
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int64 ::= int64?
     
  int32 ::= int32?
     
  dispoffset ::= dispoffset?
     
  label ::= label?

procedure

(paren-x64-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the paren-x64-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-paren-x64-v7 a)  any/c

  a : paren-x64-v7?
Evaluates a paren-x64-v7 program to a value.

paren-x64-rt-v7 : grammar?

  p ::= (begin s ...)
     
  s ::= (set! loc triv)
  | (set! reg fvar)
  | (set! reg_1 (binop reg_1 int32))
  | (set! reg_1 (binop reg_1 loc))
  | (jump trg)
  | (compare reg opand)
  | (jump-if relop pc-addr)
     
  trg ::= reg
  | pc-addr
     
  triv ::= trg
  | int64
     
  opand ::= reg
  | int64
     
  loc ::= reg
  | addr
     
  reg ::= rsp
  | rbp
  | rax
  | rbx
  | rcx
  | rdx
  | rsi
  | rdi
  | r8
  | r9
  | r10
  | r11
  | r12
  | r13
  | r14
  | r15
     
  addr ::= (fbp - dispoffset)
     
  fbp ::= frame-base-pointer-register?
     
  binop ::= *
  | +
  | -
  | bitwise-and
  | bitwise-ior
  | bitwise-xor
  | arithmetic-shift-right
     
  relop ::= <
  | <=
  | =
  | >=
  | >
  | !=
     
  int32 ::= int32?
     
  int64 ::= int64?
     
  label ::= label?
     
  dispoffset ::= dispoffset?

procedure

(paren-x64-rt-v7? a)  boolean?

  a : any/c
Decides whether a is a valid program in the paren-x64-rt-v7 grammar, represented as a quoted datum. The first non-terminal in the grammar defines valid programs.

procedure

(interp-paren-x64-rt-v7 a)  any/c

  a : paren-x64-rt-v7?
Evaluates a paren-x64-rt-v7 program to a value.