本次的工作是完成刚流片的FPGA中PCIe IP核的bring up,也就是芯片的中PCIe的第一个使用者,将PCIe IP核正常使用起来,并配合公司的EDA团队,完成PCIe IP核到用户的呈现。
        经过两个月的调试和文档阅读,对PCIe也有了初步的认识,对于PCIe的学习主要来自3个方面:
       1、 王齐老师的《PCI Express 体系结构导读》和王齐老师的博客http://blog.sina.com.cn/s/blog_6472c4cc0100qbvp.html。非常感谢王齐老师的书,对于学习PCIe协议无疑是最佳的学习资料。
      2、《PCI Express Base Specification 3.0》PCIe的标准协议。
      3、 Synopsys公司提供 PCIe ip相关的data sheet。
以下是对PCIe建立链接过程的记录,主要针对Sysnosys 的PCIe的IP,但是同时应该也有普遍的适用性:
1.1   端口身份的识别
该部分是PCIe 底层Core识别PCIe端口的过程,PCIe总线中的有3中角色:RC(root complex)、EP(end point)、switch。他们在PCIe总线中拓扑结构如下图所示:
PCIe的IP Core在上电后首要的任务就是通过外部的IO或者寄存器,识别自身在PCIe的系统中扮演的角色,不同的角色也决定其在后续的过程中不同的启动和配置流程。
作为用户,在例化这个IP核时,需要做的第一个事情就是通过接口配置PCIe的device_type。
1.2   关注时钟与复位
在使用PCIe的IP时,再需要关注的是该内核的时钟和复位过程。可能作为用户,该过程硬件已经帮你做完了,但是也最最好熟悉一下结构和流程,并确保core的内部时钟已经启动,复位已经成功。
在实际的应用过程中,测试的第一步就是将PCIe core的时钟拉到芯片外部进行测试。
1.3   Disable PCIe的LTSSM的状态机
LTSSM(Link Training and Status State Machine )是PCIe最为核心的一个状态机,PCIe总线在进行链路训练时,将使用LTSSM状态机。而在启动LTSSM之前,用户一般需要进行参数的配置,所以在Core启动后,先会将LTSSM状态机disable。
1.4   通过DBI配置参数
该部分是配置PCIe参数的部分,DBI(data bus interface)是synopsys定义的访问PCIe寄存器的接口,PCIe协议规定了两种配置空间:PCI Configuration Space和 PCIe Extend configuration Space。而往往IP的生成商,会加入一个属于自己的配置空间,synopsys添加的配置空间为:Port
 logic Synosys Register。
其中PCI Configuration Space中主要由:PCI configuration header、PCI Power Management Capability、PCI Express Capability 、MSI Capability、MSI-X Capability VPD Capability组成。
PCI configuration header:提供了关于Vendor ID和Device ID等信息,其中比较重要的是Base Address Register(BAR),该寄存器设计到PCIe设备的地址空间的分配。
PCI Power Management Capability:该部分是系统电源管理的寄存器,这些Capability一般都会包含一个Status寄存器、一个Control寄存器、一个Capability寄存器。其中control寄存器通常是需要用户配置的,而Capability主要是供用户访问,以知道当前部分的参数设置的情况,而status寄存器是提供用户访问,以获得当前部分(比如电源)的具体的状态。
PCI Express Capability:该结构存放了一些和PCIe总线相关的信,包括PCIe链路和插槽的信息。
MSI、MSI-X:为中断控制的capability,与Power Management capability寄存器的结构是类似的。
PCIe Extend configuration Space是PCIe设备独有的,PCI设备并不支持该结构,实际上绝大多数的PCIe设备也不支持该结构。
Port logic SynosysRegister:是synopsys公司针对自身的IP,定义的与接口相关的寄存器,该部分寄存器多与物理层相关。
在此时的测试过程中,以进行Loopback测试为例,主要需要设置的参数包括PCI configurationheader和Port logicSynosys Register。
1、  Set the PIPE Loopback Enable bit
2、  Set the Loopback Enable bit
3、  设置BAR地址分配寄存器。
1.5   启动LTSSM
app_ltssm_enable=1;LTSSM状态机的跳转如下图所示,而当状态机进入Loopback状态机后,表示PCIe工作正常。
1.6   检测LTSSM状态机
检测LTSSM状态的方式有两种:
1、  通过Port logic Synosys Register中寄存器Debug Register 0中的最低6bit查询
2、  通过cxpl_debug_info IO直接查询。
在确认LTSSM状态机进入Loopback之后,用户需要查询数据链路层的状态,通过PCI ExpressCapability register中的 Link status Register 的Data Link Layer Active位,可以确认PCIe数据链路层正常工作,用户可以进行TLP包的发送与接收。

