[RESEND,v1,11/55] pid: Add equel_pid() helper

Submitted by Kirill Tkhai on March 24, 2017, 3:10 p.m.

Details

Message ID 149036823914.23093.1019831336710602871.stgit@localhost.localdomain
State New
Series "Nested pid namespaces support"
Headers show

Commit Message

Kirill Tkhai March 24, 2017, 3:10 p.m.
This allows to compare pids values on the whole hierarhy.

Signed-off-by: Kirill Tkhai <ktkhai@virtuozzo.com>
---
 criu/include/pid.h |   17 +++++++++++++++++
 1 file changed, 17 insertions(+)

Patch hide | download patch | download mbox

diff --git a/criu/include/pid.h b/criu/include/pid.h
index 475b17a3..478e5d0b 100644
--- a/criu/include/pid.h
+++ b/criu/include/pid.h
@@ -4,6 +4,7 @@ 
 #include <compel/task-state.h>
 #include "stdbool.h"
 #include "rbtree.h"
+#include "log.h"
 
 /*
  * Task states, used in e.g. struct pid's state.
@@ -45,6 +46,22 @@  struct pid {
 	} ns[1]; /* Must be at the end of struct pid */
 };
 
+#define equal_pid(a, b)							\
+({									\
+	int ___i, ___ret = true;					\
+	if (a->level == b->level) {					\
+		for (___i = 0; ___i < a->level; ___i++)			\
+			if (a->ns[___i].virt != b->ns[___i].virt) {	\
+				___ret = false;				\
+				break;					\
+			}						\
+	} else {							\
+		pr_err("Wrong pid nesting level\n");			\
+		___ret = false;						\
+	}								\
+	___ret;								\
+})
+
 /*
  * When we have to restore a shared resource, we mush select which
  * task should do it, and make other(s) wait for it. In order to