Commit 1691c607 authored by Raphael Defosseux's avatar Raphael Defosseux

Merge remote-tracking branch 'origin/fix-nas-ue-memory-leaks' into integration_2024_w36

parents fd6cf5aa 47833b1a
...@@ -1823,6 +1823,7 @@ void *rrc_nrue(void *notUsed) ...@@ -1823,6 +1823,7 @@ void *rrc_nrue(void *notUsed)
// error: the remote gNB is hardcoded here // error: the remote gNB is hardcoded here
rb_id_t srb_id = rrc->Srb[2] == RB_ESTABLISHED ? 2 : 1; rb_id_t srb_id = rrc->Srb[2] == RB_ESTABLISHED ? 2 : 1;
nr_pdcp_data_req_srb(rrc->ue_id, srb_id, 0, length, buffer, deliver_pdu_srb_rlc, NULL); nr_pdcp_data_req_srb(rrc->ue_id, srb_id, 0, length, buffer, deliver_pdu_srb_rlc, NULL);
free(req->nasMsg.data);
free(buffer); free(buffer);
break; break;
} }
......
...@@ -614,6 +614,8 @@ static void generateAuthenticationResp(nr_ue_nas_t *nas, as_nas_info_t *initialN ...@@ -614,6 +614,8 @@ static void generateAuthenticationResp(nr_ue_nas_t *nas, as_nas_info_t *initialN
initialNasMsg->data = (Byte_t *)malloc(size * sizeof(Byte_t)); initialNasMsg->data = (Byte_t *)malloc(size * sizeof(Byte_t));
initialNasMsg->length = mm_msg_encode(mm_msg, (uint8_t *)(initialNasMsg->data), size); initialNasMsg->length = mm_msg_encode(mm_msg, (uint8_t *)(initialNasMsg->data), size);
// Free res value after encode
free(res.value);
} }
int nas_itti_kgnb_refresh_req(instance_t instance, const uint8_t kgnb[32]) int nas_itti_kgnb_refresh_req(instance_t instance, const uint8_t kgnb[32])
...@@ -1002,6 +1004,11 @@ static void generatePduSessionEstablishRequest(nr_ue_nas_t *nas, as_nas_info_t * ...@@ -1002,6 +1004,11 @@ static void generatePduSessionEstablishRequest(nr_ue_nas_t *nas, as_nas_info_t *
security_header_len security_header_len
+ mm_msg_encode(mm_msg, (uint8_t *)(initialNasMsg->data + security_header_len), size - security_header_len); + mm_msg_encode(mm_msg, (uint8_t *)(initialNasMsg->data + security_header_len), size - security_header_len);
// Free allocated memory after encode
free(req_buffer);
free(mm_msg->uplink_nas_transport.dnn.value);
free(mm_msg->uplink_nas_transport.snssai.value);
/* ciphering */ /* ciphering */
uint8_t buf[initialNasMsg->length - 7]; uint8_t buf[initialNasMsg->length - 7];
stream_cipher.context = nas->security_container->ciphering_context; stream_cipher.context = nas->security_container->ciphering_context;
...@@ -1323,6 +1330,8 @@ void *nas_nrue(void *args_p) ...@@ -1323,6 +1330,8 @@ void *nas_nrue(void *args_p)
capture_pdu_session_establishment_accept_msg(pdu_buffer, pdu_length); capture_pdu_session_establishment_accept_msg(pdu_buffer, pdu_length);
} }
// Free NAS buffer memory after use (coming from RRC)
free(pdu_buffer);
break; break;
} }
...@@ -1447,6 +1456,8 @@ void *nas_nrue(void *args_p) ...@@ -1447,6 +1456,8 @@ void *nas_nrue(void *args_p)
LOG_W(NR_RRC, "unknown message type %d\n", msg_type); LOG_W(NR_RRC, "unknown message type %d\n", msg_type);
break; break;
} }
// Free NAS buffer memory after use (coming from RRC)
free(pdu_buffer);
if (initialNasMsg.length > 0) if (initialNasMsg.length > 0)
send_nas_uplink_data_req(nas, &initialNasMsg); send_nas_uplink_data_req(nas, &initialNasMsg);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment