Index: bench/Xfer4fBench.cpp |
diff --git a/bench/Xfer4fBench.cpp b/bench/Xfer4fBench.cpp |
index f2bcedc3ed077e7ab8cbb8ebd186a280dae1e87a..bc234a7edbeb14b19786b54f663c846420184dda 100644 |
--- a/bench/Xfer4fBench.cpp |
+++ b/bench/Xfer4fBench.cpp |
@@ -15,20 +15,22 @@ |
#define INNER_LOOPS 1000 |
// Benchmark that draws non-AA rects or AA text with an SkXfermode::Mode. |
-class Xfer4fBench : public Benchmark { |
+class XferD32Bench : public Benchmark { |
public: |
- Xfer4fBench(SkXfermode::Mode mode, const char name[], bool doN, uint32_t flags) |
+ XferD32Bench(SkXfermode::Mode mode, const char name[], bool doN, uint32_t flags) |
: fDoN(doN) |
, fFlags(flags & ~USE_AA) |
{ |
- fProc1 = SkXfermode::GetPM4fProc1(mode, fFlags); |
- fProcN = SkXfermode::GetPM4fProcN(mode, fFlags); |
+ fXfer.reset(SkXfermode::Create(mode)); |
+ |
+ fProc1 = SkXfermode::GetD32Proc(fXfer, fFlags | SkXfermode::kSrcIsSingle_D32Flag); |
+ fProcN = SkXfermode::GetD32Proc(fXfer, fFlags); |
fName.printf("xfer4f_%s_%s_%c_%s_%s", |
name, |
(flags & USE_AA) ? "aa" : "bw", |
fDoN ? 'N' : '1', |
- (flags & SkXfermode::kSrcIsOpaque_PM4fFlag) ? "opaque" : "alpha", |
- (flags & SkXfermode::kDstIsSRGB_PM4fFlag) ? "srgb" : "linear"); |
+ (flags & SkXfermode::kSrcIsOpaque_D32Flag) ? "opaque" : "alpha", |
+ (flags & SkXfermode::kDstIsSRGB_D32Flag) ? "srgb" : "linear"); |
for (int i = 0; i < N; ++i) { |
fSrc[i] = {{ 1, 1, 1, 1 }}; |
@@ -49,24 +51,23 @@ protected: |
const char* onGetName() override { return fName.c_str(); } |
void onDraw(int loops, SkCanvas*) override { |
- const SkXfermode::PM4fState state{ nullptr, fFlags }; |
- |
for (int i = 0; i < loops * INNER_LOOPS; ++i) { |
if (fDoN) { |
- fProcN(state, fDst, fSrc, N, fAA); |
+ fProcN(fXfer, fDst, fSrc, N, fAA); |
} else { |
- fProc1(state, fDst, fSrc[0], N, fAA); |
+ fProc1(fXfer, fDst, fSrc, N, fAA); |
} |
} |
} |
private: |
- SkString fName; |
- SkXfermode::PM4fProc1 fProc1; |
- SkXfermode::PM4fProcN fProcN; |
- const SkAlpha* fAA; |
- bool fDoN; |
- uint32_t fFlags; |
+ SkAutoTUnref<SkXfermode> fXfer; |
+ SkString fName; |
+ SkXfermode::D32Proc fProc1; |
+ SkXfermode::D32Proc fProcN; |
+ const SkAlpha* fAA; |
+ bool fDoN; |
+ uint32_t fFlags; |
enum { |
N = 1000, |
@@ -79,26 +80,26 @@ private: |
}; |
#define F00 0 |
-#define F01 (SkXfermode::kSrcIsOpaque_PM4fFlag) |
-#define F10 (SkXfermode::kDstIsSRGB_PM4fFlag) |
-#define F11 (SkXfermode::kSrcIsOpaque_PM4fFlag | SkXfermode::kDstIsSRGB_PM4fFlag) |
- |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F10); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F00); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F11); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F01); ) |
- |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F10); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F00); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F11); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F01); ) |
- |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F10 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F00 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F11 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", false, F01 | USE_AA); ) |
- |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F10 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F00 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F11 | USE_AA); ) |
-DEF_BENCH( return new Xfer4fBench(SkXfermode::kSrcOver_Mode, "srcover", true, F01 | USE_AA); ) |
+#define F01 (SkXfermode::kSrcIsOpaque_D32Flag) |
+#define F10 (SkXfermode::kDstIsSRGB_D32Flag) |
+#define F11 (SkXfermode::kSrcIsOpaque_D32Flag | SkXfermode::kDstIsSRGB_D32Flag) |
+ |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F10); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F00); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F11); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F01); ) |
+ |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F10); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F00); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F11); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F01); ) |
+ |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F10 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F00 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F11 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", false, F01 | USE_AA); ) |
+ |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F10 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F00 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F11 | USE_AA); ) |
+DEF_BENCH( return new XferD32Bench(SkXfermode::kSrcOver_Mode, "srcover", true, F01 | USE_AA); ) |