blob: 84ef9c2575f5a217cce51dd621a7a8d1e3fb3132 [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
John Reck0418afa32016-03-07 13:24:25 -080017#include <benchmark/benchmark.h>
Chris Craik0a24b142015-10-19 17:10:19 -070018
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 Craik0a24b142015-10-19 17:10:19 -070030
31#include <vector>
32
33using namespace android;
34using namespace android::uirenderer;
Chris Craik27e58b42015-12-07 10:01:38 -080035using namespace android::uirenderer::renderthread;
36using namespace android::uirenderer::test;
Chris Craik0a24b142015-10-19 17:10:19 -070037
Chris Craik6e068c012016-01-15 16:15:30 -080038const FrameBuilder::LightGeometry sLightGeometry = { {100, 100, 100}, 50};
39const BakedOpRenderer::LightInfo sLightInfo = { 128, 128 };
Chris Craik0a24b142015-10-19 17:10:19 -070040
Chris Craik9cd1bbe2016-04-14 16:08:25 -070041static sp<RenderNode> createTestNode() {
Chris Craik8d1f2122015-11-24 16:40:09 -080042 auto node = TestUtils::createNode(0, 0, 200, 200,
43 [](RenderProperties& props, RecordingCanvas& canvas) {
44 SkBitmap bitmap = TestUtils::createSkBitmap(10, 10);
45 SkPaint paint;
46
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.
Florin Malitaeecff562015-12-21 10:43:01 -050049 canvas.save(SaveFlags::MatrixClip);
Chris Craik8d1f2122015-11-24 16:40:09 -080050 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 });
57 TestUtils::syncHierarchyPropertiesAndDisplayList(node);
Chris Craik9cd1bbe2016-04-14 16:08:25 -070058 return node;
Chris Craik8d1f2122015-11-24 16:40:09 -080059}
Chris Craik0a24b142015-10-19 17:10:19 -070060
John Reck0418afa32016-03-07 13:24:25 -080061void BM_FrameBuilder_defer(benchmark::State& state) {
Chris Craik9cd1bbe2016-04-14 16:08:25 -070062 TestUtils::runOnRenderThread([&state](RenderThread& thread) {
63 auto node = createTestNode();
64 while (state.KeepRunning()) {
65 FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200,
66 sLightGeometry, Caches::getInstance());
67 frameBuilder.deferRenderNode(*node);
68 benchmark::DoNotOptimize(&frameBuilder);
69 }
70 });
Chris Craik0a24b142015-10-19 17:10:19 -070071}
John Reck0418afa32016-03-07 13:24:25 -080072BENCHMARK(BM_FrameBuilder_defer);
Chris Craik0a24b142015-10-19 17:10:19 -070073
John Reck0418afa32016-03-07 13:24:25 -080074void BM_FrameBuilder_deferAndRender(benchmark::State& state) {
75 TestUtils::runOnRenderThread([&state](RenderThread& thread) {
Chris Craik9cd1bbe2016-04-14 16:08:25 -070076 auto node = createTestNode();
Chris Craik8d1f2122015-11-24 16:40:09 -080077
Chris Craik0b7e8242015-10-28 16:50:44 -070078 RenderState& renderState = thread.renderState();
79 Caches& caches = Caches::getInstance();
Chris Craik98787e62015-11-13 10:55:30 -080080
John Reck0418afa32016-03-07 13:24:25 -080081 while (state.KeepRunning()) {
Chris Craik9cd1bbe2016-04-14 16:08:25 -070082 FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200,
83 sLightGeometry, caches);
84 frameBuilder.deferRenderNode(*node);
Chris Craik0a24b142015-10-19 17:10:19 -070085
Chris Craik6e068c012016-01-15 16:15:30 -080086 BakedOpRenderer renderer(caches, renderState, true, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -080087 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
John Reck0418afa32016-03-07 13:24:25 -080088 benchmark::DoNotOptimize(&renderer);
Chris Craik0a24b142015-10-19 17:10:19 -070089 }
Chris Craik0a24b142015-10-19 17:10:19 -070090 });
91}
John Reck0418afa32016-03-07 13:24:25 -080092BENCHMARK(BM_FrameBuilder_deferAndRender);
Chris Craik27e58b42015-12-07 10:01:38 -080093
Chris Craik9cd1bbe2016-04-14 16:08:25 -070094static sp<RenderNode> getSyncedSceneNode(const char* sceneName) {
Chris Craik27e58b42015-12-07 10:01:38 -080095 gDisplay = getBuiltInDisplay(); // switch to real display if present
96
97 TestContext testContext;
98 TestScene::Options opts;
99 std::unique_ptr<TestScene> scene(TestScene::testMap()[sceneName].createScene(opts));
100
101 sp<RenderNode> rootNode = TestUtils::createNode(0, 0, gDisplay.w, gDisplay.h,
102 [&scene](RenderProperties& props, TestCanvas& canvas) {
103 scene->createContent(gDisplay.w, gDisplay.h, canvas);
104 });
105
106 TestUtils::syncHierarchyPropertiesAndDisplayList(rootNode);
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700107 return rootNode;
Chris Craik27e58b42015-12-07 10:01:38 -0800108}
109
John Reck0418afa32016-03-07 13:24:25 -0800110static auto SCENES = {
111 "listview",
112};
113
114void BM_FrameBuilder_defer_scene(benchmark::State& state) {
John Reck2c0f9372016-03-28 09:34:35 -0700115 TestUtils::runOnRenderThread([&state](RenderThread& thread) {
116 const char* sceneName = *(SCENES.begin() + state.range_x());
117 state.SetLabel(sceneName);
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700118 auto node = getSyncedSceneNode(sceneName);
John Reck2c0f9372016-03-28 09:34:35 -0700119 while (state.KeepRunning()) {
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700120 FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h),
121 gDisplay.w, gDisplay.h,
122 sLightGeometry, Caches::getInstance());
123 frameBuilder.deferRenderNode(*node);
John Reck2c0f9372016-03-28 09:34:35 -0700124 benchmark::DoNotOptimize(&frameBuilder);
125 }
126 });
Chris Craik27e58b42015-12-07 10:01:38 -0800127}
John Reck0418afa32016-03-07 13:24:25 -0800128BENCHMARK(BM_FrameBuilder_defer_scene)->DenseRange(0, SCENES.size() - 1);
Chris Craik27e58b42015-12-07 10:01:38 -0800129
John Reck0418afa32016-03-07 13:24:25 -0800130void BM_FrameBuilder_deferAndRender_scene(benchmark::State& state) {
131 TestUtils::runOnRenderThread([&state](RenderThread& thread) {
132 const char* sceneName = *(SCENES.begin() + state.range_x());
133 state.SetLabel(sceneName);
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700134 auto node = getSyncedSceneNode(sceneName);
Chris Craik27e58b42015-12-07 10:01:38 -0800135
136 RenderState& renderState = thread.renderState();
137 Caches& caches = Caches::getInstance();
138
John Reck0418afa32016-03-07 13:24:25 -0800139 while (state.KeepRunning()) {
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700140 FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h),
141 gDisplay.w, gDisplay.h,
142 sLightGeometry, Caches::getInstance());
143 frameBuilder.deferRenderNode(*node);
Chris Craik27e58b42015-12-07 10:01:38 -0800144
Chris Craik6e068c012016-01-15 16:15:30 -0800145 BakedOpRenderer renderer(caches, renderState, true, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -0800146 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
John Reck0418afa32016-03-07 13:24:25 -0800147 benchmark::DoNotOptimize(&renderer);
Chris Craik27e58b42015-12-07 10:01:38 -0800148 }
Chris Craik27e58b42015-12-07 10:01:38 -0800149 });
150}
John Reck0418afa32016-03-07 13:24:25 -0800151BENCHMARK(BM_FrameBuilder_deferAndRender_scene)->DenseRange(0, SCENES.size() - 1);