This repository has been archived on 2022-12-27. You can view files and clone it, but cannot push or open issues or pull requests.
compilateurMIPS/compiler.ml

74 lines
1.6 KiB
OCaml
Raw Normal View History

2022-12-06 20:39:15 +01:00
open Ast.IR
open Mips
2022-12-06 22:22:48 +01:00
module Env = Map.Make (String)
2022-12-06 20:39:15 +01:00
2022-12-08 19:55:22 +01:00
type info =
{ asm : instr list
; env : loc Env.t
; fpo : int (* FP offset *)
2022-12-09 14:14:33 +01:00
; cnt : int (* Counter *)
; ret : string (* Return *)
2022-12-08 19:55:22 +01:00
}
2022-12-08 14:04:46 +01:00
let compile_value = function
2022-12-06 22:22:48 +01:00
| Int n -> [ Li (V0, n) ]
2022-12-08 21:30:39 +01:00
| Bool b -> [ Li (V0, if b then 1 else 0) ]
2022-12-06 22:22:48 +01:00
;;
2022-12-06 20:39:15 +01:00
2022-12-09 14:45:59 +01:00
let rec compile_expr env = function
2022-12-08 14:04:46 +01:00
| Val v -> compile_value v
2022-12-08 19:55:22 +01:00
| Var v -> [ Lw (V0, Env.find v env) ]
2022-12-09 14:45:59 +01:00
| Call (f, args) ->
let ca =
List.map
(fun a -> compile_expr env a @ [ Addi (SP, SP, -4); Sw (V0, Mem (SP, 0)) ])
args
in
List.flatten ca @ Env.find f Baselib.builtins
2022-12-08 19:55:22 +01:00
;;
let compile_instr info = function
| Decl v ->
{ info with env = Env.add v (Mem (FP, -info.fpo)) info.env; fpo = info.fpo + 4 }
| Assign (v, e) ->
{ info with
asm = info.asm @ compile_expr info.env e @ [ Sw (V0, Env.find v info.env) ]
}
2022-12-09 14:14:33 +01:00
| Return e -> { info with asm = info.asm @ compile_expr info.env e @ [ B info.ret ] }
2022-12-08 19:55:22 +01:00
;;
let rec compile_block info = function
| [] -> info
| i :: b -> compile_block (compile_instr info i) b
;;
2022-12-09 14:14:33 +01:00
let compile_body body counter =
let compiled =
compile_block
{ asm = []
; env = Env.empty
; fpo = 8
; cnt = counter + 1
; ret = "ret" ^ string_of_int counter
}
body
in
2022-12-08 19:55:22 +01:00
[ Addi (SP, SP, -compiled.fpo)
; Sw (RA, Mem (SP, compiled.fpo - 4))
; Sw (FP, Mem (SP, compiled.fpo - 8))
; Addi (FP, SP, compiled.fpo - 4)
]
@ compiled.asm
2022-12-09 14:14:33 +01:00
@ [ Label compiled.ret
; Addi (SP, SP, compiled.fpo)
; Lw (RA, Mem (FP, 0))
; Lw (FP, Mem (FP, -4))
; Jr RA
]
2022-12-08 14:04:46 +01:00
;;
2022-12-08 19:55:22 +01:00
let compile ir =
2022-12-09 14:14:33 +01:00
let asm = compile_body ir 0 in
2022-12-09 14:45:59 +01:00
{ text = asm; data = [] }
2022-12-08 19:55:22 +01:00
;;