request_region(int io_port, int off_set,char *devname)
如果这段I/O 端口没有被占用,在我们的驱动程序中就可以使用它。在使用之前,必须向系统登记,以防止其他程序占用。
登记后,在/proc/ioports文件中可以看到你登记的io口。
int request_irq(unsigned int irq, void(*handle)(int, void*, struct pt_regs*)unsigned int long flags, const char *device);
如果登记成功,返回0,这是在/proc/interrupts文件中可以看你请求的中断。
测试时,先创建设备节点:#mknod test c 254 0 (设备名,类型,主设备号,从设备号),
然后进入/proc/
然后查看:文件iomem,ioports,interrupts,device,module等文件,
interrupts是对应的中断号和对应的设备(如定时器),这是系统所使用的中断。
iomem:是系统所使用的内存
ioports:使用的寄存器地址和对应的设备名。
device:当前你打开的设备有哪些
module:是系统当前加载了哪些模块,这个模块是我们的驱动程序。
linux内核启动顺序:
1,boot加载完内核后,内核先执行head.S文件,执行完后跳转到linux2.4/init/main.c函数。里面有一个start kerenl()函数,
然后找到/etc/inittab这个shell脚本并执行,这是x86架构,这是系统配置文件,但是44b0开发板是找到/etc/linuxrc脚本并执行。