Opened 4 months ago

#18984 new bug

BFS: KDL in `bfs_unlink`, corrupted linked list

Reported by: jessicah Owned by: axeld
Priority: normal Milestone: Unscheduled
Component: File Systems/BFS Version: R1/beta4
Keywords: Cc:
Blocked By: Blocking:
Platform: All

Description

On hrev57730. Whilst trying to remove several very large directories simultaneously, and running pkgman update, system crashed.

KDL:

PANIC: ASSERT FAILED (../haiku-git/headers/private/kernel/util/DoublyLinkedList.h:399): fFirst == __null ? fLast == __null : fLast != __null; list: 0xffffffff8329fef8

Welcome to Kernel Debugging Land...
Thread 602 "TrackerTaskLoop" running on CPU 0
stack trace for thread 602 "TrackerTaskLoop"
    kernel stack: 0xffffffff93743000 to 0xffffffff93748000
      user stack: 0x00007faddec92000 to 0x00007faddecd2000
frame                       caller             <image>:function + offset
 0 ffffffff93747a70 (+  32) ffffffff8014ba60   <kernel_x86_64> arch_debug_call_with_fault_handler + 0x1a
 1 ffffffff93747a90 (+  80) ffffffff800b3af8   <kernel_x86_64> debug_call_with_fault_handler + 0x78
 2 ffffffff93747ae0 (+  96) ffffffff800b51a4   <kernel_x86_64> kernel_debugger_loop(char const*, char const*, __va_list_tag*, int) + 0xf4
 3 ffffffff93747b40 (+  80) ffffffff800b553e   <kernel_x86_64> kernel_debugger_internal(char const*, char const*, __va_list_tag*, int) + 0x6e
 4 ffffffff93747b90 (+ 240) ffffffff800b58d7   <kernel_x86_64> panic + 0xb7
 5 ffffffff93747c80 (+  32) ffffffff8212f7ce   <bfs> Inode::RemovedFromTransaction[clone .localalias] () + 0xce
 6 ffffffff93747ca0 (+  64) ffffffff82138c41   <bfs> Transaction::NotifyListeners[clone .localalias] (bool) + 0x81
 7 ffffffff93747ce0 (+  48) ffffffff82138e63   <bfs> Journal::Unlock(Transaction*, bool) + 0x53
 8 ffffffff93747d10 (+ 128) ffffffff8213f6c8   <bfs> bfs_unlink(fs_volume*, fs_vnode*, char const*) + 0xe8
 9 ffffffff93747d90 (+ 320) ffffffff801049b0   <kernel_x86_64> common_unlink(int, char*, bool) + 0x60
10 ffffffff93747ed0 (+  80) ffffffff8010b6dc   <kernel_x86_64> _user_unlink + 0x7c
11 ffffffff93747f20 (+  16) ffffffff8014d63f   <kernel_x86_64> x86_64_syscall_entry + 0xfb
user iframe at 0xffffffff93747f30 (end = 0xffffffff93747ff8)
 rax 0x7e                  rbx 0x7faddecd1390        rcx 0x1b52e81a9fc
 rdx 0x0                   rsi 0x1118c6cc2370        rdi 0x39
 rbp 0x7faddecd0d70         r8 0x80                   r9 0x2
 r10 0x1b52e81abbc         r11 0x246                 r12 0x7faddecd0ca0
 r13 0x0                   r14 0x7faddecd0c80        r15 0x7faddecd0ce0
 rip 0x1b52e81a9fc         rsp 0x7faddecd0c48     rflags 0x246
 vector: 0x63, error code: 0x0
12 ffffffff93747f30 (+140386565131840) 000001b52e81a9fc   <libroot.so> _kern_unlink + 0x0c
13 00007faddecd0d70 (+ 304) 00000211f226b3f7   <libtracker.so> _ZN8BPrivate17WellKnowEntryList5MatchEPK8node_ref (nearest) + 0xe7
14 00007faddecd0ea0 (+ 304) 00000211f226b3f7   <libtracker.so> _ZN8BPrivate17WellKnowEntryList5MatchEPK8node_ref (nearest) + 0xe7
15 00007faddecd0fd0 (+ 304) 00000211f226b3f7   <libtracker.so> _ZN8BPrivate17WellKnowEntryList5MatchEPK8node_ref (nearest) + 0xe7
16 00007faddecd1100 (+ 304) 00000211f226b3f7   <libtracker.so> _ZN8BPrivate17WellKnowEntryList5MatchEPK8node_ref (nearest) + 0xe7
17 00007faddecd1230 (+ 304) 00000211f226b3f7   <libtracker.so> _ZN8BPrivate17WellKnowEntryList5MatchEPK8node_ref (nearest) + 0xe7
18 00007faddecd1360 (+ 224) 00000211f226eff3   <libtracker.so> _ZN8BPrivate13FSMoveToTrashEP11BObjectListI9entry_refEP5BListb (nearest) + 0x393
19 00007faddecd1440 (+  48) 00000211f22f320f   <libtracker.so> _Z13TruncTimeBaseIN8BPrivate9BPoseViewEEfP7BStringlPKT_f (nearest) + 0x2c2f
20 00007faddecd1470 (+  16) 00000211f22f2f1a   <libtracker.so> _Z13TruncTimeBaseIN8BPrivate9BPoseViewEEfP7BStringlPKT_f (nearest) + 0x293a
21 00007faddecd1480 (+  32) 000001b52e819dd9   <libroot.so> _thread_do_exit_work (nearest) + 0x89
22 00007faddecd14a0 (+   0) 00007faf557be258   <commpage> commpage_thread_exit + 0x00

Upon reboot, it replayed the journal:

bfs: Replay log, disk was not correctly unmounted...
register_domain(9, unix)
unregister_domain(0xffffffff83151900, 9, unix)
bfs: replay block run 0:330:1 in log at 160!
bfs: replay block run 52:38186:1 in log at 161!
bfs: replay block run 52:38187:1 in log at 162!
bfs: replay block run 52:38189:1 in log at 163!
bfs: replay block run 52:38190:1 in log at 164!
register_domain(5, internet6)
unregister_domain(0xffffffff83151900, 5, internet6)
bfs: replay block run 52:38192:1 in log at 165!
bfs: replay block run 52:38193:1 in log at 166!
bfs: replay block run 52:38195:1 in log at 167!
bfs: replay block run 52:38198:1 in log at 168!
register_domain(1, internet)
unregister_domain(0xffffffff83151900, 1, internet)
bfs: replay block run 53:54448:1 in log at 169!
bfs: replay block run 53:54449:1 in log at 170!
...
bfs: replay block run 0:2513:1 in log at 2194!
bfs: replay block run 52:38148:1 in log at 2195!
bfs: replay block run 52:38149:1 in log at 2196!
bfs: replay block run 62:39194:1 in log at 2197!
bfs: replay block run 77:47656:1 in log at 2198!
bfs: replay block run 77:48612:1 in log at 2199!
bfs: replay block run 77:48642:1 in log at 2200!
bfs: replay block run 95:37664:1 in log at 2201!
bfs: replay block run 444:14171:1 in log at 2202!
bfs: mounted "Development" (root node at 524288, device = /dev/disk/nvme/0/0)

Change History (0)

Note: See TracTickets for help on using tickets.