pci: Don't allow mapping to isa ports
This commit is contained in:
parent
923d4148d0
commit
81f8976500
12
src/pci.js
12
src/pci.js
|
@ -547,7 +547,11 @@ PCI.prototype.set_io_bars = function(bar, from, to)
|
|||
for(var i = 0; i < count; i++)
|
||||
{
|
||||
var old_entry = ports[from + i];
|
||||
ports[from + i] = this.io.create_empty_entry();
|
||||
|
||||
if(from + i >= 0x1000)
|
||||
{
|
||||
ports[from + i] = this.io.create_empty_entry();
|
||||
}
|
||||
|
||||
if(old_entry.read8 === this.io.empty_port_read8 &&
|
||||
old_entry.read16 === this.io.empty_port_read16 &&
|
||||
|
@ -556,6 +560,7 @@ PCI.prototype.set_io_bars = function(bar, from, to)
|
|||
old_entry.write16 === this.io.empty_port_write &&
|
||||
old_entry.write32 === this.io.empty_port_write)
|
||||
{
|
||||
// happens when a device doesn't register its full range (currently ne2k and virtio)
|
||||
dbg_log("Warning: Bad IO bar: Source not mapped, port=" + h(from + i, 4), LOG_PCI);
|
||||
}
|
||||
|
||||
|
@ -563,7 +568,10 @@ PCI.prototype.set_io_bars = function(bar, from, to)
|
|||
var empty_entry = ports[to + i];
|
||||
dbg_assert(entry && empty_entry);
|
||||
|
||||
ports[to + i] = entry;
|
||||
if(to + i >= 0x1000)
|
||||
{
|
||||
ports[to + i] = entry;
|
||||
}
|
||||
|
||||
if(empty_entry.read8 === this.io.empty_port_read8 ||
|
||||
empty_entry.read16 === this.io.empty_port_read16 ||
|
||||
|
|
Loading…
Reference in a new issue