DPDK通过在多核设备上,创建多个线程,每个线程绑定到单独的核上,减少线程调度的开销,以提高性能。

DPDK的线程分为控制线程和数据线程,控制线程一般绑定到MASTER核上,主要是接受用户配置,并传递配置参数给数据线程等;数据线程主要是处理数据包。

一、初始化

1、rte_eal_cpu_init()函数中,通过读取/sys/devices/system/cpu/cpuX/下的相关信息,确定当前系统有哪些CPU核,已经每个核属于哪个CPU Socket。

2、eal_parse_args()函数,解析-c参数,确认哪些CPU核是可以使用的,以及设置第一个核为MASTER。

3、为每一个SLAVE核创建线程,并调用eal_thread_set_affinity()绑定cpu。线程的执行体是eal_thread_loop()。eal_thread_loop()的主体是一个while死循环,调用不同模块注册到lcore_config[lcore_id].f的回调函数。

 RTE_LCORE_FOREACH_SLAVE(i) {

     /*
* create communication pipes between master thread
* and children
*/
if (pipe(lcore_config[i].pipe_master2slave) < )
rte_panic("Cannot create pipe\n");
if (pipe(lcore_config[i].pipe_slave2master) < )
rte_panic("Cannot create pipe\n"); lcore_config[i].state = WAIT; /* create a thread for each lcore */
ret = pthread_create(&lcore_config[i].thread_id, NULL,
eal_thread_loop, NULL);
if (ret != )
rte_panic("Cannot create thread\n");
}

二、注册

不同的模块需要调用rte_eal_mp_remote_launch(),将自己的回调处理函数注册到lcore_config[].f中。以l2fwd为例,注册的回调处理函数是l2fwd_launch_on_lcore()。

 rte_eal_mp_remote_launch(l2fwd_launch_one_lcore, NULL, CALL_MASTER);

DPDK每个核上的线程最终会调用eal_thread_loop()--->l2fwd_launch_on_lcore(),调用到自己实现的处理函数。

错误之处,欢迎指出。

转载请标明转自http://www.cnblogs.com/MerlinJ/p/4103790.html

最新文章

  1. C++远征之封装篇(下)
  2. Java抽象类的总结
  3. python 培训之HTTP
  4. ASP.NET弹出显示ex.Message异常信息 存在换行符和回车符处理办法。
  5. [BZOJ3671][UOJ#6][NOI2014]随机数生成器
  6. mysql优化SQL语句的一般步骤及常用方法
  7. C# WinForm捕获未处理的异常
  8. PHP技术开发微信公众平台
  9. GreenDao 3.2.0 的基本使用
  10. win7电脑关机时间长怎么办
  11. 剑指offer:反转链表
  12. Codeforces Round #498 (Div. 3)
  13. confluence6.3.1升级最新版本(6.15.1)
  14. P3258 [JLOI2014]松鼠的新家 (简单的点差分)
  15. Hadoop项目实战-用户行为分析之应用概述(一)
  16. configure编译选项
  17. css 规则中两个类连在一起是什么意思?
  18. Struts2框架的数据封装一之属性封装(属性封装的第二种方式:封装成javaBean)
  19. day8 异常处理
  20. 1 :2 Strust2—Demo

热门文章

  1. PHP的require()函数可以在一行代码中多次读取
  2. Citrix 服务器虚拟化之二十一 桌面虚拟化之部署Provisioning Services
  3. 《一课经济学》书摘笔记III
  4. Oracle中的约束
  5. go mobile 得生命周期事件
  6. OpenCV数据结构:CvMat,IplImage,CvArr的应用
  7. [SQL]patindex的用法
  8. Eclipse自定义Ant版本
  9. BC之Run
  10. oracle 内存结构 share pool sql解析的过程