Home | History | Annotate | Download | only in service
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 // This file contains the GPUTrace class.
      6 #ifndef GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_
      7 #define GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_
      8 
      9 #include <string>
     10 
     11 #include "base/basictypes.h"
     12 #include "base/memory/scoped_ptr.h"
     13 #include "base/memory/weak_ptr.h"
     14 #include "base/threading/thread.h"
     15 #include "gpu/command_buffer/service/gles2_cmd_decoder.h"
     16 #include "gpu/gpu_export.h"
     17 #include "ui/gl/gl_bindings.h"
     18 
     19 namespace gpu {
     20 namespace gles2 {
     21 
     22 class Outputter;
     23 class GPUTrace;
     24 
     25 // Id used to keep trace namespaces separate
     26 enum GpuTracerSource {
     27   kTraceGroupInvalid = -1,
     28 
     29   kTraceGroupMarker = 0,
     30   kTraceCHROMIUM = 1,
     31   kTraceDecoder = 2,
     32 
     33   NUM_TRACER_SOURCES
     34 };
     35 
     36 enum GpuTracerType {
     37   kTracerTypeInvalid = -1,
     38 
     39   kTracerTypeARBTimer,
     40   kTracerTypeDisjointTimer
     41 };
     42 
     43 // Marker structure for a Trace.
     44 struct TraceMarker {
     45   TraceMarker(const std::string& name);
     46   ~TraceMarker();
     47 
     48   std::string name_;
     49   scoped_refptr<GPUTrace> trace_;
     50 };
     51 
     52 // Traces GPU Commands.
     53 class GPUTracer : public base::SupportsWeakPtr<GPUTracer> {
     54  public:
     55   explicit GPUTracer(gles2::GLES2Decoder* decoder);
     56   ~GPUTracer();
     57 
     58   // Scheduled processing in decoder begins.
     59   bool BeginDecoding();
     60 
     61   // Scheduled processing in decoder ends.
     62   bool EndDecoding();
     63 
     64   // Begin a trace marker.
     65   bool Begin(const std::string& name, GpuTracerSource source);
     66 
     67   // End the last started trace marker.
     68   bool End(GpuTracerSource source);
     69 
     70   bool IsTracing();
     71 
     72   // Retrieve the name of the current open trace.
     73   // Returns empty string if no current open trace.
     74   const std::string& CurrentName() const;
     75 
     76  private:
     77   // Trace Processing.
     78   scoped_refptr<GPUTrace> CreateTrace(const std::string& name);
     79   void Process();
     80   void ProcessTraces();
     81 
     82   void CalculateTimerOffset();
     83   void IssueProcessTask();
     84 
     85   scoped_refptr<Outputter> outputter_;
     86   std::vector<TraceMarker> markers_[NUM_TRACER_SOURCES];
     87   std::deque<scoped_refptr<GPUTrace> > traces_;
     88 
     89   const unsigned char* gpu_trace_srv_category;
     90   const unsigned char* gpu_trace_dev_category;
     91   gles2::GLES2Decoder* decoder_;
     92 
     93   int64 timer_offset_;
     94   GpuTracerSource last_tracer_source_;
     95 
     96   GpuTracerType tracer_type_;
     97   bool gpu_timing_synced_;
     98   bool gpu_executing_;
     99   bool process_posted_;
    100 
    101   DISALLOW_COPY_AND_ASSIGN(GPUTracer);
    102 };
    103 
    104 class Outputter : public base::RefCounted<Outputter> {
    105  public:
    106   virtual void Trace(const std::string& name,
    107                      int64 start_time,
    108                      int64 end_time) = 0;
    109 
    110  protected:
    111   virtual ~Outputter() {}
    112   friend class base::RefCounted<Outputter>;
    113 };
    114 
    115 class TraceOutputter : public Outputter {
    116  public:
    117   static scoped_refptr<TraceOutputter> Create(const std::string& name);
    118   virtual void Trace(const std::string& name,
    119                      int64 start_time,
    120                      int64 end_time) OVERRIDE;
    121 
    122  protected:
    123   friend class base::RefCounted<Outputter>;
    124   explicit TraceOutputter(const std::string& name);
    125   virtual ~TraceOutputter();
    126 
    127   base::Thread named_thread_;
    128   uint64 local_trace_id_;
    129 
    130   DISALLOW_COPY_AND_ASSIGN(TraceOutputter);
    131 };
    132 
    133 class GPU_EXPORT GPUTrace
    134     : public base::RefCounted<GPUTrace> {
    135  public:
    136   GPUTrace(scoped_refptr<Outputter> outputter,
    137            const std::string& name,
    138            int64 offset,
    139            GpuTracerType tracer_type);
    140 
    141   bool IsEnabled() { return tracer_type_ != kTracerTypeInvalid; }
    142   const std::string& name() { return name_; }
    143 
    144   void Start();
    145   void End();
    146   bool IsAvailable();
    147   void Process();
    148 
    149  private:
    150   ~GPUTrace();
    151 
    152   void Output();
    153 
    154   friend class base::RefCounted<GPUTrace>;
    155 
    156   std::string name_;
    157   scoped_refptr<Outputter> outputter_;
    158 
    159   int64 offset_;
    160   int64 start_time_;
    161   int64 end_time_;
    162   GpuTracerType tracer_type_;
    163   bool end_requested_;
    164 
    165   GLuint queries_[2];
    166 
    167   DISALLOW_COPY_AND_ASSIGN(GPUTrace);
    168 };
    169 
    170 }  // namespace gles2
    171 }  // namespace gpu
    172 
    173 #endif  // GPU_COMMAND_BUFFER_SERVICE_GPU_TRACER_H_
    174