| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2012 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | #include "SkBenchmark.h" |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 8 | #include "SkRefCnt.h" |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 9 | #include "SkThread.h" |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 10 | #include "SkWeakRefCnt.h" |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 11 | #include <memory> |
| 12 | |
| 13 | enum { |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 14 | M = 2 |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 15 | }; |
| 16 | |
| 17 | class RefCntBench_Stack : public SkBenchmark { |
| 18 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 19 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 20 | return backend == kNonRendering_Backend; |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 21 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 22 | |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 23 | protected: |
| 24 | virtual const char* onGetName() { |
| 25 | return "ref_cnt_stack"; |
| 26 | } |
| 27 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 28 | virtual void onDraw(SkCanvas*) { |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 29 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 30 | SkRefCnt ref; |
| 31 | for (int j = 0; j < M; ++j) { |
| 32 | ref.ref(); |
| 33 | ref.unref(); |
| 34 | } |
| 35 | } |
| 36 | } |
| 37 | |
| 38 | private: |
| 39 | typedef SkBenchmark INHERITED; |
| 40 | }; |
| 41 | |
| 42 | class PlacedRefCnt : public SkRefCnt { |
| 43 | public: |
| robertphillips@google.com | 15e9d3e | 2012-06-21 20:25:03 +0000 | [diff] [blame] | 44 | SK_DECLARE_INST_COUNT(PlacedRefCnt) |
| 45 | |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 46 | PlacedRefCnt() : SkRefCnt() { } |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 47 | void operator delete(void*) { } |
| robertphillips@google.com | 15e9d3e | 2012-06-21 20:25:03 +0000 | [diff] [blame] | 48 | |
| 49 | private: |
| 50 | typedef SkRefCnt INHERITED; |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 51 | }; |
| 52 | |
| robertphillips@google.com | 15e9d3e | 2012-06-21 20:25:03 +0000 | [diff] [blame] | 53 | SK_DEFINE_INST_COUNT(PlacedRefCnt) |
| 54 | |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 55 | class RefCntBench_Heap : public SkBenchmark { |
| 56 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 57 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 58 | return backend == kNonRendering_Backend; |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 59 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 60 | |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 61 | protected: |
| 62 | virtual const char* onGetName() { |
| 63 | return "ref_cnt_heap"; |
| 64 | } |
| 65 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 66 | virtual void onDraw(SkCanvas*) { |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 67 | char memory[sizeof(PlacedRefCnt)]; |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 68 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 69 | PlacedRefCnt* ref = new (memory) PlacedRefCnt(); |
| 70 | for (int j = 0; j < M; ++j) { |
| 71 | ref->ref(); |
| 72 | ref->unref(); |
| 73 | } |
| 74 | ref->unref(); |
| 75 | } |
| 76 | } |
| 77 | |
| 78 | private: |
| 79 | typedef SkBenchmark INHERITED; |
| 80 | }; |
| 81 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 82 | class RefCntBench_New : public SkBenchmark { |
| 83 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 84 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 85 | return backend == kNonRendering_Backend; |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 86 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 87 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 88 | protected: |
| 89 | virtual const char* onGetName() { |
| 90 | return "ref_cnt_new"; |
| 91 | } |
| 92 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 93 | virtual void onDraw(SkCanvas*) { |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 94 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 95 | SkRefCnt* ref = new SkRefCnt(); |
| 96 | for (int j = 0; j < M; ++j) { |
| 97 | ref->ref(); |
| 98 | ref->unref(); |
| 99 | } |
| 100 | ref->unref(); |
| 101 | } |
| 102 | } |
| 103 | |
| 104 | private: |
| 105 | typedef SkBenchmark INHERITED; |
| 106 | }; |
| 107 | |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 108 | /////////////////////////////////////////////////////////////////////////////// |
| 109 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 110 | class WeakRefCntBench_Stack : public SkBenchmark { |
| 111 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 112 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 113 | return backend == kNonRendering_Backend; |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 114 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 115 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 116 | protected: |
| 117 | virtual const char* onGetName() { |
| 118 | return "ref_cnt_stack_weak"; |
| 119 | } |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 120 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 121 | virtual void onDraw(SkCanvas*) { |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 122 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 123 | SkWeakRefCnt ref; |
| 124 | for (int j = 0; j < M; ++j) { |
| 125 | ref.ref(); |
| 126 | ref.unref(); |
| 127 | } |
| 128 | } |
| 129 | } |
| bungeman@google.com | 5548752 | 2012-05-14 14:09:24 +0000 | [diff] [blame] | 130 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 131 | private: |
| 132 | typedef SkBenchmark INHERITED; |
| 133 | }; |
| 134 | |
| 135 | class PlacedWeakRefCnt : public SkWeakRefCnt { |
| 136 | public: |
| 137 | PlacedWeakRefCnt() : SkWeakRefCnt() { } |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 138 | void operator delete(void*) { } |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 139 | }; |
| 140 | |
| 141 | class WeakRefCntBench_Heap : public SkBenchmark { |
| 142 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 143 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 144 | return backend == kNonRendering_Backend; |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 145 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 146 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 147 | protected: |
| 148 | virtual const char* onGetName() { |
| 149 | return "ref_cnt_heap_weak"; |
| 150 | } |
| 151 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 152 | virtual void onDraw(SkCanvas*) { |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 153 | char memory[sizeof(PlacedWeakRefCnt)]; |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 154 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 155 | PlacedWeakRefCnt* ref = new (memory) PlacedWeakRefCnt(); |
| 156 | for (int j = 0; j < M; ++j) { |
| 157 | ref->ref(); |
| 158 | ref->unref(); |
| 159 | } |
| 160 | ref->unref(); |
| 161 | } |
| 162 | } |
| 163 | |
| 164 | private: |
| 165 | typedef SkBenchmark INHERITED; |
| 166 | }; |
| 167 | |
| 168 | class WeakRefCntBench_New : public SkBenchmark { |
| 169 | public: |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 170 | virtual bool isSuitableFor(Backend backend) SK_OVERRIDE { |
| 171 | return backend == kNonRendering_Backend; |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 172 | } |
| commit-bot@chromium.org | 644629c | 2013-11-21 06:21:58 +0000 | [diff] [blame^] | 173 | |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 174 | protected: |
| 175 | virtual const char* onGetName() { |
| 176 | return "ref_cnt_new_weak"; |
| 177 | } |
| 178 | |
| sugoi@google.com | 77472f0 | 2013-03-05 18:50:01 +0000 | [diff] [blame] | 179 | virtual void onDraw(SkCanvas*) { |
| mtklein@google.com | c289743 | 2013-09-10 19:23:38 +0000 | [diff] [blame] | 180 | for (int i = 0; i < this->getLoops(); ++i) { |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 181 | SkWeakRefCnt* ref = new SkWeakRefCnt(); |
| 182 | for (int j = 0; j < M; ++j) { |
| 183 | ref->ref(); |
| 184 | ref->unref(); |
| 185 | } |
| 186 | ref->unref(); |
| 187 | } |
| 188 | } |
| 189 | |
| 190 | private: |
| 191 | typedef SkBenchmark INHERITED; |
| 192 | }; |
| 193 | |
| 194 | /////////////////////////////////////////////////////////////////////////////// |
| 195 | |
| mtklein@google.com | 410e6e8 | 2013-09-13 19:52:27 +0000 | [diff] [blame] | 196 | DEF_BENCH( return new RefCntBench_Stack(); ) |
| 197 | DEF_BENCH( return new RefCntBench_Heap(); ) |
| 198 | DEF_BENCH( return new RefCntBench_New(); ) |
| bungeman@google.com | a02bc15 | 2012-05-16 18:21:56 +0000 | [diff] [blame] | 199 | |
| mtklein@google.com | 410e6e8 | 2013-09-13 19:52:27 +0000 | [diff] [blame] | 200 | DEF_BENCH( return new WeakRefCntBench_Stack(); ) |
| 201 | DEF_BENCH( return new WeakRefCntBench_Heap(); ) |
| 202 | DEF_BENCH( return new WeakRefCntBench_New(); ) |