blob: 3f911e6d6d5828c43d4ce0ccd6aa277b9a9d5788 [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 Welte8c8caaa2010-03-04 15:02:54 +010017#define GSMTAP_VERSION 0x02
Harald Welteec8b4502010-02-20 20:34:29 +010018
19#define GSMTAP_TYPE_UM 0x01
20#define GSMTAP_TYPE_ABIS 0x02
21#define GSMTAP_TYPE_UM_BURST 0x03 /* raw burst bits */
Harald Weltefe851ff2010-11-18 23:54:20 +010022#define GSMTAP_TYPE_SIM 0x04
Harald Weltec035ec62011-01-19 09:40:59 +010023#define GSMTAP_TYPE_TETRA_I1 0x05 /* tetra air interface */
24#define GSMTAP_TYPE_TETRA_I1_BURST 0x06 /* tetra air interface */
Harald Welteec8b4502010-02-20 20:34:29 +010025
Harald Weltedba84782011-01-18 21:38:12 +010026/* sub-types for TYPE_UM_BURST */
Harald Welteec8b4502010-02-20 20:34:29 +010027#define GSMTAP_BURST_UNKNOWN 0x00
28#define GSMTAP_BURST_FCCH 0x01
29#define GSMTAP_BURST_PARTIAL_SCH 0x02
30#define GSMTAP_BURST_SCH 0x03
31#define GSMTAP_BURST_CTS_SCH 0x04
32#define GSMTAP_BURST_COMPACT_SCH 0x05
33#define GSMTAP_BURST_NORMAL 0x06
34#define GSMTAP_BURST_DUMMY 0x07
35#define GSMTAP_BURST_ACCESS 0x08
36#define GSMTAP_BURST_NONE 0x09
37
Harald Weltedba84782011-01-18 21:38:12 +010038/* sub-types for TYPE_UM */
Harald Welte8c8caaa2010-03-04 15:02:54 +010039#define GSMTAP_CHANNEL_UNKNOWN 0x00
40#define GSMTAP_CHANNEL_BCCH 0x01
41#define GSMTAP_CHANNEL_CCCH 0x02
42#define GSMTAP_CHANNEL_RACH 0x03
43#define GSMTAP_CHANNEL_AGCH 0x04
44#define GSMTAP_CHANNEL_PCH 0x05
45#define GSMTAP_CHANNEL_SDCCH 0x06
46#define GSMTAP_CHANNEL_SDCCH4 0x07
47#define GSMTAP_CHANNEL_SDCCH8 0x08
48#define GSMTAP_CHANNEL_TCH_F 0x09
49#define GSMTAP_CHANNEL_TCH_H 0x0a
50#define GSMTAP_CHANNEL_ACCH 0x80
51
Harald Weltec035ec62011-01-19 09:40:59 +010052/* sub-types for TYPE_TETRA_AIR */
53#define GSMTAP_TETRA_BSCH 0x01
54#define GSMTAP_TETRA_AACH 0x02
55#define GSMTAP_TETRA_AACH 0x03
56#define GSMTAP_TETRA_SCH_HU 0x04
57#define GSMTAP_TETRA_SCH_HD 0x05
58#define GSMTAP_TETRA_SCH_F 0x06
59#define GSMTAP_TETRA_BNCH 0x07
60#define GSMTAP_TETRA_STCH 0x08
61#define GSMTAP_TETRA_TCH_F 0x09
62
Harald Weltedba84782011-01-18 21:38:12 +010063/* flags for the ARFCN */
Harald Welte4e128792010-03-04 15:15:37 +010064#define GSMTAP_ARFCN_F_PCS 0x8000
65#define GSMTAP_ARFCN_F_UPLINK 0x4000
66#define GSMTAP_ARFCN_MASK 0x3fff
67
Harald Weltedba84782011-01-18 21:38:12 +010068/* IANA-assigned well-known UDP port for GSMTAP messages */
Harald Welte8c8caaa2010-03-04 15:02:54 +010069#define GSMTAP_UDP_PORT 4729
Harald Welteec8b4502010-02-20 20:34:29 +010070
71struct gsmtap_hdr {
Harald Welte8c8caaa2010-03-04 15:02:54 +010072 uint8_t version; /* version, set to 0x01 currently */
73 uint8_t hdr_len; /* length in number of 32bit words */
74 uint8_t type; /* see GSMTAP_TYPE_* */
75 uint8_t timeslot; /* timeslot (0..7 on Um) */
Harald Welteec8b4502010-02-20 20:34:29 +010076
Harald Welte8c8caaa2010-03-04 15:02:54 +010077 uint16_t arfcn; /* ARFCN (frequency) */
78 int8_t signal_dbm; /* signal level in dBm */
79 int8_t snr_db; /* signal/noise ratio in dB */
Harald Welteec8b4502010-02-20 20:34:29 +010080
Harald Welte8c8caaa2010-03-04 15:02:54 +010081 uint32_t frame_number; /* GSM Frame Number (FN) */
Harald Welteec8b4502010-02-20 20:34:29 +010082
Harald Welte8c8caaa2010-03-04 15:02:54 +010083 uint8_t sub_type; /* Type of burst/channel, see above */
84 uint8_t antenna_nr; /* Antenna Number */
85 uint8_t sub_slot; /* sub-slot within timeslot */
86 uint8_t res; /* reserved for future use (RFU) */
Harald Welteec8b4502010-02-20 20:34:29 +010087
88} __attribute__((packed));
89
Harald Welteec8b4502010-02-20 20:34:29 +010090#endif /* _GSMTAP_H */