cgroup/cpuset: Fix retval in update_cpumask()
authorKamalesh Babulal <kamalesh.babulal@oracle.com>
Thu, 29 Feb 2024 10:11:14 +0000 (15:41 +0530)
committerTejun Heo <tj@kernel.org>
Thu, 29 Feb 2024 20:30:35 +0000 (10:30 -1000)
The update_cpumask(), checks for newly requested cpumask by calling
validate_change(), which returns an error on passing an invalid set
of cpu(s). Independent of the error returned, update_cpumask() always
returns zero, suppressing the error and returning success to the user
on writing an invalid cpu range for a cpuset. Fix it by returning
retval instead, which is returned by validate_change().

Fixes: 99fe36ba6fc1 ("cgroup/cpuset: Improve temporary cpumasks handling")
Signed-off-by: Kamalesh Babulal <kamalesh.babulal@oracle.com>
Reviewed-by: Waiman Long <longman@redhat.com>
Cc: stable@vger.kernel.org # v6.6+
Signed-off-by: Tejun Heo <tj@kernel.org>
kernel/cgroup/cpuset.c

index 7260f095802a4a188e0c7e5a1a5702205be6e2dd..927bef3a598ad5ce4b0fee8dfce70d0a89c1964c 100644 (file)
@@ -2562,7 +2562,7 @@ static int update_cpumask(struct cpuset *cs, struct cpuset *trialcs,
                update_partition_sd_lb(cs, old_prs);
 out_free:
        free_cpumasks(NULL, &tmp);
-       return 0;
+       return retval;
 }
 
 /**