Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangjie
OpenXG-RAN
Commits
1c30f692
Commit
1c30f692
authored
Nov 06, 2014
by
Lionel Gauthier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
git-svn-id:
http://svn.eurecom.fr/openair4G/trunk@5982
818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent
645d2ae7
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
136 additions
and
50 deletions
+136
-50
openair-cn/GTPV1-U/gtpv1u.h
openair-cn/GTPV1-U/gtpv1u.h
+3
-0
openair-cn/GTPV1-U/gtpv1u_eNB.c
openair-cn/GTPV1-U/gtpv1u_eNB.c
+8
-3
openair-cn/GTPV1-U/gtpv1u_task.c
openair-cn/GTPV1-U/gtpv1u_task.c
+91
-25
openair-cn/GTPV1-U/nw-gtpv1u/include/NwGtpv1uPrivate.h
openair-cn/GTPV1-U/nw-gtpv1u/include/NwGtpv1uPrivate.h
+3
-1
openair-cn/GTPV1-U/nw-gtpv1u/shared/NwGtpv1uMsg.h
openair-cn/GTPV1-U/nw-gtpv1u/shared/NwGtpv1uMsg.h
+1
-0
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1u.c
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1u.c
+15
-17
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c
+15
-4
No files found.
openair-cn/GTPV1-U/gtpv1u.h
View file @
1c30f692
...
@@ -51,6 +51,9 @@
...
@@ -51,6 +51,9 @@
# define GTPU_ERROR(x, args...) fprintf(stderr, "[GTPU][E]"x, ##args)
# define GTPU_ERROR(x, args...) fprintf(stderr, "[GTPU][E]"x, ##args)
#endif
#endif
#warning "TO BE REFINED"
# define GTPU_HEADER_OVERHEAD_MAX 64
uint32_t
gtpv1u_new_teid
(
void
);
uint32_t
gtpv1u_new_teid
(
void
);
#endif
/* GTPV1_U_H_ */
#endif
/* GTPV1_U_H_ */
openair-cn/GTPV1-U/gtpv1u_eNB.c
View file @
1c30f692
...
@@ -86,6 +86,7 @@ NwGtpv1uRcT
...
@@ -86,6 +86,7 @@ NwGtpv1uRcT
NwGtpv1uUdpHandleT
udpHandle
,
NwGtpv1uUdpHandleT
udpHandle
,
NwU8T
*
buffer
,
NwU8T
*
buffer
,
NwU32T
buffer_len
,
NwU32T
buffer_len
,
NwU32T
buffer_offset
,
NwU32T
peerIpAddr
,
NwU32T
peerIpAddr
,
NwU16T
peerPort
);
NwU16T
peerPort
);
...
@@ -100,6 +101,7 @@ int
...
@@ -100,6 +101,7 @@ int
uint32_t
address
,
uint32_t
address
,
uint8_t
*
buffer
,
uint8_t
*
buffer
,
uint32_t
length
,
uint32_t
length
,
uint32_t
offset
,
void
*
arg_p
);
void
*
arg_p
);
//int
//int
//gtpv1u_create_tunnel_endpoint(
//gtpv1u_create_tunnel_endpoint(
...
@@ -187,6 +189,7 @@ NwGtpv1uRcT gtpv1u_eNB_send_udp_msg(
...
@@ -187,6 +189,7 @@ NwGtpv1uRcT gtpv1u_eNB_send_udp_msg(
NwGtpv1uUdpHandleT
udpHandle
,
NwGtpv1uUdpHandleT
udpHandle
,
NwU8T
*
buffer
,
NwU8T
*
buffer
,
NwU32T
buffer_len
,
NwU32T
buffer_len
,
NwU32T
buffer_offset
,
NwU32T
peerIpAddr
,
NwU32T
peerIpAddr
,
NwU16T
peerPort
)
NwU16T
peerPort
)
{
{
...
@@ -202,6 +205,7 @@ NwGtpv1uRcT gtpv1u_eNB_send_udp_msg(
...
@@ -202,6 +205,7 @@ NwGtpv1uRcT gtpv1u_eNB_send_udp_msg(
udp_data_req_p
->
peer_port
=
peerPort
;
udp_data_req_p
->
peer_port
=
peerPort
;
udp_data_req_p
->
buffer
=
buffer
;
udp_data_req_p
->
buffer
=
buffer
;
udp_data_req_p
->
buffer_length
=
buffer_len
;
udp_data_req_p
->
buffer_length
=
buffer_len
;
udp_data_req_p
->
buffer_offset
=
buffer_offset
;
return
itti_send_msg_to_task
(
TASK_UDP
,
INSTANCE_DEFAULT
,
message_p
);
return
itti_send_msg_to_task
(
TASK_UDP
,
INSTANCE_DEFAULT
,
message_p
);
}
else
{
}
else
{
return
NW_GTPV1U_FAILURE
;
return
NW_GTPV1U_FAILURE
;
...
@@ -858,7 +862,7 @@ void *gtpv1u_eNB_task(void *args)
...
@@ -858,7 +862,7 @@ void *gtpv1u_eNB_task(void *args)
udp_data_ind_p
->
buffer_length
,
udp_data_ind_p
->
buffer_length
,
udp_data_ind_p
->
peer_port
,
udp_data_ind_p
->
peer_port
,
udp_data_ind_p
->
peer_address
);
udp_data_ind_p
->
peer_address
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
received_message_p
),
udp_data_ind_p
->
buffer
);
//
itti_free(ITTI_MSG_ORIGIN_ID(received_message_p), udp_data_ind_p->buffer);
}
}
break
;
break
;
...
@@ -896,6 +900,7 @@ void *gtpv1u_eNB_task(void *args)
...
@@ -896,6 +900,7 @@ void *gtpv1u_eNB_task(void *args)
gtpv1u_data_g
.
seq_num
++
,
gtpv1u_data_g
.
seq_num
++
,
data_req_p
->
buffer
,
data_req_p
->
buffer
,
data_req_p
->
length
,
data_req_p
->
length
,
data_req_p
->
offset
,
&
(
stack_req
.
apiInfo
.
sendtoInfo
.
hMsg
));
&
(
stack_req
.
apiInfo
.
sendtoInfo
.
hMsg
));
if
(
rc
!=
NW_GTPV1U_OK
)
{
if
(
rc
!=
NW_GTPV1U_OK
)
{
...
@@ -913,8 +918,8 @@ void *gtpv1u_eNB_task(void *args)
...
@@ -913,8 +918,8 @@ void *gtpv1u_eNB_task(void *args)
}
}
}
}
}
}
/* Buffer
is no longer needed,
free it */
/* Buffer
still needed, do not
free it */
itti_free
(
ITTI_MSG_ORIGIN_ID
(
received_message_p
),
data_req_p
->
buffer
);
//
itti_free(ITTI_MSG_ORIGIN_ID(received_message_p), data_req_p->buffer);
}
}
break
;
break
;
...
...
openair-cn/GTPV1-U/gtpv1u_task.c
View file @
1c30f692
...
@@ -36,6 +36,7 @@
...
@@ -36,6 +36,7 @@
#include <string.h>
#include <string.h>
#include <unistd.h>
#include <unistd.h>
#include <errno.h>
#include <errno.h>
#include <sys/time.h>
#include "mme_config.h"
#include "mme_config.h"
...
@@ -62,6 +63,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
...
@@ -62,6 +63,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
NwGtpv1uUdpHandleT
udpHandle
,
NwGtpv1uUdpHandleT
udpHandle
,
NwU8T
*
buffer
,
NwU8T
*
buffer
,
NwU32T
buffer_len
,
NwU32T
buffer_len
,
NwU32T
buffer_offset
,
NwU32T
peerIpAddr
,
NwU32T
peerIpAddr
,
NwU32T
peerPort
);
NwU32T
peerPort
);
...
@@ -76,6 +78,69 @@ NwGtpv1uRcT gtpv1u_process_stack_req(
...
@@ -76,6 +78,69 @@ NwGtpv1uRcT gtpv1u_process_stack_req(
NwGtpv1uUlpHandleT
hUlp
,
NwGtpv1uUlpHandleT
hUlp
,
NwGtpv1uUlpApiT
*
pUlpApi
);
NwGtpv1uUlpApiT
*
pUlpApi
);
//-----------------------------------------------------------------------------
void
gtpu_print_hex_octets
(
unsigned
char
*
dataP
,
unsigned
long
sizeP
)
//-----------------------------------------------------------------------------
{
unsigned
long
octet_index
=
0
;
unsigned
long
buffer_marker
=
0
;
unsigned
char
aindex
;
#define GTPU_2_PRINT_BUFFER_LEN 8000
char
gtpu_2_print_buffer
[
GTPU_2_PRINT_BUFFER_LEN
];
struct
timeval
tv
;
struct
timezone
tz
;
char
timeofday
[
64
];
unsigned
int
h
,
m
,
s
;
if
(
dataP
==
NULL
)
{
return
;
}
gettimeofday
(
&
tv
,
&
tz
);
h
=
tv
.
tv_sec
/
3600
/
24
;
m
=
(
tv
.
tv_sec
/
60
)
%
60
;
s
=
tv
.
tv_sec
%
60
;
snprintf
(
timeofday
,
64
,
"%02d:%02d:%02d.%06d"
,
h
,
m
,
s
,
tv
.
tv_usec
);
GTPU_DEBUG
(
"%s------+-------------------------------------------------|
\n
"
,
timeofday
);
GTPU_DEBUG
(
"%s | 0 1 2 3 4 5 6 7 8 9 a b c d e f |
\n
"
,
timeofday
);
GTPU_DEBUG
(
"%s------+-------------------------------------------------|
\n
"
,
timeofday
);
for
(
octet_index
=
0
;
octet_index
<
sizeP
;
octet_index
++
)
{
if
(
GTPU_2_PRINT_BUFFER_LEN
<
(
buffer_marker
+
32
))
{
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
"... (print buffer overflow)"
);
GTPU_DEBUG
(
"%s%s"
,
timeofday
,
gtpu_2_print_buffer
);
return
;
}
if
((
octet_index
%
16
)
==
0
){
if
(
octet_index
!=
0
)
{
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
" |
\n
"
);
GTPU_DEBUG
(
"%s%s"
,
timeofday
,
gtpu_2_print_buffer
);
buffer_marker
=
0
;
}
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
" %04ld |"
,
octet_index
);
}
/*
* Print every single octet in hexadecimal form
*/
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
" %02x"
,
dataP
[
octet_index
]);
/*
* Align newline and pipes according to the octets in groups of 2
*/
}
/*
* Append enough spaces and put final pipe
*/
for
(
aindex
=
octet_index
;
aindex
<
16
;
++
aindex
)
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
" "
);
//GTPU_DEBUG(" ");
buffer_marker
+=
snprintf
(
&
gtpu_2_print_buffer
[
buffer_marker
],
GTPU_2_PRINT_BUFFER_LEN
-
buffer_marker
,
" |
\n
"
);
GTPU_DEBUG
(
"%s%s"
,
timeofday
,
gtpu_2_print_buffer
);
}
static
int
gtpv1u_send_init_udp
(
uint16_t
port_number
)
static
int
gtpv1u_send_init_udp
(
uint16_t
port_number
)
{
{
// Create and alloc new message
// Create and alloc new message
...
@@ -111,6 +176,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
...
@@ -111,6 +176,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
NwGtpv1uUdpHandleT
udpHandle
,
NwGtpv1uUdpHandleT
udpHandle
,
NwU8T
*
buffer
,
NwU8T
*
buffer
,
NwU32T
buffer_len
,
NwU32T
buffer_len
,
NwU32T
buffer_offset
,
NwU32T
peerIpAddr
,
NwU32T
peerIpAddr
,
NwU32T
peerPort
)
NwU32T
peerPort
)
{
{
...
@@ -126,6 +192,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
...
@@ -126,6 +192,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg(
udp_data_req_p
->
peer_port
=
peerPort
;
udp_data_req_p
->
peer_port
=
peerPort
;
udp_data_req_p
->
buffer
=
buffer
;
udp_data_req_p
->
buffer
=
buffer
;
udp_data_req_p
->
buffer_length
=
buffer_len
;
udp_data_req_p
->
buffer_length
=
buffer_len
;
udp_data_req_p
->
buffer_offset
=
buffer_offset
;
return
itti_send_msg_to_task
(
TASK_UDP
,
INSTANCE_DEFAULT
,
message_p
);
return
itti_send_msg_to_task
(
TASK_UDP
,
INSTANCE_DEFAULT
,
message_p
);
}
}
...
@@ -141,34 +208,38 @@ NwGtpv1uRcT gtpv1u_process_stack_req(
...
@@ -141,34 +208,38 @@ NwGtpv1uRcT gtpv1u_process_stack_req(
* - END-MARKER
* - END-MARKER
*/
*/
case
NW_GTPV1U_ULP_API_RECV_TPDU
:
{
case
NW_GTPV1U_ULP_API_RECV_TPDU
:
{
uint8_t
buffer
[
4096
];
//
uint8_t buffer[4096];
uint32_t
buffer_len
;
//
uint32_t buffer_len;
MessageDef
*
message_p
;
MessageDef
*
message_p
=
NULL
;
Gtpv1uTunnelDataInd
*
data_ind_p
;
Gtpv1uTunnelDataInd
*
data_ind_p
=
NULL
;
/* Nw-gptv1u stack has processed a PDU. we can forward it to IPV4
/* Nw-gptv1u stack has processed a PDU. we can forward it to IPV4
* task for transmission.
* task for transmission.
*/
*/
if
(
NW_GTPV1U_OK
!=
nwGtpv1uMsgGetTpdu
(
pUlpApi
->
apiInfo
.
recvMsgInfo
.
hMsg
,
/*
if (NW_GTPV1U_OK != nwGtpv1uMsgGetTpdu(pUlpApi->apiInfo.recvMsgInfo.hMsg,
buffer, (NwU32T *)&buffer_len)) {
buffer, (NwU32T *)&buffer_len)) {
GTPU_ERROR("Error while retrieving T-PDU\n");
GTPU_ERROR("Error while retrieving T-PDU\n");
}
}*/
GTPU_DEBUG
(
"Received TPDU from gtpv1u stack %u with size %d
\n
"
,
pUlpApi
->
apiInfo
.
recvMsgInfo
.
teid
,
buffer_len
);
GTPU_DEBUG
(
"Received TPDU from gtpv1u stack %u with size %d
\n
"
,
pUlpApi
->
apiInfo
.
recvMsgInfo
.
teid
,
((
NwGtpv1uMsgT
*
)
pUlpApi
->
apiInfo
.
recvMsgInfo
.
hMsg
)
->
msgBufLen
);
message_p
=
itti_alloc_new_message
(
TASK_GTPV1_U
,
GTPV1U_TUNNEL_DATA_IND
);
message_p
=
itti_alloc_new_message
(
TASK_GTPV1_U
,
GTPV1U_TUNNEL_DATA_IND
);
if
(
message_p
==
NULL
)
{
if
(
message_p
==
NULL
)
{
return
-
1
;
return
-
1
;
}
}
data_ind_p
=
&
message_p
->
ittiMsg
.
gtpv1uTunnelDataInd
;
data_ind_p
=
&
message_p
->
ittiMsg
.
gtpv1uTunnelDataInd
;
data_ind_p
->
buffer
=
malloc
(
sizeof
(
uint8_t
)
*
buffer_len
);
data_ind_p
->
buffer
=
((
NwGtpv1uMsgT
*
)
pUlpApi
->
apiInfo
.
recvMsgInfo
.
hMsg
)
->
msgBuf
;
data_ind_p
->
length
=
((
NwGtpv1uMsgT
*
)
pUlpApi
->
apiInfo
.
recvMsgInfo
.
hMsg
)
->
msgBufLen
;
data_ind_p
->
offset
=
((
NwGtpv1uMsgT
*
)
pUlpApi
->
apiInfo
.
recvMsgInfo
.
hMsg
)
->
msgBufOffset
;
data_ind_p
->
local_S1u_teid
=
pUlpApi
->
apiInfo
.
recvMsgInfo
.
teid
;
data_ind_p
->
local_S1u_teid
=
pUlpApi
->
apiInfo
.
recvMsgInfo
.
teid
;
if
(
data_ind_p
->
buffer
==
NULL
)
{
if
(
data_ind_p
->
buffer
==
NULL
)
{
GTPU_ERROR
(
"Failed to allocate new buffer
\n
"
);
GTPU_ERROR
(
"Failed to allocate new buffer
\n
"
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
message_p
),
message_p
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
message_p
),
message_p
);
message_p
=
NULL
;
message_p
=
NULL
;
}
else
{
}
else
{
memcpy
(
data_ind_p
->
buffer
,
buffer
,
buffer_len
);
//
memcpy(data_ind_p->buffer, buffer, buffer_len);
data_ind_p
->
length
=
buffer_len
;
//
data_ind_p->length = buffer_len;
if
(
itti_send_msg_to_task
(
TASK_FW_IP
,
INSTANCE_DEFAULT
,
message_p
)
<
0
)
{
if
(
itti_send_msg_to_task
(
TASK_FW_IP
,
INSTANCE_DEFAULT
,
message_p
)
<
0
)
{
GTPU_ERROR
(
"Failed to send message to task
\n
"
);
GTPU_ERROR
(
"Failed to send message to task
\n
"
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
message_p
),
message_p
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
message_p
),
message_p
);
...
@@ -387,7 +458,7 @@ static void *gtpv1u_thread(void *args)
...
@@ -387,7 +458,7 @@ static void *gtpv1u_thread(void *args)
udp_data_ind_p
->
buffer_length
,
udp_data_ind_p
->
buffer_length
,
udp_data_ind_p
->
peer_port
,
udp_data_ind_p
->
peer_port
,
udp_data_ind_p
->
peer_address
);
udp_data_ind_p
->
peer_address
);
itti_free
(
ITTI_MSG_ORIGIN_ID
(
received_message_p
),
udp_data_ind_p
->
buffer
);
//
itti_free(ITTI_MSG_ORIGIN_ID(received_message_p), udp_data_ind_p->buffer);
}
}
break
;
break
;
...
@@ -400,18 +471,13 @@ static void *gtpv1u_thread(void *args)
...
@@ -400,18 +471,13 @@ static void *gtpv1u_thread(void *args)
gtpv1u_teid2enb_info_t
*
gtpv1u_teid2enb_info
=
NULL
;
gtpv1u_teid2enb_info_t
*
gtpv1u_teid2enb_info
=
NULL
;
data_req_p
=
&
received_message_p
->
ittiMsg
.
gtpv1uTunnelDataReq
;
data_req_p
=
&
received_message_p
->
ittiMsg
.
gtpv1uTunnelDataReq
;
//ipv4_send_data(ipv4_data_p->sd, data_ind_p->buffer, data_ind_p->length);
memset
(
&
stack_req
,
0
,
sizeof
(
NwGtpv1uUlpApiT
));
GTPU_DEBUG
(
"-- GTPV1U_TUNNEL_DATA_REQ -----------------------------------------------------
\n
%s :
\n
"
,
__FUNCTION__
);
gtpu_print_hex_octets
(
data_req_p
->
buffer
,
data_req_p
->
length
);
/*
memset
(
&
stack_req
,
0
,
sizeof
(
NwGtpv1uUlpApiT
));
* typedef struct
{
NW_IN NwU32T teid;
NW_IN NwU32T ipAddr;
NW_IN NwU8T flags;
NW_IN NwGtpv1uMsgHandleT hMsg;
} NwGtpv1uSendtoInfoT;*/
hash_rc
=
hashtable_get
(
gtpv1u_sgw_data
.
S1U_mapping
,
(
uint64_t
)
data_req_p
->
local_S1u_teid
,
(
void
**
)
&
gtpv1u_teid2enb_info
);
hash_rc
=
hashtable_get
(
gtpv1u_sgw_data
.
S1U_mapping
,
(
uint64_t
)
data_req_p
->
local_S1u_teid
,
(
void
**
)
&
gtpv1u_teid2enb_info
);
...
@@ -430,8 +496,7 @@ static void *gtpv1u_thread(void *args)
...
@@ -430,8 +496,7 @@ static void *gtpv1u_thread(void *args)
NW_IN NwU8T *tpdu,
NW_IN NwU8T *tpdu,
NW_IN NwU16T tpduLength,
NW_IN NwU16T tpduLength,
NW_OUT NwGtpv1uMsgHandleT *phMsg)*/
NW_OUT NwGtpv1uMsgHandleT *phMsg)*/
GTPU_DEBUG
(
"GTPV1U_TUNNEL_DATA_REQ buffer %p seq num %d %d bytes
\n
"
,
GTPU_DEBUG
(
"GTPV1U_TUNNEL_DATA_REQ seq num %d %d bytes
\n
"
,
data_req_p
->
buffer
,
gtpv1u_sgw_data
.
seq_num
,
gtpv1u_sgw_data
.
seq_num
,
data_req_p
->
length
);
data_req_p
->
length
);
rc
=
nwGtpv1uGpduMsgNew
(
gtpv1u_sgw_data
.
gtpv1u_stack
,
rc
=
nwGtpv1uGpduMsgNew
(
gtpv1u_sgw_data
.
gtpv1u_stack
,
...
@@ -440,6 +505,7 @@ static void *gtpv1u_thread(void *args)
...
@@ -440,6 +505,7 @@ static void *gtpv1u_thread(void *args)
gtpv1u_sgw_data
.
seq_num
++
,
gtpv1u_sgw_data
.
seq_num
++
,
data_req_p
->
buffer
,
data_req_p
->
buffer
,
data_req_p
->
length
,
data_req_p
->
length
,
data_req_p
->
offset
,
&
(
stack_req
.
apiInfo
.
sendtoInfo
.
hMsg
));
&
(
stack_req
.
apiInfo
.
sendtoInfo
.
hMsg
));
if
(
rc
!=
NW_GTPV1U_OK
)
{
if
(
rc
!=
NW_GTPV1U_OK
)
{
...
@@ -456,8 +522,8 @@ static void *gtpv1u_thread(void *args)
...
@@ -456,8 +522,8 @@ static void *gtpv1u_thread(void *args)
}
}
}
}
}
}
/* Buffer is
no longer needed,
free it */
/* Buffer is
still needed, do not
free it */
itti_free
(
ITTI_MSG_ORIGIN_ID
(
received_message_p
),
data_req_p
->
buffer
);
//
itti_free(ITTI_MSG_ORIGIN_ID(received_message_p), data_req_p->buffer);
}
}
break
;
break
;
case
TERMINATE_MESSAGE
:
{
case
TERMINATE_MESSAGE
:
{
...
...
openair-cn/GTPV1-U/nw-gtpv1u/include/NwGtpv1uPrivate.h
View file @
1c30f692
...
@@ -166,7 +166,9 @@ typedef struct NwGtpv1uMsg
...
@@ -166,7 +166,9 @@ typedef struct NwGtpv1uMsg
NwU16T
seqNum
;
NwU16T
seqNum
;
NwU8T
npduNum
;
NwU8T
npduNum
;
NwU8T
nextExtHdrType
;
NwU8T
nextExtHdrType
;
NwU8T
msgBuf
[
NW_GTPV1U_MAX_MSG_LEN
];
NwU8T
*
msgBuf
;
NwU32T
msgBufLen
;
NwU32T
msgBufOffset
;
struct
NwGtpv1uMsg
*
next
;
struct
NwGtpv1uMsg
*
next
;
}
NwGtpv1uMsgT
;
}
NwGtpv1uMsgT
;
...
...
openair-cn/GTPV1-U/nw-gtpv1u/shared/NwGtpv1uMsg.h
View file @
1c30f692
...
@@ -121,6 +121,7 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -121,6 +121,7 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
NW_IN
NwU16T
seqNum
,
NW_IN
NwU16T
seqNum
,
NW_IN
NwU8T
*
tpdu
,
NW_IN
NwU8T
*
tpdu
,
NW_IN
NwU16T
tpduLength
,
NW_IN
NwU16T
tpduLength
,
NW_IN
NwU32T
tpduOffset
,
NW_OUT
NwGtpv1uMsgHandleT
*
phMsg
);
NW_OUT
NwGtpv1uMsgHandleT
*
phMsg
);
/**
/**
...
...
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1u.c
View file @
1c30f692
...
@@ -198,7 +198,7 @@ nwGtpv1uCreateAndSendMsg( NwGtpv1uStackT *thiz, NwU32T peerIp, NwU16T peerPort,
...
@@ -198,7 +198,7 @@ nwGtpv1uCreateAndSendMsg( NwGtpv1uStackT *thiz, NwU32T peerIp, NwU16T peerPort,
NW_ENTER
(
thiz
);
NW_ENTER
(
thiz
);
msgHdr
=
pMsg
->
msgBuf
;
msgHdr
=
&
pMsg
->
msgBuf
[
pMsg
->
msgBufOffset
]
;
NW_ASSERT
(
msgHdr
!=
NULL
);
NW_ASSERT
(
msgHdr
!=
NULL
);
*
(
msgHdr
++
)
=
(
pMsg
->
version
<<
5
)
|
*
(
msgHdr
++
)
=
(
pMsg
->
version
<<
5
)
|
...
@@ -228,7 +228,8 @@ nwGtpv1uCreateAndSendMsg( NwGtpv1uStackT *thiz, NwU32T peerIp, NwU16T peerPort,
...
@@ -228,7 +228,8 @@ nwGtpv1uCreateAndSendMsg( NwGtpv1uStackT *thiz, NwU32T peerIp, NwU16T peerPort,
rc
=
thiz
->
udp
.
udpDataReqCallback
(
thiz
->
udp
.
hUdp
,
rc
=
thiz
->
udp
.
udpDataReqCallback
(
thiz
->
udp
.
hUdp
,
pMsg
->
msgBuf
,
pMsg
->
msgBuf
,
pMsg
->
msgLen
+
NW_GTPV1U_EPC_MIN_HEADER_SIZE
,
pMsg
->
msgLen
,
pMsg
->
msgOffset
,
peerIp
,
peerIp
,
peerPort
);
peerPort
);
...
@@ -490,11 +491,11 @@ nwGtpv1uProcessGpdu( NwGtpv1uStackT *thiz,
...
@@ -490,11 +491,11 @@ nwGtpv1uProcessGpdu( NwGtpv1uStackT *thiz,
NwGtpv1uMsgHeaderT
*
msgHdr
=
NULL
;
NwGtpv1uMsgHeaderT
*
msgHdr
=
NULL
;
NwGtpv1uTunnelEndPointT
*
pTunnelEndPoint
=
NULL
;
NwGtpv1uTunnelEndPointT
*
pTunnelEndPoint
=
NULL
;
NwGtpv1uTunnelEndPointT
tunnelEndPointKey
;
NwGtpv1uTunnelEndPointT
tunnelEndPointKey
;
NwU16T
payload_len
=
0
;
NwU16T
hdr_len
=
0
;
NwU16T
hdr_len
=
0
;
NW_ENTER
(
thiz
);
NW_ENTER
(
thiz
);
// no buffer offset
msgHdr
=
(
NwGtpv1uMsgHeaderT
*
)
gpdu
;
msgHdr
=
(
NwGtpv1uMsgHeaderT
*
)
gpdu
;
tunnelEndPointKey
.
teid
=
ntohl
(
msgHdr
->
teid
);
tunnelEndPointKey
.
teid
=
ntohl
(
msgHdr
->
teid
);
...
@@ -509,22 +510,19 @@ nwGtpv1uProcessGpdu( NwGtpv1uStackT *thiz,
...
@@ -509,22 +510,19 @@ nwGtpv1uProcessGpdu( NwGtpv1uStackT *thiz,
(
NwU8T
*
)
gpdu
,
(
NwU8T
*
)
gpdu
,
gpduLen
,
gpduLen
,
&
hMsg
);
&
hMsg
);
/*
NwU8T* msgBuf;
NwU32T msgBufLen;
NwU32T msgBufOffset;
*/
if
(
NW_GTPV1U_OK
==
rc
)
{
if
(
NW_GTPV1U_OK
==
rc
)
{
NwGtpv1uMsgT
*
pMsg
=
(
NwGtpv1uMsgT
*
)
hMsg
;
NwGtpv1uMsgT
*
pMsg
=
(
NwGtpv1uMsgT
*
)
hMsg
;
GTPU_DEBUG
(
"Received T-PDU over tunnel end-point '%x' of size %u from "
NW_IPV4_ADDR
"
\n
"
,
GTPU_DEBUG
(
"Received T-PDU over tunnel end-point '%x' of size %u (decapsulated %u)from "
NW_IPV4_ADDR
"
\n
"
,
ntohl
(
msgHdr
->
teid
),
pMsg
->
msgLen
,
NW_IPV4_ADDR_FORMAT
((
peerIp
)));
ntohl
(
msgHdr
->
teid
),
gpduLen
,
pMsg
->
msgLen
,
NW_IPV4_ADDR_FORMAT
((
peerIp
)));
payload_len
=
ntohs
(
msgHdr
->
msgLength
);
AssertFatal
(
gpduLen
==
(
pMsg
->
msgLen
+
pMsg
->
msgOffset
),
hdr_len
=
NW_GTPV1U_EPC_MIN_HEADER_SIZE
;
"Mismatch gpduLen %d / buffer offset %d / msg len %d / buffer len"
,
if
(
msgHdr
->
S
||
msgHdr
->
PN
||
msgHdr
->
E
)
{
gpduLen
,
pMsg
->
msgBufOffset
,
pMsg
->
msgLen
,
pMsg
->
msgBufLen
);
hdr_len
=
NW_GTPV1U_EPC_SPECIFIC_HEADER_SIZE
;
payload_len
=
payload_len
-
(
NW_GTPV1U_EPC_SPECIFIC_HEADER_SIZE
-
NW_GTPV1U_EPC_MIN_HEADER_SIZE
);
}
AssertFatal
(
gpduLen
==
(
payload_len
+
hdr_len
),
"Mismatch gpduLen %d / hdr_len %d / payload_len %d"
,
gpduLen
,
hdr_len
,
payload_len
);
rc
=
nwGtpSessionSendMsgApiToUlpEntity
(
pTunnelEndPoint
,
pMsg
);
rc
=
nwGtpSessionSendMsgApiToUlpEntity
(
pTunnelEndPoint
,
pMsg
);
}
}
...
...
openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c
View file @
1c30f692
...
@@ -117,11 +117,13 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -117,11 +117,13 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
NW_IN
NwU16T
seqNum
,
NW_IN
NwU16T
seqNum
,
NW_IN
NwU8T
*
tpdu
,
NW_IN
NwU8T
*
tpdu
,
NW_IN
NwU16T
tpduLength
,
NW_IN
NwU16T
tpduLength
,
NW_IN
NwU32T
tpduOffset
,
NW_OUT
NwGtpv1uMsgHandleT
*
phMsg
)
NW_OUT
NwGtpv1uMsgHandleT
*
phMsg
)
{
{
NwGtpv1uStackT
*
pStack
=
(
NwGtpv1uStackT
*
)
hGtpuStackHandle
;
NwGtpv1uStackT
*
pStack
=
(
NwGtpv1uStackT
*
)
hGtpuStackHandle
;
NwGtpv1uMsgT
*
pMsg
;
NwGtpv1uMsgT
*
pMsg
;
NwU32T
header_len
=
0
;
NwU32T
header_len
=
0
;
NwU32T
msgExtraLen
=
0
;
if
(
gpGtpv1uMsgPool
)
{
if
(
gpGtpv1uMsgPool
)
{
pMsg
=
gpGtpv1uMsgPool
;
pMsg
=
gpGtpv1uMsgPool
;
...
@@ -130,7 +132,15 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -130,7 +132,15 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
NW_GTPV1U_MALLOC
(
pStack
,
sizeof
(
NwGtpv1uMsgT
),
pMsg
,
NwGtpv1uMsgT
*
);
NW_GTPV1U_MALLOC
(
pStack
,
sizeof
(
NwGtpv1uMsgT
),
pMsg
,
NwGtpv1uMsgT
*
);
}
}
if
(
pMsg
)
{
if
(
pMsg
)
{
msgExtraLen
=
(((
seqNumFlag
)
||
(
NW_FALSE
)
||
(
NW_FALSE
)
)
?
(
NW_GTPV1U_EPC_SPECIFIC_HEADER_SIZE
-
NW_GTPV1U_EPC_MIN_HEADER_SIZE
)
:
0
);
AssertFatal
((
msgExtraLen
+
NW_GTPV1U_EPC_MIN_HEADER_SIZE
)
<=
tpduOffset
);
pMsg
->
msgBuf
=
tpdu
;
pMsg
->
msgBufLen
=
tpduLength
+
msgExtraLen
+
NW_GTPV1U_EPC_MIN_HEADER_SIZE
;
pMsg
->
msgBufOffset
=
tpduOffset
-
(
msgExtraLen
+
NW_GTPV1U_EPC_MIN_HEADER_SIZE
);
// Version field: This field is used to determine the version of the GTP-U protocol.
// Version field: This field is used to determine the version of the GTP-U protocol.
// The version number shall be set to '1'.
// The version number shall be set to '1'.
pMsg
->
version
=
NW_GTPU_VERSION
;
pMsg
->
version
=
NW_GTPU_VERSION
;
...
@@ -181,7 +191,7 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -181,7 +191,7 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
pMsg
->
teid
=
teid
;
pMsg
->
teid
=
teid
;
pMsg
->
nextExtHdrType
=
0x00
;
pMsg
->
nextExtHdrType
=
0x00
;
memcpy
(
pMsg
->
msgBuf
+
header_len
,
tpdu
,
tpduLength
);
//
memcpy(pMsg->msgBuf + header_len, tpdu, tpduLength);
*
phMsg
=
(
NwGtpv1uMsgHandleT
)
pMsg
;
*
phMsg
=
(
NwGtpv1uMsgHandleT
)
pMsg
;
return
NW_GTPV1U_OK
;
return
NW_GTPV1U_OK
;
}
}
...
@@ -231,8 +241,7 @@ nwGtpv1uMsgFromBufferNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -231,8 +241,7 @@ nwGtpv1uMsgFromBufferNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
if
(
pMsg
)
{
if
(
pMsg
)
{
memcpy
(
pMsg
->
msgBuf
,
pBuf
,
bufLen
);
pMsg
->
msgBuf
=
pBuf
;
pMsg
->
msgLen
=
bufLen
;
pMsg
->
version
=
((
*
pBuf
)
&
0xE0
)
>>
5
;
pMsg
->
version
=
((
*
pBuf
)
&
0xE0
)
>>
5
;
pMsg
->
protocolType
=
((
*
pBuf
)
&
0x10
)
>>
4
;
pMsg
->
protocolType
=
((
*
pBuf
)
&
0x10
)
>>
4
;
...
@@ -255,6 +264,8 @@ nwGtpv1uMsgFromBufferNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
...
@@ -255,6 +264,8 @@ nwGtpv1uMsgFromBufferNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle,
pMsg
->
npduNum
=
*
(
pBuf
++
);
pMsg
->
npduNum
=
*
(
pBuf
++
);
pMsg
->
nextExtHdrType
=
*
(
pBuf
++
);
pMsg
->
nextExtHdrType
=
*
(
pBuf
++
);
}
}
pMsg
->
msgOffset
=
(
NwU32T
)(
pBuf
-
pMsg
->
msgBuf
);
pMsg
->
msgLen
=
bufLen
-
pMsg
->
msgOffset
;
*
phMsg
=
(
NwGtpv1uMsgHandleT
)
pMsg
;
*
phMsg
=
(
NwGtpv1uMsgHandleT
)
pMsg
;
return
NW_GTPV1U_OK
;
return
NW_GTPV1U_OK
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment