Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2164929
  • 博文数量: 374
  • 博客积分: 7276
  • 博客等级: 少将
  • 技术积分: 5669
  • 用 户 组: 普通用户
  • 注册时间: 2011-10-06 16:35
文章分类

全部博文(374)

文章存档

2013年(23)

2012年(153)

2011年(198)

分类: LINUX

2012-02-12 16:36:48

PCI 结构概述

PCI 全称 Peripheral Component Interconnect,本地话叫外围设备互联,顾名思义,其就是用于连接外设的,比如声卡、网卡等

现代 CPU 的速度都远远快于外围设备,这个速度间的不匹配就需要一个“连接器”(桥,Bridge)来缓冲一下。因此 CPU 都是直接和一个主桥相联,这个主桥下就是 0 号 PCI 总线。(MIPS 和主桥间是通过 64 bit SysAD 总线,在 x86 上是通过前端总线相联)。

PCI 设备寻址

PCI 设备由一个 8 bit 的总线号,一个 5 bit 的设备编号以及一个 3 bit 的功能编号来标识

因此一个主桥下最多拥有 256 个总线,这个对大型系统上而言是不够的,为此 Linux 引入 PCI 域的概念,每个 PCI 域可拥有 256 个总线,而每个总线可有 32 个设备,每个设备则可以是多功能板(如音频设备加 CD-ROM 驱动器,最多 8 个功能)。所以每个功能都可以用一个 16 bit 的值来标识,该值用作 PCI 总线内设备的唯一地址

例如在 Malta 板上,lspci 则有如下输出:

0000:00:00.0   Galileo GT64xxx Bridge(0x11ab/0x4620)
0000:00:0a.0   Intel PIIX4 Bridge (0x8086/0x7110)
0000:00:0a.1   Intel PIIX4 IDE (0x8086/0x7111)
0000:00:0a.2   Intel PIIX4 USB (0x8086/0x7112)
0000:00:0a.3   Intel PIIX4 Power (0x8086/0x7113)
0000:00:0b.0   AMD PCNET32 ethernet (0x1022/0x2000)
0000:00:0c.0   Crystal sound card (0x1013/0x6005)

0000 即为 PCI 域
00 则为 PCI Bus 号
00, 0a, 0b, 0c 则为设备号
0, 1, 2, 3 则为功能号,其皆属于 0a 这个设备,则 IDE, USB, Power 皆在同一 PIIX4 桥内

阅读(3099) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~