| Index: bench/MergeBench.cpp
 | 
| diff --git a/bench/MergeBench.cpp b/bench/MergeBench.cpp
 | 
| index e1f7d97b5eb5483293f5850567a38b1816c07990..061a4d36f3201478b230d590534168193ad235d3 100644
 | 
| --- a/bench/MergeBench.cpp
 | 
| +++ b/bench/MergeBench.cpp
 | 
| @@ -16,6 +16,41 @@
 | 
|  #define FILTER_WIDTH_LARGE  SkIntToScalar(256)
 | 
|  #define FILTER_HEIGHT_LARGE SkIntToScalar(256)
 | 
|  
 | 
| +static sk_sp<SkImage> make_bitmap() {
 | 
| +    sk_sp<SkSurface> surface(SkSurface::MakeRasterN32Premul(80, 80));
 | 
| +    surface->getCanvas()->clear(0x00000000);
 | 
| +    SkPaint paint;
 | 
| +    paint.setAntiAlias(true);
 | 
| +    paint.setColor(0xFF884422);
 | 
| +    paint.setTextSize(SkIntToScalar(96));
 | 
| +    const char* str = "g";
 | 
| +    surface->getCanvas()->drawText(str, strlen(str), 15, 55, paint);
 | 
| +    return surface->makeImageSnapshot();
 | 
| +}
 | 
| +
 | 
| +static sk_sp<SkImage> make_checkerboard() {
 | 
| +    sk_sp<SkSurface> surface(SkSurface::MakeRasterN32Premul(80, 80));
 | 
| +    SkCanvas* canvas = surface->getCanvas();
 | 
| +    canvas->clear(0x00000000);
 | 
| +    SkPaint darkPaint;
 | 
| +    darkPaint.setColor(0xFF804020);
 | 
| +    SkPaint lightPaint;
 | 
| +    lightPaint.setColor(0xFF244484);
 | 
| +    for (int y = 0; y < 80; y += 16) {
 | 
| +        for (int x = 0; x < 80; x += 16) {
 | 
| +            canvas->save();
 | 
| +            canvas->translate(SkIntToScalar(x), SkIntToScalar(y));
 | 
| +            canvas->drawRect(SkRect::MakeXYWH(0, 0, 8, 8), darkPaint);
 | 
| +            canvas->drawRect(SkRect::MakeXYWH(8, 0, 8, 8), lightPaint);
 | 
| +            canvas->drawRect(SkRect::MakeXYWH(0, 8, 8, 8), lightPaint);
 | 
| +            canvas->drawRect(SkRect::MakeXYWH(8, 8, 8, 8), darkPaint);
 | 
| +            canvas->restore();
 | 
| +        }
 | 
| +    }
 | 
| +
 | 
| +    return surface->makeImageSnapshot();
 | 
| +}
 | 
| +
 | 
|  class MergeBench : public Benchmark {
 | 
|  public:
 | 
|      MergeBench(bool small) : fIsSmall(small), fInitialized(false) { }
 | 
| @@ -27,8 +62,8 @@ protected:
 | 
|  
 | 
|      void onDelayedSetup() override {
 | 
|          if (!fInitialized) {
 | 
| -            make_bitmap();
 | 
| -            make_checkerboard();
 | 
| +            fImage = make_bitmap();
 | 
| +            fCheckerboard = make_checkerboard();
 | 
|              fInitialized = true;
 | 
|          }
 | 
|      }
 | 
| @@ -37,52 +72,17 @@ protected:
 | 
|          SkRect r = fIsSmall ? SkRect::MakeWH(FILTER_WIDTH_SMALL, FILTER_HEIGHT_SMALL) :
 | 
|                                SkRect::MakeWH(FILTER_WIDTH_LARGE, FILTER_HEIGHT_LARGE);
 | 
|          SkPaint paint;
 | 
| -        paint.setImageFilter(mergeBitmaps())->unref();
 | 
| +        paint.setImageFilter(this->mergeBitmaps());
 | 
|          for (int i = 0; i < loops; i++) {
 | 
|              canvas->drawRect(r, paint);
 | 
|          }
 | 
|      }
 | 
|  
 | 
|  private:
 | 
| -    SkImageFilter* mergeBitmaps() {
 | 
| -        SkAutoTUnref<SkImageFilter> first(SkImageSource::Create(fCheckerboard.get()));
 | 
| -        SkAutoTUnref<SkImageFilter> second(SkImageSource::Create(fImage.get()));
 | 
| -        return SkMergeImageFilter::Create(first, second);
 | 
| -    }
 | 
| -
 | 
| -    void make_bitmap() {
 | 
| -        auto surface(SkSurface::MakeRasterN32Premul(80, 80));
 | 
| -        surface->getCanvas()->clear(0x00000000);
 | 
| -        SkPaint paint;
 | 
| -        paint.setAntiAlias(true);
 | 
| -        paint.setColor(0xFF884422);
 | 
| -        paint.setTextSize(SkIntToScalar(96));
 | 
| -        const char* str = "g";
 | 
| -        surface->getCanvas()->drawText(str, strlen(str), 15, 55, paint);
 | 
| -        fImage = surface->makeImageSnapshot();
 | 
| -    }
 | 
| -
 | 
| -    void make_checkerboard() {
 | 
| -        auto surface(SkSurface::MakeRasterN32Premul(80, 80));
 | 
| -        SkCanvas* canvas = surface->getCanvas();
 | 
| -        canvas->clear(0x00000000);
 | 
| -        SkPaint darkPaint;
 | 
| -        darkPaint.setColor(0xFF804020);
 | 
| -        SkPaint lightPaint;
 | 
| -        lightPaint.setColor(0xFF244484);
 | 
| -        for (int y = 0; y < 80; y += 16) {
 | 
| -            for (int x = 0; x < 80; x += 16) {
 | 
| -                canvas->save();
 | 
| -                canvas->translate(SkIntToScalar(x), SkIntToScalar(y));
 | 
| -                canvas->drawRect(SkRect::MakeXYWH(0, 0, 8, 8), darkPaint);
 | 
| -                canvas->drawRect(SkRect::MakeXYWH(8, 0, 8, 8), lightPaint);
 | 
| -                canvas->drawRect(SkRect::MakeXYWH(0, 8, 8, 8), lightPaint);
 | 
| -                canvas->drawRect(SkRect::MakeXYWH(8, 8, 8, 8), darkPaint);
 | 
| -                canvas->restore();
 | 
| -            }
 | 
| -        }
 | 
| -
 | 
| -        fCheckerboard = surface->makeImageSnapshot();
 | 
| +    sk_sp<SkImageFilter> mergeBitmaps() {
 | 
| +        sk_sp<SkImageFilter> first(SkImageSource::Create(fCheckerboard.get()));
 | 
| +        sk_sp<SkImageFilter> second(SkImageSource::Create(fImage.get()));
 | 
| +        return SkMergeImageFilter::Make(std::move(first), std::move(second));
 | 
|      }
 | 
|  
 | 
|      bool fIsSmall;
 | 
| 
 |