C语言实现循环缓冲fifo及总结

本文探讨了C语言如何实现循环缓冲fifo,强调其作为先进先出的数据结构,并指出在Linux系统下,循环缓冲fifo提供了免锁机制,提高了处理效率,特别适用于UART收发中断场景,避免频繁中断对CPU的影响。
摘要由CSDN通过智能技术生成

**循环缓冲fifo是先进先出的。生产者和消费者都只有一个,linux系统下使用提供了一种免锁的机制,处理时不用加锁。**UART下收发fifo主要是解决收发中断过于频繁,会导致CPU效率不高。

#include<stdio.h>

	struct  cycle_fifo_t
	{
		int *fifo_ptr;//数据缓冲的起始位置
		volatile int rd;//读指针的地址
		volatile int wr;//写指针的地址
		int fifo_buffer;//数据区的大小
	};
	enum isr_name_t
	{
		second = 0,//秒任务的中断
		button,    //按键的中断
	};

	enum isr_name_t isr_name;//中断向量名
	struct cycle_fifo_t isr_fifo;//中断向量的双向循环fifo
	
//
	void fifo_init(struct cycle_fifo_t *fifo, void *buffer, int len)
	{
		fifo->fifo_ptr = buffer;//指向同一片内存地址
		fifo->rd = 0;
		fifo->wr = 0;
		fifo->fifo_buffer = len;
	}  

	//往fifo里面存放中断向量名
	void fifo_put_byte(struct cycle_fifo_t *fifo, int isr_name)
	{
		//首先判断下fifo还有没有空间可以写
		if (fifo_get_free_byte(fifo))
		{
			fifo->fifo_ptr[fifo->wr] = isr_name;
		}

		if (++fifo->wr == fifo->fifo_buffer)//fifo缓存的内容写到头了,需要从头开始写
		{
			fifo->wr = 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值