aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHarald Welte <laforge@gnumonks.org>2010-12-23 01:31:07 +0100
committerHarald Welte <laforge@gnumonks.org>2010-12-26 10:01:42 +0100
commit28ad6611e69ce11084b8f3daf8183a57f694166e (patch)
tree7ee0c9e93a4635230db428d78c2207de9b4fc9cc
parente2c63c46f16aadd1f89791cd22e6a5170605fbb5 (diff)
MNCC: Introduce bsc_hack argument '-m' for enabling MNCC socket
-rw-r--r--openbsc/src/bsc_hack.c16
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());