[PATCH] cgroup: deprecate remount option changes and "name=" mountoption

From: Tejun Heo
Date: Wed Mar 14 2012 - 17:52:32 EST


This patch removes the following features.

* Rebinding subsys by remount: Never reached useful state - only works
on empty hierarchies.

* release_agent update by remount: release_agent itself will be
replaced with conventional fsnotify notification.

* "name=" mount option: This has been broken for years before Li fixed
it recently. It has very marginal usefulness (plain bind mount can
mostly replace it) and is quite unusual. Take the chance and mark
for deprecation.

Signed-off-by: Tejun Heo <tj@xxxxxxxxxx>
Cc: Li Zefan <lizf@xxxxxxxxxxxxxx>
Cc: Lennart Poettering <mzxreary@xxxxxxxxxxx>
---
If you want these to survive, now is the time to scream. :)

Thanks.

Documentation/feature-removal-schedule.txt | 12 ++++++++++++
kernel/cgroup.c | 10 ++++++++++
2 files changed, 22 insertions(+)

Index: work/Documentation/feature-removal-schedule.txt
===================================================================
--- work.orig/Documentation/feature-removal-schedule.txt
+++ work/Documentation/feature-removal-schedule.txt
@@ -510,3 +510,15 @@ Why: The pci_scan_bus_parented() interfa
convert to using pci_scan_root_bus() so they can supply a list of
bus resources when the bus is created.
Who: Bjorn Helgaas <bhelgaas@xxxxxxxxxx>
+
+----------------------------
+
+What: cgroup option updates via remount, and "name=" mount option
+When: March 2013
+Why: Remount currently allows changing bound subsystems and
+ release_agent. Rebinding is hardly useful as it only works
+ when the hierarchy is empty and release_agent itself should be
+ replaced with conventional fsnotify. "name=" option allows
+ mounting existing hierarchy by its name, which isn't useful
+ and has been broken for years without anyone noticing.
+Who: Tejun Heo <tj@xxxxxxxxxx>
Index: work/kernel/cgroup.c
===================================================================
--- work.orig/kernel/cgroup.c
+++ work/kernel/cgroup.c
@@ -1146,6 +1146,11 @@ static int parse_cgroupfs_options(char *
}
if (!strncmp(token, "name=", 5)) {
const char *name = token + 5;
+
+ /* See feature-removal-schedule.txt */
+ pr_warning("cgroup: name= option is deprecated (pid=%d comm=%s name=%s)\n",
+ task_tgid_nr(current), current->comm, name);
+
/* Can't specify an empty name */
if (!strlen(name))
return -EINVAL;
@@ -1294,6 +1299,11 @@ static int cgroup_remount(struct super_b
if (ret)
goto out_unlock;

+ /* See feature-removal-schedule.txt */
+ if (opts.subsys_bits != root->actual_subsys_bits || opts.release_agent)
+ pr_warning("cgroup: option changes via remount are deprecated (pid=%d comm=%s)\n",
+ task_tgid_nr(current), current->comm);
+
/* Don't allow flags or name to change at remount */
if (opts.flags != root->flags ||
(opts.name && strcmp(opts.name, root->name))) {
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/