diff g23m-gsm/dl/dl_pei.c @ 0:75a11d740a02

initial import of gsm-fw from freecalypso-sw rev 1033:5ab737ac3ad7
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 09 Jun 2016 00:02:41 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/g23m-gsm/dl/dl_pei.c	Thu Jun 09 00:02:41 2016 +0000
@@ -0,0 +1,732 @@
+/*
++-----------------------------------------------------------------------------
+|  Project :
+|  Modul   :
++-----------------------------------------------------------------------------
+|  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 module implements the process body interface
+|             for the entity DL of the mobile station.
++-----------------------------------------------------------------------------
+*/
+
+#ifndef DL_PEI_C
+#define DL_PEI_C
+
+#include "config.h"
+#include "fixedconf.h"
+#include "condat-features.h"
+
+#define ENTITY_DL
+
+/*==== INCLUDES ===================================================*/
+#include "typedefs.h"
+#include <string.h>
+#include <stdlib.h>
+#include <stddef.h>
+#include "vsi.h"
+#include "pconst.cdg"
+#include "custom.h"
+#include "gsm.h"
+#include "mon_dl.h"
+#include "prim.h"
+#include "pei.h"
+#include "tok.h"
+#include "ccdapi.h"
+#include "dl.h"
+#include "dl_em.h"
+#include "dl_trc.h"
+
+/*==== EXPORT =====================================================*/
+#ifdef TI_PS_HCOMM_CHANGE
+#else
+GLOBAL T_HANDLE hCommDL         = VSI_ERROR;    /* Self  Communication */
+GLOBAL T_HANDLE hCommRR         = VSI_ERROR;    /* RR  Communication */
+GLOBAL T_HANDLE hCommPL         = VSI_ERROR;    /* PL  Communication */
+#ifdef FF_EM_MODE
+GLOBAL T_HANDLE hCommMMI        = VSI_ERROR;    /* EM  Communication */
+#endif /* FF_EM_MODE */
+#endif
+GLOBAL USHORT dl_handle;
+
+/*==== PRIVATE ====================================================*/
+
+LOCAL void pei_not_supported (void *data);
+LOCAL int dl_process_signal (ULONG opc, void *signal_data);
+
+LOCAL SHORT pei_signal (T_SIGNAL_OPC opc, void *signal_data);
+
+/*==== VARIABLES ==================================================*/
+#ifdef _SIMULATION_
+static UBYTE             first_access = TRUE;
+#endif /* _SIMULATION_ */
+
+static T_MONITOR         dl_mon;
+
+/*==== FUNCTIONS ==================================================*/
+/* Please consider that the opc's are not necessarily sorted
+ * in sequential order.
+ * DL doesn't use the normal technique to get the primitive from the table.
+ * Instead it uses the direct search and compare:
+ * for (i=0; i<n; i++, table++)
+ *  if (table->opc EQ opc)
+ *    break;
+ */
+LOCAL const T_FUNC dl_table[] = {
+  MAK_FUNC_S( drr_dl_establish_req      , DL_ESTABLISH_REQ     ), /* 0x80000003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x80010003 */
+  MAK_FUNC_0( drr_dl_release_req        , DL_RELEASE_REQ       ), /* 0x80020003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x80030003 */
+  MAK_FUNC_S( drr_dl_data_req           , DL_DATA_REQ          ), /* 0x80040003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x80050003 */
+  MAK_FUNC_S( drr_dl_unitdata_req       , DL_UNITDATA_REQ      ), /* 0x80060003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x80070003 */
+  MAK_FUNC_0( drr_dl_suspend_req        , DL_SUSPEND_REQ       ), /* 0x80080003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x80090003 */
+  MAK_FUNC_S( drr_dl_resume_req         , DL_RESUME_REQ        ), /* 0x800a0003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x800b0003 */
+  MAK_FUNC_S( drr_dl_reconnect_req      , DL_RECONNECT_REQ     ), /* 0x800c0003 */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x800d0003 */
+#if defined (DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE)
+  MAK_FUNC_0( dl_trace_read_all         , DL_TRACE_REQ         ), /* 0x800e0003 */
+#else
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x800e0003 */
+#endif /* DL_TRACE_ENABLED && !DL_IMMEDIATE_TRACE */
+  MAK_FUNC_N( pei_not_supported         , 0                    ), /* 0x800f0003 */
+  MAK_FUNC_S( drr_dl_short_unitdata_req , DL_SHORT_UNITDATA_REQ)  /* 0x80100003 */
+};
+
+LOCAL const T_FUNC mphc_table[] = {
+  MAK_FUNC_0( dph_ph_data_ind, PH_DATA_IND )                      /* 0x0000006d */
+};
+
+
+#if defined (DL_2TO1)
+  #if defined(_SIMULATION_)
+    LOCAL const T_FUNC l1_test_table[] = {
+      MAK_FUNC_0( l1test_call_mphc_read_dcch, L1TEST_CALL_MPHC_READ_DCCH    ), /* 8000409b */
+      MAK_FUNC_N( pei_not_supported         , 0                             )  /* removed */
+      MAK_FUNC_N( pei_not_supported         , 0                             )  /* removed */
+    };
+  #endif  /* _SIMULATION_ */
+#else /* DL_2TO1 */
+
+  LOCAL const T_FUNC mdl_table[] = {
+    MAK_FUNC_0( drr_mdl_release_req     , MDL_RELEASE_REQ      ) /* 0x80004004 */
+  };
+
+  #if defined (_SIMULATION_) || (defined (DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE))
+    LOCAL const T_FUNC ph_table[] = {
+    #if defined(_SIMULATION_)
+        MAK_FUNC_0( dph_ph_ready_to_send    , PH_READY_TO_SEND     ), /* 0x4100 */
+    #else
+        MAK_FUNC_N( pei_not_supported       , 0                    ), /* 0x4100 */
+    #endif  /* _SIMULATION_ */
+        MAK_FUNC_N( pei_not_supported       , 0                    ), /* 0x4101 */
+    #if defined (DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE)
+        MAK_FUNC_0( dl_trace_read           , PH_TRACE_IND         )  /* 0x4102 */
+    #else
+        MAK_FUNC_N( pei_not_supported       , 0                    )  /* 0x4102 */
+    #endif /* DL_TRACE_ENABLED && !DL_IMMEDIATE_TRACE*/
+    };
+  #endif  /* _SIMULATION_||(DL_TRACE_ENABLED&& !DL_IMMEDIATE_TRACE) */
+#endif /* DL_2TO1 */
+
+#ifdef FF_EM_MODE
+LOCAL const T_FUNC em_ul_table[] = {
+  MAK_FUNC_0( dl_em_dl_event_req      , EM_DL_EVENT_REQ      ), /* 0x3e0A*/
+};
+#endif /* FF_EM_MODE */
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_primitive       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Process protocol specific primitive.
+
+*/
+LOCAL SHORT pei_primitive (void * ptr)
+{
+  GET_INSTANCE_DATA;
+  T_PRIM *prim = (T_PRIM*)ptr;
+  /*
+   *             |            |
+   *            DL           MDL
+   *             |            |
+   *      +------v------------v------+
+   *      |                          |
+   *      |            DL            |
+   *      |                          |
+   *      +-------------^------------+
+   *                    |
+   *                 MPHC/PH
+   *                    |
+   *
+   */
+
+  TRACE_FUNCTION ("pei_primitive()");
+
+  if (prim NEQ NULL)
+  {
+    ULONG           opc = prim->custom.opc;
+    USHORT          n;
+    const T_FUNC    *table;
+
+    VSI_PPM_REC ((T_PRIM_HEADER*)prim, __FILE__, __LINE__);
+
+    PTRACE_IN (opc);
+
+    switch (SAP_NR(opc))
+    {
+      case SAP_NR(DL_UL):   table =  dl_table; n = TAB_SIZE (dl_table); break;
+      /*case SAP_NR(MPHC_UL):*/ /* same as MPHC_DL */
+      case SAP_NR(MPHC_DL):   
+        table =  mphc_table; 
+        n = TAB_SIZE (mphc_table); 
+        /*
+         * The opcodes for MPHC_DL start at 0x6d
+         */
+        opc -= 0x6d; 
+        break;
+#if defined (DL_2TO1)
+  #if defined(_SIMULATION_)
+      case SAP_NR(L1TEST_UL):
+      case SAP_NR(L1TEST_DL):   table =  l1_test_table; n = TAB_SIZE (l1_test_table); break;
+  #endif /* _SIMULATION_ */
+#else /* DL_2TO1 */
+      case SAP_NR(MDL_DL):  table = mdl_table; n = TAB_SIZE (mdl_table); break;
+  #if defined (_SIMULATION_) || (defined (DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE))
+      case SAP_NR(PH_UL):
+      case SAP_NR(PH_DL):   table =  ph_table; n = TAB_SIZE (ph_table); break;
+  #endif  /* _SIMULATION_||(DL_TRACE_ENABLED&&!DL_IMMEDIATE_TRACE) */
+#endif /* DL_2TO1 */
+
+#ifdef FF_EM_MODE
+      case EM_Ul:           
+        table = em_ul_table; 
+        n = TAB_SIZE (em_ul_table); 
+        /*
+         * The opcodes for EM_Ul start at 0x0a
+         */        
+        opc -= 0x0a; 
+        break;
+#endif /* FF_EM_MODE*/
+      default    : table = NULL;      n = 0;                      break;
+    }
+    if (table)
+    {
+
+#if defined (_SIMULATION_)
+      if (opc NEQ PH_READY_TO_SEND)
+      /*
+       * this simulates function call of layer 1 in the
+       * windows environment
+       */
+#endif /* _SIMULATION_ */
+      dl_data->dl_active = TRUE;
+
+
+      if (PRIM_NR(opc)<n)
+      {
+        table += PRIM_NR(opc);
+#ifdef PALLOC_TRANSITION
+        /*lint -e661 (Warning -- Possible access of out-of-bounds) */
+        P_SDU(prim) = table->soff ? (T_sdu*) (((char*)&prim->data) + table->soff) : 0;
+        /*lint +e661 (Warning -- Possible access of out-of-bounds) */
+#ifndef NO_COPY_ROUTING
+        P_LEN(prim) = table->size + sizeof (T_PRIM_HEADER);
+#endif /* NO_COPY_ROUTING */
+#endif /* PALLOC_TRANSITION */
+
+#if defined (DL_TRACE_ENABLED) && !defined(DL_2TO1)
+        if ((opc EQ DL_TRACE_REQ) OR (opc EQ PH_TRACE_IND))
+          /*lint -e661 (Warning -- Possible access of out-of-bounds) */
+          JUMP (table->func)();
+          /*lint +e661 (Warning -- Possible access of out-of-bounds) */
+        else
+#endif /* DL_TRACE_ENABLED && !DL_2TO1 */
+          /*lint -e661 (Warning -- Possible access of out-of-bounds) */
+          JUMP (table->func) (P2D(prim));
+          /*lint +e661 (Warning -- Possible access of out-of-bounds) */
+      }
+      else
+      {
+        pei_not_supported (P2D(prim));
+      }
+      dl_data->dl_active = FALSE;
+
+      return PEI_OK;
+    }
+
+#if defined (_SIMULATION_)
+    /* TDC is not able to send signals, therefore the redirection over primitives */
+    if (opc EQ DL_SIGNAL_EM_READ)
+    { /* test ACI read of EM buffer only */
+      return dl_process_signal(DL_SIGNAL_EM_READ, NULL);
+    }
+#endif /* _SIMULATION_ */
+
+    /*
+     * Primitive is no GSM Primitive
+     * then forward to the environment
+     */
+
+#ifdef GSM_ONLY
+    MY_PFREE (P2D(prim))
+
+    return PEI_ERROR;
+#else
+    if (opc & SYS_MASK)
+      vsi_c_primitive (VSI_CALLER prim);
+    else
+    {
+      void* p = (void*)P2D(prim);
+      MY_PFREE (p);
+      return PEI_ERROR;
+    }
+#endif
+  }
+  return PEI_OK;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_not_supported   |
++--------------------------------------------------------------------+
+
+  PURPOSE : An unsupported primitive is received.
+
+*/
+
+LOCAL void pei_not_supported (void * data)
+{
+  TRACE_FUNCTION ("pei_not_supported()");
+
+  MY_PFREE (data);
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_init            |
++--------------------------------------------------------------------+
+
+  PURPOSE : Initialize Protocol Stack Entity
+
+*/
+
+LOCAL SHORT pei_init (T_HANDLE handle)
+{
+  dl_handle = handle;
+
+  TRACE_FUNCTION ("pei_init() " __DATE__ " " __TIME__);
+
+#ifdef TI_PS_HCOMM_CHANGE
+  if (!cl_hcom_all_handles_open())
+  {
+    return PEI_ERROR;
+  }
+#else /* for hCommHandles backward compatibility */
+  if (hCommDL < VSI_OK)
+  {
+    if ((hCommDL = vsi_c_open (VSI_CALLER DL_NAME)) < VSI_OK)
+      return PEI_ERROR;
+  }
+
+  if (hCommRR < VSI_OK)
+  {
+    if ((hCommRR = vsi_c_open (VSI_CALLER RR_NAME)) < VSI_OK)
+      return PEI_ERROR;
+  }
+
+
+  if (hCommPL < VSI_OK)
+  {
+    if ((hCommPL = vsi_c_open (VSI_CALLER PL_NAME)) < VSI_OK)
+      return PEI_ERROR;
+  }
+
+#ifdef FF_EM_MODE
+  if (hCommMMI < VSI_OK)
+  {
+    if ((hCommMMI = vsi_c_open (VSI_CALLER ACI_NAME)) < VSI_OK)
+      return PEI_ERROR;
+  }
+#endif /* FF_EM_MODE */
+#endif
+
+  TRC_INIT ();
+
+#if !defined(_SIMULATION_)
+  TRACE_EVENT (dl_version());
+  SYST_TRACE (dl_version());
+#endif  /* !_SIMULATION_ */
+
+  /*
+   * Initialize data base
+   */
+
+#if defined(DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE)
+  dl_trace_init ();
+#endif  /* DL_TRACE_ENABLED && !DL_IMMEDIATE_TRACE*/
+
+  com_init_data ();
+  dcch0_init_dl_data ();
+  sacch0_init_dl_data ();
+
+#ifdef FF_EM_MODE
+  /*
+   initialise event flags
+  */
+  em_init_dl_event_trace();
+  /*
+   initialise dl semaphor for EM event tracing
+  */
+  em_dl_sem_init();
+#endif /* FF_EM_MODE */
+
+  return PEI_OK;
+}
+
+#ifdef _SIMULATION_
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_exit            |
++--------------------------------------------------------------------+
+
+  PURPOSE : Close Resources and terminate
+
+*/
+LOCAL SHORT pei_exit (void)
+{
+  TRACE_FUNCTION ("pei_exit()");
+
+#if defined(DL_TRACE_ENABLED) && !defined(DL_IMMEDIATE_TRACE)
+  dl_trace_exit ();
+#endif  /* DL_TRACE_ENABLED && !DL_IMMEDIATE_TRACE*/
+
+#ifdef FF_EM_MODE
+  em_dl_sem_exit();
+#endif /* FF_EM_MODE */
+
+  /*
+   * clean up communication
+   */
+#ifdef TI_PS_HCOMM_CHANGE
+#else /* for hCommHandles backward compatibility */
+  vsi_c_close (VSI_CALLER hCommDL);
+  hCommDL = VSI_ERROR;
+
+  vsi_c_close (VSI_CALLER hCommRR);
+  hCommRR = VSI_ERROR;
+
+  vsi_c_close (VSI_CALLER hCommPL);
+  hCommPL = VSI_ERROR;
+
+#ifdef FF_EM_MODE
+  vsi_c_close (VSI_CALLER hCommMMI);
+  hCommMMI = VSI_ERROR;
+#endif /* FF_EM_MODE */
+#endif
+
+  TRC_EXIT ();
+
+  return PEI_OK;
+}
+#endif /* _SIMULATION_ */
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_config          |
++--------------------------------------------------------------------+
+
+  PURPOSE : Dynamic Configuration
+
+*/
+
+/* Implements Measure#36 */
+#ifdef NCONFIG
+#else /* NCONFIG */
+LOCAL SHORT pei_config (T_PEI_CONFIG inString)
+{
+  return PEI_OK;
+}
+#endif /* NCONFIG */
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : dl_pei_config       |
++--------------------------------------------------------------------+
+
+  PURPOSE : Dynamic Configuration
+
+*/
+/* Implements Measure#36 */
+#ifdef NCONFIG
+#else /* NCONFIG */
+GLOBAL T_PEI_RETURN dl_pei_config ( char * inString, char * dummy )
+{
+  return pei_config ( inString );
+}
+#endif /* NCONFIG */
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_monitor         |
++--------------------------------------------------------------------+
+
+  PURPOSE : Monitoring of physical Parameters
+
+*/
+
+LOCAL SHORT pei_monitor (void ** monitor)
+{
+  TRACE_FUNCTION ("pei_monitor()");
+
+/* Implements Measure#32: Row 50 */
+
+  * monitor = &dl_mon;
+
+  return PEI_OK;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_create          |
++--------------------------------------------------------------------+
+
+  PURPOSE : Create the Protocol Stack Entity
+
+*/
+
+/*
+ * New Frame
+ */
+GLOBAL T_PEI_RETURN dl_pei_create (T_PEI_INFO **info)
+{
+  static const T_PEI_INFO pei_info =
+  {
+    "DL",
+    {
+      pei_init,
+#ifdef _SIMULATION_
+      pei_exit,
+#else
+      NULL,
+#endif
+      pei_primitive,
+      NULL,             /* no timeout function */
+      pei_signal,       /* signal function     */
+      NULL,             /* no run function     */
+/* Implements Measure#36 */
+#ifdef NCONFIG
+      NULL,             /* no pei_config function     */
+#else /* NCONFIG */
+      pei_config,
+#endif /* NCONFIG */
+      pei_monitor,
+    },
+    #if defined (GPRS)
+    1536,                             /* Stack Size incresed for omaps00140330      */
+    #else
+    #if defined (FAX_AND_DATA)
+    1536,                             /* Stack Size incresed for omaps00140330      */
+    #else
+    1394,                            /* Stack Size incresed for omaps00140330      */
+    #endif
+    #endif
+    10+DL_SIGNAL_DATA_ELEMENTS,     /* Queue Entries   */
+    215,                            /* Priority        */
+    0,                              /* number of timer */
+                                    /* flags           */
+#ifdef _TARGET_
+#ifdef GPRS
+    PASSIVE_BODY|COPY_BY_REF|TRC_NO_SUSPEND|PRIM_NO_SUSPEND
+#else
+    PASSIVE_BODY|COPY_BY_REF|TRC_NO_SUSPEND|PRIM_NO_SUSPEND
+#endif
+#else
+    PASSIVE_BODY|COPY_BY_REF
+#endif
+
+  };
+
+  TRACE_FUNCTION ("pei_create");
+  /*
+   *  Close Resources if open
+   */
+
+#ifdef _SIMULATION_
+  if (first_access)
+    first_access = FALSE;
+  else
+    pei_exit ();
+#endif
+
+  /*
+   * export startup configuration data
+   */
+  *info = (T_PEI_INFO *)&pei_info;
+  /*
+   *  Initialize entity data
+   */
+
+  /*
+   *  Initialize Condat Coder Decoder and
+   *  processes
+   */
+
+
+  return PEI_OK;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-PS (6147)              MODULE  : DL_PEI              |
+| STATE   : code                       ROUTINE : pei_signal          |
++--------------------------------------------------------------------+
+
+  PURPOSE : Functional interface to signal a primitive.
+
+*/
+LOCAL SHORT pei_signal (T_SIGNAL_OPC opc, void *signal_data)
+{
+#ifdef TRACE_FKT
+  {
+    char buf[24];
+    sprintf(buf, "pei_signal (0x%lx)", (ULONG)opc);
+    TRACE_FUNCTION (buf);
+    PTRACE_IN(opc);
+  }
+#elif defined(_SIMULATION_)
+  TRACE_EVENT_WIN_P1 ("pei_signal (0x%lx)", (ULONG)opc);
+#endif
+
+  dl_process_signal ((ULONG)opc, signal_data);
+
+  return PEI_OK;
+}
+
+LOCAL int dl_process_signal (ULONG opc, void *signal_data)
+{
+  /*TRACE_FUNCTION ("pei_process_signal()");*/
+  GET_INSTANCE_DATA;
+  switch (opc)
+  {
+#if defined(DL_TRACE_ENABLED) && !defined (DL_IMMEDIATE_TRACE) && !defined(DL_2TO1)
+  case DL_TRACE_REQ:  /* RR -> DL */
+    SYST_TRACE("call dl_trace_read_all()");
+    dl_trace_read_all ();
+    break;
+  case PH_TRACE_IND:  /* ALR/TIL -> DL */
+    dl_trace_read ();
+    break;
+#endif  /* DL_TRACE_ENABLED && !DL_IMMEDIATE_TRACE &6 !DL_2TO1 */
+#if defined(INVOKE_SIGNAL)
+  case DL_SIGNAL_ESTABLISH_IND:
+    sig_handle_drr_dl_establish_ind ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_ESTABLISH_CNF:
+    sig_handle_drr_dl_establish_cnf ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_DATA_IND:
+    sig_handle_com_data_ind ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_DATA_CNF:
+    sig_handle_drr_dl_data_cnf ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#if 0 /* happens in primitive context only */
+  case DL_SIGNAL_UNITDATA_IND:
+    sig_handle_drr_dl_unitdata_ind (dl_data, (T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#endif  /* 0 */
+  case DL_SIGNAL_SHORT_UNITDATA_IND:
+    sig_handle_drr_dl_short_unitdata_ind ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_RELEASE_IND:
+    sig_handle_drr_dl_release_ind ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_RELEASE_CNF:
+    sig_handle_drr_dl_release_cnf ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_ERROR_IND:
+    sig_handle_drr_error_ind ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_FREE_POINTER:
+    sig_handle_com_free_pointer ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+  case DL_SIGNAL_CONCATENATE:
+    sig_handle_com_concatenate((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#if defined(DL_TRACE_ENABLED)
+  case DL_SIGNAL_L2TRACE:
+    sig_handle_com_l2trace ((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#endif /*DL_TRACE_ENABLED*/
+  case DL_SIGNAL_L3TRACE:
+    sig_handle_com_l3trace((T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#if defined(FF_EM_MODE)
+  case DL_SIGNAL_EM_IND:
+    sig_handle_dl_em_first_event_check ();
+    break;
+  case DL_SIGNAL_EM_WRITE:
+    sig_handle_dl_em_write (dl_data, (T_DL_SIGNAL_DATA *) signal_data);
+    break;
+#if defined(_SIMULATION_)
+  case DL_SIGNAL_EM_READ:
+    {
+      T_MONITOR *dummy;
+
+      em_dl_sem_read ();
+      em_dl_sem_reset ();
+      pei_monitor (&dummy);
+      TRACE_EVENT_WIN (dummy->version);
+    }
+    break;
+#endif  /* _SIMULATION_ */
+#endif  /* FF_EM_MODE */
+#endif /* INVOKE_SIGNAL */
+  default:
+    break;
+  }
+
+#if defined(INVOKE_SIGNAL)
+  if (signal_data)
+  {
+    TRACE_EVENT_WIN_P1 ("pei_process_signal(): set data with idx=%u to FREE",
+      ((T_DL_SIGNAL_DATA *)signal_data)->idx);
+
+    ((T_DL_SIGNAL_DATA *)signal_data)->busy = FALSE;
+  }
+#endif /* INVOKE_SIGNAL */
+
+  return PEI_OK;
+}/* dl_process_signal */
+
+GLOBAL UBYTE * dl_get_sacch_buffer (void)
+{
+  GET_INSTANCE_DATA;
+  return dl_data->sacch_act_buffer.buf;
+}
+
+#endif  /* DL_PEI_C */