nitb/ctrl: Add ctrl command to set the TRX max_power_reduction
In case the BTS is connected the new attribute should be set through OML. This is left as a todo item. Addresses: SYS#267
This commit is contained in:
parent
ebe55aa95a
commit
d092f48648
|
@ -151,6 +151,27 @@ oom:
|
|||
}
|
||||
CTRL_CMD_DEFINE(net_mcc_mnc_apply, "mcc-mnc-apply");
|
||||
|
||||
/* TRX related commands below here */
|
||||
CTRL_HELPER_GET_INT(trx_max_power, struct gsm_bts_trx, max_power_red);
|
||||
CTRL_HELPER_SET_INT(trx_max_power, struct gsm_bts_trx, max_power_red);
|
||||
static int verify_trx_max_power(struct ctrl_cmd *cmd, const char *value, void *_data)
|
||||
{
|
||||
int tmp = atoi(value);
|
||||
|
||||
if (tmp < 0 || tmp > 22) {
|
||||
cmd->reply = "Value must be between 0 and 22";
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (tmp & 1) {
|
||||
cmd->reply = "Value must be even";
|
||||
return -1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
CTRL_CMD_DEFINE(trx_max_power, "max-power-reduction");
|
||||
|
||||
int bsc_base_ctrl_cmds_install(void)
|
||||
{
|
||||
int rc = 0;
|
||||
|
@ -161,5 +182,6 @@ int bsc_base_ctrl_cmds_install(void)
|
|||
rc |= ctrl_cmd_install(CTRL_NODE_ROOT, &cmd_net_apply_config);
|
||||
rc |= ctrl_cmd_install(CTRL_NODE_ROOT, &cmd_net_mcc_mnc_apply);
|
||||
|
||||
rc |= ctrl_cmd_install(CTRL_NODE_TRX, &cmd_trx_max_power);
|
||||
return rc;
|
||||
}
|
||||
|
|
|
@ -176,6 +176,26 @@ class TestCtrlBSC(TestCtrlBase):
|
|||
self.assertEquals(r['mtype'], 'ERROR')
|
||||
self.assertEquals(r['error'], 'Error while resolving object')
|
||||
|
||||
def testTrxPowerRed(self):
|
||||
r = self.do_get('bts.0.trx.0.max-power-reduction')
|
||||
self.assertEquals(r['mtype'], 'GET_REPLY')
|
||||
self.assertEquals(r['var'], 'bts.0.trx.0.max-power-reduction')
|
||||
self.assertEquals(r['value'], '20')
|
||||
|
||||
r = self.do_set('bts.0.trx.0.max-power-reduction', '22')
|
||||
self.assertEquals(r['mtype'], 'SET_REPLY')
|
||||
self.assertEquals(r['var'], 'bts.0.trx.0.max-power-reduction')
|
||||
self.assertEquals(r['value'], '22')
|
||||
|
||||
r = self.do_get('bts.0.trx.0.max-power-reduction')
|
||||
self.assertEquals(r['mtype'], 'GET_REPLY')
|
||||
self.assertEquals(r['var'], 'bts.0.trx.0.max-power-reduction')
|
||||
self.assertEquals(r['value'], '22')
|
||||
|
||||
r = self.do_set('bts.0.trx.0.max-power-reduction', '1')
|
||||
self.assertEquals(r['mtype'], 'ERROR')
|
||||
self.assertEquals(r['error'], 'Value must be even')
|
||||
|
||||
def testRfLock(self):
|
||||
r = self.do_get('bts.0.rf_state')
|
||||
self.assertEquals(r['mtype'], 'GET_REPLY')
|
||||
|
|
Loading…
Reference in New Issue