首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux PCI和PCIe总线

()获得 – dev号(也叫slot)和func号一般通过宏PCI_DEVFN()合并成一个字节 – 因为PCI规范允许单个系统拥有高达256个总线,所以总线编号是8位。...pcibios_init x86 BIOS专门提供了针对PCI总线的操作,这些操作里就包括了总线枚举的整个过程,Linux kernel中的宏CONFIG_PCI_BIOS。...在系统加电以后自检时,就会完成对PCI总线的枚举,之后LinuxPCI配置空间的访问都是通过BIOS调用的形式进行,提供有这些功能和服务的BIOS就称之为PCI BIOS 。...需要注意的是Linux x86_64是不采用PCI BIOS访问PCI配置空间的,而是内核实现了直接访问PCI配置空间的函数(CONFIG_PCI_DIRECT)。...所以Linux x86驱动程序中pci_read_config_byte()最终调用的是pci_bios_read_config_byte()。

5.7K40

Linux驱动PCI子系统剖析

PCI总线常见于x86体系,本文默认面向的体系为x86,注意x86架构下IO与内存是独立编址的。 附: 本文默认读者熟悉Linux设备驱动模型,不熟悉的可以先阅读这两篇blog。...Linux驱动之I2C子系统剖析 Linux驱动之SPI子系统剖析 PCI寻址 PCI系统总体布局组织为树状,从CPU连接的Host Bridge引出PCI主桥,主桥连接的是PCI总线0,可以直接连接PCI...设备,或者再挂上PCI桥引出下一级PCI总线。...PCI规范允许一个系统最多拥有256条总线,每条总线最多带有32个设备,每个设备可以是最多8个功能的多功能板,但是对于大型系统而言总线数不够,故还支持PCI域,每个PCI域可最多支持256个总线。...驱动的注册接口为pci_register_driver(struct pci_driver *drv),当调用该接口后,会调用PCI总线下的match方法来进行匹配 static int pci_bus_match

3.2K20
您找到你想要的搜索结果了吗?
是的
没有找到

Linux笔记(21)| platform总线驱动分析

//本文主要参考《野火Linux实战开发指南》 上次跟大家分享了设备模型的一些东西,包括总线、设备、驱动等的一些概念,还有他们之间的联系。...因为在Linux当中,对于I2C、SPI、USB这些常见类型的物理总线来说,Linux内核会自动创建与之相应的驱动总线,因此I2C设备、SPI设备、 USB设备自然是注册挂载在相应的总线上。...它们也就没有相应的物理总线,比如led、rtc时钟、蜂鸣器、按键等等,Linux内核将不会为它们创建相应的驱动总线。...为了使这部分设备的驱动开发也能够遵循设备驱动模型,Linux内核引入了一种虚拟的总线——平台总线(platform bus)。...平台总线用于管理、挂载那些没有相应物理总线的设备,这些设备被称为平台设备,对应的设备驱动则被称为平台驱动

2.2K40

Linux 总线、设备、驱动模型的探究

设备驱动模型的需求 总线、设备和驱动模型,如果把它们之间的关系比喻成生活中的例子是比较容易理解的。...没错,Linux 内核里就是运用了这种设计思想去对设备和驱动进行适配隔离的,只不过在内核里我们不叫做适配层,而取名为总线,意为通过这个总线去把驱动和对应的设备绑定一起,如图: ?...基于这种设计思想,Linux 把设备驱动分为了总线、设备和驱动三个实体,这三个实体在内核里的职责分别如下: ?...看到这里,可能有些喜欢探究本质的读者又要问了,设备向总线注册了板级信息,驱动也向总线注册了驱动模块,但总线是怎么做到驱动和设备匹配的呢?接下来就讲下设备和驱动是怎么通过总线进行“联姻”的。...最底层是不同板子的板级文件代码,中间层是内核的总线,最上层是对应的驱动,现在描述板级的代码已经和驱动解耦了,这也是 Linux 设备驱动模型最早的实现机制,但随着时代的发展,就像是人类的贪婪促进了社会的进步一样

6.4K41

19.Linux-USB总线驱动分析

