summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Treehugger Robot <treehugger-gerrit@google.com> 2019-08-06 01:42:19 +0000
committer Gerrit Code Review <noreply-gerritcodereview@google.com> 2019-08-06 01:42:19 +0000
commit008181ebab2d77afc461b1026b82bc4a166c3b5d (patch)
tree2868de1975f2b1bcfad0f4483e641f0f9b6c6ade
parent7a129feb164e5bdf912032ba8dc452bac88eaa6d (diff)
parent64ae917b3380a9121f9057eb6847802331ffa057 (diff)
Merge "libbinder: add way to debug print stability"
-rw-r--r--libs/binder/Stability.cpp4
-rw-r--r--libs/binder/include/binder/Stability.h3
2 files changed, 7 insertions, 0 deletions
diff --git a/libs/binder/Stability.cpp b/libs/binder/Stability.cpp
index 0bcce5bf94..0a10a1d354 100644
--- a/libs/binder/Stability.cpp
+++ b/libs/binder/Stability.cpp
@@ -28,6 +28,10 @@ void Stability::markVintf(IBinder* binder) {
LOG_ALWAYS_FATAL_IF(result != OK, "Should only mark known object.");
}
+void Stability::debugLogStability(const std::string& tag, const sp<IBinder>& binder) {
+ ALOGE("%s: stability is %s", tag.c_str(), stabilityString(get(binder.get())).c_str());
+}
+
void Stability::tryMarkCompilationUnit(IBinder* binder) {
(void) set(binder, kLocalStability, false /*log*/);
}
diff --git a/libs/binder/include/binder/Stability.h b/libs/binder/include/binder/Stability.h
index 148def60d3..9d98c7f911 100644
--- a/libs/binder/include/binder/Stability.h
+++ b/libs/binder/include/binder/Stability.h
@@ -40,6 +40,9 @@ public:
// expressed here is guaranteed to be stable for multiple years (Stable AIDL)
static void markVintf(IBinder* binder);
+ // WARNING: for debugging only
+ static void debugLogStability(const std::string& tag, const sp<IBinder>& binder);
+
private:
// Parcel needs to store stability level since this is more efficient than storing and looking
// up the efficiency level of a binder object. So, we expose the underlying type.