DPDK多核多线程机制简析
2016-06-26 09:05
295 查看
DPDK通过在多核设备上,创建多个线程,每个线程绑定到单独的核上,减少线程调度的开销,以提高性能。
DPDK的线程分为控制线程和数据线程,控制线程一般绑定到MASTER核上,主要是接受用户配置,并传递配置参数给数据线程等;数据线程主要是处理数据包。
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) < 0)
rte_panic("Cannot create pipe\n");
if (pipe(lcore_config[i].pipe_slave2master) < 0)
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 != 0)
rte_panic("Cannot create thread\n");
}
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
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) < 0)
rte_panic("Cannot create pipe\n");
if (pipe(lcore_config[i].pipe_slave2master) < 0)
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 != 0)
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
相关文章推荐
- JavaScript类型系统之布尔Boolean类型详解
- previous definition was here
- 山寨币交易平台开发
- 用Quartus II Timequest Timing Analyzer进行时序分析 :实例讲解
- C++中输入输出流及文件流操作笔记
- 解决:HttpClient导致应用出现过多Close_Wait的问题
- Ng机器学习 Week11 Application Example: Photo OCR
- 请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
- 内存四区之堆栈区
- MySQL数据库优化概述
- MySQL数据库优化概述
- 虚拟币交易平台开发
- 第一次练习打字(6月25号)真不好意思昨天一直再找回博客账号,好在找客服解决了!!
- C语言函数重载
- 纸牌游戏之六 游戏概述
- 纸牌游戏之六 游戏概述
- 纸牌游戏之六 游戏概述
- 【树链剖分/线段树】BZOJ1036-[ZJOI2008]树的统计Count
- 比特币交易平台开发
- 欧几里德算法