PCI 总线学习笔记

PCI 总线学习笔记

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

转载请注明出处:http://blog.csdn.net/lg2lh/article/details/8042008

PCI的基本协议这里就不介绍了,由于一般的芯片协议都是集成好的,我仅仅须要大体了解即可,不须要做芯片,我感觉就不须要太了解协议。 

这里解说是基于PLX 的9054(9052)芯片为基础的,本人仅仅是入门,望批评指正。

PCI 总线学习笔记

一、地址映射与传输数据

上图中间部分是9054的内部结构图,9054实际上充当了一个“桥”的作用,即所谓的“桥片技术”。9054的作用事实上是把LOCAL总线端管理的一片地址,和PCI总线端管理的一片地址一一相应起来,即所谓的地址映射,而PCI总线与PC机的CPU管理的内存地址又是一一相应的,这样就实现了桥:CPU 地址 <=> PCI 地址 <=> LOCAL 地址。

一般系统PCI地址是CPU地址一部分,关于PCI地址与系统地址关系能够看还有一篇转载博文http://blog.csdn.net/lg2lh/article/details/8041029

上面仅仅是说了LOCAL总线与PCI总线以及CPU总线的相应关系,可是PCI技术的实际作用是进行传输数据。由内部结构图能够看出,9054内部没有什么存储单元,仅仅有几个FIFO。那系统是怎么进行传输数据的呢,大家都知道一段地址相应了一段存储空间,由上面地址映射能够知道,PCI芯片9054实际就是把LOCAL总线地址管理的外部存储空间的数据传输到PCI总线地址相应的内存空间中,及CPU的内存空间。或者是将内存中的传输数据到LOCAL总线管理的外部地址空间中去。Local端地址总线管理的存储空间一般由我们的控制芯片如FPGA或MCU提供。

二、PCI9054的基本知识

PCI9054的引脚主要分为3部分:PCI总线接口,LOCAL总线接口,及串行EEPROM总线接口。

LOCAL总线的数据宽度为32位,时钟可达50Mhz。以下介绍三种总线的作用,接口图例如以下图所看到的。

PCI 总线学习笔记

PCI总线接口:负责与PC机PCI总线通信,要接至PCI板卡的金手指处,对32位系统,金手指一共120跟信号线,A,B两面各60根,1-62,当中50,51处,无金手指引脚,共60根。

LOCAL总线接口:主要负责LOCAL端地址数据管理,与外围CPLD或MCU相连。

串行EEPROM总线接口:主要负责PCI9054的全部的寄存器配置,将寄存器配置烧写至EEPROM,PCI设备上电后载入EEPROM内容,完毕PCI9054的寄存器配置。主要包含:PCI配置寄存器,PCI本地配置寄存器,执行时间寄存器,DMA配置寄存器,I2O信息寄存器(消息队列寄存器?)。

 

PCI9054的PCI总线与LOCAL总线传输数据主要有三种模式:主模式,从模式,DMA模式。

而LOCAL总线的控制也有三种模式,M,C,J模式。当中经常使用C模式:地址数据总线非复用模式。

 

三、PCI9054的寄存器之间的关系

前面第一节讲到了PCI总线与LOCAL地址映射,以及PCI地址与PC机内存空间映射,一般PC机就觉得PCI地址就是内存空间地址,所以9054解决的就是把LOCAL总线管理的地址空间与内存空间地址相应起来,以下讲一下怎样通过9054寄存器配置映射关系。

要明白,是通过PLX_MON这个软件按要求配置好各寄存器内容,然后将数据烧写到EEPROM中,共17字。

首先看一下PCI9054寄存器主要有哪些,前面已说主要有五部分:PCI配置寄存器,PCI本地配置寄存器,执行时间寄存器,DMA配置寄存器,I2O信息寄存器(消息队列寄存器)

 

1、 PCI配置寄存器:主要用来配置与PCI总线相关的寄存器,比如,设备ID,供应商ID,类别代码,版本,系统供应商ID,子系统ID等。PCI设备ID为9054,供应商ID为10B5,类别代码0680。相应寄存器例如以下:

PCI 总线学习笔记

主要介绍一下最后四个寄存器,这四个主要完毕LOCAL端总线相关的寄存器在PCI总线的映射,以及LOCAL总线管理的地址空间在PCI总线上的映射。这四个寄存器都是由系统进行配置的,无法通过EEPROM配置。当中PCIBAR0,PCIBAR1,比較好理解,就是把LOCAL总线配置寄存器,DMA寄存器,执行寄存器映射到相应的内存空间去,配置的值就是他们在内存空间的起始地址

