receive和process的过程

(一)

receive最终在fuse_kern_chan.c中的fuse_kern_chan_receive函数实现,使用系统调用读取

        res = read(fuse_chan_fd(ch), buf, size);

其中fuse_chan_fd(ch)就是/dev/fuse, buf和size在fuse_loop_mt.c中fuse_do_work中定义。      

struct fuse_buf fbuf = {
  .mem = w->buf,
  .size = w->bufsize,
};

其中的fbuf->mem就是buf,fbuf->size就是size。

size的值为 135168

这些值在 fuse_loop_mt.c::fuse_loop_start_thread中被赋值。

w->bufsize = fuse_chan_bufsize(mt->prevch);

w->buf = malloc(w->bufsize);

receive完成后,就是process。process函数最终是fuse_lowlevel.c中的fuse_ll_process_buf 。

(二)

执行ls dir1命令,fuse_ll_process_buf 会收到这些操作码:

  3  FUSE_GETATTR

[getattr] Called
  Attributes of / requested

  27  FUSE_OPENDIR

  28  FUSE_READDIR

--> Getting The List of Files of /

  1  FUSE_LOOKUP

[getattr] Called
  Attributes of /file54 requested

  1

[getattr] Called
  Attributes of /file349 requested

  28  FUSE_READDIR

  29  FUSE_RELEASEDIR

  42  FUSE_BATCH_FORGET

每一个操作码都耗费fuse_do_work(fuse_lootp_mt.c)的一个循环。即一个receive,一个process。

最终按照操作码调用对应函数:   

    fuse_ll_ops[in->opcode].func(req, in->nodeid, inarg);

in根据fuse_ll_process_buf中的参数buf得来。

func函数也在fuse_lowlevel.c中,比如do_getattr函数,该函数调用:

     req->f->op.getattr(req, nodeid, fip);

去执行用户定义的函数。 这里的op类型是struct fuse_lowlevel_ops,定义在fuse_lowlevel.c。

最终应该会去往fuse.c中的fuse_fs_getattr函数,在里面调用fs->op.getattr(path, buf);这个getattr函数在用户程序ssfs.c中定义。

op是在用户程序ssfs.c中定义,由fuse_main函数传递而来。

(三)

由于用户程序ssfs.c中只定义了三种操作,所以只会接受到三种三座。没有定义的操作,在fuse_lowlevel.c中进行对应的判断如if (req->f->op.setxattr)不成立于是调用fuse_reply_err(req, ENOSYS);进行回应。

(四)接上面(二)的结尾

static struct fuse_lowlevel_ops fuse_path_ops 在fuse.c中定义,有一句 

  .getattr = fuse_lib_getattr,

全局搜索只有这一处比较像lowlevel的getattr函数指针。

在fuse.c中,有

  static void fuse_lib_getattr(fuse_req_t req, fuse_ino_t ino,struct fuse_file_info *fi)

这与fuse_lowlevel.c中的getattr函数里面的调用是一致的。

  fuse_lib_getattr函数调用fuse_fs_fgetattr(f->fs, path, &buf, fi);, 里面调用fs->op.getattr(path, buf);

        这里应该就是用户定义的getattr了。

这里fs->op正是struct fuse_operations类型的。这个变量由用户程序ssfs.c的fuse_main传入。

时间: 2024-10-25 08:00:18

receive和process的过程的相关文章

C#的Process类调用第三方插件实现PDF文件转SWF文件

在项目开发过程中,有时会需要用到调用第三方程序实现本系统的某一些功能,例如本文中需要使用到的swftools插件,那么如何在程序中使用这个插件,并且该插件是如何将PDF文件转化为SWF文件的呢?接下来就会做一个简单的介绍. 在.NET平台中,对C#提供了一个操作对本地和远程的访问进程,使能够启动和停止系统进程.这个类就是System.Diagnostics.Process,我们首先来了解一下该类. 一.解析System.Diagnostics.Process类 在C#中使用Process类可以提

软件工程:软件工程过程与方法

