Change in osmo-ttcn3-hacks[master]: bts: Add tests for CBCH LOAD IND (underflow, overflow)

Harald Welte gerrit-no-reply at lists.osmocom.org
Tue May 21 14:42:09 UTC 2019


Harald Welte has submitted this change and it was merged. ( https://gerrit.osmocom.org/14116 )

Change subject: bts: Add tests for CBCH LOAD IND (underflow, overflow)
......................................................................

bts: Add tests for CBCH LOAD IND (underflow, overflow)

Change-Id: Ia0a82771ba2912ef06fb0d9ee0816e8150701005
Related: OS#4011
---
M bts/BTS_Tests_SMSCB.ttcn
M library/RSL_Types.ttcn
2 files changed, 251 insertions(+), 5 deletions(-)

Approvals:
  Jenkins Builder: Verified
  Harald Welte: Looks good to me, approved



diff --git a/bts/BTS_Tests_SMSCB.ttcn b/bts/BTS_Tests_SMSCB.ttcn
index ac7ec9f..801a5fc 100644
--- a/bts/BTS_Tests_SMSCB.ttcn
+++ b/bts/BTS_Tests_SMSCB.ttcn
@@ -19,6 +19,7 @@
 import from L1CTL_PortType all;
 import from L1CTL_Types all;
 import from LAPDm_Types all;
+import from IPA_Emulation all;
 
 import from RSL_Types all;
 
@@ -186,13 +187,10 @@
 		RSL_CCHAN.send(ts_RSL_UD(rsl));
 	}
 }
