Zbigniew Jędrzejewski-Szmek 708deb
From b1d6dcf5a5c5aa02843c026dede0638f77798cb4 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 708deb
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek 708deb
Date: Mon, 29 Sep 2014 07:31:14 -0500
Zbigniew Jędrzejewski-Szmek 708deb
Subject: [PATCH] Do not format USEC_INFINITY as NULL
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
systemctl would print 'CPUQuotaPerSecUSec=(null)' for no limit. This
Zbigniew Jędrzejewski-Szmek 708deb
does not look right.
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
Since USEC_INFINITY is one of the valid values, format_timespan()
Zbigniew Jędrzejewski-Szmek 708deb
could return NULL, and we should wrap every use of it in strna() or
Zbigniew Jędrzejewski-Szmek 708deb
similar. But most callers didn't do that, and it seems more robust to
Zbigniew Jędrzejewski-Szmek 708deb
return a string ("infinity") that makes sense most of the time, even
Zbigniew Jędrzejewski-Szmek 708deb
if in some places the result will not be grammatically correct.
Zbigniew Jędrzejewski-Szmek 708deb
---
Zbigniew Jędrzejewski-Szmek 708deb
 src/core/cgroup.c           |  2 +-
Zbigniew Jędrzejewski-Szmek 708deb
 src/core/timer.c            |  2 +-
Zbigniew Jędrzejewski-Szmek 708deb
 src/network/networkd-link.c | 12 ++++--------
Zbigniew Jędrzejewski-Szmek 708deb
 src/shared/time-util.c      | 21 +++++++++++++++------
Zbigniew Jędrzejewski-Szmek 708deb
 src/test/test-time.c        |  7 +++++++
Zbigniew Jędrzejewski-Szmek 708deb
 5 files changed, 28 insertions(+), 16 deletions(-)
Zbigniew Jędrzejewski-Szmek 708deb
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/core/cgroup.c b/src/core/cgroup.c
Zbigniew Jędrzejewski-Szmek 708deb
index 6c6e4f5e7b..e604c3cbc6 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/core/cgroup.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/core/cgroup.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -111,7 +111,7 @@ void cgroup_context_dump(CGroupContext *c, FILE* f, const char *prefix) {
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, yes_no(c->memory_accounting),
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, c->cpu_shares,
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, c->startup_cpu_shares,
Zbigniew Jędrzejewski-Szmek 708deb
-                prefix, strna(format_timespan(u, sizeof(u), c->cpu_quota_per_sec_usec, 1)),
Zbigniew Jędrzejewski-Szmek 708deb
+                prefix, format_timespan(u, sizeof(u), c->cpu_quota_per_sec_usec, 1),
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, c->blockio_weight,
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, c->startup_blockio_weight,
Zbigniew Jędrzejewski-Szmek 708deb
                 prefix, c->memory_limit,
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/core/timer.c b/src/core/timer.c
Zbigniew Jędrzejewski-Szmek 708deb
index dc0f289c7a..a3713e2140 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/core/timer.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/core/timer.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -242,7 +242,7 @@ static void timer_dump(Unit *u, FILE *f, const char *prefix) {
Zbigniew Jędrzejewski-Szmek 708deb
                                 "%s%s: %s\n",
Zbigniew Jędrzejewski-Szmek 708deb
                                 prefix,
Zbigniew Jędrzejewski-Szmek 708deb
                                 timer_base_to_string(v->base),
Zbigniew Jędrzejewski-Szmek 708deb
-                                strna(format_timespan(timespan1, sizeof(timespan1), v->value, 0)));
Zbigniew Jędrzejewski-Szmek 708deb
+                                format_timespan(timespan1, sizeof(timespan1), v->value, 0));
Zbigniew Jędrzejewski-Szmek 708deb
                 }
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
 }
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/network/networkd-link.c b/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 708deb
index 427f6953c5..dcbe38a90a 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/network/networkd-link.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -1475,12 +1475,10 @@ int link_rtnl_process_address(sd_rtnl *rtnl, sd_rtnl_message *message,
Zbigniew Jędrzejewski-Szmek 708deb
         case RTM_NEWADDR:
Zbigniew Jędrzejewski-Szmek 708deb
                 if (!address_dropped)
Zbigniew Jędrzejewski-Szmek 708deb
                         log_debug_link(link, "added address: %s/%u (valid for %s)",
Zbigniew Jędrzejewski-Szmek 708deb
-                                       buf, address->prefixlen,
Zbigniew Jędrzejewski-Szmek 708deb
-                                       strna(valid_str));
Zbigniew Jędrzejewski-Szmek 708deb
+                                       buf, address->prefixlen, valid_str);
Zbigniew Jędrzejewski-Szmek 708deb
                 else
