aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--bench/MipMapBench.cpp15
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); )