diff options
author | Andreas Eversberg <jolly@eversberg.eu> | 2013-12-11 16:13:28 +0100 |
---|---|---|
committer | Andreas Eversberg <jolly@eversberg.eu> | 2016-09-25 08:11:43 +0200 |
commit | 1f102e49d91974760e6603858d193cd37d85cef2 (patch) | |
tree | 25b389a56ceaa4ebea50b8041509d0466f63b2e1 /src/host/layer23/src/mobile/vty_interface.c | |
parent | 6188bdc5481a936a66b7c03e29e53c78a3ba62e7 (diff) |
[WIP] HO: VTY test option to fake a better neighbor cell to force handover
The handover is forced by reporting perfect measurement results of a given
neighbor cell. All other neighbor cells and the serving cell is reported as
poor. The falke report will sustain until the connection is released or a
new 'better' cell is specified.
Diffstat (limited to 'src/host/layer23/src/mobile/vty_interface.c')
-rw-r--r-- | src/host/layer23/src/mobile/vty_interface.c | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/src/host/layer23/src/mobile/vty_interface.c b/src/host/layer23/src/mobile/vty_interface.c index eda181a9..1b6f3a5d 100644 --- a/src/host/layer23/src/mobile/vty_interface.c +++ b/src/host/layer23/src/mobile/vty_interface.c @@ -967,8 +967,11 @@ DEFUN(service, service_cmd, "service MS_NAME (*#06#|*#21#|*#67#|*#61#|*#62#" return CMD_SUCCESS; } +#define TEST_STR "Test functions\n" + DEFUN(test_reselection, test_reselection_cmd, "test re-selection NAME", - "Manually trigger cell re-selection\nName of MS (see \"show ms\")") + TEST_STR "Manually trigger cell re-selection\n" + "Name of MS (see \"show ms\")") { struct osmocom_ms *ms; struct gsm_settings *set; @@ -994,6 +997,38 @@ DEFUN(test_reselection, test_reselection_cmd, "test re-selection NAME", return CMD_SUCCESS; } +DEFUN(test_handover, test_handover_cmd, "test handover NAME <0-1024> [pcs]", + TEST_STR "Force handover by faking measurement report\n" + "Name of MS (see \"show ms\")\nARFCN to be reported best cell\n" + "Given frequency is PCS band (1900) rather than DCS band.") +{ + struct osmocom_ms *ms; + uint16_t arfcn = atoi(argv[1]); + const char *err_msg; + + ms = get_ms(argv[0], vty); + if (!ms) + return CMD_WARNING; + + if (argc > 2) { + if (arfcn < 512 || arfcn > 810) { + vty_out(vty, "Given ARFCN not in PCS band%s", + VTY_NEWLINE); + return CMD_WARNING; + } + arfcn |= ARFCN_PCS; + } + + err_msg = gsm48_rr_force_handover(ms, arfcn); + if (err_msg) { + vty_out(vty, "Cannot force handover: %s%s", err_msg, + VTY_NEWLINE); + return CMD_WARNING; + } + + return CMD_SUCCESS; +} + DEFUN(delete_forbidden_plmn, delete_forbidden_plmn_cmd, "delete forbidden plmn NAME MCC MNC", "Delete\nForbidden\nplmn\nName of MS (see \"show ms\")\n" @@ -2852,6 +2887,7 @@ int ms_vty_init(void) install_element(ENABLE_NODE, &sms_cmd); install_element(ENABLE_NODE, &service_cmd); install_element(ENABLE_NODE, &test_reselection_cmd); + install_element(ENABLE_NODE, &test_handover_cmd); install_element(ENABLE_NODE, &delete_forbidden_plmn_cmd); #ifdef _HAVE_GPSD |