USART与USB接收不定数据方法,标准库、HAL库都适用

很多时候,我们使用串口或USB接收数据时,往往不知道PC端会发多长的数据下来,

为了解决这个不定数据接收问题,在此各提供一个解决思路。

串口数据不定接收:

  由于STM32单片机带IDLE中断,所以利用这个中断,可以接收不定长字节的数据,

由于STM32属于ARM单片机,所以这篇文章的方法也适合其他的ARM单片机。

IDLE就是串口收到一帧数据后,发生的中断。什么是一帧数据呢?比如说给单片机一

次发来1个字节,或者一次发来8个字节,这些一次发来的数据,就称为一帧数据,也可以

叫做一包数据。

还有一个RXNE中断,当接收到1个字节,就会产生RXNE中断,当接收到一帧数据,就

会产生IDLE中断。比如给单片机一次性发送8个字节,就会产生8次RXNE中断,1次IDLE中断。

这里只写RXNE中断例子,IDLE中断的类似,只是寄存器地址不同,各位可以查手册编写。

eg:

  在中断服务函数里添加一下代码,函数外部定义 buff[ ] 和 i=0 ; 我这里使用的是串口1:

  if(UASART_GetITStatus(UASART1, UASART_IT_RXNE != RESET)) //接收一个字节判断

  {

    buff [i++] = UASART1->DR;       //把接收到的字节保存到数组后,数组下标自加1

  }

  就这么几句代码就可以实现了,buff[ ],就是接收到的数据,i-1 就是数据长度了

=======================================================================

USB不定数据接收:

usb不定数据接收,利用了定时器作为校验来接收,这个方法通用性强,适用于uasart

也适用于usb,还使用于hal库。不过这个方法有一个局限性,就是PC端发送数据过来的时间

间隔不可以太短,否则会出现误判情况。

定时器方法的原理是:先定时一个时间间隔合适的时间,一般几毫秒就可以了,然后在

接收服务函数里把接收到的数据存到buff[ ],i++,接着定时器计数值清0,打开定时器,如果

数据没接受完,每次接收都清空了定时器计数器,使得定时器无法进入定时器中断。如果数据

接收完成了,则过不会清空定时器计数器,进入定时器中断,此时则判断数据已经接收完成,

可以在定时器中断中取出数据和数据长度。

       eg:

这里我是用HAL库作为例子,在usbd_cdc_if.c文件中找到USB接收中断服务函数,在里面

修改代码即可。

  

  

  

  

因为usb发送,每发送最大包是64个字节,而且usb接收可以自己算出接收长度,不过超

过64字节就会出错,所以我这里进行了一个最大包处理。

原文地址:https://www.cnblogs.com/xingboy/p/9415653.html

时间: 2024-08-24 19:20:58

USART与USB接收不定数据方法,标准库、HAL库都适用的相关文章

APUE读书笔记-第五章 标准I/O库

今天草草的把第四章结了,后面的内容分析的也不是很详细,就连书中的例子都没有怎么实验,还是等以后有机会吧. 从5.3节开始研究起吧,这一节主要谈了一个进程预定义的3个流,分别是标准输入.标准输出和标准错误,通过stdin.stdout.stderr引用.这里要和进程中的文件描述符STDIN_FILENO.STDOUT_FILENO.STDERR_FILENO相区分. /* Standard streams. */ extern struct _IO_FILE *stdin; /* Standard

UNIX环境高级编程---标准I/O库

前言:我想大家学习C语言接触过的第一个函数应该是printf,但是我们真正理解它了吗?最近看Linux以及网络编程这块,我觉得I/O这块很难理解.以前从来没认识到Unix I/O和C标准库I/O函数压根不是一码事.Unix I/O也叫低级I/O,也叫Unbuffered I/O,是操作系统内核部分,也是系统调用:而C标准I/O函数相对也成Buffered I/O,高级I/O,一般是为了效率考虑对这些系统调用的封装.以前使用getchar()经常为输入完后的回车而出错.那是不理解标准I/O实现时的

STM32F4 UART1 DMA发送和接收不定长度数据

STM32F4 串口收发使用DMA还是很方便的.但是配置DMA时需要配置数据长度,这一点对于发送来说可以预估计自己发送的长度来配置DMA发送数据长度,但是对于接收不是很好解决,因为如果使用DMA接收中断是要配置的数据长度减到0才能出发中断.但是我们无法判断接受数据的长度,导致无法判断数据接收完成.网上有提出的解决方法是用定时器固定周期的读DMA接收的长度来判断是否接收完成,也有使用UART的空闲中断来处理的.在这里我使用UART的空闲中断来处理接收不定长数据.当然也要打开DMA接收完成中断,处理

stm32 usb数据接收与数据发送程序流程分析

http://blog.csdn.net/u011318735/article/details/17424349 既然学习了USB,那就必须的搞懂USB设备与USB主机数据是怎么通讯的.这里主要讲设备端,因为我们的代码是做USB设备用的. 我们需要必须要定义了USB中断.起始在STM32的中断向量表中给USB两个中断,我们可以在stm32f10x.h中找到这两个中断: USB_HP_CAN1_TX_IRQn = 19, /*!< USB Device High Priority or CAN1

ThinkPHP中使用ajax接收json数据的方法

本文实例讲述了ThinkPHP中使用ajax接收json数据的方法.分享给大家供大家参考.具体分析如下: 这里通过ThinkPHP+jquery实现ajax,扩展了下,写了个查询,前台代码如下: 首先需要引入jquery.js,主要代码如下: 1 function ajax(id,pic){ 2 3 //由于ThinkPHP不解析JavaScript里的ThinkPHP常量,所以需要先在这里定义. 4 5 var URL='__URL__'; 6 7 $.ajax({ 8 9 url: URL+

Python3的tcp socket接收不定长数据包接收到的数据不全。

Python Socket API参考出处:http://blog.csdn.net/xiangpingli/article/details/47706707 使用socket.recv(pack_length)接收不定长的数据,如果数据包长度超过一定值,则接收的数据不全. 参照python3.4的文档可发现: socket.recv(bufsize[, flags]) Receive data from the socket. The return value is a bytes objec

STM32CubeMX HAL库串口+DMA数据发送不定长度数据接收

参考资料:1.ST HAL库官网资料 2.https://blog.csdn.net/u014470361/article/details/79206352#comments 一.STM32CubeMX配置外部时钟 注意在进行外部时钟配置时,即"High Speed Clock"和"Low Speed Clock"需配置成"Crytal/Ceramic Resonator(低温/陶瓷谐振器)"不能配置为"BYASS Clock Sour

详述USB OTG发展及协议标准

USB On-The-Go 扩大了USB 的应用领域,将USB 从传统的PC 与外设通讯的模式,扩展到移动电子和嵌入式领域中,抛开主机PC,实现通常的外设与外设之间点对点(Point to Point)的数据传输模式. 1 什么是USB On-The-Go 我们先来回顾一下通用串行总线(Universal Serial Bus,简称为USB)发展的历史: i)1994 年11 月,以Intel 为首的7 家公司(Intel.Compaq.Microsoft.IBM.DEC.Northern Te

VC++ 6.0 C8051F340 USB 通信 CAN 数据解析

// HelloWorld.cpp : Defines the entry point for the console application. // /***************************************************************************** * VC++ 6.0 C8051F340 USB 通信 CAN 数据解析 * 声明: * 1. 这是在<VC++ 6.0 C8051F340 USB PC侧通信 Demo>的基础上的代码: