pcie 驱动程序分析

本文介绍了海思3536 ARM系统中PCIe驱动的工作原理,从`hisi_pcie_init`函数分析,包括设备和驱动的注册,以及`pcie_init`中的硬件寄存器配置。讲解了`__arch_pcie_info_setup`完成的内存/IO基地址映射,`pci_common_init`中的PCI控制器初始化。重点在于PCIe配置空间的读写函数实现,这些函数使得访问PCIe配置空间成为可能。
摘要由CSDN通过智能技术生成
       PCIE 是外围设备互连(Peripheral Component Interconnect Express)的简称,作为一种通用的总线接口标准,在目前的计算机系统中得到了非常广泛的应用。PCIE  总线支持 3 个独立的物理地址空间:存储器空间, IO 空间和配置空间。 每个PCIE 设备都有一个配置空间,配置空间采用 Id 寻址方法,用总线号,设备号,功能号和寄存器号来唯一标识一个配置空间。配置空间只能由 host 桥来访问。

    <<Linux那些事儿之我是PCI>> 已经告诉我们如何从do_initcalls找到找到PCI 驱动的入口

postcore_initcall(pcibus_class_init);

postcore_initcall(pci_driver_init);

文件

函数

入口

内存位置

arch/i386/pci/acpi.c

pci_acpi_init

subsys_initcall

.initcall4.init

arch/i386/pci/common.c

pcibios_init

subsys_initcall

.initcall4.init

arch/i386/pci/i386.c

pcibios_assign_resources

fs_initcall

.initcall5.init

arch/i386/pci/legacy.c

pci_legacy_init

 

 

drivers/pci/pci-acpi.c

acpi_pci_init

arch_initcall

.initcall3.init

drivers/pci/pci- driver.c

pci_driver_init

postcore_initcall

.initcall2.init

drivers/pci/pci- sysfs.c

pci_sysfs_init

late_initcall

.initcall7.init

drivers/pci/pci.c

pci_init

device_initcall

.initcall6.init

drivers/pci/probe.c

pcibus_class_init

postcore_initcall

.initcall2.init

drivers/pci/proc.c

pci_proc_init

__initcall

.initcall6.init

arch/i386/pci/init.c

pci_access_init

arch_initcall

  • 3
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值