blob: b6217665d74356613d4abe20e6205913b787090b [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
Chris Craik9e7fcfd2015-11-25 13:27:33 -080019#include "BakedOpDispatcher.h"
Chris Craik0a24b142015-10-19 17:10:19 -070020#include "BakedOpRenderer.h"
John Reck1bcacfd2017-11-03 10:12:19 -070021#include "BakedOpState.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"
John Reck1bcacfd2017-11-03 10:12:19 -070026#include "Vector.h"
Chris Craik27e58b42015-12-07 10:01:38 -080027#include "tests/common/TestContext.h"
28#include "tests/common/TestScene.h"
Chris Craik8160f202015-12-02 14:50:25 -080029#include "tests/common/TestUtils.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
John Reck1bcacfd2017-11-03 10:12:19 -070038const 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() {
John Reck1bcacfd2017-11-03 10:12:19 -070042 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 Craik8d1f2122015-11-24 16:40:09 -080046
John Reck1bcacfd2017-11-03 10:12:19 -070047 // 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 Craik8d1f2122015-11-24 16:40:09 -080057 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()) {
John Reck1bcacfd2017-11-03 10:12:19 -070065 FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200, sLightGeometry,
66 Caches::getInstance());
Chris Craik9cd1bbe2016-04-14 16:08:25 -070067 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()) {
John Reck1bcacfd2017-11-03 10:12:19 -070082 FrameBuilder frameBuilder(SkRect::MakeWH(100, 200), 100, 200, sLightGeometry, caches);
Chris Craik9cd1bbe2016-04-14 16:08:25 -070083 frameBuilder.deferRenderNode(*node);
Chris Craik0a24b142015-10-19 17:10:19 -070084
Romain Guy07ae5052017-06-13 18:25:32 -070085 BakedOpRenderer renderer(caches, renderState, true, false, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -080086 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
John Reck0418afa32016-03-07 13:24:25 -080087 benchmark::DoNotOptimize(&renderer);
Chris Craik0a24b142015-10-19 17:10:19 -070088 }
Chris Craik0a24b142015-10-19 17:10:19 -070089 });
90}
John Reck0418afa32016-03-07 13:24:25 -080091BENCHMARK(BM_FrameBuilder_deferAndRender);
Chris Craik27e58b42015-12-07 10:01:38 -080092
Chris Craik9cd1bbe2016-04-14 16:08:25 -070093static sp<RenderNode> getSyncedSceneNode(const char* sceneName) {
John Reck1bcacfd2017-11-03 10:12:19 -070094 gDisplay = getBuiltInDisplay(); // switch to real display if present
Chris Craik27e58b42015-12-07 10:01:38 -080095
96 TestContext testContext;
97 TestScene::Options opts;
98 std::unique_ptr<TestScene> scene(TestScene::testMap()[sceneName].createScene(opts));
99
John Reck1bcacfd2017-11-03 10:12:19 -0700100 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 Craik27e58b42015-12-07 10:01:38 -0800105
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) {
Martijn Coenen90213f32016-11-14 14:56:03 +0100116 const char* sceneName = *(SCENES.begin() + state.range(0));
John Reck2c0f9372016-03-28 09:34:35 -0700117 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()) {
John Reck1bcacfd2017-11-03 10:12:19 -0700120 FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w,
121 gDisplay.h, sLightGeometry, Caches::getInstance());
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700122 frameBuilder.deferRenderNode(*node);
John Reck2c0f9372016-03-28 09:34:35 -0700123 benchmark::DoNotOptimize(&frameBuilder);
124 }
125 });
Chris Craik27e58b42015-12-07 10:01:38 -0800126}
John Reck0418afa32016-03-07 13:24:25 -0800127BENCHMARK(BM_FrameBuilder_defer_scene)->DenseRange(0, SCENES.size() - 1);
Chris Craik27e58b42015-12-07 10:01:38 -0800128
John Reck0418afa32016-03-07 13:24:25 -0800129void BM_FrameBuilder_deferAndRender_scene(benchmark::State& state) {
130 TestUtils::runOnRenderThread([&state](RenderThread& thread) {
Martijn Coenen90213f32016-11-14 14:56:03 +0100131 const char* sceneName = *(SCENES.begin() + state.range(0));
John Reck0418afa32016-03-07 13:24:25 -0800132 state.SetLabel(sceneName);
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700133 auto node = getSyncedSceneNode(sceneName);
Chris Craik27e58b42015-12-07 10:01:38 -0800134
135 RenderState& renderState = thread.renderState();
136 Caches& caches = Caches::getInstance();
137
John Reck0418afa32016-03-07 13:24:25 -0800138 while (state.KeepRunning()) {
John Reck1bcacfd2017-11-03 10:12:19 -0700139 FrameBuilder frameBuilder(SkRect::MakeWH(gDisplay.w, gDisplay.h), gDisplay.w,
140 gDisplay.h, sLightGeometry, Caches::getInstance());
Chris Craik9cd1bbe2016-04-14 16:08:25 -0700141 frameBuilder.deferRenderNode(*node);
Chris Craik27e58b42015-12-07 10:01:38 -0800142
Romain Guy07ae5052017-06-13 18:25:32 -0700143 BakedOpRenderer renderer(caches, renderState, true, false, sLightInfo);
Chris Craikf158b492016-01-12 14:45:08 -0800144 frameBuilder.replayBakedOps<BakedOpDispatcher>(renderer);
John Reck0418afa32016-03-07 13:24:25 -0800145 benchmark::DoNotOptimize(&renderer);
Chris Craik27e58b42015-12-07 10:01:38 -0800146 }
Chris Craik27e58b42015-12-07 10:01:38 -0800147 });
148}
John Reck0418afa32016-03-07 13:24:25 -0800149BENCHMARK(BM_FrameBuilder_deferAndRender_scene)->DenseRange(0, SCENES.size() - 1);