summaryrefslogtreecommitdiff
path: root/weaver/aidl/default/service.cpp
diff options
context:
space:
mode:
authorChengYou Ho <chengyouho@google.com>2021-01-02 22:45:32 +0800
committerChengyou Ho <chengyouho@google.com>2021-01-22 06:34:31 +0000
commit10f8a48b6477813f9272df0250a4b5d49a7366f8 (patch)
tree690d11b5c31607478aa179d3e90e056be2822e1e /weaver/aidl/default/service.cpp
parent0bc3543c868fbdb8f8c60667b1b91a8bb0ec395d (diff)
Add weaver aidl interface
Bug: 176107318 Change-Id: I4dd064843e3e630b878ff08f89100e1b4303a02c
Diffstat (limited to 'weaver/aidl/default/service.cpp')
-rw-r--r--weaver/aidl/default/service.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/weaver/aidl/default/service.cpp b/weaver/aidl/default/service.cpp
new file mode 100644
index 0000000000..1495bc9201
--- /dev/null
+++ b/weaver/aidl/default/service.cpp
@@ -0,0 +1,35 @@
+/*
+ * 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 <android-base/logging.h>
+#include <android/binder_manager.h>
+#include <android/binder_process.h>
+
+#include "Weaver.h"
+
+using ::aidl::android::hardware::weaver::Weaver;
+
+int main() {
+ ABinderProcess_setThreadPoolMaxThreadCount(0);
+ std::shared_ptr<Weaver> weaver = ndk::SharedRefBase::make<Weaver>();
+
+ const std::string instance = std::string() + Weaver::descriptor + "/default";
+ binder_status_t status = AServiceManager_addService(weaver->asBinder().get(), instance.c_str());
+ CHECK(status == STATUS_OK);
+
+ ABinderProcess_joinThreadPool();
+ return -1; // Should never be reached
+}