您的位置:首页 > 娱乐 > 八卦 > MCU的环形FIFO

MCU的环形FIFO

2024/10/8 12:52:44 来源:https://blog.csdn.net/JasonKyro/article/details/139550139  浏览:    关键词:MCU的环形FIFO

fifo.h

#ifndef __FIFO_H
#define __FIFO_H#include "main.h"#define RINGBUFF_LEN	(500)     //定义最大接收字节数 500typedef struct
{uint16_t Head;   										// 头指针 指向可读起始地址  每读一个,数字+1uint16_t Tail;											// 尾指针	指向可写的起始地址	 每写一个,数字+1,当尾指针超过数组大小,// 则尾指针又指向数组首地址。uint16_t Lenght;										// 长度uint8_t  Ring_data[RINGBUFF_LEN];		// 数据缓冲区
}RingBuff_t;uint16_t getRingBuffLenght(RingBuff_t *ringBuff);    // 获取缓冲区长度
void initRingBuff(RingBuff_t *ringBuff);
void writeRingBuff(RingBuff_t *ringBuff,uint8_t data);									 // 写入对应数据
void deleteRingBuff(RingBuff_t *ringBuff,uint16_t size);               // 删除对应长度的数据
uint8_t readRingBuff(RingBuff_t *ringBuff,uint16_t position);    // 读取对应位的数据/*   使用示例1.创建环形队列句柄RingBuff_t _ringBuff2.初始化initRingBuff(&_ringBuff);	3.添加数据HAL_UART_Receive_IT(&huart2,&_RxBuff[0],1);			// 打开串口中断	writeRingBuff(&_ringBuff,tjc_RxBuff[0]);4. 数据包解析#define FRAMELENGTH 6  // 数据包的长度void DataAnalysis()
{while(getRingBuffLenght(&tjc_ringBuff) >= FRAMELENGTH)    // 如果以及接收的数据长于数据包的长度{//校验帧头帧尾是否匹配if(readRingBuff(&tjc_ringBuff,0) != 0x55 ||readRingBuff(&tjc_ringBuff,4) != 0xff || readRingBuff(&tjc_ringBuff,5) != 0xff){deleteRingBuff(&tjc_ringBuff,1);									//不匹配删除1字节}else												  //匹配{																											// 数据处理 开始	 switch (readRingBuff(&tjc_ringBuff,1))			// 判断页面和控件{case 0x10:				// 左右break;default:break;}// 数据处理 结束		deleteRingBuff(&tjc_ringBuff,FRAMELENGTH);							// 删除对应数据包的break;}}
}*/#endif

fifo.c

#include <stdint.h>
#include <stdio.h>
#include <stdarg.h>
#include <stddef.h>
#include <string.h>
#include <stdlib.h>
#include <fifo.h>/********************************************************
函数名:  	initRingBuff
功能:    	初始化环形缓冲区
输入参数:
返回值: 		void
修改记录:
**********************************************************/
void initRingBuff(RingBuff_t *ringBuff)
{//初始化相关信息ringBuff->Head = 0;ringBuff->Tail = 0;ringBuff->Lenght = 0;
}/********************************************************
函数名:  	writeRingBuff
功能:    	往环形缓冲区写入数据  每次写入一个数据
**********************************************************/
void writeRingBuff(RingBuff_t *ringBuff,uint8_t data)
{if(ringBuff->Lenght >= RINGBUFF_LEN) 								//判断缓冲区是否已满{return ;}ringBuff->Ring_data[ringBuff->Tail]=data;							//写入到尾数据ringBuff->Tail = (ringBuff->Tail+1)%RINGBUFF_LEN;			//防止越界非法访问 Tail=RINGBUFF_LEN 就为0//如果Tail指针已经到达缓冲区的末尾,那么Tail+1就会变成0   ringBuff->Lenght++;}																	// 数据长度+1/********************************************************
函数名:  	deleteRingBuff
功能:    	删除串口缓冲区中相应长度的数据  从头删除指定长度
输入参数:	要删除的长度
**********************************************************/
void deleteRingBuff(RingBuff_t *ringBuff, uint16_t size)
{if(size >= ringBuff->Lenght)        // 确保小于以有数据{initRingBuff(ringBuff);return;}for(int i = 0; i < size; i++){if(ringBuff->Lenght == 0)//判断非空{initRingBuff(ringBuff);return;}ringBuff->Head = (ringBuff->Head+1)%RINGBUFF_LEN;//防止越界非法访问ringBuff->Lenght--;}
}/********************************************************
函数名:  	readRingBuff
功能:    	从串口缓冲区读取1字节数据
输入参数:		position:读取的位置
返回值: 		所在位置的数据(1字节)  
**********************************************************/
uint8_t readRingBuff(RingBuff_t *ringBuff, uint16_t position)
{uint16_t realPosition = (ringBuff->Head + position) % RINGBUFF_LEN;return ringBuff->Ring_data[realPosition];
}/********************************************************
函数名:  	getRingBuffLenght
功能:    	获取串口缓冲区的数据数量
返回值: 		串口缓冲区的数据数量
**********************************************************/
uint16_t getRingBuffLenght(RingBuff_t *ringBuff)
{return ringBuff->Lenght;
}/********************************************************
函数名:  	isRingBuffOverflow
功能:    	判断环形缓冲区是否已满
返回值: 		1:环形缓冲区已满 , 2:环形缓冲区未满
**********************************************************/
uint8_t isRingBuffOverflow(RingBuff_t *ringBuff)
{return ringBuff->Lenght == RINGBUFF_LEN;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com