diff options
author | 2019-09-05 16:53:28 +0000 | |
---|---|---|
committer | 2019-09-05 16:53:28 +0000 | |
commit | b653dd0a088f3be9d0fccd3d2099b3f8ab63ca2c (patch) | |
tree | a3796f67d19deece6118e60d2faebde9499ce083 /services/bufferhub/BufferClient.cpp | |
parent | 0bc2361309d705f8c7f7766f1912fd0f7035d199 (diff) | |
parent | 9c724d78b9f2e00a7d4de3bfd2c65f6226fa8529 (diff) |
Merge "DO NOT MERGE - Merge Android 10 into master"
Diffstat (limited to 'services/bufferhub/BufferClient.cpp')
-rw-r--r-- | services/bufferhub/BufferClient.cpp | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/services/bufferhub/BufferClient.cpp b/services/bufferhub/BufferClient.cpp new file mode 100644 index 0000000000..ec7e535699 --- /dev/null +++ b/services/bufferhub/BufferClient.cpp @@ -0,0 +1,100 @@ +/* + * Copyright (C) 2018 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include <bufferhub/BufferClient.h> +#include <bufferhub/BufferHubService.h> +#include <hidl/HidlSupport.h> +#include <log/log.h> + +namespace android { +namespace frameworks { +namespace bufferhub { +namespace V1_0 { +namespace implementation { + +using hardware::hidl_handle; +using hardware::Void; + +BufferClient* BufferClient::create(BufferHubService* service, + const std::shared_ptr<BufferNode>& node) { + if (!service) { + ALOGE("%s: service cannot be nullptr.", __FUNCTION__); + return nullptr; + } else if (!node) { + ALOGE("%s: node cannot be nullptr.", __FUNCTION__); + return nullptr; + } + return new BufferClient(service, node); +} + +BufferClient::~BufferClient() { + { + std::lock_guard<std::mutex> lock(mClosedMutex); + if (!mClosed) { + ALOGW("%s: client of buffer #%d destroyed without close. Closing it now.", __FUNCTION__, + mBufferNode->id()); + } + } + + close(); +} + +Return<BufferHubStatus> BufferClient::close() { + std::lock_guard<std::mutex> lock(mClosedMutex); + if (mClosed) { + return BufferHubStatus::CLIENT_CLOSED; + } + + getService()->onClientClosed(this); + mBufferNode.reset(); + mClosed = true; + return BufferHubStatus::NO_ERROR; +} + +Return<void> BufferClient::duplicate(duplicate_cb _hidl_cb) { + std::lock_guard<std::mutex> lock(mClosedMutex); + if (mClosed) { + _hidl_cb(/*token=*/hidl_handle(), /*status=*/BufferHubStatus::CLIENT_CLOSED); + return Void(); + } + + if (!mBufferNode) { + // Should never happen + ALOGE("%s: node is missing.", __FUNCTION__); + _hidl_cb(/*token=*/hidl_handle(), /*status=*/BufferHubStatus::BUFFER_FREED); + return Void(); + } + + const hidl_handle token = getService()->registerToken(this); + _hidl_cb(/*token=*/token, /*status=*/BufferHubStatus::NO_ERROR); + return Void(); +} + +sp<BufferHubService> BufferClient::getService() { + sp<BufferHubService> service = mService.promote(); + if (service == nullptr) { + // Should never happen. Kill the process. + LOG_FATAL("%s: service died.", __FUNCTION__); + } + + return service; +} + +} // namespace implementation +} // namespace V1_0 +} // namespace bufferhub +} // namespace frameworks +} // namespace android
\ No newline at end of file |