PMD: eth_ixgbevf_dev_init(): VF Initialization Failure: -15
EAL: Error - exiting with code: 1
Cause: Requested device 0000:01:10.0 cannot be used
在DPDK源码目录下执行grep -r “eth_ixgbevf_dev_init” ./搜索代码报错位置如下:
问题原因:-15是#define IXGBE_ERR_RESET_FAILED -15网卡PF reset失败;
解决办法:最终确认是PF没有UP导致,ifconfig或ip link set xxx up后问题消失;
问题二:
在82599上创建了两个VF之后,使能多队列为4,启动DPDK时多队列配置出现错误:
PMD: ixgbevf_dev_rx_init(): The number of Rx queue invalid, it should be power of 2
PMD: ixgbevf_dev_start(): Unable to initialize RX hardware (-1)
问题原因:gdb查看网卡队列初始化为0,并且没有走到rte_eth_dev_rx_queue_config函数,在rte_eth_dev_configure函数中判断dev_conf->intr_conf.lsc地方返回;
(gdb) p rte_eth_devices[1]->data->nb_rx_queues
$7 = 0
(gdb) p dev_conf->intr_conf.lsc
$1 = 1
解决办法:去掉rte_eth_conf port_conf里的全局配置.intr_conf = {.lsc =1}关闭lsc中断;
问题三:
在82599或I350上创建了两个VF之后,启动DPDK注册完成接口后无法正常UP;
问题原因:虚拟网卡VF注册最后没有正常的调用OPEN函数,或者网口扫描读取状态寄存器不对;
万兆和千兆的状态更新函数获取的都是PF的寄存器状态:
解决办法:保证正常的调用OPEN函数和网口扫描读取状态寄存器即可。
如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!
加入交流群
请使用微信扫一扫!