软件篇:
上一篇文章回忆了s3c2440的中止控制器原理的相关硬件常识,有了这个根底再来剖析Linux中的软件剖析方法,心里就有底了。面临众多如海的Linux源代码,s3c2440的中止到底是怎样呢,怎样处理,怎样完成的呢?一步一步来揭开它奥秘的面纱吧,当然需要从Linux内核源码下手!
在Linux中start_kernel()时会进行体系结构的初始化:init_IRQ(), 故名思议,其源代码如下:
- void__initinit_IRQ(void)
- {
- intirq;
- for(irq=0;irq
- irq_desc[irq].status|=IRQ_NOREQUEST|IRQ_NOPROBE;
- #ifdefCONFIG_SMP
- cpumask_setall(bad_irq_desc.affinity);
- bad_irq_desc.cpu=smp_processor_id();
- #endif
- init_arch_irq();//这里是体系初始化irq的进口
- }
init_arch_irq()初始值为:void (*init_arch_irq)(void)__initdata = NULL; 相当于一个变量函数(函数就像变量相同,被赋值),默认值为NULL,那么在其他当地应该被再次赋值。其实在setup_arch()中init_arch_irq()现已有所指向了,在arch/arm/kernel/setup.c中setup_arch进行体系渠道相关初始化:
- void__initsetup_arch(char**cmdline_p)
- {
- structtag*tags=(structtag*)&init_tags;
- structmachine_desc*mdesc;
- char*from=default_command_line;
- unwind_init();
- setup_processor();
- mdesc=setup_machine(machine_arch_type);
- machine_name=mdesc->name;
- …
- cpu_init();
- …
- init_arch_irq=mdesc->init_irq;//这里是init_arch_irq()指向的函数
- system_timer=mdesc->timer;
- init_machine=mdesc->init_machine;
- …
- early_trap_init()//初始化中止向量表
- }
mdesc是一个struct machine_desc的数据结构,msdesc 经过 setup_machine(machine_arch_type) 获取渠道体系的MACHINE_START相关参数。
- #defineMACHINE_START(_type,_name)\
- staticconststructmachine_desc__mach_desc_##_type\
- __used\
- __attribute__((__section__(“.arch.info.init”)))={\
- .nr=MACH_TYPE_##_type,\
- .name=_name,
- #defineMACHINE_END\
- };
这个参数如下:
- MACHINE_START(S3C2440,”SMDK2440″)
- /*Maintainer:BenDooks
*/ - .phys_io=S3C2410_PA_UART,
- .io_pg_offst=(((u32)S3C24XX_VA_UART)>>18)&0xfffc,
- .boot_params=S3C2410_SDRAM_PA+0x100,
- .init_irq=s3c24xx_init_irq,//这里是方针CPU的irq初始化函数
- .map_io=smdk2440_map_io,
- .init_machine=smdk2440_machine_init,
- .timer=&s3c24xx_timer,
- MACHINE_END
可见s3c24xx_init_irq()才是所要找得中止初始化进口程序,所以碑文init_arch_irq()实践是碑文s3c24xx_init_irq()程序。中止的初始化作业:首要,清空各interrupt pending的值,然后再向体系注册首要的中止,从上篇中咱们知道s3c2440有60个中止,但体系中首要用了58个中止,
注册中止首要用下面三个函数:
- intset_irq_chip(unsignedintirq,structirq_chip*chip)
- staticinlinevoidset_irq_handler(unsignedintirq,irq_flow_handler_thandle)
- staticinlinevoidset_irq_chained_handler(unsignedintirq,irq_flow_handler_thandle)
至此,中止的初始化进程完成了,那么它是怎样作业的,详细的流程由怎样,各中止函数的回调函数怎样了解,下文将持续深入探讨。。