On Thu, 2006-11-30 at 12:16 +0000, Steven Whitehouse wrote:
> >From bfded27ba010d1c3b0aa3843f97dc9b80de751be Mon Sep 17 00:00:00 2001
> From: Steven Whitehouse <[EMAIL PROTECTED]>
> Date: Wed, 1 Nov 2006 16:05:38 -0500
> Subject: [PATCH] [GFS2] Shrink gfs2_inode (8) - i_vn
> 
> This shrinks the size of the gfs2_inode by 8 bytes by
> replacing the version counter with a one bit valid/invalid
> flag.
What is the version number used for?
It seems like anything that was specifically carving a 64 container
has a more specific reason that just ON/OFF?



> 
> Signed-off-by: Steven Whitehouse <[EMAIL PROTECTED]>
> ---
>  fs/gfs2/glops.c     |    5 +++--
>  fs/gfs2/incore.h    |    2 +-
>  fs/gfs2/inode.c     |    4 ++--
>  fs/gfs2/ops_inode.c |    2 +-
>  4 files changed, 7 insertions(+), 6 deletions(-)
> 
> diff --git a/fs/gfs2/glops.c b/fs/gfs2/glops.c
> index aad45b7..9c20337 100644
> --- a/fs/gfs2/glops.c
> +++ b/fs/gfs2/glops.c
> @@ -305,8 +305,9 @@ static void inode_go_inval(struct gfs2_g
>       int data = (flags & DIO_DATA);
>  
>       if (meta) {
> +             struct gfs2_inode *ip = gl->gl_object;
>               gfs2_meta_inval(gl);
> -             gl->gl_vn++;
> +             set_bit(GIF_INVALID, &ip->i_flags);
>       }
>       if (data)
>               gfs2_page_inval(gl);
> @@ -351,7 +352,7 @@ static int inode_go_lock(struct gfs2_hol
>       if (!ip)
>               return 0;
>  
> -     if (ip->i_vn != gl->gl_vn) {
> +     if (test_bit(GIF_INVALID, &ip->i_flags)) {
>               error = gfs2_inode_refresh(ip);
>               if (error)
>                       return error;
> diff --git a/fs/gfs2/incore.h b/fs/gfs2/incore.h
> index c0a8c3b..227a74d 100644
> --- a/fs/gfs2/incore.h
> +++ b/fs/gfs2/incore.h
> @@ -217,6 +217,7 @@ struct gfs2_alloc {
>  };
>  
>  enum {
> +     GIF_INVALID             = 0,
>       GIF_QD_LOCKED           = 1,
>       GIF_PAGED               = 2,
>       GIF_SW_PAGED            = 3,
> @@ -228,7 +229,6 @@ struct gfs2_inode {
>  
>       unsigned long i_flags;          /* GIF_... */
>  
> -     u64 i_vn;
>       struct gfs2_dinode_host i_di; /* To be replaced by ref to block */
>  
>       struct gfs2_glock *i_gl; /* Move into i_gh? */
> diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c
> index f6177fc..e467780 100644
> --- a/fs/gfs2/inode.c
> +++ b/fs/gfs2/inode.c
> @@ -145,7 +145,7 @@ struct inode *gfs2_inode_lookup(struct s
>               if (unlikely(error))
>                       goto fail_put;
>  
> -             ip->i_vn = ip->i_gl->gl_vn - 1;
> +             set_bit(GIF_INVALID, &ip->i_flags);
>               error = gfs2_glock_nq_init(io_gl, LM_ST_SHARED, GL_EXACT, 
> &ip->i_iopen_gh);
>               if (unlikely(error))
>                       goto fail_iopen;
> @@ -242,7 +242,7 @@ int gfs2_inode_refresh(struct gfs2_inode
>  
>       error = gfs2_dinode_in(ip, dibh->b_data);
>       brelse(dibh);
> -     ip->i_vn = ip->i_gl->gl_vn;
> +     clear_bit(GIF_INVALID, &ip->i_flags);
>  
>       return error;
>  }
> diff --git a/fs/gfs2/ops_inode.c b/fs/gfs2/ops_inode.c
> index 0e4eade..b247f25 100644
> --- a/fs/gfs2/ops_inode.c
> +++ b/fs/gfs2/ops_inode.c
> @@ -844,7 +844,7 @@ static int gfs2_permission(struct inode 
>       struct gfs2_holder i_gh;
>       int error;
>  
> -     if (ip->i_vn == ip->i_gl->gl_vn)
> +     if (!test_bit(GIF_INVALID, &ip->i_flags))
>               return generic_permission(inode, mask, gfs2_check_acl);
>  
>       error = gfs2_glock_nq_init(ip->i_gl, LM_ST_SHARED, LM_FLAG_ANY, &i_gh);
-- 
Russell Cattelan <[EMAIL PROTECTED]>

Attachment: signature.asc
Description: This is a digitally signed message part

Reply via email to