On Wed, Feb 03, 2016 at 10:26:36AM -0200, Guilherme G. Piccoli wrote: >On 02/02/2016 09:48 PM, Gavin Shan wrote: >>On Tue, Jan 19, 2016 at 06:18:20PM -0200, Guilherme G. Piccoli wrote: >>>- /* only attempt to use a new window if 64-bit DMA is requested */ >>>- if (!disable_ddw && dma_mask == DMA_BIT_MASK(64)) { >>>+ /* We should check if EEH is enabled here, since DDW mechanism has >>>+ * an intrinsic dependency of EEH config addr information. Also, we >>>+ * only attempt to use a new window if 64-bit DMA is requested */ >>>+ if (eeh_enabled() && !disable_ddw && dma_mask == DMA_BIT_MASK(64)) { >>> dn = pci_device_to_OF_node(pdev); >>> dev_dbg(dev, "node is %s\n", dn->full_name); >>> >> >>There are two types of addresses: (1) PCI config address (2) PE config >>address. >>(1) is used to indentify one PCI device which is included in the PE. (2) is >>the >>PCI config address of PE's primary bus in pHyp. Both of them can be used to >>identify >>the PE. It means the (1) PCI config address, which is retrieved from pci_dn, >>can be >>passed to hypervisor. Then we don't have to disable DDW when EEH is disabled. >> >>Guilherme, did you hit the crash on pHyp or PowerKVM? > >Gavin, thanks very much for the clarification. So, we can interchange >edev->config_addr with pdn->pci_ext_config_space ? >This would solve the issue with DDW being enabled when EEH is not. > >I hit the issue on PowerVM (PHyp). I wasn't able to perform hotplug in qemu >that time I was testing this - I can re-test on qemu. Can we use pci_dn >config address in qemu guest too? >
On PowerKVM, QEMU can't recognize (1). pHyp is expected to support both of them. Please have a try with (1) when eeh_enabled() returns false. The address (1) can be retrieved from pci_dn as below: (pdn->busno << 8) | (pdn->devfn) Thanks, Gavin _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev