Subversion Repositories HelenOS

Rev

Show changed files | Directory listing | RSS feed

Filtering Options

Rev Age Author Path Log message Diff
2729 5984 d 10 h decky /branches/network/ add networking branch  
2710 6000 d 2 h jermar /trunk/uspace/ VFS_WRITE and tmpfs_write fixes.  
2709 6000 d 4 h jermar /trunk/uspace/srv/vfs/ VFS_OPEN and VFS_WRITE now understand O_APPEND.  
2708 6000 d 4 h jermar /trunk/uspace/ VFS_OPEN now understands O_CREAT and O_EXCL.  
2707 6000 d 6 h jermar /trunk/uspace/ Support for mkdir().  
2704 6001 d 8 h jermar /trunk/uspace/srv/vfs/ Additional VFS lookup flags.  
2700 6008 d 7 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).
 
2698 6009 d 3 h jermar /trunk/uspace/srv/vfs/ Small fix for VFS_TRUNCATE. Move lookup and registration code to separate
modules.
 
2693 6014 d 7 h jermar /trunk/uspace/ Add ftruncate() and support for VFS_TRUNCATE to VFS and TMPFS.  
2691 6018 d 1 h jermar /trunk/uspace/srv/vfs/ Improve the API for converting (VFS triplets, size) to VFS nodes by introducing
a new type for results of vfs_lookup_internal().
 
2690 6018 d 23 h jermar /trunk/uspace/srv/ Make a distinction between VFS operations that are common to VFS and FS
implementations, operations that are VFS only and operations that are FS
implementations only.
 
2689 6019 d 0 h jermar /trunk/uspace/srv/vfs/ Merge all VFS operations into one file.  
2688 6019 d 0 h jermar /trunk/uspace/ Make uspace rwlock API naming conventions consistent with kernel rwlock API.  
2687 6019 d 0 h jermar /trunk/uspace/srv/ Management of the cached VFS node size.  
2684 6021 d 1 h jermar /trunk/ Add libc and VFS implementation of lseek(), VFS_SEEK resp.
Add the size member to the VFS node structure (not yet initialized).
 
2683 6021 d 4 h jermar /trunk/uspace/srv/vfs/ Introduce the open file lock. Modify vfs_rdwr() to take this lock into account
when reading or writing from/to an open file.
 
2682 6021 d 6 h jermar /trunk/uspace/ Fix type in declaration of VFS node rwlock.
Introduce a dedicated type for futexes. Make the existing futex code use this
newly introduced type and fix formatting in futex.c.
 
2681 6021 d 7 h jermar /trunk/uspace/ Turn the namespace futex into rwlock.  
2680 6021 d 8 h jermar /trunk/uspace/ Add basic rwlock API for uspace so that VFS can be designed/implemented using
this API. So far, the implementation of this API merely wraps futexes into
rwlocks. Real rwlocks are wanted by ticket #54.

Using the new rwlock API, replace the VFS node content futex with an rwlock.
Lock the contents rwlock as reader on reads and as writer on writes.
 
2679 6025 d 0 h jermar /trunk/uspace/srv/vfs/ Rename unlink_futex to namespace_futex and introduce a new futex for serializing
concurrent access to a VFS node's contents by multiple clients.
 
2678 6027 d 3 h jermar /trunk/uspace/ The IPC_M_SHARE_* and IPC_M_DATA_* calls pass through 3 stages. Rename the send,
receive and deliver wrappers to names ending with 'start', 'receive' and
'finalize', respectively. This should make it clearer for dummies.
 
2677 6027 d 4 h jermar /trunk/ Rename IPC_M_AS_AREA_SEND to IPC_M_SHARE_OUT. Rename IPC_M_AS_AREA_RECV to
IPC_M_SHARE_IN. Provide user-friendly wrappers for these methods so that even
dummies can get it right. Some applications using simpler protocols still use
these methods directly.
 
2676 6027 d 10 h jermar /trunk/ Simplify the IPC_M_DATA_WRITE protocol. Do not pass the source address space
virtual address to the recipient. This feature was not used anyway. Now
IPC_M_DATA_WRITE and IPC_M_DATA_READ are feature-aligned.
 
2666 6033 d 1 h jermar /trunk/uspace/srv/ VFS and TMPFS support for VFS_WRITE.  
2663 6034 d 23 h jermar /trunk/uspace/ Reimplement VFS_READ using IPC_M_DATA_READ.  
2660 6035 d 1 h jermar /trunk/ Rename IPC_M_DATA_SEND to IPC_M_DATA_WRITE. Now, when we also add
IPC_M_DATA_READ, it will not clash and cause confusion with userspace wrappers
such as ipc_data_receive(). Rename the forementioned wrappers to
ipc_data_write_send(), ipc_data_write_receive() and ipc_data_write_deliver().
 
2659 6035 d 21 h jermar /trunk/uspace/srv/vfs/ After VFS_READ, update the position pointer in the open file.  
2658 6035 d 22 h jermar /trunk/uspace/srv/ VFS work.
Foundation for TMPFS-side VFS_READ and fixes in VFS-side VFS_READ.
 
2657 6036 d 0 h jermar /trunk/uspace/ VFS work.
Cleaner VFS_MOUNT protocol.
 
2654 6039 d 4 h jermar /trunk/uspace/srv/vfs/ VFS work.
Don't hang up the connection to VFS after VFS_MOUNT.
 
2653 6039 d 4 h jermar /trunk/uspace/srv/vfs/ VFS work.
Index of the last PLB character of a pathname was not correctly calculated.
 
2652 6039 d 4 h jermar /trunk/uspace/srv/vfs/ VFS work.
Fix VFS node hash function to hash only within the limits of its supposed
ranges.
 
2651 6039 d 4 h jermar /trunk/uspace/srv/vfs/ VFS work. Releas the FS phone earlier.  
2650 6039 d 4 h jermar /trunk/uspace/srv/vfs/ VFS work. FS info futex must be initialized.  
2641 6044 d 2 h jermar /trunk/uspace/srv/vfs/ VFS work.
During VFS_REGISTER, use strncmp() instead of strcmp().
Add one excessive convenience byte to vfs_info.name to support the
above-mentioned change. In case the fs name spans all available
characters, make sure this convenience byte is zero.
 
2637 6054 d 1 h cejka /trunk/ Extended IPC_M_CONNECT_TO_ME to use 3 user defined parameters.
Phone identifier is passed in ARG5.
 
2635 6056 d 1 h cejka /trunk/ Function ipc_connect_me_to sends 3 user defined arguments now.
One argument added also to ipc_forward_fast.
Fixed devmap and improved its test.
 
2625 6064 d 2 h jermar /trunk/uspace/srv/vfs/ VFS work.
Proto implementation of VFS_READ.
 
2624 6064 d 2 h jermar /trunk/uspace/srv/vfs/ Add sanity checks to functions using file descriptors as indices into files.  
2619 6067 d 23 h jermar /trunk/ Modify ipc_answer_*() to make use of all six syscall arguments. The recommended
means of answering calls is via the ipc_answer_m() macros (where m denotes the
number of return arguments) that automatically decide between the fast register
version or the slow universal version of ipc_answer().