]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
parse-util: prefix load average macros with LOAD_AVG_
authorLuca Boccassi <luca.boccassi@microsoft.com>
Mon, 27 Sep 2021 13:49:47 +0000 (14:49 +0100)
committerLennart Poettering <lennart@poettering.net>
Mon, 27 Sep 2021 18:34:41 +0000 (20:34 +0200)
Follow-up for #20839

src/basic/parse-util.c
src/basic/parse-util.h
src/oom/oomd-manager.c
src/oom/oomd-util.c
src/test/test-parse-util.c
src/test/test-psi-util.c

index 352de039b904555069d4addd581a920472f50462..27b1b84affeebb132ee22fa174f8405dfac48bf6 100644 (file)
@@ -740,13 +740,13 @@ int parse_oom_score_adjust(const char *s, int *ret) {
 int store_loadavg_fixed_point(unsigned long i, unsigned long f, loadavg_t *ret) {
         assert(ret);
 
-        if (i >= (~0UL << PRECISION_BITS))
+        if (i >= (~0UL << LOADAVG_PRECISION_BITS))
                 return -ERANGE;
 
-        i = i << PRECISION_BITS;
-        f = DIV_ROUND_UP((f << PRECISION_BITS), 100);
+        i = i << LOADAVG_PRECISION_BITS;
+        f = DIV_ROUND_UP((f << LOADAVG_PRECISION_BITS), 100);
 
-        if (f >= FIXED_POINT_1_0)
+        if (f >= LOADAVG_FIXED_POINT_1_0)
                 return -ERANGE;
 
         *ret = i | f;
index e437e0de964a3bbeaad72d2d5c6a7d736649fef3..3dc5e140c9a0406e9fe03c9e456ff626b60bfd52 100644 (file)
@@ -138,10 +138,10 @@ int parse_oom_score_adjust(const char *s, int *ret);
 /* Implement floating point using fixed integers, to improve performance when
  * calculating load averages. These macros can be used to extract the integer
  * and decimal parts of a value. */
-#define PRECISION_BITS  11
-#define FIXED_POINT_1_0 (1 << PRECISION_BITS)
-#define INT_SIDE(x)     ((x) >> PRECISION_BITS)
-#define DECIMAL_SIDE(x) INT_SIDE(((x) & (FIXED_POINT_1_0 - 1)) * 100)
+#define LOADAVG_PRECISION_BITS  11
+#define LOADAVG_FIXED_POINT_1_0 (1 << LOADAVG_PRECISION_BITS)
+#define LOADAVG_INT_SIDE(x)     ((x) >> LOADAVG_PRECISION_BITS)
+#define LOADAVG_DECIMAL_SIDE(x) LOADAVG_INT_SIDE(((x) & (LOADAVG_FIXED_POINT_1_0 - 1)) * 100)
 
 /* Given a Linux load average (e.g. decimal number 34.89 where 34 is passed as i and 89 is passed as f), convert it
  * to a loadavg_t. */
index 1dc83a505c7950c9ba72ecf171d1d40b3dcabb8b..b0d365e46b25220bb18c02d97bf0d2583f67bf85 100644 (file)
@@ -502,8 +502,8 @@ static int monitor_memory_pressure_contexts_handler(sd_event_source *s, uint64_t
 
                         log_debug("Memory pressure for %s is %lu.%02lu%% > %lu.%02lu%% for > %s with reclaim activity",
                                   t->path,
-                                  INT_SIDE(t->memory_pressure.avg10), DECIMAL_SIDE(t->memory_pressure.avg10),
-                                  INT_SIDE(t->mem_pressure_limit), DECIMAL_SIDE(t->mem_pressure_limit),
+                                  LOADAVG_INT_SIDE(t->memory_pressure.avg10), LOADAVG_DECIMAL_SIDE(t->memory_pressure.avg10),
+                                  LOADAVG_INT_SIDE(t->mem_pressure_limit), LOADAVG_DECIMAL_SIDE(t->mem_pressure_limit),
                                   FORMAT_TIMESPAN(m->default_mem_pressure_duration_usec, USEC_PER_SEC));
 
                         r = update_monitored_cgroup_contexts_candidates(
@@ -527,8 +527,8 @@ static int monitor_memory_pressure_contexts_handler(sd_event_source *s, uint64_t
                                         log_notice("Killed %s due to memory pressure for %s being %lu.%02lu%% > %lu.%02lu%%"
                                                    " for > %s with reclaim activity",
                                                    selected, t->path,
-                                                   INT_SIDE(t->memory_pressure.avg10), DECIMAL_SIDE(t->memory_pressure.avg10),
-                                                   INT_SIDE(t->mem_pressure_limit), DECIMAL_SIDE(t->mem_pressure_limit),
+                                                   LOADAVG_INT_SIDE(t->memory_pressure.avg10), LOADAVG_DECIMAL_SIDE(t->memory_pressure.avg10),
+                                                   LOADAVG_INT_SIDE(t->mem_pressure_limit), LOADAVG_DECIMAL_SIDE(t->mem_pressure_limit),
                                                    FORMAT_TIMESPAN(m->default_mem_pressure_duration_usec, USEC_PER_SEC));
                                 return 0;
                         }
@@ -811,7 +811,7 @@ int manager_get_dump_string(Manager *m, char **ret) {
                 "System Context:\n",
                 yes_no(m->dry_run),
                 PERMYRIAD_AS_PERCENT_FORMAT_VAL(m->swap_used_limit_permyriad),
-                INT_SIDE(m->default_mem_pressure_limit), DECIMAL_SIDE(m->default_mem_pressure_limit),
+                LOADAVG_INT_SIDE(m->default_mem_pressure_limit), LOADAVG_DECIMAL_SIDE(m->default_mem_pressure_limit),
                 FORMAT_TIMESPAN(m->default_mem_pressure_duration_usec, USEC_PER_SEC));
         oomd_dump_system_context(&m->system_context, f, "\t");
 
index a92bc5fdf6f5ca903cfd526d14eb3f139f512f9e..64ea8cf7e43201c2203273ac321459b39c4774c4 100644 (file)
@@ -530,11 +530,11 @@ void oomd_dump_memory_pressure_cgroup_context(const OomdCGroupContext *ctx, FILE
                 "%s\tPressure: Avg10: %lu.%02lu Avg60: %lu.%02lu Avg300: %lu.%02lu Total: %s\n"
                 "%s\tCurrent Memory Usage: %s\n",
                 strempty(prefix), ctx->path,
-                strempty(prefix), INT_SIDE(ctx->mem_pressure_limit), DECIMAL_SIDE(ctx->mem_pressure_limit),
+                strempty(prefix), LOADAVG_INT_SIDE(ctx->mem_pressure_limit), LOADAVG_DECIMAL_SIDE(ctx->mem_pressure_limit),
                 strempty(prefix),
-                INT_SIDE(ctx->memory_pressure.avg10), DECIMAL_SIDE(ctx->memory_pressure.avg10),
-                INT_SIDE(ctx->memory_pressure.avg60), DECIMAL_SIDE(ctx->memory_pressure.avg60),
-                INT_SIDE(ctx->memory_pressure.avg300), DECIMAL_SIDE(ctx->memory_pressure.avg300),
+                LOADAVG_INT_SIDE(ctx->memory_pressure.avg10), LOADAVG_DECIMAL_SIDE(ctx->memory_pressure.avg10),
+                LOADAVG_INT_SIDE(ctx->memory_pressure.avg60), LOADAVG_DECIMAL_SIDE(ctx->memory_pressure.avg60),
+                LOADAVG_INT_SIDE(ctx->memory_pressure.avg300), LOADAVG_DECIMAL_SIDE(ctx->memory_pressure.avg300),
                 FORMAT_TIMESPAN(ctx->memory_pressure.total, USEC_PER_SEC),
                 strempty(prefix), FORMAT_BYTES(ctx->current_memory_usage));
 
index 1163a55bc6298531d2efdee64e73ed2730c0e470..b6a593d0dbab5609c5d341fc8123ec296e6bbcf6 100644 (file)
@@ -804,24 +804,24 @@ static void test_parse_loadavg_fixed_point(void) {
         loadavg_t fp;
 
         assert_se(parse_loadavg_fixed_point("1.23", &fp) == 0);
-        assert_se(INT_SIDE(fp) == 1);
-        assert_se(DECIMAL_SIDE(fp) == 23);
+        assert_se(LOADAVG_INT_SIDE(fp) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(fp) == 23);
 
         assert_se(parse_loadavg_fixed_point("1.80", &fp) == 0);
-        assert_se(INT_SIDE(fp) == 1);
-        assert_se(DECIMAL_SIDE(fp) == 80);
+        assert_se(LOADAVG_INT_SIDE(fp) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(fp) == 80);
 
         assert_se(parse_loadavg_fixed_point("0.07", &fp) == 0);
-        assert_se(INT_SIDE(fp) == 0);
-        assert_se(DECIMAL_SIDE(fp) == 7);
+        assert_se(LOADAVG_INT_SIDE(fp) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(fp) == 7);
 
         assert_se(parse_loadavg_fixed_point("0.00", &fp) == 0);
-        assert_se(INT_SIDE(fp) == 0);
-        assert_se(DECIMAL_SIDE(fp) == 0);
+        assert_se(LOADAVG_INT_SIDE(fp) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(fp) == 0);
 
         assert_se(parse_loadavg_fixed_point("4096.57", &fp) == 0);
-        assert_se(INT_SIDE(fp) == 4096);
-        assert_se(DECIMAL_SIDE(fp) == 57);
+        assert_se(LOADAVG_INT_SIDE(fp) == 4096);
+        assert_se(LOADAVG_DECIMAL_SIDE(fp) == 57);
 
         /* Caps out at 2 digit fracs */
         assert_se(parse_loadavg_fixed_point("1.100", &fp) == -ERANGE);
index 999a1fb51e80d244adb8f7ba3859024a95fe23b6..857ecb59a460b1e865aed32b236ec822e3613863 100644 (file)
@@ -35,40 +35,40 @@ static void test_read_mem_pressure(void) {
         assert_se(write_string_file(path, "some avg10=0.22 avg60=0.17 avg300=1.11 total=58761459\n"
                                           "full avg10=0.23 avg60=0.16 avg300=1.08 total=58464525", WRITE_STRING_FILE_CREATE) == 0);
         assert_se(read_resource_pressure(path, PRESSURE_TYPE_SOME, &rp) == 0);
-        assert_se(INT_SIDE(rp.avg10) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg10) == 22);
-        assert_se(INT_SIDE(rp.avg60) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg60) == 17);
-        assert_se(INT_SIDE(rp.avg300) == 1);
-        assert_se(DECIMAL_SIDE(rp.avg300) == 11);
+        assert_se(LOADAVG_INT_SIDE(rp.avg10) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg10) == 22);
+        assert_se(LOADAVG_INT_SIDE(rp.avg60) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg60) == 17);
+        assert_se(LOADAVG_INT_SIDE(rp.avg300) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg300) == 11);
         assert_se(rp.total == 58761459);
         assert(read_resource_pressure(path, PRESSURE_TYPE_FULL, &rp) == 0);
-        assert_se(INT_SIDE(rp.avg10) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg10) == 23);
-        assert_se(INT_SIDE(rp.avg60) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg60) == 16);
-        assert_se(INT_SIDE(rp.avg300) == 1);
-        assert_se(DECIMAL_SIDE(rp.avg300) == 8);
+        assert_se(LOADAVG_INT_SIDE(rp.avg10) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg10) == 23);
+        assert_se(LOADAVG_INT_SIDE(rp.avg60) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg60) == 16);
+        assert_se(LOADAVG_INT_SIDE(rp.avg300) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg300) == 8);
         assert_se(rp.total == 58464525);
 
         /* Pressure file with extra unsupported fields */
         assert_se(write_string_file(path, "some avg5=0.55 avg10=0.22 avg60=0.17 avg300=1.11 total=58761459\n"
                                           "full avg10=0.23 avg60=0.16 avg300=1.08 avg600=2.00 total=58464525", WRITE_STRING_FILE_CREATE) == 0);
         assert_se(read_resource_pressure(path, PRESSURE_TYPE_SOME, &rp) == 0);
