(1)CPU读取发送侧描述符tx_ring队列,检查DD标志是否为1,为1则说明发送完毕
(2)针对发送完毕的描述符需要释放该描述符里对应的缓冲区
(3)CPU将准备发送的缓冲区mbuf的虚拟地址填充到描述符sw_ring
(4)CPU通过将准备发送的缓冲区mbuf的虚拟地址转换得到该mbuf里data数据部分的物理地址填充到发送测描述符tx_ring队列 中,并将DD标志清0
(5)DMA控制器读取base寄存器,获取发送侧描述符,根据发送测描述符获取tx_ring队列地址,读取head指针里的元素,判断DD标志释放为0则从描述符中获取数据缓存区地址,通过PCIE总线将数据拷贝到网卡硬件Tx_FIFO缓存中往外发送数据
(6)DMA控制器回写该描述符中队列里DD的标志置1,通知CPU该缓存中数据已成功发送
(7)至此,应用发送数据包完毕
注意:这里有两个非常关键的队列tx_ring、sw_ring,tx_ring描述符里存放的是mbuf里data区的起始物理地址供DMA控制器读取报文(硬件DMA直接操作物理地址,不需要cpu参与);sw_ring描述符里存放的是mbuf的起始虚拟地址供应用写入数据包