0.概述
7801暂时无错误注入,无法直接进中断看错误情况,具体效果后续看7840的带错误注入的测试情况。
1.简介
data:image/s3,"s3://crabby-images/635fe/635fe5eccf5f2627879fa351b52a76c31e29db37" alt=""
2.特性
data:image/s3,"s3://crabby-images/b86c7/b86c775924734cae39376931273f5172e9241d81" alt=""
3.功能
data:image/s3,"s3://crabby-images/87b40/87b40b5f3470db03ae0d33fef628f3b7d4b161e2" alt=""
4.调试
可以看到在库文件里面有ecc_sram的库。
data:image/s3,"s3://crabby-images/a3c9f/a3c9f67e1073b1ad8529f9d140418eb4f7612947" alt=""
在官方GPIO代码里面写了点测试代码
data:image/s3,"s3://crabby-images/8956d/8956d636269fa82a6e4fea7ed275257322cd0c62" alt=""
成功打开2bit中断
data:image/s3,"s3://crabby-images/ffc85/ffc85ff5ad209d623e1c3d547e11e2993d68f3fb" alt=""
因为没有错误注入,没法直接测试,回头瞅瞅7840加了错误注入的测试结果
调试看到状态值始终为0。回头找个有问题的芯片测下能不能近中断。
data:image/s3,"s3://crabby-images/26ad4/26ad4372d34a673dd2b6d09c7b677ee57b8938d6" alt=""
cpp
#include "ac780x_ecc_sram_reg.h"
#include "ac780x_ecc_sram.h"
ECC_SRAM_ConfigType g_eccSranCfg;
void ECC_SRAM_CallBack()
{
// 0: no error, 1: 2 bit error, 2/3: 1 bit error
unsigned int eccSramStatus = ECC_SRAM_GetErrStatus();
if (1 == eccSramStatus)
{
unsigned int ErrAddr1bit = ECC_SRAM_Get1BitErrAddr();
}
if (2 == eccSramStatus)
{
unsigned int ErrAddr2bit = ECC_SRAM_Get2BitErrAddr();
}
}
void Ecc_SramInit()
{
g_eccSranCfg.interruptEn = 1;
g_eccSranCfg.resetEn = 1;
g_eccSranCfg.callBack = ECC_SRAM_CallBack;
ECC_SRAM_Init(&g_eccSranCfg);
}