1f64205a4SAaron Tomlin // SPDX-License-Identifier: GPL-2.0-or-later
2f64205a4SAaron Tomlin /*
3f64205a4SAaron Tomlin * Module kdb support
4f64205a4SAaron Tomlin *
5f64205a4SAaron Tomlin * Copyright (C) 2010 Jason Wessel
6f64205a4SAaron Tomlin */
7f64205a4SAaron Tomlin
8f64205a4SAaron Tomlin #include <linux/module.h>
9f64205a4SAaron Tomlin #include <linux/kdb.h>
10f64205a4SAaron Tomlin #include "internal.h"
11f64205a4SAaron Tomlin
12f64205a4SAaron Tomlin /*
13f64205a4SAaron Tomlin * kdb_lsmod - This function implements the 'lsmod' command. Lists
14f64205a4SAaron Tomlin * currently loaded kernel modules.
15f64205a4SAaron Tomlin * Mostly taken from userland lsmod.
16f64205a4SAaron Tomlin */
kdb_lsmod(int argc,const char ** argv)17f64205a4SAaron Tomlin int kdb_lsmod(int argc, const char **argv)
18f64205a4SAaron Tomlin {
19f64205a4SAaron Tomlin struct module *mod;
20f64205a4SAaron Tomlin
21f64205a4SAaron Tomlin if (argc != 0)
22f64205a4SAaron Tomlin return KDB_ARGCOUNT;
23f64205a4SAaron Tomlin
24f64205a4SAaron Tomlin kdb_printf("Module Size modstruct Used by\n");
25f64205a4SAaron Tomlin list_for_each_entry(mod, &modules, list) {
26f64205a4SAaron Tomlin if (mod->state == MODULE_STATE_UNFORMED)
27f64205a4SAaron Tomlin continue;
28f64205a4SAaron Tomlin
29*ac3b4328SSong Liu kdb_printf("%-20s%8u", mod->name, mod->mem[MOD_TEXT].size);
30*ac3b4328SSong Liu kdb_printf("/%8u", mod->mem[MOD_RODATA].size);
31*ac3b4328SSong Liu kdb_printf("/%8u", mod->mem[MOD_RO_AFTER_INIT].size);
32*ac3b4328SSong Liu kdb_printf("/%8u", mod->mem[MOD_DATA].size);
33*ac3b4328SSong Liu
3401dc0386SChristophe Leroy kdb_printf(" 0x%px ", (void *)mod);
35f64205a4SAaron Tomlin #ifdef CONFIG_MODULE_UNLOAD
36f64205a4SAaron Tomlin kdb_printf("%4d ", module_refcount(mod));
37f64205a4SAaron Tomlin #endif
38f64205a4SAaron Tomlin if (mod->state == MODULE_STATE_GOING)
39f64205a4SAaron Tomlin kdb_printf(" (Unloading)");
40f64205a4SAaron Tomlin else if (mod->state == MODULE_STATE_COMING)
41f64205a4SAaron Tomlin kdb_printf(" (Loading)");
42f64205a4SAaron Tomlin else
43f64205a4SAaron Tomlin kdb_printf(" (Live)");
44*ac3b4328SSong Liu kdb_printf(" 0x%px", mod->mem[MOD_TEXT].base);
45*ac3b4328SSong Liu kdb_printf("/0x%px", mod->mem[MOD_RODATA].base);
46*ac3b4328SSong Liu kdb_printf("/0x%px", mod->mem[MOD_RO_AFTER_INIT].base);
47*ac3b4328SSong Liu kdb_printf("/0x%px", mod->mem[MOD_DATA].base);
48f64205a4SAaron Tomlin
49f64205a4SAaron Tomlin #ifdef CONFIG_MODULE_UNLOAD
50f64205a4SAaron Tomlin {
51f64205a4SAaron Tomlin struct module_use *use;
52f64205a4SAaron Tomlin
53f64205a4SAaron Tomlin kdb_printf(" [ ");
54f64205a4SAaron Tomlin list_for_each_entry(use, &mod->source_list,
55f64205a4SAaron Tomlin source_list)
56f64205a4SAaron Tomlin kdb_printf("%s ", use->target->name);
57f64205a4SAaron Tomlin kdb_printf("]\n");
58f64205a4SAaron Tomlin }
59f64205a4SAaron Tomlin #endif
60f64205a4SAaron Tomlin }
61f64205a4SAaron Tomlin
62f64205a4SAaron Tomlin return 0;
63f64205a4SAaron Tomlin }
64