• 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
  • 相关阅读:
    云服务器重启后无法获取IP地址怎么办?
    java计算机毕业设计个人连锁民宿信息管理系统设计与开发系统(修改)源码+mysql数据库+系统+lw文档+部署
    Springboot 之 JPA 多数据源实现
    Go | 函数(包)的使用
    设计模式-状态模式
    管理类联考——数学——汇总篇——知识点突破——数据分析——记忆
    CSS_背景属性
    YOLOv5 onnx \tensorrt 推理
    Pflag、Viper、Cobra 核心功能介绍
    java类加载过程
  • 原文地址:https://blog.csdn.net/qq_27087571/article/details/132760123