如何识别PCI/PCIE设备需要申请多大的地址空间?

news/2024/12/22 23:07:35/

1、PCI/PCIE设备的配置空间

(1)PCI/PCIE设备需要的资源都在配置空间里进行指定,其中需要的地址空间资源在配置空间的基地址寄存器里指定;
(2)参考博客:《PCI设备和PCI桥的配置空间(header_type0、header_type1)和配置命令(type0、type1)详解》;

2、PCI/PCIE的host计算出设备要申请的地址资源

2.1、读取设备基地址寄存器

在这里插入图片描述

(1)桥设备的配置空间也有2个基地址寄存器,非桥设备有6个基地址寄存器;
(2)基地址寄存器的位图含义如上,首先读出基地址寄存器的值,bit0是只读的,bit0是0代码申请内存空间地址,bit0是1表示申请I/O空间地址;
(3)如果是申请内存空间地址,则高28位是可以配置的,低4位表示固定的含义;如果是申请I/O空间地址,则高30位是可以配置的;

2.2、计算需要申请地址空间大小

(1)首先读出基地址寄存器的值,判断是要申请内存地址还是I/O地址;
(2)将0xFFFFFFFF写到基地址寄存器中,然后再读取出来;
(3)判断读取出来的值,高位有多少个1。因为有些bit位是只读的,所以不会被写成1;
(4)计算出需要分配的地址空间大小,将分配给设备的PCIE地址空间的基地址写到基地址寄存器;

2.3、举例

在这里插入图片描述

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

3、内存地址空间和I/O地址空间区别

内存地址空间:
(1)内存地址空间是可以支持预取和合并的;
(2)内存是你写1读出来就是1,不会自己改变;
I/O地址空间:
(1)I/O地址,更多的是反馈外部的状态,比如读取gpio引脚,这个引脚的高低状态是外部设备决定的,可以通过读取gpio引脚电平来得知外设状态;
(2)I/O地址是不支持预取和合并的。比如:要根据时序来先拉高再拉低,不能将两个动作合并成一个动作,只做最后拉低的动作;

4、内核中pcie的HOST驱动对地址分配的优化

(1)内核的PCIE控制器驱动程序,会扫描完挂载的所有设备,计算出每个设备需要的地址空间;
(2)因为申请的地址空间是需要对齐的,为了避免地址空间浪费,需要对地址空间分配的先后顺序进行排序,基本原则:先分配比较大的地址空间,再分配小的地址空间;
(3)比如现在要分配三个地址空间:1M、4K、2M。其中地址都有对齐要求,2M大小的地址空间要求首地址2M对齐,1M大小的地址空间要求首地址1M对齐,4K大小的地址空间要求首地址4K对齐。最优的分配顺序:先分配2M,再分配1M,最后分配4K,这样能最大程度避免因为地址对齐带来的地址空间的浪费;


http://www.ppmy.cn/news/1065165.html

相关文章

C语言基础之——指针(下)

前言:本篇文章将继续讲解有关指针的剩余基础知识。 学无止境,一起加油叭!! 目录 一.指针运算 1.指针 - 整数 2.指针的关系运算 3.指针 - 指针 二.指针与数组 三.二级指针 四.指针数组 总结 一.指针运算 指针运算包括以下三…

【Go 基础篇】Go语言循环结构:实现重复执行与迭代控制

介绍 循环结构是编程中的重要概念,它允许我们重复执行一段代码块,或者按照一定的条件进行迭代控制。Go语言提供了多种循环结构,包括for、while和do-while等,用于不同的场景下实现循环操作。本篇博客将深入探讨Go语言中的循环结构…

前端面试:【系统设计与架构】前端架构模式的演进

前端架构模式在现代Web开发中扮演着关键角色,它们帮助我们组织和管理前端应用的复杂性。本文将介绍一些常见的前端架构模式,包括MVC、MVVM、Flux和Redux,以及它们的演进和应用。 1. MVC(Model-View-Controller)&#x…

2023.8 - java - 多态

多态是同一个行为具有多个不同表现形式或形态的能力。 多态就是同一个接口,使用不同的实例而执行不同操作, 多态的优点 1. 可替换性2 可扩充性3. 接口性、灵活性、简化性4. 消除类型之间的耦合关系 多态存在的三个必要条件 继承重写父类引用指向子类…

ctfshow-web14

0x00 前言 CTF 加解密合集CTF Web合集 0x01 题目 0x02 Write Up 首先看到这个,swith,那么直接输入4,则会打印$url的值 然后访问一下 查看一下,发现完整的请求是http://c7ff9ed6-dccd-4d01-907a-f1c61c016c15.challenge.ctf.sho…

10.Oracle中decode函数

【函数格式】: decode ( expression, condition_01, result_01, condition_02, result_02, ......, condition_n, result_n, result_default) 【函数说明】: 若表达式expression值与condition_01值匹配,则返回result_01,…

《golang设计模式》第二部分·结构型模式-03-组合模式(Composite)

文章目录 1. 概述1.1 角色1.2 类图 2. 代码示例2.1 设计2.2 代码2.3 类图 1. 概述 将叶子节点和复合节点组合起来,定义一个抽象接口遍历他们 1.1 角色 Component(抽象构件):为叶子构件和复合构件声明接口,定义了结构…

Idea Maven 构建,运行Java程序,二次开发Jmeter

Idea Maven 构建 1. maven下载2. Idea 配置3. 配置Maven镜像4. 在Maven项目pom.xml中添加依赖5. 创建jar包,更新pom,执行代码 1. maven下载 【官网】https://maven.apache.org/download.cgi 【其他版本】https://dlcdn.apache.org/maven/maven-3/ 2. …