public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Mingming Cao <cmm@us.ibm.com>
To: Andrew Morton <akpm@osdl.org>
Cc: Hugh Dickins <hugh@veritas.com>, Mel Gorman <mel@skynet.ie>,
	"Martin J. Bligh" <mbligh@mbligh.org>,
	linux-kernel@vger.kernel.org
Subject: Re: Boot failure with ext2 and initrds
Date: Thu, 16 Nov 2006 01:05:01 -0800	[thread overview]
Message-ID: <1163667901.4310.53.camel@localhost.localdomain> (raw)
In-Reply-To: <20061114113120.d4c22b02.akpm@osdl.org>

On Tue, 2006-11-14 at 11:31 -0800, Andrew Morton wrote:
> On Tue, 14 Nov 2006 19:11:22 +0000 (GMT)
> Hugh Dickins <hugh@veritas.com> wrote:
> 
> > On Tue, 14 Nov 2006, Mel Gorman wrote:
> > > 2.6.19-rc5-mm2
> > > 
> > > Am seeing errors with systems using ext2. First machine is a plan old x86
> > > using initramfs. Console output looks like;
> > > ...
> > > Configuring network interfaces...BUG: soft lockup detected on CPU#3!
> > > ...
> > >  [<c01b3b80>] ext2_try_to_allocate+0xdb/0x152
> > >  [<c01b3e72>] ext2_try_to_allocate_with_rsv+0x4b/0x1b2
> > > 
> > > I've not investigated yet what patches might be at fault.
> > 
> > I expect you'll find it's
> > ext2-reservations-bring-ext2-reservations-code-in-line-with-latest-ext3.patch
> > which gets stuck in a loop there for me too: back it out and all seems fine.
> > 
> > It's not obvious which part of the patch is to blame: mostly it's
> > cleanup, but a few variables do change size: I'm currently narrowing
> > down to where a fix is needed.
> > 
> 
> Doing s/-Wall/-W/ tends to shake out bugs in this stuff.
> 
> The below might help.
> 
> Sorry, I tested this well, then the cleanup patch was merged and I didn't
> get onto retesting :(
> 
> 
> 
> From: Andrew Morton <akpm@osdl.org>
> 
> Signed-off-by: Andrew Morton <akpm@osdl.org>
> ---
> 
>  fs/ext2/balloc.c |   33 +++++++++++++++------------------
>  1 files changed, 15 insertions(+), 18 deletions(-)
> 
> diff -puN fs/ext2/balloc.c~ext2-reservations-bring-ext2-reservations-code-in-line-with-latest-ext3-fix fs/ext2/balloc.c
> --- a/fs/ext2/balloc.c~ext2-reservations-bring-ext2-reservations-code-in-line-with-latest-ext3-fix
> +++ a/fs/ext2/balloc.c
> @@ -1155,9 +1155,10 @@ int ext2_new_blocks(struct inode *inode,

This is different from ext3.  Shouldn't the return value from
ext2_new_blocks() a ext2_fsblk_t type?

ext2_alloc_blocks() already thinks that ext2_new_blocks return unsigned
block number.


>  	struct buffer_head *gdp_bh;
>  	int group_no;
>  	int goal_group;
> +	ext2_grpblk_t grp_target_blk;	/* blockgroup relative goal block */
> +	ext2_grpblk_t grp_alloc_blk;	/* blockgroup-relative allocated block*/
>  	ext2_fsblk_t ret_block;		/* filesyetem-wide allocated block */
>  	int bgi;			/* blockgroup iteration index */
> -	int target_block;
>  	int performed_allocation = 0;
>  	ext2_grpblk_t free_blocks;	/* number of free blocks in a group */
>  	struct super_block *sb;
> @@ -1230,14 +1231,15 @@ retry_alloc:
>  		my_rsv = NULL;
> 
>  	if (free_blocks > 0) {
> -		ret_block = ((goal - le32_to_cpu(es->s_first_data_block)) %
> +		grp_target_blk = ((goal - le32_to_cpu(es->s_first_data_block)) %
>  				EXT2_BLOCKS_PER_GROUP(sb));
>  		bitmap_bh = read_block_bitmap(sb, group_no);
>  		if (!bitmap_bh)
>  			goto io_error;
> -		ret_block = ext2_try_to_allocate_with_rsv(sb, group_no,
> -					bitmap_bh, ret_block, my_rsv, &num);
> -		if (ret_block >= 0)
> +		grp_alloc_blk = ext2_try_to_allocate_with_rsv(sb, group_no,
> +					bitmap_bh, grp_target_blk,
> +					my_rsv, &num);
> +		if (grp_alloc_blk >= 0)
>  			goto allocated;
>  	}
> 
> @@ -1273,9 +1275,9 @@ retry_alloc:
>  		/*
>  		 * try to allocate block(s) from this group, without a goal(-1).
>  		 */
> -		ret_block = ext2_try_to_allocate_with_rsv(sb, group_no,
> +		grp_alloc_blk = ext2_try_to_allocate_with_rsv(sb, group_no,
>  					bitmap_bh, -1, my_rsv, &num);
> -		if (ret_block >= 0)
> +		if (grp_alloc_blk >= 0)
>  			goto allocated;
>  	}
>  	/*
> @@ -1299,25 +1301,20 @@ allocated:
>  	ext2_debug("using block group %d(%d)\n",
>  			group_no, gdp->bg_free_blocks_count);
> 
> -	target_block = ret_block + group_no * EXT2_BLOCKS_PER_GROUP(sb)
> -				+ le32_to_cpu(es->s_first_data_block);
> +	ret_block = grp_alloc_blk + ext2_group_first_block_no(sb, group_no);
> 
> -	if (in_range(le32_to_cpu(gdp->bg_block_bitmap), target_block, num) ||
> -	    in_range(le32_to_cpu(gdp->bg_inode_bitmap), target_block, num) ||
> -	    in_range(target_block, le32_to_cpu(gdp->bg_inode_table),
> +	if (in_range(le32_to_cpu(gdp->bg_block_bitmap), ret_block, num) ||
> +	    in_range(le32_to_cpu(gdp->bg_inode_bitmap), ret_block, num) ||
> +	    in_range(ret_block, le32_to_cpu(gdp->bg_inode_table),
>  		      EXT2_SB(sb)->s_itb_per_group) ||
> -	    in_range(target_block + num - 1, le32_to_cpu(gdp->bg_inode_table),
> +	    in_range(ret_block + num - 1, le32_to_cpu(gdp->bg_inode_table),
>  		      EXT2_SB(sb)->s_itb_per_group))
>  		ext2_error(sb, "ext2_new_blocks",
>  			    "Allocating block in system zone - "
> -			    "blocks from %u, length %lu", target_block, num);
> +			    "blocks from %u, length %lu", ret_block, num);
> 
>  	performed_allocation = 1;
> 
> -
> -	/* ret_block was blockgroup-relative.  Now it becomes fs-relative */
> -	ret_block = target_block;
> -
>  	if (ret_block + num - 1 >= le32_to_cpu(es->s_blocks_count)) {
>  		ext2_error(sb, "ext2_new_blocks",
>  			    "block("E2FSBLK") >= blocks count(%d) - "
> _
> 
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 


  parent reply	other threads:[~2006-11-16  9:05 UTC|newest]

Thread overview: 185+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-11-14  9:41 2.6.19-rc5-mm2 Andrew Morton
2006-11-14 11:11 ` 2.6.19-rc5-mm2 Jiri Slaby
2006-11-14 11:54   ` 2.6.19-rc5-mm2 Jiri Slaby
2006-11-14 11:31 ` 2.6.19-rc5-mm2 Reuben Farrelly
2006-11-14 17:00   ` 2.6.19-rc5-mm2 Gautham R Shenoy
2006-11-14 20:58     ` 2.6.19-rc5-mm2 Mattia Dongili
2006-11-15 10:34       ` 2.6.19-rc5-mm2 Gautham R Shenoy
2006-11-15 10:42         ` 2.6.19-rc5-mm2 Reuben Farrelly
2006-11-14 12:46 ` 2.6.19-rc5-mm2 Mariusz Kozlowski
2006-11-14 13:07   ` 2.6.19-rc5-mm2 Mariusz Kozlowski
2006-11-14 16:41   ` 2.6.19-rc5-mm2 Andrew Morton
2006-11-14 17:09     ` 2.6.19-rc5-mm2 Andrew Morton
2006-11-14 19:23       ` 2.6.19-rc5-mm2 Mariusz Kozlowski
2006-11-14 13:50 ` 2.6.19-rc5-mm2 Eric Dumazet
2006-11-14 18:33 ` [-mm patch] fix the DLM dependencies Adrian Bunk
2006-11-14 22:56   ` [-mm patch] fix the DLM dependencies, part 2 Adrian Bunk
2006-11-15 10:11     ` Patrick Caulfield
2006-11-15 10:23       ` Adrian Bunk
2006-11-14 18:49 ` Boot failure with ext2 and initrds Mel Gorman
2006-11-14 19:08   ` Martin Bligh
2006-11-14 19:11   ` Hugh Dickins
2006-11-14 19:21     ` Martin Bligh
2006-11-14 20:20       ` Hugh Dickins
2006-11-14 20:30         ` Martin Bligh
2006-11-14 19:31     ` Andrew Morton
2006-11-14 21:18       ` Hugh Dickins
2006-11-14 21:19         ` Martin Bligh
2006-11-15 14:17         ` Hugh Dickins
2006-11-15 15:32           ` Martin J. Bligh
2006-11-15 15:56             ` Hugh Dickins
2006-11-16  5:45           ` Andrew Morton
2006-11-16  6:39             ` Andrew Morton
2006-11-16  6:55             ` Mingming Cao
2006-11-16  7:22               ` Andrew Morton
2006-11-16  8:49                 ` Mingming Cao
2006-11-16  9:13                   ` Andrew Morton
2006-11-16  9:37                     ` Alex Tomas
2006-11-16  9:48                       ` Andrew Morton
2006-11-16  9:49                         ` Andrew Morton
2006-11-16 16:26                     ` Hugh Dickins
2006-11-16 20:15                     ` Mingming Cao
2006-11-16 21:27                       ` Andrew Morton
2006-11-20 16:19                         ` Hugh Dickins
2006-11-20 20:54                           ` Hugh Dickins
2006-11-21  1:36                             ` Mingming Cao
2006-11-21  1:47                           ` Mingming Cao
2006-11-21  5:39                             ` Hugh Dickins
2006-11-22  0:43                               ` Mingming Cao
2006-11-28 17:38                                 ` Hugh Dickins
2006-11-28 17:40                                   ` [PATCH 1/6] ext2 balloc: fix _with_rsv freeze Hugh Dickins
2006-11-28 19:26                                     ` Mingming Cao
2006-11-28 20:07                                       ` Hugh Dickins
2006-11-29  0:42                                         ` Mingming Cao
2006-11-29  4:14                                     ` [PATCH 6/12] " Mingming Cao
2006-11-29  4:15                                     ` [PATCH 12/12] ext3 " Mingming Cao
2006-11-28 17:40                                   ` [PATCH 2/6] ext2 balloc: reset windowsz when full Hugh Dickins
2006-11-28 19:36                                     ` Mingming Cao
2006-11-29  4:14                                     ` [PATCH 2/12] ext3 balloc: fix off-by-one against grp_goal Mingming Cao
2006-11-29  4:15                                     ` [PATCH 8/12] ext4 " Mingming Cao
2006-11-28 17:41                                   ` [PATCH 3/6] ext2 balloc: fix off-by-one against rsv_end Hugh Dickins
2006-11-28 19:42                                     ` Mingming Cao
2006-11-28 17:42                                   ` [PATCH 4/6] ext2 balloc: fix off-by-one against grp_goal Hugh Dickins
2006-11-28 23:30                                     ` Mingming Cao
2006-11-29  4:13                                     ` [PATCH 1/12] ext3 balloc: reset windowsz when full Mingming Cao
2006-11-29  5:46                                       ` Hugh Dickins
2006-11-29  4:14                                     ` [PATCH 3/12] ext3 balloc: fix off-by-one against rsv_end Mingming Cao
2006-11-29  4:14                                     ` [PATCH 7/12] ext4 balloc: reset windowsz when full Mingming Cao
2006-11-29  4:15                                     ` [PATCH 9/12] ext4 balloc: fix off-by-one against rsv_end Mingming Cao
2006-11-28 17:43                                   ` [PATCH 5/6] ext2 balloc: say rb_entry not list_entry Hugh Dickins
2006-11-28 23:30                                     ` Mingming Cao
2006-11-29  4:14                                     ` [PATCH 4/12] ext3 " Mingming Cao
2006-11-29  4:15                                     ` [PATCH 10/12] ext4 " Mingming Cao
2006-11-28 17:44                                   ` [PATCH 6/6] ext2 balloc: use io_error label Hugh Dickins
2006-11-28 23:31                                     ` Mingming Cao
2006-11-29  4:14                                     ` [PATCH 5/12] ext3 " Mingming Cao
2006-11-29  4:15                                     ` [PATCH 11/12] ext4 " Mingming Cao
2006-11-28 21:04                                   ` Boot failure with ext2 and initrds Mingming Cao
2006-11-28 22:33                                     ` Andrew Morton
2006-11-28 23:38                                       ` Mingming Cao
2006-11-16 12:34                 ` Russell King
2006-11-25 14:59                   ` Russell King
2006-11-29  7:40                     ` Russell King
2006-11-29  8:30                       ` Andrew Morton
2006-11-29  9:20                         ` Russell King
2006-11-29  9:39                           ` Andrew Morton
2006-11-29 18:16                             ` Russell King
2006-11-14 21:19       ` Mel Gorman
2006-11-15  0:25       ` Andy Whitcroft
2006-11-15  0:58         ` Andrew Morton
2006-11-15 23:54           ` Andy Whitcroft
2006-11-16  9:05       ` Mingming Cao [this message]
2006-11-14 20:02 ` 2.6.19-rc5-mm2: no help text for FAULT_INJECTION Adrian Bunk
2006-11-14 21:12   ` [PATCH -mm] CONFIG_FAULT_INJECTION help text Akinobu Mita
2006-11-14 21:15     ` [PATCH -mm] failslab: remove __GFP_HIGHMEM filtering Akinobu Mita
2006-11-14 22:56 ` 2.6.19-rc5-mm2: warnings in MODPOST and later Adrian Bunk
2006-11-14 23:09   ` Andrew Morton
2006-11-15  7:42     ` Arjan van de Ven
2006-11-14 23:13 ` and in www.kernel.org page? Re: 2.6.19-rc5-mm2 Sergio Monteiro Basto
2006-11-15 23:16 ` 2.6.19-rc5-mm2: paravirt X86_PAE=y compile error Adrian Bunk
2006-11-15 23:36   ` Andrew Morton
2006-11-16  1:30     ` Zachary Amsden
2006-11-16  2:27       ` Chris Wright
2006-11-16  7:05         ` Andi Kleen
2006-11-28 23:36     ` Randy Dunlap
2006-11-16 12:16 ` [-mm patch] remove arch/i386/kernel/time_hpet.c:hpet_reenable() Adrian Bunk
2006-11-16 17:17 ` 2.6.19-rc5-mm2 Mattia Dongili
2006-11-16 18:29   ` 2.6.19-rc5-mm2 Stefan Richter
2006-11-16 20:39     ` 2.6.19-rc5-mm2 Mattia Dongili
2006-11-16 22:50       ` 2.6.19-rc5-mm2 Stefan Richter
2006-11-17  7:16         ` 2.6.19-rc5-mm2 Mattia Dongili
2006-11-17 15:02           ` 2.6.19-rc5-mm2 Stefan Richter
2006-11-17 15:24             ` 2.6.19-rc5-mm2 (Oops in class_device_remove_attrs during nodemgr_remove_host) Stefan Richter
2006-11-18  9:47               ` Greg KH
2006-11-18 11:27                 ` Stefan Richter
2006-11-18 17:07                   ` Stefan Richter
2006-11-18 21:45                     ` Stefan Richter
2006-11-18 22:08                       ` Stefan Richter
2006-11-19  8:56                       ` Mattia Dongili
2006-11-19 16:22                       ` ohci1394 oops bisected [was Re: 2.6.19-rc5-mm2 (Oops in class_device_remove_attrs during nodemgr_remove_host)] Mattia Dongili
2006-11-19 17:13                         ` Stefan Richter
2006-11-19 20:33                           ` Andrew Morton
2006-11-19 21:01                             ` Stefan Richter
2006-11-24  8:41                               ` Greg KH
2006-11-24 17:13                                 ` Stefan Richter
2006-11-19 17:14                         ` Gene Heskett
2006-11-19 18:07                           ` Kino segfault (was Re: ohci1394 oops bisected) Stefan Richter
2006-11-19 20:11                             ` Gene Heskett
2006-11-17  1:19 ` [-mm patch] crypto/xcbc.c: make some code static Adrian Bunk
2006-11-17  2:44   ` Herbert Xu
2006-11-17  1:19 ` [-mm patch] make drivers/acpi/bay.c:drive_bays static Adrian Bunk
2006-11-17  1:19 ` [-mm patch] make drivers/base/core.c:setup_parent() static Adrian Bunk
2006-11-17  1:19 ` [-mm patch] make geode_aes_crypt() static Adrian Bunk
2006-11-17 12:42 ` -mm: cx88-blackbird.c: unused code re-added Adrian Bunk
2006-11-17 13:53   ` [v4l-dvb-maintainer] " Michael Krufky
2006-11-17 14:13   ` Mauro Carvalho Chehab
2006-11-17 14:21 ` [-mm patch] drivers/media/video/cafe_ccic.c: make a function static Adrian Bunk
2006-11-17 14:21 ` [-mm patch] remove drivers/pci/search.c:pci_find_device_reverse() Adrian Bunk
2006-11-17 14:32   ` Alan Cox
2006-11-18  0:06     ` [2.6 patch] mark pci_find_device() as __deprecated Adrian Bunk
2006-11-18  1:42       ` Alan
2006-11-19  9:47       ` Arjan van de Ven
2006-11-19  9:52         ` Muli Ben-Yehuda
2006-11-19 10:01           ` Arjan van de Ven
2006-11-19 14:06           ` Adrian Bunk
2006-11-19 15:24             ` Muli Ben-Yehuda
2006-11-19 15:49               ` Adrian Bunk
2006-11-19 16:50               ` Arjan van de Ven
2006-11-19 14:04         ` Adrian Bunk
2006-11-19 14:13           ` Arjan van de Ven
2006-11-19 14:27             ` Adrian Bunk
2006-11-17 19:54   ` [-mm patch] remove drivers/pci/search.c:pci_find_device_reverse() Andrew Morton
2006-11-17 20:33     ` Adrian Bunk
2006-11-17 22:16     ` Alan Cox
2006-11-19  9:44     ` Arjan van de Ven
2006-11-17 17:02 ` [-mm patch] make net/core/skbuff.c:skb_over_panic() static Adrian Bunk
2006-11-21  0:55   ` David Miller
2006-11-21  1:37     ` Andrew Morton
2006-11-21  1:40       ` David Miller
2006-11-21  1:39     ` David Miller
2006-11-17 17:02 ` [-mm patch] security/slim/slm_main.c: make 2 functions static Adrian Bunk
2006-11-17 23:58 ` [-mm patch] make sound/pci/hda/patch_sigmatel.c:stac92xx_dmic_labels[] static Adrian Bunk
2006-11-20 16:44   ` [Alsa-devel] " Takashi Iwai
2006-11-17 23:58 ` [-mm patch] make mm/thrash.c:global_faults static Adrian Bunk
2006-11-17 23:59 ` [RFC: -mm patch] remove kernel/timer.c:wall_jiffies Adrian Bunk
2006-11-18  7:00   ` Ingo Molnar
2006-11-17 23:59 ` [RFC: -mm patch] make kernel/timer.c:__next_timer_interrupt() static Adrian Bunk
2006-11-18  6:58   ` Ingo Molnar
2006-11-20  2:23 ` [-mm patch] drivers/scsi/scsi_scan.c: make 2 functions static Adrian Bunk
2006-11-20  2:34   ` Matthew Wilcox
2006-11-20  2:24 ` [-mm patch] fs/dlm/lowcomms-tcp.c: remove 2 functions Adrian Bunk
2006-11-20  2:24 ` [-mm patch] make ext2_get_blocks() static Adrian Bunk
2006-11-20  2:24 ` [-mm patch] fs/reiser4/: possible cleanups Adrian Bunk
2006-11-21 18:37 ` -mm: please drop reiser4-export-handle_ra_miss.patch Adrian Bunk
2006-11-21 19:42 ` [-mm patch] unexport {,__}remove_from_page_cache Adrian Bunk
2006-11-22  3:23 ` 2.6.19-rc5-mm2: suspend related BLOCK=n compile error Adrian Bunk
2006-11-22  3:34   ` Randy Dunlap
2006-11-22 11:20     ` Rafael J. Wysocki
2006-11-22  4:17 ` [-mm patch] CACHEFILES must depend on PROC_FS Adrian Bunk
2006-11-22  4:35   ` Randy Dunlap
2006-11-22  4:17 ` [-mm patch] fs/fscache/main.c: cleanups Adrian Bunk
2006-11-22  4:38 ` [-mm patch] drivers/mtd/nand/rtc_from4.c: use lib/bitrev.c Adrian Bunk
2006-11-28 22:19   ` David Woodhouse
2006-11-28 22:49     ` Andrew Morton
2006-11-28 22:52       ` David Woodhouse
2006-11-29  0:09         ` Andrew Morton

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1163667901.4310.53.camel@localhost.localdomain \
    --to=cmm@us.ibm.com \
    --cc=akpm@osdl.org \
    --cc=hugh@veritas.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mbligh@mbligh.org \
    --cc=mel@skynet.ie \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox