diff options
Diffstat (limited to 'drivers/pci/setup-bus.c')
| -rw-r--r-- | drivers/pci/setup-bus.c | 11 | 
1 files changed, 9 insertions, 2 deletions
diff --git a/drivers/pci/setup-bus.c b/drivers/pci/setup-bus.c index 8fa2d4be88d..dad5425f1f0 100644 --- a/drivers/pci/setup-bus.c +++ b/drivers/pci/setup-bus.c @@ -469,16 +469,23 @@ static void pci_setup_bridge_io(struct pci_bus *bus)  	struct pci_dev *bridge = bus->self;  	struct resource *res;  	struct pci_bus_region region; +	unsigned long io_mask; +	u8 io_base_lo, io_limit_lo;  	u32 l, io_upper16; +	io_mask = PCI_IO_RANGE_MASK; +	if (bridge->io_window_1k) +		io_mask = PCI_IO_1K_RANGE_MASK; +  	/* Set up the top and bottom of the PCI I/O segment for this bus. */  	res = bus->resource[0];  	pcibios_resource_to_bus(bridge, ®ion, res);  	if (res->flags & IORESOURCE_IO) {  		pci_read_config_dword(bridge, PCI_IO_BASE, &l);  		l &= 0xffff0000; -		l |= (region.start >> 8) & 0x00f0; -		l |= region.end & 0xf000; +		io_base_lo = (region.start >> 8) & io_mask; +		io_limit_lo = (region.end >> 8) & io_mask; +		l |= ((u32) io_limit_lo << 8) | io_base_lo;  		/* Set up upper 16 bits of I/O base/limit. */  		io_upper16 = (region.end & 0xffff0000) | (region.start >> 16);  		dev_info(&bridge->dev, "  bridge window %pR\n", res);  |