X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=ls-map.c;h=9b2cc8cfa72db2a248ea323cf522b7ff36638f6e;hb=d462e89c81b9bb0986087abf30a8ea62dcc123a3;hp=c3ef54b7b1f59f60ac891a11157bc403f35becf0;hpb=6e0e7f4df5c7b778ee56ecf2ddec13bc8ec250c3;p=pciutils.git diff --git a/ls-map.c b/ls-map.c index c3ef54b..9b2cc8c 100644 --- a/ls-map.c +++ b/ls-map.c @@ -52,13 +52,14 @@ map_bridge(struct bus_info *bi, struct device *d, int np, int ns, int nl) static void do_map_bus(int bus) { + int domain = (filter.domain >= 0 ? filter.domain : 0); int dev, func; int verbose = pacc->debugging; struct bus_info *bi = bus_info + bus; struct device *d; if (verbose) - printf("Mapping bus %02x\n", bus); + printf("Mapping bus %04x:%02x\n", domain, bus); for (dev = 0; dev < 32; dev++) if (filter.slot < 0 || filter.slot == dev) { @@ -66,15 +67,14 @@ do_map_bus(int bus) for (func = 0; func < func_limit; func++) if (filter.func < 0 || filter.func == func) { - /* XXX: Bus mapping supports only domain 0 */ - struct pci_dev *p = pci_get_dev(pacc, 0, bus, dev, func); + struct pci_dev *p = pci_get_dev(pacc, domain, bus, dev, func); u16 vendor = pci_read_word(p, PCI_VENDOR_ID); if (vendor && vendor != 0xffff) { if (!func && (pci_read_byte(p, PCI_HEADER_TYPE) & 0x80)) func_limit = 8; if (verbose) - printf("Discovered device %02x:%02x.%d\n", bus, dev, func); + printf("Discovered device %04x:%02x:%02x.%d\n", domain, bus, dev, func); bi->exists = 1; if (d = scan_device(p)) { @@ -165,6 +165,7 @@ map_the_bus(void) { if (pacc->method == PCI_ACCESS_PROC_BUS_PCI || pacc->method == PCI_ACCESS_SYS_BUS_PCI || + pacc->method == PCI_ACCESS_WIN32_CFGMGR32 || pacc->method == PCI_ACCESS_DUMP) printf("WARNING: Bus mapping can be reliable only with direct hardware access enabled.\n\n"); bus_info = xmalloc(sizeof(struct bus_info) * 256);