Open5GS项目中SGsAP协议行为异常问题的分析与修复
背景概述
在移动通信网络中,SGsAP(SGs Application Protocol)协议负责LTE(4G)核心网(EPC)与2G/3G电路交换(CS)核心网之间的交互,主要支持CSFB(Circuit Switched Fallback)功能。Open5GS作为开源5G核心网实现,其MME(Mobility Management Entity)模块需要正确处理SGsAP协议行为。
问题现象
在Open5GS项目中发现SGsAP协议存在两个关键问题:
-
当HSS中配置的Network Access Mode(NAM)为"Packet only"时,MME仍然尝试建立SGs关联,这违反了3GPP TS 29.118规范第4.1节的规定。
-
当NAM设置为"Packet and Circuit"时,如果CS核心网拒绝了SGs关联请求,MME错误地导致整个UE附着过程失败,而按照规范,这应该只影响SGs关联本身,不影响PS(Packet Switched)域的附着。
技术分析
问题1:NAM模式处理不当
根据3GPP规范,Network Access Mode有三种可能值:
- ONLY_PACKET:仅支持分组交换业务
- ONLY_CIRCUIT:仅支持电路交换业务
- PACKET_AND_CIRCUIT:同时支持两种业务
当NAM为ONLY_PACKET时,MME不应尝试建立任何SGs关联,因为UE明确指示不支持CS业务。原始实现中缺少这一判断逻辑。
问题2:SGs关联失败处理不当
当NAM为PACKET_AND_CIRCUIT时,虽然MME需要尝试建立SGs关联,但SGs关联失败不应影响PS域的附着过程。原始实现中错误地将SGs关联失败传播到了整个附着流程。
深层原因
通过分析发现,问题还涉及多个技术细节:
- PTI(Procedure Transaction Identity)处理不当:在SGsAP启用时,Create Bearer Request处理顺序错误导致PTI被错误设置为0
- 多承载处理问题:原始实现在添加第一个会话的流时错误地断言了承载数量
- NAS消息构建问题:Attach Accept消息中的LAI和MS Identity信息处理不当
解决方案
开发团队通过多次迭代修复了这些问题,主要修改包括:
-
正确识别和处理HSS下发的NAM模式,在ONLY_PACKET时跳过SGs关联建立
-
解耦SGs关联失败与PS附着流程,确保SGs问题不影响基本分组业务
-
修复PTI处理逻辑,确保正确的消息处理顺序
-
改进多承载场景下的断言检查
-
优化NAS消息构建,正确处理LAI和MS Identity信息
验证结果
修复后经过全面测试验证了以下场景:
- NAM设置为PS only且SGsAP启用:UE成功附着,不尝试SGs关联
- NAM设置为PS+CS且SGsAP启用:UE成功附着,正确建立SGs关联
- NAM设置为PS+CS但HLR账户无效:UE成功附着PS域,SGs关联失败不影响
- NAM设置为PS+CS且SGsAP禁用:UE成功附着
技术启示
这一案例展示了核心网实现中几个重要原则:
- 必须严格遵循3GPP规范中对各种模式的定义和处理要求
- 不同域(PS/CS)的业务应该适当解耦,避免错误传播
- 协议状态机和消息处理顺序对系统稳定性至关重要
- 全面的测试用例对验证复杂场景非常必要
Open5GS通过这次修复不仅解决了具体问题,还提高了整个MME模块的健壮性,为后续功能扩展奠定了更好基础。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
pc-uishopTNT开源商城系统使用java语言开发,基于SpringBoot架构体系构建的一套b2b2c商城,商城是满足集平台自营和多商户入驻于一体的多商户运营服务系统。包含PC 端、手机端(H5\APP\小程序),系统架构以及实现案例中应满足和未来可能出现的业务系统进行对接。Vue00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01