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

ForwardFlowAnalysis.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 November 2, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca) (*)
00068    Repackaged all source files and performed extensive modifications.
00069    First initial release of Soot.
00070 
00071  - Modified on 15-Jun-1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*)
00072    First internal release (Version 0.1).
00073 */
00074 
00075 import ca.mcgill.sable.soot.*;
00076 import ca.mcgill.sable.util.*;
00077 
00078 public abstract class ForwardFlowAnalysis extends FlowAnalysis
00079 {
00080     public ForwardFlowAnalysis(StmtGraph graph)
00081     {
00082         super(graph);
00083     }
00084     protected void doAnalysis()
00085     {
00086         LinkedList changedStmts = new LinkedList();
00087         HashSet changedStmtsSet = new HashSet();
00088 
00089         int numNodes = graph.size();
00090         int numComputations = 0;
00091         
00092         // Set initial values and nodes to visit.
00093         {
00094             Iterator it = graph.iterator();
00095 
00096             while(it.hasNext())
00097             {
00098                 Stmt s = (Stmt) it.next();
00099 
00100                 changedStmts.addLast(s);
00101                 changedStmtsSet.add(s);
00102 
00103                 stmtToBeforeFlow.put(s, newInitialFlow());
00104                 stmtToAfterFlow.put(s, newInitialFlow());
00105             }
00106         }
00107 
00108         // Perform fixed point flow analysis
00109         {
00110             Object previousAfterFlow = newInitialFlow();
00111 
00112             while(!changedStmts.isEmpty())
00113             {
00114                 Object beforeFlow;
00115                 Object afterFlow;
00116 
00117                 Stmt s = (Stmt) changedStmts.removeFirst();
00118 
00119                 changedStmtsSet.remove(s);
00120 
00121                 copy(stmtToAfterFlow.get(s), previousAfterFlow);
00122 
00123                 // Compute and store beforeFlow
00124                 {
00125                     List preds = graph.getPredsOf(s);
00126 
00127                     beforeFlow = stmtToBeforeFlow.get(s);
00128 
00129                     if(preds.size() == 1)
00130                         copy(stmtToAfterFlow.get(preds.get(0)), beforeFlow);
00131                     else if(preds.size() != 0)
00132                     {
00133                         Iterator predIt = preds.iterator();
00134 
00135                         copy(stmtToAfterFlow.get(predIt.next()), beforeFlow);
00136 
00137                         while(predIt.hasNext())
00138                         {
00139                             Object otherBranchFlow = stmtToAfterFlow.get(predIt.
00140 next());
00141                             merge(beforeFlow, otherBranchFlow, beforeFlow);
00142                         }
00143                     }
00144                 }
00145 
00146                 // Compute afterFlow and store it.
00147                 {
00148                     afterFlow = stmtToAfterFlow.get(s);
00149                     flowThrough(beforeFlow, s, afterFlow);
00150                     numComputations++;
00151                 }
00152 
00153                 // Update queue appropriately
00154                     if(!afterFlow.equals(previousAfterFlow))
00155                     {
00156                         Iterator succIt = graph.getSuccsOf(s).iterator();
00157 
00158                         while(succIt.hasNext())
00159                         {
00160                             Stmt succ = (Stmt) succIt.next();
00161                             
00162                             if(!changedStmtsSet.contains(succ))
00163                             {
00164                                 changedStmts.addLast(succ);
00165                                 changedStmtsSet.add(succ);
00166                             }
00167                         }
00168                     }
00169             }
00170         }
00171         
00172         // System.out.println("{" + graph.getBody().getMethod().getSignature() + "} numNodes: " + numNodes + 
00173         //    " numComputations: " + numComputations + " avg: " + Main.truncatedOf((double) numComputations / numNodes, 2));
00174         
00175         Main.totalFlowNodes += numNodes;
00176         Main.totalFlowComputations += numComputations;
00177     }
00178     protected boolean isForward()
00179     {
00180         return true;
00181     }
00182 }

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