Home My Page Projects Code Snippets Project Openings SML/NJ
Summary Activity Forums Tracker Lists Tasks Docs Surveys News SCM Files

SCM Repository

[smlnj] View of /sml/trunk/src/MLRISC/gc-safety/gc-typing.sml
ViewVC logotype

View of /sml/trunk/src/MLRISC/gc-safety/gc-typing.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 651 - (download) (annotate)
Thu Jun 1 18:34:03 2000 UTC (19 years, 3 months ago) by monnier
File size: 1675 byte(s)
bring revisions from the vendor branch to the trunk
(*
 * This module is responsible for propagating gc type information.
 *)
functor GCTyping
   (structure IR : MLRISC_IR
    structure GCProps : GC_PROPERTIES
    structure GCMap : GC_MAP
    structure Props : INSN_PROPERTIES
       sharing GCMap.GC = GCProps.GC
       sharing IR.I = GCProps.I = Props.I
   ) : GC_TYPING =
struct

   structure IR  = IR
   structure CFG = IR.CFG
   structure GC  = GCProps.GC
   structure G   = Graph
   structure An  = Annotations 

   fun gcTyping(IR as G.GRAPH cfg) =
       case #get GCMap.GCMAP (CFG.getAnnotations IR)
       of NONE => IR (* no gc map; do nothing *)
        | SOME gcmap =>
       let val lookup = Intmap.map gcmap
           val add    = Intmap.add gcmap
           fun update(dst,ty) = 
               (lookup dst; ()) handle _ => add(dst,ty)
           fun move(dst,src) = 
               (lookup dst; ()) handle _ => 
                   (add(dst,lookup src) handle _ => ())
           val prop = GCProps.propagate {lookup=lookup,update=update} 
           fun process(b,CFG.BLOCK{insns,...}) = 
           let fun scan [] = ()
                 | scan(i::is) =
                   (case Props.instrKind i of
                      Props.IK_COPY =>
                        let val (dst,src) = Props.moveDstSrc i
                            fun copy(d::ds,s::ss) = (move(d,s); copy(ds,ss))
                              | copy _ = ()
                        in  copy(dst,src)
                        end
                    | _ => prop i handle _ => ();
                    scan is
                   )
           in  scan(rev(!insns))
           end
       in  #forall_nodes cfg process;
           IR
       end 

end

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0