aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKalesh Singh <kaleshsingh@google.com>2022-11-23 00:35:11 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2022-11-23 00:35:11 +0000
commit494481b06a02c3999b85e93b10d3e8ef214d0b10 (patch)
tree0826fe92a08684f6246d6a7a0986f249d1a43e1a
parent77e2f6cbbf4d8ef20b3d94568a643df824a0a5d5 (diff)
parent61488b893922a3b349d8ea98e7b7f9287a8640f5 (diff)
downloadtrace-cmd-494481b06a02c3999b85e93b10d3e8ef214d0b10.tar.gz
ANDROID: libtracecmd: Add pthread_set/get_affinity_np() am: 61488b8939
Original change: https://android-review.googlesource.com/c/platform/external/trace-cmd/+/2084180 Change-Id: Id1ecd9a1a8af74088941afeccf9b3bebc28a20f1 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
-rw-r--r--lib/trace-cmd/trace-timesync.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/lib/trace-cmd/trace-timesync.c b/lib/trace-cmd/trace-timesync.c
index cc44af38..bbefda20 100644
--- a/lib/trace-cmd/trace-timesync.c
+++ b/lib/trace-cmd/trace-timesync.c
@@ -41,6 +41,28 @@ struct tsync_probe_request_msg {
unsigned short cpu;
} __packed;
+#ifdef __ANDROID__
+#define __NR_sched_setaffinity 122
+#define __NR_sched_getaffinity 123
+
+static int pthread_setaffinity_np(pthread_t thread, size_t cpusetsize, const cpu_set_t *cpuset)
+{
+ return -syscall(__NR_sched_setaffinity, thread, cpusetsize, cpuset);
+}
+
+static int pthread_getaffinity_np(pthread_t thread, size_t cpusetsize, const cpu_set_t *cpuset)
+{
+ long ret = syscall(__NR_sched_getaffinity, thread, cpusetsize, cpuset);
+
+ if (ret < 0)
+ return ret;
+ if (ret < cpusetsize)
+ memset((char *)cpuset+ret, 0, cpusetsize-ret);
+
+ return 0;
+}
+#endif /* __ANDROID__ */
+
static struct tsync_proto *tsync_proto_list;
static struct tsync_proto *tsync_proto_find(const char *proto_name)