Allow bit 1 of I/O BARs to be set.

Usually bit 1 of I/O BARs is 0 since it is reserved, but control has an I/O BAR where this bit is set.
bar_cfg is used to determine the default values of the least significant bits (2 bits for I/O BARs and 4 bits for Memory BARs).
The upper bits of bar_cfg determine which bits can be set and also determines the size of the BAR.
This commit is contained in:
joevt 2022-09-02 00:59:35 -07:00
parent fb56a6b536
commit 37c352955c

View File

@ -246,7 +246,7 @@ void PCIDevice::set_bar_value(int bar_num, uint32_t value)
{ {
uint32_t bar_cfg = this->bars_cfg[bar_num]; uint32_t bar_cfg = this->bars_cfg[bar_num];
if (bar_cfg & 1) { if (bar_cfg & 1) {
this->bars[bar_num] = (value & 0xFFFFFFFCUL) | 1; this->bars[bar_num] = (value & 0xFFFFFFFCUL) | (bar_cfg & 3);
} else { } else {
if (bar_cfg & 6) { if (bar_cfg & 6) {
ABORT_F("Invalid or unsupported PCI space type: %d", (bar_cfg >> 1) & 3); ABORT_F("Invalid or unsupported PCI space type: %d", (bar_cfg >> 1) & 3);