linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Tao Ma <tao.ma@oracle.com>
To: Mark Fasheh <mfasheh@suse.com>
Cc: linux-kernel@vger.kernel.org, joel.becker@oracle.com,
	ocfs2-devel@oss.oracle.com, linux-fsdevel@vger.kernel.org
Subject: Re: [PATCH 0/39] Ocfs2 updates for 2.6.28
Date: Sun, 28 Sep 2008 13:16:49 +0800	[thread overview]
Message-ID: <48DF1341.8070101@oracle.com> (raw)
In-Reply-To: <1222293680-15451-1-git-send-email-mfasheh@suse.com>

Hi Mark,
	do you see my 2 patches for xattr?
http://oss.oracle.com/pipermail/ocfs2-devel/2008-September/002839.html
this is pretty straightforward and I think it can be committed with it.
http://oss.oracle.com/pipermail/ocfs2-devel/2008-September/002839.html
this is the new support for empty bucket.

Regards,
Tao


Mark Fasheh wrote:
> Hi,
> 
> 	The following patches comprise the bulk of Ocfs2 updates for the
> 2.6.28 merge window. They can roughly be broken up into 4 sets which add
> incremental features to Ocfs2. The patches are presented as they come in
> git.
> 
> 
> EA Support
> 
> The largest set adds support for extended attributes in Ocfs2. Extended
> attributes are stored both within the inode block, and externally, when their
> numbers grow. Individual attributes can be arbitrarily sized. Smaller ones
> have their data stored inline. Larger attributes grow out to a btree. In
> theory the btrees have similar limits to inode data. In practice though, the
> VFS limits EA sizes to 64K.
> 
> When inode space for attributes run low, new ones are created in an external
> disk block. When the block fills up, external attributes are moved to an
> indexed btree. The btree can store many thousands of attributes, if needed.
> 
> The patches leading up to EA support further abstracted portions of the Ocfs2
> btree code. Ultimately, this means we can "add" a btree to any Ocfs2 structure
> by embedding a header, and providing the proper callbacks to manipulate
> certain key fields. The xattr code makes use of this, as will future Ocfs2
> features.
> 
> Joel made some further improvements to our 'generic' (for Ocfs2 at least)
> btree support which completed the interface by cleaning things up and
> providing for proper callbacks in a static operations structure. Those patches
> follow the xattr series as they were developed afterwards.
> 
> 
> JBD2 Support
> 
> Ocfs2 can now use JBD2. Amongst other benefits, this allows us to support
> large block devices with more than 32 bits worth of block numbers. As a part
> of these patches, and 'inode64' mount option is added which toggles creation
> of inodes whose inode number requires more than 32 bits to be adequately
> described.
> 
> JBD2 support in Ocfs2 is compiled in by default, however since journaling is
> so central to the operation of a file system, we kept our 'legacy' JBD
> support. We did this to provide a fallback for any users who might hit a
> problem, while we fix it. Legacy JBD support will be removed from Ocfs2 in
> 2.6.29.
> 
> 
> Cluster Aware POSIX File Locks
> 
> This was added via the 'plock' interface which Dave Teigland pulled into
> fs/dlm last merge window. The majority of the support is actually provided in
> userspace via the dlm_controld. As a result, cluster-aware POSIX locks only
> work for userspace cluster stacks right now.
> 
> 
> Local Alloc Throttling
> 
> These patches allow the "local alloc" file in Ocfs2 to throttle back the
> number of free disk blocks it caches. This is done during times of extreme
> fragmentation, or very low disk space. The traditional behavior was to
> completely disable the local alloc feature, which resulted in performance
> problems on some corner cases. The throttling has increased performance by 10
> times during such situations.
> 
> 
> Please pull from 'merge_window' branch of
> git://git.kernel.org/pub/scm/linux/kernel/git/mfasheh/ocfs2.git merge_window
> 
> to receive the following updates:
> 
>  Documentation/filesystems/ocfs2.txt |    4 +
>  fs/Kconfig                          |   40 +-
>  fs/ocfs2/Makefile                   |    5 +-
>  fs/ocfs2/alloc.c                    |  857 +++++--
>  fs/ocfs2/alloc.h                    |   86 +-
>  fs/ocfs2/aops.c                     |   49 +-
>  fs/ocfs2/cluster/masklog.c          |    1 +
>  fs/ocfs2/cluster/masklog.h          |    1 +
>  fs/ocfs2/dir.c                      |   26 +-
>  fs/ocfs2/extent_map.c               |   60 +
>  fs/ocfs2/extent_map.h               |    3 +
>  fs/ocfs2/file.c                     |  313 +--
>  fs/ocfs2/file.h                     |   32 +-
>  fs/ocfs2/inode.c                    |   28 +-
>  fs/ocfs2/inode.h                    |    4 +
>  fs/ocfs2/journal.c                  |   72 +-
>  fs/ocfs2/journal.h                  |   52 +-
>  fs/ocfs2/localalloc.c               |  362 +++-
>  fs/ocfs2/localalloc.h               |    4 +
>  fs/ocfs2/locks.c                    |   15 +
>  fs/ocfs2/locks.h                    |    1 +
>  fs/ocfs2/namei.c                    |   13 +-
>  fs/ocfs2/ocfs2.h                    |   56 +-
>  fs/ocfs2/ocfs2_fs.h                 |  220 ++-
>  fs/ocfs2/ocfs2_jbd_compat.h         |   82 +
>  fs/ocfs2/stack_user.c               |   33 +
>  fs/ocfs2/stackglue.c                |   20 +
>  fs/ocfs2/stackglue.h                |   19 +
>  fs/ocfs2/suballoc.c                 |  205 ++-
>  fs/ocfs2/suballoc.h                 |   26 +-
>  fs/ocfs2/super.c                    |   59 +-
>  fs/ocfs2/symlink.c                  |    9 +
>  fs/ocfs2/uptodate.c                 |   38 +-
>  fs/ocfs2/uptodate.h                 |    3 +
>  fs/ocfs2/xattr.c                    | 4851 +++++++++++++++++++++++++++++++++++
>  fs/ocfs2/xattr.h                    |   68 +
>  fs/ocfs2/xattr_trusted.c            |   82 +
>  fs/ocfs2/xattr_user.c               |   94 +
>  38 files changed, 7271 insertions(+), 622 deletions(-)
>  create mode 100644 fs/ocfs2/ocfs2_jbd_compat.h
>  create mode 100644 fs/ocfs2/xattr.c
>  create mode 100644 fs/ocfs2/xattr.h
>  create mode 100644 fs/ocfs2/xattr_trusted.c
>  create mode 100644 fs/ocfs2/xattr_user.c
> 
> Joel Becker (15):
>       ocfs2: Prefix the extent tree operations structure.
>       ocfs2: Prefix the ocfs2_extent_tree structure.
>       ocfs2: Make ocfs2_extent_tree get/put instead of alloc.
>       ocfs2: Make 'private' into 'object' on ocfs2_extent_tree.
>       ocfs2: Provide the get_root_el() method to ocfs2_extent_tree_operations.
>       ocfs2: Use struct ocfs2_extent_tree in ocfs2_num_free_extents().
>       ocfs2: Determine an extent tree's max_leaf_clusters in an et_op.
>       ocfs2: Create specific get_extent_tree functions.
>       ocfs2: Add an insertion check to ocfs2_extent_tree_operations.
>       ocfs2: Make ocfs2_extent_tree the first-class representation of a tree.
>       ocfs2: Comment struct ocfs2_extent_tree_operations.
>       ocfs2: Change ocfs2_get_*_extent_tree() to ocfs2_init_*_extent_tree()
>       ocfs2: Limit inode allocation to 32bits.
>       ocfs2: Add the 'inode64' mount option.
>       ocfs2: Switch over to JBD2.
> 
> Mark Fasheh (5):
>       ocfs2: POSIX file locks support
>       ocfs2: Track local alloc bits internally
>       ocfs2: throttle back local alloc when low on disk space
>       ocfs2: track local alloc state via debugfs
>       ocfs2: fix printk format warnings
> 
> Sunil Mushran (1):
>       ocfs2: Add xattr mount option in ocfs2_show_options()
> 
> Tao Ma (15):
>       ocfs2: Modify ocfs2_num_free_extents for future xattr usage.
>       ocfs2: Use ocfs2_extent_list instead of ocfs2_dinode.
>       ocfs2: Abstract ocfs2_extent_tree in b-tree operations.
>       ocfs2: Make high level btree extend code generic
>       ocfs2: Add the basic xattr disk layout in ocfs2_fs.h
>       ocfs2: Add helper function in uptodate.c for removing xattr clusters
>       ocfs2: Add extent tree operation for xattr value btrees
>       ocfs2: Add xattr index tree operations
>       ocfs2: Add xattr bucket iteration for large numbers of EAs
>       ocfs2: Add xattr lookup code xattr btrees
>       ocfs2: Optionally limit extent size in ocfs2_insert_extent()
>       ocfs2: Enable xattr set in index btree
>       ocfs2: Delete all xattr buckets during inode removal
>       ocfs2: bug-fix for journal extend in xattr.
>       ocfs2: Resolve deadlock in ocfs2_xattr_free_block.
> 
> Tiger Yang (3):
>       ocfs2: reserve inline space for extended attribute
>       ocfs2: Add extended attribute support
>       ocfs2: Add incompatible flag for extended attribute
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html

      parent reply	other threads:[~2008-09-28  5:17 UTC|newest]

