在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

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

3天內不再提示

瑞薩e2studio----Code Flash/Data Flash讀寫

RA生態工作室 ? 2021-11-26 17:17 ? 次閱讀
pYYBAGGA3i6Af0z4AABdWrtWoBM374.png

1.概述

本篇文章主要介紹如何使用e2studio對瑞薩進行Flash配置,并且分別對Code Flash & Data Flash進行讀寫操作。

Flash有Code Flash(儲存程序代碼)以及Data Flash(儲存一般數據),其中Code Flash主要以NOR型為主,儲存系統程序代碼及小量數據;而Data Flash則是以NAND型為主,用于儲存大量數據。

2.硬件準備

首先需要準備一個開發板,這里我準備的是芯片型號 R7FA2L1AB2DFL 的開發板。

3.新建工程

4954818c-4c51-11ec-9483-dac502259ad0.png

4.工程模板

4996dda2-4c51-11ec-9483-dac502259ad0.png

5.保存工程路徑

49c3d00a-4c51-11ec-9483-dac502259ad0.png

6.芯片配置

本文中使用R7FA2L1AB2DFL來進行演示。

4a023700-4c51-11ec-9483-dac502259ad0.png

7

7.工程模板選擇

4a151992-4c51-11ec-9483-dac502259ad0.png

8.Flash配置

點擊 Stacks -> New Stack -> Driver -> Storage -> Flash Driver on r_flash_lp。

4a4bd040-4c51-11ec-9483-dac502259ad0.png

9.Flash屬性配置

4a7f1af4-4c51-11ec-9483-dac502259ad0.png

10.設置E2STUDIO堆棧

4ac101bc-4c51-11ec-9483-dac502259ad0.png

11.e2studio的重定向printf設置

4ad24f8a-4c51-11ec-9483-dac502259ad0.png

C++ 構建->設置->GNU ARM Cross C Linker->Miscellaneous去掉Other linker flags中的 “--specs=rdimon.specs”

4afac30c-4c51-11ec-9483-dac502259ad0.png

12.printf輸出重定向到串口

打印最常用的方法是printf,所以要解決的問題是將printf的輸出重定向到串口,然后通過串口將數據發送出去。

注意一定要加上頭文件#include


#ifdef __GNUC__                                 //串口重定向
    #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
    #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif

PUTCHAR_PROTOTYPE
{
        err = R_SCI_UART_Write(&g_uart0_ctrl, (uint8_t *)&ch, 1);
        if(FSP_SUCCESS != err) __BKPT();
        while(uart_send_complete_flag == false){}
        uart_send_complete_flag = false;
        return ch;
}

int _write(int fd,char *pBuffer,int size)
{
    for(int i=0;i;i++)>

13.R_FLASH_LP_Open()函數原型

4b09c154-4c51-11ec-9483-dac502259ad0.png

故可以用R_FLASH_LP_Open ()函數進行初始化開啟初始化Flash。


 /* Open the flash lp instance. */
     fsp_err_t err = R_FLASH_LP_Open(&g_flash0_ctrl, &g_flash0_cfg);
    assert(FSP_SUCCESS == err);

14.R_FLASH_LP_Erase()函數原型

4b58d244-4c51-11ec-9483-dac502259ad0.png

故可以用R_FLASH_LP_Erase()函數進行擦除指定的代碼或數據閃存塊。


 /* Erase 1 block of code flash starting at block 62. */
    err = R_FLASH_LP_Erase(&g_flash0_ctrl, FLASH_CF_BLOCK_62, 1);
    assert(FSP_SUCCESS == err);

15.R_FLASH_LP_StatusGet()函數原型

4b6c0dfa-4c51-11ec-9483-dac502259ad0.png

故可以用R_FLASH_LP_StatusGet()函數對Code Flash或者Data Flash進行寫數據。

/* Write 32 bytes to the first block of data flash. */
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_CF_BLOCK_62, g_src_uint8_length);
    assert(FSP_SUCCESS == err);

16.R_FLASH_L

4b6c0dfa-4c51-11ec-9483-dac502259ad0.png

