2008-05-30 00:22:37 +04:00
|
|
|
/*
|
|
|
|
** 2008 May 27
|
|
|
|
**
|
|
|
|
** The author disclaims copyright to this source code. In place of
|
|
|
|
** a legal notice, here is a blessing:
|
|
|
|
**
|
|
|
|
** May you do good and not evil.
|
|
|
|
** May you find forgiveness for yourself and forgive others.
|
|
|
|
** May you share freely, never taking more than you give.
|
|
|
|
**
|
|
|
|
******************************************************************************
|
|
|
|
**
|
|
|
|
** This file contains inline asm code for retrieving "high-performance"
|
2019-11-20 15:07:40 +03:00
|
|
|
** counters for x86 and x86_64 class CPUs.
|
2008-05-30 00:22:37 +04:00
|
|
|
*/
|
2016-07-09 19:14:45 +03:00
|
|
|
#ifndef SQLITE_HWTIME_H
|
|
|
|
#define SQLITE_HWTIME_H
|
2008-05-30 00:22:37 +04:00
|
|
|
|
|
|
|
/*
|
2023-06-07 11:40:31 +03:00
|
|
|
** The following routine only works on Pentium-class (or newer) processors.
|
2008-05-30 00:22:37 +04:00
|
|
|
** It uses the RDTSC opcode to read the cycle count value out of the
|
|
|
|
** processor and returns that value. This can be used for high-res
|
|
|
|
** profiling.
|
|
|
|
*/
|
2019-11-20 15:07:40 +03:00
|
|
|
#if !defined(__STRICT_ANSI__) && \
|
|
|
|
(defined(__GNUC__) || defined(_MSC_VER)) && \
|
|
|
|
(defined(i386) || defined(__i386__) || defined(_M_IX86))
|
2008-05-30 00:22:37 +04:00
|
|
|
|
|
|
|
#if defined(__GNUC__)
|
|
|
|
|
|
|
|
__inline__ sqlite_uint64 sqlite3Hwtime(void){
|
|
|
|
unsigned int lo, hi;
|
|
|
|
__asm__ __volatile__ ("rdtsc" : "=a" (lo), "=d" (hi));
|
|
|
|
return (sqlite_uint64)hi << 32 | lo;
|
|
|
|
}
|
|
|
|
|
|
|
|
#elif defined(_MSC_VER)
|
|
|
|
|
|
|
|
__declspec(naked) __inline sqlite_uint64 __cdecl sqlite3Hwtime(void){
|
|
|
|
__asm {
|
|
|
|
rdtsc
|
|
|
|
ret ; return value at EDX:EAX
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2019-11-20 15:07:40 +03:00
|
|
|
#elif !defined(__STRICT_ANSI__) && (defined(__GNUC__) && defined(__x86_64__))
|
2008-06-12 06:24:38 +04:00
|
|
|
|
|
|
|
__inline__ sqlite_uint64 sqlite3Hwtime(void){
|
2022-12-05 21:19:56 +03:00
|
|
|
unsigned int lo, hi;
|
|
|
|
__asm__ __volatile__ ("rdtsc" : "=a" (lo), "=d" (hi));
|
|
|
|
return (sqlite_uint64)hi << 32 | lo;
|
2008-06-12 06:24:38 +04:00
|
|
|
}
|
|
|
|
|
2019-11-20 15:07:40 +03:00
|
|
|
#elif !defined(__STRICT_ANSI__) && (defined(__GNUC__) && defined(__ppc__))
|
2008-08-01 18:33:15 +04:00
|
|
|
|
|
|
|
__inline__ sqlite_uint64 sqlite3Hwtime(void){
|
|
|
|
unsigned long long retval;
|
|
|
|
unsigned long junk;
|
|
|
|
__asm__ __volatile__ ("\n\
|
|
|
|
1: mftbu %1\n\
|
|
|
|
mftb %L0\n\
|
|
|
|
mftbu %0\n\
|
|
|
|
cmpw %0,%1\n\
|
|
|
|
bne 1b"
|
|
|
|
: "=r" (retval), "=r" (junk));
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2008-05-30 00:22:37 +04:00
|
|
|
#else
|
|
|
|
|
|
|
|
/*
|
2019-11-20 15:07:40 +03:00
|
|
|
** asm() is needed for hardware timing support. Without asm(),
|
|
|
|
** disable the sqlite3Hwtime() routine.
|
|
|
|
**
|
|
|
|
** sqlite3Hwtime() is only used for some obscure debugging
|
|
|
|
** and analysis configurations, not in any deliverable, so this
|
|
|
|
** should not be a great loss.
|
2008-05-30 00:22:37 +04:00
|
|
|
*/
|
|
|
|
sqlite_uint64 sqlite3Hwtime(void){ return ((sqlite_uint64)0); }
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2016-07-09 19:14:45 +03:00
|
|
|
#endif /* !defined(SQLITE_HWTIME_H) */
|