国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

瑞薩e2studio----獨立看門狗IWDT

RA生態工作室 ? 2021-11-26 17:18 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

pYYBAGGA3i6Af0z4AABdWrtWoBM374.png

1.概述

本篇文章主要介紹如何使用e2studio對瑞薩進行獨立看門狗IWDT配置,并且配置RTC時鐘產生1s的周期中斷,通過串口打印查看獨立看門狗IWDT的計數值。

2.硬件準備

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

3.新建工程

79f00140-4c51-11ec-9483-dac502259ad0.png


4.工程模板

7a1da5aa-4c51-11ec-9483-dac502259ad0.png

5.保存工程路徑

7a2e751a-4c51-11ec-9483-dac502259ad0.png

6.芯片配置

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

7a589e6c-4c51-11ec-9483-dac502259ad0.png

7

7.工程模板選擇

7a83c75e-4c51-11ec-9483-dac502259ad0.png

8.IWDT配置

點擊Stacks -> New Stack->Driver -> Monitoring -> Watchdog Driver on r_iwdt。

7ab06124-4c51-11ec-9483-dac502259ad0.png

9.IWDT屬性配置

7afaecc6-4c51-11ec-9483-dac502259ad0.png

10.OFS屬性配置

7b46a36e-4c51-11ec-9483-dac502259ad0.png

11.RTC配置

點擊Stacks->New Stack->Driver->Timers -> RTC Driver on r_rtc。

7ab06124-4c51-11ec-9483-dac502259ad0.png

12.RTC屬性配置

7bd62390-4c51-11ec-9483-dac502259ad0.png

13.設置E2STUDIO堆棧

7c0206d6-4c51-11ec-9483-dac502259ad0.png

14.e2studio的重定向printf設置

7c35a842-4c51-11ec-9483-dac502259ad0.png

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

7c50a386-4c51-11ec-9483-dac502259ad0.png

15.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++)>

16.R_IWDT_Open()函數原型

7c60a3a8-4c51-11ec-9483-dac502259ad0.png

故可以用R_IWDT_Open()函數進行初始化和開啟IWDT。


 /* Open the module. */
     err = R_IWDT_Open(&g_iwdt0_ctrl, &g_iwdt0_cfg);
     /* Handle any errors. This function should be defined by the user. */
     assert(FSP_SUCCESS == err);

17.R_IWDT_Refresh()函數原型

7c93a92e-4c51-11ec-9483-dac502259ad0.png

故可以用R_IWDT_Refresh()函數進行喂狗操作。

 /* Refresh before the counter underflows to prevent reset or NMI. */
(void) R_IWDT_Refresh(&g_iwdt0_ctrl);

18.R_IWDT_CounterGet()函數原型

7cd4c3fa-4c51-11ec-9483-dac502259ad0.png

故可以用R_IWDT_CounterGet()函數獲取當前的計數值。


 uint32_t iwdt_counter = 0U;
 err = R_IWDT_CounterGet(&g_iwdt0_ctrl, &iwdt_counter);

19.IWDT周期設定

通過查閱數據手冊,可以得知IWDT使用的時鐘為15k。

7cf9117e-4c51-11ec-9483-dac502259ad0.png

IWDT從IWDTCLK運行,依據上文的設定,IWDT周期如下所示。

Paramete Equal to
IWDTCLK 15kHz
Clock division rati IWDTCLK/32
Timeout period 2048 cycles
IWDT clock frequency 15 kHz / 32 = 468.75 Hz
Cycle time 1 / 468.75 Hz = 2.13 ms
Timeout 2.13 ms x 2048 cycles = 4.362 seconds

上述可以看到在該設置下的溢出時間為4.362s,那么1s的計數為1s/2.13ms=469。

20.IWDT計數周期

IWDT計數是從最高一直減到0,當到0時候觸發復位。

7d2dce96-4c51-11ec-9483-dac502259ad0.png

21.演示效果

設置每過1s打印一次當前時間,分別設置喂狗和不喂狗,結果如下。

延遲1s的計數為1s/2.13ms=469,打印為1570,由于是向下計數,2048-1570=478,符合計算值。

