GPIO

习惯了stm32的GPIO,发现高端处理器arm在这方面反而简单了。

ARM9控制GPIO只有三种寄存器。

GPxCON:配置引脚功能,GPACON用一位控制一个GPIO,分别是0为输出引脚,1为输入引脚。GPBCON---GPH/JCON 则用两位控制一个引脚,分别是00表示输入,01表示输出,10表示特殊功能。

GPxDAT:当此引脚被设置为输入时,读此引脚可知相应引脚的电平状态是高还是低。当次引脚被设置为输出时,写此引脚可令此引脚输出高电平或者低电平。

GPxUP:某位为1时,相应引脚无内部上拉电阻,某位为0时,相应引脚使用内部上拉电阻。

相比于stm32的八种输入输出模式,7个寄存器,还不算配置复用的寄存器…..果然…..没有库函数的stm32可怎么活啊。

中断

先说一下irq和fiq的区别:

1) fiq拥有更多的bank的寄存器,irq则没有,这意味着irq要用更多的时间去保存现场。

2) fiq的优先级高于irq,所以fiq可以打断irq,但是irq不能打断fiq。

3) 只能有一个中断被设置为irq。

当发生一个中断的时候,arm9核会自动完成如下的事情(arm9工作):

1) 在异常工作模式的连接寄存器R14中保存前一个工作模式的下一条。

2) 将cpsr的值复制到异常模式的spsr。

3) 将cpsr的工作模式设为这个异常对应的工作模式。

4) 令pc等于这个异常在异常向量表的地址。

中断处理(程序员工作):

1) cpu响应了中断之后,需要保存当前的运行环境(各个寄存器),然后调用中断服务程序(ISR)。

2) 在ISR中读取中断控制器,外设的相关寄存器来判断这是哪一个中断。

3) 清除中断。

4) 最后回复中断程序的运行环境(就是上面保存的各个寄存器),

从异常工作模式退出返回之前的工作模式,需要软件完成下列事情(程序员工作):

1) 前面进入异常模式时候,连接寄存器保存了前一个工作模式的下一条指令地址,将它减去一个适当的值后赋给pc。

2) 将spsr的值赋值回cpsr。

Arm9外部中断:

Arm9的清爽向量表如下,如下,每种异常对应一种运行模式,地址零处为Reset向量:

Arm9有60个中断源,其中一级中断有23个。比如EIN4_7属于一级中断源,但是该中断源包含EIN4\EIN5\EIN6\EIN7四个子中断源。

下图是外部中断,包含了中断号,中断引脚,外部中断挂起寄存器,中断屏蔽寄存器,源挂起寄存器。

上面主要说的是外部中断的寄存器,下面确切说一下各个寄存器:

SUBSRCOND寄存器:用来标示中断,主要是处理内部中断,如INT_RXD0,INT_TXD0。

INTSUBMSK寄存器:用来屏蔽SUBSRCOND中所标示的中断。某位被标示为1时,表示该中断被屏蔽。

SRCPND寄存器:用来标示中断,包括内部中断和外部中断。

INTMASK寄存器:用来屏蔽SRCPND中的中断。

INTMOD寄存器:设置FIQ。

PRIORITY寄存器:设置7个仲裁器的仲裁规则,以达到设置中断优先级的目的。

INTPND寄存器:经过中断优先级仲裁器选出优先级最高的中断,这个中断在INTPND寄存器中相应的位被置1,随后cpu进入中断模式处理它。

INTOFFSET寄存器:这个寄存器用来查看INTPND寄存器中哪一位被置一。

补:EINTMASK寄存器:用来屏蔽外部中断。

