summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorwenchangliu <wenchangliu@google.com>2020-11-18 17:08:45 +0800
committerwenchangliu <wenchangliu@google.com>2020-12-08 17:58:34 +0800
commit7fd4376324d166ad7de4a2ee2f0e27d8c140cbcd (patch)
tree1cd7b2f35f16dad376f27ca4b17486b2bf7676e5
parent517801bbe8945e56edd1dcc86089b2b3e14b0610 (diff)
downloadav-7fd4376324d166ad7de4a2ee2f0e27d8c140cbcd.tar.gz
ECOService: Implement Stats Provider
Bug: 158313935 Test: atest VideoEncoderTest#testH264Surf720p30fps4Mbps Change-Id: Icd2ae595320fee436deb91c79290593b17ba2e49
-rw-r--r--media/eco/Android.bp2
-rw-r--r--media/eco/ECOServiceStatsProvider.cpp130
-rw-r--r--media/eco/include/eco/ECOServiceStatsProvider.h28
3 files changed, 153 insertions, 7 deletions
diff --git a/media/eco/Android.bp b/media/eco/Android.bp
index 0475861..60727c5 100644
--- a/media/eco/Android.bp
+++ b/media/eco/Android.bp
@@ -20,6 +20,7 @@ cc_library_shared {
"ECOService.cpp",
"ECOSession.cpp",
"ECOUtils.cpp",
+ "ECOServiceStatsProvider.cpp",
],
aidl: {
@@ -44,6 +45,7 @@ cc_library_shared {
"libcutils",
"liblog",
"libutils",
+ "libcodec2_hidl@1.0",
],
export_include_dirs: [
diff --git a/media/eco/ECOServiceStatsProvider.cpp b/media/eco/ECOServiceStatsProvider.cpp
new file mode 100644
index 0000000..8ca7ef0
--- /dev/null
+++ b/media/eco/ECOServiceStatsProvider.cpp
@@ -0,0 +1,130 @@
+/*
+ * Copyright (C) 2020 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.
+ */
+
+//#define LOG_NDEBUG 0
+#define LOG_TAG "ECOServiceStatsProvider"
+#include <eco/ECOServiceStatsProvider.h>
+
+namespace android {
+namespace media {
+namespace eco {
+
+ECOServiceStatsProvider::ECOServiceStatsProvider(
+ int32_t width, int32_t height, bool isCameraRecording,
+ android::sp<IECOSession>& session, const char* name)
+ : BnECOServiceStatsProvider(),
+ mWidth(width),
+ mHeight(height),
+ mIsCameraRecording(isCameraRecording),
+ mECOSession(session),
+ mProviderName(name) {
+ ALOGD("%s, construct with w: %d, h: %d, isCameraRecording: %d, ProviderName:%s",
+ __func__, width, height, isCameraRecording, name);
+}
+
+Status ECOServiceStatsProvider::getType(int32_t* _aidl_return) {
+ *_aidl_return = STATS_PROVIDER_TYPE_VIDEO_ENCODER;
+ return Status::ok();
+}
+
+Status ECOServiceStatsProvider::getName(::android::String16* _aidl_return) {
+ *_aidl_return = String16(mProviderName);
+ return Status::ok();
+}
+
+Status ECOServiceStatsProvider::getECOSession(android::sp<::android::IBinder>* _aidl_return) {
+ *_aidl_return = IInterface::asBinder(mECOSession);
+ return Status::ok();
+}
+
+Status ECOServiceStatsProvider::isCameraRecording(bool* _aidl_return) {
+ *_aidl_return = mIsCameraRecording;
+ return Status::ok();
+}
+
+void ECOServiceStatsProvider::binderDied(const wp<IBinder>& /* who */) {}
+
+bool ECOServiceStatsProvider::updateStats(const ECOData& data) {
+ bool ret = false;
+ if (mECOSession) {
+ Status status = mECOSession->pushNewStats(data, &ret);
+ return ret;
+ }
+ return ret;
+}
+
+bool ECOServiceStatsProvider::addProvider() {
+ bool ret = false;
+ if (mECOSession) {
+ ECOData providerConfig(ECOData::DATA_TYPE_STATS_PROVIDER_CONFIG, systemTime() / 1000);
+ mECOSession->addStatsProvider(this, providerConfig, &ret);
+ return ret;
+ }
+ return ret;
+}
+
+bool ECOServiceStatsProvider::removeProvider() {
+ bool ret = false;
+ if (mECOSession) {
+ mECOSession->removeStatsProvider(this, &ret);
+ return ret;
+ }
+ return ret;
+}
+
+android::sp<ECOServiceStatsProvider> ECOServiceStatsProvider::create(
+ int32_t width, int32_t height, bool isCameraRecording, const char* name) {
+
+ android::sp<android::IServiceManager> sm = android::defaultServiceManager();
+ android::sp<android::IBinder> binder = sm->getService(String16("media.ecoservice"));
+
+ if (binder == nullptr) {
+ ALOGE("Failed to connect to ecoservice");
+ return nullptr;
+ }
+
+ android::sp<IECOService> service = android::interface_cast<IECOService>(binder);
+ ALOGI("Connected to ecoservice");
+
+ // Obtain the ECOSession and add the listener to the service.
+ android::sp<IECOSession> session = nullptr;
+
+ service->obtainSession(width, height, isCameraRecording, &session);
+
+ if (session == nullptr) {
+ ALOGE("Failed to obtain an ECO session");
+ return nullptr;
+ }
+ ALOGI("Obtained an ECO session");
+
+ return new ECOServiceStatsProvider(width, height, isCameraRecording, session, name);
+}
+
+float ECOServiceStatsProvider::getFramerate(int64_t currTimestamp) {
+ float framerate;
+ int64_t timeInterval = currTimestamp - mLastFrameTimestamp;
+ if (timeInterval == 0) {
+ framerate = 0.0;
+ } else {
+ framerate = 1E6 / (currTimestamp - mLastFrameTimestamp);
+ }
+ mLastFrameTimestamp = currTimestamp;
+ return framerate;
+}
+
+} // namespace eco
+} // namespace media
+} // namespace android
diff --git a/media/eco/include/eco/ECOServiceStatsProvider.h b/media/eco/include/eco/ECOServiceStatsProvider.h
index a6e1586..ed0ca7d 100644
--- a/media/eco/include/eco/ECOServiceStatsProvider.h
+++ b/media/eco/include/eco/ECOServiceStatsProvider.h
@@ -19,6 +19,7 @@
#include <android/media/eco/BnECOServiceStatsProvider.h>
#include <android/media/eco/IECOSession.h>
+#include <android/media/eco/IECOService.h>
#include <binder/BinderService.h>
#include <condition_variable>
@@ -27,6 +28,7 @@
#include <thread>
#include "ECOData.h"
+#include "ECOServiceConstants.h"
namespace android {
namespace media {
@@ -43,20 +45,32 @@ class ECOServiceStatsProvider : public BinderService<IECOServiceStatsProvider>,
friend class BinderService<IECOServiceStatsProvider>;
public:
- // Create a ECOServiceStatsProvider with specifed width, height and isCameraRecording.
- ECOServiceStatsProvider(int32_t width, int32_t height, bool isCameraRecording);
-
virtual ~ECOServiceStatsProvider() {}
- virtual Status getType(int32_t* _aidl_return) = 0;
- virtual Status getName(::android::String16* _aidl_return) = 0;
- virtual Status getECOSession(::android::sp<::android::IBinder>* _aidl_return) = 0;
- virtual Status isCameraRecording(bool* _aidl_return) = 0;
+ virtual Status getType(int32_t* _aidl_return);
+ virtual Status getName(::android::String16* _aidl_return);
+ virtual Status getECOSession(::android::sp<::android::IBinder>* _aidl_return);
+ virtual Status isCameraRecording(bool* _aidl_return);
// IBinder::DeathRecipient implementation
virtual void binderDied(const wp<IBinder>& who);
+ bool updateStats(const ECOData& data);
+ bool addProvider();
+ bool removeProvider();
+ float getFramerate(int64_t currTimestamp);
+ static android::sp<ECOServiceStatsProvider> create(
+ int32_t width, int32_t height, bool isCameraRecording, const char* name);
+
private:
+ ECOServiceStatsProvider(int32_t width, int32_t height, bool isCameraRecording,
+ android::sp<IECOSession>& session, const char* name);
+ int32_t mWidth = 0;
+ int32_t mHeight = 0;
+ bool mIsCameraRecording = false;
+ android::sp<IECOSession> mECOSession = nullptr;
+ const char* mProviderName = nullptr;
+ int64_t mLastFrameTimestamp = 0;
};
} // namespace eco