Re: [Syzkaller & bisect] There is BUG: unable to handle kernel NULL pointer dereference in xfs_extent_free_diff_items in v6.4-rc3

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 22.05.23 18:05, Darrick J. Wong wrote:
> On Mon, May 22, 2023 at 01:39:27PM +0700, Bagas Sanjaya wrote:
>> On Mon, May 22, 2023 at 10:07:28AM +0800, Pengfei Xu wrote:
>>> Greeting!
>>> There is BUG: unable to handle kernel NULL pointer dereference in
>>> xfs_extent_free_diff_items in v6.4-rc3:
>>>
>>> Above issue could be reproduced in v6.4-rc3 and v6.4-rc2 kernel in guest.
>>>
>>> Bisected this issue between v6.4-rc2 and v5.11, found the problem commit is:
>>> "
>>> f6b384631e1e xfs: give xfs_extfree_intent its own perag reference
>>> "
>>>
>>> report0, repro.stat and so on detailed info is link: https://github.com/xupengfe/syzkaller_logs/tree/main/230521_043336_xfs_extent_free_diff_items
>>> Syzkaller reproduced code: https://github.com/xupengfe/syzkaller_logs/blob/main/230521_043336_xfs_extent_free_diff_items/repro.c
>>> Syzkaller reproduced prog: https://github.com/xupengfe/syzkaller_logs/blob/main/230521_043336_xfs_extent_free_diff_items/repro.prog
>>> Kconfig: https://github.com/xupengfe/syzkaller_logs/blob/main/230521_043336_xfs_extent_free_diff_items/kconfig_origin
>>> Bisect info: https://github.com/xupengfe/syzkaller_logs/blob/main/230521_043336_xfs_extent_free_diff_items/bisect_info.log
>>> Issue dmesg: https://github.com/xupengfe/syzkaller_logs/blob/main/230521_043336_xfs_extent_free_diff_items/v6.4-rc3_reproduce_dmesg.log
>>>
>>> v6.4-rc3 reproduced info:
> 
> Diagnosis and patches welcomed.
> 
> Or are we doing the usual syzbot bullshit where you all assume that I'm
> going to do all the fucking work for you?

Darrick, sorry for the trouble. Bagas recently out of the blue started
to help with adding regressions to the tracking. That's great, but OTOH
it means that it's likely time to write a few things up that are obvious
to some of us and myself.

Bagas, please for the foreseeable future don't add regressions found by
syzkaller to the regression tracking, unless some well known developer
actually looked into the issue and indicated that it's something that
needs to be fixed.

Syzbot is great. But it occasionally does odd things or goes of the
rails. And in can easily find problems that didn't happen in an earlier
version, but are unlikely to be encountered by users in practice (aka
"in the wild"). And we normally don't consider those regressions that
needs to be fixed.

Ciao, Thorsten

#regzbot inconclusive: syzbot regression that would need further analysis

