]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
cgroup: Move cgroup_parse_float() implementation out of CONFIG_SYSFS
authorTejun Heo <tj@kernel.org>
Fri, 14 Jun 2019 17:12:45 +0000 (10:12 -0700)
committerTejun Heo <tj@kernel.org>
Fri, 14 Jun 2019 17:14:44 +0000 (10:14 -0700)
a5e112e6424a ("cgroup: add cgroup_parse_float()") accidentally added
cgroup_parse_float() inside CONFIG_SYSFS block.  Move it outside so
that it doesn't cause failures on !CONFIG_SYSFS builds.

Signed-off-by: Tejun Heo <tj@kernel.org>
Fixes: a5e112e6424a ("cgroup: add cgroup_parse_float()")
kernel/cgroup/cgroup.c

index 9e3dffb09489b66e700760853671f593748c3f64..f582414e15ba6d2101a479aef13b3d928b14675f 100644 (file)
@@ -6229,6 +6229,48 @@ struct cgroup *cgroup_get_from_fd(int fd)
 }
 EXPORT_SYMBOL_GPL(cgroup_get_from_fd);
 
+static u64 power_of_ten(int power)
+{
+       u64 v = 1;
+       while (power--)
+               v *= 10;
+       return v;
+}
+
+/**
+ * cgroup_parse_float - parse a floating number
+ * @input: input string
+ * @dec_shift: number of decimal digits to shift
+ * @v: output
+ *
+ * Parse a decimal floating point number in @input and store the result in
+ * @v with decimal point right shifted @dec_shift times.  For example, if
+ * @input is "12.3456" and @dec_shift is 3, *@v will be set to 12345.
+ * Returns 0 on success, -errno otherwise.
+ *
+ * There's nothing cgroup specific about this function except that it's
+ * currently the only user.
+ */
+int cgroup_parse_float(const char *input, unsigned dec_shift, s64 *v)
+{
+       s64 whole, frac = 0;
+       int fstart = 0, fend = 0, flen;
+
+       if (!sscanf(input, "%lld.%n%lld%n", &whole, &fstart, &frac, &fend))
+               return -EINVAL;
+       if (frac < 0)
+               return -EINVAL;
+
+       flen = fend > fstart ? fend - fstart : 0;
+       if (flen < dec_shift)
+               frac *= power_of_ten(dec_shift - flen);
+       else
+               frac = DIV_ROUND_CLOSEST_ULL(frac, power_of_ten(flen - dec_shift));
+
+       *v = whole * power_of_ten(dec_shift) + frac;
+       return 0;
+}
+
 /*
  * sock->sk_cgrp_data handling.  For more info, see sock_cgroup_data
  * definition in cgroup-defs.h.
@@ -6392,46 +6434,4 @@ static int __init cgroup_sysfs_init(void)
 }
 subsys_initcall(cgroup_sysfs_init);
 
-static u64 power_of_ten(int power)
-{
-       u64 v = 1;
-       while (power--)
-               v *= 10;
-       return v;
-}
-
-/**
- * cgroup_parse_float - parse a floating number
- * @input: input string
- * @dec_shift: number of decimal digits to shift
- * @v: output
- *
- * Parse a decimal floating point number in @input and store the result in
- * @v with decimal point right shifted @dec_shift times.  For example, if
- * @input is "12.3456" and @dec_shift is 3, *@v will be set to 12345.
- * Returns 0 on success, -errno otherwise.
- *
- * There's nothing cgroup specific about this function except that it's
- * currently the only user.
- */
-int cgroup_parse_float(const char *input, unsigned dec_shift, s64 *v)
-{
-       s64 whole, frac = 0;
-       int fstart = 0, fend = 0, flen;
-
-       if (!sscanf(input, "%lld.%n%lld%n", &whole, &fstart, &frac, &fend))
-               return -EINVAL;
-       if (frac < 0)
-               return -EINVAL;
-
-       flen = fend > fstart ? fend - fstart : 0;
-       if (flen < dec_shift)
-               frac *= power_of_ten(dec_shift - flen);
-       else
-               frac = DIV_ROUND_CLOSEST_ULL(frac, power_of_ten(flen - dec_shift));
-
-       *v = whole * power_of_ten(dec_shift) + frac;
-       return 0;
-}
-
 #endif /* CONFIG_SYSFS */