aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoel Becker <joel.becker@oracle.com>2008-10-24 20:04:49 -0400
committerMark Fasheh <mfasheh@suse.com>2009-01-05 11:34:16 -0500
commit3e6329463e3a5c311e1d607ff3db735a18b6d67a (patch)
tree9c27f3e08be43e93f69103561f197d2beee22c97
parent51def39f0cabd46131c7c4df08751cb0cb9433d1 (diff)
ocfs2: Convenient access to an xattr bucket's header.
The xattr code often wants to access the ocfs2_xattr_header at the start of an bucket. Rather than walk the pointer chains, let's just create another nice macro. As a side benefit, we can get rid of the mostly spurious ->bu_xh element on the bucket structure. The idea is ripped from the ocfs2_path code. Signed-off-by: Joel Becker <joel.becker@oracle.com> Signed-off-by: Mark Fasheh <mfasheh@suse.com>
-rw-r--r--fs/ocfs2/xattr.c28
1 files changed, 12 insertions, 16 deletions
diff --git a/fs/ocfs2/xattr.c b/fs/ocfs2/xattr.c
index 8594df36640e..1b77302b54ff 100644
--- a/fs/ocfs2/xattr.c
+++ b/fs/ocfs2/xattr.c
@@ -62,7 +62,6 @@ struct ocfs2_xattr_def_value_root {
62 62
63struct ocfs2_xattr_bucket { 63struct ocfs2_xattr_bucket {
64 struct buffer_head *bu_bhs[OCFS2_XATTR_MAX_BLOCKS_PER_BUCKET]; 64 struct buffer_head *bu_bhs[OCFS2_XATTR_MAX_BLOCKS_PER_BUCKET];
65 struct ocfs2_xattr_header *bu_xh;
66}; 65};
67 66
68#define OCFS2_XATTR_ROOT_SIZE (sizeof(struct ocfs2_xattr_def_value_root)) 67#define OCFS2_XATTR_ROOT_SIZE (sizeof(struct ocfs2_xattr_def_value_root))
@@ -156,6 +155,7 @@ static inline u16 ocfs2_xattr_max_xe_in_bucket(struct super_block *sb)
156 155
157#define bucket_blkno(_b) ((_b)->bu_bhs[0]->b_blocknr) 156#define bucket_blkno(_b) ((_b)->bu_bhs[0]->b_blocknr)
158#define bucket_block(_b, _n) ((_b)->bu_bhs[(_n)]->b_data) 157#define bucket_block(_b, _n) ((_b)->bu_bhs[(_n)]->b_data)
158#define bucket_xh(_b) ((struct ocfs2_xattr_header *)bucket_block((_b), 0))
159 159
160static inline const char *ocfs2_xattr_prefix(int name_index) 160static inline const char *ocfs2_xattr_prefix(int name_index)
161{ 161{
@@ -798,7 +798,7 @@ static int ocfs2_xattr_block_get(struct inode *inode,
798 798
799 if (le16_to_cpu(xb->xb_flags) & OCFS2_XATTR_INDEXED) { 799 if (le16_to_cpu(xb->xb_flags) & OCFS2_XATTR_INDEXED) {
800 ret = ocfs2_xattr_bucket_get_name_value(inode, 800 ret = ocfs2_xattr_bucket_get_name_value(inode,
801 xs->bucket.bu_xh, 801 bucket_xh(&xs->bucket),
802 i, 802 i,
803 &block_off, 803 &block_off,
804 &name_offset); 804 &name_offset);
@@ -2280,11 +2280,9 @@ static int ocfs2_xattr_bucket_find(struct inode *inode,
2280 bh = NULL; 2280 bh = NULL;
2281 } 2281 }
2282 xs->bucket.bu_bhs[0] = lower_bh; 2282 xs->bucket.bu_bhs[0] = lower_bh;
2283 xs->bucket.bu_xh = (struct ocfs2_xattr_header *)
2284 bucket_block(&xs->bucket, 0);
2285 lower_bh = NULL; 2283 lower_bh = NULL;
2286 2284
2287 xs->header = xs->bucket.bu_xh; 2285 xs->header = bucket_xh(&xs->bucket);
2288 xs->base = bucket_block(&xs->bucket, 0); 2286 xs->base = bucket_block(&xs->bucket, 0);
2289 xs->end = xs->base + inode->i_sb->s_blocksize; 2287 xs->end = xs->base + inode->i_sb->s_blocksize;
2290 2288
@@ -2379,17 +2377,16 @@ static int ocfs2_iterate_xattr_buckets(struct inode *inode,
2379 goto out; 2377 goto out;
2380 } 2378 }
2381 2379
2382 bucket.bu_xh = (struct ocfs2_xattr_header *)bucket_block(&bucket, 0);
2383 /* 2380 /*
2384 * The real bucket num in this series of blocks is stored 2381 * The real bucket num in this series of blocks is stored
2385 * in the 1st bucket. 2382 * in the 1st bucket.
2386 */ 2383 */
2387 if (i == 0) 2384 if (i == 0)
2388 num_buckets = le16_to_cpu(bucket.bu_xh->xh_num_buckets); 2385 num_buckets = le16_to_cpu(bucket_xh(&bucket)->xh_num_buckets);
2389 2386
2390 mlog(0, "iterating xattr bucket %llu, first hash %u\n", 2387 mlog(0, "iterating xattr bucket %llu, first hash %u\n",
2391 (unsigned long long)blkno, 2388 (unsigned long long)blkno,
2392 le32_to_cpu(bucket.bu_xh->xh_entries[0].xe_name_hash)); 2389 le32_to_cpu(bucket_xh(&bucket)->xh_entries[0].xe_name_hash));
2393 if (func) { 2390 if (func) {
2394 ret = func(inode, &bucket, para); 2391 ret = func(inode, &bucket, para);
2395 if (ret) { 2392 if (ret) {
@@ -2444,14 +2441,14 @@ static int ocfs2_list_xattr_bucket(struct inode *inode,
2444 int i, block_off, new_offset; 2441 int i, block_off, new_offset;
2445 const char *prefix, *name; 2442 const char *prefix, *name;
2446 2443
2447 for (i = 0 ; i < le16_to_cpu(bucket->bu_xh->xh_count); i++) { 2444 for (i = 0 ; i < le16_to_cpu(bucket_xh(bucket)->xh_count); i++) {
2448 struct ocfs2_xattr_entry *entry = &bucket->bu_xh->xh_entries[i]; 2445 struct ocfs2_xattr_entry *entry = &bucket_xh(bucket)->xh_entries[i];
2449 type = ocfs2_xattr_get_type(entry); 2446 type = ocfs2_xattr_get_type(entry);
2450 prefix = ocfs2_xattr_prefix(type); 2447 prefix = ocfs2_xattr_prefix(type);
2451 2448
2452 if (prefix) { 2449 if (prefix) {
2453 ret = ocfs2_xattr_bucket_get_name_value(inode, 2450 ret = ocfs2_xattr_bucket_get_name_value(inode,
2454 bucket->bu_xh, 2451 bucket_xh(bucket),
2455 i, 2452 i,
2456 &block_off, 2453 &block_off,
2457 &new_offset); 2454 &new_offset);
@@ -2631,8 +2628,7 @@ static int ocfs2_xattr_update_xattr_search(struct inode *inode,
2631 2628
2632 xs->bucket.bu_bhs[0] = new_bh; 2629 xs->bucket.bu_bhs[0] = new_bh;
2633 get_bh(new_bh); 2630 get_bh(new_bh);
2634 xs->bucket.bu_xh = (struct ocfs2_xattr_header *)bucket_block(&xs->bucket, 0); 2631 xs->header = bucket_xh(&xs->bucket);
2635 xs->header = xs->bucket.bu_xh;
2636 2632
2637 xs->base = new_bh->b_data; 2633 xs->base = new_bh->b_data;
2638 xs->end = xs->base + inode->i_sb->s_blocksize; 2634 xs->end = xs->base + inode->i_sb->s_blocksize;
@@ -4398,7 +4394,7 @@ static void ocfs2_xattr_bucket_remove_xs(struct inode *inode,
4398 struct ocfs2_xattr_search *xs) 4394 struct ocfs2_xattr_search *xs)
4399{ 4395{
4400 handle_t *handle = NULL; 4396 handle_t *handle = NULL;
4401 struct ocfs2_xattr_header *xh = xs->bucket.bu_xh; 4397 struct ocfs2_xattr_header *xh = bucket_xh(&xs->bucket);
4402 struct ocfs2_xattr_entry *last = &xh->xh_entries[ 4398 struct ocfs2_xattr_entry *last = &xh->xh_entries[
4403 le16_to_cpu(xh->xh_count) - 1]; 4399 le16_to_cpu(xh->xh_count) - 1];
4404 int ret = 0; 4400 int ret = 0;
@@ -4533,7 +4529,7 @@ static int ocfs2_check_xattr_bucket_collision(struct inode *inode,
4533 struct ocfs2_xattr_bucket *bucket, 4529 struct ocfs2_xattr_bucket *bucket,
4534 const char *name) 4530 const char *name)
4535{ 4531{
4536 struct ocfs2_xattr_header *xh = bucket->bu_xh; 4532 struct ocfs2_xattr_header *xh = bucket_xh(bucket);
4537 u32 name_hash = ocfs2_xattr_name_hash(inode, name, strlen(name)); 4533 u32 name_hash = ocfs2_xattr_name_hash(inode, name, strlen(name));
4538 4534
4539 if (name_hash != le32_to_cpu(xh->xh_entries[0].xe_name_hash)) 4535 if (name_hash != le32_to_cpu(xh->xh_entries[0].xe_name_hash))
@@ -4703,7 +4699,7 @@ static int ocfs2_delete_xattr_in_bucket(struct inode *inode,
4703 void *para) 4699 void *para)
4704{ 4700{
4705 int ret = 0; 4701 int ret = 0;
4706 struct ocfs2_xattr_header *xh = bucket->bu_xh; 4702 struct ocfs2_xattr_header *xh = bucket_xh(bucket);
4707 u16 i; 4703 u16 i;
4708 struct ocfs2_xattr_entry *xe; 4704 struct ocfs2_xattr_entry *xe;
4709 4705