PCI: iproc: Add PAXCv2 related binding

Add new compatible string "brcm,iproc-pcie-paxc-v2" to the iProc PCIe
device tree binding document.  "brcm,iproc-pcie-paxc-v2" is for the second
generation of the Broadcom iProc PCIe PAXC host controller.

Update the binding document with more detailed description of each
compatible string and compatible SoCs.

Add description of optional property "msi-map", for use with MSI
controllers with sideband data.

Signed-off-by: Ray Jui <ray.jui@broadcom.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Scott Branden <scott.branden@broadcom.com>
This commit is contained in:
Ray Jui 2016-10-31 17:38:34 -07:00 committed by Bjorn Helgaas
parent 538928fd6c
commit f29224ae95
1 changed files with 23 additions and 8 deletions

View File

@ -1,10 +1,15 @@
* Broadcom iProc PCIe controller with the platform bus interface * Broadcom iProc PCIe controller with the platform bus interface
Required properties: Required properties:
- compatible: Must be "brcm,iproc-pcie" for PAXB, or "brcm,iproc-pcie-paxc" - compatible:
for PAXC. PAXB-based root complex is used for external endpoint devices. "brcm,iproc-pcie" for the first generation of PAXB based controller,
PAXC-based root complex is connected to emulated endpoint devices used in SoCs including NSP, Cygnus, NS2, and Pegasus
internal to the ASIC "brcm,iproc-pcie-paxc" for the first generation of PAXC based
controller, used in NS2
"brcm,iproc-pcie-paxc-v2" for the second generation of PAXC based
controller, used in Stingray
PAXB-based root complex is used for external endpoint devices. PAXC-based
root complex is connected to emulated endpoint devices internal to the ASIC
- reg: base address and length of the PCIe controller I/O register space - reg: base address and length of the PCIe controller I/O register space
- #interrupt-cells: set to <1> - #interrupt-cells: set to <1>
- interrupt-map-mask and interrupt-map, standard PCI properties to define the - interrupt-map-mask and interrupt-map, standard PCI properties to define the
@ -19,6 +24,7 @@ Required properties:
Optional properties: Optional properties:
- phys: phandle of the PCIe PHY device - phys: phandle of the PCIe PHY device
- phy-names: must be "pcie-phy" - phy-names: must be "pcie-phy"
- dma-coherent: present if DMA operations are coherent
- brcm,pcie-ob: Some iProc SoCs do not have the outbound address mapping done - brcm,pcie-ob: Some iProc SoCs do not have the outbound address mapping done
by the ASIC after power on reset. In this case, SW needs to configure it by the ASIC after power on reset. In this case, SW needs to configure it
@ -41,10 +47,19 @@ For older platforms without MSI integrated in the GIC, iProc PCIe core provides
an event queue based MSI support. The iProc MSI uses host memories to store an event queue based MSI support. The iProc MSI uses host memories to store
MSI posted writes in the event queues MSI posted writes in the event queues
- msi-parent: Link to the device node of the MSI controller. On newer iProc On newer iProc platforms, gicv2m or gicv3-its based MSI support should be used
platforms, the MSI controller may be gicv2m or gicv3-its. On older iProc
platforms without MSI support in its interrupt controller, one may use the - msi-map: Maps a Requester ID to an MSI controller and associated MSI
event queue based MSI support integrated within the iProc PCIe core. sideband data
- msi-parent: Link to the device node of the MSI controller, used when no MSI
sideband data is passed between the iProc PCIe controller and the MSI
controller
Refer to the following binding documents for more detailed description on
the use of 'msi-map' and 'msi-parent':
Documentation/devicetree/bindings/pci/pci-msi.txt
Documentation/devicetree/bindings/interrupt-controller/msi.txt
When the iProc event queue based MSI is used, one needs to define the When the iProc event queue based MSI is used, one needs to define the
following properties in the MSI device node: following properties in the MSI device node: