[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <ZYZUarJep8b746Et@google.com>
Date: Fri, 22 Dec 2023 20:30:50 -0700
From: Yu Zhao <yuzhao@...gle.com>
To: syzbot <syzbot+03fd9b3f71641f0ebf2d@...kaller.appspotmail.com>
Cc: akpm@...ux-foundation.org, axboe@...nel.dk, io-uring@...r.kernel.org,
linux-kernel@...r.kernel.org, linux-mm@...ck.org,
syzkaller-bugs@...glegroups.com
Subject: Re: [syzbot] [mm] WARNING in get_pte_pfn
On Fri, Dec 22, 2023 at 12:11:21AM -0800, syzbot wrote:
> Hello,
>
> syzbot found the following issue on:
>
> HEAD commit: 0e389834672c Merge tag 'for-6.7-rc5-tag' of git://git.kern..
> git tree: upstream
> console output: https://syzkaller.appspot.com/x/log.txt?x=1454824ee80000
> kernel config: https://syzkaller.appspot.com/x/.config?x=f21aff374937e60e
> dashboard link: https://syzkaller.appspot.com/bug?extid=03fd9b3f71641f0ebf2d
> compiler: gcc (Debian 12.2.0-14) 12.2.0, GNU ld (GNU Binutils for Debian) 2.40
> syz repro: https://syzkaller.appspot.com/x/repro.syz?x=13b4ef49e80000
> C reproducer: https://syzkaller.appspot.com/x/repro.c?x=118314d6e80000
>
> Downloadable assets:
> disk image: https://storage.googleapis.com/syzbot-assets/e58cd74e152a/disk-0e389834.raw.xz
> vmlinux: https://storage.googleapis.com/syzbot-assets/45d17ccb34bc/vmlinux-0e389834.xz
> kernel image: https://storage.googleapis.com/syzbot-assets/b9b7105d4e08/bzImage-0e389834.xz
>
> IMPORTANT: if you fix the issue, please add the following tag to the commit:
> Reported-by: syzbot+03fd9b3f71641f0ebf2d@...kaller.appspotmail.com
>
> ------------[ cut here ]------------
> WARNING: CPU: 1 PID: 5066 at mm/vmscan.c:3242 get_pte_pfn+0x1b5/0x3f0 mm/vmscan.c:3242
> Modules linked in:
> CPU: 1 PID: 5066 Comm: syz-executor668 Not tainted 6.7.0-rc5-syzkaller-00270-g0e389834672c #0
> Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 11/17/2023
> RIP: 0010:get_pte_pfn+0x1b5/0x3f0 mm/vmscan.c:3242
> Code: f3 74 2a e8 6d 78 cb ff 31 ff 48 b8 00 00 00 00 00 00 00 02 48 21 c5 48 89 ee e8 e6 73 cb ff 48 85 ed 74 4e e8 4c 78 cb ff 90 <0f> 0b 90 48 c7 c3 ff ff ff ff e8 3c 78 cb ff 48 b8 00 00 00 00 00
> RSP: 0018:ffffc900041e6878 EFLAGS: 00010293
> RAX: 0000000000000000 RBX: 000000000007891d RCX: ffffffff81bbf6e3
> RDX: ffff88807d813b80 RSI: ffffffff81bbf684 RDI: 0000000000000005
> RBP: 0000000000000000 R08: 0000000000000005 R09: 0000000000000000
> R10: 0000000000000200 R11: 0000000000000003 R12: 0000000000000200
> R13: 1ffff9200083cd0f R14: 0000000000010b21 R15: 0000000020ffc000
> FS: 0000555555f4d480(0000) GS:ffff8880b9900000(0000) knlGS:0000000000000000
> CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> CR2: 0000000000000000 CR3: 000000005fbfa000 CR4: 0000000000350ef0
> Call Trace:
> <TASK>
> lru_gen_look_around+0x70d/0x11a0 mm/vmscan.c:4001
> folio_referenced_one+0x5a2/0xf70 mm/rmap.c:843
> rmap_walk_anon+0x225/0x570 mm/rmap.c:2485
> rmap_walk mm/rmap.c:2562 [inline]
> rmap_walk mm/rmap.c:2557 [inline]
> folio_referenced+0x28a/0x4b0 mm/rmap.c:960
> folio_check_references mm/vmscan.c:829 [inline]
> shrink_folio_list+0x1ace/0x3f00 mm/vmscan.c:1160
> evict_folios+0x6e7/0x1b90 mm/vmscan.c:4499
> try_to_shrink_lruvec+0x638/0xa10 mm/vmscan.c:4704
> lru_gen_shrink_lruvec mm/vmscan.c:4849 [inline]
> shrink_lruvec+0x314/0x2990 mm/vmscan.c:5622
> shrink_node_memcgs mm/vmscan.c:5842 [inline]
> shrink_node+0x811/0x3710 mm/vmscan.c:5877
> shrink_zones mm/vmscan.c:6116 [inline]
> do_try_to_free_pages+0x36c/0x1940 mm/vmscan.c:6178
#syz test
diff --git a/mm/vmscan.c b/mm/vmscan.c
index 9dd8977de5a2..041f9ad8f95b 100644
--- a/mm/vmscan.c
+++ b/mm/vmscan.c
@@ -3230,7 +3230,8 @@ static bool get_next_vma(unsigned long mask, unsigned long size, struct mm_walk
return false;
}
-static unsigned long get_pte_pfn(pte_t pte, struct vm_area_struct *vma, unsigned long addr)
+static unsigned long get_pte_pfn(pte_t pte, struct vm_area_struct *vma, unsigned long addr,
+ struct page *page)
{
unsigned long pfn = pte_pfn(pte);
@@ -3239,8 +3240,14 @@ static unsigned long get_pte_pfn(pte_t pte, struct vm_area_struct *vma, unsigned
if (!pte_present(pte) || is_zero_pfn(pfn))
return -1;
- if (WARN_ON_ONCE(pte_devmap(pte) || pte_special(pte)))
+ if (pte_devmap(pte) || pte_special(pte)) {
+ if (page)
+ dump_page(page, "get_pte_pfn()");
+ dump_vma(vma);
+ dump_mm(vma->vm_mm);
+ BUG();
return -1;
+ }
if (WARN_ON_ONCE(!pfn_valid(pfn)))
return -1;
@@ -3331,7 +3338,7 @@ static bool walk_pte_range(pmd_t *pmd, unsigned long start, unsigned long end,
total++;
walk->mm_stats[MM_LEAF_TOTAL]++;
- pfn = get_pte_pfn(ptent, args->vma, addr);
+ pfn = get_pte_pfn(ptent, args->vma, addr, NULL);
if (pfn == -1)
continue;
@@ -3998,7 +4005,7 @@ void lru_gen_look_around(struct page_vma_mapped_walk *pvmw)
unsigned long pfn;
pte_t ptent = ptep_get(pte + i);
- pfn = get_pte_pfn(ptent, pvmw->vma, addr);
+ pfn = get_pte_pfn(ptent, pvmw->vma, addr, pfn_to_page(pvmw->pfn));
if (pfn == -1)
continue;
Powered by blists - more mailing lists