是因为windows自带了USB总线驱动程序, USB总线驱动程序负责: 识别USB设备,给USB设备找到对应的驱动程序 新接入的USB设备的默认地址(编号)是0,在未分配新编号前,PC主机使用0地址和它通信...然后USB总线驱动程序都会给它分配一个地址(编号) PC机想访问USB总线上某个USB设备时,发出的命令都含有对应的地址(编号) USB是一种主从结构。...其中usb_bus_type是一个全局变量, 它和我们之前学的platform平台总线相似,属于USB总线, 是Linux中bus的一种....如下图所示,每当创建一个USB设备,或者USB设备驱动时,USB总线都会调用match成员来匹配一次,使USB设备和USB设备驱动联系起来....id_table来匹配该USB设备 USB总线驱动程序大概流程就此结束,未完待续——分析完后下节开始写USB驱动

8.5K91

PCI总线的桥与配置(一)

但是这些HOST主桥所完成的最基本功能依然是分离存储器域与PCI总线域,完成PCI总线域到存储器域,存储器域到PCI总线域之间的数据传递,并管理PCI设备的配置空间。...当处理器访问PCI设备时,首先访问的是这个设备在存储器域上的PCI设备空间,之后HOST主桥将这个存储器域的PCI总线地址转换为PCI总线域的物理地址[3],然后再通过PCI总线事务访问PCI总线域的地址空间...PCI总线x域上的PCI总线地址0x0000-0000与PCI总线y域上的PCI总线地址0x0000-0000并不相同,而且这两个PCI总线地址经过HOST主桥反向映射后,得到的存储器地址也不相同。...PCI总线可以使用PCI桥扩展PCI总线,并形成一颗PCI总线树。在一颗PCI总线树上,有几个PCI桥(包括HOST主桥),就有几条PCI总线。...在一颗PCI总线树中,总线号由系统软件决定,通常与HOST主桥直接相连的PCI总线编号为0,系统软件使用DFS(Depth-First Search)算法扫描PCI总线树上的所有PCI总线,并依次进行编号

1.2K50

PCI总线的桥与配置(二)

PCI桥的配置空间在系统软件遍历PCI总线树时配置,系统软件不需要专门的驱动程序设置PCI桥的使用方法,这也是PCI桥被称为透明桥的主要原因。 在某些处理器系统中,还有一类PCI桥,叫做非透明桥。...,并将驱动程序的中断服务例程注册到操作系统中[4]。...除此之外在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.6K31

Linux内核平台总线设备驱动模型浅析

复习总线设备驱动模型,做了一点小笔记,大牛略过。 一、Linux系统的驱动框架的基础很大一部分是围绕着总线设备驱动模型展开的。...如支持mini2440的nandflash,dm9000等)    dev_t           devt;            // 设备号  }; 任何建立在平台总线设备驱动模型基础上的驱动代码...(如平台驱动PCI驱动,USB驱动,I2C驱动,SPI驱动等),它们的设备结构体(如platform_device, pci_dev,usb_device,i2c_device, spi_device...(如平台驱动PCI驱动,USB驱动,I2C驱动,SPI驱动等),它们的驱动结构体(如platform_driver, pci_driver,usb_driver,i2c_driver,spi_driver...) {     // 将驱动绑定在对应的总线上,主要工作把驱动(device_driver)添加到总线(bus_type)的klist_drivers链表中去      ret =bus_add_driver

1.9K30

PCI被“拍在沙滩上”谈并行总线和串行总线

串行总线和并行总线接口 在高速串行总线流行起来之前,芯片之间的互联通过系统同步或者源同步的并行接口传输数据,而所谓的并行接口,是指通信中一个或几个字节(8位)数据是在n*8条并行传输线上同时由源端传到目的地...并行总线与串行总线的区别对比及优缺点 很明显,并行通信的速度要比串行通信的速度快得多,效率更高,费时更少。...按照理论分析并行总线可以一次传多个数据位,而且时钟远远低于串行,理论应该成为目前高速传输信号的首选,那为什么像PCI、IEEE 1284、PATA等并行总线被PCIe、USB、SAT等串行总线所取代呢?...下面就针对并行总线为什么不能成为目前总线接口的主流? 图1‑5演示了系统同步(共同时钟)方式及源同步时钟方式并行总线接口。 ?...经上所述,并行总线在发高速传输的今天遇到了很多瓶颈,而这些瓶颈因为不能被解决,所以被串行总线所取代,但是将来随着一些工艺问题的解决,并行总线可能又被抬上“舞台”,像《PCIe“拍了拍”PCI- PCI

