因工作需要分析了部分SPDK代码,主要梳理login请求以及响应的处理,供参考。

参考代码——SPDK代码实现(以PLOGI为例):

SPDK处理PLOGI分为三个阶段:

第一阶段通过一条GET_PARAMETERS的mailbox命令获取本端端口参数;

第二阶段mailbox命令完成后的回调处理中,使用获取的参数填充PLOGI的Payload部分,并进行发送;

第三阶段处理PLOGI的响应;

所需的主要资源以及处理过程如图5- 3、图5- 4所示。umq_hba用于描述一个FC端口,下图标号中的1,4是从端口的req_free队列中取下的umq_request资源;分别用于发送PLOGI和执行mailbox命令以及记录回调函数;标号5用于描述芯片的队列资源,6,7的iocb_pkt是队列中的entry。

驱动调用芯片处理请求的过程为:

  1. 将umq_request资源和umq_iocb_pkt资源通过iocb_handle进行关联,如橙色箭头所示;

  2. 向芯片的request队列中插入umq_iocb_pkt作为一条entry;

  3. 更新队列的生产者指针,告诉芯片有新的iocb入队;

  4. 芯片处理iocb,处理完成后将umq_iocb_pkt从request队列移动到response队列;

  5. 轮询线程从response队列中取出umq_iocb_pkt进行处理,通过umq_iocb_pkt中的handle找到步骤1中关联的umq_request,调用umq_request结构体中记录的回调函数cbfn;

图5- 3 SPDK发送PLOGI所需资源

实际的执过程如下图所示:

1.首先申请一个umq_request结构体,用于发送PLOGI,填充部分信息;

2.再申请一个umq_request结构体,用于执行MBOX_GET_PLOGI_TMPLT的mailbox命令,获取端口参数;

2.芯片执行完mailbox命令后会在response队列中产生一条entry,轮询线程检测到该entry并进行处理;

3.处理entry过程中,通过entry找到关联的步骤2中申请的umq_request结构体,并执行其成员中的回调函数req->cbfn:umq_mailbox_iocb_done;

4.umq_mailbox_iocb_done执行过程中,重新获取到步骤1中申请的umq_request,填充PLOGI的payload DMA buffer,并请求芯片发送;

5.轮询线程从response队列中检测到对端设备发来的LS_ACC并进行处理,将端口状态设置为UMQ_PORT_CB_STATE_PLOGI_ACK;

详细过程可根据下图中的执行过程,结合图5-3中的资源标号以及源代码进行详细分析。

图5- 4  SPDK发送PLOGI过程分析


