From 4bfdfe7f70376612ad2343dd71e8b6ad52124ee6 Mon Sep 17 00:00:00 2001 From: Harald Welte Date: Wed, 10 Jun 2009 23:11:52 +0800 Subject: reworked MNCC codebase This is Harald's reworked MNCC base, slowly heading towards integration into master. The key changes are: * provide much more structure to the data in gsm_mncc * encode_* and decode_* functions now take a structure rather than tons of individual arguments (whose order nobody can remember) * make sure we don't have copies of the same code everywhere by introducing mncc_set_cause() and mncc_release_ind() * save horizontal screen space if possible * make sure we break lines > 80 characters --- openbsc/src/trau_mux.c | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) (limited to 'openbsc/src/trau_mux.c') diff --git a/openbsc/src/trau_mux.c b/openbsc/src/trau_mux.c index 96f858992..196d15fa7 100644 --- a/openbsc/src/trau_mux.c +++ b/openbsc/src/trau_mux.c @@ -145,6 +145,9 @@ int trau_mux_input(struct gsm_e1_subslot *src_e1_ss, u_int8_t trau_bits_out[TRAU_FRAME_BITS]; struct gsm_e1_subslot *dst_e1_ss = lookup_trau_mux_map(src_e1_ss); struct subch_mux *mx; + struct upqueue_entry *ue; + struct msgb *msg; + struct gsm_trau_frame *frame; int rc; /* decode TRAU, change it to downlink, re-encode */ @@ -152,8 +155,23 @@ int trau_mux_input(struct gsm_e1_subslot *src_e1_ss, if (rc) return rc; - if (!dst_e1_ss) - return -EINVAL; + if (!dst_e1_ss) { + /* frame shall be sent to upqueue */ + if (!(ue = lookup_trau_upqueue(src_e1_ss))) + return -EINVAL; + if (!ue->callref) + return -EINVAL; + msg = msgb_alloc(sizeof(struct gsm_trau_frame) + sizeof(tf)); + if (!msg) + return -ENOMEM; + frame = (struct gsm_trau_frame *)msg->data; + frame->msg_type = GSM_TRAU_FRAME; + frame->callref = ue->callref; + memcpy(frame->data, &tf, sizeof(tf)); + msgb_enqueue(&ue->net->upqueue, msg); + + return 0; + } mx = e1inp_get_mux(dst_e1_ss->e1_nr, dst_e1_ss->e1_ts); if (!mx) -- cgit v1.2.3