2.5K20

设备管理器里“SM总线控制器”、“其它PCI桥设备”驱动有问题

各自是“SM总线控制器”和“其它PCI桥设备“,主板是七彩虹的,芯片组是 geForce 7025的,南桥是 nForce 630a,用七彩虹官网的主板驱动装了没用。...用驱动人生先备份还有一个相同主板的机器的驱动。...得到 NVIDIA nForce PCI System Management_*.zip, NVIDIA Network Bus Enumerator_*.zip. 第一个是SM总线驱动。...第二个是其它PCI桥设备驱动。 将它们分别解压到不同文件夹,更新驱动时选相应的的文件夹。就ok了。...其它PCI桥设备驱动更新后,winxp就会识别出网卡,由于nVidia的主板是软网卡,必须装这个驱动才干识别到。 只是还是不清楚为什么装主板驱动没用,曾经仅仅要装主板驱动就基本ok了。

2.2K20

PCI设备驱动程序「建议收藏」

其实,只要你认真下去,虽然有些东西看不明白,但是对于你写PCI驱动来说,似乎“不那么重要”。因为,Linux内核对PCI总线已经有了完美的支持,你所需要做的内容是非常小的一部份。...Linux下的PCI总线,在系统上电的时候会逐一的扫描系统中存在的设备(包括设备和桥),总线号中断号都是这个时候分配给设备的,如果你是初学者,这个过程如果不是很明白,你大可以先略过,去找一个带有PCI总线的开发板...众所周知,Linux 2.6内核引入了总线驱动模型这一概念,如此,很多基于总线的设备驱动就分成了总线驱动和设备驱动两部分。...下面是我写的一个PCI总线驱动程序,注意是PCI设备识别时的驱动程序,这里并没有实现具体的功能驱动。...基于PCI总线的设备有很多种,但就PCI总线驱动这一块来说,都大同小异,实现了PCI总线驱动之后,再去继续做具体的设备驱动

2K21

I2C总线架构 之 总线驱动

这种做法完全不适应Linux的通用性的设计理念,对于Linux来讲:同样的事情我只做一遍,向外提供接口,不管你是什么IIC设备挂载那条IIC总线上,都可以用。...因此,这就需要Linux在代码架构上有非常严谨的模块化设计。 架构设计 在Linux设计中,将I2C代码框架分为三个部分:I2C总线、I2C核心、I2C驱动。...「I2C总线驱动(i2c adapter):」 根据平台定制的i2c驱动,其中包含i2c传输的算法设计。...I2C设备驱动对上和用户应用程序打交道,对下和I2C核心对接。 ? 本篇主要对IIC总线驱动的总结。...i2c总线结构体 Linux在分层中,必不可少的将每一层模块封装成一个结构体,然后将结构体作为一个与外接交互的桥梁。

1.4K30

服务器系统sm总线控制器驱动,sm总线控制器驱动

SM总线控制器是全称System Management,是主板控制芯片上的一个通信控制器,主板芯片技术中的一种,如果你遇到设备管理器中quotm总线控制器quot有一黄色问号,下载您所使用的主板最新的系统所对应的驱动程序...,在安装了正确的主机板驱动程序后,系统将能够正确识别您所有的芯片,问题即可解决。...sm总线控制器简介 几年前,Intel在其81x系列芯片组中就开始使用ICH芯片,并在ICH中运用System Management Bus(简称Smbus,系统管理总线)技术。...SM总线控制器是1995年由Intel提出的,应用于移动PC和桌面PC系统中的低速率通讯。它主要是希望通过一条廉价并且功能强大的总线(由两条线组成),来控制主板上的设备并收集相应的信息。...“Intel Software Installation Utility”,可以在主板驱动盘 sm总线控制器驱动安装方法 1.到本站下载安装,打开安装程序,点击下一步继续安装 2.点击yes进行下一步

