From a06e9a8aa7b1612e43ce7ec0868276876278c9a9 Mon Sep 17 00:00:00 2001 From: Chris Young Date: Sun, 30 Nov 2014 13:53:34 +0000 Subject: Use ReadEClock() instead; AmigaOS 3 compatibility. This might be marginally quicker. --- src/time.c | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/time.c b/src/time.c index 4a5b8f2..72d3ff9 100644 --- a/src/time.c +++ b/src/time.c @@ -24,7 +24,10 @@ #include #include #include -#elif defined(__amigaos4__) +#elif defined(__amiga) +#ifdef __amigaos4__ +#define __USE_INLINE__ 1 +#endif #include #include #else @@ -57,16 +60,22 @@ nsuerror nsu_getmonotonic_ms(uint64_t *current_out) mach_port_deallocate(mach_task_self(), cclock); current = (mts.tv_sec * 1000) + (mts.tv_nsec / 1000000); -#elif defined(__amigaos4__) - struct TimeVal tv; +#elif defined(__amiga) + struct EClockVal eclockval; + int freq = 0; + uint64 eclock; /* NB: The calling task must already have opened timer.device * and obtained the interface. */ + assert(TimerBase != NULL); +#ifdef __amigaos4__ assert(ITimer != NULL); +#endif - ITimer->GetUpTime(&tv); - current = (tv.Seconds * 1000) + (tv.Microseconds / 1000); + freq = ReadEClock(&eclockval) / 1000; + eclock = ((uint64)eclockval.ev_hi << 32) | (eclockval.ev_lo); + current = eclock / freq; #else #warning "Using dodgy gettimeofday() fallback" /** \todo Implement this properly! */ -- cgit v1.2.3