On 02/27/2010 12:38 AM, Antoine Martin wrote:
1 0 0 98 0 1| 0 0 | 66B 354B| 0 0 | 30 11
1 1 0 98 0 0| 0 0 | 66B 354B| 0 0 | 29 11
From that point onwards, nothing will happen.
The host has disk IO to spare... So what is it waiting for??
Moved to an AMD64 host. No effect.
Disabled swap before running the test. No effect.
Moved the guest to a fully up-to-date FC12 server
(2.6.31.6-145.fc12.x86_64), no effect.
I have narrowed it down to the guest's filesystem used for backing the
disk image which is loop mounted: although it was not completely full
(and had enough inodes), freeing some space on it prevents the system
from misbehaving.
FYI: the disk image was clean and was fscked before each test. kvm had
been updated to 0.12.3
The weird thing is that the same filesystem works fine (no system
hang) if used directly from the host, it is only misbehaving via kvm...
So I am not dismissing the possibility that kvm may be at least partly
to blame, or that it is exposing a filesystem bug (race?) not normally
encountered.
(I have backed up the full 32GB virtual disk in case someone suggests
further investigation)
Well, well. I've just hit the exact same bug on another *host* (not a
guest), running stock Fedora 12.
So this isn't a kvm bug after all. Definitely a loop+ext(4?) bug.
Looks like you need a pretty big loop mounted partition to trigger it.
(bigger than available ram?)
This is what triggered it on a quad amd system with 8Gb of ram, software
raid-1 partition:
mount -o loop 2GB.dd source
dd if=/dev/zero of=8GB.dd bs=1048576 count=8192
mkfs.ext4 -f 8GB.dd
mount -o loop 8GB.dd dest
rsync -rplogtD source/* dest/
umount source
umount dest
^ this is where it hangs, I then tried to issue a 'sync' from another
terminal, which also hung.
It took more than 10 minutes to settle itself, during that time one CPU
was stuck in wait state.
dstat reported almost no IO at the time (<1MB/s)
I assume dstat reports page write back like any other disk IO?
That raid partition does ~60MB/s, so writing back 8GB shouldn't take 10
minutes. (that's even assuming it would have to write back the whole 8GB
at umount time - which should not be the case)
Cheers
Antoine
Here's the hung trace:
INFO: task umount:526 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
umount D 0000000000000002 0 526 32488 0x00000000
ffff880140f9fc88 0000000000000086 ffff880008e3c228 ffffffff810d5fd9
ffff880140f9fc28 ffff880140f9fcd8 ffff880140f9ffd8 ffff880140f9ffd8
ffff88021b5e03d8 000000000000f980 0000000000015740 ffff88021b5e03d8
Call Trace:
[<ffffffff810d5fd9>] ? sync_page+0x0/0x4a
[<ffffffff81046fbd>] ? __enqueue_entity+0x7b/0x7d
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff8113a055>] bdi_sched_wait+0xe/0x12
[<ffffffff814549f0>] __wait_on_bit+0x48/0x7b
[<ffffffff8102649f>] ? native_smp_send_reschedule+0x5c/0x5e
[<ffffffff81454a91>] out_of_line_wait_on_bit+0x6e/0x79
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff810748dc>] ? wake_bit_function+0x0/0x33
[<ffffffff8113ad0b>] wait_on_bit.clone.1+0x1e/0x20
[<ffffffff8113ad71>] bdi_sync_writeback+0x64/0x6b
[<ffffffff8113ad9a>] sync_inodes_sb+0x22/0xec
[<ffffffff8113e547>] __sync_filesystem+0x4e/0x77
[<ffffffff8113e71d>] sync_filesystem+0x4b/0x4f
[<ffffffff8111d6d9>] generic_shutdown_super+0x27/0xc9
[<ffffffff8111d7a2>] kill_block_super+0x27/0x3f
[<ffffffff8111ded7>] deactivate_super+0x56/0x6b
[<ffffffff81134262>] mntput_no_expire+0xb4/0xec
[<ffffffff8113482a>] sys_umount+0x2d5/0x304
[<ffffffff81458133>] ? do_page_fault+0x270/0x2a0
[<ffffffff81011d32>] system_call_fastpath+0x16/0x1b
INFO: task umount:526 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
umount D 0000000000000002 0 526 32488 0x00000000
ffff880140f9fc88 0000000000000086 ffff880008e3c228 ffffffff810d5fd9
ffff880140f9fc28 ffff880140f9fcd8 ffff880140f9ffd8 ffff880140f9ffd8
ffff88021b5e03d8 000000000000f980 0000000000015740 ffff88021b5e03d8
Call Trace:
[<ffffffff810d5fd9>] ? sync_page+0x0/0x4a
[<ffffffff81046fbd>] ? __enqueue_entity+0x7b/0x7d
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff8113a055>] bdi_sched_wait+0xe/0x12
[<ffffffff814549f0>] __wait_on_bit+0x48/0x7b
[<ffffffff8102649f>] ? native_smp_send_reschedule+0x5c/0x5e
[<ffffffff81454a91>] out_of_line_wait_on_bit+0x6e/0x79
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff810748dc>] ? wake_bit_function+0x0/0x33
[<ffffffff8113ad0b>] wait_on_bit.clone.1+0x1e/0x20
[<ffffffff8113ad71>] bdi_sync_writeback+0x64/0x6b
[<ffffffff8113ad9a>] sync_inodes_sb+0x22/0xec
[<ffffffff8113e547>] __sync_filesystem+0x4e/0x77
[<ffffffff8113e71d>] sync_filesystem+0x4b/0x4f
[<ffffffff8111d6d9>] generic_shutdown_super+0x27/0xc9
[<ffffffff8111d7a2>] kill_block_super+0x27/0x3f
[<ffffffff8111ded7>] deactivate_super+0x56/0x6b
[<ffffffff81134262>] mntput_no_expire+0xb4/0xec
[<ffffffff8113482a>] sys_umount+0x2d5/0x304
[<ffffffff81458133>] ? do_page_fault+0x270/0x2a0
[<ffffffff81011d32>] system_call_fastpath+0x16/0x1b
INFO: task umount:526 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
umount D 0000000000000002 0 526 32488 0x00000000
ffff880140f9fc88 0000000000000086 ffff880008e3c228 ffffffff810d5fd9
ffff880140f9fc28 ffff880140f9fcd8 ffff880140f9ffd8 ffff880140f9ffd8
ffff88021b5e03d8 000000000000f980 0000000000015740 ffff88021b5e03d8
Call Trace:
[<ffffffff810d5fd9>] ? sync_page+0x0/0x4a
[<ffffffff81046fbd>] ? __enqueue_entity+0x7b/0x7d
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff8113a055>] bdi_sched_wait+0xe/0x12
[<ffffffff814549f0>] __wait_on_bit+0x48/0x7b
[<ffffffff8102649f>] ? native_smp_send_reschedule+0x5c/0x5e
[<ffffffff81454a91>] out_of_line_wait_on_bit+0x6e/0x79
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff810748dc>] ? wake_bit_function+0x0/0x33
[<ffffffff8113ad0b>] wait_on_bit.clone.1+0x1e/0x20
[<ffffffff8113ad71>] bdi_sync_writeback+0x64/0x6b
[<ffffffff8113ad9a>] sync_inodes_sb+0x22/0xec
[<ffffffff8113e547>] __sync_filesystem+0x4e/0x77
[<ffffffff8113e71d>] sync_filesystem+0x4b/0x4f
[<ffffffff8111d6d9>] generic_shutdown_super+0x27/0xc9
[<ffffffff8111d7a2>] kill_block_super+0x27/0x3f
[<ffffffff8111ded7>] deactivate_super+0x56/0x6b
[<ffffffff81134262>] mntput_no_expire+0xb4/0xec
[<ffffffff8113482a>] sys_umount+0x2d5/0x304
[<ffffffff81458133>] ? do_page_fault+0x270/0x2a0
[<ffffffff81011d32>] system_call_fastpath+0x16/0x1b
INFO: task umount:526 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
umount D 0000000000000002 0 526 32488 0x00000000
ffff880140f9fc88 0000000000000086 ffff880008e3c228 ffffffff810d5fd9
ffff880140f9fc28 ffff880140f9fcd8 ffff880140f9ffd8 ffff880140f9ffd8
ffff88021b5e03d8 000000000000f980 0000000000015740 ffff88021b5e03d8
Call Trace:
[<ffffffff810d5fd9>] ? sync_page+0x0/0x4a
[<ffffffff81046fbd>] ? __enqueue_entity+0x7b/0x7d
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff8113a055>] bdi_sched_wait+0xe/0x12
[<ffffffff814549f0>] __wait_on_bit+0x48/0x7b
[<ffffffff8102649f>] ? native_smp_send_reschedule+0x5c/0x5e
[<ffffffff81454a91>] out_of_line_wait_on_bit+0x6e/0x79
[<ffffffff8113a047>] ? bdi_sched_wait+0x0/0x12
[<ffffffff810748dc>] ? wake_bit_function+0x0/0x33
[<ffffffff8113ad0b>] wait_on_bit.clone.1+0x1e/0x20
[<ffffffff8113ad71>] bdi_sync_writeback+0x64/0x6b
[<ffffffff8113ad9a>] sync_inodes_sb+0x22/0xec
[<ffffffff8113e547>] __sync_filesystem+0x4e/0x77
[<ffffffff8113e71d>] sync_filesystem+0x4b/0x4f
[<ffffffff8111d6d9>] generic_shutdown_super+0x27/0xc9
[<ffffffff8111d7a2>] kill_block_super+0x27/0x3f
[<ffffffff8111ded7>] deactivate_super+0x56/0x6b
[<ffffffff81134262>] mntput_no_expire+0xb4/0xec
[<ffffffff8113482a>] sys_umount+0x2d5/0x304
[<ffffffff81458133>] ? do_page_fault+0x270/0x2a0
[<ffffffff81011d32>] system_call_fastpath+0x16/0x1b
INFO: task sync:741 blocked for more than 120 seconds.
"echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message.
sync D 0000000000000000 0 741 552 0x00000000
ffff88003c31fed8 0000000000000086 0000000000000000 ffff8801b7472ec0
ffff88003c31fe38 0000000000000246 ffff88003c31ffd8 ffff88003c31ffd8
ffff8801b7473298 000000000000f980 0000000000015740 ffff8801b7473298
Call Trace:
[<ffffffff81455a2e>] __down_read+0x92/0xaa
[<ffffffff814550e1>] down_read+0x31/0x35
[<ffffffff8113e5f6>] sync_filesystems+0x86/0xf6
[<ffffffff8113e6b6>] sys_sync+0x17/0x33
[<ffffffff81011d32>] system_call_fastpath+0x16/0x1b
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html