Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1753902
  • 博文数量: 206
  • 博客积分: 1450
  • 博客等级: 上尉
  • 技术积分: 2285
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-11 11:38
个人简介

学习永无止境!!

文章分类

全部博文(206)

文章存档

2022年(5)

2019年(3)

2018年(8)

2017年(32)

2016年(7)

2015年(13)

2014年(44)

2013年(24)

2011年(6)

2010年(17)

2009年(46)

2008年(1)

分类: 嵌入式

2013-03-13 11:04:44

以下均针对于内核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");
}
阅读(2421) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~