首页 > 其他分享 >pci p2p

pci p2p

时间:2023-10-07 11:00:12浏览次数:21  
标签:bridge struct whitelist host pci p2p p2pdma

概述

在2018年,针对pci支持p2pdma的驱动合入主线,没记错的话应该是4.20.
补丁如下:

commit 52916982af48d9f9fc01ad825259de1eb3a9b25e
Author: Logan Gunthorpe <[email protected]>
Date:   Thu Oct 4 15:27:35 2018 -0600

    PCI/P2PDMA: Support peer-to-peer memory

一、pci p2p DMA的条件

1.1内核配置

需要开启 CONFIG_PCI_P2PDMA 才能使用p2p的DMA。
需要设备具备内存,并以 ZONE_DEVICE 方式注册到内核中,暴露给驱动,需要注意的是,arm 默认不开启 CONFIG_ZONE_DEVICE,需要手动打开。

1.2 host bridge要求

从代码看,要求两个device 同属于同一个host_bridge,除此之外,还有一个白名单。

static bool host_bridge_whitelist(struct pci_dev *a, struct pci_dev *b,
				  bool warn)
{
	struct pci_host_bridge *host_a = pci_find_host_bridge(a->bus);
	struct pci_host_bridge *host_b = pci_find_host_bridge(b->bus);

	if (host_a == host_b)//caq:相同host brdige,没得说
		return __host_bridge_whitelist(host_a, true, warn);//caq:此时白名单检查传参为true

	if (__host_bridge_whitelist(host_a, false, warn) &&//caq:否则检查白名单
	    __host_bridge_whitelist(host_b, false, warn))//caq:此时传参为false
		return true;

	return false;
}
//caq:检查哪些host_bridge支持p2p
static bool __host_bridge_whitelist(struct pci_host_bridge *host,
				    bool same_host_bridge, bool warn)
{
	struct pci_dev *root = pci_host_bridge_dev(host);
	const struct pci_p2pdma_whitelist_entry *entry;
	unsigned short vendor, device;

	if (!root)
		return false;

	vendor = root->vendor;//caq:取vendorid
	device = root->device;//caq:取deviceid

	for (entry = pci_p2pdma_whitelist; entry->vendor; entry++) {
		if (vendor != entry->vendor || device != entry->device)
			continue;
		if (entry->flags & REQ_SAME_HOST_BRIDGE && !same_host_bridge)//caq:入参same_host_bridge 就是 true的话,则跳过
			return false;

		return true;//caq:如果 same_host_bridge 传参为true,则只要是在白名单之内的pci_host_bridge设备,都支持p2pdma
	}

	if (warn)//caq:如果没找到,则打印warning
		pci_warn(root, "Host bridge not in P2PDMA whitelist: %04x:%04x\n",
			 vendor, device);

	return false;
}

那么,是哪些设备在白名单之内呢?

static const struct pci_p2pdma_whitelist_entry {
	unsigned short vendor;
	unsigned short device;
	enum {
		REQ_SAME_HOST_BRIDGE	= 1 << 0,//caq:是否要求同一个host bridge
	} flags;
} pci_p2pdma_whitelist[] = {//caq:白名单列表
	/* Intel Xeon E5/Core i7 */
	{PCI_VENDOR_ID_INTEL,	0x3c00, REQ_SAME_HOST_BRIDGE},
	{PCI_VENDOR_ID_INTEL,	0x3c01, REQ_SAME_HOST_BRIDGE},
	/* Intel Xeon E7 v3/Xeon E5 v3/Core i7 */
	{PCI_VENDOR_ID_INTEL,	0x2f00, REQ_SAME_HOST_BRIDGE},
	{PCI_VENDOR_ID_INTEL,	0x2f01, REQ_SAME_HOST_BRIDGE},
	/* Intel SkyLake-E */
	{PCI_VENDOR_ID_INTEL,	0x2030, 0},//caq:不要求同一个host_bridge,也支持p2p
	{PCI_VENDOR_ID_INTEL,	0x2031, 0},
	{PCI_VENDOR_ID_INTEL,	0x2032, 0},
	{PCI_VENDOR_ID_INTEL,	0x2033, 0},
	{PCI_VENDOR_ID_INTEL,	0x2020, 0},
	{PCI_VENDOR_ID_INTEL,	0x09a2, 0},
	{}
};

简单这么一看,只有intel的某些host_bridge支持p2pdma,那么,amd能忍么?

1.3 cpu要求

前面说到intel 通过白名单添加host_bridge的方式来支持跨host_bridge的p2p dma,amd一看,他也要有,然后提交了如下patch:

