成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Linux虛擬化KVM-Qemu分析之Virtqueue

云計(jì)算 虛擬化
Virtqueue這種設(shè)計(jì)思想比較巧妙,不僅用在virtio中,在AMP系統(tǒng)中處理器之間的通信也能看到它的身影。

 [[390061]]

本文轉(zhuǎn)載自微信公眾號(hào)「LoyenWang」,作者LoyenWang。轉(zhuǎn)載本文請(qǐng)聯(lián)系LoyenWang公眾號(hào)。

背景

  • Read the fucking source code! --By 魯迅
  • A picture is worth a thousand words. --By 高爾基

說(shuō)明:

  1. KVM版本:5.9.1
  2. QEMU版本:5.0.0
  3. 工具:Source Insight 3.5, Visio
  4. 文章同步在博客園:https://www.cnblogs.com/LoyenWang/

1. 概述

汪汪汪,最近忙成狗了,一下子把我更新的節(jié)奏打亂了,草率的道個(gè)歉。

  • 前邊系列將Virtio Device和Virtio Driver都已經(jīng)講完,本文將分析virtqueue;
  • virtqueue用于前后端之間的數(shù)據(jù)交換,一看到這種數(shù)據(jù)隊(duì)列,首先想到的就是ring-buffer,實(shí)際的實(shí)現(xiàn)會(huì)是怎么樣的呢?

2. 數(shù)據(jù)結(jié)構(gòu)

先看一下核心的數(shù)據(jù)結(jié)構(gòu):

  • 通常Virtio設(shè)備操作Virtqueue時(shí),都是通過(guò)struct virtqueue結(jié)構(gòu)體,這個(gè)可以理解成對(duì)外的一個(gè)接口,而Virtqueue機(jī)制的實(shí)現(xiàn)依賴于struct vring_virtqueue結(jié)構(gòu)體;
  • Virtqueue有三個(gè)核心的數(shù)據(jù)結(jié)構(gòu),由struct vring負(fù)責(zé)組織:
  1. struct vring_desc:描述符表,每一項(xiàng)描述符指向一片內(nèi)存,內(nèi)存類型可以分為out類型和in類型,分別代表輸出和輸入,而內(nèi)存的管理都由驅(qū)動(dòng)來(lái)負(fù)責(zé)。該結(jié)構(gòu)體中的next字段,可用于將多個(gè)描述符構(gòu)成一個(gè)描述符鏈,而flag字段用于描述屬性,比如只讀只寫等;
  2. struct vring_avail:可用描述符區(qū)域,用于記錄設(shè)備可用的描述符ID,它的主體是數(shù)組ring,實(shí)際就是一個(gè)環(huán)形緩沖區(qū);
  3. struct vring_used:已用描述符區(qū)域,用于記錄設(shè)備已經(jīng)處理完的描述符ID,同樣,它的ring數(shù)組也是環(huán)形緩沖區(qū),與struct vring_avail不同的是,它還記錄了設(shè)備寫回的數(shù)據(jù)長(zhǎng)度;

這么看,當(dāng)然是有點(diǎn)不太直觀,所以,下圖來(lái)了:

  • 簡(jiǎn)單來(lái)說(shuō),驅(qū)動(dòng)會(huì)分配好內(nèi)存(scatterlist),并通過(guò)virtqueue_add添加到描述表中,這樣描述符表中的條目就都能對(duì)應(yīng)到具體的物理地址了,其實(shí)可以把它理解成一個(gè)資源池子;
  • 驅(qū)動(dòng)可以將可用的資源更新到struct vring_avail中,也就是將可用的描述符ID添加到ring數(shù)組中,熟悉環(huán)形緩沖區(qū)的同學(xué)應(yīng)該清楚它的機(jī)制,通過(guò)維護(hù)頭尾兩個(gè)指針來(lái)進(jìn)行管理,Driver負(fù)責(zé)更新頭指針(idx),Device負(fù)責(zé)更新尾指針(Qemu中的Device負(fù)責(zé)維護(hù)一個(gè)last_avail_idx),頭尾指針,你追我趕,生生不息;
  • 當(dāng)設(shè)備使用完了后,將已用的描述符ID更新到struct vring_used中,vring_virtqueue自身維護(hù)了last_used_idx,機(jī)制與struct vring_avail一致;

3. 流程分析

