Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 21 Apr 2007 11:08:21 +0100 (BST)
From:      Robert Watson <rwatson@FreeBSD.org>
To:        "Stephane E. Potvin" <sepotvin@FreeBSD.org>
Cc:        Greg Lewis <glewis@eyesbeyond.com>, freebsd-current@FreeBSD.org, Pawel Jakub Dawidek <pjd@FreeBSD.org>
Subject:   Re: ZFS, procfs and java
Message-ID:  <20070421110405.Y39377@fledge.watson.org>
In-Reply-To: <46297494.5050104@FreeBSD.org>
References:  <46297494.5050104@FreeBSD.org>

next in thread | previous in thread | raw e-mail | index | archive | help

On Fri, 20 Apr 2007, Stephane E. Potvin wrote:

> It seems that the ZFS cache (dnlc) doesn't update the VSF_namecache fields 
> in the vnodes (v_cache_src, v_cache_dst and v_dd). This unfortunately causes 
> the file link in /proc/curproc to return "unknown" as it uses vn_fullpath 
> which relies on the namecache fields to be set correctly.
>
> Java uses /proc/curproc/file to know where to find its libraries and doesn't 
> expect the "unknown" return value returned when using ZFS (due to 
> vn_fullpath failing). The attached patches to the java/jdk15 port fixes this 
> issue but it doesn't fix the root of the problem.
>
> Would it be possible to add support in dnlc for updating the VFS namecache 
> fields or to add knowledge of dnlc into vn_fullpath?

No application should rely on the correctness and usefulness of 
/proc/curproc/file -- the conversion from a vnode to a pathname is inherently 
unreliable.  Likewise, properly ported applications should not rely on the 
availability of procfs, as its use is deprecated.  My advice would be to talk 
to the Java porters about entirely eliminating this dependency.

As a matter of debugging/logging convenience, it would be nice if ZFS 
implemented the name cache hooks, since using vn_fullpath is useful for procfs 
monitoring of process address space, audit, etc.

Robert N M Watson
Computer Laboratory
University of Cambridge



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070421110405.Y39377>