OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2016 Google Inc. | 2 * Copyright 2016 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "Benchmark.h" | 8 #include "Benchmark.h" |
9 #include "SkString.h" | 9 #include "SkString.h" |
10 #include "SkXfermode.h" | 10 #include "SkXfermode.h" |
11 | 11 |
12 #define USE_AA (1 << 31) // merge with Xfermode::PMFlags w/o conflict | 12 #define USE_AA (1 << 31) // merge with Xfermode::PMFlags w/o conflict |
13 | 13 |
14 #define INNER_LOOPS 1000 | 14 #define INNER_LOOPS 1000 |
15 | 15 |
16 // Benchmark that draws non-AA rects or AA text with an SkXfermode::Mode. | 16 // Benchmark that draws non-AA rects or AA text with an SkXfermode::Mode. |
17 class XferU64Bench : public Benchmark { | 17 class XferU64Bench : public Benchmark { |
18 public: | 18 public: |
19 XferU64Bench(bool doN, uint32_t flags) | 19 XferU64Bench(SkXfermode::Mode mode, const char name[], bool doN, uint32_t fl
ags) |
20 : fDoN(doN) | 20 : fDoN(doN) |
21 , fFlags(flags & ~USE_AA) | 21 , fFlags(flags & ~USE_AA) |
22 { | 22 { |
23 SkXfermode::Mode mode = SkXfermode::kSrcOver_Mode; | 23 fXfer.reset(SkXfermode::Create(mode)); |
24 | 24 |
25 fProc1 = SkXfermode::GetU64Proc1(mode, fFlags); | 25 fProc1 = SkXfermode::GetU64Proc1(mode, fFlags); |
26 fProcN = SkXfermode::GetU64ProcN(mode, fFlags); | 26 fProcN = SkXfermode::GetU64ProcN(mode, fFlags); |
27 fName.printf("xferu64_%s_%c_%s_%s", | 27 fName.printf("xferu64_%s_%s_%c_%s_%s", |
| 28 name, |
28 (flags & USE_AA) ? "aa" : "bw", | 29 (flags & USE_AA) ? "aa" : "bw", |
29 fDoN ? 'N' : '1', | 30 fDoN ? 'N' : '1', |
30 (flags & SkXfermode::kSrcIsOpaque_U64Flag) ? "opaque" : "al
pha", | 31 (flags & SkXfermode::kSrcIsOpaque_U64Flag) ? "opaque" : "al
pha", |
31 (flags & SkXfermode::kDstIsFloat16_U64Flag) ? "f16" : "u16"
); | 32 (flags & SkXfermode::kDstIsFloat16_U64Flag) ? "f16" : "u16"
); |
32 | 33 |
33 for (int i = 0; i < N; ++i) { | 34 for (int i = 0; i < N; ++i) { |
34 fSrc[i] = {{ 1, 1, 1, 1 }}; | 35 fSrc[i] = {{ 1, 1, 1, 1 }}; |
35 fDst[i] = 0; | 36 fDst[i] = 0; |
36 fAAStorage[i] = i * 255 / (N - 1); | 37 fAAStorage[i] = i * 255 / (N - 1); |
37 } | 38 } |
38 | 39 |
39 if (flags & USE_AA) { | 40 if (flags & USE_AA) { |
40 fAA = fAAStorage; | 41 fAA = fAAStorage; |
41 } else { | 42 } else { |
42 fAA = nullptr; | 43 fAA = nullptr; |
43 } | 44 } |
44 } | 45 } |
45 | 46 |
46 protected: | 47 protected: |
47 bool isSuitableFor(Backend backend) override { return backend == kNonRenderi
ng_Backend; } | 48 bool isSuitableFor(Backend backend) override { return backend == kNonRenderi
ng_Backend; } |
48 | 49 |
49 const char* onGetName() override { return fName.c_str(); } | 50 const char* onGetName() override { return fName.c_str(); } |
50 | 51 |
51 void onDraw(int loops, SkCanvas*) override { | 52 void onDraw(int loops, SkCanvas*) override { |
52 const SkXfermode::U64State state{ nullptr, fFlags }; | 53 const SkXfermode::U64State state{ fXfer, fFlags }; |
53 | 54 |
54 for (int i = 0; i < loops * INNER_LOOPS; ++i) { | 55 for (int i = 0; i < loops * INNER_LOOPS; ++i) { |
55 if (fDoN) { | 56 if (fDoN) { |
56 fProcN(state, fDst, fSrc, N, fAA); | 57 fProcN(state, fDst, fSrc, N, fAA); |
57 } else { | 58 } else { |
58 fProc1(state, fDst, fSrc[0], N, fAA); | 59 fProc1(state, fDst, fSrc[0], N, fAA); |
59 } | 60 } |
60 } | 61 } |
61 } | 62 } |
62 | 63 |
63 private: | 64 private: |
| 65 SkAutoTUnref<SkXfermode> fXfer; |
64 SkString fName; | 66 SkString fName; |
65 SkXfermode::U64Proc1 fProc1; | 67 SkXfermode::U64Proc1 fProc1; |
66 SkXfermode::U64ProcN fProcN; | 68 SkXfermode::U64ProcN fProcN; |
67 const SkAlpha* fAA; | 69 const SkAlpha* fAA; |
68 bool fDoN; | 70 bool fDoN; |
69 uint32_t fFlags; | 71 uint32_t fFlags; |
70 | 72 |
71 enum { | 73 enum { |
72 N = 1000, | 74 N = 1000, |
73 }; | 75 }; |
74 SkPM4f fSrc[N]; | 76 SkPM4f fSrc[N]; |
75 uint64_t fDst[N]; | 77 uint64_t fDst[N]; |
76 uint8_t fAAStorage[N]; | 78 uint8_t fAAStorage[N]; |
77 | 79 |
78 typedef Benchmark INHERITED; | 80 typedef Benchmark INHERITED; |
79 }; | 81 }; |
80 | 82 |
81 #define F00 0 | 83 #define F00 0 |
82 #define F01 (SkXfermode::kSrcIsOpaque_U64Flag) | 84 #define F01 (SkXfermode::kSrcIsOpaque_U64Flag) |
83 #define F10 (SkXfermode::kDstIsFloat16_U64Flag) | 85 #define F10 (SkXfermode::kDstIsFloat16_U64Flag) |
84 #define F11 (SkXfermode::kDstIsFloat16_U64Flag | SkXfermode::kSrcIsOpaque_U64Fla
g) | 86 #define F11 (SkXfermode::kDstIsFloat16_U64Flag | SkXfermode::kSrcIsOpaque_U64Fla
g) |
85 | 87 |
86 #if 0 | 88 #define MODE SkXfermode::kSrcOver_Mode |
87 DEF_BENCH( return new XferU64Bench(true, F10 | USE_AA); ) | 89 #define NAME "srcover" |
88 DEF_BENCH( return new XferU64Bench(true, F11 | USE_AA); ) | |
89 DEF_BENCH( return new XferU64Bench(true, F10); ) | |
90 DEF_BENCH( return new XferU64Bench(true, F11); ) | |
91 | 90 |
92 DEF_BENCH( return new XferU64Bench(true, F00 | USE_AA); ) | 91 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F10 | USE_AA); ) |
93 DEF_BENCH( return new XferU64Bench(true, F01 | USE_AA); ) | 92 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F11 | USE_AA); ) |
94 DEF_BENCH( return new XferU64Bench(true, F00); ) | 93 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F10); ) |
95 DEF_BENCH( return new XferU64Bench(true, F01); ) | 94 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F11); ) |
96 #endif | |
97 | 95 |
98 DEF_BENCH( return new XferU64Bench(false, F10 | USE_AA); ) | 96 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F00 | USE_AA); ) |
99 DEF_BENCH( return new XferU64Bench(false, F11 | USE_AA); ) | 97 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F01 | USE_AA); ) |
100 DEF_BENCH( return new XferU64Bench(false, F10); ) | 98 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F00); ) |
101 DEF_BENCH( return new XferU64Bench(false, F11); ) | 99 DEF_BENCH( return new XferU64Bench(MODE, NAME, true, F01); ) |
102 | 100 |
103 DEF_BENCH( return new XferU64Bench(false, F00 | USE_AA); ) | 101 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F10 | USE_AA); ) |
104 DEF_BENCH( return new XferU64Bench(false, F01 | USE_AA); ) | 102 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F11 | USE_AA); ) |
105 DEF_BENCH( return new XferU64Bench(false, F00); ) | 103 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F10); ) |
106 DEF_BENCH( return new XferU64Bench(false, F01); ) | 104 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F11); ) |
| 105 |
| 106 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F00 | USE_AA); ) |
| 107 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F01 | USE_AA); ) |
| 108 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F00); ) |
| 109 DEF_BENCH( return new XferU64Bench(MODE, NAME, false, F01); ) |
OLD | NEW |