故可以用R_FLASH_LP_Write()函數對Code Flash或者Data Flash進行寫數據。

 /* Write 32 bytes to the first block of data flash. */
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_CF_BLOCK_62, g_src_uint8_length);
    assert(FSP_SUCCESS == err);

17.R_FLASH_LP_StatusGet()函數原型

4ba9e2d8-4c51-11ec-9483-dac502259ad0.png

對Data Flash進行寫操作時候,數據可以在后臺運行,故可以用R_FLASH_LP_StatusGet()函數查詢是否執行完畢。

/* Wait until the current flash operation completes. */
    do
    {
        err = R_FLASH_LP_StatusGet(&g_flash0_ctrl, &status);
    } while ((FSP_SUCCESS == err) && (FLASH_STATUS_BUSY == status));

18.Code Flash

對Code Flash進行讀寫操作時候,特別要注意寫的地址,因為如果寫的不對,會覆蓋到代碼區,造成運行錯誤,同時對于擦除,是一塊的數據都會直接擦除掉。

在RA2L1中,Code flash有2種規格,分別是128KB和256KB,每塊大小為2KB。

4bea6a2e-4c51-11ec-9483-dac502259ad0.png

為了兼容其他的型號,向Block62種寫入數據并且讀取出來,地址范圍是0x0001F000 - 0x0001F800。

使用R_FLASH_LP_Write()寫入的時候,寫入的是字節為單位,故num_bytes為g_src_uint8_length*1;


#define FLASH_CF_BLOCK_62               0x0001F000U /*   2 KB: 0x0001F000 - 0x0001F800 */
volatile uint8_t g_src_uint8[4]={0x1a,0x24,0x46,0x6a};
volatile uint8_t  g_src_uint8_length=4;
 /* Write 32 bytes to the first block of data flash. */
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_CF_BLOCK_62, g_src_uint8_length);
    assert(FSP_SUCCESS == err);
    assert(0 == memcmp(g_src_uint8, (uint8_t *) FLASH_CF_BLOCK_62, g_src_uint8_length));

19.Data Flash

對Data Flash進行讀寫操作時候,特別要注意要等待Data Flash寫完才能進行后續讀寫操作。

在RA2L1中, Data flash都是8KB的,每塊大小為1KB 。

4c1b4c8e-4c51-11ec-9483-dac502259ad0.png

向Block0種寫入數據并且讀取出來,地址范圍是0x40100000 - 0x401003FF。

使用R_FLASH_LP_Write()寫入的時候,寫入的是字節為單位,故num_bytes為g_src_uint8_length*1;

#define FLASH_DF_BLOCK_0               0x40100000U  /*   1 KB: 0x40100000 - 0x401003FF */
volatile uint8_t g_src_uint8[4]={0x1a,0x24,0x46,0x6a};
volatile uint8_t  g_src_uint8_length=4;
flash_status_t status;
/* Write 32 bytes to the first block of data flash. */
err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_DF_BLOCK_0, g_src_uint8_length);
assert(FSP_SUCCESS == err);
/* Wait until the current flash operation completes. */
do
{
err = R_FLASH_LP_StatusGet(&g_flash0_ctrl, &status);
} while ((FSP_SUCCESS == err) && (FLASH_STATUS_BUSY == status));

20.演示效果

向Data Flash地址0x40100000寫入{0x1a,0x24,0x46,0x6a}和{0xaabbccdd,0x11111111,0x22222222,0x33333333,0x44444444}

向Code Flash地址0x0001F000寫入{0x1a,0x24,0x46,0x6a}和{0xaabbccdd,0x11111111,0x22222222,0x33333333,0x44444444}

通過串口打印出的結果如下所示。

4c659abe-4c51-11ec-9483-dac502259ad0.png

內存地址查詢結果如下所示。

4ca84a8a-4c51-11ec-9483-dac502259ad0.png4cde8eba-4c51-11ec-9483-dac502259ad0.png

21.完整代碼

#include "hal_data.h"
#include 
FSP_CPP_HEADER
void R_BSP_WarmStart(bsp_warm_start_event_t event);
FSP_CPP_FOOTER

