From owner-freebsd-fs@FreeBSD.ORG Mon Feb 19 07:54:01 2007 Return-Path: X-Original-To: freebsd-fs@FreeBSD.ORG Delivered-To: freebsd-fs@FreeBSD.ORG Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 36B6B16A400 for ; Mon, 19 Feb 2007 07:54:01 +0000 (UTC) (envelope-from olli@lurza.secnetix.de) Received: from lurza.secnetix.de (lurza.secnetix.de [83.120.8.8]) by mx1.freebsd.org (Postfix) with ESMTP id AEDCE13C478 for ; Mon, 19 Feb 2007 07:54:00 +0000 (UTC) (envelope-from olli@lurza.secnetix.de) Received: from lurza.secnetix.de (xydilc@localhost [127.0.0.1]) by lurza.secnetix.de (8.13.4/8.13.4) with ESMTP id l1J7rrC0012211; Mon, 19 Feb 2007 08:53:58 +0100 (CET) (envelope-from oliver.fromme@secnetix.de) Received: (from olli@localhost) by lurza.secnetix.de (8.13.4/8.13.1/Submit) id l1J7rrFO012210; Mon, 19 Feb 2007 08:53:53 +0100 (CET) (envelope-from olli) Date: Mon, 19 Feb 2007 08:53:53 +0100 (CET) Message-Id: <200702190753.l1J7rrFO012210@lurza.secnetix.de> From: Oliver Fromme To: freebsd-fs@FreeBSD.ORG, adamsch1@yahoo.com In-Reply-To: <401753.71633.qm@web31809.mail.mud.yahoo.com> X-Newsgroups: list.freebsd-fs User-Agent: tin/1.8.2-20060425 ("Shillay") (UNIX) (FreeBSD/4.11-STABLE (i386)) MIME-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 8bit X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-2.1.2 (lurza.secnetix.de [127.0.0.1]); Mon, 19 Feb 2007 08:53:59 +0100 (CET) Cc: Subject: Re: Advice on runtime directories ala .snapshot X-BeenThere: freebsd-fs@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list Reply-To: freebsd-fs@FreeBSD.ORG, adamsch1@yahoo.com List-Id: Filesystems List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 19 Feb 2007 07:54:01 -0000 Shane Adams wrote: > I've been thinking about how I could add a "virtual" directory entry > similar to netapp, namely a .snapshot. Obviously I'd want to do this > at runtime, but I'm having trouble attacking this problem. There's no precedent for such a thing in FreeBSD currently. The closest thing would be the ".snap" directory used for FreeBSD's snapshot feature, or maybe even the historical "lost+found" directory. But both of them are created statically in the file system, and they represent ordinary directory entries without any magic. You will find purely synthetic files and directories only in the synthetic file systems such as procfs or devfs. > I've been looking at the ufs_lookup routines, seems thats the only > place to tackle such a feature? Or possibly inject a .snapshot entry > as the last entry read in a call to ufs_readdir ? It would be easier to give advice if we knew what you're actually trying to implement. Personally, I think it's not a good idea to mix real and synthetic entries within the same file system. Or at least there should be _very_ good reasons for doing so, and very careful consideration of all possible cases. For example, what's supposed to happen in case of a conflict, i.e. if there is already a real entry with the same name (".snapshot") with some contents? > I believe doing a ls -la on a netapp will not return the .snapshot > directory, only explicitly nameing the directory will achieve the > effects you want. That behaviour is configurable. On a NetApp filer you can configure per volume whether the .snapshot directory appears only in the mount point directory, or in every directory below it. In the case of a NetApp it's not a big problem to manage such synthetic directories, because it has full controll over its file system. Clients can only access it remotely (NFS, SMB, ...), so from the clients' viewpoint the whole file system is kind of "synthetic". Best regards Oliver -- Oliver Fromme, secnetix GmbH & Co. KG, Marktplatz 29, 85567 Grafing b. M. Handelsregister: Registergericht Muenchen, HRA 74606, Geschäftsfuehrung: secnetix Verwaltungsgesellsch. mbH, Handelsregister: Registergericht Mün- chen, HRB 125758, Geschäftsführer: Maik Bachmann, Olaf Erb, Ralf Gebhart Any opinions expressed in this message are personal to the author and may not necessarily reflect the opinions of secnetix GmbH & Co KG in any way. FreeBSD-Dienstleistungen, -Produkte und mehr: http://www.secnetix.de/bsd "If you think C++ is not overly complicated, just what is a protected abstract virtual base pure virtual private destructor, and when was the last time you needed one?" -- Tom Cargil, C++ Journal