blob: 128b1e0ab73846c6f2ce2473f7912dcfe1c2e00c [file] [log] [blame]
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +02001/* bts.h
2 *
3 * Copyright (C) 2012 Ivan Klyuchnikov
4 * Copyright (C) 2013 by Holger Hans Peter Freyther
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
23
24#ifdef __cplusplus
25extern "C" {
26#include <osmocom/core/linuxlist.h>
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +010027#include <osmocom/core/rate_ctr.h>
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020028#include <osmocom/core/timer.h>
29}
Holger Hans Peter Freytherb78adcd2013-10-17 20:12:37 +020030
31#include "poll_controller.h"
Holger Hans Peter Freythercedf8902013-10-19 20:47:12 +020032#include "sba.h"
Holger Hans Peter Freyther111614a2013-10-19 20:04:57 +020033#include "ta.h"
Holger Hans Peter Freyther34bd8bd2013-10-19 21:10:38 +020034#include "tbf.h"
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020035#endif
36
37#include <stdint.h>
38
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +020039struct BTS;
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020040
41/*
42 * PDCH instance
43 */
44struct gprs_rlcmac_pdch {
Holger Hans Peter Freyther17b0d832013-10-19 17:37:48 +020045#ifdef __cplusplus
Holger Hans Peter Freyther24e98d02013-10-19 18:15:44 +020046 struct gprs_rlcmac_paging *dequeue_paging();
47 struct msgb *packet_paging_request();
48
Holger Hans Peter Freytherf0984892013-10-19 18:28:59 +020049 void add_paging(struct gprs_rlcmac_paging *pag);
Holger Hans Peter Freyther24e98d02013-10-19 18:15:44 +020050
Holger Hans Peter Freyther09ef27a2013-10-20 16:37:05 +020051 void free_resources();
Holger Hans Peter Freyther17b0d832013-10-19 17:37:48 +020052
53 bool is_enabled() const;
54
55 void enable();
56 void disable();
Holger Hans Peter Freyther9ae367f2013-10-26 16:42:38 +020057
58 /* dispatching of messages */
59 int rcv_block(uint8_t *data, uint8_t len, uint32_t fn, int8_t rssi);
Holger Hans Peter Freyther65be4802013-10-26 18:39:36 +020060
61 gprs_rlcmac_bts *bts_data() const;
62 BTS *bts() const;
Holger Hans Peter Freyther05f8efc2013-10-26 18:53:16 +020063 uint8_t trx_no() const;
Holger Hans Peter Freyther17b0d832013-10-19 17:37:48 +020064#endif
65
66 uint8_t m_is_enabled; /* TS is enabled */
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020067 uint8_t tsc; /* TSC of this slot */
68 uint8_t next_ul_tfi; /* next uplink TBF/TFI to schedule (0..31) */
69 uint8_t next_dl_tfi; /* next downlink TBF/TFI to schedule (0..31) */
Holger Hans Peter Freyther705653b2013-11-26 16:39:28 +010070 uint8_t next_ctrl_prio; /* next kind of ctrl message to schedule */
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020071 struct gprs_rlcmac_tbf *ul_tbf[32]; /* array of UL TBF, by UL TFI */
72 struct gprs_rlcmac_tbf *dl_tbf[32]; /* array of DL TBF, by DL TFI */
73 struct llist_head paging_list; /* list of paging messages */
74 uint32_t last_rts_fn; /* store last frame number of RTS */
Holger Hans Peter Freyther4ed1dae2013-10-20 10:14:03 +020075
76 /* back pointers */
77 struct gprs_rlcmac_trx *trx;
78 uint8_t ts_no;
Holger Hans Peter Freytherd11290b2013-10-26 17:32:04 +020079
80#ifdef __cplusplus
81private:
Holger Hans Peter Freyther05f8efc2013-10-26 18:53:16 +020082 int rcv_data_block_acknowledged(uint8_t *data, uint8_t len, int8_t rssi);
83 int rcv_control_block(bitvec *rlc_block, uint32_t fn);
Holger Hans Peter Freytherd11290b2013-10-26 17:32:04 +020084
Holger Hans Peter Freythere1a075a2013-10-27 13:35:30 +010085 void rcv_control_ack(Packet_Control_Acknowledgement_t *, uint32_t fn);
Holger Hans Peter Freyther5da20142013-10-27 11:41:01 +010086 void rcv_control_dl_ack_nack(Packet_Downlink_Ack_Nack_t *, uint32_t fn);
Holger Hans Peter Freyther7a344712013-10-27 11:37:53 +010087 void rcv_resource_request(Packet_Resource_Request_t *t, uint32_t fn);
Holger Hans Peter Freythercb5c49b2013-10-27 11:19:13 +010088 void rcv_measurement_report(Packet_Measurement_Report_t *t, uint32_t fn);
Holger Hans Peter Freytherd11290b2013-10-26 17:32:04 +020089#endif
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +020090};
91
92struct gprs_rlcmac_trx {
93 void *fl1h;
94 uint16_t arfcn;
95 struct gprs_rlcmac_pdch pdch[8];
96 struct gprs_rlcmac_tbf *ul_tbf[32]; /* array of UL TBF, by UL TFI */
97 struct gprs_rlcmac_tbf *dl_tbf[32]; /* array of DL TBF, by DL TFI */
Holger Hans Peter Freyther4ed1dae2013-10-20 10:14:03 +020098
99 /* back pointers */
100 struct BTS *bts;
101 uint8_t trx_no;
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +0200102};
103
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200104/**
105 * This is the data from C. As soon as our minimal compiler is gcc 4.7
106 * we can start to compile pcu_vty.c with c++ and remove the split.
107 */
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +0200108struct gprs_rlcmac_bts {
109 uint8_t bsic;
110 uint8_t fc_interval;
111 uint8_t cs1;
112 uint8_t cs2;
113 uint8_t cs3;
114 uint8_t cs4;
115 uint8_t initial_cs_dl, initial_cs_ul;
116 uint8_t force_cs; /* 0=use from BTS 1=use from VTY */
117 uint16_t force_llc_lifetime; /* overrides lifetime from SGSN */
118 uint8_t t3142;
119 uint8_t t3169;
120 uint8_t t3191;
121 uint16_t t3193_msec;
122 uint8_t t3195;
123 uint8_t n3101;
124 uint8_t n3103;
125 uint8_t n3105;
126 struct gprs_rlcmac_trx trx[8];
127 int (*alloc_algorithm)(struct gprs_rlcmac_bts *bts,
128 struct gprs_rlcmac_tbf *old_tbf,
129 struct gprs_rlcmac_tbf *tbf, uint32_t cust, uint8_t single);
130 uint32_t alloc_algorithm_curst; /* options to customize algorithm */
131 uint8_t force_two_phase;
132 uint8_t alpha, gamma;
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200133
Holger Hans Peter Freyther34bd8bd2013-10-19 21:10:38 +0200134 /* TBF handling, make private or move into TBFController */
135 /* list of uplink TBFs */
136 struct llist_head ul_tbfs;
137 /* list of downlink TBFs */
138 struct llist_head dl_tbfs;
139
140
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200141 /**
142 * Point back to the C++ object. This is used during the transition
143 * period.
144 */
145 struct BTS *bts;
Holger Hans Peter Freyther67ed34e2013-10-17 17:01:54 +0200146};
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200147
148#ifdef __cplusplus
149/**
150 * I represent a GSM BTS. I have one or more TRX, I know the current
151 * GSM time and I have controllers that help with allocating resources
152 * on my TRXs.
153 */
154struct BTS {
155public:
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100156 enum {
157 CTR_TBF_DL_ALLOCATED,
158 CTR_TBF_DL_FREED,
159 CTR_TBF_UL_ALLOCATED,
160 CTR_TBF_UL_FREED,
Holger Hans Peter Freytheraa35ba72013-11-13 15:02:50 +0100161 CTR_TBF_REUSED,
Holger Hans Peter Freythere9429b52013-11-13 19:36:57 +0100162 CTR_RLC_SENT,
163 CTR_RLC_RESENT,
Holger Hans Peter Freytheref93bdb2013-11-24 00:01:50 +0100164 CTR_RLC_RESTARTED,
Holger Hans Peter Freytherc70aae42013-11-19 17:09:37 +0100165 CTR_RLC_STALLED,
Holger Hans Peter Freyther092478f2013-11-23 01:01:19 +0100166 CTR_RLC_NACKED,
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100167 CTR_DECODE_ERRORS,
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100168 CTR_SBA_ALLOCATED,
169 CTR_SBA_FREED,
170 CTR_SBA_TIMEDOUT,
Holger Hans Peter Freyther19977872013-10-27 10:34:31 +0100171 CTR_LLC_FRAME_TIMEDOUT,
172 CTR_LLC_FRAME_DROPPED,
Holger Hans Peter Freytherb3d5ee22013-11-13 16:43:26 +0100173 CTR_LLC_FRAME_SCHED,
Holger Hans Peter Freytherc1ae2262013-10-27 10:50:35 +0100174 CTR_RACH_REQUESTS,
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100175 };
176
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200177 BTS();
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100178 ~BTS();
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200179
180 static BTS* main_bts();
181
182 struct gprs_rlcmac_bts *bts_data();
Holger Hans Peter Freythercedf8902013-10-19 20:47:12 +0200183 SBAController *sba();
Holger Hans Peter Freyther111614a2013-10-19 20:04:57 +0200184 TimingAdvance *timing_advance();
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200185
Holger Hans Peter Freyther9b30c7f2013-10-17 19:59:56 +0200186 /** TODO: change the number to unsigned */
187 void set_current_frame_number(int frame_number);
188 int current_frame_number() const;
189
Holger Hans Peter Freytherf0984892013-10-19 18:28:59 +0200190 /** add paging to paging queue(s) */
191 int add_paging(uint8_t chan_needed, uint8_t *identity_lv);
192
Holger Hans Peter Freyther34bd8bd2013-10-19 21:10:38 +0200193 gprs_rlcmac_tbf *tbf_by_tlli(uint32_t tlli, enum gprs_rlcmac_tbf_direction dir);
194 gprs_rlcmac_tbf *tbf_by_poll_fn(uint32_t fn, uint8_t trx, uint8_t ts);
Holger Hans Peter Freytherf63cabd2013-10-26 19:10:43 +0200195 gprs_rlcmac_tbf *tbf_by_tfi(uint8_t tfi, uint8_t trx, enum gprs_rlcmac_tbf_direction dir);
Holger Hans Peter Freyther34bd8bd2013-10-19 21:10:38 +0200196
Holger Hans Peter Freyther70ddde62013-10-26 19:17:58 +0200197 int tfi_find_free(enum gprs_rlcmac_tbf_direction dir, uint8_t *_trx, int8_t use_trx);
198
Holger Hans Peter Freyther40cfaa62013-10-26 19:49:16 +0200199 int rcv_imm_ass_cnf(const uint8_t *data, uint32_t fn);
Holger Hans Peter Freyther02beed52013-10-26 20:56:20 +0200200 int rcv_rach(uint8_t ra, uint32_t Fn, int16_t qta);
Holger Hans Peter Freyther40cfaa62013-10-26 19:49:16 +0200201
Holger Hans Peter Freyther24c1a5b2013-10-26 20:27:44 +0200202 void trigger_dl_ass(gprs_rlcmac_tbf *tbf, gprs_rlcmac_tbf *old_tbf, const char *imsi);
Holger Hans Peter Freytherd9262b32013-10-26 20:12:59 +0200203 void snd_dl_ass(gprs_rlcmac_tbf *tbf, uint8_t poll, const char *imsi);
204
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100205 /*
206 * Statistics
207 */
208 void tbf_dl_created();
209 void tbf_dl_freed();
210 void tbf_ul_created();
211 void tbf_ul_freed();
Holger Hans Peter Freytheraa35ba72013-11-13 15:02:50 +0100212 void tbf_reused();
Holger Hans Peter Freythere9429b52013-11-13 19:36:57 +0100213 void rlc_sent();
214 void rlc_resent();
Holger Hans Peter Freytheref93bdb2013-11-24 00:01:50 +0100215 void rlc_restarted();
Holger Hans Peter Freytherc70aae42013-11-19 17:09:37 +0100216 void rlc_stalled();
Holger Hans Peter Freyther092478f2013-11-23 01:01:19 +0100217 void rlc_nacked();
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100218 void decode_error();
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100219 void sba_allocated();
220 void sba_freed();
221 void sba_timedout();
Holger Hans Peter Freytherb3d5ee22013-11-13 16:43:26 +0100222 void llc_timedout_frame();
223 void llc_dropped_frame();
224 void llc_frame_sched();
Holger Hans Peter Freytherc1ae2262013-10-27 10:50:35 +0100225 void rach_frame();
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100226
227 /*
228 * Below for C interface for the VTY
229 */
230 struct rate_ctr_group *rate_counters() const;
231
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200232private:
Holger Hans Peter Freyther9b30c7f2013-10-17 19:59:56 +0200233 int m_cur_fn;
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200234 struct gprs_rlcmac_bts m_bts;
Holger Hans Peter Freytherb78adcd2013-10-17 20:12:37 +0200235 PollController m_pollController;
Holger Hans Peter Freythercedf8902013-10-19 20:47:12 +0200236 SBAController m_sba;
Holger Hans Peter Freyther111614a2013-10-19 20:04:57 +0200237 TimingAdvance m_ta;
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100238 struct rate_ctr_group *m_ratectrs;
Holger Hans Peter Freytherb78adcd2013-10-17 20:12:37 +0200239
240private:
241 /* disable copying to avoid slicing */
242 BTS(const BTS&);
243 BTS& operator=(const BTS&);
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200244};
Holger Hans Peter Freyther9b30c7f2013-10-17 19:59:56 +0200245
246inline int BTS::current_frame_number() const
247{
248 return m_cur_fn;
249}
Holger Hans Peter Freyther111614a2013-10-19 20:04:57 +0200250
251inline TimingAdvance *BTS::timing_advance()
252{
253 return &m_ta;
254}
Holger Hans Peter Freythercedf8902013-10-19 20:47:12 +0200255
256inline SBAController *BTS::sba()
257{
258 return &m_sba;
259}
Holger Hans Peter Freyther65be4802013-10-26 18:39:36 +0200260
261inline BTS *gprs_rlcmac_pdch::bts() const
262{
263 return trx->bts;
264}
265
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100266inline struct rate_ctr_group *BTS::rate_counters() const
267{
268 return m_ratectrs;
269}
270
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100271#define CREATE_COUNT_INLINE(func_name, ctr_name) \
272 inline void BTS::func_name() {\
273 rate_ctr_inc(&m_ratectrs->ctr[ctr_name]); \
274 }
Holger Hans Peter Freyther15877642013-10-27 09:50:15 +0100275
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100276CREATE_COUNT_INLINE(tbf_dl_created, CTR_TBF_DL_ALLOCATED)
277CREATE_COUNT_INLINE(tbf_dl_freed, CTR_TBF_DL_FREED)
278CREATE_COUNT_INLINE(tbf_ul_created, CTR_TBF_UL_ALLOCATED)
279CREATE_COUNT_INLINE(tbf_ul_freed, CTR_TBF_UL_FREED)
Holger Hans Peter Freytheraa35ba72013-11-13 15:02:50 +0100280CREATE_COUNT_INLINE(tbf_reused, CTR_TBF_REUSED)
Holger Hans Peter Freythere9429b52013-11-13 19:36:57 +0100281CREATE_COUNT_INLINE(rlc_sent, CTR_RLC_SENT)
282CREATE_COUNT_INLINE(rlc_resent, CTR_RLC_RESENT)
Holger Hans Peter Freytheref93bdb2013-11-24 00:01:50 +0100283CREATE_COUNT_INLINE(rlc_restarted, CTR_RLC_RESTARTED)
Holger Hans Peter Freytherc70aae42013-11-19 17:09:37 +0100284CREATE_COUNT_INLINE(rlc_stalled, CTR_RLC_STALLED)
Holger Hans Peter Freyther092478f2013-11-23 01:01:19 +0100285CREATE_COUNT_INLINE(rlc_nacked, CTR_RLC_NACKED)
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100286CREATE_COUNT_INLINE(decode_error, CTR_DECODE_ERRORS)
287CREATE_COUNT_INLINE(sba_allocated, CTR_SBA_ALLOCATED)
288CREATE_COUNT_INLINE(sba_freed, CTR_SBA_FREED)
289CREATE_COUNT_INLINE(sba_timedout, CTR_SBA_TIMEDOUT)
Holger Hans Peter Freytherb3d5ee22013-11-13 16:43:26 +0100290CREATE_COUNT_INLINE(llc_timedout_frame, CTR_LLC_FRAME_TIMEDOUT);
291CREATE_COUNT_INLINE(llc_dropped_frame, CTR_LLC_FRAME_DROPPED);
292CREATE_COUNT_INLINE(llc_frame_sched, CTR_LLC_FRAME_SCHED);
Holger Hans Peter Freytherc1ae2262013-10-27 10:50:35 +0100293CREATE_COUNT_INLINE(rach_frame, CTR_RACH_REQUESTS);
Holger Hans Peter Freyther15877642013-10-27 09:50:15 +0100294
Holger Hans Peter Freyther93e048f2013-10-27 10:00:47 +0100295#undef CREATE_COUNT_INLINE
Holger Hans Peter Freyther15877642013-10-27 09:50:15 +0100296
Holger Hans Peter Freyther15877642013-10-27 09:50:15 +0100297
Holger Hans Peter Freyther65be4802013-10-26 18:39:36 +0200298inline gprs_rlcmac_bts *gprs_rlcmac_pdch::bts_data() const
299{
300 return trx->bts->bts_data();
301}
Holger Hans Peter Freyther05f8efc2013-10-26 18:53:16 +0200302
303inline uint8_t gprs_rlcmac_pdch::trx_no() const
304{
305 return trx->trx_no;
306}
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200307#endif
308
309#ifdef __cplusplus
310extern "C" {
311#endif
312 struct gprs_rlcmac_bts *bts_main_data();
Holger Hans Peter Freytherf5372982013-10-27 09:02:31 +0100313 struct rate_ctr_group *bts_main_data_stats();
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200314#ifdef __cplusplus
315}
Holger Hans Peter Freyther17b0d832013-10-19 17:37:48 +0200316
317inline bool gprs_rlcmac_pdch::is_enabled() const
318{
319 return m_is_enabled;
320}
Holger Hans Peter Freytherb6acfda2013-10-17 19:41:11 +0200321#endif