加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 通过MINIX上的文件名检索文件的inode编号

发布时间:2020-12-16 06:53:01 所属栏目:百科 来源:网络整理
导读:我想在VFS服务器中创建一个新的系统调用,它将被赋予一个文件名作为参数,并将在MINIX3.2.1中打印该特定文件的inode编号. 我检查了do_stat()函数的代码(在/usr/src/servers/vfs/stadir.c里面),我发现我必须分配一个vnode结构变量派系eat_path()才能访问v_inode
我想在VFS服务器中创建一个新的系统调用,它将被赋予一个文件名作为参数,并将在MINIX3.2.1中打印该特定文件的inode编号.
我检查了do_stat()函数的代码(在/usr/src/servers/vfs/stadir.c里面),我发现我必须分配一个vnode结构变量派系eat_path()才能访问v_inode_nr是inode数字.为了做到这一点,我如何能够分配我正在寻找的文件,在哪里放置用户输入文件名(m_in.m1_p1)?

这是stadir.c中的do_stat()函数

int do_stat() {
  /* Perform the stat(name,buf) system call. */
  int r;
  struct vnode *vp;
  struct vmnt *vmp;
  char fullpath[PATH_MAX];
  struct lookup resolve;
  int old_stat = 0;
  vir_bytes vname1,statbuf;
  size_t vname1_length;

  vname1 = (vir_bytes)job_m_in.name1;
  vname1_length = (size_t)job_m_in.name1_length;
  statbuf = (vir_bytes)job_m_in.m1_p2;

  lookup_init(&resolve,fullpath,PATH_NOFLAGS,&vmp,&vp);
  resolve.l_vmnt_lock = VMNT_READ;
  resolve.l_vnode_lock = VNODE_READ;

  if (job_call_nr == PREV_STAT)
    old_stat = 1;

  if (fetch_name(vname1,vname1_length,fullpath) != OK)
    return (err_code);
  if ((vp = eat_path(&resolve,fp)) == NULL)
    return (err_code);
  r = req_stat(vp->v_fs_e,vp->v_inode_nr,who_e,statbuf,old_stat);

  unlock_vnode(vp);
  unlock_vmnt(vmp);

  put_vnode(vp);
  return r;
}

解决方法

我找到了解决问题的方法,我无法理解fetch_name()参数的工作方式(vname1,vname1_length和fullpath).
所以为了做到这一点,我研究了/usr/src/vfs/params.h
#define name m3_p1
?#define flength m2_l1
?#define name1 m1_p1
?#define name2 m1_p2
?#define name_length m3_i1
?#define name1_length m1_i1
?#define name2_length m1_i2
?#define nbytes m1_i2

你可以看到name1代表m1_p1而name1_length代表m1_i1消息变量.

至于fetch_name函数,我看了/usr/src/vfs/utility.c

int fetch_name(vir_bytes path,size_t len,char *dest)
{
/* Go get path and put it in 'dest'.  */
int r;

因此fetch_name实际上获取路径(来自用户的文件名)并将其转换为文件的完整路径.

现在的问题是它实际上是size_t len变量是什么……我在网上看了一下,我发现它是路径变量的strlen!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读