diff src/g23m-fad/ppp/ppp_pei.c @ 1:fa8dc04885d8

src/g23m-*: import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:25:50 +0000 (2020-10-16)
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-fad/ppp/ppp_pei.c	Fri Oct 16 06:25:50 2020 +0000
@@ -0,0 +1,1176 @@
+/* 
++----------------------------------------------------------------------------- 
+|  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 Point-to-Point Protocol (PPP)
+|             
+|             Exported functions:
+|             
+|             pei_create    - Create the Protocol Stack Entity
+|             pei_init      - Initialize Protocol Stack Entity
+|             pei_primitive - Process Primitive
+|             pei_timeout   - Process Timeout
+|             pei_exit      - Close resources and terminate
+|             pei_run       - Process Primitive
+|             pei_config    - Dynamic Configuration
+|             pei_monitor   - Monitoring of physical Parameters
++----------------------------------------------------------------------------- 
+*/ 
+
+#define PPP_PEI_C
+
+#define ENTITY_PPP
+
+/*==== INCLUDES =============================================================*/
+
+#include <stddef.h>
+#include "typedefs.h"   /* to get Condat data types */
+#include "vsi.h"        /* to get a lot of macros */
+/*lint -efile(766,macdef.h) */
+#include "macdef.h"     /* to get a lot of macros */
+#include "custom.h"     /* to get a lot of macros */
+#include "gsm.h"        /* to get a lot of macros */
+/*lint -efile(766,cnf_ppp.h) */
+#include "cnf_ppp.h"    /* to get cnf-definitions */
+#include "mon_ppp.h"    /* to get mon-definitions */
+#include "prim.h"       /* to get the definitions of used SAP and directions */
+#include "dti.h"        /* to get the DTILIB definitions */
+#include "ppp.h"        /* to get the global entity definitions */
+
+#ifdef FF_STATUS_TE
+#include "gdi.h"        /* To include driver type-defines */
+#include "ste.h"        /* To include function interface for TE status driver */
+#endif /* FF_STATUS_TE */
+
+#include "ppp_rtf.h"     /* to get rt functions */
+#include "ppp_rtp.h"     /* to get rt primitives */
+#include "ppp_rts.h"     /* to get rt signals */
+
+/*lint -efile(766,ppp_prxp.h) */
+#include "ppp_prxf.h"     /* to get prx functions */
+#include "ppp_prxp.h"     /* to get prx primitives */
+#include "ppp_prxs.h"     /* to get prx signals */
+
+/*lint -efile(766,ppp_ptxp.h) */
+#include "ppp_ptxf.h"     /* to get ptx functions */
+#include "ppp_ptxp.h"     /* to get ptx primitives */
+#include "ppp_ptxs.h"     /* to get ptx signals */
+
+/*lint -efile(766,ppp_frxp.h) */
+#include "ppp_frxf.h"     /* to get frx functions */
+#include "ppp_frxp.h"     /* to get frx primitives */
+#include "ppp_frxs.h"     /* to get frx signals */
+
+/*lint -efile(766,ppp_ftxp.h) */
+#include "ppp_ftxf.h"     /* to get ftx functions */
+#include "ppp_ftxp.h"     /* to get ftx primitives */
+#include "ppp_ftxs.h"     /* to get ftx signals */
+
+#include "ppp_arbf.h"     /* to get arb functions */
+#include "ppp_arbp.h"     /* to get arb primitives */
+#include "ppp_arbs.h"     /* to get arb signals */
+
+/*lint -efile(766,ppp_lcpp.h) */
+/*lint -efile(766,ppp_lcps.h) */
+#include "ppp_lcpf.h"     /* to get lcp functions */
+#include "ppp_lcpp.h"     /* to get lcp primitives */
+#include "ppp_lcps.h"     /* to get lcp signals */
+
+/*lint -efile(766,ppp_onap.h) */
+/*lint -efile(766,ppp_onas.h) */
+#include "ppp_onaf.h"     /* to get ona functions */
+#include "ppp_onap.h"     /* to get ona primitives */
+#include "ppp_onas.h"     /* to get ona signals */
+
+/*lint -efile(766,ppp_ncpp.h) */
+/*lint -efile(766,ppp_ncps.h) */
+#include "ppp_ncpf.h"     /* to get ncp functions */
+#include "ppp_ncpp.h"     /* to get ncp primitives */
+#include "ppp_ncps.h"     /* to get ncp signals */
+
+/*lint -efile(766,ppp_papp.h) */
+/*lint -efile(766,ppp_paps.h) */
+#include "ppp_papf.h"     /* to get pap functions */
+#include "ppp_papp.h"     /* to get pap primitives */
+#include "ppp_paps.h"     /* to get pap signals */
+
+/*lint -efile(766,ppp_capp.h) */
+/*lint -efile(766,ppp_caps.h) */
+#include "ppp_capf.h"     /* to get chap functions */
+#include "ppp_capp.h"     /* to get chap primitives */
+#include "ppp_caps.h"     /* to get chap signals */
+
+#include "ppp_dti.h"      /* to get the DTI signals */
+
+/*==== DEFINITIONS ==========================================================*/
+
+/*==== TYPES ================================================================*/
+
+/*==== GLOBAL VARS ==========================================================*/
+
+/*==== LOCAL VARS ===========================================================*/
+
+static  BOOL          first_access  = TRUE;
+static  T_MONITOR     ppp_mon;
+
+/*
+ * Jumptables to primitive handler functions. One table per SAP.
+ *
+ * Use MAK_FUNC_0 for primitives which contains no SDU.
+ * Use MAK_FUNC_S for primitives which contains a SDU.
+ */
+
+/*
+ * Function is needed for developing. This declaration can be removed
+ * as soon as this function is no more called (i.e. all primitives are
+ * handled).
+ */
+
+LOCAL void primitive_not_supported (void *data);
+LOCAL void pei_dti_dti_ready_ind   (T_DTI2_READY_IND        *dti_ready_ind);
+LOCAL void pei_dti_dti_data_req    (T_DTI2_DATA_REQ         *dti_data_req);
+LOCAL void pei_dti_dti_data_ind    (T_DTI2_DATA_IND         *dti_data_ind);
+LOCAL void pei_dti_dti_getdata_req (T_DTI2_GETDATA_REQ      *dti_getdata_req);
+LOCAL void pei_dti_dti_data_test_ind (T_DTI2_DATA_TEST_IND  *dti_data_test_ind);
+LOCAL void pei_dti_dti_data_test_req (T_DTI2_DATA_TEST_REQ  *dti_data_test_req);
+LOCAL void pei_dti_dti_connect_req    (T_DTI2_CONNECT_REQ    *dti_connect_req );
+LOCAL void pei_dti_dti_disconnect_ind (T_DTI2_DISCONNECT_IND *dti_disconnect_ind);   
+LOCAL void pei_dti_dti_connect_cnf    (T_DTI2_CONNECT_CNF    *dti_connect_cnf);
+LOCAL void pei_dti_dti_connect_ind    (T_DTI2_CONNECT_IND    *dti_connect_ind);
+LOCAL void pei_dti_dti_connect_res    (T_DTI2_CONNECT_RES    *dti_connect_res);
+LOCAL void pei_dti_dti_disconnect_req (T_DTI2_DISCONNECT_REQ *dti_disconnect_req);
+
+
+static const T_FUNC ppp_table[] =
+{
+  MAK_FUNC_0(arb_ppp_establish_req,      PPP_ESTABLISH_REQ),    /* 7500 */
+  MAK_FUNC_0(arb_ppp_terminate_req,      PPP_TERMINATE_REQ),    /* 7501 */
+  MAK_FUNC_S(arb_ppp_pdp_activate_res,  PPP_PDP_ACTIVATE_RES),/* 7502 */
+  MAK_FUNC_0(arb_ppp_pdp_activate_rej,  PPP_PDP_ACTIVATE_REJ),/* 7503 */
+  MAK_FUNC_0(arb_ppp_modification_req,  PPP_MODIFICATION_REQ)  /* 7504 */
+};
+
+LOCAL const T_FUNC dti_dl_table[] = {
+  MAK_FUNC_0( pei_dti_dti_connect_ind    ,   DTI2_CONNECT_IND   ),
+  MAK_FUNC_0( pei_dti_dti_connect_cnf    ,   DTI2_CONNECT_CNF   ),
+  MAK_FUNC_0( pei_dti_dti_disconnect_ind ,   DTI2_DISCONNECT_IND)
+  ,
+  MAK_FUNC_0( pei_dti_dti_ready_ind      ,   DTI2_READY_IND      ),
+  MAK_FUNC_0( pei_dti_dti_data_ind       ,   DTI2_DATA_IND       )
+#if defined (_SIMULATION_)
+  ,
+  MAK_FUNC_S( pei_dti_dti_data_test_ind  ,  DTI2_DATA_TEST_IND   )
+#endif
+};
+
+LOCAL const T_FUNC dti_ul_table[] = {
+  MAK_FUNC_0( pei_dti_dti_connect_req       ,   DTI2_CONNECT_REQ   ),
+  MAK_FUNC_0( pei_dti_dti_connect_res       ,   DTI2_CONNECT_RES   ),
+  MAK_FUNC_0( pei_dti_dti_disconnect_req,       DTI2_DISCONNECT_REQ)
+  ,
+  MAK_FUNC_0( pei_dti_dti_getdata_req       ,   DTI2_GETDATA_REQ    ),
+  MAK_FUNC_0( pei_dti_dti_data_req          ,   DTI2_DATA_REQ       )
+
+#if defined (_SIMULATION_)
+  ,
+  MAK_FUNC_S( pei_dti_dti_data_test_req     ,   DTI2_DATA_TEST_REQ  )
+#endif
+};
+
+/*==== DIAGNOSTICS ==========================================================*/
+#ifdef _DEBUG
+#endif /* _DEBUG */
+
+/*==== END DIAGNOSTICS ======================================================*/
+
+/*==== PRIVATE FUNCTIONS ====================================================*/
+
+/*
++------------------------------------------------------------------------------
+|  Function    : primitive_not_supported
++------------------------------------------------------------------------------
+|  Description  :  This function handles unsupported primitives.
+|
+|  Parameters  :  -
+|
+|  Return      :  -
+|
++------------------------------------------------------------------------------
+*/
+LOCAL void primitive_not_supported (void *data)
+{
+  TRACE_FUNCTION ("primitive_not_supported");
+
+  PFREE (data);
+}
+
+
+/*==== PUBLIC FUNCTIONS =====================================================*/
+
+/* qqq hier malen
++------------------------------------------------------------------------------
+|  Function    : pei_primitive
++------------------------------------------------------------------------------
+|  Description  :  This function is called by the frame when a primitive is
+|                  received and needs to be processed.
+|
+|                            |        |
+|                           MMI      DTI                 UPLINK
+|                            |        |
+|                   +--------v--------v--------+
+|                   |                          |
+|                   |            PPP           |
+|                   |                          |
+|                   +-------------^------------+
+|                                 |
+|                                DTI                     DOWNLINK
+|                                 |
+|
+|
+|  Parameters  :  prim      - Pointer to the received primitive
+|
+|  Return      :  PEI_OK    - function succeeded
+|                 PEI_ERROR - function failed
+|
++------------------------------------------------------------------------------
+*/
+
+/*qqq hier kucken*/
+LOCAL SHORT pei_primitive (void * primptr)
+{
+  TRACE_FUNCTION ("pei_primitive");
+
+  if (primptr NEQ NULL)
+  {
+    T_PRIM *prim  = (T_PRIM *)primptr;
+    USHORT           opc = (USHORT)prim->custom.opc;
+    USHORT           n;
+    const T_FUNC    *table;
+
+    /*
+     * This must be called for Partition Pool supervision. Will be replaced
+     * by another macro some time.
+     */
+    VSI_PPM_REC (&prim->custom, __FILE__, __LINE__);
+    PTRACE_IN (opc);
+
+    switch (opc & OPC_MASK)
+    {
+      case PPP_DL:
+        table = ppp_table;
+        n = TAB_SIZE (ppp_table);
+        break;
+      case DTI_UL:
+
+        table = dti_ul_table;
+        n = TAB_SIZE (dti_ul_table);
+        break;
+      case DTI_DL:
+        table = dti_dl_table;
+        n = TAB_SIZE (dti_dl_table);
+        break;
+      default:
+        table = NULL;
+        n = 0;
+        break;
+    }
+
+    if (table NEQ NULL)
+    {
+#define PRIM_OFFSET_DTI2 0x50
+#define PRM_MASK2 0x000F
+      if (((opc & PRM_MASK) - PRIM_OFFSET_DTI2) < n)
+      {
+        table += opc & PRM_MASK2;
+#ifdef PALLOC_TRANSITION
+        P_SDU(prim) = table->soff ? (T_sdu*) (((char*)&prim->data) + table->soff) : 0; /*lint !e740 !e545 */
+#ifndef NO_COPY_ROUTING
+        P_LEN(prim) = table->size + sizeof (T_PRIM_HEADER);
+#endif /* NO_COPY_ROUTING */
+#endif /* PALLOC_TRANSITION */
+        JUMP (table->func) (P2D(prim));
+      }
+      else
+      {
+        primitive_not_supported (P2D(prim));
+      }
+      return PEI_OK;
+    }
+
+    /*
+     * primitive is not a GSM primitive - forward it to the environment
+     */
+    if (opc & SYS_MASK)
+      vsi_c_primitive (VSI_CALLER prim); /*lint !e534 */
+    else
+    {
+      PFREE (P2D(prim));
+      return PEI_ERROR;
+    }
+  }
+  return PEI_OK;
+}
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_init
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame. It is used to initialise
+|                 the entitiy.
+|
+|  Parameters  :  handle            - task handle
+|
+|  Return      :  PEI_OK            - entity initialised
+|                 PEI_ERROR         - entity not (yet) initialised
+|
++------------------------------------------------------------------------------
+*/
+
+/*qqq hier Kommunikationskanaele eintragen*/
+LOCAL SHORT pei_init (T_HANDLE handle)
+{
+
+  TRACE_FUNCTION ("pei_init");
+
+  /*
+   * Initialize task handle
+   */
+  PPP_handle = handle;
+  /*
+   * Open communication channel
+   */
+  if (hCommMMI < VSI_OK)
+  {
+    if ((hCommMMI = vsi_c_open (VSI_CALLER ACI_NAME)) < VSI_OK) /*lint !e605 */
+      return PEI_ERROR;
+  }
+
+  if (hCommPPP < VSI_OK)
+  {
+    if ((hCommPPP = vsi_c_open (VSI_CALLER PPP_NAME)) < VSI_OK) /*lint !e605 */
+      return PEI_ERROR;
+  }
+
+  /*
+   * Initialize global pointer ppp_data. This is required to access all
+   * entity data.
+   */
+  ppp_data = &ppp_data_base;
+  ppp_data->fcstab      = fcstab_base;
+  ppp_data->ftx.accmtab = accmtab_base;
+
+
+  /*
+   * Initialize entity data (call init function of every service)
+   */
+  rt_init();
+  prx_init();
+  ptx_init();
+  frx_init();
+  ftx_init();
+  arb_init();
+  lcp_init();
+  ona_init();
+  ncp_init();
+  pap_init();
+  chap_init();
+
+  /*
+   * initialize global entity variables
+   */
+  ppp_data->mc = PPP_MC_DEFAULT;
+  ppp_data->mt = PPP_MT_DEFAULT;
+  ppp_data->mf = PPP_MF_DEFAULT;
+
+    /*
+     * a value different from 0 indicates an error or 
+     * administrative termination
+     */
+  ppp_data->ppp_cause = 0;
+
+  ppp_data->mru  = PPP_MRU_DEFAULT;
+  ppp_data->n_hc = PPP_HC_OFF;
+
+  ppp_data->pco_mask = PPP_PCO_MASK_DEFAULT;
+
+ /*
+  * Init DTILIB channels and allocate the DTI Database
+  */     
+  if ( (
+    ppp_data->ppphDTI = dti_init (
+      MAX_PPP_LINKS,
+      PPP_handle,
+      DTI_DEFAULT_OPTIONS,
+      sig_callback
+      )
+    ) EQ D_NO_DATA_BASE)
+  {
+    TRACE_ERROR("Open the DTILIB Databank not correct");
+    return PEI_ERROR;
+  }
+  return PEI_OK;
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_timeout
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame when a timer has expired.
+|
+|  Parameters  :  index             - timer index
+|
+|  Return      :  PEI_OK            - timeout processed
+|                 PEI_ERROR         - timeout not processed
+|
++------------------------------------------------------------------------------
+*/
+/*qqq hier noch ppp timer eintragen!!!*/
+LOCAL SHORT pei_timeout (USHORT index)
+{
+  TRACE_FUNCTION ("pei_timeout");
+
+  /*
+   * Process timeout
+   */
+  switch (index)
+  {
+    case RT_INDEX:
+      /*
+       * RT expired.
+       */
+      rt_rt_expired();
+      break;
+    default:
+      TRACE_ERROR("Unknown Timeout");
+      break;
+  }
+
+  return PEI_OK;
+}
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_signal
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame when a signal has been 
+|                 received.
+|
+|  Parameters  :  opc               - signal operation code
+|                 *data             - pointer to primitive
+|
+|  Return      :  PEI_OK            - signal processed
+|                 PEI_ERROR         - signal not processed
+|
++------------------------------------------------------------------------------
+*/
+LOCAL SHORT pei_signal (ULONG opc, void *data)
+{
+  TRACE_FUNCTION ("pei_signal");
+
+  /*
+   * Process signal
+   */
+  switch (opc)
+  {
+#ifdef FF_STATUS_TE
+    /*
+     * Call-back from TE status driver - power status has changed
+     */
+    case NEW_POWER_STATUS:      
+      new_power_status_TE ( );
+      break;
+#endif /* FF_STATUS_TE */
+
+    default:
+      TRACE_ERROR("Unknown Signal OPC");
+      break;
+  } /*lint !e764 switch statement does not have a case */
+
+  return PEI_OK;
+} /*lint !e715 data not referenced */
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_exit
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame when the entity is
+|                 terminated. All open resources are freed.
+|
+|  Parameters  :  -
+|
+|  Return      :  PEI_OK            - exit sucessful
+|                 PEI_ERROR         - exit not sueccessful
+|
++------------------------------------------------------------------------------
+*/
+LOCAL SHORT pei_exit (void)
+{
+  TRACE_FUNCTION ("pei_exit");
+
+  /*
+   * Stop timer
+   */
+  sig_any_rt_srt_req ();
+
+  /*
+   * Close communication channel
+   */
+  vsi_c_close (VSI_CALLER hCommMMI); /*lint !e534 Ignoring return value */
+  hCommMMI = VSI_ERROR;
+
+  /*
+   *  Deinit the DTI Database
+   */
+  dti_deinit(ppp_data->ppphDTI);
+
+  return PEI_OK;
+}
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_run
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame when entering the main
+|                 loop. This fucntion is only required in the active variant.
+|
+|                 This function is not used.
+|
+|  Parameters  :  handle            - Communication handle
+|
+|  Return      :  PEI_OK            - sucessful
+|                 PEI_ERROR         - not successful
+|
++------------------------------------------------------------------------------
+*/
+LOCAL SHORT pei_run (T_HANDLE TaskHandle, T_HANDLE ComHandle )
+{
+  return PEI_OK;
+} /*lint !e715 TaskHandle and ComHandle not referenced */
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_config
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame when a primitive is
+|                 received indicating dynamic configuration.
+|
+|                 This function is not used in this entity.
+|
+|  Parameters  :  handle            - Communication handle
+|
+|  Return      :  PEI_OK            - sucessful
+|                 PEI_ERROR         - not successful
+|
++------------------------------------------------------------------------------
+*/
+LOCAL SHORT pei_config (char *inString)
+{
+#ifndef NCONFIG
+  ULONG new_mask;
+#endif /* !NCONFIG */
+
+  TRACE_FUNCTION ("pei_config");
+  TRACE_FUNCTION (inString);
+
+#ifndef NCONFIG
+  /*
+   * Parse next keyword and number of variables
+   */
+
+  /*if(!strcmp(inString,"PCO="))*/
+  if (inString[0] EQ 'P' &&
+      inString[1] EQ 'C' &&
+      inString[2] EQ 'O' &&
+      inString[3] EQ '=')
+  {
+    TRACE_EVENT ("New PCO content:");
+    new_mask = 0;
+    /*
+     * LCP MRU
+     */
+    if((inString[4] EQ 0x31) ||
+       ((inString[4] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_LCP_MRU)))
+    {
+      TRACE_EVENT(" - LCP MRU");
+      new_mask|= PPP_PCO_MASK_LCP_MRU;
+    }
+    /*
+     * LCP AP
+     */
+    if((inString[5] EQ 0x31) ||
+       ((inString[5] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_LCP_AP)))
+    {
+      TRACE_EVENT(" - LCP Authentication protocol");
+      new_mask|= PPP_PCO_MASK_LCP_AP;
+    }
+    /*
+     * LCP TWO
+     */
+    if((inString[6] EQ 0x31) ||
+       ((inString[6] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_LCP_TWO)))
+    {
+      TRACE_EVENT(" - two LCP packets");
+      new_mask|= PPP_PCO_MASK_LCP_TWO;
+    }
+    /*
+     * Authentication Protocol
+     */
+    if((inString[7] EQ 0x31) ||
+       ((inString[7] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_AUTH_PROT)))
+    {
+      TRACE_EVENT(" - PAP/CHAP Authentication packet(s)");
+      new_mask|= PPP_PCO_MASK_AUTH_PROT;
+    }
+    /*
+     * IPCP HC
+     */
+    if((inString[8] EQ 0x31) ||
+       ((inString[8] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_IPCP_HC)))
+    {
+      TRACE_EVENT(" - VJ Header Compression");
+      new_mask|= PPP_PCO_MASK_IPCP_HC;
+    }
+    /*
+     * IPCP IP
+     */
+    if((inString[9] EQ 0x31) ||
+       ((inString[9] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_IPCP_IP)))
+    {
+      TRACE_EVENT(" - IP address");
+      new_mask|= PPP_PCO_MASK_IPCP_IP;
+    }
+    /*
+     * IPCP PDNS
+     */
+    if((inString[10] EQ 0x31) ||
+       ((inString[10] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_IPCP_PDNS)))
+    {
+      TRACE_EVENT(" - primary DNS address");
+      new_mask|= PPP_PCO_MASK_IPCP_PDNS;
+    }
+    /*
+     * IPCP SDNS
+     */
+    if((inString[11] EQ 0x31) ||
+       ((inString[11] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_IPCP_SDNS)))
+    {
+      TRACE_EVENT(" - secondary DNS address");
+      new_mask|= PPP_PCO_MASK_IPCP_SDNS;
+    }
+    /*
+     * IPCP GATEWAY
+     */
+    if((inString[12] EQ 0x31) ||
+       ((inString[12] NEQ 0x30) && 
+        (ppp_data->pco_mask & PPP_PCO_MASK_IPCP_GATEWAY)))
+    {
+      TRACE_EVENT(" - Gateway address");
+      new_mask|= PPP_PCO_MASK_IPCP_GATEWAY;
+    }
+
+    if(new_mask EQ 0)
+    {
+      TRACE_EVENT(" - no content");
+    }
+    /*
+     * set new PCO mask
+     */
+    ppp_data->pco_mask = new_mask;
+  }
+  else
+  {
+    TRACE_ERROR("config command does not exist");
+  }
+#endif /* !NCONFIG */
+
+  return PEI_OK;
+}
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_config
++------------------------------------------------------------------------------
+|  Description  : This function is called by the frame in case sudden entity
+|                 specific data is requested (e.g. entity Version).
+|
+|  Parameters  :  out_monitor       - return the address of the data to be
+|                                     monitoredCommunication handle
+|
+|  Return      :  PEI_OK            - sucessful (address in out_monitor is valid)
+|                 PEI_ERROR         - not successful
+|
++------------------------------------------------------------------------------
+*/
+LOCAL SHORT pei_monitor (void ** out_monitor)
+{
+  TRACE_FUNCTION ("pei_monitor");
+
+  /*
+   * Version = "0.S" (S = Step).
+   */
+  ppp_mon.version = VERSION_PPP; /*lint !e605 Increase in pointer capability */
+  *out_monitor = &ppp_mon;
+
+  return PEI_OK;
+}
+
+
+
+/*
++------------------------------------------------------------------------------
+|  Function    : pei_create
++------------------------------------------------------------------------------
+|  Description  :  This function is called by the frame when the process is 
+|                  created.
+|
+|  Parameters  :  out_name          - Pointer to the buffer in which to locate
+|                                     the name of this entity
+|
+|  Return      :  PEI_OK            - entity created successfuly
+|                 PEI_ERROR         - entity could not be created
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL SHORT pei_create (T_PEI_INFO **info)
+{
+  static T_PEI_INFO pei_info =
+              {
+               "PPP",         /*lint !e605 Increase in pointer capability */
+               {              /* pei-table */
+                 pei_init,
+                 pei_exit,
+                 pei_primitive,
+                 pei_timeout,
+                 pei_signal,
+                 pei_run,
+                 pei_config,
+                 pei_monitor
+               },
+               2048,          /* stack size */
+               10,            /* queue entries */
+               185,           /* priority (1->low, 255->high) */
+               TIMER_MAX,     /* number of timers */
+               0x03|PRIM_NO_SUSPEND /* flags: bit 0   active(0) body/passive(1) */
+              };              /*        bit 1   com by copy(0)/reference(1) */
+
+
+  TRACE_FUNCTION ("pei_create");
+
+  /*
+   * Close Resources if open
+   */
+  if (first_access)
+    first_access = FALSE;
+  else
+    pei_exit(); /*lint !e534 Ignoring return value */
+
+  /*
+   * Export startup configuration data
+   */
+  *info = &pei_info;
+
+  return PEI_OK;
+}
+
+/*
++------------------------------------------------------------------------------
+|  Function    : sig_callback
++------------------------------------------------------------------------------
+|  Description  :  This is the DTI Callback Function which handles the DTI signals.
+|          
+|
+|  Parameters  :  instance        -   DTI instance  
+|                 inter_face      -   DTI interface
+|                 channel         -   DTI channel
+|                 reason          -   DTI reason
+|                 *dti_data_ind   -   Ptr. to the data primitive
+|
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void sig_callback(U8 instance, U8 inter_face, U8 channel,
+                         U8 reason, T_DTI2_DATA_IND *dti_data_ind)
+{
+  DTI_HANDLE hDTI;
+
+  TRACE_FUNCTION("sig_callback");
+  
+  hDTI = ppp_data->ppphDTI;
+  
+  if (hDTI NEQ D_NO_DATA_BASE)
+  {
+    switch (reason)
+    {
+      case DTI_REASON_CONNECTION_OPENED:
+        /*
+         *  DTI connect
+         */
+        sig_dti_arb_connection_opened_ind (hDTI, instance, inter_face, channel);
+        break;
+
+      case DTI_REASON_CONNECTION_CLOSED:
+        /*
+         *  DTI disconnect
+         */
+        sig_dti_arb_connection_closed_ind (hDTI, instance, inter_face, channel);
+        break;
+
+      case DTI_REASON_DATA_RECEIVED:
+        if(inter_face EQ PROT_LAYER)          
+          /*
+           *  Data packet recived from Protocol Layer. Process it and send.
+           */
+          sig_dti_prx_data_received_ind(dti_data_ind);
+        else
+          /*
+           *  Data packet recived from Peer Layer. Process it and send.
+           */            
+          sig_dti_frx_data_received_ind (dti_data_ind);
+        break;
+
+      case DTI_REASON_TX_BUFFER_FULL:
+        if(inter_face EQ PROT_LAYER)
+            /*
+             *  Buffer full for sending data to Protocol Layer.
+             */
+            sig_dti_ptx_tx_buffer_full_ind();
+         else
+            /*
+             *  Buffer full for sending data to Peer Layer.
+             */
+            sig_dti_ftx_tx_buffer_full_ind ();
+        break;
+
+      case DTI_REASON_TX_BUFFER_READY:
+        if(inter_face EQ PROT_LAYER)
+            /*
+             *  Buffer ready Protocol Layer.
+             */
+            sig_dti_ptx_tx_buffer_ready_ind();
+          else
+            /*
+             *  Buffer ready Peer Layer.
+             */
+            sig_dti_ftx_tx_buffer_ready_ind();
+        break;
+
+      default:
+        TRACE_ERROR("Pointer to no DTI database");
+        break;
+    } /* end switch */
+  } /* end if */
+  else 
+  {
+    TRACE_ERROR("Pointer to DTILIB database non existing");
+  }
+} /* sig_callback() */
+
+/*
++------------------------------------------------------------------------------
+| Function    : sig_any_dti_data_ind
++------------------------------------------------------------------------------
+| Description : This function sends a Data Primitive
+|
+| Parameters  : *hDTI           -   Ptr. to DTI Databank
+|               *dti_data_ind   -   Ptr. to Primitive which shall be sended
+|               instance        -   DTI instance
+|               interface       -   DTI interface
+|               channel         -   DTI channel
+|
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void sig_any_dti_data_ind (
+  DTI_HANDLE hDTI,
+  T_DTI2_DATA_IND *dti_data_ind,
+  UBYTE instance,
+  UBYTE inter_face,
+  UBYTE channel,
+  UBYTE p_id
+  )
+{
+  T_desc2*  temp_desc;
+
+  TRACE_FUNCTION ("sig_any_dti_data_ind()");
+                                            
+  dti_data_ind->parameters.p_id                   = p_id;
+  dti_data_ind->parameters.st_lines.st_flow       = DTI_FLOW_ON;
+  dti_data_ind->parameters.st_lines.st_line_sa    = DTI_SA_ON;
+  dti_data_ind->parameters.st_lines.st_line_sb    = DTI_SB_ON;
+  dti_data_ind->parameters.st_lines.st_break_len  = DTI_BREAK_OFF;
+
+  /*
+   *  This PPP does not support handle of offset in the descriptor. 
+   *  Offset is set to 0 and size to len.
+   */
+  temp_desc = (T_desc2*)dti_data_ind->desc_list2.first;
+  while(temp_desc)
+  {
+    temp_desc->offset = 0;
+    temp_desc->size   = temp_desc->len;
+    temp_desc         = (T_desc2*)temp_desc->next;
+  }
+  
+  dti_send_data(hDTI, instance, inter_face, channel, dti_data_ind);
+} /* sig_any_dti_data_ind () */
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_connect_req
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_connect_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void pei_dti_dti_connect_req (
+                    T_DTI2_CONNECT_REQ   *dti_connect_req
+                  )
+{
+    dti_dti_connect_req (ppp_data->ppphDTI, dti_connect_req);
+}
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_disconnect_ind
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_disconnect_ind
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void pei_dti_dti_disconnect_ind (
+                    T_DTI2_DISCONNECT_IND   *dti_disconnect_ind
+                  )
+{
+    dti_dti_disconnect_ind (ppp_data->ppphDTI, dti_disconnect_ind);
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_connect_cnf
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_connect_cnf
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_connect_cnf (
+                    T_DTI2_CONNECT_CNF   *dti_connect_cnf
+                  )
+{
+    dti_dti_connect_cnf(ppp_data->ppphDTI, dti_connect_cnf);
+}
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_connect_ind
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_connect_ind
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_connect_ind (
+                    T_DTI2_CONNECT_IND   *dti_connect_ind
+                  )
+{    
+    dti_dti_connect_ind(ppp_data->ppphDTI, dti_connect_ind);
+}
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_connect_res
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_connect_res
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_connect_res (
+                    T_DTI2_CONNECT_RES   *dti_connect_res
+                  )
+{
+    dti_dti_connect_res(ppp_data->ppphDTI, dti_connect_res);  
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_disconnect_req
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_disconnect_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_disconnect_req (
+                    T_DTI2_DISCONNECT_REQ   *dti_disconnect_req
+                  )
+{
+    dti_dti_disconnect_req (ppp_data->ppphDTI, dti_disconnect_req);
+}
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_ready_ind
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_ready_ind
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_ready_ind (
+                    T_DTI2_READY_IND   *dti_ready_ind
+                  )
+{
+    dti_dti_ready_ind (ppp_data->ppphDTI, dti_ready_ind);
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_data_req
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_data_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+
+GLOBAL void pei_dti_dti_data_req (
+                    T_DTI2_DATA_REQ   *dti_data_req
+                  )
+{
+    dti_dti_data_req (ppp_data->ppphDTI, dti_data_req);
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_data_ind
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_data_ind
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_data_ind (
+                    T_DTI2_DATA_IND   *dti_data_ind
+                  )
+{
+    dti_dti_data_ind (ppp_data->ppphDTI, dti_data_ind);
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_getdata_req
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_getdata_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_getdata_req (
+                    T_DTI2_GETDATA_REQ   *dti_getdata_req
+                  )
+{
+  dti_dti_getdata_req (ppp_data->ppphDTI, dti_getdata_req);
+}
+ 
+/*==== Start functions only use with Windows ===============================*/
+
+#if defined (_SIMULATION_)
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_data_test_req
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_data_test_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_data_test_req (
+                    T_DTI2_DATA_TEST_REQ   *dti_data_test_req
+                  )
+{
+    dti_dti_data_test_req (ppp_data->ppphDTI, dti_data_test_req);
+}
+
+/*
++------------------------------------------------------------------------------
+| Function    : pei_dti_dti_data_test_ind
++------------------------------------------------------------------------------
+| Description : Helpfunction to activate dti_dti_data_test_req
+|
+| Parameters  : Ptr. to primitive
+|
++------------------------------------------------------------------------------
+*/
+    
+GLOBAL void pei_dti_dti_data_test_ind (
+                    T_DTI2_DATA_TEST_IND   *dti_data_test_ind
+                  )
+{
+  dti_dti_data_test_ind (ppp_data->ppphDTI, dti_data_test_ind);   
+}
+
+#endif /* _SIMULATION_) */
+
+/*==== END OF FILE =========================================================*/