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 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 17 | #include <benchmark/benchmark.h> |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 18 | |
Chris Craik | 9e7fcfd | 2015-11-25 13:27:33 -0800 | [diff] [blame] | 19 | #include "BakedOpDispatcher.h" |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 20 | #include "BakedOpRenderer.h" |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 21 | #include "BakedOpState.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" |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 26 | #include "Vector.h" |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 27 | #include "tests/common/TestContext.h" |
| 28 | #include "tests/common/TestScene.h" |
Chris Craik | 8160f20 | 2015-12-02 14:50:25 -0800 | [diff] [blame] | 29 | #include "tests/common/TestUtils.h" |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 30 | |
| 31 | #include <vector> |
| 32 | |
| 33 | using namespace android; |
| 34 | using namespace android::uirenderer; |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 35 | using namespace android::uirenderer::renderthread; |
| 36 | using namespace android::uirenderer::test; |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 37 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 38 | const FrameBuilder::LightGeometry sLightGeometry = {{100, 100, 100}, 50}; |
| 39 | const BakedOpRenderer::LightInfo sLightInfo = {128, 128}; |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 40 | |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 41 | static sp<RenderNode> createTestNode() { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 42 | auto node = TestUtils::createNode<RecordingCanvas>( |
| 43 | 0, 0, 200, 200, [](RenderProperties& props, RecordingCanvas& canvas) { |
| 44 | sk_sp<Bitmap> bitmap(TestUtils::createBitmap(10, 10)); |
| 45 | SkPaint paint; |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 46 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 47 | // Alternate between drawing rects and bitmaps, with bitmaps overlapping rects. |
| 48 | // Rects don't overlap bitmaps, so bitmaps should be brought to front as a group. |
| 49 | canvas.save(SaveFlags::MatrixClip); |
| 50 | for (int i = 0; i < 30; i++) { |
| 51 | canvas.translate(0, 10); |
| 52 | canvas.drawRect(0, 0, 10, 10, paint); |
| 53 | canvas.drawBitmap(*bitmap, 5, 0, nullptr); |
| 54 | } |
| 55 | canvas.restore(); |
| 56 | }); |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 57 | TestUtils::syncHierarchyPropertiesAndDisplayList(node); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 58 | return node; |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 59 | } |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 60 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 61 | void BM_FrameBuilder_defer(benchmark::State& state) { |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 62 | TestUtils::runOnRenderThread([&state](RenderThread& thread) { |
| 63 | auto node = createTestNode(); |
| 64 | while (state.KeepRunning()) { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 65 | FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200, sLightGeometry, |
| 66 | Caches::getInstance()); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 67 | frameBuilder.deferRenderNode(*node); |
| 68 | benchmark::DoNotOptimize(&frameBuilder); |
| 69 | } |
| 70 | }); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 71 | } |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 72 | BENCHMARK(BM_FrameBuilder_defer); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 73 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 74 | void BM_FrameBuilder_deferAndRender(benchmark::State& state) { |
| 75 | TestUtils::runOnRenderThread([&state](RenderThread& thread) { |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 76 | auto node = createTestNode(); |
Chris Craik | 8d1f212 | 2015-11-24 16:40:09 -0800 | [diff] [blame] | 77 | |
Chris Craik | 0b7e824 | 2015-10-28 16:50:44 -0700 | [diff] [blame] | 78 | RenderState& renderState = thread.renderState(); |
| 79 | Caches& caches = Caches::getInstance(); |
Chris Craik | 98787e6 | 2015-11-13 10:55:30 -0800 | [diff] [blame] | 80 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 81 | while (state.KeepRunning()) { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 82 | FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200, sLightGeometry, caches); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 83 | frameBuilder.deferRenderNode(*node); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 84 | |
Romain Guy | 07ae505 | 2017-06-13 18:25:32 -0700 | [diff] [blame] | 85 | BakedOpRenderer renderer(caches, renderState, true, false, sLightInfo); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 86 | frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer); |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 87 | benchmark::DoNotOptimize(&renderer); |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 88 | } |
Chris Craik | 0a24b14 | 2015-10-19 17:10:19 -0700 | [diff] [blame] | 89 | }); |
| 90 | } |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 91 | BENCHMARK(BM_FrameBuilder_deferAndRender); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 92 | |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 93 | static sp<RenderNode> getSyncedSceneNode(const char* sceneName) { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 94 | gDisplay = getBuiltInDisplay(); // switch to real display if present |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 95 | |
| 96 | TestContext testContext; |
| 97 | TestScene::Options opts; |
| 98 | std::unique_ptr<TestScene> scene(TestScene::testMap()[sceneName].createScene(opts)); |
| 99 | |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 100 | sp<RenderNode> rootNode = TestUtils::createNode<RecordingCanvas>( |
| 101 | 0, 0, gDisplay.w, gDisplay.h, |
| 102 | [&scene](RenderProperties& props, RecordingCanvas& canvas) { |
| 103 | scene->createContent(gDisplay.w, gDisplay.h, canvas); |
| 104 | }); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 105 | |
| 106 | TestUtils::syncHierarchyPropertiesAndDisplayList(rootNode); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 107 | return rootNode; |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 108 | } |
| 109 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 110 | static auto SCENES = { |
| 111 | "listview", |
| 112 | }; |
| 113 | |
| 114 | void BM_FrameBuilder_defer_scene(benchmark::State& state) { |
John Reck | 2c0f937 | 2016-03-28 09:34:35 -0700 | [diff] [blame] | 115 | TestUtils::runOnRenderThread([&state](RenderThread& thread) { |
Martijn Coenen | 90213f3 | 2016-11-14 14:56:03 +0100 | [diff] [blame] | 116 | const char* sceneName = *(SCENES.begin() + state.range(0)); |
John Reck | 2c0f937 | 2016-03-28 09:34:35 -0700 | [diff] [blame] | 117 | state.SetLabel(sceneName); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 118 | auto node = getSyncedSceneNode(sceneName); |
John Reck | 2c0f937 | 2016-03-28 09:34:35 -0700 | [diff] [blame] | 119 | while (state.KeepRunning()) { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 120 | FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, |
| 121 | gDisplay.h, sLightGeometry, Caches::getInstance()); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 122 | frameBuilder.deferRenderNode(*node); |
John Reck | 2c0f937 | 2016-03-28 09:34:35 -0700 | [diff] [blame] | 123 | benchmark::DoNotOptimize(&frameBuilder); |
| 124 | } |
| 125 | }); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 126 | } |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 127 | BENCHMARK(BM_FrameBuilder_defer_scene)->DenseRange(0, SCENES.size() - 1); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 128 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 129 | void BM_FrameBuilder_deferAndRender_scene(benchmark::State& state) { |
| 130 | TestUtils::runOnRenderThread([&state](RenderThread& thread) { |
Martijn Coenen | 90213f3 | 2016-11-14 14:56:03 +0100 | [diff] [blame] | 131 | const char* sceneName = *(SCENES.begin() + state.range(0)); |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 132 | state.SetLabel(sceneName); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 133 | auto node = getSyncedSceneNode(sceneName); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 134 | |
| 135 | RenderState& renderState = thread.renderState(); |
| 136 | Caches& caches = Caches::getInstance(); |
| 137 | |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 138 | while (state.KeepRunning()) { |
John Reck | 1bcacfd | 2017-11-03 10:12:19 -0700 | [diff] [blame] | 139 | FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, |
| 140 | gDisplay.h, sLightGeometry, Caches::getInstance()); |
Chris Craik | 9cd1bbe | 2016-04-14 16:08:25 -0700 | [diff] [blame] | 141 | frameBuilder.deferRenderNode(*node); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 142 | |
Romain Guy | 07ae505 | 2017-06-13 18:25:32 -0700 | [diff] [blame] | 143 | BakedOpRenderer renderer(caches, renderState, true, false, sLightInfo); |
Chris Craik | f158b49 | 2016-01-12 14:45:08 -0800 | [diff] [blame] | 144 | frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer); |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 145 | benchmark::DoNotOptimize(&renderer); |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 146 | } |
Chris Craik | 27e58b4 | 2015-12-07 10:01:38 -0800 | [diff] [blame] | 147 | }); |
| 148 | } |
John Reck | 0418afa3 | 2016-03-07 13:24:25 -0800 | [diff] [blame] | 149 | BENCHMARK(BM_FrameBuilder_deferAndRender_scene)->DenseRange(0, SCENES.size() - 1); |