當不執行喂狗時候,計數值到0時會進行復位。

7d5c5bda-4c51-11ec-9483-dac502259ad0.png7d8641fc-4c51-11ec-9483-dac502259ad0.png

22.完整代碼

#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 == RTC_EVENT_PERIODIC_IRQ)
        rtc_flag=1;

}

/*******************************************************************************************************************//**
 * 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);

    /* Initialize the RTC module*/
    err = R_RTC_Open(&g_rtc0_ctrl, &g_rtc0_cfg);
    /* Handle any errors. This function should be defined by the user. */
    assert(FSP_SUCCESS == err);
    /* Set the periodic interrupt rate to 1 second */
    R_RTC_PeriodicIrqRateSet(&g_rtc0_ctrl, RTC_PERIODIC_IRQ_SELECT_1_SECOND);

    printf("starting up !\n");

    /* (Optional) Enable the IWDT to count and generate NMI or reset when the
     * debugger is connected. */
    R_DEBUG->DBGSTOPCR_b.DBGSTOP_IWDT = 0;
    /* (Optional) Check if the IWDTRF flag is set to know if the system is
     * recovering from a IWDT reset. */
    if (R_SYSTEM->RSTSR1_b.IWDTRF)
    {
        /* Clear the flag. */
        R_SYSTEM->RSTSR1 = 0U;
    }
    /* Open the module. */
     err = R_IWDT_Open(&g_iwdt0_ctrl, &g_iwdt0_cfg);
     /* Handle any errors. This function should be defined by the user. */
     assert(FSP_SUCCESS == err);
     /* Initialize other application code. */
     /* Do not call R_IWDT_Refresh() in auto start mode unless the
      * counter is in the acceptable refresh window. */
    (void) R_IWDT_Refresh(&g_iwdt0_ctrl);
    while(1)
    {
            if(rtc_flag)
            {
                uint32_t iwdt_counter = 0U;
                err = R_IWDT_CounterGet(&g_iwdt0_ctrl, &iwdt_counter);
                assert(FSP_SUCCESS == err);
                printf("iwdt_counter=%d\n",iwdt_counter);
                /* Refresh before the counter underflows to prevent reset or NMI. */
                (void) R_IWDT_Refresh(&g_iwdt0_ctrl);
                rtc_flag=0;
            }
    }
#if BSP_TZ_SECURE_BUILD
    /* Enter non-secure code */
    R_BSP_NonSecureEnter();
#endif
};i++)>

原創:By RA_Billy Xiao


