File: mlrisc-glue.sml

package info (click to toggle)
mlton 20210117%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 58,464 kB
  • sloc: ansic: 27,682; sh: 4,455; asm: 3,569; lisp: 2,879; makefile: 2,347; perl: 1,169; python: 191; pascal: 68; javascript: 7
file content (141 lines) | stat: -rw-r--r-- 4,487 bytes parent folder | download | duplicates (5)
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
(*
 * Simple module for building the IR etc.  Doesn't do any real optimizations.
 *
 * -- Allen
 *)

functor MLRISCGlue
   (structure Asm       : INSTRUCTION_EMITTER
    structure Flowgraph : FLOWGRAPH
    structure InsnProps : INSN_PROPERTIES
    structure FreqProps : FREQUENCY_PROPERTIES
       sharing InsnProps.I = Asm.I = Flowgraph.I = FreqProps.I
       sharing Flowgraph.P = Asm.P 
   ) : MLRISC_GLUE =
struct

   structure F = Flowgraph
   structure I = F.I
 
   val mlrisc  = MLRiscControl.getFlag       "mlrisc"
   val phases  = MLRiscControl.getStringList "mlrisc-phases"
   val view_IR = MLRiscControl.getFlag       "view-IR"
   val verbose = MLRiscControl.getFlag       "verbose"

   fun error msg = MLRiscErrorMsg.error("MLRISCGlue",msg)

   structure GraphViewer = GraphViewer(AllDisplays)

   structure FormatInsn = FormatInstruction(Asm)

   structure CFG = ControlFlowGraph
      (structure I         = I
       structure PseudoOps = F.P
       structure GraphImpl = DirectedGraph
       structure InsnProps = InsnProps
       structure Asm = Asm
      )

   structure Util = CFGUtil
      (structure CFG       = CFG
       structure InsnProps = InsnProps
      )

   structure CFG2Cluster = CFG2Cluster
      (structure CFG       = CFG
       structure Util      = Util
       structure Flowgraph = Flowgraph
      )

   structure Cluster2CFG = Cluster2CFG
      (structure CFG       = CFG
       structure Util      = Util
       structure Flowgraph = Flowgraph
       structure InsnProps = InsnProps
      )
       
   structure Dom = DominatorTree(DirectedGraph)

   structure CDG = ControlDependenceGraph
      (structure Dom       = Dom
       structure GraphImpl = DirectedGraph
      )

   structure Loop = LoopStructure
      (structure Dom       = Dom
       structure GraphImpl = DirectedGraph
      )

   structure IR = MLRISC_IR
      (structure CFG         = CFG
       structure CDG         = CDG
       structure Loop        = Loop
       structure GraphViewer = GraphViewer
       structure Util        = Util
      )

   structure Guess = StaticBranchPrediction
      (structure IR        = IR
       structure InsnProps = InsnProps
       structure FreqProps = FreqProps
       val loopMultiplier=10
      )
      
   structure Liveness = LivenessAnalysis(CFG)

   structure Reshape = ReshapeBranches
     (structure IR        = IR
      structure InsnProps = InsnProps
     )

   structure BranchChaining = BranchChaining
     (structure IR        = IR
      structure InsnProps = InsnProps
     )

   structure CPR = CriticalPathReduction
     (structure IR        = IR
      structure InsnProps = InsnProps
     )

   structure ClusterGraph = ClusterGraph(Flowgraph)

   structure ClusterViewer = ClusterViewer
     (structure GraphViewer = GraphViewer
      structure ClusterGraph = ClusterGraph
      structure Asm          = Asm
     )

   fun view phase ir = if !view_IR then IR.view phase ir else ()
   fun view' cluster = if !view_IR then 
      ClusterViewer.view(ClusterGraph.clusterGraph cluster) else ()

   fun optimize cluster =
   let datatype rep = IR of IR.IR
                    | CLUSTER of F.cluster
       fun doPhase "cluster->cfg" (CLUSTER c) = IR(Cluster2CFG.cluster2cfg c)
         | doPhase "cfg->cluster" (IR cfg) = 
            CLUSTER(CFG2Cluster.cfg2cluster{cfg=cfg,relayout=false})
         | doPhase "guess" (r as IR ir) = (Guess.run ir; r)
         | doPhase "reshape"   (r as IR ir) = (Reshape.run ir; r)
         | doPhase "branch-chaining" (r as IR ir) = (BranchChaining.run ir; r)
         | doPhase "cpr"   (r as IR ir) = (CPR.run ir; r)
         | doPhase "view-cfg"  (r as IR ir) = (view "cfg" ir; r)
         | doPhase "view-dom"  (r as IR ir) = (view "dom" ir; r)
         | doPhase "view-pdom" (r as IR ir) = (view "pdom" ir; r)
         | doPhase "view-doms" (r as IR ir) = (view "doms" ir; r)
         | doPhase "view-cdg"  (r as IR ir) = (view "cdg" ir; r)
         | doPhase "view-loop" (r as IR ir) = (view "loop" ir; r)
         | doPhase "view-cluster" (r as CLUSTER c) = (view' c; r)
         | doPhase phase _ = error(phase)
       fun doPhases [] (CLUSTER c) = c
         | doPhases [] _ = error "cluster needed"
         | doPhases (phase::phases) ir = 
            (if !verbose then print("["^phase^"]\n") else (); 
             doPhases phases (doPhase phase ir))
   in  doPhases (!phases) (CLUSTER cluster)
   end

   fun codegen cluster = if !mlrisc then optimize cluster else cluster

end