28377D芯片CLA模块调试记录(1)

如果是在flash状态下需要通过代码从flash复制到ram
#ifdef _FLASH
memcpy((uint32_t *)&Cla1funcsRunStart, (uint32_t *)&Cla1funcsLoadStart,(uint32_t)&Cla1funcsLoadSize);
#endif //_FLASH
这些变量决定了存储空间分配状态,具体调整在.cmd文件中

初始化并等待CLA1ToCPUMsgRAM
MemCfgRegs.MSGxINIT.bit.INIT_CLA1TOCPU = 1;
while(MemCfgRegs.MSGxINITDONE.bit.INITDONE_CLA1TOCPU != 1){};
初始化并等待CPUToCLA1MsgRAM
MemCfgRegs.MSGxINIT.bit.INIT_CPUTOCLA1 = 1;
while(MemCfgRegs.MSGxINITDONE.bit.INITDONE_CPUTOCLA1 != 1){};
CLA1ToCPUMsgRAM是CLA到CPU的存储区域,这个区域CLA可读可写,CPU只读
CPUToCLA1MsgRAM是CPU到CLA的存储区域,这个区域CPU可读可写,CLA只读
具体资料来自芯片数据表的6.3章节

MemCfgRegs.LSxMSEL.bit.MSEL_LS0 = 1;
这类寄存器是选择将LS存储器的存储类型,选0是分配给CPU,选1是CPU和CLA共用。
MemCfgRegs.LSxCLAPGM.bit.CLAPGM_LS0 = 0;
这类寄存器是选择将存储空间分配给CLA后的实际用途的,选0将用作CLA数据空间,选1将用作CLA程序空间
存储空间地址资料来自于芯片数据表6.3章节

上述几项配置要经过EALLOW;与EDIS;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值