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:问题解决

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/741755.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

汉诺塔问题代码写法的详细解析

汉诺塔游戏规则&#xff1a; 规则&#xff1a; 汉诺塔问题是一个经典的问题。汉诺塔&#xff08;Hanoi Tower&#xff09;&#xff0c;又称河内塔&#xff0c;源于印度一个古老传说。大梵天创造世界的时候做了三根金刚石柱子&#xff0c;在一根柱子上从下往上按照大小顺序摞着…

有来团队后台项目-解析3

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、引入Elment-plus安装element-plus安装icons修改tsconfig.json (可选)配置按需自动引入验证是否导入成功展示效果typings 文件夹里生成两个文件总结一、引入Elment-plus elementplus 安装el…

30天学会QT(进阶)--------------第二天(创建项目)

1、如何规范的创建一个项目 由于本人也是从其他的项目上学来的&#xff0c;所以也不算是业界规范&#xff0c;每个公司或者个人都有自己的方式去创建项目&#xff0c;项目的创建是本着简洁&#xff0c;明了&#xff0c;方便而言的&#xff0c;所以对于我来说&#xff0c;不繁琐…

案例--某站视频爬取

众所周知&#xff0c;某站的视频是&#xff1a; 由视频和音频分开的。 所以我们进行获取&#xff0c;需要分别获得它的音频和视频数据&#xff0c;然后进行音视频合并。 这么多年了&#xff0c;某站还是老样子&#xff0c;只要加个防盗链就能绕过。&#xff08;防止403&#xf…

蓝桥杯刷题(五)

[蓝桥杯 2022 省 B] 刷题统计 题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 样例 #2样例输入 #2样例输出 #2 提示 题目描述 小明决定从下周一开始努力刷题准备蓝桥杯竞赛。他计划周一至周五每天做 a a…

RocketMQ学习笔记三(面试题)

【RocketMQ面试题&#xff08;23道&#xff09;】-CSDN博客 ------------------------------------------------------------------------------------------------ 最好的学习资源在官网&#xff1a;初识RocketMQ | RocketMQ (apache.org) 以下内容来源于官网哦。 基本概念…

fs模块 文件写入 之 追加写入

文件的同步、异步追加写入&#xff1a; 一、异步追加 &#xff08;1&#xff09;语法&#xff1a;fs.appendFile(path,data,[options],callback(data,err)) &#xff08;2&#xff09;操作 1》引入fs模块 const fsrequire(fs); 2》调用appendFile fs.appendFile(./我可以…

大数据开发(HBase面试真题-卷一)

大数据开发&#xff08;HBase面试真题&#xff09; 1、请解释Hive和HBase之间的主要区别&#xff1f;2、描述一下Apache HBase与关系数据库之间有何区别&#xff1f;3、简要介绍HDFS和HBase&#xff0c;并描述它们适用的场景。4、HBase Column Family的概念是什么&#xff1f;5…

如何发现并防范“隐蔽式”CC攻击

网络安全是当今互联网时代不可忽视的重要议题。随着科技的发展&#xff0c;黑客渗透技术也日益复杂和潜在危险。德迅云安全为用户提供全方位的保护&#xff0c;确保用户信息安全 http&https是什么&#xff1f; HTTP&#xff08;Hypertext Transfer Protocol&#xff0c;超…

学python新手如何安装pycharm;python小白如何安装pycharm

首先找到官网&#xff1a; Download PyCharm: The Python IDE for data science and web development by JetBrains 打开后选择下载&#xff0c;下图标红部分 点击exe程序&#xff0c;点击下一步&#xff01; 选择安装路径&#xff0c;下一步 弹出界面全选 选择默认 然后直接…

前端面试练习24.3.13

1.请描述下对vue生命周期的理解 Vue 组件的生命周期是指组件从创建、挂载到销毁的整个过程中所经历的一系列钩子函数的调用顺序。 在vue3 中&#xff0c;我们使用了组合式的API&#xff0c;使用了setup语法糖&#xff0c;提供了更灵活的方式来组织组件的逻辑&#xff0c;不再依…

Java基于微信小程序的校园生活互助小助手

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

小米官网登录注册的滑动效果

小米官网登录注册的滑动效果 登录组成页面 <div class"client"><div class"userbox"><div class"title"><a href"javascript:;" class"active" id"DL">登录</a><a href&quo…

Android工具adb下载安装环境配置详细教程

Android工具adb的下载安装与环境配置详细教程如下&#xff1a; 一、下载ADB ADB通常作为Android SDK的一部分提供&#xff0c;因此&#xff0c;您可以从Android开发者网站下载Android Studio&#xff0c;并在安装时选择包括ADB。 另外&#xff0c;您也可以通过官方下载地址直…

使用tui-image-editor 图片编辑 标注图片

需求背景&#xff1a; 鼠标悬浮在图片上 出现编辑按钮 点击编辑 对该图片进行编辑&#xff08;输入文案、涂鸦、标记、裁剪等&#xff09; 可以体验一下它线上编辑器 Image-editor | TOAST UI :: Make Your Web Delicious! 使用 首先在你的前端项目中安装&#xff1a; np…

高概率文字生成Stable Cascade Comfyui极简安装教程

Stable Diffisuin 2.1之前的模型的痛点是不能生成文字&#xff0c;SDXL能生成文字&#xff0c;但正确率极低。Stable Diffusion 3据说能生成高画质图的同时&#xff0c;还能正确输出文字&#xff0c;但......还不能下载到。这中间stability.ai出了一个Stable Cascade模型。工作…

Spring MVC中常用注解

文章目录 Spring MVC 框架提供了一系列注解&#xff0c;用于简化开发者的编码工作&#xff0c;并提高代码的可读性和可维护性。以下是 Spring MVC 中常用的注解&#xff1a;Controller&#xff1a;RestController&#xff1a;RequestMapping&#xff1a;PathVariable&#xff1…

dp7——博弈

能帮到你的话&#xff0c;就给个赞吧 &#x1f618; 文章目录 博弈dp需要记录玩家的转换 下位01 486. 预测赢家⭐思想⭐相似题目464. 我能赢吗877. 石子游戏 博弈 dp需要记录玩家的转换 下位 01 486. 预测赢家⭐ 思想⭐ dp定义的是当前玩家 如dp[i] 代表A 则dp[i 1] 代表…

多模态大模型Claude 3正式接入集简云与语聚!对标GPT-4且支持中文

自OpenAI发布GPT-4以来&#xff0c;引发了业务模式与应用使用的巨大变革&#xff0c;掀起了各大企业对于多模态大模型的研究热潮。3月初&#xff0c;AnthropicClaude在官网正式发布Claude 3系列多模态大模型&#xff0c;据了解&#xff0c;该模型在多个维度上超越了GPT-4&#…

Open3D国内镜像源

pip install open3d -i https://mirrors.aliyun.com/pypi/simple/ 国内常用镜像源 清华大学 &#xff1a;https://pypi.tuna.tsinghua.edu.cn/simple/ 阿里云&#xff1a;https://mirrors.aliyun.com/pypi/simple/ 中国科学技术大学 &#xff1a;http://pypi.mirrors.ustc.edu.…