Re: Learning ext2 fs

From: Fawad Lateef
Date: Thu Oct 27 2005 - 13:29:05 EST


On 10/27/05, Paulo da Silva <psdasilva@xxxxxxxxxxxx> wrote:
> I am reading the ext2 fs code. One of my purposes
> is to save the original data of a file to another file
> just before it is changed by write/mmap/whatever.
> Because of mmap (any other reasons?) I thought
> of doing this at "ext2-writepage" or/and
> "ext2-writepages".
>
> Is this the right place?

ya, AFAIK ext2-writepage/s and ext2-readpage/s are the functions
actually dealing with the file data and you can also see
generic_file_write/read assigned to the fields in ext2_file_operations
variable because they also deals with the file data ...

> Is there a lower level where I can read/write blocks
> of data from/to hd instead of full pages?
>

I think at the lower-level you can deal with the block-layer but at
this layer AFAIK you won't be able to distinguish between file data
and file system data/structures because you will be dealing with just
the blocks/chunks of data for block devices.

> How do I tell the really file data from other data?
>

the functions readpage/writepage deals with the file data only not
with the file-system data/structures. Here I am considering by saying
other data you mean file-system data/structures


> I traced these functions but I only got
> "ext2-writepages" to be called. "ext2-writepage"
> was never called using the programs
> I wrote to test this. When is "ext2-writepage" called?
>

I think it doesn't matter that writepage or writepages are called
because both almost do the same thing and the writepages version deals
with more data and in your case the data may be big enough to handle
by the writepages.

> Thanks for any help.
> Any readings advice is also welcome.
>

I think you can first get some detailed understanding of VFS layer and
then you can easily understand the code of the file-system like EXT2 !

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