matanp has uploaded this change for review. (
https://gerrit.osmocom.org/c/osmo-bsc/+/32761 )
Change subject: ctrl: Add setting SI5 neighbor list
......................................................................
ctrl: Add setting SI5 neighbor list
Change-Id: I1bab242cdbd0d7b39636d69027bf75794a5d5ba7
---
M src/osmo-bsc/bts_ctrl.c
1 file changed, 60 insertions(+), 12 deletions(-)
git pull ssh://gerrit.osmocom.org:29418/osmo-bsc refs/changes/61/32761/1
diff --git a/src/osmo-bsc/bts_ctrl.c b/src/osmo-bsc/bts_ctrl.c
index b6a2396..353af7f 100644
--- a/src/osmo-bsc/bts_ctrl.c
+++ b/src/osmo-bsc/bts_ctrl.c
@@ -568,10 +568,8 @@
return 0;
}
-static int set_bts_neighbor_list_add_del(struct ctrl_cmd *cmd, void *data, bool add)
+static int set_bts_neighbor_list_add_del(struct ctrl_cmd *cmd, void *data, bool add,
struct bitvec *neigh_list)
{
- struct gsm_bts *bts = cmd->node;
- struct bitvec *bv = &bts->si_common.neigh_list;
int arfcn_int;
uint16_t arfcn;
enum gsm_band unused;
@@ -582,20 +580,15 @@
}
arfcn = (uint16_t) arfcn_int;
- if (bts->neigh_list_manual_mode == NL_MODE_AUTOMATIC) {
- cmd->reply = "Neighbor list not in manual mode";
- return CTRL_CMD_ERROR;
- }
-
if (gsm_arfcn2band_rc(arfcn, &unused) < 0) {
cmd->reply = "Invalid arfcn detected";
return CTRL_CMD_ERROR;
}
if (add)
- bitvec_set_bit_pos(bv, arfcn, 1);
+ bitvec_set_bit_pos(neigh_list, arfcn, 1);
else
- bitvec_set_bit_pos(bv, arfcn, 0);
+ bitvec_set_bit_pos(neigh_list, arfcn, 0);
cmd->reply = "OK";
return CTRL_CMD_REPLY;
@@ -608,7 +601,12 @@
static int set_bts_neighbor_list_add(struct ctrl_cmd *cmd, void *data)
{
- return set_bts_neighbor_list_add_del(cmd, data, true);
+ struct gsm_bts *bts = cmd->node;
+ if (bts->neigh_list_manual_mode == NL_MODE_AUTOMATIC) {
+ cmd->reply = "Neighbor list not in manual mode";
+ return CTRL_CMD_ERROR;
+ }
+ return set_bts_neighbor_list_add_del(cmd, data, true,
&bts->si_common.neigh_list);
}
CTRL_CMD_DEFINE_WO(bts_neighbor_list_add, "neighbor-list add");
@@ -620,11 +618,50 @@
static int set_bts_neighbor_list_del(struct ctrl_cmd *cmd, void *data)
{
- return set_bts_neighbor_list_add_del(cmd, data, false);
+ struct gsm_bts *bts = cmd->node;
+ if (bts->neigh_list_manual_mode == NL_MODE_AUTOMATIC) {
+ cmd->reply = "Neighbor list not in manual mode";
+ return CTRL_CMD_ERROR;
+ }
+ return set_bts_neighbor_list_add_del(cmd, data, false,
&bts->si_common.neigh_list);
}
CTRL_CMD_DEFINE_WO(bts_neighbor_list_del, "neighbor-list del");
+static int verify_bts_neighbor_list_si5_add(struct ctrl_cmd *cmd, const char *value, void
*_data)
+{
+ return verify_bts_neighbor_list_add_del(cmd, value, _data);
+}
+
+static int set_bts_neighbor_list_si5_add(struct ctrl_cmd *cmd, void *data)
+{
+ struct gsm_bts *bts = cmd->node;
+ if (bts->neigh_list_manual_mode != NL_MODE_MANUAL_SI5SEP) {
+ cmd->reply = "Neighbor list not in manual mode with separate SI5";
+ return CTRL_CMD_ERROR;
+ }
+ return set_bts_neighbor_list_add_del(cmd, data, true,
&bts->si_common.si5_neigh_list);
+}
+
+CTRL_CMD_DEFINE_WO(bts_neighbor_list_si5_add, "neighbor-list si5-add");
+
+static int verify_bts_neighbor_list_si5_del(struct ctrl_cmd *cmd, const char *value, void
*_data)
+{
+ return verify_bts_neighbor_list_add_del(cmd, value, _data);
+}
+
+static int set_bts_neighbor_list_si5_del(struct ctrl_cmd *cmd, void *data)
+{
+ struct gsm_bts *bts = cmd->node;
+ if (bts->neigh_list_manual_mode != NL_MODE_MANUAL_SI5SEP) {
+ cmd->reply = "Neighbor list not in manual mode with separate SI5";
+ return CTRL_CMD_ERROR;
+ }
+ return set_bts_neighbor_list_add_del(cmd, data, false,
&bts->si_common.si5_neigh_list);
+}
+
+CTRL_CMD_DEFINE_WO(bts_neighbor_list_si5_del, "neighbor-list si5-del");
+
static int verify_bts_neighbor_list_mode(struct ctrl_cmd *cmd, const char *value, void
*_data)
{
if (!strcmp(value, "automatic"))
@@ -1022,6 +1059,8 @@
rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_si5);
rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_add);
rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_del);
+ rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_si5_add);
+ rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_si5_del);
rc |= ctrl_cmd_install(CTRL_NODE_BTS, &cmd_bts_neighbor_list_mode);
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);
--
To view, visit
https://gerrit.osmocom.org/c/osmo-bsc/+/32761
To unsubscribe, or for help writing mail filters, visit
https://gerrit.osmocom.org/settings
Gerrit-Project: osmo-bsc
Gerrit-Branch: master
Gerrit-Change-Id: I1bab242cdbd0d7b39636d69027bf75794a5d5ba7
Gerrit-Change-Number: 32761
Gerrit-PatchSet: 1
Gerrit-Owner: matanp <matan1008(a)gmail.com>
Gerrit-MessageType: newchange