mirror of
https://github.com/dingusdev/dingusppc.git
synced 2025-01-10 13:29:38 +00:00
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:
parent
fb56a6b536
commit
37c352955c
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user