KE15Z Flash size:256KB
Flash Access Segment Size Register (FTFE_FACSS) read-only:
段的大小。
Flash Access Segment Number Register (FTFE_FACSN) read-only :
该寄存器提供了可用于XACC和SACC访问program flash 段的数量
XACCH3,XACCH2, XACCH1,XACCH0 这4个寄存器控制高32个段即 对于此单板flash memory: 0x20000 ~ 0x40000
XACCL3, XACCL2, XACCL1, XACCL0 这4个寄存器控制低32个段,即对于次单板flash memory:0x0 ~ 0x20000
并且每个寄存器的每一位控制一个段,若该位为1 则作为一般flash 使用,若为0 则保护.只能执行code;在没有执行flash program once command 命令之前 8个寄存器全为F;
由上图可知XACCL3 寄存器中的8位对应于第0 到 第7个段,设 XACCL3[0] 为 1,其他位为0, 则 第 0 个段可 存储数据 也可以执行code
XACCH3 寄存器中的8位对应于第32 到 第39个段,设 XACCH3[0] 为1,其他位为0, 则 第 32个段可 存储数据 也可以执行code
regestvalue1 = FTFx->FACSN;//0x40 => 64 segments totalsize 256KB
regestvalue2 = FTFx->FACSS;//0x04 => Segment Size:4KB totalsize 256KBXACC_value[0] = FTFx->XACCH3; //1 0x00020000 ~ 0x00021000 erase enable
XACC_value[1] = FTFx->XACCH2;//0
XACC_value[2] = FTFx->XACCL1;//0
XACC_value[3] = FTFx->XACCH0;//0XACC_value[4] = FTFx->XACCL3; //1 0x0000 ~ 0x1000 erase enable
XACC_value[5] = FTFx->XACCL2;//0
XACC_value[6] = FTFx->XACCL1;//0
XACC_value[7] = FTFx->XACCL0;//0
Program Once command
若想对 XACC 寄存器赋值 需要使用 Program Once 命令对 Program Once field 编程,Program Once field 存在于 Program flash 0 IFR map,在第二个图中XACC 寄存器的 索引值为 0x08;
uint8_t s_buffer[0] = 0x1 //对 XACCL3 寄存器bit 0 赋值1
FLASH_ProgramOnce(&s_flashDriver, 0x8, (uint8_t *)s_buffer, 8);