[Bcache v13 00/16]

From: Kent Overstreet
Date: Wed May 09 2012 - 23:07:35 EST


bcache: a cache for arbitrary block devices using an SSD.

Short overview:
Bcache does both writethrough and writeback caching. It presents itself as a
new block device, a bit like say md. You can cache an arbitrary number of
block devices with a single cache device, and attach and detach things at
runtime - it's quite flexible.

It's very fast. It uses a b+ tree for the index, along with a journal to
coalesce index updates, and a bunch of other cool tricks like auxiliary binary
search trees with software floating point keys for searching within btree
nodes.

Bcache is solid, production ready code. There are still bugs being found that
affect specific configurations, but there haven't been any major issues found
in awhile - it's well past time I started working on getting it into mainline.

It's a lot of code - I tried to split it out so that it'd make some sort of
sense for reviewing. Let me know if there's anything else I can do to make
review easier.

TODO/known issues:

__up_write() needs to be exported for bcache to compile as a module - it's
used for bypassing lockdep when traversing the btree during garbage
collection. If someone else knows a better solution, please let me know.

The userspace interface is going to change before it goes in. The general
consensus at LSF was that we don't want yet another interface for
probing/managing block devices, and dm exists so we may as well use that. I
don't think anyone's started on that yet, though.

Documentation needs to be updated. That's being actively worked on, though.

Kent Overstreet (16):
Only clone bio vecs that are in use
Bio pool freeing
Revert "rw_semaphore: remove up/down_read_non_owner"
Fix ratelimit macro to compile in c99 mode
Export get_random_int()
Export blk_fill_rwbs()
Closures
bcache: Documentation, and changes to generic code
Bcache: generic utility code
bcache: Superblock/initialization/sysfs code
bcache: Core btree code
bcache: Bset code (lookups within a btree node)
bcache: Journalling
bcache: Request, io and allocation code
bcache: Writeback
bcache: Debug and tracing code

Documentation/ABI/testing/sysfs-block-bcache | 156 ++
Documentation/bcache.txt | 255 +++
block/blk-core.c | 2 +-
drivers/block/Kconfig | 2 +
drivers/block/Makefile | 1 +
drivers/block/bcache/Kconfig | 42 +
drivers/block/bcache/Makefile | 8 +
drivers/block/bcache/alloc.c | 591 +++++++
drivers/block/bcache/bcache.h | 839 ++++++++++
drivers/block/bcache/bset.c | 1149 +++++++++++++
drivers/block/bcache/bset.h | 218 +++
drivers/block/bcache/btree.c | 2249 ++++++++++++++++++++++++++
drivers/block/bcache/btree.h | 272 ++++
drivers/block/bcache/debug.c | 574 +++++++
drivers/block/bcache/debug.h | 53 +
drivers/block/bcache/io.c | 198 +++
drivers/block/bcache/journal.c | 722 +++++++++
drivers/block/bcache/journal.h | 113 ++
drivers/block/bcache/request.c | 1470 +++++++++++++++++
drivers/block/bcache/request.h | 58 +
drivers/block/bcache/stats.c | 243 +++
drivers/block/bcache/stats.h | 58 +
drivers/block/bcache/super.c | 2000 +++++++++++++++++++++++
drivers/block/bcache/sysfs.c | 802 +++++++++
drivers/block/bcache/sysfs.h | 99 ++
drivers/block/bcache/trace.c | 26 +
drivers/block/bcache/util.c | 572 +++++++
drivers/block/bcache/util.h | 657 ++++++++
drivers/block/bcache/writeback.c | 518 ++++++
drivers/block/rbd.c | 2 +-
drivers/char/random.c | 1 +
drivers/md/dm.c | 27 +-
drivers/md/md.c | 3 +-
fs/bio.c | 55 +-
include/linux/bio.h | 7 +-
include/linux/blk_types.h | 2 +
include/linux/cgroup_subsys.h | 6 +
include/linux/closure.h | 614 +++++++
include/linux/ratelimit.h | 2 +-
include/linux/rwsem.h | 10 +
include/linux/sched.h | 4 +
include/trace/events/bcache.h | 257 +++
kernel/fork.c | 4 +
kernel/rwsem.c | 16 +
kernel/trace/blktrace.c | 1 +
lib/Kconfig | 3 +
lib/Kconfig.debug | 9 +
lib/Makefile | 2 +
lib/closure.c | 363 +++++
49 files changed, 15288 insertions(+), 47 deletions(-)
create mode 100644 Documentation/ABI/testing/sysfs-block-bcache
create mode 100644 Documentation/bcache.txt
create mode 100644 drivers/block/bcache/Kconfig
create mode 100644 drivers/block/bcache/Makefile
create mode 100644 drivers/block/bcache/alloc.c
create mode 100644 drivers/block/bcache/bcache.h
create mode 100644 drivers/block/bcache/bset.c
create mode 100644 drivers/block/bcache/bset.h
create mode 100644 drivers/block/bcache/btree.c
create mode 100644 drivers/block/bcache/btree.h
create mode 100644 drivers/block/bcache/debug.c
create mode 100644 drivers/block/bcache/debug.h
create mode 100644 drivers/block/bcache/io.c
create mode 100644 drivers/block/bcache/journal.c
create mode 100644 drivers/block/bcache/journal.h
create mode 100644 drivers/block/bcache/request.c
create mode 100644 drivers/block/bcache/request.h
create mode 100644 drivers/block/bcache/stats.c
create mode 100644 drivers/block/bcache/stats.h
create mode 100644 drivers/block/bcache/super.c
create mode 100644 drivers/block/bcache/sysfs.c
create mode 100644 drivers/block/bcache/sysfs.h
create mode 100644 drivers/block/bcache/trace.c
create mode 100644 drivers/block/bcache/util.c
create mode 100644 drivers/block/bcache/util.h
create mode 100644 drivers/block/bcache/writeback.c
create mode 100644 include/linux/closure.h
create mode 100644 include/trace/events/bcache.h
create mode 100644 lib/closure.c

--
1.7.9.rc2

--
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/