基于ARM9芯片S3C2410异常中断程序设计
发布时间:2008/8/29 0:00:00 访问次数:1047
验证的代码详细分析了基于arm嵌入式系统的异常处理流程,本文结合经过实际验证的代码对arm9中断处理流程进行分析,并设计出基于s3c2410芯片的外部中断处理程序。 arm9 arm9处理器 arm处理器 嵌入式系统 嵌入式
s3c2410x 的中断控制寄存器能接收来自56个中断源的请求。内部的外围模块和外部管脚产生的多个中断请求通过中断控制器冲裁后,向arm920t核发出fiq或者 irq中断。arm内核只有2个外部中断输入信号nirq和nfiq,在具体嵌入式系统中,需要用中断控制器管理多个外部中断源,选择其中一个中断,通过 nirq或nfiq向arm内核发出中断请求。
arm920t内核可以识别正常中断请求和快速中断请求两种类型的外部中断,中断的行为模式由中断控制器来设置。s3c2410x的中断控制器包括6类寄存器:中断源状态寄存器、中断模式寄存器、中断屏蔽寄存器、优先级寄存器、中断状态寄存器,以及中断偏移寄存器。
在初始化程序中,需要选择相应管脚的功能,在此定义gpf3为eint3模式,通过外部中断控制寄存器extint0设定eint3是下降沿触发方式,通过设置中断源悬挂寄存器srcpnd、中断悬挂寄存器intpnd和中断屏蔽寄存器intmsk开启eint3。中断模式寄存器和中断优先级寄存器采用系统默认方式。具体代码实现如下:
void eint_init(void){
rgpfcon = (rgpfcon & 0x3f0c)|(1<<7);
rextint0 = (rextint0 & ~(0x7<<12)) | 0x2<<12;
pisr_eint3=(u32)eint3int;
rsrcpnd = bit_eint3;
rintpnd = bit_eint3;
rintmsk=~( bit_eint3);
}
如果采用eint4~eint23之间的中断源,还需要设置外部中断悬挂寄存器eintpend和外部中断掩码寄存器eintmask的相关位。
在c语言的main()程序中调用eint_init()函数,即可完成中断处理的初始化操作。 若外部下降沿信号接到gpf3管脚,就可以调用eint3int中断处理函数。
总之,本文采用的异常处理程序设计方式灵活可靠,可以在系统运行期间动态修改中断向量表,利用c语言也可实现中断处理函数的动态配置。在所设计的键盘处理程序中采用该方法,取得了很好地效果,该方法具有很强的通用性。
欢迎转载,信息来自维库电子市场网(www.dzsc.com)
验证的代码详细分析了基于arm嵌入式系统的异常处理流程,本文结合经过实际验证的代码对arm9中断处理流程进行分析,并设计出基于s3c2410芯片的外部中断处理程序。 arm9 arm9处理器 arm处理器 嵌入式系统 嵌入式
s3c2410x 的中断控制寄存器能接收来自56个中断源的请求。内部的外围模块和外部管脚产生的多个中断请求通过中断控制器冲裁后,向arm920t核发出fiq或者 irq中断。arm内核只有2个外部中断输入信号nirq和nfiq,在具体嵌入式系统中,需要用中断控制器管理多个外部中断源,选择其中一个中断,通过 nirq或nfiq向arm内核发出中断请求。
arm920t内核可以识别正常中断请求和快速中断请求两种类型的外部中断,中断的行为模式由中断控制器来设置。s3c2410x的中断控制器包括6类寄存器:中断源状态寄存器、中断模式寄存器、中断屏蔽寄存器、优先级寄存器、中断状态寄存器,以及中断偏移寄存器。
在初始化程序中,需要选择相应管脚的功能,在此定义gpf3为eint3模式,通过外部中断控制寄存器extint0设定eint3是下降沿触发方式,通过设置中断源悬挂寄存器srcpnd、中断悬挂寄存器intpnd和中断屏蔽寄存器intmsk开启eint3。中断模式寄存器和中断优先级寄存器采用系统默认方式。具体代码实现如下:
void eint_init(void){
rgpfcon = (rgpfcon & 0x3f0c)|(1<<7);
rextint0 = (rextint0 & ~(0x7<<12)) | 0x2<<12;
pisr_eint3=(u32)eint3int;
rsrcpnd = bit_eint3;
rintpnd = bit_eint3;
rintmsk=~( bit_eint3);
}
如果采用eint4~eint23之间的中断源,还需要设置外部中断悬挂寄存器eintpend和外部中断掩码寄存器eintmask的相关位。
在c语言的main()程序中调用eint_init()函数,即可完成中断处理的初始化操作。 若外部下降沿信号接到gpf3管脚,就可以调用eint3int中断处理函数。
总之,本文采用的异常处理程序设计方式灵活可靠,可以在系统运行期间动态修改中断向量表,利用c语言也可实现中断处理函数的动态配置。在所设计的键盘处理程序中采用该方法,取得了很好地效果,该方法具有很强的通用性。
欢迎转载,信息来自维库电子市场网(www.dzsc.com)