diff options
author | 2020-09-22 18:11:45 +0000 | |
---|---|---|
committer | 2020-09-25 12:33:30 +0000 | |
commit | 421dfd5842d44a77883fac7ad2781c363e77aed3 (patch) | |
tree | 6d9773522d0e5cc0777c27804802b434214ee14c /libs/gui/SurfaceControl.cpp | |
parent | 2ec1f7b970563ffd1651c36c52e9fc6831120915 (diff) |
Convert SurfaceControl parceling to SAFE_PARCEL
Test: Existing tests
Change-Id: I7618f9677e538fca90ae5cfb0693e5926701f564
Diffstat (limited to 'libs/gui/SurfaceControl.cpp')
-rw-r--r-- | libs/gui/SurfaceControl.cpp | 49 |
1 files changed, 21 insertions, 28 deletions
diff --git a/libs/gui/SurfaceControl.cpp b/libs/gui/SurfaceControl.cpp index 8dcb71bcfc..0246b7315e 100644 --- a/libs/gui/SurfaceControl.cpp +++ b/libs/gui/SurfaceControl.cpp @@ -169,42 +169,35 @@ void SurfaceControl::setTransformHint(uint32_t hint) { mTransformHint = hint; } -void SurfaceControl::writeToParcel(Parcel* parcel) -{ - parcel->writeStrongBinder(ISurfaceComposerClient::asBinder(mClient->getClient())); - parcel->writeStrongBinder(mHandle); - parcel->writeStrongBinder(IGraphicBufferProducer::asBinder(mGraphicBufferProducer)); - parcel->writeUint32(mTransformHint); +status_t SurfaceControl::writeToParcel(Parcel& parcel) { + SAFE_PARCEL(parcel.writeStrongBinder, ISurfaceComposerClient::asBinder(mClient->getClient())); + SAFE_PARCEL(parcel.writeStrongBinder, mHandle); + SAFE_PARCEL(parcel.writeStrongBinder, IGraphicBufferProducer::asBinder(mGraphicBufferProducer)); + SAFE_PARCEL(parcel.writeUint32, mTransformHint); + + return NO_ERROR; } -sp<SurfaceControl> SurfaceControl::readFromParcel(const Parcel* parcel) { - bool invalidParcel = false; - status_t status; +status_t SurfaceControl::readFromParcel(const Parcel& parcel, + sp<SurfaceControl>* outSurfaceControl) { sp<IBinder> client; - if ((status = parcel->readStrongBinder(&client)) != OK) { - ALOGE("Failed to read client: %s", statusToString(status).c_str()); - invalidParcel = true; - } sp<IBinder> handle; - if ((status = parcel->readStrongBinder(&handle)) != OK) { - ALOGE("Failed to read handle: %s", statusToString(status).c_str()); - invalidParcel = true; - } sp<IBinder> gbp; - if ((status = parcel->readNullableStrongBinder(&gbp)) != OK) { - ALOGE("Failed to read gbp: %s", statusToString(status).c_str()); - invalidParcel = true; - } - uint32_t transformHint = parcel->readUint32(); + uint32_t transformHint; + + SAFE_PARCEL(parcel.readStrongBinder, &client); + SAFE_PARCEL(parcel.readStrongBinder, &handle); + SAFE_PARCEL(parcel.readNullableStrongBinder, &gbp); + SAFE_PARCEL(parcel.readUint32, &transformHint); - if (invalidParcel) { - return nullptr; - } // We aren't the original owner of the surface. - return new SurfaceControl(new SurfaceComposerClient( - interface_cast<ISurfaceComposerClient>(client)), - handle.get(), interface_cast<IGraphicBufferProducer>(gbp), + *outSurfaceControl = + new SurfaceControl(new SurfaceComposerClient( + interface_cast<ISurfaceComposerClient>(client)), + handle.get(), interface_cast<IGraphicBufferProducer>(gbp), transformHint); + + return NO_ERROR; } // ---------------------------------------------------------------------------- |