-private function f_smscb_setup(inout CbchTestPars pars) runs on test_CT {
 
-	f_cbch_compute_exp_blocks(pars);
+private function f_vty_cbch_setup(boolean use_sdcch4 := true) runs on test_CT {
 
-	f_init_vty_bsc();
-	/* ensure that a CBCH is present in channel combination */
-	if (pars.use_sdcch4) {
+	if (use_sdcch4 == true) {
 		f_vty_config2(BSCVTY, {"network", "bts 0", "trx 0", "timeslot 0"},
 					"phys_chan_config CCCH+SDCCH4+CBCH");
 		f_vty_config2(BSCVTY, {"network", "bts 0", "trx 0", "timeslot 6"},
@@ -205,6 +203,14 @@
 	}
 	f_vty_transceive(BSCVTY, "drop bts connection 0 oml");
 	f_sleep(2.0);
+}
+private function f_smscb_setup(inout CbchTestPars pars) runs on test_CT {
+
+	f_cbch_compute_exp_blocks(pars);
+
+	f_init_vty_bsc();
+	/* ensure that a CBCH is present in channel combination */
+	f_vty_cbch_setup(pars.use_sdcch4);
 	f_init(testcasename());
 
 	f_init_l1ctl();
@@ -687,6 +693,174 @@
 	Misc_Helpers.f_shutdown(__BFILE__, __LINE__, pass);
 }
 
+/* Verify there are no CBCH load indications if no CBCH is present */
+testcase TC_cbch_load_idle_no_cbch() runs on test_CT {
+	var ASP_RSL_Unitdata rx_ud;
+	timer T := 10.0;
+
+	f_init(testcasename());
+	f_init_vty_bsc();
+
+	T.start;
+	alt {
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_BASIC)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_EXTD)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive { repeat; }
+	[] T.timeout {
+		setverdict(pass);
+		}
+	}
+	Misc_Helpers.f_shutdown(__BFILE__, __LINE__);
+}
+
+/* Verify the CBCH load indications of an idle cell (without CBCH load) */
+function f_TC_cbc_load_idle() runs on test_CT {
+	template integer tr_slot_count := (2 .. 15);
+	const integer min_load_ind := 4;
+	var integer basic_count := 0;
+	var integer extd_count := 0;
+	var ASP_RSL_Unitdata rx_ud;
+	timer T := 10.0;
+
+	f_init(testcasename());
+
+	RSL_CCHAN.clear;
+	T.start;
+	alt {
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_BASIC(false, tr_slot_count))) {
+		basic_count := basic_count + 1;
+		repeat;
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_EXTD(false, tr_slot_count))) -> value rx_ud {
+		extd_count := extd_count + 1;
+		repeat;
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_BASIC)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_EXTD)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive { repeat; }
+	[] T.timeout {
+		if ((basic_count >= min_load_ind) and (extd_count >= min_load_ind)) {
+			setverdict(pass);
+		} else {
+			setverdict(fail, "Insufficient number of CBCH LOAD IND: ",
+				   "BASIC=", basic_count, " EXTD=", extd_count);
+		}
+		}
+	}
+	f_smscb_cleanup();
+	Misc_Helpers.f_shutdown(__BFILE__, __LINE__);
+}
+testcase TC_cbc_sdcch4_load_idle() runs on test_CT {
+	f_init_vty_bsc();
+	f_vty_cbch_setup(use_sdcch4 := true);
+	f_TC_cbc_load_idle();
+}
+testcase TC_cbc_sdcch8_load_idle() runs on test_CT {
+	f_init_vty_bsc();
+	f_vty_cbch_setup(use_sdcch4 := false);
+	f_TC_cbc_load_idle();
+}
+
+/* Verify CBCH overload indications are sent when sending too many SMS CB CMD */
+function f_TC_cbc_load_overload(CbchTestPars pars) runs on test_CT {
+	template integer tr_slot_count_basic := (11 .. 13);
+	template integer tr_slot_count_extd := (2 .. 15);
+	const integer min_load_ind := 4;
+	var integer basic_count := 0;
+	var integer extd_count := 0;
+	var ASP_RSL_Unitdata rx_ud;
+	timer T_total := 10.0;
+	timer T_retransmit := 0.2;
+	timer T_initial_guard := 2.0;
+	var integer i;
+
+	f_init(testcasename());
+
+	/* send tons of SMSCB Command */
+	for (i := 0; i < 30; i := i+1) {
+		f_smscb_setup_rsl_chan(pars.basic);
+	}
+
+	/* keep sending SMSCB Commands for another two seconds */
+	T_initial_guard.start;
+	T_retransmit.start;
+	alt {
+	[] T_retransmit.timeout {
+		f_smscb_setup_rsl_chan(pars.basic);
+		T_retransmit.start;
+		repeat;
+		}
+	[] T_initial_guard.timeout { }
+	}
+	/* clear any pending messages (where load may not have peaked yet) */
+	RSL_CCHAN.clear;
+
+	/* keep sending SMSCB Commands while verifying LOAD INDICATIONS */
+	T_total.start;
+	T_retransmit.start;
+	alt {
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_BASIC(true, tr_slot_count_basic))) {
+		basic_count := basic_count + 1;
+		repeat;
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_EXTD(false, tr_slot_count_extd))) {
+		extd_count := extd_count + 1;
+		repeat;
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_BASIC)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive(tr_RSL_UD(tr_RSL_CBCH_LOAD_IND_EXTD)) -> value rx_ud {
+		setverdict(fail, "Received unexpected CBCH LOAD IND: ", rx_ud);
+		}
+	[] RSL_CCHAN.receive { repeat; }
+	[] T_retransmit.timeout {
+		f_smscb_setup_rsl_chan(pars.basic);
+		T_retransmit.start;
+		repeat;
+		}
+	[] T_total.timeout {
+		if ((basic_count >= min_load_ind) and (extd_count >= min_load_ind)) {
+			setverdict(pass);
+		} else {
+			setverdict(fail, "Insufficient number of CBCH LOAD IND: ",
+				   "BASIC=", basic_count, " EXTD=", extd_count);
+		}
+		}
+	}
+	f_smscb_cleanup();
+	Misc_Helpers.f_shutdown(__BFILE__, __LINE__);
+}
+testcase TC_cbc_sdcch4_load_overload() runs on test_CT {
+	var CbchTestPars pars := {
+		use_sdcch4 := true,
+		basic := valueof(t_CbchPC(msgs_1m_3b_norm)),
+		extended := omit
+	};
+
+	f_init_vty_bsc();
+	f_vty_cbch_setup(use_sdcch4 := true);
+	f_TC_cbc_load_overload(pars);
+}
+testcase TC_cbc_sdcch8_load_overload() runs on test_CT {
+	var CbchTestPars pars := {
+		use_sdcch4 := true,
+		basic := valueof(t_CbchPC(msgs_1m_3b_norm)),
+		extended := omit
+	};
+
+	f_init_vty_bsc();
+	f_vty_cbch_setup(use_sdcch4 := true);
+	f_TC_cbc_load_overload(pars);
+}
 
 
 /* SMSCB TODO:
@@ -696,6 +870,8 @@
  */
 
 control {
+	execute( TC_cbch_load_idle_no_cbch() );
+
 	execute( TC_sms_cb_cmd_sdcch4_1block() );
 	execute( TC_sms_cb_cmd_sdcch4_2block() );
 	execute( TC_sms_cb_cmd_sdcch4_3block() );
@@ -705,6 +881,9 @@
 	execute( TC_sms_cb_cmd_sdcch4_default_only() );
 	execute( TC_sms_cb_cmd_sdcch4_default_and_normal() );
 	execute( TC_sms_cb_cmd_sdcch4_default_then_null() );
+	execute( TC_cbc_sdcch4_load_idle() );
+	execute( TC_cbc_sdcch4_load_overload() );
+
 	if (false) { /* FIXME: SDCCH/8 support broken, needs trxcon + L1CTL work */
 	execute( TC_sms_cb_cmd_sdcch8_1block() );
 	execute( TC_sms_cb_cmd_sdcch8_2block() );
@@ -714,6 +893,8 @@
 	execute( TC_sms_cb_cmd_sdcch8_schedule() );
 	execute( TC_sms_cb_cmd_sdcch8_default_only() );
 	execute( TC_sms_cb_cmd_sdcch8_default_and_normal() );
+	execute( TC_cbc_sdcch8_load_idle() );
+	execute( TC_cbc_sdcch8_load_overload() );
 	}
 }
 
