Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 1 | /* TITAN REW encode/decode definitions for 3GPP TS 44.060 RLC/MAC Blocks */ |
| 2 | |
| 3 | /* (C) 2017-2018 Harald Welte <laforge@gnumonks.org> |
| 4 | * (C) 2020 by sysmocom s.f.m.c. GmbH <info@sysmocom.de> |
| 5 | * All rights reserved. |
| 6 | * |
| 7 | * Released under the terms of GNU General Public License, Version 2 or |
| 8 | * (at your option) any later version. |
| 9 | * |
| 10 | * SPDX-License-Identifier: GPL-2.0-or-later |
| 11 | */ |
| 12 | |
| 13 | module RLCMAC_Templates { |
| 14 | import from General_Types all; |
| 15 | import from Osmocom_Types all; |
| 16 | import from GSM_Types all; |
| 17 | import from RLCMAC_CSN1_Types all; |
| 18 | import from RLCMAC_CSN1_Templates all; |
| 19 | import from RLCMAC_Types all; |
| 20 | |
| 21 | /* TS 44.060 10.4.5 */ |
| 22 | function f_rrbp_fn_delay(MacRrbp rrbp) return uint32_t { |
| 23 | select (rrbp) { |
| 24 | case (RRBP_Nplus13_mod_2715648) { return 13; } |
| 25 | case (RRBP_Nplus17_or_18_mod_2715648) { return 17; } |
| 26 | case (RRBP_Nplus21_or_22_mod_2715648) { return 21; } |
| 27 | case (RRBP_Nplus26_mod_2715648) { return 26; } |
| 28 | } |
| 29 | return 0; |
| 30 | } |
| 31 | |
Vadim Yanitskiy | 2742bcd | 2020-05-10 12:45:18 +0700 | [diff] [blame] | 32 | function f_rrbp_ack_fn(uint32_t current_fn, MacRrbp rrbp) |
| 33 | return uint32_t { |
| 34 | return (current_fn + f_rrbp_fn_delay(rrbp)) mod 2715648; |
| 35 | } |
| 36 | |
Pau Espin Pedrol | 27d6af5 | 2020-04-30 20:13:32 +0200 | [diff] [blame] | 37 | function f_rlcmac_mcs2headertype(CodingScheme mcs) return EgprsHeaderType { |
| 38 | select (mcs) { |
| 39 | case (MCS_0) { return RLCMAC_HDR_TYPE_3; } |
| 40 | case (MCS_1) { return RLCMAC_HDR_TYPE_3; } |
| 41 | case (MCS_2) { return RLCMAC_HDR_TYPE_3; } |
| 42 | case (MCS_3) { return RLCMAC_HDR_TYPE_3; } |
| 43 | case (MCS_4) { return RLCMAC_HDR_TYPE_3; } |
| 44 | case (MCS_5) { return RLCMAC_HDR_TYPE_2; } |
| 45 | case (MCS_6) { return RLCMAC_HDR_TYPE_2; } |
| 46 | case (MCS_7) { return RLCMAC_HDR_TYPE_1; } |
| 47 | case (MCS_8) { return RLCMAC_HDR_TYPE_1; } |
| 48 | case (MCS_9) { return RLCMAC_HDR_TYPE_1; } |
| 49 | } |
| 50 | return RLCMAC_HDR_TYPE_3; |
| 51 | } |
| 52 | |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 53 | function f_rlcmac_cs_mcs2block_len(CodingScheme cs_mcs) return uint32_t { |
| 54 | select (cs_mcs) { |
| 55 | case (CS_1) { return 23; } |
| 56 | case (CS_2) { return 34; } |
| 57 | case (CS_3) { return 40; } |
| 58 | case (CS_4) { return 54; } |
| 59 | case (MCS_1) { return 27; } |
| 60 | case (MCS_2) { return 33; } |
| 61 | case (MCS_3) { return 42; } |
| 62 | case (MCS_4) { return 49; } |
| 63 | case (MCS_5) { return 61; } |
| 64 | case (MCS_6) { return 79; } |
| 65 | case (MCS_7) { return 119; } |
| 66 | case (MCS_8) { return 143; } |
| 67 | case (MCS_9) { return 155; } |
| 68 | } |
| 69 | return 0; |
| 70 | } |
| 71 | |
| 72 | function f_rlcmac_block_len2cs_mcs(uint32_t len) return CodingScheme { |
| 73 | select (len) { |
| 74 | case (23) { return CS_1; } |
| 75 | case (34) { return CS_2; } |
| 76 | case (40) { return CS_3; } |
| 77 | case (54) { return CS_4; } |
| 78 | case (27) { return MCS_1; } |
| 79 | case (33) { return MCS_2; } |
| 80 | case (42) { return MCS_3; } |
| 81 | case (49) { return MCS_4; } |
| 82 | case (60) { return MCS_5; } |
| 83 | case (61) { return MCS_5; } |
| 84 | case (78) { return MCS_6; } |
| 85 | case (79) { return MCS_6; } |
| 86 | case (118) { return MCS_7; } |
| 87 | case (119) { return MCS_7; } |
| 88 | case (142) { return MCS_8; } |
| 89 | case (143) { return MCS_8; } |
| 90 | case (154) { return MCS_9; } |
| 91 | case (155) { return MCS_9; } |
| 92 | } |
| 93 | return CS_1; |
| 94 | } |
| 95 | |
Pau Espin Pedrol | 42acafc | 2020-05-14 15:18:38 +0200 | [diff] [blame] | 96 | function f_rlcmac_block_ChCodingCommand2cs_mcs(ChCodingCommand chcc) return CodingScheme { |
| 97 | select (chcc) { |
| 98 | case (CH_CODING_CS1) { return CS_1; } |
| 99 | case (CH_CODING_CS2) { return CS_2; } |
| 100 | case (CH_CODING_CS3) { return CS_3; } |
| 101 | case (CH_CODING_CS4) { return CS_4; } |
| 102 | } |
| 103 | return CS_1; |
| 104 | } |
| 105 | |
| 106 | function f_rlcmac_block_EgprsChCodingCommand2cs_mcs(EgprsChCodingCommand echcc) return CodingScheme { |
| 107 | select (echcc) { |
| 108 | case (CH_CODING_MCS1) { return MCS_1; } |
| 109 | case (CH_CODING_MCS2) { return MCS_2; } |
| 110 | case (CH_CODING_MCS3) { return MCS_3; } |
| 111 | case (CH_CODING_MCS4) { return MCS_4; } |
| 112 | case (CH_CODING_MCS5) { return MCS_5; } |
| 113 | case (CH_CODING_MCS6) { return MCS_6; } |
| 114 | case (CH_CODING_MCS7) { return MCS_7; } |
| 115 | case (CH_CODING_MCS8) { return MCS_8; } |
| 116 | case (CH_CODING_MCS9) { return MCS_9; } |
| 117 | /* CH_CODING_MCS5_7 */ |
| 118 | /* CH_CODING_MCS6_9 */ |
| 119 | } |
| 120 | return MCS_1; |
| 121 | } |
| 122 | |
| 123 | /* 1 -> CS_1 / MCS_1, 2 -> CS_2 / MCS_2, etc. */ |
| 124 | function f_rlcmac_block_int2cs_mcs(integer n, boolean is_mcs) return CodingScheme { |
| 125 | var CodingScheme cs_mcs; |
| 126 | if (not is_mcs) { |
| 127 | int2enum(n - 1, cs_mcs); |
| 128 | return cs_mcs; |
| 129 | } else { |
| 130 | cs_mcs := MCS_0; |
| 131 | int2enum(enum2int(cs_mcs) + n, cs_mcs); |
| 132 | return cs_mcs; |
| 133 | } |
| 134 | } |
| 135 | |
Pau Espin Pedrol | 27d6af5 | 2020-04-30 20:13:32 +0200 | [diff] [blame] | 136 | /* Coding and Puncturing Scheme indicator field for Header type 1 in EGPRS TBF or EC TBF or downlink EGPRS2 TBF */ |
| 137 | function f_rlcmac_cps_htype1_to_mcs(uint3_t cps) return CodingScheme { |
| 138 | var CodingSchemeArray egprs_Header_type1_coding_puncturing_scheme_to_mcs := { |
| 139 | MCS_9 /* 0x00, "(MCS-9/P1 ; MCS-9/P1)" */, |
| 140 | MCS_9 /* 0x01, "(MCS-9/P1 ; MCS-9/P2)" */, |
| 141 | MCS_9 /* 0x02, "(MCS-9/P1 ; MCS-9/P3)" */, |
| 142 | MCS_0 /* 0x03, "reserved" */, |
| 143 | MCS_9 /* 0x04, "(MCS-9/P2 ; MCS-9/P1)" */, |
| 144 | MCS_9 /* 0x05, "(MCS-9/P2 ; MCS-9/P2)" */, |
| 145 | MCS_9 /* 0x06, "(MCS-9/P2 ; MCS-9/P3)" */, |
| 146 | MCS_0 /* 0x07, "reserved" */, |
| 147 | MCS_9 /* 0x08, "(MCS-9/P3 ; MCS-9/P1)" */, |
| 148 | MCS_9 /* 0x09, "(MCS-9/P3 ; MCS-9/P2)" */, |
| 149 | MCS_9 /* 0x0A, "(MCS-9/P3 ; MCS-9/P3)" */, |
| 150 | MCS_8 /* 0x0B, "(MCS-8/P1 ; MCS-8/P1)" */, |
| 151 | MCS_8 /* 0x0C, "(MCS-8/P1 ; MCS-8/P2)" */, |
| 152 | MCS_8 /* 0x0D, "(MCS-8/P1 ; MCS-8/P3)" */, |
| 153 | MCS_8 /* 0x0E, "(MCS-8/P2 ; MCS-8/P1)" */, |
| 154 | MCS_8 /* 0x0F, "(MCS-8/P2 ; MCS-8/P2)" */, |
| 155 | MCS_8 /* 0x10, "(MCS-8/P2 ; MCS-8/P3)" */, |
| 156 | MCS_8 /* 0x11, "(MCS-8/P3 ; MCS-8/P1)" */, |
| 157 | MCS_8 /* 0x12, "(MCS-8/P3 ; MCS-8/P2)" */, |
| 158 | MCS_8 /* 0x13, "(MCS-8/P3 ; MCS-8/P3)" */, |
| 159 | MCS_7 /* 0x14, "(MCS-7/P1 ; MCS-7/P1)" */, |
| 160 | MCS_7 /* 0x15, "(MCS-7/P1 ; MCS-7/P2)" */, |
| 161 | MCS_7 /* 0x16, "(MCS-7/P1 ; MCS-7/P3)" */, |
| 162 | MCS_7 /* 0x17, "(MCS-7/P2 ; MCS-7/P1)" */, |
| 163 | MCS_7 /* 0x18, "(MCS-7/P2 ; MCS-7/P2)" */, |
| 164 | MCS_7 /* 0x19, "(MCS-7/P2 ; MCS-7/P3)" */, |
| 165 | MCS_7 /* 0x1A, "(MCS-7/P3 ; MCS-7/P1)" */, |
| 166 | MCS_7 /* 0x1B, "(MCS-7/P3 ; MCS-7/P2)" */, |
| 167 | MCS_7 /* 0x1C, "(MCS-7/P3 ; MCS-7/P3)" */, |
| 168 | MCS_0 /* 0x1D, "reserved" */, |
| 169 | MCS_0 /* 0x1E, "reserved" */, |
| 170 | MCS_0 /* 0x1F, "reserved" */ |
| 171 | }; |
| 172 | return egprs_Header_type1_coding_puncturing_scheme_to_mcs[cps]; |
| 173 | } |
| 174 | |
| 175 | /* Coding and Puncturing Scheme indicator field for Header type 2 in (EC-)EGPRS TBF or uplink EGPRS2-A TBF */ |
| 176 | function f_rlcmac_cps_htype2_to_mcs(uint3_t cps) return CodingScheme { |
| 177 | var CodingSchemeArray egprs_Header_type2_coding_puncturing_scheme_to_mcs := { |
| 178 | MCS_6 /* {0x00, "MCS-6/P1"} */, |
| 179 | MCS_6 /* {0x01, "MCS-6/P2"} */, |
| 180 | MCS_6 /* {0x02, "MCS-6/P1 with 6 octet padding"} */, |
| 181 | MCS_6 /* {0x03, "MCS-6/P2 with 6 octet padding "} */, |
| 182 | MCS_5 /* {0x04, "MCS-5/P1"} */, |
| 183 | MCS_5 /* {0x05, "MCS-5/P2"} */, |
| 184 | MCS_5 /* {0x06, "MCS-6/P1 with 10 octet padding "} */, |
| 185 | MCS_5 /* {0x07, "MCS-6/P2 with 10 octet padding "} */ |
| 186 | }; |
| 187 | return egprs_Header_type2_coding_puncturing_scheme_to_mcs[cps]; |
| 188 | } |
| 189 | |
| 190 | /* Coding and Puncturing Scheme indicator field for Header type 3 */ |
| 191 | function f_rlcmac_cps_htype3_to_mcs(uint3_t cps) return CodingScheme { |
| 192 | var CodingSchemeArray egprs_Header_type3_coding_puncturing_scheme_to_mcs := { |
| 193 | MCS_4 /* {0x00, "MCS-4/P1"} */, |
| 194 | MCS_4 /* {0x01, "MCS-4/P2"} */, |
| 195 | MCS_4 /* {0x02, "MCS-4/P3"} */, |
| 196 | MCS_3 /* {0x03, "MCS-3/P1"} */, |
| 197 | MCS_3 /* {0x04, "MCS-3/P2"} */, |
| 198 | MCS_3 /* {0x05, "MCS-3/P3"} */, |
| 199 | MCS_3 /* {0x06, "MCS-3/P1 with padding"} */, |
| 200 | MCS_3 /* {0x07, "MCS-3/P2 with padding"} */, |
| 201 | MCS_3 /* {0x08, "MCS-3/P3 with padding"} */, |
| 202 | MCS_2 /* {0x09, "MCS-2/P1"} */, |
| 203 | MCS_2 /* {0x0A, "MCS-2/P2"} */, |
| 204 | MCS_1 /* {0x0B, "MCS-1/P1"} */, |
| 205 | MCS_1 /* {0x0C, "MCS-1/P2"} */, |
| 206 | MCS_2 /* {0x0D, "MCS-2/P1 with padding"} */, |
| 207 | MCS_2 /* {0x0E, "MCS-2/P2 with padding"} */, |
| 208 | MCS_0 /* {0x0F, "MCS-0"} */ |
| 209 | }; |
| 210 | return egprs_Header_type3_coding_puncturing_scheme_to_mcs[cps]; |
| 211 | } |
| 212 | |
| 213 | function f_rlcmac_cps_htype_to_mcs(uint3_t cps, EgprsHeaderType htype) return CodingScheme { |
| 214 | select (htype) { |
| 215 | case (RLCMAC_HDR_TYPE_1) { return f_rlcmac_cps_htype1_to_mcs(cps); } |
| 216 | case (RLCMAC_HDR_TYPE_2) { return f_rlcmac_cps_htype2_to_mcs(cps); } |
| 217 | case (RLCMAC_HDR_TYPE_3) { return f_rlcmac_cps_htype3_to_mcs(cps); } |
| 218 | } |
| 219 | //TODO: return error here. |
| 220 | return CS_1; |
| 221 | } |
| 222 | |
| 223 | function f_rlcmac_mcs_to_cps_htype1(CodingScheme mcs, uint2_t part, boolean with_padding) return uint5_t { |
| 224 | //TODO: implement similar to f_rlcmac_mcs_to_cps_htype3() |
| 225 | //TODO: return error here. |
| 226 | return 0; |
| 227 | } |
| 228 | |
| 229 | function f_rlcmac_mcs_to_cps_htype2(CodingScheme mcs, uint2_t part, boolean with_padding) return uint5_t { |
| 230 | //TODO: implement similar to f_rlcmac_mcs_to_cps_htype3() |
| 231 | //TODO: return error here. |
| 232 | return 0; |
| 233 | } |
| 234 | |
| 235 | function f_rlcmac_mcs_to_cps_htype3(CodingScheme mcs, uint2_t part, boolean with_padding) return uint5_t { |
| 236 | select (mcs) { |
| 237 | case (MCS_4) { |
| 238 | select (part) { |
| 239 | case (1) { return 0; /* {0x00, "MCS-4/P1"} */ } |
| 240 | case (2) { return 1; /* {0x01, "MCS-4/P2"} */ } |
| 241 | case (3) { return 2; /* {0x01, "MCS-4/P2"} */ } |
| 242 | } |
| 243 | } |
| 244 | case (MCS_3) { |
| 245 | if (not with_padding) { |
| 246 | select (part) { |
| 247 | case (1) { return 3; /* {0x03, "MCS-3/P1"} */ } |
| 248 | case (2) { return 4; /* {0x04, "MCS-3/P2"} */ } |
| 249 | case (3) { return 5; /* {0x05, "MCS-3/P3"} */ } |
| 250 | } |
| 251 | } else { |
| 252 | select (part) { |
| 253 | case (1) { return 6; /* {0x06, "MCS-3/P1 with padding"} */ } |
| 254 | case (2) { return 7; /* {0x07, "MCS-3/P2 with padding"} */ } |
| 255 | case (3) { return 8; /* {0x08, "MCS-3/P3 with padding"} */ } |
| 256 | } |
| 257 | } |
| 258 | } |
| 259 | case (MCS_2) { |
| 260 | if (not with_padding) { |
| 261 | select (part) { |
| 262 | case (1) { return 9; /* {0x09, "MCS-2/P1"} */ } |
| 263 | case (2) { return 10; /* {0x0A, "MCS-2/P2"} */ } |
| 264 | } |
| 265 | } else { |
| 266 | select (part) { |
| 267 | case (1) { return 13; /* {0x0D, "MCS-2/P1 with padding"} */ } |
| 268 | case (2) { return 14; /* {0x0E, "MCS-2/P2 with padding"} */} |
| 269 | } |
| 270 | } |
| 271 | } |
| 272 | case (MCS_1) { |
| 273 | select (part) { |
| 274 | case (1) { return 11; /* {0x0B, "MCS-1/P1"} */ } |
| 275 | case (2) { return 12; /* {0x0C, "MCS-1/P2"} */ } |
| 276 | } |
| 277 | } |
| 278 | case (MCS_0) { return 15; /* {0x0F, "MCS-0"} */ } |
| 279 | } |
| 280 | //TODO: return error here. |
| 281 | return 0; |
| 282 | } |
| 283 | |
| 284 | function f_rlcmac_mcs_to_cps(CodingScheme mcs, uint2_t part, boolean with_padding := false) return uint5_t { |
| 285 | |
| 286 | var EgprsHeaderType htype := f_rlcmac_mcs2headertype(mcs); |
| 287 | select (htype) { |
| 288 | case (RLCMAC_HDR_TYPE_1) { return f_rlcmac_mcs_to_cps_htype1(mcs, part, with_padding); } |
| 289 | case (RLCMAC_HDR_TYPE_2) { return f_rlcmac_mcs_to_cps_htype2(mcs, part, with_padding); } |
| 290 | case (RLCMAC_HDR_TYPE_3) { return f_rlcmac_mcs_to_cps_htype3(mcs, part, with_padding); } |
| 291 | } |
| 292 | //TODO: return error here. |
| 293 | return 0; |
| 294 | } |
| 295 | |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 296 | template (value) RlcmacUlBlock ts_RLC_UL_CTRL_ACK(RlcmacUlCtrlMsg ctrl, |
| 297 | MacPayloadType pt := MAC_PT_RLCMAC_NO_OPT, |
| 298 | boolean retry := false) := { |
| 299 | ctrl := { |
| 300 | mac_hdr := { |
| 301 | payload_type := pt, |
| 302 | spare := '00000'B, |
| 303 | retry := retry |
| 304 | }, |
| 305 | payload := ctrl |
| 306 | } |
| 307 | } |
| 308 | |
| 309 | /* Send Template for Downlink ACK/NACK */ |
| 310 | template RlcmacUlBlock ts_RLCMAC_DL_ACK_NACK(template uint5_t tfi, AckNackDescription andesc, boolean retry := false) := { |
| 311 | ctrl := { |
| 312 | mac_hdr := { |
| 313 | payload_type := MAC_PT_RLCMAC_NO_OPT, |
| 314 | spare := '00000'B, |
| 315 | retry := retry |
| 316 | }, |
| 317 | payload := { |
| 318 | msg_type := PACKET_DL_ACK_NACK, |
| 319 | u := { |
| 320 | dl_ack_nack := { |
| 321 | dl_tfi := tfi, |
| 322 | ack_nack_desc := andesc, |
| 323 | chreq_desc_presence := '0'B, |
| 324 | chreq_desc := omit, |
| 325 | ch_qual_rep := c_ChQualRep_default |
| 326 | } |
| 327 | } |
| 328 | } |
| 329 | } |
| 330 | } |
| 331 | |
| 332 | /* Template for uplink Data block */ |
| 333 | template RlcmacUlBlock t_RLCMAC_UL_DATA(template uint5_t tfi, template uint4_t cv, template uint7_t bsn, |
| 334 | template LlcBlocks blocks := {}, template boolean stall := false) := { |
| 335 | data := { |
| 336 | mac_hdr := { |
| 337 | payload_type := MAC_PT_RLC_DATA, |
| 338 | countdown := cv, |
| 339 | stall_ind := false, |
| 340 | retry := false, |
| 341 | spare := '0'B, |
| 342 | pfi_ind := false, |
| 343 | tfi := tfi, |
| 344 | tlli_ind := false, |
| 345 | bsn := bsn, |
| 346 | e := false |
| 347 | }, |
| 348 | tlli := omit, |
| 349 | pfi := omit, |
| 350 | blocks := blocks |
| 351 | } |
| 352 | } |
| 353 | template RlcmacUlBlock t_RLCMAC_UL_DATA_TLLI(template uint5_t tfi, template uint4_t cv, template uint7_t bsn, |
| 354 | template LlcBlocks blocks := {}, template boolean stall := false, template GprsTlli tlli) := { |
| 355 | data := { |
| 356 | mac_hdr := { |
| 357 | payload_type := MAC_PT_RLC_DATA, |
| 358 | countdown := cv, |
| 359 | stall_ind := false, |
| 360 | retry := false, |
| 361 | spare := '0'B, |
| 362 | pfi_ind := false, |
| 363 | tfi := tfi, |
| 364 | tlli_ind := true, |
| 365 | bsn := bsn, |
| 366 | e := false |
| 367 | }, |
| 368 | tlli := tlli, |
| 369 | pfi := omit, |
| 370 | blocks := blocks |
| 371 | } |
| 372 | } |
| 373 | |
Pau Espin Pedrol | 2456dad | 2020-04-30 20:22:38 +0200 | [diff] [blame] | 374 | /* Template for uplink Data block */ |
| 375 | template RlcmacUlBlock t_RLCMAC_UL_EGPRS_DATA(CodingScheme mcs, |
| 376 | template uint5_t tfi, template uint4_t cv, |
| 377 | template uint11_t bsn1, template EgprsLlcBlocks blocks := {}) := { |
| 378 | data_egprs := { |
| 379 | mac_hdr := { |
| 380 | header_type := f_rlcmac_mcs2headertype(mcs), |
| 381 | tfi := tfi, |
| 382 | countdown := cv, |
| 383 | foi_si := '0'B, |
| 384 | r_ri := '0'B, |
| 385 | bsn1 := bsn1, |
| 386 | cps := f_rlcmac_mcs_to_cps(mcs, 1, false), |
| 387 | pfi_ind := false, |
| 388 | rsb := '0'B, |
| 389 | spb := '00'B |
| 390 | }, |
| 391 | tlli_ind := false, |
| 392 | e := false, |
| 393 | tlli := omit, |
| 394 | pfi := omit, |
| 395 | blocks := blocks |
| 396 | } |
| 397 | } |
| 398 | |
Vadim Yanitskiy | 0a9b148 | 2020-05-10 14:43:21 +0700 | [diff] [blame] | 399 | template DlMacHeader t_RLCMAC_DlMacH(template (present) MacPayloadType pt, |
| 400 | template (present) boolean rrbp_valid, |
| 401 | template (present) MacRrbp rrbp, |
| 402 | template (present) uint3_t usf) := { |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 403 | payload_type := pt, |
| 404 | rrbp := rrbp, |
Vadim Yanitskiy | 0a9b148 | 2020-05-10 14:43:21 +0700 | [diff] [blame] | 405 | rrbp_valid := rrbp_valid, |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 406 | usf := usf |
| 407 | } |
| 408 | |
| 409 | template RlcmacDlBlock tr_RLCMAC_DUMMY_CTRL(template uint3_t usf := ?, template PageMode page_mode := ?) := { |
| 410 | ctrl := { |
| 411 | mac_hdr := { |
| 412 | payload_type := (MAC_PT_RLCMAC_NO_OPT, MAC_PT_RLCMAC_OPT), |
| 413 | rrbp:= ?, |
| 414 | rrbp_valid := ?, |
| 415 | usf := usf |
| 416 | }, |
| 417 | opt := *, |
| 418 | payload := { |
| 419 | msg_type := PACKET_DL_DUMMY_CTRL, |
| 420 | u := { |
| 421 | dl_dummy := { |
| 422 | page_mode := page_mode, |
| 423 | persistence_levels_present := ?, |
| 424 | persistence_levels := * |
| 425 | } |
| 426 | } |
| 427 | } |
| 428 | } |
| 429 | } |
| 430 | |
| 431 | template RlcmacDlBlock tr_RLCMAC_DL_PACKET_ASS(template uint3_t usf := ?) := { |
| 432 | ctrl := { |
| 433 | mac_hdr := { |
| 434 | payload_type := (MAC_PT_RLCMAC_NO_OPT, MAC_PT_RLCMAC_OPT), |
| 435 | rrbp:= ?, |
| 436 | rrbp_valid := ?, |
| 437 | usf := usf |
| 438 | }, |
| 439 | opt := *, |
| 440 | payload := { |
| 441 | msg_type := PACKET_DL_ASSIGNMENT, |
| 442 | u := { |
| 443 | dl_assignment := { |
| 444 | page_mode := ?, |
| 445 | pres1 := ?, |
| 446 | persistence_levels := *, |
| 447 | tfi_or_tlli := ? |
| 448 | } |
| 449 | } |
| 450 | } |
| 451 | } |
| 452 | } |
| 453 | |
| 454 | template RlcmacDlBlock tr_RLCMAC_UL_PACKET_ASS(template uint3_t usf := ?) := { |
| 455 | ctrl := { |
| 456 | mac_hdr := { |
| 457 | payload_type := (MAC_PT_RLCMAC_NO_OPT, MAC_PT_RLCMAC_OPT), |
| 458 | rrbp:= ?, |
| 459 | rrbp_valid := ?, |
| 460 | usf := usf |
| 461 | }, |
| 462 | opt := *, |
| 463 | payload := { |
| 464 | msg_type := PACKET_UL_ASSIGNMENT, |
| 465 | u := { |
| 466 | ul_assignment := { |
| 467 | page_mode := ?, |
| 468 | persistence_levels_present := ?, |
| 469 | persistence_levels := *, |
| 470 | identity := ?, |
| 471 | is_egprs := ?, /* msg escape */ |
Pau Espin Pedrol | 45b664b | 2020-05-14 15:16:40 +0200 | [diff] [blame] | 472 | gprs := *, |
| 473 | egprs := * |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 474 | } |
| 475 | } |
| 476 | } |
| 477 | } |
| 478 | } |
| 479 | |
Pau Espin Pedrol | 02c972d | 2020-05-13 15:56:16 +0200 | [diff] [blame] | 480 | template RlcmacDlBlock tr_RLCMAC_UL_PACKET_ASS_GPRS(template uint3_t usf := ?, template PktUlAssGprs gprs := ?) |
| 481 | modifies tr_RLCMAC_UL_PACKET_ASS := { |
| 482 | ctrl := { |
| 483 | payload := { |
| 484 | u := { |
| 485 | ul_assignment := { |
| 486 | is_egprs := '0'B, |
Pau Espin Pedrol | 45b664b | 2020-05-14 15:16:40 +0200 | [diff] [blame] | 487 | gprs := gprs, |
| 488 | egprs := omit |
| 489 | } |
| 490 | } |
| 491 | } |
| 492 | } |
| 493 | } |
| 494 | |
| 495 | template RlcmacDlBlock tr_RLCMAC_UL_PACKET_ASS_EGPRS(template uint3_t usf := ?, template PktUlAssEgprs egprs := ?) |
| 496 | modifies tr_RLCMAC_UL_PACKET_ASS := { |
| 497 | ctrl := { |
| 498 | payload := { |
| 499 | u := { |
| 500 | ul_assignment := { |
| 501 | is_egprs := '1'B, |
| 502 | gprs := omit, |
| 503 | egprs := egprs |
Pau Espin Pedrol | 02c972d | 2020-05-13 15:56:16 +0200 | [diff] [blame] | 504 | } |
| 505 | } |
| 506 | } |
| 507 | } |
| 508 | } |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 509 | |
| 510 | /* Receive Template for Uplink ACK/NACK */ |
Pau Espin Pedrol | 692222c | 2020-05-17 00:25:37 +0200 | [diff] [blame^] | 511 | template RlcmacDlBlock tr_RLCMAC_UL_ACK_NACK(template uint5_t ul_tfi) := { |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 512 | ctrl := { |
| 513 | mac_hdr := { |
| 514 | payload_type := (MAC_PT_RLCMAC_NO_OPT, MAC_PT_RLCMAC_OPT), |
| 515 | rrbp:= ?, |
| 516 | rrbp_valid := ?, |
| 517 | usf := ? |
| 518 | }, |
| 519 | opt := *, |
| 520 | payload := { |
| 521 | msg_type := PACKET_UL_ACK_NACK, |
| 522 | u := { |
| 523 | ul_ack_nack := { |
| 524 | page_mode := ?, |
| 525 | msg_excape := ?, |
| 526 | uplink_tfi := ul_tfi, |
Pau Espin Pedrol | 692222c | 2020-05-17 00:25:37 +0200 | [diff] [blame^] | 527 | is_egprs := ?, |
| 528 | gprs := *, |
| 529 | egprs := * |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 530 | } |
| 531 | } |
| 532 | } |
| 533 | } |
Pau Espin Pedrol | 692222c | 2020-05-17 00:25:37 +0200 | [diff] [blame^] | 534 | }; |
| 535 | |
| 536 | template RlcmacDlBlock tr_RLCMAC_UL_ACK_NACK_GPRS(template uint5_t ul_tfi, template UlAckNackGprs gprs := tr_UlAckNackGprs(*)) |
| 537 | modifies tr_RLCMAC_UL_ACK_NACK := { |
| 538 | ctrl := { |
| 539 | payload := { |
| 540 | u := { |
| 541 | ul_ack_nack := { |
| 542 | is_egprs := '0'B, |
| 543 | gprs := gprs, |
| 544 | egprs := omit |
| 545 | } |
| 546 | } |
| 547 | } |
| 548 | } |
| 549 | }; |
| 550 | |
| 551 | template RlcmacDlBlock tr_RLCMAC_UL_ACK_NACK_EGPRS(template uint5_t ul_tfi, template UlAckNackEgprs egprs := tr_UlAckNackEgprs(*)) |
| 552 | modifies tr_RLCMAC_UL_ACK_NACK := { |
| 553 | ctrl := { |
| 554 | payload := { |
| 555 | u := { |
| 556 | ul_ack_nack := { |
| 557 | is_egprs := '1'B, |
| 558 | gprs := omit, |
| 559 | egprs := egprs |
| 560 | } |
| 561 | } |
| 562 | } |
| 563 | } |
| 564 | }; |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 565 | |
| 566 | template RlcmacDlBlock tr_RLCMAC_PACKET_PAG_REQ(template uint3_t usf := ?) := { |
| 567 | ctrl := { |
| 568 | mac_hdr := { |
| 569 | payload_type := MAC_PT_RLCMAC_NO_OPT, |
| 570 | rrbp:= ?, |
| 571 | rrbp_valid := ?, |
| 572 | usf := usf |
| 573 | }, |
| 574 | opt := *, |
| 575 | payload := { |
| 576 | msg_type := PACKET_PAGING_REQUEST, |
| 577 | u := { |
| 578 | paging := { |
| 579 | page_mode := ?, |
| 580 | persistence_levels_present := ?, |
| 581 | persistence_levels := *, |
| 582 | nln_present := ?, |
| 583 | nln := *, |
| 584 | repeated_pageinfo_present := ?, |
| 585 | repeated_pageinfo := * |
| 586 | } |
| 587 | } |
| 588 | } |
| 589 | } |
| 590 | } |
| 591 | |
Vadim Yanitskiy | b6733a6 | 2020-05-10 14:39:00 +0700 | [diff] [blame] | 592 | /* Either GPRS or EGPRS data block with arbitrary contents */ |
| 593 | template RlcmacDlBlock tr_RLCMAC_DATA := (tr_RLCMAC_DATA_GPRS, tr_RLCMAC_DATA_EGPRS); |
| 594 | |
Vadim Yanitskiy | d4f22aa | 2020-05-10 13:13:46 +0700 | [diff] [blame] | 595 | template RlcmacDlBlock tr_RLCMAC_DATA_GPRS(template (present) boolean rrbp_valid := ?, |
| 596 | template (present) MacRrbp rrbp := ?, |
| 597 | template (present) uint3_t usf := ?) := { |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 598 | data := { |
| 599 | mac_hdr := { |
| 600 | mac_hdr := { |
| 601 | payload_type := MAC_PT_RLC_DATA, |
Vadim Yanitskiy | d4f22aa | 2020-05-10 13:13:46 +0700 | [diff] [blame] | 602 | rrbp := rrbp, |
| 603 | rrbp_valid := rrbp_valid, |
| 604 | usf := usf |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 605 | }, |
| 606 | hdr_ext := ? |
| 607 | }, |
| 608 | blocks := ? |
| 609 | } |
| 610 | } |
| 611 | |
| 612 | template RlcmacDlBlock tr_RLCMAC_DATA_EGPRS := { |
| 613 | data_egprs := { |
| 614 | mac_hdr := ?, |
| 615 | fbi := ?, |
| 616 | e := ?, |
| 617 | blocks := ? |
| 618 | } |
| 619 | } |
| 620 | |
| 621 | /* Template for Uplink MAC Control Header */ |
| 622 | template UlMacCtrlHeader t_RLCMAC_UlMacCtrlH(template MacPayloadType pt, template boolean retry := false) := { |
| 623 | payload_type := pt, |
| 624 | spare := '00000'B, |
| 625 | retry := retry |
| 626 | } |
| 627 | |
| 628 | /* Template for Uplink Control ACK */ |
| 629 | template RlcmacUlBlock ts_RLCMAC_CTRL_ACK(GprsTlli tlli, CtrlAck ack := MS_RCVD_TWO_RLC_SAME_RTI_DIFF_RBSN) := { |
| 630 | ctrl := { |
| 631 | mac_hdr := t_RLCMAC_UlMacCtrlH(MAC_PT_RLCMAC_NO_OPT), |
| 632 | payload := { |
| 633 | msg_type := PACKET_CONTROL_ACK, |
| 634 | u := { |
| 635 | ctrl_ack := { |
| 636 | tlli := tlli, |
| 637 | ctrl_ack := ack |
| 638 | } |
| 639 | } |
| 640 | } |
| 641 | } |
| 642 | } |
| 643 | |
| 644 | /* Template for a LlcBlock (part of a LLC frame inside RlcMac?lDataBlock */ |
| 645 | template LlcBlock t_RLCMAC_LLCBLOCK(octetstring data, boolean more := false, boolean e := true) := { |
| 646 | /* let encoder figure out the header */ |
| 647 | hdr := omit, |
| 648 | payload := data |
| 649 | } |
| 650 | |
Pau Espin Pedrol | 2456dad | 2020-04-30 20:22:38 +0200 | [diff] [blame] | 651 | /* Template for a LlcBlock (part of a LLC frame inside RlcMacEgprs?lDataBlock */ |
| 652 | template EgprsLlcBlock t_RLCMAC_LLCBLOCK_EGPRS(octetstring data, boolean e := true) := { |
| 653 | /* let encoder figure out the header */ |
| 654 | hdr := omit, |
| 655 | payload := data |
| 656 | } |
| 657 | |
Pau Espin Pedrol | e8d7d16 | 2020-04-29 19:07:36 +0200 | [diff] [blame] | 658 | } with { encode "RAW"; variant "FIELDORDER(msb)" } |