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