diff options
author | Harald Welte <laforge@gnumonks.org> | 2010-12-23 01:31:07 +0100 |
---|---|---|
committer | Harald Welte <laforge@gnumonks.org> | 2010-12-26 10:01:42 +0100 |
commit | 28ad6611e69ce11084b8f3daf8183a57f694166e (patch) | |
tree | 7ee0c9e93a4635230db428d78c2207de9b4fc9cc | |
parent | e2c63c46f16aadd1f89791cd22e6a5170605fbb5 (diff) |
MNCC: Introduce bsc_hack argument '-m' for enabling MNCC socket
-rw-r--r-- | openbsc/src/bsc_hack.c | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/openbsc/src/bsc_hack.c b/openbsc/src/bsc_hack.c index 4adf9f9c7..477a7a380 100644 --- a/openbsc/src/bsc_hack.c +++ b/openbsc/src/bsc_hack.c @@ -49,6 +49,7 @@ static const char *database_name = "hlr.sqlite3"; static const char *config_file = "openbsc.cfg"; extern const char *openbsc_copyright; static int daemonize = 0; +static int use_mncc_sock = 0; /* timer to store statistics */ #define DB_SYNC_INTERVAL 60, 0 @@ -91,6 +92,7 @@ static void print_help() printf(" -V --version. Print the version of OpenBSC.\n"); printf(" -P --rtp-proxy Enable the RTP Proxy code inside OpenBSC\n"); printf(" -e --log-level number. Set a global loglevel.\n"); + printf(" -m --mncc-sock Disable built-in MNCC handler and offer socket\n"); } static void handle_options(int argc, char **argv) @@ -110,10 +112,11 @@ static void handle_options(int argc, char **argv) {"version", 0, 0, 'V' }, {"rtp-proxy", 0, 0, 'P'}, {"log-level", 1, 0, 'e'}, + {"mncc-sock", 0, 0, 'm'}, {0, 0, 0, 0} }; - c = getopt_long(argc, argv, "hd:Dsl:ar:p:TPVc:e:", + c = getopt_long(argc, argv, "hd:Dsl:ar:p:TPVc:e:m", long_options, &option_index); if (c == -1) break; @@ -150,6 +153,9 @@ static void handle_options(int argc, char **argv) case 'e': log_set_log_level(stderr_target, atoi(optarg)); break; + case 'm': + use_mncc_sock = 1; + break; case 'V': print_version(1); exit(0); @@ -243,7 +249,13 @@ int main(int argc, char **argv) /* parse options */ handle_options(argc, argv); - rc = bsc_bootstrap_network(int_mncc_recv, config_file); + /* internal MNCC handler or MNCC socket? */ + if (use_mncc_sock) { + rc = bsc_bootstrap_network(mncc_sock_from_cc, config_file); + if (rc >= 0) + mncc_sock_init(bsc_gsmnet); + } else + rc = bsc_bootstrap_network(int_mncc_recv, config_file); if (rc < 0) exit(1); bsc_api_init(bsc_gsmnet, msc_bsc_api()); |