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
    评论
MT7620A是一款嵌入式芯片,支持PCIe接口,因此可以使用PCIe扩展板来增加更多的外设。下面是关于OpenWrt MT7620A PCIe驱动程序的详细分析: 1. 驱动文件 MT7620A的PCIe驱动程序位于OpenWrt的内核源代码中,路径为:`/target/linux/ramips/mt7620a/`,其中包含了以下文件: - pcie.c - pcie.h - pcie-mediatek.c - pcie-mt7620.c - pcie.c 其中,pcie-mediatek.c和pcie-mt7620.c是MT7620A PCIe驱动程序的主要实现文件。 2. 驱动框架 MT7620A PCIe驱动程序的框架主要包括以下几个部分: - PCIe控制器初始化:在pcie-mt7620.c中实现。 - PCIe PHY初始化:在pcie-mediatek.c中实现。 - PCIe端口初始化:在pcie-mt7620.c中实现。 - PCIe设备驱动:在pcie.c中实现。 3. 驱动程序分析 在MT7620A PCIe驱动程序的实现中,pcie-mt7620.c主要负责PCIe控制器的初始化和端口的初始化,而pcie-mediatek.c则负责PCIe PHY的初始化。以下是MT7620A PCIe驱动程序的详细分析: - pcie-mt7620.c 在pcie-mt7620.c中,主要实现了mt7620_pcie_init()函数,用于初始化PCIe控制器和PCIe端口。在该函数中,首先进行了PCIe控制器的硬件初始化,然后进行PCIe端口的初始化。 PCIe控制器的硬件初始化包括设置PCIe控制器的寄存器和使能相关时钟。PCIe端口的初始化包括设置PCIe端口的寄存器和使能PCIe端口。 - pcie-mediatek.c 在pcie-mediatek.c中,主要实现了mtk_pcie_phy_init()函数,用于初始化PCIe PHY。在该函数中,首先进行了PHY的硬件初始化,然后进行了PHY的软件初始化。 PHY的硬件初始化包括设置PHY的寄存器和使能PHY相关时钟。PHY的软件初始化包括设置PHY的参数和使能PHY。 - pcie.c 在pcie.c中,主要实现了PCIe设备驱动程序PCIe设备驱动程序可以通过PCIe总线与CPU相连接,用于管理和控制PCIe设备。PCIe设备驱动程序可以使用标准Linux设备驱动程序接口(如file_operations、ioctl等)来与用户空间进行交互。 4. 总结 以上是关于OpenWrt MT7620A PCIe驱动程序的详细分析。MT7620A PCIe驱动程序的实现主要涉及PCIe控制器的初始化、PCIe PHY的初始化、PCIe端口的初始化和PCIe设备驱动程序的实现等方面。如果你想更深入地了解MT7620A PCIe驱动程序的实现,可以阅读OpenWrt内核源代码中相关的文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值