原文標題:瑞薩e2studio----獨立看門狗IWDT

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

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

    關注

    147

    文章

    18924

    瀏覽量

    398068
  • ARM
    ARM
    +關注

    關注

    135

    文章

    9552

    瀏覽量

    391856
  • 嵌入式
    +關注

    關注

    5198

    文章

    20445

    瀏覽量

    333994
  • 開發板
    +關注

    關注

    26

    文章

    6290

    瀏覽量

    118065
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    FPB-RA6E2試用】Zephyr看門狗(WDT)機制

    程序卡死未按時喂狗,看門狗就會直接切斷并復位MCU的電源軌,讓系統重啟。 在傳統的裸機開發中,配置看門狗需要翻閱芯片手冊,操作復雜的控制寄存器和分頻器。而在Zephyr中,無論底層是
    發表于 02-20 10:35

    FPB-RA6E2試用】【FPB-RA6E2看門狗(Watchdog Timer, WDT)個人理解及資料整理

    FPB-RA6E2看門狗(Watchdog Timer, WDT)個人理解及資料整理
    發表于 01-14 11:09

    RA × Zephyr評測】多線程和看門狗

    本文章旨在評估使用 Zephyr RTOS 在 Renesas FPB-RA6E2 開發板上實現多線程調度與硬件看門狗功能的應用。評估內容包括任務調度、看門狗初始化流程、主程序邏輯的詳細解析,以及實驗現象與數據分析。
    的頭像 發表于 01-10 10:23 ?2465次閱讀
    【<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA × Zephyr評測】多線程和<b class='flag-5'>看門狗</b>

    怎樣開始去啟用獨立看門狗呢?

    看門狗的原理是什么呢? 怎樣開始去啟用獨立看門狗呢?
    發表于 01-08 06:33

    CW32配置IWDT獨立看門狗配置步驟

    _KR 寄存器寫入 0x5555,解除 IWDT 寄存器鎖定功能; 步驟 4:配置 IWDT_CR,配置看門狗計數時鐘與 RC10K 振蕩器的預分頻值、溢出后動作、深度休眠模式下是否自動暫停; 步驟 5:配置
    發表于 12-24 08:27

    IWDT窗口看門狗的配置

    _KR 寄存器寫入 0x5555,解除 IWDT 寄存器鎖定功能; 步驟 4:配置 IWDT_CR,配置看門狗計數時鐘與 RC10K 振蕩器的預分頻值、溢出后動作、深度休眠模式下是否 自動暫停; 步驟 5
    發表于 12-10 06:10

    IWDT獨立看門狗的配置

    _KR 寄存器寫入 0x5555,解除 IWDT 寄存器鎖定功能; 步驟 4: 配置 IWDT_CR,配置看門狗計數時鐘與 RC10K 振蕩器的預分頻值、溢出后動作、深度休眠模式下是否自動暫停; 步驟 5
    發表于 12-05 06:18

    芯源MCU看門狗設置過程

    1 配置IWDT獨立看門狗 步驟1:設置SYSCTRL_APBEN1.IWDT 為1,使能IWDT 的配置時鐘; 步驟
    發表于 12-03 06:33

    中科芯CKS32F107XX系列MCU的獨立看門狗介紹

    中科芯CKS32F107xx系列產品內部提供兩個看門狗定時器單元,獨立看門狗IWDG(Independent Watchdog)和窗口型看門狗WWDG(Window Watchdog
    的頭像 發表于 11-28 14:51 ?3853次閱讀
    中科芯CKS32F107XX系列MCU的<b class='flag-5'>獨立</b><b class='flag-5'>看門狗</b>介紹

    CW32A030看門狗和SysTick定時器

    CW32A030的看門狗獨立看門狗和窗口看門狗如下: 1、 獨立看門狗
    發表于 11-27 07:52

    “喂狗”的藝術:看門狗不叫,才是系統好

    看門狗選哪只好呢? 中間那只看起來不錯。 咳咳搞錯了,自動化項目中說的看門狗是PLC的看門狗,那這個有什么用呢?難道真的是看大門的
    的頭像 發表于 11-25 10:50 ?303次閱讀
    “喂狗”的藝術:<b class='flag-5'>看門狗</b>不叫,才是系統好

    既然有獨立看門狗了,為啥還要窗口看門狗(WWDT),窗口看門狗的特色是什么?

    既然有獨立看門狗了,為啥還要窗口看門狗(WWDT),窗口看門狗的特色是什么?
    發表于 11-21 06:42

    CW32配置IWDT為窗口看門狗的步驟

    _KR 寄存器寫入 0x5555,解除 IWDT 寄存器鎖定功能; 步驟 4:配置 IWDT_CR,配置看門狗計數時鐘與 RC10K 振蕩器的預分頻值、溢出后動作、深度休眠模式下是否自動暫停; 步驟 5:配置
    發表于 11-13 06:53

    【RA4E2開發板評測】電壓檢測器 ThreadX顯示量程0-3300 mV+獨立看門狗定時器

    續前【RA4E2開發板評測】電壓檢測器 ThreadX顯示量程0-3300 mV+深度軟件待機模式 獨立看門狗定時器: 由于單片機的工作常常會受到來自外界電磁場的干擾,造成程序的跑飛,而陷入死循環
    發表于 09-17 23:06

    看門狗,你真的會用嗎?

    嵌入式系統開發中,看門狗是一種重要的機制,用于在程序異常時自動重啟系統,保障其穩定性。本文將深入探討看門狗及其在程序穩定性中的作用,幫助您更好地理解和應用看門狗技術。看門狗首先需要明確
    的頭像 發表于 03-12 11:37 ?5071次閱讀
    <b class='flag-5'>看門狗</b>,你真的會用嗎?