chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

瑞薩e2studio----看門狗WDT

RA生態(tài)工作室 ? 2021-12-02 17:54 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

pYYBAGGA3i6Af0z4AABdWrtWoBM374.png

1.概述

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

2.硬件準備

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

pYYBAGGLLTuAKokoAAL5D_IbQXA990.png

3.新建工程

54017b28-51d1-11ec-a27f-dac502259ad0.png

4.工程模板

547eb43a-51d1-11ec-a27f-dac502259ad0.png

5.保存工程路徑

54d2af72-51d1-11ec-a27f-dac502259ad0.png

6.芯片配置

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

5562c6de-51d1-11ec-a27f-dac502259ad0.png

7

7.工程模板選擇

55e9ef1a-51d1-11ec-a27f-dac502259ad0.png

8.WDT配置

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

565a593a-51d1-11ec-a27f-dac502259ad0.png

9.WDT屬性配置

56e257ea-51d1-11ec-a27f-dac502259ad0.png

10.RTC配置

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

577330d0-51d1-11ec-a27f-dac502259ad0.png

11.RTC屬性配置

580e5eac-51d1-11ec-a27f-dac502259ad0.png

12.設(shè)置E2STUDIO堆棧

58895102-51d1-11ec-a27f-dac502259ad0.png

13.e2studio的重定向printf設(shè)置

58f021fc-51d1-11ec-a27f-dac502259ad0.png

C++ 構(gòu)建->設(shè)置->GNU ARM Cross C Linker->Miscellaneous去掉Other linker flags中的 “--specs=rdimon.specs”

5958e80e-51d1-11ec-a27f-dac502259ad0.png

14.printf輸出重定向到串口

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

注意一定要加上頭文件#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++)>

15.R_WDT_Open()函數(shù)原型

5a017df2-51d1-11ec-a27f-dac502259ad0.png

故可以用R_WDT_Open()函數(shù)進行初始化和開啟WDT。


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

16.R_WDT_Refresh()函數(shù)原型

5a75542a-51d1-11ec-a27f-dac502259ad0.png

故可以用R_WDT_Refresh()函數(shù)進行喂狗操作。

 		 /* Refresh before the counter underflows to prevent reset or NMI. */
        err = R_WDT_Refresh(&g_wdt0_ctrl);
        assert(FSP_SUCCESS == err);

17.R_WDT_CounterGet()函數(shù)原型

5aeaeb18-51d1-11ec-a27f-dac502259ad0.png

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

  /* Read the current WDT counter value. */
  err = R_WDT_CounterGet(&g_wdt0_ctrl, &wdt_counter);
  assert(FSP_SUCCESS == err);

18.WDT周期設(shè)定

通過查閱數(shù)據(jù)手冊,可以得知WDT使用的時鐘為PCLKB。

5b8cd7e8-51d1-11ec-a27f-dac502259ad0.png

在本案例中,使用的PCLKB時鐘為24MHz。

5c34f90a-51d1-11ec-a27f-dac502259ad0.png

WDT從PCLKB運行,依據(jù)上文的設(shè)定,PCLKB周期如下所示。

Paramete Equal to
PLCKB/2 24MHz
Clock division ratio PLCK/8192
Timeout period 16384 cycles
WDT clock frequency 24MHz / 8192 = 2929.6875 Hz
Cycle time 1 / 2929.6875 Hz = 341.33 us
Timeout 341.33 us * 16384 cycles = 5.59 seconds

上述可以看到在該設(shè)置下的溢出時間為5.59s,那么1s的計數(shù)為1s/341.33 us=2930。

19.WDT計數(shù)周期

WDT計數(shù)是從最高一直減到0,當?shù)?時候觸發(fā)復(fù)位。

5ca1bb94-51d1-11ec-a27f-dac502259ad0.png

20.演示效果

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

延遲1s的計數(shù)為1s/341.33us=2930,打印為13460,由于是向下計數(shù),16384-2930=13554,符合計算值。

當不執(zhí)行喂狗時候,計數(shù)值到0時會進行復(fù)位,2個復(fù)位之間為5.595s,符合計算的5.59s。

5d49d39c-51d1-11ec-a27f-dac502259ad0.png5d9512ee-51d1-11ec-a27f-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 == RTC_EVENT_PERIODIC_IRQ)
        rtc_flag=1;

}
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);
    /* (Optional) Enable the WDT to count and generate NMI or reset when the
     * debugger is connected. */
    R_DEBUG->DBGSTOPCR_b.DBGSTOP_WDT = 0;
    /* (Optional) Check if the WDTRF flag is set to know if the system is
     * recovering from a WDT reset. */
    if (R_SYSTEM->RSTSR1_b.WDTRF)
    {
        /* Clear the flag. */
        R_SYSTEM->RSTSR1 = 0U;
    }
    /* Open the module. */
    err = R_WDT_Open(&g_wdt0_ctrl, &g_wdt0_cfg);
    /* Handle any errors. This function should be defined by the user. */
    assert(FSP_SUCCESS == err);
    /* In register start mode, start the watchdog by calling R_WDT_Refresh. */
       err = R_WDT_Refresh(&g_wdt0_ctrl);
       assert(FSP_SUCCESS == err);
       printf("starting up !\n");
       uint32_t wdt_counter = 0U;