diff --git a/library/RSL_Types.ttcn b/library/RSL_Types.ttcn
index 74de46a..bfa0af4 100644
--- a/library/RSL_Types.ttcn
+++ b/library/RSL_Types.ttcn
@@ -658,6 +658,24 @@
 		last_block := last_block
 	}
 
+	/* 9.4.43 CBCH Load Information */
+	type record RSL_IE_CbchLoadInfo {
+		boolean		overflow,
+		BIT3		spare,
+		uint4_t		slot_count
+	};
+	template RSL_IE_CbchLoadInfo tr_CbchLoadInfo(template boolean overflow,
+					    template uint4_t slot_count) := {
+		overflow := overflow,
+		spare := ?,
+		slot_count := slot_count
+	}
+	template (value) RSL_IE_CbchLoadInfo ts_CbchLoadInfo(boolean overflow, uint4_t slot_count) := {
+		overflow := overflow,
+		spare := '000'B,
+		slot_count := slot_count
+	}
+
 	/* 9.3.53 */
 	type record RSL_IE_MultirateCtrl {
 		uint3_t		spare,
@@ -762,6 +780,7 @@
 		RSL_IE_ChanNeeded	chan_needed,
 		RSL_IE_CbCommandType	cb_cmd_type,
 		RSL_LV			smscb_message,
+		RSL_IE_CbchLoadInfo	cbch_load_info,
 		RSL_SacchInfo		sacch_info,
 
 		RSL_IE_StartingTime	starting_time,
@@ -816,6 +835,7 @@
 					chan_needed, iei = RSL_IE_CHAN_NEEDED;
 					cb_cmd_type, iei = RSL_IE_CB_CMD_TYPE;
 					smscb_message, iei = RSL_IE_SMSCB_MSG;
+					cbch_load_info, iei = RSL_IE_CBCH_LOAD_INFO;
 					sacch_info, iei = RSL_IE_SACCH_INFO;
 					starting_time, iei = RSL_IE_STARTNG_TIME;
 					encr_info, iei = RSL_IE_ENCR_INFO;
@@ -1600,6 +1620,51 @@
 		}
 	}
 
