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 }