Files
checker_slave/source/main/main.c
2023-06-16 18:07:44 +08:00

542 lines
13 KiB
C

#ifdef RT_THREAD
#include "stdio.h"
#include "rtthread.h"
#include "board.h"
#include "mystdlib.h"
#include "list.h"
#include "mystring.h"
#include "signal.h"
#include "prot_mcu.h"
#include "debug.h"
#include "handle.h"
#include "prot_uc.h"
#include "transmit.h"
#include "tcp.h"
#include "netconf.h"
#include "stm32f4x7_eth_bsp.h"
#include "commend.h"
#include "dev_flash.h"
#include "mymisc.h"
#include "dev_backup.h"
#include "compiler_info.h"
#include "udp.h"
#include "moter.h"
int main()
{
const sys_param_def *par=sys_param();
ETH_BSP_Config();
LwIP_Init();
debug_init();
app_init();
protu_def *protu=app_variable("protu",0,0);
protu_def *protu2=app_variable("protu2",0,0);
tran_def *tran=app_variable("tran",0,0);
void *cmd=app_variable("cmd",0,0);
void *udp=app_variable("udp",0,0);
connect(protu,protu_recv_signal,0,tran,tran_recv_slot);
connect(tran,tran_reply_signal,0,protu,protu_reply_call);
connect(tran,tran_send_signal,0,protu,protu_send_call);
connect(udp,udp_recv_signal,0,cmd,cmd_recv_slot);
connect(cmd,cmd_reply_signal,0,udp,udp_reply_call);
connect(protu2,protu_recv_signal,0,cmd,cmd_recv_slot);
connect(cmd,cmd_reply_signal,0,protu2,protu_send_call);
//DBG_LOG("询预压");
//DBG_LOG("我知道");
//--diag_suppress=550,177
while(1)
{
rt_thread_mdelay(5000);
}
}
int init_wdog(void)
{
if(bk_wdog_fun())
{
rt_thread_idle_sethook((void (*)(void))bk_wdog_fun());
}
return 0;
}
app_init_export(init_wdog)
static int test(list_def *argv)
{
if(list_length(argv)<2){
cmd_print("param num too less.");
return -1;
}
int num=str_atoi(list_get_str(argv,1));
cmd_print("test num=%d,hex=%x",num,num);
return 0;
}
commend_export(test,test,"cmd test")
static int scheme_info(list_def *argv)
{
const scheme_def *s=check_scheme();
if(s->plan_id==0xffffffff){
cmd_print("scheme is empty.");
return -1;
}
cmd_print("plan id: %d",s->plan_id);
cmd_print("timeout_m: %d",s->timeout_m);
cmd_print("range num: %d",s->range_num);
for(int i=0;i<s->range_num;i++)
{
cmd_print(" max:%5d, min:%5d %s",s->range[i].max,s->range[i].min,
s->range[i].max<s->range[i].min?"err":"ok");
}
return 0;
}
commend_export(scheme,scheme_info,"print scheme info")
static int updata_slave(list_def *argv)
{
void *ptr=flash_get_slave();
tran_def *tran=app_variable("tran",0,0);
uint8_t *data=ptr;
data+=FLASH_FILE_HEAD_SIZE;
flash_file *file=ptr;
if(tran==0){
DBG_WARN("can not fond variable \"tran\"");
return -1;
}
if(list_length(argv)<2){
cmd_print("param num too less.");
return -1;
}
list_def *addrs=str_atod_list(list_get_str(argv,1),',');
for(int i=0;i<list_length(addrs);i++)
{
int addr=list_get_int(addrs,i);
port_mcu *mcu=tran_get_portm(tran,addr-1);
if(mcu)
port_start(mcu,updata_creat(data,file->file_size));
}
cmd_print("start updata,addr=%s",str_temp(list_string(addrs)));
return 0;
}
commend_export(updatas,updata_slave,"updata slave")
static int memused(list_def *argv)
{
uint32_t used,total,max_used;
rt_memory_info(&total,&used,&max_used);
cmd_print("mem total=%d,used=%d,max_used=%d",total,used,max_used);
used=mem_perused();
cmd_print("mem used=%d.",used);
return 0;
}
commend_export(memused,memused,"print the mem use info")
static int reboot(list_def *argv)
{
cmd_print("mcu will reboot later");
later_execute((void (*)(void *))bk_reboot_app,0,50);
return 0;
}
commend_export(reboot,reboot,"reboot mcu")
static int moter(list_def *argv)
{
const sys_param_def *par=sys_param();
cmd_print("moter ctl");
if(list_length(argv)<3){
cmd_print("param num too less.");
return -1;
}
int fre=str_atoi(list_get_str(argv,1));
int count=str_atoi(list_get_str(argv,2));
moter_start(fre,count);
cmd_print("moter start,fre=%d,count=%d",fre,count);
return 0;
}
commend_export(moter,moter,"control moter up or down|use:moter [frequency] [count]")
static void print_sys_param(const sys_param_def *par)
{
cmd_print(" - - - - - - - - - - - - - - ");
cmd_print("pack time: %s",par->pack_time);
cmd_print("host if: %s",par->host_if);
cmd_print("device type: %s",par->device_type);
cmd_print("mac addr: %02x.%02x.%02x.%02x.%02x.%02x",
par->mac[0],par->mac[1],par->mac[2],par->mac[3],par->mac[4],par->mac[5]);
cmd_print("local ip: %d.%d.%d.%d",
par->local_ip[0],par->local_ip[1],par->local_ip[2],par->local_ip[3]);
cmd_print("host ip: %d.%d.%d.%d",
par->host_ip[0],par->host_ip[1],par->host_ip[2],par->host_ip[3]);
cmd_print("host port: %d",par->host_port);
cmd_print("local cmd port: %d",par->local_cmd_port);
cmd_print("host log port: %d",par->host_log_port);
cmd_print("local id: %d",par->local_id);
cmd_print("host log ip: %d.%d.%d.%d",
par->host_log_ip[0],par->host_log_ip[1],par->host_log_ip[2],par->host_log_ip[3]);
cmd_print("uart bsp: %d",par->uartbsp);
cmd_print("coder ret mode: %d",par->coder_ret_mode);
cmd_print("slave_addr_start: %d",par->slave_addr_start);
}
static int sysinfo(list_def *argv)
{
const sys_param_def *par=sys_param();
cmd_print("build time: %s",BUILD_DATE);
cmd_print("soft version: %s",SOFT_VERSION);
cmd_print("run time: %d",rt_tick_get()/1000);
cmd_print("startup: %s",bk_get_currtype());
cmd_print("watch dog: %s",bk_wdog_fun()?"on":"off");
cmd_print("reboot times: %d",bk_reboot_times());
print_sys_param(par);
return 0;
}
commend_export(sysinfo,sysinfo,"print the software info")
static void print_sys_help(void)
{
cmd_print("example for how to set system params:");
cmd_print("set hostif uart4/utcp");
cmd_print("set devicetype checker/coder");
cmd_print("set localip 192.168.80.10");
cmd_print("set hostip 192.168.80.100");
cmd_print("set hostport 7777");
cmd_print("set localcmdport 7777");
cmd_print("set hostlogport 12345");
cmd_print("set localid 1");
cmd_print("set hostlogip 192.168.80.80");
cmd_print("set uartbsp 115200");
cmd_print("set codermode 1/0");
cmd_print("set slave_addr_start 1/0");
cmd_print("set save");
}
static int sys_set(list_def *argv)
{
static sys_param_def *spar=0;
if(spar==0){
spar=calloc(1,sizeof(sys_param_def));
memcpy(spar,sys_param(),sizeof(sys_param_def));
}
if(list_length(argv)<2){
cmd_print(" - - - -SET TEMP- - - - ");
print_sys_param(spar);
return 0;
}
if(strcmp(list_get_str(argv,1),"help")==0)
{
print_sys_help();
return 0;
}
else if(strcmp(list_get_str(argv,1),"save")==0)
{
cmd_print(" - - - -SET TEMP- - - - ");
print_sys_param(spar);
flash_save_param(spar);
cmd_print("param saved,device will reboot later.");
later_execute((void (*)(void *))bk_reboot_app,0,100);
return 0;
}else{
if(list_length(argv)<3){
cmd_print("param num too less.");
print_sys_help();
return -1;
}
}
if(strcmp(list_get_str(argv,1),"hostif")==0)
{
char *str=list_get_str(argv,2);
memcpy(spar->host_if,str,strlen(str)+1);
cmd_print("host if: %s",spar->host_if);
}
else if(strcmp(list_get_str(argv,1),"devicetype")==0)
{
char *str=list_get_str(argv,2);
memcpy(spar->device_type,str,strlen(str)+1);
cmd_print("device type: %s",spar->device_type);
}
else if(strcmp(list_get_str(argv,1),"localip")==0)
{
char *str=list_get_str(argv,2);
list_def *ip=str_atod_list(str,'.');
spar->local_ip[0]=list_get_int(ip,0);
spar->local_ip[1]=list_get_int(ip,1);
spar->local_ip[2]=list_get_int(ip,2);
spar->local_ip[3]=list_get_int(ip,3);
cmd_print("local ip: %d.%d.%d.%d",
spar->local_ip[0],spar->local_ip[1],spar->local_ip[2],spar->local_ip[3]);
}
else if(strcmp(list_get_str(argv,1),"hostip")==0)
{
char *str=list_get_str(argv,2);
list_def *ip=str_atod_list(str,'.');
spar->host_ip[0]=list_get_int(ip,0);
spar->host_ip[1]=list_get_int(ip,1);
spar->host_ip[2]=list_get_int(ip,2);
spar->host_ip[3]=list_get_int(ip,3);
cmd_print("host ip: %d.%d.%d.%d",
spar->host_ip[0],spar->host_ip[1],spar->host_ip[2],spar->host_ip[3]);
}
else if(strcmp(list_get_str(argv,1),"hostport")==0)
{
char *str=list_get_str(argv,2);
spar->host_port=str_atoi(str);
cmd_print("host port: %d",spar->host_port);
}
else if(strcmp(list_get_str(argv,1),"localcmdport")==0)
{
char *str=list_get_str(argv,2);
spar->local_cmd_port=str_atoi(str);
cmd_print("local cmd port: %d",spar->local_cmd_port);
}
else if(strcmp(list_get_str(argv,1),"hostlogport")==0)
{
char *str=list_get_str(argv,2);
spar->host_log_port=str_atoi(str);
cmd_print("local log port: %d",spar->host_log_port);
}
else if(strcmp(list_get_str(argv,1),"localid")==0)
{
char *str=list_get_str(argv,2);
spar->local_id=str_atoi(str);
cmd_print("local id: %d",spar->local_id);
}
else if(strcmp(list_get_str(argv,1),"uartbsp")==0)
{
char *str=list_get_str(argv,2);
spar->uartbsp=str_atoi(str);
cmd_print("uart bsp: %d",spar->uartbsp);
}
else if(strcmp(list_get_str(argv,1),"hostlogip")==0)
{
char *str=list_get_str(argv,2);
list_def *ip=str_atod_list(str,'.');
spar->host_log_ip[0]=list_get_int(ip,0);
spar->host_log_ip[1]=list_get_int(ip,1);
spar->host_log_ip[2]=list_get_int(ip,2);
spar->host_log_ip[3]=list_get_int(ip,3);
cmd_print("host log ip: %d.%d.%d.%d",
spar->host_log_ip[0],spar->host_log_ip[1],spar->host_log_ip[2],spar->host_log_ip[3]);
}
else if(strcmp(list_get_str(argv,1),"codermode")==0)
{
char *str=list_get_str(argv,2);
spar->coder_ret_mode=str_atoi(str);
cmd_print("coder ret mode: %d",spar->coder_ret_mode);
}
else if(strcmp(list_get_str(argv,1),"slave_addr_start")==0)
{
char *str=list_get_str(argv,2);
spar->slave_addr_start=str_atoi(str);
cmd_print("slave addr start: %d",spar->slave_addr_start);
}
else{
cmd_print("unknown cmd for sysset.");
print_sys_help();
return -1;
}
return 0;
}
commend_export(set,sys_set,"set the system params")
#else
#include "board.h"
#include "dev_flash.h"
#include "dev_backup.h"
#include "crc.h"
#include "dev_watchdog.h"
#include "string.h"
#define APP_ADDR 0x08020000
void __set_msp(uint32_t addr);
typedef void (*app)(void);
void app_run(void)
{
app app_fun;
if(((*(volatile uint32_t*)APP_ADDR)&0x2FFE0000)==0x20000000)
{
// wdog_start();
// bk_set_wdog_fun(wdog_refresh);
app_fun=(app)*(volatile uint32_t*)(APP_ADDR+4);
__set_msp(*(volatile uint32_t*)APP_ADDR);
app_fun();
}
}
void param_init(rom_head *h);
void app_updata(void);
int main()
{
uint32_t boot_type=bk_get_boottype();
bk_init();
switch(boot_type){
// 重启并升级
case REBOOT_APP_TO_BOOT:
{
uint8_t *rom;
rom_head *head;
rom=flash_get_rom(&head);
param_init(head);
if(rom)
{
if(head->crc==crc_crc32(rom,head->size))
{
flash_updata_app(rom,head->size);
}
}
bk_reboot_guide();
break;
}
// 重新运行boot
case REBOOT_BOOT_TO_BOOT:
break;
// 重启app
case REBOOT_APP_TO_APP:
// 引导至app
case REBOOT_BOOT_TO_APP:
// 断言失败重启
case REBOOT_PARAM_ERR:
// 硬件错误重启
case REBOOT_HARD_ERR:
// 看门狗重启
case REBOOT_INIT:
// 上电启动
default:
param_init(0);
app_run();
break;
}
while(1)
{
}
}
// 初始化mac地址
void mac_init(uint8_t *mac)
{
const uint8_t *mcu_id=(const uint8_t *)0x1FFF7A10;
for(int i=0;i<6;i++)
{
mac[i]=mcu_id[i*2]^((mcu_id[i*2+1]<<4)|(mcu_id[i*2+1]>>4));
}
}
// 参数初始化
void param_init(rom_head *h)
{
static sys_param_def pars={0};
memcpy(&pars,sys_param(),sizeof(sys_param_def));
if(h){
memcpy(pars.pack_time,h->pack_time,20);
if(pars.local_id==0xffffffff){
memcpy(pars.host_if,h->host_if,8);
memcpy(pars.device_type,"checker",8);
mac_init(pars.mac);
memcpy(pars.local_ip,h->local_ip,4);
memcpy(pars.host_ip,h->host_ip,4);
pars.host_port=h->host_port;
pars.local_cmd_port=7777;
pars.host_log_port=12345;
pars.local_id=1;
}
flash_save_param(&pars);
}
else{
// 填充默认配置
if(pars.local_id==0xffffffff){
memcpy(pars.pack_time,"initial app",12);
memcpy(pars.host_if,"uart4",6);
memcpy(pars.device_type,"coder",6);
mac_init(pars.mac);
memcpy(pars.local_ip,(uint8_t []){192,168,80,10},4);
memcpy(pars.host_ip,(uint8_t []){192,168,80,80},4);
memcpy(pars.host_log_ip,(uint8_t []){192,168,80,80},4);
pars.host_port=9527;
pars.local_cmd_port=7777;
pars.host_log_port=12345;
pars.local_id=1;
flash_save_param(&pars);
}
}
}
#endif