acpi: Add missing error handling to acpi_pci_link_route_irqs()
Otherwise the resouce buffer may have been freed when AcpiSetCurrentResources() is called, leading to a use-after-free. PR: 255862 Submitted by: Lv Yunlong <lylgood@foxmail.com> (original version) MFC after: 1 week
This commit is contained in:
parent
27130028a5
commit
4cf3327528
@ -843,8 +843,10 @@ acpi_pci_link_srs_from_links(struct acpi_pci_link_softc *sc,
|
||||
device_printf(sc->pl_dev,
|
||||
"Unable to build resources: %s\n",
|
||||
AcpiFormatException(status));
|
||||
if (srsbuf->Pointer != NULL)
|
||||
if (srsbuf->Pointer != NULL) {
|
||||
AcpiOsFree(srsbuf->Pointer);
|
||||
srsbuf->Pointer = NULL;
|
||||
}
|
||||
return (status);
|
||||
}
|
||||
}
|
||||
@ -867,6 +869,8 @@ acpi_pci_link_route_irqs(device_t dev)
|
||||
status = acpi_pci_link_srs_from_links(sc, &srsbuf);
|
||||
else
|
||||
status = acpi_pci_link_srs_from_crs(sc, &srsbuf);
|
||||
if (ACPI_FAILURE(status))
|
||||
return (status);
|
||||
|
||||
/* Write out new resources via _SRS. */
|
||||
status = AcpiSetCurrentResources(acpi_get_handle(dev), &srsbuf);
|
||||
|
Loading…
Reference in New Issue
Block a user