Skip to content
  • Pasha Tatashin's avatar
    mm/page_table_check: check entries at pmd levels · 80110bbf
    Pasha Tatashin authored
    syzbot detected a case where the page table counters were not properly
    updated.
    
      syzkaller login:  ------------[ cut here ]------------
      kernel BUG at mm/page_table_check.c:162!
      invalid opcode: 0000 [#1] PREEMPT SMP KASAN
      CPU: 0 PID: 3099 Comm: pasha Not tainted 5.16.0+ #48
      Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIO4
      RIP: 0010:__page_table_check_zero+0x159/0x1a0
      Call Trace:
       free_pcp_prepare+0x3be/0xaa0
       free_unref_page+0x1c/0x650
       free_compound_page+0xec/0x130
       free_transhuge_page+0x1be/0x260
       __put_compound_page+0x90/0xd0
       release_pages+0x54c/0x1060
       __pagevec_release+0x7c/0x110
       shmem_undo_range+0x85e/0x1250
      ...
    
    The repro involved having a huge page that is split due to uprobe event
    temporarily replacing one of the pages in the huge page.  Later the huge
    page was combined again, but the counters were off, as the PTE level was
    not properly updated.
    
    Make sure that when PMD is cleared and prior to freeing the level the
    PTEs are updated.
    
    Link: https://lkml.kernel.org/r/20220131203249.2832273-5-pasha.tatashin@soleen.com
    
    
    Fixes: df4e817b ("mm: page table check")
    Signed-off-by: default avatarPasha Tatashin <pasha.tatashin@soleen.com>
    Acked-by: default avatarDavid Rientjes <rientjes@google.com>
    Cc: Aneesh Kumar K.V <aneesh.kumar@linux.ibm.com>
    Cc: Anshuman Khandual <anshuman.khandual@arm.com>
    Cc: Dave Hansen <dave.hansen@linux.intel.com>
    Cc: Greg Thelen <gthelen@google.com>
    Cc: H. Peter Anvin <hpa@zytor.com>
    Cc: Hugh Dickins <hughd@google.com>
    Cc: Ingo Molnar <mingo@redhat.com>
    Cc: Jiri Slaby <jirislaby@kernel.org>
    Cc: Mike Rapoport <rppt@kernel.org>
    Cc: Muchun Song <songmuchun@bytedance.com>
    Cc: Paul Turner <pjt@google.com>
    Cc: Wei Xu <weixugc@google.com>
    Cc: Will Deacon <will@kernel.org>
    Cc: Zi Yan <ziy@nvidia.com>
    Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
    Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
    80110bbf
Loading