0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

瑞薩RH850 FCL、FDL和EEL庫(kù)的配置和使用

jf_Vqngj70R ? 來(lái)源:美男子玩編程 ? 作者:美男子玩編程 ? 2023-01-13 13:16 ? 次閱讀

瑞薩RH850 Flash中有兩種存儲(chǔ)類型:Mapping of Code Flash Memory和Mapping of Data Flash Memory。

Mapping of Code Flash Memory存儲(chǔ)代碼,Mapping of Data Flash Memory存儲(chǔ)數(shù)據(jù)。

pYYBAGPA6YKADsPPAAFy4tYj9PA427.jpgpoYBAGPA6YKAcTxGAAEF9s1lLOI980.jpg

瑞薩車規(guī)級(jí)MCU操作Flash沒(méi)有直接提供寄存器接口,需要安裝官方提供的庫(kù)文件,有三種形式:

FCL:程序存儲(chǔ)區(qū)仿真庫(kù),可使用此庫(kù)訪問(wèn)程序存儲(chǔ)區(qū),一般用于程序自升級(jí)操作;

pYYBAGPA6YKAaI1PAAClD6eDS28186.jpg

FDL:數(shù)據(jù)存儲(chǔ)區(qū)仿真庫(kù),可通過(guò)此庫(kù)操作數(shù)據(jù)區(qū),需要人為定義地址和數(shù)據(jù)長(zhǎng)度,占用Flash空間比EEL略少,但占用RAM大;

EEL:EEPROM仿真庫(kù),可使用此庫(kù)來(lái)訪問(wèn)數(shù)據(jù)內(nèi)存區(qū),該方法類似于訪問(wèn)外部EEPROM,使用此庫(kù)時(shí),不用管理對(duì)數(shù)據(jù)區(qū)閃存寫和擦除操作,其占用Flash容量大,需配合FDL庫(kù)來(lái)操作。

pYYBAGPA6YKACOF9AACeuC3rAlc957.jpg

1FCL庫(kù)

1.1、配置FCL庫(kù)

第1步:下載FCL庫(kù)(點(diǎn)擊閱讀原文查看)。

FCL庫(kù)官網(wǎng)地址

RH850 FCL庫(kù)與用戶手冊(cè)地址

第2步:安裝FCL庫(kù)。

8b2b5f26-9300-11ed-bfe3-dac502259ad0.png

安裝完成后可見(jiàn)官方庫(kù)文件和用戶使用文件兩部分:

poYBAGPA6YKAHhICAABP3kRPY0c611.jpg

文件系統(tǒng)結(jié)構(gòu)說(shuō)明如下所示:

poYBAGPA6YKAUeS6AALvwf1agqE474.jpg
poYBAGPA6YKALwhrAAHnHkMZPB0822.jpg

第3步:將官方庫(kù)文件和對(duì)應(yīng)的用戶使用文件添加到自己的工程后,在CS+工程中的添加FCL需要的代碼段,如下圖所示:

pYYBAGPA6YKAOJTNAAIcCYjWMYA491.jpgpYYBAGPA6YKACDAeAAGlP2n14d8607.jpg

注意:

在這些代碼段中請(qǐng)不要插入其他段;

FCL_RESERVED.bss段:在RAM中存放FCL庫(kù)運(yùn)行的代碼,即復(fù)制上面代碼段的內(nèi)容到此RAM中。如果定義了R_FCL_HANDLER_CALL_USER,則用戶代碼R_FCL_CODE_USER.text也在RAM中運(yùn)行。在實(shí)際應(yīng)用中定義FCL_RESERVED預(yù)留的大小,大小必須包含該庫(kù)代碼量和用戶代碼量(如果定義了R_FCL_HANDLER_CALL_USER );

/* This array reserves the copy area in the device RAM */
#define FCL_RAM_EXECUTION_AREA_SIZE 0x8000
R_FCL_NOINIT uint8_t FCL_Copy_area[FCL_RAM_EXECUTION_AREA_SIZE];

R_FCL_DATA.bss:FCL內(nèi)部運(yùn)行數(shù)據(jù)段;

在CS+環(huán)境下,F(xiàn)CL編譯后會(huì)出現(xiàn)3個(gè)對(duì)齊失配警告,請(qǐng)忽略。

W0561322:Section alignment mismatch : "R_FCL_CODE_USR.text"
W0561322:Section alignment mismatch : "R_FCL_CODE_RAM.text"
W0561322:Section alignment mismatch : "R_FCL_CODE_ROMRAM.text"

第4步:修改fcl_cfg.h文件。

#define R_FCL_COMMAND_EXECUTION_MODE    R_FCL_HANDLER_CALL_USER
//修改成
#define R_FCL_COMMAND_EXECUTION_MODE    R_FCL_HANDLER_CALL_INTERNAL

R_FCL_HANDLER_CALL_USER(user mode):user模式,用戶代碼運(yùn)行在RAM區(qū),在自編程命令執(zhí)行期間,可以運(yùn)行用戶代碼,用戶可以輪詢庫(kù)的運(yùn)行狀態(tài)。需要消耗一定的RAM空間;

R_FCL_HANDLER_CALL_INTERNAL (internal mode):internal模式,不需要輪詢庫(kù)的狀態(tài),在自編程命令執(zhí)行期間沒(méi)有狀態(tài)值的返回,直到命令執(zhí)行結(jié)束。消耗RAM空間小。

第5步:修改fcl_descriptor.h文件。

#define FCL_CPU_FREQUENCY_MHZ  (240)                          /*!< CPU frequency in MHz */
#define FCL_AUTHENTICATION_ID {0xFFFFFFFF, 
                               0xFFFFFFFF, 
                               0xFFFFFFFF, 
                               0xFFFFFFFF}                    /*!< 128Bit authentication ID */
#define FCL_RAM_ADDRESS        0xFEBC0000                     /*!< RAM address range blocked for FCL */

FCL_CPU_FREQUENCY_MHZ:CPU工作頻率配置,請(qǐng)不要在庫(kù)的運(yùn)行期間改變CPU的工作頻率,如果需要改變,改完后必須重新初始化FCL庫(kù);

FCL_AUTHENTICATION_ID:如果設(shè)備設(shè)置了ID驗(yàn)證碼,需要提供相應(yīng)的ID碼,在FCL初始階段需要驗(yàn)證ID,如果ID驗(yàn)證不通過(guò),不能成功執(zhí)行FCL命令;

FCL_RAM_ADDRESS:根據(jù)相應(yīng)的設(shè)備配置RAM起始位。

第6步:修改r_fcl_types.h文件。

#define R_FCL_NO_BFA_SWITCH


#if ((defined R_FCL_MIRROR_FCU_COPY) && (defined R_FCL_NO_FCU_COPY))
    #error "r_fcl_types.h: Invalid define for support device macro"
#elif ((defined R_FCL_MIRROR_FCU_COPY) && (defined R_FCL_NO_BFA_SWITCH))
    #error "r_fcl_types.h: Invalid define for support device macro"
#elif ((defined R_FCL_NO_FCU_COPY) && (defined R_FCL_NO_BFA_SWITCH))
    #error "r_fcl_types.h: Invalid define for support device macro"
#elif (defined R_FCL_MIRROR_FCU_COPY)
    #define R_FCL_INNER_NO_BFA_SWITCH
#elif (defined R_FCL_NO_FCU_COPY)
    #define R_FCL_INNER_NO_FCU_COPY
#elif (defined R_FCL_NO_BFA_SWITCH)
    #define R_FCL_INNER_NO_BFA_SWITCH
    #define R_FCL_INNER_NO_FCU_COPY
#endif

在FCL V2.12版本中增加了R_FCL_NO_FCU_COPY、R_FCL_MIRROR_FCU_COPY和R_FCL_NO_BFA_SWITCH預(yù)編譯配置選項(xiàng)。

在執(zhí)行FCL庫(kù)環(huán)境準(zhǔn)備命令時(shí),為了從MCU內(nèi)部固件讀取數(shù)據(jù),需要開(kāi)關(guān)CodeFlash幾次。有些設(shè)備需要更少的開(kāi)關(guān)來(lái)完成這個(gè)準(zhǔn)備工作,需要定義R_FCL_NO_BFA_SWITCH 宏;

R_FCL_NO_BFA_SWITCH 宏和R_FCL_NO_FCU_COPY、R_FCL_MIRROR_FCU_COPY 不能同時(shí)被定義。

預(yù)編譯目標(biāo)設(shè)備所需的定義如下表所示:

poYBAGPA6YKAOm1RAAMqZW26e8s684.jpg

1.2、使用FCL庫(kù)

pYYBAGPA6YKAFaX8AALJKRvcLus123.jpgpYYBAGPA6YKAFaX8AALJKRvcLus123.jpg

2FDL庫(kù)

2.1、配置FDL庫(kù)

第1步:下載FDL庫(kù)(點(diǎn)擊閱讀原文查看)。

FDL庫(kù)官網(wǎng)地址:https://www.renesas.cn/cn/en/software-tool/data-flash-libraries#download