fsp_err_t err = FSP_SUCCESS;
volatile bool uart_send_complete_flag = false;
void user_uart_callback (uart_callback_args_t * p_args)
{
    if(p_args->event == UART_EVENT_TX_COMPLETE)
    {
        uart_send_complete_flag = true;
    }
}
#ifdef __GNUC__                                 //串口重定向
    #define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
#else
    #define PUTCHAR_PROTOTYPE int fputc(int ch, FILE *f)
#endif
PUTCHAR_PROTOTYPE
{
        err = R_SCI_UART_Write(&g_uart0_ctrl, (uint8_t *)&ch, 1);
        if(FSP_SUCCESS != err) __BKPT();
        while(uart_send_complete_flag == false){}
        uart_send_complete_flag = false;
        return ch;
}
int _write(int fd,char *pBuffer,int size)
{
    for(int i=0;ievent;
}

#define FLASH_DF_BLOCK_0               0x40100000U  /*   1 KB: 0x40100000 - 0x401003FF */
#define FLASH_CF_BLOCK_62               0x0001F000U /*   2 KB: 0x0001F000 - 0x0001F800 */
/*******************************************************************************************************************//**
 * main() is generated by the RA Configuration editor and is used to generate threads if an RTOS is used.  This function
 * is called by main() when no RTOS is used.
 **********************************************************************************************************************/
void hal_entry(void)
{
    /* TODO: add your own code here */
    err = R_SCI_UART_Open(&g_uart0_ctrl, &g_uart0_cfg);
    assert(FSP_SUCCESS == err);
    volatile uint8_t  g_src_uint8_length=4;
    volatile uint8_t g_src_uint8[4]={0x1a,0x24,0x46,0x6a};
    volatile uint8_t  g_src_uint32_length=5;
    volatile uint32_t g_src_uint32[5]={
    0xaabbccdd,0x11111111,0x22222222,0x33333333,0x44444444
    };
    /********************code flash*******************************/
    flash_result_t blank_check_result;
    /* Open the flash lp instance. */
     fsp_err_t err = R_FLASH_LP_Open(&g_flash0_ctrl, &g_flash0_cfg);
    assert(FSP_SUCCESS == err);
     /* Disable interrupts to prevent vector table access while code flash is in P/E mode. */
    __disable_irq();
    /* Erase 1 block of code flash starting at block 62. */
    err = R_FLASH_LP_Erase(&g_flash0_ctrl, FLASH_CF_BLOCK_62, 1);
    assert(FSP_SUCCESS == err);
    /* Write 32 bytes to the first block of data flash. */
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_CF_BLOCK_62, g_src_uint8_length);
    assert(FSP_SUCCESS == err);
    assert(0 == memcmp(g_src_uint8, (uint8_t *) FLASH_CF_BLOCK_62, g_src_uint8_length));
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint32, FLASH_CF_BLOCK_62+g_src_uint8_length*1, g_src_uint32_length*4);
    assert(FSP_SUCCESS == err);
    assert(0 == memcmp(g_src_uint32, (uint8_t *) FLASH_CF_BLOCK_62+g_src_uint8_length*1, g_src_uint32_length*4));
    /* Enable interrupts after code flash operations are complete. */
    __enable_irq();
    printf("\n/********************code flash*******************************/\n");
    PrintFlashTest(6,FLASH_CF_BLOCK_62);
    /********************data flash*******************************/
    interrupt_called = false;
    /* Erase 1 block of data flash starting at block 0. */
    err = R_FLASH_LP_Erase(&g_flash0_ctrl, FLASH_DF_BLOCK_0, 1);
    assert(FSP_SUCCESS == err);
    while (!interrupt_called)
    {
    ;
    }
    assert(FLASH_EVENT_ERASE_COMPLETE == flash_event);
    interrupt_called = false;
    flash_status_t status;
    /* Write 32 bytes to the first block of data flash. */
    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint8, FLASH_DF_BLOCK_0, g_src_uint8_length);
    assert(FSP_SUCCESS == err);

    /* Wait until the current flash operation completes. */
    do
    {
        err = R_FLASH_LP_StatusGet(&g_flash0_ctrl, &status);
    } while ((FSP_SUCCESS == err) && (FLASH_STATUS_BUSY == status));

    err = R_FLASH_LP_Write(&g_flash0_ctrl, (uint32_t) g_src_uint32, FLASH_DF_BLOCK_0+g_src_uint8_length*1, g_src_uint32_length*4);
    assert(FSP_SUCCESS == err);
    /* Wait until the current flash operation completes. */
    do
    {
        err = R_FLASH_LP_StatusGet(&g_flash0_ctrl, &status);
    } while ((FSP_SUCCESS == err) && (FLASH_STATUS_BUSY == status));

    /* If the interrupt wasn't called process the error. */
    assert(interrupt_called);
    /* If the event wasn't a write complete process the error. */
    assert(FLASH_EVENT_WRITE_COMPLETE == flash_event);
    /* Verify the data was written correctly. */
    assert(0 == memcmp(g_src_uint8, (uint8_t *) FLASH_DF_BLOCK_0, g_src_uint8_length));
    assert(0 == memcmp(g_src_uint32, (uint8_t *) FLASH_DF_BLOCK_0+g_src_uint8_length*1, g_src_uint32_length*4));
    printf("\n/********************data flash*******************************/\n");
    PrintFlashTest(6,FLASH_DF_BLOCK_0);
    while(1)
    {
        R_BSP_SoftwareDelay(1000, BSP_DELAY_UNITS_MILLISECONDS); // NOLINT100->160
    }
