aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPau Espin Pedrol <pespin@sysmocom.de>2019-09-30 19:07:16 +0200
committerPau Espin Pedrol <pespin@sysmocom.de>2019-10-01 10:38:55 +0200
commit58543709e422ce6ba20baa232e6a5aced9b99164 (patch)
treed252aec92eaacb44699b8317528d0982faa814d7
parent1ec211f57f5b338d192714f60a14d278bf13cb7f (diff)
Log AGCH and PCH blocks using GSMTAP
-rw-r--r--src/bts.h2
-rw-r--r--src/pcu_l1_if.cpp10
-rw-r--r--src/pcu_vty.c4
3 files changed, 16 insertions, 0 deletions
diff --git a/src/bts.h b/src/bts.h
index 4ffe4336..c2cc3163 100644
--- a/src/bts.h
+++ b/src/bts.h
@@ -58,6 +58,8 @@ enum pcu_gsmtap_category {
PCU_GSMTAP_C_DL_DATA_GPRS = 3, /* downlink GPRS data blocks */
PCU_GSMTAP_C_DL_DATA_EGPRS = 4, /* downlink EGPRS data blocks */
PCU_GSMTAP_C_DL_PTCCH = 5, /* downlink PTCCH blocks */
+ PCU_GSMTAP_C_DL_AGCH = 6, /* downlink AGCH blocks */
+ PCU_GSMTAP_C_DL_PCH = 7, /* downlink PCH blocks */
PCU_GSMTAP_C_UL_UNKNOWN = 15, /* unknown or undecodable uplink blocks */
PCU_GSMTAP_C_UL_DUMMY = 16, /* uplink dummy blocks */
diff --git a/src/pcu_l1_if.cpp b/src/pcu_l1_if.cpp
index 8901ce6f..ac04663e 100644
--- a/src/pcu_l1_if.cpp
+++ b/src/pcu_l1_if.cpp
@@ -207,16 +207,22 @@ void pcu_l1if_tx_ptcch(msgb *msg, uint8_t trx, uint8_t ts, uint16_t arfcn,
void pcu_l1if_tx_agch(bitvec * block, int plen)
{
+ struct gprs_rlcmac_bts *bts = bts_main_data();
uint8_t data[23]; /* prefix PLEN */
/* FIXME: why does OpenBTS has no PLEN and no fill in message? */
bitvec_pack(block, data + 1);
data[0] = (plen << 2) | 0x01;
+
+ if (bts->gsmtap_categ_mask & (1 << PCU_GSMTAP_C_DL_AGCH))
+ gsmtap_send(bts->gsmtap, 0, 0, GSMTAP_CHANNEL_AGCH, 0, 0, 0, 0, data, 23);
+
pcu_tx_data_req(0, 0, PCU_IF_SAPI_AGCH, 0, 0, 0, data, 23);
}
void pcu_l1if_tx_pch(bitvec * block, int plen, const char *imsi)
{
+ struct gprs_rlcmac_bts *bts = bts_main_data();
uint8_t data[3+1+23]; /* prefix PLEN */
/* paging group */
@@ -230,6 +236,10 @@ void pcu_l1if_tx_pch(bitvec * block, int plen, const char *imsi)
OSMO_ASSERT(block->data_len <= sizeof(data) - (3+1));
bitvec_pack(block, data + 3+1);
data[3] = (plen << 2) | 0x01;
+
+ if (bts->gsmtap_categ_mask & (1 << PCU_GSMTAP_C_DL_PCH))
+ gsmtap_send(bts->gsmtap, 0, 0, GSMTAP_CHANNEL_PCH, 0, 0, 0, 0, data + 4, 23);
+
pcu_tx_data_req(0, 0, PCU_IF_SAPI_PCH, 0, 0, 0, data, 23+3);
}
diff --git a/src/pcu_vty.c b/src/pcu_vty.c
index a131dd2d..23a42e79 100644
--- a/src/pcu_vty.c
+++ b/src/pcu_vty.c
@@ -28,6 +28,8 @@ static const struct value_string pcu_gsmtap_categ_names[] = {
{ PCU_GSMTAP_C_DL_DATA_GPRS, "dl-data-gprs" },
{ PCU_GSMTAP_C_DL_DATA_EGPRS, "dl-data-egprs" },
{ PCU_GSMTAP_C_DL_PTCCH, "dl-ptcch" },
+ { PCU_GSMTAP_C_DL_AGCH, "dl-agch" },
+ { PCU_GSMTAP_C_DL_PCH, "dl-pch" },
{ PCU_GSMTAP_C_UL_UNKNOWN, "ul-unknown" },
{ PCU_GSMTAP_C_UL_DUMMY, "ul-dummy" },
@@ -46,6 +48,8 @@ static const struct value_string pcu_gsmtap_categ_help[] = {
{ PCU_GSMTAP_C_DL_DATA_GPRS, "Downlink Data Blocks (GPRS)" },
{ PCU_GSMTAP_C_DL_DATA_EGPRS, "Downlink Data Blocks (EGPRS)" },
{ PCU_GSMTAP_C_DL_PTCCH, "Downlink PTCCH Blocks" },
+ { PCU_GSMTAP_C_DL_AGCH, "Downlink AGCH Blocks" },
+ { PCU_GSMTAP_C_DL_PCH, "Downlink PCH Blocks" },
{ PCU_GSMTAP_C_UL_UNKNOWN, "Unknown / Unparseable / Erroneous Downlink Blocks" },
{ PCU_GSMTAP_C_UL_DUMMY, "Uplink Dummy Blocks" },