blob: 7845eb4fa8e20833067a2aa5f24fdde0c34c9032 [file] [log] [blame]
Chris Craik0a24b142015-10-19 17:10:19 -07001/*
Chris Craik5ea17242016-01-11 14:07:59 -08002 * Copyright (C) 2016 The Android Open Source Project
Chris Craik0a24b142015-10-19 17:10:19 -07003 *
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 Craik9e7fcfd2015-11-25 13:27:33 -080020#include "BakedOpDispatcher.h"
Chris Craik0a24b142015-10-19 17:10:19 -070021#include "BakedOpRenderer.h"
Chris Craikf158b492016-01-12 14:45:08 -080022#include "FrameBuilder.h"
Chris Craik8d1f2122015-11-24 16:40:09 -080023#include "LayerUpdateQueue.h"
Chris Craik0a24b142015-10-19 17:10:19 -070024#include "RecordedOp.h"
25#include "RecordingCanvas.h"
Chris Craik27e58b42015-12-07 10:01:38 -080026#include "tests/common/TestContext.h"
27#include "tests/common/TestScene.h"
Chris Craik8160f202015-12-02 14:50:25 -080028#include "tests/common/TestUtils.h"
Chris Craik8d1f2122015-11-24 16:40:09 -080029#include "Vector.h"
Chris Craik15c3f192015-12-03 12:16:56 -080030#include "tests/microbench/MicroBench.h"
Chris Craik0a24b142015-10-19 17:10:19 -070031
32#include <vector>
33
34using namespace android;
35using namespace android::uirenderer;
Chris Craik27e58b42015-12-07 10:01:38 -080036using namespace android::uirenderer::renderthread;
37using namespace android::uirenderer::test;
Chris Craik0a24b142015-10-19 17:10:19 -070038
Chris Craik8d1f2122015-11-24 16:40:09 -080039const LayerUpdateQueue sEmptyLayerUpdateQueue;
Chris Craik6e068c012016-01-15 16:15:30 -080040const FrameBuilder::LightGeometry sLightGeometry = { {100, 100, 100}, 50};
41const BakedOpRenderer::LightInfo sLightInfo = { 128, 128 };
Chris Craik0a24b142015-10-19 17:10:19 -070042
Chris Craik8d1f2122015-11-24 16:40:09 -080043static 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 Malitaeecff562015-12-21 10:43:01 -050051 canvas.save(SaveFlags::MatrixClip);
Chris Craik8d1f2122015-11-24 16:40:09 -080052 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 Craik0a24b142015-10-19 17:10:19 -070064
Chris Craik5ea17242016-01-11 14:07:59 -080065BENCHMARK_NO_ARG(BM_FrameBuilder_defer);
66void BM_FrameBuilder_defer::Run(int iters) {
Chris Craik8d1f2122015-11-24 16:40:09 -080067 auto nodes = createTestNodeList();
Chris Craik0a24b142015-10-19 17:10:19 -070068 StartBenchmarkTiming();
69 for (int i = 0; i < iters; i++) {
Chris Craikf158b492016-01-12 14:45:08 -080070 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, SkRect::MakeWH(100, 200), 100, 200,
Chris Craik6e068c012016-01-15 16:15:30 -080071 nodes, sLightGeometry, nullptr);
Chris Craikf158b492016-01-12 14:45:08 -080072 MicroBench::DoNotOptimize(&frameBuilder);
Chris Craik0a24b142015-10-19 17:10:19 -070073 }
74 StopBenchmarkTiming();
75}
76
Chris Craik5ea17242016-01-11 14:07:59 -080077BENCHMARK_NO_ARG(BM_FrameBuilder_deferAndRender);
78void BM_FrameBuilder_deferAndRender::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -080079 TestUtils::runOnRenderThread([this, iters](RenderThread& thread) {
Chris Craik8d1f2122015-11-24 16:40:09 -080080 auto nodes = createTestNodeList();
Chris Craik8d1f2122015-11-24 16:40:09 -080081
Chris Craik0b7e8242015-10-28 16:50:44 -070082 RenderState& renderState = thread.renderState();
83 Caches& caches = Caches::getInstance();
Chris Craik98787e62015-11-13 10:55:30 -080084
Chris Craik0a24b142015-10-19 17:10:19 -070085 StartBenchmarkTiming();
86 for (int i = 0; i < iters; i++) {
Chris Craikf158b492016-01-12 14:45:08 -080087 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, SkRect::MakeWH(100, 200), 100, 200,
Chris Craik6e068c012016-01-15 16:15:30 -080088 nodes, sLightGeometry, nullptr);
Chris Craik0a24b142015-10-19 17:10:19 -070089
Chris Craik6e068c012016-01-15 16:15:30 -080090 BakedOpRenderer renderer(caches, renderState, true, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -080091 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
Chris Craik5854b342015-10-26 15:49:56 -070092 MicroBench::DoNotOptimize(&renderer);
Chris Craik0a24b142015-10-19 17:10:19 -070093 }
94 StopBenchmarkTiming();
95 });
96}
Chris Craik27e58b42015-12-07 10:01:38 -080097
98static 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
116static 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 Craikf158b492016-01-12 14:45:08 -0800120 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue,
Chris Craik27e58b42015-12-07 10:01:38 -0800121 SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, gDisplay.h,
Chris Craik6e068c012016-01-15 16:15:30 -0800122 nodes, sLightGeometry, nullptr);
Chris Craikf158b492016-01-12 14:45:08 -0800123 MicroBench::DoNotOptimize(&frameBuilder);
Chris Craik27e58b42015-12-07 10:01:38 -0800124 }
125 benchmark.StopBenchmarkTiming();
126}
127
128static 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 Craik27e58b42015-12-07 10:01:38 -0800132
133 RenderState& renderState = thread.renderState();
134 Caches& caches = Caches::getInstance();
135
136 benchmark.StartBenchmarkTiming();
137 for (int i = 0; i < iters; i++) {
Chris Craikf158b492016-01-12 14:45:08 -0800138 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue,
Chris Craik27e58b42015-12-07 10:01:38 -0800139 SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, gDisplay.h,
Chris Craik6e068c012016-01-15 16:15:30 -0800140 nodes, sLightGeometry, nullptr);
Chris Craik27e58b42015-12-07 10:01:38 -0800141
Chris Craik6e068c012016-01-15 16:15:30 -0800142 BakedOpRenderer renderer(caches, renderState, true, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -0800143 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
Chris Craik27e58b42015-12-07 10:01:38 -0800144 MicroBench::DoNotOptimize(&renderer);
145 }
146 benchmark.StopBenchmarkTiming();
147 });
148}
149
Chris Craik5ea17242016-01-11 14:07:59 -0800150BENCHMARK_NO_ARG(BM_FrameBuilder_listview_defer);
151void BM_FrameBuilder_listview_defer::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -0800152 benchDeferScene(*this, iters, "listview");
153}
154
Chris Craik5ea17242016-01-11 14:07:59 -0800155BENCHMARK_NO_ARG(BM_FrameBuilder_listview_deferAndRender);
156void BM_FrameBuilder_listview_deferAndRender::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -0800157 benchDeferAndRenderScene(*this, iters, "listview");
158}
159