Mercurial > hg > Members > kono > jpf-core
view src/main/gov/nasa/jpf/vm/ConstInsnPathTime.java @ 0:61d41facf527
initial v8 import (history reset)
author | Peter Mehlitz <Peter.C.Mehlitz@nasa.gov> |
---|---|
date | Fri, 23 Jan 2015 10:14:01 -0800 |
parents | |
children |
line wrap: on
line source
/* * Copyright (C) 2014, United States Government, as represented by the * Administrator of the National Aeronautics and Space Administration. * All rights reserved. * * The Java Pathfinder core (jpf-core) platform is licensed under the * Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0. * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package gov.nasa.jpf.vm; import gov.nasa.jpf.Config; import gov.nasa.jpf.ListenerAdapter; /** * time model that uses instruction count along current path to deduce * the execution time. * * NOTE: the requirement that time has to be strictly increasing along a path * means we cannot skip the initialization */ public class ConstInsnPathTime extends ListenerAdapter implements TimeModel { // note - this class is not public since we want to make sure this listener // is the only one using this type static class TimeVal { final long time; TimeVal (long t){ time = t; } } VM vm; int perInsnTime; // simple constant time assumed for each instruction long transitionStartTime; public ConstInsnPathTime (VM vm, Config conf){ perInsnTime = conf.getInt("vm.time.per_insn", 1); vm.addListener(this); this.vm = vm; } protected long computeTime (){ ThreadInfo tiCurrent = vm.getCurrentThread(); long t = tiCurrent.getExecutedInstructions() * perInsnTime; return transitionStartTime + t; } //-- the listener interface @Override public void choiceGeneratorRegistered(VM vm, ChoiceGenerator<?> nextCG, ThreadInfo ti, Instruction executedInsn){ ChoiceGenerator<?> cgPrev = nextCG.getPreviousChoiceGenerator(); ThreadInfo tiCurrent = vm.getCurrentThread(); long t = tiCurrent.getExecutedInstructions() * perInsnTime; TimeVal tv = null; if (nextCG.isCascaded()){ // there's got to be a previous one, and its associated with the same insn tv = cgPrev.getAttr(TimeVal.class); } else { if (cgPrev != null){ TimeVal tvPrev = cgPrev.getAttr(TimeVal.class); // there has to be one tv = new TimeVal(tvPrev.time + t); } else { tv = new TimeVal( t); } } nextCG.addAttr( tv); } @Override public void choiceGeneratorAdvanced(VM vm, ChoiceGenerator<?> currentCG){ TimeVal tv = currentCG.getAttr(TimeVal.class); if (tv != null){ transitionStartTime = tv.time; } else { transitionStartTime = 0; } } //--- the TimeModel interface @Override public long currentTimeMillis() { return computeTime(); } @Override public long nanoTime() { return computeTime(); } }