More mesh_panic stuff, trying to debug the mesh problems for real now.

This commit is contained in:
Stefan `Sec` Zehl 2012-01-03 01:09:20 +01:00
parent 5e69eadb38
commit dda913d107

View file

@ -36,21 +36,25 @@ void initMesh(void){
meshbuffer[0].flags=MF_USED; meshbuffer[0].flags=MF_USED;
}; };
#define MP_OK 0
#define MP_SEND 1
#define MP_RECV 2
#define MP_IGNORE 4
int mesh_sanity(uint8_t * pkt){ int mesh_sanity(uint8_t * pkt){
if(MO_TYPE(pkt)>0x7f || MO_TYPE(pkt)<0x20) if(MO_TYPE(pkt)>0x7f || MO_TYPE(pkt)<0x20)
return 1; return MP_SEND;
if(MO_TYPE(pkt)=='T' && MO_BODY(pkt)[5]) if(MO_TYPE(pkt)=='T' && MO_BODY(pkt)[5])
return 3; return MP_SEND;
if(MO_TYPE(pkt)>='A' && MO_TYPE(pkt)<='Z'){ if(MO_TYPE(pkt)>='A' && MO_TYPE(pkt)<='Z'){
if(MO_TIME(pkt)>1325379600) if(MO_TIME(pkt)>1326409200)
return 1; return MP_SEND;
if(MO_TIME(pkt)<1324602000) if(MO_TIME(pkt)<1324602000)
return 1; return MP_SEND;
}else if(MO_TYPE(pkt)>='a' && MO_TYPE(pkt)<='z'){ }else if(MO_TYPE(pkt)>='a' && MO_TYPE(pkt)<='z'){
if(MO_TIME(pkt)>16777216) if(MO_TIME(pkt)>16777216)
return 1; return MP_SEND;
if(MO_TIME(pkt)<0) if(MO_TIME(pkt)<0)
return 1; return MP_SEND;
}; };
if(MO_TYPE(pkt)!='A' && if(MO_TYPE(pkt)!='A' &&
MO_TYPE(pkt)!='a' && MO_TYPE(pkt)!='a' &&
@ -60,9 +64,9 @@ int mesh_sanity(uint8_t * pkt){
MO_TYPE(pkt)!='G' && MO_TYPE(pkt)!='G' &&
MO_TYPE(pkt)!='T' MO_TYPE(pkt)!='T'
){ ){
return 2; return MP_IGNORE;
}; };
return 0; return MP_OK;
}; };
MPKT * meshGetMessage(uint8_t type){ MPKT * meshGetMessage(uint8_t type){
@ -90,7 +94,7 @@ MPKT * meshGetMessage(uint8_t type){
}; };
void meshPanic(uint8_t * pkt){ void meshPanic(uint8_t * pkt){
#if 0 #if 1
setSystemFont(); setSystemFont();
lcdClear(); lcdClear();
lcdPrint("MESH-PANIC:"); lcdPrint("MESH-PANIC:");
@ -122,10 +126,7 @@ void mesh_cleanup(void){
if (MO_TIME(meshbuffer[i].pkt)-now>SECS_DAY) if (MO_TIME(meshbuffer[i].pkt)-now>SECS_DAY)
meshbuffer[i].flags=MF_FREE; meshbuffer[i].flags=MF_FREE;
}; };
if(mesh_sanity(meshbuffer[i].pkt)==1){ if(mesh_sanity(meshbuffer[i].pkt)&MP_SEND!=0){
meshbuffer[i].flags=MF_FREE;
};
if(mesh_sanity(meshbuffer[i].pkt)==3){
meshbuffer[i].flags=MF_FREE; meshbuffer[i].flags=MF_FREE;
meshPanic(meshbuffer[i].pkt); meshPanic(meshbuffer[i].pkt);
}; };
@ -215,7 +216,7 @@ uint8_t mesh_recvqloop_work(void){
if(mesh_sanity(buf)){ if(mesh_sanity(buf)){
meshincctr++; meshincctr++;
if(mesh_sanity(buf)==3){ if(mesh_sanity(buf)&MP_RECV!=0){
meshPanic(buf); meshPanic(buf);
}; };
return 0; return 0;