From 9c3c6106d72ecb384cc97ab3d8c1b5f5e9fe2df5 Mon Sep 17 00:00:00 2001 From: Alexander Bokovoy Date: Mon, 14 Apr 2008 15:35:45 +0000 Subject: Add small preface to a VFS guide. More to come. (This used to be commit 9de9b5852c925a91e90651f28837a86ecd2e9e21) --- docs/Samba3-Developers-Guide/vfs.xml | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'docs') diff --git a/docs/Samba3-Developers-Guide/vfs.xml b/docs/Samba3-Developers-Guide/vfs.xml index 25a45b6875..9005f5fd52 100644 --- a/docs/Samba3-Developers-Guide/vfs.xml +++ b/docs/Samba3-Developers-Guide/vfs.xml @@ -22,6 +22,32 @@ The Samba (Posix) VFS layer +While most of Samba deployments are done using POSIX-compatible operating systems, +there is clearly more to a file system than what is required by POSIX when it comes to +adopting semantics of NT file system. Since Samba 2.2 all file-system related operations +go through an abstraction layer for virtual file system (VFS) that is modelled after +both POSIX and additional functions needed to transform NTFS semantics. + + + +This abstraction layer now provides more features than a regular POSIX file system could +fill in. It is not required that all of them should be implemented by your +particular file system. However, when those features are available, Samba would advertize them to a +CIFS client and they might be used by an application and in case of Windows client that +might mean a client expects even more additional functionality when it encounters +those features. There is a practical reason to allow handling of this snowfall without modifying +the Samba core and it is fulfilled by providing an infrastructure to dynamically load +VFS modules at run time. + + +Each VFS module could implement a number of VFS operations. The way it does it is +irrelevant, only two things actually matter: whether specific implementation wants to cooperate +with other modules' implementations or not, and whether module needs to store additional +information that is specific to a context it is operating in. Multiple VFS modules could +be loaded at the same time and it is even possible to load several instances of the same +VFS module with different parameters. + + The general interface -- cgit