广播命令可以接收各个从机的返回数据

This commit is contained in:
ranchuan
2023-12-09 10:37:48 +08:00
parent dc6487c309
commit fe11c52253
10 changed files with 156 additions and 21 deletions

View File

@@ -10,5 +10,6 @@
广播方式升级从机成功
2023.12.7
批检仪检测流程验证成功
2023.12.8
广播命令可以接收各个从机的返回数据,计划将所有命令转化为广播命令

View File

@@ -6,7 +6,7 @@
#define BUILD_DATE "2023-12-07 18:27:08"
#define BUILD_DATE "2023-12-08 10:04:55"

View File

@@ -1,5 +1,5 @@
{
"build_date": "2023-12-07 18:27:08",
"build_date": "2023-12-08 10:04:55",
"hard_version": "MHPZ2_V1.00",
"private": [
"info.json",

View File

@@ -25,6 +25,8 @@ void prot_slave::init()
}else{
if((broadcast_!=nullptr)&&(broadcast_->busy)){
broadcast_->addr_response|=1<<(src-1);
// 存储从机的数据
broadcast_->ret_data[src-1]=data;
if(broadcast_->check_response()==true){
// broadcast_->dolater(broadcast_->cmd,data);
emit boardcast_dolater_signal(broadcast_->cmd,data);

View File

@@ -102,11 +102,46 @@ signals:
using namespace std;
// using namespace std::placeholders;
typedef std::function<void(int addr,int ack,myarray data)> prots_end_cbfun;
class slave_data;
typedef std::function<void(int addr,int ack,slave_data data)> prots_end_cbfun;
typedef std::function<void(int rate,mystring data)> prots_rate_cbfun;
typedef struct{
int addr;
myarray data;
}slave_ret;
// 定义保存从机数据的类
class slave_data{
public:
QList<slave_ret> data;
// 重载括号操作符index为地址-1
myarray &operator [](int index){
for(int i=0;i<data.size();i++){
if(data[i].addr==(index+1)){
return data[i].data;
}
}
slave_ret r;
r.addr=index+1;
data.append(r);
return data.last().data;
}
// 清除
void clear(){
data.clear();
}
int size(){
return data.size();
}
slave_ret &at(int index){
return data[index];
}
};
class HandleBoardCast : public QObject
@@ -140,18 +175,31 @@ public:
int addr;
int addr_response;
int cmd;
slave_data ret_data;
public:
// 判断是否所有从机都返回
bool check_response(){
return (addr^addr_response)==0?true:false;
}
// 把地址列表转化为bit
void trun_list_to_bit(QList<int> addrs){
int trun_list_to_bit(QList<int> addrs){
addr=0;
foreach(int adr,addrs){
addr|=1<<(adr-1);
}
return addr;
}
// 把bit转化为地址列表
QList<int> trun_bit_to_list(int addrs){
QList<int> l;
for(int i=0;i<32;i++){
if(addrs&(1<<i)){
l.append(i+1);
}
}
return l;
}
void set_cbfun(prots_end_cbfun end_fun,prots_rate_cbfun rate_fun){
this->end_cb=end_fun;
this->rate_cb=rate_fun;
@@ -168,6 +216,7 @@ protected:
this->data_send=data;
this->times_retry=times;
this->addr_response=0;
this->ret_data.clear();
if(timer_retry_==nullptr){
timer_retry_=new QTimer();
connect(timer_retry_,&QTimer::timeout,this,&HandleBoardCast::timeout_retry);
@@ -180,7 +229,7 @@ protected:
return 0;
}
// 发送操作结束信号
int end(int ack,myarray data){
int end(int ack,slave_data data){
emit end_signal(0x1f,ack,data);
if(end_cb!=nullptr){
end_cb(0x1f,ack,data);
@@ -252,12 +301,12 @@ private:
QTimer *timer_;
QTimer *timer_retry_;
int times_retry;
myarray data_send;
myarray data_send;// 发送的数据
prots_end_cbfun end_cb;
prots_rate_cbfun rate_cb;
signals:
void send_data_signal(int addr, int cmd, myarray data);
void end_signal(int addr,int ack,myarray data);
void end_signal(int addr,int ack,slave_data data);
void rate_signal(int rate,mystring str);
};

View File

@@ -24,7 +24,7 @@ void rate_slot(int rate,mystring str)
strs=strs.arg(rate).arg(str);
c->send(strs.data());
}
void end_slot(int addr,int ack,myarray data)
void end_slot(int addr,int ack,slave_data data)
{
command *c=command_start();
mystring strs("ack:%1,%2");
@@ -101,7 +101,7 @@ static void mcu_cmdlines(QList<myarray> args)
if(ack==false){
qWarning("handle is busy.");
}else{
b->set_cbfun([=](int addr,int ack,myarray data){
b->set_cbfun([=](int addr,int ack,slave_data data){
end_slot(addr,!ack,data);
},[=](int rate,mystring str){
rate_slot(rate,str);
@@ -124,7 +124,7 @@ static void mcu_cmdlines(QList<myarray> args)
if(ack==false){
qWarning("handle is busy.");
}else{
b->set_cbfun([=](int addr,int ack,myarray data){
b->set_cbfun([=](int addr,int ack,slave_data data){
end_slot(addr,!ack,data);
},[=](int rate,mystring str){
rate_slot(rate,str);
@@ -149,7 +149,7 @@ static void mcu_cmdlines(QList<myarray> args)
if(ack==false){
qWarning("handle is busy.");
}else{
b->set_cbfun([=](int addr,int ack,myarray data){
b->set_cbfun([=](int addr,int ack,slave_data data){
end_slot(addr,!ack,data);
},[=](int rate,mystring str){
rate_slot(rate,str);

View File

@@ -272,7 +272,7 @@ void selfdev_slaveupdate::timeout(){
qDebug("slave update timeout");
}
void selfdev_slaveupdate::slave_end_slot(int addr,int ack, myarray data)
void selfdev_slaveupdate::slave_end_slot(int addr,int ack, slave_data data)
{
qDebug("slave update end,ack=%d",ack);
busy=0;
@@ -348,7 +348,7 @@ void selfdev_update_scheme::timeout(){
qDebug("slave update timeout");
}
void selfdev_update_scheme::slave_end_slot(int addr,int ack, myarray data)
void selfdev_update_scheme::slave_end_slot(int addr,int ack, slave_data data)
{
qDebug("slave update end,ack=%d",ack);
busy=0;
@@ -563,6 +563,27 @@ static myarray slave_to_bootinfo_byte(myarray data){
return data;
}
//void selfdev_bootinfo::slave_end_slot(int addr,int ack, slave_data data)
//{
// if(addr<=0||addr>slave_acked.size()){
// qWarning("slave addr err:%d",addr);
// return;
// }
// for(int i=0;i<data.size();i++){
// slave_ret slave=data.at(i);
// slave_acked.replace(slave.addr-1,slave.data);
// slave_acked_num++;
// myarray r;
// r.append(char(0));
// r+=bootinfo_fill_local();
// for(int i=0;i<slave_acked.size();i++){
// r.append(slave_to_bootinfo_byte(slave_acked[i]));
// }
// emit send_data_signal(0x34,r);
// busy=0;
// }
//}
void selfdev_bootinfo::slave_end_slot(int addr,int ack, myarray data)
{
if(addr<=0||addr>slave_acked.size()){
@@ -583,6 +604,8 @@ void selfdev_bootinfo::slave_end_slot(int addr,int ack, myarray data)
}
}
static HandlePc *get_selfdev_bootinfo(){
return new selfdev_bootinfo();
}

View File

@@ -3,6 +3,7 @@
#include "prot/prot_pc.h"
#include "prot/prot_m4.h"
#include "prot_cmd/cmd_slave.h"
// 检测 自研批检仪
@@ -80,7 +81,7 @@ public:
int dolater(int cmd, myarray data);
void timeout();
public slots:
void slave_end_slot(int addr,int ack, myarray data);
void slave_end_slot(int addr,int ack, slave_data data);
signals:
void send_to_m4_signal(myarray data);
};
@@ -100,7 +101,7 @@ public:
int dolater(int cmd, myarray data);
void timeout();
public slots:
void slave_end_slot(int addr,int ack, myarray data);
void slave_end_slot(int addr,int ack, slave_data data);
signals:
void send_to_m4_signal(myarray data);
};
@@ -147,6 +148,7 @@ public:
int dolater(int cmd, myarray data);
void timeout();
public slots:
// void slave_end_slot(int addr,int ack, slave_data data);
void slave_end_slot(int addr,int ack, myarray data);
protected:
QList<myarray> slave_acked;

View File

@@ -52,6 +52,54 @@ int slave_check::dolater(int cmd, myarray data)
int slave_check2::start(myarray data)
{
mycfg *cfg_=syscfg();
check_cfg *ccfg_=check_plan();
int timeout=ccfg_->get_check_time_out()*1000;
busy=1;
cmd=0x0c;
qDebug("addr %d start check,timeout=%d",addr,timeout);
send_data(cmd,myarray(),3);
timeout_start(timeout);
return 0;
}
void slave_check2::timeout()
{
timeout_stop();
qWarning("addr %d check timeout.",addr);
end(1,ret_data);
busy=0;
}
int slave_check2::dolater(int cmd, myarray data)
{
timeout_stop_retry();
if(cmd==0x0c){
if(data.size()<=16){
qDebug("addr %d recv first ack.",addr);
}else{
qDebug("addr %d recv secend ack.",addr);
send_data(0x14,myarray(),5);
end(0,ret_data);
timeout_stop();
}
}else if(cmd==0x14){
// 所有从机都 停止上报时取消忙状态
busy=0;
}
return 0;
}
void slave_result::timeout()
{
timeout_stop();
@@ -212,7 +260,7 @@ void boardcast_updata::timeout()
{
timeout_stop();
qWarning("slave updata timeout.");
end(1,myarray());
end(1,ret_data);
busy=0;
}
@@ -259,7 +307,7 @@ int boardcast_updata::dolater(int cmd, myarray data)
timeout_stop();
timeout_stop_retry();
qDebug("slave updata end.");
end(0,data);
end(0,ret_data);
busy=0;
}
return 0;
@@ -301,7 +349,7 @@ void boardcast_updata_scheme::timeout()
{
timeout_stop();
qWarning("slave updata timeout.");
end(1,myarray());
end(1,ret_data);
busy=0;
}
@@ -333,7 +381,7 @@ int boardcast_updata_scheme::dolater(int cmd, myarray data)
timeout_stop();
timeout_stop_retry();
qDebug("slave updata scheme end.");
end(0,data);
end(0,ret_data);
busy=0;
}
return 0;

View File

@@ -16,6 +16,16 @@ public:
};
// 从机检测命令
class slave_check2:public HandleBoardCast
{
public:
slave_check2():HandleBoardCast(){}
int start(myarray data);
int dolater(int cmd, myarray data);
void timeout();
};
// 获取检测结果命令