以下介绍PCIBAR2,PCIBAR3寄存器,后面会提到LOCAL总线管理了两部分地址空间,space0和space1。PCIBAR2,PCIBAR3就是把这两部分映射到PCI总线地址上,即把这两个空间映射到PC机的内存空间。PCIBAR2的配置值就是LOCAL总线端space0空间映射到PCI内存空间的起始地址,PCIBAR3的配置值则是LOCAL总线端space1空间映射到PCI内存空间的起始地址。而LOCAL总线端SPACE0和SPACE1在local端的实际地址及范围,则是由LOCAL配置寄存器决定。以下介绍LOCAL端配置寄存器。

 

2、 LOCAL配置寄存器

PCI 总线学习笔记

SPACE0相应的寄存器。

LAS0RRSPACE0基地址寄存器。这个寄存器与PCI总线的PCIBAR2寄存器相互相应,即LOCAL端的FPGA(MCU)就是通过訪问这个地址来訪问PCIBAR2所指的PCI内存空间

若此时LAS0RR设为0x80000001,而PCIBAR2设置值是0XE7000000.则对于PCI空间0XE7000000的訪问就会映射到对本地空间0x80000001的訪问。映射图例如以下。

PCI 总线学习笔记

LAS0BA:SPACE0空间的地址范围,在EEPROM的设置值是实际范围的补码

 

LAS1RR LAS1BA与上面两个同样,仅仅是用来映射SPACE1空间起始地址和范围的,不再赘述。

 

3、 DMA配置寄存器

PCI 总线学习笔记

4、 寄存器配置方法

最后介绍一下EEPROM配置字,配置字有长载入模式和额外长载入模式,当中长载入模式共17个长字,额外长载入模式则22个长字。当中LAS1RR LAS1BA这两个寄存器是在额外长载入模式中配置的。对PLX9054最重要的配置就是完毕对PCI寄存器和LOCAL寄存器的配置。17长字与22长字详细载入内容例如以下表。


PCI 总线学习笔记

PCI 总线学习笔记

PCI 总线学习笔记

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118116.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm选择解释器_python高级编程

    pycharm选择解释器_python高级编程一、IDE配置解释器二、配置pip镜像按照【配置永久生效】全局配置文件Window系统下,文件夹路径中输入%APPDATA%,若没有pip目录创建,并在里面创建文件pip.ini,内容如下[global]timeout=6000index-url=https://pypi.mirrors.ustc.edu.cn/simple/tr…

  • js nextSibling属性和previousSibling属性

    js nextSibling属性和previousSibling属性   1:nextSibling属性       该属性表示当前节点的下一个节点(其后的节点与当前节点同属一个级别);如果其后没有与其同级的节点,则返回null。      需要特别注意的是:该属性在不同的浏览器中的执行结果并不都相同,见下面例示:     先来看一个例子: [javascript] viewplain copy&lt;body&gt;  &lt;div&gt;  &lt;…

  • 让电脑报废的代码(30万行代码)

    作者:小傅哥博客:https://bugstack.cn沉淀、分享、成长,让自己和他人都能有所收获!????一、前言20万行代码写完,毕业了找一份工作不是问题!刚一毕业因为找不到工作,就得报名去参加Java培训的大有人在。并不是说参加培训就不好,只不过以你现在这个毕业的时间点参加,就会显得特别匆忙。因为你的压力既来自于培训还需要花家里一笔不小的费用,也有同班同学已经找到一份不错的工作开始赚钱的比对。大学四年其实有足够的时间让你学会编程,也能从一个较长时间的学习中,知道自己适合不适合做程序员。

  • npm 更新node 版本「建议收藏」

    npm 更新node 版本「建议收藏」mac系统需要切换到root用户sudo-u查看版本npm-vnode-v更新npm版本npminstall-gnpm更新node版本先清除npm缓存:npmcacheclean-f 然后安装n模块:npminstall-gn安装n时报错解决方案如何升级nodejs版本安装n模块报错npmERR!notsupU…

  • QOS流量整形「建议收藏」

    QOS流量整形「建议收藏」文章目录1、拓扑2、路由器配置整形命令3、交换机配置整形命令4、小结

    2022年10月22日
  • JAVA: String转JsonArray

    JAVA: String转JsonArrayStringstr=”…”;JsonArrayjsonArray=newJsonParser().parse(str).getAsJsonArray();JsonObjectjsonObject=jsonArray.get(0).getAsJsonObject();StringtempId=jsonObject.get(“SUBJECT_DIRECTOR_ID”).getAsString();

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号