3.1 發(fā)送

當(dāng)驅(qū)動(dòng)需要把數(shù)據(jù)發(fā)送給設(shè)備時(shí),流程如上圖所示:

①A表示分配一個(gè)Buffer并添加到Virtqueue中,①B表示從Used隊(duì)列中獲取一個(gè)Buffer,這兩種中選擇一種方式;

②表示將Data拷貝到Buffer中,用于傳送;

③表示更新Avail隊(duì)列中的描述符索引值,注意,驅(qū)動(dòng)中需要執(zhí)行memory barrier操作,確保Device能看到正確的值;

④與⑤表示Driver通知Device來(lái)取數(shù)據(jù);

⑥表示Device從Avail隊(duì)列中獲取到描述符索引值;

⑦表示將描述符索引對(duì)應(yīng)的地址中的數(shù)據(jù)取出來(lái);

⑧表示Device更新Used隊(duì)列中的描述符索引;

⑨與⑩表示Device通知Driver數(shù)據(jù)已經(jīng)取完了;

3.2 接收

當(dāng)驅(qū)動(dòng)從設(shè)備接收數(shù)據(jù)時(shí),流程如上圖所示:

①表示Device從Avail隊(duì)列中獲取可用描述符索引值;

②表示將數(shù)據(jù)拷貝至描述符索引對(duì)應(yīng)的地址上;

③表示更新Used隊(duì)列中的描述符索引值;

④與⑤表示Device通知Driver來(lái)取數(shù)據(jù);

⑥表示Driver從Used隊(duì)列中獲取已用描述符索引值;

⑦表示將描述符索引對(duì)應(yīng)地址中的數(shù)據(jù)取出來(lái);

⑧表示將Avail隊(duì)列中的描述符索引值進(jìn)行更新;

⑨與⑩表示Driver通知Device有新的可用描述符;

3.3 代碼分析

代碼的分析將圍繞下邊這個(gè)圖來(lái)展開(kāi)(Virtio-Net),偷個(gè)懶,只分析單向數(shù)據(jù)發(fā)送了:

3.3.1 virtqueue創(chuàng)建

  • 之前的系列文章分析過(guò)virtio設(shè)備和驅(qū)動(dòng),Virtio-Net是PCI網(wǎng)卡設(shè)備驅(qū)動(dòng),分別會(huì)在virtnet-probe和virtio_pci_probe中完成所有的初始化;
  • virtnet_probe函數(shù)入口中,通過(guò)init_vqs完成Virtqueue的初始化,這個(gè)逐級(jí)調(diào)用關(guān)系如圖所示,最終會(huì)調(diào)用到vring_create_virtqueue來(lái)創(chuàng)建Virtqueue;
  • 這個(gè)創(chuàng)建的過(guò)程中,有些細(xì)節(jié)是忽略的,比如通過(guò)PCI去讀取設(shè)備的配置空間,獲取創(chuàng)建Virtqueue所需要的信息等;
  • 最終就是圍繞vring_virtqueue數(shù)據(jù)結(jié)構(gòu)的初始化展開(kāi),其中vring數(shù)據(jù)結(jié)構(gòu)的內(nèi)存分配也都是在驅(qū)動(dòng)中完成,整個(gè)結(jié)構(gòu)體都由驅(qū)動(dòng)來(lái)管理與維護(hù);

3.3.2 virtio-net驅(qū)動(dòng)發(fā)送

  • 網(wǎng)絡(luò)數(shù)據(jù)的傳輸在驅(qū)動(dòng)中通過(guò)start_xmit函數(shù)來(lái)實(shí)現(xiàn);
  • xmit_skb函數(shù)中,sg_init_table初始化sg列表,sg_set_buf將sg指向特定的buffer,skb_to_sgvec將socket buffer中的數(shù)據(jù)填充sg;
  • 通過(guò)virtqueue_add_outbuf將sg添加到Virtqueue中,并更新Avail隊(duì)列中描述符的索引值;
  • virtqueue_notify通知Device,可以過(guò)來(lái)取數(shù)據(jù)了;

