• virtio代码分析(一)-qemu部分


    virtio内容众多,代码分布于qemu,linux,dpdk等中,而且分为frontend和backend,可以运行于userspace也可以运行于kernelspace,极其难以理解,不看代码只看原理性文档往往流于表面,只有真正看懂了代码才能理解virtio。

    qemu和linux中的virtio-net举例分析代码,这儿只分析qemu部分virtio代码,在qemu中创建一个virtio-net设备,tap作为backend,有2个queue,那么qemu中tx和rx各2个,再加1个controll queue就得创建5个queue了

    1. -netdev tap,id=hostnet0,queues=2
    2. -device virtio-net-pci,host_mtu=1450,mq=on,vectors=5,netdev=hostnet0,id=net0,mac=fa:16:3e:d8:fe:81,bus=pci.0,addr=0x3

    我们先看数据结构NetClientState,重点关注peer和incoming_queue

    1. struct NetClientState {
    2. NetClientInfo *info;
    3. int link_down;
    4. QTAILQ_ENTRY(NetClientState) next;
    5. NetClientState *peer;
    6. NetQueue *incoming_queue;
    7. char *model;
    8. char *name;
    9. char info_str[256];
    10. unsigned receive_disabled : 1;
    11. NetClientDestructor *destructor;
    12. unsigned int queue_index;
    13. unsigned rxfilter_notify_enabled:1;
    14. int vring_enable;
    15. int vnet_hdr_len;
    16. bool is_netdev;
    17. QTAILQ_HEAD(, NetFilterState) filters;
    18. };

    先看qemu中的参数-netdev,创建了2个TAPState,每个TAPState包含一个NetClientState,函数qemu_net_client_setup参数peer为空,所以创建的ncs中peer为空。

    1. net_tap_fd_init
    2. └─qemu_new_net_client
    3. └─qemu_net_client_setup//这个函数参数peer为NULL

    再看qemu的参数-device中有netdev=hostnet0,而-netdev中有id=hostnet0,根据name找到了刚才tap创建的2个NetClientState和queue个数为2

    1. typedef struct NICPeers {
    2. NetClientState *ncs[MAX_QUEUE_NUM];
    3. int32_t queues;
    4. }
  • 相关阅读:
    1.8 逻辑运算(Python)
    Vue3+tsx开发语法详解
    DQL(数据库查询)
    Django实现部门管理功能
    Qt时间和定时器
    Visual Studio首次运行报错
    Linux网络编程-数据链路层
    UnityAI——排队过窄洞
    微服务 Spring Cloud 8,开源RPC框架如何选型?
    vue ant前端定义数组 后端java 接受数组
  • 原文地址:https://blog.csdn.net/lingshengxiyou/article/details/127792637