aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndreas Eversberg <jolly@eversberg.eu>2013-07-08 18:34:14 +0200
committerAndreas Eversberg <jolly@eversberg.eu>2014-04-06 08:58:16 +0200
commit3d3f88f2f88b88185817c7a00024fe3a9d005a59 (patch)
tree47a87b4dcbe42b4bcaf5b6cd1714d442bd007a40
parent8bbe9bdc9c7d6181e7f56fa6d7323e0d77a846b0 (diff)
Fix: Process all TRX on GSM Time indication, not only C0
-rw-r--r--src/common/l1sap.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/common/l1sap.c b/src/common/l1sap.c
index e66a0100..8ae76fff 100644
--- a/src/common/l1sap.c
+++ b/src/common/l1sap.c
@@ -279,11 +279,11 @@ static int to_gsmtap(struct gsm_bts_trx *trx, struct osmo_phsap_prim *l1sap)
}
/* time information received from bts model */
-static int l1sap_info_time_ind(struct gsm_bts_trx *trx,
+static int l1sap_info_time_ind(struct gsm_bts *bts,
struct osmo_phsap_prim *l1sap,
struct info_time_ind_param *info_time_ind)
{
- struct gsm_bts *bts = trx->bts;
+ struct gsm_bts_trx *trx;
struct gsm_bts_role_bts *btsb = bts->role;
DEBUGP(DL1P, "MPH_INFO time ind %u\n", info_time_ind->fn);
@@ -296,7 +296,8 @@ static int l1sap_info_time_ind(struct gsm_bts_trx *trx,
/* check if the measurement period of some lchan has ended
* and pre-compute the respective measurement */
- trx_meas_check_compute(trx, info_time_ind->fn - 1);
+ llist_for_each_entry(trx, &bts->trx_list, list)
+ trx_meas_check_compute(trx, info_time_ind->fn - 1);
/* increment 'total' for every possible rach */
if (bts->c0->ts[0].pchan != GSM_PCHAN_CCCH_SDCCH4
@@ -343,7 +344,7 @@ static int l1sap_mph_info_ind(struct gsm_bts_trx *trx,
switch (info->type) {
case PRIM_INFO_TIME:
- rc = l1sap_info_time_ind(trx, l1sap, &info->u.time_ind);
+ rc = l1sap_info_time_ind(trx->bts, l1sap, &info->u.time_ind);
break;
case PRIM_INFO_MEAS:
rc = l1sap_info_meas_ind(trx, l1sap, &info->u.meas_ind);