On Wed, 2003-11-05 at 10:18, Martin Hicks wrote: > ext2 & ext3 lists, > > Attatched is a patch that allows ext2 and ext3 to link correctly when > the kernel is configured with a large NR_CPUS. We do have an immediate > need for this patch. > > Any opinions on this? The per-cpu lists are causing the kmalloc to fail > due to allocating more than the max. The last patch worked alright on a machine with an ext[23] root, but I missed a kfree()->vfree() conversion on the error path. This patch seems to make it better. mh -- Martin Hicks Wild Open Source Inc. mort@xxxxxxxxxxxxxxxxxx 613-266-2296 # This is a BitKeeper generated patch for the following project: # Project Name: Linux kernel tree # This patch format is intended for GNU patch command version 2.5 or higher. # This patch includes the following deltas: # ChangeSet 1.1356 -> 1.1358 # fs/ext2/super.c 1.55 -> 1.57 # fs/ext3/super.c 1.79 -> 1.81 # # The following is the BitKeeper ChangeSet Log # -------------------------------------------- # 03/11/04 mort@xxxxxxxxxxxxxx 1.1357 # Fix over-sized kmalloc() calls in ext[23]_get_super() when there are # large numbers of processors. This is due to the per-processor # variables in the ext[23] superblock structure. Replace kmalloc() with # vmalloc() # -------------------------------------------- # 03/11/05 mort@xxxxxxxxxxxxxxxx 1.1358 # Missed a kfree->vfree change. # -------------------------------------------- # diff -Nru a/fs/ext2/super.c b/fs/ext2/super.c --- a/fs/ext2/super.c Wed Nov 5 08:48:29 2003 +++ b/fs/ext2/super.c Wed Nov 5 08:48:29 2003 @@ -20,6 +20,7 @@ #include <linux/module.h> #include <linux/string.h> #include <linux/slab.h> +#include <linux/vmalloc.h> #include <linux/init.h> #include <linux/blkdev.h> #include <linux/parser.h> @@ -145,7 +146,7 @@ kfree(sbi->s_debts); brelse (sbi->s_sbh); sb->s_fs_info = NULL; - kfree(sbi); + vfree(sbi); return; } @@ -571,7 +572,7 @@ int db_count; int i, j; - sbi = kmalloc(sizeof(*sbi), GFP_KERNEL); + sbi = vmalloc(sizeof(*sbi)); if (!sbi) return -ENOMEM; sb->s_fs_info = sbi; @@ -847,7 +848,7 @@ brelse(bh); failed_sbi: sb->s_fs_info = NULL; - kfree(sbi); + vfree(sbi); return -EINVAL; } diff -Nru a/fs/ext3/super.c b/fs/ext3/super.c --- a/fs/ext3/super.c Wed Nov 5 08:48:29 2003 +++ b/fs/ext3/super.c Wed Nov 5 08:48:29 2003 @@ -25,6 +25,7 @@ #include <linux/ext3_fs.h> #include <linux/ext3_jbd.h> #include <linux/slab.h> +#include <linux/vmalloc.h> #include <linux/init.h> #include <linux/blkdev.h> #include <linux/parser.h> @@ -421,7 +422,7 @@ ext3_blkdev_remove(sbi); } sb->s_fs_info = NULL; - kfree(sbi); + vfree(sbi); return; } @@ -1044,7 +1045,7 @@ int i; int needs_recovery; - sbi = kmalloc(sizeof(*sbi), GFP_KERNEL); + sbi = vmalloc(sizeof(*sbi)); if (!sbi) return -ENOMEM; sb->s_fs_info = sbi; @@ -1404,7 +1405,7 @@ brelse(bh); out_fail: sb->s_fs_info = NULL; - kfree(sbi); + vfree(sbi); return -EINVAL; } _______________________________________________ Ext3-users@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/ext3-users