File: clusterBBScheduler.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 (30 lines) | stat: -rw-r--r-- 838 bytes parent folder | download | duplicates (8)
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
(*
 * Simple minded basic block scheduling
 *) 
functor ClusterBasicBlockScheduler
   (structure Flowgraph : FLOWGRAPH
    structure BBSched   : BASIC_BLOCK_SCHEDULER
       sharing Flowgraph.I = BBSched.I
    val cpu : string ref
   ) : CLUSTER_OPTIMIZATION =
struct

   structure F = Flowgraph
   type flowgraph = F.cluster

   val name = "Basic Block Scheduling"

   fun run(cluster as F.CLUSTER{blocks, annotations, ...}) = 
   if #contains MLRiscAnnotations.NO_OPTIMIZATION (!annotations)
   then cluster
   else
   let val schedule = BBSched.schedule {cpu= !cpu}
       fun sched(F.BBLOCK{annotations, insns, ...}) = 
            if #contains MLRiscAnnotations.NO_OPTIMIZATION (!annotations) 
            then ()
            else insns := schedule(! insns)
         | sched _ = ()
   in  app sched blocks;
       cluster
   end
end