lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Mon, 04 Dec 2006 09:26:07 +0000
From:	Steven Whitehouse <swhiteho@...hat.com>
To:	Russell Cattelan <cattelan@...barn.com>
Cc:	cluster-devel@...hat.com, linux-kernel@...r.kernel.org
Subject: Re: [GFS2] Shrink gfs2_inode (8) - i_vn [28/70]

Hi,

On Fri, 2006-12-01 at 12:25 -0600, Russell Cattelan wrote:
> On Thu, 2006-11-30 at 12:16 +0000, Steven Whitehouse wrote:
> > >From bfded27ba010d1c3b0aa3843f97dc9b80de751be Mon Sep 17 00:00:00 2001
> > From: Steven Whitehouse <swhiteho@...hat.com>
> > 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?
> 
It was being used to show whether the glock had been released and thus
whether the inode needed to be reread from disk when the glock was next
taken. That doesn't require a 64 bit counter, a simple flag is perfectly
ok to indicate this,

Steve.

> 
> 
> > 
> > Signed-off-by: Steven Whitehouse <swhiteho@...hat.com>
> > ---
> >  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);

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