RH850 FDL庫(kù)與用戶手冊(cè)地址:https://www.renesas.cn/cn/en/products/microcontrollers-microprocessors/rh850-automotive-mcus/rh850f1km-s4-high-end-automotive-microcontrollers-ideal-body-applications/design-support#hardware_tools

第2步:安裝FDL庫(kù)。

8c02de06-9300-11ed-bfe3-dac502259ad0.png

安裝完成后可見(jiàn)官方庫(kù)文件和用戶使用文件兩部分:

poYBAGPA6YKAUFoQAABQ7Qb8Nzo941.jpg
pYYBAGPA6oeAVAROAAPmyZOk7j4585.pngpoYBAGPA6YKAb9diAAH1yHkKie4757.jpg

第3步:將官方庫(kù)文件和對(duì)應(yīng)的用戶使用文件添加到自己的工程后,在CS+工程中的添加FDL需要的代碼段,如下圖所示:

pYYBAGPA6YKAOJTNAAIcCYjWMYA491.jpgpYYBAGPA6YKAajWlAALD078Sjuk187.jpg

注意:

FDL庫(kù)的代碼段請(qǐng)按照如圖樣例1設(shè)置,位置可以任意,但不要插在FCL代碼的中間;

R_FDL_Data.bss:FCL內(nèi)部運(yùn)行變量數(shù)據(jù)段;

R_FDL_CodeRam.bss: 在執(zhí)行FDL環(huán)境準(zhǔn)備期間,Code Flash不可用,需要從RAM中運(yùn)行代碼。

第4步:修改r_fdl.h文件。

#define R_FDL_NO_BFA_SWITCH


/* Global compiler definition */
#if ((defined R_FDL_MIRROR_FCU_COPY) && (defined R_FDL_NO_FCU_COPY))
    #error "r_fdl.h: Invalid define for support device macro"
#elif ((defined R_FDL_MIRROR_FCU_COPY) && (defined R_FDL_NO_BFA_SWITCH))
    #error "r_fdl.h: Invalid define for support device macro"
#elif ((defined R_FDL_NO_FCU_COPY) && (defined R_FDL_NO_BFA_SWITCH))
    #error "r_fdl.h: Invalid define for support device macro"
#elif (defined R_FDL_MIRROR_FCU_COPY)
    #define R_FDL_INNER_NO_BFA_SWITCH
#elif (defined R_FDL_NO_FCU_COPY)
    #define R_FDL_INNER_NO_FCU_COPY
#elif (defined R_FDL_NO_BFA_SWITCH)
    #define R_FDL_INNER_NO_BFA_SWITCH
    #define R_FDL_INNER_NO_FCU_COPY
#endif

在FDL V2.12版本中增加了R_FDL_NO_FCU_COPY, R_FDL_MIRROR_FCU_COPY和R_FDL_NO_BFA_SWITCH預(yù)編譯配置選項(xiàng)。

在執(zhí)行FDL庫(kù)初始化時(shí),為了從MCU內(nèi)部拷貝固件,需要在固件區(qū)和用戶區(qū)來(lái)回切換幾次,需要定義宏R_FDL_NO_BFA_SWITCH 。有些設(shè)備不需要拷貝固件(比如RH850/D1M1A),需要定義R_FDL_NO_FCU_COPY宏。

不要同時(shí)定義R_FDL_NO_BFA_SWITCH和R_FDL_NO_FCU_COPY, R_FDL_MIRROR_FCU_COPY 。

預(yù)編譯目標(biāo)設(shè)備所需的定義如下表所示:

poYBAGPA6YKALqsuAAKbhrIYoTw665.jpg

第5步:修改fdl_descriptor.h文件。

/* The Flash programming hardware is provided with a clock, derived from the CPU subsystem frequency. Check that 
       the frequency is correct as this has an impact on the programming quality and performance! */
    #define CPU_FREQUENCY_MHZ       (240)                           /**< CPU frequency in MHz */


    /*****************************************************************************************************************
     *  Important definitions for run-time configuration of the FDL: 
     *   - EEL/FDL Pool -
     *****************************************************************************************************************/
    /* The physical erase unit of the Data Flash is 64Byte. 
       The Renesas EEL works with a ring buffer consisting of ring buffer (virtual) blocks that merge a certain number 
       of physical blocks.
       E.g. virtual block size of 2kB equals 32 physical blocks of 64Bytes --> EEL_VIRTUALBLOCKSIZE = 32
            virtual block size of 4kB equals 64 physical blocks of 64Bytes --> EEL_VIRTUALBLOCKSIZE = 64


       Note: If the Renesas EEL is not used, an alignment is not necessary "EEL_VIRTUALBLOCKSIZE" need not be defined 
       and the pools start and size definitions can be set free to the application needs */
    #define EEL_VIRTUALBLOCKSIZE    (64u)


    #define FDL_POOL_SIZE           (16u * EEL_VIRTUALBLOCKSIZE)    /**< Number of Data Flash blocks, accessible by
                                                                         the FDL. Typically it is the complete
                                                                         no. of available Data Flash blocks */
    #define EEL_POOL_START          (1u * EEL_VIRTUALBLOCKSIZE)     /**< 1st block of the EEL pool */
    #define EEL_POOL_SIZE           (6u * EEL_VIRTUALBLOCKSIZE)     /**< no. of blocks for the EEL pool */

CPU_FREQUENCY_MHZ:CPU工作頻率配置,請(qǐng)不要在庫(kù)的運(yùn)行期間改變CPU的工作頻率,如果需要改變,改變后必須重新初始化FDL庫(kù);

EEL_VIRTUALBLOCKSIZE虛擬塊定:Data Flash物理塊的大小為64Bytes,在EEL(EE2PROM Emulation Library)庫(kù)中,需要合并一定數(shù)量的物理塊虛擬成一個(gè)虛擬塊作為EEL的緩沖區(qū),用戶可以根據(jù)實(shí)際應(yīng)用定義虛擬塊的大?。?/p>

如果沒(méi)有使用EEL,設(shè)EEL_VIRTUALBLOCKSIZE = 0。如果使用EEL,例如要定義2KB的虛擬塊,則需要32塊64B的物理塊組成,那么設(shè)EEL_VIRTUALBLOCKSIZE = 32。

FDL_POOL_SIZE :設(shè)備Data Flash的物理塊的數(shù)量;

EEL_POOL_START、EEL_POOL_SIZE:EEL池的起始?jí)K和大小定義。

如果沒(méi)有使用EEL,設(shè)EEL_POOL_START = 0, EEL_POOL_SIZE = 0;

如果使用EEL,例如,EEL_POOL_START = 0u * EEL_VIRTUALBLOCKSIZE、EEL_POOL_SIZE = 5 * EEL_VIRTUALBLOCKSIZE。

2.2、使用FDL庫(kù)

poYBAGPA6YKAL4kKAAMQ3Vxvmu8657.jpg

3EEL庫(kù)

FDL和EEL都是操作Data Flash Memory,EEL依托于FDL,在FDL庫(kù)中已經(jīng)講解了使用EEL的方法。EEL和FDL關(guān)系如下圖所示:

poYBAGPA6YOABIO1AAB5NI9f-yk578.jpg

EEL PooL:EEL Pool為EEL提供存儲(chǔ)數(shù)據(jù)和管理信息;

User PooL:所有不是EEL Pool分配的FDL Pool空間都可由用戶應(yīng)用程序自由使用,因此稱為User PooL。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • FlaSh
    +關(guān)注

    關(guān)注

    10

    文章

    1598

    瀏覽量

    147338
  • 存儲(chǔ)
    +關(guān)注

    關(guān)注

    13

    文章

    4123

    瀏覽量

    85276
  • 瑞薩
    +關(guān)注

    關(guān)注

    33

    文章

    22274

    瀏覽量

    85509
  • FDL
    FDL
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

    6257
  • rh850
    +關(guān)注

    關(guān)注

    2

    文章

    24

    瀏覽量

    4538

原文標(biāo)題:瑞薩RH850 FCL、FDL和EEL庫(kù)的配置和使用

