[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-id: <20081117180801.GC3146@webber.adilger.int>
Date: Mon, 17 Nov 2008 12:08:01 -0600
From: Andreas Dilger <adilger@....com>
To: Frank Mayhar <fmayhar@...gle.com>
Cc: linux-ext4@...r.kernel.org, Michael Rubin <mrubin@...gle.com>
Subject: Re: [RFC PATCH 1/1] Allow ext4 to run without a journal, take 2.
On Nov 17, 2008 09:20 -0800, Frank Mayhar wrote:
> > > + if (handle->h_transaction == NULL)
> > > + return 0;
> >
> > Does this ever happen? Ah, is this the case where the handle is pointing
> > to the ext4_sb_info()? I think I'd prefer to have a magic value here,
> > so that it isn't possible to accidentally dereference a pointer that
> > happens to have NULL data in it.
>
> So some magic value that gets stuffed into the pointer? Or just a magic
> pointer value that gets stuffed into 'handle'?
I mean a magic value that is stuffed into the s_nojournal_flag pointer
instead of just using NULL (which is a very common value of pointers to
random memory). Ideally this value will be chosen in a way that it is
unlikely to be a valid pointer (e.g. 0x01234567 for 32-bit machines,
0x0123456789abcdef for 64-bit machines).
> > So, this appears to be the place where ext4_sb_info->s_nojournal_flag is
> > actually used. To make this more clear, it would be better to do actually
> > reference this variable here so that it is easier for the reader to follow.
> >
> > current->journal_info = &EXT4_SB(sb)->s_nojournal_flag;
>
> Hmm. Okay, I'll have to think about this a bit; I haven't had my coffee
> yet.
This is functionally equivalent to the method you are using (i.e. it stores
the pointer to the start of the struct), except that it allows the reader
to find where this field is used.
Cheers, Andreas
--
Andreas Dilger
Sr. Staff Engineer, Lustre Group
Sun Microsystems of Canada, Inc.
--
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists