Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 15 Aug 1999 18:40:00 -0400 (EDT)
From:      Alfred Perlstein <bright@rush.net>
To:        John Polstra <jdp@polstra.com>
Cc:        hackers@FreeBSD.ORG
Subject:   Re: Getting device and inode number from a vnode
Message-ID:  <Pine.BSF.3.96.990815181303.20420B-100000@cygnus.rush.net>
In-Reply-To: <XFMail.990815145645.jdp@polstra.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, 15 Aug 1999, John Polstra wrote:

> I have two VFS-related questions which are probably pretty basic.
> 
> 1. I have a pointer to a vnode and I want to get the corresponding
> dev_t and inode number.  Is there a non-sleazy way to do that other
> than calling vn_stat?

use vn_todev from "vfs_subr.c" ~line 2970 of 2976 if you just
need the dev_t.  but you may wind up needing the GETATTR call for
the inode lookup.

> 2. The first action of vn_stat is to call VOP_GETATTR.  VOP_GETATTR(9)
> says, "The file should not be locked on entry."  But when stat calls
> vn_stat, the vnode is locked.  Which is correct -- or doesn't it
> matter?

the lookup at the begininngin of the stat() call's side-effect is to 
lock the vnode it returns but kern/vnode.src seems to indicate
that the vnode's locking state doesn't matter...

so does the various states that vnodes are in when called from
vfs_syscalls, such as the lseek syscall.

it's slighly confusing, if the vnode is locked for "access" calls
why is it not locked for attribute calls?

-Alfred Perlstein - [bright@rush.net|alfred@freebsd.org]
Wintelcom systems administrator and programmer
   - http://www.wintelcom.net/ [bright@wintelcom.net]



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.BSF.3.96.990815181303.20420B-100000>