Go to file
2004-11-30 00:00:02 +00:00
doc fix 2004-09-02 18:13:57 +00:00
example API change 2004-11-26 12:15:06 +00:00
include API change 2004-11-26 12:15:06 +00:00
kernel merge to 2_0_merge4 2004-11-30 00:00:02 +00:00
lib merge to 2_0_merge4 2004-11-30 00:00:02 +00:00
util merge to 2_0_merge4 2004-11-30 00:00:02 +00:00
.cvsignore merge up to fuse_2_0_merge1 2004-11-10 11:52:26 +00:00
AUTHORS merge from 2_0_merge1 to 2_0_merge2 2004-11-11 10:33:58 +00:00
ChangeLog merge to 2_0_merge4 2004-11-30 00:00:02 +00:00
configure.in API change 2004-11-26 12:15:06 +00:00
COPYING build with automake 2001-11-07 12:09:43 +00:00
COPYING.LIB version change + cleanups 2002-10-25 12:41:16 +00:00
FAQ fix 2004-10-19 22:01:21 +00:00
Filesystems add entry to Filesystems 2004-11-24 07:59:54 +00:00
fuse.pc.in fix 2004-11-10 12:31:08 +00:00
makeconf.sh merge from 2_0_merge1 to 2_0_merge2 2004-11-11 10:33:58 +00:00
Makefile.am merge from 2_0_merge1 to 2_0_merge2 2004-11-11 10:33:58 +00:00
NEWS merge from 2_0_merge1 to 2_0_merge2 2004-11-11 10:33:58 +00:00
README fix 2004-10-19 22:01:21 +00:00
README-2.4 integrated 2.6 kernel support 2004-01-07 12:16:45 +00:00
README.NFS fix 2004-01-26 11:28:44 +00:00

General Information
===================

FUSE (Filesystem in USErspace) is a simple interface for userspace
programs to export a virtual filesystem to the linux kernel.  FUSE
also aims to provide a secure method for non privileged users to
create and mount their own filesystem implementations.

You can download the source code releases from

  http://sourceforge.net/projects/fuse

or alternatively you can use CVS to get the very latest development
version by setting the cvsroot to

  :pserver:anonymous@cvs.sourceforge.net:/cvsroot/fuse

and checking out the 'fuse' module.

Installation
============

./configure
make
make install

Also see the file 'INSTALL'

How To Use
==========

FUSE is made up of three main parts:

 - A kernel filesystem module

 - A userspace library

 - A mount/unmount program


Here's how to create your very own virtual filesystem in five easy
steps (after installing FUSE):

  1) Edit the file example/fusexmp.c to do whatever you want...

  2) Build the fusexmp program

  3) run 'example/fusexmp /mnt/fuse -d'

  4) ls -al /mnt/fuse

  5) Be glad

If it doesn't work out, please ask!  Also see the file 'include/fuse.h' for
detailed documentation of the library interface.

Security
========

If you run 'make install', the fusermount program is installed
set-user-id to root.  This is done to allow normal users to mount
their own filesystem implementations. 

There must however be some limitations, in order to prevent Bad User from
doing nasty things.  Currently those limitations are:

  - The user can only mount on a mountpoint, for which it has write
    permission

  - The mountpoint is not a sticky directory which isn't owned by the
    user (like /tmp usually is)

  - No other user (including root) can access the contents of the mounted
    filesystem.