-        assert_se(INT_SIDE(rp.avg10) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg10) == 22);
-        assert_se(INT_SIDE(rp.avg60) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg60) == 17);
-        assert_se(INT_SIDE(rp.avg300) == 1);
-        assert_se(DECIMAL_SIDE(rp.avg300) == 11);
+        assert_se(LOADAVG_INT_SIDE(rp.avg10) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg10) == 22);
+        assert_se(LOADAVG_INT_SIDE(rp.avg60) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg60) == 17);
+        assert_se(LOADAVG_INT_SIDE(rp.avg300) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg300) == 11);
         assert_se(rp.total == 58761459);
         assert(read_resource_pressure(path, PRESSURE_TYPE_FULL, &rp) == 0);
-        assert_se(INT_SIDE(rp.avg10) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg10) == 23);
-        assert_se(INT_SIDE(rp.avg60) == 0);
-        assert_se(DECIMAL_SIDE(rp.avg60) == 16);
-        assert_se(INT_SIDE(rp.avg300) == 1);
-        assert_se(DECIMAL_SIDE(rp.avg300) == 8);
+        assert_se(LOADAVG_INT_SIDE(rp.avg10) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg10) == 23);
+        assert_se(LOADAVG_INT_SIDE(rp.avg60) == 0);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg60) == 16);
+        assert_se(LOADAVG_INT_SIDE(rp.avg300) == 1);
+        assert_se(LOADAVG_DECIMAL_SIDE(rp.avg300) == 8);
         assert_se(rp.total == 58464525);
 }