2023-05-18 00:58:26 +00:00
|
|
|
|
/*
|
|
|
|
|
* @Author: murmur test@test.com
|
|
|
|
|
* @Date: 2023-05-05 10:07:30
|
|
|
|
|
* @LastEditors: murmur test@test.com
|
|
|
|
|
* @LastEditTime: 2023-05-11 16:34:31
|
|
|
|
|
* @FilePath: \TT12-MCU\applications\ttmsg\ttmsg.c
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @Description:
|
|
|
|
|
*
|
|
|
|
|
* Copyright (c) 2023 by ${git_name_email}, All Rights Reserved.
|
2023-05-18 00:58:26 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// #include <dfs_file.h>
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
|
|
|
|
#define LOG_TAG "ttmsg"
|
2023-06-20 10:09:07 +00:00
|
|
|
|
#define LOG_LVL LOG_LVL_DBG
|
2023-05-11 03:33:47 +00:00
|
|
|
|
#include <ulog.h>
|
|
|
|
|
|
|
|
|
|
#include "ttmsg.h"
|
2023-05-29 12:49:30 +00:00
|
|
|
|
#include <board.h>
|
2023-05-30 08:53:31 +00:00
|
|
|
|
#include <ttTR.h>
|
2023-06-01 02:23:08 +00:00
|
|
|
|
#include <cfg.h>
|
2023-06-16 03:18:52 +00:00
|
|
|
|
|
|
|
|
|
extern struct rt_event tcp_chk;//tcp条件
|
|
|
|
|
|
|
|
|
|
|
2023-05-11 03:33:47 +00:00
|
|
|
|
/**
|
|
|
|
|
* @brief 按指定分隔符分割字符串
|
|
|
|
|
*
|
|
|
|
|
* @param str 待分割字符串
|
|
|
|
|
* @param deli 分隔符
|
|
|
|
|
* @param out 输出字符串数组
|
|
|
|
|
* @return size_t 分割后字符串个数
|
|
|
|
|
*/
|
2023-05-23 06:59:35 +00:00
|
|
|
|
#ifdef USE_STRTOK
|
2023-05-18 00:58:26 +00:00
|
|
|
|
static size_t split(const char *str, const char *deli, char (*out)[STR_LEN_MAX])
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
2023-05-23 06:59:35 +00:00
|
|
|
|
char buf[50];
|
|
|
|
|
strcpy(buf, str); // strtok会修改字符串
|
|
|
|
|
char *token = strtok(buf, deli);
|
|
|
|
|
char *rst[STR_LEN_MAX];
|
|
|
|
|
|
|
|
|
|
size_t i = 0;
|
|
|
|
|
while (token)
|
|
|
|
|
{
|
|
|
|
|
rst[i++] = token;
|
|
|
|
|
token = strtok(NULL, deli);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 更新out
|
|
|
|
|
for (size_t ii = 0; ii < i; ii++)
|
|
|
|
|
{
|
|
|
|
|
// out[ii] = id[ii];
|
|
|
|
|
strcpy(out[ii], rst[ii]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return i;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
2023-05-23 06:59:35 +00:00
|
|
|
|
#else
|
|
|
|
|
// strtok_r版本
|
2023-05-29 12:49:30 +00:00
|
|
|
|
static size_t split(const char *str, const char *delim, rt_uint8_t (*out)[STR_LEN_MAX])
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
|
|
|
|
char buf[50];
|
|
|
|
|
strcpy(buf, str); // strtok会修改字符串
|
|
|
|
|
|
|
|
|
|
char *token = NULL;
|
|
|
|
|
char *saveptr = NULL;
|
|
|
|
|
char *rst[STR_LEN_MAX];
|
|
|
|
|
int idx = 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
token = strtok_r(buf, delim, &saveptr);
|
|
|
|
|
while (token)
|
|
|
|
|
{
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// LOG_D("---%s---",token);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
rst[idx++] = token;
|
|
|
|
|
token = strtok_r(NULL, delim, &saveptr);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 更新out
|
|
|
|
|
for (size_t ii = 0; ii < idx; ii++)
|
|
|
|
|
{
|
|
|
|
|
// out[ii] = id[ii];
|
|
|
|
|
strcpy(out[ii], rst[ii]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return idx;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief 从文件名字符串提取ID
|
|
|
|
|
*
|
|
|
|
|
* @param fin 文件名,支持路径
|
|
|
|
|
* @param out 提取结果
|
|
|
|
|
* @return size_t ID长度
|
|
|
|
|
*/
|
2023-05-29 12:49:30 +00:00
|
|
|
|
static size_t getID(const char *str, rt_uint8_t *out)
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
2023-05-23 06:59:35 +00:00
|
|
|
|
char id[10][STR_LEN_MAX] = {};
|
|
|
|
|
// 分割路径
|
|
|
|
|
size_t len = split(str, "/", id);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// 分割后缀
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// LOG_D("file is %s",id[len-1]);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
len = split(id[len - 1], ".", id);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// 分割时间
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// LOG_D("file name is %s",id[0]);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
len = split(id[0], "_", id);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
unsigned char tmp[len];
|
|
|
|
|
for (size_t i = 0; i < len; i++)
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
2023-05-23 06:59:35 +00:00
|
|
|
|
unsigned int v = atoi(id[i]);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// 去除代表20的2000
|
|
|
|
|
if (v > 0xff)
|
|
|
|
|
{
|
|
|
|
|
v = v - 2000;
|
|
|
|
|
}
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
tmp[i] = v;
|
|
|
|
|
}
|
|
|
|
|
LOG_HEX("file ID",16,tmp,len);
|
|
|
|
|
memcpy(out, tmp, len);
|
|
|
|
|
return len;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2023-05-18 00:58:26 +00:00
|
|
|
|
* @brief 根据配置初始化MSG
|
|
|
|
|
* @param *tpl MSG结构体
|
|
|
|
|
* @param fin 文件名,由时间戳和随机码组成,作为数据包唯一ID
|
2023-05-11 03:33:47 +00:00
|
|
|
|
* @param flag 参数配置,如信息类型、压缩方式、加密方式等
|
2023-05-18 00:58:26 +00:00
|
|
|
|
* @return 成功返回0
|
2023-05-11 03:33:47 +00:00
|
|
|
|
*/
|
2023-05-29 12:49:30 +00:00
|
|
|
|
rt_uint8_t packInit(MSG *tpl, const rt_uint8_t *fin, rt_uint8_t flag)
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// memset(tpl, 0, sizeof(MSG)); // 分配空间
|
|
|
|
|
// 模板
|
|
|
|
|
MSG msgs_tpl = {
|
|
|
|
|
.fstart = {0x88, 0xAA, 0xBB, 0x88},
|
|
|
|
|
.fnum = {0x00, 0x01},
|
|
|
|
|
.fbak = {0x00, 0x02},
|
|
|
|
|
.ftype = {
|
|
|
|
|
0x70, 0x21},
|
|
|
|
|
.fdlen = {0x00, 0x00},
|
|
|
|
|
|
|
|
|
|
.ftccid = {0x37, 0x32, 0x32, 0x32},
|
|
|
|
|
|
|
|
|
|
.fcfg = flag,
|
2023-05-11 03:33:47 +00:00
|
|
|
|
};
|
2023-05-23 06:59:35 +00:00
|
|
|
|
rt_memcpy(tpl, &msgs_tpl, sizeof(MSG));
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
size_t len = getID(fin, tpl->findex);
|
|
|
|
|
if (len != 7)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("file name %s format error", fin);
|
|
|
|
|
return RT_ERROR;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-18 00:58:26 +00:00
|
|
|
|
return RT_EOK;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @description: 按MSG帧格式拼接din数据后输出到dout
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @param *p_msg MSG格式配置文件
|
2023-05-11 03:33:47 +00:00
|
|
|
|
* @param {rt_uint8_t} *din 待打包数据
|
|
|
|
|
* @param {rt_uint8_t} len 待打包数据长度
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @param {rt_uint8_t} *dout 打包后数据
|
2023-05-11 03:33:47 +00:00
|
|
|
|
* @return {*} 打包后数据总长度
|
|
|
|
|
*/
|
2023-05-18 00:58:26 +00:00
|
|
|
|
rt_uint8_t packMsg(MSG *p_msg, rt_uint8_t *din, rt_uint8_t len, rt_uint8_t *dout)
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
rt_uint8_t fralen = sizeof(MSG) + len; // len of current frame
|
2023-05-11 03:33:47 +00:00
|
|
|
|
// 计算各字段
|
2023-05-23 06:59:35 +00:00
|
|
|
|
p_msg->fdlen[0] = 0; // 单包长度必不会超过0xFF,故高字节始终为0
|
|
|
|
|
p_msg->fdlen[1] = fralen - 13; // 总长度-帧头长度
|
2023-05-18 00:58:26 +00:00
|
|
|
|
// memcpy(p_msg->findex,id,6);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
|
|
|
|
// 将待发数据传入帧数据
|
2023-05-23 06:59:35 +00:00
|
|
|
|
rt_memcpy(p_msg->fdata, din, len);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-18 00:58:26 +00:00
|
|
|
|
// 将打包后帧数据传入buff
|
2023-05-23 06:59:35 +00:00
|
|
|
|
rt_memcpy(dout, p_msg, fralen);
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return fralen;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
/**
|
|
|
|
|
* @description: 将din按指定长度w分割,再按MSG帧格式拼接
|
|
|
|
|
* @param *cfg MSG格式配置文件
|
|
|
|
|
* @param {rt_uint8_t} *din 待打包数据
|
|
|
|
|
* @param {rt_uint8_t} len 待打包数据长度
|
|
|
|
|
* @param {rt_uint8_t} w 分割长度
|
|
|
|
|
* @param {rt_uint8_t} *dout 打包后数据
|
|
|
|
|
* @return {*} 打包后数据总长度
|
|
|
|
|
*/
|
2023-05-25 06:58:31 +00:00
|
|
|
|
rt_uint8_t packMsgs(MSG *cfg, rt_uint8_t *din, size_t len, rt_uint8_t w, rt_uint8_t (*dout)[200], rt_uint8_t *arrlen)
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
|
|
|
|
if (!(w > 0)) // 无效长度
|
|
|
|
|
{
|
|
|
|
|
w = len;
|
|
|
|
|
}
|
2023-05-29 12:49:30 +00:00
|
|
|
|
rt_uint8_t row = (len / w) + (len % w > 0 ? 1 : 0);
|
|
|
|
|
LOG_I("ROW = %d",row);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
// rt_uint8_t packdata[row][200]; // 打包后数据
|
|
|
|
|
rt_uint8_t tlen[row]; // 打包后数据各维长度
|
|
|
|
|
|
|
|
|
|
cfg->fallpiece[0]=row;
|
2023-05-29 12:49:30 +00:00
|
|
|
|
rt_uint8_t tmplen = 0;
|
|
|
|
|
size_t var=0;
|
|
|
|
|
for (rt_uint8_t index = 0; index< row;index++)
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
2023-05-29 12:49:30 +00:00
|
|
|
|
// rt_uint8_t tmplen = w; // 当前待打包数据的长度
|
|
|
|
|
tmplen = (len - var) > w ? w : (len - var); // 判断最后一包数据的长度
|
2023-05-23 06:59:35 +00:00
|
|
|
|
cfg->fcurpiece[0] = index+1;
|
2023-05-25 06:58:31 +00:00
|
|
|
|
rt_uint8_t col = packMsg(cfg, din+var, tmplen, dout[index]);
|
|
|
|
|
arrlen[index] = col;
|
2023-05-29 12:49:30 +00:00
|
|
|
|
// index++;
|
|
|
|
|
var += w;
|
|
|
|
|
LOG_D("index/row-var-tmplen");
|
|
|
|
|
LOG_D("%5d/%3d-%3d-%6d",index,row,var,tmplen);
|
|
|
|
|
LOG_HEX("per msg",27,dout[index],col);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return row;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-05-18 00:58:26 +00:00
|
|
|
|
/**
|
|
|
|
|
* 将指定文件按帧协议进行切片打包,返回二维数组
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @param *cfg MSG格式配置文件
|
2023-05-18 00:58:26 +00:00
|
|
|
|
* @param fin 待打包文件名
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @param flag 配置信息
|
2023-05-18 00:58:26 +00:00
|
|
|
|
* @param dout 打包后二维数组
|
2023-05-23 06:59:35 +00:00
|
|
|
|
* @param arrlen 打包后二维数组各维数组的长度
|
2023-05-18 00:58:26 +00:00
|
|
|
|
* @return
|
|
|
|
|
*/
|
2023-05-25 06:58:31 +00:00
|
|
|
|
rt_uint8_t pack_File(const char *fin, rt_uint8_t flag, const rt_uint8_t (*dout)[200], rt_uint8_t *arrLen)
|
2023-05-11 03:33:47 +00:00
|
|
|
|
{
|
2023-06-16 03:18:52 +00:00
|
|
|
|
static MSG cfg;
|
|
|
|
|
rt_memset(&cfg, 0, sizeof(MSG)); // 分配空间
|
2023-06-06 07:45:13 +00:00
|
|
|
|
rt_uint8_t rst = packInit(&cfg, fin, flag);
|
|
|
|
|
if (rst != RT_EOK)
|
|
|
|
|
{
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
int fd_in = -1; //, fd_out = -1;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static size_t file_size = 0;
|
|
|
|
|
rt_uint8_t len=0;
|
|
|
|
|
// rt_uint8_t *buffer = RT_NULL;
|
|
|
|
|
static size_t flen = 150; // 每包数据初始长度,最大不超过 FRAME_DATA_LEN_MAX
|
|
|
|
|
// rt_uint8_t len = 0;
|
2023-05-25 06:58:31 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
fd_in = open(fin, O_RDONLY, 0);
|
|
|
|
|
if (fd_in < 0)
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
LOG_E("open the input file : %s error!\n", fin);
|
|
|
|
|
close(fd_in);
|
|
|
|
|
return len;
|
2023-05-23 06:59:35 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
file_size = lseek(fd_in, 0, SEEK_END);
|
|
|
|
|
LOG_I("file size is %d bytes.", file_size);
|
|
|
|
|
lseek(fd_in, 0, SEEK_SET);
|
|
|
|
|
rt_uint8_t *buffer = RT_NULL;
|
2023-06-16 03:18:52 +00:00
|
|
|
|
// extern rt_uint8_t *buffer;
|
2023-06-06 07:45:13 +00:00
|
|
|
|
buffer = rt_malloc(file_size);
|
|
|
|
|
if (buffer == RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("No memory for read %s.", fin);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
2023-05-23 06:59:35 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
read(fd_in, buffer, file_size);
|
|
|
|
|
// LOG_HEX()
|
|
|
|
|
close(fd_in);
|
|
|
|
|
// 粗略调整每包大小
|
|
|
|
|
if (file_size > (size_t)FRAME_DATA_LEN_MAX)
|
|
|
|
|
{
|
|
|
|
|
while (file_size % flen < flen / 1.2 && flen < FRAME_DATA_LEN_MAX) // 阈值约83%
|
|
|
|
|
{
|
|
|
|
|
flen += 1;
|
|
|
|
|
}
|
|
|
|
|
if (file_size % flen < flen / 1.2)
|
|
|
|
|
{ // 到达限制仍不符合要求
|
|
|
|
|
flen = 150;
|
|
|
|
|
while (file_size % flen < flen / 2.5 && flen < FRAME_DATA_LEN_MAX) // 调整阈值为40%
|
|
|
|
|
{
|
|
|
|
|
flen += 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
flen = file_size;
|
|
|
|
|
}
|
|
|
|
|
LOG_I("flen is %d",flen);
|
|
|
|
|
// s[0] = packMsg(&cfg, buffer, flen, d[0]);
|
|
|
|
|
len = packMsgs(&cfg, buffer, file_size, flen, dout, arrLen);
|
|
|
|
|
if (fd_in >= 0)
|
|
|
|
|
{
|
|
|
|
|
close(fd_in);
|
|
|
|
|
}
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
if (buffer != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
LOG_D("try to free buf.");
|
|
|
|
|
rt_free(buffer);
|
|
|
|
|
LOG_D("free buf done.");
|
|
|
|
|
}
|
2023-05-25 06:58:31 +00:00
|
|
|
|
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
return len;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-19 07:56:45 +00:00
|
|
|
|
#ifdef PF
|
2023-05-29 12:49:30 +00:00
|
|
|
|
// static rt_uint8_t *buffer = RT_NULL;
|
|
|
|
|
// static MSG cfg;
|
|
|
|
|
static int pf_thread_entry(void* parameter)
|
|
|
|
|
{
|
2023-06-19 07:56:45 +00:00
|
|
|
|
static char d[30][200];
|
|
|
|
|
static char s[30];
|
2023-05-23 06:59:35 +00:00
|
|
|
|
char *f = (char *) parameter;
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// static char d[5][200];
|
|
|
|
|
// static char s[5];
|
2023-06-16 03:18:52 +00:00
|
|
|
|
// rt_uint8_t *buffer = RT_NULL;
|
|
|
|
|
// static MSG cfg;
|
2023-05-29 12:49:30 +00:00
|
|
|
|
static rt_uint8_t len=0;
|
2023-06-16 03:18:52 +00:00
|
|
|
|
len = pack_File(f, 0, d, s);
|
|
|
|
|
//#define DEMO
|
2023-05-29 12:49:30 +00:00
|
|
|
|
#ifdef DEMO
|
2023-05-25 06:58:31 +00:00
|
|
|
|
{
|
2023-05-29 12:49:30 +00:00
|
|
|
|
//
|
2023-05-25 06:58:31 +00:00
|
|
|
|
rt_memset(&cfg, 0, sizeof(MSG)); // 分配空间
|
|
|
|
|
rt_uint8_t rst = packInit(&cfg, f, 0);
|
|
|
|
|
if (rst != RT_EOK)
|
|
|
|
|
{
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int fd_in = -1; //, fd_out = -1;
|
|
|
|
|
|
|
|
|
|
static size_t file_size = 0;
|
|
|
|
|
// rt_uint8_t *buffer = RT_NULL;
|
2023-05-29 12:49:30 +00:00
|
|
|
|
static size_t flen = 150; // 每包数据初始长度,最大不超过 FRAME_DATA_LEN_MAX
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// rt_uint8_t len = 0;
|
|
|
|
|
|
|
|
|
|
fd_in = open(f, O_RDONLY, 0);
|
|
|
|
|
if (fd_in < 0)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("open the input file : %s error!\n", f);
|
|
|
|
|
close(fd_in);
|
|
|
|
|
return len;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
file_size = lseek(fd_in, 0, SEEK_END);
|
|
|
|
|
LOG_I("file size is %d bytes.", file_size);
|
|
|
|
|
lseek(fd_in, 0, SEEK_SET);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
// static rt_uint8_t *buffer = RT_NULL;
|
2023-05-25 06:58:31 +00:00
|
|
|
|
buffer = rt_malloc(file_size);
|
|
|
|
|
if (buffer == RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("No memory for read %s.", f);
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
read(fd_in, buffer, file_size);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
// LOG_HEX()
|
2023-05-25 06:58:31 +00:00
|
|
|
|
close(fd_in);
|
|
|
|
|
// 粗略调整每包大小
|
2023-05-29 12:49:30 +00:00
|
|
|
|
if (file_size > (size_t)FRAME_DATA_LEN_MAX)
|
2023-05-25 06:58:31 +00:00
|
|
|
|
{
|
|
|
|
|
while (file_size % flen < flen / 1.2 && flen < FRAME_DATA_LEN_MAX) // 阈值约83%
|
|
|
|
|
{
|
|
|
|
|
flen += 1;
|
|
|
|
|
}
|
|
|
|
|
if (file_size % flen < flen / 1.2)
|
|
|
|
|
{ // 到达限制仍不符合要求
|
|
|
|
|
flen = 150;
|
|
|
|
|
while (file_size % flen < flen / 2.5 && flen < FRAME_DATA_LEN_MAX) // 调整阈值为40%
|
|
|
|
|
{
|
|
|
|
|
flen += 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
flen = file_size;
|
|
|
|
|
}
|
2023-05-29 12:49:30 +00:00
|
|
|
|
LOG_I("flen is %d",flen);
|
2023-05-25 06:58:31 +00:00
|
|
|
|
// s[0] = packMsg(&cfg, buffer, flen, d[0]);
|
|
|
|
|
len = packMsgs(&cfg, buffer, file_size, flen, d, s);
|
|
|
|
|
if (fd_in >= 0)
|
|
|
|
|
{
|
|
|
|
|
close(fd_in);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (buffer != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
LOG_D("try to free buf.");
|
|
|
|
|
rt_free(buffer);
|
|
|
|
|
LOG_D("free buf done.");
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-05-29 12:49:30 +00:00
|
|
|
|
#endif
|
2023-05-25 06:58:31 +00:00
|
|
|
|
|
|
|
|
|
rt_kprintf("len is %d\n", len);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
if (len && (tcpInit() == RT_EOK))
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
2023-06-16 03:18:52 +00:00
|
|
|
|
// rt_event_send(&tcp_chk, TT_TCP_OK);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
for (size_t var = 0; var < len; var++)
|
|
|
|
|
{
|
2023-06-11 08:32:09 +00:00
|
|
|
|
sendMsg(d[var], s[var]);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
LOG_D("i = %d",var);
|
2023-06-19 07:56:45 +00:00
|
|
|
|
// LOG_HEX("d", 27, d[var], s[var]);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
}
|
2023-06-16 03:18:52 +00:00
|
|
|
|
tcpClose();
|
2023-05-23 06:59:35 +00:00
|
|
|
|
LOG_I("Done.");
|
|
|
|
|
}
|
2023-05-25 06:58:31 +00:00
|
|
|
|
return RT_EOK;
|
2023-05-11 03:33:47 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-29 12:49:30 +00:00
|
|
|
|
static int pmsg(int argc, char **argv)
|
2023-05-23 06:59:35 +00:00
|
|
|
|
{
|
|
|
|
|
if (argc == 2)
|
|
|
|
|
{
|
|
|
|
|
static char c[STR_LEN_MAX];
|
|
|
|
|
strcpy(c, argv[1]);
|
|
|
|
|
|
|
|
|
|
/* 创建线程 */
|
2023-06-19 07:56:45 +00:00
|
|
|
|
rt_thread_t thread = rt_thread_create("pmsg", pf_thread_entry, (void *) c, 1024 * 2, 25, 10);
|
2023-05-23 06:59:35 +00:00
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
// rt_kprintf("done");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'pmsg' create failure.");
|
|
|
|
|
return RT_ERROR;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
rt_kprintf("Usage:\n");
|
|
|
|
|
rt_kprintf("pmsg [input_file] pack \"input_file\" \n");
|
|
|
|
|
}
|
2023-05-29 12:49:30 +00:00
|
|
|
|
return 0;
|
2023-05-23 06:59:35 +00:00
|
|
|
|
}
|
|
|
|
|
#include <finsh.h>
|
2023-05-11 03:33:47 +00:00
|
|
|
|
|
2023-05-23 06:59:35 +00:00
|
|
|
|
MSH_CMD_EXPORT(pmsg, 打包文件。);
|
2023-06-19 07:56:45 +00:00
|
|
|
|
#endif
|
2023-05-29 12:49:30 +00:00
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
/**
|
|
|
|
|
* 天通上电
|
2023-06-18 01:34:09 +00:00
|
|
|
|
* @param parameter "0"断电,其它上电
|
2023-06-01 09:10:00 +00:00
|
|
|
|
*/
|
2023-05-29 12:49:30 +00:00
|
|
|
|
void pwTT_thread_entry(void *parameter)
|
|
|
|
|
{
|
|
|
|
|
// LOG_I("--%s--",parameter);
|
2023-06-17 10:26:40 +00:00
|
|
|
|
if (strcmp(parameter,"NULL")==0)//无参数,状态翻转
|
2023-06-01 02:23:08 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// LOG_I("null");
|
2023-05-29 12:49:30 +00:00
|
|
|
|
int f = rt_pin_read(TT_EN);
|
|
|
|
|
rt_pin_write(TT_EN, !f);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2023-06-17 10:26:40 +00:00
|
|
|
|
rt_bool_t flag = !(rt_bool_t) atoi(parameter);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
if ((rt_bool_t)rt_pin_read(TT_EN) != flag) {//目标状态与当前状态一致才响应
|
2023-06-17 10:26:40 +00:00
|
|
|
|
rt_pin_write(TT_EN, flag);//
|
2023-06-16 03:18:52 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-05-29 12:49:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-16 03:18:52 +00:00
|
|
|
|
if (rt_pin_read(TT_EN))//检查设置后状态
|
2023-06-01 02:23:08 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//#ifdef NO_RELAY
|
2023-06-17 10:26:40 +00:00
|
|
|
|
LOG_I("set TT %s", "OFF");//高电平关断
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//#endif
|
2023-06-01 02:23:08 +00:00
|
|
|
|
add_val("swCnt");//更新统计值
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2023-06-17 10:26:40 +00:00
|
|
|
|
LOG_I("set TT %s", "ON");//低电平开启
|
2023-06-01 02:23:08 +00:00
|
|
|
|
}
|
2023-05-29 12:49:30 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int swTT(int argc, char **argv)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static char s[5]="NULL";
|
|
|
|
|
if (argc >= 2)
|
2023-05-29 12:49:30 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
rt_strcpy(s,argv[1]);
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
rt_strcpy(s,"NULL");
|
2023-05-29 12:49:30 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* 创建线程 */
|
2023-06-06 07:45:13 +00:00
|
|
|
|
rt_thread_t thread = rt_thread_create("sw_TT", pwTT_thread_entry, (void *) s, 1024 * 2, 25, 10);
|
2023-05-29 12:49:30 +00:00
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'sw_TT' create failure.");
|
|
|
|
|
return RT_ERROR;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MSH_CMD_EXPORT(swTT, 切换TT电源。不带参切换电源状态,支持参数);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
|
2023-06-20 10:09:07 +00:00
|
|
|
|
extern struct rt_messagequeue TTrx_mq;
|
2023-06-16 03:18:52 +00:00
|
|
|
|
void recTT_thread_entry()
|
|
|
|
|
{
|
2023-07-20 07:29:37 +00:00
|
|
|
|
// while(tcpInit() != RT_EOK)
|
|
|
|
|
// {
|
|
|
|
|
// LOG_W("TT server is not ready.");
|
|
|
|
|
// rt_thread_mdelay(100);
|
|
|
|
|
// }
|
|
|
|
|
// LOG_D("TT server is ready.");
|
2023-06-20 10:09:07 +00:00
|
|
|
|
static TTRx_MSG msg;
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
2023-06-16 03:18:52 +00:00
|
|
|
|
|
2023-06-20 10:09:07 +00:00
|
|
|
|
rt_memset(&msg, 0, sizeof(msg));
|
|
|
|
|
if (rt_mq_recv(&TTrx_mq, &msg, sizeof(msg), RT_WAITING_FOREVER) == RT_EOK)
|
|
|
|
|
{
|
2023-07-20 07:29:37 +00:00
|
|
|
|
//
|
|
|
|
|
if (!msg.size)
|
|
|
|
|
{ //收到数据长度为0表示tcp断开
|
2023-06-21 03:08:53 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
2023-07-20 08:18:42 +00:00
|
|
|
|
LOG_I("%d Bytes received from TT",msg.size);
|
2023-07-20 07:29:37 +00:00
|
|
|
|
LOG_HEX("TTrec", 16, msg.data, msg.size);
|
2023-06-20 10:09:07 +00:00
|
|
|
|
//此处处理接收到数据
|
2023-07-20 08:18:42 +00:00
|
|
|
|
// rt_uint8_t rec_good[] = { 0x88, 0xAA, 0xBB, 0x88, 0x41,0x43,0x4B }; //前四字节=帧头、后三字节=ACK
|
|
|
|
|
// if (rt_memcmp(msg.data, rec_good, 4) == 0 && rt_memcmp(msg.data+msg.size-3, rec_good+4, 3) == 0)
|
|
|
|
|
// {
|
|
|
|
|
// LOG_I("ack is good.");
|
|
|
|
|
// }
|
|
|
|
|
// else
|
2023-07-20 07:29:37 +00:00
|
|
|
|
{
|
|
|
|
|
LOG_D("try to parse data.");
|
|
|
|
|
parseTTData(msg.data,msg.size);
|
|
|
|
|
}
|
2023-06-20 10:09:07 +00:00
|
|
|
|
}
|
2023-06-16 03:18:52 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//INIT_COMPONENT_EXPORT(recTT_thread_entry);
|
|
|
|
|
|
2023-07-20 07:29:37 +00:00
|
|
|
|
void recTT(void)
|
2023-06-16 03:18:52 +00:00
|
|
|
|
{
|
2023-06-17 10:26:40 +00:00
|
|
|
|
/* 创建线程 */
|
2023-06-20 10:09:07 +00:00
|
|
|
|
rt_thread_t thread = rt_thread_create("recTT", recTT_thread_entry, RT_NULL, 1024 * 2, 27, 10);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'recTT' create failure.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-20 10:09:07 +00:00
|
|
|
|
MSH_CMD_EXPORT(recTT,TTrx demo.)
|