// Copyright 2016 The SwiftShader Authors. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include "Config.hpp" #include "System/Thread.hpp" #include "System/Timer.hpp" namespace sw { Profiler profiler; Profiler::Profiler() { reset(); } void Profiler::reset() { framesSec = 0; framesTotal = 0; FPS = 0; #if PERF_PROFILE for(int i = 0; i < PERF_TIMERS; i++) { cycles[i] = 0; } ropOperations = 0; ropOperationsTotal = 0; ropOperationsFrame = 0; texOperations = 0; texOperationsTotal = 0; texOperationsFrame = 0; compressedTex = 0; compressedTexTotal = 0; compressedTexFrame = 0; #endif }; void Profiler::nextFrame() { #if PERF_PROFILE ropOperationsFrame = sw::atomicExchange(&ropOperations, 0); texOperationsFrame = sw::atomicExchange(&texOperations, 0); compressedTexFrame = sw::atomicExchange(&compressedTex, 0); ropOperationsTotal += ropOperationsFrame; texOperationsTotal += texOperationsFrame; compressedTexTotal += compressedTexFrame; #endif static double fpsTime = sw::Timer::seconds(); double time = sw::Timer::seconds(); double delta = time - fpsTime; framesSec++; if(delta > 1.0) { FPS = framesSec / delta; fpsTime = time; framesTotal += framesSec; framesSec = 0; } } }