Chinaunix首页 | 论坛 | 博客
  • 博客访问: 343763
  • 博文数量: 96
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 152
  • 用 户 组: 普通用户
  • 注册时间: 2013-09-02 09:27
文章分类

全部博文(96)

文章存档

2017年(2)

2016年(30)

2015年(38)

2014年(25)

2013年(1)

我的朋友

分类: 嵌入式

2015-09-25 11:50:28

原文地址:Linux中的THIS_MODULE 作者:xuelei_51

以下均针对于内核2.6.18

在module.h 中 THIS_MODULE的定义如下:

extern struct module __this_module; #define THIS_MODULE (&__this_module)

即是保存了__this_module这个对象的地址,那这个__this_module在哪里定义呢?这就要从module的编译说起啦,如果编译过模块就会发现,会生成*.mod.c这样的一个文件,打开这个文件,就会发现,类似下面的定义:

struct module __this_module
__attribute__((section(".gnu.linkonce.this_module"))) = {
 .name = KBUILD_MODNAME,
 .init = init_module,
#ifdef CONFIG_MODULE_UNLOAD
 .exit = cleanup_module, #endif };

这个文件是调用modpost生成的,modpost的main中有这样一段代码:

    for (mod = modules; mod; mod = mod->next) { if (mod->skip) continue;

        buf.pos = 0;

        add_header(&buf, mod);
        add_versions(&buf, mod);
        add_depends(&buf, mod, modules);
        add_moddevtable(&buf, mod);
        add_srcversion(&buf, mod);

        sprintf(fname, "%s.mod.c", mod->name);
        write_if_changed(&buf, fname);
    }

其中的add_header就偷偷添加了__this_module 的定义

static void add_header(struct buffer *b, struct module *mod)
{
    buf_printf(b,
"#include \n");
    buf_printf(b,
"#include \n");
    buf_printf(b,
"#include \n");
    buf_printf(b,
"\n");
    buf_printf(b,
"MODULE_INFO(vermagic, VERMAGIC_STRING);\n");
    buf_printf(b,
"\n");
    buf_printf(b,
"struct module __this_module\n");
    buf_printf(b,
"__attribute__((section(\".gnu.linkonce.this_module\"))) = {\n");
    buf_printf(b,
" .name = KBUILD_MODNAME,\n"); if (mod->has_init)
        buf_printf(b,
" .init = init_module,\n"); if (mod->has_cleanup)
        buf_printf(b,
"#ifdef CONFIG_MODULE_UNLOAD\n" " .exit = cleanup_module,\n" "#endif\n");
    buf_printf(b,
"};\n");
}
阅读(1310) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~