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));
4613fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->writeFloat(mColor.r));
4713fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->writeFloat(mColor.g));
4813fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->writeFloat(mColor.b));
4913fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->writeFloat(mColor.a));
50a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(mFlags));
51a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mPixelFormat));
52a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeUint32(static_cast<uint32_t>(mDataSpace)));
53a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    for (size_t index = 0; index < 4; index++) {
54a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita        RETURN_ON_ERROR(parcel->writeFloat(mMatrix[index / 2][index % 2]));
55a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    }
56a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferWidth));
57a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferHeight));
58a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferStride));
59a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferFormat));
60a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeInt32(mNumQueuedFrames));
61a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mRefreshPending));
62a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mIsOpaque));
63a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->writeBool(mContentDirty));
64a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return NO_ERROR;
65a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
66a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
67a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitastatus_t LayerDebugInfo::readFromParcel(const Parcel* parcel) {
68a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mName = parcel->readCString();
69a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
70a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mParentName = parcel->readCString();
71a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
72a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mType = parcel->readCString();
73a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
74a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mTransparentRegion));
75a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mVisibleRegion));
76a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mSurfaceDamageRegion));
77a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mLayerStack));
78a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readFloat(&mX));
79a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readFloat(&mY));
80a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mZ));
81a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mWidth));
82a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mHeight));
83a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mCrop));
84a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->read(mFinalCrop));
8513fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    mColor.r = parcel->readFloat();
8613fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->errorCheck());
8713fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    mColor.g = parcel->readFloat();
8813fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->errorCheck());
8913fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    mColor.b = parcel->readFloat();
9013fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->errorCheck());
9113fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    mColor.a = parcel->readFloat();
9213fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    RETURN_ON_ERROR(parcel->errorCheck());
93a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readUint32(&mFlags));
94a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mPixelFormat));
95a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    // \todo [2017-07-25 kraita]: Static casting mDataSpace pointer to an uint32 does work. Better ways?
96a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    mDataSpace = static_cast<android_dataspace>(parcel->readUint32());
97a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->errorCheck());
98a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    for (size_t index = 0; index < 4; index++) {
99a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita        RETURN_ON_ERROR(parcel->readFloat(&mMatrix[index / 2][index % 2]));
100a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    }
101a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferWidth));
102a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferHeight));
103a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferStride));
104a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferFormat));
105a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readInt32(&mNumQueuedFrames));
106a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mRefreshPending));
107a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mIsOpaque));
108a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    RETURN_ON_ERROR(parcel->readBool(&mContentDirty));
109a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return NO_ERROR;
110a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
111a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
112a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raitastd::string to_string(const LayerDebugInfo& info) {
113a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    String8 result;
114a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
115a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("+ %s (%s)\n", info.mType.c_str(), info.mName.c_str());
116a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mTransparentRegion.dump(result, "TransparentRegion");
117a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mVisibleRegion.dump(result, "VisibleRegion");
118a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    info.mSurfaceDamageRegion.dump(result, "SurfaceDamageRegion");
119a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
120a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      layerStack=%4d, z=%9d, pos=(%g,%g), size=(%4d,%4d), ",
121a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mLayerStack, info.mZ, static_cast<double>(info.mX), static_cast<double>(info.mY),
122a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mWidth, info.mHeight);
123a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
124a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("crop=%s, finalCrop=%s, ",
125a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            to_string(info.mCrop).c_str(), to_string(info.mFinalCrop).c_str());
126a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("isOpaque=%1d, invalidate=%1d, ", info.mIsOpaque, info.mContentDirty);
127a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("dataspace=%s, ", dataspaceDetails(info.mDataSpace).c_str());
128a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("pixelformat=%s, ", decodePixelFormat(info.mPixelFormat).c_str());
12913fdc49516d17f41e64e62e73c313b0928bf13ccchaviw    result.appendFormat("color=(%.3f,%.3f,%.3f,%.3f), flags=0x%08x, ",
13013fdc49516d17f41e64e62e73c313b0928bf13ccchaviw            static_cast<double>(info.mColor.r), static_cast<double>(info.mColor.g),
13113fdc49516d17f41e64e62e73c313b0928bf13ccchaviw            static_cast<double>(info.mColor.b), static_cast<double>(info.mColor.a),
13213fdc49516d17f41e64e62e73c313b0928bf13ccchaviw            info.mFlags);
133a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("tr=[%.2f, %.2f][%.2f, %.2f]",
134a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            static_cast<double>(info.mMatrix[0][0]), static_cast<double>(info.mMatrix[0][1]),
135a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            static_cast<double>(info.mMatrix[1][0]), static_cast<double>(info.mMatrix[1][1]));
136a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.append("\n");
137a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      parent=%s\n", info.mParentName.c_str());
138a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat("      activeBuffer=[%4ux%4u:%4u,%s],",
139a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mActiveBufferWidth, info.mActiveBufferHeight,
140a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mActiveBufferStride,
141a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            decodePixelFormat(info.mActiveBufferFormat).c_str());
142a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.appendFormat(" queued-frames=%d, mRefreshPending=%d",
143a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita            info.mNumQueuedFrames, info.mRefreshPending);
144a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    result.append("\n");
145a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita    return std::string(result.c_str());
146a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita}
147a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita
148a099a24c93bfa599fc5c36a647e946c26f68514fKalle Raita} // android
149