Blame SOURCES/rhbz1643997.0018-tapset-bpf-task.stp-rudiment-of-task-tapset.patch

132810
From ba62b58974fd25f7281fa151411c8e32b3951fbb Mon Sep 17 00:00:00 2001
132810
From: Serhei Makarov <smakarov@redhat.com>
132810
Date: Fri, 2 Nov 2018 12:22:01 -0400
132810
Subject: [PATCH 18/32] tapset/bpf/task.stp :: rudiment of task tapset
132810
132810
---
132810
 tapset/bpf/task.stp                         | 20 ++++++++++++++++++++
132810
 testsuite/systemtap.bpf/bpf_tests/task1.stp | 15 +++++++++++++++
132810
 2 files changed, 35 insertions(+)
132810
 create mode 100644 tapset/bpf/task.stp
132810
 create mode 100644 testsuite/systemtap.bpf/bpf_tests/task1.stp
132810
132810
diff --git a/tapset/bpf/task.stp b/tapset/bpf/task.stp
132810
new file mode 100644
132810
index 000000000..9f558a166
132810
--- /dev/null
132810
+++ b/tapset/bpf/task.stp
132810
@@ -0,0 +1,20 @@
132810
+// task information tapset
132810
+// Copyright (C) 2018 Red Hat Inc.
132810
+//
132810
+// This file is part of systemtap, and is free software.  You can
132810
+// redistribute it and/or modify it under the terms of the GNU General
132810
+// Public License (GPL); either version 2, or (at your option) any
132810
+// later version.
132810
+
132810
+@__private30 function _task_cur:long()
132810
+%{ /* bpf */ /* pure */
132810
+  call, $$, get_current_task;
132810
+%}
132810
+
132810
+/**
132810
+ * sfunction task_current - The current task_struct of the current task
132810
+ */
132810
+function task_current:long () {
132810
+  // TODO: return & @task(_task_cur())
132810
+  return & @cast(_task_cur(), "task_struct")
132810
+}
132810
diff --git a/testsuite/systemtap.bpf/bpf_tests/task1.stp b/testsuite/systemtap.bpf/bpf_tests/task1.stp
132810
new file mode 100644
132810
index 000000000..b0faab361
132810
--- /dev/null
132810
+++ b/testsuite/systemtap.bpf/bpf_tests/task1.stp
132810
@@ -0,0 +1,15 @@
132810
+probe begin {
132810
+	printf("BEGIN\n")
132810
+}
132810
+
132810
+probe kernel.function("vfs_read") {
132810
+	// TODO: PR23816, task.stp tapset
132810
+	printf("vfs_read by %s", execname())
132810
+	printf("/%s", kernel_string(@cast(task_current(), "task_struct")->comm))
132810
+	printf(" PID %d/%d\n", pid(), @cast(task_current(), "task_struct")->tgid)
132810
+	exit()
132810
+}
132810
+
132810
+probe end {
132810
+	printf("END PASS\n")
132810
+}
132810
-- 
132810
2.14.5
132810