文档版本 开发工具 测试平台 工程名字 日期 作者 备注
V1.0 ise14.7 DBF板 Day2/PCIETest1 2016.03.31 lutianfei none
  • 参考资料:

    • Spartan 6 PCIE_V2.4 真教程(二)
    • 菜鸟5小时速成FPGA_PCIE设计高手教程.pdf
    • v6_pcie_ug517.pdf
    • PCI+EXPRESS体系结构导读.pdf
    • xapp1052.pdf


(一) 常见接口速度


(二)事务处理层协议理解

2.1 事物层空间说明

  • 1、PCI配置空间 :主要用于向系统提供设备自身的基本信息,并接受系统对设备全局状态的控制和查询。
  • 2、I/O空间 :主要包括设备控制寄存器状态寄存器,一般用于控制和查询设备的工作状态以及少量数据的交换。
  • 3、存储器空间:主要包括内存、显存、扩展ROM、设备缓冲区等,一般用于存放大量数据和进行数据块交换。
  • 4、消息空间 : 传递消息的时间信号机制空间。

2.2 配置空间概述

  • PCI设备只有在系统软件初始化配置空间之后,才能够被其他主设备访问。当PCI设备的配置空间被初值化之后,该设备在当前的PCI总线树上将拥有一个独立的PCI总线地址空间,即BAR(Base Address Register)寄存器所描述的空间。

2.2.1 配置空间寄存器说明

  • Vendor ID : 代表PCI设备的生产厂商
  • Device ID : 代表PCI厂商所生成的具体设备
  • Revision ID : 记录PCI设备的版本号,可以看成Device ID寄存器的扩展。
  • Class Code :供系统软件识别当前PCI设备的分类。 
    • Base Class Code : 将PCI设备分类为显卡、网卡、PCI桥等设备
    • Sub Class Code : 对这些设备进一步细分
    • Interface : 编程接口
  • Header Type:有8位,其中 
    • 7位:为1表示PCI设备为多功能设备,为0表示单功能设备。
    • 6~0位:0PCI Agent 设备的配置空间(普通PCI都此设置);1PCI桥使用的配置空间
  • Subsystem IDSubsystem Vendor ID:与Device ID 、Vendor ID功能类似,但是进一步细分了。 
  • Capabilities Pointer : PCIe设备必须支持此寄存器,存放一些与PCI设备相关的扩展配置信息。
  • Interrupt Pin :PCI通过了4个中断引脚INTA#,INTB#,INTC#,INTD#
  • Base Address Register0~5 : 保存PCI设备使用的地址空间的基地址,该基地址保存的是该设备在PCI总线域中的地址。
  • Command:PCI设备的命令寄存器,在初始化时,值为0,此时该PCI设备只能够接受配置请求总线事物外,无法接受任何存储器或者I/O请求。系统软件需要合理设置该寄存器之后,才能访问该设备的存储器或I/O空间。(寄存器具体功能查看《PCI+EXPRESS体系结构导读》p49)
  • Status :绝大多数是只读位,保存PCI设备的状态。

2.2.2 PCI总线配置概述

  • Type00配置请求:与HOST主桥或PCI桥直接相连的PCI Agent设备或PCI桥。
  • Type01配置请求:至少穿越一个PCI桥,访问没有与其直接相连的PCI Agent设备或PCI桥。

2.3 BAR空间概述

  • PC启动后,BIOS探测搜有的外设。对PCIe(PCI)设备来说,BIOS检测到板卡有多少个BAR空间,每个空间有多大,然后对应为这些BAR空间分配地址。对PCI设备来说,它能“看”到PCIe板卡的空间只有BAR空间,也只能访问这些BAR空间。
  • 板卡可以发送合法的 PCIe TLP 包,并得到 PC 端的响应;但是 PC 端访问板卡被局限在 BAR 空间内。

2.3.1 BAR空间与DMA空间映射关系例子

