目标:只允许“高级函数”访问OTP中的数据,其它应用程序不能直接读取OTP内容
例程@ F413-Nuclo,F401-Nucleo
• 需要解决的问题和达到的目标• 用户需要将一部分数据写入NVM,一次性希望写入后该部分数据不能再被修改
• 该端数据只能被部分关键代码访问,其他的应用数据无法直接读取该段数据的内容
• 目标环境
• 应用程序使用的MCU为STM32F4
• 分析(以F413为例)
• F413带有528字节的OTP,可以满足数据一次性写入之后无法被修改的需求
• 为了实现只允许部分代码访问OTP的要求,需要将代码分区,并设置不同的访问权限
• F413带有MPU功能,通过合理配置MPU和不同代码的运行级别,可以实现访问控制
• 首先可以将代码区分为运行于特权级别的代码(关键函数),和运行于用户级别的代码(普通应用)
• 设置不同的MPU region及其访问权限,使得OTP所在的region只能被运行在特权级别的代码读取
|