blob: 1b0d46d6e7c1d8dcb1f9327c498f5e5b4ff8cef7 [file] [log] [blame]
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "gpu/perftests/measurements.h"
#include <stdint.h>
#include "base/logging.h"
#include "testing/perf/perf_test.h"
#include "ui/gl/gpu_timing.h"
namespace gpu {
Measurement::Measurement() : name(), wall_time(), cpu_time(), gpu_time() {
}
Measurement::Measurement(const Measurement& m)
: name(m.name),
wall_time(m.wall_time),
cpu_time(m.cpu_time),
gpu_time(m.gpu_time) {
}
Measurement::Measurement(const std::string& name,
const base::TimeDelta wall_time,
const base::TimeDelta cpu_time,
const base::TimeDelta gpu_time)
: name(name), wall_time(wall_time), cpu_time(cpu_time), gpu_time(gpu_time) {
}
void Measurement::PrintResult(const std::string& graph) const {
perf_test::PrintResult(graph, "", name + "_wall", wall_time.InMillisecondsF(),
"ms", true);
if (cpu_time.InMicroseconds() >= 0) {
perf_test::PrintResult(graph, "", name + "_cpu", cpu_time.InMillisecondsF(),
"ms", true);
}
if (gpu_time.InMicroseconds() >= 0) {
perf_test::PrintResult(graph, "", name + "_gpu", gpu_time.InMillisecondsF(),
"ms", true);
}
}
Measurement& Measurement::Increment(const Measurement& m) {
wall_time += m.wall_time;
cpu_time += m.cpu_time;
gpu_time += m.gpu_time;
return *this;
}
Measurement Measurement::Divide(int a) const {
return Measurement(name, wall_time / a, cpu_time / a, gpu_time / a);
}
Measurement::~Measurement() {
}
MeasurementTimers::MeasurementTimers(gl::GPUTimingClient* gpu_timing_client)
: wall_time_start_(), cpu_time_start_(), gpu_timer_() {
DCHECK(gpu_timing_client);
wall_time_start_ = base::TimeTicks::Now();
if (base::ThreadTicks::IsSupported()) {
base::ThreadTicks::WaitUntilInitialized();
cpu_time_start_ = base::ThreadTicks::Now();
} else {
static bool logged_once = false;
LOG_IF(WARNING, !logged_once) << "ThreadTicks not supported.";
logged_once = true;
}
if (gpu_timing_client->IsAvailable()) {
gpu_timer_ = gpu_timing_client->CreateGPUTimer(true);
gpu_timer_->Start();
}
}
void MeasurementTimers::Record() {
wall_time_ = base::TimeTicks::Now() - wall_time_start_;
if (base::ThreadTicks::IsSupported()) {
cpu_time_ = base::ThreadTicks::Now() - cpu_time_start_;
}
if (gpu_timer_.get()) {
gpu_timer_->End();
}
}
Measurement MeasurementTimers::GetAsMeasurement(const std::string& name) {
DCHECK_NE(base::TimeDelta(),
wall_time_); // At least wall_time_ has been set.
if (!base::ThreadTicks::IsSupported()) {
cpu_time_ = base::TimeDelta::FromMicroseconds(-1);
}
int64_t gpu_time = -1;
if (gpu_timer_.get() != nullptr && gpu_timer_->IsAvailable()) {
gpu_time = gpu_timer_->GetDeltaElapsed();
}
return Measurement(name, wall_time_, cpu_time_,
base::TimeDelta::FromMicroseconds(gpu_time));
}
MeasurementTimers::~MeasurementTimers() {
if (gpu_timer_.get()) {
gpu_timer_->Destroy(true);
}
}
} // namespace gpu