/* This file is part of JOP, the Java Optimized Processor see <http://www.jopdesign.com/> Copyright (C) 2001-2008, Martin Schoeberl (martin@jopdesign.com) 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.io.examples; import util.Timer; import com.jopdesign.io.*; import com.jopdesign.sys.*; public class MeasureIH implements Runnable { static int ts, te, to; public static void main(String[] args) { IOFactory fact = IOFactory.getFactory(); SerialPort sp = fact.getSerialPort(); SysDevice sys = fact.getSysDevice(); MeasureIH ih = new MeasureIH(); fact.registerInterruptHandler(1, ih); System.out.println("Measure IH respons time"); // enable software interrupt 1 fact.enableInterrupt(1); // measure overhead ts = Native.rdMem(Const.IO_CNT); sys.intNr = 2; te = Native.rdMem(Const.IO_CNT); to = te-ts; ts = Native.rdMem(Const.IO_CNT); for (int i=0; i<200; ++i) { // Timer.wd(); // int t = Timer.getTimeoutMs(200); // while (!Timer.timeout(t)); ts = Native.rdMem(Const.IO_CNT); // trigger a SW interrupt via the system HW object sys.intNr = 1; } } public void run() { te = Native.rdMem(Const.IO_CNT); System.out.print(te-ts-to); System.out.print(" "); // need to be set in JVMHelp // System.out.print(JVMHelp.ts-ts-to); System.out.print(" "); } }