SMC建链机制

SMC建链机制,因为SMC的建链是建立在TCP的建链之上,所以SMC的建链可以分为两个部分,分别是Server端和Client端的建链流程。如果对SMC建链的报文有疑问的,可以恶补一下阿里发布的一些前置知识点。链接为:系列解读 SMC-R (二):融合 TCP 与 RDMA 的 SMC-R 通信 | 龙蜥技术-阿里云开发者社区

链接里要纠正一下,在三次握手的最后一次时,是不会携带SMC信息到TCP选项头中的,内容还是比较通俗易懂的。

Server端主要就是延用TCP的起server的流程,从socket的创建,到socket的监听,再到socket的accept三个流程

Server端socket的创建

socket的创建,调用的就是模块初始化时候注册的smc_create接口,调用路径为__sock_create->smc_create

static int smc_create(struct net *net, struct socket *sock, int protocol, int kern)

{

        sock->ops = &smc_sock_ops; 

        --->>>给sock ops回挂smc的钩子函数,还有些省略的代码做的检查就是对SMC socket一些入参做校验,这里不做详细展开

        sock->state = SS_UNCONNECTED;

        --->>>初始化smc socket的状态为unconnected

        sk = smc_sock_alloc(net, sock, protocol);

        --->>>调用smc函数,创建smc类型的sock,sk_state状态置为SMC_INIT,主要初始化三个工作队列,tcp_listen_works、connect_work和conn.tx_work

        sock_create_kern(net, family, SOCK_STREAM, IPPROTO_TCP, &smc->clcsock);

        --->>>创建内核态TCP socket,保存在clcsock下

}

Server端socket的监听

smc socket的监听,调用的是create啥时候注册的接口smc_sock_ops中的smc_listen函数,调用路径为__sys_listen->smc_listen

static int smc_listen(struct socket *sock, int backlog)

{

        smc_copy_sock_settings_to_clc(smc);

        --->>>拷贝smc的sk信息到clcsoc

  • 13
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值