#if BSP_TZ_SECURE_BUILD
    /* Enter non-secure code */
    R_BSP_NonSecureEnter();
#endif
}
/*FLASH讀取打印程序*/
void PrintFlashTest(uint32_t L,uint32_t addr)
{
    uint32_t i=0;
    for(i=0;i;i++)>;i++)>

原創:By RA_Billy Xiao


原文標題:瑞薩e2studio----Code Flash&Data Flash讀寫

文章出處:【微信公眾號:RA生態工作室】歡迎添加關注!文章轉載請注明出處。

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

    關注

    146

    文章

    17550

    瀏覽量

    355789
  • ARM
    ARM
    +關注

    關注

    134

    文章

    9237

    瀏覽量

    371915
  • 嵌入式
    +關注

    關注

    5113

    文章

    19337

    瀏覽量

    311215
  • 開發板
    +關注

    關注

    25

    文章

    5260

    瀏覽量

    99728
收藏 1人收藏

    評論

    相關推薦

    RA2L1入門學習】+e2_studio軟件安裝及使用

    一、e2_studio軟件安裝及使用 注冊e2 studio | Renesas 電子 下載軟件 安裝 4.創建工程 更改工程位置 新
    發表于 03-27 13:25

    RA8快速上手指南:Cortex-M85內核RA8開發環境搭建 并點亮一個LED

    因為Cortex-M內核,RA8系列單片機支持多種市面上常見的開發環境,像Keil MDK、IAR EWARM等,而本文講述的是自家官方的IDE(
    的頭像 發表于 03-17 14:35 ?463次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA8快速上手指南:Cortex-M85內核<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA8開發環境搭建 并點亮一個LED

    e2studio和Keil簡介及如何安裝e2studio開發環境

    (簡稱為e2e2s)是電子的一款包含代碼開發、構建和調試的開發工具。e2studio基于開
    的頭像 發表于 03-13 17:27 ?517次閱讀
    <b class='flag-5'>e</b>2<b class='flag-5'>studio</b>和Keil簡介及如何安裝<b class='flag-5'>e</b>2<b class='flag-5'>studio</b>開發環境

    **RA2L1入門學習】+**UART測試實驗

    RA2L1入門學習】+UART測試實驗 本篇文章主要介紹如何使用e2studio單片
    發表于 03-09 15:45

    RA2L1入門學習】RA2L1開發環境搭建

    e2 studio 和 FSP 的下載、安裝及使用指南 1. 什么是 e2 studio 和 FSP? e2
    發表于 03-07 11:33

    RA2L1入門學習】00. 開箱 + 點燈

    常用到的。 【點燈】 開發MCU是要用到E2 Studio的(簡稱e2s)來開發以及編譯程序。通過Renesas
    發表于 03-07 11:07

    基于RA0E1開發板的IIC OLED測試

    基于前面關于e2 studio開發軟件的使用,以及工程測試基礎,本文進一步探索實現硬件IIC OLED的文字和圖片顯示。
    的頭像 發表于 02-13 13:36 ?358次閱讀
    基于<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA0<b class='flag-5'>E</b>1開發板的IIC OLED測試

    RA2L1入門學習】2. PWM呼吸燈

    .燒錄程序: 3.實驗圖片: 經過這兩天的使用,發現e2studio中的stacks頁面還是挺好用的,可以拖拽函數,編寫程序更加方便快捷。在stacks頁面還能看到用到了哪些堆棧,非常的贊。 本人第一次使用該開發板,作為入門學習,主要是體驗一下
    發表于 01-30 21:55

    RA2L1入門學習】1. 點亮LED

    首次使用單片機,先說一下使用感受。 本次學習使用的是RA-Eco-RA2L1-48PIN-V1.0開發板+e2studio(官方的集成開發環境)+RAFP(官方的程序燒錄工具)。
    發表于 01-29 22:17

    e2 studio中Reality AI組件的使用方法

    本實驗將為您介紹如何在e2 studio中使用Reality AI相關組件來進行AI開發,主要涉及如何使用Reality AI Data shipper/collector,Reality AI
    的頭像 發表于 01-21 13:48 ?492次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2</b> <b class='flag-5'>studio</b>中Reality AI組件的使用方法

    FPB-RA6E2 評估板入門學習

    FPB-RA6E2 評估板入門學習
    的頭像 發表于 12-11 09:22 ?490次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b> FPB-RA6<b class='flag-5'>E2</b> 評估板入門學習

    FPB-RA4E2 開發板測評】簡介、環境搭建、程序測試

    2 studio 集成開發環境、工具鏈和 FSP 軟件包。 新建工程 打開 e2 studio 軟件, 依次點擊文件 - 新建 - C
    發表于 11-20 10:49

    e2studio(1)----芯片之搭建FSP環境

    視頻教學 樣品申請 請勿添加外鏈 e2studio軟件 e2studio的集成開發環境,FSP 提供了眾多可提高效率的工具,用于開發針對
    發表于 09-30 15:28

    STM32CUBEMX(10)--Flash讀寫

    概述 本例程主要講解如何對芯片自帶Flash進行讀寫,用芯片內部Flash可以對一些需要斷電保存的數據進行保存,無需加外部得存儲芯片,本例程采用的是STM32F030R8T6,64K大小的Fl
    發表于 09-10 15:36

    如何使用e2studio單片機進行GPIO輸出

    本篇文章主要介紹如何使用e2studio單片機進行GPIO輸出,并以LED顯示。
    的頭像 發表于 07-30 16:12 ?880次閱讀
    如何使用<b class='flag-5'>e2studio</b>對<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>單片機進行GPIO輸出
    主站蜘蛛池模板: 久久永久免费 | 1024国产看片在线观看 | 黄色大秀 | 欧美一二区视频 | sis色中色| 日本拍拍视频 | 午夜在线观看免费观看大全 | 特级毛片免费看 | 就去干综合 | 日本大黄视频 | 毛片网站在线 | 美国三级网 | 婷婷在线观看香蕉五月天 | 亚洲综合婷婷 | 操日韩美女 | 黄频免费| 成人黄色一级片 | 国产精品 色 | 在线免费视频国产 | 俄罗斯小屁孩cao大人免费 | 精品国内一区二区三区免费视频 | 日本极度另类网站 | 天堂8在线天堂资源在线 | 一品毛片 | caoporn97人人做人人爱最新 | 国产性较精品视频免费 | 欧美性黑人十极品hd | 亚洲第一区第二区 | 91啪在线视频 | 四虎永久地址4hu紧急入口 | 美女大黄三级视频在线观看 | 久久精彩免费视频 | 亚洲成人在线电影 | 91综合在线| 色视频在线免费看 | 久久婷婷国产综合精品 | 大乳妇女bd视频在线观看 | 亚洲一级毛片免费观看 | 狠狠干视频网 | 日本一区二区三区不卡在线看 | 人人看人人做人人爱精品 |

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品