diff src/condat2/frame/config/gprscomp.c @ 3:93999a60b835

src/aci2, src/condat2: import of g23m/condat source pieces from TCS211
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 26 Sep 2016 00:29:36 +0000
parents
children 1b9df37ab303
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/condat2/frame/config/gprscomp.c	Mon Sep 26 00:29:36 2016 +0000
@@ -0,0 +1,734 @@
+/*
++-----------------------------------------------------------------------------
+|  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 :  Component Table for GPRS
++-----------------------------------------------------------------------------
+*/
+
+#ifndef _TARGET_
+#define NEW_ENTITY
+#endif
+
+/*==== INCLUDES ===================================================*/
+
+#include "nucleus.h"
+#include "typedefs.h"
+#include "os.h"
+#include "vsi.h"
+#include "pei.h"
+#include "gprsconst.h"
+#include "frm_defs.h"
+#include "frm_types.h"
+#include "frm_glob.h"
+#include "os_types.h"
+#include "os_glob.h"
+#include "gprsconst.h"
+
+/*==== CONSTANTS ==================================================*/
+
+
+/*==== EXTERNALS ==================================================*/
+
+extern SHORT tstrcv_pei_create(T_PEI_INFO const **Info);
+extern SHORT tstsnd_pei_create(T_PEI_INFO const **Info);
+extern SHORT aci_pei_create   (T_PEI_INFO const **Info);
+extern SHORT cst_pei_create   (T_PEI_INFO const **Info);
+#ifdef FF_ESIM
+extern SHORT esim_pei_create  (T_PEI_INFO const **Info); /* esim module */
+#endif
+extern SHORT sim_pei_create   (T_PEI_INFO const **Info);
+extern SHORT sms_pei_create   (T_PEI_INFO const **Info);
+extern SHORT cc_pei_create    (T_PEI_INFO const **Info);
+extern SHORT sm_pei_create    (T_PEI_INFO const **Info);
+extern SHORT ss_pei_create    (T_PEI_INFO const **Info);
+extern SHORT mm_pei_create    (T_PEI_INFO const **Info);
+extern SHORT gmm_pei_create   (T_PEI_INFO const **Info);
+extern SHORT rr_pei_create    (T_PEI_INFO const **Info);
+extern SHORT grr_pei_create   (T_PEI_INFO const **Info);
+extern SHORT grlc_pei_create  (T_PEI_INFO const **Info);
+extern SHORT dl_pei_create    (T_PEI_INFO const **Info);
+extern SHORT pl_pei_create    (T_PEI_INFO const **Info);
+#ifdef FAX_AND_DATA
+extern SHORT l2r_pei_create   (T_PEI_INFO const **Info);
+extern SHORT rlp_pei_create   (T_PEI_INFO const **Info);
+#ifdef FF_FAX
+extern SHORT fad_pei_create   (T_PEI_INFO const **Info);
+extern SHORT t30_pei_create   (T_PEI_INFO const **Info);
+#endif
+#endif /* FAX_AND_DATA */
+extern SHORT llc_pei_create   (T_PEI_INFO const **Info);
+extern SHORT sndcp_pei_create (T_PEI_INFO const **Info);
+extern SHORT ppp_pei_create   (T_PEI_INFO const **Info);
+extern SHORT uart_pei_create  (T_PEI_INFO const **Info);
+
+#ifdef FF_MUX
+extern SHORT mux_pei_create (T_PEI_INFO const **Info);
+#endif /* MUX */
+
+#ifdef FF_PKTIO
+extern SHORT pktio_pei_create (T_PEI_INFO const **Info);
+#endif /* #ifdef FF_PKTIO */
+
+#ifdef FF_PSI
+extern SHORT psi_pei_create (T_PEI_INFO const **Info);
+#endif
+
+#ifdef FF_EOTD
+extern SHORT lc_pei_create    (T_PEI_INFO const **Info);
+extern SHORT rrlp_pei_create  (T_PEI_INFO const **Info);
+#endif /* FF_EOTD */
+
+#ifdef CO_UDP_IP
+extern SHORT udp_pei_create   (T_PEI_INFO const **Info);
+extern SHORT ip_pei_create    (T_PEI_INFO const **Info);
+#endif /* CO_UDP_IP */
+
+#ifdef FF_WAP
+extern SHORT wap_pei_create   (T_PEI_INFO const **Info);
+#endif /* FF_WAP */
+
+#ifdef _TARGET_
+extern SHORT l1_pei_create    (T_PEI_INFO const **Info);
+#ifdef FF_TCP_IP
+extern SHORT aaa_pei_create   (T_PEI_INFO const **Info);
+#endif /* FF_TCP_IP */
+#endif /* _TARGET_ */
+
+
+#ifdef FF_GPF_TCPIP
+extern SHORT tcpip_pei_create (T_PEI_INFO const **Info);
+#endif /* FF_TCP_IP */
+
+#if defined (CO_TCPIP_TESTAPP) || defined (CO_BAT_TESTAPP)
+extern SHORT app_pei_create   (T_PEI_INFO const **Info);
+#endif /* CO_TCPIP_TESTAPP */
+#ifndef _TARGET_
+extern SHORT ra_pei_create    (T_PEI_INFO const **Info);
+#endif
+
+#ifndef FF_ATI_BAT
+  #ifdef  FF_BAT 
+extern SHORT gdd_dio_pei_create(T_PEI_INFO const **Info);
+  #endif
+#endif
+
+/*==== VARIABLES ==================================================*/
+
+//EF For normal Test Definition Language (TDL) TAP usage set newTstHeader = FALSE
+//EF For multiple entity (TCSL) Test Case Script Lang.   set newTstHeader = TRUE
+#ifndef _TARGET_
+
+#ifdef TDL_TAP
+BOOL newTstHeader = FALSE;
+#else
+BOOL newTstHeader = TRUE;
+#endif
+
+#endif
+
+#ifndef DATA_EXT_RAM
+
+const T_COMPONENT_ADDRESS tstrcv_list[] =
+{
+  { tstrcv_pei_create,   NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS tstsnd_list[] =
+{
+  { tstsnd_pei_create,   NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS mmi_list[] =
+{
+  { aci_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+#ifdef FF_ESIM
+const T_COMPONENT_ADDRESS esim_list[] =
+{
+  { esim_pei_create,     NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif
+
+const T_COMPONENT_ADDRESS cst_list[] =
+{
+  { cst_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS sim_list[] =
+{
+  { sim_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS cm_list[] =
+{
+  { sms_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { cc_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { sm_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { ss_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   (int)"CM" }
+};
+
+const T_COMPONENT_ADDRESS mmgmm_list[] =
+{
+  { mm_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { gmm_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   (int)"MMGMM" }
+};
+
+const T_COMPONENT_ADDRESS rr_list[] =
+{
+  { rr_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS grr_list[] =
+{
+  { grr_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS grlc_list[] =
+{
+  { grlc_pei_create,     NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS dl_list[] =
+{
+  { dl_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS pl_list[] =
+{
+  { pl_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+#ifdef FAX_AND_DATA
+const T_COMPONENT_ADDRESS l2rt30_list[] =
+{
+  { l2r_pei_create,      NULL,   ASSIGNED_BY_TI },
+#ifdef FF_FAX
+  { t30_pei_create,      NULL,   ASSIGNED_BY_TI },
+#endif
+  { NULL,                NULL,   (int)"L2RT30" }
+};
+
+const T_COMPONENT_ADDRESS rlpfad_list[] =
+{
+  { rlp_pei_create,      NULL,   ASSIGNED_BY_TI },
+#ifdef FF_FAX
+  { fad_pei_create,      NULL,   ASSIGNED_BY_TI },
+#endif
+  { NULL,                NULL,   (int)"RLPFAD" }
+};
+#endif /* FAX_AND_DATA */
+
+
+const T_COMPONENT_ADDRESS llc_list[] =
+{
+  { llc_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS sndcp_list[] =
+{
+  { sndcp_pei_create,    NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS ppp_list[] =
+{
+  { ppp_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS uart_list[] =
+{
+  { uart_pei_create,     NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+#ifdef FF_MUX
+const T_COMPONENT_ADDRESS mux_list[] =
+{
+  { mux_pei_create,    NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* MUX */
+
+#ifdef FF_PKTIO
+const T_COMPONENT_ADDRESS pktio_list[] =
+{
+  { pktio_pei_create,    NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* #ifdef FF_PKTIO */
+
+#ifdef FF_PSI
+const T_COMPONENT_ADDRESS psi_list[] =
+{
+  { psi_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* #ifdef FF_PSI */
+
+#ifdef FF_EOTD
+const T_COMPONENT_ADDRESS eotd_list[] =
+{
+  { lc_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { rrlp_pei_create,     NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   (int)"EOTD" }
+};
+#endif /* FF_EOTD */
+
+#ifdef FF_WAP
+const T_COMPONENT_ADDRESS wap_list[] =
+{
+  { wap_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* FF_WAP */
+
+#ifdef CO_UDP_IP
+const T_COMPONENT_ADDRESS udp_list[] =
+{
+  { udp_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+
+const T_COMPONENT_ADDRESS ip_list[] =
+{
+  { ip_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* CO_UDP_IP */
+
+#ifndef _TARGET_
+const T_COMPONENT_ADDRESS ra_list[] =
+{
+  { ra_pei_create,       NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* !_TARGET_ */
+
+#ifdef FF_TCP_IP
+const T_COMPONENT_ADDRESS aaa_list[] =
+{
+#ifdef _TARGET_
+  { aaa_pei_create,      NULL,   ASSIGNED_BY_TI },
+#else /* _TARGET_ */
+  { NULL,               "AAA",   ASSIGNED_BY_TI },
+#endif /* else _TARGET_ */
+  { NULL,                NULL,   0 }
+};
+#endif /* FF_TCP_IP */
+
+#ifdef FF_GPF_TCPIP
+const T_COMPONENT_ADDRESS tcpip_list[] =
+{
+  { tcpip_pei_create,    NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif
+
+#if defined (CO_TCPIP_TESTAPP) || defined (CO_BAT_TESTAPP)
+const T_COMPONENT_ADDRESS app_list[] =
+{
+  { app_pei_create,      NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+#endif /* CO_TCPIP_TESTAPP */
+
+const T_COMPONENT_ADDRESS l1_list[] =
+{
+#ifdef _TARGET_
+  { l1_pei_create,       NULL,   ASSIGNED_BY_TI },
+#else
+  { NULL,                "L1",   ASSIGNED_BY_TI },
+#endif
+  { NULL,                NULL,   0 }
+};
+
+#ifndef FF_ATI_BAT
+  #ifdef  FF_BAT
+const T_COMPONENT_ADDRESS gdd_dio_list[] =
+{
+  { gdd_dio_pei_create,    NULL,   ASSIGNED_BY_TI },
+  { NULL,                NULL,   0 }
+};
+  #endif
+#endif
+
+const T_COMPONENT_ADDRESS *ComponentTables[]=
+{
+  tstrcv_list,
+  tstsnd_list,
+  mmi_list,
+  cst_list,
+  sim_list,
+  cm_list,
+  mmgmm_list,
+  rr_list,
+  grr_list,
+  grlc_list,
+  dl_list,
+  pl_list,
+#ifdef FAX_AND_DATA
+  l2rt30_list,
+  rlpfad_list,
+#endif /* FAX_AND_DATA */
+  llc_list,
+  sndcp_list,
+  ppp_list,
+  uart_list,
+#ifdef FF_MUX
+  mux_list,
+#endif
+#ifdef FF_PKTIO
+  pktio_list,
+#endif
+#ifdef FF_PSI
+  psi_list,
+#endif
+#ifndef FF_ATI_BAT
+  #ifdef  FF_BAT
+  gdd_dio_list,
+  #endif /* FF_BAT */
+#endif
+#ifdef FF_EOTD
+  eotd_list,
+#endif
+#ifdef FF_WAP
+  wap_list,
+#endif
+
+#ifdef CO_UDP_IP
+  udp_list,
+  ip_list,
+#endif
+#if defined _SIMULATION_ && defined FF_FAX
+  ra_list,
+#endif
+#ifdef FF_TCP_IP
+  aaa_list,
+#endif /* FF_TCP_IP */
+
+#ifdef FF_GPF_TCPIP
+  tcpip_list,
+#endif
+
+#if defined (CO_TCPIP_TESTAPP) || defined (CO_BAT_TESTAPP)
+  app_list,
+#endif /* CO_TCPIP_TESTAPP */
+
+#ifdef FF_ESIM
+  esim_list, /* needed for esim module */
+#endif
+  l1_list,
+  NULL
+};
+
+/*==== VERSIONS ===================================================*/
+#ifndef CTRACE
+  char * str2ind_version = "&0";
+#endif
+
+#endif /* DATA_EXT_RAM */
+
+/*==== MEMORY CONFIGURATION =======================================*/
+
+/*
+ * Partitions pool configuration for primitive communication
+ */
+
+/*
+ * Memory extensions for multiplexer
+ */
+#ifdef FF_MUX
+#define PRIMPOOL_0_MUX_ADDITION 30
+#define PRIMPOOL_2_MUX_ADDITION 10
+#else /* FF_MUX */
+#define PRIMPOOL_0_MUX_ADDITION  0
+#define PRIMPOOL_2_MUX_ADDITION  0
+#endif /* else FF_MUX */
+
+/*
+ * Memory extensions for multiple PDP contexts
+ */
+#ifdef FF_PKTIO
+#define PRIMPOOL_2_MPDP_ADDITION 30
+#else /* FF_PKTIO */
+#define PRIMPOOL_2_MPDP_ADDITION  0
+#endif /* else FF_PKTIO */
+#ifdef WIN32
+/*
+ * Required for testing LLC acknowledged mode.
+ */
+#define PRIMPOOL_0_PARTITIONS		200
+#define PRIMPOOL_1_PARTITIONS		100
+#define PRIMPOOL_2_PARTITIONS		 20
+#define PRIMPOOL_3_PARTITIONS		 20
+
+#else /*WIN32*/
+
+#define PRIMPOOL_0_PARTITIONS   (190 + PRIMPOOL_0_MUX_ADDITION)
+#define PRIMPOOL_1_PARTITIONS		 110
+#define PRIMPOOL_2_PARTITIONS   ( 50 + PRIMPOOL_2_MPDP_ADDITION + PRIMPOOL_2_MUX_ADDITION)
+#define PRIMPOOL_3_PARTITIONS		   7
+
+#endif /*WIN32*/
+
+#define PRIM_PARTITION_0_SIZE	    60
+#define PRIM_PARTITION_1_SIZE	   128
+#define PRIM_PARTITION_2_SIZE	   632
+#define PRIM_PARTITION_3_SIZE	  1600
+
+#ifndef DATA_INT_RAM
+unsigned int MaxPrimPartSize = PRIM_PARTITION_3_SIZE;
+#endif /* !DATA_INT_RAM */
+
+#if (!defined DATA_EXT_RAM && defined PRIM_0_INT_RAM) || (!defined DATA_INT_RAM && !defined PRIM_0_INT_RAM)
+char pool10 [ POOL_SIZE(PRIMPOOL_0_PARTITIONS,ALIGN_SIZE(PRIM_PARTITION_0_SIZE)) ];
+#else
+extern char pool10 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined PRIM_1_INT_RAM) || (!defined DATA_INT_RAM && !defined PRIM_1_INT_RAM)
+char pool11 [ POOL_SIZE(PRIMPOOL_1_PARTITIONS,ALIGN_SIZE(PRIM_PARTITION_1_SIZE)) ];
+#else
+extern char pool11 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined PRIM_2_INT_RAM) || (!defined DATA_INT_RAM && !defined PRIM_2_INT_RAM)
+char pool12 [ POOL_SIZE(PRIMPOOL_2_PARTITIONS,ALIGN_SIZE(PRIM_PARTITION_2_SIZE)) ];
+#else
+extern char pool12 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined PRIM_3_INT_RAM) || (!defined DATA_INT_RAM && !defined PRIM_3_INT_RAM)
+char pool13 [ POOL_SIZE(PRIMPOOL_3_PARTITIONS,ALIGN_SIZE(PRIM_PARTITION_3_SIZE)) ];
+#else
+extern char pool13 [];
+#endif
+
+#ifndef DATA_INT_RAM
+const T_FRM_PARTITION_POOL_CONFIG prim_grp_config[] =
+{
+  { PRIMPOOL_0_PARTITIONS, ALIGN_SIZE(PRIM_PARTITION_0_SIZE), &pool10 },
+  { PRIMPOOL_1_PARTITIONS, ALIGN_SIZE(PRIM_PARTITION_1_SIZE), &pool11 },
+  { PRIMPOOL_2_PARTITIONS, ALIGN_SIZE(PRIM_PARTITION_2_SIZE), &pool12 },
+  { PRIMPOOL_3_PARTITIONS, ALIGN_SIZE(PRIM_PARTITION_3_SIZE), &pool13 },
+  { 0                    , 0                    , NULL	  }
+};
+#endif /* !DATA_INT_RAM */
+
+/*
+ * Partitions pool configuration for test interface communication
+ */
+#define TESTPOOL_0_PARTITIONS		 10
+#define TESTPOOL_1_PARTITIONS		200
+#define TESTPOOL_2_PARTITIONS		  2
+
+#define TSTSND_QUEUE_ENTRIES         (TESTPOOL_0_PARTITIONS+TESTPOOL_1_PARTITIONS+TESTPOOL_2_PARTITIONS)
+#define TSTRCV_QUEUE_ENTRIES         50
+
+#define TEST_PARTITION_0_SIZE	    80
+#ifdef _TARGET_
+ #define TEST_PARTITION_1_SIZE   160
+#else
+ #define TEST_PARTITION_1_SIZE   260
+#endif
+#define TEST_PARTITION_2_SIZE	  1600
+
+#ifndef DATA_INT_RAM
+const USHORT TST_SndQueueEntries    = TSTSND_QUEUE_ENTRIES;
+const USHORT TST_RcvQueueEntries    = TSTRCV_QUEUE_ENTRIES;
+const USHORT TextTracePartitionSize = TEST_PARTITION_1_SIZE;
+#endif /* !DATA_INT_RAM */
+
+#if (!defined DATA_EXT_RAM && defined TEST_0_INT_RAM) || (!defined DATA_INT_RAM && !defined TEST_0_INT_RAM)
+char pool20 [ POOL_SIZE(TESTPOOL_0_PARTITIONS,ALIGN_SIZE(TEST_PARTITION_0_SIZE)) ];
+#else
+extern char pool20 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined TEST_1_INT_RAM) || (!defined DATA_INT_RAM && !defined TEST_1_INT_RAM)
+char pool21 [ POOL_SIZE(TESTPOOL_1_PARTITIONS,ALIGN_SIZE(TEST_PARTITION_1_SIZE)) ];
+#else
+extern char pool21 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined TEST_2_INT_RAM) || (!defined DATA_INT_RAM && !defined TEST_2_INT_RAM)
+char pool22 [ POOL_SIZE(TESTPOOL_2_PARTITIONS,ALIGN_SIZE(TEST_PARTITION_2_SIZE)) ];
+#else
+extern char pool22 [];
+#endif
+
+#ifndef DATA_INT_RAM
+const T_FRM_PARTITION_POOL_CONFIG test_grp_config[] =
+{
+  { TESTPOOL_0_PARTITIONS, ALIGN_SIZE(TEST_PARTITION_0_SIZE), &pool20 },
+  { TESTPOOL_1_PARTITIONS, ALIGN_SIZE(TEST_PARTITION_1_SIZE), &pool21 },
+  { TESTPOOL_2_PARTITIONS, ALIGN_SIZE(TEST_PARTITION_2_SIZE), &pool22 },
+  { 0                    , 0                    , NULL	  }
+};
+#endif /* !DATA_INT_RAM */
+
+/*
+ * Partitions pool configuration for general purpose allocation
+ */
+
+#define DMEMPOOL_0_PARTITIONS		70
+#define DMEMPOOL_1_PARTITIONS		 2
+
+#define DMEM_PARTITION_0_SIZE		16
+#ifdef _TARGET_
+#define DMEM_PARTITION_1_SIZE		1600 /* for non tracing ccd arm7 */
+#else
+#define DMEM_PARTITION_1_SIZE		2800 /* for non tracing ccd pc */
+#endif
+
+#if (!defined DATA_EXT_RAM && defined DMEM_0_INT_RAM) || (!defined DATA_INT_RAM && !defined DMEM_0_INT_RAM)
+char pool30 [ POOL_SIZE(DMEMPOOL_0_PARTITIONS,ALIGN_SIZE(DMEM_PARTITION_0_SIZE)) ];
+#else
+extern char pool30 [];
+#endif
+
+#if (!defined DATA_EXT_RAM && defined DMEM_1_INT_RAM) || (!defined DATA_INT_RAM && !defined DMEM_1_INT_RAM)
+char pool31 [ POOL_SIZE(DMEMPOOL_1_PARTITIONS,ALIGN_SIZE(DMEM_PARTITION_1_SIZE)) ];
+#else
+extern char pool31 [];
+#endif
+
+#ifndef DATA_INT_RAM
+const T_FRM_PARTITION_POOL_CONFIG dmem_grp_config[] =
+{
+  { DMEMPOOL_0_PARTITIONS, ALIGN_SIZE(DMEM_PARTITION_0_SIZE), &pool30 },
+  { DMEMPOOL_1_PARTITIONS, ALIGN_SIZE(DMEM_PARTITION_1_SIZE), &pool31 },
+  { 0                    , 0                    , NULL	  }
+};
+#endif /* !DATA_INT_RAM */
+
+/*
+ * Partitions group list
+ */
+
+#ifndef DATA_INT_RAM
+const T_FRM_PARTITION_GROUP_CONFIG partition_grp_config[MAX_POOL_GROUPS+1] =
+{
+  { "PRIM", &prim_grp_config[0] },
+  { "TEST", &test_grp_config[0] },
+  { "DMEM", &dmem_grp_config[0] },
+  { NULL,   NULL                }
+};
+
+extern T_HANDLE PrimGroupHandle;
+extern T_HANDLE DmemGroupHandle;
+extern T_HANDLE TestGroupHandle;
+
+T_HANDLE *PoolGroupHandle[MAX_POOL_GROUPS+1] =
+{
+  &PrimGroupHandle,
+  &TestGroupHandle,
+  &DmemGroupHandle,
+  NULL
+};
+#endif /* !DATA_INT_RAM */
+
+/*
+ * Dynamic Memory Pool Configuration
+ */
+
+#ifdef _TARGET_
+#ifdef FF_ESIM
+ #define EXT_DATA_POOL_PS_BASE_SIZE 45000
+#else
+ #define EXT_DATA_POOL_PS_BASE_SIZE 35000
+#endif
+#define INT_DATA_POOL_PS_BASE_SIZE 25000
+#else /* _TARGET_ */
+#define EXT_DATA_POOL_TCPIP_ADDTIION 120000
+#define EXT_DATA_POOL_PS_BASE_SIZE  80000 + EXT_DATA_POOL_TCPIP_ADDTIION
+#define INT_DATA_POOL_PS_BASE_SIZE  1000
+#endif /* _TARGET_ */
+
+#ifdef MEMORY_SUPERVISION
+ #define EXT_DATA_POOL_PPS_ADDITION ((EXT_DATA_POOL_PS_BASE_SIZE>>3)+25000)
+ #define INT_DATA_POOL_PPS_ADDITION ((INT_DATA_POOL_PS_BASE_SIZE>>3))
+#else  /* MEMORY_SUPERVISION */
+ #define EXT_DATA_POOL_PPS_ADDITION 0
+ #define INT_DATA_POOL_PPS_ADDITION 0
+#endif /* MEMORY_SUPERVISION */
+
+#if defined (FF_WAP) || defined (FF_SAT_E)
+ #define EXT_DATA_POOL_WAP_ADDITION 15000
+#else
+ #define EXT_DATA_POOL_WAP_ADDITION 0
+#endif /* FF_WAP OR SAT E */
+
+#ifdef GRR_PPC_IF_PRIM
+ #define INT_DATA_POOL_GRR_PPC_IF_PRIM_ADDITION  3000
+#else  /* #ifdef GRR_PPC_IF_PRIM */
+ #define INT_DATA_POOL_GRR_PPC_IF_PRIM_ADDITION  0
+#endif /* #ifdef GRR_PPC_IF_PRIM */
+
+#define EXT_DATA_POOL_PS_SIZE   (EXT_DATA_POOL_PS_BASE_SIZE + EXT_DATA_POOL_WAP_ADDITION             + EXT_DATA_POOL_PPS_ADDITION)
+#define INT_DATA_POOL_PS_SIZE   (INT_DATA_POOL_PS_BASE_SIZE + INT_DATA_POOL_GRR_PPC_IF_PRIM_ADDITION + INT_DATA_POOL_PPS_ADDITION)
+
+#define EXT_DATA_POOL_GPF_SIZE  (2048 + OS_QUEUE_ENTRY_SIZE(TSTSND_QUEUE_ENTRIES) + OS_QUEUE_ENTRY_SIZE(TSTRCV_QUEUE_ENTRIES))
+
+#define EXT_DATA_POOL_SIZE      (EXT_DATA_POOL_PS_SIZE + EXT_DATA_POOL_GPF_SIZE)
+#define INT_DATA_POOL_SIZE      (INT_DATA_POOL_PS_SIZE)
+
+#ifndef DATA_INT_RAM
+char ext_data_pool              [ EXT_DATA_POOL_SIZE ];
+#endif
+
+#ifndef DATA_EXT_RAM
+char int_data_pool              [ INT_DATA_POOL_SIZE ];
+#else
+extern char int_data_pool       [ ];
+#endif
+
+#ifndef DATA_INT_RAM
+
+const T_MEMORY_POOL_CONFIG memory_pool_config[MAX_MEMORY_POOLS+1] =
+{
+  { "INTPOOL", INT_DATA_POOL_SIZE, &int_data_pool[0] },
+  { "EXTPOOL", EXT_DATA_POOL_SIZE, &ext_data_pool[0] },
+  {  NULL }
+};
+
+extern T_HANDLE ext_data_pool_handle;
+extern T_HANDLE int_data_pool_handle;
+
+T_HANDLE *MemoryPoolHandle[MAX_MEMORY_POOLS+1] =
+{
+  &int_data_pool_handle,
+  &ext_data_pool_handle,
+  NULL
+};
+
+#endif /* !DATA_INT_RAM */