| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2017 The Android Open Source Project | 
|  | 3 | * | 
|  | 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 |  | 
|  | 17 | #include <gui/LayerDebugInfo.h> | 
|  | 18 |  | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 19 | #include <android-base/stringprintf.h> | 
|  | 20 |  | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 21 | #include <ui/DebugUtils.h> | 
|  | 22 |  | 
|  | 23 | #include <binder/Parcel.h> | 
|  | 24 |  | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 25 | using namespace android; | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 26 | using android::base::StringAppendF; | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 27 |  | 
|  | 28 | #define RETURN_ON_ERROR(X) do {status_t res = (X); if (res != NO_ERROR) return res;} while(false) | 
|  | 29 |  | 
|  | 30 | namespace android { | 
|  | 31 |  | 
|  | 32 | status_t LayerDebugInfo::writeToParcel(Parcel* parcel) const { | 
|  | 33 | RETURN_ON_ERROR(parcel->writeCString(mName.c_str())); | 
|  | 34 | RETURN_ON_ERROR(parcel->writeCString(mParentName.c_str())); | 
|  | 35 | RETURN_ON_ERROR(parcel->writeCString(mType.c_str())); | 
|  | 36 | RETURN_ON_ERROR(parcel->write(mTransparentRegion)); | 
|  | 37 | RETURN_ON_ERROR(parcel->write(mVisibleRegion)); | 
|  | 38 | RETURN_ON_ERROR(parcel->write(mSurfaceDamageRegion)); | 
|  | 39 | RETURN_ON_ERROR(parcel->writeUint32(mLayerStack)); | 
|  | 40 | RETURN_ON_ERROR(parcel->writeFloat(mX)); | 
|  | 41 | RETURN_ON_ERROR(parcel->writeFloat(mY)); | 
|  | 42 | RETURN_ON_ERROR(parcel->writeUint32(mZ)); | 
|  | 43 | RETURN_ON_ERROR(parcel->writeInt32(mWidth)); | 
|  | 44 | RETURN_ON_ERROR(parcel->writeInt32(mHeight)); | 
|  | 45 | RETURN_ON_ERROR(parcel->write(mCrop)); | 
| chaviw | 13fdc49 | 2017-06-27 12:40:18 -0700 | [diff] [blame] | 46 | RETURN_ON_ERROR(parcel->writeFloat(mColor.r)); | 
|  | 47 | RETURN_ON_ERROR(parcel->writeFloat(mColor.g)); | 
|  | 48 | RETURN_ON_ERROR(parcel->writeFloat(mColor.b)); | 
|  | 49 | RETURN_ON_ERROR(parcel->writeFloat(mColor.a)); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 50 | RETURN_ON_ERROR(parcel->writeUint32(mFlags)); | 
|  | 51 | RETURN_ON_ERROR(parcel->writeInt32(mPixelFormat)); | 
|  | 52 | RETURN_ON_ERROR(parcel->writeUint32(static_cast<uint32_t>(mDataSpace))); | 
|  | 53 | for (size_t index = 0; index < 4; index++) { | 
|  | 54 | RETURN_ON_ERROR(parcel->writeFloat(mMatrix[index / 2][index % 2])); | 
|  | 55 | } | 
|  | 56 | RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferWidth)); | 
|  | 57 | RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferHeight)); | 
|  | 58 | RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferStride)); | 
|  | 59 | RETURN_ON_ERROR(parcel->writeInt32(mActiveBufferFormat)); | 
|  | 60 | RETURN_ON_ERROR(parcel->writeInt32(mNumQueuedFrames)); | 
|  | 61 | RETURN_ON_ERROR(parcel->writeBool(mRefreshPending)); | 
|  | 62 | RETURN_ON_ERROR(parcel->writeBool(mIsOpaque)); | 
|  | 63 | RETURN_ON_ERROR(parcel->writeBool(mContentDirty)); | 
| John Reck | c00c669 | 2021-02-16 11:37:33 -0500 | [diff] [blame] | 64 | RETURN_ON_ERROR(parcel->write(mStretchEffect)); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 65 | return NO_ERROR; | 
|  | 66 | } | 
|  | 67 |  | 
|  | 68 | status_t LayerDebugInfo::readFromParcel(const Parcel* parcel) { | 
|  | 69 | mName = parcel->readCString(); | 
|  | 70 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 71 | mParentName = parcel->readCString(); | 
|  | 72 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 73 | mType = parcel->readCString(); | 
|  | 74 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 75 | RETURN_ON_ERROR(parcel->read(mTransparentRegion)); | 
|  | 76 | RETURN_ON_ERROR(parcel->read(mVisibleRegion)); | 
|  | 77 | RETURN_ON_ERROR(parcel->read(mSurfaceDamageRegion)); | 
|  | 78 | RETURN_ON_ERROR(parcel->readUint32(&mLayerStack)); | 
|  | 79 | RETURN_ON_ERROR(parcel->readFloat(&mX)); | 
|  | 80 | RETURN_ON_ERROR(parcel->readFloat(&mY)); | 
|  | 81 | RETURN_ON_ERROR(parcel->readUint32(&mZ)); | 
|  | 82 | RETURN_ON_ERROR(parcel->readInt32(&mWidth)); | 
|  | 83 | RETURN_ON_ERROR(parcel->readInt32(&mHeight)); | 
|  | 84 | RETURN_ON_ERROR(parcel->read(mCrop)); | 
| chaviw | 13fdc49 | 2017-06-27 12:40:18 -0700 | [diff] [blame] | 85 | mColor.r = parcel->readFloat(); | 
|  | 86 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 87 | mColor.g = parcel->readFloat(); | 
|  | 88 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 89 | mColor.b = parcel->readFloat(); | 
|  | 90 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 91 | mColor.a = parcel->readFloat(); | 
|  | 92 | RETURN_ON_ERROR(parcel->errorCheck()); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 93 | RETURN_ON_ERROR(parcel->readUint32(&mFlags)); | 
|  | 94 | RETURN_ON_ERROR(parcel->readInt32(&mPixelFormat)); | 
|  | 95 | // \todo [2017-07-25 kraita]: Static casting mDataSpace pointer to an uint32 does work. Better ways? | 
|  | 96 | mDataSpace = static_cast<android_dataspace>(parcel->readUint32()); | 
|  | 97 | RETURN_ON_ERROR(parcel->errorCheck()); | 
|  | 98 | for (size_t index = 0; index < 4; index++) { | 
|  | 99 | RETURN_ON_ERROR(parcel->readFloat(&mMatrix[index / 2][index % 2])); | 
|  | 100 | } | 
|  | 101 | RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferWidth)); | 
|  | 102 | RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferHeight)); | 
|  | 103 | RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferStride)); | 
|  | 104 | RETURN_ON_ERROR(parcel->readInt32(&mActiveBufferFormat)); | 
|  | 105 | RETURN_ON_ERROR(parcel->readInt32(&mNumQueuedFrames)); | 
|  | 106 | RETURN_ON_ERROR(parcel->readBool(&mRefreshPending)); | 
|  | 107 | RETURN_ON_ERROR(parcel->readBool(&mIsOpaque)); | 
|  | 108 | RETURN_ON_ERROR(parcel->readBool(&mContentDirty)); | 
| John Reck | c00c669 | 2021-02-16 11:37:33 -0500 | [diff] [blame] | 109 | RETURN_ON_ERROR(parcel->read(mStretchEffect)); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 110 | return NO_ERROR; | 
|  | 111 | } | 
|  | 112 |  | 
|  | 113 | std::string to_string(const LayerDebugInfo& info) { | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 114 | std::string result; | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 115 |  | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 116 | StringAppendF(&result, "+ %s (%s)\n", info.mType.c_str(), info.mName.c_str()); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 117 | info.mTransparentRegion.dump(result, "TransparentRegion"); | 
|  | 118 | info.mVisibleRegion.dump(result, "VisibleRegion"); | 
|  | 119 | info.mSurfaceDamageRegion.dump(result, "SurfaceDamageRegion"); | 
| John Reck | c00c669 | 2021-02-16 11:37:33 -0500 | [diff] [blame] | 120 | if (info.mStretchEffect.hasEffect()) { | 
|  | 121 | const auto& se = info.mStretchEffect; | 
| Nader Jawad | 2dfc98b | 2021-04-08 20:35:39 -0700 | [diff] [blame] | 122 | StringAppendF(&result, | 
|  | 123 | "  StretchEffect width = %f, height = %f vec=(%f, %f) " | 
|  | 124 | "maxAmount=(%f, %f)\n", | 
|  | 125 | se.width, se.height, | 
|  | 126 | se.vectorX, se.vectorY, se.maxAmountX, se.maxAmountY); | 
| John Reck | c00c669 | 2021-02-16 11:37:33 -0500 | [diff] [blame] | 127 | } | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 128 |  | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 129 | StringAppendF(&result, "      layerStack=%4d, z=%9d, pos=(%g,%g), size=(%4d,%4d), ", | 
|  | 130 | info.mLayerStack, info.mZ, static_cast<double>(info.mX), | 
|  | 131 | static_cast<double>(info.mY), info.mWidth, info.mHeight); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 132 |  | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 133 | StringAppendF(&result, "crop=%s, ", to_string(info.mCrop).c_str()); | 
|  | 134 | StringAppendF(&result, "isOpaque=%1d, invalidate=%1d, ", info.mIsOpaque, info.mContentDirty); | 
|  | 135 | StringAppendF(&result, "dataspace=%s, ", dataspaceDetails(info.mDataSpace).c_str()); | 
|  | 136 | StringAppendF(&result, "pixelformat=%s, ", decodePixelFormat(info.mPixelFormat).c_str()); | 
|  | 137 | StringAppendF(&result, "color=(%.3f,%.3f,%.3f,%.3f), flags=0x%08x, ", | 
|  | 138 | static_cast<double>(info.mColor.r), static_cast<double>(info.mColor.g), | 
|  | 139 | static_cast<double>(info.mColor.b), static_cast<double>(info.mColor.a), | 
|  | 140 | info.mFlags); | 
|  | 141 | StringAppendF(&result, "tr=[%.2f, %.2f][%.2f, %.2f]", static_cast<double>(info.mMatrix[0][0]), | 
|  | 142 | static_cast<double>(info.mMatrix[0][1]), static_cast<double>(info.mMatrix[1][0]), | 
|  | 143 | static_cast<double>(info.mMatrix[1][1])); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 144 | result.append("\n"); | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 145 | StringAppendF(&result, "      parent=%s\n", info.mParentName.c_str()); | 
|  | 146 | StringAppendF(&result, "      activeBuffer=[%4ux%4u:%4u,%s],", info.mActiveBufferWidth, | 
|  | 147 | info.mActiveBufferHeight, info.mActiveBufferStride, | 
|  | 148 | decodePixelFormat(info.mActiveBufferFormat).c_str()); | 
|  | 149 | StringAppendF(&result, " queued-frames=%d, mRefreshPending=%d", info.mNumQueuedFrames, | 
|  | 150 | info.mRefreshPending); | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 151 | result.append("\n"); | 
| Yiwei Zhang | 5434a78 | 2018-12-05 18:06:32 -0800 | [diff] [blame] | 152 | return result; | 
| Kalle Raita | a099a24 | 2017-01-11 11:17:29 -0800 | [diff] [blame] | 153 | } | 
|  | 154 |  | 
|  | 155 | } // android |