日期:2014-05-16  浏览次数:20760 次

100分求 内核模块的调试方法
今天遇到一个新问题,小弟也是新手
我现在要修改内核源码 Board-dm646x-evm.c (kernel\arch\arm\mach-davinci)

需要添加几个东西,假如加入的是这个 I2C_BOARD_INFO("frontboard", 0x90),


问题来了,就是出现在调试问题, 我不能保证我的代码一次性的写对,肯定是需要返回修改测试的。

以前遇到驱动模块的时候,都是insmod 一个模块,测试写的对不对,然后在卸载,很方便调试了,但是这个内核文件我看了一下,好像不是模块的,因为没找到声明这个文件是模块的 宏, 这里我就不知道怎么调试了, 大家能不能给我点方法呢?

先谢谢了




------解决方案--------------------
不是所有的硬件驱动可以做成kernel module方式,系统早期初始化时用到的设备就只能build in kernel.
例如一些总线控制器驱动。

输出日志是个好的选择,或者kgdb,或者JTAG调试。
------解决方案--------------------
Linux kernel 2.6源代码目录树中:include\linux\init.h文件中实现了module_init等宏:
C/C++ code

#define pure_initcall(fn)        __define_initcall("0",fn,0)

#define core_initcall(fn)        __define_initcall("1",fn,1)
#define core_initcall_sync(fn)        __define_initcall("1s",fn,1s)
#define postcore_initcall(fn)        __define_initcall("2",fn,2)
#define postcore_initcall_sync(fn)    __define_initcall("2s",fn,2s)
#define arch_initcall(fn)        __define_initcall("3",fn,3)
#define arch_initcall_sync(fn)        __define_initcall("3s",fn,3s)
#define subsys_initcall(fn)        __define_initcall("4",fn,4)
#define subsys_initcall_sync(fn)    __define_initcall("4s",fn,4s)
#define fs_initcall(fn)            __define_initcall("5",fn,5)
#define fs_initcall_sync(fn)        __define_initcall("5s",fn,5s)
#define rootfs_initcall(fn)        __define_initcall("rootfs",fn,rootfs)
#define device_initcall(fn)        __define_initcall("6",fn,6)
#define device_initcall_sync(fn)    __define_initcall("6s",fn,6s)
#define late_initcall(fn)        __define_initcall("7",fn,7)
#define late_initcall_sync(fn)        __define_initcall("7s",fn,7s)

#define __initcall(fn) device_initcall(fn)

/* ... */
/**
 * module_init() - driver initialization entry point
 * @x: function to be run at kernel boot time or module insertion
 * 
 * module_init() will either be called during do_initcalls() (if
 * builtin) or at module insertion time (if a module).  There can only
 * be one per module.
 */
#define module_init(x)    __initcall(x);

------解决方案--------------------
arch下的绝对是要编译进内核的,不能做成模块。
也就是说,只能改一次,编译一次,烧写一次。