Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2180)

Unified Diff: content/renderer/skia_benchmarking_extension.cc

Issue 19266015: [SkiaBenchmarkingExtension] Add draw command timing info. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased. Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/skia_benchmarking_extension.cc
diff --git a/content/renderer/skia_benchmarking_extension.cc b/content/renderer/skia_benchmarking_extension.cc
deleted file mode 100644
index 078b51d2cd24d425a6f499e5e6ba015a307e139d..0000000000000000000000000000000000000000
--- a/content/renderer/skia_benchmarking_extension.cc
+++ /dev/null
@@ -1,243 +0,0 @@
-// Copyright (c) 2013 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 "content/renderer/skia_benchmarking_extension.h"
-
-#include "base/values.h"
-#include "cc/base/math_util.h"
-#include "cc/resources/picture.h"
-#include "content/public/renderer/v8_value_converter.h"
-#include "third_party/WebKit/public/platform/WebArrayBuffer.h"
-#include "third_party/WebKit/public/web/WebFrame.h"
-#include "third_party/skia/include/core/SkCanvas.h"
-#include "third_party/skia/include/core/SkColorPriv.h"
-#include "third_party/skia/include/core/SkGraphics.h"
-#include "third_party/skia/src/utils/debugger/SkDebugCanvas.h"
-#include "third_party/skia/src/utils/debugger/SkDrawCommand.h"
-#include "ui/gfx/rect_conversions.h"
-#include "ui/gfx/skia_util.h"
-#include "v8/include/v8.h"
-
-using WebKit::WebFrame;
-
-namespace {
-
-const char kSkiaBenchmarkingExtensionName[] = "v8/SkiaBenchmarking";
-
-static scoped_refptr<cc::Picture> ParsePictureArg(v8::Handle<v8::Value> arg) {
- scoped_ptr<content::V8ValueConverter> converter(
- content::V8ValueConverter::create());
-
- v8::String::Value v8_picture(arg);
- scoped_ptr<base::Value> picture_value(
- converter->FromV8Value(arg, v8::Context::GetCurrent()));
- if (!picture_value)
- return NULL;
-
- return cc::Picture::CreateFromValue(picture_value.get());
-}
-
-class SkiaBenchmarkingWrapper : public v8::Extension {
- public:
- SkiaBenchmarkingWrapper() :
- v8::Extension(kSkiaBenchmarkingExtensionName,
- "if (typeof(chrome) == 'undefined') {"
- " chrome = {};"
- "};"
- "if (typeof(chrome.skiaBenchmarking) == 'undefined') {"
- " chrome.skiaBenchmarking = {};"
- "};"
- "chrome.skiaBenchmarking.rasterize = function(picture, params) {"
- " /* "
- " Rasterizes a Picture JSON-encoded by cc::Picture::AsValue()."
- " @param {Object} picture A json-encoded cc::Picture."
- " @param {"
- " 'scale': {Number},"
- " 'stop': {Number},"
- " 'clip': [Number, Number, Number, Number]"
- " } (optional) Rasterization parameters."
- " @returns {"
- " 'width': {Number},"
- " 'height': {Number},"
- " 'data': {ArrayBuffer}"
- " }"
- " @returns undefined if the arguments are invalid or the picture"
- " version is not supported."
- " */"
- " native function Rasterize();"
- " return Rasterize(picture, params);"
- "};"
- "chrome.skiaBenchmarking.getOps = function(picture) {"
- " /* "
- " Extracts the Skia draw commands from a JSON-encoded cc::Picture"
- " @param {Object} picture A json-encoded cc::Picture."
- " @returns [{ 'cmd': {String}, 'info': [String, ...] }, ...]"
- " @returns undefined if the arguments are invalid or the picture"
- " version is not supported."
- " */"
- " native function GetOps();"
- " return GetOps(picture);"
- "};"
- ) {
- content::SkiaBenchmarkingExtension::InitSkGraphics();
- }
-
- virtual v8::Handle<v8::FunctionTemplate> GetNativeFunction(
- v8::Handle<v8::String> name) OVERRIDE {
- if (name->Equals(v8::String::New("Rasterize")))
- return v8::FunctionTemplate::New(Rasterize);
- if (name->Equals(v8::String::New("GetOps")))
- return v8::FunctionTemplate::New(GetOps);
-
- return v8::Handle<v8::FunctionTemplate>();
- }
-
- static void Rasterize(const v8::FunctionCallbackInfo<v8::Value>& args) {
- if (args.Length() < 1)
- return;
-
- scoped_refptr<cc::Picture> picture = ParsePictureArg(args[0]);
- if (!picture.get())
- return;
-
- double scale = 1.0;
- gfx::Rect clip_rect(picture->LayerRect());
- int stop_index = -1;
-
- if (args.Length() > 1) {
- scoped_ptr<content::V8ValueConverter> converter(
- content::V8ValueConverter::create());
- scoped_ptr<base::Value> params_value(
- converter->FromV8Value(args[1], v8::Context::GetCurrent()));
-
- const base::DictionaryValue* params_dict = NULL;
- if (params_value.get() && params_value->GetAsDictionary(&params_dict)) {
- params_dict->GetDouble("scale", &scale);
- params_dict->GetInteger("stop", &stop_index);
-
- const base::Value* clip_value = NULL;
- if (params_dict->Get("clip", &clip_value))
- cc::MathUtil::FromValue(clip_value, &clip_rect);
- }
- }
-
- gfx::RectF clip(clip_rect);
- clip.Intersect(picture->LayerRect());
- clip.Scale(scale);
- gfx::Rect snapped_clip = gfx::ToEnclosingRect(clip);
-
- const int kMaxBitmapSize = 4096;
- if (snapped_clip.width() > kMaxBitmapSize
- || snapped_clip.height() > kMaxBitmapSize)
- return;
-
- SkBitmap bitmap;
- bitmap.setConfig(SkBitmap::kARGB_8888_Config, snapped_clip.width(),
- snapped_clip.height());
- if (!bitmap.allocPixels())
- return;
- bitmap.eraseARGB(0, 0, 0, 0);
-
- SkCanvas canvas(bitmap);
- canvas.translate(SkFloatToScalar(-clip.x()),
- SkFloatToScalar(-clip.y()));
- canvas.clipRect(gfx::RectToSkRect(snapped_clip));
- canvas.scale(scale, scale);
- canvas.translate(picture->LayerRect().x(),
- picture->LayerRect().y());
-
- // First, build a debug canvas for the given picture.
- SkDebugCanvas debug_canvas(picture->LayerRect().width(),
- picture->LayerRect().height());
- picture->Replay(&debug_canvas);
-
- // Raster the requested command subset into the bitmap-backed canvas.
- int last_index = debug_canvas.getSize() - 1;
- debug_canvas.drawTo(&canvas, stop_index < 0
- ? last_index
- : std::min(last_index, stop_index));
-
- WebKit::WebArrayBuffer buffer =
- WebKit::WebArrayBuffer::create(bitmap.getSize(), 1);
- uint32* packed_pixels = reinterpret_cast<uint32*>(bitmap.getPixels());
- uint8* buffer_pixels = reinterpret_cast<uint8*>(buffer.data());
- // Swizzle from native Skia format to RGBA as we copy out.
- for (size_t i = 0; i < bitmap.getSize(); i += 4) {
- uint32 c = packed_pixels[i >> 2];
- buffer_pixels[i] = SkGetPackedR32(c);
- buffer_pixels[i + 1] = SkGetPackedG32(c);
- buffer_pixels[i + 2] = SkGetPackedB32(c);
- buffer_pixels[i + 3] = SkGetPackedA32(c);
- }
-
- v8::Handle<v8::Object> result = v8::Object::New();
- result->Set(v8::String::New("width"),
- v8::Number::New(snapped_clip.width()));
- result->Set(v8::String::New("height"),
- v8::Number::New(snapped_clip.height()));
- result->Set(v8::String::New("data"), buffer.toV8Value());
-
- args.GetReturnValue().Set(result);
- }
-
- static void GetOps(const v8::FunctionCallbackInfo<v8::Value>& args) {
- if (args.Length() != 1)
- return;
-
- scoped_refptr<cc::Picture> picture = ParsePictureArg(args[0]);
- if (!picture.get())
- return;
-
- gfx::Rect bounds = picture->LayerRect();
- SkDebugCanvas canvas(bounds.width(), bounds.height());
- picture->Replay(&canvas);
-
- v8::Local<v8::Array> result = v8::Array::New(canvas.getSize());
- for (int i = 0; i < canvas.getSize(); ++i) {
- DrawType cmd_type = canvas.getDrawCommandAt(i)->getType();
- v8::Handle<v8::Object> cmd = v8::Object::New();
- cmd->Set(v8::String::New("cmd_type"), v8::Integer::New(cmd_type));
- cmd->Set(v8::String::New("cmd_string"), v8::String::New(
- SkDrawCommand::GetCommandString(cmd_type)));
-
- SkTDArray<SkString*>* info = canvas.getCommandInfo(i);
- DCHECK(info);
-
- v8::Local<v8::Array> v8_info = v8::Array::New(info->count());
- for (int j = 0; j < info->count(); ++j) {
- const SkString* info_str = (*info)[j];
- DCHECK(info_str);
- v8_info->Set(j, v8::String::New(info_str->c_str()));
- }
-
- cmd->Set(v8::String::New("info"), v8_info);
-
- result->Set(i, cmd);
- }
-
- args.GetReturnValue().Set(result);
- }
-};
-
-} // namespace
-
-namespace content {
-
-v8::Extension* SkiaBenchmarkingExtension::Get() {
- return new SkiaBenchmarkingWrapper();
-}
-
-void SkiaBenchmarkingExtension::InitSkGraphics() {
- // Always call on the main render thread.
- // Does not need to be thread-safe, as long as the above holds.
- // FIXME: remove this after Skia updates SkGraphics::Init() to be
- // thread-safe and idempotent.
- static bool skia_initialized = false;
- if (!skia_initialized) {
- SkGraphics::Init();
- skia_initialized = true;
- }
-}
-
-} // namespace content

Powered by Google App Engine
This is Rietveld 408576698