2.4 事物处理层概述

TLP(Transaction Layer Sepcification) 有三部分组成,帧头数据摘要(或者称 ECRC)。 TLP 头标长 3 或者 4 个 DW,格式和内容随事物类型变化;数据端为 TLP 帧头定义下的数据段,如果该 TLP 不携带数据,那该段为空。 Digest段( Optional)是基于头标、数据字段计算出来的 CRC,成为 ECRC,一般 Digest 段由 IP 核填充。所以, PCIe 的处理在用户层表现为处理 TLP 中头标数据段。 

2.4.1 存储器读、写请求TLP包头格式

  • Fmt与Type:规定事物类型、头标长度和是否有数据载荷。 
     

  • Posted与Non-Posted

    • Non-posted :即请求需要返回completion的响应包;
    • Posted:即不需要completion返回响应包。例如上面的存储器写入请求包和Message包都隶属于posted包。
  • ** Length : 1~1024DW,当值为**0:表示1024DW

  • DW BE

  • Requester ID : 包含“生成这个TLP报文”的PCIe设备的总线号(Bus Number)设备号(Device Number)功能号(Function Number)

  • Tag:Requester ID、Tag合起来组成Transaction ID,在同一时间段内,PCIe设备发出的每一个Non-Posted数据请求TLP,其Transaction ID必须唯一。也就是Tag必须唯一。

2.4.2 完成包报文头格式

 
* Byte0~3 与存储器、配置请求报文对应字段含义一致。 
Completer ID:该字段存放“发送完成报文”的PCIe设备的ID号。 
Byte Count 记录源设备还需要从目标设备中获得多少字节的数据就能完成全部数据传递。 
Lower Address:接收端必须使用存储器读写完成TLP的Low Address 字段,识别一个TLP中包含数据的起始地址。

2.3.3 配置读写请求报文头格式

  • 配置请求TLP第0~7字节与存储器请求类似,第8~11字节中的BUSDeviceFunction Number中存放该TLP访问的目标设备的相应号码。
  • Ext RegisterReigister Number存放寄存器号。
  • 配置请求报文的其他字段必须为一下值: 
     

2.4.4 消息请求报文头格式

    • PCIe总线规定了一下几类消息报文:

      • INTx Interrupt Signaling INTx中断信息包
      • Power Management 电源管理机能。
      • Error Signaling错误信息包
      • Locked Transaction Support 锁住交易的支持
      • Slot Power Limit Support插槽电源限制的支持
      • Vendor-Defined Messages制造商自行定义信息
    • INTx 中断消息报文 

    • 转载:http://blog.csdn.net/lutianfeiml/article/details/51025557

Virtex6 PCIe 超简版基础概念学习(一)的更多相关文章

  1. Virtex6 PCIe 超简版基础概念学习(二)

    Virtex6 PCIe 超简版基础概念学习(二) 分类:FPGAPCIe (2081)  (0)  举报  收藏 文档版本 开发工具 测试平台 工程名字 日期 作者 备注 V1.0 ise14.7 ...

  2. 【Spring源码解析】—— 简单工厂模式的BeanFactory的超简版实现

    一.什么是简单工厂模式 设计模式的核心是“分工”,通过分工将对象与职责划分的更细化,进而提升系统设计的可扩展性,使其更容易维护. 开闭原则:对扩展开放,对修改关闭:要增加一个新的处理逻辑,可以开一个新 ...

  3. react 组件的生命周期 超简版

    组件从被创建到被销毁的过程称为组件的 生命周期: 通常,组件的生命周期可以被分为三个阶段:挂载阶段.更新阶段.卸载阶段: 一.挂载阶段 这个阶段组件被创建,执行初始化,并被挂载到DOM中,完成组件的第 ...

  4. FFmpeg简易播放器的实现-最简版

    本文为作者原创:https://www.cnblogs.com/leisure_chn/p/10040202.html,转载请注明出处 基于FFmpeg和SDL实现的简易视频播放器,主要分为读取视频文 ...

  5. typescript 简版跳一跳

    typescript 简版跳一跳 学习typescript,第一步应该是学习官方文档,理解最基础的语法.第二步开始用typescript实现一些js+css 或者canvas类型的游行.现在开始我们用 ...

  6. js消除小游戏(极简版)

    js小游戏极简版 (1) 基础布局 <div class = "box"> <p></p> <div class="div&qu ...

  7. 手写一个简版 asp.net core

    手写一个简版 asp.net core Intro 之前看到过蒋金楠老师的一篇 200 行代码带你了解 asp.net core 框架,最近参考蒋老师和 Edison 的文章和代码,结合自己对 asp ...

  8. 腾讯云短信SDK-精简版

    /** * 腾讯云短信SDK-精简版 * 本模块使用-向腾讯云短信服务器发送请求 * @return json 腾讯服务器返回值-json字符串 */ private function send_sm ...

  9. linux发行版基础目录

    linux发行版基础目录 linux 基础目录 linux基础目录 目录 作用 / 根目录,起源 /boot linux引导启动目录 /lib 库目录 /bin 常用内部命令 /sbin 常用内部管理 ...

