File: instr-gen.sml

package info (click to toggle)
smlnj 110.79-8
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 82,564 kB
  • sloc: ansic: 32,532; asm: 6,314; sh: 2,296; makefile: 1,821; perl: 1,170; pascal: 295; yacc: 190; cs: 78; python: 77; lisp: 19
file content (35 lines) | stat: -rw-r--r-- 921 bytes parent folder | download | duplicates (4)
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
(*
 * Generate a linear sequence of instructions
 *)
functor InstrGen
   (structure I      : INSTRUCTIONS
    structure Stream : INSTRUCTION_STREAM
    structure CFG    : CONTROL_FLOW_GRAPH
    			where I = I
			  and P = Stream.P
   ) : INSTR_GEN =
struct
   structure C   = I.C
   structure I   = I
   structure S   = Stream
   structure CFG = CFG

   (* Pretty stupid, eh? *)
   fun newStream(instrs) =
   let fun emit i = instrs := i :: !instrs 
       fun can'tUse _ = MLRiscErrorMsg.error("InstrGen","unimplemented")
   in  Stream.STREAM
       { beginCluster   = can'tUse,
         endCluster     = can'tUse,
         emit           = emit,
         pseudoOp       = can'tUse,
         defineLabel    = can'tUse,
         entryLabel     = can'tUse,
         comment        = can'tUse,
         annotation     = can'tUse,
         getAnnotations = can'tUse,
         exitBlock      = can'tUse
       }
   end 

end