启动文件Startup_vle.c

步骤1:初始化核心的通用寄存器

步骤2:初始化IVPR(异常向量表基址)和MSR寄存器以启用机器检查和异常(IVORx)

步骤3:初始化堆栈指针(r1)

步骤4:启动代码应确保MCU内部看门狗不会被服务,直到看门狗从MCAL看门狗驱动程序初始化。这可以通过增加看门狗服务时间来实现

Step5:设置AIPS_A/B母线桥及其保护功能:

(1) AIPS_MPRA(主特权寄存器A)

定义每个总线主节点的访问权限级别(8个主节点)

"111"[默认值:参照芯片配置]-

信任为读;

信任为写;

从这个主服务器访问不强制进入用户模式;

(2) AIPS_PACRn(外围访问控制寄存器A-H)

定义每个On-Platform外设支持的访问级别

"000"[默认:参照芯片配置]-

这个外设不需要管理员权限级别的访问;(OS)

这个外设允许写访问;

允许来自不受信任的主机的访问;

(3) AIPS_OPACRn(离台外围访问控制寄存器A-Z, AA-AF)

定义每个非平台外设支持的访问级别

"000"[默认:参照芯片配置]-

这个外设不需要管理员权限级别的访问;(OS)

这个外设允许写访问;

允许来自不受信任的主机的访问;

Step6:使能BTB

Step7:

初始化内部RAM,避免出现ECC错误

Step8:

Erase ".sbss" & ".bss" & ".bss_no_cacheable"

Step9:

将初始化的数据从Flash复制到SRAM

.PPC.EMB。Sdata0 & .sdata & .data & .data_no_cacheable & .ramcode

Step10:定义全局变量指针

Step11:Enable D_CACHE & I_CACHE

Step12:

配置INTC为硬件矢量模式

Step13:

Jump to main()

相关推荐
XLYcmy2 分钟前
高级密码生成器程序详解:专门设计用于生成基于用户个人信息的密码猜测组合
开发语言·数据结构·python·网络安全·数据安全·源代码·口令安全
独自破碎E10 分钟前
Leetcode862和至少为K的最短子数组
java·开发语言
qq_3707730913 分钟前
x64dbg 脚本常用命令
开发语言·x64dbg
军军君0124 分钟前
Three.js基础功能学习五:雾与渲染目标
开发语言·前端·javascript·学习·3d·前端框架·three
charlie11451419130 分钟前
FreeRTOS:软件定时器(Software Timers)与时间管理
开发语言·笔记·学习·freertos·实时操作系统·工程
washingtin38 分钟前
Get “https://registry-1.docker.io/v2/“: context deadline exceeded
java·开发语言
only-lucky44 分钟前
Python版本OpenCV
开发语言·python·opencv
三万棵雪松1 小时前
【python-基础】
开发语言·python
一路往蓝-Anbo1 小时前
C语言从句柄到对象 (七) —— 给对象加把锁:RTOS 环境下的并发安全
java·c语言·开发语言·stm32·单片机·嵌入式硬件·算法
先做个垃圾出来………1 小时前
2610.转换二维数组
开发语言·python