Re: Finding hardlinks

From: Nikita Danilov
Date: Thu Jan 04 2007 - 08:59:56 EST


Mikulas Patocka writes:
> > > BTW. How does ReiserFS find that a given inode number (or object ID in
> > > ReiserFS terminology) is free before assigning it to new file/directory?
> >
> > reiserfs v3 has an extent map of free object identifiers in
> > super-block.
>
> Inode free space can have at most 2^31 extents --- if inode numbers
> alternate between "allocated", "free". How do you pack it to superblock?

In the worst case, when free/used extents are small, some free oids are
"leaked", but this has never been problem in practice. In fact, there
was a patch for reiserfs v3 to store this map in special hidden file but
it wasn't included in mainline, as nobody ever complained about oid map
fragmentation.

>
> > reiser4 used 64 bit object identifiers without reuse.
>
> So you are going to hit the same problem as I did with SpadFS --- you
> can't export 64-bit inode number to userspace (programs without
> -D_FILE_OFFSET_BITS=64 will have stat() randomly failing with EOVERFLOW
> then) and if you export only 32-bit number, it will eventually wrap-around
> and colliding st_ino will cause data corruption with many userspace
> programs.

Indeed, this is fundamental problem. Reiser4 tries to ameliorate it by
using hash function that starts colliding only when there are billions
of files, in which case 32bit inode number is screwed anyway.

Note, that none of the above problems invalidates reasons for having
long in-kernel inode identifiers that I outlined in other message.

>
> Mikulas

Nikita.

-
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/