[CRIU] [PATCH v8 01/10] parse: add a helper to obtain an uptime

Pavel Tikhomirov ptikhomirov at virtuozzo.com
Thu Feb 22 14:49:19 MSK 2018


will be used in the next patch

https://jira.sw.ru/browse/PSBM-67502

note: man for /proc/uptime says that uptime is in seconds and for now
the format is "seconds.centiseconds", where ecentiseconds is 2 digits

v8: add length specifier to parse only centiseconds

Signed-off-by: Pavel Tikhomirov <ptikhomirov at virtuozzo.com>
---
 criu/include/proc_parse.h |  1 +
 criu/proc_parse.c         | 24 ++++++++++++++++++++++++
 2 files changed, 25 insertions(+)

diff --git a/criu/include/proc_parse.h b/criu/include/proc_parse.h
index 0f5e91056..c68566130 100644
--- a/criu/include/proc_parse.h
+++ b/criu/include/proc_parse.h
@@ -108,5 +108,6 @@ int parse_children(pid_t pid, pid_t **_c, int *_n);
 
 extern bool is_vma_range_fmt(char *line);
 extern void parse_vmflags(char *buf, u32 *flags, u64 *madv, int *io_pf);
+extern int parse_uptime(struct timeval *_tv);
 
 #endif /* __CR_PROC_PARSE_H__ */
diff --git a/criu/proc_parse.c b/criu/proc_parse.c
index 4ab11a31a..5aabed1eb 100644
--- a/criu/proc_parse.c
+++ b/criu/proc_parse.c
@@ -2712,3 +2712,27 @@ int parse_children(pid_t pid, pid_t **_c, int *_n)
 	xfree(ch);
 	return -1;
 }
+
+__maybe_unused int parse_uptime(struct timeval *_tv)
+{
+	unsigned long sec, csec;
+	FILE *f;
+
+	f = fopen("/proc/uptime", "r");
+	if (!f) {
+		pr_perror("Failed to fopen /proc/uptime");
+		return -1;
+	}
+
+	if (fscanf(f, "%lu.%2lu", &sec, &csec) != 2) {
+		pr_perror("Failed to parse /proc/uptime");
+		fclose(f);
+		return -1;
+	}
+
+	_tv->tv_sec = sec;
+	_tv->tv_usec = csec * (USEC_PER_SEC / 100);
+
+	fclose(f);
+	return 0;
+}
-- 
2.14.3



More information about the CRIU mailing list