2023-06-01 09:10:00 +00:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
*
|
|
|
|
|
* Change Logs:
|
|
|
|
|
* Date Author Notes
|
|
|
|
|
* 2023-06-01 murmur the first version
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
|
|
|
|
|
#define LOG_TAG "main_scha"
|
|
|
|
|
#define LOG_LVL LOG_LVL_DBG
|
|
|
|
|
#include <ulog.h>
|
|
|
|
|
#include <board.h>
|
|
|
|
|
#include <ttmsg/ttmsg.h>
|
|
|
|
|
#include <cfg.h>
|
2023-06-02 02:23:26 +00:00
|
|
|
|
#include <usrcfg.h>
|
2023-06-06 07:45:13 +00:00
|
|
|
|
#include <ttTR.h>
|
|
|
|
|
static struct rt_event sw_check;//软件条件
|
|
|
|
|
static struct rt_event hw_check;//硬件条件
|
2023-06-16 03:18:52 +00:00
|
|
|
|
struct rt_event tcp_chk;//tcp条件
|
2023-06-02 02:23:26 +00:00
|
|
|
|
//#define FILE_IS_OK 1
|
|
|
|
|
//#define TIMER_IS_OUT 1<<1
|
|
|
|
|
//#define TT_IS_OK 1<<2
|
2023-06-06 07:45:13 +00:00
|
|
|
|
#define ALL_READY 1
|
2023-06-01 09:10:00 +00:00
|
|
|
|
|
2023-06-02 02:23:26 +00:00
|
|
|
|
static int maxTTWaitTime = 4;
|
|
|
|
|
static int maxTTRetryCnt = 3;
|
2023-06-01 09:10:00 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static void initEvent(void)
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
|
|
|
|
/* 事 件 控 制 块 */
|
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
rt_err_t result = rt_event_init(&sw_check, "SHcheck", RT_IPC_FLAG_PRIO);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
result = rt_event_init(&hw_check, "HWcheck", RT_IPC_FLAG_PRIO) | result;
|
|
|
|
|
result = rt_event_init(&tcp_chk, "tcpTT", RT_IPC_FLAG_PRIO) | result;
|
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
if (result != RT_EOK)
|
|
|
|
|
{
|
|
|
|
|
LOG_E("init event failed.\n");
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-02 06:37:58 +00:00
|
|
|
|
INIT_COMPONENT_EXPORT(initEvent);
|
2023-06-01 09:10:00 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
void upSWflag(void)
|
|
|
|
|
{
|
|
|
|
|
rt_event_send(&sw_check, FILE_IS_OK);
|
|
|
|
|
}
|
|
|
|
|
void upTTflag(void)
|
|
|
|
|
{
|
|
|
|
|
rt_event_send(&sw_check, TT_IS_OK);
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
/**
|
|
|
|
|
* 更新各参数
|
|
|
|
|
*/
|
|
|
|
|
static void updatecfg()
|
|
|
|
|
{
|
2023-06-02 02:23:26 +00:00
|
|
|
|
maxTTWaitTime = get_cfg("maxTTWaitTime");
|
|
|
|
|
maxTTRetryCnt = get_cfg("maxTTRetryCnt");
|
2023-06-01 09:10:00 +00:00
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//extern struct rt_event update_cfg;
|
|
|
|
|
//void t3(void)
|
|
|
|
|
//{
|
|
|
|
|
// int32_t e;
|
|
|
|
|
// int rst = rt_event_recv(&update_cfg, CFGCHANGEED, RT_EVENT_FLAG_OR , RT_WAITING_FOREVER, &e);
|
|
|
|
|
// if (rst == RT_EOK) {
|
|
|
|
|
//// update_cfg();
|
|
|
|
|
// LOG_I("ggxb");
|
|
|
|
|
// }
|
|
|
|
|
//}
|
2023-06-02 06:37:58 +00:00
|
|
|
|
|
|
|
|
|
//INIT_COMPONENT_EXPORT(t3);
|
2023-06-06 07:45:13 +00:00
|
|
|
|
extern void ttinfoInit(void);
|
|
|
|
|
extern void startTTinfo(void);
|
2023-06-01 09:10:00 +00:00
|
|
|
|
/**
|
|
|
|
|
* 监控TT状态。需求条件1:TT连续5个周期为激活状态且信号强度不低于5。
|
|
|
|
|
*/
|
|
|
|
|
void checkTT()
|
|
|
|
|
{
|
2023-06-02 02:23:26 +00:00
|
|
|
|
static rt_thread_t thread = RT_NULL;
|
2023-06-01 09:10:00 +00:00
|
|
|
|
//上电
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// pwTT_thread_entry("1");
|
2023-06-02 02:23:26 +00:00
|
|
|
|
//延时30s等待系统启动、可以GET信息,避免不必要的错误
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// rt_thread_mdelay(1000*3);
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// char c[3][10]={"getTT","10","1"} ;
|
|
|
|
|
//// getTT(3,c);
|
|
|
|
|
// getTT(1, RT_NULL);
|
2023-06-01 09:10:00 +00:00
|
|
|
|
// getTTinfo_thread_entry()
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//#define NEW_THREAD
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static CFG cfg;
|
|
|
|
|
memset(&cfg, 0, sizeof(CFG));
|
|
|
|
|
//
|
|
|
|
|
cfg.s = 1;
|
2023-06-11 08:32:09 +00:00
|
|
|
|
cfg.cnt = maxTTWaitTime*60/cfg.s-2;//避免通信异常
|
2023-06-06 07:45:13 +00:00
|
|
|
|
extern void getTTinfo_thread_entry(void* parameter);
|
|
|
|
|
#define NEW_THREAD
|
|
|
|
|
#ifdef NEW_THREAD
|
2023-06-02 02:23:26 +00:00
|
|
|
|
/* 创建 serial 线程 */
|
|
|
|
|
thread = rt_thread_create("getTT", getTTinfo_thread_entry, (void *) &cfg, 1024 * 3, 25, 10);
|
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'getTT' create failure.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2023-06-06 07:45:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ttinfoInit();
|
|
|
|
|
// startTTinfo();
|
|
|
|
|
|
|
|
|
|
// rt_thread_create("getS", startTTinfo, RT_NULL, 1024 * 3, 25, 10);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void getFileData_thread_entry(void)
|
|
|
|
|
{
|
|
|
|
|
//等待事件
|
|
|
|
|
extern struct rt_event hw_check;//硬件条件
|
|
|
|
|
while(1)
|
|
|
|
|
{
|
|
|
|
|
if (rt_event_recv(&hw_check, ALL_READY, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR,
|
|
|
|
|
RT_WAITING_FOREVER, RT_NULL) == RT_EOK)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
//get file to be send
|
2023-06-16 03:18:52 +00:00
|
|
|
|
char *f="2023_06_16_10_28_00_123.bin";
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// char *f="1023_05_19_15_29_59_254.txt";
|
|
|
|
|
// pack file
|
|
|
|
|
|
|
|
|
|
static rt_uint8_t d[10][200] = { };
|
|
|
|
|
static rt_uint8_t s[10] = { };
|
|
|
|
|
rt_uint8_t len = 0;
|
|
|
|
|
#define __PCK
|
|
|
|
|
#ifdef __PCK
|
|
|
|
|
// LOG_D("%p--%p",d,s);
|
|
|
|
|
// LOG_I("pack %s ...",f);
|
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
|
|
|
|
|
|
|
|
|
len = pack_File(f, 0, d, s);
|
|
|
|
|
rt_kprintf("len is %d\n", len);
|
2023-06-16 03:18:52 +00:00
|
|
|
|
if (len && (tcpInit() == RT_EOK))
|
|
|
|
|
{
|
|
|
|
|
// rt_event_send(&tcp_chk, TT_TCP_OK);
|
|
|
|
|
for (size_t var = 0; var < len; var++)
|
|
|
|
|
{
|
|
|
|
|
sendMsg(d[var], s[var]);
|
|
|
|
|
LOG_D("i = %d",var);
|
|
|
|
|
LOG_HEX("d", 27, d[var], s[var]);
|
|
|
|
|
}
|
|
|
|
|
tcpClose();
|
|
|
|
|
LOG_I("Done.");
|
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
rt_uint8_t *buffer = RT_NULL;
|
|
|
|
|
static MSG cfg;
|
|
|
|
|
// static rt_uint8_t len=0;
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
//
|
|
|
|
|
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;
|
|
|
|
|
static size_t flen = 150; // 每包数据初始长度,最大不超过 FRAME_DATA_LEN_MAX
|
|
|
|
|
// 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);
|
|
|
|
|
// static rt_uint8_t *buffer = RT_NULL;
|
|
|
|
|
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);
|
|
|
|
|
// 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, 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.");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-01 09:10:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//MSH_CMD_EXPORT(getFileData_thread_entry,tet);
|
|
|
|
|
static void gg(void)
|
|
|
|
|
{
|
|
|
|
|
/* 创建 serial 线程 */
|
|
|
|
|
rt_thread_t thread = rt_thread_create("PSmsg", getFileData_thread_entry, RT_NULL, 1024 * 12, 27, 10);
|
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'PSmsg' create failure.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void try()
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
|
|
|
|
static rt_err_t rst = RT_ERROR;
|
|
|
|
|
updatecfg();
|
2023-06-06 07:45:13 +00:00
|
|
|
|
static rt_uint8_t d[10][200] = { };
|
|
|
|
|
static rt_uint8_t s[10] = { };
|
2023-06-01 09:10:00 +00:00
|
|
|
|
while(1)
|
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
// int e;
|
|
|
|
|
LOG_I("等待软件就绪");
|
2023-06-01 09:10:00 +00:00
|
|
|
|
rst = rt_event_recv(&sw_check, FILE_IS_OK | TIMER_IS_OUT, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR,
|
2023-06-06 07:45:13 +00:00
|
|
|
|
RT_WAITING_FOREVER, RT_NULL);
|
2023-06-02 02:23:26 +00:00
|
|
|
|
if (rst == RT_EOK)//软件条件满足
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
2023-06-02 02:23:26 +00:00
|
|
|
|
//检查硬件条件
|
2023-06-06 07:45:13 +00:00
|
|
|
|
LOG_I("软件就绪,开始等待TT");
|
|
|
|
|
// continue;
|
2023-06-02 02:23:26 +00:00
|
|
|
|
checkTT();
|
|
|
|
|
//打包数据
|
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-06 07:45:13 +00:00
|
|
|
|
for (size_t var = 0; var < maxTTRetryCnt; var++)//轮询尝试
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
LOG_I("第%d次尝试。",var+1);
|
|
|
|
|
//rt_tick_from_millisecond(maxTTWaitTime * 1000)
|
2023-06-11 08:32:09 +00:00
|
|
|
|
rst = rt_event_recv(&sw_check, TT_IS_OK, RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR, maxTTWaitTime*60*1000,
|
2023-06-06 07:45:13 +00:00
|
|
|
|
RT_NULL);
|
2023-06-02 02:23:26 +00:00
|
|
|
|
if (rst == RT_EOK)//硬件条件满足
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
LOG_I("TT准备OK");
|
|
|
|
|
rt_event_send(&hw_check, ALL_READY);
|
2023-06-01 09:10:00 +00:00
|
|
|
|
break;
|
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
else if(rst == RT_ETIMEOUT);//超时则重试
|
2023-06-01 09:10:00 +00:00
|
|
|
|
{
|
2023-06-06 07:45:13 +00:00
|
|
|
|
LOG_W("第%d次尝试中TT准备失败。",var+1);
|
|
|
|
|
// pwTT_thread_entry("0");
|
2023-06-02 02:23:26 +00:00
|
|
|
|
rt_thread_mdelay(1000);
|
|
|
|
|
checkTT();
|
|
|
|
|
// continue;
|
2023-06-01 09:10:00 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//continue;
|
2023-06-02 02:23:26 +00:00
|
|
|
|
//发送数据
|
2023-06-06 07:45:13 +00:00
|
|
|
|
//可能有多个待发文件,每个文件打包后为一个二维数组
|
|
|
|
|
// 如果先打包后发送,需要三维数组,和大内存占用
|
|
|
|
|
// 故改为“打包-发送”轮询操作
|
|
|
|
|
//gg();
|
|
|
|
|
#ifdef _NO
|
|
|
|
|
char *f="1023_05_19_15_29_59_254.txt";
|
|
|
|
|
// pack file
|
|
|
|
|
// static rt_uint8_t d[10][200] = { };
|
|
|
|
|
// static rt_uint8_t s[10] = { };
|
|
|
|
|
rt_uint8_t len = 0;
|
|
|
|
|
// LOG_D("%p--%p",d,s);
|
|
|
|
|
// LOG_I("pack %s ...",f);
|
|
|
|
|
len = pack_File(f, 0, d, s);
|
|
|
|
|
rt_kprintf("len is %d\n", len);
|
|
|
|
|
if (len)
|
|
|
|
|
{
|
|
|
|
|
for (size_t var = 0; var < len; ++var) {
|
|
|
|
|
// LOG_HEX("d",27,d[var],s[var]);
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
LOG_I("Done.");
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
LOG_I("----------------------------");
|
|
|
|
|
//initEvent();
|
|
|
|
|
// rt_thread_mdelay(100);
|
|
|
|
|
|
2023-06-02 02:23:26 +00:00
|
|
|
|
|
2023-06-01 09:10:00 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-06-06 07:45:13 +00:00
|
|
|
|
|
|
|
|
|
MSH_CMD_EXPORT(gg,file);
|
|
|
|
|
|
|
|
|
|
void smsg()
|
|
|
|
|
{
|
|
|
|
|
/* 创建 serial 线程 */
|
|
|
|
|
rt_thread_t thread = rt_thread_create("checkSta", try, RT_NULL, 1024 * 5, 24, 10);
|
|
|
|
|
/* 创建成功则启动线程 */
|
|
|
|
|
if (thread != RT_NULL)
|
|
|
|
|
{
|
|
|
|
|
rt_thread_startup(thread);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
LOG_E("thread 'checkSta' create failure.");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
INIT_COMPONENT_EXPORT(smsg);
|
|
|
|
|
MSH_CMD_EXPORT(smsg,smsg);
|