提交 b4dccd8d 编写于 作者: I Isaku Yamahata 提交者: Anthony Liguori

pci/monitor: print out bridge's filtering values and so on.

make pci_info_device() print out bridge's filtering value like
io base/limit, subbus and subordinate bus.
Signed-off-by: NIsaku Yamahata <yamahata@valinux.co.jp>
Acked-by: NMichael S. Tsirkin <mst@redhat.com>
Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
上级 a0c7a97e
...@@ -970,7 +970,32 @@ static void pci_info_device(PCIBus *bus, PCIDevice *d) ...@@ -970,7 +970,32 @@ static void pci_info_device(PCIBus *bus, PCIDevice *d)
d->config[PCI_INTERRUPT_LINE]); d->config[PCI_INTERRUPT_LINE]);
} }
if (class == 0x0604) { if (class == 0x0604) {
uint64_t base;
uint64_t limit;
monitor_printf(mon, " BUS %d.\n", d->config[0x19]); monitor_printf(mon, " BUS %d.\n", d->config[0x19]);
monitor_printf(mon, " secondary bus %d.\n",
d->config[PCI_SECONDARY_BUS]);
monitor_printf(mon, " subordinate bus %d.\n",
d->config[PCI_SUBORDINATE_BUS]);
base = pci_bridge_get_base(d, PCI_BASE_ADDRESS_SPACE_IO);
limit = pci_bridge_get_limit(d, PCI_BASE_ADDRESS_SPACE_IO);
monitor_printf(mon, " IO range [0x%04"PRIx64", 0x%04"PRIx64"]\n",
base, limit);
base = pci_bridge_get_base(d, PCI_BASE_ADDRESS_SPACE_MEMORY);
limit= pci_config_get_memory_base(d, PCI_BASE_ADDRESS_SPACE_MEMORY);
monitor_printf(mon,
" memory range [0x%08"PRIx64", 0x%08"PRIx64"]\n",
base, limit);
base = pci_bridge_get_base(d, PCI_BASE_ADDRESS_SPACE_MEMORY |
PCI_BASE_ADDRESS_MEM_PREFETCH);
limit = pci_bridge_get_limit(d, PCI_BASE_ADDRESS_SPACE_MEMORY |
PCI_BASE_ADDRESS_MEM_PREFETCH);
monitor_printf(mon, " prefetchable memory range "
"[0x%08"PRIx64", 0x%08"PRIx64"]\n", base, limit);
} }
for(i = 0;i < PCI_NUM_REGIONS; i++) { for(i = 0;i < PCI_NUM_REGIONS; i++) {
r = &d->io_regions[i]; r = &d->io_regions[i];
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册