Skip to content
Snippets Groups Projects
Commit 278ee6b9 authored by Wei Wang's avatar Wei Wang Committed by android-build-team Robot
Browse files

libcutils: remove schedgroup fds [DO NOT MERGE]

Change-Id: Ie2c576dca8097668edd4c4e4fe947e862bd0c6d9
parent 1d2adc7f
Branches
No related tags found
No related merge requests found
...@@ -56,10 +56,6 @@ static pthread_once_t the_once = PTHREAD_ONCE_INIT; ...@@ -56,10 +56,6 @@ static pthread_once_t the_once = PTHREAD_ONCE_INIT;
static int __sys_supports_schedgroups = -1; static int __sys_supports_schedgroups = -1;
// File descriptors open to /dev/cpuctl/../tasks, setup by initialize, or -1 on error.
static int bg_cgroup_fd = -1;
static int fg_cgroup_fd = -1;
#ifdef USE_CPUSETS #ifdef USE_CPUSETS
// File descriptors open to /dev/cpuset/../tasks, setup by initialize, or -1 on error // File descriptors open to /dev/cpuset/../tasks, setup by initialize, or -1 on error
static int system_bg_cpuset_fd = -1; static int system_bg_cpuset_fd = -1;
...@@ -73,6 +69,7 @@ static int bg_schedboost_fd = -1; ...@@ -73,6 +69,7 @@ static int bg_schedboost_fd = -1;
static int fg_schedboost_fd = -1; static int fg_schedboost_fd = -1;
static int ta_schedboost_fd = -1; static int ta_schedboost_fd = -1;
#if defined(USE_CPUSETS) || defined(USE_SCHEDBOOST)
/* Add tid to the scheduling group defined by the policy */ /* Add tid to the scheduling group defined by the policy */
static int add_tid_to_cgroup(int tid, int fd) static int add_tid_to_cgroup(int tid, int fd)
{ {
...@@ -107,30 +104,18 @@ static int add_tid_to_cgroup(int tid, int fd) ...@@ -107,30 +104,18 @@ static int add_tid_to_cgroup(int tid, int fd)
return 0; return 0;
} }
#endif //defined(USE_CPUSETS) || defined(USE_SCHEDBOOST)
static void __initialize(void) { static void __initialize(void) {
char* filename;
if (!access("/dev/cpuctl/tasks", F_OK)) { if (!access("/dev/cpuctl/tasks", F_OK)) {
__sys_supports_schedgroups = 1; __sys_supports_schedgroups = 1;
filename = "/dev/cpuctl/tasks";
fg_cgroup_fd = open(filename, O_WRONLY | O_CLOEXEC);
if (fg_cgroup_fd < 0) {
SLOGE("open of %s failed: %s\n", filename, strerror(errno));
}
filename = "/dev/cpuctl/bg_non_interactive/tasks";
bg_cgroup_fd = open(filename, O_WRONLY | O_CLOEXEC);
if (bg_cgroup_fd < 0) {
SLOGE("open of %s failed: %s\n", filename, strerror(errno));
}
} else { } else {
__sys_supports_schedgroups = 0; __sys_supports_schedgroups = 0;
} }
#ifdef USE_CPUSETS #ifdef USE_CPUSETS
if (!access("/dev/cpuset/tasks", F_OK)) { if (!access("/dev/cpuset/tasks", F_OK)) {
char* filename;
filename = "/dev/cpuset/foreground/tasks"; filename = "/dev/cpuset/foreground/tasks";
fg_cpuset_fd = open(filename, O_WRONLY | O_CLOEXEC); fg_cpuset_fd = open(filename, O_WRONLY | O_CLOEXEC);
filename = "/dev/cpuset/background/tasks"; filename = "/dev/cpuset/background/tasks";
...@@ -380,35 +365,24 @@ int set_sched_policy(int tid, SchedPolicy policy) ...@@ -380,35 +365,24 @@ int set_sched_policy(int tid, SchedPolicy policy)
#endif #endif
if (__sys_supports_schedgroups) { if (__sys_supports_schedgroups) {
int fd = -1;
int boost_fd = -1; int boost_fd = -1;
switch (policy) { switch (policy) {
case SP_BACKGROUND: case SP_BACKGROUND:
fd = bg_cgroup_fd;
boost_fd = bg_schedboost_fd; boost_fd = bg_schedboost_fd;
break; break;
case SP_FOREGROUND: case SP_FOREGROUND:
case SP_AUDIO_APP: case SP_AUDIO_APP:
case SP_AUDIO_SYS: case SP_AUDIO_SYS:
fd = fg_cgroup_fd;
boost_fd = fg_schedboost_fd; boost_fd = fg_schedboost_fd;
break; break;
case SP_TOP_APP: case SP_TOP_APP:
fd = fg_cgroup_fd;
boost_fd = ta_schedboost_fd; boost_fd = ta_schedboost_fd;
break; break;
default: default:
fd = -1;
boost_fd = -1; boost_fd = -1;
break; break;
} }
if (fd > 0 && add_tid_to_cgroup(tid, fd) != 0) {
if (errno != ESRCH && errno != ENOENT)
return -errno;
}
#ifdef USE_SCHEDBOOST #ifdef USE_SCHEDBOOST
if (boost_fd > 0 && add_tid_to_cgroup(tid, boost_fd) != 0) { if (boost_fd > 0 && add_tid_to_cgroup(tid, boost_fd) != 0) {
if (errno != ESRCH && errno != ENOENT) if (errno != ESRCH && errno != ENOENT)
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment