/* * $Id$ * * $Log$ * Revision 1.2 2001/09/25 21:39:54 jonesrt * -fixed problems compiling with local copy of cernlib routine timel.c * (the cernlib team botched that routine in the 2001 libkernlib.a distribution) * -rtj- * * Revision 1.2 1997/02/04 17:34:47 mclareni * Merge Winnt and 97a versions * * Revision 1.1.1.1.2.1 1997/01/21 11:29:45 mclareni * All mods for Winnt 96a on winnt branch * * Revision 1.1.1.1 1996/02/15 17:49:27 mclareni * Kernlib * */ #include "kerngen/pilot.h" #if defined(CERNLIB_WINNT) #include "wntgs/timel.c" #elif defined(CERNLIB_QMDOS) #include "dosgs/timel.c" #elif defined(CERNLIB_QMIRTD) #include "irtdgs/timel.c" #else /*> ROUTINE TIMEL CERN PROGLIB# Z007 TIMEST .VERSION KERNFOR 4.39 940228 ORIG. 01/03/85 FCA, mod 03/11/93 GF */ #include #include #include #include #include #include #ifndef CLOCKS_PER_SEC #define CLOCKS_PER_SEC CLK_TCK #endif #ifndef RLIMIT_CPU #define RLIMIT_CPU 0 /* For HP-UX... */ #endif #ifndef RLIM_INFINITY #define RLIM_INFINITY 0x7fffffff /* For HP-UX... */ #endif #if defined(CERNLIB_QSYSBSD)||defined(CERNLIB_QMVMI)||defined(CERNLIB_QMVAOS) #define HZ 60.; #endif #ifndef HZ #ifdef __GNUC__ #define HZ 1 #else #define HZ 1./CLOCKS_PER_SEC #endif #endif struct tms tps; static float timlim; static time_t timstart, timlast; static int tml_init = 1; float deftim = 999.; #if defined(CERNLIB_QX_SC) #define timest timest_ #define timex timex_ #define timed timed_ #define timel timel_ #endif #if defined(CERNLIB_QXCAPT) #define timest TIMEST #define timex TIMEX #define timed TIMED #define timel TIMEL #endif /* local routine called by timst, and time_init */ static void time_st(timl) float timl; { times(&tps); timlim = timl; timstart = tps.tms_utime+tps.tms_cutime+tps.tms_stime+tps.tms_cstime; timlast = timstart; tml_init = 0; return; } /* local routine to start by default */ static void time_init() { struct rlimit rlimit; float maxtime; maxtime=deftim; if (getrlimit(RLIMIT_CPU, &rlimit)==0) { if ( rlimit.rlim_cur != RLIM_INFINITY ) maxtime = (float) rlimit.rlim_cur; } time_st(maxtime); return; } void timest(timl) float *timl; { struct rlimit rlimit; float maxtime; if (tml_init != 0) { /* get maximum time allowed by system, and do not allow more */ maxtime = *timl; if (getrlimit(RLIMIT_CPU, &rlimit)==0) { maxtime = (float) rlimit.rlim_cur; maxtime = ( maxtime > *timl ) ? *timl : maxtime; } time_st(maxtime); } return; } void timex(tx) /* C CERN PROGLIB# Z007 TIMEX .VERSION KERNFOR 4.39 940228 C */ float *tx; { time_t timnow; if (tml_init) { time_init(); *tx = 0.; } else { times(&tps); timnow = tps.tms_utime+tps.tms_cutime+tps.tms_stime+tps.tms_cstime; *tx = (float) (timnow - timstart) / HZ; } return; } void timed(td) /* C CERN PROGLIB# Z007 TIMED .VERSION KERNFOR 4.39 940228 C */ float *td; { time_t timnow; if (tml_init) { time_init(); *td = timlim; } else { times(&tps); timnow = tps.tms_utime+tps.tms_cutime+tps.tms_stime+tps.tms_cstime; *td = (float) (timnow - timlast) / HZ; timlast = timnow; } return; } void timel(tl) /* C CERN PROGLIB# Z007 TIMEL .VERSION KERNFOR 4.39 940228 C */ float *tl; { time_t timnow; if (tml_init) { time_init(); *tl = timlim; } else { times(&tps); timnow = tps.tms_utime+tps.tms_cutime+tps.tms_stime+tps.tms_cstime; *tl = timlim - (float) (timnow - timstart) / HZ; } return; } #ifdef __GNUC__ #undef time_t #endif /*> END <----------------------------------------------------------*/ #endif