diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2023-08-29 14:53:51 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2023-08-29 14:53:51 -0700 | 
| commit | d68b4b6f307d155475cce541f2aee938032ed22e (patch) | |
| tree | c2a6487ac8b1bce963b5b352b42e461a6fa8da15 /scripts/gdb/linux/modules.py | |
| parent | b96a3e9142fdf346b05b20e867b4f0dfca119e96 (diff) | |
| parent | dce8f8ed1de1d9d6d27c5ccd202ce4ec163b100c (diff) | |
Merge tag 'mm-nonmm-stable-2023-08-28-22-48' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm
Pull non-MM updates from Andrew Morton:
 - An extensive rework of kexec and crash Kconfig from Eric DeVolder
   ("refactor Kconfig to consolidate KEXEC and CRASH options")
 - kernel.h slimming work from Andy Shevchenko ("kernel.h: Split out a
   couple of macros to args.h")
 - gdb feature work from Kuan-Ying Lee ("Add GDB memory helper
   commands")
 - vsprintf inclusion rationalization from Andy Shevchenko
   ("lib/vsprintf: Rework header inclusions")
 - Switch the handling of kdump from a udev scheme to in-kernel
   handling, by Eric DeVolder ("crash: Kernel handling of CPU and memory
   hot un/plug")
 - Many singleton patches to various parts of the tree
* tag 'mm-nonmm-stable-2023-08-28-22-48' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm: (81 commits)
  document while_each_thread(), change first_tid() to use for_each_thread()
  drivers/char/mem.c: shrink character device's devlist[] array
  x86/crash: optimize CPU changes
  crash: change crash_prepare_elf64_headers() to for_each_possible_cpu()
  crash: hotplug support for kexec_load()
  x86/crash: add x86 crash hotplug support
  crash: memory and CPU hotplug sysfs attributes
  kexec: exclude elfcorehdr from the segment digest
  crash: add generic infrastructure for crash hotplug support
  crash: move a few code bits to setup support of crash hotplug
  kstrtox: consistently use _tolower()
  kill do_each_thread()
  nilfs2: fix WARNING in mark_buffer_dirty due to discarded buffer reuse
  scripts/bloat-o-meter: count weak symbol sizes
  treewide: drop CONFIG_EMBEDDED
  lockdep: fix static memory detection even more
  lib/vsprintf: declare no_hash_pointers in sprintf.h
  lib/vsprintf: split out sprintf() and friends
  kernel/fork: stop playing lockless games for exe_file replacement
  adfs: delete unused "union adfs_dirtail" definition
  ...
Diffstat (limited to 'scripts/gdb/linux/modules.py')
| -rw-r--r-- | scripts/gdb/linux/modules.py | 44 | 
1 files changed, 40 insertions, 4 deletions
| diff --git a/scripts/gdb/linux/modules.py b/scripts/gdb/linux/modules.py index 261f28640f4c..298dfcc25eae 100644 --- a/scripts/gdb/linux/modules.py +++ b/scripts/gdb/linux/modules.py @@ -73,11 +73,17 @@ class LxLsmod(gdb.Command):                  "        " if utils.get_long_type().sizeof == 8 else ""))          for module in module_list(): -            layout = module['mem'][constants.LX_MOD_TEXT] +            text = module['mem'][constants.LX_MOD_TEXT] +            text_addr = str(text['base']).split()[0] +            total_size = 0 + +            for i in range(constants.LX_MOD_TEXT, constants.LX_MOD_RO_AFTER_INIT + 1): +                total_size += module['mem'][i]['size'] +              gdb.write("{address} {name:<19} {size:>8}  {ref}".format( -                address=str(layout['base']).split()[0], +                address=text_addr,                  name=module['name'].string(), -                size=str(layout['size']), +                size=str(total_size),                  ref=str(module['refcnt']['counter'] - 1)))              t = self._module_use_type.get_type().pointer() @@ -91,5 +97,35 @@ class LxLsmod(gdb.Command):              gdb.write("\n") -  LxLsmod() + +def help(): +    t = """Usage: lx-getmod-by-textaddr [Heximal Address] +    Example: lx-getmod-by-textaddr 0xffff800002d305ac\n""" +    gdb.write("Unrecognized command\n") +    raise gdb.GdbError(t) + +class LxFindTextAddrinMod(gdb.Command): +    '''Look up loaded kernel module by text address.''' + +    def __init__(self): +        super(LxFindTextAddrinMod, self).__init__('lx-getmod-by-textaddr', gdb.COMMAND_SUPPORT) + +    def invoke(self, arg, from_tty): +        args = gdb.string_to_argv(arg) + +        if len(args) != 1: +            help() + +        addr = gdb.Value(int(args[0], 16)).cast(utils.get_ulong_type()) +        for mod in module_list(): +            mod_text_start = mod['mem'][constants.LX_MOD_TEXT]['base'] +            mod_text_end = mod_text_start + mod['mem'][constants.LX_MOD_TEXT]['size'].cast(utils.get_ulong_type()) + +            if addr >= mod_text_start and addr < mod_text_end: +                s = "0x%x" % addr + " is in " + mod['name'].string() + ".ko\n" +                gdb.write(s) +                return +        gdb.write("0x%x is not in any module text section\n" % addr) + +LxFindTextAddrinMod() | 
