/*
 * ring_queue.h
 *
 *  Created on: 2024年6月21日
 *      Author: psx
 */

#ifndef DRIVERS_RINGQUEUE_RING_QUEUE_H_
#define DRIVERS_RINGQUEUE_RING_QUEUE_H_


//#define RING_QUEUE_DEBUG //定义本宏会打印RingQueue的调试信息

#define RQ_OK 1
#define RQ_ERROR 0
#define RQ_OVERFLOW -2
typedef unsigned char RQ_ElementType;//元素类型

typedef struct _ring_queue
{
    RQ_ElementType *elems;
    int size;
    volatile int front, rear;
}RingQueue;

//初始化队列,需传入保存队列状态的结构q,队列使用的buffer和buffer大小
int InitRingQueue(RingQueue *q, RQ_ElementType *buff, int size);

#define RingQueueFull(q) (((q)->rear+1) % (q)->size == (q)->front)
#define RingQueueEmpty(q) ((q)->front == (q)->rear)


//遍历队列,
//消费者使用,故对生产者可能修改的rear先读取缓存
int ShowRingQueue(RingQueue *q);

//向队尾插入元素e
int InRingQueue(RingQueue *q,RQ_ElementType e);

//从队首删除元素
int OutRingQueue(RingQueue *q, RQ_ElementType *e);

//队列中的元素个数
int RingQueueLength(RingQueue *q);


#endif /* DRIVERS_RINGQUEUE_RING_QUEUE_H_ */