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

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

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

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

嵌入式單片機MCU開發(fā) ? 來源:嵌入式單片機MCU開發(fā) ? 作者:嵌入式單片機MCU開 ? 2022-11-15 11:19 ? 次閱讀

概述

本篇文章主要介紹如何使用e2studio對瑞薩單片機進行USRT通過定時器中斷方式接收不定長數(shù)據(jù)。 需要樣片的可以加qun申請:6_15061293 。

完整代碼下載

https://download.csdn.net/download/qq_24312945/84995168

樣品申請

https://www.wjx.top/vm/wBbmSFp.aspx#

硬件準備

首先需要準備一個開發(fā)板,這里我準備的是芯片型號R7FAM2AD3CFP的開發(fā)板: 在這里插入圖片描述

樣品申請

https://www.wjx.top/vm/wBbmSFp.aspx#

新建工程

在這里插入圖片描述

工程模板

在這里插入圖片描述

保存工程路徑

在這里插入圖片描述

芯片配置

本文中使用R7FA4M2AD3CFP來進行演示。 在這里插入圖片描述

工程模板選擇

在這里插入圖片描述

時鐘設(shè)置

開發(fā)板上的外部高速晶振為12M,需要修改XTAL為12M. 在這里插入圖片描述

UART配置

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

在這里插入圖片描述

UART屬性配置

由于開發(fā)板的typc-c接口所接的是串口9,故配置為通道9。 在這里插入圖片描述

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

發(fā)送完畢可以用UART_EVENT_TX_COMPLETE進行判斷。 在這里插入圖片描述

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;
    }
}

設(shè)置e2studio堆棧

在這里插入圖片描述

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

在這里插入圖片描述 C++ 構(gòu)建->設(shè)置->GNU ARM Cross C Linker->Miscellaneous去掉Other linker flags中的 “--specs=rdimon.specs”

在這里插入圖片描述

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_uart9_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;ireturn size;
}

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

設(shè)置接受到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);
    }
}

printf_usart打印函數(shù)

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

