Subversion Repositories HelenOS

Rev

Go to most recent revision | Show changed files | Details | Compare with Previous | Blame | RSS feed

Filtering Options

Rev Age Author Path Log message Diff
3593 5663 d 6 h rimsky /branches/sparc/ Merged latest trunk changes into sparc branch.  
3397 5729 d 15 h rimsky /branches/sparc/ Merged recent changes from trunk into the Sparc branch.  
3343 5753 d 12 h decky /branches/sparc/ add sparc branch  
3109 5827 d 13 h jermar /trunk/uspace/srv/ Split the 'mount another filesystem here' and 'you are being mounted and the
device is this' mount semantics. Add VFS_MOUNTED VFS operation that corresponds
to the latter and reserve VFS_MOUNT only for the former. Because of this
change, the VFS server does not maintain the mr_node VFS node for the name space
root anymore and the VFS_LOOKUP operation is now not meant to be used on
unmounted file system, not even for looking up the root node of unmounted file
systems. In the light of these changes, TMPFS is now initialized from
tmpfs_mounted() function.
 
3103 5828 d 6 h jermar /trunk/uspace/srv/fs/tmpfs/ Evict the code which loads the TMPFS file system from a file system dump to a
dedicated source file.
 
3091 5830 d 9 h jermar /trunk/uspace/srv/fs/tmpfs/ Return value argument to ipc_call_sync_X_Y() may not be int or it will
break on 64-machines that are sensitive to unaligned memory accesses.
Moreover, overcasting int * to sysarg_t * is not a good idea either
even if the int is by chance aligned on a 64-bit boundary as some
unknown memory will get overwritten during the assignment. Change the
type of the retval argument to ipcarg_t.
 
3087 5830 d 14 h decky /trunk/uspace/srv/fs/tmpfs/ initialize tmpfs from RAM disk  
2958 5846 d 7 h jermar /trunk/uspace/srv/ Make VFS_MOUNT call even when mounting the root file system.  
2863 5874 d 17 h jermar /trunk/uspace/ Revert libfs node_get() API to a model without the parent node pointer
argument.
 
2858 5880 d 1 h jermar /trunk/uspace/ libfs destroy operation should rather return an error code instead of a truth
value.
 
2857 5880 d 2 h jermar /trunk/uspace/ Add stubs for unimplemented FAT libfs operations.  
2852 5880 d 23 h jermar /trunk/uspace/ Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
Add node_put() to libfs operations and instrument libfs_lookup() to use it at
appropriate places.
 
2844 5882 d 6 h jermar /trunk/uspace/ Add fat_root_get() and fat_plb_get_char().  
2831 5885 d 0 h jermar /trunk/uspace/ Commit progress on the FAT file system server implementation.  
2792 5892 d 9 h jermar /trunk/uspace/ libfs' node_get() operation does not need the file system handle.  
2791 5895 d 6 h jermar /trunk/uspace/ Make libfs_lookup() more generic.  
2770 5914 d 8 h jermar /trunk/uspace/ Introduce fs_handle_t, dev_handle_t and fs_index_t.  
2763 5916 d 11 h jermar /trunk/uspace/ Support for rename().  
2760 5919 d 6 h jermar /trunk/uspace/ Support for multiple TMPFS node names.  
2758 5920 d 7 h jermar /trunk/uspace/ No need to keep the parent pointer in the TMPFS node. Moreover, other file
systems won't have it either. Finally, if TMPFS is to support hardlinks, there
can be multiple parents.
 
2757 5920 d 8 h jermar /trunk/uspace/srv/fs/tmpfs/ Set the TMPFS root node's link count to 1.  
2756 5920 d 9 h jermar /trunk/uspace/srv/fs/tmpfs/ Introduce real link counts for TMPFS.  
2747 5927 d 6 h jermar /trunk/uspace/ Move the core lookup logic from TMPFS to libfs.  
2742 5929 d 6 h jermar /trunk/uspace/srv/ Separate creation of a TMPFS node and its linking in the file system name space.
Rename VFS_FREE to VFS_DESTROY and destroy_node() to unlink_node().
 
2739 5935 d 7 h jermar /trunk/uspace/srv/fs/tmpfs/ Remove duplicate initialization.  
2736 5937 d 9 h jermar /trunk/uspace/srv/fs/tmpfs/ Unlink a TMPFS node more thoroughly.  
2735 5937 d 12 h jermar /trunk/uspace/ Support for rmdir(), unlink() and the respective VFS operations.  
2733 5937 d 14 h jermar /trunk/uspace/ Add TMPFS support for destroying leaf links in the file system namespace.  
2732 5937 d 15 h jermar /trunk/uspace/srv/fs/tmpfs/ When freeing up a TMPFS node, it should also be removed from the dentries hash table.  
2731 5937 d 15 h jermar /trunk/uspace/srv/ Add the VFS_FREE operation. This operation frees up whatever resources used by
a file system node for which there is no name (i.e. an unlinked node).

Cleanup VFS operations enums and remove unneeded VFS operations.
 
2730 5938 d 17 h jermar /trunk/uspace/srv/ Introduce the notion of VFS node link counts.  
2728 5943 d 7 h jermar /trunk/uspace/srv/fs/tmpfs/ Descend vs. descent.  
2711 5958 d 10 h jermar /trunk/uspace/ Remove the debugging hack from tmpfs_init(), which created several files and
directories on the filesystem. TMPFS is now self-sufficient enough to be able
to create its content via the standard VFS interface.
 
2710 5958 d 10 h jermar /trunk/uspace/ VFS_WRITE and tmpfs_write fixes.  
2707 5958 d 14 h jermar /trunk/uspace/ Support for mkdir().  
2706 5958 d 18 h jermar /trunk/uspace/srv/fs/tmpfs/ Move handling of the miss on excessive components out of the main loop in
tmpfs_lookup.
 
2705 5959 d 6 h jermar /trunk/uspace/ More elegant, flexible and complete version of tmpfs_lookup.  
2700 5966 d 15 h jermar /trunk/uspace/ Introduce the notion of lflag (i.e. lookup flags) to support the ability to
limit the scope of VFS node types that can be opened by open() and opendir(). In
the future, lflag will also specify actions for VFS_LOOKUP handlers that will be
carried out in situations such as the VFS node is not found (e.g. implementation
of mkdir() and open() with O_CREAT in oflag).
 
2699 5967 d 5 h jermar /trunk/uspace/ Finish implementation of readdir(). Functions from this family are implemented
via using file descriptors for directories. For example, readdir() is
implemented as read() from an open directory. Of course, FS implementations
must understand that they are asked to read a directory and behave accordingly.
 
2693 5972 d 15 h jermar /trunk/uspace/ Add ftruncate() and support for VFS_TRUNCATE to VFS and TMPFS.