LayerDebugInfo.cpp revision a099a24c93bfa599fc5c36a647e946c26f68514f
1a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita/*
2a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * Copyright (C) 2017 The Android Open Source Project
3a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita *
4a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * Licensed under the Apache License, Version 2.0 (the "License");
5a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * you may not use this file except in compliance with the License.
6a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * You may obtain a copy of the License at
7a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita *
8a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita *      http://www.apache.org/licenses/LICENSE-2.0
9a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita *
10a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * Unless required by applicable law or agreed to in writing, software
11a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * distributed under the License is distributed on an "AS IS" BASIS,
12a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * See the License for the specific language governing permissions and
14a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita * limitations under the License.
15a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita */
16a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
17a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita#include <gui/LayerDebugInfo.h>
18a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
19a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita#include <ui/DebugUtils.h>
20a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
21a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita#include <binder/Parcel.h>
22a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
23a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita#include <utils/String8.h>
24a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
25a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitausing namespace android;
26a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
27a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita#define RETURN_ON_ERROR(X) do {status_t res = (X); if (res != NO_ERROR) return res;} while(false)
28a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
29a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitanamespace android {
30a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
31a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitastatus_t LayerDebugInfo::writeToParcel(Parcel* parcel) const {
32a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeCString(mName.c_str()));
33a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeCString(mParentName.c_str()));
34a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeCString(mType.c_str()));
35a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->write(mTransparentRegion));
36a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->write(mVisibleRegion));
37a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->write(mSurfaceDamageRegion));
38a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(mLayerStack));
39a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeFloat(mX));
40a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeFloat(mY));
41a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(mZ));
42a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mWidth));
43a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mHeight));
44a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->write(mCrop));
45a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->write(mFinalCrop));
46a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeFloat(mAlpha));
47a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(mFlags));
48a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mPixelFormat));
49a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(static_cast<uint32_t>(mDataSpace)));
50a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    for (size_t index = 0; index < 4; index++) {
51a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita        RETURN_ON_ERROR(parcel->writeFloat(mMatrix[index / 2][index % 2]));
52a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    }
53a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferWidth));
54a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferHeight));
55a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferStride));
56a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferFormat));
57a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mNumQueuedFrames));
58a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mRefreshPending));
59a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mIsOpaque));
60a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mContentDirty));
61a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return NO_ERROR;
62a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
63a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
64a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitastatus_t LayerDebugInfo::readFromParcel(const Parcel* parcel) {
65a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mName = parcel->readCString();
66a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
67a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mParentName = parcel->readCString();
68a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
69a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mType = parcel->readCString();
70a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
71a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mTransparentRegion));
72a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mVisibleRegion));
73a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mSurfaceDamageRegion));
74a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mLayerStack));
75a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readFloat(&mX));
76a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readFloat(&mY));
77a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mZ));
78a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mWidth));
79a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mHeight));
80a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mCrop));
81a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mFinalCrop));
82a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readFloat(&mAlpha));
83a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mFlags));
84a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mPixelFormat));
85a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    // \todo [2017-07-25 kraita]: Static casting mDataSpace pointer to an uint32 does work. Better ways?
86a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mDataSpace = static_cast<android_dataspace>(parcel->readUint32());
87a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
88a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    for (size_t index = 0; index < 4; index++) {
89a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita        RETURN_ON_ERROR(parcel->readFloat(&mMatrix[index / 2][index % 2]));
90a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    }
91a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferWidth));
92a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferHeight));
93a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferStride));
94a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferFormat));
95a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mNumQueuedFrames));
96a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mRefreshPending));
97a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mIsOpaque));
98a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mContentDirty));
99a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return NO_ERROR;
100a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
101a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
102a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitastd::string to_string(const LayerDebugInfo& info) {
103a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    String8 result;
104a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
105a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("+ %s (%s)\n", info.mType.c_str(), info.mName.c_str());
106a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mTransparentRegion.dump(result, "TransparentRegion");
107a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mVisibleRegion.dump(result, "VisibleRegion");
108a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mSurfaceDamageRegion.dump(result, "SurfaceDamageRegion");
109a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
110a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      layerStack=%4d, z=%9d, pos=(%g,%g), size=(%4d,%4d), ",
111a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mLayerStack, info.mZ, static_cast<double>(info.mX), static_cast<double>(info.mY),
112a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mWidth, info.mHeight);
113a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
114a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("crop=%s, finalCrop=%s, ",
115a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            to_string(info.mCrop).c_str(), to_string(info.mFinalCrop).c_str());
116a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("isOpaque=%1d, invalidate=%1d, ", info.mIsOpaque, info.mContentDirty);
117a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("dataspace=%s, ", dataspaceDetails(info.mDataSpace).c_str());
118a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("pixelformat=%s, ", decodePixelFormat(info.mPixelFormat).c_str());
119a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("alpha=%.3f, flags=0x%08x, ",
120a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            static_cast<double>(info.mAlpha), info.mFlags);
121a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("tr=[%.2f, %.2f][%.2f, %.2f]",
122a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            static_cast<double>(info.mMatrix[0][0]), static_cast<double>(info.mMatrix[0][1]),
123a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            static_cast<double>(info.mMatrix[1][0]), static_cast<double>(info.mMatrix[1][1]));
124a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.append("\n");
125a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      parent=%s\n", info.mParentName.c_str());
126a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      activeBuffer=[%4ux%4u:%4u,%s],",
127a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mActiveBufferWidth, info.mActiveBufferHeight,
128a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mActiveBufferStride,
129a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            decodePixelFormat(info.mActiveBufferFormat).c_str());
130a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat(" queued-frames=%d, mRefreshPending=%d",
131a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mNumQueuedFrames, info.mRefreshPending);
132a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.append("\n");
133a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return std::string(result.c_str());
134a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
135a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
136a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita} // android
137