0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

瑞萨e2studio----USRT通过定时器中断方式接收不定长数据

RA生态工作室 2021-11-02 17:21 次阅读
pYYBAGGA3i6Af0z4AABdWrtWoBM374.png

1.概述

本篇文章主要介绍如何使用e2studio对瑞萨单片机进行USRT通过定时器中断方式接收不定长数据。

2.硬件准备

首先需要准备一个开发板,这里我准备的是芯片型号 R7FA2L1AB2DFL 的开发板。

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重定向已经在上述文章中讲述,故可以查看往期文章进行学习。

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

11.回调函数user_uart_callback ()

设置接受到0xff则输出已经输入的数据。

若接收到新的数据,使用R_GPT_Reset进行充值定时器计数。

volatile bool uart_send_complete_flag = false;

uint8_t RxBuff[1];      //进入中断接收数据的数组
uint8_t DataBuff[5000]; //保存接收到的数据的数组
int RxLine=0;           //接收到的数据长度
int Rx_flag=0;                  //接受到数据标志
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++;                      //每接收到一个数据,进入回调数据长度加1
        DataBuff[RxLine-1]=RxBuff[0];  //把每次接收到的数据保存到缓存数组
        Rx_flag=1;
        if(RxBuff[0]==0xff)            //接收结束标志位,这个数据可以自定义,根据实际需求,这里只做示例使用,不一定是0xff
        {
            Rx_flag_finish=1;
        }
        RxBuff[0]=0;
        err = R_GPT_Reset(&g_timer0_ctrl);
        assert(FSP_SUCCESS == err);
    }
}

12.printf_usart打印函数

打印已经接受的数据以及其长度。


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无输入则输出已经输入的数据。

频率=时钟源/period,若设置计数时间为500ms一次,频率为1Hz,则period=48M/1=48000000

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

14.定时器回调函数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];      //进入中断接收数据的数组
uint8_t DataBuff[5000]; //保存接收到的数据的数组
int RxLine=0;           //接收到的数据长度
int Rx_flag=0;                  //接受到数据标志
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++;                      //每接收到一个数据,进入回调数据长度加1
        DataBuff[RxLine-1]=RxBuff[0];  //把每次接收到的数据保存到缓存数组
        Rx_flag=1;
        if(RxBuff[0]==0xff)            //接收结束标志位,这个数据可以自定义,根据实际需求,这里只做示例使用,不一定是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.发送数据,并且以0xff结尾

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

17.发送数据,延时500ms后打印

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

18.教学视频

视频教学稍后会在B站官方账号更新,请留意B站视频更新~

pYYBAGGBAquAWrKsAAAxP_X9ph8052.png


原文标题:瑞萨e2studio----USRT通过定时器中断方式接收不定长数据

文章出处:【微信公众号:RA生态工作室】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • mcu
    mcu
    +关注

    关注

    146

    文章

    17123

    浏览量

    350980
  • ARM
    ARM
    +关注

    关注

    134

    文章

    9084

    浏览量

    367381
  • 嵌入式
    +关注

    关注

    5082

    文章

    19104

    浏览量

    304797
收藏 人收藏

    评论

    相关推荐

    ethercat中断对程序中其他周期性中断的影响

    ethercat数据收发中断对程序中其他周期计时中断的影响要如何解决,周期中断
    发表于 11-21 18:34

    【代码分享】基于乐鑫ESP32的串口不定长数据接收方法

    【代码分享】基于乐鑫ESP32的串口不定长数据接收方法
    的头像 发表于 11-15 01:02 388次阅读
    【代码分享】基于乐鑫ESP32的串口<b class='flag-5'>不定长</b><b class='flag-5'>数据</b><b class='flag-5'>接收</b>方法

    e2studio(1)----芯片之搭建FSP环境

    视频教学 样品申请 请勿添加外链 e2studio软件 e2studio的集成开发环境,FSP 提供了众多可提高效率的工具,用于开发针对
    发表于 09-30 15:28

    单片机PWM输出

    如何通过e2-studio配置GPT定时器输出指定数量PWM后停止输出
    发表于 09-19 10:01

    STM32CUBEMX(8)--USART通过定时器中断方式接收不定长数据

    概述 本文利用中断实现串口不定长接收(非DMA),使用HAL库,将接收数据打印出去。 DMA接收
    发表于 09-06 16:48

    STM32CUBEMX(2)--USART通过DMA方式接收不定长数据

    概述 直接存储访问(DMA)用于在外设与存储之间以及存储与存储之间提供高速数据传输。可以在无需任何CPU操作的情况下
    发表于 09-04 11:48

    如何使用e2studio单片机进行GPIO输出

    本篇文章主要介绍如何使用e2studio单片机进行GPIO输出,并以LED显示。
    的头像 发表于 07-30 16:12 649次阅读
    如何使用<b class='flag-5'>e2studio</b>对<b class='flag-5'>瑞</b><b class='flag-5'>萨</b>单片机进行GPIO输出

    定时器的工作方式介绍

    定时器是计算机和嵌入式系统中常见的一种硬件模块,用于实现定时和计数功能。定时器的工作方式通常由一组寄存来控制,这些寄存
    的头像 发表于 07-12 10:29 898次阅读

    请问如何实现ESP32 uart的接收空闲中断

    我当前使用的是ESP-IDF.当uart接收不定长数据时,希望通过空闲中断或者事件的方式来结束
    发表于 06-05 07:55

    求助,关于定时器判断串口接收问题求解

    时,Tim3Flag回变成2(初始为0),以后中断接收一帧数据,Tim3Flag加1, 这个第一次为什么Tim3Flag回加2? 这就是
    发表于 05-15 07:32

    如何实现一个软件定时器

    在Linux,uC/OS,FreeRTOS等操作系统中,都带有软件定时器,原理大同小异。典型的实现方法是:通过一个硬件定时器产生固定的时钟节拍,每次硬件定时器
    的头像 发表于 04-29 11:00 631次阅读

    stm32f103通过UART_RX空闲中断服务函数接收不定长数据,运行一段时间后会进入HardFault_Handler的原因?

    目的:通过UART RX DMA + UART空闲中断接收不定长数据。 描述:打开UART_RX_DMA
    发表于 04-26 06:43

    STM32F030串口用IDLE中断接收不定长度数据包,中断异常的原因?

    如题,在使用IDLE中断接收不定长度的数据包,发现程序一直处于IDLE中断中。程序如下 串口配置程序 void USART_Configu
    发表于 04-12 06:08

    用STM32F030F4串口空闲中断接收不定长数据,发生中断后不知道如何计算接收到的字节数?

    我用STM32F030F4串口空闲中断接收不定长数据,发生中断后不知道怎样计算接收到的字节数。
    发表于 04-03 07:12

    stm32f103如何实现spi从机接收不定长数据

    stm32f103 如何实现spi从机接收不定长数据数据首字节说明了数据长度) 求个思路或例程 用的HAL 库
    发表于 03-28 07:47