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