/**************************************************************************** * * SciTech OS Portability Manager Library * * ======================================================================== * * The contents of this file are subject to the SciTech MGL Public * License Version 1.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.scitechsoft.com/mgl-license.txt * * Software distributed under the License is distributed on an * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is Copyright (C) 1991-1998 SciTech Software, Inc. * * The Initial Developer of the Original Code is SciTech Software, Inc. * All Rights Reserved. * * ======================================================================== * * Language: ANSI C * Environment: Any * * Description: Test program for the PM_blockUntilTimeout function. * ****************************************************************************/ #include #include "pmapi.h" #define DELAY_MSECS 1100 #define LOOPS 5 /*-------------------------- Implementation -------------------------------*/ /* The following routine takes a long count in microseconds and outputs * a string representing the count in seconds. It could be modified to * return a pointer to a static string representing the count rather * than printing it out. */ void ReportTime(ulong count) { ulong secs; secs = count / 1000000L; count = count - secs * 1000000L; printf("Time taken: %lu.%06lu seconds\n",secs,count); } int main(void) { int i; printf("Detecting processor information ..."); fflush(stdout); printf("\n\n%s\n", CPU_getProcessorName()); ZTimerInit(); LZTimerOn(); for (i = 0; i < LOOPS; i++) { PM_blockUntilTimeout(DELAY_MSECS); ReportTime(LZTimerLap()); } LZTimerOff(); return 0; }