Page MenuHomeFreeBSD

pci_host_generic: Pass a valid end address in generic_pcie_translate_resource
ClosedPublic

Authored by jhb on Mar 4 2024, 10:44 PM.
Tags
None
Referenced Files
F140878220: D44205.id135386.diff
Mon, Dec 29, 4:29 AM
F140835200: D44205.diff
Sun, Dec 28, 3:35 PM
Unknown Object (File)
Wed, Dec 24, 12:54 PM
Unknown Object (File)
Sat, Dec 13, 4:49 AM
Unknown Object (File)
Nov 17 2025, 3:43 PM
Unknown Object (File)
Nov 5 2025, 7:15 AM
Unknown Object (File)
Oct 31 2025, 7:29 PM
Unknown Object (File)
Oct 30 2025, 11:03 AM
Subscribers

Details

Summary

The generic_pcie_containing_range helper added in commit d79b6b8ec267
assumed that the passed in (start, end) range used to locate the
containing mapping range was a valid address range (with end >=
start). The previous version of
generic_pcie_translate_resource_common only used the start address to
locate a mapping range, so the end address of 0 did not matter, but an
end of 0 now causes the first range to match and an incorrect
translation for resources using a later range.

PR: 277211
Reported by: dch, tuexen
Fixes: d79b6b8ec267 pci_host_generic: Don't rewrite resource start address for translation

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable