blob: 9c2965bed7a89f65fe239e4df9199bd78603b859 [file] [log] [blame]
Neels Hofmeyr17518fe2017-06-20 04:35:06 +02001/*! \file gsmtap.h
2 * gsmtap header, pseudo-header in front of the actua GSM payload.
3 * GSMTAP is a generic header format for GSM protocol captures,
Harald Welte8c8caaa2010-03-04 15:02:54 +01004 * it uses the IANA-assigned UDP port number 4729 and carries
5 * payload in various formats of GSM interfaces such as Um MAC
6 * blocks or Um bursts.
7 *
8 * Example programs generating GSMTAP data are airprobe
9 * (http://airprobe.org/) or OsmocomBB (http://bb.osmocom.org/)
10 */
Harald Welteec8b4502010-02-20 20:34:29 +010011
Neels Hofmeyr17518fe2017-06-20 04:35:06 +020012#pragma once
13
Harald Welteec8b4502010-02-20 20:34:29 +010014#include <stdint.h>
15
Harald Welteccd040f2011-10-08 14:39:22 +020016/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
17
18/* The GSMTAP format definition is maintained in libosmocore,
19 * specifically the latest version can always be obtained from
20 * http://cgit.osmocom.org/cgit/libosmocore/tree/include/osmocom/core/gsmtap.h
21 *
22 * If you want to introduce new protocol/burst/channel types or extend
23 * GSMTAP in any way, please contact the GSMTAP maintainer at either the
24 * public openbsc@lists.osmocom.org mailing list, or privately at
25 * Harald Welte <laforge@gnumonks.org>.
26 *
27 * Your cooperation ensures that all projects will use the same GSMTAP
28 * definitions and remain compatible with each other.
29 */
30
Harald Welte8c8caaa2010-03-04 15:02:54 +010031#define GSMTAP_VERSION 0x02
Harald Welteec8b4502010-02-20 20:34:29 +010032
33#define GSMTAP_TYPE_UM 0x01
34#define GSMTAP_TYPE_ABIS 0x02
35#define GSMTAP_TYPE_UM_BURST 0x03 /* raw burst bits */
Kévin Redon0bc3b832018-07-26 11:30:59 +020036#define GSMTAP_TYPE_SIM 0x04 /* ISO 7816 smart card interface */
Harald Weltec035ec62011-01-19 09:40:59 +010037#define GSMTAP_TYPE_TETRA_I1 0x05 /* tetra air interface */
38#define GSMTAP_TYPE_TETRA_I1_BURST 0x06 /* tetra air interface */
Harald Weltefae779a2011-10-08 14:35:51 +020039#define GSMTAP_TYPE_WMX_BURST 0x07 /* WiMAX burst */
40#define GSMTAP_TYPE_GB_LLC 0x08 /* GPRS Gb interface: LLC */
41#define GSMTAP_TYPE_GB_SNDCP 0x09 /* GPRS Gb interface: SNDCP */
Sylvain Munautf84571d2011-10-09 16:57:33 +020042#define GSMTAP_TYPE_GMR1_UM 0x0a /* GMR-1 L2 packets */
Harald Weltea102b632012-09-02 14:07:57 +020043#define GSMTAP_TYPE_UMTS_RLC_MAC 0x0b
44#define GSMTAP_TYPE_UMTS_RRC 0x0c
Maxb0a3c2f2014-06-10 19:04:59 +020045#define GSMTAP_TYPE_LTE_RRC 0x0d /* LTE interface */
altaff6a0ceb2015-01-12 12:51:44 +010046#define GSMTAP_TYPE_LTE_MAC 0x0e /* LTE MAC interface */
Harald Welte2d2e2cc2016-04-25 12:11:20 +020047#define GSMTAP_TYPE_LTE_MAC_FRAMED 0x0f /* LTE MAC with context hdr */
Harald Weltea65e9932016-12-02 13:54:36 +010048#define GSMTAP_TYPE_OSMOCORE_LOG 0x10 /* libosmocore logging */
Harald Welteebcf02d2017-01-07 13:27:54 +010049#define GSMTAP_TYPE_QC_DIAG 0x11 /* Qualcomm DIAG frame */
Harald Weltef9b1e552017-11-23 22:30:36 +010050#define GSMTAP_TYPE_LTE_NAS 0x12 /* LTE Non-Access Stratum */
Harald Welteec8b4502010-02-20 20:34:29 +010051
Harald Welteccd040f2011-10-08 14:39:22 +020052/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
53
Harald Weltedba84782011-01-18 21:38:12 +010054/* sub-types for TYPE_UM_BURST */
Harald Welteec8b4502010-02-20 20:34:29 +010055#define GSMTAP_BURST_UNKNOWN 0x00
56#define GSMTAP_BURST_FCCH 0x01
57#define GSMTAP_BURST_PARTIAL_SCH 0x02
58#define GSMTAP_BURST_SCH 0x03
59#define GSMTAP_BURST_CTS_SCH 0x04
60#define GSMTAP_BURST_COMPACT_SCH 0x05
61#define GSMTAP_BURST_NORMAL 0x06
62#define GSMTAP_BURST_DUMMY 0x07
63#define GSMTAP_BURST_ACCESS 0x08
64#define GSMTAP_BURST_NONE 0x09
Harald Weltefae779a2011-10-08 14:35:51 +020065/* WiMAX bursts */
66#define GSMTAP_BURST_CDMA_CODE 0x10 /* WiMAX CDMA Code Attribute burst */
67#define GSMTAP_BURST_FCH 0x11 /* WiMAX FCH burst */
68#define GSMTAP_BURST_FFB 0x12 /* WiMAX Fast Feedback burst */
69#define GSMTAP_BURST_PDU 0x13 /* WiMAX PDU burst */
70#define GSMTAP_BURST_HACK 0x14 /* WiMAX HARQ ACK burst */
71#define GSMTAP_BURST_PHY_ATTRIBUTES 0x15 /* WiMAX PHY Attributes burst */
Harald Welteec8b4502010-02-20 20:34:29 +010072
Harald Welteccd040f2011-10-08 14:39:22 +020073/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
74
Harald Weltedba84782011-01-18 21:38:12 +010075/* sub-types for TYPE_UM */
Harald Welte8c8caaa2010-03-04 15:02:54 +010076#define GSMTAP_CHANNEL_UNKNOWN 0x00
77#define GSMTAP_CHANNEL_BCCH 0x01
78#define GSMTAP_CHANNEL_CCCH 0x02
79#define GSMTAP_CHANNEL_RACH 0x03
80#define GSMTAP_CHANNEL_AGCH 0x04
81#define GSMTAP_CHANNEL_PCH 0x05
82#define GSMTAP_CHANNEL_SDCCH 0x06
83#define GSMTAP_CHANNEL_SDCCH4 0x07
84#define GSMTAP_CHANNEL_SDCCH8 0x08
85#define GSMTAP_CHANNEL_TCH_F 0x09
86#define GSMTAP_CHANNEL_TCH_H 0x0a
Harald Welte7d974ad2012-01-26 13:10:36 +010087#define GSMTAP_CHANNEL_PACCH 0x0b
Harald Welteaa244bf2011-09-26 00:24:59 +020088#define GSMTAP_CHANNEL_CBCH52 0x0c
Harald Welte977231c2017-07-29 13:35:37 +020089#define GSMTAP_CHANNEL_PDTCH 0x0d
90/* for legacy reasons we use a mis-spelled name. PDCH is really the physical channel, but we use it as PDTCH */
91#define GSMTAP_CHANNEL_PDCH GSMTAP_CHANNEL_PDTCH
Harald Welteaa244bf2011-09-26 00:24:59 +020092#define GSMTAP_CHANNEL_PTCCH 0x0e
Harald Welte7d974ad2012-01-26 13:10:36 +010093#define GSMTAP_CHANNEL_CBCH51 0x0f
Harald Welte3e04ed62012-02-08 18:13:34 +010094
95/* GPRS Coding Scheme CS1..4 */
96#define GSMTAP_GPRS_CS_BASE 0x20
97#define GSMTAP_GPRS_CS(N) (GSMTAP_GPRS_CS_BASE + N)
98/* (E) GPRS Coding Scheme MCS0..9 */
99#define GSMTAP_GPRS_MCS_BASE 0x30
100#define GSMTAP_GPRS_MCS(N) (GSMTAP_GPRS_MCS_BASE + N)
101
Harald Welte8c8caaa2010-03-04 15:02:54 +0100102#define GSMTAP_CHANNEL_ACCH 0x80
103
Harald Welteccd040f2011-10-08 14:39:22 +0200104/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
105
Kévin Redon0bc3b832018-07-26 11:30:59 +0200106/* sub-types for GSMTAP_TYPE_SIM */
107#define GSMTAP_SIM_APDU 0x00 /* APDU data (complete APDU) */
108#define GSMTAP_SIM_ATR 0x01 /* card ATR data */
109#define GSMTAP_SIM_PPS_REQ 0x02 /* PPS request data */
110#define GSMTAP_SIM_PPS_RSP 0x03 /* PPS response data */
111#define GSMTAP_SIM_TPDU_HDR 0x04 /* TPDU command header */
112#define GSMTAP_SIM_TPDU_CMD 0x05 /* TPDU command body */
113#define GSMTAP_SIM_TPDU_RSP 0x06 /* TPDU response body */
114#define GSMTAP_SIM_TPDU_SW 0x07 /* TPDU response trailer */
115
116/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
117
Harald Weltec035ec62011-01-19 09:40:59 +0100118/* sub-types for TYPE_TETRA_AIR */
119#define GSMTAP_TETRA_BSCH 0x01
120#define GSMTAP_TETRA_AACH 0x02
Holger Hans Peter Freythere7509082011-01-28 10:13:41 +0100121#define GSMTAP_TETRA_SCH_HU 0x03
122#define GSMTAP_TETRA_SCH_HD 0x04
123#define GSMTAP_TETRA_SCH_F 0x05
124#define GSMTAP_TETRA_BNCH 0x06
125#define GSMTAP_TETRA_STCH 0x07
126#define GSMTAP_TETRA_TCH_F 0x08
allesklar2eb182822018-02-11 21:40:43 +0000127#define GSMTAP_TETRA_DMO_SCH_S 0x09
128#define GSMTAP_TETRA_DMO_SCH_H 0x0a
129#define GSMTAP_TETRA_DMO_SCH_F 0x0b
130#define GSMTAP_TETRA_DMO_STCH 0x0c
131#define GSMTAP_TETRA_DMO_TCH 0x0d
Harald Weltec035ec62011-01-19 09:40:59 +0100132
Harald Welteccd040f2011-10-08 14:39:22 +0200133/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
134
Sylvain Munautf84571d2011-10-09 16:57:33 +0200135/* sub-types for TYPE_GMR1_UM */
136#define GSMTAP_GMR1_UNKNOWN 0x00
137#define GSMTAP_GMR1_BCCH 0x01
138#define GSMTAP_GMR1_CCCH 0x02 /* either AGCH or PCH */
139#define GSMTAP_GMR1_PCH 0x03
140#define GSMTAP_GMR1_AGCH 0x04
141#define GSMTAP_GMR1_BACH 0x05
142#define GSMTAP_GMR1_RACH 0x06
143#define GSMTAP_GMR1_CBCH 0x07
144#define GSMTAP_GMR1_SDCCH 0x08
145#define GSMTAP_GMR1_TACCH 0x09
146#define GSMTAP_GMR1_GBCH 0x0a
147
148#define GSMTAP_GMR1_SACCH 0x01 /* to be combined with _TCH{6,9} */
149#define GSMTAP_GMR1_FACCH 0x02 /* to be combines with _TCH{3,6,9} */
150#define GSMTAP_GMR1_DKAB 0x03 /* to be combined with _TCH3 */
151#define GSMTAP_GMR1_TCH3 0x10
152#define GSMTAP_GMR1_TCH6 0x14
153#define GSMTAP_GMR1_TCH9 0x18
154
155/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
156
Harald Weltea102b632012-09-02 14:07:57 +0200157#define GSMTAP_UMTS_CH_PCCH 0x01
158#define GSMTAP_UMTS_CH_CCCH 0x02
159#define GSMTAP_UMTS_CH_DCCH 0x03
160
Maxb0a3c2f2014-06-10 19:04:59 +0200161/* sub-types for TYPE_LTE_RRC */
162#define GSMTAP_LTE_CH_BCCH 0x01
163#define GSMTAP_LTE_CH_CCCH 0x02
164#define GSMTAP_LTE_CH_DCCH 0x03
165#define GSMTAP_LTE_CH_MCCH 0x04
166#define GSMTAP_LTE_CH_PCCH 0x05
167#define GSMTAP_LTE_CH_DTCH 0x06
168#define GSMTAP_LTE_CH_MTCH 0x07
169
Harald Weltedba84782011-01-18 21:38:12 +0100170/* flags for the ARFCN */
Harald Welte4e128792010-03-04 15:15:37 +0100171#define GSMTAP_ARFCN_F_PCS 0x8000
172#define GSMTAP_ARFCN_F_UPLINK 0x4000
173#define GSMTAP_ARFCN_MASK 0x3fff
174
Harald Weltedba84782011-01-18 21:38:12 +0100175/* IANA-assigned well-known UDP port for GSMTAP messages */
Harald Welte8c8caaa2010-03-04 15:02:54 +0100176#define GSMTAP_UDP_PORT 4729
Harald Welteec8b4502010-02-20 20:34:29 +0100177
Tobias Engel24e5e052013-02-20 22:00:06 +0100178/* UMTS RRC message types */
179enum {
180 GSMTAP_RRC_SUB_DL_DCCH_Message = 0,
181 GSMTAP_RRC_SUB_UL_DCCH_Message,
182 GSMTAP_RRC_SUB_DL_CCCH_Message,
183 GSMTAP_RRC_SUB_UL_CCCH_Message,
184 GSMTAP_RRC_SUB_PCCH_Message,
185 GSMTAP_RRC_SUB_DL_SHCCH_Message,
186 GSMTAP_RRC_SUB_UL_SHCCH_Message,
187 GSMTAP_RRC_SUB_BCCH_FACH_Message,
188 GSMTAP_RRC_SUB_BCCH_BCH_Message,
189 GSMTAP_RRC_SUB_MCCH_Message,
190 GSMTAP_RRC_SUB_MSCH_Message,
191 GSMTAP_RRC_SUB_HandoverToUTRANCommand,
192 GSMTAP_RRC_SUB_InterRATHandoverInfo,
193 GSMTAP_RRC_SUB_SystemInformation_BCH,
194 GSMTAP_RRC_SUB_System_Information_Container,
195 GSMTAP_RRC_SUB_UE_RadioAccessCapabilityInfo,
196 GSMTAP_RRC_SUB_MasterInformationBlock,
197 GSMTAP_RRC_SUB_SysInfoType1,
198 GSMTAP_RRC_SUB_SysInfoType2,
199 GSMTAP_RRC_SUB_SysInfoType3,
200 GSMTAP_RRC_SUB_SysInfoType4,
201 GSMTAP_RRC_SUB_SysInfoType5,
202 GSMTAP_RRC_SUB_SysInfoType5bis,
203 GSMTAP_RRC_SUB_SysInfoType6,
204 GSMTAP_RRC_SUB_SysInfoType7,
205 GSMTAP_RRC_SUB_SysInfoType8,
206 GSMTAP_RRC_SUB_SysInfoType9,
207 GSMTAP_RRC_SUB_SysInfoType10,
208 GSMTAP_RRC_SUB_SysInfoType11,
209 GSMTAP_RRC_SUB_SysInfoType11bis,
210 GSMTAP_RRC_SUB_SysInfoType12,
211 GSMTAP_RRC_SUB_SysInfoType13,
212 GSMTAP_RRC_SUB_SysInfoType13_1,
213 GSMTAP_RRC_SUB_SysInfoType13_2,
214 GSMTAP_RRC_SUB_SysInfoType13_3,
215 GSMTAP_RRC_SUB_SysInfoType13_4,
216 GSMTAP_RRC_SUB_SysInfoType14,
217 GSMTAP_RRC_SUB_SysInfoType15,
218 GSMTAP_RRC_SUB_SysInfoType15bis,
219 GSMTAP_RRC_SUB_SysInfoType15_1,
220 GSMTAP_RRC_SUB_SysInfoType15_1bis,
221 GSMTAP_RRC_SUB_SysInfoType15_2,
222 GSMTAP_RRC_SUB_SysInfoType15_2bis,
223 GSMTAP_RRC_SUB_SysInfoType15_2ter,
224 GSMTAP_RRC_SUB_SysInfoType15_3,
225 GSMTAP_RRC_SUB_SysInfoType15_3bis,
226 GSMTAP_RRC_SUB_SysInfoType15_4,
227 GSMTAP_RRC_SUB_SysInfoType15_5,
228 GSMTAP_RRC_SUB_SysInfoType15_6,
229 GSMTAP_RRC_SUB_SysInfoType15_7,
230 GSMTAP_RRC_SUB_SysInfoType15_8,
231 GSMTAP_RRC_SUB_SysInfoType16,
232 GSMTAP_RRC_SUB_SysInfoType17,
233 GSMTAP_RRC_SUB_SysInfoType18,
234 GSMTAP_RRC_SUB_SysInfoType19,
235 GSMTAP_RRC_SUB_SysInfoType20,
236 GSMTAP_RRC_SUB_SysInfoType21,
237 GSMTAP_RRC_SUB_SysInfoType22,
238 GSMTAP_RRC_SUB_SysInfoTypeSB1,
239 GSMTAP_RRC_SUB_SysInfoTypeSB2,
240 GSMTAP_RRC_SUB_ToTargetRNC_Container,
241 GSMTAP_RRC_SUB_TargetRNC_ToSourceRNC_Container,
242
243 GSMTAP_RRC_SUB_MAX
244};
245
altaff6a0ceb2015-01-12 12:51:44 +0100246/* LTE RRC message types */
247enum {
Shinjo Parkd741b782018-10-07 20:20:32 +0200248 GSMTAP_LTE_RRC_SUB_DL_CCCH_Message = 0,
249 GSMTAP_LTE_RRC_SUB_DL_DCCH_Message,
250 GSMTAP_LTE_RRC_SUB_UL_CCCH_Message,
251 GSMTAP_LTE_RRC_SUB_UL_DCCH_Message,
252 GSMTAP_LTE_RRC_SUB_BCCH_BCH_Message,
253 GSMTAP_LTE_RRC_SUB_BCCH_DL_SCH_Message,
254 GSMTAP_LTE_RRC_SUB_PCCH_Message,
255 GSMTAP_LTE_RRC_SUB_MCCH_Message,
256 GSMTAP_LTE_RRC_SUB_BCCH_BCH_Message_MBMS,
257 GSMTAP_LTE_RRC_SUB_BCCH_DL_SCH_Message_BR,
258 GSMTAP_LTE_RRC_SUB_BCCH_DL_SCH_Message_MBMS,
259 GSMTAP_LTE_RRC_SUB_SC_MCCH_Message,
260 GSMTAP_LTE_RRC_SUB_SBCCH_SL_BCH_Message,
261 GSMTAP_LTE_RRC_SUB_SBCCH_SL_BCH_Message_V2X,
262 GSMTAP_LTE_RRC_SUB_DL_CCCH_Message_NB,
263 GSMTAP_LTE_RRC_SUB_DL_DCCH_Message_NB,
264 GSMTAP_LTE_RRC_SUB_UL_CCCH_Message_NB,
265 GSMTAP_LTE_RRC_SUB_UL_DCCH_Message_NB,
266 GSMTAP_LTE_RRC_SUB_BCCH_BCH_Message_NB,
267 GSMTAP_LTE_RRC_SUB_BCCH_BCH_Message_TDD_NB,
268 GSMTAP_LTE_RRC_SUB_BCCH_DL_SCH_Message_NB,
269 GSMTAP_LTE_RRC_SUB_PCCH_Message_NB,
270 GSMTAP_LTE_RRC_SUB_SC_MCCH_Message_NB,
altaff6a0ceb2015-01-12 12:51:44 +0100271
Shinjo Parkd741b782018-10-07 20:20:32 +0200272 GSMTAP_LTE_RRC_SUB_MAX
altaff6a0ceb2015-01-12 12:51:44 +0100273};
274
Shinjo Parkf589cbb2018-10-07 20:23:32 +0200275/* LTE NAS message types */
276enum {
277 GSMTAP_LTE_NAS_PLAIN = 0,
278 GSMTAP_LTE_NAS_SEC_HEADER,
279
280 GSMTAP_LTE_NAS_SUB_MAX
281};
282
Harald Welteccd040f2011-10-08 14:39:22 +0200283/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200284/*! Structure of the GTMTAP pseudo-header */
Harald Welteec8b4502010-02-20 20:34:29 +0100285struct gsmtap_hdr {
Harald Welte2d2e2cc2016-04-25 12:11:20 +0200286 uint8_t version; /*!< version, set to 0x01 currently */
287 uint8_t hdr_len; /*!< length in number of 32bit words */
288 uint8_t type; /*!< see GSMTAP_TYPE_* */
289 uint8_t timeslot; /*!< timeslot (0..7 on Um) */
Harald Welteec8b4502010-02-20 20:34:29 +0100290
Harald Welte2d2e2cc2016-04-25 12:11:20 +0200291 uint16_t arfcn; /*!< ARFCN (frequency) */
292 int8_t signal_dbm; /*!< signal level in dBm */
293 int8_t snr_db; /*!< signal/noise ratio in dB */
Harald Welteec8b4502010-02-20 20:34:29 +0100294
Harald Welte2d2e2cc2016-04-25 12:11:20 +0200295 uint32_t frame_number; /*!< GSM Frame Number (FN) */
Harald Welteec8b4502010-02-20 20:34:29 +0100296
Harald Welte2d2e2cc2016-04-25 12:11:20 +0200297 uint8_t sub_type; /*!< Type of burst/channel, see above */
298 uint8_t antenna_nr; /*!< Antenna Number */
299 uint8_t sub_slot; /*!< sub-slot within timeslot */
300 uint8_t res; /*!< reserved for future use (RFU) */
Harald Welteec8b4502010-02-20 20:34:29 +0100301
302} __attribute__((packed));
Harald Weltea65e9932016-12-02 13:54:36 +0100303
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200304/*! Structure of the GTMTAP libosmocore logging header */
Harald Weltea65e9932016-12-02 13:54:36 +0100305struct gsmtap_osmocore_log_hdr {
306 struct {
307 uint32_t sec;
308 uint32_t usec;
309 } ts;
310 char proc_name[16]; /*!< name of process */
311 uint32_t pid; /*!< process ID */
312 uint8_t level; /*!< logging level */
313 uint8_t _pad[3];
314 /* TODO: color */
315 char subsys[16]; /*!< logging sub-system */
316 struct {
317 char name[32]; /*!< source file name */
318 uint32_t line_nr;/*!< line number */
319 } src_file;
320} __attribute__((packed));