Re: [patch] arca-vm-2.2.5

Ingo Molnar (mingo@chiara.csoma.elte.hu)
Wed, 7 Apr 1999 00:19:36 +0200 (CEST)


On Tue, 6 Apr 1999, Stephen C. Tweedie wrote:

-#define i (((unsigned long) inode)/(sizeof(struct inode) \
& ~ (sizeof(struct inode) - 1)))
+#define i (((unsigned long) inode-PAGE_OFFSET)/(sizeof(struct inode) \
& ~ (sizeof(struct inode) - 1)))

> This just ends up adding or subtracting a constant to the hash function,
> so won't have any effect at all on the occupancy distribution of the
> hash buckets.

btw. shouldnt it rather be something like:

#define log2(x) \
({ \
int __res; \
\
switch (x) { \
case 0x040 ... 0x07f: __res = 0x040; break; \
case 0x080 ... 0x0ff: __res = 0x080; break; \
case 0x100 ... 0x1ff: __res = 0x100; break; \
case 0x200 ... 0x3ff: __res = 0x200; break; \
case 0x400 ... 0x7ff: __res = 0x400; break; \
case 0x800 ... 0xfff: __res = 0x800; break; \
} \
__res; \
})

#define i (((unsigned long) inode)/log2(sizeof(struct inode)))

because otherwise we 'over-estimate' and include systematic bits in the
supposedly random index. Eg. in 2.2.5 the size of struct inode is 0x110,
which means 'i' will have values 0x11, 0x22, 0x33, for inodes within the
same page. (we'd preferably have i == 0x01, 0x02, 0x03...)

the hash was designed when struct inode has a size of 512 i think, for
which the original #define was correct. But for 0x110 it isnt IMHO. (my
above macros produce i==0,1,2...0xf iterated over inode addresses within
the same physical page.)

-- mingo

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