衡阳派盒市场营销有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

【GD32H757Z海棠派開發板使用手冊】第四講 FMC-片內Flash擦寫讀實驗

聚沃科技 ? 2024-04-19 10:09 ? 次閱讀
wKgZomYgeJOAUiXJAB6mQrDJGEg027.png

4.1實驗內容

通過本實驗主要學習以下內容:

  • FMC控制器原理;
  • FMC擦寫讀操作;

4.2實驗原理

4.2.1FMC控制器原理

FMC即Flash控制器,其提供了片上Flash操作所需要的所有功能,在GD32H7XX系列MCU中,具有高達3840KB字節的片上閃存可用于存儲指令或數據。FMC也提供了扇區擦除和整片擦除操作以及編程操作。

Flash讀取可以支持64字節雙字、32位整字、16位半字或字節讀操作;Flash編程可以支持64位雙字、32位整字編程;Flash擦除支持扇區擦除和整片擦除操作。

Flash具有僅執行的專用代碼讀保護區域,便于芯片代碼保護以及二次合作開發。

FMC框圖如下所示,FMC支持用以訪問代碼或數據的64位AXI接口以及用以訪問寄存器的32位AHB從機接口。

wKgZomYh0M2ASXBaAABWBI1KHf8769.png

閃存包括3840KB字節主閃存,分為960個扇區,扇區大小為4KB,和64KB用于引導加載程序的信息塊。主存儲閃存的每個扇區都可以單獨擦除 。

wKgZomYh0NmADs3jAACHzfMnsTQ573.png

有關Flash擦寫操作均需要先解鎖Flash,然后進行擦寫操作,擦寫完成后再進行鎖Flash,注意Flash特性只能由1寫0,也就是Flash需要先擦除才能寫入新的數據,如果確保寫入地址的數據為全0xFF,也可以直接寫入。讀取Flash數據可以采取直接尋址的方式進行讀取。

下面為各位讀者介紹Flash擦寫讀的相關操作。

4.2.2Flash擦除操作原理

Flash擦除可分為塊擦除以及整片擦除,如下圖所示,扇區擦除時間典型值為100ms,整片擦除也根據容量大小會有差異。

wKgaomYh0PGAK-fYAAEQucyDXmc569.png

有關Flash的相關操作均在gd32h7xx_fmc.c中實現,下面介紹下擦除實現的函數,如下表所示。

wKgZomYh0P6AaAOHAABYIxnVQHU429.png

4.2.3Flash寫入編程操作原理

GD32H7系列MCU可支持64位雙字/32位整字編程,如下圖所示,Flash 32位整字編程時間典型值為1us。

wKgaomYh0PGAK-fYAAEQucyDXmc569.png

有關Flash編程實現函數如下表所示。

wKgaomYh0SuAdNZjAACGC3qGvsg217.png

4.2.4Flash讀取操作原理

Flash讀取可以采用直接尋址的方式進行操作,具體可參考以下示例代碼。

C
uint32_t read_data;
read_data = *(uint32_t *)0x08001000;

注意:有關Flash有以下參數讀者需要了解,GD32H7xx系列MCU的內部Flash具有至少10萬次的擦寫次數以及20年的數據保持能力,但需注意,隨著擦寫次數的增加數據保持時間會下降。

4.3硬件設計

本例程不涉及硬件電路。

4.4代碼解析

4.4.1Flash寫入多字節函數

Flash寫入多字節操作函數如下所示,寫入的過程主要分為擦寫兩個操作,由于Flash特有特性,需要先擦除才可以寫入,因而需要確保寫入地址的初識數據為0xFF。本函數可以實現根據地址識別對應頁并進行擦除的功能,使用上非常方便,使用者只需要關心擦寫的起始地址以及數據和長度即可,擦寫的位置函數中會進行實現。