文章出處:【微信號(hào):美男子玩編程,微信公眾號(hào):美男子玩編程】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    從什么渠道可以找到的芯片手冊(cè)?

    在baidu,及官網(wǎng)查找均不能很好地獲得的芯片手冊(cè),如RH850/F1L。向其他的一些大廠如TI,F(xiàn)reescale他們的官網(wǎng)均有豐
    發(fā)表于 02-13 15:19

    RH850/F1L用戶手冊(cè)的CAN接口部分介紹

    本文介紹RH850/F1L用戶手冊(cè)(user manual)的CAN接口部分的中文翻譯。博主會(huì)持續(xù)更新該用戶手冊(cè),直到整個(gè)翻譯完成,有興趣的朋友可持續(xù)關(guān)注.版權(quán)聲明本博文系歐科曼汽車電子所
    發(fā)表于 12-09 07:46

    RH850F1x開(kāi)發(fā)環(huán)境的搭建方法

    幫到大家。RH850F1x完整開(kāi)發(fā)環(huán)境介紹買RH850F1x開(kāi)發(fā)板,贈(zèng)送完整開(kāi)發(fā)環(huán)境,包括1、IAR for RH850編譯器2、CAN
    發(fā)表于 01-27 06:55

    如何配置***編譯器使其可以結(jié)合E1仿真器對(duì)RH850進(jìn)行仿真調(diào)試?

    如何配置***編譯器使其可以結(jié)合E1仿真器對(duì)RH850進(jìn)行仿真調(diào)試?
    發(fā)表于 02-16 07:00

    RH850P1M-C芯片或者RH850P系列誰(shuí)用過(guò),用什么配置軟件???

    最近在使用RH850/P1M-C/R7F701374單片機(jī),開(kāi)發(fā)環(huán)境使用過(guò)CS+、e2 studio、IAR都有這個(gè)芯片型號(hào)。但是配置軟件卻沒(méi)看到有這個(gè)系列信號(hào),我在renesas
    發(fā)表于 01-18 10:00

    RH850 R7F7010693 誰(shuí)能破解

    RH850 R7F7010693 誰(shuí)能破解?可以的加我V:13520223020
    發(fā)表于 04-22 14:29

    推出汽車電子應(yīng)用的新RH850系列微控制器

    電子株式會(huì)社(以下簡(jiǎn)稱“電子”)宣布推出面向汽車電子應(yīng)用的全新RH850系列32位微控制器(MCU)。
    發(fā)表于 03-12 08:27 ?1913次閱讀

    結(jié)合GHS MULTI使用E1仿真器實(shí)現(xiàn)對(duì)RH850單片機(jī)的仿真調(diào)試

    廣泛應(yīng)用,而GHS編譯器由于其出色的性能,在車載行業(yè)也得到眾多認(rèn)可。本文介紹如何配置GHS編譯器,使其可以結(jié)合E1仿真器對(duì)RH850進(jìn)行仿真調(diào)試。1、首先將USB KEY加密狗插入
    發(fā)表于 12-20 19:01 ?20次下載
    結(jié)合GHS MULTI使用<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>E1仿真器實(shí)現(xiàn)對(duì)<b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>RH850</b>單片機(jī)的仿真調(diào)試

    RH850 智能配置器用戶指南:IAREW、MULTI

    RH850 智能配置器用戶指南:IAREW、MULTI
    發(fā)表于 01-09 19:09 ?4次下載
    <b class='flag-5'>RH850</b> 智能<b class='flag-5'>配置</b>器用戶指南:IAREW、MULTI

    RH850 智能配置器用戶指南:CS+

    RH850 智能配置器用戶指南:CS+
    發(fā)表于 03-16 19:21 ?1次下載
    <b class='flag-5'>RH850</b> 智能<b class='flag-5'>配置</b>器用戶指南:CS+

    RH850 智能配置器用戶指南:IAREW、MULTI

    RH850 智能配置器用戶指南:IAREW、MULTI
    發(fā)表于 06-30 18:55 ?1次下載
    <b class='flag-5'>RH850</b> 智能<b class='flag-5'>配置</b>器用戶指南:IAREW、MULTI

    RH850 智能配置器用戶指南:CS+

    RH850 智能配置器用戶指南:CS+
    發(fā)表于 07-06 20:06 ?2次下載
    <b class='flag-5'>RH850</b> 智能<b class='flag-5'>配置</b>器用戶指南:CS+

    rh850是什么芯片?

    rh850是什么芯片? RH850是一款高性能的32位RISC微處理器芯片。它由日本的電子公司(Renesas Electronics)開(kāi)發(fā)和推出,其系列產(chǎn)品在電子系統(tǒng)和汽車領(lǐng)域得
    的頭像 發(fā)表于 08-15 16:22 ?3606次閱讀

    rh850是arm架構(gòu)嗎?

    rh850是arm架構(gòu)嗎? Rh850不是ARM架構(gòu),而是一種基于RISC架構(gòu)的嵌入式微控制器。在本文中,我們將深入探討RH850微控制器的特點(diǎn)、應(yīng)用和發(fā)展前景。 RH850的介紹
    的頭像 發(fā)表于 08-15 16:23 ?1866次閱讀

    RH850智能配置器e2studio用戶指南

    電子發(fā)燒友網(wǎng)站提供《RH850智能配置器e2studio用戶指南.pdf》資料免費(fèi)下載
    發(fā)表于 01-30 09:34 ?0次下載
    <b class='flag-5'>RH850</b>智能<b class='flag-5'>配置</b>器e2studio用戶指南