Fixed descriptions of VTY interface commands.
[osmocom-bb.git] / src / host / layer23 / src / app_mobile.c
index 1cf62ed..46e0e06 100644 (file)
@@ -35,6 +35,7 @@
 #include <osmocom/gsmtap_util.h>
 #include <osmocom/logging.h>
 #include <osmocom/telnet_interface.h>
+#include <osmocom/file.h>
 
 #include <osmocore/msgb.h>
 #include <osmocore/talloc.h>
@@ -42,6 +43,7 @@
 #include <osmocore/signal.h>
 
 extern struct log_target *stderr_target;
+static const char *config_file = "osmocom.cfg";
 
 static int started = 0;
 
@@ -85,11 +87,9 @@ static int signal_cb(unsigned int subsys, unsigned int signal,
                }
                started = 1;
                ms = signal_data;
-               gsm_subscr_testcard(ms, 1, 1, "0000000000");
-//             ms->subscr.plmn_valid = 1;
-               ms->subscr.plmn_mcc = 262;
-               ms->subscr.plmn_mnc = 2;
-               ms->plmn.mode = PLMN_MODE_MANUAL;
+               /* insert test card, if enabled */
+               if (ms->settings.simtype == GSM_SIM_TYPE_TEST)
+                       gsm_subscr_testcard(ms);
                /* start PLMN + cell selection process */
                nmsg = gsm322_msgb_alloc(GSM322_EVENT_SWITCH_ON);
                if (!nmsg)
@@ -137,9 +137,13 @@ int mobile_exit(struct osmocom_ms *ms)
 
 int l23_app_init(struct osmocom_ms *ms)
 {
-       log_parse_category_mask(stderr_target, "DCS:DPLMN:DRR:DMM:DCC:DMNCC:DPAG");
+       int rc;
+
+       log_parse_category_mask(stderr_target, "DRSL:DLAPDM:DCS:DPLMN:DRR:DMM:DCC:DMNCC:DPAG");
 
        srand(time(NULL));
+
+       gsm_settings_init(ms);
        gsm48_cc_init(ms);
        gsm_support_init(ms);
        gsm_subscr_init(ms);
@@ -148,11 +152,22 @@ int l23_app_init(struct osmocom_ms *ms)
        INIT_LLIST_HEAD(&ms->trans_list);
        ms->cclayer.mncc_recv = mncc_recv_dummy;
        gsm322_init(ms);
+
        l23_app_work = mobile_work;
        register_signal_handler(SS_L1CTL, &signal_cb, NULL);
        l23_app_exit = mobile_exit;
 
        telnet_init(ms, 4242);
+       rc = vty_read_config_file(config_file);
+       if (rc < 0) {
+               fprintf(stderr, "Failed to parse the config file: '%s'\n",
+                       config_file);
+               fprintf(stderr, "Please check or create config file using: "
+                       "'touch %s%s'\n", OSMOCOM_CONFDIR, config_file);
+               return rc;
+       }
+
+       gsm_random_imei(&ms->settings);
 
        return 0;
 }