Zbigniew Jędrzejewski-Szmek 708deb
From e931d3f4241231e4102eda06adaf7cbfd68c6a5d Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 708deb
From: Thomas Hindoe Paaboel Andersen <phomes@gmail.com>
Zbigniew Jędrzejewski-Szmek 708deb
Date: Sat, 27 Sep 2014 22:25:07 +0200
Zbigniew Jędrzejewski-Szmek 708deb
Subject: [PATCH] bootchart: check return of strftime
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
Found by coverity. Fixes: CID#996314 and #996312
Zbigniew Jędrzejewski-Szmek 708deb
---
Zbigniew Jędrzejewski-Szmek 708deb
 src/bootchart/bootchart.c | 8 ++++++--
Zbigniew Jędrzejewski-Szmek 708deb
 src/bootchart/svg.c       | 5 +++--
Zbigniew Jędrzejewski-Szmek 708deb
 2 files changed, 9 insertions(+), 4 deletions(-)
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/bootchart/bootchart.c b/src/bootchart/bootchart.c
Zbigniew Jędrzejewski-Szmek 708deb
index 8ef5ad18a6..366a5ab5d0 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/bootchart/bootchart.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/bootchart/bootchart.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -389,7 +389,9 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
                 if (!of && (access(arg_output_path, R_OK|W_OK|X_OK) == 0)) {
Zbigniew Jędrzejewski-Szmek 708deb
                         t = time(NULL);
Zbigniew Jędrzejewski-Szmek 708deb
-                        strftime(datestr, sizeof(datestr), "%Y%m%d-%H%M", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+                        r = strftime(datestr, sizeof(datestr), "%Y%m%d-%H%M", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+                        assert_se(r > 0);
Zbigniew Jędrzejewski-Szmek 708deb
+
Zbigniew Jędrzejewski-Szmek 708deb
                         snprintf(output_file, PATH_MAX, "%s/bootchart-%s.svg", arg_output_path, datestr);
Zbigniew Jędrzejewski-Szmek 708deb
                         of = fopen(output_file, "we");
Zbigniew Jędrzejewski-Szmek 708deb
                 }
Zbigniew Jędrzejewski-Szmek 708deb
@@ -457,7 +459,9 @@ int main(int argc, char *argv[]) {
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         if (!of) {
Zbigniew Jędrzejewski-Szmek 708deb
                 t = time(NULL);
Zbigniew Jędrzejewski-Szmek 708deb
-                strftime(datestr, sizeof(datestr), "%Y%m%d-%H%M", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+                r = strftime(datestr, sizeof(datestr), "%Y%m%d-%H%M", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+                assert_se(r > 0);
Zbigniew Jędrzejewski-Szmek 708deb
+
Zbigniew Jędrzejewski-Szmek 708deb
                 snprintf(output_file, PATH_MAX, "%s/bootchart-%s.svg", arg_output_path, datestr);
Zbigniew Jędrzejewski-Szmek 708deb
                 of = fopen(output_file, "we");
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/bootchart/svg.c b/src/bootchart/svg.c
Zbigniew Jędrzejewski-Szmek 708deb
index 135883fb83..faf377e506 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/bootchart/svg.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/bootchart/svg.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -162,7 +162,7 @@ static void svg_title(const char *build) {
Zbigniew Jędrzejewski-Szmek 708deb
         char *c;
Zbigniew Jędrzejewski-Szmek 708deb
         FILE *f;
Zbigniew Jędrzejewski-Szmek 708deb
         time_t t;
Zbigniew Jędrzejewski-Szmek 708deb
-        int fd;
Zbigniew Jędrzejewski-Szmek 708deb
+        int fd, r;
Zbigniew Jędrzejewski-Szmek 708deb
         struct utsname uts;
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         /* grab /proc/cmdline */
Zbigniew Jędrzejewski-Szmek 708deb
@@ -196,7 +196,8 @@ static void svg_title(const char *build) {
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         /* date */
Zbigniew Jędrzejewski-Szmek 708deb
         t = time(NULL);
Zbigniew Jędrzejewski-Szmek 708deb
-        strftime(date, sizeof(date), "%a, %d %b %Y %H:%M:%S %z", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+        r = strftime(date, sizeof(date), "%a, %d %b %Y %H:%M:%S %z", localtime(&t);;
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(r > 0);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         /* CPU type */
Zbigniew Jędrzejewski-Szmek 708deb
         fd = openat(procfd, "cpuinfo", O_RDONLY);