Intel DPDK 目的是为了解决网络数据包的快速转发。他依赖于三个技术: poll方式的网卡驱动,大内存,无锁操作。
看看桥模式源码:
1、rte_eal_init初始化硬件。
2、l2fwd_parse_args 解析l2fwd使用的参数,使用了三个参数
l2fwd_enabled_port_mask 使用的端口,l2fwd_rx_queue_per_lcore,每一个lcore
的接收队列,timer_period 定时参数。
3、rte_get_timer_hz() 把时间转化为cycles数。
4、rte_pktmbuf_pool_create 创建mbuf接收内存池
5、rte_eth_dev_count()获取端口数目
6、l2fwd_dst_ports 端口全部初始化为0 然后0-1 2-3 等按照配置编写好固定的转发路径
7、lcore_queue_conf 每一个核的端口配置。每一个端口对应一个队列,如果
每一个核有多个接收队列,似乎是要配置多个对应的端口
8、初始化每一个端口的macd地址,TX 和RX的queue (ring),RX使用l2fwd_pktmbuf_pool来保存数据包,
TX使用tx_buffer放发送的数据包(通过rte_zmalloc_socket来分配)
9、rte_eth_dev_start 函数来开始设备
10、rte_eth_promiscuous_enable 来把接口在混杂模式
11、rte_each_mp_remote_launch(l2fwd_launch_one_lcore,NULL,CALL_MASTER)来启动收发数据包