HomeFreeBSD

bhyve: ignore low bits of CFGADR

Description

bhyve: ignore low bits of CFGADR

Bhyve could emulate wrong PCI registers.
In the best case, the guest reads wrong registers and the device driver would
report some errors.
In the worst case, the guest writes to wrong PCI registers and could brick
hardware when using PCI passthrough.

According to Intels specification, low bits of CFGADR should be
ignored. Some OS like linux may rely on it. Otherwise, bhyve could
emulate a wrong PCI register.

E.g.
If linux would like to read 2 bytes from offset 0x02, following would
happen.
linux:
outl 0x80000002 at CFGADR
inw at CFGDAT + 2
bhyve:
cfgoff = 0x80000002 & 0xFF = 0x02
coff = cfgoff + (port - CFGDAT) = 0x02 + 0x02 = 0x04
Bhyve would emulate the register at offset 0x04 not 0x02.

Reviewed By: bhyve, grehan
Differential Revision: https://reviews.freebsd.org/D31819
Sponsored by: Beckhoff Automation GmbH & Co. KG

(cherry picked from commit 1b0e2f0b607e88feb57accc9521e9623b56ab7e2)

Details

Provenance
corvinkAuthored on Oct 15 2021, 7:25 AM
manuCommitted on Jan 14 2022, 1:51 PM
Reviewer
bhyve
Differential Revision
D31819: bhyve: ignore low bits of CFGADR
Parents
rGd3546083b4d5: pkgbase: Track pkg 1.17
Branches
Unknown
Tags
Unknown