commit 7d5b10fcb81e511ddf79c1c6b7f6efb282f80680
Author: Alex Deucher <[email protected]>
Date:   Mon Apr 6 15:42:01 2020 -0400

    PCI/P2PDMA: Add AMD Zen Raven and Renoir Root Ports to whitelist

    According to the hardware architect, pre-Zen parts support p2p writes and
    Zen parts support both p2p reads and writes.

    Add entries for Zen parts Raven (0x15d0) and Renoir (0x1630).

    Link: https://lore.kernel.org/r/[email protected]
    Signed-off-by: Alex Deucher <[email protected]>
    Signed-off-by: Bjorn Helgaas <[email protected]>
    Acked-by: Christian König <[email protected]>
    Acked-by: Huang Rui <[email protected]>

diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c
index b73b10bce0df..e8e444eeb1cd 100644
--- a/drivers/pci/p2pdma.c
+++ b/drivers/pci/p2pdma.c
@@ -282,6 +282,8 @@ static const struct pci_p2pdma_whitelist_entry {
 } pci_p2pdma_whitelist[] = {
        /* AMD ZEN */
        {PCI_VENDOR_ID_AMD,     0x1450, 0},
+       {PCI_VENDOR_ID_AMD,     0x15d0, 0},
+       {PCI_VENDOR_ID_AMD,     0x1630, 0},

        /* Intel Xeon E5/Core i7 */
        {PCI_VENDOR_ID_INTEL,   0x3c00, REQ_SAME_HOST_BRIDGE},

当前在此之前还添加了一个0x1450,但是加着加着amd缓过头来了,amd的zen架构之后,都支持跨host_bridge 来支持p2pdma,那岂不是白名单得一直加下去?
所以,amd干脆另起炉灶:

commit dea286bb71baded7d2fb4f090e3b9fd2c1ccac58
Author: Logan Gunthorpe <[email protected]>
Date:   Wed Jul 29 17:18:44 2020 -0600

    PCI/P2PDMA: Allow P2PDMA on AMD Zen and newer CPUs

    Allow P2PDMA if the CPU vendor is AMD and family is 0x17 (Zen) or greater.

    [bhelgaas: commit log, simplify #if/#else/#endif]
    Link: https://lore.kernel.org/r/[email protected]
    Signed-off-by: Logan Gunthorpe <[email protected]>
    Signed-off-by: Bjorn Helgaas <[email protected]>
    Reviewed-by: Alex Deucher <[email protected]>
    Cc: Christian König <[email protected]>
    Cc: Huang Rui <[email protected]>

diff --git a/drivers/pci/p2pdma.c b/drivers/pci/p2pdma.c
index e8e444eeb1cd..1ec61fced4c3 100644
--- a/drivers/pci/p2pdma.c
+++ b/drivers/pci/p2pdma.c
@@ -273,6 +273,19 @@ static void seq_buf_print_bus_devfn(struct seq_buf *buf, struct pci_dev *pdev)
        seq_buf_printf(buf, "%s;", pci_name(pdev));
 }

+static bool cpu_supports_p2pdma(void)
+{
+#ifdef CONFIG_X86
+       struct cpuinfo_x86 *c = &cpu_data(0);
+
+       /* Any AMD CPU whose family ID is Zen or newer supports p2pdma */
+       if (c->x86_vendor == X86_VENDOR_AMD && c->x86 >= 0x17)//caq:amd另起炉灶,只要是zen或者更新的架构,都支持,但比如zen被授权出去,host_bridge被第三方修改,能保证么?
+               return true;
+#endif
+
+       return false;
+}
+
 static const struct pci_p2pdma_whitelist_entry {
        unsigned short vendor;
        unsigned short device;
@@ -280,11 +293,6 @@ static const struct pci_p2pdma_whitelist_entry {
                REQ_SAME_HOST_BRIDGE    = 1 << 0,
        } flags;
 } pci_p2pdma_whitelist[] = {
-       /* AMD ZEN */
-       {PCI_VENDOR_ID_AMD,     0x1450, 0},
-       {PCI_VENDOR_ID_AMD,     0x15d0, 0},
-       {PCI_VENDOR_ID_AMD,     0x1630, 0},
-
        /* Intel Xeon E5/Core i7 */
        {PCI_VENDOR_ID_INTEL,   0x3c00, REQ_SAME_HOST_BRIDGE},
        {PCI_VENDOR_ID_INTEL,   0x3c01, REQ_SAME_HOST_BRIDGE},
@@ -473,7 +481,8 @@ upstream_bridge_distance(struct pci_dev *provider, struct pci_dev *client,
                                              acs_redirects, acs_list);

        if (map_type == PCI_P2PDMA_MAP_THRU_HOST_BRIDGE) {
-               if (!host_bridge_whitelist(provider, client))
+               if (!cpu_supports_p2pdma() &&
+                   !host_bridge_whitelist(provider, client))
                        map_type = PCI_P2PDMA_MAP_NOT_SUPPORTED;
        }

总而言之,就是zen系列之后的,全支持,不再跟intel那样加白名单了,有点霸气,但是不是还会改回来还未知,比如amd做了一款编号大于 0x17 的cpu,但是又不支持跨host_bridge的p2pdma咋办?

标签:bridge,struct,whitelist,host,pci,p2p,p2pdma
From: https://www.cnblogs.com/10087622blog/p/17745805.html

相关文章

  • stepci 试用
    stepci是一个api自动测试工具,以下是一个简单的试用试用支持的命令 package.json{"devDependencies":{"stepci":"^2.6.8"},"scripts":{"app":"exportSTEPCI_DISABLE_ANALYTICS=true&&......
  • stepci 开源api 自动测试框架
    stepci是基于nodejs开发的,开源api自动测试框架包含的特性语言无关 可以基于yaml,json,js定义支持多种框架 rest,graphl,grpc,trpc,soap自托管 可以集成到ci/cd中,同时可以自己部署与行可集成 可以很好的与其他工具集成说明stepci目前也支持负载测试(预览状态),同时还支持f......
  • 270-VC709E 基于FMC接口的Virtex7 XC7VX690T PCIeX8 接口卡
    一、板卡概述       本板卡基于Xilinx公司的FPGA XC7VX690T-FFG1761 芯片,支持PCIeX8、两组 64bit DDR3容量8GByte,HPC的FMC连接器,板卡支持各种FMC子卡扩展。软件支持windows,Linux操作系统。   二、功能和技术指标: 板卡功能参数内容主处理器XC7V690T-2FFG17......
  • crash —— 如何查看PCI设备拓扑?
    在linux系统上用lspci可以查看PCI设备信息,crash的dev命令也提供了这个功能。crash>dev-pROOTBUSBUSNAMEffff893eaeb430000000:00PCIDEVDO:BU:SL.FNCLASSPCI_IDTYPEffff88deaf8130000000:00:00.006008086:2020ROOT_PORTffff......
  • P2P协议的传输艺术
    FTP采用两个TCP连接来传输一个文件。控制连接:服务器以被动的方式,打开众所周知用于FTP的端口21,客户端则主动发起连接。该连接将命令从客户端传给服务器,并传回服务器的应答。常用的命令有:list——获取文件目录;reter——取一个文件;store——存一个文件。数据连接:每当一个文件在......
  • 【转_0916】验证工程师如何快速上手PCIe 【知乎】
    https://zhuanlan.zhihu.com/p/545522598 (2)PCIe的通道https://zhuanlan.zhihu.com/p/70125574 (3)LogicJitterGibbs https://www.zhihu.com/column/c_1274723658410524672 ......
  • PCI DSS 4.0 对云服务提供商的影响1 - A1 多租户服务提供商的附加 PCI DSS 要求
    对于某些类型的服务提供商而言,PCIDSS4.0版的一大变化是附录A1的范围发生了变化。在PCIDSSv3.2.1中,附录A1的标题是"共享托管服务提供商的附加PCIDSS要求",而在PCIDSSv4.0中,附录A1的标题是"多租户服务提供商的附加PCIDSS要求"。 虽然"共享主机提供商"和......
  • PCIe 5.0 SSD明年底杀入笔记本!慧荣主控用上6nm先进工艺
    PCIe5.0SSD的严重发热问题大家应该都不陌生,有实验显示无风扇时连续写入55秒之后就会罢工,一个重要原因就是群联E26主控采用了相对落后的12nm工艺,功耗和发热无法控制。这就导致PCIe5.0SSD现在只能用在桌面平台,而且基本离不开风扇的辅助。近日,慧荣披露了他们的PCIe5.0SSD主控......
  • 经典p2p下载工具:比特彗星(BitComet)
    比特彗星(BitComet)是一个运用了P2P下载技术的工具,BitComet比特彗星现在经过多年发展,已经充分发挥了下载工具的的大部分功能,并且BitComet比特彗星现在主要功能完全免费,更加符合大多数用户的需求。BitComet比特彗星软件特色长效种子独有的长效种子功能,能显著提高下载速度,延长种子寿......
  • .NET Core(C#)通过SharpCifs访问操作Windows(smb)共享目录方法代码
    .NETCore(C#)通过SharpCifs访问操作Windows(smb)共享目录方法代码本文主要介绍.NETCore中,使用SharpCifs访问windows共享目录或smb协义共享目录,或操作共享文件的方法代码。 1、SharpCifs的安装引用使用Nuget管理工具搜索"SharpCifs"=>找到选择"安装"相关文档:VS(Vis......