+	/* 8.5.9 BTS -> BSC CBCH LOAD INDICATION */
+	template RSL_Message tr_RSL_CBCH_LOAD_IND_BASIC(template boolean overflow := ?,
+							template uint4_t slot_count := ?,
+							template RslChannelNr chan_nr := ?) := {
+		msg_disc := tr_RSL_MsgDisc(RSL_MDISC_CCHAN, false),
+		msg_type := RSL_MT_CBCH_LOAD_IND,
+		ies := {
+			tr_RSL_IE(RSL_IE_Body:{chan_nr := chan_nr}),
+			tr_RSL_IE(RSL_IE_Body:{cbch_load_info := tr_CbchLoadInfo(overflow, slot_count)})
+		}
+	}
+	template (value) RSL_Message ts_RSL_CBCH_LOAD_IND_BASIC(boolean overflow, uint4_t slot_count,
+								template (value) RslChannelNr chan_nr :=
+									ts_RslChanNr_SDCCH4(0, 2)) := {
+		msg_disc := ts_RSL_MsgDisc(RSL_MDISC_CCHAN, false),
+		msg_type := RSL_MT_CBCH_LOAD_IND,
+		ies := {
+			t_RSL_IE(RSL_IE_CHAN_NR, RSL_IE_Body:{chan_nr := chan_nr}),
+			t_RSL_IE(RSL_IE_CBCH_LOAD_INFO, RSL_IE_Body:{cbch_load_info := ts_CbchLoadInfo(overflow, slot_count)})
+		}
+	}
+	template RSL_Message tr_RSL_CBCH_LOAD_IND_EXTD(template boolean overflow := ?,
+							template uint4_t slot_count := ?,
+							template RslChannelNr chan_nr := ?) := {
+		msg_disc := tr_RSL_MsgDisc(RSL_MDISC_CCHAN, false),
+		msg_type := RSL_MT_CBCH_LOAD_IND,
+		ies := {
+			tr_RSL_IE(RSL_IE_Body:{chan_nr := chan_nr}),
+			tr_RSL_IE(RSL_IE_Body:{cbch_load_info := tr_CbchLoadInfo(overflow, slot_count)}),
+			tr_RSL_IE(RSL_IE_Body:{smscb_chan_ind := 1})
+		}
+	}
+	template (value) RSL_Message ts_RSL_CBCH_LOAD_IND_EXTD(boolean overflow, uint4_t slot_count,
+								template (value) RslChannelNr chan_nr :=
+									ts_RslChanNr_SDCCH4(0, 2)) := {
+		msg_disc := ts_RSL_MsgDisc(RSL_MDISC_CCHAN, false),
+		msg_type := RSL_MT_CBCH_LOAD_IND,
+		ies := {
+			t_RSL_IE(RSL_IE_CHAN_NR, RSL_IE_Body:{chan_nr := chan_nr}),
+			t_RSL_IE(RSL_IE_CBCH_LOAD_INFO, RSL_IE_Body:{cbch_load_info := ts_CbchLoadInfo(overflow, slot_count)}),
+			t_RSL_IE(RSL_IE_SMSCB_CHAN_INDICATOR, RSL_IE_Body:{smscb_chan_ind := 1})
+		}
+	}
+
+
 	/* 8.6.2 BTS <- BSC */
 	template (value) RSL_Message ts_RSL_SACCH_FILL(RSL_IE_SysinfoType si_type, octetstring l3_info) := {
 		msg_disc := ts_RSL_MsgDisc(RSL_MDISC_TRX_MGMT, false),

-- 
To view, visit https://gerrit.osmocom.org/14116
To unsubscribe, or for help writing mail filters, visit https://gerrit.osmocom.org/settings

Gerrit-Project: osmo-ttcn3-hacks
Gerrit-Branch: master
Gerrit-MessageType: merged
Gerrit-Change-Id: Ia0a82771ba2912ef06fb0d9ee0816e8150701005
Gerrit-Change-Number: 14116
Gerrit-PatchSet: 2
Gerrit-Owner: Harald Welte <laforge at gnumonks.org>
Gerrit-Reviewer: Harald Welte <laforge at gnumonks.org>
Gerrit-Reviewer: Jenkins Builder (1000002)
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osmocom.org/pipermail/gerrit-log/attachments/20190521/2c9d8fae/attachment.html>


More information about the gerrit-log mailing list