关于MPU的笔记

MPU(memory protection unit)内存保护单元。这些系统必须提供一种机制来保证正在运行的任务不破坏其他任务的操作。即要防止系统资源和其他一些任务不受非法访问。嵌入式系统有专门的硬件来检测和限制系统资源的访问。它能保证资源的所有权,任务需要遵守一组由操作环境定义的、由硬件维护的规则,在硬件级上授予监视和控制资源程序的特殊权限。受保护系统主动防止一个任务使用其他任务的资源。因此使用硬件主动监视系统比协调加强的软件历程,提供了更好的保护。

MPU的主要作用如下:

1、设置不同存储区域的存储器访问权限(管理员级、用户级);

2、设置存储器内存和外设属性(可缓存、可缓冲、可共享)。

MPU的优点如下:

1、阻止用户应用程序破坏操作系统使用的数据;

2、阻止一个任务访问其他任务的数据区,从而隔离任务;

3、把关键数据区域设置为只读,从根本上解决被破坏的可能;

4、检测意外的存储访问,如堆栈溢出、数组越界等;

5、将SRAM或RAM空间定义为不可执行,防止代码攻击,提高嵌入式的安全性,使系统更安全。

--------------------------------------------------------------------------------

MPU可配置8/16个内存区域,每个区域最小要求为256字节,每个区域还可以配置8个子区域(但需要大小一致)。在保护的16个内存空间内,有可能会出现保护区域的重叠或嵌套,优先级从0~15越来越大。下图为MPU内存地址映射的区域。

--------------------------------------------------------------------------------

对于配置好的MPU,我们不可以访问定义外的地址空间,

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值