Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1601782
  • 博文数量: 92
  • 博客积分: 2002
  • 博客等级: 大尉
  • 技术积分: 4717
  • 用 户 组: 普通用户
  • 注册时间: 2010-09-01 17:09
文章分类

全部博文(92)

文章存档

2013年(1)

2012年(6)

2011年(85)

分类: LINUX

2011-04-26 16:56:38

    和我们通常写程序不同,如果仅仅是全局变量,虽然编译内核的时候能连接成功,但是连接之后再就没有办法使用这个变量了
    而模块的加载是运行时的,它引用某个变量时,内核需要解析它,否则模块不能工作,EXPORT_SYMBOL 的定义如下

  1. #define __EXPORT_SYMBOL(sym, sec) \
  2.         extern typeof(sym) sym; \
  3.         __CRC_SYMBOL(sym, sec) \
  4.         static const char __kstrtab_##sym[] \
  5.         __attribute__((section("__ksymtab_strings"))) \
  6.         = MODULE_SYMBOL_PREFIX #sym; \
  7.         static const struct kernel_symbol __ksymtab_##sym \
  8.         __attribute_used__ \
  9.         __attribute__((section("__ksymtab" sec), unused)) \
  10.         = { (unsigned long)&sym, __kstrtab_##sym }

它放在固定的节,这样内核解析的时候就能在此节里找符号了,之后的重定位和普通的连接原理类似.

-------------------------------------------------------------------------------------------

EXPORT_SYMBOL宏的用法:

在a.c中这样写:
int var = 100;   //var是全局的.
EXPORT_SYMBOL(var);


然后在b.c中调用它的话就:
extern int var;
阅读(3987) | 评论(0) | 转发(3) |
0

上一篇:继电器原理图

下一篇:top命令

给主人留下些什么吧!~~