/******************************************************************************** * File Name: MC8332GpsTask.h * Function Describe: Header file for MC8332GpsTask.c * Explain: * Writer: * Date: 2016-3-11 *******************************************************************************/ #include "includes.h" void MC8332_GPS_RecvHandle(unsigned char *pMsg,unsigned short tempLen) { char buf[20]; char buf2[50]; char result[10]; unsigned short cmd,ackCmd,smsLen; unsigned char Result,i,buBiaoResponsed; short targetIndex; SUTDS ds; //////////////////////////////////////////// // char buftest[100]; // char buf22[3]; // for(i=0;i<25;i++) // { // sprintf(buf22, "%02x", pMsg[i]); // strcat(buftest, buf22); // } // strcat(buftest, "\r\n"); // SlwTrace(INF, buftest); //////////////////////////////////////////// //////////处理布标类型指令 cmd = (pMsg[1]<<8) | (pMsg[2]&0xff); buBiaoResponsed=1; sprintf(buf2, "\r\ncmd=%04x", cmd); SlwTrace(INF, buf2,1); switch(cmd) {//布标命令返回 case TS_TERMINAL_REGISTRATION_REPLY://终端注册应答 //7E 8100 000A 000166000016 0250 0100 00 20161118165030 E07E 成功 //7E 8100 0003 000166000016 0251 0100 01 A07E 已注册 Result = pMsg[15]; sprintf(buf2, "\r\nresult=%02x", Result); SlwTrace(INF, buf2,1); switch(Result) { case 0://00注册成功 for(i =0; i < 7; i++) sutProductPara.AutH[i]=pMsg[16+i]; SaveProductParaToFlash("AUTH-REC"); sprintf(result, "Ok"); break; case 1://01 车辆已注册 sprintf(result, "Car Exist");break; case 2://02 无此车辆 sprintf(result, "No car");break; case 3://03 终端已经被注册 sprintf(result, "Device Exist");break; case 4://04 数据库无此终端 sprintf(result, "No Record");break; default://无效值 //统称失败 sprintf(result, "Faile"); break; } sprintf(buf2, "\r\n[Register]%d %s", Result,result); SlwTrace(INF, buf2,1); //注册应答后直接进行一次鉴权 Authentication(); break; case TS_TEXT_INFORMATION_ISSUED://文本下发 //7E83000005000166000009000001 31323334ED7E smsLen = (pMsg[3] << 8) | (pMsg[4]&0xff); if(SMS_SIGNAL_LEN <= smsLen) smsLen = SMS_SIGNAL_LEN; //memset(sutMess.GBKMess1, 0,sizeof(sutMess.GBKMess1)); //GBKTostr(pMsg+28,sutMess.GBKMess1,smsLen); memcpy(sutMess.GBKMess1, pMsg+14, smsLen-1); sutMess.GBKMess1[smsLen-1] = 0;//最后一个补0 sutMess.len = smsLen; ////////////////////////// sutFeed.feedID=TS_SETTING_TERMINAL_PARAMETERS; ds.Data.ucData.b1=pMsg[11]; ds.Data.ucData.b2=pMsg[12]; sutFeed.feedliushuiID=ds.Data.usData; sutFeed.result=2; ////////////////////////// if(sutMess.len > 0) SetGotNewMessage(); break; case TS_PLATFORM_UNIVERSAL_ANSWER://通用平台应答 //7E8001000500016600001602400000010201B57E //buf[0]=0x7e; //if(-1 != (targetIndex=FindTargetIndex((char *)pMsg, '\r', buf, 1,2))) targetIndex = tempLen;//这个长度是去掉了两个7E的长度 { ackCmd=(pMsg[targetIndex-3]<<8) | (pMsg[targetIndex-2]&0xff); Result = pMsg[targetIndex-1]; sprintf(buf2, "\r\nLen=%d,ackCmd=%04x,result=%02x", tempLen,ackCmd,Result); SlwTrace(INF, buf2,1); switch(ackCmd) { case TS_TERMINAL_AUTHENTICATION://终端鉴权应答 if(Result == 0) {//鉴权成功 sutGpsInfo.isGpsAuthOk=1; sprintf(buf2, "\r\n[ATH]Ok"); //TSGpsServerConect();//鉴权成功后发一包终端应答包即可以支持文本接收了 }else { sutGpsInfo.isGpsAuthOk=0; sprintf(buf2, "\r\n[ATH]Faile"); } SlwTrace(INF, buf2,1); break; case TS_LOCATION_INFORMATION_REPORTING://位置包应答 SlwTrace(INF, "\r\nLocation ACK",1); break; case TS_TERMINAL_HEARTBEAT://心跳应答 SlwTrace(INF, "\r\nHearTick ACK",1); break; } } break; default: buBiaoResponsed=0; break; } if(buBiaoResponsed) g_ucModemSentTcpCt=0; /////////////处理其它类型指令 } void AtHandle(char *pMsg) { int csq; static uint8_t flag =0; short targetIndex; unsigned char tempSocket,i,temp; unsigned short tempLen; char buf[80]="\r\n"; char bufTemp[3]; if(0==ModemStrCmp(pMsg,"+CSQ:")){ csq=GetCSQ(pMsg); if(csq>=0 && csq<100)g_iCSQ=csq; }else if(0==ModemStrCmp(pMsg,"+POC_PPP:")){ sutGpsStatus.PPPStatus=GetPPPStatus(pMsg); }else if(0==ModemStrCmp(pMsg,"+TCPSTATUS:")) {//查询指令返回状态 if(tcpControl ==2)//控制配置服务器操作 { #if(USE_CONFIG_FUN==1) if(OPEN == GetIPNewStatus(pMsg,CONFIG_SER_SOCKET)) sutConfig.g_ubConfigTcpStatus = 1; else { if(sutConfig.g_ubConfigTcpStatus) sutConfig.g_ucTcpRetryNum=CONFIG_TCP_RETRY_CNT; sutConfig.g_ubConfigTcpStatus = 0; } #endif }else { GetIPNewStatus(pMsg,GPS_DATA_SOCKET); if(tcpControl == 1) { sutGpsStatus.IPStatus=GetIPNewStatus(pMsg,GPS_DATA_SOCKET); if(sutGpsStatus.IPStatus == CLOSE) sutGpsInfo.isGpsAuthOk=0;//鉴权清掉,再次连接后要重新鉴权 if(0==flag) { if(sutPocStatus.Logined && sutGpsStatus.IPStatus == OPEN) { flag ++; Registration(); registerActFlag=1; } } }else if(tcpControl == 0) {//HGS if(OPEN == sutGpsStatus.IPStatus) HgsConnetStatus=1; } } }else if(0==ModemStrCmp(pMsg,"+TCPRECV:")){//+TCPRECV:0,2,31 if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ":", 1,1))) { tempSocket = atoi(&pMsg[targetIndex]);//找到socket if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ",",1,1))) { tempLen = atoi(&pMsg[targetIndex]); if(-1 != (targetIndex=FindTargetIndex(pMsg, '\r', ",",1,2))) { // if(changeDataFormat(&pMsg[targetIndex],tempLen)) // { // SlwTrace(INF, "DataFormat Err",1); // return; // } if(tempSocket == GPS_DATA_SOCKET) { if(tcpControl == 0) { Hgs_Data_RecvHandle(&pMsg[targetIndex],tempLen); }else if(tcpControl == 1) { //走布标判断 if(pMsg[targetIndex] == 0x7e && pMsg[targetIndex+tempLen-1] == 0x7e) {//是布标协议,进行转义 tempLen=reduce((unsigned char *)&pMsg[targetIndex+1], tempLen-1); MC8332_GPS_RecvHandle((unsigned char *)&pMsg[targetIndex],tempLen); }else { SlwTrace(INF, "Unknown Protocol",1); } } ///////////////////////////////////////// #if 0 tempLen += 2; if(tempLen > 30) tempLen=30; for(i=0;i= 24) g_usModeHTime -= 24; g_usModeMTime=atoi(&pMsg[20]); g_usModeSTime=atoi(&pMsg[23]); SetTime(g_usModeHTime, g_usModeMTime, g_usModeSTime);//保存下来,以便下次启动,没登陆前可以使用本地时间显示 SlwTrace(INF, "UpdateTime",1); }else if(0==ModemStrCmp(pMsg, "^MODE:")) {//^MODE: 9 与下面位置不一,模块问题 //^MODE:2 与上面位置不一,模块问题 if(pMsg[6] == ' ') bufTemp[0]=pMsg[7]; else bufTemp[0]=pMsg[6]; sprintf(buf, "[Mode %c]", bufTemp[0]); switch(bufTemp[0]) { case 0x30:strcat(buf, "No server");break; case 0x32:strcat(buf, "CDMA Mode");break; case 0x33:strcat(buf, "GSM");break; case 0x34:strcat(buf, "TD-SCDMA/EVDO");break; case 0x35:strcat(buf, "WCDMA");break; case 0x39:strcat(buf, "LTE");break; default:strcat(buf, "Unknow");break; } SlwTrace(INF, buf, 1); } } /************************************************ 每10ms处理一次 **************************************************/ void GpsTaskTick(unsigned char reset) { static unsigned char sucSecCt=0; static unsigned char sucSteep=0; static unsigned char sucSynSentCt=0; unsigned char temp[4]; char buf[50]; int i; if(reset){ sucSecCt=0; sucSteep=0; return; } //GPS Uart消息处理 if(g_usUart3RecvLen) { process_nema((char *)RxBuffer3); g_usUart3RecvLen=0; } //===========以下控制每秒执行一次============ if(++sucSecCt>99)sucSecCt=0; else return; //////////////////20170112//////////////////// GpsCtrlSendPos();//里面涉及到鉴权,所以得跑起来 //TCP发送防护,如果IPSTATUS一直等于SYN_SENT持续达10秒,则关闭TCP链路 if(sutGpsStatus.IPStatus==SYN_SENT) { if(++sucSynSentCt>10){ sucSynSentCt=0; g_ucModemSentTcpCt=0; sprintf(buf, "AT+TCPCLOSE=%d\r\n",GPS_DATA_SOCKET); ModemSendAT(buf); sutGpsStatus.IPStatus=CLOSE; g_ucModemSentTcpCt=0; sutGpsInfo.isServerLogin=0; } }else sucSynSentCt=0; //---以下控制--- if(++sucSteep>4)sucSteep=0; //---- if(sucSteep==0) { ModemSendAT("AT+CSQ\r\n"); sprintf(buf, "[ATH]:%d,[GPS]:%d,[BAT]:%0.2f", sutGpsInfo.isGpsAuthOk, sutGpsInfo.isGpsValid, (double)g_iVbat/100); SlwTrace(INF,buf,1); } else if(1==sucSteep) { ModemSendAT("AT+POC_PPP\r\n"); }else if(2==sucSteep) { if(99==g_iCSQ)return; if(sutGpsStatus.PPPStatus==OPEN){ sprintf(buf, "AT+TCPSTATUS=%d\r\n", GPS_DATA_SOCKET); ModemSendAT(buf); }else{ SlwTrace(INF, "Wait POC_PPP",1); } }else if(3==sucSteep) { if(99==g_iCSQ) return; if(sutGpsInfo.isGpsWork==0) { if(sutGpsStatus.CheckCnt < 50) { if(++sutGpsStatus.CheckCnt >= 2) { sutGpsStatus.CheckCnt = NO_GPS_CHECK_TIMEOUT;//设置为此值时认为是没有GPS机型 } } SlwTrace(INF,"GPS modem not work!",1); } if(sutGpsStatus.IPStatus==CLOSE && sutGpsStatus.PPPStatus==OPEN) { if(tcpControl == 1) {//当控制为GPS时才去连接 sutGpsInfo.isServerLogin=0; sprintf(buf,"AT+TCPOPEN=%d,%s:%d\r\n",GPS_DATA_SOCKET,sutProductPara.GIP,sutProductPara.GpsPort); SlwTrace(DEBUG,buf,0); ModemSendAT(buf); } } }else if(4==sucSteep) { if(99==g_iCSQ)return; if(sutGpsStatus.IPStatus==OPEN && 0==sutGpsInfo.isServerLogin) { sutGpsInfo.isServerLogin = OPEN; if(registerActFlag) { sucGpsSentTcpCt=16;//会及时鉴权 //heartTickCt=0;//如果鉴权成功后会及时发心跳或位置包(本来不用的,但TCP断开后再连接上,鉴权成功不发心跳还是收不了文本) } } } }