diff src/g23m-fad/rlp/rlp_tim.c @ 1:d393cd9bb723

src/g23m-*: initial import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 04:40:46 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-fad/rlp/rlp_tim.c	Sun Jul 15 04:40:46 2018 +0000
@@ -0,0 +1,465 @@
+/*
++-----------------------------------------------------------------------------
+|  Project :  CSD (8411)
+|  Modul   :  Rlp_tim.c
++-----------------------------------------------------------------------------
+|  Copyright 2002 Texas Instruments Berlin, AG
+|                 All rights reserved.
+|
+|                 This file is confidential and a trade secret of Texas
+|                 Instruments Berlin, AG
+|                 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 Berlin, AG.
++-----------------------------------------------------------------------------
+|  Purpose :  This Modul defines the timer handling functions
+|             for the component Radio Link Protocol of the base station
++-----------------------------------------------------------------------------
+*/
+
+#ifndef RLP_TIM_C
+#define RLP_TIM_C
+#endif
+
+#define ENTITY_RLP
+
+/*==== INCLUDES ===================================================*/
+
+#include <string.h>
+#include "typedefs.h"
+#include "vsi.h"
+#include "macdef.h"
+#include "custom.h"
+#include "gsm.h"
+#include "cus_rlp.h"
+#include "prim.h"
+#include "tok.h"
+#include "rlp.h"
+
+/*==== EXPORT =====================================================*/
+
+/*==== PRIVAT =====================================================*/
+
+/*==== VARIABLES ==================================================*/
+
+/*==== FUNCTIONS ==================================================*/
+
+/*
++------------------------------------------------------------------------------
+|  Function    : tim_tt
++------------------------------------------------------------------------------
+|  Description : Timeout of timer TT
+|
+|  Parameters  :
+|
+|
+|  Return      :
++------------------------------------------------------------------------------
+*/
+
+
+LOCAL void tim_tt (void)
+{
+
+  BOOL retransError;
+
+  TRACE_FUNCTION ("tim_tt()");
+
+  switch (GET_STATE (KER))
+  {
+    case RLP_PENDING_CONNECT_REQ:
+      /*
+       * processing for state RLP_PENDING_CONNECT_REQ
+       */
+      rlp_data->ker.Poll_xchg = IW_IDLE;
+
+      if (rlp_data->ker.SABM_Count > rlp_data->ker.N2)
+      {
+        ker_send_rlp_error_ind (RLP_ERR_SABM_RETRANS);
+        SET_STATE (KER, RLP_PERMANENT_ERROR);
+      }
+      else
+        rlp_data->ker.SABM_State = ISW_SEND;
+      break;
+
+    case RLP_CONNECTION_ESTABLISHED:
+      /*
+       * processing for state RLP_CONNECTION_ESTABLISHED
+       */
+      rlp_data->ker.Poll_xchg = IW_IDLE;
+
+      sbm_check_rej_count(&retransError);
+
+      if (!retransError)
+      {
+        switch (rlp_data->ker.Poll_State)
+        {
+          case ISW_IDLE:
+            rlp_data->ker.Poll_State = ISW_SEND;
+            break;
+
+          case ISW_WAIT:
+            if (rlp_data->ker.Poll_Count <= rlp_data->ker.N2)
+              rlp_data->ker.Poll_State = ISW_SEND;
+
+            else
+            {
+              ker_reset_all_t_rcvs ();
+              rbm_reset_srej_slots();
+              TIMERSTOP (TRCVR_HANDLE);
+              rlp_data->ker.DISC_State = ISW_SEND;
+              rlp_data->ker.DISC_Count = 0;
+              rlp_data->ker.DISC_PBit = 1;
+
+              ker_deinit_link_vars ();
+              rlp_data->ker.DISC_Ind = TRUE;
+
+              SET_STATE (KER, RLP_DISCONNECT_INITIATED);
+              TRACE_EVENT("#10");
+            }
+            break;
+        }
+      }
+      else
+      {
+        ker_reset_all_t_rcvs ();
+        rbm_reset_srej_slots();
+        TIMERSTOP (TRCVR_HANDLE);
+
+        rlp_data->ker.DISC_State = ISW_SEND;
+        rlp_data->ker.DISC_Count = 0;
+        rlp_data->ker.DISC_PBit = 1;
+
+        ker_deinit_link_vars ();
+        rlp_data->ker.DISC_Ind = TRUE;
+
+        SET_STATE (KER, RLP_DISCONNECT_INITIATED);
+        TRACE_EVENT("#11");
+      }
+
+      break;
+
+    case RLP_DISCONNECT_INITIATED:
+      /*
+       * processing for state RLP_DISCONNECT_INITIATED
+       */
+      if (rlp_data->ker.DISC_PBit EQ 1)
+        rlp_data->ker.Poll_xchg = IW_IDLE;
+
+      if (rlp_data->ker.DISC_Count > rlp_data->ker.N2)
+      {
+        ker_send_rlp_error_ind (RLP_ERR_DISC_RETRANS);
+        SET_STATE (KER, RLP_PERMANENT_ERROR);
+      }
+      else
+        rlp_data->ker.DISC_State = ISW_SEND;
+      break;
+
+    case RLP_PENDING_RESET_REQ:
+      /*
+       * processing for state RLP_PENDING_RESET_REQ
+       */
+      rlp_data->ker.Poll_xchg = IW_IDLE;
+      if (rlp_data->ker.SABM_Count > rlp_data->ker.N2)
+      {
+        ker_send_rlp_error_ind (RLP_ERR_SABM_RETRANS);
+        SET_STATE (KER, RLP_PERMANENT_ERROR);
+      }
+      else
+        rlp_data->ker.SABM_State = ISW_SEND;
+      break;
+
+    case RLP_PENDING_REMAP_REQ:
+      /*
+       * processing for state RLP_PENDING_REMAP_REQ
+       */
+      rlp_data->ker.Poll_xchg = IW_IDLE;
+
+      ker_send_rlp_error_ind (RLP_ERR_REMAP_RETRANS);
+      SET_STATE (KER, RLP_PERMANENT_ERROR);
+  }
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : tim_tul_rcv
++------------------------------------------------------------------------------
+|  Description : Timeout of timer TUL_RCV
+|
+|  Parameters  : -
+|
+|
+|  Return      : -
++------------------------------------------------------------------------------
+*/
+
+
+LOCAL void tim_tul_rcv (void)
+{
+  TRACE_FUNCTION ("tim_tul_rcv()");
+
+  switch (GET_STATE (KER))
+  {
+    case RLP_CONNECTION_ESTABLISHED:
+    case RLP_PENDING_REMAP_REQ:
+    case RLP_REMAP_DATA:
+      /*
+       * processing for states RLP_CONNECTION_ESTABLISHED
+       *                       RLP_PENDING_REMAP_REQ:
+       *                       RLP_REMAP_DATA:
+       */
+      switch (rlp_data->ker.UL_Rcv_State)
+      {
+        case IW_WAIT:
+        {
+          T_RLP_DATA_IND *rlp_data_ind;
+
+          if (rlp_data->rbm.CurrPrimCou > 0 )
+          {
+            /* if some data are there */
+            rlp_data_ind = rbm_get_curr_prim ();
+            /*
+             * send the waiting but not complete filled prim to L2R
+             */
+            PSENDX (L2R, rlp_data_ind);
+            rlp_data->ker.UL_Rcv_State = IW_IDLE;
+          }
+          else
+          {
+            TRACE_EVENT("no data to send!");
+          }
+          break;
+        }
+      }
+      break;
+  }
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : tim_trcvr
++------------------------------------------------------------------------------
+|  Description : Timeout of timer TRCVR
+|
+|  Parameters  : -
+|
+|
+|  Return      : -
++------------------------------------------------------------------------------
+*/
+
+
+LOCAL void tim_trcvr (void)
+{
+  TRACE_FUNCTION ("tim_trcvr()");
+
+  switch (GET_STATE (KER))
+  {
+    case RLP_CONNECTION_ESTABLISHED:
+      /*
+       * processing for state RLP_CONNECTION_ESTABLISHED
+       */
+      switch (rlp_data->ker.REJ_State)
+      {
+        case ISW_WAIT:
+          ker_reset_all_t_rcvs();
+          rbm_reset_srej_slots();
+
+          TIMERSTOP(TT_HANDLE);
+          rlp_data->ker.REJ_State = ISW_IDLE; /* jk: acc. ETSI after timer reset IDLE */
+                                              /* in order to enable new REJ condition */
+          /*
+           * Don't disconnect
+           * a timeout of TRCVR can be ignored
+           * The network will get a timeout for the sent frames,
+           * which we have not received.
+           */
+          /*
+          rlp_data->ker.DISC_State = ISW_SEND;
+          rlp_data->ker.DISC_Count = 0;
+
+          switch(rlp_data->ker.Poll_xchg)
+          {
+          case IW_IDLE:
+            rlp_data->ker.DISC_PBit = 1;
+            break;
+
+          default:
+            rlp_data->ker.DISC_PBit = 0;
+            break;
+          }
+
+          ker_deinit_link_vars();
+          rlp_data->ker.DISC_Ind = TRUE;
+          SET_STATE (KER, RLP_DISCONNECT_INITIATED);
+          TRACE_EVENT("#12");
+          */
+          break;
+      }
+        break;
+  }
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : tim_trcvs
++------------------------------------------------------------------------------
+|  Description : Timeout of timer TRCVS
+|
+|  Parameters  : rcvs_slot
+|
+|
+|  Return      : -
++------------------------------------------------------------------------------
+*/
+
+
+LOCAL void tim_trcvs (T_FRAME_NUM rcvs_slot)
+{
+  TRACE_FUNCTION ("tim_trcvs()");
+
+  TRACE_EVENT_P1 ("Timeout RCVS[%d]", rcvs_slot);
+
+  if (GET_STATE (KER) EQ RLP_CONNECTION_ESTABLISHED)
+  {
+    if (rbm_is_state_wait(rcvs_slot))
+    {
+      rlp_data->ker.SREJ_Count--;
+
+      if(srm_get_counter(rcvs_slot) > rlp_data->ker.N2)
+      {
+        ker_reset_all_t_rcvs();
+        rbm_reset_srej_slots();
+        TIMERSTOP(TT_HANDLE);
+        rlp_data->ker.DISC_State = ISW_SEND;
+        rlp_data->ker.DISC_Count = 0;
+
+        switch(rlp_data->ker.Poll_xchg)
+        {
+        case IW_IDLE:
+          rlp_data->ker.DISC_PBit = 1;
+          break;
+
+        default:
+          rlp_data->ker.DISC_PBit = 0;
+          break;
+        }
+        ker_deinit_link_vars();
+        rlp_data->ker.DISC_Ind = TRUE;
+        SET_STATE (KER, RLP_DISCONNECT_INITIATED);
+        TRACE_EVENT("#13");
+      }
+      else
+      {
+        rbm_set_rslot_wait2srej (rcvs_slot);
+      }
+    }
+  }
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : tim_txid
++------------------------------------------------------------------------------
+|  Description : Timeout of timer TXID
+|
+|  Parameters  : -
+|
+|
+|  Return      : -
++------------------------------------------------------------------------------
+*/
+
+
+LOCAL void tim_txid (void)
+{
+  TRACE_FUNCTION ("tim_txid()");
+
+  switch (GET_STATE (KER))
+  {
+    case RLP_ADM_AND_DETACHED:
+      /*
+       * no processing for state RLP_ADM_AND_DETACHED
+       */
+      break;
+
+    default:
+      /*
+       * processing for all other kernel states
+       */
+      rlp_data->ker.Poll_xchg = IW_IDLE;
+      if (rlp_data->ker.XID_Count >= rlp_data->ker.N2)
+      {
+        ker_send_rlp_error_ind (RLP_ERR_XID_RETRANS);
+        SET_STATE (KER, RLP_PERMANENT_ERROR);
+      }
+      else
+      {
+        SET_STATE(KERXID_C, ISW_SEND);
+        rlp_data->ker.XID_Count++;
+      }
+      break;
+  }
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : rlp_exec_timeout
++------------------------------------------------------------------------------
+|  Description : execute timeout function depending on index
+|
+|  Parameters  : index
+|
+|
+|  Return      : -
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void rlp_exec_timeout (USHORT index)
+{
+  T_FRAME_NUM   rcvs_slot;
+
+  TRACE_FUNCTION ("rlp_exec_timeout()");
+
+  switch (index)
+  {
+    case TT_HANDLE:
+      tim_tt ();
+      break;
+
+    case TUL_RCV_HANDLE:
+      tim_tul_rcv ();
+      break;
+
+    case TRCVR_HANDLE:
+      tim_trcvr ();
+      break;
+
+    case TXID_HANDLE:
+      tim_txid ();
+      break;
+
+    default:
+      if ( index < MAX_SREJ_COUNT )
+      {
+        /* case TRCVS_HANDLE: */
+        if ((rcvs_slot = ker_getSlotTRCVS (index)) NEQ INVALID_IDX)
+        {
+          /*
+           * store the index of the rcvs_timer
+           */
+          rlp_data->rcvs_slot = rcvs_slot;
+          tim_trcvs (rlp_data->rcvs_slot);
+        }
+      }
+      else
+      {
+        TRACE_EVENT ("UNDEFINED TIMEOUT");
+      }
+      break;
+  }
+}
+
+