[lxc-devel] [lxc/master] lxc: Do not use strcmp to avoid incorrectly outputs that Criu 2.12.1 …

federicobriata on Github lxc-bot at linuxcontainers.org
Mon Sep 4 10:24:40 UTC 2017


A non-text attachment was scrubbed...
Name: not available
Type: text/x-mailbox
Size: 390 bytes
Desc: not available
URL: <http://lists.linuxcontainers.org/pipermail/lxc-devel/attachments/20170904/6bf35adb/attachment.bin>
-------------- next part --------------
From 74adad9060852e0476fc0c4998a090197feb7fdd Mon Sep 17 00:00:00 2001
From: Federico Briata <federico-pietro.briata at cnhind.com>
Date: Mon, 4 Sep 2017 12:16:35 +0200
Subject: [PATCH] lxc: Do not use strcmp to avoid incorrectly outputs that Criu
 2.12.1 is less than 2.8

Signed-off-by: Federico Briata <federico-pietro.briata at cnhind.com>
---
 src/lxc/criu.c | 19 ++++++++++++++++++-
 1 file changed, 18 insertions(+), 1 deletion(-)

diff --git a/src/lxc/criu.c b/src/lxc/criu.c
index 9305b52a0..b1faaddfc 100644
--- a/src/lxc/criu.c
+++ b/src/lxc/criu.c
@@ -126,6 +126,23 @@ static int load_tty_major_minor(char *directory, char *output, int len)
 	return 0;
 }
 
+ // Do not use strcmp to avoid incorrectly outputs that Criu 2.12.1 is less than 2.8
+static int cmpVersion(const char *v1, const char *v2)
+{
+	int i;
+	int oct_v1[3], oct_v2[3];
+	sscanf(v1, "%d.%d.%d", &oct_v1[0], &oct_v1[1], &oct_v1[2]);
+	sscanf(v2, "%d.%d.%d", &oct_v2[0], &oct_v2[1], &oct_v2[2]);
+
+	for (i = 0; i < 3; i++) {
+		if (oct_v1[i] > oct_v2[i])
+			return 1;
+		else if (oct_v1[i] < oct_v2[i])
+			return -1;
+	}
+	return 0;
+}
+
 static void exec_criu(struct criu_opts *opts)
 {
 	char **argv, log[PATH_MAX];
@@ -500,7 +517,7 @@ static void exec_criu(struct criu_opts *opts)
 			struct lxc_netdev *n = it->elem;
 			bool external_not_veth;
 
-			if (strcmp(opts->criu_version, CRIU_EXTERNAL_NOT_VETH) >= 0) {
+			if (cmpVersion(opts->criu_version, CRIU_EXTERNAL_NOT_VETH) >= 0) {
 				/* Since criu version 2.8 the usage of --veth-pair
 				 * has been deprecated:
 				 * git tag --contains f2037e6d3445fc400


More information about the lxc-devel mailing list