mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-07 13:13:57 +08:00
ACPI / tables: fix acpi_parse_entries_array() so it traverses all subtables
The acpi_parse_entries_array() function currently returns the very first time there is any error found by one of the callback functions, or if one of the callbacks returns a non-zero value. However, the ACPI subtables being traversed could still have valid entries that could be used by one of the callback functions. And, if the comments are correct, that is what should happen -- always traverse all of the subtables, calling as many of the callbacks as possible. This patch makes the function consistent with its description so that it will properly invoke all callbacks for all matching entries, for all subtables, instead of stopping abruptly as it does today. This does change the semantics of using acpi_parse_entries_array(). In examining all users of the function, none of them rely on the current behavior; that is, there appears to be no assumption that either all subtables are traversed and all callbacks invoked, or that the function will return immediately on any error from a callback. Each callback operates independently. Hence, there should be no functional change due to this change in semantics. Future patches being prepared will rely on this new behavior; indeed, they were written assuming the acpi_parse_entries_array() function operated as its comments describe. For example, a callback that counts the number of subtables of a specific type can now be assured that as many subtables as possible have been enumerated. Signed-off-by: Al Stone <ahs3@redhat.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
fa162a05de
commit
8726d4f441
@ -246,6 +246,7 @@ acpi_parse_entries_array(char *id, unsigned long table_size,
|
|||||||
struct acpi_subtable_header *entry;
|
struct acpi_subtable_header *entry;
|
||||||
unsigned long table_end;
|
unsigned long table_end;
|
||||||
int count = 0;
|
int count = 0;
|
||||||
|
int errs = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (acpi_disabled)
|
if (acpi_disabled)
|
||||||
@ -278,8 +279,10 @@ acpi_parse_entries_array(char *id, unsigned long table_size,
|
|||||||
if (entry->type != proc[i].id)
|
if (entry->type != proc[i].id)
|
||||||
continue;
|
continue;
|
||||||
if (!proc[i].handler ||
|
if (!proc[i].handler ||
|
||||||
proc[i].handler(entry, table_end))
|
(!errs && proc[i].handler(entry, table_end))) {
|
||||||
return -EINVAL;
|
errs++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
proc[i].count++;
|
proc[i].count++;
|
||||||
break;
|
break;
|
||||||
@ -305,7 +308,7 @@ acpi_parse_entries_array(char *id, unsigned long table_size,
|
|||||||
id, proc->id, count - max_entries, count);
|
id, proc->id, count - max_entries, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
return count;
|
return errs ? -EINVAL : count;
|
||||||
}
|
}
|
||||||
|
|
||||||
int __init
|
int __init
|
||||||
|
Loading…
Reference in New Issue
Block a user