加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
udp-piece.h 2.87 KB
一键复制 编辑 原始数据 按行查看 历史
LUCKY 提交于 2018-07-02 11:40 . 初始版本
#ifndef _UDP_PIECE_H_
#define _UDP_PIECE_H_
#ifdef __cplusplus
extern "C" {
#endif
#include <errno.h>
#include <stdint.h>
#include <stdio.h>
#include "circular_buffer.h"
#define HEAD_POS_SYNC_WORD 0 // 同步字
#define HEAD_POS_TOTAL_SIZE 2 // 所有分片数据的大小(不包括HEAD) //total data length of all pieces
#define HEAD_POS_TOTAL_PIECES 4 // 所有分片的数量
#define HEAD_POS_P_INDEX 6 // 分片序号,从0开始
#define HEAD_POS_P_LENGTH 8 // 当前分片数据的大小
#define HEAD_SIZE 12 // 头部大小
#define PIECE_FIX_SIZE 512 //每个分片数据最大字节数
typedef struct udp_piece
{
int recv_pieces; // 当前已经接收的分片数量
int total_size; // 总数据大小
int total_pieces; // 分片总数量
int left; // 最后一片的大小
int piece_size; // 分片大小
int recv_len; // 接收数据的长度
uint8_t *recv_buf; // 保存接收数据
uint8_t *send_ptr; // 指向发送数据的buffer
uint8_t piece_buf[PIECE_FIX_SIZE+HEAD_SIZE+1]; //单帧的buffer
circular_buffer_t *circular_buffer; // 环形缓存
}udp_piece_t;
/**
* @brief 初始化资源
* @param buf_size 设置环形缓冲区数据的最大长度
* @return 成功则返回一个句柄,失败则返回NULL
*/
udp_piece_t *udp_piece_init(int buf_size);
/**
* @brief 释放资源
* @param udp_piece 句柄
*/
void udp_piece_deinit(udp_piece_t *udp_piece);
/**
* @brief 重置,这里不会重新分配资源,只是讲部分参数重置到初始化状态
* @param udp_piece 句柄
*/
void udp_piece_reset(udp_piece_t *udp_piece);
/**
* @brief 根据长度进行切割,返回切割后的分片数量
* @param udp_piece 句柄
* @param buf 要分片数据的指针
* @param size 要分片数据的长度
* @return 返回分片的数量
*/
int udp_piece_cut(udp_piece_t *udp_piece, void *buf, int size);
/**
* @brief 根据分片编号获取切片指针及分片数据大小
* @param udp_piece 句柄
* @param index 分片编号
* @param got_piece_size 获取指定编号分片数据的长度
* @return 返回指定分片编号的数据指针
*/
uint8_t *udp_piece_get(udp_piece_t *udp_piece, int index, int *got_piece_size);
/**
* @brief 重组分片
* @param udp_piece 句柄
* @param buf 分片数据的指针
* @param size 分片数据的长度
* @return 返回-1则重组失败,返回0则正在重组中,返回1则重组成功
*/
int udp_piece_merge(udp_piece_t *udp_piece, void *buf, int size);
/**
* @brief 重组分片,使用环形缓存
* @param udp_piece 句柄
* @param buf 分片数据的指针
* @param size 分片数据的长度
* @return 返回-1则重组失败,返回0则正在重组中,返回1则重组成功
*/
int udp_piece_merge_ex(udp_piece_t *udp_piece, void *buf, int size);
#ifdef __cplusplus
}
#endif /* end of __cplusplus */
#endif
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化