#include "../../public/src/include/pub_include.h" #include "../../snmp/src/include/snmp.h" #include "../../snmp/src/include/heartbeat.h" #include "./include/mtp3.h" #ifdef _INCLUDE_M2UA #include "../../m2ua/src/include/m2ua.h" #endif #include "./include/mtpstm.h" #include "./include/mtpext.h" #include "./include/mtpfunc.h" /*@ignore@*/ char mtpconfile[] = {"./conf/mtp3.conf"}; FILE *mtpfpConf; char MTP_OBJECT_LKA[20]={"[LINK ATTRIBUTE]\n"}; char MTP_OBJECT_NSP[80]={"[NATIONAL NETWORK SP]\n"}; char MTP_OBJECT_NSSP[80]={"[NATIONAL NETWORK SPARE SP]\n"}; char MTP_OBJECT_ISP[80]={"[INTERNATIONAL NETWORK SP]\n"}; char MTP_OBJECT_ISSP[80]={"[INTERNATIONAL NETWORK SPARE SP]\n"}; char MTP_OBJECT_LSA[40]={"[LINKSET ATTRIBUTE]\n"}; char MTP_OBJECT_LSP[20]={"[LOCAL SP]\n"}; char MTP_OBJECT_SNL[40]={"[SERVICE NETWORK SP LEN]\n"}; char MTP_OBJECT_SG[40]={"[SG ATTRIBUTES]\n"}; char MTP_OBJECT_MTP3LITE_PORT[40]={"[MTP3LITE TCP PORT]"}; long atol(const char *nptr); void hmrt_tcoc_update_routing_tables(BYTE chl); void hmrt_tcbc_update_routing_tables(BYTE chl); void update_timer(int link); BOOL Alinkset_status(BYTE routine); BOOL Nlinkset_status(BYTE routine); void mark_normal_linkset_available(BYTE *routine); void mark_alternative_linkset_unavailable(BYTE *routine); void mark_alternative_linkset_available(BYTE *routine); void mark_normal_linkset_unavailable(BYTE *routine); void mark_dstSP_inaccessible(BYTE *routine); void hmrt_tfrc_update_routing_tables(BYTE dst, BYTE nw); void otherMTP3_managed_link_unavailable(BYTE chl); void mtp3_reload_data(); int MTP3_LinkIP_List(DWORD IP,BYTE mode); void deactive_mtp3lite_lk(BYTE link); //extern from sccp/sccpfun.c extern ull Bcd2Ull(BYTE *pBcd, int BcdLen); extern int ParseLine(char *str, char (*row)[128], int maxrow); extern int Str2Bcd(BYTE *pBcd, char *pStr, int maxLen); extern void deactive_m3ua_lk(BYTE link); static u32 mtp3_primomcip=0; // primary omc ip address static u32 mtp3_secdomcip=0; // secondary omc ip address static u32 mtp2_object_id[] = {1,3,6,1,4,1,1373,1,3,1,1,3}; #define MTP2_PREOID_LEN 12 void mtp3_send_mtp2_alarm(WORD component,BYTE alarm) { snmp_pdu snmp_buf; snmp_addr snmp_addr; time_t cur_time; u8 *buf; snmp_addr.remote_port = 4957; snmp_addr.local_port = 4957; snmp_addr.broadcast = 0; snmp_buf.pdu_type = 7; snmp_buf.var_num = 1; memcpy(snmp_buf.var[0].oid, mtp2_object_id, MTP2_PREOID_LEN*4); snmp_buf.var[0].oid[MTP2_PREOID_LEN] = 4; snmp_buf.var[0].oidlen = MTP2_PREOID_LEN + 1; snmp_buf.var[0].vartype = 4; buf = snmp_buf.var[0].msg; buf[0] = mtp2_module; // system id buf[1] = mtp2_systemid; cur_time = time(NULL); buf[2] = cur_time >> 24; // time stamp buf[3] = cur_time >> 16; buf[4] = cur_time >> 8; buf[5] = cur_time; // byte 6--13 16 LED status (green continuous: 0x09, yellow continuous: 0x0a) buf[6] = 0x99; if (alarm != 0) buf[7] = 0xaf; else buf[7] = 0x9f; memset(buf+8, 0xff, 6); buf[14] = component>>8; // first byte of component id buf[15] = component&255; // second byte of component id buf[16] = alarm; // alarm level buf[17] = 0; buf[18] = 0;//length 1 buf[19] = 0;//component id buf[20] = 0;//component id buf[21] = 0; buf[22] = 20;//length 2 // memcpy(buf+30, hlr_vm_ptr->sys_param.hlr_seqnum, HLR_SEQNUM_LEN); // snmp_buf.var[0].msglen = 37 + HLR_SEQNUM_LEN; snmp_buf.var[0].msglen = 23; // snmp_addr.remote_ip = 0x81ea12ac; if (mtp3_primomcip != 0) { snmp_addr.remote_ip = mtp3_primomcip; snmp_send(&snmp_buf, &snmp_addr); } if (mtp3_secdomcip != 0) { snmp_addr.remote_ip = mtp3_secdomcip; snmp_send(&snmp_buf, &snmp_addr); } } int Mtp3BinSearchIndex(BYTE low, BYTE high,ull key, BYTE nw) { mtp3DPCIndex *sort_rec = &mtp3SortRoutine.nw[nw]; static int mid; static long long midvalue; if(low>high) { // LogErr("BinSearchIndex ERR,low=%d,high=%d,key=%lld",low,high,key); return low; } if(high == low+1 ) { if(key<=sort_rec->dpc[low]) return low; else if(key<=sort_rec->dpc[high]) return high; else return high+1; } if(low == high) { if(key<=sort_rec->dpc[low]) return low; else return low+1; } mid = (low + high)/2; midvalue = sort_rec->dpc[mid]; if(key == midvalue) { return mid; } else if(keyhigh) { // LogErr("BinSearchIndex ERR,low=%d,high=%d,key=%lld",low,high,key); return -1; } if (sort_rec->sortedNum <= 0) return -1; if (high > sort_rec->sortedNum-1) high = sort_rec->sortedNum-1; if(high == low+1 ) { if(key==sort_rec->dpc[low]) return low; else if(key==sort_rec->dpc[high]) return high; else return -1; } if(low == high) { if(key==sort_rec->dpc[low]) return low; else return -1; } mid = (low + high)/2; midvalue = sort_rec->dpc[mid]; if(key == midvalue) { return mid; } else if(keysortedNum > 256 - 1) { mtp3SortRoutine.nw[nw].sortedNum = 256 - 1; return 0; } if(opc == mtp3_para->nw[nw].opc14 && (pc_length(nw)==MTP3_14BIT_PC)) opc = 0; else if(opc == mtp3_para->nw[nw].opc24 && (pc_length(nw)==MTP3_24BIT_PC)) opc = 0; opc_dpc = opc; opc_dpc = (opc_dpc<<32)|dpc; if(sort_rec->sortedNum == 0) { index1 = 0; sort_rec->dpc[index1] = opc_dpc; sort_rec->sortedNum = 1; sort_rec->index[index1] = real_index; return 1; } else { index1 = Mtp3BinSearchValue(0,255,nw,opc_dpc); if (index1>=0 && index1 < sort_rec->sortedNum)//already has this record return 0; while(sort_rec->dpc[0] > sort_rec->dpc[sort_rec->sortedNum - 1]) sort_rec->sortedNum = (sort_rec->sortedNum - 1) % 256; //LogErr("--AddSortRec,start BinSearchIndex key=%lld",key); index1 = Mtp3BinSearchIndex(0,sort_rec->sortedNum-1,opc_dpc,nw); if (index1 >= sort_rec->sortedNum) { if (sort_rec->sortedNum >= 256-1) { return 0; } sort_rec->dpc[sort_rec->sortedNum] = opc_dpc; sort_rec->index[sort_rec->sortedNum] = real_index; sort_rec->sortedNum ++; } // LogErr("---AddSortRec: index1=%d,store_i=%d,old_key=%lld",index1,index,sort_rec[index1].key); } if (sort_rec->dpc[index1] != opc_dpc) {// insert a item int moveNum = (sort_rec->sortedNum-index1) % 256; if (sort_rec->sortedNum >= 256) { return 0; } memmove(&sort_rec->dpc[index1+1],&sort_rec->dpc[index1],moveNum*sizeof(ull)); memmove(&sort_rec->index[index1+1],&sort_rec->index[index1],moveNum*sizeof(DWORD)); sort_rec->dpc[index1]=opc_dpc; sort_rec->index[index1]=real_index; sort_rec->sortedNum ++; return 1; } //LogErr("--rearrange:%lld,%lld,%lld",sort_rec[index1-1].key,key,sort_rec[index1+1].key); return 1; } int Mtp3DeleteRecord(ull key,BYTE nw) //VLR_RECORD vlr_record) { mtp3DPCIndex *sort_rec = &mtp3SortRoutine.nw[nw]; // long long imsi=key; DWORD MoveNum; int index=-1; if (sort_rec->sortedNum == 0) { return 0; } index = Mtp3BinSearchValue(0,255,nw,key); // index = BinSearchIndex(1,vlr_record_number,key); if(index<0 || index>=sort_rec->sortedNum) { // LogMsg("VLR--ERROR!Delete Record index=%ld",index); return 0; } MoveNum = (sort_rec->sortedNum-index) % 256; memmove(&sort_rec->dpc[index],&sort_rec->dpc[index+1],MoveNum*sizeof(ull)); memmove(&sort_rec->index[index],&sort_rec->index[index+1],MoveNum*sizeof(DWORD)); // LogErr("----After del %lld,%lld,%lld",sort_rec[index-1].key,sort_rec[index].key,sort_rec[index+1].key); sort_rec->dpc[sort_rec->sortedNum]=0; sort_rec->index[sort_rec->sortedNum]=0; sort_rec->sortedNum--; return 1; } BYTE mtp_encode_integer(BYTE *buf,DWORD val,BYTE value_len) { if(val<128) { if (value_len == 4) { buf[0] = 0; buf[1] = 0; buf[2]=val; return 3; } else { buf[0] = val; return 1; } } else if(val<0x8000) { if (value_len == 4) { buf[0] = 0; buf[1]=val >>8; buf[2]=val & 0xFF; return 3; } else { buf[0]=val; return 1; } } else if(val <0x800000) { buf[0]=val >>16; buf[1]=(val & 0xFF00)>>8; buf[2]=val & 0xFF; return 3; } // else if(val <0x80000000) else { buf[0]=(val & 0xFF0000)>>16; buf[1]=(val & 0xFF00)>>8; buf[2]=val & 0xFF; return 3; } } int mtp3_reset_sccp() { DWORD oid[20] = {1,3,6,1,4,1,1373,2,3,2,3,3,2};//SCCP_OID BYTE value=0; return set_response(13,oid,&value,1); } void del_1dst_from_table(ls_info *ls, BYTE dpc_place, BYTE ud_select) { BYTE dst_num; int i; switch (ud_select) { case UPDATE_NLS: dst_num = ls->influ_dstnum_asNLS; if (dst_num == 0) return; ls->influ_dstnum_asNLS --; for (i=0; iinflu_dstplace_intable_asNLS[i] == dpc_place) { memcpy(&ls->influ_dstplace_intable_asNLS[i], &ls->influ_dstplace_intable_asNLS[i+1],dst_num-i-1); ls->influ_dstplace_intable_asNLS[dst_num-1] = 0; return; } } break; case 1: dst_num = ls->influ_dstnum_asALS; if (dst_num == 0) return; ls->influ_dstnum_asALS --; for (i=0; iinflu_dstplace_intable_asALS[i] == dpc_place) { memcpy(&ls->influ_dstplace_intable_asALS[i], &ls->influ_dstplace_intable_asALS[i+1],dst_num-i-1); ls->influ_dstplace_intable_asALS[dst_num-1] = 0; return; } } break; } } void add_1dst_to_table(ls_info *ls, BYTE place,BYTE ud_select) { BYTE dst_num; switch (ud_select) { case UPDATE_NLS: dst_num = ls->influ_dstnum_asNLS; ls->influ_dstplace_intable_asNLS[dst_num] = place; ls->influ_dstnum_asNLS = dst_num + 1; break; case UPDATE_ALS: dst_num = ls->influ_dstnum_asALS; ls->influ_dstplace_intable_asALS[dst_num] = place; ls->influ_dstnum_asALS = dst_num + 1; break; } } void scan_conf_right_or_not(BYTE nw) { static BYTE index=0; BYTE nls; BYTE lsnw; return; nls = mtp3_para->nw[nw].normal_ls[index]; if (nls < 128) { lsnw = mtp3_para->ls_pro[nls] & 3; if ((lsnw != nw) && (mtp3_para->nw[nw].dpc[index] != 0)) printf("configure error,nw %d,dpc=%lx normal linkset belong to network %d\n",nw,mtp3_para->nw[nw].dpc[index],lsnw); } index ++; } void mtp3lite_upd_route_status(BYTE chl, BYTE flag) { ls_info *ls; int i; BYTE dpc_index, lsno, nw; lsno = mtp3_para->lk[chl].e1_to_linkset; if (lsno >= 0x80) return; ls = &mtp3.ls[lsno]; nw = mtp3_para->ls_pro[lsno] & 3; for (i = 0; i < ls->influ_dstnum_asNLS; i++) { dpc_index = ls->influ_dstplace_intable_asNLS[i]; if (!flag) mark_normal_linkset_unavailable(&mtp3.nw[nw].routine[dpc_index]); else mark_normal_linkset_available(&mtp3.nw[nw].routine[dpc_index]); if ((mtp3.nw[nw].routine[dpc_index] & 0x0f) == 0x0a)// all road unavailable mark_dstSP_inaccessible(&mtp3.nw[nw].routine[dpc_index]); hmrt_tfrc_update_routing_tables(dpc_index,nw); } } void change_the_whole_ls(BYTE lsno,BYTE oldnw,BYTE nw) { ls_info *ls; int i; nw_para *nwpara; BYTE *routine; BYTE ls_available; BYTE dpc_index; int added=0; ull opc_dpc=0; ls = &mtp3.ls[lsno]; // printf("oldnw = %d,newnw=%d\n",oldnw,nw); for (i=0;iinflu_dstnum_asNLS;i++) { dpc_index = ls->influ_dstplace_intable_asNLS[i]; mark_normal_linkset_unavailable(&mtp3.nw[oldnw].routine[dpc_index]); if ((mtp3.nw[oldnw].routine[dpc_index] & 0x0f) == 0x0a)// all road unavailable mark_dstSP_inaccessible(&mtp3.nw[oldnw].routine[dpc_index]); hmrt_tfrc_update_routing_tables(dpc_index,oldnw); ls->influ_dstplace_intable_asNLS[i] = 0xff; opc_dpc = mtp3_para->nw[oldnw].opc[dpc_index]; opc_dpc = (opc_dpc<<32)| mtp3_para->nw[oldnw].dpc[dpc_index]; Mtp3DeleteRecord(opc_dpc, oldnw); } for (i=0;iinflu_dstnum_asALS;i++) { dpc_index = ls->influ_dstplace_intable_asALS[i]; mark_alternative_linkset_unavailable(&mtp3.nw[oldnw].routine[dpc_index]); if ((mtp3.nw[oldnw].routine[dpc_index] & 0x0f) == 0x0a)// all road unavailable mark_dstSP_inaccessible(&mtp3.nw[oldnw].routine[dpc_index]); hmrt_tfrc_update_routing_tables(dpc_index,oldnw); ls->influ_dstplace_intable_asALS[i] = 0xff; opc_dpc = mtp3_para->nw[oldnw].opc[dpc_index]; opc_dpc = (opc_dpc<<32) | mtp3_para->nw[oldnw].dpc[dpc_index]; Mtp3DeleteRecord(opc_dpc,oldnw); } ls->influ_dstnum_asNLS = 0; ls->influ_dstnum_asALS = 0; if (mtp3.ls[lsno].links_available_t > 0) ls_available = TRUE; else ls_available = FALSE; nwpara = &mtp3_para->nw[nw]; for (i=0;i<256;i++) { if (nwpara->dpc[i] == 0) continue; routine = &mtp3.nw[nw].routine[i]; if (nwpara->normal_ls[i] == lsno) { if (ls_available == TRUE) mark_normal_linkset_available(routine); else mark_normal_linkset_unavailable(routine); add_1dst_to_table(&mtp3.ls[lsno],i,UPDATE_NLS); Mtp3AddSortRec(nw,nwpara->dpc[i], i, nwpara->opc[i]);//??- added = 1; } if ((nwpara->alternative_ls[i] == lsno) && (nwpara->normal_ls[i] < 128) ) { if (ls_available == TRUE) mark_alternative_linkset_available(routine); else mark_alternative_linkset_unavailable(routine); add_1dst_to_table(&mtp3.ls[lsno],i,UPDATE_ALS); if (!added) Mtp3AddSortRec(nw,nwpara->dpc[i], i, nwpara->opc[i]);//??- } hmrt_tfrc_update_routing_tables(i,nw); added=0; } } void update_ls_influence_dst_table(BYTE nw, long dst, BYTE place, BYTE nls, BYTE als, DWORD rc, long opc)//??- { BYTE *routine; DWORD pc_new, rc_new, opc_new; BYTE nls_old; BYTE als_old; DWORD pc_old; BYTE nlsnw; BYTE alsnw; ull opc_dpc_new=0, opc_dpc_old=0; pc_new = decode_integer((BYTE*)&dst,4); rc_new = decode_integer((BYTE*)&rc,4); opc_new = decode_integer((BYTE*)&opc,4); routine = &mtp3.nw[nw].routine[place]; nls_old = mtp3_para->nw[nw].normal_ls[place]; als_old = mtp3_para->nw[nw].alternative_ls[place]; pc_old = mtp3_para->nw[nw].dpc[place]; nlsnw = mtp3_para->ls_pro[nls] & 3; alsnw = mtp3_para->ls_pro[als] & 3; if ((pc_old == pc_new) && (nls_old == nls) && (als_old == als) && (mtp3_para->nw[nw].rc[place] == rc_new)&& (mtp3_para->nw[nw].opc[place] == opc_new)) return; /* if(opc_new == 0 && pc_new != 0) { if(pc_length(nw) == MTP3_24BIT_PC) opc_new = mtp3_para->nw[nw].opc24; else opc_new = mtp3_para->nw[nw].opc14; } */ opc_dpc_new = opc_new; opc_dpc_new = (opc_dpc_new<<32)|pc_new; opc_dpc_old = mtp3_para->nw[nw].opc[place]; opc_dpc_old = (opc_dpc_old<<32)|pc_old; if (pc_old > 0) Mtp3DeleteRecord(opc_dpc_old,nw);//delect this pc from sort table //??- if (pc_new > 0) { if ((nls<128 && nlsnw == nw) || (als<128 && alsnw==nw)) { Mtp3AddSortRec(nw,pc_new,place, opc_new);//add this new pc to the sort table //??- } } if ( (nls != nls_old) || (als != als_old) ) { if ((nls < 128) && (nlsnw == nw)) { if (mtp3.ls[nls].links_available_t > 0) mark_normal_linkset_available(routine); else mark_normal_linkset_unavailable(routine); if (nls != nls_old) add_1dst_to_table(&mtp3.ls[nls],place,UPDATE_NLS); } else mark_normal_linkset_unavailable(routine); if ((als < 128) && (nls < 128) &&// if one spc doesn't has normal linkset,it can not has alternative linkset (alsnw == nw)) { if (mtp3.ls[als].links_available_t > 0) mark_alternative_linkset_available(routine); else mark_alternative_linkset_unavailable(routine); if ((als != als_old) || (nls_old > 127) ) { // printf("renew alternative linkset %d,num=%d\n",als,mtp3.ls[als].influ_dstnum_asALS); add_1dst_to_table(&mtp3.ls[als],place,UPDATE_ALS); // printf("renew alternative linkset %d,num=%d\n",als,mtp3.ls[als].influ_dstnum_asALS); } } else mark_alternative_linkset_unavailable(routine); if ((mtp3.nw[nw].routine[place] & 0x0f) == 0x0a) mark_dstSP_inaccessible(routine); hmrt_tfrc_update_routing_tables(place,nw); mtp3_para->nw[nw].dpc[place] = pc_new; mtp3_para->nw[nw].opc[place] = opc_new; mtp3_para->nw[nw].normal_ls[place] = nls; mtp3_para->nw[nw].alternative_ls[place] = als; if ( (nls_old < 128) && (nls_old != nls) ) del_1dst_from_table(&mtp3.ls[nls_old],place,UPDATE_NLS); if ( (als_old < 128) && (als_old != als) ) del_1dst_from_table(&mtp3.ls[als_old],place,UPDATE_ALS); } if (mtp3_para->ls_op_pc[nls] == pc_new) mtp3.ls[nls].adjacent_sp_place = place; mtp3_para->nw[nw].dpc[place] = pc_new; mtp3_para->nw[nw].opc[place] = opc_new; mtp3_para->nw[nw].rc[place] = rc_new; } int mtp3_write_parameter() { int i,j; int ix4; mtpfpConf = fopen(mtpconfile,"w"); if (mtpfpConf == NULL) return -1; fprintf(mtpfpConf,"#MTP3 CONFIGURE FILE\n"); fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[SERVICE NETWORK SP LEN]\n"); fprintf(mtpfpConf,"[%02x]\n",mtp3_para->nw_pro); fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[MTP3LITE TCP PORT]\n"); fprintf(mtpfpConf,"[%04x]\n",mtp3_para->mtp3lite_port); fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[LOCAL SP]\n"); fprintf(mtpfpConf,"[%06lx]\t[%06lx]\t[%06lx]\t[%06lx]\t\n",mtp3_para->nw[0].opc14, mtp3_para->nw[1].opc14,mtp3_para->nw[2].opc14,mtp3_para->nw[3].opc14); fprintf(mtpfpConf,"[%06lx]\t[%06lx]\t[%06lx]\t[%06lx]\t\n",mtp3_para->nw[0].opc24, mtp3_para->nw[1].opc24,mtp3_para->nw[2].opc24,mtp3_para->nw[3].opc24); fprintf(mtpfpConf,"\n"); /* e1 to linkset */ fprintf(mtpfpConf,"[LINK ATTRIBUTE]\n"); for (i=0; i<64; i++) { ix4 = i*4; for (j=0; j<4; j++) { fprintf(mtpfpConf,"[%02x.%02x.%08lx.%02x.%02x.%02x.%08lx.%02x.%02x.%08lx]\t",mtp3_para->lk[ix4+j].e1_to_linkset, mtp3_para->lk[ix4+j].e1_to_slc,mtp3_para->lk[ix4+j].e1_to_mtp3,mtp3_para->lk[ix4+j].e1_lk_type,mtp3_para->lk[ix4+j].e1_to_sg,mtp3_para->lk[ix4+j].e1_to_iid, mtp3_para->lk[ix4+j].remote_ip,mtp3_para->lk[ix4+j].inactive,mtp3_para->lk[ix4+j].inactive_tm,mtp3_para->lk[ix4+j].e1_to_alterMTP3); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); /* linkset remote sp */ fprintf(mtpfpConf,"[LINKSET ATTRIBUTE]\n"); for (i=0; i<32; i++) { ix4 = i*4; for (j=0; j<4; j++) { if (1) { char ls_reserved[128]={0}; char temp[16]; int k; for (k=0;k<16;k++) { sprintf(temp,"%02x",mtp3_para->ls_reserved[ix4+j][k]); strcat(ls_reserved,temp); } fprintf(mtpfpConf,"[%06lx.%02x.%-16s.%08lx]\t",mtp3_para->ls_op_pc[ix4+j],mtp3_para->ls_pro[ix4+j],ls_reserved, mtp3_para->ls_opc[ix4+j]); } } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); /* SG */ fprintf(mtpfpConf, "[SG ATTRIBUTES]\n"); for (i = 0; i < 64; i++) { ix4 = i * 4; for (j = 0; j < 4; j++) { fprintf(mtpfpConf, "[%02X.%02X.%02X.%08lX]\t", mtp3_para->sg[ix4+j].enable, mtp3_para->sg[ix4+j].server, mtp3_para->sg[ix4+j].data_ack, mtp3_para->sg[ix4+j].ip); } fprintf(mtpfpConf, "\n"); } fprintf(mtpfpConf, "\n"); /* NATIONAL NETWORK SP */ fprintf(mtpfpConf,"[NATIONAL NETWORK SP]\n"); for (i=0; i<64; i++) { ix4 = i*4; for (j=0; j<4; j++) { fprintf(mtpfpConf,"[%06lx.%02x.%02x.%08lx.%08lx]\t",mtp3_para->nw[2].dpc[ix4+j],mtp3_para->nw[2].normal_ls[ix4+j], mtp3_para->nw[2].alternative_ls[ix4+j], mtp3_para->nw[2].rc[ix4+j], mtp3_para->nw[2].opc[ix4+j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); /* NATIONAL NETWORK SPARE SP */ fprintf(mtpfpConf,"[NATIONAL NETWORK SPARE SP]\n"); for (i=0; i<64; i++) { ix4 = i*4; for (j=0; j<4; j++) { fprintf(mtpfpConf,"[%06lx.%02x.%02x.%08lx.%08lx]\t",mtp3_para->nw[3].dpc[ix4+j],mtp3_para->nw[3].normal_ls[ix4+j], mtp3_para->nw[3].alternative_ls[ix4+j], mtp3_para->nw[3].rc[ix4+j], mtp3_para->nw[3].opc[ix4+j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); /* INTERNATIONAL NETWORK SP */ fprintf(mtpfpConf,"[INTERNATIONAL NETWORK SP]\n"); for (i=0; i<64; i++) { ix4 = i*4; for (j=0; j<4; j++) { fprintf(mtpfpConf,"[%06lx.%02x.%02x.%08lx.%08lx]\t",mtp3_para->nw[0].dpc[ix4+j],mtp3_para->nw[0].normal_ls[ix4+j], mtp3_para->nw[0].alternative_ls[ix4+j], mtp3_para->nw[0].rc[ix4+j], mtp3_para->nw[0].opc[ix4+j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); /* INTERNATIONAL NETWORK SP */ fprintf(mtpfpConf,"[INTERNATIONAL NETWORK SPARE SP]\n"); for (i=0; i<64; i++) { ix4 = i*4; for (j=0; j<4; j++) { fprintf(mtpfpConf,"[%06lx.%02x.%02x.%08lx.%08lx]\t",mtp3_para->nw[1].dpc[ix4+j],mtp3_para->nw[1].normal_ls[ix4+j], mtp3_para->nw[1].alternative_ls[ix4+j], mtp3_para->nw[1].rc[ix4+j], mtp3_para->nw[1].opc[ix4+j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[LOCAL ACN]\n"); for(i=0;ilocalAcn[i]); } fprintf(mtpfpConf,"\n\n"); fprintf(mtpfpConf,"[INTERNATIONAL NETWORK ACN]\n"); for (i=0; i<256; i++) { for (j=0;jnw[0].acn[i][j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[INTERNATIONAL NETWORK SPARE ACN]\n"); for (i=0; i<256; i++) { for (j=0;jnw[1].acn[i][j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[NATIONAL NETWORK ACN]\n"); for (i=0; i<256; i++) { for (j=0;jnw[2].acn[i][j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); fprintf(mtpfpConf,"[NATIONAL NETWORK SPARE ACN]\n"); for (i=0; i<256; i++) { for (j=0;jnw[3].acn[i][j]); } fprintf(mtpfpConf,"\n"); } fprintf(mtpfpConf,"\n"); fclose(mtpfpConf); return 1; } static int issquare(char c) { if ((c=='[') || (c==']') || (c==' ') || (c=='\t')) return 1; return 0; } static int isdot(char c) { if ((c=='.')) return 1; return 0; } int ParseLineWithSquare(char *str, char (*row)[128], int maxrow) { char *pstr = str; int len, index = 0, i; BOOL black = 0; len = strlen(str); for(i = 0; i < len && index < maxrow; i++) { if(issquare(str[i])) { if(black == 0) pstr = str + i + 1; else { str[i] = '\0'; if(strlen(pstr) > 128) pstr[127] = 0; sprintf(row[index++], "%s", pstr); pstr = str + i + 1; } black = 0; } else black = 1; } if(black == 1) { if(strlen(pstr) > 128) pstr[127] = 0; sprintf(row[index++], "%s", pstr); } return index; } int ParseLineWithDot(char *str, char (*row)[128], int maxrow) { char *pstr = str; int len, index = 0, i; BOOL black = 0; len = strlen(str); for(i = 0; i < len && index < maxrow; i++) { if(isdot(str[i])) { if(black == 0) pstr = str + i + 1; else { str[i] = '\0'; if(strlen(pstr) > 128) pstr[127] = 0; sprintf(row[index++], "%s", pstr); pstr = str + i + 1; } black = 0; } else black = 1; } if(black == 1) { if(strlen(pstr) > 128) pstr[127] = 0; sprintf(row[index++], "%s", pstr); } return index; } int ReadMtp3NetworkPara(char *s) { char LineInfo[1][128]; int rtn; rtn = ParseLineWithSquare(s, LineInfo, 1); mtp3_para->nw_pro = strtoll(LineInfo[0],NULL,16); return 1; } int ReadMtp3LitePortPara(char *s) { char LineInfo[1][128]; int rtn; rtn = ParseLineWithSquare(s, LineInfo, 1); mtp3_para->mtp3lite_port = strtoll(LineInfo[0],NULL,16); return 1; } int ReadMtp3OPCPara(char *s) { char LineInfo[8][128]; int rtn; int instance; static int Base=0; rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four links if (Base==0) { for (instance=0;instance<4;instance++) { mtp3_para->nw[instance].opc14 = strtoll(LineInfo[instance],NULL,16); } } else { for (instance=0;instance<4;instance++) { mtp3_para->nw[instance].opc24 = strtoll(LineInfo[instance],NULL,16); } } Base++; if (Base > 1) { Base = 0; return 1; } return 0; } int ReadMtp3LinkPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; DWORD mtp3ip; rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four links for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,10); mtp3_para->lk[Base+Instance].e1_to_linkset = strtoll(DetailInfo[0],NULL,16); mtp3_para->lk[Base+Instance].e1_to_slc = strtoll(DetailInfo[1],NULL,16); mtp3ip = strtoll(DetailInfo[2],NULL,16); if (rtn == 3) { if (mtp3ip == 0xff) mtp3_para->lk[Base+Instance].e1_to_mtp3 = 0xffffffff; else mtp3_para->lk[Base+Instance].e1_to_mtp3 = 0x010012ac | ((mtp3ip & 0xff) << 16); mtp3_para->lk[Base+Instance].e1_lk_type = 0x01; mtp3_para->lk[Base+Instance].e1_to_alterMTP3 = 0xffffffff; } else { mtp3_para->lk[Base+Instance].e1_to_mtp3 = mtp3ip; mtp3_para->lk[Base+Instance].e1_lk_type = strtoll(DetailInfo[3],NULL,16); mtp3_para->lk[Base+Instance].e1_to_sg = strtoll(DetailInfo[4],NULL,16); mtp3_para->lk[Base+Instance].e1_to_iid = strtoll(DetailInfo[5],NULL,16); mtp3_para->lk[Base+Instance].remote_ip = strtoll(DetailInfo[6],NULL,16); mtp3_para->lk[Base+Instance].inactive = strtoll(DetailInfo[7],NULL,16); mtp3_para->lk[Base+Instance].inactive_tm = strtoll(DetailInfo[8],NULL,16); mtp3_para->lk[Base+Instance].e1_to_alterMTP3 = strtoll(DetailInfo[9],NULL,16); if(mtp3_para->lk[Base+Instance].e1_to_alterMTP3 == mtp3_para->lk[Base+Instance].e1_to_mtp3) { mtp3_para->lk[Base+Instance].e1_to_alterMTP3 = 0xffffffff; } } #ifdef _INCLUDE_M2UA set_m2ua_link(Base+Instance, (BYTE *) &mtp3_para->lk[Base+Instance]); #endif } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3LinksetPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; memset(DetailInfo, 0, sizeof(DetailInfo)); rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,4); mtp3_para->ls_op_pc[Base+Instance] = strtoll(DetailInfo[0],NULL,16); mtp3_para->ls_pro[Base+Instance] = strtoll(DetailInfo[1],NULL,16); if (rtn == 3) Str2Bcd(mtp3_para->ls_reserved[Base+Instance],DetailInfo[2],16); mtp3_para->ls_opc[Base+Instance] = strtoll(DetailInfo[3],NULL,16); } Base+=4; if (Base >= 128) { Base = 0; return 1; } return 0; } int ReadMtp3SGPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,4); mtp3_para->sg[Base+Instance].enable = strtoll(DetailInfo[0],NULL,16); mtp3_para->sg[Base+Instance].server = strtoll(DetailInfo[1],NULL,16); mtp3_para->sg[Base+Instance].data_ack = strtoll(DetailInfo[2],NULL,16); mtp3_para->sg[Base+Instance].ip = strtoll(DetailInfo[3],NULL,16); #ifdef _INCLUDE_M2UA set_m2ua_sg(Base+Instance, (BYTE *) &mtp3_para->sg[Base+Instance]); #endif } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3NATPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; memset(DetailInfo, 0, sizeof(DetailInfo)); rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,5);//4);//3); mtp3_para->nw[2].dpc[Base+Instance] = strtoll(DetailInfo[0],NULL,16); mtp3_para->nw[2].normal_ls[Base+Instance] = strtoll(DetailInfo[1],NULL,16); mtp3_para->nw[2].alternative_ls[Base+Instance] = strtoll(DetailInfo[2],NULL,16); mtp3_para->nw[2].rc[Base+Instance] = strtoll(DetailInfo[3],NULL,16); mtp3_para->nw[2].opc[Base+Instance] = strtoll(DetailInfo[4],NULL,16); } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3NATsPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; memset(DetailInfo, 0, sizeof(DetailInfo)); rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,5); mtp3_para->nw[3].dpc[Base+Instance] = strtoll(DetailInfo[0],NULL,16); mtp3_para->nw[3].normal_ls[Base+Instance] = strtoll(DetailInfo[1],NULL,16); mtp3_para->nw[3].alternative_ls[Base+Instance] = strtoll(DetailInfo[2],NULL,16); mtp3_para->nw[3].rc[Base+Instance] = strtoll(DetailInfo[3],NULL,16); mtp3_para->nw[3].opc[Base+Instance] = strtoll(DetailInfo[4],NULL,16); } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3INTPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; memset(DetailInfo, 0, sizeof(DetailInfo)); rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,5); mtp3_para->nw[0].dpc[Base+Instance] = strtoll(DetailInfo[0],NULL,16); mtp3_para->nw[0].normal_ls[Base+Instance] = strtoll(DetailInfo[1],NULL,16); mtp3_para->nw[0].alternative_ls[Base+Instance] = strtoll(DetailInfo[2],NULL,16); mtp3_para->nw[0].rc[Base+Instance] = strtoll(DetailInfo[3],NULL,16); mtp3_para->nw[0].opc[Base+Instance] = strtoll(DetailInfo[4],NULL,16); } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3INTsPara(char *s) { char LineInfo[8][128]; char DetailInfo[10][128]; int rtn; int Instance; static int Base=0; memset(DetailInfo, 0, sizeof(DetailInfo)); rtn = ParseLineWithSquare(s, LineInfo, 4);//each line four linksets for (Instance=0;Instance<4;Instance++) { rtn = ParseLineWithDot(LineInfo[Instance],DetailInfo,5); mtp3_para->nw[1].dpc[Base+Instance] = strtoll(DetailInfo[0],NULL,16); mtp3_para->nw[1].normal_ls[Base+Instance] = strtoll(DetailInfo[1],NULL,16); mtp3_para->nw[1].alternative_ls[Base+Instance] = strtoll(DetailInfo[2],NULL,16); mtp3_para->nw[1].rc[Base+Instance] = strtoll(DetailInfo[3],NULL,16); mtp3_para->nw[1].opc[Base+Instance] = strtoll(DetailInfo[4],NULL,16); } Base+=4; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3LocalACNPara(char *s) { char LineInfo[1][128]; int rtn; rtn = ParseLine(s, LineInfo, 1);//each line four linksets AsciiToBcd(mtp3_para->localAcn,LineInfo[0],MAX_ACN_NUM*2); return 1; } int ReadMtp3INTACNPara(char *s) { char LineInfo[1][128]; int rtn; static int Base=0; rtn = ParseLine(s, LineInfo, 1);//each line four linksets AsciiToBcd(mtp3_para->nw[0].acn[Base],LineInfo[0],MAX_ACN_NUM*2); Base++; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3INTsACNPara(char *s) { char LineInfo[1][128]; int rtn; static int Base=0; rtn = ParseLine(s, LineInfo, 1);//each line four linksets AsciiToBcd(mtp3_para->nw[1].acn[Base],LineInfo[0],MAX_ACN_NUM*2); Base++; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3NATACNPara(char *s) { char LineInfo[1][128]; int rtn; static int Base=0; rtn = ParseLine(s, LineInfo, 1);//each line four linksets AsciiToBcd(mtp3_para->nw[2].acn[Base],LineInfo[0],MAX_ACN_NUM*2); Base++; if (Base >= 256) { Base = 0; return 1; } return 0; } int ReadMtp3NATSACNPara(char *s) { char LineInfo[1][128]; int rtn; static int Base=0; rtn = ParseLine(s, LineInfo, 1);//each line four linksets AsciiToBcd(mtp3_para->nw[3].acn[Base],LineInfo[0],MAX_ACN_NUM*2); Base++; if (Base >= 256) { Base = 0; return 1; } return 0; } void mtp3_readpara_from_disk() { char s[1024]={0}; int len; BYTE state = 0; FILE *fp; fp = fopen(mtpconfile,"rb"); if (fp==NULL) { printf("mtp3 config file %s missed!!\n",mtpconfile); return; } s[0] = 0; while ( fgets(s,1024,fp) != (char *)0 ) { if ( (int *)strchr(s,'#') != NULL ) continue; if ( (len=strlen(s))==0 ) continue; if ( strstr(s,"[SERVICE NETWORK SP LEN]") != NULL ) { state = 1; continue; } else if ( strstr(s,"[MTP3LITE TCP PORT]") != NULL ) { state = 2; continue; } else if ( strstr(s,"[LOCAL SP]") != NULL ) { state = 3; continue; } else if ( strstr(s,"[LINK ATTRIBUTE]") != NULL ) { state = 4; continue; } else if ( strstr(s,"[LINKSET ATTRIBUTE]") != NULL ) { state = 5; continue; } else if ( strstr(s,"[SG ATTRIBUTES]") != NULL ) { state = 6; continue; } else if ( strstr(s,"[NATIONAL NETWORK SP]") != NULL ) { state = 7; continue; } else if ( strstr(s,"[NATIONAL NETWORK SPARE SP]") != NULL ) { state = 8; continue; } else if ( strstr(s,"[INTERNATIONAL NETWORK SP]") != NULL ) { state = 9; continue; } else if ( strstr(s,"[INTERNATIONAL NETWORK SPARE SP]") != NULL ) { state = 10; continue; } else if ( strstr(s,"[LOCAL ACN]") != NULL ) { state = 11; continue; } else if ( strstr(s,"[INTERNATIONAL NETWORK ACN]") != NULL ) { state = 12; continue; } else if ( strstr(s,"[INTERNATIONAL NETWORK SPARE ACN]") != NULL ) { state = 13; continue; } else if ( strstr(s,"[NATIONAL NETWORK ACN]") != NULL ) { state = 14; continue; } else if ( strstr(s,"[NATIONAL NETWORK SPARE ACN]") != NULL ) { state = 15; continue; } switch (state) { case 1: if (ReadMtp3NetworkPara(s)) state = 0; break; case 2: if (ReadMtp3LitePortPara(s)) state = 0; break; case 3: if (ReadMtp3OPCPara(s)) state = 0; break; case 4: if (ReadMtp3LinkPara(s)) state = 0; break; case 5: if (ReadMtp3LinksetPara(s)) state = 0; break; case 6: if (ReadMtp3SGPara(s)) state = 0; break; case 7: if (ReadMtp3NATPara(s)) state = 0; break; case 8: if (ReadMtp3NATsPara(s)) state = 0; break; case 9: if (ReadMtp3INTPara(s)) state = 0; break; case 10: if (ReadMtp3INTsPara(s)) state = 0; break; case 11: if (ReadMtp3LocalACNPara(s)) state = 0; break; case 12: if (ReadMtp3INTACNPara(s)) state = 0; break; case 13: if (ReadMtp3INTsACNPara(s)) state = 0; break; case 14: if (ReadMtp3NATACNPara(s)) state = 0; break; case 15: if (ReadMtp3NATSACNPara(s)) state = 0; break; default: break; } } fclose(fp); } void mtp3_setlink_to_IDLE(BYTE link) { BYTE oldls; BYTE oldslc; DWORD oldip; BYTE oldtp; oldls = mtp3_para->lk[link].e1_to_linkset; oldslc = mtp3_para->lk[link].e1_to_slc; oldip = mtp3_para->lk[link].e1_to_mtp3; oldtp = mtp3_para->lk[link].e1_lk_type; if (mtp3ObjState.link_l3_state[link] == AVAILABLE) { if ((MTP3_LINK_TYPE(link) == LKTYPE_MTP3_LITE) && // Not MTP3LITE (mtp3_para->lk[link].e1_lk_type & 0x01)) // Enabled {//sccp lite link deactive_mtp3lite_lk(link); } else if((MTP3_LINK_TYPE(link) == LKTYPE_M3UA) && // Not M3UA (mtp3_para->lk[link].e1_lk_type & 0x01)) // Enabled {//sccp lite link deactive_m3ua_lk(link); } else { mtp3ObjInput.sltc_input[link] = SLTC_STOP; sltc_proc(link); init_lsac_state[link] = TRUE; lsac_proc(link); init_tlac_state[link] = TRUE; tlac_proc(link); if (mtp3ObjState.link_l3_state[link] == AVAILABLE) otherMTP3_managed_link_unavailable(link); mtp3ObjState.link_l2_state[link] = UNAVAILABLE; mtp3ObjState.link_l3_state[link] = UNAVAILABLE; } } if (mtp3ObjState.lk_configured[link] == PARA_CONFIGURED) { mtp3.ls[oldls].linksNum_configured--; ls_slc[oldls*16+oldslc] = 0xff; update_sls_to_link_table(oldls); } mtp3ObjState.lk_configured[link] = PARA_NOT_CONFIGURED; // printf("link %d update para,new ls=%d,new slc = %d,new ip=%lx\n",link,newls,newslc,newip); } int mtp_setmib(BYTE oidlen, DWORD *oid, BYTE *pdata,WORD datalen) { int instance; DWORD pc; BYTE command; int ls; int slc; DWORD ip; DWORD ip1; int tp; int i; DWORD oldpc, opc, oldopc; BYTE old_lsnw; BYTE new_lsnw; DWORD oldpar, rc; BOOL para_changed=0; if ( oidlen < MTP3_OID_LEN) { printf("set failed,object id length not correct\n"); return -1; } if ( oid[MTP3_OID_LEN] == 2 )/* configure */ { switch (oid[MTP3_OID_LEN+1]) { case 1:/* sp/stp */ break; case 2:/* 14/24bit (for four service networks) */ oldpar = mtp3_para->nw_pro; mtp3_para->nw_pro = decode_integer(pdata,datalen); if (oldpar != mtp3_para->nw_pro) mtp3_reset_sccp(); return 1; case 3:/* opc */ memcpy(&pc,pdata,4); pc = pc << 8; switch (oid[MTP3_OID_LEN+2]) { case 1: oldpar = mtp3_para->nw[0].opc14; mtp3_para->nw[0].opc14 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[0].opc14) { mtp3_reset_sccp(); mtp3_delete_opc(0, mtp3_para->nw[0].opc14); } return 3; case 2: oldpar = mtp3_para->nw[1].opc14; mtp3_para->nw[1].opc14 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[1].opc14) { mtp3_reset_sccp(); mtp3_delete_opc(1, mtp3_para->nw[1].opc14); } return 3; case 3: oldpar = mtp3_para->nw[2].opc14; mtp3_para->nw[2].opc14 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[2].opc14) { mtp3_reset_sccp(); mtp3_delete_opc(2, mtp3_para->nw[2].opc14); } return 3; case 4: oldpar = mtp3_para->nw[3].opc14; mtp3_para->nw[3].opc14 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[3].opc14) { mtp3_reset_sccp(); mtp3_delete_opc(3, mtp3_para->nw[3].opc14); } return 3; case 5: oldpar = mtp3_para->nw[0].opc24; mtp3_para->nw[0].opc24 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[0].opc24) { mtp3_reset_sccp(); mtp3_delete_opc(0, mtp3_para->nw[0].opc24); } return 3; case 6: oldpar = mtp3_para->nw[1].opc24; mtp3_para->nw[1].opc24 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[1].opc24) { mtp3_reset_sccp(); mtp3_delete_opc(1, mtp3_para->nw[1].opc24); } return 3; case 7: oldpar = mtp3_para->nw[2].opc24; mtp3_para->nw[2].opc24 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[2].opc24) { mtp3_reset_sccp(); mtp3_delete_opc(2, mtp3_para->nw[2].opc24); } return 3; case 8: oldpar = mtp3_para->nw[3].opc24; mtp3_para->nw[3].opc24 = decode_integer((BYTE*)&pc,4); if (oldpar != mtp3_para->nw[3].opc24) { mtp3_reset_sccp(); mtp3_delete_opc(3, mtp3_para->nw[3].opc24); } return 3; default: return -1; } break; case 4:/* linkset */ instance = oid[MTP3_OID_LEN+3]; if (instance > 127) return -1; switch (oid[MTP3_OID_LEN+2]) { case 1: oldpc = mtp3_para->ls_op_pc[instance]; old_lsnw = mtp3_para->ls_pro[instance] & 3; if(datalen>=24) { memcpy(&opc, &pdata[20], 4); opc = ntohl(opc); } oldopc = mtp3_para->ls_opc[instance]; mtp3_para->ls_opc[instance]=opc; new_lsnw = pdata[3] & 3; memcpy(&pc,pdata,4); pc = pc << 8; mtp3_para->ls_op_pc[instance] = decode_integer((BYTE*)&pc,4); /* linkset adjacent sp */ mtp3_para->ls_pro[instance] = pdata[3]; memcpy(&mtp3_para->ls_reserved[instance],&pdata[4],16); if (old_lsnw != new_lsnw) { change_the_whole_ls(instance,old_lsnw,new_lsnw); } if ((oldpc != mtp3_para->ls_op_pc[instance]) || (old_lsnw != new_lsnw)||(oldopc != mtp3_para->ls_opc[instance]) ) { pc = mtp3_para->ls_op_pc[instance]; for (i=0;i<256;i++) { if (mtp3_para->nw[new_lsnw].dpc[i] == pc && mtp3_para->nw[new_lsnw].opc[i] == opc) { mtp3.ls[instance].adjacent_sp_place = i; return 24; } } // printf("not found pc in table\n"); mtp3.ls[instance].adjacent_sp_place = 0xffff; } return 24; default: return -1; } break; case 5:/* link */ instance = oid[MTP3_OID_LEN+3]; switch (oid[MTP3_OID_LEN+2]) { case 1:/* e1 to linkset */ ls = pdata[0]; slc = pdata[1]; memcpy(&ip,&pdata[2],4); memcpy(&ip1,&pdata[15],4); // ip = pdata[2]; tp = pdata[6]; if(ip == ip1 && ip1 != 0xffffff) {//ip can not be same as ip1 ip1 = 0xffffffff; memcpy(&pdata[15], &ip1, 4); } if (ls!=mtp3_para->lk[instance].e1_to_linkset || slc!=mtp3_para->lk[instance].e1_to_slc || ip!=mtp3_para->lk[instance].e1_to_mtp3 || ip1!=mtp3_para->lk[instance].e1_to_alterMTP3 || tp != mtp3_para->lk[instance].e1_lk_type) { mtp3_setlink_to_IDLE(instance); para_changed = 1; } if (datalen<19) memcpy((BYTE *)&mtp3_para->lk[instance].e1_to_linkset, pdata, 15); else memcpy((BYTE *)&mtp3_para->lk[instance].e1_to_linkset, pdata, 19); mtp3ObjState.link_type[instance] = mtp3_para->lk[instance].e1_lk_type; if (para_changed) { if (update_ls_slc_table(instance) == 1) { update_sls_to_link_table(ls); MTP3_LinkIP_List(mtp3_para->lk[instance].e1_to_mtp3,1); MTP3_LinkIP_List(mtp3_para->lk[instance].e1_to_alterMTP3,1); } } #ifdef _INCLUDE_M2UA set_m2ua_link(instance & 0xff, pdata); #endif return 19; case 2:/* link command */ mtp3ObjState.lk_command[instance] = pdata[0]; if (mtp3ObjState.lk_mtp3[instance] != mtp3_localip) return 1; if (MTP3_LINK_TYPE(instance) == LKTYPE_MTP3_LITE) { if (pdata[0]==0)//disable deactive_mtp3lite_lk(instance); return 1; } else if (MTP3_LINK_TYPE(instance) == LKTYPE_M3UA) { if (pdata[0]==0)//disable deactive_m3ua_lk(instance); return 1; } else { command = pdata[0]; if (command < 2) { mtp3ObjInput.lsac_input_from_mgmt[instance] = command; return 1; } else if (command < 4) { mtp3ObjInput.tlac_input_from_mgmt[instance] = command - 1; return 1; } else return -1; } case 3:/* MTP3LITE TCP Port */ mtp3_para->mtp3lite_port = pdata[1]; mtp3_para->mtp3lite_port = (mtp3_para->mtp3lite_port << 8) | pdata[0]; return 2; default: return -1; } break; case 6:/* routine table */ instance = oid[MTP3_OID_LEN+3]; memcpy(&pc,pdata,4); memcpy(&rc,&pdata[5],4); pc = pc << 8; memcpy(&opc, &pdata[9], 4); if ((oid[MTP3_OID_LEN+2] > 4) || (oid[MTP3_OID_LEN+2] < 1)) return -1; update_ls_influence_dst_table((oid[MTP3_OID_LEN+2]-1),pc,instance,pdata[3],pdata[4], rc, opc); return 13; case 7:/* dpc->acn */ instance = oid[MTP3_OID_LEN+3]; if (oid[MTP3_OID_LEN+2] == 1) { memcpy(mtp3_para->localAcn,pdata,MAX_ACN_NUM); } else if ((oid[MTP3_OID_LEN+2] > 1) && (oid[MTP3_OID_LEN+2] < 6)) { memcpy(mtp3_para->nw[oid[MTP3_OID_LEN+2]-2].acn[instance],pdata,MAX_ACN_NUM); } else return -1; return MAX_ACN_NUM; case 8:/* timer */ instance = oid[MTP3_OID_LEN+3]; switch (oid[MTP3_OID_LEN+2]) { case 1:/* link timer */ memcpy(&mtp3_para->lt[instance].t1,pdata,10); update_timer(instance); return 10; default: return -1; } return -1; case 9:/* sg */ instance = oid[MTP3_OID_LEN+2]; memcpy(&mtp3_para->sg[instance],pdata,7); #ifdef _INCLUDE_M2UA set_m2ua_sg(instance & 0xff, pdata); return 7; #else return 7; #endif default: return -1; } return -1; } else if (oid[MTP3_OID_LEN] == 3)/* status */ { switch (oid[MTP3_OID_LEN+1]) { case 7: case 8:/* command */ switch (pdata[0]) { case 1: reset_mtp3(); break; case 2: printf("save parameter\n"); return mtp3_write_parameter(); break; case 3://load data mtp3_reload_data(); break; default: break; } return 1; default: return -1; } } else return -1; } void mtp3_data_reverse(BYTE *pdata,BYTE *csta,BYTE len,BYTE data_type) { int i; int j=0; for (i=0; i 15) temp = 15; mtp3_measure.measure[portion_num].lk_measure1[instance][i] = temp; } break; case 1: temp = mtp3_measure.measure[portion_num].ls_measure[instance][0]; temp = (temp + 3) / 6; if (temp > 15) temp = 15; mtp3_measure.measure[portion_num].ls_measure[instance][0] = temp; temp = mtp3_measure.measure[portion_num].ls_measure[instance][6]; temp = (temp + 3) / 6; if (temp > 15) temp = 15; mtp3_measure.measure[portion_num].ls_measure[instance][6] = temp; break; default: break; } } int mtp_getmib(BYTE oidlen, DWORD *oid, BYTE *pdata,BYTE *vartype) { /* 1.3.6.1.4.1.1373.1.1.2.2.2.2 */ unsigned int instance; BYTE portion_num=0; DWORD timestamp; DWORD get_rc=0; if ( oidlen < 12 ) { printf("get fail,object id not correct\n"); return -1; } if ( oid[MTP3_OID_LEN] == 2 )/* configure */ { switch (oid[MTP3_OID_LEN+1]) { case 1:/* sp/stp */ return -1; case 2:/* 14/24bit (for four service networks) */ *vartype = 4; return mtp_encode_integer(pdata,mtp3_para->nw_pro,1); case 3:/* opc */ *vartype = 4; switch (oid[MTP3_OID_LEN+2]) { case 1: return mtp_encode_integer(pdata,mtp3_para->nw[0].opc14,4); case 2: return mtp_encode_integer(pdata,mtp3_para->nw[1].opc14,4); case 3: return mtp_encode_integer(pdata,mtp3_para->nw[2].opc14,4); case 4: return mtp_encode_integer(pdata,mtp3_para->nw[3].opc14,4); case 5: return mtp_encode_integer(pdata,mtp3_para->nw[0].opc24,4); case 6: return mtp_encode_integer(pdata,mtp3_para->nw[1].opc24,4); case 7: return mtp_encode_integer(pdata,mtp3_para->nw[2].opc24,4); case 8: return mtp_encode_integer(pdata,mtp3_para->nw[3].opc24,4); default: return -1; } return -1; case 4:/* linkset */ instance = oid[MTP3_OID_LEN+3]; *vartype = 4; switch (oid[MTP3_OID_LEN+2]) { case 1: mtp_encode_integer(pdata,mtp3_para->ls_op_pc[instance],4); pdata[3] = mtp3_para->ls_pro[instance]; memcpy(&pdata[4],&mtp3_para->ls_reserved[instance],16); get_rc = htonl(mtp3_para->ls_opc[instance]); memcpy(&pdata[20], &get_rc, 4); return 24; /* linkset adjacent sp */ default: return -1; } return -1; case 5:/* link */ instance = oid[MTP3_OID_LEN+3]; *vartype = 4; switch (oid[MTP3_OID_LEN+2]) { case 1:/* e1 to linkset */ memcpy(pdata,&mtp3_para->lk[instance].e1_to_linkset,19); return 19; case 2: memcpy(pdata,&mtp3ObjState.lk_command[instance],1); return 1; case 3: pdata[0] = mtp3_para->mtp3lite_port; pdata[1] = mtp3_para->mtp3lite_port >> 8; return 2; default: return -1; } return -1; case 6:/* internation network routine table */ instance = oid[MTP3_OID_LEN+3]; *vartype = 4; switch (oid[MTP3_OID_LEN+2]) { case 1: mtp_encode_integer(pdata,mtp3_para->nw[0].dpc[instance],4); memcpy(&pdata[3],&mtp3_para->nw[0].normal_ls[instance],1); memcpy(&pdata[4],&mtp3_para->nw[0].alternative_ls[instance],1); get_rc = htonl(mtp3_para->nw[0].rc[instance]); memcpy(&pdata[5], &get_rc, 4); get_rc = htonl(mtp3_para->nw[0].opc[instance]); memcpy(&pdata[9], &get_rc, 4); return 13; case 2: mtp_encode_integer(pdata,mtp3_para->nw[1].dpc[instance],4); memcpy(&pdata[3],&mtp3_para->nw[1].normal_ls[instance],1); memcpy(&pdata[4],&mtp3_para->nw[1].alternative_ls[instance],1); get_rc = htonl(mtp3_para->nw[1].rc[instance]); memcpy(&pdata[5], &get_rc, 4); get_rc = htonl(mtp3_para->nw[1].opc[instance]); memcpy(&pdata[9], &get_rc, 4); return 13; case 3: mtp_encode_integer(pdata,mtp3_para->nw[2].dpc[instance], 4); memcpy(&pdata[3],&mtp3_para->nw[2].normal_ls[instance],1); memcpy(&pdata[4],&mtp3_para->nw[2].alternative_ls[instance],1); get_rc = htonl(mtp3_para->nw[2].rc[instance]); memcpy(&pdata[5], &get_rc, 4); get_rc = htonl(mtp3_para->nw[2].opc[instance]); memcpy(&pdata[9], &get_rc, 4); return 13; case 4: mtp_encode_integer(pdata,mtp3_para->nw[3].dpc[instance],4); memcpy(&pdata[3],&mtp3_para->nw[3].normal_ls[instance],1); memcpy(&pdata[4],&mtp3_para->nw[3].alternative_ls[instance],1); get_rc = htonl(mtp3_para->nw[3].rc[instance]); memcpy(&pdata[5], &get_rc, 4); get_rc = htonl(mtp3_para->nw[3].opc[instance]); memcpy(&pdata[9], &get_rc, 4); return 13; default: return -1; } return -1; case 7: instance = oid[MTP3_OID_LEN+3]; *vartype = 4; if (oid[MTP3_OID_LEN+2] == 1) { memcpy(pdata,mtp3_para->localAcn,MAX_ACN_NUM); } else if ((oid[MTP3_OID_LEN+2] > 1) && (oid[MTP3_OID_LEN+2] < 6)) { memcpy(pdata,mtp3_para->nw[oid[MTP3_OID_LEN+2]-2].acn[instance],MAX_ACN_NUM); } else return -1; return MAX_ACN_NUM; case 8: instance = oid[MTP3_OID_LEN+3]; *vartype = 4; switch (oid[MTP3_OID_LEN+2]) { case 1:/* link timer */ memcpy(pdata,&mtp3_para->lt[instance].t1,10); return 10; default: return -1; } return -1; case 9:/* SG */ instance = oid[MTP3_OID_LEN+2]; *vartype = 4; memcpy(pdata,&mtp3_para->sg[instance],7); return 7; default: return -1; } return -1; } else if (oid[MTP3_OID_LEN] == 3)/* status */ { *vartype = 4; switch (oid[MTP3_OID_LEN+1]) { case 1:/* link status */ return mtp_encode_integer(pdata,mtp3ObjState.link_l3_state[oid[MTP3_OID_LEN+2]],1); case 2:/* linkset status */ instance= oid[MTP3_OID_LEN+2]; if (instance > 127) return -1; if (mtp3.ls[instance].links_available > 0) pdata[0] = 1; else pdata[0] = 0; return 1; case 3:/* international network routine */ return mtp_encode_integer(pdata,mtp3.nw[0].routine[oid[MTP3_OID_LEN+2]],1); case 4:/* international network spare routine */ return mtp_encode_integer(pdata,mtp3.nw[1].routine[oid[MTP3_OID_LEN+2]],1); case 5:/* national network routine */ return mtp_encode_integer(pdata,mtp3.nw[2].routine[oid[MTP3_OID_LEN+2]],1); case 6:/* national network spare routine */ return mtp_encode_integer(pdata,mtp3.nw[3].routine[oid[MTP3_OID_LEN+2]],1); case 7:/* version */ memcpy(pdata,mtp3_heartbeat.version,3); return 3; default: return -1; } } else if (oid[MTP3_OID_LEN] == 1)/* measurement */ { switch (oid[MTP3_OID_LEN+1]) { case 1:/* MTP signalling link faults and performance */ *vartype = 4; instance = oid[MTP3_OID_LEN+2]; if (instance > 8) return -1; portion_num = oid[MTP3_OID_LEN+3]; if ( (portion_num > 95) || (portion_num == mtp3_csta_p) ) return -1; timestamp = mtp3_measure.measure[portion_num].time_stamp; if (timestamp == 0) return 0; second_to_min(0,portion_num,instance); mtp3_data_reverse(pdata,(BYTE*)×tamp,4,4); mtp3_data_reverse(&pdata[4],(BYTE*)&mtp3_measure.measure[portion_num].lk_measure1[instance],36,4); return 40; case 2:/* Signalling link availability */ return -1; case 3:/* Signalling link set and route set availability */ *vartype = 4; instance = oid[MTP3_OID_LEN+2]; if (instance > 127) return -1; portion_num = oid[MTP3_OID_LEN+3]; /* if ( (portion_num > 95) || (portion_num == mtp3_csta_p) ) return -1;*/ timestamp = mtp3_measure.measure[portion_num].time_stamp; /* if (timestamp == 0) return 0;*/ second_to_min(1,portion_num,instance); mtp3_data_reverse(pdata,(BYTE*)×tamp,4,4); mtp3_data_reverse(&pdata[4],(BYTE*)&mtp3_measure.measure[portion_num].ls_measure[instance],32,4); return 36; case 5:/* Signalling traffic distribution */ switch (oid[MTP3_OID_LEN+2]) { case 1:/* total traffic */ *vartype = 4; instance = oid[MTP3_OID_LEN+3]; portion_num = oid[MTP3_OID_LEN+4]; if ( (portion_num > 95) || (portion_num == mtp3_csta_p) ) return -1; /* if (instance < 8) { timestamp = mtp3_measure.measure[portion_num].time_stamp; if (timestamp == 0) return 0; mtp3_data_reverse(pdata,(BYTE*)×tamp,4,4); mtp3_data_reverse(&pdata[4],(BYTE*)&mtp3_measure.measure[portion_num].tf_measure1[instance-1],80,4); return 84; }*/ else if (instance < 14) { timestamp = mtp3_measure.measure[portion_num].time_stamp; if (timestamp == 0) return 0; mtp3_data_reverse(pdata,(BYTE*)×tamp,4,4); mtp3_data_reverse(&pdata[4],(BYTE*)&mtp3_measure.measure[portion_num].tf_measure2[instance-8],80,4); return 84; } else return -1; default: return -1; } return -1; case 6:/* error */ *vartype = 4; portion_num = oid[MTP3_OID_LEN+2]; if ( (portion_num > 95) || (portion_num == mtp3_csta_p) ) return -1; timestamp = mtp3_measure.measure[portion_num].time_stamp; if (timestamp == 0) return 0; mtp3_data_reverse(pdata,(BYTE*)×tamp,4,4); mtp3_data_reverse(&pdata[4],(BYTE*)mtp3_measure.measure[portion_num].tf_measure5,12,4); return 16; default: return -1; } } else return -1; } void set_led(BYTE nled,BYTE ncolor); //void set_alarm(BYTE component_id,BYTE alarm_code); //void set_status(BYTE component_id,BYTE info_len,BYTE *info); void set_heartbeat(BYTE reason,BYTE object) { BYTE place; BYTE temp; place = object/4; temp = (object % 4)*2; switch (reason) { case ALARM_LINK_UNAVAILABLE: mtp3_heartbeat.link_state[place] &= (~(3<lk[chl].e1_to_linkset; ls = &mtp3.ls[lsno];*/ mtp3ObjState.link_l2_state[chl] = MTP2_STATE_WORKING; mtp3ObjInput.tsrc_input_from_tlac[chl] = TSRC_TLAC_LINK_AVAILABLE; tsrc_proc(chl); /* ls->links_available++;*/ hmrt_tcbc_update_routing_tables(chl); } void otherMTP3_managed_link_unavailable(BYTE chl) { /* WORD lsno; ls_info *ls; lsno = mtp3_para->lk[chl].e1_to_linkset; ls = &mtp3.ls[lsno];*/ mtp3ObjInput.tsrc_input_from_tlac[chl] = TSRC_TLAC_LINK_UNAVAILABLE; tsrc_proc(chl); /* ls->links_available--;*/ hmrt_tcoc_update_routing_tables(chl); // mtp3ObjState.tlac_state[chl] = TLAC_UNAVAILABLE_STATE; /*init init_tlac_state*/ init_tlac_state[chl] = TRUE; tlac_proc(chl); init_lsac_state[chl] = TRUE; lsac_proc(chl); } int sys_mtp3_table(DWORD ip) { int empty; int i; if (ip==0) return -1; empty = -1; for (i=0;i= 0) return empty; return -1; } void master_MTP3(BYTE link,BYTE masterMTP3,DWORD srcIP) { DWORD NMTP3; DWORD AMTP3; masterMTP3 = masterMTP3 & 1; NMTP3 = mtp3_para->lk[link].e1_to_mtp3; AMTP3 = mtp3_para->lk[link].e1_to_alterMTP3; if (srcIP==NMTP3) { if (masterMTP3) mtp3ObjState.lk_NMTP3_ok[link] |= 1; else mtp3ObjState.lk_NMTP3_ok[link] &= 0xf0; } else if (srcIP==AMTP3) { if (masterMTP3) mtp3ObjState.lk_AMTP3_ok[link] |= 1; else mtp3ObjState.lk_AMTP3_ok[link] &= 0xf0; } } void trap_platform (BYTE oid_len,DWORD *oid_ptr,BYTE *msg_ptr,WORD msg_len,snmp_addr *addr) { heartbeat_msg *phbmsg = (heartbeat_msg *)msg_ptr; BYTE *pstatus = phbmsg->info; heartbeat_compoent_of_mtp3 *phbmtp3 = NULL; WORD mtp3len=0; int i,j,pos = 2; //component_id=0:iptrans; BYTE newHeartbeat=0; int chl; BYTE chl_state; DWORD remote_ip; int temp; struct in_addr in; in.s_addr = addr->remote_ip; mtp3_debug(MTP3DB_PFHB,"get platform heartbeat from %s",inet_ntoa(in)); if (msg_len > 128) mtp3_showbuf(MTP3DB_PFHB,msg_ptr,128); else mtp3_showbuf(MTP3DB_PFHB,msg_ptr,msg_len); remote_ip = addr->remote_ip; if ((temp=sys_mtp3_table(remote_ip)) >= 0) { MTP3IPMng.mtp3_flag_new[temp] = 1; MTP3IPMng.mtp3_flag_ip[temp] = remote_ip; } if ( remote_ip == mtp3_localip )/* heartbeat from itself */ return; if ((temp=MTP3_LinkIP_List(remote_ip,0))<0) return; if (sizeof(struct heartbeat_msg) >= (INFO_LEN + 18)) newHeartbeat = 1; if (!newHeartbeat) {//old version heartbeat, length and component_id are one octet pos = 1; pos += pstatus[pos]+1; //length of iptrans status pos++; //component_id=1:MTP3 mtp3len = pstatus[pos]; pos++; //length of mtp3 hb if (pstatus[pos-1] != 1)//not mtp3 component return; } else {//new version heartbeat, length and component_id are 2 octets pos ++; //length is 2 octets pos += pstatus[pos]+1; //length of iptrans status pos ++; //component_id=1:mtp3 pos ++; //component_id is 2 octets if (pstatus[pos-1] != 1)//not mtp3 component return; mtp3len = pstatus[pos]*256+pstatus[pos+1]; pos ++; //length of mtp3 hb pos ++; //length is 2 octets } phbmtp3 = (heartbeat_compoent_of_mtp3*)&pstatus[pos]; if (mtp3len > MTP3_HB_LEN || mtp3len < (MTP3_HB_LEN-34)) return; for (i=0; i<64; i++) { temp = phbmtp3->link_state[i]; for (j=0; j<4; j++) { chl = i*4+j; chl_state = (temp >> (j*2)) & 3; if ( (mtp3ObjState.lk_mtp3[chl] == remote_ip) && (mtp3ObjState.link_l3_state[chl] != chl_state) ) { if ( mtp3ObjState.lk_configured[chl] != PARA_CONFIGURED ) { continue; } switch (chl_state) { case UNAVAILABLE: if (mtp3ObjState.link_l3_state[chl] == INHIBITED) { mtp3_debug(MTP3DB_EVENT,"link %d L3 state changed from INHIBITED to UNAVAILABLE,invoke by %s",chl,inet_ntoa(in)); mtp3ObjState.link_l3_state[chl] = UNAVAILABLE; } else { mtp3_debug(MTP3DB_EVENT,"link %d L3 out of service,invoke by %s",chl,inet_ntoa(in)); otherMTP3_managed_link_unavailable(chl); } break; case AVAILABLE: mtp3_debug(MTP3DB_EVENT,"link %d L3 in service,invoke by %s",chl,inet_ntoa(in)); otherMTP3_managed_link_available(chl); break; case INHIBITED: mtp3_debug(MTP3DB_EVENT,"link %d L3 inhibited,invoke by %s",chl,inet_ntoa(in)); if (mtp3ObjState.link_l3_state[chl] == AVAILABLE) otherMTP3_managed_link_unavailable(chl); mtp3ObjState.link_l3_state[chl] = INHIBITED; break; default: break; } } } } if (mtp3len > 100) { for (i=0;i<32;i++) { for (j=0; j<8; j++) { chl = i*8+j; master_MTP3(chl,(phbmtp3->masterMTP3[i]>>j),remote_ip); } } if (mtp3len > 132) { MTP3IPMng.LinkIPSubSta[temp][0] = phbmtp3->SubState[0]; MTP3IPMng.LinkIPSubSta[temp][1] = phbmtp3->SubState[1]; } else { MTP3IPMng.LinkIPSubSta[temp][0] = 0xff; MTP3IPMng.LinkIPSubSta[temp][1] = 0xff; } } else { MTP3IPMng.LinkIPSubSta[temp][0] = 0xff; MTP3IPMng.LinkIPSubSta[temp][1] = 0xff; } } void trap_mtp2 (BYTE oid_len,DWORD *oid_ptr,BYTE *msg_ptr,WORD msg_len,snmp_addr *addr) { int i; mtp2_heartbeat *mtp2; BYTE offset; BYTE new_l2_state; BYTE chl; BYTE ls; BYTE module_id; struct in_addr in; in.s_addr = addr->remote_ip; mtp3_debug(MTP3DB_PRIMITIVE_MSG,"get MTP2 heartbeat from %s",inet_ntoa(in)); mtp3_showbuf(MTP3DB_PRIMITIVE_MSG,msg_ptr,msg_len); mtp2 = (mtp2_heartbeat*)msg_ptr; module_id = (mtp2->systemid & 1)*16+mtp2->moduleid; if (module_id > 31) return; mtp2_flag_new[module_id] = 1; offset = module_id << 3; for ( i=0; i<8; i++ ) { chl = offset + i; mtp3ObjState.link_l1_state[chl] = (mtp2->l1_state >> i) & 1; new_l2_state = mtp2->l2_state[i];/* e1 l2 state from mtp2 */ if ( (mtp3ObjState.lk_configured[chl] == PARA_NOT_CONFIGURED) || (mtp3ObjState.lk_mtp3[chl] != mtp3_localip) ) continue; if ( new_l2_state != mtp3ObjState.link_l2_state[chl] ) { ls = mtp3_para->lk[chl].e1_to_linkset; if (new_l2_state == MTP2_STATE_WORKING)/* link from unavailable->available */ { current_measure->lk_measure1[chl][2]++;/* restoration */ mtp3_debug(MTP3DB_EVENT,"link %d L2 in service",chl); mtp3ObjInput.lsac_input_from_l2[chl] = LSAC_L2_IN_SERVICE; } else if (mtp3ObjState.link_l2_state[chl] == MTP2_STATE_WORKING)/* link from available->unavailable */ { local_change_over[chl]++; mtp3_debug(MTP3DB_EVENT,"link %d L2 out of service",chl); mtp3ObjInput.lsac_input_from_l2[chl] = LSAC_L2_OUT_OF_SERVICE; if ( mtp2->retrieved_bsnt[i] < 128 ) local_bsnt_retrievable[chl] = TRUE; else { // mtp3_debug(MTP3_DEBUG_LOG,"Link %d BSNT RETRIEVE FAILED",chl); local_bsnt_retrievable[chl] = FALSE; } mtp3ObjInput.sltc_input[chl] = SLTC_STOP; sltc_proc(chl); } } mtp3ObjState.link_l2_state[chl] = new_l2_state; if ( (mtp2->e1_dstip[i]+32 != ((mtp3ObjState.lk_mtp3[chl] >> 16) & 0xff)) && (mtp3ObjState.lk_configured[chl] == PARA_CONFIGURED) ) send_command_to_mtp2(chl,MTP2_ACTIVE_LINK);/* give this port a correct ip */ retrieved_bsnt[chl] = mtp2->retrieved_bsnt[i]; } if (mtp2->alarm_code == 3) { mtp2_buf_full[mtp2->alarm_component]++; } } void mtp3_dealtrap(BYTE oid_len,DWORD *oid_ptr,BYTE *msg_ptr,WORD msg_len,snmp_addr *addr) { DWORD mtp2_oid[20] = MTP2_HB_OID; DWORD platform_oid[20] = PLATFORM_HB_OID; DWORD omc_oid[20] = MTP3_OMC_OID; if (memcmp(&oid_ptr[9],&mtp2_oid[9],16)==0) { trap_mtp2 (oid_len,oid_ptr,msg_ptr,msg_len,addr); } else if (memcmp(&oid_ptr[9],&platform_oid[9],8)==0) { trap_platform(oid_len,oid_ptr,msg_ptr,msg_len,addr); } else if (memcmp(oid_ptr,omc_oid,MTP3_OMC_OID_LEN*sizeof(DWORD))==0) {//omc heartbeat if ((mtp3_para->MTP3SerialNum==0) ||//support old version, do not have serial number (Bcd2Ull(&msg_ptr[39],MTP3_SERNUM_LEN)==mtp3_para->MTP3SerialNum) ) { switch(msg_ptr[0]) { case 0: mtp3_primomcip = addr->remote_ip; break; case 1: mtp3_secdomcip = addr->remote_ip; break; default: break; } } } } void mtp_snmp_init() { DWORD mib_oid[20] = MTP3_OID; snmp_init(4957); heartbeat_init(0xff); inquire_setmsg(MTP3_OID_LEN,mib_oid, mtp_setmib); inquire_getmsg(MTP3_OID_LEN,mib_oid, mtp_getmib); // inquire_trapmsg(trapcall trap_mtp2)/* mtp2 heartbeat */ inquire_trapmsg(mtp3_dealtrap); // rob_trapmsg(MTP2_HBOID_LEN,mtp2_oid,trap_mtp2); } /*@end@*/