aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMax <msuraev@sysmocom.de>2018-11-19 14:05:04 +0100
committerMax <msuraev@sysmocom.de>2018-11-23 00:03:40 +0000
commit6f379baa9bef487f10439e2f7fc973473b4248ab (patch)
treebbfac9046bd292ec1d8e6b4c1868d70eeb62d1f4 /src
parent5188a31535aa5fabf26d6cce3d6a9bfea5f04023 (diff)
vty: add command to show TRX selectively
Add following commands showing only TRX with appropriate RSL link status: * show trx connected * show trx disconnected This simplifies troubleshooting of complex setup with multiple BTS with several TRX each. Change-Id: I48866ce311a3e2c63235f60a497efe97bbd05a4a
Diffstat (limited to 'src')
-rw-r--r--src/osmo-bsc/bsc_vty.c50
1 files changed, 46 insertions, 4 deletions
diff --git a/src/osmo-bsc/bsc_vty.c b/src/osmo-bsc/bsc_vty.c
index 4f18d4735..983dcb9b3 100644
--- a/src/osmo-bsc/bsc_vty.c
+++ b/src/osmo-bsc/bsc_vty.c
@@ -1079,8 +1079,14 @@ static int config_write_net(struct vty *vty)
return CMD_SUCCESS;
}
-static void trx_dump_vty(struct vty *vty, struct gsm_bts_trx *trx)
+static void trx_dump_vty(struct vty *vty, struct gsm_bts_trx *trx, bool print_rsl, bool show_connected)
{
+ if (show_connected && !trx->rsl_link)
+ return;
+
+ if (!show_connected && trx->rsl_link)
+ return;
+
vty_out(vty, "TRX %u of BTS %u is on ARFCN %u%s",
trx->nr, trx->bts->nr, trx->arfcn, VTY_NEWLINE);
vty_out(vty, "Description: %s%s",
@@ -1091,7 +1097,8 @@ static void trx_dump_vty(struct vty *vty, struct gsm_bts_trx *trx)
trx->nominal_power - trx->max_power_red, VTY_NEWLINE);
vty_out(vty, " NM State: ");
net_dump_nmstate(vty, &trx->mo.nm_state);
- vty_out(vty, " RSL State: %s%s", trx->rsl_link? "connected" : "disconnected", VTY_NEWLINE);
+ if (print_rsl)
+ vty_out(vty, " RSL State: %s%s", trx->rsl_link? "connected" : "disconnected", VTY_NEWLINE);
vty_out(vty, " Baseband Transceiver NM State: ");
net_dump_nmstate(vty, &trx->bb_transc.mo.nm_state);
if (is_ipaccess_bts(trx->bts)) {
@@ -1103,11 +1110,17 @@ static void trx_dump_vty(struct vty *vty, struct gsm_bts_trx *trx)
}
}
+static void trx_dump_vty_all(struct vty *vty, struct gsm_bts_trx *trx)
+{
+ trx_dump_vty(vty, trx, true, true);
+ trx_dump_vty(vty, trx, true, false);
+}
+
static inline void print_all_trx(struct vty *vty, const struct gsm_bts *bts)
{
uint8_t trx_nr;
for (trx_nr = 0; trx_nr < bts->num_trx; trx_nr++)
- trx_dump_vty(vty, gsm_bts_trx_num(bts, trx_nr));
+ trx_dump_vty_all(vty, gsm_bts_trx_num(bts, trx_nr));
}
DEFUN(show_trx,
@@ -1137,7 +1150,8 @@ DEFUN(show_trx,
VTY_NEWLINE);
return CMD_WARNING;
}
- trx_dump_vty(vty, gsm_bts_trx_num(bts, trx_nr));
+ trx_dump_vty_all(vty, gsm_bts_trx_num(bts, trx_nr));
+
return CMD_SUCCESS;
}
if (bts) {
@@ -1320,6 +1334,33 @@ static void meas_rep_dump_vty(struct vty *vty, struct gsm_meas_rep *mr,
meas_rep_dump_uni_vty(vty, &mr->ul, prefix, "ul");
}
+static inline void print_all_trx_ext(struct vty *vty, bool show_connected)
+{
+ struct gsm_network *net = gsmnet_from_vty(vty);
+ struct gsm_bts *bts = NULL;
+ uint8_t bts_nr;
+ for (bts_nr = 0; bts_nr < net->num_bts; bts_nr++) {
+ uint8_t trx_nr;
+ bts = gsm_bts_num(net, bts_nr);
+ for (trx_nr = 0; trx_nr < bts->num_trx; trx_nr++)
+ trx_dump_vty(vty, gsm_bts_trx_num(bts, trx_nr), false, show_connected);
+ }
+}
+
+DEFUN(show_trx_con,
+ show_trx_con_cmd,
+ "show trx (connected|disconnected)",
+ SHOW_STR "Display information about a TRX\n"
+ "Show TRX with RSL connected\n"
+ "Show TRX with RSL disconnected\n")
+{
+ if (!strcmp(argv[0], "connected"))
+ print_all_trx_ext(vty, true);
+ else
+ print_all_trx_ext(vty, false);
+
+ return CMD_SUCCESS;
+}
static void lchan_dump_full_vty(struct vty *vty, struct gsm_lchan *lchan)
{
@@ -4956,6 +4997,7 @@ int bsc_vty_init(struct gsm_network *network)
install_element_ve(&show_bts_cmd);
install_element_ve(&show_rejected_bts_cmd);
install_element_ve(&show_trx_cmd);
+ install_element_ve(&show_trx_con_cmd);
install_element_ve(&show_ts_cmd);
install_element_ve(&show_lchan_cmd);
install_element_ve(&show_lchan_summary_cmd);