blob: f9c2b671fdf32d26d23d3f175cd81a6afc5ccf7b [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;
40const Vector3 sLightCenter = {100, 100, 100};
Chris Craik0a24b142015-10-19 17:10:19 -070041
Chris Craik8d1f2122015-11-24 16:40:09 -080042static std::vector<sp<RenderNode>> createTestNodeList() {
43 auto node = TestUtils::createNode(0, 0, 200, 200,
44 [](RenderProperties& props, RecordingCanvas& canvas) {
45 SkBitmap bitmap = TestUtils::createSkBitmap(10, 10);
46 SkPaint paint;
47
48 // Alternate between drawing rects and bitmaps, with bitmaps overlapping rects.
49 // Rects don't overlap bitmaps, so bitmaps should be brought to front as a group.
Florin Malitaeecff562015-12-21 10:43:01 -050050 canvas.save(SaveFlags::MatrixClip);
Chris Craik8d1f2122015-11-24 16:40:09 -080051 for (int i = 0; i < 30; i++) {
52 canvas.translate(0, 10);
53 canvas.drawRect(0, 0, 10, 10, paint);
54 canvas.drawBitmap(bitmap, 5, 0, nullptr);
55 }
56 canvas.restore();
57 });
58 TestUtils::syncHierarchyPropertiesAndDisplayList(node);
59 std::vector<sp<RenderNode>> vec;
60 vec.emplace_back(node);
61 return vec;
62}
Chris Craik0a24b142015-10-19 17:10:19 -070063
Chris Craik5ea17242016-01-11 14:07:59 -080064BENCHMARK_NO_ARG(BM_FrameBuilder_defer);
65void BM_FrameBuilder_defer::Run(int iters) {
Chris Craik8d1f2122015-11-24 16:40:09 -080066 auto nodes = createTestNodeList();
Chris Craik0a24b142015-10-19 17:10:19 -070067 StartBenchmarkTiming();
68 for (int i = 0; i < iters; i++) {
Chris Craikf158b492016-01-12 14:45:08 -080069 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue, SkRect::MakeWH(100, 200), 100, 200,
Chris Craik8d1f2122015-11-24 16:40:09 -080070 nodes, sLightCenter);
Chris Craikf158b492016-01-12 14:45:08 -080071 MicroBench::DoNotOptimize(&frameBuilder);
Chris Craik0a24b142015-10-19 17:10:19 -070072 }
73 StopBenchmarkTiming();
74}
75
Chris Craik5ea17242016-01-11 14:07:59 -080076BENCHMARK_NO_ARG(BM_FrameBuilder_deferAndRender);
77void BM_FrameBuilder_deferAndRender::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -080078 TestUtils::runOnRenderThread([this, iters](RenderThread& thread) {
Chris Craik8d1f2122015-11-24 16:40:09 -080079 auto nodes = createTestNodeList();
80 BakedOpRenderer::LightInfo lightInfo = {50.0f, 128, 128 };
81
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 Craik8d1f2122015-11-24 16:40:09 -080088 nodes, sLightCenter);
Chris Craik0a24b142015-10-19 17:10:19 -070089
Chris Craik98787e62015-11-13 10:55:30 -080090 BakedOpRenderer renderer(caches, renderState, true, lightInfo);
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,
122 nodes, sLightCenter);
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);
132 BakedOpRenderer::LightInfo lightInfo = {50.0f, 128, 128 }; // TODO!
133
134 RenderState& renderState = thread.renderState();
135 Caches& caches = Caches::getInstance();
136
137 benchmark.StartBenchmarkTiming();
138 for (int i = 0; i < iters; i++) {
Chris Craikf158b492016-01-12 14:45:08 -0800139 FrameBuilder frameBuilder(sEmptyLayerUpdateQueue,
Chris Craik27e58b42015-12-07 10:01:38 -0800140 SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w, gDisplay.h,
141 nodes, sLightCenter);
142
143 BakedOpRenderer renderer(caches, renderState, true, lightInfo);
Chris Craikf158b492016-01-12 14:45:08 -0800144 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
Chris Craik27e58b42015-12-07 10:01:38 -0800145 MicroBench::DoNotOptimize(&renderer);
146 }
147 benchmark.StopBenchmarkTiming();
148 });
149}
150
Chris Craik5ea17242016-01-11 14:07:59 -0800151BENCHMARK_NO_ARG(BM_FrameBuilder_listview_defer);
152void BM_FrameBuilder_listview_defer::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -0800153 benchDeferScene(*this, iters, "listview");
154}
155
Chris Craik5ea17242016-01-11 14:07:59 -0800156BENCHMARK_NO_ARG(BM_FrameBuilder_listview_deferAndRender);
157void BM_FrameBuilder_listview_deferAndRender::Run(int iters) {
Chris Craik27e58b42015-12-07 10:01:38 -0800158 benchDeferAndRenderScene(*this, iters, "listview");
159}
160