diff options
author | 2019-01-29 12:46:35 -0800 | |
---|---|---|
committer | 2019-01-30 01:37:57 +0000 | |
commit | 6f54dca05107d4da9bb66c467967d950e4f1e14b (patch) | |
tree | a78b1b651cb5e12a00f7bb044322985c8c785c4c /libs/ui/BufferHubBuffer.cpp | |
parent | 7de6f68ff865afa3b329b605b78d0cf0df2a050d (diff) |
Clean up initWithBufferTraits
Bug: None
Test: BufferHub_test BufferHubServer_test VtsHalBufferHubV1_0TargetTest
Change-Id: I3b386c3710ca1268587e3a3b03632e02cd353b6e
Diffstat (limited to 'libs/ui/BufferHubBuffer.cpp')
-rw-r--r-- | libs/ui/BufferHubBuffer.cpp | 32 |
1 files changed, 15 insertions, 17 deletions
diff --git a/libs/ui/BufferHubBuffer.cpp b/libs/ui/BufferHubBuffer.cpp index f3856d0cc5..4b3d3ba06e 100644 --- a/libs/ui/BufferHubBuffer.cpp +++ b/libs/ui/BufferHubBuffer.cpp @@ -167,32 +167,30 @@ int BufferHubBuffer::initWithBufferTraits(const BufferTraits& bufferTraits) { return -EINVAL; } - int bufferId = bufferTraits.bufferInfo->data[2]; - if (bufferId < 0) { - ALOGE("%s: Received an invalid (negative) id!", __FUNCTION__); + // Import fds. Dup fds because hidl_handle owns the fds. + unique_fd ashmemFd(fcntl(bufferTraits.bufferInfo->data[0], F_DUPFD_CLOEXEC, 0)); + mMetadata = BufferHubMetadata::Import(std::move(ashmemFd)); + if (!mMetadata.IsValid()) { + ALOGE("%s: Received an invalid metadata.", __FUNCTION__); return -EINVAL; } - uint32_t clientBitMask; - memcpy(&clientBitMask, &bufferTraits.bufferInfo->data[3], sizeof(clientBitMask)); - if (clientBitMask == 0U) { - ALOGE("%s: Received a invalid client state mask!", __FUNCTION__); + mEventFd = BufferHubEventFd(fcntl(bufferTraits.bufferInfo->data[1], F_DUPFD_CLOEXEC, 0)); + if (!mEventFd.isValid()) { + ALOGE("%s: Received ad invalid event fd.", __FUNCTION__); return -EINVAL; } - // Import fds. Dup fds because hidl_handle owns the fds. - const int eventFd = fcntl(bufferTraits.bufferInfo->data[1], F_DUPFD_CLOEXEC, 0); - if (eventFd < 0) { - ALOGE("%s: Received a invalid event fd!", __FUNCTION__); + int bufferId = bufferTraits.bufferInfo->data[2]; + if (bufferId < 0) { + ALOGE("%s: Received an invalid (negative) id.", __FUNCTION__); return -EINVAL; } - mEventFd = BufferHubEventFd(eventFd); - - unique_fd ashmemFd(fcntl(bufferTraits.bufferInfo->data[0], F_DUPFD_CLOEXEC, 0)); - mMetadata = BufferHubMetadata::Import(std::move(ashmemFd)); - if (!mMetadata.IsValid()) { - ALOGE("%s: invalid metadata.", __FUNCTION__); + uint32_t clientBitMask; + memcpy(&clientBitMask, &bufferTraits.bufferInfo->data[3], sizeof(clientBitMask)); + if (clientBitMask == 0U) { + ALOGE("%s: Received an invalid client state mask.", __FUNCTION__); return -EINVAL; } |