diff options
| author | TreeHugger Robot <treehugger-gerrit@google.com> | 2019-07-02 07:41:24 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2019-07-02 07:41:24 +0000 |
| commit | 26f1b51bfbd5e8d2d2e55247a8bae49ccd52872d (patch) | |
| tree | 0d99225e22e2956cf075fcf48527d0e17e872c0f /sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp | |
| parent | 3adfddb29552dbf79387c23e10a9960d1f9c2f79 (diff) | |
| parent | 8b76f6692c718c21272d3585541b72fed7ac93f0 (diff) | |
Merge "DO NOT MERGE - Merge qt-dev-plus-aosp-without-vendor (5699924) into stage-aosp-master" into stage-aosp-master
Diffstat (limited to 'sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp')
| -rw-r--r-- | sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp b/sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp new file mode 100644 index 0000000000..affdf8b6b3 --- /dev/null +++ b/sensors/common/vts/utils/SensorsHidlEnvironmentBase.cpp @@ -0,0 +1,67 @@ +/* + * 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 "SensorsHidlEnvironmentBase.h" + +void SensorsHidlEnvironmentBase::HidlSetUp() { + ASSERT_TRUE(resetHal()) << "could not get hidl service"; + + mCollectionEnabled = false; + startPollingThread(); + + // In case framework just stopped for test and there is sensor events in the pipe, + // wait some time for those events to be cleared to avoid them messing up the test. + std::this_thread::sleep_for(std::chrono::seconds(3)); +} + +void SensorsHidlEnvironmentBase::HidlTearDown() { + mStopThread = true; + mPollThread.detach(); +} + +void SensorsHidlEnvironmentBase::catEvents(std::vector<Event>* output) { + std::lock_guard<std::mutex> lock(mEventsMutex); + if (output) { + output->insert(output->end(), mEvents.begin(), mEvents.end()); + } + mEvents.clear(); +} + +void SensorsHidlEnvironmentBase::setCollection(bool enable) { + std::lock_guard<std::mutex> lock(mEventsMutex); + mCollectionEnabled = enable; +} + +void SensorsHidlEnvironmentBase::addEvent(const Event& ev) { + std::lock_guard<std::mutex> lock(mEventsMutex); + if (mCollectionEnabled) { + mEvents.push_back(ev); + } + + if (mCallback != nullptr) { + mCallback->onEvent(ev); + } +} + +void SensorsHidlEnvironmentBase::registerCallback(IEventCallback* callback) { + std::lock_guard<std::mutex> lock(mEventsMutex); + mCallback = callback; +} + +void SensorsHidlEnvironmentBase::unregisterCallback() { + std::lock_guard<std::mutex> lock(mEventsMutex); + mCallback = nullptr; +}
\ No newline at end of file |
