1. 21 Aug, 2023 9 commits
    • Kuan-Ying Lee's avatar
      scripts/gdb/slab: add slab support · 79939c4a
      Kuan-Ying Lee authored
      Add 'lx-slabinfo' and 'lx-slabtrace' support.
      
      This GDB scripts print slabinfo and slabtrace for user
      to analyze slab memory usage.
      
      Example output like below:
      (gdb) lx-slabinfo
           Pointer       |         name         | active_objs  |   num_objs   | objsize  | objperslab  | pagesperslab
      ------------------ | -------------------- | ------------ | ------------ | -------- | ----------- | -------------
      0xffff0000c59df480 | p9_req_t             | 0            | 0            | 280      | 29          | 2
      0xffff0000c59df280 | isp1760_qh           | 0            | 0            | 160      | 25          | 1
      0xffff0000c59df080 | isp1760_qtd          | 0            | 0            | 184      | 22          | 1
      0xffff0000c59dee80 | isp1760_urb_listite  | 0            | 0            | 136      | 30          | 1
      0xffff0000c59dec80 | asd_sas_event        | 0            | 0            | 256      | 32          | 2
      0xffff0000c59dea80 | sas_task             | 0            | 0            | 448      | 36          | 4
      0xffff0000c59de880 | bio-120              | 18           | 21           | 384      | 21          | 2
      0xffff0000c59de680 | io_kiocb             | 0            | 0            | 448      | 36          | 4
      0xffff0000c59de480 | bfq_io_cq            | 0            | 0            | 1504     | 21          | 8
      0xffff0000c59de280 | bfq_queue            | 0            | 0            | 720      | 22          | 4
      0xffff0000c59de080 | mqueue_inode_cache   | 1            | 28           | 1152     | 28          | 8
      0xffff0000c59dde80 | v9fs_inode_cache     | 0            | 0            | 832      | 39          | 8
      ...
      
      (gdb) lx-slabtrace --cache_name kmalloc-1k
      63 <tty_register_device_attr+508> waste=16632/264 age=46856/46871/46888 pid=1 cpus=6,
         0xffff800008720240 <__kmem_cache_alloc_node+236>:    mov     x22, x0
         0xffff80000862a4fc <kmalloc_trace+64>:       mov     x21, x0
         0xffff8000095d086c <tty_register_device_attr+508>:   mov     x19, x0
         0xffff8000095d0f98 <tty_register_driver+704>:        cmn     x0, #0x1, lsl #12
         0xffff80000c2677e8 <vty_init+620>:   Cannot access memory at address 0xffff80000c2677e8
         0xffff80000c265a10 <tty_init+276>:   Cannot access memory at address 0xffff80000c265a10
         0xffff80000c26d3c4 <chr_dev_init+204>:       Cannot access memory at address 0xffff80000c26d3c4
         0xffff8000080161d4 <do_one_initcall+176>:    mov     w21, w0
         0xffff80000c1c1b58 <kernel_init_freeable+956>:       Cannot access memory at address 0xffff80000c1c1b58
         0xffff80000acf1334 <kernel_init+36>: bl      0xffff8000081ac040 <async_synchronize_full>
         0xffff800008018d00 <ret_from_fork+16>:       mrs     x28, sp_el0
      
      (gdb) lx-slabtrace --cache_name kmalloc-1k --free
      428 <not-available> age=4294958600 pid=0 cpus=0,
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-8-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      79939c4a
    • Kuan-Ying Lee's avatar
      scripts/gdb/page_owner: add page owner support · 2f060190
      Kuan-Ying Lee authored
      This GDB script prints page owner information for user to analyze the
      memory usage or memory corruption issue.
      
      Example output from an aarch64 system:
      
      (gdb) lx-dump-page-owner --pfn 655360
      page_owner tracks the page as allocated
      Page last allocated via order 0, gfp_mask: 0x8, pid: 1, tgid: 1 ("swapper/0\000\000\000\000\000\000"), ts 1295948880 ns, free_ts 1011852016 ns
      PFN: 655360, Flags: 0x3fffc0000000000
         0xffff8000086ab964 <post_alloc_hook+452>:    ldp     x19, x20, [sp, #16]
         0xffff80000862e4e0 <split_map_pages+344>:    cbnz    w22, 0xffff80000862e57c <split_map_pages+500>
         0xffff8000086370c4 <isolate_freepages_range+556>:    mov     x0, x27
         0xffff8000086bc1cc <alloc_contig_range+808>: mov     x24, x0
         0xffff80000877d6d8 <cma_alloc+772>:  mov     w1, w0
         0xffff8000082c8d18 <dma_alloc_from_contiguous+104>:  ldr     x19, [sp, #16]
         0xffff8000082ce0e8 <atomic_pool_expand+208>: mov     x19, x0
         0xffff80000c1e41b4 <__dma_atomic_pool_init+172>:     Cannot access memory at address 0xffff80000c1e41b4
         0xffff80000c1e4298 <dma_atomic_pool_init+92>:        Cannot access memory at address 0xffff80000c1e4298
         0xffff8000080161d4 <do_one_initcall+176>:    mov     w21, w0
         0xffff80000c1c1b50 <kernel_init_freeable+952>:       Cannot access memory at address 0xffff80000c1c1b50
         0xffff80000acf87dc <kernel_init+36>: bl      0xffff8000081ab100 <async_synchronize_full>
         0xffff800008018d00 <ret_from_fork+16>:       mrs     x28, sp_el0
      page last free stack trace:
         0xffff8000086a6e8c <free_unref_page_prepare+796>:    mov     w2, w23
         0xffff8000086aee1c <free_unref_page+96>:     tst     w0, #0xff
         0xffff8000086af3f8 <__free_pages+292>:       ldp     x19, x20, [sp, #16]
         0xffff80000c1f3214 <init_cma_reserved_pageblock+220>:        Cannot access memory at address 0xffff80000c1f3214
         0xffff80000c20363c <cma_init_reserved_areas+1284>:   Cannot access memory at address 0xffff80000c20363c
         0xffff8000080161d4 <do_one_initcall+176>:    mov     w21, w0
         0xffff80000c1c1b50 <kernel_init_freeable+952>:       Cannot access memory at address 0xffff80000c1c1b50
         0xffff80000acf87dc <kernel_init+36>: bl      0xffff8000081ab100 <async_synchronize_full>
         0xffff800008018d00 <ret_from_fork+16>:       mrs     x28, sp_el0
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-7-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      2f060190
    • Kuan-Ying Lee's avatar
      scripts/gdb/stackdepot: add stackdepot support · 0e1b240a
      Kuan-Ying Lee authored
      Add support for printing the backtrace of stackdepot handle.
      
      This is the preparation patch for dumping page_owner,
      slabtrace usage.
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-6-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      0e1b240a
    • Kuan-Ying Lee's avatar
      scripts/gdb/aarch64: add aarch64 page operation helper commands and configs · eb985b5d
      Kuan-Ying Lee authored
      1. Move page table debugging from mm.py to pgtable.py.
      
      2. Add aarch64 kernel config and memory constants value.
      
      3. Add below aarch64 page operation helper commands.
         page_to_pfn, page_to_phys, pfn_to_page, page_address,
         virt_to_phys, sym_to_pfn, pfn_to_kaddr, virt_to_page.
      
      4. Only support CONFIG_SPARSEMEM_VMEMMAP=y now.
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-5-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      eb985b5d
    • Kuan-Ying Lee's avatar
      scripts/gdb/utils: add common type usage · 4d040cbc
      Kuan-Ying Lee authored
      Since we often use 'unsigned long', 'size_t', 'usigned int'
      and 'struct page', we add these common types to utils.
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-4-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      4d040cbc
    • Kuan-Ying Lee's avatar
      scripts/gdb/modules: add get module text support · 82141540
      Kuan-Ying Lee authored
      When we get an text address from coredump and we cannot find
      this address in vmlinux, it might located in kernel module.
      
      We want to know which kernel module it located in.
      
      This GDB scripts can help us to find the target kernel module.
      
      (gdb) lx-getmod-by-textaddr 0xffff800002d305ac
      0xffff800002d305ac is in kasan_test.ko
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-3-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      82141540
    • Kuan-Ying Lee's avatar
      scripts/gdb/symbols: add specific ko module load command · 11f95653
      Kuan-Ying Lee authored
      Patch series "Add GDB memory helper commands", v2.
      
      I've created some GDB commands I think useful when I debug some memory
      issues and kernel module issue.
      
      For memory issue, we would like to get slabinfo, slabtrace, page_owner and
      vmallocinfo to debug the memory issues.
      
      For module issue, we would like to query kernel module name when we get a
      module text address and load module symbol by specific path.
      
      Patch 1-2:
       - Add kernel module related command.
      Patch 3-5:
       - Prepares for the memory-related command.
      Patch 6-8:
       - Add memory-related commands.
      
      
      This patch (of 8):
      
      Add lx-symbols <ko_path> command to support add specific
      ko module.
      
      Example output like below:
      (gdb) lx-symbols mm/kasan/kasan_test.ko
      loading @0xffff800002d30000: mm/kasan/kasan_test.ko
      
      Link: https://lkml.kernel.org/r/20230808083020.22254-1-Kuan-Ying.Lee@mediatek.com
      Link: https://lkml.kernel.org/r/20230808083020.22254-2-Kuan-Ying.Lee@mediatek.comSigned-off-by: default avatarKuan-Ying Lee <Kuan-Ying.Lee@mediatek.com>
      Cc: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
      Cc: Chinwen Chang <chinwen.chang@mediatek.com>
      Cc: Matthias Brugger <matthias.bgg@gmail.com>
      Cc: Qun-Wei Lin <qun-wei.lin@mediatek.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      11f95653
    • Jim Cromie's avatar
      checkpatch: reword long-line warning about commit-msg · 8e7b7ffb
      Jim Cromie authored
      Reword the warning to complain about line length 1st, since thats
      whats actually tested.
      
      Link: https://lkml.kernel.org/r/20230808033019.21911-3-jim.cromie@gmail.com
      Cc: apw@canonical.com
      Cc: joe@perches.com
      Signed-off-by: default avatarJim Cromie <jim.cromie@gmail.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      8e7b7ffb
    • Jim Cromie's avatar
      checkpatch: special case extern struct in .c · 5b2c7334
      Jim Cromie authored
      "externs should be avoided in .c files" needs an exception for linker
      symbols, like those that mark the start, stop of many kernel sections.
      
      Since checkpatch already checks REALNAME to avoid looking at fragments
      changing vmlinux.lds.h, add a new else-if block to look at them
      instead.  As a simple heuristic, treat all words (in the patch-line)
      as possible symbols, to screen later warnings.
      
      For my test case, the possible-symbols included BOUNDED_BY (a macro),
      which is extra, but not troublesome - these are just to screen
      WARNINGS that might be issued on later fragments (changing .c files)
      
      Where the WARN is issued, precede it with an else-if block to catch
      one common extern-in-c use case: "extern struct foo bar[]".  Here we
      can at least issue a softer warning, after checking for a match with a
      maybe-linker-symbol parsed earlier from the patch.
      
      Though heuristic, it worked for my test-case, allowing both start__,
      stop__ $symbol's (wo the prefixes specifically named).  I've coded it
      narrowly, it can be expanded later to cover any other expressions.
      
      It does require that the externs in .c's have the additions to
      vmlinux.lds.h in the same patch.  And requires vmlinux.lds.h before .c
      fragments.
      
      Link: https://lkml.kernel.org/r/20230808033019.21911-2-jim.cromie@gmail.comSigned-off-by: default avatarJim Cromie <jim.cromie@gmail.com>
      Cc: Joe Perches <joe@perches.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      5b2c7334
  2. 18 Aug, 2023 31 commits