首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Linux驱动之PCI子系统剖析

PCI总线常见于x86体系,本文默认面向的体系为x86,注意x86架构下IO与内存是独立编址的。 附: 本文默认读者熟悉Linux设备驱动模型,不熟悉的可以先阅读这两篇blog。...Linux驱动之I2C子系统剖析 Linux驱动之SPI子系统剖析 PCI寻址 PCI系统总体布局组织为树状,从CPU连接的Host Bridge引出PCI主桥,主桥连接的是PCI总线0,可以直接连接PCI...Linux内核启动时会从PCI设备的配置寄存器里读取内存/IO起始地址以及irq,并把这些信息赋值给struct pci_dev的相应成员来生成软件描述的PCI设备。...当linux系统启动时,会探测系统中的所有PCI设备,并为探测到的每个PCI设备做如下操作: 1.分配一个struct pci_dev结构体,用来表示相应的PCI设备 2.为这个结构体填充设备vendor...*dev); struct pci_error_handlers *err_handler; struct device_driver driver; struct pci_dynids

3.2K20

PCI PCI-X PCI-E区别「建议收藏」

PCIPCI-X、PCI-E区别 一、PCI总线 PCI总线标准是由PCISIG于1992年开发的,已经有超过8年的历史。 PCI的总带宽=33MHz×32BIT/8=133MB/S。...二、PCI-X总线 PCI-X是在增加了电源管理功能和热插拔技术的PCI V2.2版本的基础上,将PCI的总带宽由133MB/S增至1.066GB/s。...pci-x不是独立的,按照PCI总线的发展是:pci-pcix-pcie,他们都是为了提高PCI的传输速度的。...PCI-X是PCI总线的扩展架构,PCI-X频率不像PCI那样固定,而是可以随着设备的变化而变化的。PCI-X采用64位PCI总线,可以支 66,100,133MHz这些频率。...PCI-E也叫PCI-Express、PCIe,是由Intel提出来的,它是串行接口,不兼容PCI。 现在的趋势是PCI-E将替代PCIPCI-X以及AGP,就像当年PCI替代ISA一样。

1.6K40

Component之PCI Show

PCI,Peripheral Component Interconnect,在PC中广泛使用,几乎所有的主板产品上都带有这种插槽,主要用于连接显卡、网卡、声卡等外设 PCI总线是一种树型结构,并且独立于...PCI总线上可以挂接PCI设备和PCI桥,PCI总线上只允许有一个PCI主设备,其他的均为PCI从设备,而且读写操作只能在主从设备之间进行,从设备之间的数据交换需要通过主设备中转 VxWorks系统提供了一组命令来查看...PCI设备的信息,要想使用这些命令,在传统PCI驱动里提供了一个组件INCLUDE_PCI_CFGSHOW ?...两个网卡就是(PCI_CLASS_NETWORK_CTLR<<16)|(PCI_SUBCLASS_NET_ETHERNET<<8)=0x020000 ?...最后,pciConfigTopoShow()可以遍历PCI总线上的所有设备 ? 这正是: PCI设备好查看,不同版本有组件。 多个命令可调用,硬件信息来呈现。

2.1K60

PCIe“拍了拍”PCI- PCI和PCIe发展历史

PCI-X 66 66 MHz 64 1 533 PCI-X 133 133 MHz 64 1 1066 PCI-X 266 133 MHz 64 2 2132 PCI-X 533 133 MHz 64...深入理解PCI空间与处理器空间的不同是理解和使用PCI的基础。 3.扩展性强。PCI总线具有很强的扩展性。...在PCI总线中,Root Bridge可以直接连出一条PCI总线,这条总线也是该Root bridge所管理的第一条PCI总线,该总线还可以通过PCI桥扩展出一系列PCI总线,并以Root bridge...在同一条PCI总线上的设备间可以直接通信,并不会影响其他PCI总线上设备间的数据通信。隶属于同一颗PCI总线树上的PCI设备,也可以直接通信,但是需要通过PCI桥进行数据转发。...所以PCIe“拍了拍”PCI,就把PCI“拍在沙滩上”了。

1.2K40

PCI Express 系列连载篇(十二)

