Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 1 | /* |
Chris Craik | 5ea1724 | 2016-01-11 14:07:59 -0800 | [diff] [blame] | 2 | * Copyright (C) 2016 The Android Open Source Project |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | #include <benchmark/Benchmark.h> |
| 18 | |
| 19 | #include "BakedOpState.h" |
Chris Craik | 9e7fcfd | 2015-11-25 13:27:33 -0800 | [diff] [blame] | 20 | #include "BakedOpDispatcher.h" |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 21 | #include "BakedOpRenderer.h" |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 22 | #include "FrameBuilder.h" |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 23 | #include "LayerUpdateQueue.h" |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 24 | #include "RecordedOp.h" |
| 25 | #include "RecordingCanvas.h" |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 26 | #include "tests/common/TestContext.h" |
| 27 | #include "tests/common/TestScene.h" |
Chris Craik | 8160f20 | 2015-12-02 14:50:25 -0800 | [diff] [blame] | 28 | #include "tests/common/TestUtils.h" |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 29 | #include "Vector.h" |
Chris Craik | 15c3f19 | 2015-12-03 12:16:56 -0800 | [diff] [blame] | 30 | #include "tests/microbench/MicroBench.h" |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 31 | |
| 32 | #include <vector> |
| 33 | |
| 34 | using namespace android; |
| 35 | using namespace android::uirenderer; |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 36 | using namespace android::uirenderer::renderthread; |
| 37 | using namespace android::uirenderer::test; |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 38 | |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 39 | const LayerUpdateQueue sEmptyLayerUpdateQueue; |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 40 | const FrameBuilder::LightGeometry sLightGeometry = { {100, 100, 100}, 50}; |
| 41 | const BakedOpRenderer::LightInfo sLightInfo = { 128, 128 }; |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 42 | |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 43 | static std::vector<sp<RenderNode>> createTestNodeList() { |
| 44 | auto node = TestUtils::createNode(0, 0, 200, 200, |
| 45 | [](RenderProperties& props, RecordingCanvas& canvas) { |
| 46 | SkBitmap bitmap = TestUtils::createSkBitmap(10, 10); |
| 47 | SkPaint paint; |
| 48 | |
| 49 | // Alternate between drawing rects and bitmaps, with bitmaps overlapping rects. |
| 50 | // Rects don't overlap bitmaps, so bitmaps should be brought to front as a group. |
Florin Malita | eecff56 | 2015-12-21 10:43:01 -0500 | [diff] [blame] | 51 | canvas.save(SaveFlags::MatrixClip); |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 52 | for (int i = 0; i < 30; i++) { |
| 53 | canvas.translate(0, 10); |
| 54 | canvas.drawRect(0, 0, 10, 10, paint); |
| 55 | canvas.drawBitmap(bitmap, 5, 0, nullptr); |
| 56 | } |
| 57 | canvas.restore(); |
| 58 | }); |
| 59 | TestUtils::syncHierarchyPropertiesAndDisplayList(node); |
| 60 | std::vector<sp<RenderNode>> vec; |
| 61 | vec.emplace_back(node); |
| 62 | return vec; |
| 63 | } |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 64 | |
Chris Craik | 5ea1724 | 2016-01-11 14:07:59 -0800 | [diff] [blame] | 65 | BENCHMARK_NO_ARG(BM_FrameBuilder_defer); |
| 66 | void BM_FrameBuilder_defer::Run(int iters) { |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 67 | auto nodes = createTestNodeList(); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 68 | StartBenchmarkTiming(); |
| 69 | for (int i = 0; i < iters; i++) { |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 70 | FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, SkRect::MakeWH(100, 200), 100, 200, |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 71 | nodes, sLightGeometry, nullptr); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 72 | MicroBench::DoNotOptimize(&frameBuilder); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 73 | } |
| 74 | StopBenchmarkTiming(); |
| 75 | } |
| 76 | |
Chris Craik | 5ea1724 | 2016-01-11 14:07:59 -0800 | [diff] [blame] | 77 | BENCHMARK_NO_ARG(BM_FrameBuilder_deferAndRender); |
| 78 | void BM_FrameBuilder_deferAndRender::Run(int iters) { |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 79 | TestUtils::runOnRenderThread([this, iters](RenderThread& thread) { |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 80 | auto nodes = createTestNodeList(); |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 81 | |
Chris Craik | 0b7e824 | 2015-10-28 16:50:44 -0700 | [diff] [blame] | 82 | RenderState& renderState = thread.renderState(); |
| 83 | Caches& caches = Caches::getInstance(); |
Chris Craik | 98787e6 | 2015-11-13 10:55:30 -0800 | [diff] [blame] | 84 | |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 85 | StartBenchmarkTiming(); |
| 86 | for (int i = 0; i < iters; i++) { |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 87 | FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, SkRect::MakeWH(100, 200), 100, 200, |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 88 | nodes, sLightGeometry, nullptr); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 89 | |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 90 | BakedOpRenderer renderer(caches, renderState, true, sLightInfo); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 91 | frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer); |
Chris Craik | 5854b34 | 2015-10-26 15:49:56 -0700 | [diff] [blame] | 92 | MicroBench::DoNotOptimize(&renderer); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 93 | } |
| 94 | StopBenchmarkTiming(); |
| 95 | }); |
| 96 | } |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 97 | |
| 98 | static std::vector<sp<RenderNode>> getSyncedSceneNodes(const char* sceneName) { |
| 99 | gDisplay = getBuiltInDisplay(); // switch to real display if present |
| 100 | |
| 101 | TestContext testContext; |
| 102 | TestScene::Options opts; |
| 103 | std::unique_ptr<TestScene> scene(TestScene::testMap()[sceneName].createScene(opts)); |
| 104 | |
| 105 | sp<RenderNode> rootNode = TestUtils::createNode(0, 0, gDisplay.w, gDisplay.h, |
| 106 | [&scene](RenderProperties& props, TestCanvas& canvas) { |
| 107 | scene->createContent(gDisplay.w, gDisplay.h, canvas); |
| 108 | }); |
| 109 | |
| 110 | TestUtils::syncHierarchyPropertiesAndDisplayList(rootNode); |
| 111 | std::vector<sp<RenderNode>> nodes; |
| 112 | nodes.emplace_back(rootNode); |
| 113 | return nodes; |
| 114 | } |
| 115 | |
| 116 | static void benchDeferScene(testing::Benchmark& benchmark, int iters, const char* sceneName) { |
| 117 | auto nodes = getSyncedSceneNodes(sceneName); |
| 118 | benchmark.StartBenchmarkTiming(); |
| 119 | for (int i = 0; i < iters; i++) { |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 120 | FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 121 | SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, gDisplay.h, |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 122 | nodes, sLightGeometry, nullptr); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 123 | MicroBench::DoNotOptimize(&frameBuilder); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 124 | } |
| 125 | benchmark.StopBenchmarkTiming(); |
| 126 | } |
| 127 | |
| 128 | static void benchDeferAndRenderScene(testing::Benchmark& benchmark, |
| 129 | int iters, const char* sceneName) { |
| 130 | TestUtils::runOnRenderThread([&benchmark, iters, sceneName](RenderThread& thread) { |
| 131 | auto nodes = getSyncedSceneNodes(sceneName); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 132 | |
| 133 | RenderState& renderState = thread.renderState(); |
| 134 | Caches& caches = Caches::getInstance(); |
| 135 | |
| 136 | benchmark.StartBenchmarkTiming(); |
| 137 | for (int i = 0; i < iters; i++) { |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 138 | FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 139 | SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, gDisplay.h, |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 140 | nodes, sLightGeometry, nullptr); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 141 | |
Chris Craik | 6e068c01 | 2016-01-15 16:15:30 -0800 | [diff] [blame] | 142 | BakedOpRenderer renderer(caches, renderState, true, sLightInfo); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 143 | frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 144 | MicroBench::DoNotOptimize(&renderer); |
| 145 | } |
| 146 | benchmark.StopBenchmarkTiming(); |
| 147 | }); |
| 148 | } |
| 149 | |
Chris Craik | 5ea1724 | 2016-01-11 14:07:59 -0800 | [diff] [blame] | 150 | BENCHMARK_NO_ARG(BM_FrameBuilder_listview_defer); |
| 151 | void BM_FrameBuilder_listview_defer::Run(int iters) { |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 152 | benchDeferScene(*this, iters, "listview"); |
| 153 | } |
| 154 | |
Chris Craik | 5ea1724 | 2016-01-11 14:07:59 -0800 | [diff] [blame] | 155 | BENCHMARK_NO_ARG(BM_FrameBuilder_listview_deferAndRender); |
| 156 | void BM_FrameBuilder_listview_deferAndRender::Run(int iters) { |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 157 | benchDeferAndRenderScene(*this, iters, "listview"); |
| 158 | } |
| 159 | |