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