Contributors: 8
Author Tokens Token Proportion Commits Commit Proportion
Aaron Tomlin 144 51.06% 1 12.50%
Christophe Leroy 52 18.44% 1 12.50%
Song Liu 48 17.02% 1 12.50%
Jason Wessel 29 10.28% 1 12.50%
Peter Zijlstra 4 1.42% 1 12.50%
Daniel R Thompson 3 1.06% 1 12.50%
Thomas Gleixner 1 0.35% 1 12.50%
Rusty Russell 1 0.35% 1 12.50%
Total 282 8

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
// SPDX-License-Identifier: GPL-2.0-or-later
/*
 * Module kdb support
 *
 * Copyright (C) 2010 Jason Wessel
 */

#include <linux/module.h>
#include <linux/kdb.h>
#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;
}