• pcie 总结


    用户空间pci 常用命令

    lspci 查看所有pci 设备
    lspci -t 树形查看所有设备
    lspci -s 00:1f.6 -vvv 查看某个设备所有信息
    lspci -s 00:1f.6 -vvv -xxx 增加16进制看看

    sudo cat /proc/iomen | grep PCI 查看所有地址映射

    如何确定pcie io空间 内存空间大小

    (1)读取出基地址寄存器的值,知道设备要申请内存地址空间;
    (2)将0xFFFFFFFF写进基地址寄存器,再读取出来;
    (3)从高位到低位依次判断读取出来的值,高12bit是1;
    (4)则设备需要申请的内存地址空间是2的20次方,也就是1M空间;
    (5)在PCIE地址空间中申请1M大小的地址,将首地址写到基地址寄存器中,CPU分配PCI地址,写到PCI设备的BAR里;
    补充:将基地址寄存器全部位写1,但是基地址寄存器有的位是只读的并且默认是0,所以可以通过先写全1再读取的方式来计算需要申请的地址空间大小;
    在这里插入图片描述

    pci 常见函数

    dev为PCI设备的软件抽象,bar的取值为0 ~ 5
    三个函数分别返回第bar个区域的首地址、尾地址和长度

    unsigned long pci_resource_start(struct pci_dev *dev, int bar);
    unsigned long pci_resource_end(struct pci_dev *dev, int bar);
    unsigned long pci_resource_len(struct pci_dev *dev, int bar);
    
    • 1
    • 2
    • 3

    返回和这个bar相关联资源的标识,申请内存
    IORESOURCE_IO:io端口
    IORESOURCE_MEM:内存

    int pci_read_config_byte(struct pci_dev *dev, int where, u8 *val)
    int pci_read_config_word(struct pci_dev *dev, int where, u16 *val)
    int pci_read_config_dword(struct pci_dev *dev, int where, u32 *val)
    int pci_write_config_byte(struct pci_dev *dev, int where, u8 val)
    int pci_write_config_word(struct pci_dev *dev, int where, u16 val)
    int pci_write_config_dword(struct pci_dev *dev, int where,  u32 val)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    获取pci 配置

    unsigned long pci_resource_flags(struct pci_dev *dev, int bar);
    
    • 1

    dma映射 申请dma

    pci_alloc_consistent
    
    • 1
  • 相关阅读:
    selenium 等待方式
    征文|@程序员,快来解锁过“中秋”的正确姿势!
    iPhone删除所有照片的高效三部曲
    HBase的flush(刷写)及compact(合并)机制
    【虚拟机】桥接模式下访问外网
    基本算法-冒泡排序
    优思学院|利用Excel进行双样本t检验
    vrrp协议与keepalived浅析
    K8s操作命令
    Git常用命令
  • 原文地址:https://blog.csdn.net/qq_27087571/article/details/132760123