Zbigniew Jędrzejewski-Szmek 708deb
                         log_debug_link(link, "updated address: %s/%u (valid for %s)",
Zbigniew Jędrzejewski-Szmek 708deb
-                                       buf, address->prefixlen,
Zbigniew Jędrzejewski-Szmek 708deb
-                                       strna(valid_str));
Zbigniew Jędrzejewski-Szmek 708deb
+                                       buf, address->prefixlen, valid_str);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
                 LIST_PREPEND(addresses, link->addresses, address);
Zbigniew Jędrzejewski-Szmek 708deb
                 address = NULL;
Zbigniew Jędrzejewski-Szmek 708deb
@@ -1491,15 +1489,13 @@ int link_rtnl_process_address(sd_rtnl *rtnl, sd_rtnl_message *message,
Zbigniew Jędrzejewski-Szmek 708deb
         case RTM_DELADDR:
Zbigniew Jędrzejewski-Szmek 708deb
                 if (address_dropped) {
Zbigniew Jędrzejewski-Szmek 708deb
                         log_debug_link(link, "removed address: %s/%u (valid for %s)",
Zbigniew Jędrzejewski-Szmek 708deb
-                                       buf, address->prefixlen,
Zbigniew Jędrzejewski-Szmek 708deb
-                                       strna(valid_str));
Zbigniew Jędrzejewski-Szmek 708deb
+                                       buf, address->prefixlen, valid_str);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
                         link_save(link);
Zbigniew Jędrzejewski-Szmek 708deb
                 } else
Zbigniew Jędrzejewski-Szmek 708deb
                         log_warning_link(link,
Zbigniew Jędrzejewski-Szmek 708deb
                                          "removing non-existent address: %s/%u (valid for %s)",
Zbigniew Jędrzejewski-Szmek 708deb
-                                         buf, address->prefixlen,
Zbigniew Jędrzejewski-Szmek 708deb
-                                         strna(valid_str));
Zbigniew Jędrzejewski-Szmek 708deb
+                                         buf, address->prefixlen, valid_str);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
                 break;
