/*
This file is part of JOP, the Java Optimized Processor
see <http://www.jopdesign.com/>
Copyright (C) 2011, Benedikt Huber (benedikt@vmars.tuwien.ac.at)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package com.jopdesign.timing;
/**
* Purpose: For processors with a method cache, provide timing information
* on the method cache load times
*/
public interface MethodCacheTiming {
/**
* @param words number of words to load
* @param loadOnInvoke whether this is an invoke or return instruction
* @return the maximum miss penalty for loading {@code words} words from method cache
*/
long getMethodCacheMissPenalty(int words, boolean loadOnInvoke);
/**
* @param words number of words to load
* @param instructionOpcode opcode the invoke instruction
* @return the maximum miss penalty for loading {@code words} words from method cache during {@code instructionOpcode}
*/
long getMethodCacheMissPenalty(int words, short instructionOpcode);
}