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

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

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

瑞薩e2studio----USRT通過定時器中斷方式接收不定長數(shù)據(jù)

RA生態(tài)工作室 ? 2021-11-02 17:21 ? 次閱讀
pYYBAGGA3i6Af0z4AABdWrtWoBM374.png

1.概述

本篇文章主要介紹如何使用e2studio對瑞薩單片機進行USRT通過定時器中斷方式接收不定長數(shù)據(jù)。

2.硬件準備

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

3.新建工程

d5eea9a0-390b-11ec-aa30-dac502259ad0.png

4.工程模板

d66613fa-390b-11ec-aa30-dac502259ad0.png

5.保存工程路徑

d6e225ee-390b-11ec-aa30-dac502259ad0.png

6.芯片配置

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

d7a0a1cc-390b-11ec-aa30-dac502259ad0.png

7.工程模板選擇

d818170c-390b-11ec-aa30-dac502259ad0.png

8.UART配置

點擊Stacks->New Stack->Driver->Connectivity -> UART Driver on r_sci_uart。

d89cd28a-390b-11ec-aa30-dac502259ad0.png

9.UART屬性配置

d922004a-390b-11ec-aa30-dac502259ad0.png

10.PRINTF重定向

PRINTF重定向已經(jīng)在上述文章中講述,故可以查看往期文章進行學習。

打印最常用的方法是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

11.回調(diào)函數(shù)user_uart_callback ()

設置接受到0xff則輸出已經(jīng)輸入的數(shù)據(jù)。

若接收到新的數(shù)據(jù),使用R_GPT_Reset進行充值定時器計數(shù)。

volatile bool uart_send_complete_flag = false;

uint8_t RxBuff[1];      //進入中斷接收數(shù)據(jù)的數(shù)組
uint8_t DataBuff[5000]; //保存接收到的數(shù)據(jù)的數(shù)組
int RxLine=0;           //接收到的數(shù)據(jù)長度
int Rx_flag=0;                  //接受到數(shù)據(jù)標志
int Rx_flag_finish=0; //接受完成或者時間溢出

void user_uart_callback (uart_callback_args_t * p_args)
{
    if(p_args->event == UART_EVENT_TX_COMPLETE)
    {
        uart_send_complete_flag = true;
    }
 if(p_args->event ==     UART_EVENT_RX_CHAR)
    {
        RxBuff[0] = p_args->data;
        RxLine++;                      //每接收到一個數(shù)據(jù),進入回調(diào)數(shù)據(jù)長度加1
        DataBuff[RxLine-1]=RxBuff[0];  //把每次接收到的數(shù)據(jù)保存到緩存數(shù)組
        Rx_flag=1;
        if(RxBuff[0]==0xff)            //接收結(jié)束標志位,這個數(shù)據(jù)可以自定義,根據(jù)實際需求,這里只做示例使用,不一定是0xff
        {
            Rx_flag_finish=1;
        }
        RxBuff[0]=0;
        err = R_GPT_Reset(&g_timer0_ctrl);
        assert(FSP_SUCCESS == err);
    }
}

12.printf_usart打印函數(shù)

打印已經(jīng)接受的數(shù)據(jù)以及其長度。


