Main Page   Packages   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members  

SparseLocalDefsFlowAnalysis.java

00001 package ca.mcgill.sable.soot.jimple;
00002 
00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
00004  * Jimple, a 3-address code Java(TM) bytecode representation.        *
00005  * Copyright (C) 1997, 1998 Raja Vallee-Rai (kor@sable.mcgill.ca)    *
00006  * All rights reserved.                                              *
00007  *                                                                   *
00008  * This work was done as a project of the Sable Research Group,      *
00009  * School of Computer Science, McGill University, Canada             *
00010  * (http://www.sable.mcgill.ca/).  It is understood that any         *
00011  * modification not identified as such is not covered by the         *
00012  * preceding statement.                                              *
00013  *                                                                   *
00014  * This work is free software; you can redistribute it and/or        *
00015  * modify it under the terms of the GNU Library General Public       *
00016  * License as published by the Free Software Foundation; either      *
00017  * version 2 of the License, or (at your option) any later version.  *
00018  *                                                                   *
00019  * This work is distributed in the hope that it will be useful,      *
00020  * but WITHOUT ANY WARRANTY; without even the implied warranty of    *
00021  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU *
00022  * Library General Public License for more details.                  *
00023  *                                                                   *
00024  * You should have received a copy of the GNU Library General Public *
00025  * License along with this library; if not, write to the             *
00026  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,      *
00027  * Boston, MA  02111-1307, USA.                                      *
00028  *                                                                   *
00029  * Java is a trademark of Sun Microsystems, Inc.                     *
00030  *                                                                   *
00031  * To submit a bug report, send a comment, or get the latest news on *
00032  * this project and other Sable Research Group projects, please      *
00033  * visit the web site: http://www.sable.mcgill.ca/                   *
00034  * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
00035 
00036 /*
00037  Reference Version
00038  -----------------
00039  This is the latest official version on which this file is based.
00040  The reference version is: $SootVersion: 1.beta.4 $
00041 
00042  Change History
00043  --------------
00044  A) Notes:
00045 
00046  Please use the following template.  Most recent changes should
00047  appear at the top of the list.
00048 
00049  - Modified on [date (March 1, 1900)] by [name]. [(*) if appropriate]
00050    [description of modification].
00051 
00052  Any Modification flagged with "(*)" was done as a project of the
00053  Sable Research Group, School of Computer Science,
00054  McGill University, Canada (http://www.sable.mcgill.ca/).
00055 
00056  You should add your copyright, using the following template, at
00057  the top of this file, along with other copyrights.
00058 
00059  *                                                                   *
00060  * Modifications by [name] are                                       *
00061  * Copyright (C) [year(s)] [your name (or company)].  All rights     *
00062  * reserved.                                                         *
00063  *                                                                   *
00064 
00065  B) Changes:
00066 
00067  - Modified on March 13, 1999 by Raja Vallee-Rai (rvalleerai@sable.mcgill.ca) (*)
00068    Re-organized the timers.
00069 
00070  - Modified on January 24, 1999 by Raja Vallee-Rai (rvalleerai@sable.mcgill.ca) (*)
00071    Branched off from SimpleLocalDefs.
00072    
00073  - Modified on November 2, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca) (*)
00074    Repackaged all source files and performed extensive modifications.
00075    First initial release of Soot.
00076 
00077  - Modified on 23-Jul-1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*)
00078    Renamed the uses of Hashtable to HashMap.
00079 
00080  - Modified on 15-Jun-1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*)
00081    First internal release (Version 0.1).
00082 */
00083 
00084 import ca.mcgill.sable.soot.*;
00085 import ca.mcgill.sable.util.*;
00086 
00087 class SparseLocalDefsFlowAnalysis extends ForwardFlowAnalysis
00088 {
00089     FlowSet emptySet;
00090     Map localToPreserveSet;
00091     FlowSet workingSet;
00092     LiveLocals liveLocals;
00093     
00094     public SparseLocalDefsFlowAnalysis(StmtGraph g, LiveLocals liveLocals)
00095     {
00096         super(g);
00097 
00098         this.liveLocals = liveLocals;
00099         if(Main.isProfilingOptimization)
00100                 Main.defsSetupTimer.start();
00101 
00102         emptySet = new ArraySparseSet();
00103         workingSet = (FlowSet) emptySet.clone();
00104         
00105         if(Main.isProfilingOptimization)
00106                 Main.defsSetupTimer.end();
00107 
00108         if(Main.isProfilingOptimization)
00109                 Main.defsAnalysisTimer.start();
00110 
00111         doAnalysis();
00112         
00113         if(Main.isProfilingOptimization)
00114                 Main.defsAnalysisTimer.end();
00115 
00116     }
00117     protected void copy(Object source, Object dest)
00118     {
00119         FlowSet sourceSet = (FlowSet) source,
00120             destSet = (FlowSet) dest;
00121             
00122         sourceSet.copy(destSet);
00123     }
00124     protected void flowThrough(Object inValue, Stmt stmt, Object outValue)
00125     {
00126         FlowSet in = (FlowSet) inValue, out = (FlowSet) outValue;
00127 
00128         if(stmt instanceof DefinitionStmt)
00129         {
00130             DefinitionStmt d = (DefinitionStmt) stmt;
00131 
00132             if(!(d.getLeftOp() instanceof Local))
00133             {
00134                 in.copy(out);
00135             }
00136             else {
00137 
00138                 Local local = (Local) d.getLeftOp();
00139     
00140                 // Kill all other definitions of this local
00141                 {
00142                     workingSet.clear();
00143                 
00144                     Iterator defIt = in.toList().iterator();
00145                     
00146                     while(defIt.hasNext())
00147                     {
00148                         DefinitionStmt def = (DefinitionStmt) defIt.next();
00149                         
00150                         if(def.getLeftOp() == local)
00151                             workingSet.add(def, workingSet);
00152                     }
00153                     
00154                     in.difference(workingSet, out);
00155                 }
00156                 
00157                     
00158                 // Perform generation
00159                     out.add(d, out);
00160             }
00161 
00162         }
00163         else
00164             in.copy(out);
00165             
00166         // Kill all definitions whose locals are no longer live
00167         {
00168             Iterator useBoxIt = stmt.getUseBoxes().iterator();
00169             List liveLocalsAfter = liveLocals.getLiveLocalsAfter(stmt);
00170             
00171             workingSet.clear();
00172             
00173             while(useBoxIt.hasNext())
00174             {
00175                 ValueBox useBox = (ValueBox) useBoxIt.next();
00176                 
00177                 if(useBox.getValue() instanceof Local)
00178                 {
00179                     Local l = (Local) useBox.getValue();
00180                     
00181                     if(!liveLocalsAfter.contains(l))
00182                     {
00183                         // Kill all definitions of l
00184                         
00185                         Iterator defIt = out.toList().iterator();
00186                     
00187                         while(defIt.hasNext())
00188                         {
00189                             DefinitionStmt def = (DefinitionStmt) defIt.next();
00190                             
00191                             if(def.getLeftOp() == l)
00192                                 workingSet.add(def, workingSet);
00193                         }
00194                     }
00195                 }
00196             }
00197             
00198             out.difference(workingSet, out);
00199         }
00200         
00201     }
00202     protected void merge(Object in1, Object in2, Object out)
00203     {
00204         FlowSet inSet1 = (FlowSet) in1,
00205             inSet2 = (FlowSet) in2;
00206 
00207         FlowSet outSet = (FlowSet) out;
00208 
00209         inSet1.union(inSet2, outSet);
00210     }
00211     protected Object newInitialFlow()
00212     {
00213         return emptySet.clone();
00214     }
00215 }

Generated at Thu Feb 7 06:55:22 2002 for Bandera by doxygen1.2.10 written by Dimitri van Heesch, © 1997-2001