C
void fmc_write_data(uint32_t write_start_addr, uint8_t *data_buf, uint16_t data_lengh)
{
uint32_t write_addr,erase_addr;
uint16_t data_write_num=0,data_lengh_word=data_lengh/4;
int32_t data_earse_num;
uint32_t* pbuff=(uint32_t*)data_buf;

if(data_lengh%4 !=0)
{
data_lengh_word++;
}


fmc_unlock(); /* 解鎖FMC */
/* 清除錯誤標志 */
fmc_flag_clear(FMC_FLAG_WPERR);
fmc_flag_clear(FMC_FLAG_PGSERR);
fmc_flag_clear(FMC_FLAG_RPERR);
fmc_flag_clear(FMC_FLAG_RSERR);
fmc_flag_clear(FMC_FLAG_ECCCOR);
fmc_flag_clear(FMC_FLAG_ECCDET);
fmc_flag_clear(FMC_FLAG_OBMERR);

erase_addr = write_start_addr;
data_earse_num = data_lengh;

if(write_start_addr%FLAG_PAGE_SIZE == 0) /* 若寫入地址為頁起始地址 */
{
for(;data_earse_num>0;)
{
fmc_sector_erase(erase_addr);
/* 清除錯誤標志 */
fmc_flag_clear(FMC_FLAG_WPERR);
fmc_flag_clear(FMC_FLAG_PGSERR);
fmc_flag_clear(FMC_FLAG_RPERR);
fmc_flag_clear(FMC_FLAG_RSERR);
fmc_flag_clear(FMC_FLAG_ECCCOR);
fmc_flag_clear(FMC_FLAG_ECCDET);
fmc_flag_clear(FMC_FLAG_OBMERR);
erase_addr+=FLAG_PAGE_SIZE;
data_earse_num-=FLAG_PAGE_SIZE;
}
}else{
/*若寫入地址不是頁起始地址*/
for(;(data_earse_num>0||erase_addr>=write_start_addr+data_lengh);)
{
fmc_sector_erase(erase_addr);
/* 清除錯誤標志 */
fmc_flag_clear(FMC_FLAG_WPERR);
fmc_flag_clear(FMC_FLAG_PGSERR);
fmc_flag_clear(FMC_FLAG_RPERR);
fmc_flag_clear(FMC_FLAG_RSERR);
fmc_flag_clear(FMC_FLAG_ECCCOR);
fmc_flag_clear(FMC_FLAG_ECCDET);
fmc_flag_clear(FMC_FLAG_OBMERR);
erase_addr+=FLAG_PAGE_SIZE;
data_earse_num-=FLAG_PAGE_SIZE;
}
}

/* 寫入數據 */
write_addr = write_start_addr;

for(data_write_num = 0; data_write_num{
fmc_word_program(write_addr, pbuff[data_write_num]);
/* 清除錯誤標志 */
fmc_flag_clear(FMC_FLAG_WPERR);
fmc_flag_clear(FMC_FLAG_PGSERR);
fmc_flag_clear(FMC_FLAG_RPERR);
fmc_flag_clear(FMC_FLAG_RSERR);
fmc_flag_clear(FMC_FLAG_ECCCOR);
fmc_flag_clear(FMC_FLAG_ECCDET);
fmc_flag_clear(FMC_FLAG_OBMERR);

write_addr+=4;
}
fmc_lock();
}

4.4.2Flash讀取數據函數

Flash讀取數據函數如下所示,采用直接尋址的方式,讀取字節數據。

C
uint8_t fmc_read_data(uint32_t write_read_addr)
{
return *(uint8_t *)write_read_addr;
}

4.4.3主函數

主函數如下所示,通過該函數實現對flash起始地址為0x080A0000的前10個字節擦寫以及讀取的驗證。

C
int main(void)
{
uint16_t read_num =0;
uint8_t i_num;
driver_init();
bsp_led_group_init();
bsp_uart_init(&BOARD_UART); /* 板載UART初始化 */
printf_log("Example of internal Flash read-write demo.\r\n");
printf_log("Write data to internal Flash.\r\n");
fmc_write_data(WRITE_START_ADDR,write_data,sizeof(write_data)); /* 向WRITE_START_ADDR地址寫入10個雙字節數據 */
printf_log("Read data from internal Flash.\r\n");
for(read_num=0;read_num{
read_data[read_num] = fmc_read_data(WRITE_START_ADDR+read_num); /* 從WRITE_START_ADDR讀取10個雙字節數據 */
}
printf_log("Verify the written and read data.\r\n");
for(i_num=0;i_num{
/* 校驗數據 */
if(read_data[i_num]!=write_data[i_num])
{
/* 校驗數據出錯 */
printf_log("Error in verifying data.\r\n");
printf_log("Turn on LED1.\r\n");
bsp_led_on(&LED1);
while(1);
}else{
}
}
/* 校驗數據成功 */
printf_log("Turn on LED1.\r\n");
bsp_led_on(&LED1);
printf_log("Verify that the data is correct and that the written and read data are consistent.\r\n");

while (1)
{
}
}

4.5實驗結果

將本實驗燒錄到海棠派實驗板中,運行后可以觀察到LED1常亮,表明擦寫以及讀取實驗正常。

教程由GD32 MCU方案商聚沃科技原創發布,了解更多GD32 MCU教程,關注聚沃科技官網

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FlaSh
    +關注

    關注

    10

    文章

    1642

    瀏覽量

    148657
  • FMC
    FMC
    +關注

    關注

    0

    文章

    96

    瀏覽量

    19758
  • 開發板
    +關注

    關注

    25

    文章

    5121

    瀏覽量

    98187
  • GD32
    +關注

    關注

    7

    文章

    413

    瀏覽量

    24467
收藏 人收藏

    評論

    相關推薦

    GD32H757Z海棠開發板使用手冊】第十三講 SDIO-SD卡讀寫實驗

    通過本實驗主要學習以下內容: ?USB協議基本原理 ?GD32H7xx USBHS的使用 ?虛擬鍵盤的協議原理及使用
    的頭像 發表于 06-06 11:26 ?2139次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第十三講 SDIO-SD卡讀寫<b class='flag-5'>實驗</b>

    迅為iMX6ULL開發板使用手冊資料下載

    開發板使用手冊》第一部分 開發板入門第二部分 開發環境搭建第三部分 Linux系統編譯第四部分 QT
    發表于 12-02 14:13

    YL-51開發板使用手冊

    YL-51開發板使用手冊,YL-51開發板使用手冊YL-51開發板使用手冊YL-51
    發表于 05-10 16:31 ?21次下載

    51開發板使用手冊

    51開發板使用手冊,感興趣的小伙伴們可以瞧一瞧。
    發表于 11-23 15:45 ?11次下載

    KC705開發板英文使用手冊

    KC705開發板英文使用手冊
    發表于 11-01 10:19 ?5次下載

    iTOP-3399開發板使用手冊大更新

    iTOP-3399開發板使用手冊大更新
    的頭像 發表于 12-10 15:46 ?1421次閱讀
    iTOP-3399<b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>大更新

    GD32H757Z海棠開發板使用手冊】第二 GPIO-按鍵查詢檢測實驗

    2.1實驗內容通過本實驗主要學習以下內容:GPIO輸入功能原理;按鍵查詢輸入檢測原理;2.2實驗原理2.2.1GPIO輸入功能原理GD32H7XX系列MCUGPIO輸入配置結構如下圖所
    的頭像 發表于 04-17 10:42 ?831次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第二<b class='flag-5'>講</b> GPIO-按鍵查詢檢測<b class='flag-5'>實驗</b>

    GD32H757Z海棠開發板使用手冊】第五 PMU-低功耗實驗

    PMU即電源管理單元,其內部結構下圖所示,由該圖可知,GD32H7XX系列MCU具有三個電源域,包括VDD/VDDA電源域、0.9V電源域以及電池備份域,其中,VDD /VDDA域由電源直接供電
    的頭像 發表于 04-20 09:32 ?1185次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第五<b class='flag-5'>講</b> PMU-低功耗<b class='flag-5'>實驗</b>

    GD32F470紫藤開發板使用手冊第四講 FMC-Flash擦寫實驗

    通過本實驗主要學習以下內容: FMC控制器原理; FMC擦寫操作;
    的頭像 發表于 05-06 11:08 ?1389次閱讀
    【<b class='flag-5'>GD</b>32F470紫藤<b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】<b class='flag-5'>第四講</b>  <b class='flag-5'>FMC-</b><b class='flag-5'>片</b><b class='flag-5'>內</b><b class='flag-5'>Flash</b><b class='flag-5'>擦寫</b><b class='flag-5'>讀</b><b class='flag-5'>實驗</b>

    GD32H757Z海棠開發板使用手冊】第八 ADC-規則組多通道采樣實驗

    通過本實驗主要學習以下內容: ADC的簡介 GD32FH757 ADC工作原理 DMA和DMAMUX的原理 規則組多通道循環采樣
    的頭像 發表于 05-14 09:39 ?749次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第八<b class='flag-5'>講</b> ADC-規則組多通道采樣<b class='flag-5'>實驗</b>

    GD32H757Z海棠開發板使用手冊】第九 USART-printf打印實驗

    通過本實驗主要學習以下內容: ?串口簡介 ?GD32H757串口工作原理 ?使用printf打印信息
    的頭像 發表于 05-15 11:39 ?840次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第九<b class='flag-5'>講</b> USART-printf打印<b class='flag-5'>實驗</b>

    GD32F303紅楓開發板使用手冊】第五 FMC-Flash擦寫實驗

    MC即Flash控制器,其提供了Flash操作所需要的所有功能,在GD32F303系列MCU中,Flash前256K字節空間內,?CPU
    的頭像 發表于 06-02 10:05 ?870次閱讀
    【<b class='flag-5'>GD</b>32F303紅楓<b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第五<b class='flag-5'>講</b> <b class='flag-5'>FMC-</b><b class='flag-5'>片</b><b class='flag-5'>內</b><b class='flag-5'>Flash</b><b class='flag-5'>擦寫</b><b class='flag-5'>讀</b><b class='flag-5'>實驗</b>

    GD32H757Z海棠開發板使用手冊】第十一講 SPI-SPI NOR FLASH讀寫實驗

    通過本實驗主要學習以下內容: ?SPI簡介 ?GD32H7 SPI簡介 ?SPI NOR FLASH——GD25Q128ESIGR簡介 ?使用GD3
    的頭像 發表于 06-04 11:42 ?1192次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第十一講 SPI-SPI NOR <b class='flag-5'>FLASH</b>讀寫<b class='flag-5'>實驗</b>

    GD32H757Z海棠開發板使用手冊】第十二 SDIO-SD卡讀寫實驗

    SD卡是一種主要以Nand Flash作為存儲介質,具有體積小、數據傳輸速度快以及支持熱插拔的優點。如今,已被廣泛應用于數碼相機、便攜式移動設備以及手機等多種設備中。SD卡的驅動一般有SPI接口或SDIO接口,本例程介紹使用GD32F4xx的SDIO接口驅動SD卡的實現。
    的頭像 發表于 06-05 10:35 ?835次閱讀
    【<b class='flag-5'>GD32H757Z</b><b class='flag-5'>海棠</b><b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第十二<b class='flag-5'>講</b> SDIO-SD卡讀寫<b class='flag-5'>實驗</b>

    GD32F303紅楓開發板使用手冊】第二十 SPI-SPI NAND FLASH讀寫實驗

    通過本實驗主要學習以下內容: ?SPI通信協議,參考19.2.1東方紅開發板使用手冊 ?GD32F303 SPI操作方式,參考19.2.2東方紅
    的頭像 發表于 06-20 09:50 ?1068次閱讀
    【<b class='flag-5'>GD</b>32F303紅楓<b class='flag-5'>派</b><b class='flag-5'>開發板</b><b class='flag-5'>使用手冊</b>】第二十<b class='flag-5'>講</b> SPI-SPI NAND <b class='flag-5'>FLASH</b>讀寫<b class='flag-5'>實驗</b>
    网上的百家乐官网是假的吗| 大上海百家乐官网娱乐城| 百家乐筹码真伪| 赣州市| 网络百家乐的陷阱| 金沙足球投注网| 真人百家乐现金游戏| 蒙特卡罗娱乐网| 百家乐是不是有假| 百家乐官网网络娱乐场开户注册| 卓达太阳城希望之洲| 百家乐官网变牌器| 大发888棋牌| 三元风水24山水法| 壹贰博网址| 噢门百家乐玩法| 百家乐官网几点开奖| 百家乐真人玩下载| 百家乐官网记牌器| 机器百家乐软件| 百家乐官网珠仔路| 大发888 34| 网上百家乐追杀| 皇冠网投| 百家乐赌博代理合作| 百家乐官网投注平台导航网| 免费百家乐预测工具| 逍遥坊百家乐官网的玩法技巧和规则| 棋牌娱乐网,| 百家乐那个平台好| 保单机百家乐官网破解方法| 大发888资讯网007| 百家乐破解视频| 永利高百家乐官网开户| 亚洲百家乐官网论坛| 大发888线上娱乐加盟合作| 百家乐路纸计算| 利高百家乐官网游戏| 百家乐平注法到| 做生意选店铺位置| 百家乐官网娱乐城提款|