int S1mmeSession::InsertToS1mmeUserInfo(S1UserInfo_T* s1_user_info, uint64_t tv_sec) { S1mmeUserInfo* user_info = AllocateS1mmeUserInfo(); user_info->SetIMSI(s1_user_info->imsi); user_info->SetSTMSI(s1_user_info->stmsi); user_info->SetAPN(s1_user_info->apn); user_info->SetClientIP(s1_user_info->user_ip); StmsiWithMmegi_T stmsi_key(s1_user_info->stmsi); #ifdef KEY_INFO_VER_2 if (s1_user_info->has_kasme) { user_info->SetCipheringAlgorithm(s1_user_info->ciphering_algorithm); user_info->nas_.mme_seq_num = s1_user_info->mme_seq_num; user_info->nas_.ue_seq_num = s1_user_info->ue_seq_num; user_info->nas_.mme_overflow= s1_user_info->mme_overflow; user_info->nas_.ue_overflow = s1_user_info->ue_overflow; memcpy(user_info->nas_.kasme, s1_user_info->kasme, KASME_LEN); } #endif SPUserInfo sp_local_user_info(user_info); ue_stmsi_map_.insert(std::make_pair(stmsi_key, sp_local_user_info)); UpdateFromStmsiTimeoutMap(s1_user_info->stmsi, tv_sec, true); }什么意思
时间: 2023-08-09 16:12:32 浏览: 84
这段代码是一个C++函数,名为"InsertToS1mmeUserInfo",它的作用是将一个S1mmeUserInfo对象添加到一个ue_stmsi_map_映射表中。具体来说,函数会先通过AllocateS1mmeUserInfo()函数分配一个S1mmeUserInfo对象,然后将该对象的各个属性设置为传入参数s1_user_info中对应的属性值。如果定义了KEY_INFO_VER_2宏,函数还会将S1_user_info中的一些额外信息设置到S1mmeUserInfo对象的nas_属性中。之后,函数会将S1mmeUserInfo对象封装成一个SPUserInfo智能指针,并以stmsi_key为键值,将其插入ue_stmsi_map_映射表中。最后,函数会调用UpdateFromStmsiTimeoutMap()函数更新与stmsi_key对应的超时信息。
相关问题
void S1mmeSession::CtEncodeKqi(S1MMEKQI* kqi, S1APNode* p_node, uint8_t worker_id) { MsgCommonInfo& common = p_node->GetCommonInfo(); SPUserInfo& sp_user_info = p_node->GetUserInfo(); //获取 buf TlvEncoder* p_encoder_cur = g_p_encoder_[worker_id]; YdCDR_T* p_dst_data = (YdCDR_T*)malloc(sizeof(YdCDR_T)); if (p_dst_data == NULL) { return; } p_dst_data->not_associate = 0; if ((common.not_associate & 0x03) == 0x03) p_dst_data->not_associate = 1; p_encoder_cur->Set(p_dst_data->cdr_data,kMaxOneCdrBufLen); uint64_t imsi = sp_user_info->GetIMSI(); if(common.eci == 0) { common.eci = sp_user_info->GetEci(); } uint16_t tmp_enbid = common.tac;//>>8; //uint32_t tmp_enbid = (common.eci >> 8)&0xfffff; char xdrid_str[32]={0}; #ifdef OPEN_NEW_HUISU convert_xdrid_to_string(xdrid_str, kqi->xdrid, s_xdr_id_len); #else #ifdef OPENCTPR g4sigtran::pr::ProcBlock* p_blk = kqi->binary_block_in_xdr_.GetBlock(); p_blk->SerializeXid(xdrid_str, sizeof(xdrid_str)); #else uint64_t subcdrid = g_ct_xdr_id.GetXid(); //reverse subend; if(::is_open_reverse) { SetReverseSubend(p_node, subcdrid); } #ifdef ONE_THIRD_YUNNAN_MRO g_ct_xdr_id.Serialize((uint8_t*)xdrid_str, s_xdr_id_len, imsi); #else g_ct_xdr_id.Serialize((uint8_t*)xdrid_str, s_xdr_id_len); #endif #endif #endif struct timespec start_time = kqi->request_time_, end_time = kqi->response_time_; if (kqi->request_time_.tv_sec == 0) { if (!(kqi->response_time_.tv_sec == 0)) { start_time = kqi->response_time_; } else if (!(kqi->complete_time_.tv_sec == 0)) { start_time = kqi->complete_time_; } } if (!(kqi->complete_time_.tv_sec == 0)) { end_time = kqi->complete_time_; } if (end_time.tv_sec == 0) { end_time = start_time; } p_encoder_cur->SetHdr(kEncoderCdr, kqi->kqi_type_, current_time_.tv_sec, worker_id); //child_kqi //p_encoder_cur->Add("0", kExportTagChildKqi);什么意思
这是一个函数的实现,函数名为S1mmeSession::CtEncodeKqi。该函数的作用是将S1MMEKQI结构体编码为TLV格式,并存储到缓冲区中。在函数中,先获取S1APNode的common和userInfo信息,然后获取TLV编码器和YdCDR_T类型的目标数据指针。接着,根据common和userInfo信息以及其他参数,设置目标数据指针的一些字段。然后,设置TLV编码器的头部信息,包括编码类型、KQI类型、时间戳和worker_id等。最后,通过TLV编码器将目标数据编码为TLV格式,并存储到缓冲区中。在函数的最后,出现了一行注释,但是没有具体说明该行代码的作用。
LogInfo("Node timeout, current_time: %ld, S1APKey: %s, MMEKey: %s, ContainerKey: %s, UserInfo: %s", current_time_.tv_sec, p_cur->GetS1APKey().ToString().c_str(), p_cur->GetMMEKey().ToString().c_str(), p_cur->GetContainerKey().ToString().c_str(), p_cur->GetUserInfo().ToString().c_str());什么意思
这段代码是一条日志记录语句,用于在程序运行时输出一些关键信息。具体来说,它输出了一个节点超时的相关信息,包括当前时间(以秒为单位),S1APKey、MMEKey、ContainerKey和UserInfo等关键信息。其中,S1APKey、MMEKey和ContainerKey是一些标识符,用于唯一标识某个节点,而UserInfo是一些额外的用户信息,可能包括一些自定义的数据。
阅读全文