随机推荐

  1. ASP.NET Core 2.2 基础知识(十八) 托管和部署 概述

    为了方便演示,以 .NET Core 控制台应用程序讲解. 我们新建一个控制台应用程序,安装 "Newtonsoft.Json" Nuget 包,然后右键点击该项目,选择" ...

  2. HDOJ 4961 Boring Sum

    Discription Number theory is interesting, while this problem is boring. Here is the problem. Given a ...

  3. [Contest20171028]火神的鱼

    火神最爱的就是吃鱼了,所以某一天他来到了一个池塘边捕鱼.池塘可以看成一个二维的平面,而他的渔网可以看成一个与坐标轴平行的矩形.池塘里的鱼不停地在水中游动,可以看成一些点.有的时候会有鱼游进渔网,有的时 ...

  4. 【树链剖分】【分块】【最近公共祖先】【块状树】bzoj1984 月下“毛景树”

    裸题,但是因为权在边上,所以要先把边权放到这条边的子节点上,然后进行链更新/查询的时候不能更新/查询其lca. #include<cstdio> #include<cmath> ...

  5. Exercise02_15

    import javax.swing.JOptionPane; public class Distance { public static void main(String[] args){ Stri ...

  6. Solr6 +mmseg4j+IK-Analyzer + SQLserver +DIH 完全配置

    如今做任何一个系统都有搜索,而搜索界有著名的三剑客: solr/elasticsearch/sphinx solr/elasticsearch 为同一类的,都是基于lucene开发的产品,本人也早在几 ...

  7. 我的vim配置---jeffy-vim-v2.1.tar

    http://files.cnblogs.com/pengdonglin137/jeffy-vim-v2.1.rar 使用方法: 在Linux下,解压后,进入解压后的目录,执行./install.sh ...

  8. WebApi单元测试记录

    一.MessageHandler不一定是全局的,也可以只应用到指定的Router上 .定义一个handler // Pipelines HttpMessageHandler affiliateShip ...

  9. 常见社工破解WPA2密码方法及防范措施

    0×00前言 何为社工?社工是一种通过利用受害者心理弱点,如本能反应.好奇心.同情心.信任.贪婪等进行诸如欺骗.盗取.控制等非法手段的一种攻击方式.在无线安全中也可以利用社工做到许多非法操作.下面举几 ...

  10. 高仿手机QQ音乐之——Android带进度条的开关

    最新版的手机QQ音乐体验确实不错,发现首页播放按钮能够显示歌曲当前进度条.认为挺有新意.效果例如以下: 自己琢磨了下.能够用自己定义组件来实现,试着做了一下.效果例如以下: 整理了下思路.大概设计流程 ...