fsl,imx6q-pcie.txt 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. * Freescale i.MX6 PCIe interface
  2. This PCIe host controller is based on the Synopsis Designware PCIe IP
  3. and thus inherits all the common properties defined in designware-pcie.txt.
  4. Required properties:
  5. - compatible: "fsl,imx6q-pcie", "fsl,imx6sx-pcie", "fsl,imx6qp-pcie"
  6. - reg: base address and length of the PCIe controller
  7. - interrupts: A list of interrupt outputs of the controller. Must contain an
  8. entry for each entry in the interrupt-names property.
  9. - interrupt-names: Must include the following entries:
  10. - "msi": The interrupt that is asserted when an MSI is received
  11. - clock-names: Must include the following additional entries:
  12. - "pcie_phy"
  13. Optional properties:
  14. - fsl,tx-deemph-gen1: Gen1 De-emphasis value. Default: 0
  15. - fsl,tx-deemph-gen2-3p5db: Gen2 (3.5db) De-emphasis value. Default: 0
  16. - fsl,tx-deemph-gen2-6db: Gen2 (6db) De-emphasis value. Default: 20
  17. - fsl,tx-swing-full: Gen2 TX SWING FULL value. Default: 127
  18. - fsl,tx-swing-low: TX launch amplitude swing_low value. Default: 127
  19. - fsl,max-link-speed: Specify PCI gen for link capability. Must be '2' for
  20. gen2, otherwise will default to gen1. Note that the IMX6 LVDS clock outputs
  21. do not meet gen2 jitter requirements and thus for gen2 capability a gen2
  22. compliant clock generator should be used and configured.
  23. - reset-gpio: Should specify the GPIO for controlling the PCI bus device reset
  24. signal. It's not polarity aware and defaults to active-low reset sequence
  25. (L=reset state, H=operation state).
  26. - reset-gpio-active-high: If present then the reset sequence using the GPIO
  27. specified in the "reset-gpio" property is reversed (H=reset state,
  28. L=operation state).
  29. Additional required properties for imx6sx-pcie:
  30. - clock names: Must include the following additional entries:
  31. - "pcie_inbound_axi"
  32. Example:
  33. pcie@0x01000000 {
  34. compatible = "fsl,imx6q-pcie", "snps,dw-pcie";
  35. reg = <0x01ffc000 0x04000>,
  36. <0x01f00000 0x80000>;
  37. reg-names = "dbi", "config";
  38. #address-cells = <3>;
  39. #size-cells = <2>;
  40. device_type = "pci";
  41. ranges = <0x00000800 0 0x01f00000 0x01f00000 0 0x00080000
  42. 0x81000000 0 0 0x01f80000 0 0x00010000
  43. 0x82000000 0 0x01000000 0x01000000 0 0x00f00000>;
  44. num-lanes = <1>;
  45. interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
  46. interrupt-names = "msi";
  47. #interrupt-cells = <1>;
  48. interrupt-map-mask = <0 0 0 0x7>;
  49. interrupt-map = <0 0 0 1 &intc GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>,
  50. <0 0 0 2 &intc GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>,
  51. <0 0 0 3 &intc GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
  52. <0 0 0 4 &intc GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>;
  53. clocks = <&clks 144>, <&clks 206>, <&clks 189>;
  54. clock-names = "pcie", "pcie_bus", "pcie_phy";
  55. };