~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/translations/zh_CN/PCI/pciebus-howto.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 .. SPDX-License-Identifier: GPL-2.0
  2 .. include:: <isonum.txt>
  3 .. include:: ../disclaimer-zh_CN.rst
  4 
  5 :Original: Documentation/PCI/pciebus-howto.rst
  6 
  7 :翻译:
  8 
  9  司延腾 Yanteng Si <siyanteng@loongson.cn>
 10 
 11 :校译:
 12 
 13 
 14 
 15 .. _cn_pciebus-howto:
 16 
 17 ===========================
 18 PCI Express端口总线驱动指南
 19 ===========================
 20 
 21 :作者: Tom L Nguyen tom.l.nguyen@intel.com 11/03/2004
 22 :版权: |copy| 2004 Intel Corporation
 23 
 24 关于本指南
 25 ==========
 26 
 27 本指南介绍了PCI Express端口总线驱动程序的基本知识,并提供了如何使服务驱
 28 动程序在PCI Express端口总线驱动程序中注册/取消注册的介绍。
 29 
 30 
 31 什么是PCI Express端口总线驱动程序
 32 =================================
 33 
 34 一个PCI Express端口是一个逻辑的PCI-PCI桥结构。有两种类型的PCI Express端
 35 口:根端口和交换端口。根端口从PCI Express根综合体发起一个PCI Express链接,
 36 交换端口将PCI Express链接连接到内部逻辑PCI总线。交换机端口,其二级总线代表
 37 交换机的内部路由逻辑,被称为交换机的上行端口。交换机的下行端口是从交换机的内部
 38 路由总线桥接到代表来自PCI Express交换机的下游PCI Express链接的总线。
 39 
 40 一个PCI Express端口可以提供多达四个不同的功能,在本文中被称为服务,这取决于
 41 其端口类型。PCI Express端口的服务包括本地热拔插支持(HP)、电源管理事件支持(PME)、
 42 高级错误报告支持(AER)和虚拟通道支持(VC)。这些服务可以由一个复杂的驱动程序
 43 处理,也可以单独分布并由相应的服务驱动程序处理。
 44 
 45 为什么要使用PCI Express端口总线驱动程序?
 46 =========================================
 47 
 48 在现有的Linux内核中,Linux设备驱动模型允许一个物理设备只由一个驱动处理。
 49 PCI Express端口是一个具有多个不同服务的PCI-PCI桥设备。为了保持一个干净和简
 50 单的解决方案,每个服务都可以有自己的软件服务驱动。在这种情况下,几个服务驱动将
 51 竞争一个PCI-PCI桥设备。例如,如果PCI Express根端口的本机热拔插服务驱动程序
 52 首先被加载,它就会要求一个PCI-PCI桥根端口。因此,内核不会为该根端口加载其他服
 53 务驱动。换句话说,使用当前的驱动模型,不可能让多个服务驱动同时加载并运行在
 54 PCI-PCI桥设备上。
 55 
 56 为了使多个服务驱动程序同时运行,需要有一个PCI Express端口总线驱动程序,它管
 57 理所有填充的PCI Express端口,并根据需要将所有提供的服务请求分配给相应的服务
 58 驱动程序。下面列出了使用PCI Express端口总线驱动程序的一些关键优势:
 59 
 60   - 允许在一个PCI-PCI桥接端口设备上同时运行多个服务驱动。
 61 
 62   - 允许以独立的分阶段方式实施服务驱动程序。
 63 
 64   - 允许一个服务驱动程序在多个PCI-PCI桥接端口设备上运行。
 65 
 66   - 管理和分配PCI-PCI桥接端口设备的资源给要求的服务驱动程序。
 67 
 68 配置PCI Express端口总线驱动程序与服务驱动程序
 69 =============================================
 70 
 71 将PCI Express端口总线驱动支持纳入内核
 72 -------------------------------------
 73 
 74 包括PCI Express端口总线驱动程序取决于内核配置中是否包含PCI Express支持。当内核
 75 中的PCI Express支持被启用时,内核将自动包含PCI Express端口总线驱动程序作为内核
 76 驱动程序。
 77 
 78 启用服务驱动支持
 79 ----------------
 80 
 81 PCI设备驱动是基于Linux设备驱动模型实现的。所有的服务驱动都是PCI设备驱动。如上所述,
 82 一旦内核加载了PCI Express端口总线驱动程序,就不可能再加载任何服务驱动程序。为了满
 83 足PCI Express端口总线驱动程序模型,需要对现有的服务驱动程序进行一些最小的改变,其
 84 对现有的服务驱动程序的功能没有影响。
 85 
 86 服务驱动程序需要使用下面所示的两个API,将其服务注册到PCI Express端口总线驱动程
 87 序中(见第5.2.1和5.2.2节)。在调用这些API之前,服务驱动程序必须初始化头文件
 88 /include/linux/pcieport_if.h中的pcie_port_service_driver数据结构。如果不这
 89 样做,将导致身份不匹配,从而使PCI Express端口总线驱动程序无法加载服务驱动程序。
 90 
 91 pcie_port_service_register
 92 ~~~~~~~~~~~~~~~~~~~~~~~~~~
 93 ::
 94 
 95   int pcie_port_service_register(struct pcie_port_service_driver *new)
 96 
 97 这个API取代了Linux驱动模型的 pci_register_driver API。一个服务驱动应该总是在模
 98 块启动时调用 pcie_port_service_register。请注意,在服务驱动被加载后,诸如
 99 pci_enable_device(dev) 和 pci_set_master(dev) 的调用不再需要,因为这些调用由
