summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTri Vo <trong@google.com>2019-11-12 14:17:45 -0800
committerandroid-build-merger <android-build-merger@google.com>2019-11-12 14:17:45 -0800
commitf2a03b676273c57b01e1ac5bc45fd8ee0f73fdaa (patch)
treeb69eed8da11ccf37c4dd98ef284e8f462ee197d5
parentfc3970790de85a2f703f83bfe39106591d40607d (diff)
parent89e661c090b00a21a7748bc0ab01775b8c87618d (diff)
downloadlibhardware_legacy-f2a03b676273c57b01e1ac5bc45fd8ee0f73fdaa.tar.gz
Merge "block_suspend: test util to block suspend from shell" am: 52e6536018android-r-preview-4android-r-preview-3android-r-preview-2
am: 89e661c090 Change-Id: Ia8108fc5ccf32b957438c3fbc14d87a1015d04ea
-rw-r--r--Android.bp11
-rw-r--r--block_suspend.cpp39
2 files changed, 50 insertions, 0 deletions
diff --git a/Android.bp b/Android.bp
index bc453fe..d196ee6 100644
--- a/Android.bp
+++ b/Android.bp
@@ -74,3 +74,14 @@ cc_library_shared {
"uevent.c",
],
}
+
+cc_test {
+ name: "block_suspend",
+ defaults: ["libpower_defaults"],
+ srcs: ["block_suspend.cpp"],
+ static_libs: ["libpower"],
+ shared_libs: [
+ "android.system.suspend@1.0",
+ ],
+ gtest: false,
+}
diff --git a/block_suspend.cpp b/block_suspend.cpp
new file mode 100644
index 0000000..99341b8
--- /dev/null
+++ b/block_suspend.cpp
@@ -0,0 +1,39 @@
+/*
+ * Copyright 2019 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 <iostream>
+
+#include <wakelock/wakelock.h>
+
+static constexpr const char *gWakeLockName = "block_suspend";
+
+static void usage() {
+ std::cout << "Usage: block_suspend\n"
+ << "Prevent device from suspending indefinitely. "
+ << "Process must be killed to unblock suspend.\n";
+}
+
+int main(int argc, char ** /* argv */) {
+ if (argc > 1) {
+ usage();
+ return 0;
+ }
+
+ android::wakelock::WakeLock wl{gWakeLockName}; // RAII object
+ while (true) {};
+ std::abort(); // should never reach here
+ return 0;
+}