blob: 0faab7e0a80e452700fa97df3fe9057c9ae47bed [file] [log] [blame]
Neels Hofmeyr17518fe2017-06-20 04:35:06 +02001/*! \file l1sap.h */
2
Sylvain Munaut12ba7782014-06-16 10:13:40 +02003#pragma once
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +01004
5#include <osmocom/core/prim.h>
6
Neels Hofmeyr87e45502017-06-20 00:17:59 +02007/*! PH-SAP related primitives (L1<->L2 SAP) */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +01008enum osmo_ph_prim {
Neels Hofmeyr87e45502017-06-20 00:17:59 +02009 PRIM_PH_DATA, /*!< PH-DATA */
10 PRIM_PH_RACH, /*!< PH-RANDOM_ACCESS */
11 PRIM_PH_CONN, /*!< PH-CONNECT */
12 PRIM_PH_EMPTY_FRAME, /*!< PH-EMPTY_FRAME */
13 PRIM_PH_RTS, /*!< PH-RTS */
14 PRIM_MPH_INFO, /*!< MPH-INFO */
15 PRIM_TCH, /*!< TCH */
16 PRIM_TCH_RTS, /*!< TCH */
Andreas Eversberg227a9de2013-02-07 12:21:33 +010017};
18
Maxadef12a2016-05-25 15:25:02 +020019extern const struct value_string osmo_ph_prim_names[];
20
Neels Hofmeyr87e45502017-06-20 00:17:59 +020021/*! PH-SAP related primitives (L1<->L2 SAP) */
Andreas Eversberg227a9de2013-02-07 12:21:33 +010022enum osmo_mph_info_type {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020023 PRIM_INFO_TIME, /*!< Current GSM time */
24 PRIM_INFO_MEAS, /*!< Measurement indication */
25 PRIM_INFO_ACTIVATE, /*!< Activation of channel */
26 PRIM_INFO_DEACTIVATE, /*!< Deactivation of channel */
27 PRIM_INFO_MODIFY, /*!< Mode Modify of channel */
28 PRIM_INFO_ACT_CIPH, /*!< Activation of ciphering */
29 PRIM_INFO_DEACT_CIPH, /*!< Deactivation of ciphering */
Andreas Eversberg4ca0f622023-10-24 15:20:51 +020030 PRIM_INFO_ACT_UL_ACC, /*!< Activation of uplink access detection */
31 PRIM_INFO_DEACT_UL_ACC, /*!< Deactivation of uplink access detection */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010032};
33
Neels Hofmeyr87e45502017-06-20 00:17:59 +020034/*! PH-DATA presence information */
Maxcc00bf82016-02-22 11:03:26 +010035enum osmo_ph_pres_info_type {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020036 PRES_INFO_INVALID = 0, /*!< Data is invalid */
37 PRES_INFO_HEADER = 1, /*!< Only header is present and valid */
38 PRES_INFO_FIRST = 3, /*!< First half of data + header are valid (2nd half may be present but invalid) */
39 PRES_INFO_SECOND = 5, /*!< Second half of data + header are valid (1st halfmay be present but invalid) */
40 PRES_INFO_BOTH = 7, /*!< Both parts + header are present and valid */
Maxcc00bf82016-02-22 11:03:26 +010041 PRES_INFO_UNKNOWN
42};
43
Neels Hofmeyr87e45502017-06-20 00:17:59 +020044/*! for PH-RANDOM_ACCESS.req */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010045struct ph_rach_req_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020046 uint8_t ra; /*!< Random Access */
47 uint8_t ta; /*!< Timing Advance */
48 uint8_t tx_power; /*!< Transmit Power */
49 uint8_t is_combined_ccch;/*!< Are we using a combined CCCH? */
50 uint16_t offset; /*!< Timing Offset */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010051};
52
Neels Hofmeyr87e45502017-06-20 00:17:59 +020053/*! for PH_RA_IND burstType inforamtion */
bhargava1a969462016-07-14 13:15:09 +053054enum ph_burst_type {
55 GSM_L1_BURST_TYPE_NONE = 0,
56 GSM_L1_BURST_TYPE_ACCESS_0,
57 GSM_L1_BURST_TYPE_ACCESS_1,
58 GSM_L1_BURST_TYPE_ACCESS_2
59};
60
Neels Hofmeyr87e45502017-06-20 00:17:59 +020061/*! for PH-RANDOM_ACCESS.ind */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010062struct ph_rach_ind_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020063 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
64 uint16_t ra; /*!< Random Access */
65 uint8_t acc_delay; /*!< Delay in bit periods */
66 uint32_t fn; /*!< GSM Frame Number at time of RA */
67 uint8_t is_11bit; /*!< no.of bits in RACH*/
68 enum ph_burst_type burst_type; /*!< type of burst*/
Harald Weltea57f90c2018-02-26 11:49:59 +010069 /* elements added on 2018-02-26 */
70 int8_t rssi; /*!< RSSI of RACH indication */
71 uint16_t ber10k; /*!< BER in units of 0.01% */
Oliver Smith858c8662019-08-23 10:14:31 +020072 int16_t acc_delay_256bits;/*!< Burst TA Offset in 1/256th bits */
73 int16_t lqual_cb; /*!< Link quality in centiBel */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010074};
75
Neels Hofmeyr87e45502017-06-20 00:17:59 +020076/*! for PH-[UNIT]DATA.{req,ind} | PH-RTS.ind */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +010077struct ph_data_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020078 uint8_t link_id; /*!< Link Identifier (Like RSL) */
79 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
80 uint32_t fn; /*!< GSM Frame Number */
81 int8_t rssi; /*!< RSSI of receivedindication */
82 uint16_t ber10k; /*!< BER in units of 0.01% */
Harald Welte38c902b2018-02-27 17:30:08 +010083 union {
Oliver Smith858c8662019-08-23 10:14:31 +020084 int16_t ta_offs_qbits; /*!< Burst TA Offset in quarter bits */
Harald Welte38c902b2018-02-27 17:30:08 +010085 int16_t ta_offs_256bits;/*!< timing advance offset (in 1/256th bits) */
86 };
Oliver Smith858c8662019-08-23 10:14:31 +020087 int16_t lqual_cb; /*!< Link quality in centiBel */
Neels Hofmeyr87e45502017-06-20 00:17:59 +020088 enum osmo_ph_pres_info_type pdch_presence_info; /*!< Info regarding presence/validity of header and data parts */
Philipp Maier7497b412019-10-29 11:46:46 +010089 uint8_t is_sub:1; /*!< flags */
Andreas Eversberg227a9de2013-02-07 12:21:33 +010090};
91
Neels Hofmeyr87e45502017-06-20 00:17:59 +020092/*! for TCH.{req,ind} | TCH-RTS.ind */
Andreas Eversberg227a9de2013-02-07 12:21:33 +010093struct ph_tch_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +020094 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
95 uint32_t fn; /*!< GSM Frame Number */
96 int8_t rssi; /*!< RSSI of received indication */
97 uint8_t marker; /*!< RTP Marker bit (speech onset indicator) */
Pau Espin Pedrol411402b2017-06-30 12:06:00 +020098 uint16_t ber10k; /*!< BER in units of 0.01% */
Oliver Smith858c8662019-08-23 10:14:31 +020099 int16_t lqual_cb; /*!< Link quality in centiBel */
Philipp Maier7497b412019-10-29 11:46:46 +0100100 int16_t ta_offs_256bits;/*!< timing advance offset (in 1/256th bits) */
101 uint8_t is_sub:1; /*!< flags */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100102};
103
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200104/*! for PH-CONN.ind */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100105struct ph_conn_ind_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200106 uint32_t fn; /*!< GSM Frame Number */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100107};
108
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200109/*! for TIME MPH-INFO.ind */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100110struct info_time_ind_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200111 uint32_t fn; /*!< GSM Frame Number */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100112};
113
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200114/*! for MEAS MPH-INFO.ind */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100115struct info_meas_ind_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200116 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
117 uint32_t fn; /*!< GSM Frame Number */
118 uint16_t ber10k; /*!< BER in units of 0.01% */
Harald Welte38c902b2018-02-27 17:30:08 +0100119 union {
120 int16_t ta_offs_qbits; /*!< timing advance offset (in qbits) */
121 int16_t ta_offs_256bits;/*!< timing advance offset (in 1/256th bits) */
122 };
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200123 int16_t c_i_cb; /*!< C/I ratio in 0.1 dB */
124 uint8_t is_sub:1; /*!< flags */
125 uint8_t inv_rssi; /*!< RSSI in dBm * -1 */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100126};
127
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200128/*! for {ACTIVATE,DEACTIVATE,MODIFY} MPH-INFO.req */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100129struct info_act_req_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200130 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
Pau Espin Pedrole9fd7ff2020-08-25 13:03:35 +0200131 uint8_t sacch_only; /*!< \brief Only deactivate SACCH */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100132};
133
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200134/*! for {ACTIVATE,DEACTIVATE} MPH-INFO.cnf */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100135struct info_act_cnf_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200136 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
137 uint8_t cause; /*!< RSL cause in case of nack */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100138};
139
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200140/*! for {ACTIVATE,DEACTIVATE} MPH-INFO.{req,cnf} */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100141struct info_ciph_req_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200142 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
143 uint8_t downlink; /*!< Apply to downlink */
144 uint8_t uplink; /*!< Apply to uplink */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100145};
146
Andreas Eversberg4ca0f622023-10-24 15:20:51 +0200147/*! for {ACT_UL_ACC,DEACT_UL_ACC} MPH-INFO.req */
148struct info_ulacc_req_param {
149 uint8_t chan_nr; /*!< Channel Number (Like RSL) */
150};
151
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200152/*! for MPH-INFO.ind */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100153struct mph_info_param {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200154 enum osmo_mph_info_type type; /*!< Info message type */
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100155 union {
156 struct info_time_ind_param time_ind;
157 struct info_meas_ind_param meas_ind;
158 struct info_act_req_param act_req;
159 struct info_act_cnf_param act_cnf;
160 struct info_ciph_req_param ciph_req;
Andreas Eversberg4ca0f622023-10-24 15:20:51 +0200161 struct info_ulacc_req_param ulacc_req;
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100162 } u;
163};
164
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200165/*! primitive header for PH-SAP primitives */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100166struct osmo_phsap_prim {
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200167 struct osmo_prim_hdr oph; /*!< generic primitive header */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100168 union {
169 struct ph_data_param data;
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100170 struct ph_tch_param tch;
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100171 struct ph_rach_req_param rach_req;
172 struct ph_rach_ind_param rach_ind;
173 struct ph_conn_ind_param conn_ind;
Andreas Eversberg227a9de2013-02-07 12:21:33 +0100174 struct mph_info_param info;
Neels Hofmeyr87e45502017-06-20 00:17:59 +0200175 } u; /*!< request-specific data */
Andreas Eversbergaa85a2d2013-02-07 12:18:37 +0100176};