3.3.3 Qemu virtio-net設(shè)備接收

  • Guest驅(qū)動(dòng)寫寄存器操作時(shí),陷入到KVM中,最終Qemu會(huì)捕獲到進(jìn)行處理,入口函數(shù)為kvm_handle_io;
  • Qemu中會(huì)針對(duì)IO內(nèi)存區(qū)域設(shè)置讀寫的操作函數(shù),當(dāng)Guest進(jìn)行IO操作時(shí),最終觸發(fā)操作函數(shù)的調(diào)用,針對(duì)Virtio-Net,由于它是PCI設(shè)備,操作函數(shù)為virtio_pci_config_write;
  • virtio_pci_config_write函數(shù)中,對(duì)Guest的寫操作進(jìn)行判斷并處理,比如在VIRTIO_PCI_QUEUE_NOTIFY時(shí),調(diào)用virtio_queue_notify,用于處理Guest驅(qū)動(dòng)的通知,并最終回調(diào)handle_output函數(shù);
  • 針對(duì)Virtio-Net設(shè)備,發(fā)送的回調(diào)函數(shù)為virtio_net_handle_tx_bh,并在virtio_net_flush_tx中完成操作;
  • 通用的操作模型:通過(guò)virtqueue_pop從Avail隊(duì)列中獲取地址,將數(shù)據(jù)進(jìn)行處理,通過(guò)virtqueue_push將處理完后的描述符索引更新到Used隊(duì)列中,通過(guò)virtio_notify通知Guest驅(qū)動(dòng);
  • Virtqueue這種設(shè)計(jì)思想比較巧妙,不僅用在virtio中,在AMP系統(tǒng)中處理器之間的通信也能看到它的身影。

草草收?qǐng)隽耍禄匾?jiàn)。

參考

https://www.redhat.com/en/blog/virtqueues-and-virtio-ring-how-data-travels

Virtual I/O Device Version 1.1

責(zé)任編輯:武曉燕 來(lái)源: LoyenWang
相關(guān)推薦

2021-02-14 16:49:22

Linux虛擬化Virtio

2021-05-07 06:42:51

Vhost-NetLinux虛擬化

2020-11-23 07:19:15

Linux虛擬化KVM

2023-08-17 16:51:00

虛擬化QEMUKVM

2020-06-18 16:39:10

KVM虛擬化虛擬機(jī)

2015-09-25 16:18:36

2019-11-12 14:48:00

Linux桌面虛擬化KVM

2024-12-27 15:28:10

HBAFC-SAN存儲(chǔ)

2018-06-05 14:28:25

KVM嵌套虛擬化

2019-06-27 15:38:52

KVM虛擬化開(kāi)源

2013-03-07 10:02:13

IBMKVM

2013-05-23 13:56:12

IBMKVM特點(diǎn)

2012-12-28 10:18:03

LinuxXenKVM

2019-08-22 16:26:02

LinuxKVM虛擬化

2013-04-08 10:08:22

開(kāi)源虛擬化KVM

2013-05-29 15:33:01

開(kāi)源虛擬化KVM

2015-09-09 17:25:06

2015-09-18 09:33:03

2013-04-07 09:33:31

開(kāi)源虛擬化KVM

2020-01-02 10:34:32

Linux虛擬化Docker
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲福利一区二区 | 好姑娘影视在线观看高清 | 亚洲一区视频 | 日韩在线精品强乱中文字幕 | 日本久久精品 | 精品成人一区二区 | 美女国内精品自产拍在线播放 | 久久综合狠狠综合久久 | 亚洲最大的黄色网址 | 国产一区二区不卡 | jlzzjlzz欧美大全| 日韩电影一区 | 免费观看毛片 | 免费av观看 | 免费福利视频一区二区三区 | 精品国产乱码久久久久久蜜柚 | 天天玩天天操天天干 | 国产a区 | 成人在线视频一区 | 国产精品久久久久久影视 | 亚洲精品国产一区 | 欧美国产精品一区二区三区 | 精品一区二区在线看 | 欧美亚洲国产一区二区三区 | 另类在线 | 黑人巨大精品欧美一区二区免费 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 国产欧美在线观看 | 亚洲一区二区三区国产 | 国产精品日韩在线观看一区二区 | 成人三级视频在线观看 | 91综合在线观看 | 国产一区2区 | 亚洲成人精品视频 | 亚洲国产高清在线观看 | 高清视频一区二区三区 | 在线精品一区二区三区 | 噜噜噜噜狠狠狠7777视频 | 欧美中文字幕 | 国产成人av一区二区三区 | 欧美亚洲视频在线观看 |