代码拉取完成,页面将自动刷新
/**
* @file queue.h
* @brief Create by AnKun on 2019/10/30
* @version 1.0.0
*/
#ifndef __QUEUE_H_
#define __QUEUE_H_
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
#include <stdbool.h>
/// 队列控制结构体
typedef struct
{
uint32_t read; ///< 读指针
uint32_t write; ///< 写指针
uint32_t size; ///< 队列大小(字节)
uint8_t* payload; ///< 队列负载数据
void (*lock)(void);
void (*unlock)(void);
} Queue, *QueuePtr;
/// 对齐四字节并预留出空间
#define QALIGN4(size) (((size + 5) >> 2) << 2)
/// 函数倒出
uint32_t Queue_GetSize(const QueuePtr queue);
uint32_t Queue_GetUsed(const QueuePtr queue);
uint32_t Queue_GetFree(const QueuePtr queue);
uint32_t Queue_Write(QueuePtr queue, const void* buf, uint32_t length);
uint32_t Queue_Read(QueuePtr queue, void* buf, uint32_t length);
void Queue_Clear(QueuePtr queue);
void Queue_Init(QueuePtr queue, uint32_t size, void* payload, void (*lock)(void), void(*unlock)(void));
void Queue_Destory(QueuePtr queue);
bool Queue_isFull(const QueuePtr queue);
bool Queue_isEmpty(const QueuePtr queue);
QueuePtr Queue_Create(uint32_t size, void (*lock)(void), void(*unlock)(void));
bool Queue_ReadByte(QueuePtr queue, uint8_t* dat);
bool Queue_WriteByte(QueuePtr queue, uint8_t dat);
void Queue_UndoRead(const QueuePtr queue, uint32_t len);
void Queue_UndoWrite(const QueuePtr queue, uint32_t len);
#endif // __QUEUE_H_
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。