Home My Page Projects Code Snippets Project Openings diderot
Summary Activity Tracker Tasks SCM

SCM Repository

[diderot] View of /trunk/src/compiler/mid-il/mid-opt.sml
ViewVC logotype

View of /trunk/src/compiler/mid-il/mid-opt.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2356 - (download) (annotate)
Sun Apr 7 14:45:25 2013 UTC (6 years, 6 months ago) by jhr
File size: 1993 byte(s)
  Merging in bug fixes and language enhancements from the vis12 branch (via staging).
  Features include type promotion, the curl and colon operator, transpose, and functions.
(* mid-opt.sml
 *
 * COPYRIGHT (c) 2011 The Diderot Project (http://diderot-language.cs.uchicago.edu)
 * All rights reserved.
 *)

structure MidOptimizer : sig

    val controls : (string * bool ref * string) list

    val optimize : MidIL.program -> MidIL.program

  end = struct

  (* Value numbering for MidIL *)
    structure VN = ValueNumberingFn (DomTreeFn(MidIL))

    val contractFlag = ref true		(* controls contraction *)
    val vnFlag = ref true		(* controls value numbering *)
    val debugFlag = ref true		(* controls printing *)
    val checkFlag = ref true		(* controls IL checking *)

    val controls = [
	    ("mid-contract", contractFlag, "enable contraction for MidIL"),
	    ("mid-vn", vnFlag, "enable value-numbering for MidIL"),
	    ("mid-debug", debugFlag, "enable printing MidIL to log file [debug]"),
	    ("mid-check", checkFlag, "enable consistency checking for MidIL [debug]")
	  ]

    val timeCheck = PhaseTimer.withTimer Timers.timeMidCheck (fn arg => CheckMidIL.check arg)

    fun checkIL (phase, prog) =
          if !checkFlag andalso timeCheck ("after " ^ phase, prog)
	    then (
	      TextIO.output(TextIO.stdErr, concat[
		  "***** Internal error after ", phase,
		  ": see log file for details\n"
		]);
              MidPP.output (Log.logFile(), "MidIL after " ^ phase, prog);
	      OS.Process.exit OS.Process.failure)
          else if !debugFlag
            then (
              MidPP.output (Log.logFile(), "MidIL after " ^ phase, prog);
              prog)
            else prog

    fun transform (ctl, timer, phase, transform, prog) =
	  if !ctl
	    then checkIL(phase, PhaseTimer.withTimer timer transform prog)
	    else prog

    fun optimize prog = let
          val prog = checkIL ("translation to MidIL", prog)
	  val prog = transform (vnFlag, Timers.timeMidVN, "value numbering", VN.transform, prog)
	  val prog = transform (contractFlag, Timers.timeMidCheck, "contraction", MidContract.transform, prog)
	  in
	    prog
	  end

  end

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