Commit e295cfcb authored by Evgeniy Dushistov's avatar Evgeniy Dushistov Committed by Linus Torvalds

[PATCH] ufs: fix oops with `ufs1' type

"rm" command, on file system with "ufs1" type cause system hang up.  This
is, in fact, not so bad as it seems to be, because of after that in "kernel
control path" there are 3-4 places which may cause "oops".

So the first patch fix oopses, and the second patch fix "kernel hang up".

"oops" appears because of reading of group's summary info partly wrong, and
access to not first group's summary info cause "oops".
Signed-off-by: default avatarEvgeniy Dushistov <dushistov@mail.ru>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 19dfe31c
...@@ -388,7 +388,8 @@ static int ufs_parse_options (char * options, unsigned * mount_options) ...@@ -388,7 +388,8 @@ static int ufs_parse_options (char * options, unsigned * mount_options)
/* /*
* Read on-disk structures associated with cylinder groups * Read on-disk structures associated with cylinder groups
*/ */
static int ufs_read_cylinder_structures (struct super_block *sb) { static int ufs_read_cylinder_structures (struct super_block *sb)
{
struct ufs_sb_info * sbi = UFS_SB(sb); struct ufs_sb_info * sbi = UFS_SB(sb);
struct ufs_sb_private_info * uspi; struct ufs_sb_private_info * uspi;
struct ufs_super_block *usb; struct ufs_super_block *usb;
...@@ -415,6 +416,7 @@ static int ufs_read_cylinder_structures (struct super_block *sb) { ...@@ -415,6 +416,7 @@ static int ufs_read_cylinder_structures (struct super_block *sb) {
base = space = kmalloc(size, GFP_KERNEL); base = space = kmalloc(size, GFP_KERNEL);
if (!base) if (!base)
goto failed; goto failed;
sbi->s_csp = (struct ufs_csum *)space;
for (i = 0; i < blks; i += uspi->s_fpb) { for (i = 0; i < blks; i += uspi->s_fpb) {
size = uspi->s_bsize; size = uspi->s_bsize;
if (i + uspi->s_fpb > blks) if (i + uspi->s_fpb > blks)
...@@ -430,7 +432,6 @@ static int ufs_read_cylinder_structures (struct super_block *sb) { ...@@ -430,7 +432,6 @@ static int ufs_read_cylinder_structures (struct super_block *sb) {
goto failed; goto failed;
ubh_ubhcpymem (space, ubh, size); ubh_ubhcpymem (space, ubh, size);
sbi->s_csp[ufs_fragstoblks(i)]=(struct ufs_csum *)space;
space += size; space += size;
ubh_brelse (ubh); ubh_brelse (ubh);
...@@ -486,7 +487,8 @@ static int ufs_read_cylinder_structures (struct super_block *sb) { ...@@ -486,7 +487,8 @@ static int ufs_read_cylinder_structures (struct super_block *sb) {
* Put on-disk structures associated with cylinder groups and * Put on-disk structures associated with cylinder groups and
* write them back to disk * write them back to disk
*/ */
static void ufs_put_cylinder_structures (struct super_block *sb) { static void ufs_put_cylinder_structures (struct super_block *sb)
{
struct ufs_sb_info * sbi = UFS_SB(sb); struct ufs_sb_info * sbi = UFS_SB(sb);
struct ufs_sb_private_info * uspi; struct ufs_sb_private_info * uspi;
struct ufs_buffer_head * ubh; struct ufs_buffer_head * ubh;
...@@ -499,7 +501,7 @@ static void ufs_put_cylinder_structures (struct super_block *sb) { ...@@ -499,7 +501,7 @@ static void ufs_put_cylinder_structures (struct super_block *sb) {
size = uspi->s_cssize; size = uspi->s_cssize;
blks = (size + uspi->s_fsize - 1) >> uspi->s_fshift; blks = (size + uspi->s_fsize - 1) >> uspi->s_fshift;
base = space = (char*) sbi->s_csp[0]; base = space = (char*) sbi->s_csp;
for (i = 0; i < blks; i += uspi->s_fpb) { for (i = 0; i < blks; i += uspi->s_fpb) {
size = uspi->s_bsize; size = uspi->s_bsize;
if (i + uspi->s_fpb > blks) if (i + uspi->s_fpb > blks)
......
...@@ -502,8 +502,7 @@ struct ufs_super_block { ...@@ -502,8 +502,7 @@ struct ufs_super_block {
/* /*
* Convert cylinder group to base address of its global summary info. * Convert cylinder group to base address of its global summary info.
*/ */
#define fs_cs(indx) \ #define fs_cs(indx) s_csp[(indx)]
s_csp[(indx) >> uspi->s_csshift][(indx) & ~uspi->s_csmask]
/* /*
* Cylinder group block for a file system. * Cylinder group block for a file system.
......
...@@ -25,7 +25,7 @@ struct ufs_csum; ...@@ -25,7 +25,7 @@ struct ufs_csum;
struct ufs_sb_info { struct ufs_sb_info {
struct ufs_sb_private_info * s_uspi; struct ufs_sb_private_info * s_uspi;
struct ufs_csum * s_csp[UFS_MAXCSBUFS]; struct ufs_csum * s_csp;
unsigned s_bytesex; unsigned s_bytesex;
unsigned s_flags; unsigned s_flags;
struct buffer_head ** s_ucg; struct buffer_head ** s_ucg;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment