<p>Vadim Yanitskiy <strong>merged</strong> this change.</p><p><a href="https://gerrit.osmocom.org/11752">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Jenkins Builder: Verified
  Harald Welte: Looks good to me, approved

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">library/GSUP_Types.ttcn: add READY-FOR-SM message<br><br>According to 3GPP TS 29.002, section 12.4, MAP-READY-FOR-SM is<br>used between the MSC and VLR as well as between the VLR and the<br>HLR to indicate that a subscriber has memory available for SMS.<br><br>This change replicates this service in GSUP as READY_FOR_SM_*.<br>The only mandatory IE for this service (excluding Invoke ID) is<br>'Alert Reason' that is replicated by OSMO_GSUP_SM_ALERT_RSN_IE.<br><br>Change-Id: If2256607527ecfcb10285583332fb8b0515d7c78<br>Related: OS#3587<br>---<br>M library/GSUP_Types.ttcn<br>1 file changed, 104 insertions(+), 3 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/library/GSUP_Types.ttcn b/library/GSUP_Types.ttcn</span><br><span>index 9cb3255..d16b4a5 100644</span><br><span>--- a/library/GSUP_Types.ttcn</span><br><span>+++ b/library/GSUP_Types.ttcn</span><br><span>@@ -51,7 +51,8 @@</span><br><span>         OSMO_GSUP_SM_RP_OA_IE           ('42'O),</span><br><span>     OSMO_GSUP_SM_RP_UI_IE           ('43'O),</span><br><span>     OSMO_GSUP_SM_RP_CAUSE_IE        ('44'O),</span><br><span style="color: hsl(0, 100%, 40%);">-        OSMO_GSUP_SM_RP_MMS_IE          ('45'O)</span><br><span style="color: hsl(120, 100%, 40%);">+       OSMO_GSUP_SM_RP_MMS_IE          ('45'O),</span><br><span style="color: hsl(120, 100%, 40%);">+      OSMO_GSUP_SM_ALERT_RSN_IE       ('46'O)</span><br><span> } with { variant "FIELDLENGTH(8)" };</span><br><span> </span><br><span> type enumerated GSUP_MessageType {</span><br><span>@@ -91,7 +92,11 @@</span><br><span> </span><br><span>         OSMO_GSUP_MSGT_MT_FORWARD_SM_REQUEST    ('00101000'B),</span><br><span>       OSMO_GSUP_MSGT_MT_FORWARD_SM_ERROR      ('00101001'B),</span><br><span style="color: hsl(0, 100%, 40%);">-  OSMO_GSUP_MSGT_MT_FORWARD_SM_RESULT     ('00101010'B)</span><br><span style="color: hsl(120, 100%, 40%);">+ OSMO_GSUP_MSGT_MT_FORWARD_SM_RESULT     ('00101010'B),</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+      OSMO_GSUP_MSGT_READY_FOR_SM_REQUEST     ('00101100'B),</span><br><span style="color: hsl(120, 100%, 40%);">+        OSMO_GSUP_MSGT_READY_FOR_SM_ERROR       ('00101101'B),</span><br><span style="color: hsl(120, 100%, 40%);">+        OSMO_GSUP_MSGT_READY_FOR_SM_RESULT      ('00101110'B)</span><br><span> } with { variant "FIELDLENGTH(8)" };</span><br><span> </span><br><span> type enumerated GSUP_CancelType {</span><br><span>@@ -150,6 +155,7 @@</span><br><span>                                sm_rp_ui, tag = OSMO_GSUP_SM_RP_UI_IE;</span><br><span>                               sm_rp_cause, tag = OSMO_GSUP_SM_RP_CAUSE_IE;</span><br><span>                                 sm_rp_mms, tag = OSMO_GSUP_SM_RP_MMS_IE;</span><br><span style="color: hsl(120, 100%, 40%);">+                              sm_alert_rsn, tag = OSMO_GSUP_SM_ALERT_RSN_IE;</span><br><span>                      )"</span><br><span> };</span><br><span> </span><br><span>@@ -190,7 +196,8 @@</span><br><span>      GSUP_SM_RP_OA           sm_rp_oa,</span><br><span>    octetstring             sm_rp_ui,</span><br><span>    OCT1                    sm_rp_cause,</span><br><span style="color: hsl(0, 100%, 40%);">-    OCT1                    sm_rp_mms</span><br><span style="color: hsl(120, 100%, 40%);">+     OCT1                    sm_rp_mms,</span><br><span style="color: hsl(120, 100%, 40%);">+    GSUP_SM_ALERT_RSN_Type  sm_alert_rsn</span><br><span> };</span><br><span> </span><br><span> type record GSUP_PDU {</span><br><span>@@ -851,6 +858,29 @@</span><br><span>      }</span><br><span> }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+/* SM Alert Reason types, see 7.6.8.8 */</span><br><span style="color: hsl(120, 100%, 40%);">+type enumerated GSUP_SM_ALERT_RSN_Type {</span><br><span style="color: hsl(120, 100%, 40%);">+        GSUP_SM_ALERT_RSN_TYPE_NONE             ('00'O),</span><br><span style="color: hsl(120, 100%, 40%);">+      GSUP_SM_ALERT_RSN_TYPE_MS_PRESENT       ('01'O),</span><br><span style="color: hsl(120, 100%, 40%);">+      GSUP_SM_ALERT_RSN_TYPE_MEM_AVAIL        ('02'O)</span><br><span style="color: hsl(120, 100%, 40%);">+} with { variant "FIELDLENGTH(8)" };</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+/* SM Alert Reason IE (used in READY-FOR-SM), see 7.6.8.8 */</span><br><span style="color: hsl(120, 100%, 40%);">+template (value) GSUP_IE ts_GSUP_IE_SM_ALERT_RSN(GSUP_SM_ALERT_RSN_Type rsn) := {</span><br><span style="color: hsl(120, 100%, 40%);">+    tag := OSMO_GSUP_SM_ALERT_RSN_IE,</span><br><span style="color: hsl(120, 100%, 40%);">+     len := 0, /* overwritten */</span><br><span style="color: hsl(120, 100%, 40%);">+   val := {</span><br><span style="color: hsl(120, 100%, 40%);">+              sm_alert_rsn := rsn</span><br><span style="color: hsl(120, 100%, 40%);">+   }</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+template GSUP_IE tr_GSUP_IE_SM_ALERT_RSN(template GSUP_SM_ALERT_RSN_Type rsn) := {</span><br><span style="color: hsl(120, 100%, 40%);">+      tag := OSMO_GSUP_SM_ALERT_RSN_IE,</span><br><span style="color: hsl(120, 100%, 40%);">+     len := ?,</span><br><span style="color: hsl(120, 100%, 40%);">+     val := {</span><br><span style="color: hsl(120, 100%, 40%);">+              sm_alert_rsn := rsn</span><br><span style="color: hsl(120, 100%, 40%);">+   }</span><br><span style="color: hsl(120, 100%, 40%);">+}</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> template (value) GSUP_IE ts_GSUP_IE_SSInfo(octetstring ss) := {</span><br><span>    tag := OSMO_GSUP_SS_INFO_IE,</span><br><span>         len := 0, /* overwritten */</span><br><span>@@ -1148,6 +1178,77 @@</span><br><span>         }</span><br><span> );</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+template (value) GSUP_PDU ts_GSUP_MO_READY_FOR_SM_REQ(</span><br><span style="color: hsl(120, 100%, 40%);">+   hexstring imsi,</span><br><span style="color: hsl(120, 100%, 40%);">+       OCT1 sm_rp_mr, /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+       GSUP_SM_ALERT_RSN_Type sm_alert_rsn /* SM Alert Reason, see 7.6.8.8 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := ts_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+ OSMO_GSUP_MSGT_READY_FOR_SM_REQUEST,</span><br><span style="color: hsl(120, 100%, 40%);">+  {</span><br><span style="color: hsl(120, 100%, 40%);">+             valueof(ts_GSUP_IE_IMSI(imsi)),</span><br><span style="color: hsl(120, 100%, 40%);">+               valueof(ts_GSUP_IE_SM_RP_MR(sm_rp_mr)),</span><br><span style="color: hsl(120, 100%, 40%);">+               valueof(ts_GSUP_IE_SM_ALERT_RSN(sm_alert_rsn))</span><br><span style="color: hsl(120, 100%, 40%);">+        }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+template GSUP_PDU tr_GSUP_MO_READY_FOR_SM_REQ(</span><br><span style="color: hsl(120, 100%, 40%);">+ template hexstring imsi := ?,</span><br><span style="color: hsl(120, 100%, 40%);">+ template OCT1 sm_rp_mr := ?, /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+ template GSUP_SM_ALERT_RSN_Type sm_alert_rsn := ? /* SM Alert Reason, see 7.6.8.8 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := tr_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+   OSMO_GSUP_MSGT_READY_FOR_SM_REQUEST,</span><br><span style="color: hsl(120, 100%, 40%);">+  {</span><br><span style="color: hsl(120, 100%, 40%);">+             tr_GSUP_IE_IMSI(imsi),</span><br><span style="color: hsl(120, 100%, 40%);">+                tr_GSUP_IE_SM_RP_MR(sm_rp_mr),</span><br><span style="color: hsl(120, 100%, 40%);">+                tr_GSUP_IE_SM_ALERT_RSN(sm_alert_rsn)</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+template (value) GSUP_PDU ts_GSUP_MO_READY_FOR_SM_RES(</span><br><span style="color: hsl(120, 100%, 40%);">+       hexstring imsi,</span><br><span style="color: hsl(120, 100%, 40%);">+       OCT1 sm_rp_mr /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := ts_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+ OSMO_GSUP_MSGT_READY_FOR_SM_RESULT,</span><br><span style="color: hsl(120, 100%, 40%);">+   {</span><br><span style="color: hsl(120, 100%, 40%);">+             valueof(ts_GSUP_IE_IMSI(imsi)),</span><br><span style="color: hsl(120, 100%, 40%);">+               valueof(ts_GSUP_IE_SM_RP_MR(sm_rp_mr))</span><br><span style="color: hsl(120, 100%, 40%);">+        }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+template GSUP_PDU tr_GSUP_MO_READY_FOR_SM_RES(</span><br><span style="color: hsl(120, 100%, 40%);">+ template hexstring imsi := ?,</span><br><span style="color: hsl(120, 100%, 40%);">+ template OCT1 sm_rp_mr := ? /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := tr_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+   OSMO_GSUP_MSGT_READY_FOR_SM_RESULT,</span><br><span style="color: hsl(120, 100%, 40%);">+   {</span><br><span style="color: hsl(120, 100%, 40%);">+             tr_GSUP_IE_IMSI(imsi),</span><br><span style="color: hsl(120, 100%, 40%);">+                tr_GSUP_IE_SM_RP_MR(sm_rp_mr)</span><br><span style="color: hsl(120, 100%, 40%);">+ }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+template (value) GSUP_PDU ts_GSUP_MO_READY_FOR_SM_ERR(</span><br><span style="color: hsl(120, 100%, 40%);">+       hexstring imsi,</span><br><span style="color: hsl(120, 100%, 40%);">+       OCT1 sm_rp_mr, /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+       OCT1 sm_rp_cause /* RP-Cause value, see GSM TS 04.11, 8.2.5.4 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := ts_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+       OSMO_GSUP_MSGT_READY_FOR_SM_ERROR,</span><br><span style="color: hsl(120, 100%, 40%);">+    {</span><br><span style="color: hsl(120, 100%, 40%);">+             valueof(ts_GSUP_IE_IMSI(imsi)),</span><br><span style="color: hsl(120, 100%, 40%);">+               valueof(ts_GSUP_IE_SM_RP_MR(sm_rp_mr)),</span><br><span style="color: hsl(120, 100%, 40%);">+               valueof(ts_GSUP_IE_SM_RP_CAUSE(sm_rp_cause))</span><br><span style="color: hsl(120, 100%, 40%);">+  }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+template GSUP_PDU tr_GSUP_MO_READY_FOR_SM_ERR(</span><br><span style="color: hsl(120, 100%, 40%);">+ template hexstring imsi := ?,</span><br><span style="color: hsl(120, 100%, 40%);">+ template OCT1 sm_rp_mr := ?, /* Message Reference, see GSM TS 04.11, 8.2.3 */</span><br><span style="color: hsl(120, 100%, 40%);">+ template OCT1 sm_rp_cause := ? /* RP-Cause value, see GSM TS 04.11, 8.2.5.4 */</span><br><span style="color: hsl(120, 100%, 40%);">+) := tr_GSUP(</span><br><span style="color: hsl(120, 100%, 40%);">+ OSMO_GSUP_MSGT_READY_FOR_SM_ERROR,</span><br><span style="color: hsl(120, 100%, 40%);">+    {</span><br><span style="color: hsl(120, 100%, 40%);">+             tr_GSUP_IE_IMSI(imsi),</span><br><span style="color: hsl(120, 100%, 40%);">+                tr_GSUP_IE_SM_RP_MR(sm_rp_mr),</span><br><span style="color: hsl(120, 100%, 40%);">+                tr_GSUP_IE_SM_RP_CAUSE(sm_rp_cause)</span><br><span style="color: hsl(120, 100%, 40%);">+   }</span><br><span style="color: hsl(120, 100%, 40%);">+);</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> function f_gsup_find_ie(GSUP_PDU msg, GSUP_IEI iei, out GSUP_IeValue ret) return boolean {</span><br><span>        for (var integer i := 0; i < sizeof(msg.ies); i := i+1) {</span><br><span>                 if (msg.ies[i].tag == iei) {</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/11752">change 11752</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/11752"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: osmo-ttcn3-hacks </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-MessageType: merged </div>
<div style="display:none"> Gerrit-Change-Id: If2256607527ecfcb10285583332fb8b0515d7c78 </div>
<div style="display:none"> Gerrit-Change-Number: 11752 </div>
<div style="display:none"> Gerrit-PatchSet: 6 </div>
<div style="display:none"> Gerrit-Owner: Vadim Yanitskiy <axilirator@gmail.com> </div>
<div style="display:none"> Gerrit-Reviewer: Harald Welte <laforge@gnumonks.org> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins Builder (1000002) </div>
<div style="display:none"> Gerrit-Reviewer: Vadim Yanitskiy <axilirator@gmail.com> </div>