在MINIX上通过文件名检索文件的inode号

4
我希望在VFS服务器中创建一个新的系统调用,该调用将以文件名作为参数,并打印出此特定文件的inode号码在MINIX3.2.1中。我查看了do_stat()函数的代码(位于/usr/src/servers/vfs/stadir.c中),发现我必须将eat_path()函数分配给vnode结构变量,以访问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;
}
3个回答

2
我已经找到了解决我的问题的方法,我无法理解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 变量到底是什么……我在网上查了一下,发现它是 path 变量中字符串的长度!


0

它是存储在m.m1_i1中的strlen(name) + 1


-1

你可以将用户输入作为 sys_call 的参数添加进去。如果我理解正确,这是一项学校作业,所以你可能只需要:

int do_stat(char * filename) { ... }


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接