Skip to content

Commit

Permalink
Merge branch 'psd' into release
Browse files Browse the repository at this point in the history
  • Loading branch information
Len Brown committed Apr 5, 2009
2 parents 3266d63 + e1eb477 commit 7329e93
Showing 1 changed file with 21 additions and 25 deletions.
46 changes: 21 additions & 25 deletions drivers/acpi/processor_perflib.c
Original file line number Diff line number Diff line change
Expand Up @@ -479,6 +479,13 @@ static int acpi_processor_get_psd(struct acpi_processor *pr)
goto end;
}

if (pdomain->coord_type != DOMAIN_COORD_TYPE_SW_ALL &&
pdomain->coord_type != DOMAIN_COORD_TYPE_SW_ANY &&
pdomain->coord_type != DOMAIN_COORD_TYPE_HW_ALL) {
printk(KERN_ERR PREFIX "Invalid _PSD:coord_type\n");
result = -EFAULT;
goto end;
}
end:
kfree(buffer.pointer);
return result;
Expand All @@ -501,9 +508,10 @@ int acpi_processor_preregister_performance(

mutex_lock(&performance_mutex);

retval = 0;

/* Call _PSD for all CPUs */
/*
* Check if another driver has already registered, and abort before
* changing pr->performance if it has. Check input data as well.
*/
for_each_possible_cpu(i) {
pr = per_cpu(processors, i);
if (!pr) {
Expand All @@ -513,13 +521,20 @@ int acpi_processor_preregister_performance(

if (pr->performance) {
retval = -EBUSY;
continue;
goto err_out;
}

if (!performance || !percpu_ptr(performance, i)) {
retval = -EINVAL;
continue;
goto err_out;
}
}

/* Call _PSD for all CPUs */
for_each_possible_cpu(i) {
pr = per_cpu(processors, i);
if (!pr)
continue;

pr->performance = percpu_ptr(performance, i);
cpumask_set_cpu(i, pr->performance->shared_cpu_map);
Expand All @@ -535,26 +550,6 @@ int acpi_processor_preregister_performance(
* Now that we have _PSD data from all CPUs, lets setup P-state
* domain info.
*/
for_each_possible_cpu(i) {
pr = per_cpu(processors, i);
if (!pr)
continue;

/* Basic validity check for domain info */
pdomain = &(pr->performance->domain_info);
if ((pdomain->revision != ACPI_PSD_REV0_REVISION) ||
(pdomain->num_entries != ACPI_PSD_REV0_ENTRIES)) {
retval = -EINVAL;
goto err_ret;
}
if (pdomain->coord_type != DOMAIN_COORD_TYPE_SW_ALL &&
pdomain->coord_type != DOMAIN_COORD_TYPE_SW_ANY &&
pdomain->coord_type != DOMAIN_COORD_TYPE_HW_ALL) {
retval = -EINVAL;
goto err_ret;
}
}

cpumask_clear(covered_cpus);
for_each_possible_cpu(i) {
pr = per_cpu(processors, i);
Expand Down Expand Up @@ -643,6 +638,7 @@ int acpi_processor_preregister_performance(
pr->performance = NULL; /* Will be set for real in register */
}

err_out:
mutex_unlock(&performance_mutex);
free_cpumask_var(covered_cpus);
return retval;
Expand Down

0 comments on commit 7329e93

Please sign in to comment.