VIRTIO-SCSI代码分析(3)VIRTIO SCSI数据流处理

VIRTIO SCSI整体数据流如下:

VIRTIO-SCSI代码分析(3)VIRTIO SCSI数据流处理_第1张图片

IO请求下发过程

        虚拟机中通过FIO等下发IO请求,IO请求通过VFS/filesystem,BLOCK层,然后到SCSI层,传递给virtio-scsi驱动,virtio-scsi驱动通过virtioscsi_commit_rqs()下发IO请求,并通过vp_notify()通知QEMU中VIRTIO设备数据准备完毕。

        虚拟机中vp_notify()访问寄存器,它会陷入到hypervisor中,并分发到QEMU中,并最终由virtio_pci_notify_write()模拟操作,通过函数virtio_scsi_handle_cmd()将数据下发,这里如果支持IO_URING时,可以通过luring_co_submit()提交IO请求;如果支持AIO时,可以通过laio_co_submit()提供IO请求。

        QEMU提交IO请求如同普通物理机上用户态提交IO请求一样,依次经过文件系统层,BLOCK层,最终下发给硬件处理。

IO请求完成过程

        硬件完成IO处理后,IO完成信息依次通过SCSI层,BLOCK层,文件系统层,最终返回到QEMU中由函数virtio_scsi_command_complete()处理。该函数通过virtio_notify()往虚拟机注入中断,虚拟机产生中断后由函数vring_interrupt()进行中断处理,并调用virtscsi_req_done()作IO完成,并将IO完成信息依次通过SCSI层,BLOCK层,文件系统层,并最终返回给虚拟机中应用。

你可能感兴趣的:(VIRTIO,VIRTIO,SCSI)