// Copyright (c) 2012 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.
// This file contains the GPUTrace class.
#ifndef GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_
#define GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_
#include <string>
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/weak_ptr.h"
#include "base/threading/thread.h"
#include "gpu/command_buffer/service/gles2_cmd_decoder.h"
#include "gpu/gpu_export.h"
#include "ui/gl/gl_bindings.h"
namespace gpu {
namespace gles2 {
// Id used to keep trace namespaces separate
enum GpuTracerSource {
kTraceGroupMarker = 0,
kTraceCHROMIUM = 1,
kTraceDecoder = 2,
};
// Traces GPU Commands.
class GPUTracer {
public:
static scoped_ptr<GPUTracer> Create(gles2::GLES2Decoder* decoder);
GPUTracer();
virtual ~GPUTracer();
// Scheduled processing in decoder begins.
virtual bool BeginDecoding() = 0;
// Scheduled processing in decoder ends.
virtual bool EndDecoding() = 0;
// Begin a trace marker.
virtual bool Begin(const std::string& name, GpuTracerSource source) = 0;
// End the last started trace marker.
virtual bool End(GpuTracerSource source) = 0;
virtual bool IsTracing() = 0;
// Retrieve the name of the current open trace.
// Returns empty string if no current open trace.
virtual const std::string& CurrentName() const = 0;
private:
DISALLOW_COPY_AND_ASSIGN(GPUTracer);
};
class Outputter : public base::RefCounted<Outputter> {
public:
virtual void Trace(const std::string& name,
int64 start_time,
int64 end_time) = 0;
protected:
virtual ~Outputter() {}
friend class base::RefCounted<Outputter>;
};
class TraceOutputter : public Outputter {
public:
static scoped_refptr<TraceOutputter> Create(const std::string& name);
virtual void Trace(const std::string& name,
int64 start_time,
int64 end_time) OVERRIDE;
protected:
friend class base::RefCounted<Outputter>;
explicit TraceOutputter(const std::string& name);
virtual ~TraceOutputter();
base::Thread named_thread_;
uint64 local_trace_id_;
DISALLOW_COPY_AND_ASSIGN(TraceOutputter);
};
class GPU_EXPORT Trace : public base::RefCounted<Trace> {
public:
explicit Trace(const std::string& name) : name_(name) {}
virtual void Start() = 0;
virtual void End() = 0;
// True if the the results of this query are available.
virtual bool IsAvailable() = 0;
virtual bool IsProcessable();
virtual void Process() = 0;
virtual const std::string& name();
protected:
virtual ~Trace() {}
private:
friend class base::RefCounted<Trace>;
std::string name_;
DISALLOW_COPY_AND_ASSIGN(Trace);
};
class GPU_EXPORT GLARBTimerTrace : public Trace {
public:
GLARBTimerTrace(scoped_refptr<Outputter> outputter,
const std::string& name,
int64 offset);
// Implementation of Tracer
virtual void Start() OVERRIDE;
virtual void End() OVERRIDE;
virtual bool IsAvailable() OVERRIDE;
virtual void Process() OVERRIDE;
private:
virtual ~GLARBTimerTrace();
void Output();
scoped_refptr<Outputter> outputter_;
int64 offset_;
int64 start_time_;
int64 end_time_;
bool end_requested_;
GLuint queries_[2];
DISALLOW_COPY_AND_ASSIGN(GLARBTimerTrace);
};
} // namespace gles2
} // namespace gpu
#endif // GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_