PCI/ACPI: Request _OSC control once for each root bridge (v3)
Move the evaluation of acpi_pci_osc_control_set() (to request control of PCI Express native features) into acpi_pci_root_add() to avoid calling it many times for the same root complex with the same arguments. Additionally, check if all of the requisite _OSC support bits are set before calling acpi_pci_osc_control_set() for a given root complex. References: https://bugzilla.kernel.org/show_bug.cgi?id=20232 Reported-by: Ozan Caglayan <ozan@pardus.org.tr> Tested-by: Ozan Caglayan <ozan@pardus.org.tr> Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
这个提交包含在:
@@ -195,24 +195,24 @@ static int __init setup_hest_disable(char *str)
|
||||
|
||||
__setup("hest_disable", setup_hest_disable);
|
||||
|
||||
static int __init hest_init(void)
|
||||
void __init acpi_hest_init(void)
|
||||
{
|
||||
acpi_status status;
|
||||
int rc = -ENODEV;
|
||||
unsigned int ghes_count = 0;
|
||||
|
||||
if (acpi_disabled)
|
||||
goto err;
|
||||
return;
|
||||
|
||||
if (hest_disable) {
|
||||
pr_info(HEST_PFX "HEST tabling parsing is disabled.\n");
|
||||
goto err;
|
||||
pr_info(HEST_PFX "Table parsing disabled.\n");
|
||||
return;
|
||||
}
|
||||
|
||||
status = acpi_get_table(ACPI_SIG_HEST, 0,
|
||||
(struct acpi_table_header **)&hest_tab);
|
||||
if (status == AE_NOT_FOUND) {
|
||||
pr_info(HEST_PFX "Table is not found!\n");
|
||||
pr_info(HEST_PFX "Table not found.\n");
|
||||
goto err;
|
||||
} else if (ACPI_FAILURE(status)) {
|
||||
const char *msg = acpi_format_exception(status);
|
||||
@@ -226,15 +226,11 @@ static int __init hest_init(void)
|
||||
goto err;
|
||||
|
||||
rc = hest_ghes_dev_register(ghes_count);
|
||||
if (rc)
|
||||
goto err;
|
||||
if (!rc) {
|
||||
pr_info(HEST_PFX "Table parsing has been initialized.\n");
|
||||
return;
|
||||
}
|
||||
|
||||
pr_info(HEST_PFX "HEST table parsing is initialized.\n");
|
||||
|
||||
return 0;
|
||||
err:
|
||||
hest_disable = 1;
|
||||
return rc;
|
||||
}
|
||||
|
||||
subsys_initcall(hest_init);
|
||||
|
在新工单中引用
屏蔽一个用户