File: clusterGraph.sig

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 (33 lines) | stat: -rw-r--r-- 826 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
(*
 * This gives a cluster a graph view so that all graph based algorithms
 * can be applied on the cluster.  The view is readonly though. 
 *
 * -- Allen
 *)
signature CLUSTER_GRAPH =
sig

   structure F : FLOWGRAPH
   structure I : INSTRUCTIONS
   structure W : FREQ
     sharing F.W = W
     sharing F.I = I

   type info
   type block = F.block
   type edge_info = W.freq ref

   type cfg = (block,edge_info,info) Graph.graph

   val clusterGraph   : F.cluster -> cfg
   val cluster        : cfg -> F.cluster
   val table          : cfg -> block Array.array
   val isTakenBranch  : edge_info Graph.edge -> bool

   val annotations    : cfg -> Annotations.annotations ref

   val insns          : block -> I.instruction list ref
   val freq           : block -> W.freq ref
   val liveOut        : block -> I.C.cellset

end