【56】linux NTB 的测试工具

2024-03-23 05:10
文章标签 linux 56 测试工具 ntb

本文主要是介绍【56】linux NTB 的测试工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://www.kernel.org/doc/html/latest/driver-api/ntb.html
https://github.com/jonmason/ntb/wiki/Linux-NTB-HOWTO-build-and-install
https://github.com/jonmason/ntb/wiki/Linux-NTB-HOWTO-test
https://www.kernel.org/doc/html/latest/driver-api/ntb.html
1、NTB的概念和作用
  NTB全称non transparent bridge,是相对于transparent bridge来说的。简单说就是枚举的时候,到了NTB这个桥时,枚举事务就结束了,也就是该桥对于枚举事务不再透明了(说白了就是PCI域隔离)。主要作用:用来连接两个或者多个分离的memory系统(说白了就是地址转换)。现在的NTB的支持两个通用特性:doorbell reg和memory地址转换窗口,还有一些不通用的特性:scratchpad和message寄存器。
  Scratchpad寄存器是一个EP两端都可以读写的寄存器,可以用让对端设备和本段设备交换少量信息。
  Message寄存器也可以用来做同样的事情。
这两种寄存器提供了特殊的mask bit来防止信息被对端设备重写(也就是说同一时间只能有一端写)。
  Doorbell reg用让对控给本控发送中断(主要用来IO到达时,及时通知本控接收数据)。
  Memory windows寄存器用来translate 对对控内存的读写请求。
2、linux NTB driver软件栈
在这里插入图片描述
  上图可以看到linux NTB的软件栈,hardware目录是各个厂商具体的实现方式,NTB抽象出一个概念:ntb_dev,所有的hardware厂商要注册对应的OPS到ntb_dev->ops,这样可以提供统一的API,上层driver是看不到底层硬件具体操作(这种抽象是linux的核心思想,否者linux根本玩不转这么多硬件)。
3、NTB的测试工具
  linux kernel在drivers\ntb\test提供了三个测试工具:ntb_tool、ntb_pingpong、ntb_perf

3.1 NTB pingpong测试原理
  pingpong测试的原理很简单,ntb_pingpong.ko加载后会注册ntb_client pp_client。
pp_link_event-> pp_setup建立好pingpong数据结构,选择使用哪个port,选择doorbell哪写bit,然后挂上hrtimer pp_timer_func。
  本控Ping操作:
pp_timer_func–>pp_ping,把计数写对端的scratch reg,然后写doorebell request reg来触发对端产生doorbell中断,最后写doorbell mask reg 来enable本端的doorbell中断。
  对控Pong操作:
中断服务函数:ndev_interrupt-> ntb_db_event-> pp_db_event-> pp_pong。会读取scratchreg(其实就是对端写过来的计数),然后增加该计数,并写doorbell mask reg来禁止本端的doorbell中断,写 doorbell status 来清除本端的doorbell中断。最后挂hrtimer pp_timer_func,等待ping的爆发。
在这里插入图片描述
在这里插入图片描述
3.2. NTB perf原理
  ntb perf是使用CPU或者DMA通过NTB往对控搬移数据。
默认是使用cpu搬运数据,如果想使用DMA搬运数据需要制定模块参数use_dma为1:insmod ntb_perf.ko dyndbg=+p use_dma=1
  注意:ntb_perf的状态机写的比较土,必须两控同时加载ntb_perf.ko(可以使用secureCRT或者xshell发送交互命令到所有对话让两控同时加载),否者必然有一控的状态机走不完。使用DMA搬运数据的代码写错了,导致填写到描述符的目的地址是个非法地址,DMA无法使用。
解决目的地址非法的patch见
https://lore.kernel.org/patchwork/patch/1156715/
增加定位信息的patch见
https://lore.kernel.org/patchwork/patch/1168668/
怎么把patch合并到自己的代码中见:
https://blog.csdn.net/linjiasen/article/details/85262213

  使用CPU搬运数据的数据流如下,下图只是画了从主控到从控的数据流,从从控到主控的数据流也是一样的,只是CPU换成从控的CPU,地址映射使用的是从端的XLAT映射主控内存。
在这里插入图片描述
  使用DMA搬运数据的数据流如下,下图只是画了从主控到从控的数据流,从从控到主控的数据流也是一样的,只是DMA换成从控的NTBCCP,地址映射使用的是从端的XLAT映射主控内存。
在这里插入图片描述

这篇关于【56】linux NTB 的测试工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/837237

相关文章

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

linux解压缩 xxx.jar文件进行内部操作过程

《linux解压缩xxx.jar文件进行内部操作过程》:本文主要介绍linux解压缩xxx.jar文件进行内部操作,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、解压文件二、压缩文件总结一、解压文件1、把 xxx.jar 文件放在服务器上,并进入当前目录#

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE