RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault的原因
来源:互联网 发布:java字符文件乱码 编辑:程序博客网 时间:2024/05/16 23:53
【译】RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault的原因
转至 http://hi.baidu.com/chinleo/item/f959194767b3fbd0c0a5924d
RL-RTX默认使能非特权模式,非特权模式下RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault。
http://www.keil.com/support/man/docs/rlarm/rlarm_ar_cfgrunpriv.htm
- ·非特权模式——受保护的模式
- ·特权模式——不受保护的模式
在特权模式,用户可以访问和配置系统寄存器和控制寄存器如NVIC中断控制器等。在非特权模式下,这些操作是不允许的。在非特权模式下访问NVIC寄存器将导致硬件错误(Hard Fault)。
宏OS_RUNPRIV使能所有任务在特权模式下运行。置1使能特权模式,置0禁止特权模式。该宏默认是禁止的。
对于旧的项目,你可以使能特权模式。在更新新的Cortex-M RTX内核库、替换RTX_Config.c配置文件的情况下,现存的代码将无需任何更改就可以运行。在特权模式下,任务是不受保护的,你可以在任何任务中配置系统,比如配置中断。
特权模式是默认禁止的。这使得所有任务运行在保护模式下。任务不允许更改系统配置、更改中断等。用户有两个选项:
- ·在任务中以特权模式如_SVC函数方式运行配置代码。
- ·在系统内核尚未启动时,即设备仍运行在特权模式时,运行配置代码。
注意:
·ARM7/ARM9的RTX内核库不支持此选项,因为上下文切换方式不同
- 【译】RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault的原因
- RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault的原因
- RL-RTX os_dly_wait()延时不准的问题
- RL-RTX SVC 函数: unprivileged模式下运行的任务如何修改要求privileged权限的寄存器
- android不能进入睡眠的原因
- STM32 的优先级NVIC配置
- STM32的内核CM3没有理解,NVIC,EXTI都涉及到了,内核到目前为止没有理解
- ARM(CM3)的汇编指令
- ARM(CM3)的汇编指令
- CM3 NVIC与中断控制
- 正式进军RL-RTX
- rtx任务间的通信--event flags
- WCDMA中RL失步是如何定义的?
- 关于STM32 NVIC配置的解释
- RL-RTX小读之os_sys_init(init)(一)
- STM32中NVIC的个人理解(转)
- CM3 STM32F的低功耗
- 进入csdn的原因
- 如何学习C#
- soj 1777. Mix order traversal
- QT 信号机制
- 2012年年末_换了家公司_呆了半个月_毅然离职
- 配置eyeOS系统--3--安装mysql数据库和Apache服务器
- RL-RTX(CM3)的任务中不能配置NVIC,否则进入HardFault的原因
- Evolution3D引擎成果截图
- 我的2012 — 毕业半年,金融5个月
- C++编程调试秘笈----读书笔记(1)
- C++编程调试秘笈----读书笔记(2)
- 用旅行商算法制作艺术图像
- Python学习笔记
- osganimationeasemotion例子
- Fedora 17无法用root账户登录解决方法