1.1K30

linux设备驱动程序注冊过程具体解释

Linux驱动程序注冊过程,大致分为两个步骤: 模块初始化 驱动程序注冊 以下以内核提供的演示样例代码pci-skeleton.c,具体说明一个pci设备驱动程序的注冊过程。...在介绍注冊函数之前,必需要具体说明下linux总线设备驱动模型,否则以下的内容非常难描写叙述清楚。...2.1 linux总线设备驱动模型 关于总线设备驱动模型,非常多书上都有具体的解说,可是都非常抽象,非常难理解(至少我是这样觉得的)。以下我尽量用最简单的方法来说明相关内容。...linux内核中分别用struct bus_type,struct device和struct device_driver来描写叙述总线、设备和驱动。...对照上面的三个结构体,你会发现:总线中既定义了设备,也定义了驱动;设备中既有总线,也有驱动驱动中既有总线也有设备相关的信息。那这三个的关系究竟是什么呢?

2.2K20

计算机总线控制驱动,什么是sm总线控制器,总线控制器驱动怎么安装?「建议收藏」

如果您的设备管理器中”sm总线控制器”有一黄色问号,那么你就可以下载这款Intel主板上的SM总线控制器驱动程序(含64位)来进行安装了! 什么是sm总线控制器?...说白了,sm总线控制器是主板驱动的一部分,如果你的设备管理器里也是一个问号,建议你重新安装一下计算机的主板驱动即可。...sm总线控制器在XP中一般不会很好的被自动安装驱动程序(不像很多USB等都可以在XP自带的驱动库里自动识别),需要单独安装。 总线控制器驱动怎么安装?...SM总线控制器是主板控制芯片上的一个通信控制器。今天我们来说说SM总线控制器驱动的安装。...下面再次打开设备管理器,再SM总线控制器上点击右键,更新驱动程序—否,暂时不,下一步—选择从列表或指定位置安装,下一步—具体选项看下图: 然后确定,下一步!

6.3K20

PCI Express 系列连载篇(二十三)PCIe总线的事务层

最近有很多大侠在交流群里讨论PCI总线PCI作为高速接口之一,在当下的FPGA产品设计研发中,地位举足轻重,应用广泛,今天给大侠带来PCI Express 系列连载,今天带来第二十三篇,PCIe总线的事务层...PCIe总线的事务层 ? TLP中与数据负载相关的参数 在PCIe总线中,有些TLP含有Data Payload,如存储器写请求、存储器读完成TLP等。...因为PCIe总线规定EP在进行存储器读请求时,需要具有足够大的缓冲接收来自目标设备的数据。...第二十篇至第二十三篇小结 本章重点介绍PCIe总线的事务层。在PCIe总线层次结构中,事务层最易理解,同时也与系统软件直接相关。 [1] 这是流量控制Infinite FC Unit的要求。...PCI Express 系列连载篇(二十三)就到这里结束,明天继续带来第二十四篇,包括MSI和MSI-X中断机制相关内容。各位大侠,明天见!

2.3K20

Linux驱动:你应该先了解驱动模型

[导读] Linux设备林林总总,嵌入式开发一个绕不开的话题就是设备驱动开发,在做具体设备驱动开发之前,有必要对Linux驱动模型有一个相对清晰的认识,将会帮助驱动开发,明白具体驱动接口操作符相应都做些什么...Linux内核驱动程序模型是先前在内核中使用的所有不同驱动程序模型的统一。 它旨在通过将一组数据和操作整合到全局可访问的数据结构中,来扩展基于基础总线来桥接设备驱动程序。.../include/linux/Device.h 定义设备驱动主要数据结构 bus_type:抽象描述总线类型,如USB/PCI/I2C/MMC等 device_driver:实现具体连接在总线上的设备驱动...,具体的驱动USB/I2C/PCI/MMC等: 注册总线,利用bus_register注册总线,bus_unregister删除总线。...设备驱动注册到总线上时,将在sysfs管理总线/设备/设备驱动的层次关系,以PCI为例: /*在总线上注册的驱动程序会在总线驱动程序目录中获得一个目录*/ /sys/bus/pci/

3.2K10
领券