当前位置: 首页 > news >正文

DPDK主从进程模式 rte_mempool_put失败

版本:19.11.6

情景:主进程应用rte_mempool_create创建mempool,rte_mempool_get获取数据;从进程应用rte_mempool_put归还数据

问题:从进程rte_mempool_put无法归还数据

原因:DPDK通过rte_mempool_ops_table.ops来存储当前应用支持的mempool,这些mempool是跟编译时连接的librte_mempool库有关系的。如果主从进程连接的库不同,rte_mempool_ops_table.ops列表就不同。但是,DPDK是通过rte_mempool的ops_index成员来表示自己是用的哪个实现,而主从进程相同rte_mempool的ops_index是相同的。如果库不同,就导致rte_mempool的ops_index对应的实现不同。最终导致访问失败。

解决:将主从进程mempool连接库要保持一致。

心得:主从进程编译参数、连接库能保持一致就保持一致,别多事。

DPDK19.11.6 mempool链接库:
librte_mempool.a
librte_mempool_bucket.a
librte_mempool_dpaa.a
librte_mempool_dpaa2.a
librte_mempool_octeontx.a
librte_mempool_octeontx2.a
librte_mempool_ring.a
librte_mempool_stack.a

mempool的实现(以下内容来自chatGPT):

  1. ring:ring内存池是DPDK中最常用的内存池实现方式之一。它基于环形缓冲区的概念,提供了高效的数据包收发和处理能力。ring内存池适用于多核环境下的数据包处理应用程序。

  2. heap:heap内存池是一种通用的内存池实现方式,它使用动态内存分配来管理内存。heap内存池适用于需要动态分配和释放内存的应用程序。

  3. stack\lcore:stack_lcore内存池是一种特殊的内存池实现方式,它与特定的lcore(逻辑核心)相关联。每个lcore都有自己的内存池,用于存储与该lcore相关的数据。stack_lcore内存池适用于需要在多个lcore之间共享数据的应用程序。

  4. memzone:memzone内存池是一种用于在共享内存中分配内存的实现方式。它允许多个进程在共享内存中分配和访问内存块,用于实现进程间的通信和数据共享。

  5. dpaa(Data Path Acceleration Architecture):dpaa是一种特定于NXP QorIQ处理器的内存池实现方式。它利用了处理器的硬件加速功能,提供了高性能的数据包处理能力。dpaa内存池适用于在NXP QorIQ处理器上运行的DPDK应用程序。

http://www.lryc.cn/news/138477.html

相关文章:

  • ZooKeeper 的工作原理
  • 【业务功能篇73】分布式ID解决方案
  • Qt安卓开发经验技巧总结V202308
  • 【vue2】前端实现下载后端返回的application/octet-stream文件流
  • 【Java】SM2Utils(国密 SM2 工具类)
  • 『C语言入门』初识C语言
  • jira创建条目rest实用脚本
  • 红外/可见光图像配准融合
  • 更高效稳定 | 基于ACM32 MCU的编程直流电源应用方案
  • postgresql创建一个只读账户指定数据库
  • CSDN编程题-每日一练(2023-08-25)
  • 前端面试:【前端工程化】构建工具Webpack、Parcel和Rollup
  • 大型企业是否有必要进行数字化转型?
  • 05有监督学习——神经网络
  • JavaWeb_LeadNews_Day7-ElasticSearch, Mongodb
  • redux中间件理解,常见的中间件,实现原理。
  • 麒麟系统上安装 MySQL 8.0.24
  • vue 展开和收起
  • 限制立方样条(RCS)中的P for overall和P for nonlinear的计算
  • vue3+ts引入echarts并实现自动缩放
  • Compressor For Mac强大视频编辑工具 v4.6.5中文版
  • maven工程的目录结构
  • 5.1 webrtc线程模型
  • 【Linux网络】Cookie和session的关系
  • android 硬编码保存mp4
  • gitlab合并分支
  • 手撕 `np.transpose` : 三维数组的循环转置
  • 计算机竞赛 基于Django与深度学习的股票预测系统
  • CSS 小技能(一):HTML 两个图片竖着平铺、设置图片点击、设置滚动条颜色
  • 【论文阅读】CONAN:一种实用的、高精度、高效的APT实时检测系统(TDSC-2020)