100 PCI端口总线驱动执行。
101 
102 pcie_port_service_unregister
103 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
104 ::
105 
106   void pcie_port_service_unregister(struct pcie_port_service_driver *new)
107 
108 pcie_port_service_unregister取代了Linux驱动模型的pci_unregister_driver。当一
109 个模块退出时,它总是被服务驱动调用。
110 
111 示例代码
112 ~~~~~~~~
113 
114 下面是服务驱动代码示例,用于初始化端口服务的驱动程序数据结构。
115 ::
116 
117   static struct pcie_port_service_id service_id[] = { {
118     .vendor = PCI_ANY_ID,
119     .device = PCI_ANY_ID,
120     .port_type = PCIE_RC_PORT,
121     .service_type = PCIE_PORT_SERVICE_AER,
122     }, { /* end: all zeroes */ }
123   };
124 
125   static struct pcie_port_service_driver root_aerdrv = {
126     .name               = (char *)device_name,
127     .id_table   = service_id,
128 
129     .probe              = aerdrv_load,
130     .remove             = aerdrv_unload,
131 
132     .suspend    = aerdrv_suspend,
133     .resume             = aerdrv_resume,
134   };
135 
136 下面是一个注册/取消注册服务驱动的示例代码。
137 ::
138 
139   static int __init aerdrv_service_init(void)
140   {
141     int retval = 0;
142 
143     retval = pcie_port_service_register(&root_aerdrv);
144     if (!retval) {
145       /*
146       * FIX ME
147       */
148     }
149     return retval;
150   }
151 
152   static void __exit aerdrv_service_exit(void)
153   {
154     pcie_port_service_unregister(&root_aerdrv);
155   }
156 
157   module_init(aerdrv_service_init);
158   module_exit(aerdrv_service_exit);
159 
160 可能的资源冲突
161 ==============
162 
163 由于PCI-PCI桥接端口设备的所有服务驱动被允许同时运行,下面列出了一些可能的资源冲突和
164 建议的解决方案。
165 
166 MSI 和 MSI-X 向量资源
167 ---------------------
168 
169 一旦设备上的MSI或MSI-X中断被启用,它就会一直保持这种模式,直到它们再次被禁用。由于同
170 一个PCI-PCI桥接端口的服务驱动程序共享同一个物理设备,如果一个单独的服务驱动程序启用或
171 禁用MSI/MSI-X模式,可能会导致不可预知的行为。
172 
173 为了避免这种情况,所有的服务驱动程序都不允许在其设备上切换中断模式。PCI Express端口
174 总线驱动程序负责确定中断模式,这对服务驱动程序来说应该是透明的。服务驱动程序只需要知道
175 分配给结构体pcie_device的字段irq的向量IRQ,当PCI Express端口总线驱动程序探测每
176 个服务驱动程序时,它被传入。服务驱动应该使用(struct pcie_device*)dev->irq来调用
177 request_irq/free_irq。此外,中断模式被存储在struct pcie_device的interrupt_mode
178 字段中。
179 
180 PCI内存/IO映射的区域
181 --------------------
182 
183 PCI Express电源管理(PME)、高级错误报告(AER)、热插拔(HP)和虚拟通道(VC)的服务
184 驱动程序访问PCI Express端口的PCI配置空间。在所有情况下,访问的寄存器是相互独立的。这
185 个补丁假定所有的服务驱动程序都会表现良好,不会覆盖其他服务驱动程序的配置设置。
186 
187 PCI配置寄存器
188 -------------
189 
190 每个服务驱动都在自己的功能结构体上运行PCI配置操作,除了PCI Express功能结构体,其中根控制
191 寄存器和设备控制寄存器是在PME和AER之间共享。这个补丁假定所有的服务驱动都会表现良好,不会
192 覆盖其他服务驱动的配置设置。

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php