blob: ec6aef310d3d87c5d9647cb845d3736050cfdcbb [file] [log] [blame]
Pau Espin Pedrola469a902019-05-31 15:37:50 +02001/*
Harald Welte632e8432017-09-05 18:12:14 +02002 * OsmoGGSN - Gateway GPRS Support Node
jjako0fe0df02004-09-17 11:30:40 +00003 * Copyright (C) 2002, 2003, 2004 Mondru AB.
Pau Espin Pedrola469a902019-05-31 15:37:50 +02004 *
jjako52c24142002-12-16 13:33:51 +00005 * The contents of this file may be used under the terms of the GNU
6 * General Public License Version 2, provided that the above copyright
7 * notice and this permission notice is included in all copies or
8 * substantial portions of the software.
Pau Espin Pedrola469a902019-05-31 15:37:50 +02009 *
jjako52c24142002-12-16 13:33:51 +000010 */
11
12#ifndef _GTP_H
13#define _GTP_H
14
Maxe6612772018-01-11 18:25:37 +010015#include <osmocom/core/utils.h>
Pau Espin Pedrol8e8c7ef2018-07-16 16:47:12 +020016#include <osmocom/core/defs.h>
Maxe6612772018-01-11 18:25:37 +010017
jjako1db1c812003-07-06 20:53:57 +000018#define GTP_MODE_GGSN 1
19#define GTP_MODE_SGSN 2
20
jjako52c24142002-12-16 13:33:51 +000021#define GTP0_PORT 3386
22#define GTP1C_PORT 2123
23#define GTP1U_PORT 2152
24#define PACKET_MAX 8196
25
Harald Weltebed35df2011-11-02 13:06:18 +010026#define GTP_MAX 0xffff /* TODO: Choose right number */
jjako52c24142002-12-16 13:33:51 +000027#define GTP0_HEADER_SIZE 20
28#define GTP1_HEADER_SIZE_SHORT 8
29#define GTP1_HEADER_SIZE_LONG 12
30
31#define SYSLOG_PRINTSIZE 255
32#define ERRMSG_SIZE 255
33
34#define RESTART_FILE "gsn_restart"
35#define NAMESIZE 1024
36
jjako2c381332003-10-21 19:09:53 +000037/* GTP version 1 extension header type definitions. */
Harald Weltebed35df2011-11-02 13:06:18 +010038#define GTP_EXT_PDCP_PDU 0xC0 /* PDCP PDU Number */
jjako2c381332003-10-21 19:09:53 +000039
jjako52c24142002-12-16 13:33:51 +000040/* GTP version 1 message type definitions. Also covers version 0 except *
41 * for anonymous PDP context which was superceded in version 1 */
42
43/* 0 For future use. */
Harald Weltebed35df2011-11-02 13:06:18 +010044#define GTP_ECHO_REQ 1 /* Echo Request */
45#define GTP_ECHO_RSP 2 /* Echo Response */
46#define GTP_NOT_SUPPORTED 3 /* Version Not Supported */
47#define GTP_ALIVE_REQ 4 /* Node Alive Request */
48#define GTP_ALIVE_RSP 5 /* Node Alive Response */
49#define GTP_REDIR_REQ 6 /* Redirection Request */
50#define GTP_REDIR_RSP 7 /* Redirection Response */
jjako52c24142002-12-16 13:33:51 +000051/* 8-15 For future use. */
Harald Weltebed35df2011-11-02 13:06:18 +010052#define GTP_CREATE_PDP_REQ 16 /* Create PDP Context Request */
53#define GTP_CREATE_PDP_RSP 17 /* Create PDP Context Response */
54#define GTP_UPDATE_PDP_REQ 18 /* Update PDP Context Request */
55#define GTP_UPDATE_PDP_RSP 19 /* Update PDP Context Response */
56#define GTP_DELETE_PDP_REQ 20 /* Delete PDP Context Request */
57#define GTP_DELETE_PDP_RSP 21 /* Delete PDP Context Response */
58 /* 22-25 For future use. *//* In version GTP 1 anonomous PDP context */
59#define GTP_ERROR 26 /* Error Indication */
60#define GTP_PDU_NOT_REQ 27 /* PDU Notification Request */
61#define GTP_PDU_NOT_RSP 28 /* PDU Notification Response */
62#define GTP_PDU_NOT_REJ_REQ 29 /* PDU Notification Reject Request */
63#define GTP_PDU_NOT_REJ_RSP 30 /* PDU Notification Reject Response */
64#define GTP_SUPP_EXT_HEADER 31 /* Supported Extension Headers Notification */
65#define GTP_SND_ROUTE_REQ 32 /* Send Routeing Information for GPRS Request */
66#define GTP_SND_ROUTE_RSP 33 /* Send Routeing Information for GPRS Response */
67#define GTP_FAILURE_REQ 34 /* Failure Report Request */
68#define GTP_FAILURE_RSP 35 /* Failure Report Response */
69#define GTP_MS_PRESENT_REQ 36 /* Note MS GPRS Present Request */
70#define GTP_MS_PRESENT_RSP 37 /* Note MS GPRS Present Response */
71/* 38-47 For future use. */
72#define GTP_IDEN_REQ 48 /* Identification Request */
73#define GTP_IDEN_RSP 49 /* Identification Response */
74#define GTP_SGSN_CONTEXT_REQ 50 /* SGSN Context Request */
75#define GTP_SGSN_CONTEXT_RSP 51 /* SGSN Context Response */
76#define GTP_SGSN_CONTEXT_ACK 52 /* SGSN Context Acknowledge */
77#define GTP_FWD_RELOC_REQ 53 /* Forward Relocation Request */
78#define GTP_FWD_RELOC_RSP 54 /* Forward Relocation Response */
79#define GTP_FWD_RELOC_COMPL 55 /* Forward Relocation Complete */
80#define GTP_RELOC_CANCEL_REQ 56 /* Relocation Cancel Request */
81#define GTP_RELOC_CANCEL_RSP 57 /* Relocation Cancel Response */
82#define GTP_FWD_SRNS 58 /* Forward SRNS Context */
83#define GTP_FWD_RELOC_ACK 59 /* Forward Relocation Complete Acknowledge */
84#define GTP_FWD_SRNS_ACK 60 /* Forward SRNS Context Acknowledge */
jjako52c24142002-12-16 13:33:51 +000085/* 61-239 For future use. */
Harald Weltebed35df2011-11-02 13:06:18 +010086#define GTP_DATA_TRAN_REQ 240 /* Data Record Transfer Request */
87#define GTP_DATA_TRAN_RSP 241 /* Data Record Transfer Response */
jjako52c24142002-12-16 13:33:51 +000088/* 242-254 For future use. */
Harald Weltebed35df2011-11-02 13:06:18 +010089#define GTP_GPDU 255 /* G-PDU */
jjako08d331d2003-10-13 20:33:30 +000090
Maxe6612772018-01-11 18:25:37 +010091extern const struct value_string gtp_type_names[];
92static inline const char *gtp_type_name(uint8_t val)
93{ return get_value_string(gtp_type_names, val); }
94
jjako08d331d2003-10-13 20:33:30 +000095/* GTP information element cause codes from 29.060 v3.9.0 7.7 */
96/* */
Harald Weltebed35df2011-11-02 13:06:18 +010097#define GTPCAUSE_REQ_IMSI 0 /* Request IMSI */
98#define GTPCAUSE_REQ_IMEI 1 /* Request IMEI */
99#define GTPCAUSE_REQ_IMSI_IMEI 2 /* Request IMSI and IMEI */
100#define GTPCAUSE_NO_ID_NEEDED 3 /* No identity needed */
101#define GTPCAUSE_MS_REFUSES_X 4 /* MS refuses */
102#define GTPCAUSE_MS_NOT_RESP_X 5 /* MS is not GPRS responding */
103#define GTPCAUSE_006 6 /* For future use 6-48 */
104#define GTPCAUSE_049 49 /* Cause values reserved for GPRS charging protocol use (See GTP' in GSM 12.15) 49-63 */
105#define GTPCAUSE_064 64 /* For future use 64-127 */
106#define GTPCAUSE_ACC_REQ 128 /* Request accepted */
107#define GTPCAUSE_129 129 /* For future use 129-176 */
108#define GTPCAUSE_177 177 /* Cause values reserved for GPRS charging protocol use (See GTP' In GSM 12.15) 177-191 */
109#define GTPCAUSE_NON_EXIST 192 /* Non-existent */
110#define GTPCAUSE_INVALID_MESSAGE 193 /* Invalid message format */
111#define GTPCAUSE_IMSI_NOT_KNOWN 194 /* IMSI not known */
112#define GTPCAUSE_MS_DETACHED 195 /* MS is GPRS detached */
113#define GTPCAUSE_MS_NOT_RESP 196 /* MS is not GPRS responding */
114#define GTPCAUSE_MS_REFUSES 197 /* MS refuses */
115#define GTPCAUSE_198 198 /* For future use */
116#define GTPCAUSE_NO_RESOURCES 199 /* No resources available */
117#define GTPCAUSE_NOT_SUPPORTED 200 /* Service not supported */
118#define GTPCAUSE_MAN_IE_INCORRECT 201 /* Mandatory IE incorrect */
119#define GTPCAUSE_MAN_IE_MISSING 202 /* Mandatory IE missing */
120#define GTPCAUSE_OPT_IE_INCORRECT 203 /* Optional IE incorrect */
121#define GTPCAUSE_SYS_FAIL 204 /* System failure */
122#define GTPCAUSE_ROAMING_REST 205 /* Roaming Restriction */
123#define GTPCAUSE_PTIMSI_MISMATCH 206 /* P-TMSI signature mismatch */
124#define GTPCAUSE_CONN_SUSP 207 /* GPRS connection suspended */
125#define GTPCAUSE_AUTH_FAIL 208 /* Authentication failure */
126#define GTPCAUSE_USER_AUTH_FAIL 209 /* User authentication failed */
127#define GTPCAUSE_CONTEXT_NOT_FOUND 210 /* Context not found */
128#define GTPCAUSE_ADDR_OCCUPIED 211 /* All dynamic PDP addresses are occupied */
129#define GTPCAUSE_NO_MEMORY 212 /* No memory is available */
130#define GTPCAUSE_RELOC_FAIL 213 /* Relocation failure */
131#define GTPCAUSE_UNKNOWN_MAN_EXTHEADER 214 /* Unknown mandatory extension header */
132#define GTPCAUSE_SEM_ERR_TFT 215 /* Semantic error in the TFT operation */
133#define GTPCAUSE_SYN_ERR_TFT 216 /* Syntactic error in the TFT operation */
134#define GTPCAUSE_SEM_ERR_FILTER 217 /* Semantic errors in packet filter(s) */
135#define GTPCAUSE_SYN_ERR_FILTER 218 /* Syntactic errors in packet filter(s) */
136#define GTPCAUSE_MISSING_APN 219 /* Missing or unknown APN */
137#define GTPCAUSE_UNKNOWN_PDP 220 /* Unknown PDP address or PDP type */
138#define GTPCAUSE_221 221 /* For Future Use 221-240 */
139#define GTPCAUSE_241 241 /* Cause Values Reserved For Gprs Charging Protocol Use (See Gtp' In Gsm 12.15) 241-255 */
jjako08d331d2003-10-13 20:33:30 +0000140
Holger Hans Peter Freyther03829962013-07-27 20:01:15 +0200141struct ul66_t;
142struct ul16_t;
Holger Hans Peter Freyther3a9befb2016-01-23 10:15:43 +0100143struct pdp_t;
Holger Hans Peter Freyther03829962013-07-27 20:01:15 +0200144
Pau Espin Pedrola469a902019-05-31 15:37:50 +0200145/* GTP 0 header.
jjako52c24142002-12-16 13:33:51 +0000146 * Explanation to some of the fields:
147 * SNDCP NPDU Number flag = 0 except for inter SGSN handover situations
148 * SNDCP N-PDU LCC Number 0 = 0xff except for inter SGSN handover situations
149 * Sequence number. Used for reliable delivery of signalling messages, and
150 * to discard "illegal" data messages.
151 * Flow label. Is used to point a particular PDP context. Is used in data
152 * messages as well as signalling messages related to a particular context.
153 * Tunnel ID is IMSI+NSAPI. Unique identifier of PDP context. Is somewhat
154 * redundant because the header also includes flow. */
155
Harald Weltebed35df2011-11-02 13:06:18 +0100156struct gtp0_header { /* Descriptions from 3GPP 09.60 */
157 uint8_t flags; /* 01 bitfield, with typical values */
158 /* 000..... Version: 1 (0) */
159 /* ...1111. Spare (7) */
160 /* .......0 SNDCP N-PDU Number flag (0) */
161 uint8_t type; /* 02 Message type. T-PDU = 0xff */
162 uint16_t length; /* 03 Length (of G-PDU excluding header) */
163 uint16_t seq; /* 05 Sequence Number */
164 uint16_t flow; /* 07 Flow Label ( = 0 for signalling) */
165 uint8_t number; /* 09 SNDCP N-PDU LCC Number ( 0 = 0xff) */
166 uint8_t spare1; /* 10 Spare */
167 uint8_t spare2; /* 11 Spare */
168 uint8_t spare3; /* 12 Spare */
169 uint64_t tid; /* 13 Tunnel ID */
Pablo Neira Ayuso0674f0b2014-03-19 22:55:29 +0100170} __attribute__((packed)); /* 20 */
jjako52c24142002-12-16 13:33:51 +0000171
Harald Weltefed598f2017-09-24 16:39:22 +0800172#define GTP1HDR_F_NPDU 0x01
173#define GTP1HDR_F_SEQ 0x02
174#define GTP1HDR_F_EXT 0x04
175#define GTP1HDR_F_GTP1 0x10
176#define GTPHDR_F_VER(n) ((n) << 5)
177#define GTPHDR_F_GET_VER(flags) ((flags)>>5)
178
Harald Weltebed35df2011-11-02 13:06:18 +0100179struct gtp1_header_short { /* Descriptions from 3GPP 29060 */
180 uint8_t flags; /* 01 bitfield, with typical values */
181 /* 001..... Version: 1 */
182 /* ...1.... Protocol Type: GTP=1, GTP'=0 */
183 /* ....0... Spare = 0 */
184 /* .....0.. Extension header flag: 0 */
185 /* ......0. Sequence number flag: 0 */
186 /* .......0 PN: N-PDU Number flag */
187 uint8_t type; /* 02 Message type. T-PDU = 0xff */
188 uint16_t length; /* 03 Length (of IP packet or signalling) */
189 uint32_t tei; /* 05 - 08 Tunnel Endpoint ID */
Pablo Neira Ayuso0674f0b2014-03-19 22:55:29 +0100190} __attribute__((packed));
jjako52c24142002-12-16 13:33:51 +0000191
Harald Weltebed35df2011-11-02 13:06:18 +0100192struct gtp1_header_long { /* Descriptions from 3GPP 29060 */
193 uint8_t flags; /* 01 bitfield, with typical values */
194 /* 001..... Version: 1 */
195 /* ...1.... Protocol Type: GTP=1, GTP'=0 */
196 /* ....0... Spare = 0 */
197 /* .....0.. Extension header flag: 0 */
198 /* ......1. Sequence number flag: 1 */
199 /* .......0 PN: N-PDU Number flag */
200 uint8_t type; /* 02 Message type. T-PDU = 0xff */
201 uint16_t length; /* 03 Length (of IP packet or signalling) */
202 uint32_t tei; /* 05 Tunnel Endpoint ID */
203 uint16_t seq; /* 10 Sequence Number */
204 uint8_t npdu; /* 11 N-PDU Number */
205 uint8_t next; /* 12 Next extension header type. Empty = 0 */
Pablo Neira Ayuso0674f0b2014-03-19 22:55:29 +0100206} __attribute__((packed));
jjako52c24142002-12-16 13:33:51 +0000207
208struct gtp0_packet {
Harald Weltebed35df2011-11-02 13:06:18 +0100209 struct gtp0_header h;
210 uint8_t p[GTP_MAX];
211} __attribute__ ((packed));
jjako52c24142002-12-16 13:33:51 +0000212
213struct gtp1_packet_short {
Harald Weltebed35df2011-11-02 13:06:18 +0100214 struct gtp1_header_short h;
215 uint8_t p[GTP_MAX];
216} __attribute__ ((packed));
jjako52c24142002-12-16 13:33:51 +0000217
218struct gtp1_packet_long {
Harald Weltebed35df2011-11-02 13:06:18 +0100219 struct gtp1_header_long h;
220 uint8_t p[GTP_MAX];
221} __attribute__ ((packed));
jjako52c24142002-12-16 13:33:51 +0000222
223union gtp_packet {
Harald Weltebed35df2011-11-02 13:06:18 +0100224 uint8_t flags;
225 struct gtp0_packet gtp0;
226 struct gtp1_packet_short gtp1s;
227 struct gtp1_packet_long gtp1l;
228} __attribute__ ((packed));
jjako52c24142002-12-16 13:33:51 +0000229
230/* ***********************************************************
231 * Information storage for each gsn instance
232 *
233 * Normally each instance of the application corresponds to
Pau Espin Pedrola469a902019-05-31 15:37:50 +0200234 * one instance of a gsn.
235 *
jjako52c24142002-12-16 13:33:51 +0000236 * In order to avoid global variables in the application, and
237 * also in order to allow several instances of a gsn in the same
238 * application this struct is provided in order to store all
239 * relevant information related to the gsn.
Pau Espin Pedrola469a902019-05-31 15:37:50 +0200240 *
jjako52c24142002-12-16 13:33:51 +0000241 * Note that this does not include information storage for '
242 * each pdp context. This is stored in another struct.
243 *************************************************************/
244
245struct gsn_t {
Harald Weltebed35df2011-11-02 13:06:18 +0100246 /* Parameters related to the network interface */
jjako52c24142002-12-16 13:33:51 +0000247
Harald Weltebed35df2011-11-02 13:06:18 +0100248 int fd0; /* GTP0 file descriptor */
249 int fd1c; /* GTP1 control plane file descriptor */
250 int fd1u; /* GTP0 user plane file descriptor */
251 int mode; /* Mode of operation: GGSN or SGSN */
252 struct in_addr gsnc; /* IP address of this gsn for signalling */
253 struct in_addr gsnu; /* IP address of this gsn for user traffic */
jjako52c24142002-12-16 13:33:51 +0000254
Harald Weltebed35df2011-11-02 13:06:18 +0100255 /* Parameters related to signalling messages */
256 uint16_t seq_next; /* Next sequence number to use */
257 int seq_first; /* First packet in queue (oldest timeout) */
258 int seq_last; /* Last packet in queue (youngest timeout) */
jjako52c24142002-12-16 13:33:51 +0000259
Harald Weltebed35df2011-11-02 13:06:18 +0100260 unsigned char restart_counter; /* Increment on restart. Stored on disk */
261 char *statedir; /* Disk location for permanent storage */
Harald Welte8a03ea82017-08-12 14:52:45 +0200262 void *priv; /* used by libgtp users to attach their own state) */
Harald Weltebed35df2011-11-02 13:06:18 +0100263 struct queue_t *queue_req; /* Request queue */
264 struct queue_t *queue_resp; /* Response queue */
jjako52c24142002-12-16 13:33:51 +0000265
Harald Weltebed35df2011-11-02 13:06:18 +0100266 /* Call back functions */
267 int (*cb_delete_context) (struct pdp_t *);
268 int (*cb_create_context_ind) (struct pdp_t *);
269 int (*cb_unsup_ind) (struct sockaddr_in * peer);
270 int (*cb_extheader_ind) (struct sockaddr_in * peer);
271 int (*cb_conf) (int type, int cause, struct pdp_t * pdp, void *cbp);
272 int (*cb_data_ind) (struct pdp_t * pdp, void *pack, unsigned len);
273 int (*cb_recovery) (struct sockaddr_in * peer, uint8_t recovery);
Pau Espin Pedrolb5f93342018-07-23 11:24:07 +0200274 int (*cb_recovery2) (struct sockaddr_in * peer, struct pdp_t * pdp, uint8_t recovery);
jjako52c24142002-12-16 13:33:51 +0000275
Harald Weltebed35df2011-11-02 13:06:18 +0100276 /* Counters */
jjako52c24142002-12-16 13:33:51 +0000277
Harald Weltebed35df2011-11-02 13:06:18 +0100278 uint64_t err_socket; /* Number of socket errors */
279 uint64_t err_readfrom; /* Number of readfrom errors */
280 uint64_t err_sendto; /* Number of sendto errors */
281 uint64_t err_memcpy; /* Number of memcpy */
282 uint64_t err_queuefull; /* Number of times queue was full */
283 uint64_t err_seq; /* Number of seq out of range */
284 uint64_t err_address; /* GSN address conversion failed */
285 uint64_t err_unknownpdp; /* GSN address conversion failed */
286 uint64_t err_unknowntid; /* Application supplied unknown imsi+nsapi */
287 uint64_t err_cause; /* Unexpected cause value received */
288 uint64_t err_outofpdp; /* Out of storage for PDP contexts */
289
290 uint64_t empty; /* Number of empty packets */
291 uint64_t unsup; /* Number of unsupported version 29.60 11.1.1 */
292 uint64_t tooshort; /* Number of too short headers 29.60 11.1.2 */
293 uint64_t unknown; /* Number of unknown messages 29.60 11.1.3 */
294 uint64_t unexpect; /* Number of unexpected messages 29.60 11.1.4 */
Neels Hofmeyrb18e8112015-10-12 14:00:21 +0200295 uint64_t duplicate; /* Number of duplicate or unsolicited replies */
Harald Weltebed35df2011-11-02 13:06:18 +0100296 uint64_t missing; /* Number of missing information field messages */
297 uint64_t incorrect; /* Number of incorrect information field messages */
298 uint64_t invalid; /* Number of invalid message format messages */
jjako52c24142002-12-16 13:33:51 +0000299};
300
jjako52c24142002-12-16 13:33:51 +0000301/* External API functions */
302
Harald Weltebed35df2011-11-02 13:06:18 +0100303extern const char *gtp_version();
jjako1db1c812003-07-06 20:53:57 +0000304extern int gtp_new(struct gsn_t **gsn, char *statedir, struct in_addr *listen,
305 int mode);
306
jjako52c24142002-12-16 13:33:51 +0000307extern int gtp_free(struct gsn_t *gsn);
308
309extern int gtp_newpdp(struct gsn_t *gsn, struct pdp_t **pdp,
310 uint64_t imsi, uint8_t nsapi);
311extern int gtp_freepdp(struct gsn_t *gsn, struct pdp_t *pdp);
Pau Espin Pedrol0d0b0592019-05-29 20:42:09 +0200312extern int gtp_freepdp_teardown(struct gsn_t *gsn, struct pdp_t *pdp);
jjako52c24142002-12-16 13:33:51 +0000313
Harald Weltebed35df2011-11-02 13:06:18 +0100314extern int gtp_create_context_req(struct gsn_t *gsn, struct pdp_t *pdp,
jjako193e8b12003-11-10 12:31:41 +0000315 void *cbp);
jjako52c24142002-12-16 13:33:51 +0000316
jjako08d331d2003-10-13 20:33:30 +0000317extern int gtp_set_cb_create_context_ind(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100318 int (*cb_create_context_ind) (struct
319 pdp_t *
320 pdp));
jjako1db1c812003-07-06 20:53:57 +0000321
Harald Weltebed35df2011-11-02 13:06:18 +0100322extern int gtp_create_context_resp(struct gsn_t *gsn, struct pdp_t *pdp,
jjako08d331d2003-10-13 20:33:30 +0000323 int cause);
324
Harald Weltebed35df2011-11-02 13:06:18 +0100325extern int gtp_update_context(struct gsn_t *gsn, struct pdp_t *pdp,
326 void *cbp, struct in_addr *inetaddr);
jjako08d331d2003-10-13 20:33:30 +0000327
Harald Weltebed35df2011-11-02 13:06:18 +0100328extern int gtp_delete_context_req(struct gsn_t *gsn, struct pdp_t *pdp,
Pau Espin Pedrol8e8c7ef2018-07-16 16:47:12 +0200329 void *cbp, int teardown)
330 OSMO_DEPRECATED("Use gtp_delete_context_req2() instead, to avoid freeing pdp ctx before reply");
331extern int gtp_delete_context_req2(struct gsn_t *gsn, struct pdp_t *pdp,
332 void *cbp, int teardown);
jjako08d331d2003-10-13 20:33:30 +0000333
334extern int gtp_data_req(struct gsn_t *gsn, struct pdp_t *pdp,
335 void *pack, unsigned len);
336
337extern int gtp_set_cb_data_ind(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100338 int (*cb_data_ind) (struct pdp_t * pdp,
339 void *pack, unsigned len));
jjako52c24142002-12-16 13:33:51 +0000340
341extern int gtp_fd(struct gsn_t *gsn);
jjako08d331d2003-10-13 20:33:30 +0000342extern int gtp_decaps0(struct gsn_t *gsn);
343extern int gtp_decaps1c(struct gsn_t *gsn);
344extern int gtp_decaps1u(struct gsn_t *gsn);
jjako52c24142002-12-16 13:33:51 +0000345extern int gtp_retrans(struct gsn_t *gsn);
346extern int gtp_retranstimeout(struct gsn_t *gsn, struct timeval *timeout);
347
Harald Weltebed35df2011-11-02 13:06:18 +0100348extern int gtp_set_cb_delete_context(struct gsn_t *gsn,
349 int (*cb_delete_context) (struct pdp_t *
350 pdp));
jjako08d331d2003-10-13 20:33:30 +0000351/*extern int gtp_set_cb_create_context(struct gsn_t *gsn,
352 int (*cb_create_context) (struct pdp_t* pdp)); */
353
354extern int gtp_set_cb_unsup_ind(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100355 int (*cb) (struct sockaddr_in * peer));
jjako08d331d2003-10-13 20:33:30 +0000356
jjako2c381332003-10-21 19:09:53 +0000357extern int gtp_set_cb_extheader_ind(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100358 int (*cb) (struct sockaddr_in * peer));
jjako08d331d2003-10-13 20:33:30 +0000359
jjako52c24142002-12-16 13:33:51 +0000360extern int gtp_set_cb_conf(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100361 int (*cb) (int type, int cause, struct pdp_t * pdp,
362 void *cbp));
jjako52c24142002-12-16 13:33:51 +0000363
Harald Welte629e9862010-12-24 20:58:09 +0100364int gtp_set_cb_recovery(struct gsn_t *gsn,
Harald Weltebed35df2011-11-02 13:06:18 +0100365 int (*cb) (struct sockaddr_in * peer,
Pau Espin Pedrolb5f93342018-07-23 11:24:07 +0200366 uint8_t recovery))
367 OSMO_DEPRECATED("Use gtp_set_cb_recovery2() instead, to obtain pdp ctx originating the recovery");
368int gtp_set_cb_recovery2(struct gsn_t *gsn,
369 int (*cb) (struct sockaddr_in * peer,
370 struct pdp_t * pdp,
Harald Weltebed35df2011-11-02 13:06:18 +0100371 uint8_t recovery));
jjako52c24142002-12-16 13:33:51 +0000372
Alexander Couzense1412d92018-09-16 05:10:03 +0200373void gtp_clear_queues(struct gsn_t *gsn);
374
jjako52c24142002-12-16 13:33:51 +0000375/* Internal functions (not part of the API */
376
jjako08d331d2003-10-13 20:33:30 +0000377extern int gtp_echo_req(struct gsn_t *gsn, int version, void *cbp,
378 struct in_addr *inetaddrs);
Harald Weltebed35df2011-11-02 13:06:18 +0100379extern int gtp_echo_resp(struct gsn_t *gsn, int version,
jjako08d331d2003-10-13 20:33:30 +0000380 struct sockaddr_in *peer, int fd,
jjako52c24142002-12-16 13:33:51 +0000381 void *pack, unsigned len);
Harald Weltebed35df2011-11-02 13:06:18 +0100382extern int gtp_echo_ind(struct gsn_t *gsn, int version,
383 struct sockaddr_in *peer, int fd,
jjako52c24142002-12-16 13:33:51 +0000384 void *pack, unsigned len);
Harald Weltebed35df2011-11-02 13:06:18 +0100385extern int gtp_echo_conf(struct gsn_t *gsn, int version,
386 struct sockaddr_in *peer, void *pack, unsigned len);
jjako52c24142002-12-16 13:33:51 +0000387
Harald Weltebed35df2011-11-02 13:06:18 +0100388extern int gtp_unsup_req(struct gsn_t *gsn, int version,
jjako08d331d2003-10-13 20:33:30 +0000389 struct sockaddr_in *peer,
390 int fd, void *pack, unsigned len);
391extern int gtp_unsup_ind(struct gsn_t *gsn, struct sockaddr_in *peer,
392 void *pack, unsigned len);
jjako52c24142002-12-16 13:33:51 +0000393
Harald Weltebed35df2011-11-02 13:06:18 +0100394extern int gtp_create_pdp_resp(struct gsn_t *gsn, int version,
jjako52c24142002-12-16 13:33:51 +0000395 struct pdp_t *pdp, uint8_t cause);
396
397extern int gtp_create_pdp_ind(struct gsn_t *gsn, int version,
jjako08d331d2003-10-13 20:33:30 +0000398 struct sockaddr_in *peer, int fd,
jjako52c24142002-12-16 13:33:51 +0000399 void *pack, unsigned len);
400
401extern int gtp_create_pdp_conf(struct gsn_t *gsn, int version,
402 struct sockaddr_in *peer,
403 void *pack, unsigned len);
404
jjako08d331d2003-10-13 20:33:30 +0000405extern int gtp_update_pdp_req(struct gsn_t *gsn, int version, void *cbp,
Harald Weltebed35df2011-11-02 13:06:18 +0100406 struct in_addr *inetaddr, struct pdp_t *pdp);
jjako52c24142002-12-16 13:33:51 +0000407
jjako08d331d2003-10-13 20:33:30 +0000408extern int gtp_delete_pdp_req(struct gsn_t *gsn, int version, void *cbp,
jjako52c24142002-12-16 13:33:51 +0000409 struct pdp_t *pdp);
410
411extern int gtp_delete_pdp_resp(struct gsn_t *gsn, int version,
jjako08d331d2003-10-13 20:33:30 +0000412 struct sockaddr_in *peer, int fd,
Harald Weltebed35df2011-11-02 13:06:18 +0100413 void *pack, unsigned len,
jjako2c381332003-10-21 19:09:53 +0000414 struct pdp_t *pdp, struct pdp_t *linked_pdp,
415 uint8_t cause, int teardown);
jjako52c24142002-12-16 13:33:51 +0000416
417extern int gtp_delete_pdp_ind(struct gsn_t *gsn, int version,
jjako08d331d2003-10-13 20:33:30 +0000418 struct sockaddr_in *peer, int fd,
jjako52c24142002-12-16 13:33:51 +0000419 void *pack, unsigned len);
420
421extern int gtp_delete_pdp_conf(struct gsn_t *gsn, int version,
422 struct sockaddr_in *peer,
423 void *pack, unsigned len);
424
jjako52c24142002-12-16 13:33:51 +0000425extern int ipv42eua(struct ul66_t *eua, struct in_addr *src);
426extern int eua2ipv4(struct in_addr *dst, struct ul66_t *eua);
427extern int gsna2in_addr(struct in_addr *dst, struct ul16_t *gsna);
428extern int in_addr2gsna(struct ul16_t *gsna, struct in_addr *src);
Harald Welteb10ee082017-08-12 19:29:16 +0200429extern const char *imsi_gtp2str(const uint64_t *imsi);
jjako52c24142002-12-16 13:33:51 +0000430
Harald Weltebed35df2011-11-02 13:06:18 +0100431#endif /* !_GTP_H */