资料介绍
														1、摘要 
	Cortex-M内核实现了一个高效异常处理模块,可以捕获非法内存访问和数个程序错误条件。本应用笔记从程序员角度描述Cortex-M Fault异常,并且讲述在软件开发周期中的Fault用法。
	2、简介 
	Cortex-M3(以下简称CM3)和Cortex-M4(以下简称CM4)内核的Fault异常可以捕获非法内存方法和非法编程行为。Fault异常能够检测到以下情况:
	总线Fault:在取址、数据读/写、取中断向量、进入/退出中断时寄存器堆栈操作(入栈/出栈)时检测到内存访问错误。
	存储器管理Fault:检测到内存访问违反了MPU定义的区域。
	用法Fault:检测到未定义的指令异常,未对齐的多重加载/存储内存访问。如果使能相应控制位,还可以检测出除数为零以及其他未对齐的内存访问。
	硬Fault:如果上面的总线Fault、存储器管理Fault、用法Fault的处理程序不能被执行(例如禁能了总线Fault、存储器管理Fault、用法Fault异常或者在这些异常处理程序执行过程中又出现了Fault)则触发硬Fault。
	本应用笔记描述CM3和CM4的Fault异常用法。系统控制寄存器组中的寄存器可以控制Fault异常或者提供引发异常的原因信息。
	更深入的文档 
	完整的异常描述见《Cortex - M3 Technical Reference Manual》或者《Cortex -M4 Technical Reference Manual》,这两本参考手册都可以在中找到。
	另一个很好的参考书是由Joseph Yiu编写的《The Definitive Guide to the ARM Cortex-M3》 (这本书有中文版:宋岩译的《ARM Cortex-M3权威指南》)。
	3、Cortex-M Fault异常和寄存器 
	每个符合CMSIS规范的编译器所提供的启动文件(Startup_device)都会定义好设备所有的异常和中断向量。这些向量表定义了异常或中断处理程序的入口地址。下表给出了一个典型的向量表,Fault异常向量用蓝色标注。
	:
:
__Vectors DCD __initial_sp ; 栈顶
DCD Reset_Handler          ; 复位处理程序入口
DCD NMI_Handler            ; NMI 处理程序入口
DCD HardFaul t_Handler     ; 硬Fault处理程序入口
DCD MemManage_Handler      ; 存储器管理处理程序入口
DCD BusFault_Handler       ; 总线Fault 处理程序入口
DCD UsageFault_Handler     ; 用法 Fault 处理程序入口
DCD 0                      ; 保留
:
:
	通常总是使能硬Fault异常的,硬Fault异常具有固定的优先级,并且优先级高于其它Fault异常以及���断,但低于NMI。硬Fault异常处理程序在以下情况下会被执行:其它非硬Fault异常(非硬Fault异常是指总线、存储器管理和用法Fault 异常,下同。)被禁能,并且这些Fault异常被触发;在执行一个非硬Fault异常处理程序���又产生非硬Fault异常。
	所有非硬Fault具有可编程的优先级。当Cortex-M内核复位后,这些非硬Fault被禁能,你可以在应用软件中通过设置“系统Handler控制及状态寄存器(SHCSR)”来使能非硬Fault异常。这个寄存器属于系统控制模寄存器组(SCB)
	3.1 Fault异常的控制寄存器
	在这里有必要介绍一下系统控制模块寄存器组(SCB)的成员,这个寄存器组的定义可以在core_cm3.h文件中,该文件属于CMSIS Cortex-M3 内核外设接口抽象层的一部分(关于不清楚CMSIS的,可以自行查找资料)。定义如下:
	(1)定义系统控制寄存器组结构体
	/** @brief System Control Block (SCB) register structure definition */
typedef struct
{
__I uint32_t CPUID;   /*!
     __IO uint32_t ICSR;   /*!
    __IO uint32_t VTOR;   /*!
    __IO uint32_t AIRCR;  /*!
    __IO uint32_t SCR;    /*!
    __IO uint32_t CCR;    /*!
    __IO uint8_t SHP[12]; /*!
    __IO uint32_t SHCSR;  /*!
    __IO uint32_t CFSR;   /*!
    __IO uint32_t HFSR;   /*!
    __IO uint32_t DFSR;   /*!
    __IO uint32_t MMFAR;  /*!
    __IO uint32_t BFAR;   /*!
    __IO uint32_t AFSR;   /*!
    __I uint32_t PFR[2];  /*!
    __I uint32_t DFR;     /*!
    __I uint32_t ADR;     /*!
    __I uint32_t MMFR[4]; /*!
    __I uint32_t ISAR[5]; /*!
} SCB_Type;
	(2) 定义系统控制寄存器组物理空间基地址
	(3) 定义指向系统控制寄存器组的指针
	#define SCB ((SCB_Type *)SCB_BASE) /*!
	通过以上三步,我们就可以使用结构体指针SCB来访问系统控制寄存器组的寄存器了,比如给系统控制寄存器SCR赋值:SCB->SCR=0xFF;
	SCB->CCR寄存器控制除数为零和未对齐内存访问是否触发用法Fault。
	SCB->SHCSR寄存器可用来使能非硬Fault异常。如果一个非硬Fault异常被禁能并且相关Fault发生,这时异常会升级为硬Fault。SCB->SHP寄存器组控制异常的优先级。
	Fault异常控制寄存器列表:
	
		
			
				
					地址/访问
				
			
			
				
					寄存器
				
			
			
				
					复位值
				
			
			
				
					描述
												
												
												
												下载该资料的人也在下载
												下载该资料的人还在阅读
											
											更多 >
											
										- Cortex-M4和Cortex-M3内核的systick不进中断的软件延时
 - ARM Cortex-M4内核MCU
 - Cortex-M3 威廉希尔官方网站 参考手册 17次下载
 - Cortex-M3威廉希尔官方网站 参考手册下载 8次下载
 - Cortex-M3工作模式、异常与中断介绍资料下载
 - Cortex-M3与Cortex-M4对比资料下载
 - ARM cortex-M3 异常处理分析资料下载
 - Cortex-M3的异常和中断资料下载
 - 《ARM Cortex-M3权威指南》笔记资料下载
 - Cortex-M3(M0)汇编-启动代码分析资料下载
 - Cortex-M3 NVIC与中断控制资料下载
 - AN-1160: 基于Cortex-M3的ADuCxxx串行下载协议
 - Cortex-M3威廉希尔官方网站 参考手册免费下载 180次下载
 - Cortex-M4处理器教程之Cortex-M4培训课件免费下载 42次下载
 - 浅谈Cortex-M3和Cortex-M4在高性能信号处理中 0次下载
 
- 强大的Arm® Cortex®-M3内核(下) 670次阅读
 - STM32基础知识总结 673次阅读
 - Cortex-M3中断优先级的相关知识 2233次阅读
 - 美信cortex-m3内核芯片的启动过程及连接文件介绍 1319次阅读
 - 基于FPGA搭建ARM Cortex-M3 SoC软核 2335次阅读
 - 如何定制一颗ARM Cortex-M3 SoC软核 1975次阅读
 - 米尔科技ARM Cortex-M3教程指南 2628次阅读
 - 米尔科技Cortex-M Prototyping System +介绍 1661次阅读
 - 米尔科技NXP LPC1857 LPC1850 Cortex-M3开发板概述 4170次阅读
 - Cortex-M3处理器中断和FreeRTOS中断优先级配置 6920次阅读
 - 学习Cortex-M3时,我们必须要知道必要的缩略语 4342次阅读
 - STM32的Cortex-M3中断异常处理 7958次阅读
 - DesignStart Cortex-M3软件开发网上课程 5729次阅读
 - 为什么说Cortex-M是低功耗应用的首选 3409次阅读
 - ARM Cortex M3/M4微控制器最大效率设计三秘诀 3515次阅读
 
下载排行
本周
- 1TC358743XBG评估板参考手册
 - 1.36 MB | 330次下载 | 免费
 - 2开关电源基础知识
 - 5.73 MB | 6次下载 | 免费
 - 3100W短波放大电路图
 - 0.05 MB | 4次下载 | 3 积分
 - 4嵌入式linux-聊天程序设计
 - 0.60 MB | 3次下载 | 免费
 - 5基于FPGA的光纤通信系统的设计与实现
 - 0.61 MB | 2次下载 | 免费
 - 6基于FPGA的C8051F单片机开发板设计
 - 0.70 MB | 2次下载 | 免费
 - 751单片机窗帘控制器仿真程序
 - 1.93 MB | 2次下载 | 免费
 - 8基于51单片机的RGB调色灯程序仿真
 - 0.86 MB | 2次下载 | 免费
 
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
 - 0.00 MB | 234315次下载 | 免费
 - 2555集成电路应用800例(新编版)
 - 0.00 MB | 33564次下载 | 免费
 - 3接口电路图大全
 - 未知 | 30323次下载 | 免费
 - 4开关电源设计实例指南
 - 未知 | 21548次下载 | 免费
 - 5电气工程师手册免费下载(新编第二版pdf电子书)
 - 0.00 MB | 15349次下载 | 免费
 - 6数字电路基础pdf(下载)
 - 未知 | 13750次下载 | 免费
 - 7电子制作实例集锦 下载
 - 未知 | 8113次下载 | 免费
 - 8《LED驱动电路设计》 温德尔著
 - 0.00 MB | 6653次下载 | 免费
 
总榜
- 1matlab软件下载入口
 - 未知 | 935054次下载 | 免费
 - 2protel99se软件下载(可英文版转中文版)
 - 78.1 MB | 537796次下载 | 免费
 - 3MATLAB 7.1 下载 (含软件介绍)
 - 未知 | 420026次下载 | 免费
 - 4OrCAD10.5下载OrCAD10.5中文版软件
 - 0.00 MB | 234315次下载 | 免费
 - 5Altium DXP2002下载入口
 - 未知 | 233046次下载 | 免费
 - 6电路仿真软件multisim 10.0免费下载
 - 340992 | 191185次下载 | 免费
 - 7十天学会AVR单片机与C语言视频教程 下载
 - 158M | 183278次下载 | 免费
 - 8proe5.0野火版下载(中文版免费下载)
 - 未知 | 138040次下载 | 免费
 
	                电子发烧友App
	            
	        
	        
          
        
        
	                    
                        
                        
                        
                        
                        

创作
发文章
发帖  
提问  
发资料
发视频
上传资料赚积分
           
            
            
                
            
评论