【S5PV210_视频编解码项目】裸机开发:实现按键的外部中断处理

本文主要是介绍【S5PV210_视频编解码项目】裸机开发:实现按键的外部中断处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

加粗样式本文所作内容:
基于S5PV210芯片实现按键的外部中断处理程序,搭建中断处理流程框架

S5PV210对于中断处理的操作流程

1 外部中断得到触发:

1)外部中断在初始化阶段得到使能
2)外界达到了外部中断的触发条件

2 跳转到向量表:

1)异常向量表在初始化阶段进行了配置ISR处理程序
2)ISR处理程序包含了保护现场和回复现场的功能
3)ISR处理程序能够跳转到中断总ISR_handel程序

3 跳转到对应中断号的中断处理程序

1)对应中断号的中断得到初始化使能
2)在ISR_handel中找到对应出现的中断号
3)在ISR_handel中跳转到对应该中断号的isr中

S5PV210实现外部中断处理的程序流

初始化阶段

1)首先初始化异常向量表:

 //初始化异常向量表r_exception_reset = (unsigned int)reset_exception;r_exception_undef = (unsigned int)undef_exception;r_exception_sotf_int = (unsigned int)sotf_int_exception;r_exception_prefetch = (unsigned int)prefetch_exception;r_exception_data = (unsigned int)data_exception;r_exception_irq = (unsigned int)IRQ_handle;r_exception_fiq = (unsigned int)IRQ_handle;

2)然后初始化芯片的中断系统:先全部中断号禁止中断,然后中断工作模式为IRQ,然后清除中断跳转寄存器

 //禁止所有中断VIC0INTENCLEAR = 0xFFFFFFFF;VIC1INTENCLEAR = 0xFFFFFFFF;VIC2INTENCLEAR = 0xFFFFFFFF;VIC3INTENCLEAR = 0xFFFFFFFF;//配置中断类型 (默认全部为IRQ工作模式)VIC0INTSELECT = 0x0;VIC1INTSELECT = 0x0;VIC2INTSELECT = 0x0;VIC3INTSELECT = 0x0;//清除中断跳转寄存器VIC0ADDR = 0;VIC1ADDR = 0;VIC2ADDR = 0;VIC3ADDR = 0;

3)设置想要调试的外部中断:设置对应GPIO的工作模式外外部中断模式,使能对应的外部中断,设置外部中断的触发方式

//配置IO引脚为外部中断工作模式rGPH0CON |= (0xFF<<8); rGPH2CON |= (0xFFFF<<0);//配置对应外部中断号下中断触发形式:下降沿触发rEXT_INT_0_CON &= ~(0xFF<<8);	rEXT_INT_0_CON |= ((2<<8)|(2<<12));		rEXT_INT_2_CON &= ~(0xFFFF<<0);rEXT_INT_2_CON |= ((2<<0)|(2<<4)|(2<<8)|(2<<12));	/*设置为0表示使能中断*/rEXT_INT_0_MASK &= ~(3<<2);	rEXT_INT_2_MASK &= ~(0x0f<<0);/*软件写1 表示清除flag*/rEXT_INT_0_PEND |= (3<<2);rEXT_INT_2_PEND |= (0x0F<<0);

实现中断处理流程

1)实现第一阶段的异常向量表跳转程序:汇编实现(保存现场-跳转IRQ处理程序-现场恢复)

IRQ_handle:// 设置IRQ模式下的栈指针ldr sp, =IRQ_STACK// 保存现场// 保存LR寄存器 lr寄存器先减去4(ARM的流水线机制)sub lr, lr, #4// 保存R0-R12寄存器stmfd sp!, {r0-r12, lr}// 跳转到真正的中断处理程序bl irq_handler// 回复现场ldmfd sp!, {r0-r12, pc}^

2)实现中断处理第二阶段:寻找中断编号,寻找中断编号对应的isr

/*1-根据状态寄存器 找到对应的中断控制器位置(VIC0/1/2/3)*/unsigned long vicaddr[4] = {VIC0ADDR,VIC1ADDR,VIC2ADDR,VIC3ADDR};void (*isr)(void) = NULL;unsigned int i = 0;for(i=0; i<3 ; i++){if(intc_getvicirqstatus(i)){/*2-根据中断控制器位置,跳转到对应中断控制器的vectaddr中拿到对应的中断isr*/isr = (void (*)(void)) vicaddr[i];break; }}(*isr)();  

3)使能对应外部中断的中断编号,配置对应该中断编号的isr程序

//根据中断号 将对应的中断回调函数绑定在VECTADDR寄存器中
void intc_setvectaddr(unsigned long intnum, void (*handler)(void))
{if(intnum < 32){( *((volatile unsigned long *)(VIC0VECTADDR + 4*(intnum - 0))) ) = (unsigned)handler;}else if(intnum < 64){( *((volatile unsigned long *)(VIC0VECTADDR + 4*(intnum - 32))) ) = (unsigned)handler;}else if(intnum < 96){( *((volatile unsigned long *)(VIC0VECTADDR + 4*(intnum - 64))) ) = (unsigned)handler;}else if(intnum < 128){( *((volatile unsigned long *)(VIC0VECTADDR + 4*(intnum - 96))) ) = (unsigned)handler;}else{printf("ERR!:intc_setvectaddr err: intnum out of max of SOC\n");}return;
}
//根据中断号将对应中断使能
void intc_enable(unsigned long intnum)
{unsigned int sTemp = 0;if(intnum < 32){sTemp = VIC0INTENABLE;sTemp |= (1<<(intnum - 0));VIC0INTENABLE = sTemp;}else if(intnum < 64){sTemp = VIC1INTENABLE;sTemp |= (1<<(intnum - 32));VIC1INTENABLE = sTemp;}else if(intnum < 96){sTemp = VIC2INTENABLE;sTemp |= (1<<(intnum - 64));VIC2INTENABLE = sTemp;}else if(intnum < 128){sTemp = VIC3INTENABLE;sTemp |= (1<<(intnum - 96));VIC3INTENABLE = sTemp;}else{VIC0INTENABLE = 0xFFFFFFFF;VIC1INTENABLE = 0xFFFFFFFF;VIC2INTENABLE = 0xFFFFFFFF;VIC3INTENABLE = 0xFFFFFFFF;printf("ERR!:intc_enable err: intnum out of max of SOC\n");}
}

在功能调试时遇到的问题

问题一:按下按键后程序没有跳转到中断处理程序

1)分析1:结合没有心跳信息打印,怀疑程序跑飞,需要调试出程序具体在哪一行飞了
2)行动1:在main函数中加入串口打印信息,看看程序在哪一行之后不能正常打印信息了
3)结果1:发现程序在配置中断向量表的第一行飞了
在这里插入图片描述

4)分析2:检查该行,还行的目的是将函数指针以地址的形式填充到中断向量表中,但是中断向量表只有一个首地址,需要根据中断号计算地址。明显偏移地址计算出错,地址是以字节形式递增的,应该×4
5)行动2:

6)结果2:问题解决

问题二:中断只能触发一次,之后就不能触发了,同时心跳信息消失

1)分析1:怀疑是中断返回时候现场恢复有问题,但是检查现场恢复程序为标准处理过程,问题出现在异常向量表的处理阶段,检查初始化代码的流程看是否缺少异常向量表初始化
2)行动1:检查初始化程序流,发现缺少了一步异常向量表初始化,加入异常向量表初始化
3)结果1:问题解决

这篇关于【S5PV210_视频编解码项目】裸机开发:实现按键的外部中断处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820305

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是