summaryrefslogtreecommitdiff
path: root/memtrack/aidl/default/main.cpp
diff options
context:
space:
mode:
authorKalesh Singh <kaleshsingh@google.com>2020-12-01 11:47:01 -0500
committerKalesh Singh <kaleshsingh@google.com>2020-12-22 20:49:35 +0000
commita851f3d711357de1ae98b6629c225cf0f1996054 (patch)
tree040bb398f98c99ce2a9d00def202b295ce013a58 /memtrack/aidl/default/main.cpp
parent2528ddcab26029f419f70b48af1bc7ae41ac00b1 (diff)
Reland: Memtrack HAL: Add stable AIDL implementation
Bug: 175021432 Test: adb shell dumpsys -l | grep android.hardware.memtrack.IMemtrack Test: VtsHalMemtrackTargetTest Change-Id: I686c0ecc31648dc6e58a6ab5e6ae914454111200
Diffstat (limited to 'memtrack/aidl/default/main.cpp')
-rw-r--r--memtrack/aidl/default/main.cpp36
1 files changed, 36 insertions, 0 deletions
diff --git a/memtrack/aidl/default/main.cpp b/memtrack/aidl/default/main.cpp
new file mode 100644
index 0000000000..d063d2aeda
--- /dev/null
+++ b/memtrack/aidl/default/main.cpp
@@ -0,0 +1,36 @@
+/*
+ * 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.
+ */
+
+#include "Memtrack.h"
+
+#include <android-base/logging.h>
+#include <android/binder_manager.h>
+#include <android/binder_process.h>
+
+using aidl::android::hardware::memtrack::Memtrack;
+
+int main() {
+ ABinderProcess_setThreadPoolMaxThreadCount(0);
+ std::shared_ptr<Memtrack> memtrack = ndk::SharedRefBase::make<Memtrack>();
+
+ const std::string instance = std::string() + Memtrack::descriptor + "/default";
+ binder_status_t status =
+ AServiceManager_addService(memtrack->asBinder().get(), instance.c_str());
+ CHECK(status == STATUS_OK);
+
+ ABinderProcess_joinThreadPool();
+ return EXIT_FAILURE; // Unreachable
+}