File: mlriscRegion.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 (38 lines) | stat: -rw-r--r-- 1,059 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
(*
 * This module implements the MLRISC annotations for describing
 * memory aliasing and control dependence.
 *
 * -- Allen
 *)

structure MLRiscRegion :> MLRISC_REGION =
struct

   datatype mutability = READONLY | IMMUTABLE | MUTABLE
   datatype region = ROOT
                   | REGION of int * mutability * string * region
                   | UNION of region list

   val counter = ref 0

   val memory = ROOT
   fun new(name,mut,parent) = 
   let val id = !counter
   in  counter := id + 1;
       REGION(!counter,mut,name,parent)
   end

   val union    = UNION
   val stack    = new("stack",MUTABLE,memory)
   val heap     = new("heap",MUTABLE,memory)
   val data     = new("data",MUTABLE,memory)
   val readonly = new("readonly",READONLY,data)

   fun toString ROOT = "root"
     | toString(REGION(_,_,name,ROOT)) = name
     | toString(REGION(_,_,name,parent)) = toString parent^"."^name
     | toString(UNION rs) = 
         String.concat(foldr (fn (r,[]) => [toString r]
                               | (r,s)  => toString r::"+"::s) [] rs)

end