PERR_HOTPLUG,
        PERR_CPUSEMPTY,
        PERR_HKEEPING,
+       PERR_ACCESS,
 };
 
 static const char * const perr_strings[] = {
        [PERR_HOTPLUG]   = "No cpu available due to hotplug",
        [PERR_CPUSEMPTY] = "cpuset.cpus and cpuset.cpus.exclusive are empty",
        [PERR_HKEEPING]  = "partition config conflicts with housekeeping setup",
+       [PERR_ACCESS]    = "Enable partition not permitted",
 };
 
 struct cpuset {
  * @cs: the cpuset to update
  * @new_prs: new partition_root_state
  * @tmp: temparary masks
- * Return: 1 if successful, 0 if error
+ * Return: 0 if successful, errcode if error
  *
  * Enable the current cpuset to become a remote partition root taking CPUs
  * directly from the top cpuset. cpuset_mutex must be held by the caller.
         * The user must have sysadmin privilege.
         */
        if (!capable(CAP_SYS_ADMIN))
-               return 0;
+               return PERR_ACCESS;
 
        /*
         * The requested exclusive_cpus must not be allocated to other
        if (cpumask_empty(tmp->new_cpus) ||
            cpumask_intersects(tmp->new_cpus, subpartitions_cpus) ||
            cpumask_subset(top_cpuset.effective_cpus, tmp->new_cpus))
-               return 0;
+               return PERR_INVCPUS;
 
        spin_lock_irq(&callback_lock);
        isolcpus_updated = partition_xcpus_add(new_prs, NULL, tmp->new_cpus);
         */
        update_tasks_cpumask(&top_cpuset, tmp->new_cpus);
        update_sibling_cpumasks(&top_cpuset, NULL, tmp);
-       return 1;
+       return 0;
 }
 
 /*
                goto out;
 
        if (!old_prs) {
-               enum partition_cmd cmd = (new_prs == PRS_ROOT)
-                                      ? partcmd_enable : partcmd_enablei;
-
                /*
                 * cpus_allowed and exclusive_cpus cannot be both empty.
                 */
                        goto out;
                }
 
-               err = update_parent_effective_cpumask(cs, cmd, NULL, &tmpmask);
                /*
-                * If an attempt to become local partition root fails,
-                * try to become a remote partition root instead.
+                * If parent is valid partition, enable local partiion.
+                * Otherwise, enable a remote partition.
                 */
-               if (err && remote_partition_enable(cs, new_prs, &tmpmask))
-                       err = 0;
+               if (is_partition_valid(parent)) {
+                       enum partition_cmd cmd = (new_prs == PRS_ROOT)
+                                              ? partcmd_enable : partcmd_enablei;
+
+                       err = update_parent_effective_cpumask(cs, cmd, NULL, &tmpmask);
+               } else {
+                       err = remote_partition_enable(cs, new_prs, &tmpmask);
+               }
        } else if (old_prs && new_prs) {
                /*
                 * A change in load balance state only, no change in cpumasks.