AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 704828
Accepted
Chan Kim
Chan Kim
Asked: 2022-06-03 21:24:41 +0800 CST2022-06-03 21:24:41 +0800 CST 2022-06-03 21:24:41 +0800 CST

ARM linux系统中的PCI枚举,是BIOS还是linux做的?如果我在 linux 启动之前不为 PCIe 做任何事情怎么办?

  • 772

我在某处读到 PCI 枚举(查找总线和设备、功能)是由 x86 系统中的 BIOS 完成的。(今天我在韩国网络文档中再次看到它:https ://melonicedlatte.com/computerarchitecture/2019/11/27 /234300.html )。那么基于arm64的系统呢?我从https://patchwork.kernel.org/project/linux-pci/patch/[email protected]/发现arm64 使用 UEFI 进行 PCIe 初始化,还发现你-boot 支持 arm64 的 PCIe。那么,如果我不使用 UEFI 固件并使用 u-boot 并且在 u-boot 期间不对 PCIe 做任何事情,操作系统(linux)会进行枚举吗?(当然我为 PCI 和我的 PCIe 控制器配置了 linux)。

pci
  • 1 1 个回答
  • 351 Views

1 个回答

  • Voted
  1. Best Answer
    Marcus Müller
    2022-06-04T00:45:16+08:002022-06-04T00:45:16+08:00

    这里有很多东西要解压:

    PCI 枚举

    PCI与PCIe 不同。剩下的问题是关于 PCIe,所以我假设这是关于 PCIe,而不是 PCI。

    PCIe 严格来说没有枚举。因为它不是总线,而是点对点链接的网络,带有网桥(在计算机网络中,您可以将这些网络交换机称为网络交换机)。网络中的任何一点都不需要知道整个网络本身就可以运行。没有bus,所以没有bus enumeration。

    操作系统需要知道那里有哪些设备。这可以通过查询所有下游连接设备的根联合体来实现,每个设备本身都是所有下游连接设备的桥接器。

    这一切都可以由操作系统完成,它可以(与 PCI 不同,通常)在任何时候都没有损害,因此,操作系统本身就是这样做的。然后它所做的实际上是设置找到的硬件,为其提供内存映射区域等等。Linux 会进行这种枚举。

    存在一个例外:需要启动的设备(即网络接口、NVMe、图形控制器……),而固件甚至需要这些设备来运行操作系统。显然,首先需要找到这些。所以:您的主板固件也可以做到这一点。

    这与您的 CPU 架构无关——它只需要完成,无论您使用的是 x86 还是 arm。在我们通常所说的“嵌入式”设备上,您可以自己编写或配置您的固件,这样它就不必尝试找出哪些设备在哪里。它仍然需要与之交谈并设置设备。所以,同样的故事:“非全网络”枚举,而是预配置设备的枚举。

    在 x86 系统中由 BIOS 完成

    “BIOS”是您的系统固件的 API。实际固件可能会进行一些初始化,但它的“BIOS”部分早于 PCIe;它与此无关。

    “UEFI”只是另一个 API。更现代。

    arm64 使用 UEFI 进行 PCIe 初始化

    究竟什么是“PCIe 初始化”?你需要在这里非常精确。

    同样,ARM64 与您是否拥有 PCIe 或您的固件如何与 PCIe 交互无关。只是不同的东西。你可以拥有一个非常类似于 PC 的计算机架构和带有 ARM、PowerPC 或……CPU 的固件,你也可以拥有一个非常非 PC 架构的内部 x86。

    此外,UEFI 可以是任何东西;这个名字的字面意思是“可扩展的固件接口”。UEFI 模块提供了一个成熟的 Web 服务器!这些当然需要其他 UEFI 模块来提供 TCP/IP 堆栈,并且这些需要网络接口驱动程序,并且需要做一些 PCIe 枚举来查找网络接口并与之通信。
    但是,您也可以构建一个不包含此类内容的 UEFI,因此不需要进行 PCIe 枚举。

    但是:不知何故,某处,您将需要加载您的软件引导加载程序/操作系统。在许多计算机上,包含它的存储设备只能通过 PCIe 访问。因此,需要进行某种设置。

    在其他方面,例如嵌入式 x86 SoC 或某些 ARM SoC,引导加载程序位于某些 eMMC 上,并且或多或少直接连接到 CPU。这一切都取决于您的计算机的设计!

    CPU架构与外围接口设计关系不大。这些只是单独的事情。

    例如,Playstation 4 是 x86 并且具有 PCIe,但它不是 PC,不会尝试具有 BIOS,硬件没有与 PC 兼容的计时器或中断控制器。

    然后,如果我不使用 UEFI 固件并使用 u-boot a

    正如 UEF 接口名称所暗示的那样,UEFI 只是您的固件提供(或不提供)的软件 API。这与它在内部对硬件所做的事情几乎没有关系。

    • 0

相关问题

  • 是否可以通过 ExressCard 将 Mini PCIe 无线适配器连接到笔记本电脑?

  • 网卡时钟和PCIe 2.0总线有什么关系?

  • 如何查询启动时协商的 PCI MaxPayloadSize?

  • lsusb 列出同一 USB 集线器下不同 PCI 控制器上的设备

  • 设置似乎没有 I/O 端口的 PCIe 串行卡

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve