summaryrefslogtreecommitdiffstats
path: root/libs/utils
diff options
context:
space:
mode:
authorGlenn Kasten <gkasten@google.com>2011-08-29 14:38:52 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2011-08-29 14:38:52 -0700
commitb4bf90b40e30096479a4d4cc9cf135e991ef1994 (patch)
treec00cccd8405fc51990f0f7cf2f92ace2b394e0ea /libs/utils
parentbce1667e7ae69ff575e73e776040524fb5515c5f (diff)
parent33eafef1a9ef508f7b1ae1edf4caf29b81a80255 (diff)
downloadframeworks_base-b4bf90b40e30096479a4d4cc9cf135e991ef1994.zip
frameworks_base-b4bf90b40e30096479a4d4cc9cf135e991ef1994.tar.gz
frameworks_base-b4bf90b40e30096479a4d4cc9cf135e991ef1994.tar.bz2
Merge "Add C++ thread API androidGetThreadSchedulingGroup"
Diffstat (limited to 'libs/utils')
-rw-r--r--libs/utils/Threads.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/libs/utils/Threads.cpp b/libs/utils/Threads.cpp
index d18c0a2..02c380b 100644
--- a/libs/utils/Threads.cpp
+++ b/libs/utils/Threads.cpp
@@ -368,6 +368,41 @@ int androidSetThreadPriority(pid_t tid, int pri)
return rc;
}
+int androidGetThreadSchedulingGroup(pid_t tid)
+{
+ int ret = ANDROID_TGROUP_DEFAULT;
+
+#if defined(HAVE_PTHREADS)
+ // convention is to not call get/set_sched_policy methods if disabled by property
+ pthread_once(&gDoSchedulingGroupOnce, checkDoSchedulingGroup);
+ if (gDoSchedulingGroup) {
+ SchedPolicy policy;
+ // get_sched_policy does not support tid == 0
+ if (tid == 0) {
+ tid = androidGetTid();
+ }
+ if (get_sched_policy(tid, &policy) < 0) {
+ ret = INVALID_OPERATION;
+ } else {
+ switch (policy) {
+ case SP_BACKGROUND:
+ ret = ANDROID_TGROUP_BG_NONINTERACT;
+ break;
+ case SP_FOREGROUND:
+ ret = ANDROID_TGROUP_FG_BOOST;
+ break;
+ default:
+ // should not happen, as enum SchedPolicy does not have any other values
+ ret = INVALID_OPERATION;
+ break;
+ }
+ }
+ }
+#endif
+
+ return ret;
+}
+
namespace android {
/*