kern___getcwd() returns ENOTDIR

David Schultz das at FreeBSD.ORG
Mon Jun 28 01:28:04 PDT 2004


On Mon, Jun 28, 2004, Pawel Jakub Dawidek wrote:
> On Sun, Jun 27, 2004 at 11:12:20AM -0700, David Schultz wrote:
> +> On Sun, Jun 27, 2004, Kentucky Mandeloid Mo. wrote:
> +> > I'm writng a smal kernel module that catches file access syscalls.
> +> > At every syscall I need a full name of file is being passed to a syscall.
> +> > I'm getting it with a path passed to syscall and if path is not starting 
> +> > with / I get current working directory of process using kern___getcwd().
> +> > In every syscall all works just fine except rmdir & unlink.
> +> > Sometimes in unlink and everytime in rmdir it returns "not a directory" error.
> +> > I know already that kern___getcwd() works through vnode cache and this method 
> +> > is not a reliable way to get file names.
> +> > So is there any other way get cwd of a proccess? 
> +> 
> +> linux_getcwd() works in more cases than kern___getcwd(), but it
> +> has other problems.
> 
> What problems does it have? Could you provide more details?
> Was it discusses when patch for changing kern___getcwd() with
> linux_getcwd() was introduced?

It was discussed when phk merged it into kern___getcwd() last
year, and on at least one other occasion.  However, I can't seem
to find the relevant thread in the mail archives.  Perhaps phk or
dwmalone remember.


More information about the freebsd-hackers mailing list