Skip to content

5GS NAS Overview and OAI Implementation status

This document provides an overview of the 5G System Non-Access Stratum (5GS NAS) protocol as specified in 3GPP TS 24.501. It highlights key message types involved in Mobility and Session Management and explains how these are implemented within the OAI software stack. The document outlines the structure of the OAI codebase by detailing current support for encoding, decoding, and unit testing of specific NAS messages, and explains how the UE handles USIM simulation and message generation.

About 5GS NAS

The 5G System Non-Access Stratum (5GS NAS) is defined in 3GPP TS 24.501. It operates within the control plane, facilitating communication between the User Equipment (UE) and the Access and Mobility Management Function (AMF) over the N1 interface.

Key 5GS NAS messages:

  • Mobility Management (5GMM): Handles UE registration, deregistration, authentication and tracking area updates. 5GMM also manages transitions between idle and connected states.
  • Session Management (5GSM): Establishes, modifies, and releases PDU sessions. Coordinates with the Session Management Function (SMF) to manage user-plane resources.

OAI Implementation Status

The following tables lists implemented NAS messages and whether there is an encoder or decoder function, and if a corresponding unit test exists.

Type Message Encoding Decoding Unit test
5GMM Service Request yes yes yes
5GMM Service Accept yes yes yes
5GMM Service Reject yes yes yes
5GMM Authentication Response yes no no
5GMM Identity Response yes no no
5GMM Security Mode Complete yes no no
5GMM Uplink NAS Transport yes no no
5GMM Registration Request yes yes no
5GMM Registration Accept yes yes yes
5GMM Registration Complete yes yes no
5GMM Deregistration Request (UE originating) yes no no
5GSM PDU Session Establishment Request yes no no
5GSM PDU Session Establishment Accept no yes no

Code Structure

openair3/NAS/NR_UE/nr_nas_msg.c: * NAS procedures and message handlers/callbacks * Integration with RRC (ITTI) and SDAP * Invokes enc/dec libraries * Handles 5GMM state and mode

openair3/NAS/NR_UE/5GS/fgs_nas_lib.c: openair3/NAS/NR_UE/5GS/NR_NAS_defs.h: * encoding and decoding functions for 5G NAS message headers and payloads * relies on 5GMM/5GSM messages libs for payload encoding

openair3/NAS/NR_UE/5GS/fgs_nas_utils.h: * NAS helpers, macros

openair3/NAS/NR_UE/5GS/5GMM: * encoding/decoding functions and definitions for 5GMM NAS messages payloads

openair3/NAS/NR_UE/5GS/5GMM/MSG/fgmm_lib.c: openair3/NAS/NR_UE/5GS/5GMM/MSG/fgmm_lib.h: * encoding/decoding functions and definitions for common 5GMM IEs

openair3/NAS/NR_UE/5GS/5GSM: * encoding and decoding functions for 5GSM NAS messages payloads

USIM Simulation

OAI includes a simulated USIM implementation that reads its parameters from standard configuration files. This allows for rapid prototyping and testing without relying on a physical UICC card. The USIM-related configuration is handled via the init_uicc() function.

Configuration

The simulation reads values from a named section in the config file.

Config options in the uicc section:

Parameter Description Default value
imsi User IMSI 2089900007487
nmc_size Number of digits in NMC 2
key Subscription key (Ki) fec86ba6eb707ed08905757b1bb44b8f
opc OPc value c42449363bbad02b66d16bc975d77cc1
amf AMF value 8000
sqn Sequence number 000000
dnn Default DNN (APN) oai
nssai_sst NSSAI slice/service type 1
nssai_sd NSSAI slice differentiator 0xffffff
imeisv IMEISV string 6754567890123413

These are parsed and stored in the uicc_t structure.

Initialization

The UE calls init_uicc via checkUicc to allocate memory for the uicc_t structure member and load parameters using config_get() from the selected config section. Then the UICC structure is stored in the NAS context. nr_ue_nas_t, to be used to fill identity and security credentials when generating responses to 5GC messages such as Identity Response, Authentication Response, and Security Mode Complete.

Milenage Authentication and Key Derivation

When the UE receives a 5GMM Authentication Request, the function generateAuthenticationResp generates a valid Authentication Response with the necessary derived NAS and AS security keys. The function derive_ue_keys parses the Authentication Request and performs the entire 5G AKA key hierarchy:

  • Extracts the RAND and SQN
  • Performs Milenage Algorithms f2-f5 using f2345() from the UICC input
  • Computes the RES using transferRES()
  • Derives the keys KAUSF, KSEAF, KAMF, KNASenc/KNASint via derive_knas() and KGNB for RRC ciphering (via derive_kgnb())

Security Mode Complete

When the UE receives a Security Mode Command from the 5GC, it responds with a Security Mode Complete message. This message is protected with the newly established NAS security context and may carry additional payloads, including the UE’s identity and a nested NAS message (e.g., Registration Request) in the FGSNasMessageContainer. The function responsible for building and securing this response is generateSecurityModeComplete.

IMEISV

The IMEISV, is encoded using the fill_imeisv() helper. This function extracts each digit from the configured imeisvStr in the UICC context and populates the mobile identity structure.

See TS 24.501 §4.4 for reference.