Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 1 | /* gprs_ms.h |
| 2 | * |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 3 | * Copyright (C) 2015-2020 by Sysmocom s.f.m.c. GmbH |
Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 4 | * Author: Jacob Erlbeck <jerlbeck@sysmocom.de> |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or |
| 7 | * modify it under the terms of the GNU General Public License |
| 8 | * as published by the Free Software Foundation; either version 2 |
| 9 | * of the License, or (at your option) any later version. |
| 10 | * |
| 11 | * This program is distributed in the hope that it will be useful, |
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 14 | * GNU General Public License for more details. |
| 15 | * |
| 16 | * You should have received a copy of the GNU General Public License |
| 17 | * along with this program; if not, write to the Free Software |
| 18 | * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| 19 | */ |
| 20 | |
| 21 | #pragma once |
| 22 | |
Jacob Erlbeck | d4ad731 | 2015-07-17 16:39:09 +0200 | [diff] [blame] | 23 | struct gprs_codel; |
Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 24 | |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 25 | #include "llc.h" |
Jacob Erlbeck | ac89a55 | 2015-06-29 14:18:46 +0200 | [diff] [blame] | 26 | #include "tbf.h" |
Pau Espin Pedrol | 442198c | 2020-10-23 22:30:04 +0200 | [diff] [blame] | 27 | #include "tbf_ul.h" |
Pau Espin Pedrol | 9d1cdb1 | 2019-09-25 17:47:02 +0200 | [diff] [blame] | 28 | #include "tbf_dl.h" |
Jacob Erlbeck | e4bcb62 | 2015-06-08 11:26:38 +0200 | [diff] [blame] | 29 | #include "pcu_l1_if.h" |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 30 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 31 | #ifdef __cplusplus |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 32 | extern "C" { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 33 | #endif |
Pau Espin Pedrol | 2ae8337 | 2020-05-18 11:35:35 +0200 | [diff] [blame] | 34 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 35 | #include <osmocom/core/timer.h> |
| 36 | #include <osmocom/core/linuxlist.h> |
Pau Espin Pedrol | bed48cc | 2021-01-11 17:32:18 +0100 | [diff] [blame] | 37 | #include <osmocom/core/rate_ctr.h> |
Pau Espin Pedrol | 43f0bce | 2020-06-26 13:09:44 +0200 | [diff] [blame] | 38 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 39 | #include <osmocom/gsm/protocol/gsm_23_003.h> |
| 40 | #include <osmocom/gsm/gsm48.h> |
| 41 | |
| 42 | #include "coding_scheme.h" |
Pau Espin Pedrol | c0a250d | 2021-01-21 18:46:13 +0100 | [diff] [blame] | 43 | #include <gsm_rlcmac.h> |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 44 | |
Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 45 | #include <stdint.h> |
| 46 | #include <stddef.h> |
Pau Espin Pedrol | f2dad59 | 2020-08-18 20:26:25 +0200 | [diff] [blame] | 47 | #include <inttypes.h> |
Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 48 | |
Pau Espin Pedrol | bed48cc | 2021-01-11 17:32:18 +0100 | [diff] [blame] | 49 | enum ms_counter_id { |
| 50 | MS_CTR_DL_CTRL_MSG_SCHED, |
| 51 | }; |
| 52 | |
Pau Espin Pedrol | 2182e62 | 2021-01-14 16:48:38 +0100 | [diff] [blame] | 53 | struct gprs_rlcmac_bts; |
Jacob Erlbeck | 23f93a1 | 2015-06-30 08:52:54 +0200 | [diff] [blame] | 54 | struct gprs_rlcmac_trx; |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 55 | struct GprsMs; |
Jacob Erlbeck | 17214bb | 2015-06-02 14:06:12 +0200 | [diff] [blame] | 56 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 57 | struct gpr_ms_callback { |
| 58 | void (*ms_idle)(struct GprsMs *); |
| 59 | void (*ms_active)(struct GprsMs *); |
Jacob Erlbeck | e04e0b0 | 2015-05-06 18:30:48 +0200 | [diff] [blame] | 60 | }; |
Jacob Erlbeck | 9399046 | 2015-05-15 15:50:43 +0200 | [diff] [blame] | 61 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 62 | struct GprsMs { |
| 63 | struct llist_head list; /* list of all GprsMs */ |
| 64 | struct gpr_ms_callback cb; |
| 65 | bool app_info_pending; |
| 66 | |
Pau Espin Pedrol | 2182e62 | 2021-01-14 16:48:38 +0100 | [diff] [blame] | 67 | struct gprs_rlcmac_bts *bts; |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 68 | struct gprs_rlcmac_ul_tbf *ul_tbf; |
| 69 | struct gprs_rlcmac_dl_tbf *dl_tbf; |
| 70 | struct llist_head old_tbfs; /* list of gprs_rlcmac_tbf */ |
| 71 | |
| 72 | uint32_t tlli; |
| 73 | uint32_t new_ul_tlli; |
| 74 | uint32_t new_dl_tlli; |
| 75 | |
| 76 | /* store IMSI for look-up and PCH retransmission */ |
| 77 | char imsi[OSMO_IMSI_BUF_SIZE]; |
| 78 | uint8_t ta; |
| 79 | uint8_t ms_class; |
| 80 | uint8_t egprs_ms_class; |
| 81 | /* current coding scheme */ |
| 82 | enum CodingScheme current_cs_ul; |
| 83 | enum CodingScheme current_cs_dl; |
| 84 | |
| 85 | struct gprs_llc_queue llc_queue; |
| 86 | |
| 87 | bool is_idle; |
| 88 | int ref; |
| 89 | struct osmo_timer_list timer; |
| 90 | unsigned delay; |
| 91 | |
| 92 | int64_t last_cs_not_low; |
| 93 | |
| 94 | struct pcu_l1_meas l1_meas; |
| 95 | unsigned nack_rate_dl; |
| 96 | uint8_t reserved_dl_slots; |
| 97 | uint8_t reserved_ul_slots; |
| 98 | struct gprs_rlcmac_trx *current_trx; |
| 99 | |
| 100 | struct gprs_codel *codel_state; |
| 101 | enum mcs_kind mode; |
| 102 | |
Pau Espin Pedrol | bed48cc | 2021-01-11 17:32:18 +0100 | [diff] [blame] | 103 | struct rate_ctr_group *ctrs; |
Pau Espin Pedrol | c0a250d | 2021-01-21 18:46:13 +0100 | [diff] [blame] | 104 | struct nacc_fsm_ctx *nacc; |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 105 | }; |
| 106 | |
Pau Espin Pedrol | 2182e62 | 2021-01-14 16:48:38 +0100 | [diff] [blame] | 107 | struct GprsMs *ms_alloc(struct gprs_rlcmac_bts *bts, uint32_t tlli); |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 108 | |
| 109 | int ms_first_common_ts(const struct GprsMs *ms); |
| 110 | void ms_set_reserved_slots(struct GprsMs *ms, struct gprs_rlcmac_trx *trx, |
| 111 | uint8_t ul_slots, uint8_t dl_slots); |
| 112 | struct GprsMs *ms_ref(struct GprsMs *ms); |
| 113 | void ms_unref(struct GprsMs *ms); |
| 114 | void ms_set_mode(struct GprsMs *ms, enum mcs_kind mode); |
| 115 | void ms_set_ms_class(struct GprsMs *ms, uint8_t ms_class_); |
| 116 | void ms_set_egprs_ms_class(struct GprsMs *ms, uint8_t ms_class_); |
| 117 | void ms_set_ta(struct GprsMs *ms, uint8_t ta_); |
| 118 | |
Pau Espin Pedrol | fc46493 | 2021-01-25 12:05:32 +0100 | [diff] [blame] | 119 | enum CodingScheme ms_current_cs_dl(const struct GprsMs *ms, enum mcs_kind req_mcs_kind); |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 120 | enum CodingScheme ms_max_cs_ul(const struct GprsMs *ms); |
| 121 | enum CodingScheme ms_max_cs_dl(const struct GprsMs *ms); |
| 122 | void ms_set_current_cs_dl(struct GprsMs *ms, enum CodingScheme scheme); |
| 123 | |
| 124 | void ms_update_error_rate(struct GprsMs *ms, struct gprs_rlcmac_tbf *tbf, int error_rate); |
| 125 | uint8_t ms_current_pacch_slots(const struct GprsMs *ms); |
| 126 | |
| 127 | void ms_merge_and_clear_ms(struct GprsMs *ms, struct GprsMs *old_ms); |
| 128 | |
| 129 | void ms_attach_tbf(struct GprsMs *ms, struct gprs_rlcmac_tbf *tbf); |
| 130 | void ms_detach_tbf(struct GprsMs *ms, struct gprs_rlcmac_tbf *tbf); |
| 131 | |
| 132 | void ms_set_tlli(struct GprsMs *ms, uint32_t tlli); |
| 133 | bool ms_confirm_tlli(struct GprsMs *ms, uint32_t tlli); |
| 134 | void ms_set_imsi(struct GprsMs *ms, const char *imsi); |
| 135 | |
| 136 | void ms_update_l1_meas(struct GprsMs *ms, const struct pcu_l1_meas *meas); |
| 137 | |
| 138 | struct gprs_rlcmac_tbf *ms_tbf(const struct GprsMs *ms, enum gprs_rlcmac_tbf_direction dir); |
| 139 | static inline struct gprs_rlcmac_ul_tbf *ms_ul_tbf(const struct GprsMs *ms) {return ms->ul_tbf;} |
| 140 | static inline struct gprs_rlcmac_dl_tbf *ms_dl_tbf(const struct GprsMs *ms) {return ms->dl_tbf;} |
| 141 | |
| 142 | |
| 143 | void ms_set_callback(struct GprsMs *ms, struct gpr_ms_callback *cb); |
| 144 | |
Pau Espin Pedrol | c0a250d | 2021-01-21 18:46:13 +0100 | [diff] [blame] | 145 | int ms_nacc_start(struct GprsMs *ms, Packet_Cell_Change_Notification_t *notif); |
| 146 | bool ms_nacc_rts(const struct GprsMs *ms); |
Pau Espin Pedrol | 952cb3d | 2021-02-01 14:52:48 +0100 | [diff] [blame] | 147 | struct msgb *ms_nacc_create_rlcmac_msg(struct GprsMs *ms, struct gprs_rlcmac_tbf *tbf, uint32_t fn, uint8_t ts); |
Pau Espin Pedrol | c0a250d | 2021-01-21 18:46:13 +0100 | [diff] [blame] | 148 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 149 | static inline bool ms_is_idle(const struct GprsMs *ms) |
Jacob Erlbeck | 6835cea | 2015-08-21 15:24:02 +0200 | [diff] [blame] | 150 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 151 | return !ms->ul_tbf && !ms->dl_tbf && !ms->ref && llist_empty(&ms->old_tbfs); |
Jacob Erlbeck | 6835cea | 2015-08-21 15:24:02 +0200 | [diff] [blame] | 152 | } |
| 153 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 154 | static inline struct gprs_llc_queue *ms_llc_queue(struct GprsMs *ms) |
Jacob Erlbeck | c8cbfc2 | 2015-09-01 11:38:40 +0200 | [diff] [blame] | 155 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 156 | return &ms->llc_queue; |
| 157 | } |
| 158 | |
| 159 | static inline bool ms_need_dl_tbf(struct GprsMs *ms) |
| 160 | { |
| 161 | if (ms_dl_tbf(ms) != NULL && |
Pau Espin Pedrol | dc2aaac | 2021-05-14 12:50:46 +0200 | [diff] [blame] | 162 | tbf_state((const struct gprs_rlcmac_tbf *)ms_dl_tbf(ms)) != TBF_ST_WAIT_RELEASE) |
Jacob Erlbeck | c8cbfc2 | 2015-09-01 11:38:40 +0200 | [diff] [blame] | 163 | return false; |
| 164 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 165 | return llc_queue_size(ms_llc_queue(ms)) > 0; |
Jacob Erlbeck | c8cbfc2 | 2015-09-01 11:38:40 +0200 | [diff] [blame] | 166 | } |
| 167 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 168 | static inline uint32_t ms_tlli(const struct GprsMs *ms) |
Jacob Erlbeck | 9399046 | 2015-05-15 15:50:43 +0200 | [diff] [blame] | 169 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 170 | if (ms->new_ul_tlli != GSM_RESERVED_TMSI) |
| 171 | return ms->new_ul_tlli; |
| 172 | if (ms->tlli != GSM_RESERVED_TMSI) |
| 173 | return ms->tlli; |
Vadim Yanitskiy | cb98894 | 2020-11-08 13:27:35 +0700 | [diff] [blame] | 174 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 175 | return ms->new_dl_tlli; |
Jacob Erlbeck | 9399046 | 2015-05-15 15:50:43 +0200 | [diff] [blame] | 176 | } |
| 177 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 178 | static inline bool ms_check_tlli(struct GprsMs *ms, uint32_t tlli) |
Jacob Erlbeck | 9399046 | 2015-05-15 15:50:43 +0200 | [diff] [blame] | 179 | { |
Vadim Yanitskiy | cb98894 | 2020-11-08 13:27:35 +0700 | [diff] [blame] | 180 | return tlli != GSM_RESERVED_TMSI && |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 181 | (tlli == ms->tlli || tlli == ms->new_ul_tlli || tlli == ms->new_dl_tlli); |
Jacob Erlbeck | 9399046 | 2015-05-15 15:50:43 +0200 | [diff] [blame] | 182 | } |
Jacob Erlbeck | b0e5eaf | 2015-05-21 11:07:16 +0200 | [diff] [blame] | 183 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 184 | static inline const char *ms_imsi(const struct GprsMs *ms) |
Jacob Erlbeck | b0e5eaf | 2015-05-21 11:07:16 +0200 | [diff] [blame] | 185 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 186 | return ms->imsi; |
Jacob Erlbeck | b0e5eaf | 2015-05-21 11:07:16 +0200 | [diff] [blame] | 187 | } |
Jacob Erlbeck | 9200ce6 | 2015-05-22 17:48:04 +0200 | [diff] [blame] | 188 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 189 | static inline uint8_t ms_ta(const struct GprsMs *ms) |
Jacob Erlbeck | 9200ce6 | 2015-05-22 17:48:04 +0200 | [diff] [blame] | 190 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 191 | return ms->ta; |
Jacob Erlbeck | 9200ce6 | 2015-05-22 17:48:04 +0200 | [diff] [blame] | 192 | } |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 193 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 194 | static inline uint8_t ms_ms_class(const struct GprsMs *ms) |
Jacob Erlbeck | befc760 | 2015-06-02 12:33:30 +0200 | [diff] [blame] | 195 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 196 | return ms->ms_class; |
Jacob Erlbeck | befc760 | 2015-06-02 12:33:30 +0200 | [diff] [blame] | 197 | } |
| 198 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 199 | static inline uint8_t ms_egprs_ms_class(const struct GprsMs *ms) |
Jacob Erlbeck | c3c5804 | 2015-09-28 17:55:32 +0200 | [diff] [blame] | 200 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 201 | return ms->egprs_ms_class; |
Jacob Erlbeck | c3c5804 | 2015-09-28 17:55:32 +0200 | [diff] [blame] | 202 | } |
| 203 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 204 | static inline enum CodingScheme ms_current_cs_ul(const struct GprsMs *ms) |
Jacob Erlbeck | a700dd9 | 2015-06-02 16:00:41 +0200 | [diff] [blame] | 205 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 206 | return ms->current_cs_ul; |
Jacob Erlbeck | a700dd9 | 2015-06-02 16:00:41 +0200 | [diff] [blame] | 207 | } |
| 208 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 209 | static inline enum mcs_kind ms_mode(const struct GprsMs *ms) |
Jacob Erlbeck | cb72890 | 2016-01-05 15:33:03 +0100 | [diff] [blame] | 210 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 211 | return ms->mode; |
Jacob Erlbeck | cb72890 | 2016-01-05 15:33:03 +0100 | [diff] [blame] | 212 | } |
| 213 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 214 | static inline void ms_set_timeout(struct GprsMs *ms, unsigned secs) |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 215 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 216 | ms->delay = secs; |
Jacob Erlbeck | d9e1024 | 2015-05-28 15:43:53 +0200 | [diff] [blame] | 217 | } |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 218 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 219 | static inline struct gprs_codel *ms_codel_state(const struct GprsMs *ms) |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 220 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 221 | return ms->codel_state; |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 222 | } |
| 223 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 224 | static inline unsigned ms_nack_rate_dl(const struct GprsMs *ms) |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 225 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 226 | return ms->nack_rate_dl; |
Jacob Erlbeck | 489a2b3 | 2015-05-28 19:07:01 +0200 | [diff] [blame] | 227 | } |
| 228 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 229 | static inline uint8_t ms_reserved_dl_slots(const struct GprsMs *ms) |
sivasankari | da7250a | 2016-12-16 12:57:18 +0530 | [diff] [blame] | 230 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 231 | return ms->reserved_dl_slots; |
sivasankari | da7250a | 2016-12-16 12:57:18 +0530 | [diff] [blame] | 232 | } |
| 233 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 234 | static inline uint8_t ms_reserved_ul_slots(const struct GprsMs *ms) |
sivasankari | da7250a | 2016-12-16 12:57:18 +0530 | [diff] [blame] | 235 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 236 | return ms->reserved_ul_slots; |
sivasankari | da7250a | 2016-12-16 12:57:18 +0530 | [diff] [blame] | 237 | } |
| 238 | |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 239 | static inline struct gprs_rlcmac_trx *ms_current_trx(const struct GprsMs *ms) |
Jacob Erlbeck | 23f93a1 | 2015-06-30 08:52:54 +0200 | [diff] [blame] | 240 | { |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 241 | return ms->current_trx; |
Jacob Erlbeck | 23f93a1 | 2015-06-30 08:52:54 +0200 | [diff] [blame] | 242 | } |
Pau Espin Pedrol | f2dad59 | 2020-08-18 20:26:25 +0200 | [diff] [blame] | 243 | |
| 244 | #define LOGPMS(ms, category, level, fmt, args...) \ |
| 245 | LOGP(category, level, "MS(TLLI=0x%08x, IMSI=%s, TA=%" PRIu8 ", %" PRIu8 "/%" PRIu8 ",%s%s) " fmt, \ |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 246 | ms_tlli(ms), ms_imsi(ms), ms_ta(ms), ms_ms_class(ms), ms_egprs_ms_class(ms), \ |
| 247 | ms_ul_tbf(ms) ? " UL": "", \ |
| 248 | ms_dl_tbf(ms) ? " DL": "", \ |
Pau Espin Pedrol | f2dad59 | 2020-08-18 20:26:25 +0200 | [diff] [blame] | 249 | ## args) |
Pau Espin Pedrol | da971ee | 2020-12-16 15:59:45 +0100 | [diff] [blame] | 250 | |
| 251 | #ifdef __cplusplus |
| 252 | } |
| 253 | #endif |