blob: 62750ddc50b9276a014e81f02a51b7816732946a [file] [log] [blame]
Harald Welteec8b4502010-02-20 20:34:29 +01001#ifndef _GSMTAP_H
2#define _GSMTAP_H
3
Harald Welte8c8caaa2010-03-04 15:02:54 +01004/* gsmtap header, pseudo-header in front of the actua GSM payload */
5
6/* GSMTAP is a generic header format for GSM protocol captures,
7 * it uses the IANA-assigned UDP port number 4729 and carries
8 * payload in various formats of GSM interfaces such as Um MAC
9 * blocks or Um bursts.
10 *
11 * Example programs generating GSMTAP data are airprobe
12 * (http://airprobe.org/) or OsmocomBB (http://bb.osmocom.org/)
13 */
Harald Welteec8b4502010-02-20 20:34:29 +010014
15#include <stdint.h>
16
Harald Welteccd040f2011-10-08 14:39:22 +020017/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
18
19/* The GSMTAP format definition is maintained in libosmocore,
20 * specifically the latest version can always be obtained from
21 * http://cgit.osmocom.org/cgit/libosmocore/tree/include/osmocom/core/gsmtap.h
22 *
23 * If you want to introduce new protocol/burst/channel types or extend
24 * GSMTAP in any way, please contact the GSMTAP maintainer at either the
25 * public openbsc@lists.osmocom.org mailing list, or privately at
26 * Harald Welte <laforge@gnumonks.org>.
27 *
28 * Your cooperation ensures that all projects will use the same GSMTAP
29 * definitions and remain compatible with each other.
30 */
31
Harald Welte8c8caaa2010-03-04 15:02:54 +010032#define GSMTAP_VERSION 0x02
Harald Welteec8b4502010-02-20 20:34:29 +010033
34#define GSMTAP_TYPE_UM 0x01
35#define GSMTAP_TYPE_ABIS 0x02
36#define GSMTAP_TYPE_UM_BURST 0x03 /* raw burst bits */
Harald Weltefe851ff2010-11-18 23:54:20 +010037#define GSMTAP_TYPE_SIM 0x04
Harald Weltec035ec62011-01-19 09:40:59 +010038#define GSMTAP_TYPE_TETRA_I1 0x05 /* tetra air interface */
39#define GSMTAP_TYPE_TETRA_I1_BURST 0x06 /* tetra air interface */
Harald Weltefae779a2011-10-08 14:35:51 +020040#define GSMTAP_TYPE_WMX_BURST 0x07 /* WiMAX burst */
41#define GSMTAP_TYPE_GB_LLC 0x08 /* GPRS Gb interface: LLC */
42#define GSMTAP_TYPE_GB_SNDCP 0x09 /* GPRS Gb interface: SNDCP */
Harald Welteec8b4502010-02-20 20:34:29 +010043
Harald Welteccd040f2011-10-08 14:39:22 +020044/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
45
Harald Weltedba84782011-01-18 21:38:12 +010046/* sub-types for TYPE_UM_BURST */
Harald Welteec8b4502010-02-20 20:34:29 +010047#define GSMTAP_BURST_UNKNOWN 0x00
48#define GSMTAP_BURST_FCCH 0x01
49#define GSMTAP_BURST_PARTIAL_SCH 0x02
50#define GSMTAP_BURST_SCH 0x03
51#define GSMTAP_BURST_CTS_SCH 0x04
52#define GSMTAP_BURST_COMPACT_SCH 0x05
53#define GSMTAP_BURST_NORMAL 0x06
54#define GSMTAP_BURST_DUMMY 0x07
55#define GSMTAP_BURST_ACCESS 0x08
56#define GSMTAP_BURST_NONE 0x09
Harald Weltefae779a2011-10-08 14:35:51 +020057/* WiMAX bursts */
58#define GSMTAP_BURST_CDMA_CODE 0x10 /* WiMAX CDMA Code Attribute burst */
59#define GSMTAP_BURST_FCH 0x11 /* WiMAX FCH burst */
60#define GSMTAP_BURST_FFB 0x12 /* WiMAX Fast Feedback burst */
61#define GSMTAP_BURST_PDU 0x13 /* WiMAX PDU burst */
62#define GSMTAP_BURST_HACK 0x14 /* WiMAX HARQ ACK burst */
63#define GSMTAP_BURST_PHY_ATTRIBUTES 0x15 /* WiMAX PHY Attributes burst */
Harald Welteec8b4502010-02-20 20:34:29 +010064
Harald Welteccd040f2011-10-08 14:39:22 +020065/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
66
Harald Weltedba84782011-01-18 21:38:12 +010067/* sub-types for TYPE_UM */
Harald Welte8c8caaa2010-03-04 15:02:54 +010068#define GSMTAP_CHANNEL_UNKNOWN 0x00
69#define GSMTAP_CHANNEL_BCCH 0x01
70#define GSMTAP_CHANNEL_CCCH 0x02
71#define GSMTAP_CHANNEL_RACH 0x03
72#define GSMTAP_CHANNEL_AGCH 0x04
73#define GSMTAP_CHANNEL_PCH 0x05
74#define GSMTAP_CHANNEL_SDCCH 0x06
75#define GSMTAP_CHANNEL_SDCCH4 0x07
76#define GSMTAP_CHANNEL_SDCCH8 0x08
77#define GSMTAP_CHANNEL_TCH_F 0x09
78#define GSMTAP_CHANNEL_TCH_H 0x0a
Harald Welteaa244bf2011-09-26 00:24:59 +020079#define GSMTAP_CHANNEL_CBCH51 0x0b
80#define GSMTAP_CHANNEL_CBCH52 0x0c
81#define GSMTAP_CHANNEL_PDCH 0x0d
82#define GSMTAP_CHANNEL_PTCCH 0x0e
Harald Weltefae779a2011-10-08 14:35:51 +020083#define GSMTAP_CHANNEL_PACCH 0x0f
Harald Welte8c8caaa2010-03-04 15:02:54 +010084#define GSMTAP_CHANNEL_ACCH 0x80
85
Harald Welteccd040f2011-10-08 14:39:22 +020086/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
87
Harald Weltec035ec62011-01-19 09:40:59 +010088/* sub-types for TYPE_TETRA_AIR */
89#define GSMTAP_TETRA_BSCH 0x01
90#define GSMTAP_TETRA_AACH 0x02
Holger Hans Peter Freythere7509082011-01-28 10:13:41 +010091#define GSMTAP_TETRA_SCH_HU 0x03
92#define GSMTAP_TETRA_SCH_HD 0x04
93#define GSMTAP_TETRA_SCH_F 0x05
94#define GSMTAP_TETRA_BNCH 0x06
95#define GSMTAP_TETRA_STCH 0x07
96#define GSMTAP_TETRA_TCH_F 0x08
Harald Weltec035ec62011-01-19 09:40:59 +010097
Harald Welteccd040f2011-10-08 14:39:22 +020098/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
99
Harald Weltedba84782011-01-18 21:38:12 +0100100/* flags for the ARFCN */
Harald Welte4e128792010-03-04 15:15:37 +0100101#define GSMTAP_ARFCN_F_PCS 0x8000
102#define GSMTAP_ARFCN_F_UPLINK 0x4000
103#define GSMTAP_ARFCN_MASK 0x3fff
104
Harald Weltedba84782011-01-18 21:38:12 +0100105/* IANA-assigned well-known UDP port for GSMTAP messages */
Harald Welte8c8caaa2010-03-04 15:02:54 +0100106#define GSMTAP_UDP_PORT 4729
Harald Welteec8b4502010-02-20 20:34:29 +0100107
Harald Welteccd040f2011-10-08 14:39:22 +0200108/* ====== DO NOT MAKE UNAPPROVED MODIFICATIONS HERE ===== */
Harald Welteec8b4502010-02-20 20:34:29 +0100109struct gsmtap_hdr {
Harald Welte8c8caaa2010-03-04 15:02:54 +0100110 uint8_t version; /* version, set to 0x01 currently */
111 uint8_t hdr_len; /* length in number of 32bit words */
112 uint8_t type; /* see GSMTAP_TYPE_* */
113 uint8_t timeslot; /* timeslot (0..7 on Um) */
Harald Welteec8b4502010-02-20 20:34:29 +0100114
Harald Welte8c8caaa2010-03-04 15:02:54 +0100115 uint16_t arfcn; /* ARFCN (frequency) */
116 int8_t signal_dbm; /* signal level in dBm */
117 int8_t snr_db; /* signal/noise ratio in dB */
Harald Welteec8b4502010-02-20 20:34:29 +0100118
Harald Welte8c8caaa2010-03-04 15:02:54 +0100119 uint32_t frame_number; /* GSM Frame Number (FN) */
Harald Welteec8b4502010-02-20 20:34:29 +0100120
Harald Welte8c8caaa2010-03-04 15:02:54 +0100121 uint8_t sub_type; /* Type of burst/channel, see above */
122 uint8_t antenna_nr; /* Antenna Number */
123 uint8_t sub_slot; /* sub-slot within timeslot */
124 uint8_t res; /* reserved for future use (RFU) */
Harald Welteec8b4502010-02-20 20:34:29 +0100125
126} __attribute__((packed));
127
Harald Welteec8b4502010-02-20 20:34:29 +0100128#endif /* _GSMTAP_H */