// SPDX-License-Identifier: GPL-2.0-or-later /* * Module kdb support * * Copyright (C) 2010 Jason Wessel */ #include #include #include "internal.h" /* * kdb_lsmod - This function implements the 'lsmod' command. Lists * currently loaded kernel modules. * Mostly taken from userland lsmod. */ int kdb_lsmod(int argc, const char **argv) { struct module *mod; if (argc != 0) return KDB_ARGCOUNT; kdb_printf("Module Size modstruct Used by\n"); list_for_each_entry(mod, &modules, list) { if (mod->state == MODULE_STATE_UNFORMED) continue; kdb_printf("%-20s%8u", mod->name, mod->mem[MOD_TEXT].size); kdb_printf("/%8u", mod->mem[MOD_RODATA].size); kdb_printf("/%8u", mod->mem[MOD_RO_AFTER_INIT].size); kdb_printf("/%8u", mod->mem[MOD_DATA].size); kdb_printf(" 0x%px ", (void *)mod); #ifdef CONFIG_MODULE_UNLOAD kdb_printf("%4d ", module_refcount(mod)); #endif if (mod->state == MODULE_STATE_GOING) kdb_printf(" (Unloading)"); else if (mod->state == MODULE_STATE_COMING) kdb_printf(" (Loading)"); else kdb_printf(" (Live)"); kdb_printf(" 0x%px", mod->mem[MOD_TEXT].base); kdb_printf("/0x%px", mod->mem[MOD_RODATA].base); kdb_printf("/0x%px", mod->mem[MOD_RO_AFTER_INIT].base); kdb_printf("/0x%px", mod->mem[MOD_DATA].base); #ifdef CONFIG_MODULE_UNLOAD { struct module_use *use; kdb_printf(" [ "); list_for_each_entry(use, &mod->source_list, source_list) kdb_printf("%s ", use->target->name); kdb_printf("]\n"); } #endif } return 0; }