while(1)
       {
           if(rtc_flag)
           {
               /* Read the current WDT counter value. */
               err = R_WDT_CounterGet(&g_wdt0_ctrl, &wdt_counter);
               assert(FSP_SUCCESS == err);
               printf("wdt_counter=%d\n",wdt_counter);
               rtc_flag=0;
               /* Refresh before the counter underflows to prevent reset or NMI. */
               err = R_WDT_Refresh(&g_wdt0_ctrl);
               assert(FSP_SUCCESS == err);
           }
       }
#if BSP_TZ_SECURE_BUILD
    /* Enter non-secure code */
    R_BSP_NonSecureEnter();
#endif
};i++)>

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

    關(guān)注

    147

    文章

    18593

    瀏覽量

    386098
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    135

    文章

    9498

    瀏覽量

    388461
  • 嵌入式
    +關(guān)注

    關(guān)注

    5186

    文章

    20133

    瀏覽量

    328471
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    6112

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    RA6E2E2S軟件安裝過程,等待過程玩下97_e2 studio_ZGZZ

    ;amp;vd_source=7ab92f6a337b22fda39554fd6e70f01a 本報告旨在記錄基于RA6E2 MCU評估板的初步開發(fā)體驗。主要內(nèi)容包括: 軟件開發(fā)環(huán)
    發(fā)表于 12-01 22:42

    “喂狗”的藝術(shù):看門狗不叫,才是系統(tǒng)好

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

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

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

    小安派BW21-CBV-Kit入門教程之看門狗簡介

    這是一個簡單的看門狗定時器(WDT)示例,演示了看門狗 API 的用法。 有關(guān)看門狗的定義和工作原理,請參閱以下信息。
    的頭像 發(fā)表于 11-13 17:22 ?4948次閱讀
    小安派BW21-CBV-Kit入門教程之<b class='flag-5'>看門狗</b>簡介

    如果 NUC505 的 WDT看門狗定時器)重置無法正常工作,怎么解決?

    如果 NUC505 的 WDT看門狗定時器)重置無法正常工作,用戶該怎么辦?
    發(fā)表于 08-28 06:56

    如果在配置位中啟用了看門狗WDT)功能,是否會影響ISP升級過程呢?

    如果在配置位中啟用了看門狗WDT) 功能,則看門狗將自動啟動。默認時鐘源是內(nèi)部低速10 kHz時鐘。復(fù)位時間 = 溢出時間延遲時間 = (2 ^ 18 1026) /10k=26.
    發(fā)表于 08-18 08:26

    RA單片機在e2 studio環(huán)境下printf編譯出錯的問題解析

    最近看到有一些網(wǎng)友在討論關(guān)于:RA單片機在e2 studio環(huán)境下printf編譯出錯的問題。
    的頭像 發(fā)表于 05-24 15:51 ?1201次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA單片機在<b class='flag-5'>e2</b> <b class='flag-5'>studio</b>環(huán)境下printf編譯出錯的問題解析

    TPS3430 具有可編程復(fù)位延遲的窗口看門狗定時器數(shù)據(jù)手冊

    TPS3430 是一款獨立的窗口看門狗定時器,具有可編程看門狗窗口和可編程看門狗復(fù)位延遲,適用于各種應(yīng)用。TPS3430窗口看門狗可實現(xiàn) 2.5% 的定時精度(25°C 時的典型值),
    的頭像 發(fā)表于 04-10 14:23 ?591次閱讀
    TPS3430 具有可編程復(fù)位延遲的窗口<b class='flag-5'>看門狗</b>定時器數(shù)據(jù)手冊

    RA2L1入門學(xué)習(xí)】+e2_studio軟件安裝及使用

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

    e2studio和Keil簡介及如何安裝e2studio開發(fā)環(huán)境

    (簡稱為e2e2s)是電子的一款包含代碼開發(fā)、構(gòu)建和調(diào)試的開發(fā)工具。e2studio基于開
    的頭像 發(fā)表于 03-13 17:27 ?2231次閱讀
    <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>開發(fā)環(huán)境

    看門狗,你真的會用嗎?

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

    安利給工程師!看門狗相關(guān)知識

    適當?shù)膮?shù)來確保系統(tǒng)在正常運行和故障場景下都能自動恢復(fù)。? ▼ 看門狗簡介 ▼ 看門狗(Watch Dog Timer,WDT) ——是一種監(jiān)控電路,主要應(yīng)用于嵌入式系統(tǒng),目的是為了提高系統(tǒng)的可靠性和穩(wěn)定性。在
    的頭像 發(fā)表于 12-31 14:29 ?910次閱讀
    安利給工程師!<b class='flag-5'>看門狗</b>相關(guān)知識

    抄作業(yè)!看門狗定時器必備知識

    具體示例解析,教你如何在一個簡單的LuatOS項目中集成看門狗定時器,設(shè)置適當?shù)膮?shù)來確保系統(tǒng)在正常運行和故障場景下都能自動恢復(fù)。 Air201最新資料下載: www.air201.cn ▼ 看門狗簡介 ▼ 看門狗(Watch
    的頭像 發(fā)表于 12-30 14:44 ?1065次閱讀
    抄作業(yè)!<b class='flag-5'>看門狗</b>定時器必備知識

    一文詳解看門狗/電壓監(jiān)控芯片規(guī)格書

    是連接到單片機。看門狗的功能是在給定的時間周期內(nèi),如果沒有收到來自MCU的喂狗信號,則會給MCU發(fā)送復(fù)位信號。2.為什么MCU需要看門狗?隨著信息技術(shù)的飛速發(fā)展,
    的頭像 發(fā)表于 12-26 17:18 ?2177次閱讀
    一文詳解<b class='flag-5'>看門狗</b>/電壓監(jiān)控芯片規(guī)格書