From: Lachlan McIlroy <lachlan@sgi.com>
To: xfs@oss.sgi.com
Subject: Re: 2.6.24-rc3 oopses while mounting fs
Date: Thu, 29 Nov 2007 10:56:42 +1100 [thread overview]
Message-ID: <474E003A.7020000@sgi.com> (raw)
In-Reply-To: <20071128134523.GF7793@luba>
[-- Attachment #1: Type: text/plain, Size: 3677 bytes --]
Peter,
This looks like a problem we've just fixed, try this patch.
We'll get this to mainline soon.
Lachlan
KELEMEN Peter wrote:
> Box is x86_64 with RHEL4 userspace. I have the log image saved
> and I can play with the filesystem if needed.
>
> Peter
>
> SGI XFS with ACLs, security attributes, realtime, large block/inode numbers, no debug enabled
> SGI XFS with ACLs, security attributes, realtime, large block/inode numbers, no debug enabled
> SGI XFS Quota Management subsystem
> XFS mounting filesystem sdc
> Starting XFS recovery on filesystem: sdc (logdev: internal)
> Unable to handle kernel paging request at ffffc20001c9b000 RIP:
> [<ffffffff881c6175>] :xfs:xlog_recover_add_to_trans+0x64/0xef
> PGD 15781d067 PUD 15781c067 PMD 130fda067 PTE 0
> Oops: 0000 [1] SMP
> CPU 0
> Modules linked in: xfs sd_mod 3w_9xxx scsi_mod ohci_hcd uhci_hcd ehci_hcd ipv6 bnx2 sky2 r8169 ns83820 dl2k acenic e100 tg3 e1000 mii
> Pid: 2434, comm: mount Not tainted 2.6.24-rc3 #1
> RIP: 0010:[<ffffffff881c6175>] [<ffffffff881c6175>] :xfs:xlog_recover_add_to_trans+0x64/0xef
> RSP: 0018:ffff81013240f728 EFLAGS: 00010286
> RAX: ffffc20001c9c000 RBX: 000000000020bd78 RCX: 00000000001cc280
> RDX: 0000000000000000 RSI: ffffc20001c9b000 RDI: ffffc20001cdbaf8
> RBP: ffff81013240f758 R08: ffff8101578011a2 R09: 0000000000000000
> R10: 0000000000000000 R11: 0000000000000002 R12: ffff8101318e4220
> R13: ffffc20001c5b508 R14: ffff8101318e4770 R15: ffffc20001c5b4fc
> FS: 00002b0dc2141b00(0000) GS:ffffffff805ef000(0000) knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 000000008005003b
> CR2: ffffc20001c9b000 CR3: 000000013243d000 CR4: 00000000000006e0
> DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
> Process mount (pid: 2434, threadinfo ffff81013240e000, task ffff8101320a4000)
> Stack: 0020bd785769c5e8 000000005769c5e8 000000000000000a ffffc20001c5b508
> 000000000000011e ffffc20001c5b4fc ffff81013240f7b8 ffffffff881c79db
> ffffc20001c6a000 00000001881da0bc ffff81013246c000 ffff81013240f828
> Call Trace:
> [<ffffffff881c79db>] :xfs:xlog_recover_process_data+0x184/0x1d9
> [<ffffffff881c89cb>] :xfs:xlog_do_recovery_pass+0x74b/0x795
> [<ffffffff881c8a52>] :xfs:xlog_do_log_recovery+0x3d/0x82
> [<ffffffff881c8aa9>] :xfs:xlog_do_recover+0x12/0x11c
> [<ffffffff881c8c37>] :xfs:xlog_recover+0x84/0x92
> [<ffffffff881c3125>] :xfs:xfs_log_mount+0x8c/0xe4
> [<ffffffff881cad92>] :xfs:xfs_mountfs+0x67d/0x97b
> [<ffffffff881cbcb7>] :xfs:xfs_mru_cache_create+0x170/0x1d5
> [<ffffffff881b2f04>] :xfs:xfs_fstrm_free_func+0x0/0x81
> [<ffffffff881be67c>] :xfs:xfs_ioinit+0xb/0xd
> [<ffffffff881d0cfa>] :xfs:xfs_mount+0x2bb/0x36b
> [<ffffffff881e1355>] :xfs:xfs_fs_fill_super+0xd2/0x245
> [<ffffffff802b7b9f>] get_filesystem+0x17/0x39
> [<ffffffff802a4659>] sget+0x3fb/0x418
> [<ffffffff802a4661>] sget+0x403/0x418
> [<ffffffff802a4d79>] set_bdev_super+0x0/0x14
> [<ffffffff802a4ec2>] get_sb_bdev+0x123/0x16f
> [<ffffffff881e1283>] :xfs:xfs_fs_fill_super+0x0/0x245
> [<ffffffff881e14db>] :xfs:xfs_fs_get_sb+0x13/0x18
> [<ffffffff802a5107>] vfs_kern_mount+0x8f/0x11c
> [<ffffffff802a51d8>] do_kern_mount+0x44/0xf4
> [<ffffffff802ba0d3>] do_mount+0x6d8/0x71e
> [<ffffffff80335682>] __up_read+0x93/0x9b
> [<ffffffff80252261>] up_read+0x23/0x27
> [<ffffffff8047a679>] do_page_fault+0x42e/0x7c7
> [<ffffffff80284d61>] zone_statistics+0x64/0x69
> [<ffffffff8027e4e0>] __alloc_pages+0x6b/0x311
> [<ffffffff802ba3c8>] sys_mount+0x8a/0xcc
> [<ffffffff8020bf8e>] system_call+0x7e/0x83
>
>
> Code: f3 a4 49 89 c7 49 8b 54 24 08 8b 42 18 85 c0 74 0e 3b 42 14
>
[-- Attachment #2: patch --]
[-- Type: text/plain, Size: 1480 bytes --]
--- a/fs/xfs/linux-2.6/xfs_buf.c 2007-11-29 10:53:01.000000000 +1100
+++ b/fs/xfs/linux-2.6/xfs_buf.c 2007-11-29 10:53:01.000000000 +1100
@@ -725,15 +725,15 @@
{
int rval;
int i = 0;
- size_t ptr;
- size_t end, end_cur;
- off_t offset;
+ unsigned long pageaddr;
+ unsigned long offset;
+ size_t buflen;
int page_count;
- page_count = PAGE_CACHE_ALIGN(len) >> PAGE_CACHE_SHIFT;
- offset = (off_t) mem - ((off_t)mem & PAGE_CACHE_MASK);
- if (offset && (len > PAGE_CACHE_SIZE))
- page_count++;
+ pageaddr = (unsigned long)mem & PAGE_CACHE_MASK;
+ offset = (unsigned long)mem - pageaddr;
+ buflen = PAGE_CACHE_ALIGN(len + offset);
+ page_count = buflen >> PAGE_CACHE_SHIFT;
/* Free any previous set of page pointers */
if (bp->b_pages)
@@ -747,22 +747,15 @@
return rval;
bp->b_offset = offset;
- ptr = (size_t) mem & PAGE_CACHE_MASK;
- end = PAGE_CACHE_ALIGN((size_t) mem + len);
- end_cur = end;
- /* set up first page */
- bp->b_pages[0] = mem_to_page(mem);
-
- ptr += PAGE_CACHE_SIZE;
- bp->b_page_count = ++i;
- while (ptr < end) {
- bp->b_pages[i] = mem_to_page((void *)ptr);
- bp->b_page_count = ++i;
- ptr += PAGE_CACHE_SIZE;
+
+ for (i = 0; i < bp->b_page_count; i++) {
+ bp->b_pages[i] = mem_to_page((void *)pageaddr);
+ pageaddr += PAGE_CACHE_SIZE;
}
bp->b_locked = 0;
- bp->b_count_desired = bp->b_buffer_length = len;
+ bp->b_count_desired = len;
+ bp->b_buffer_length = buflen;
bp->b_flags |= XBF_MAPPED;
return 0;
next prev parent reply other threads:[~2007-11-28 23:57 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-11-28 13:45 2.6.24-rc3 oopses while mounting fs KELEMEN Peter
2007-11-28 23:56 ` Lachlan McIlroy [this message]
2007-11-30 22:31 ` KELEMEN Peter
2007-12-03 3:24 ` Lachlan McIlroy
2007-12-03 22:02 ` KELEMEN Peter
2007-12-04 0:11 ` Timothy Shimmin
2007-12-04 7:08 ` Lachlan McIlroy
2007-12-04 9:57 ` KELEMEN Peter
2007-12-05 5:47 ` Lachlan McIlroy
2007-12-05 6:38 ` Timothy Shimmin
2007-12-05 7:04 ` Lachlan McIlroy
2007-12-04 9:42 ` KELEMEN Peter
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=474E003A.7020000@sgi.com \
--to=lachlan@sgi.com \
--cc=xfs@oss.sgi.com \
/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