xref: /linux-6.15/kernel/module/kdb.c (revision ac3b4328)
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