/*
This file is part of JOP, the Java Optimized Processor
see <http://www.jopdesign.com/>
Copyright (C) 2008, Rasmus Pedersen
(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 wcet.devel;
import com.jopdesign.sys.Config;
import com.jopdesign.sys.Const;
import com.jopdesign.sys.Native;
public class Rasmus {
/* Debugging signals to manipulate the cache */
final static int CACHE_FLUSH = -51;
final static int CACHE_DUMP = -53;
static int ts, te, to;
static A a;
final static boolean MEASURE_CACHE = false;
public static void main(String[] args) {
ts = Native.rdMem(Const.IO_CNT);
te = Native.rdMem(Const.IO_CNT);
to = te-ts;
int min = 0x7fffffff;
int max = 0;
int val = 0;
for(int i = 0; i < 100; i++) {
if((i&2) == 0) a = new A();
else a = new B();
invoke();
val = te-ts-to;
if (val<min) min = val;
if (val>max) max = val;
}
if (Config.MEASURE) {
System.out.print("min: "); System.out.println(min);
System.out.print("max: "); System.out.println(max);
}
}
static void invoke() {
if (MEASURE_CACHE) Native.wrMem(1,CACHE_FLUSH);
measure();
if (Config.MEASURE) te = Native.rdMem(Const.IO_CNT);
if (MEASURE_CACHE) Native.rdMem(CACHE_DUMP);
}
static void measure() {
if (Config.MEASURE) ts = Native.rdMem(Const.IO_CNT);
dowcet();
dowcet2();
}
static public int dowcet() {
for(int j = 0; j < 5; j++) // @WCA loop=5
bar();
return 0;
}
static void bar() {
int i = 0;
i = i + 1;
}
static public int dowcet2() {
bar(a);
return 0;
}
static void bar(A a) {
a.foo();
}
//a can now be an A or it can also be a B. So
//either A.foo() or B.foo() is invoked. We don't know,
//so we have to consider both possibilities for the WCET
// from ms mail
static class A {
void foo() {
int ia = 1;
}
}
static class B extends A {
// overwrites A.foo()
void foo() {
int ib = 3;
ib++;
ib--;
}
}
}