<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: iMX6 PCIe for a beginner... in i.MX Processors</title>
    <link>https://community.nxp.com/t5/i-MX-Processors/iMX6-PCIe-for-a-beginner/m-p/476190#M75559</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Please distinguish between root complex and endpoint drivers. What&lt;/P&gt;&lt;P&gt;pci-imx6.c implements is a root complex driver. It abstracts i.MX6&lt;/P&gt;&lt;P&gt;PCI hardware to the rest of the system allowing the standard kernel PCI&lt;/P&gt;&lt;P&gt;subsystem to work on i.MX6 platform. If you want to connect a custom&lt;/P&gt;&lt;P&gt;device to i.MX6, you neither need to re-implement the root complex driver,&lt;/P&gt;&lt;P&gt;nor to directly interact with it. PCI device drivers use platform-independent&lt;/P&gt;&lt;P&gt;Linux PCI subsystem services. It that sense, a correctly written PCI device driver&lt;/P&gt;&lt;P&gt;can operate on any supported hardware/platform/architecture, and any&lt;/P&gt;&lt;P&gt;PCI device driver can be taken as an example. For more details, refer&lt;/P&gt;&lt;P&gt;to i.MX Linux Reference Manual, Chapter 41 and to&lt;/P&gt;&lt;P&gt;Documentation/PCI/pci.txt.&amp;nbsp; Section 41.4.2 of i.MX Linux Reference Manual&lt;/P&gt;&lt;P&gt;mentions some peripherals tested on i.MX reference boards, look at their&lt;/P&gt;&lt;P&gt;drivers first.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Have a great day,&lt;BR /&gt;Platon&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 08 Jan 2016 12:15:17 GMT</pubDate>
    <dc:creator>bpe</dc:creator>
    <dc:date>2016-01-08T12:15:17Z</dc:date>
    <item>
      <title>iMX6 PCIe for a beginner...</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/iMX6-PCIe-for-a-beginner/m-p/476189#M75558</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I need to learn PCIe for the iMX6Q to communicate with an FPGA, EIM is not an option here. I am looking for some help. I know that the Kernel needs to be configured and support needs to be added for the Freescale driver in the Kernel. Where I am having trouble is how do I interact with the Freescale driver; or do I need to write my own? When looking at the pcie-imx6.c file there seems to be a lot of chip specific information as well as the .compatible being setup for the device tree.&lt;/P&gt;&lt;P&gt;When reading articles on Linux PCIe driver development the way a driver a written is different from the pcie-imx6.c file. Is there a simple PCIe example for the iMX6 anywhere?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Again, any help is appreciated.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Thu, 07 Jan 2016 22:55:10 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/iMX6-PCIe-for-a-beginner/m-p/476189#M75558</guid>
      <dc:creator>concerned12345</dc:creator>
      <dc:date>2016-01-07T22:55:10Z</dc:date>
    </item>
    <item>
      <title>Re: iMX6 PCIe for a beginner...</title>
      <link>https://community.nxp.com/t5/i-MX-Processors/iMX6-PCIe-for-a-beginner/m-p/476190#M75559</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Please distinguish between root complex and endpoint drivers. What&lt;/P&gt;&lt;P&gt;pci-imx6.c implements is a root complex driver. It abstracts i.MX6&lt;/P&gt;&lt;P&gt;PCI hardware to the rest of the system allowing the standard kernel PCI&lt;/P&gt;&lt;P&gt;subsystem to work on i.MX6 platform. If you want to connect a custom&lt;/P&gt;&lt;P&gt;device to i.MX6, you neither need to re-implement the root complex driver,&lt;/P&gt;&lt;P&gt;nor to directly interact with it. PCI device drivers use platform-independent&lt;/P&gt;&lt;P&gt;Linux PCI subsystem services. It that sense, a correctly written PCI device driver&lt;/P&gt;&lt;P&gt;can operate on any supported hardware/platform/architecture, and any&lt;/P&gt;&lt;P&gt;PCI device driver can be taken as an example. For more details, refer&lt;/P&gt;&lt;P&gt;to i.MX Linux Reference Manual, Chapter 41 and to&lt;/P&gt;&lt;P&gt;Documentation/PCI/pci.txt.&amp;nbsp; Section 41.4.2 of i.MX Linux Reference Manual&lt;/P&gt;&lt;P&gt;mentions some peripherals tested on i.MX reference boards, look at their&lt;/P&gt;&lt;P&gt;drivers first.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;BR /&gt;Have a great day,&lt;BR /&gt;Platon&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;-----------------------------------------------------------------------------------------------------------------------&lt;BR /&gt;Note: If this post answers your question, please click the Correct Answer button. Thank you!&lt;BR /&gt;-----------------------------------------------------------------------------------------------------------------------&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 08 Jan 2016 12:15:17 GMT</pubDate>
      <guid>https://community.nxp.com/t5/i-MX-Processors/iMX6-PCIe-for-a-beginner/m-p/476190#M75559</guid>
      <dc:creator>bpe</dc:creator>
      <dc:date>2016-01-08T12:15:17Z</dc:date>
    </item>
  </channel>
</rss>