Zbigniew Jędrzejewski-Szmek 708deb
         default:
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/shared/time-util.c b/src/shared/time-util.c
Zbigniew Jędrzejewski-Szmek 708deb
index 2dc01e6ed3..066ef973ac 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/shared/time-util.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/shared/time-util.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -279,11 +279,8 @@ char *format_timespan(char *buf, size_t l, usec_t t, usec_t accuracy) {
Zbigniew Jędrzejewski-Szmek 708deb
         assert(buf);
Zbigniew Jędrzejewski-Szmek 708deb
         assert(l > 0);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
-        if (t == USEC_INFINITY)
Zbigniew Jędrzejewski-Szmek 708deb
-                return NULL;
Zbigniew Jędrzejewski-Szmek 708deb
-
Zbigniew Jędrzejewski-Szmek 708deb
-        if (t <= 0) {
Zbigniew Jędrzejewski-Szmek 708deb
-                snprintf(p, l, "0");
Zbigniew Jędrzejewski-Szmek 708deb
+        if (t == USEC_INFINITY || t <= 0) {
Zbigniew Jędrzejewski-Szmek 708deb
+                strncpy(p, t == USEC_INFINITY ? "infinity" : "0", l);
Zbigniew Jędrzejewski-Szmek 708deb
                 p[l-1] = 0;
Zbigniew Jędrzejewski-Szmek 708deb
                 return p;
Zbigniew Jędrzejewski-Szmek 708deb
         }
Zbigniew Jędrzejewski-Szmek 708deb
@@ -628,7 +625,7 @@ int parse_sec(const char *t, usec_t *usec) {
Zbigniew Jędrzejewski-Szmek 708deb
                 { "", USEC_PER_SEC }, /* default is sec */
Zbigniew Jędrzejewski-Szmek 708deb
         };
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
-        const char *p;
Zbigniew Jędrzejewski-Szmek 708deb
+        const char *p, *s;
Zbigniew Jędrzejewski-Szmek 708deb
         usec_t r = 0;
Zbigniew Jędrzejewski-Szmek 708deb
         bool something = false;
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
@@ -636,6 +633,18 @@ int parse_sec(const char *t, usec_t *usec) {
Zbigniew Jędrzejewski-Szmek 708deb
         assert(usec);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         p = t;
Zbigniew Jędrzejewski-Szmek 708deb
+
Zbigniew Jędrzejewski-Szmek 708deb
+        p += strspn(p, WHITESPACE);
Zbigniew Jędrzejewski-Szmek 708deb
+        s = startswith(p, "infinity");
Zbigniew Jędrzejewski-Szmek 708deb
+        if (s) {
Zbigniew Jędrzejewski-Szmek 708deb
+                s += strspn(s, WHITESPACE);
Zbigniew Jędrzejewski-Szmek 708deb
+                if (*s != 0)
Zbigniew Jędrzejewski-Szmek 708deb
+                        return -EINVAL;
Zbigniew Jędrzejewski-Szmek 708deb
+
Zbigniew Jędrzejewski-Szmek 708deb
+                *usec = USEC_INFINITY;
Zbigniew Jędrzejewski-Szmek 708deb
+                return 0;
Zbigniew Jędrzejewski-Szmek 708deb
+        }
Zbigniew Jędrzejewski-Szmek 708deb
+
Zbigniew Jędrzejewski-Szmek 708deb
         for (;;) {
Zbigniew Jędrzejewski-Szmek 708deb
                 long long l, z = 0;
Zbigniew Jędrzejewski-Szmek 708deb
                 char *e;
Zbigniew Jędrzejewski-Szmek 708deb
diff --git a/src/test/test-time.c b/src/test/test-time.c
Zbigniew Jędrzejewski-Szmek 708deb
index 87e7ae742a..8cfc4cc4fe 100644
Zbigniew Jędrzejewski-Szmek 708deb
--- a/src/test/test-time.c
Zbigniew Jędrzejewski-Szmek 708deb
+++ b/src/test/test-time.c
Zbigniew Jędrzejewski-Szmek 708deb
@@ -43,12 +43,18 @@ static void test_parse_sec(void) {
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(u == 2500 * USEC_PER_MSEC);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec(".7", &u) >= 0);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(u == 700 * USEC_PER_MSEC);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(parse_sec("infinity", &u) >= 0);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(u == USEC_INFINITY);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(parse_sec(" infinity ", &u) >= 0);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(u == USEC_INFINITY);
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec(" xyz ", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec("", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec(" . ", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec(" 5. ", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
         assert_se(parse_sec(".s ", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(parse_sec(" infinity .7", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
+        assert_se(parse_sec(".3 infinity", &u) < 0);
Zbigniew Jędrzejewski-Szmek 708deb
 }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
 static void test_parse_nsec(void) {
Zbigniew Jędrzejewski-Szmek 708deb
@@ -125,6 +131,7 @@ static void test_format_timespan(usec_t accuracy) {
Zbigniew Jędrzejewski-Szmek 708deb
         test_format_timespan_one(986087, accuracy);
Zbigniew Jędrzejewski-Szmek 708deb
         test_format_timespan_one(500 * USEC_PER_MSEC, accuracy);
Zbigniew Jędrzejewski-Szmek 708deb
         test_format_timespan_one(9*USEC_PER_YEAR/5 - 23, accuracy);
Zbigniew Jędrzejewski-Szmek 708deb
+        test_format_timespan_one(USEC_INFINITY, accuracy);
Zbigniew Jędrzejewski-Szmek 708deb
 }
Zbigniew Jędrzejewski-Szmek 708deb
 
Zbigniew Jędrzejewski-Szmek 708deb
 static void test_timezone_is_valid(void) {