index e335e3fc8ee1c0abd2fd4cb361e6082f7cd61a4e..71cd14877374e403727d5ba4c181be54ad05d089 100644 (file)
--- a/src/shared/xprofiler.pas
+++ b/src/shared/xprofiler.pas
-(* Copyright (C) DooM 2D:Forever Developers
+(* Copyright (C) Doom 2D: Forever Developers
*
* 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
*
* 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
interface
interface
-uses
- SysUtils,
- {$IF DEFINED(LINUX)}
+{$IFNDEF IN_TOOLS}
+ uses
+ SysUtils;
+
+ {$DEFINE STOPWATCH_IS_HERE}
+
+{$ELSE}
+ uses
+ SysUtils
+ {$IF DEFINED(LINUX) OR DEFINED(ANDROID)}
{$DEFINE STOPWATCH_IS_HERE}
{$DEFINE STOPWATCH_IS_HERE}
- unixtype, linux
+ , unixtype, linux
{$ELSEIF DEFINED(WINDOWS)}
{$DEFINE STOPWATCH_IS_HERE}
{$ELSEIF DEFINED(WINDOWS)}
{$DEFINE STOPWATCH_IS_HERE}
- Windows
+ , Windows
+ {$ELSEIF DEFINED(HAIKU)}
+ {$DEFINE STOPWATCH_IS_HERE}
+ , unixtype
{$ELSE}
{$IFDEF STOPWATCH_IS_HERE}
{$UNDEF STOPWATCH_IS_HERE}
{$ELSE}
{$IFDEF STOPWATCH_IS_HERE}
{$UNDEF STOPWATCH_IS_HERE}
{$WARNING You suck!}
{$ENDIF}
;
{$WARNING You suck!}
{$ENDIF}
;
+{$ENDIF} // IN_TOOLS
{$IF DEFINED(STOPWATCH_IS_HERE)}
type
{$IF DEFINED(STOPWATCH_IS_HERE)}
type
end;
end;
+function getTimeMicro (): UInt64; inline;
+function getTimeMilli (): UInt64; inline;
+
+
implementation
implementation
+{$IFNDEF IN_TOOLS}
+uses
+ SDL2;
+
+type
+ THPTimeType = Int64;
+{$ELSE}
{$IF DEFINED(LINUX)}
type THPTimeType = TTimeSpec;
{$ELSE}
{$IF DEFINED(LINUX)}
type THPTimeType = TTimeSpec;
{$ELSE}
var
mFrequency: Int64 = 0;
mHasHPTimer: Boolean = false;
var
mFrequency: Int64 = 0;
mHasHPTimer: Boolean = false;
+{$ENDIF}
// ////////////////////////////////////////////////////////////////////////// //
procedure initTimerIntr ();
// ////////////////////////////////////////////////////////////////////////// //
procedure initTimerIntr ();
+{$IFDEF IN_TOOLS}
var
r: THPTimeType;
var
r: THPTimeType;
+{$ENDIF}
begin
begin
+{$IFDEF IN_TOOLS}
if (mFrequency = 0) then
begin
{$IF DEFINED(LINUX)}
if (mFrequency = 0) then
begin
{$IF DEFINED(LINUX)}
if not mHasHPTimer then raise Exception.Create('profiler error: hires timer is not available');
mFrequency := 1; // just a flag
if (r.tv_nsec <> 0) then mFrequency := 1000000000000000000 div r.tv_nsec;
if not mHasHPTimer then raise Exception.Create('profiler error: hires timer is not available');
mFrequency := 1; // just a flag
if (r.tv_nsec <> 0) then mFrequency := 1000000000000000000 div r.tv_nsec;
-{$ELSE}
+{$ELSEIF DEFINED(WINDOWS)}
mHasHPTimer := QueryPerformanceFrequency(r);
if not mHasHPTimer then raise Exception.Create('profiler error: hires timer is not available');
mFrequency := r;
{$ENDIF}
end;
mHasHPTimer := QueryPerformanceFrequency(r);
if not mHasHPTimer then raise Exception.Create('profiler error: hires timer is not available');
mFrequency := r;
{$ENDIF}
end;
+{$ENDIF}
+ (* init sdl timers? *)
end;
end;
-function curTimeMicro (): UInt64; inline;
+{$IFDEF IN_TOOLS}
+function getTimeMicro (): UInt64; inline;
var
r: THPTimeType;
begin
var
r: THPTimeType;
begin
- if (mFrequency = 0) then initTimerIntr();
+ //if (mFrequency = 0) then initTimerIntr();
{$IF DEFINED(LINUX)}
clock_gettime(CLOCK_MONOTONIC, @r);
result := UInt64(r.tv_sec)*1000000+UInt64(r.tv_nsec) div 1000; // microseconds
{$IF DEFINED(LINUX)}
clock_gettime(CLOCK_MONOTONIC, @r);
result := UInt64(r.tv_sec)*1000000+UInt64(r.tv_nsec) div 1000; // microseconds
- {$ELSE}
+ {$ELSEIF DEFINED(WINDOWS)}
QueryPerformanceCounter(r);
result := UInt64(r)*1000000 div mFrequency;
{$ENDIF}
end;
QueryPerformanceCounter(r);
result := UInt64(r)*1000000 div mFrequency;
{$ENDIF}
end;
+{$ELSE}
+function getTimeMicro (): UInt64; inline;
+begin
+ Result := SDL_GetPerformanceCounter() * 1000000 div SDL_GetPerformanceFrequency()
+end;
+{$ENDIF}
+
+
+function getTimeMilli (): UInt64; inline;
+begin
+ result := getTimeMicro div 1000;
+end;
// ////////////////////////////////////////////////////////////////////////// //
// ////////////////////////////////////////////////////////////////////////// //
var
e: UInt64;
begin
var
e: UInt64;
begin
- e := curTimeMicro();
+ e := getTimeMicro();
if (mStartPosition > e) then mStartPosition := e;
Inc(mElapsed, e-mStartPosition);
mStartPosition := e;
if (mStartPosition > e) then mStartPosition := e;
Inc(mElapsed, e-mStartPosition);
mStartPosition := e;
procedure TStopWatch.start (reset: Boolean=true);
begin
if mRunning and not reset then exit; // nothing to do
procedure TStopWatch.start (reset: Boolean=true);
begin
if mRunning and not reset then exit; // nothing to do
- mStartPosition := curTimeMicro();
+ mStartPosition := getTimeMicro();
mRunning := true;
if (reset) then mElapsed := 0;
end;
mRunning := true;
if (reset) then mElapsed := 0;
end;
begin
if (xpsecs[idx].name = aName) then
begin
begin
if (xpsecs[idx].name = aName) then
begin
- if (idx = xpscur) then raise Exception.Create('profiler error(0): dobule resume: "'+aName+'"');
- if (xpsecs[idx].prevAct <> -1) then raise Exception.Create('profiler error(1): dobule resume: "'+aName+'"');
+ if (idx = xpscur) then raise Exception.Create('profiler error(0): double resume: "'+aName+'"');
+ if (xpsecs[idx].prevAct <> -1) then raise Exception.Create('profiler error(1): double resume: "'+aName+'"');
xpsecs[idx].prevAct := xpscur;
xpscur := idx;
xpsecs[idx].timer.resume();
xpsecs[idx].prevAct := xpscur;
xpscur := idx;
xpsecs[idx].timer.resume();
end;
end;
+begin
+ initTimerIntr();
end.
end.