From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Vegard Nossum" Subject: Re: latest -git: A peculiar case of a stuck process (ext3/sched-related?) Date: Fri, 18 Jul 2008 12:39:18 +0200 Message-ID: <19f34abd0807180339k4d359fb4sc1cc556567f4f3f3@mail.gmail.com> References: <19f34abd0807180245l2a633644n1a8d91cb3587d9e4@mail.gmail.com> <19f34abd0807180317g40a218a2p2bb2857c6f5aa659@mail.gmail.com> <20080718033225.c141978c.akpm@linux-foundation.org> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Cc: linux-ext4@vger.kernel.org, sct@redhat.com, adilger@sun.com, "Ingo Molnar" , "Peter Zijlstra" , "Linux Kernel Mailing List" To: "Andrew Morton" Return-path: Received: from qb-out-0506.google.com ([72.14.204.230]:23830 "EHLO qb-out-0506.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754748AbYGRKjW (ORCPT ); Fri, 18 Jul 2008 06:39:22 -0400 Received: by qb-out-0506.google.com with SMTP id p36so1307684qba.17 for ; Fri, 18 Jul 2008 03:39:19 -0700 (PDT) In-Reply-To: <20080718033225.c141978c.akpm@linux-foundation.org> Content-Disposition: inline Sender: linux-ext4-owner@vger.kernel.org List-ID: On Fri, Jul 18, 2008 at 12:32 PM, Andrew Morton wrote: > On Fri, 18 Jul 2008 12:17:17 +0200 "Vegard Nossum" wrote: > >> And the ext3_find_entry() corresponds to this line: >> >> for (; de < top; de = ext3_next_entry(de)) /* <--- HERE! */ >> if (ext3_match (namelen, name, de)) { >> if (!ext3_check_dir_entry("ext3_find_entry", >> dir, de, bh, >> (block<> +((char *)de - bh->b_data))) { >> brelse (bh); >> *err = ERR_BAD_DX_DIR; >> goto errout; >> } >> *res_dir = de; >> dx_release (frames); >> return bh; >> } >> >> Is it possible that this loop can get stuck with a corrupt filesystem image? > > yup. ext2 did that a couple of times. See the explicit check for > de->rec_len == 0 in ext2_find_entry(). > > We fixed one filesystem and forgot the others. Again. Wow, that change is OLD, though: commit aa4f3f285643956bb614cf7b8f88e15f3a375886 Author: Andrew Morton Date: Mon Apr 29 23:51:34 2002 -0700 [PATCH] ext2 directory handling Will you also send the patch for ext3? :-) Vegard -- "The animistic metaphor of the bug that maliciously sneaked in while the programmer was not looking is intellectually dishonest as it disguises that the error is the programmer's own creation." -- E. W. Dijkstra, EWD1036