diff options
author | Matan Perelman <matan1008@gmail.com> | 2023-04-25 21:24:12 +0300 |
---|---|---|
committer | Matan Perelman <matan1008@gmail.com> | 2023-04-25 23:36:43 +0300 |
commit | 986d06cda86b8db04d2ab68e892724fe56e99d5f (patch) | |
tree | ad2947729bdfc04d4823f8ed502be5886337d974 | |
parent | 1619a828254085cb66eeeff994ec662b352e359b (diff) |
ctrl: Add penalty time controlfeature/control-interface-penalty-time
Change-Id: Idfdd54dec72fb5f52eee22df018161d75b8c48c8
-rw-r--r-- | src/osmo-bsc/bts_ctrl.c | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/src/osmo-bsc/bts_ctrl.c b/src/osmo-bsc/bts_ctrl.c index a971fabcd..2dcbbc5d7 100644 --- a/src/osmo-bsc/bts_ctrl.c +++ b/src/osmo-bsc/bts_ctrl.c @@ -737,6 +737,65 @@ static int set_bts_cell_reselection_offset(struct ctrl_cmd *cmd, void *data) CTRL_CMD_DEFINE(bts_cell_reselection_offset, "cell-reselection-offset"); +static int verify_bts_penalty_time(struct ctrl_cmd *cmd, const char *value, void *_data) +{ + int penalty_time; + + if (strcmp(value, "reserved") == 0) + return 0; + + penalty_time = atoi(value); + + if (penalty_time < 20 || penalty_time > 620) { + cmd->reply = "Value is out of range"; + return 1; + } else if (penalty_time % 20 != 0) { + cmd->reply = "Value must be a multiple of 20"; + return 1; + } + + return 0; +} + +static int get_bts_penalty_time(struct ctrl_cmd *cmd, void *data) +{ + struct gsm_bts *bts = cmd->node; + + if (!bts->si_common.cell_ro_sel_par.present) { + cmd->reply = "0"; + return CTRL_CMD_REPLY; + } + + if (bts->si_common.cell_ro_sel_par.penalty_time == 31) { + cmd->reply = "reserved"; + return CTRL_CMD_REPLY; + } + + /* Calculate the penalty time in seconds */ + cmd->reply = talloc_asprintf(cmd, "%u", (bts->si_common.cell_ro_sel_par.penalty_time * 20) + 20); + if (!cmd->reply) { + cmd->reply = "OOM"; + return CTRL_CMD_ERROR; + } + + return CTRL_CMD_REPLY; +} + +static int set_bts_penalty_time(struct ctrl_cmd *cmd, void *data) +{ + struct gsm_bts *bts = cmd->node; + bts->si_common.cell_ro_sel_par.present = 1; + + if (strcmp(cmd->value, "reserved") == 0) + bts->si_common.cell_ro_sel_par.penalty_time = 31; + else + bts->si_common.cell_ro_sel_par.penalty_time = (atoi(cmd->value) - 20) / 20; + + return CTRL_CMD_REPLY; +} + +CTRL_CMD_DEFINE(bts_penalty_time, "penalty-time"); + int bsc_bts_ctrl_cmds_install(void) { int rc = 0; @@ -760,6 +819,7 @@ int bsc_bts_ctrl_cmds_install(void) rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_si2quater_neighbor_list_del_earfcn); rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_si2quater_neighbor_list_del_uarfcn); rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_cell_reselection_offset); + rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_penalty_time); rc |= neighbor_ident_ctrl_init(); |