Thread overview: 62+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-09-24 22:00 [PATCH 0/39] Ocfs2 updates for 2.6.28 Mark Fasheh
2008-09-24 22:00 ` [PATCH 01/39] ocfs2: POSIX file locks support Mark Fasheh
2008-10-02  6:11   ` Andrew Morton
2008-10-07 20:09     ` Mark Fasheh
2008-09-24 22:00 ` [PATCH 02/39] ocfs2: Track local alloc bits internally Mark Fasheh
2008-09-24 22:00 ` [PATCH 03/39] ocfs2: throttle back local alloc when low on disk space Mark Fasheh
2008-10-02  6:11   ` Andrew Morton
2008-09-24 22:00 ` [PATCH 04/39] ocfs2: track local alloc state via debugfs Mark Fasheh
2008-10-02  6:11   ` Andrew Morton
2008-10-07 20:10     ` Mark Fasheh
2008-09-24 22:00 ` [PATCH 05/39] ocfs2: Modify ocfs2_num_free_extents for future xattr usage Mark Fasheh
2008-09-24 22:00 ` [PATCH 06/39] ocfs2: Use ocfs2_extent_list instead of ocfs2_dinode Mark Fasheh
2008-09-24 22:00 ` [PATCH 07/39] ocfs2: Abstract ocfs2_extent_tree in b-tree operations Mark Fasheh
2008-09-24 22:00 ` [PATCH 08/39] ocfs2: Make high level btree extend code generic Mark Fasheh
2008-09-24 22:00 ` [PATCH 09/39] ocfs2: Add the basic xattr disk layout in ocfs2_fs.h Mark Fasheh
2008-09-24 22:00 ` [PATCH 10/39] ocfs2: Add helper function in uptodate.c for removing xattr clusters Mark Fasheh
2008-10-02  6:11   ` Andrew Morton
2008-10-07 20:18     ` Mark Fasheh
2008-09-24 22:00 ` [PATCH 11/39] ocfs2: Add extent tree operation for xattr value btrees Mark Fasheh
2008-10-02  6:12   ` Andrew Morton
2008-10-07 20:19     ` Mark Fasheh
2008-10-02  6:12   ` Andrew Morton
2008-10-07 21:19     ` Mark Fasheh
2008-09-24 22:00 ` [PATCH 12/39] ocfs2: reserve inline space for extended attribute Mark Fasheh
2008-09-24 22:00 ` [PATCH 13/39] ocfs2: Add extended attribute support Mark Fasheh
2008-10-02  6:12   ` Andrew Morton
2008-10-07 20:22     ` Mark Fasheh
2008-10-02  8:16   ` [Ocfs2-devel] " Christoph Hellwig
2008-10-07 22:08     ` Mark Fasheh
2008-10-08  1:56       ` Tiger Yang
2008-10-08 13:16         ` Christoph Hellwig
2008-10-08 13:34         ` Christoph Hellwig
2008-10-08 14:04           ` Tao Ma
2008-10-09  0:38             ` Mark Fasheh
2008-10-08 13:22       ` Christoph Hellwig
2008-09-24 22:00 ` [PATCH 14/39] ocfs2: Add xattr index tree operations Mark Fasheh
2008-09-24 22:00 ` [PATCH 15/39] ocfs2: Add xattr bucket iteration for large numbers of EAs Mark Fasheh
2008-09-24 22:00 ` [PATCH 16/39] ocfs2: Add xattr lookup code xattr btrees Mark Fasheh
2008-09-24 22:00 ` [PATCH 17/39] ocfs2: Optionally limit extent size in ocfs2_insert_extent() Mark Fasheh
2008-09-24 22:00 ` [PATCH 18/39] ocfs2: Enable xattr set in index btree Mark Fasheh
2008-09-24 22:01 ` [PATCH 19/39] ocfs2: Delete all xattr buckets during inode removal Mark Fasheh
2008-09-24 22:01 ` [PATCH 20/39] ocfs2: Add incompatible flag for extended attribute Mark Fasheh
2008-09-24 22:01 ` [PATCH 21/39] ocfs2: fix printk format warnings Mark Fasheh
2008-09-24 22:01 ` [PATCH 22/39] ocfs2: Prefix the extent tree operations structure Mark Fasheh
2008-09-24 22:01 ` [PATCH 23/39] ocfs2: Prefix the ocfs2_extent_tree structure Mark Fasheh
2008-09-24 22:01 ` [PATCH 24/39] ocfs2: Make ocfs2_extent_tree get/put instead of alloc Mark Fasheh
2008-09-24 22:01 ` [PATCH 25/39] ocfs2: Make 'private' into 'object' on ocfs2_extent_tree Mark Fasheh
2008-09-24 22:01 ` [PATCH 26/39] ocfs2: Provide the get_root_el() method to ocfs2_extent_tree_operations Mark Fasheh
2008-09-24 22:01 ` [PATCH 27/39] ocfs2: Use struct ocfs2_extent_tree in ocfs2_num_free_extents() Mark Fasheh
2008-09-24 22:01 ` [PATCH 28/39] ocfs2: Determine an extent tree's max_leaf_clusters in an et_op Mark Fasheh
2008-09-24 22:01 ` [PATCH 29/39] ocfs2: Create specific get_extent_tree functions Mark Fasheh
2008-09-24 22:01 ` [PATCH 30/39] ocfs2: Add an insertion check to ocfs2_extent_tree_operations Mark Fasheh
2008-09-24 22:01 ` [PATCH 31/39] ocfs2: Make ocfs2_extent_tree the first-class representation of a tree Mark Fasheh
2008-09-24 22:01 ` [PATCH 32/39] ocfs2: Comment struct ocfs2_extent_tree_operations Mark Fasheh
2008-09-24 22:01 ` [PATCH 33/39] ocfs2: Change ocfs2_get_*_extent_tree() to ocfs2_init_*_extent_tree() Mark Fasheh
2008-09-24 22:01 ` [PATCH 34/39] ocfs2: bug-fix for journal extend in xattr Mark Fasheh
2008-09-24 22:01 ` [PATCH 35/39] ocfs2: Resolve deadlock in ocfs2_xattr_free_block Mark Fasheh
2008-09-24 22:01 ` [PATCH 36/39] ocfs2: Limit inode allocation to 32bits Mark Fasheh
2008-09-24 22:01 ` [PATCH 37/39] ocfs2: Add the 'inode64' mount option Mark Fasheh
2008-09-24 22:01 ` [PATCH 38/39] ocfs2: Switch over to JBD2 Mark Fasheh
2008-09-24 22:01 ` [PATCH 39/39] ocfs2: Add xattr mount option in ocfs2_show_options() Mark Fasheh
2008-09-28  5:16 ` Tao Ma [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=48DF1341.8070101@oracle.com \
    --to=tao.ma@oracle.com \
    --cc=joel.becker@oracle.com \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mfasheh@suse.com \
    --cc=ocfs2-devel@oss.oracle.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).