PCIe 驱动流程(LTSSM)的更多相关文章

  1. andorid之摄像头驱动流程--MTK平台

    原文地址:andorid之摄像头驱动流程--MTK平台 作者:守候心田 camera成像原理: 景物通过镜头生产光学图像投射到sensor表面上,然后转为模拟电信号,经过数模变成数字图像信号,在经过D ...

  2. andriod之摄像头驱动流程

    camera成像原理: 景物通过镜头生产光学图像投射到sensor表面上,然后转为模拟电信号,经过数模变成数字图像信号,在经过DSP加工出来,然后在通过IO接口传输到CPU处理. 由于摄像头满足总线. ...

  3. android休眠唤醒驱动流程分析【转】

    转自:http://blog.csdn.net/hanmengaidudu/article/details/11777501 标准linux休眠过程: l        power managemen ...

  4. [RK3288][Android6.0] TS-ADC驱动流程小结【转】

    本文转载自:https://blog.csdn.net/kris_fei/article/details/55045936 Platform: RK3288OS: Android 6.0Kernel: ...

  5. [Android6.0][RK3399] 电池系统(三)电量计 CW2015 驱动流程分析【转】

    本文转载自:http://blog.csdn.net/dearsq/article/details/72770295 Platform: RK3399 OS: Android 6.0 Kernel: ...

  6. [RK3288][Android6.0] 系统按键驱动流程分析【转】

    本文转载自:http://blog.csdn.net/kris_fei/article/details/77894406 Rockchip的按键驱动位于 kernel/drivers/input/ke ...

  7. android MTK驱动背光唤醒流程

    在标准的android驱动中,睡眠唤醒流程非常清晰,能够较方便的更改lcd唤醒时间和led背光的点亮时间,但是也很容易出现问题,比如说闪屏,唤醒慢! 出现闪屏有两个原因 1. 开背光时间在唤醒lcd前 ...

  8. 以太网驱动的流程浅析(一)-Ifconfig主要流程【原创】

    以太网驱动的流程浅析(一)-Ifconfig主要流程 Author:张昺华 Email:920052390@qq.com Time:2019年3月23日星期六 此文也在我的个人公众号以及<Lin ...

  9. 以太网驱动的流程浅析(三)-ifconfig的-19错误最底层分析【原创】

    以太网驱动流程浅析(三)-ifconfig的-19错误最底层分析 Author:张昺华 Email:920052390@qq.com Time:2019年3月23日星期六 此文也在我的个人公众号以及& ...

随机推荐

  1. Mybatis Update操作返回值问题

    https://www.cnblogs.com/jpfss/p/8918315.html

  2. spring-boot入门总结

    1.org.springframework.web.bind.annotation不存在 错误的pom.xml <dependency> <groupId>org.spring ...

  3. 搭建自己的Docker registry(五)

    弄了一天,在网上查了很多资料,感觉都好复杂好复杂,一步一步踩坑踩出来就好了. 服务器:阿里云(香港) 环境:CentOS Linux release 7.4.1708 (Core) Docker:1. ...

  4. 访问器 & 修改器

    访问器 model /** * 定义一个访问器 当 Eloquent 尝试获取 title 的值时,将会自动调用此访问器(查詢時自動調用) * @author jackie <2019.02.1 ...

  5. dubbo 熔断,限流,降级

    1 写在前面 1.1 名词解释 consumer表示服务调用方 provider标示服务提供方,dubbo里面一般就这么讲. 下面的A调用B服务,一般是泛指调用B服务里面的一个接口. 1.2 拓扑图 ...

  6. linux下C语言多线程编程实例

    用一个实例.来学习linux下C语言多线程编程实例. 代码目的:通过创建两个线程来实现对一个数的递加.代码: //包含的头文件 #include <pthread.h> #include ...

  7. 《女神异闻录 5》的 UI 设计

    转自:https://www.zhihu.com/question/50995871?sort=created <女神异闻录5>是近两年最为火热的JRPG游戏之一,它的出色不仅在于剧情暗讽 ...

  8. Rest API的简单应用

    写在前面 最近一直在搞通过Rest api的方式读取sharepoint文档库中的内容.有些地方需要注意,在此做下记录. 步骤 启动sharepoint服务器的服务 这里可以使用脚本的方式进行启动,脚 ...

  9. 未预期的符号 `$'{\r'' 附近有语法错误

    ../runcmake: 行 2: $'\r': 未找到命令 ../runcmake: 行 3: 未预期的符号 `$'{\r'' 附近有语法错误 考虑到代码是从windows下一直过来的,脚本可能在格 ...

  10. wampserver_x86_3.0.6 允许外网访问配置教程

    1.打开wamp目录下的apache配置文件中的httpd.conf 用可以看行数的编辑器打开 大概244行: 改为 <Directory /> AllowOverride none Re ...