05da783f87
This reverts commit c8b721b086
.
Reason for revert: Looks like it's causing build failures around
MakeRenderTargetContext on the roll.
Original change's description:
> Make SkGpuDevice hold a GrRecordingContext
>
> This makes the code reflect what is actually going on. During DDL
> recording the SkGpuDevice only holds a recording context.
>
> This can't land until the following Chrome-side CL lands:
>
> https://chromium-review.googlesource.com/c/chromium/src/+/2277964 (Add GrContext.h include to skia renderer for upcoming Skia roll)
>
> Change-Id: I69cfa744226c315c25f68fc509b7b59ec38bbf31
> Reviewed-on: https://skia-review.googlesource.com/c/skia/+/299867
> Commit-Queue: Robert Phillips <robertphillips@google.com>
> Reviewed-by: Brian Salomon <bsalomon@google.com>
> Reviewed-by: Adlai Holler <adlai@google.com>
TBR=bsalomon@google.com,robertphillips@google.com,adlai@google.com
Change-Id: I6a362daf7c40e36ed9f068c5b2d477c16a3f778e
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/300853
Reviewed-by: Chris Dalton <csmartdalton@google.com>
Commit-Queue: Chris Dalton <csmartdalton@google.com>
80 lines
2.5 KiB
C++
80 lines
2.5 KiB
C++
/*
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#include "bench/Benchmark.h"
|
|
#include "include/core/SkCanvas.h"
|
|
#include "include/core/SkImage.h"
|
|
#include "include/core/SkPaint.h"
|
|
#include "include/core/SkSurface.h"
|
|
|
|
class GrMipMapBench: public Benchmark {
|
|
sk_sp<SkSurface> fSurface;
|
|
SkString fName;
|
|
const int fW, fH;
|
|
|
|
public:
|
|
GrMipMapBench(int w, int h) : fW(w), fH(h) {
|
|
fName.printf("gr_mipmap_build_%dx%d", w, h);
|
|
}
|
|
|
|
protected:
|
|
bool isSuitableFor(Backend backend) override {
|
|
return kGPU_Backend == backend;
|
|
}
|
|
|
|
const char* onGetName() override { return fName.c_str(); }
|
|
|
|
void onDraw(int loops, SkCanvas* canvas) override {
|
|
if (!fSurface) {
|
|
GrContext* context = canvas->getGrContext();
|
|
if (nullptr == context) {
|
|
return;
|
|
}
|
|
auto srgb = SkColorSpace::MakeSRGB();
|
|
SkImageInfo info =
|
|
SkImageInfo::Make(fW, fH, kRGBA_8888_SkColorType, kPremul_SkAlphaType, srgb);
|
|
// We're benching the regeneration of the mip levels not the need to allocate them every
|
|
// frame. Thus we create the surface with mips to begin with.
|
|
fSurface = SkSurface::MakeRenderTarget(context, SkBudgeted::kNo, info, 0,
|
|
kBottomLeft_GrSurfaceOrigin, nullptr, true);
|
|
|
|
}
|
|
|
|
// Clear surface once:
|
|
fSurface->getCanvas()->clear(SK_ColorBLACK);
|
|
|
|
SkPaint paint;
|
|
paint.setFilterQuality(kMedium_SkFilterQuality);
|
|
paint.setColor(SK_ColorWHITE);
|
|
for (int i = 0; i < loops; i++) {
|
|
// Touch surface so mips are dirtied
|
|
fSurface->getCanvas()->drawPoint(0, 0, paint);
|
|
|
|
// Draw reduced version of surface to original canvas, to trigger mip generation
|
|
canvas->save();
|
|
canvas->scale(0.1f, 0.1f);
|
|
canvas->drawImage(fSurface->makeImageSnapshot(), 0, 0, &paint);
|
|
canvas->restore();
|
|
}
|
|
}
|
|
|
|
void onPerCanvasPostDraw(SkCanvas*) override {
|
|
fSurface.reset(nullptr);
|
|
}
|
|
|
|
private:
|
|
typedef Benchmark INHERITED;
|
|
};
|
|
|
|
// Build variants that exercise the width and heights being even or odd at each level, as the
|
|
// impl specializes on each of these.
|
|
//
|
|
DEF_BENCH( return new GrMipMapBench(511, 511); )
|
|
DEF_BENCH( return new GrMipMapBench(512, 511); )
|
|
DEF_BENCH( return new GrMipMapBench(511, 512); )
|
|
DEF_BENCH( return new GrMipMapBench(512, 512); )
|