>>> [   91.419498] loop0: detected capacity change from 0 to 65536
>>> [   91.420095] XFS: attr2 mount option is deprecated.
>>> [   91.420500] XFS: ikeep mount option is deprecated.
>>> [   91.422379] XFS (loop0): Deprecated V4 format (crc=0) will not be supported after September 2030.
>>> [   91.423468] XFS (loop0): Mounting V4 Filesystem d28317a9-9e04-4f2a-be27-e55b4c413ff6
>>> [   91.428169] XFS (loop0): Ending clean mount
>>> [   91.429120] XFS (loop0): Quotacheck needed: Please wait.
>>> [   91.432182] BUG: kernel NULL pointer dereference, address: 0000000000000008
>>> [   91.432770] #PF: supervisor read access in kernel mode
>>> [   91.433216] #PF: error_code(0x0000) - not-present page
>>> [   91.433640] PGD 0 P4D 0 
>>> [   91.433864] Oops: 0000 [#1] PREEMPT SMP NOPTI
>>> [   91.434232] CPU: 0 PID: 33 Comm: kworker/u4:2 Not tainted 6.4.0-rc3-kvm #2
>>> [   91.434793] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 0.0.0 02/06/2015
>>> [   91.435445] Workqueue: xfs_iwalk-393 xfs_pwork_work
>>> [   91.435855] RIP: 0010:xfs_extent_free_diff_items+0x27/0x40
>>> [   91.436312] Code: 90 90 90 f3 0f 1e fa 0f 1f 44 00 00 55 48 89 e5 41 54 49 89 f4 53 48 89 d3 e8 05 73 7d ff 49 8b 44 24 28 48 8b 53 28 5b 41 5c <8b> 40 08 5d 2b 42 08 c3 cc cc cc cc 66 66 2e 0f 1f 84 00 00 00 00
>>> [   91.437812] RSP: 0000:ffffc9000012b8c0 EFLAGS: 00010246
>>> [   91.438250] RAX: 0000000000000000 RBX: ffff8880015826c8 RCX: ffffffff81d71e41
>>> [   91.438840] RDX: 0000000000000000 RSI: ffff888001ca4800 RDI: 0000000000000002
>>> [   91.439430] RBP: ffffc9000012b8c0 R08: ffffc9000012b8e0 R09: 0000000000000000
>>> [   91.440019] R10: ffff88800613f290 R11: ffffffff83e426c0 R12: ffff888001582230
>>> [   91.440610] R13: ffff888001582428 R14: ffffffff81b042c0 R15: ffffc9000012b908
>>> [   91.441202] FS:  0000000000000000(0000) GS:ffff88807ec00000(0000) knlGS:0000000000000000
>>> [   91.441864] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>>> [   91.442343] CR2: 0000000000000008 CR3: 000000000ed22006 CR4: 0000000000770ef0
>>> [   91.442941] PKRU: 55555554
>>> [   91.443178] Call Trace:
>>> [   91.443394]  <TASK>
>>> [   91.443585]  list_sort+0xb8/0x3a0
>>> [   91.443885]  xfs_extent_free_create_intent+0xb6/0xc0
>>> [   91.444312]  xfs_defer_create_intents+0xc3/0x220
>>> [   91.444711]  ? write_comp_data+0x2f/0x90
>>> [   91.445056]  xfs_defer_finish_noroll+0x9e/0xbc0
>>> [   91.445449]  ? list_sort+0x344/0x3a0
>>> [   91.445768]  __xfs_trans_commit+0x4be/0x630
>>> [   91.446135]  xfs_trans_commit+0x20/0x30
>>> [   91.446473]  xfs_dquot_disk_alloc+0x45d/0x4e0
>>> [   91.446860]  xfs_qm_dqread+0x2f7/0x310
>>> [   91.447192]  xfs_qm_dqget+0xd5/0x300
>>> [   91.447506]  xfs_qm_quotacheck_dqadjust+0x5a/0x230
>>> [   91.447921]  xfs_qm_dqusage_adjust+0x249/0x300
>>> [   91.448313]  xfs_iwalk_ag_recs+0x1bd/0x2e0
>>> [   91.448671]  xfs_iwalk_run_callbacks+0xc3/0x1c0
>>> [   91.449071]  xfs_iwalk_ag+0x32e/0x3f0
>>> [   91.449398]  xfs_iwalk_ag_work+0xbe/0xf0
>>> [   91.449744]  xfs_pwork_work+0x2c/0xc0
>>> [   91.450064]  process_one_work+0x3b1/0x860
>>> [   91.450416]  worker_thread+0x52/0x660
>>> [   91.450739]  ? __pfx_worker_thread+0x10/0x10
>>> [   91.451113]  kthread+0x16d/0x1c0
>>> [   91.451406]  ? __pfx_kthread+0x10/0x10
>>> [   91.451740]  ret_from_fork+0x29/0x50
>>> [   91.452064]  </TASK>
>>> [   91.452261] Modules linked in:
>>> [   91.452530] CR2: 0000000000000008
>>> [   91.452819] ---[ end trace 0000000000000000 ]---
>>> [   91.487979] RIP: 0010:xfs_extent_free_diff_items+0x27/0x40
>>> [   91.488463] Code: 90 90 90 f3 0f 1e fa 0f 1f 44 00 00 55 48 89 e5 41 54 49 89 f4 53 48 89 d3 e8 05 73 7d ff 49 8b 44 24 28 48 8b 53 28 5b 41 5c <8b> 40 08 5d 2b 42 08 c3 cc cc cc cc 66 66 2e 0f 1f 84 00 00 00 00
>>> [   91.490021] RSP: 0000:ffffc9000012b8c0 EFLAGS: 00010246
>>> [   91.490472] RAX: 0000000000000000 RBX: ffff8880015826c8 RCX: ffffffff81d71e41
>>> [   91.491080] RDX: 0000000000000000 RSI: ffff888001ca4800 RDI: 0000000000000002
>>> [   91.491689] RBP: ffffc9000012b8c0 R08: ffffc9000012b8e0 R09: 0000000000000000
>>> [   91.492298] R10: ffff88800613f290 R11: ffffffff83e426c0 R12: ffff888001582230
>>> [   91.492909] R13: ffff888001582428 R14: ffffffff81b042c0 R15: ffffc9000012b908
>>> [   91.493516] FS:  0000000000000000(0000) GS:ffff88807ec00000(0000) knlGS:0000000000000000
>>> [   91.494199] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
>>> [   91.494695] CR2: 0000000000000008 CR3: 000000000ed22006 CR4: 0000000000770ef0
>>> [   91.495306] PKRU: 55555554
>>> [   91.495549] note: kworker/u4:2[33] exited with irqs disabled
>>> "
>>>
>>
>> Thanks for the regression report. I'm adding it to regzbot:
>>
>> #regzbot ^introduced: f6b384631e1e34
>> #regzbot title: unable to handle kernel NULL pointer dereference in xfs_extent_free_diff_items (due to xfs_extfree_intent perag change)
>> #regzbot link: https://bugzilla.kernel.org/show_bug.cgi?id=217470
>>
>> -- 
>> An old man doll... just what I always wanted! - Clara
> 
> 
> 
> 



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux