diff options
Diffstat (limited to 'bench/MipMapBench.cpp')
-rw-r--r-- | bench/MipMapBench.cpp | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/bench/MipMapBench.cpp b/bench/MipMapBench.cpp index 36def3ad2d..bffae4292d 100644 --- a/bench/MipMapBench.cpp +++ b/bench/MipMapBench.cpp @@ -14,12 +14,16 @@ class MipMapBench: public Benchmark { SkString fName; const int fW, fH; SkDestinationSurfaceColorMode fColorMode; + bool fHalfFoat; public: - MipMapBench(int w, int h, SkDestinationSurfaceColorMode colorMode) - : fW(w), fH(h), fColorMode(colorMode) + MipMapBench(int w, int h, SkDestinationSurfaceColorMode colorMode, bool halfFloat = false) + : fW(w), fH(h), fColorMode(colorMode), fHalfFoat(halfFloat) { fName.printf("mipmap_build_%dx%d_%d_gamma", w, h, static_cast<int>(colorMode)); + if (halfFloat) { + fName.append("_f16"); + } } protected: @@ -30,7 +34,10 @@ protected: const char* onGetName() override { return fName.c_str(); } void onDelayedSetup() override { - SkImageInfo info = SkImageInfo::MakeS32(fW, fH, kPremul_SkAlphaType); + SkImageInfo info = fHalfFoat ? SkImageInfo::Make(fW, fH, kRGBA_F16_SkColorType, + kPremul_SkAlphaType, + SkColorSpace::MakeSRGBLinear()) + : SkImageInfo::MakeS32(fW, fH, kPremul_SkAlphaType); fBitmap.allocPixels(info); fBitmap.eraseColor(SK_ColorWHITE); // so we don't read uninitialized memory } @@ -56,3 +63,5 @@ DEF_BENCH( return new MipMapBench(512, 512, SkDestinationSurfaceColorMode::kGammaAndColorSpaceAware); ) DEF_BENCH( return new MipMapBench(511, 511, SkDestinationSurfaceColorMode::kGammaAndColorSpaceAware); ) +DEF_BENCH( return new MipMapBench(512, 512, SkDestinationSurfaceColorMode::kLegacy, true); ) +DEF_BENCH( return new MipMapBench(511, 511, SkDestinationSurfaceColorMode::kLegacy, true); ) |