SPDK发送和接收连接请求的处理的更多相关文章

  1. [java,2018-01-16] HttpClient发送、接收 json 请求

    最近需要用到许多在后台发送http请求的功能,可能需要发送json和xml类型的数据. 就抽取出来写了一个帮助类: 首先判断发送的数据类型是json还是xml: import org.dom4j.Do ...

  2. 使用HttpRequester模拟发送及接收Json请求

    1.开发人员在火狐浏览器里经常使用的工具有Firebug,httprequester,restclient......火狐浏览器有一些强大的插件供开发人员使用!需要的可以在附加组件中扩展. 2.htt ...

  3. 使用httperrequest,模拟发送及接收Json请求

    使用httpreques\Json-Handle\tcpdump\wireshark工具进行,抓取手机访问网络的包,分析request及response请求,通过httprequester来实现模拟发 ...

  4. 使用firefox插件httperrequest,模拟发送及接收Json请求 【转】

    转自[http://blog.csdn.net/feixue1232/article/details/8535212] 目标:使用httpreques\Json-Handle\tcpdump\wire ...

  5. Go net/http 发送常见的 http 请求

    使用 golang 中的 net/http 包来发送和接收 http 请求 开启 web server 先实现一个简单的 http server,用来接收请求 package main import ...

  6. [Socket网络编程]由于套接字没有连接并且(当使用一个 sendto 调用发送数据报套接字时)没有提供地址,发送或接收数据的请求没有被接受。

    原文地址:http://blog.sina.com.cn/s/blog_70bf579801017ylu.html,记录在此方便查看 解决办法: MSDN的说明: Close 方法可关闭远程主机连接, ...

  7. socket 错误之:OSError: [WinError 10057] 由于套接字没有连接并且(当使用一个 sendto 调用发送数据报套接字时)没有提供地址,发送或接收数据的请求没有被接受。

    出错的代码 #server端 import socket import struct sk=socket.socket() sk.bind(('127.0.0.1',8080)) sk.listen( ...

  8. [NIO]用dawn发送接收HTTP请求

    HTTP协议的下层使用的是tcp.所以我们建立一个tcp连接就能发送接收http请求.dawn底层使用了nio.可是经过dawn的封装之后,我们在编写代码的时候,就和使用普通的堵塞式socket一样 ...

  9. 手把手教你Android手机与BLE终端通信--连接,发送和接收数据

    假设你还没有看上一篇 手把手教你Android手机与BLE终端通信--搜索,你就先看看吧,由于这一篇要接着讲搜索到蓝牙后的连接.和连接后的发送和接收数据. 评论里有非常多人问假设一条信息特别长,怎么不 ...

随机推荐

  1. Spring Boot2 系列教程(六)自定义 Spring Boot 中的 starter

    我们使用 Spring Boot,基本上都是沉醉在它 Stater 的方便之中.Starter 为我们带来了众多的自动化配置,有了这些自动化配置,我们可以不费吹灰之力就能搭建一个生产级开发环境,有的小 ...

  2. 54 (OC)* 网络七层架构

    一:TCP/IP协议 二:七层协议 1:物理层 物理层为设备之间的数据通信提供传输媒体及互连设备,为数据传输提供可靠的环境.  1.1:传输媒体和互连设备        物理层的媒体包括架空明线.平衡 ...

  3. spring中ehcache的配置和使用方法

    继续上篇,这篇介绍服务层缓存,ehcache一般的配置和用法 一.添加jar包引用 修改pom.xml文件,加入: <dependency> <groupId>org.spri ...

  4. C++类拷贝控制 深拷贝 浅拷贝

    普通类型对象之间的复制很简单,而类对象与普通对象不同,类对象内部结构一般较为复杂,存在各种成员变量,这篇文章将帮你理清C++类对象的拷贝方式 拷贝构造函数,拷贝赋值运算符 首先我们简单了解下默认的拷贝 ...

  5. [Advanced Python] 14 - "Generator": calculating prime

    高性能编程 几个核心问题 • 生成器是怎样节约内存的?• 使用生成器的最佳时机是什么?• 我如何使用 itertools 来创建复杂的生成器工作流?• 延迟估值何时有益,何时无益? From: htt ...

  6. Java中的方法和方法重载

    上次我们讲了Java中的一些基本的语法;今天我们就讲一点内容,来说说Java中的方法和方法重载以及需要注意的一些地方; 方法: Java的方法类似与其他语言的函数,是一段用来完成特定功能的代码片段, ...

  7. 一步步构建.NET Core Web应用程序---基本项目结构

    前言 随着.NET Core日益成熟, 我作为C#&.NET体系中的一份子也加入了.NET Core 这一体系中,随着不断学习, 接触到的各种框架日益庞杂,接下来我会由一个新手的角度把整个基于 ...

  8. HTML学习之轮播图

    这可以说是一种非常简单的实现轮播图的方法了,由于时间仓促所以没写自动轮播部分.简单说一下原理吧,就是把所有图片堆叠在一个盒子里,设置所有图片的透明度为0,这样就把所有图片都隐藏了,第一张图片除外(第一 ...

  9. yii2 qq邮箱配置发送

    'mailer' => [ 'class' => 'yii\swiftmailer\Mailer', 'useFileTransport' =>false,//这句一定有,false ...

  10. Netty中粘包和拆包的解决方案

    粘包和拆包是TCP网络编程中不可避免的,无论是服务端还是客户端,当我们读取或者发送消息的时候,都需要考虑TCP底层的粘包/拆包机制. TCP粘包和拆包 TCP是个“流”协议,所谓流,就是没有界限的一串 ...