今天中午美美的睡了一觉,借着突破readdir的基础,迅速看懂了NFSD端的read代码。想想之前看不懂时候,面对满屏幕的繁杂数据结构,完全失去了思考能力。
分析代码之前,先总结一下,希望经过这次拖沓的一个月 读代码,以后面对稍稍复杂庞大的代码,能够迅速理出头绪。
1.首先要从宏观理解代码的结构和流程,这一点其实很快就做到了。
2.面对较多的变量和数据结构定义以及较多的函数调用,可以通过做笔记,从函数调用和数据传递两条线索整理出整个流程。进度之所以非常缓慢,就是因为被众多的定义和函数调用吓着了,不能一口吃掉,但是也没有耐心一点点蝉食。
3.用source insight方便了代码追踪,大大加快了进度。
结论:下次看代码,用source insight,复杂的流程整理笔记。
言归正传,下面说read流程。
struct nfsd3_readargs {
struct svc_fh fh;
__u64 offset; 指的是在文件中的偏移量
__u32 count; 指的是要读的字节数量,其实在rqst中vec中也包含了个读多少的数量
int vlen; 指明在rqst中,vec向量的个数。
};
resp->count = argp->count;
if (max_blocksize < resp->count)
resp->count = max_blo