尽管程序员领着一份不错的薪水,可是他们也同样付出了巨大的精力与时间.随着软件规模的日益庞大,用户需求的不确定以及快速变更,使得软件开发已经不能停留在小作坊式的个人英雄时代,它已经发展为如今的依赖团队合作的行为,常规的管理方法已经无法满足软件开发的实际需求.而软件工程正是研究如何以系统性的.规范化的 .可定量的过程化方法高效开发与管理.维护软件的交叉性学科. 软件工程过程有哪些 常见的软件开发过程模型有哪些 UML中一般有哪些图 软件工程过程有哪些 软件工程是一门系统科学,是研究与应用如何以系统性

SICP 第一章 构造过程抽象 1

Chapter 1 Building Abstractions with Procedures .title { text-align: center } .todo { font-family: monospace; color: red } .done { color: green } .tag { background-color: #eee; font-family: monospace; padding: 2px; font-size: 80%; font-weight: normal

Java中的APT的工作过程

Java中的APT的工作过程 APT即Annotatino Processing Tool, 他的作用是处理代码中的注解, 用来生成代码, 换句话说, 这是用代码生成代码的工具, 减少boilerplate代码. 我们通过一个简单的例子来简单APT的工作过程, 因为本文demo不设计ide及gradle等, 请注意包名及import问题. 根据上一篇博客Java中的自定义注解, 首先设计一个自定义注解MyAnnotation. package com.example; import java.l

Reactor模型

Reactor模型 原文地址:http://www.ivaneye.com/2016/07/23/iomodel.html 无处不在的C/S架构 在这个充斥着云的时代,我们使用的软件可以说99%都是C/S架构的! 你发邮件用的Outlook,Foxmail等 你看视频用的优酷,土豆等 你写文档用的Office365,googleDoc,Evernote等 你浏览网页用的IE,Chrome等(B/S是特殊的C/S) ...... C/S架构的软件带来的一个明显的好处就是:只要有网络,你可以在任何地

高性能Server---Reactor模型

无处不在的C/S架构 在这个充斥着云的时代,我们使用的软件可以说99%都是C/S架构的! 你发邮件用的Outlook,Foxmail等 你看视频用的优酷,土豆等 你写文档用的Office365,googleDoc,Evernote等 你浏览网页用的IE,Chrome等(B/S是特殊的C/S) …… C/S架构的软件带来的一个明显的好处就是:只要有网络,你可以在任何地方干同一件事. 例如:你在家里使用Office365编写了文档.到了公司,只要打开编辑地址就可以看到在家里编写的文档,进行展示或者继

java网络编程socket\server\TCP笔记(转)

java网络编程socket\server\TCP笔记(转) 2012-12-14 08:30:04|  分类: Socket |  标签:java  |举报|字号 订阅 1 TCP的开销 a  连接协商三次握手,c->syn->s,s->syn ack->c, c->ack->s b  关闭协商四次握手,c->fin->s, s->ack-c,s->fin->c,c->ack->s c  保持数据有序,响应确认等计算开销 d

软件工程术语(下)

A B C D E F G H I J K L [M] N O P Q R S T U V W X Y Z  major defect主要缺陷      一个工作产品中所存在的那些严重影响产品功能的正确表现.且若在产品开发周期的后期发现将可能比在产品开发前期发现更加难以改正的故障. management管理      软件工程过程中的核心支持工作流程,其目的在于计划和管理开发项目. marshal反串行化      反串行化 (deserialize) 的同义词. measurement dys

一种绝对提高开发水平的方法

一.概要 英语对提升软件开发水平非常重要. 如果你英文水平不高,这并不影响你成为一个普通程序员,程序更多是靠逻辑思维. 如果做了多年开发的你发现自己的水平一直上不去,你要提高自己的英文水平了. 我周围的高水平的开发者英文都不差,官方API没问题. 英语是世界上使用最广泛的语言之一,是欧盟.许多国际组织与英联邦国家的官方语言之一.如今英语也是与电脑联系最密切的语言,大多数编程语言都与英语有关系. 英语在软件行业.编程世界里都占有压倒性的优势,它能够帮助人们在关键词和代码库的选择上带来灵感.根据HO