arm9的中断的更多相关文章

  1. ARM9的中断控制器

    简要复习一下ARM9中断控制器的控制过程: 1.首先能识别触发的中断(对应中断源必须打开,然后查询当前中断状态寄存器),硬件会操控PC跳到中断向量入口(IRQ_HANDLE,硬件控制的只要是IRQ中断 ...

  2. uboot中添加FIQ中断及相关问题

    本文主要说明了在uboot中添加FIQ中断时遇到的问题以及对应的解决办法. 首先交代一下项目的软硬件环境.硬件方面,使用s3c2440作为主控芯片,外接串口.网卡等设备.软件方面,主控芯片上电后运行u ...

  3. linux中断的上半部和下半部 【转】

    转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=24690947&id=3491821 一.什么是下半部 中断是一 ...

  4. ARM中断深入分析几点

    ARM中断深入分析几点 1.程序发生中断后,是如何跳转到中断程序里面的? 2.执行完中断后,如何返回到原来被打断的地方接着执行呢? 3.ARM处理器的流水线结构对中断返回地址的计算有什么影响? 4.A ...

  5. arm9的时钟和定时器

    时钟 两种能够提供时钟的方式: 1) 晶振 2) PLL(也就是锁相环):通用PLL需啊一个晶振,和对晶体特定频率分频或倍频的锁相环电路. 学习ARM9时钟的四步: 1) 晶振:12MHZ 2) 有多 ...

  6. 【ARM-Linux开发】ARM7 ARM9 ARM Cortex M3 M4 有什么区别

    ARM7 ARM9 ARM Cortex M3 M4 区别 arm7 arm9 可以类比386和奔腾, 不同代,arm9相比arm7指令集和性能都有所增强,arm7和arm9都有带mmu和无mmu的版 ...

  7. 【Linux开发】linux设备驱动归纳总结(六):3.中断的上半部和下半部——工作队列

    linux设备驱动归纳总结(六):3.中断的上半部和下半部--工作队列 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ...

  8. angular2系列教程(九)Jsonp、URLSearchParams、中断选择数据流

    大家好,今天我们要讲的是http模块的第二部分,主要学习ng2中Jsonp.URLSearchParams.observable中断选择数据流的用法. 例子

  9. myrocks复制中断问题排查

    背景 mysql可以支持多种不同的存储引擎,innodb由于其高效的读写性能,并且支持事务特性,使得它成为mysql存储引擎的代名词,使用非常广泛.随着SSD逐渐普及,硬件存储成本越来越高,面向写优化 ...

随机推荐

  1. Netty对WebSocket的支持

    WebSocket长连接 一.创建服务端代码 1.MyServer 类 public class MyServer { public static void main(String[] args) t ...

  2. nodejs爬虫如何设置动态ip以及userAgent

    nodejs爬虫如何设置动态ip以及userAgent 转https://blog.csdn.net/u014374031/article/details/78833765 前言 在写nodejs爬虫 ...

  3. matlab学习笔记8 基本绘图命令-LineSpec线条设定

    一起来学matlab-matlab学习笔记8 基本绘图命令_4 LineSpec线条设定 觉得有用的话,欢迎一起讨论相互学习~Follow Me 绘图函数接受线条设定作为参数并相应地修改生成的图形.您 ...

  4. [Algorithm] Graph

    图的概念有点多,在此只讨论最基础的内容,所以选择比较薄的高教版<数据结构>. 1.4 非线性数据结构--图 ........................................ ...

  5. css选择器测试2-用ul和li简单排版

    之前的博文:测试了一些css样式的优先级,都是比较常见的选择器 ,这里测试一些其他一些选择方式. *:通配符,所有页面的元素都走这个.设置多个class:一个标签里不能有两个class,如果想要设置多 ...

  6. Python: ImportRequestsError: No module named 'requests'解决方法

    运行Python程序时,出现下面错误: import requests  ModuleNotFoundError: No module named ‘requests’ 原因:没有导入requests ...

  7. [JAVA] maven 阿里云节点 settings.xml

    <?xml version="1.0" encoding="UTF-8"?> <settings xmlns="http://mav ...

  8. Qt信号-槽原理剖析--(2)自己实现信号槽

    时间乃是最大的革新家--培根 先了解一下相关宏: qt为c++增加的相关宏:signals, slots,emit 在qt的预编译过程中,这些宏会被替换. 1)#define signals publ ...

  9. [转帖]helm模板文件chart编写语法详解

    helm模板文件chart编写语法详解 https://blog.51cto.com/qujunorz/2421328 需要学习一下. charts编写介绍 开始 快速创建一个chart模板,helm ...

  10. 【C++札记】友元

    C++封装的类增加了对类中数据成员的访问限制,从而保证了安全性.如想访问类中的私有成员需要通过类中提供的公共接口来访问,这样间接的访问方式,无疑使得程序的运行效率有所降低. 友元的提出可以使得类外的函 ...