Re: New filesystem for Linux



Mikulas Patocka wrote:
Hi


Hi

As my PhD thesis, I am designing and writing a filesystem, and it's now in
a state that it can be released. You can download it from
http://artax.karlin.mff.cuni.cz/~mikulas/spadfs/


Does not compile for me , using 2.6.18.1 , gcc 4.1.1. Here the error :

/work/crazy/packages/fs/spadfs-0.9.0/super.c: In function 'SPADFS_GET_SB':
/work/crazy/packages/fs/spadfs-0.9.0/super.c:636: error: too few
arguments to function 'get_sb_bdev'
/work/crazy/packages/fs/spadfs-0.9.0/super.c: At top level:
/work/crazy/packages/fs/spadfs-0.9.0/super.c:645: warning:
initialization from incompatible pointer type
/work/crazy/packages/fs/spadfs-0.9.0/super.c:651: warning:
initialization from incompatible pointer type
/work/crazy/packages/fs/spadfs-0.9.0/super.c: In function 'SPADFS_GET_SB':
/work/crazy/packages/fs/spadfs-0.9.0/super.c:637: warning: control
reaches end of non-void function
make[2]: *** [/work/crazy/packages/fs/spadfs-0.9.0/super.o] Error 1
make[1]: *** [_module_/work/crazy/packages/fs/spadfs-0.9.0] Error 2
make[1]: Leaving directory `/usr/src/linux-2.6.18-fw2'
make: *** [spadfs] Error 2



It has some new features, such as keeping inode information directly in
directory (until you create hardlink) so that ls -la doesn't seek much,
new method to keep data consistent in case of crashes (instead of
journaling), free space is organized in lists of free runs and converted
to bitmap only in case of extreme fragmentation.

It is not very widely tested, so if you want, test it.

I have these questions:

* There is a rw semaphore that is locked for read for nearly all
operations and locked for write only rarely. However locking for read
causes cache line pingpong on SMP systems. Do you have an idea how to make
it better?

It could be improved by making a semaphore for each CPU and locking for
read only the CPU's semaphore and for write all semaphores. Or is there a
better method?

* This leads to another observation --- on i386 locking a semaphore is 2
instructions, on x86_64 it is a call to two nested functions. Has it some
reason or was it just implementator's laziness? Given the fact that locked
instruction takes 16 ticks on Opteron (and can overlap about 2 ticks with
other instructions), it would make sense to have optimized semaphores too.

* How to implement ordered-data consistency? That would mean that on
internal sync event, I'd have to flush all pages of a files that were
extended. I could scan all dirty inodes and find pages to flush --- what
kernel function would you recommend for doing it? Currently I call only
sync_blockdev which doesn't touch buffers attached to pages.

Mikulas
-


Gabriel

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



Relevant Pages

  • New filesystem for Linux
    ... It could be improved by making a semaphore for each CPU and locking for read only the CPU's semaphore and for write all semaphores. ... Given the fact that locked instruction takes 16 ticks on Opteron (and can overlap about 2 ticks with other instructions), it would make sense to have optimized semaphores too. ... That would mean that on internal sync event, I'd have to flush all pages of a files that were extended. ...
    (Linux-Kernel)
  • [PATCH 3/6] Replace dquot flush semaphore with a completion
    ... Use the new completion flush code to implement the dquot ... * semaphore embedded in the dquot. ... Since we were able to lock the dquot's flush lock and ...
    (Linux-Kernel)
  • Re: [PATCH 1/19] MUTEX: Introduce simple mutex implementation
    ... in case of a semaphore it is a semantically correct use case. ... Think of "initialization" as a user. ... and as such the mutex should start out being held. ...
    (Linux-Kernel)
  • Re: [PATCH 1/19] MUTEX: Introduce simple mutex implementation
    ... >>> How does a MUTEX start off as locked. ... It is _not_ wrong to have a semaphore start out in locked state. ... it makes perfect sense if the data structures that the ... semaphore needs need initialization. ...
    (Linux-Kernel)
  • Re: [PATCH 1/19] MUTEX: Introduce simple mutex implementation
    ... It's not really a mutex, ... > It is _not_ wrong to have a semaphore start out in locked state. ... > semaphore needs need initialization. ... > to make the semaphore come up as locked, and the data structures in some ...
    (Linux-Kernel)