android_kernel_google_msm/fs/ufs
Evgeniy Dushistov c37336b078 [PATCH] ufs: write to hole in big file
On UFS, this scenario:
	open(O_TRUNC)
	lseek(1024 * 1024 * 80)
	write("A")
	lseek(1024 * 2)
	write("A")

may cause access to invalid address.

This happened because of "goal" is calculated in wrong way in block
allocation path, as I see this problem exists also in 2.4.

We use construction like this i_data[lastfrag], i_data array of pointers to
direct blocks, indirect and so on, it has ceratain size ~20 elements, and
lastfrag may have value for example 40000.

Also this patch fixes related to handling such scenario issues, wrong
zeroing metadata, in case of block(not fragment) allocation, and wrong goal
calculation, when we allocate block

Signed-off-by: Evgeniy Dushistov <dushistov@mail.ru>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2006-08-27 11:01:31 -07:00
..
balloc.c [PATCH] ufs: handle truncated pages 2006-08-06 08:57:46 -07:00
cylinder.c
dir.c
file.c
ialloc.c
inode.c [PATCH] ufs: write to hole in big file 2006-08-27 11:01:31 -07:00
Makefile
namei.c
super.c
swab.h
symlink.c
truncate.c
util.c [PATCH] ufs: handle truncated pages 2006-08-06 08:57:46 -07:00
util.h