diff src/g23m-gsm/alr2/alr_test/alr_cbch_constraints.cpp @ 2:3a14ee9a9843

src/g23m-gsm: same alr2 & alr3 structure as in Selenite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:29:12 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-gsm/alr2/alr_test/alr_cbch_constraints.cpp	Fri Oct 16 06:29:12 2020 +0000
@@ -0,0 +1,970 @@
+/*
+  +------------------------------------------------------------------------------
+  |  File:       alr_cbch_constraints.cpp
+  +------------------------------------------------------------------------------
+  |              Copyright 2003 Texas Instruments
+  |              All rights reserved.
+  |
+  |              This file is confidential and a trade secret of Texas Instruments.
+  |              The receipt of or possession of this file does not convey
+  |              any rights to reproduce or disclose its contents or to
+  |              manufacture, use, or sell anything it may describe, in
+  |              whole, or in part, without the specific written consent of
+  |              Texas Instruments.
+  +------------------------------------------------------------------------------
+  | Purpose:     Contains test constraints for alr
+  |
+  +------------------------------------------------------------------------------
+*/
+#include "alr_constraints.h"
+const U8 MSG_ID_3_7_11_TO_13[40] = {
+ 	3, 0, 3, 0,
+	7, 0, 7, 0,
+	11, 0, 13, 0,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF
+};
+const U8 DCS_ID_EMPTY[40] = {
+ 	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF,
+	0xFF, 0xFF, 0xFF, 0xFF
+};
+
+T_cbch cbch_description_8()
+{
+  const U16 CBCH_DESCRIPTION_8_MA_elements[5] = {
+ 	  0x0E,
+	  0x17,
+	  0x45,
+	  0x73,
+	  NOT_PRESENT_16BIT
+  };
+  T_ARRAY<U16> CBCH_DESCRIPTION_8_MA(CBCH_DESCRIPTION_8_MA_elements, SKIP_TO_END);
+
+  T_cbch pstruct;
+  pstruct->stat = STAT_ACT;
+  pstruct->ch = CH_SDCCH_8_0;
+  pstruct->tn = 3;
+  pstruct->tsc = 3;
+  pstruct->h = H_FREQ;
+  pstruct->arfcn = 0;
+  pstruct->maio = 1;
+  pstruct->hsn = 0;
+  pstruct->ma = CBCH_DESCRIPTION_8_MA;
+  return pstruct;
+}
+T_cbch cbch_description_4()
+{
+  const U16 CBCH_DESCRIPTION_4_MA_elements[5] = {
+    0x0E, 0x17, 0x45, 0x73, NOT_PRESENT_16BIT
+  };
+  T_ARRAY<U16> CBCH_DESCRIPTION_4_MA(CBCH_DESCRIPTION_4_MA_elements, SKIP_TO_END);
+
+  T_cbch pstruct;
+  pstruct->stat = STAT_ACT;
+  pstruct->ch = CH_SDCCH_4_0;
+  pstruct->tn = 0;
+  pstruct->tsc = 3;
+  pstruct->h = H_FREQ;
+  pstruct->arfcn = 0;
+  pstruct->maio = 1;
+  pstruct->hsn = 0;
+  pstruct->ma = CBCH_DESCRIPTION_4_MA;
+  return pstruct;
+}
+T_cbch_desc channel_desc_cbch_8()
+{
+  T_cbch_desc pstruct;
+  pstruct->chan_sel.h = 1;
+  pstruct->chan_sel.rf_channel.maio = 1;
+  pstruct->chan_sel.rf_channel.hsn = 0;
+  pstruct->channel_type = 0x04;
+  pstruct->sub_channel = 0;
+  pstruct->timeslot_no = 3;
+  pstruct->tsc = 3;
+  return pstruct;
+}
+T_cbch_desc channel_desc_cbch_4()
+{
+  T_cbch_desc pstruct;
+  pstruct->chan_sel.h = 1;
+  pstruct->chan_sel.rf_channel.maio = 1;
+  pstruct->chan_sel.rf_channel.hsn = 0;
+  pstruct->channel_type = 0x03;
+  pstruct->sub_channel = 0;
+  pstruct->timeslot_no = 0;
+  pstruct->tsc = 3;
+  return pstruct;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_53()
+{
+  const U8 NULL_MESSAGE_CONTENT_elements[23] = {
+ 	  0x0F,
+	  0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B
+  };
+  T_ARRAY<U8> NULL_MESSAGE_CONTENT(NULL_MESSAGE_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = NULL_MESSAGE_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_54(CHAR variant)
+{
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  if (variant == 'A') {
+    const U8 CBCH_1_7_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x00,
+	    0x00, 0x07,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_7_CONTENT(CBCH_1_7_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_7_CONTENT;
+  }
+  if (variant == 'B') {
+    const U8 CBCH_1_11_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x00,
+	    0x00, 0x0B,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_11_CONTENT(CBCH_1_11_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_11_CONTENT;
+  }
+  if (variant == 'C') {
+    const U8 CBCH_1_12_CONTENT_elements[23] = {
+      0x00,
+      0x00, 0x00,
+      0x00, 0x0C,
+      0x00,
+      0x01,
+      0xAA, 0xAB, 0xAC, 0xAD,
+      0xAE, 0xAF, 0xB0, 0xB1,
+      0xB2, 0xB3, 0xB4, 0xB5,
+      0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_12_CONTENT(CBCH_1_12_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_12_CONTENT;
+  }
+  if (variant == 'D') {
+    const U8 CBCH_1_13_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x00,
+	    0x00, 0x0D,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_13_CONTENT(CBCH_1_13_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_13_CONTENT;
+  }
+  if (variant == 'E') {
+    const U8 CBCH_1_7_2_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x02,
+	    0x00, 0x07,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_7_2_CONTENT(CBCH_1_7_2_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_7_2_CONTENT;
+  }
+  if (variant == 'F') {
+    const U8 CBCH_1_7_B_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x0B,
+	    0x00, 0x07,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_7_B_CONTENT(CBCH_1_7_B_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_7_B_CONTENT;
+  }
+  if (variant == 'G') {
+    const U8 CBCH_1_7_scope_la_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x80, 0x00,
+	    0x00, 0x07,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_7_scope_la_CONTENT(CBCH_1_7_scope_la_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_7_scope_la_CONTENT;
+  }
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_55()
+{
+  const U8 CBCH_2_CONTENT_elements[23] = {
+ 	  0x01,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF
+  };
+  T_ARRAY<U8> CBCH_2_CONTENT(CBCH_2_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_2_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_56()
+{
+  const U8 CBCH_3_CONTENT_elements[23] = {
+ 	  0x02,
+	  0xD0, 0xD1, 0xD2, 0xD3,
+	  0xD4, 0xD5, 0xD6, 0xD7,
+	  0xD8, 0xD9, 0xDA, 0xDB,
+	  0xDC, 0xDD, 0xDE, 0xDF,
+	  0xE0, 0xE1, 0xE2, 0xE3,
+	  0xE4, 0xE5
+  };
+  T_ARRAY<U8> CBCH_3_CONTENT(CBCH_3_CONTENT_elements, SKIP_TO_END);
+
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_3_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_57()
+{
+  const U8 CBCH_4_CONTENT_elements[23] = {
+ 	  0x03,
+	  0xE6, 0xE7, 0xE8, 0xE9,
+	  0xEA, 0xEB, 0xEC, 0xED,
+	  0xEE, 0xEF, 0xF0, 0xF1,
+	  0xF2, 0xF3, 0xF4, 0xF5,
+	  0xF6, 0xF7, 0xF8, 0xF9,
+	  0xFA, 0xFB
+  };
+  T_ARRAY<U8> CBCH_4_CONTENT(CBCH_4_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_4_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_58()
+{
+  const U8 CBCH_1_8_CONTENT_elements[23] = {
+ 	  0x00,
+	  0x00, 0x00,
+	  0x00, 0x08,
+	  0x00,
+	  0x01,
+	  0xAA, 0xAB, 0xAC, 0xAD,
+	  0xAE, 0xAF, 0xB0, 0xB1,
+	  0xB2, 0xB3, 0xB4, 0xB5,
+	  0xB6, 0xB7, 0xB8, 0xB9
+  };
+  T_ARRAY<U8> CBCH_1_8_CONTENT(CBCH_1_8_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_1_8_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_59()
+{
+  const U8 SCHEDULE_1_B_CONTENT_elements[23] = {
+ 	  0x08,
+	  0x0B, 0x12,
+	  0x12, 0x04, 0x80,
+	  0x00, 0x00, 0x00,
+	  0x80, 0x05,
+	  0x41,
+	  0x80, 0x07,
+	  0x41,
+	  0x40,
+	  0x80, 0x03,
+	  0x40, 0x40, 0x40, 0x40, 0x40
+  };
+  T_ARRAY<U8> SCHEDULE_1_B_CONTENT(SCHEDULE_1_B_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = SCHEDULE_1_B_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_60()
+{
+  const U8 SCHEDULE_2_CONTENT_elements[23] = {
+    0x01,
+    0x40, 0x40, 0x40, 0x40, 0x40,
+    0x80, 0x08,
+    0x02,
+    0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+    0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+    0x2B, 0x2B, 0x2B, 0x2B
+  };
+  T_ARRAY<U8> SCHEDULE_2_CONTENT(SCHEDULE_2_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = SCHEDULE_2_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_61()
+{
+  const U8 SCHEDULE_3_CONTENT_elements[23] = {
+ 	  0x02,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B
+  };
+  T_ARRAY<U8> SCHEDULE_3_CONTENT(SCHEDULE_3_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = SCHEDULE_3_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_62()
+{
+  const U8 SCHEDULE_4_CONTENT_elements[23] = {
+ 	  0x13,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B, 0x2B, 0x2B, 0x2B,
+	  0x2B, 0x2B
+  };
+  T_ARRAY<U8> SCHEDULE_4_CONTENT(SCHEDULE_4_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = SCHEDULE_4_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_66()
+{
+  const U8 CBCH_2_CONTENT_elements[23] = {
+ 	  0x0B,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF
+  };
+  T_ARRAY<U8> CBCH_2_CONTENT(CBCH_2_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_2_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_data_ind_67()
+{
+  const U8 SCHEDULE_1_B_CONTENT_elements[23] = {
+ 	  0x08,
+	  0x01, 0x30,
+	  0x12, 0x04, 0x80,
+	  0x00, 0x00, 0x00,
+	  0x80, 0x05,
+	  0x41,
+	  0x80, 0x07,
+	  0x41,
+	  0x40,
+	  0x80, 0x03,
+	  0x40, 0x40, 0x40, 0x40, 0x40
+  };
+  T_ARRAY<U8> SCHEDULE_1_B_CONTENT(SCHEDULE_1_B_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = SCHEDULE_1_B_CONTENT;
+  prim->tc = TC_0;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_68(CHAR variant)
+{
+  const U8 CBCH_2_CONTENT_elements[23] = {
+ 	  0x0B,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF
+  };
+  T_ARRAY<U8> CBCH_2_CONTENT(CBCH_2_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = INVALID_BLOCK;
+  prim->l2_frame.content = CBCH_2_CONTENT;
+  if( variant == 'A') prim->tc = TC_0;
+  if( variant == 'B') prim->tc = TC_4;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_69()
+{
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  {
+    const U8 CBCH_1_7_CONTENT_elements[23] = {
+ 	    0x00,
+	    0x00, 0x00,
+	    0x00, 0x0B,
+	    0x00,
+	    0x01,
+	    0xAA, 0xAB, 0xAC, 0xAD,
+	    0xAE, 0xAF, 0xB0, 0xB1,
+	    0xB2, 0xB3, 0xB4, 0xB5,
+	    0xB6, 0xB7, 0xB8, 0xB9
+    };
+    T_ARRAY<U8> CBCH_1_7_CONTENT(CBCH_1_7_CONTENT_elements, SKIP_TO_END);
+
+    prim->l2_frame.content =  CBCH_1_7_CONTENT;
+  }
+  prim->tc = TC_4;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_70()
+{
+  const U8 CBCH_2_CONTENT_elements[23] = {
+ 	  0x01,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF
+  };
+  T_ARRAY<U8> CBCH_2_CONTENT(CBCH_2_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_2_CONTENT;
+  prim->tc = TC_5;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_71()
+{
+  const U8 CBCH_3_CONTENT_elements[23] = {
+ 	  0x02,
+	  0xD0, 0xD1, 0xD2, 0xD3,
+	  0xD4, 0xD5, 0xD6, 0xD7,
+	  0xD8, 0xD9, 0xDA, 0xDB,
+	  0xDC, 0xDD, 0xDE, 0xDF,
+	  0xE0, 0xE1, 0xE2, 0xE3,
+	  0xE4, 0xE5
+  };
+  T_ARRAY<U8> CBCH_3_CONTENT(CBCH_3_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_3_CONTENT;
+  prim->tc = TC_6;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_72()
+{
+  const U8 CBCH_4_CONTENT_elements[23] = {
+ 	  0x03,
+	  0xE6, 0xE7, 0xE8, 0xE9,
+	  0xEA, 0xEB, 0xEC, 0xED,
+	  0xEE, 0xEF, 0xF0, 0xF1,
+	  0xF2, 0xF3, 0xF4, 0xF5,
+	  0xF6, 0xF7, 0xF8, 0xF9,
+	  0xFA, 0xFB
+  };
+  T_ARRAY<U8> CBCH_4_CONTENT(CBCH_4_CONTENT_elements, SKIP_TO_END);
+
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_CBCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame.content = CBCH_4_CONTENT;
+  prim->tc = TC_7;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_data_ind_73()
+{
+  T_MPHC_DATA_IND prim;
+  prim->radio_freq = ARFCN_23;
+  prim->l2_channel = L2_CHANNEL_NBCCH;
+  prim->error_flag = VALID_BLOCK;
+  prim->l2_frame = l2_sys_info_3_new();
+  prim->tc = TC_1;
+  prim->ccch_lev._skip;
+  prim->fn = FN_OFFSET_0; //FN_OFFSET_14;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mph_cbch_req_1()
+{
+  T_MPH_CBCH_REQ prim;
+  prim->cbch.stat._skip;
+  prim->cbch.ch._skip;
+  prim->cbch.tn._skip;
+  prim->cbch.tsc._skip;
+  prim->cbch.h._skip;
+  prim->cbch.arfcn._skip;
+  prim->cbch.maio._skip;
+  prim->cbch.hsn._skip;
+
+  return prim;
+}
+T_PRIMITIVE_UNION mph_cbch_req_2(CHAR variant)
+{
+  T_MPH_CBCH_REQ prim;
+  if (variant == 'A')   prim->cbch = cbch_description_4();
+  if (variant == 'B')   prim->cbch = cbch_description_8();
+  return prim;
+}
+T_PRIMITIVE_UNION mph_cbch_req_3(CHAR variant)
+{
+  T_MPH_CBCH_REQ prim;
+  if (variant == 'A')   prim->cbch = cbch_description_4();
+  if (variant == 'B')   prim->cbch = cbch_description_8();
+  if (variant == 'C')   prim->cbch = cbch_description_4();
+  return prim;
+}
+T_PRIMITIVE_UNION mmi_cbch_req_1()
+{
+  T_MMI_CBCH_REQ prim;
+  prim->msg_id = MSG_ID_3_7_11_TO_13;
+  prim->dcs_id = DCS_ID_EMPTY;
+  prim->modus = CBCH_ACCEPT;
+  return prim;
+}
+T_PRIMITIVE_UNION mmi_cbch_req_2(CHAR variant)
+{
+  T_MMI_CBCH_REQ prim;
+  if (variant == 'A')   prim->msg_id = MSG_ID_3_7_11_TO_13;
+  if (variant == 'B')   prim->msg_id = MSG_ID_3_7_11_TO_13;
+  if (variant == 'C') {
+    const U8 MSG_ID_1_TO_20[40] = {
+ 	    1, 0, 20, 0,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF,
+	    0xFF, 0xFF, 0xFF, 0xFF
+    };
+
+    prim->msg_id = MSG_ID_1_TO_20;
+  }
+  prim->dcs_id = DCS_ID_EMPTY;
+  prim->modus = CBCH_ACCEPT;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_config_cbch_req_1(CHAR variant)
+{
+  T_MPHC_CONFIG_CBCH_REQ prim;
+  if (variant == 'A')   prim->cbch_desc = channel_desc_cbch_4();
+  if (variant == 'B')   prim->cbch_desc = channel_desc_cbch_8();
+  prim->cbch_freq_list = freq_list();
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_config_cbch_req_2(CHAR variant)
+{
+  T_MPHC_CONFIG_CBCH_REQ prim;
+  if (variant == 'A')   prim->cbch_desc = channel_desc_cbch_4();
+  if (variant == 'B')   prim->cbch_desc = channel_desc_cbch_8();
+  if (variant == 'C')   prim->cbch_desc = channel_desc_cbch_4();
+  prim->cbch_freq_list = freq_list();
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_cbch_schedule_req_1()
+{
+  T_MPHC_CBCH_SCHEDULE_REQ prim;
+  prim->cbch_select = CBCH_READ_NORM;
+  prim->schedule_length = SCHED_LEN_0;
+  prim->first_blocks_0._skip;
+  prim->first_blocks_1._skip;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_cbch_schedule_req_2()
+{
+  T_MPHC_CBCH_SCHEDULE_REQ prim;
+  prim->cbch_select = CBCH_READ_EXT;
+  prim->schedule_length = SCHED_LEN_0;
+  prim->first_blocks_0._skip;
+  prim->first_blocks_1._skip;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_cbch_schedule_req_3()
+{
+  T_MPHC_CBCH_SCHEDULE_REQ prim;
+  prim->cbch_select = CBCH_READ_NORM;
+  prim->schedule_length = SCHED_LEN_8;
+  prim->first_blocks_0 = FIRST_BLOCKS_0_UNSCH;
+  prim->first_blocks_1 = FIRST_BLOCKS_1_B;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_cbch_schedule_req_4(CHAR variant)
+{
+  T_MPHC_CBCH_SCHEDULE_REQ prim;
+  prim->cbch_select._skip;
+  prim->schedule_length = SCHED_LEN_30 ;
+  if( variant == 'A')   prim->first_blocks_0 = FIRST_BLOCKS_0_B;
+  if( variant == 'B')   prim->first_blocks_0 = FIRST_BLOCKS_0_DRX;
+  if( variant == 'A')   prim->first_blocks_1 = FIRST_BLOCKS_1_B;
+  if( variant == 'B')   prim->first_blocks_1 = FIRST_BLOCKS_1_B;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_cbch_info_req_1()
+{
+  T_MPHC_CBCH_INFO_REQ prim;
+  prim->tb_bitmap = CBCH_NORM_BLOCK234;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_cbch_info_req_2()
+{
+  T_MPHC_CBCH_INFO_REQ prim;
+  prim->tb_bitmap = 0;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mphc_cbch_info_req_3()
+{
+  T_MPHC_CBCH_INFO_REQ prim;
+  prim->tb_bitmap = CBCH_EXT_BLOCK234;
+  return prim;
+}
+
+T_PRIMITIVE_UNION mmi_cbch_ind_1(CHAR variant)
+{
+  T_MMI_CBCH_IND prim;
+  const U8 CBCH_MSG_7[88] = {
+    0x00, 0x00,
+    0x00, 0x07,
+    0x00,
+    0x01,
+    0xAA, 0xAB, 0xAC, 0xAD,
+    0xAE, 0xAF, 0xB0, 0xB1,
+    0xB2, 0xB3, 0xB4, 0xB5,
+    0xB6, 0xB7, 0xB8, 0xB9,
+    0xBA, 0xBB, 0xBC, 0xBD,
+    0xBE, 0xBF, 0xC0, 0xC1,
+    0xC2, 0xC3, 0xC4, 0xC5,
+    0xC6, 0xC7, 0xC8, 0xC9,
+    0xCA, 0xCB, 0xCC, 0xCD,
+    0xCE, 0xCF,
+    0xD0, 0xD1, 0xD2, 0xD3,
+    0xD4, 0xD5, 0xD6, 0xD7,
+    0xD8, 0xD9, 0xDA, 0xDB,
+    0xDC, 0xDD, 0xDE, 0xDF,
+    0xE0, 0xE1, 0xE2, 0xE3,
+    0xE4, 0xE5,
+    0xE6, 0xE7, 0xE8, 0xE9,
+    0xEA, 0xEB, 0xEC, 0xED,
+    0xEE, 0xEF, 0xF0, 0xF1,
+    0xF2, 0xF3, 0xF4, 0xF5,
+    0xF6, 0xF7, 0xF8, 0xF9,
+    0xFA, 0xFB
+  };
+  const U8 CBCH_MSG_7_updt_2[88] = {
+    0x00, 0x02,
+    0x00, 0x07,
+    0x00,
+    0x01,
+    0xAA, 0xAB, 0xAC, 0xAD,
+    0xAE, 0xAF, 0xB0, 0xB1,
+    0xB2, 0xB3, 0xB4, 0xB5,
+    0xB6, 0xB7, 0xB8, 0xB9,
+    0xBA, 0xBB, 0xBC, 0xBD,
+    0xBE, 0xBF, 0xC0, 0xC1,
+    0xC2, 0xC3, 0xC4, 0xC5,
+    0xC6, 0xC7, 0xC8, 0xC9,
+    0xCA, 0xCB, 0xCC, 0xCD,
+    0xCE, 0xCF,
+    0xD0, 0xD1, 0xD2, 0xD3,
+    0xD4, 0xD5, 0xD6, 0xD7,
+    0xD8, 0xD9, 0xDA, 0xDB,
+    0xDC, 0xDD, 0xDE, 0xDF,
+    0xE0, 0xE1, 0xE2, 0xE3,
+    0xE4, 0xE5,
+    0xE6, 0xE7, 0xE8, 0xE9,
+    0xEA, 0xEB, 0xEC, 0xED,
+    0xEE, 0xEF, 0xF0, 0xF1,
+    0xF2, 0xF3, 0xF4, 0xF5,
+    0xF6, 0xF7, 0xF8, 0xF9,
+    0xFA, 0xFB
+  };
+  const U8 CBCH_MSG_7_scope_la[88] = {
+    0x80, 0x00,
+    0x00, 0x07,
+    0x00,
+    0x01,
+    0xAA, 0xAB, 0xAC, 0xAD,
+    0xAE, 0xAF, 0xB0, 0xB1,
+    0xB2, 0xB3, 0xB4, 0xB5,
+    0xB6, 0xB7, 0xB8, 0xB9,
+    0xBA, 0xBB, 0xBC, 0xBD,
+    0xBE, 0xBF, 0xC0, 0xC1,
+    0xC2, 0xC3, 0xC4, 0xC5,
+    0xC6, 0xC7, 0xC8, 0xC9,
+    0xCA, 0xCB, 0xCC, 0xCD,
+    0xCE, 0xCF,
+    0xD0, 0xD1, 0xD2, 0xD3,
+    0xD4, 0xD5, 0xD6, 0xD7,
+    0xD8, 0xD9, 0xDA, 0xDB,
+    0xDC, 0xDD, 0xDE, 0xDF,
+    0xE0, 0xE1, 0xE2, 0xE3,
+    0xE4, 0xE5,
+    0xE6, 0xE7, 0xE8, 0xE9,
+    0xEA, 0xEB, 0xEC, 0xED,
+    0xEE, 0xEF, 0xF0, 0xF1,
+    0xF2, 0xF3, 0xF4, 0xF5,
+    0xF6, 0xF7, 0xF8, 0xF9,
+    0xFA, 0xFB
+  };
+  const U8 CBCH_MSG_11[88] = {
+ 	  0x00, 0x00,
+	  0x00, 0x0B,
+	  0x00,
+	  0x01,
+	  0xAA, 0xAB, 0xAC, 0xAD,
+	  0xAE, 0xAF, 0xB0, 0xB1,
+	  0xB2, 0xB3, 0xB4, 0xB5,
+	  0xB6, 0xB7, 0xB8, 0xB9,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF,
+	  0xD0, 0xD1, 0xD2, 0xD3,
+	  0xD4, 0xD5, 0xD6, 0xD7,
+	  0xD8, 0xD9, 0xDA, 0xDB,
+	  0xDC, 0xDD, 0xDE, 0xDF,
+	  0xE0, 0xE1, 0xE2, 0xE3,
+	  0xE4, 0xE5,
+	  0xE6, 0xE7, 0xE8, 0xE9,
+	  0xEA, 0xEB, 0xEC, 0xED,
+	  0xEE, 0xEF, 0xF0, 0xF1,
+	  0xF2, 0xF3, 0xF4, 0xF5,
+	  0xF6, 0xF7, 0xF8, 0xF9,
+	  0xFA, 0xFB
+  };
+  const U8 CBCH_MSG_12[88] = {
+ 	  0x00, 0x00,
+	  0x00, 0x0C,
+	  0x00,
+	  0x01,
+	  0xAA, 0xAB, 0xAC, 0xAD,
+	  0xAE, 0xAF, 0xB0, 0xB1,
+	  0xB2, 0xB3, 0xB4, 0xB5,
+	  0xB6, 0xB7, 0xB8, 0xB9,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF,
+	  0xD0, 0xD1, 0xD2, 0xD3,
+	  0xD4, 0xD5, 0xD6, 0xD7,
+	  0xD8, 0xD9, 0xDA, 0xDB,
+	  0xDC, 0xDD, 0xDE, 0xDF,
+	  0xE0, 0xE1, 0xE2, 0xE3,
+	  0xE4, 0xE5,
+	  0xE6, 0xE7, 0xE8, 0xE9,
+	  0xEA, 0xEB, 0xEC, 0xED,
+	  0xEE, 0xEF, 0xF0, 0xF1,
+	  0xF2, 0xF3, 0xF4, 0xF5,
+	  0xF6, 0xF7, 0xF8, 0xF9,
+	  0xFA, 0xFB
+  };
+  const U8 CBCH_MSG_13[88] = {
+ 	  0x00, 0x00,
+	  0x00, 0x0D,
+	  0x00,
+	  0x01,
+	  0xAA, 0xAB, 0xAC, 0xAD,
+	  0xAE, 0xAF, 0xB0, 0xB1,
+	  0xB2, 0xB3, 0xB4, 0xB5,
+	  0xB6, 0xB7, 0xB8, 0xB9,
+	  0xBA, 0xBB, 0xBC, 0xBD,
+	  0xBE, 0xBF, 0xC0, 0xC1,
+	  0xC2, 0xC3, 0xC4, 0xC5,
+	  0xC6, 0xC7, 0xC8, 0xC9,
+	  0xCA, 0xCB, 0xCC, 0xCD,
+	  0xCE, 0xCF,
+	  0xD0, 0xD1, 0xD2, 0xD3,
+	  0xD4, 0xD5, 0xD6, 0xD7,
+	  0xD8, 0xD9, 0xDA, 0xDB,
+	  0xDC, 0xDD, 0xDE, 0xDF,
+	  0xE0, 0xE1, 0xE2, 0xE3,
+	  0xE4, 0xE5,
+	  0xE6, 0xE7, 0xE8, 0xE9,
+	  0xEA, 0xEB, 0xEC, 0xED,
+	  0xEE, 0xEF, 0xF0, 0xF1,
+	  0xF2, 0xF3, 0xF4, 0xF5,
+	  0xF6, 0xF7, 0xF8, 0xF9,
+	  0xFA, 0xFB
+  };
+
+  if (variant == 'A')   prim->cbch_msg = CBCH_MSG_7;
+  if (variant == 'B')   prim->cbch_msg = CBCH_MSG_11;
+  if (variant == 'C')   prim->cbch_msg = CBCH_MSG_12;
+  if (variant == 'D')   prim->cbch_msg = CBCH_MSG_13;
+  if (variant == 'E')   prim->cbch_msg = CBCH_MSG_7_updt_2;
+  if (variant == 'F')   prim->cbch_msg = CBCH_MSG_7_scope_la;
+  prim->cbch_len = CBCH_LEN_88;
+  return prim;
+}
+T_PRIMITIVE_UNION mphc_stop_cbch_req()
+{
+   T_MPHC_STOP_CBCH_REQ prim;
+   prim->normal_cbch._skip;
+   prim->extended_cbch._skip;
+   return prim;
+}