r3056: added a id -> pointer data structure (a type of radix tree). This is
authorAndrew Tridgell <tridge@samba.org>
Tue, 19 Oct 2004 06:39:51 +0000 (06:39 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 18:01:54 +0000 (13:01 -0500)
commitcf1b85348a0fc5bf4788291109c9dca9e95eb9c2
tree4ddd852640cc81c255677a7a6057a6d84b692a45
parent2b8aa720f47804f783679388f40a9345eff897b9
r3056: added a id -> pointer data structure (a type of radix tree). This is
an extremely efficient way of mapping from an integer handle (such as
an open file handle) to a pointer (such as the structure containing
the open file information). The code is taken from lib/idr.c in the
2.6 Linux kernel, and is very fast and space efficient. By using
talloc it even has auto cleanup.

This commit converts the handling of open file handles and open
directory search handles to use the idtree routines. In combination
with talloc destructors, this simplifies the structure handling in the
pvfs backend a lot. For example, we no longer need to keep a linked
list of open directory searches at all, and we no longer need to do
linear scans of the list of open files on most operations.

The end result is that the pvfs code is now extremely scalable. You
can have 10s of thousands of open files and open searches and the code
still runs very fast.

I have also added a small optimisation into the file close path, to
avoid looking in the byte range locking database if we know that there
are no locks outstanding.
(This used to be commit 16835a0ef91a16fa01145b773aad8d43da215dbf)
source4/ntvfs/common/idtree.c [new file with mode: 0644]
source4/ntvfs/posix/config.mk
source4/ntvfs/posix/pvfs_lock.c
source4/ntvfs/posix/pvfs_open.c
source4/ntvfs/posix/pvfs_search.c
source4/ntvfs/posix/vfs_posix.c
source4/ntvfs/posix/vfs_posix.h