This is merely a historical archive of years 2008-2021, before the migration to mailman3.
A maintained and still updated list archive can be found at https://lists.osmocom.org/hyperkitty/list/OpenBSC@lists.osmocom.org/.
Holger Hans Peter Freyther holger at freyther.deOn Thu, Dec 13, 2012 at 10:14:27PM +0100, Tobias Engel wrote: > It was, but not in msc_compl_l3. It was/is also accessed in > msc_release_connection, but before calling gsm0808_clear, so that is not > a problem. Sorry, I didn't read it carefully enough. I prepared a very simple testcase and it is crashing the the NITB. I will apply a patch like the one below and the rule would be that msc_release_connection may only be called from a timer or from the trans_free command. The test case is attached to this email. diff --git a/openbsc/src/libmsc/gsm_04_08.c b/openbsc/src/libmsc/gsm_04_08.c index 9816174..fd482e0 100644 --- a/openbsc/src/libmsc/gsm_04_08.c +++ b/openbsc/src/libmsc/gsm_04_08.c @@ -965,7 +965,6 @@ static int gsm48_rx_mm_imsi_detach_ind(struct gsm_subscriber_connection *co * imagine an IMSI DETACH happening during an active call! */ release_anchor(conn); - msc_release_connection(conn); return 0; } -------------- next part -------------- " (C) 2012 by Holger Hans Peter Freyther All Rights Reserved This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. " PackageLoader fileInPackage: #FakeBTS. FakeBTS.OpenBSCTest subclass: IMSIDetach [ <import: OsmoGSM> startTest [ "1. Connect to the BTS" self createAndConnectBTS: '1801/0/0'. self testIMSIDetach. ] testIMSIDetach [ | lchan detach tmsi | tmsi := self allocateTmsi: '901010000001111'. "2. Get a LCHAN" lchan := self requireAnyChannel. "3. Send a IMSI Detach" detach := GSM48IMSIDetachInd new. detach mi tmsi: tmsi. lchan sendGSM: detach toMessage. "Wait for the channel to be released.." [ | msg | "Read all messages until the end on SAPI=0. Ignore SAPI=3" "If we send another SAPI=3 Release Indication we get a double RF Channel Release from the NITB." [ msg := GSM48MSG decode: lchan nextSapi0Msg readStream. (msg isKindOf: GSM48RRChannelRelease) ifTrue: [lchan releaseAllSapis. ^true] ] on: Exception do: [Transcript nextPutAll: 'GSM decoding error'; nl.]. ] repeat. ] ] Eval [ | test | test := IMSIDetach new startTest; stopBts; yourself. ]