1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef THIRD_PARTY_BLINK_RENDERER_PLATFORM_GRAPHICS_SCOPED_RASTER_TIMER_H_
#define THIRD_PARTY_BLINK_RENDERER_PLATFORM_GRAPHICS_SCOPED_RASTER_TIMER_H_
#include <optional>
#include "base/timer/elapsed_timer.h"
#include "gpu/command_buffer/client/raster_interface.h"
#include "third_party/blink/renderer/platform/platform_export.h"
#include "third_party/blink/renderer/platform/wtf/vector.h"
namespace blink {
class PLATFORM_EXPORT ScopedRasterTimer {
STACK_ALLOCATED();
public:
class Host;
// raster_interface: pass null if rasterization is not gpu-accelerated
ScopedRasterTimer(gpu::raster::RasterInterface* raster_interface,
Host& host,
bool always_measure_for_testing);
~ScopedRasterTimer();
// Histogram names.
static constexpr const char* const kRasterDurationUnacceleratedHistogram =
"Blink.Canvas.RasterDuration.Unaccelerated";
static constexpr const char* const kRasterDurationAcceleratedCpuHistogram =
"Blink.Canvas.RasterDuration.Accelerated.CPU";
static constexpr const char* const kRasterDurationAcceleratedGpuHistogram =
"Blink.Canvas.RasterDuration.Accelerated.GPU";
static constexpr const char* const kRasterDurationAcceleratedTotalHistogram =
"Blink.Canvas.RasterDuration.Accelerated.Total";
private:
class AsyncGpuRasterTimer {
public:
// At construction time: starts tracking commands issued to the gpu
// interface.
explicit AsyncGpuRasterTimer(
gpu::raster::RasterInterface& raster_interface);
// Stop tracking issue command
void FinishedIssuingCommands(gpu::raster::RasterInterface& raster_interface,
base::TimeDelta cpu_raster_duration);
// Returns true if the timer is done (i.e. all commands issued before
// call to FinishedIssuingCommands have been executed and timed on the
// service side). Must wait for this method to return true before
// destroying `this`, otherwise the measurement will be lost.
bool CheckTimer(gpu::raster::RasterInterface& raster_interface);
~AsyncGpuRasterTimer() = default;
private:
GLuint done_ = 0;
GLuint gl_query_id_ = 0u;
base::TimeDelta cpu_raster_duration_;
};
public:
// Classes with methods that use ScopedRasterTimer must inherit
// ScopedRasterTimer::Host
class Host {
public:
void CheckGpuTimers(gpu::raster::RasterInterface* raster_interface);
void AddGpuTimer(std::unique_ptr<AsyncGpuRasterTimer>);
private:
WTF::Vector<std::unique_ptr<AsyncGpuRasterTimer>> gpu_timers_;
};
private:
bool active_ = false;
// Optional. nullptr indicates that raster work load is not GPU accelerated.
gpu::raster::RasterInterface* const raster_interface_;
std::optional<base::ElapsedTimer> timer_;
std::unique_ptr<AsyncGpuRasterTimer> gpu_timer_;
Host& host_;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_RENDERER_PLATFORM_GRAPHICS_SCOPED_RASTER_TIMER_H_
|