diff options
author | Holger Hans Peter Freyther <zecke@selfish.org> | 2010-04-26 16:02:04 +0800 |
---|---|---|
committer | Holger Hans Peter Freyther <zecke@selfish.org> | 2010-12-21 13:53:41 +0100 |
commit | d85642a1a7dc52a9618c56402ad85ee5f0739d0e (patch) | |
tree | c2181ee6697342c78cedf41949c2522e231c5a2c /openbsc/src/input | |
parent | 6f615551a402ea87843077e3d79d16251d53f078 (diff) |
ts Make the e1inp_ts delay configurable
Currently the nanoBTS bootstrap code requires a high delay
otherwise we are not bringing the device up properly. Changing
the init code turns out harder than it seems like. So this is
a workaround for that to allow a high speed RSL/OML connection
after the bringup.
The line driver can have a default TS delay. It is set to the
current default for the nanoBTS and the BS11. For the ipaccess
case we will set the delay lower for the RSL connection and
inside the ipaccess-config we can set it low right away to
have fast firmware flashing and such.
Diffstat (limited to 'openbsc/src/input')
-rw-r--r-- | openbsc/src/input/ipaccess.c | 4 | ||||
-rw-r--r-- | openbsc/src/input/misdn.c | 3 |
2 files changed, 5 insertions, 2 deletions
diff --git a/openbsc/src/input/ipaccess.c b/openbsc/src/input/ipaccess.c index 18268f6b9..03eba8b4d 100644 --- a/openbsc/src/input/ipaccess.c +++ b/openbsc/src/input/ipaccess.c @@ -282,6 +282,7 @@ static int ipaccess_rcvmsg(struct e1inp_line *line, struct msgb *msg, trx->rsl_link = e1inp_sign_link_create(e1i_ts, E1INP_SIGN_RSL, trx, trx->rsl_tei, 0); + trx->rsl_link->ts->sign.delay = 10; /* get rid of our old temporary bfd */ memcpy(newbfd, bfd, sizeof(*newbfd)); @@ -589,7 +590,7 @@ static int handle_ts1_write(struct bsc_fd *bfd) e1i_ts->sign.tx_timer.data = e1i_ts; /* Reducing this might break the nanoBTS 900 init. */ - bsc_schedule_timer(&e1i_ts->sign.tx_timer, 0, 100000); + bsc_schedule_timer(&e1i_ts->sign.tx_timer, 0, e1i_ts->sign.delay); return ret; } @@ -622,6 +623,7 @@ static int ipaccess_fd_cb(struct bsc_fd *bfd, unsigned int what) struct e1inp_driver ipaccess_driver = { .name = "ip.access", .want_write = ts_want_write, + .default_delay = 100000, }; /* callback of the OML listening filedescriptor */ diff --git a/openbsc/src/input/misdn.c b/openbsc/src/input/misdn.c index fa8aca02c..b36bdf8b2 100644 --- a/openbsc/src/input/misdn.c +++ b/openbsc/src/input/misdn.c @@ -247,7 +247,7 @@ static int handle_ts1_write(struct bsc_fd *bfd) /* set tx delay timer for next event */ e1i_ts->sign.tx_timer.cb = timeout_ts1_write; e1i_ts->sign.tx_timer.data = e1i_ts; - bsc_schedule_timer(&e1i_ts->sign.tx_timer, 0, 50000); + bsc_schedule_timer(&e1i_ts->sign.tx_timer, 0, e1i_ts->sign.delay); return ret; } @@ -387,6 +387,7 @@ static int activate_bchan(struct e1inp_line *line, int ts, int act) struct e1inp_driver misdn_driver = { .name = "mISDNuser", .want_write = ts_want_write, + .default_delay = 50000, }; static int mi_e1_setup(struct e1inp_line *line, int release_l2) |