,包括PCI设备的正向译码与负向译码、处理器到PCI设备的数据传送、PCI设备的DMA操作、PCI桥的Combining、Merging和Collapsing。...PCI设备的数据传递使用地址译码方式,当一个存储器读写总线事务到达PCI总线时,在这条总线上的所有PCI设备将进行地址译码,如果当前总线事务使用的地址在某个PCI设备的BAR空间中时,该PCI设备将使能...如果这个地址在某个PCI设备的BAR空间中命中时,这个PCI设备将接收这个PCI总线请求。这个过程也被称为PCI总线的正向译码,这种方式也是大多数PCI设备所采用的译码方式。...以图3-2为例,当PCI设备11访问主存储器空间时,首先将存储器读写总线事务发送到PCI总线1上,而这个存储器地址显然不会在PCI总线1的任何PCI设备的BAR空间中,此时PCI桥1将认领这个PCI总线的数据请求...(1) PCI总线0发现其下的设备PCI桥4能够处理来自PCI总线0的数据请求,则PCI桥4将接管这个PCI写请求,并通过总线仲裁逻辑获得PCI总线4的使用权,之后将这个存储器写请求发向PCI总线4。

89610

PCI Express 系列连载篇(十四)

最近有很多大侠在交流群里讨论PCI总线,PCI作为高速接口之一,在当下的FPGA产品设计研发中,地位举足轻重,应用广泛,今天给大侠带来PCI Express 系列连载,今天带来第十四篇,PCI设备对不可...但是这些设置与PCI设备进行DMA操作时,是否进行Cache一致性操作并没有直接关系。 在x86处理器系统中,一个PCI设备进行DMA写操作,可以将数据从PCI设备写入到主存储器中。...PCI设备进行DMA写时,数据将直接进入主存储器,而PCI设备进行DMA读所读取的数据将直接从主存储器获得。...PCI设备对可Cache的存储器空间进行DMA读写 PCI设备向“可Cache的存储器空间”进行读操作的过程相对简单。...在这个处理器系统中,当PCI设备,如PCI设备01,进行DMA写操作时,数据将首先到达HOST主桥,而HOST主桥将首先接管该PCI设备数据访问并将其转换为FSB总线事务,并在Request Phase

1K10

linux命令讲解大全】206.PCI设备的配置与查询工具:setpci

setpci 查询和配置PCI设备的使用工具 补充说明 setpci命令是一个查询和配置PCI设备的使用工具。...显示指令执行的细节信息 -f:当没有任何操作需要完成时,不显示任何信息 -D:测试模式,并不真正将配置信息写入寄存器 -d:仅显示给定厂商和设备的信息 -s:仅显示指定总线、插槽上的设备或设备上的功能块信息 参数 PCI...设备:指定要配置的PCI设备 操作:指定要完成的配置操作 实例 Linux下调节笔记本屏幕亮度方法: 首先进入终端输入lspci命令,列出各种设备的地址: lspci 00:00.0 host bridge...bridge: Intel Corporation N10/ICH 7 Family PCI Express Port 1 (rev 02) 00:1c.1 PCI bridge: Intel Corporation...N10/ICH 7 Family PCI Express Port 2 (rev 02) ......

13310

PCI Express 系列连载篇(十九)

最近有很多大侠在交流群里讨论PCI总线,PCI作为高速接口之一,在当下的FPGA产品设计研发中,地位举足轻重,应用广泛,今天给大侠带来PCI Express 系列连载,今天带来第十九篇,PCIe设备的扩展配置空间以及第十六篇至第十九篇小结...PCIe设备的扩展配置空间 本系列在前十篇讲述了PCI设备使用的基本配置空间。这个基本配置空间共由64个字节组成,其地址范围为0x00~0x3F,这64个字节是所有PCI设备必须支持的。...事实上,许多PCI设备也仅支持这64个配置寄存器。...此外PCI/PCI-X和PCIe设备还扩展了0x40~0xFF这段配置空间,在这段空间主要存放一些与MSI或者MSI-X中断机制和电源管理相关的Capability结构。...PCI-X和PCIe总线规范要求其设备必须支持Capabilities结构。

92940

PCI Express 系列连载篇(八)

PCI总线的电气特性决定了在一条PCI总线上挂接的负载有限,当PCI总线需要连接多个PCI设备时,需要使用PCI桥进行总线扩展,扩展出的PCI总线可以连接其他PCI设备,包括PCI桥。...如在PCI总线x域上的PCI桥1、PCI设备01、PCI设备11、PCI桥2、PCI设备21和PCI设备22等都将共享一个4GB大小的空间。...除此之外在Linux系统中,ioremap函数的输入参数为存储器域的物理地址,而不能使用PCI总线域的物理地址。...而在pci_devàresource[bar].start参数中保存的地址已经经过PCI总线域到存储器域的地址转换,因此在编写Linux系统的设备驱动程序时,需要使用pci_devàresource[bar...在Linux系统中,设备驱动程序调用pci_enable_device函数,使能该寄存器的I/O和Memory Space位之后,才能访问该设备的存储器或者I/O地址空间。

1.3K21
领券