Merge pull request #18998 from Calinou/customizable-performance-reporting-rate

Make the performance reporting update frequency customizable
This commit is contained in:
Max Hilbrunner 2018-05-26 17:31:52 +02:00 committed by GitHub
commit 16974d81d8
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 21 additions and 8 deletions

View file

@ -1071,6 +1071,7 @@ ProjectSettings::ProjectSettings() {
GLOBAL_DEF("rendering/quality/intended_usage/framebuffer_mode", 2); GLOBAL_DEF("rendering/quality/intended_usage/framebuffer_mode", 2);
GLOBAL_DEF("debug/settings/profiler/max_functions", 16384); GLOBAL_DEF("debug/settings/profiler/max_functions", 16384);
GLOBAL_DEF("debug/settings/performance/update_frequency_msec", 250);
//assigning here, because using GLOBAL_GET on every block for compressing can be slow //assigning here, because using GLOBAL_GET on every block for compressing can be slow
Compression::zstd_long_distance_matching = GLOBAL_DEF("compression/formats/zstd/long_distance_matching", false); Compression::zstd_long_distance_matching = GLOBAL_DEF("compression/formats/zstd/long_distance_matching", false);

View file

@ -854,7 +854,7 @@ void ScriptDebuggerRemote::idle_poll() {
if (performance) { if (performance) {
uint64_t pt = OS::get_singleton()->get_ticks_msec(); uint64_t pt = OS::get_singleton()->get_ticks_msec();
if (pt - last_perf_time > 1000) { if (pt - last_perf_time > update_frequency) {
last_perf_time = pt; last_perf_time = pt;
int max = performance->get("MONITOR_MAX"); int max = performance->get("MONITOR_MAX");
@ -1081,7 +1081,7 @@ ScriptDebuggerRemote::ScriptDebuggerRemote() :
eh.userdata = this; eh.userdata = this;
add_error_handler(&eh); add_error_handler(&eh);
profile_info.resize(CLAMP(int(ProjectSettings::get_singleton()->get("debug/settings/profiler/max_functions")), 128, 65535)); profile_info.resize(CLAMP(int(GLOBAL_GET("debug/settings/profiler/max_functions")), 128, 65535));
profile_info_ptrs.resize(profile_info.size()); profile_info_ptrs.resize(profile_info.size());
} }

View file

@ -29,6 +29,7 @@
/*************************************************************************/ /*************************************************************************/
#include "script_language.h" #include "script_language.h"
#include "project_settings.h"
ScriptLanguage *ScriptServer::_languages[MAX_LANGUAGES]; ScriptLanguage *ScriptServer::_languages[MAX_LANGUAGES];
int ScriptServer::_language_count = 0; int ScriptServer::_language_count = 0;
@ -283,6 +284,7 @@ ScriptDebugger::ScriptDebugger() {
lines_left = -1; lines_left = -1;
depth = -1; depth = -1;
break_lang = NULL; break_lang = NULL;
update_frequency = GLOBAL_GET("debug/settings/performance/update_frequency_msec");
} }
bool PlaceHolderScriptInstance::set(const StringName &p_name, const Variant &p_value) { bool PlaceHolderScriptInstance::set(const StringName &p_name, const Variant &p_value) {

View file

@ -352,6 +352,8 @@ class ScriptDebugger {
public: public:
typedef void (*RequestSceneTreeMessageFunc)(void *); typedef void (*RequestSceneTreeMessageFunc)(void *);
int update_frequency;
struct LiveEditFuncs { struct LiveEditFuncs {
void *udata; void *udata;

View file

@ -1706,7 +1706,7 @@ bool Main::start() {
uint64_t Main::last_ticks = 0; uint64_t Main::last_ticks = 0;
uint64_t Main::target_ticks = 0; uint64_t Main::target_ticks = 0;
uint32_t Main::frames = 0; Array Main::frame_times = Array();
uint32_t Main::frame = 0; uint32_t Main::frame = 0;
bool Main::force_redraw_requested = false; bool Main::force_redraw_requested = false;
@ -1825,10 +1825,19 @@ bool Main::iteration() {
script_debugger->idle_poll(); script_debugger->idle_poll();
} }
frames++;
Engine::get_singleton()->_idle_frames++; Engine::get_singleton()->_idle_frames++;
if (frame > 1000000) { // FPS counter
frame_times.push_back(ticks);
int frames = frame_times.size();
while (frame_times.size() > 0 && (int)frame_times.get(0) <= ticks - 1000000) {
frame_times.pop_front();
}
int update_frequency = MAX(1, (int)GLOBAL_GET("debug/settings/performance/update_frequency_msec"));
if (frame > update_frequency * 1000) {
if (editor || project_manager) { if (editor || project_manager) {
if (print_fps) { if (print_fps) {
@ -1844,8 +1853,7 @@ bool Main::iteration() {
idle_process_max = 0; idle_process_max = 0;
physics_process_max = 0; physics_process_max = 0;
frame %= 1000000; frame %= update_frequency * 1000;
frames = 0;
} }
if (fixed_fps != -1) if (fixed_fps != -1)

View file

@ -44,7 +44,7 @@ class Main {
static void print_help(const char *p_binary); static void print_help(const char *p_binary);
static uint64_t last_ticks; static uint64_t last_ticks;
static uint64_t target_ticks; static uint64_t target_ticks;
static uint32_t frames; static Array frame_times;
static uint32_t frame; static uint32_t frame;
static bool force_redraw_requested; static bool force_redraw_requested;