use GetTimeStampMS to increase heartbeat and stats timing resolution. some rearrange on stat code ( MOSES special ones still out )
parent
f0c865555b
commit
08f9c54554
|
@ -398,16 +398,16 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
private int m_update_coarse_locations = 50;
|
private int m_update_coarse_locations = 50;
|
||||||
private int m_update_temp_cleaning = 180;
|
private int m_update_temp_cleaning = 180;
|
||||||
|
|
||||||
private int agentMS;
|
private float agentMS;
|
||||||
private int frameMS;
|
private float frameMS;
|
||||||
private int physicsMS2;
|
private float physicsMS2;
|
||||||
private int physicsMS;
|
private float physicsMS;
|
||||||
private int otherMS;
|
private float otherMS;
|
||||||
private int tempOnRezMS;
|
private float tempOnRezMS;
|
||||||
private int eventMS;
|
private float eventMS;
|
||||||
private int backupMS;
|
private float backupMS;
|
||||||
private int terrainMS;
|
private float terrainMS;
|
||||||
private int landMS;
|
private float landMS;
|
||||||
|
|
||||||
// A temporary configuration flag to enable using FireAndForget to process
|
// A temporary configuration flag to enable using FireAndForget to process
|
||||||
// collisions from the physics engine. There is a problem with collisions
|
// collisions from the physics engine. There is a problem with collisions
|
||||||
|
@ -785,15 +785,15 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
get { return m_capsModule; }
|
get { return m_capsModule; }
|
||||||
}
|
}
|
||||||
|
|
||||||
public int MonitorFrameTime { get { return frameMS; } }
|
public int MonitorFrameTime { get { return (int)frameMS; } }
|
||||||
public int MonitorPhysicsUpdateTime { get { return physicsMS; } }
|
public int MonitorPhysicsUpdateTime { get { return (int)physicsMS; } }
|
||||||
public int MonitorPhysicsSyncTime { get { return physicsMS2; } }
|
public int MonitorPhysicsSyncTime { get { return (int)physicsMS2; } }
|
||||||
public int MonitorOtherTime { get { return otherMS; } }
|
public int MonitorOtherTime { get { return (int)otherMS; } }
|
||||||
public int MonitorTempOnRezTime { get { return tempOnRezMS; } }
|
public int MonitorTempOnRezTime { get { return (int)tempOnRezMS; } }
|
||||||
public int MonitorEventTime { get { return eventMS; } } // This may need to be divided into each event?
|
public int MonitorEventTime { get { return (int)eventMS; } } // This may need to be divided into each event?
|
||||||
public int MonitorBackupTime { get { return backupMS; } }
|
public int MonitorBackupTime { get { return (int)backupMS; } }
|
||||||
public int MonitorTerrainTime { get { return terrainMS; } }
|
public int MonitorTerrainTime { get { return (int)terrainMS; } }
|
||||||
public int MonitorLandTime { get { return landMS; } }
|
public int MonitorLandTime { get { return (int)landMS; } }
|
||||||
public int MonitorLastFrameTick { get { return m_lastFrameTick; } }
|
public int MonitorLastFrameTick { get { return m_lastFrameTick; } }
|
||||||
|
|
||||||
public UpdatePrioritizationSchemes UpdatePrioritizationScheme { get; set; }
|
public UpdatePrioritizationSchemes UpdatePrioritizationScheme { get; set; }
|
||||||
|
@ -1714,20 +1714,21 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
float physicsFPS = 0f;
|
float physicsFPS = 0f;
|
||||||
|
|
||||||
int tmpMS;
|
|
||||||
int previousFrameTick;
|
int previousFrameTick;
|
||||||
int maintc;
|
|
||||||
int sleepMS;
|
double tmpMS;
|
||||||
int framestart;
|
double tmpMS2;
|
||||||
|
double framestart;
|
||||||
|
float sleepMS;
|
||||||
|
|
||||||
while (!m_shuttingDown && ((endFrame == null && Active) || Frame < endFrame))
|
while (!m_shuttingDown && ((endFrame == null && Active) || Frame < endFrame))
|
||||||
{
|
{
|
||||||
framestart = Util.EnvironmentTickCount();
|
framestart = Util.GetTimeStampMS();
|
||||||
++Frame;
|
++Frame;
|
||||||
|
|
||||||
// m_log.DebugFormat("[SCENE]: Processing frame {0} in {1}", Frame, RegionInfo.RegionName);
|
// m_log.DebugFormat("[SCENE]: Processing frame {0} in {1}", Frame, RegionInfo.RegionName);
|
||||||
|
|
||||||
agentMS = tempOnRezMS = eventMS = backupMS = terrainMS = landMS = 0;
|
agentMS = tempOnRezMS = eventMS = backupMS = terrainMS = landMS = 0f;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -1735,7 +1736,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
// Apply taints in terrain module to terrain in physics scene
|
// Apply taints in terrain module to terrain in physics scene
|
||||||
|
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
tmpMS = Util.GetTimeStampMS();
|
||||||
|
|
||||||
if (Frame % 4 == 0)
|
if (Frame % 4 == 0)
|
||||||
{
|
{
|
||||||
CheckTerrainUpdates();
|
CheckTerrainUpdates();
|
||||||
|
@ -1746,26 +1748,29 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
UpdateTerrain();
|
UpdateTerrain();
|
||||||
}
|
}
|
||||||
|
|
||||||
terrainMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
terrainMS = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
|
|
||||||
if (PhysicsEnabled && Frame % m_update_physics == 0)
|
if (PhysicsEnabled && Frame % m_update_physics == 0)
|
||||||
m_sceneGraph.UpdatePreparePhysics();
|
m_sceneGraph.UpdatePreparePhysics();
|
||||||
|
|
||||||
physicsMS2 = Util.EnvironmentTickCountSubtract(tmpMS);
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
physicsMS2 = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
|
|
||||||
// Apply any pending avatar force input to the avatar's velocity
|
// Apply any pending avatar force input to the avatar's velocity
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
if (Frame % m_update_entitymovement == 0)
|
if (Frame % m_update_entitymovement == 0)
|
||||||
m_sceneGraph.UpdateScenePresenceMovement();
|
m_sceneGraph.UpdateScenePresenceMovement();
|
||||||
|
|
||||||
// Get the simulation frame time that the avatar force input
|
// Get the simulation frame time that the avatar force input
|
||||||
// took
|
// took
|
||||||
agentMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
agentMS = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
|
|
||||||
// Perform the main physics update. This will do the actual work of moving objects and avatars according to their
|
// Perform the main physics update. This will do the actual work of moving objects and avatars according to their
|
||||||
// velocity
|
// velocity
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
if (Frame % m_update_physics == 0)
|
if (Frame % m_update_physics == 0)
|
||||||
{
|
{
|
||||||
if (PhysicsEnabled)
|
if (PhysicsEnabled)
|
||||||
|
@ -1775,11 +1780,9 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
SynchronizeScene(this);
|
SynchronizeScene(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add the main physics update time to the prepare physics time
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
physicsMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
physicsMS = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
// Start the stopwatch for the remainder of the simulation
|
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
|
|
||||||
// Check if any objects have reached their targets
|
// Check if any objects have reached their targets
|
||||||
CheckAtTargets();
|
CheckAtTargets();
|
||||||
|
@ -1794,29 +1797,37 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
if (Frame % m_update_presences == 0)
|
if (Frame % m_update_presences == 0)
|
||||||
m_sceneGraph.UpdatePresences();
|
m_sceneGraph.UpdatePresences();
|
||||||
|
|
||||||
agentMS += Util.EnvironmentTickCountSubtract(tmpMS);
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
agentMS += (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
|
|
||||||
// Delete temp-on-rez stuff
|
// Delete temp-on-rez stuff
|
||||||
if (Frame % m_update_temp_cleaning == 0 && !m_cleaningTemps)
|
if (Frame % m_update_temp_cleaning == 0 && !m_cleaningTemps)
|
||||||
{
|
{
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
m_cleaningTemps = true;
|
m_cleaningTemps = true;
|
||||||
Util.FireAndForget(delegate { CleanTempObjects(); m_cleaningTemps = false; });
|
Util.FireAndForget(delegate { CleanTempObjects(); m_cleaningTemps = false; });
|
||||||
tempOnRezMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
tempOnRezMS = (float)(tmpMS2 - tmpMS); // bad.. counts the FireAndForget, not CleanTempObjects
|
||||||
|
tmpMS = tmpMS2;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Frame % m_update_events == 0)
|
if (Frame % m_update_events == 0)
|
||||||
{
|
{
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
UpdateEvents();
|
UpdateEvents();
|
||||||
eventMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
|
||||||
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
eventMS = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (PeriodicBackup && Frame % m_update_backup == 0)
|
if (PeriodicBackup && Frame % m_update_backup == 0)
|
||||||
{
|
{
|
||||||
tmpMS = Util.EnvironmentTickCount();
|
|
||||||
UpdateStorageBackup();
|
UpdateStorageBackup();
|
||||||
backupMS = Util.EnvironmentTickCountSubtract(tmpMS);
|
|
||||||
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
|
backupMS = (float)(tmpMS2 - tmpMS);
|
||||||
|
tmpMS = tmpMS2;
|
||||||
}
|
}
|
||||||
|
|
||||||
//if (Frame % m_update_land == 0)
|
//if (Frame % m_update_land == 0)
|
||||||
|
@ -1887,20 +1898,26 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
StatsReporter.addOtherMS(otherMS);
|
StatsReporter.addOtherMS(otherMS);
|
||||||
StatsReporter.addScriptLines(m_sceneGraph.GetScriptLPS());
|
StatsReporter.addScriptLines(m_sceneGraph.GetScriptLPS());
|
||||||
|
|
||||||
|
|
||||||
|
tmpMS = Util.GetTimeStampMS();
|
||||||
|
|
||||||
previousFrameTick = m_lastFrameTick;
|
previousFrameTick = m_lastFrameTick;
|
||||||
m_lastFrameTick = Util.EnvironmentTickCount();
|
m_lastFrameTick = (int)(tmpMS + 0.5);
|
||||||
tmpMS = Util.EnvironmentTickCountSubtract(m_lastFrameTick, framestart);
|
|
||||||
tmpMS = (int)(MinFrameTime * 1000) - tmpMS;
|
// estimate sleep time
|
||||||
|
tmpMS2 = tmpMS - framestart;
|
||||||
|
tmpMS2 = (double)MinFrameTime * 1000.0D - tmpMS2;
|
||||||
|
|
||||||
m_firstHeartbeat = false;
|
m_firstHeartbeat = false;
|
||||||
|
|
||||||
sleepMS = Util.EnvironmentTickCount();
|
// sleep if we can
|
||||||
|
if (tmpMS2 > 0)
|
||||||
|
Thread.Sleep((int)(tmpMS2 +0.5));
|
||||||
|
|
||||||
if (tmpMS > 0)
|
tmpMS2 = Util.GetTimeStampMS();
|
||||||
Thread.Sleep(tmpMS);
|
|
||||||
|
|
||||||
sleepMS = Util.EnvironmentTickCountSubtract(sleepMS);
|
sleepMS = (float)(tmpMS2 - tmpMS);
|
||||||
frameMS = Util.EnvironmentTickCountSubtract(framestart);
|
frameMS = (float)(tmpMS2 - framestart);
|
||||||
StatsReporter.addSleepMS(sleepMS);
|
StatsReporter.addSleepMS(sleepMS);
|
||||||
StatsReporter.addFrameMS(frameMS);
|
StatsReporter.addFrameMS(frameMS);
|
||||||
|
|
||||||
|
|
|
@ -90,7 +90,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
Agents = 13,
|
Agents = 13,
|
||||||
ChildAgents = 14,
|
ChildAgents = 14,
|
||||||
ActiveScripts = 15,
|
ActiveScripts = 15,
|
||||||
ScriptLinesPerSecond = 16,
|
LSLScriptLinesPerSecond = 16, // viewers don't like this
|
||||||
InPacketsPerSecond = 17,
|
InPacketsPerSecond = 17,
|
||||||
OutPacketsPerSecond = 18,
|
OutPacketsPerSecond = 18,
|
||||||
PendingDownloads = 19,
|
PendingDownloads = 19,
|
||||||
|
@ -109,11 +109,18 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
SimSpareMs = 32,
|
SimSpareMs = 32,
|
||||||
SimSleepMs = 33,
|
SimSleepMs = 33,
|
||||||
SimIoPumpTime = 34,
|
SimIoPumpTime = 34,
|
||||||
FrameDilation = 35,
|
SimPCTSscriptsRun = 35,
|
||||||
UsersLoggingIn = 36,
|
SimRegionIdle = 36, // dataserver only
|
||||||
TotalGeoPrim = 37,
|
SimRegionIdlePossible = 37, // dataserver only
|
||||||
TotalMesh = 38,
|
SimAIStepTimeMS = 38,
|
||||||
ThreadCount = 39
|
SimSkippedSillouet_PS = 39,
|
||||||
|
SimSkippedCharsPerC = 40,
|
||||||
|
|
||||||
|
MOSESFrameDilation = 100,
|
||||||
|
MOSESUsersLoggingIn = 101,
|
||||||
|
MOSESTotalGeoPrim = 102,
|
||||||
|
MOSESTotalMesh = 103,
|
||||||
|
MOSESThreadCount = 104
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -170,7 +177,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Our nominal fps target, as expected in fps stats when a sim is running normally.
|
/// Our nominal fps target, as expected in fps stats when a sim is running normally.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private float m_nominalReportedFps = 55;
|
private float m_nominalReportedFps = 11;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Parameter to adjust reported scene fps
|
/// Parameter to adjust reported scene fps
|
||||||
|
@ -197,17 +204,14 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private int m_objectUpdates;
|
private int m_objectUpdates;
|
||||||
|
|
||||||
private int m_frameMS;
|
private float m_frameMS;
|
||||||
|
|
||||||
private int m_netMS;
|
private float m_netMS;
|
||||||
private int m_agentMS;
|
private float m_agentMS;
|
||||||
private int m_physicsMS;
|
private float m_physicsMS;
|
||||||
private int m_imageMS;
|
private float m_imageMS;
|
||||||
private int m_otherMS;
|
private float m_otherMS;
|
||||||
private int m_sleeptimeMS;
|
private float m_sleeptimeMS;
|
||||||
|
|
||||||
//Ckrinke: (3-21-08) Comment out to remove a compiler warning. Bring back into play when needed.
|
|
||||||
//Ckrinke private int m_scriptMS = 0;
|
|
||||||
|
|
||||||
private int m_rootAgents;
|
private int m_rootAgents;
|
||||||
private int m_childAgents;
|
private int m_childAgents;
|
||||||
|
@ -221,7 +225,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
private int m_pendingDownloads;
|
private int m_pendingDownloads;
|
||||||
private int m_pendingUploads = 0; // FIXME: Not currently filled in
|
private int m_pendingUploads = 0; // FIXME: Not currently filled in
|
||||||
private int m_activeScripts;
|
private int m_activeScripts;
|
||||||
private int m_scriptLinesPerSecond;
|
// private int m_scriptLinesPerSecond;
|
||||||
|
|
||||||
private int m_objectCapacity = 45000;
|
private int m_objectCapacity = 45000;
|
||||||
|
|
||||||
|
@ -264,8 +268,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public SimStatsReporter(Scene scene)
|
public SimStatsReporter(Scene scene)
|
||||||
{
|
{
|
||||||
m_scene = scene;
|
m_scene = scene;
|
||||||
m_reportedFpsCorrectionFactor = scene.MinFrameTime * m_nominalReportedFps;
|
// m_reportedFpsCorrectionFactor = 5.0f; // needs to come from config
|
||||||
m_statsUpdateFactor = (float)(m_statsUpdatesEveryMS / 1000);
|
m_reportedFpsCorrectionFactor = 1.0f; // needs to come from config
|
||||||
|
m_nominalReportedFps *= m_reportedFpsCorrectionFactor;
|
||||||
|
m_statsUpdateFactor = (float)(m_statsUpdatesEveryMS / 1000.0f);
|
||||||
ReportingRegion = scene.RegionInfo;
|
ReportingRegion = scene.RegionInfo;
|
||||||
|
|
||||||
m_objectCapacity = scene.RegionInfo.ObjectCapacity;
|
m_objectCapacity = scene.RegionInfo.ObjectCapacity;
|
||||||
|
@ -310,7 +316,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
public void SetUpdateMS(int ms)
|
public void SetUpdateMS(int ms)
|
||||||
{
|
{
|
||||||
m_statsUpdatesEveryMS = ms;
|
m_statsUpdatesEveryMS = ms;
|
||||||
m_statsUpdateFactor = (float)(m_statsUpdatesEveryMS / 1000);
|
m_statsUpdateFactor = (float)(m_statsUpdatesEveryMS / 1000.0f);
|
||||||
m_report.Interval = m_statsUpdatesEveryMS;
|
m_report.Interval = m_statsUpdatesEveryMS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -333,8 +339,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
if (!m_scene.Active)
|
if (!m_scene.Active)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
SimStatsPacket.StatBlock[] sb = new SimStatsPacket.StatBlock[23];
|
SimStatsPacket.StatBlock[] sb = new SimStatsPacket.StatBlock[23];
|
||||||
SimStatsPacket.RegionBlock rb = new SimStatsPacket.RegionBlock();
|
SimStatsPacket.RegionBlock rb = new SimStatsPacket.RegionBlock();
|
||||||
|
|
||||||
// Know what's not thread safe in Mono... modifying timers.
|
// Know what's not thread safe in Mono... modifying timers.
|
||||||
// m_log.Debug("Firing Stats Heart Beat");
|
// m_log.Debug("Firing Stats Heart Beat");
|
||||||
|
@ -354,21 +360,14 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
|
|
||||||
#region various statistic googly moogly
|
#region various statistic googly moogly
|
||||||
|
int reportedFPS = (int)(m_fps * m_reportedFpsCorrectionFactor);
|
||||||
// ORIGINAL code commented out until we have time to add our own
|
|
||||||
// statistics to the statistics window, this will be done as a
|
|
||||||
// new section given the title of our current project
|
|
||||||
// We're going to lie about the FPS because we've been lying since 2008. The actual FPS is currently
|
|
||||||
// locked at a maximum of 11. Maybe at some point this can change so that we're not lying.
|
|
||||||
//int reportedFPS = (int)(m_fps * m_reportedFpsCorrectionFactor);
|
|
||||||
int reportedFPS = m_fps;
|
|
||||||
|
|
||||||
// save the reported value so there is something available for llGetRegionFPS
|
// save the reported value so there is something available for llGetRegionFPS
|
||||||
lastReportedSimFPS = reportedFPS / m_statsUpdateFactor;
|
lastReportedSimFPS = reportedFPS / m_statsUpdateFactor;
|
||||||
|
|
||||||
// ORIGINAL code commented out until we have time to add our own
|
// ORIGINAL code commented out until we have time to add our own
|
||||||
// statistics to the statistics window
|
// statistics to the statistics window
|
||||||
float physfps = ((m_pfps / 1000));
|
float physfps = ((m_pfps / 1000.0f));
|
||||||
|
|
||||||
//if (physfps > 600)
|
//if (physfps > 600)
|
||||||
//physfps = physfps - (physfps - 600);
|
//physfps = physfps - (physfps - 600);
|
||||||
|
@ -377,7 +376,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
physfps = 0;
|
physfps = 0;
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
float factor = 1 / m_statsUpdateFactor;
|
float factor = 1.0f / m_statsUpdateFactor;
|
||||||
|
|
||||||
if (reportedFPS <= 0)
|
if (reportedFPS <= 0)
|
||||||
reportedFPS = 1;
|
reportedFPS = 1;
|
||||||
|
@ -386,7 +385,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
float TotalFrameTime = m_frameMS * perframe;
|
float TotalFrameTime = m_frameMS * perframe;
|
||||||
|
|
||||||
float targetframetime = 1100.0f / (float)m_nominalReportedFps;
|
float targetframetime = 1000.0f / (float)m_nominalReportedFps;
|
||||||
|
|
||||||
float sparetime;
|
float sparetime;
|
||||||
float sleeptime;
|
float sleeptime;
|
||||||
|
@ -432,9 +431,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
sb[i] = new SimStatsPacket.StatBlock();
|
sb[i] = new SimStatsPacket.StatBlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sb[0].StatID = (uint) Stats.TimeDilation;
|
sb[0].StatID = (uint) Stats.TimeDilation;
|
||||||
sb[0].StatValue = (Single.IsNaN(m_timeDilation)) ? 0.1f : m_timeDilation ; //((((m_timeDilation + (0.10f * statsUpdateFactor)) /10) / statsUpdateFactor));
|
sb[0].StatValue = (Single.IsNaN(m_timeDilation)) ? 0.1f : m_timeDilation ;
|
||||||
|
|
||||||
sb[1].StatID = (uint) Stats.SimFPS;
|
sb[1].StatID = (uint) Stats.SimFPS;
|
||||||
sb[1].StatValue = reportedFPS / m_statsUpdateFactor;
|
sb[1].StatValue = reportedFPS / m_statsUpdateFactor;
|
||||||
|
@ -493,14 +491,15 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
sb[19].StatID = (uint)Stats.ActiveScripts;
|
sb[19].StatID = (uint)Stats.ActiveScripts;
|
||||||
sb[19].StatValue = m_activeScripts;
|
sb[19].StatValue = m_activeScripts;
|
||||||
|
|
||||||
sb[20].StatID = (uint)Stats.ScriptLinesPerSecond;
|
sb[20].StatID = (uint)Stats.SimSpareMs;
|
||||||
sb[20].StatValue = m_scriptLinesPerSecond / m_statsUpdateFactor;
|
sb[20].StatValue = sparetime;
|
||||||
|
|
||||||
sb[21].StatID = (uint)Stats.SimSpareMs;
|
sb[21].StatID = (uint)Stats.SimSleepMs;
|
||||||
sb[21].StatValue = sparetime;
|
sb[21].StatValue = sleeptime;
|
||||||
|
|
||||||
sb[22].StatID = (uint)Stats.SimSleepMs;
|
// this should came from phys engine
|
||||||
sb[22].StatValue = sleeptime;
|
sb[22].StatID = (uint)Stats.SimPhysicsStepMs;
|
||||||
|
sb[22].StatValue = 20;
|
||||||
|
|
||||||
for (int i = 0; i < 23; i++)
|
for (int i = 0; i < 23; i++)
|
||||||
{
|
{
|
||||||
|
@ -563,7 +562,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
//m_inPacketsPerSecond = 0;
|
//m_inPacketsPerSecond = 0;
|
||||||
//m_outPacketsPerSecond = 0;
|
//m_outPacketsPerSecond = 0;
|
||||||
m_unAckedBytes = 0;
|
m_unAckedBytes = 0;
|
||||||
m_scriptLinesPerSecond = 0;
|
// m_scriptLinesPerSecond = 0;
|
||||||
|
|
||||||
m_frameMS = 0;
|
m_frameMS = 0;
|
||||||
m_agentMS = 0;
|
m_agentMS = 0;
|
||||||
|
@ -571,7 +570,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
m_physicsMS = 0;
|
m_physicsMS = 0;
|
||||||
m_imageMS = 0;
|
m_imageMS = 0;
|
||||||
m_otherMS = 0;
|
m_otherMS = 0;
|
||||||
// m_spareMS = 0;
|
|
||||||
m_sleeptimeMS = 0;
|
m_sleeptimeMS = 0;
|
||||||
|
|
||||||
//Ckrinke This variable is not used, so comment to remove compiler warning until it is used.
|
//Ckrinke This variable is not used, so comment to remove compiler warning until it is used.
|
||||||
|
@ -646,7 +644,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
if (m_unAckedBytes < 0) m_unAckedBytes = 0;
|
if (m_unAckedBytes < 0) m_unAckedBytes = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addFrameMS(int ms)
|
public void addFrameMS(float ms)
|
||||||
{
|
{
|
||||||
m_frameMS += ms;
|
m_frameMS += ms;
|
||||||
|
|
||||||
|
@ -656,32 +654,32 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
SlowFramesStat.Value++;
|
SlowFramesStat.Value++;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addNetMS(int ms)
|
public void addNetMS(float ms)
|
||||||
{
|
{
|
||||||
m_netMS += ms;
|
m_netMS += ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAgentMS(int ms)
|
public void addAgentMS(float ms)
|
||||||
{
|
{
|
||||||
m_agentMS += ms;
|
m_agentMS += ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addPhysicsMS(int ms)
|
public void addPhysicsMS(float ms)
|
||||||
{
|
{
|
||||||
m_physicsMS += ms;
|
m_physicsMS += ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addImageMS(int ms)
|
public void addImageMS(float ms)
|
||||||
{
|
{
|
||||||
m_imageMS += ms;
|
m_imageMS += ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addOtherMS(int ms)
|
public void addOtherMS(float ms)
|
||||||
{
|
{
|
||||||
m_otherMS += ms;
|
m_otherMS += ms;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addSleepMS(int ms)
|
public void addSleepMS(float ms)
|
||||||
{
|
{
|
||||||
m_sleeptimeMS += ms;
|
m_sleeptimeMS += ms;
|
||||||
}
|
}
|
||||||
|
@ -698,7 +696,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
public void addScriptLines(int count)
|
public void addScriptLines(int count)
|
||||||
{
|
{
|
||||||
m_scriptLinesPerSecond += count;
|
// we need events not lines
|
||||||
|
// m_scriptLinesPerSecond += count;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddPacketsStats(int inPackets, int outPackets, int unAckedBytes)
|
public void AddPacketsStats(int inPackets, int outPackets, int unAckedBytes)
|
||||||
|
|
Loading…
Reference in New Issue