[LTP] [PATCH] cgroup_fj: don't disable controller that was already enabled

Wei Gao wegao@suse.com
Fri Jun 12 11:04:14 CEST 2026


On Thu, Jun 11, 2026 at 05:03:41PM +0200, Andrea Cervesato wrote:
> From: Andrea Cervesato <andrea.cervesato@suse.com>
> 
> On immutable distributions (and systemd-managed systems in general)
> the cpuset controller is typically already enabled at the root cgroup
> level. The cleanup tried to unconditionally disable it via
> subtree_control, which failed with EBUSY because other system cgroups
> were still using it, producing a spurious TWARN.
> 
> Save whether the controller was already enabled at root before
> cgroup_require and skip the root-level disable in cleanup when it
> was.
> 
> Signed-off-by: Andrea Cervesato <andrea.cervesato@suse.com>
> ---
>  testcases/kernel/controllers/cgroup_fj/cgroup_fj_common.sh | 10 +++++++++-
>  1 file changed, 9 insertions(+), 1 deletion(-)
> 
> diff --git a/testcases/kernel/controllers/cgroup_fj/cgroup_fj_common.sh b/testcases/kernel/controllers/cgroup_fj/cgroup_fj_common.sh
> index 153d351d7936effb15527620f565acaaed7ac747..8b5e73466ba32d2c66a2805a03f4d2136c16509b 100755
> --- a/testcases/kernel/controllers/cgroup_fj/cgroup_fj_common.sh
> +++ b/testcases/kernel/controllers/cgroup_fj/cgroup_fj_common.sh
> @@ -57,6 +57,14 @@ create_subgroup()
>  
>  common_setup()
>  {
> +    # Check if the controller is already enabled at root before
> +    # cgroup_require potentially enables it, so that cleanup does
> +    # not disable a controller the system was already using.
> +    if [ -f /sys/fs/cgroup/cgroup.subtree_control ] && \
> +       grep -qw "$subsystem" /sys/fs/cgroup/cgroup.subtree_control; then
> +        ctrl_was_enabled=1
> +    fi
> +
>      cgroup_require "$subsystem"
>      mount_point=$(cgroup_get_mountpoint "$subsystem")
>      start_path=$(cgroup_get_test_path "$subsystem")
> @@ -77,7 +85,7 @@ common_cleanup()
>  
>      cgroup_cleanup
>  
> -    if [ "$cgroup_version" = "2" ]; then
> +    if [ "$cgroup_version" = "2" ] && [ "$ctrl_was_enabled" != "1" ]; then
>          case "$subsystem" in
>          cpu|io|memory|pids)
>              :;;
> 
> ---
> base-commit: a375e8deed471723f5a0114c56eb48fe6f6f45d3
> change-id: 20260611-fix_cgroup_immutable-2259f7591f8d
> 
> Best regards,
> -- 
> Andrea Cervesato <andrea.cervesato@suse.com>
Reviewed-by: Wei Gao <wegao@suse.com>
> 
> 
> -- 
> Mailing list info: https://lists.linux.it/listinfo/ltp


More information about the ltp mailing list