void printf_usart(void)
{

    printf("length=%d
",RxLine);
    for(int i=0;iprintf("data:[%d] = 0x%x
",i,DataBuff[i]);
    memset(DataBuff,0,sizeof(DataBuff));  //清空緩存數(shù)組
    //memset()作用:可以方便的清空一個結(jié)構(gòu)類型的變量或數(shù)組。
    //例句:memset(aTxbuffer,0,sizeof(aTxbuffer))  用memset清空aTxbuffer。
    RxLine=0;  //清空接收長度
    Rx_flag_finish=0;
    Rx_flag = 0;
}

定時器設(shè)置

點擊Stacks->New Stack->Driver->Timers -> Timers Driver on r_gpt。 在這里插入圖片描述 設(shè)置500ms無輸入則輸出已經(jīng)輸入的數(shù)據(jù)。 頻率=時鐘源/period,若設(shè)置計數(shù)時間為500ms一次,頻率為2Hz,則period=50M/2=25000000 在這里插入圖片描述

定時器回調(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;
            }
        }
}

完整代碼

#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;ireturn size;
}
/* 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;
            }
        }
}
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
",RxLine);
    for(int i=0;i"data:[%d] = 0x%x
",i,DataBuff[i]);
    memset(DataBuff,0,sizeof(DataBuff));  //清空緩存數(shù)組
    //memset()作用:可以方便的清空一個結(jié)構(gòu)類型的變量或數(shù)組。
    //例句:memset(aTxbuffer,0,sizeof(aTxbuffer))  用memset清空aTxbuffer。
    RxLine=0;  //清空接收長度
    Rx_flag_finish=0;
    Rx_flag = 0;
}

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

在這里插入圖片描述

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

在這里插入圖片描述

審核編輯:湯梓紅

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

    關(guān)注

    35

    文章

    22309

    瀏覽量

    86304
  • 定時器
    +關(guān)注

    關(guān)注

    23

    文章

    3248

    瀏覽量

    114792
  • uart
    +關(guān)注

    關(guān)注

    22

    文章

    1235

    瀏覽量

    101387
收藏 人收藏

    評論

    相關(guān)推薦

    CW32L083串口中斷+定時器實現(xiàn)不定長數(shù)據(jù)接收

    CW32L083 用串口中斷定時器中斷實現(xiàn)串口的不定長數(shù)據(jù)接收,特別適用于AT指令的
    的頭像 發(fā)表于 07-12 09:00 ?2018次閱讀
    CW32L083串口<b class='flag-5'>中斷</b>+<b class='flag-5'>定時器</b>實現(xiàn)<b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b><b class='flag-5'>接收</b>

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

    本文利用中斷實現(xiàn)串口不定長接收(非DMA),使用HAL庫,將接收數(shù)據(jù)打印出去。
    的頭像 發(fā)表于 11-14 16:31 ?1420次閱讀
    STM32CUBEMX(8)--USART<b class='flag-5'>通過</b><b class='flag-5'>定時器</b><b class='flag-5'>中斷</b><b class='flag-5'>方式</b><b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>

    e2studio(2)----GPIO輸出

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

    e2studio(3)----GPIO輸入檢測

    本篇文章主要介紹如何使用e2studio單片機進行GPIO輸出,并以LED顯示。
    的頭像 發(fā)表于 11-14 20:15 ?2794次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(3)----GPIO輸入檢測

    e2studio(8)----PWM

    本篇文章主要介紹如何使用e2studio單片機進行PWM輸出。
    的頭像 發(fā)表于 11-15 10:43 ?1183次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(8)----PWM

    e2studio(9)----EXIT

    本篇文章主要介紹如何使用e2studio單片機進行EXIT檢測,之后通過按鍵形式以及燈的亮滅形式進行演示。
    的頭像 發(fā)表于 11-15 10:53 ?1077次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(9)----EXIT

    e2studio(10)----DAC

    本篇文章主要介紹如何使用e2studio單片機進行DAC輸出。
    的頭像 發(fā)表于 11-15 10:59 ?1004次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(10)----DAC

    e2studio(13)----定時器AGT配置PWM輸出

    本篇文章主要介紹如何使用e2studio單片機進行定時器AGT配置PWM輸出。
    的頭像 發(fā)表于 11-15 11:31 ?1476次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(13)----<b class='flag-5'>定時器</b>AGT配置PWM輸出

    e2studio(14)----定時器GPT配置輸入捕獲

    本篇文章主要介紹如何使用e2studio單片機定時器輸入捕獲,同時輸入一個PWM驗證是否正確。
    的頭像 發(fā)表于 11-15 11:54 ?1324次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(14)----<b class='flag-5'>定時器</b>GPT配置輸入捕獲

    e2studio(7)----ADC通過單次掃描多通道方式采樣

    本篇文章主要介紹如何使用e2studio單片機進行ADC通過單次掃描多通道方式采樣。
    的頭像 發(fā)表于 11-18 10:45 ?1436次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>(7)----ADC<b class='flag-5'>通過</b>單次掃描多通道<b class='flag-5'>方式</b>采樣

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

    本篇文章主要介紹如何使用e2studio單片機進行USRT通過定時器
    的頭像 發(fā)表于 11-02 17:21 ?1551次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio----USRT</b><b class='flag-5'>通過</b><b class='flag-5'>定時器</b><b class='flag-5'>中斷</b><b class='flag-5'>方式</b><b class='flag-5'>接收</b><b class='flag-5'>不定長</b><b class='flag-5'>數(shù)據(jù)</b>

    e2studio----外部中斷&amp;amp;amp;amp;定時器配置輸入捕獲測量頻率

    本篇文章主要介紹如何使用e2studio單片機外部中斷進行輸入捕獲,同時通過定時器計算其頻
    的頭像 發(fā)表于 11-11 18:38 ?1511次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>----外部<b class='flag-5'>中斷</b>&amp;amp;amp;amp;<b class='flag-5'>定時器</b>配置輸入捕獲測量頻率

    e2studio----定時器GPT配置輸入捕獲

    本篇文章主要介紹如何使用e2studio單片機定時器輸入捕獲,同時輸入一個PWM驗證是否正確。
    的頭像 發(fā)表于 11-11 18:38 ?1373次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>----<b class='flag-5'>定時器</b>GPT配置輸入捕獲

    e2studio----定時器AGT配置PWM輸出

    本篇文章主要介紹如何使用e2studio單片機進行定時器AGT配置PWM輸出。
    的頭像 發(fā)表于 11-11 18:37 ?1423次閱讀
    <b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e2studio</b>----<b class='flag-5'>定時器</b>AGT配置PWM輸出

    使用e2 studio FSP基于RA2E1定時器配置PWM輸出

    使用e2 studio FSP基于RA2E1定時器配置PWM輸出
    的頭像 發(fā)表于 08-01 00:13 ?727次閱讀
    使用<b class='flag-5'>瑞</b><b class='flag-5'>薩</b><b class='flag-5'>e</b>2 <b class='flag-5'>studio</b> FSP基于RA<b class='flag-5'>2E</b>1<b class='flag-5'>定時器</b>配置PWM輸出