void printf_usart(void)
{

    printf("length=%d\r\n",RxLine);
    for(int i=0;i

13.定時器設置

點擊Stacks->New Stack->Driver->Timers -> Timers Driver on r_gpt。

d99460fe-390b-11ec-aa30-dac502259ad0.png

設置500ms無輸入則輸出已經(jīng)輸入的數(shù)據(jù)。

頻率=時鐘源/period,若設置計數(shù)時間為500ms一次,頻率為1Hz,則period=48M/1=48000000

da3faf86-390b-11ec-aa30-dac502259ad0.png

14.定時器回調(diào)函數(shù)timer0_callback()


 /* Callback function */
    void timer0_callback(timer_callback_args_t *p_args)
    {
        /* TODO: add your own code here */
        if (TIMER_EVENT_CYCLE_END == p_args->event)
        {
            if(Rx_flag==1)
            {
                printf_usart();
                Rx_flag=0;
            }
        }
}

15.完整代碼

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

void printf_usart(void);

fsp_err_t err = FSP_SUCCESS;
volatile bool uart_send_complete_flag = false;

uint8_t RxBuff[1];      //進入中斷接收數(shù)據(jù)的數(shù)組
uint8_t DataBuff[5000]; //保存接收到的數(shù)據(jù)的數(shù)組
int RxLine=0;           //接收到的數(shù)據(jù)長度
int Rx_flag=0;                  //接受到數(shù)據(jù)標志
int Rx_flag_finish=0;                  //接受完成或者時間溢出
void user_uart_callback (uart_callback_args_t * p_args)
{
    if(p_args->event == UART_EVENT_TX_COMPLETE)
    {
        uart_send_complete_flag = true;
    }
    if(p_args->event ==     UART_EVENT_RX_CHAR)
    {
        RxBuff[0] = p_args->data;
        RxLine++;                      //每接收到一個數(shù)據(jù),進入回調(diào)數(shù)據(jù)長度加1
        DataBuff[RxLine-1]=RxBuff[0];  //把每次接收到的數(shù)據(jù)保存到緩存數(shù)組
        Rx_flag=1;
        if(RxBuff[0]==0xff)            //接收結(jié)束標志位,這個數(shù)據(jù)可以自定義,根據(jù)實際需求,這里只做示例使用,不一定是0xff
        {
            Rx_flag_finish=1;
        }
        RxBuff[0]=0;
        err = R_GPT_Reset(&g_timer0_ctrl);
        assert(FSP_SUCCESS == err);
    }
}
#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)
        {
            if(Rx_flag==1)
            {
                printf_usart();
                Rx_flag=0;
            }
        }
}
void hal_entry(void)
{
    /* TODO: add your own code here */
    /* Open the transfer instance with initial configuration. */
    err = R_SCI_UART_Open(&g_uart0_ctrl, &g_uart0_cfg);
    assert(FSP_SUCCESS == err);
    /* Initializes the module. */
    err = R_GPT_Open(&g_timer0_ctrl, &g_timer0_cfg);
    /* Handle any errors. This function should be defined by the user. */
    assert(FSP_SUCCESS == err);
    /* Start the timer. */
    (void) R_GPT_Start(&g_timer0_ctrl);
          while(1)
          {
              R_BSP_SoftwareDelay(1, BSP_DELAY_UNITS_MILLISECONDS); // NOLINT100->160
              if(Rx_flag_finish==1)
              {
                      printf_usart();
              }
          }
 #if BSP_TZ_SECURE_BUILD
       /* Enter non-secure code */
       R_BSP_NonSecureEnter();
   #endif
   }

void printf_usart(void)
{

    printf("length=%d\r\n",RxLine);
    for(int i=0;i

16.發(fā)送數(shù)據(jù),并且以0xff結(jié)尾

dacbf7a2-390b-11ec-aa30-dac502259ad0.png

17.發(fā)送數(shù)據(jù),延時500ms后打印

db67c1e6-390b-11ec-aa30-dac502259ad0.png

18.教學視頻

視頻教學稍后會在B站官方賬號更新,請留意B站視頻更新~

pYYBAGGBAquAWrKsAAAxP_X9ph8052.png


原文標題:瑞薩e2studio----USRT通過定時器中斷方式接收不定長數(shù)據(jù)

文章出處:【微信公眾號:RA生態(tài)工作室】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

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

    關(guān)注

    146

    文章

    16885

    瀏覽量

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

    關(guān)注

    134

    文章

    9027

    瀏覽量

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

    關(guān)注

    5059

    文章

    18973

    瀏覽量

    301997
收藏 人收藏

    評論

    相關(guān)推薦

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

    視頻教學 樣品申請 請勿添加外鏈 e2studio軟件 e2studio的集成開發(fā)環(huán)境,F(xiàn)SP 提供了眾多可提高效率的工具,用于開發(fā)針對
    發(fā)表于 09-30 15:28

    單片機PWM輸出

    如何通過e2-studio配置GPT定時器輸出指定數(shù)量PWM后停止輸出
    發(fā)表于 09-19 10:01

    STM32CUBEMX(8)--USART通過定時器中斷方式接收不定長數(shù)據(jù)

    概述 本文利用中斷實現(xiàn)串口不定長接收(非DMA),使用HAL庫,將接收數(shù)據(jù)打印出去。 DMA接收
    發(fā)表于 09-06 16:48

    STM32CUBEMX(2)--USART通過DMA方式接收不定長數(shù)據(jù)

    概述 直接存儲訪問(DMA)用于在外設與存儲之間以及存儲與存儲之間提供高速數(shù)據(jù)傳輸。可以在無需任何CPU操作的情況下
    發(fā)表于 09-04 11:48

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

    本篇文章主要介紹如何使用e2studio單片機進行GPIO輸出,并以LED顯示。
    的頭像 發(fā)表于 07-30 16:12 ?554次閱讀
    如何使用<b class='flag-5'>e2studio</b>對<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>單片機進行GPIO輸出

    定時器的工作方式介紹

    定時器是計算機和嵌入式系統(tǒng)中常見的一種硬件模塊,用于實現(xiàn)定時和計數(shù)功能。定時器的工作方式通常由一組寄存來控制,這些寄存
    的頭像 發(fā)表于 07-12 10:29 ?653次閱讀

    請問如何實現(xiàn)ESP32 uart的接收空閑中斷?

    我當前使用的是ESP-IDF.當uart接收不定長數(shù)據(jù)時,希望通過空閑中斷或者事件的方式來結(jié)束
    發(fā)表于 06-05 07:55

    如何實現(xiàn)一個軟件定時器?

    在Linux,uC/OS,F(xiàn)reeRTOS等操作系統(tǒng)中,都帶有軟件定時器,原理大同小異。典型的實現(xiàn)方法是:通過一個硬件定時器產(chǎn)生固定的時鐘節(jié)拍,每次硬件定時器
    的頭像 發(fā)表于 04-29 11:00 ?567次閱讀

    stm32f103通過UART_RX空閑中斷服務函數(shù)接收不定長數(shù)據(jù),運行一段時間后會進入HardFault_Handler的原因?

    目的:通過UART RX DMA + UART空閑中斷接收不定長數(shù)據(jù)。 描述:打開UART_RX_DMA
    發(fā)表于 04-26 06:43

    STM32F030串口用IDLE中斷接收不定長度數(shù)據(jù)包,中斷異常的原因?

    如題,在使用IDLE中斷接收不定長度的數(shù)據(jù)包,發(fā)現(xiàn)程序一直處于IDLE中斷中。程序如下 串口配置程序 void USART_Configu
    發(fā)表于 04-12 06:08

    用STM32F030F4串口空閑中斷接收不定長數(shù)據(jù),發(fā)生中斷后不知道如何計算接收到的字節(jié)數(shù)?

    我用STM32F030F4串口空閑中斷接收不定長數(shù)據(jù),發(fā)生中斷后不知道怎樣計算接收到的字節(jié)數(shù)。
    發(fā)表于 04-03 07:12

    stm32f103如何實現(xiàn)spi從機接收不定長數(shù)據(jù)?

    stm32f103 如何實現(xiàn)spi從機接收不定長數(shù)據(jù)數(shù)據(jù)首字節(jié)說明了數(shù)據(jù)長度) 求個思路或例程 用的HAL 庫
    發(fā)表于 03-28 07:47

    e2studio(28)----SPI 驅(qū)動WS2812燈珠

    本文介紹了如何使用RA微控制,結(jié)合E2STUDIO配置工具和SPI通訊接口,來驅(qū)動和控制WS2812 LED燈帶。這是一個集硬件連接、軟件配置和編程開發(fā)于一體的綜合性項目,目標是
    的頭像 發(fā)表于 12-01 16:48 ?1887次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(28)----SPI 驅(qū)動WS2812燈珠

    基于RASC的keil電子時鐘制作(RA)(7)----配置RTC時鐘及顯示時間

    本文將詳細講解如何借助e2studio來對微控制進行實時時鐘(RTC)的設置和配置,以便實現(xiàn)日歷功能和一秒鐘產(chǎn)生的中斷,從而
    的頭像 發(fā)表于 12-01 15:06 ?629次閱讀
    基于RASC的keil電子時鐘制作(<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA)(7)----配置RTC時鐘及顯示時間

    電子時鐘制作(RA)(6)----配置RTC時鐘及顯示時間

    本文將詳細講解如何借助e2studio來對微控制進行實時時鐘(RTC)的設置和配置,以便實現(xiàn)日歷功能和一秒鐘產(chǎn)生的中斷,從而
    的頭像 發(fā)表于 12-01 14:09 ?834次閱讀
    電子時鐘制作(<b class='flag-5'>瑞</b><b class='flag-5'>薩</b>RA)(6)----配置RTC時鐘及顯示時間