diff gpf/frame/frame.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/gpf/frame/frame.c	Thu Jun 09 00:02:41 2016 +0000
@@ -0,0 +1,1472 @@
+/* 
++------------------------------------------------------------------------------
+|  File:       frame.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 general frame functionality.
++----------------------------------------------------------------------------- 
+*/ 
+
+
+#ifndef __FRAME_C__
+#define __FRAME_C__
+#endif
+
+/*==== INCLUDES ===================================================*/
+
+#include <stdarg.h>
+#include <string.h>
+#include <stdio.h>
+
+#include "gpfconf.h"
+#include "typedefs.h"
+
+#include "glob_defs.h"
+#include "os.h"
+#include "vsi.h"
+#include "pei.h"
+#include "frame.h"
+#include "tools.h"
+#include "gdi.h"
+#include "frm_defs.h"
+#include "frm_types.h"
+#include "frm_glob.h"
+#include "route.h"
+#include "p_frame.h"
+#include "prf_func.h"
+#ifdef _ESF_SUPPORT_
+#include "esf_func.h"
+#endif
+#include "frm_ext.h"
+
+/*==== TYPES ======================================================*/
+
+typedef struct
+{
+  char const *Name;
+  USHORT Id;
+} T_NAME_ID;
+
+/*==== CONSTANTS ==================================================*/
+
+#define RUNNING   0x01
+#undef VSI_CALLER
+#define VSI_CALLER   TaskHandle,
+
+/*==== EXTERNALS ==================================================*/
+/* -------------- S H A R E D - BEGIN ---------------- */
+#ifdef _TOOLS_
+#pragma data_seg("FRAME_SHARED") 
+#endif
+
+#if defined _NUCLEUS_ && !defined _TARGET_
+extern char TraceBuffer[];
+#endif
+
+#ifndef _TOOLS_
+extern const T_MEMORY_POOL_CONFIG memory_pool_config[];
+extern const T_FRM_PARTITION_GROUP_CONFIG partition_grp_config[];
+extern T_HANDLE MemoryPoolHandle[];
+extern OS_HANDLE PoolGroupHandle[];
+extern const T_DRV_LIST DrvList[]; 
+#ifdef MEMORY_SUPERVISION      
+extern USHORT NumberOfPPMPartitions;
+extern USHORT NumOfPPMPools;
+extern USHORT NumOfPPMGroups;
+extern USHORT NumOfPrimPools;
+extern USHORT NumOfDmemPools;
+#endif
+#endif
+
+extern T_DRV_LIST const *DriverConfigList;
+
+#ifndef _TOOLS_
+extern const T_COMPONENT_ADDRESS *ComponentTables[];
+extern const char * const frame_version_date;
+extern const char * const frame_version_time;
+extern const char * const misc_version_date;
+extern const char * const misc_version_time;
+extern const char * const tif_version_date;
+extern const char * const tif_version_time;
+#endif
+
+#ifdef _TOOLS_
+  __declspec (dllimport) T_HANDLE TST_Handle;
+#else
+  extern T_HANDLE TST_Handle;
+#endif
+
+#ifdef MEMORY_SUPERVISION
+extern int ppm_check_partition_owner;
+#endif
+
+/*==== VARIABLES ==================================================*/
+    
+#ifndef RUN_INT_RAM
+UBYTE SuppressOK=1;
+GLOBAL T_HANDLE MemPoolHandle;                                                 
+GLOBAL T_HANDLE PrimGroupHandle;
+GLOBAL T_HANDLE DmemGroupHandle;
+GLOBAL T_HANDLE TestGroupHandle;
+GLOBAL T_HANDLE LemuGroupHandle;
+GLOBAL T_HANDLE int_data_pool_handle;
+GLOBAL T_HANDLE ext_data_pool_handle;
+GLOBAL UBYTE FrameEnv=0;
+GLOBAL USHORT TestInterface = 0;
+GLOBAL USHORT NextTimerEntry = 0;
+int time_is_tdma_frame;
+char error_ind_dst[RESOURCE_NAMELEN] = {0};
+T_FRM_ERROR_IND *frm_error_ind = NULL;
+char check_desclist = FALSE;
+GLOBAL USHORT NumberOfStartedTasks = 0;
+GLOBAL USHORT NumberOfRunningTasks = 0;
+GLOBAL USHORT TooManyTasks = 0;
+
+const T_PEI_INFO DummyInfo = 
+  { 
+    "",          /* Name */
+    { 
+      NULL,
+      NULL,
+      NULL,
+      NULL,
+      NULL,
+      NULL,
+      NULL,
+      NULL
+    },
+    768,        /* stack size */
+    10,         /* queue entries */
+    1,          /* priority */
+    0,          /* number of timers */
+    COPY_BY_REF /* Flags */
+ };
+
+const T_NAME_ID Resource[] =
+{
+  { "TASK",       OS_OBJTASK},
+  { "QUEUE",      OS_OBJQUEUE},
+  { "TIMER",      OS_OBJTIMER },
+  { "SEMAPHORE",  OS_OBJSEMAPHORE},
+  { "PARTITION",  OS_OBJPARTITIONGROUP},
+  { "MEMORY",     OS_OBJMEMORYPOOL},
+  { NULL,         0 }
+};
+
+#ifdef _TOOLS_
+LOCAL T_COMPONENT_ADDRESS *ComponentTables [NUM_OF_COMPONENT_TABLES+1]={0};
+typedef void T_INIT_FUNC ( void );
+T_INIT_FUNC *InitFunc;
+ULONG init_stack_time = 0;
+ULONG init_local_time = 0;
+ULONG  MaxPrimPartSize = 65536;
+USHORT TextTracePartitionSize = 260;
+#endif
+
+char TaskName [ RESOURCE_NAMELEN ];
+
+#else /* RUN_INT_RAM */
+extern USHORT TestInterface;
+extern USHORT NextTimerEntry;
+extern USHORT NumberOfStartedTasks;
+extern USHORT NumberOfRunningTasks;
+extern USHORT TooManyTasks;
+extern char TaskName[];
+extern T_HANDLE int_data_pool_handle;
+extern T_HANDLE ext_data_pool_handle;
+#endif /* RUN_INT_RAM */
+
+#ifdef _TOOLS_
+#pragma data_seg()
+#endif
+
+#ifdef _ESF_SUPPORT_
+int esf_init_func2_ready = FALSE;
+int firstTime = TRUE;
+#endif
+
+/* -------------- S H A R E D - END ---------------- */
+
+
+/*==== PROTOTYPES =================================================*/
+
+GLOBAL void pf_TaskEntry (T_HANDLE TaskHandle, ULONG Value );
+LOCAL SHORT pf_HandleMessage (T_HANDLE TaskHandle, OS_QDATA *pMsg );
+LOCAL LONG pf_CreateTask ( const T_COMPONENT_ADDRESS *Comp );
+LOCAL void pf_ProcessProtocolPrim ( T_HANDLE TaskHandle, T_VOID_STRUCT *pPrim);
+LOCAL void pf_Reset (T_HANDLE TaskHandle);
+int is_entity_in_task (T_HANDLE t_handle, char *name );
+int int_vsi_o_ttrace ( T_HANDLE Caller, ULONG TraceClass, const char * const format, va_list varpars );
+
+#ifndef _TOOLS_
+GLOBAL void InitializeApplication ( void );
+#endif
+
+/*==== LINT =======================================================*/
+
+/*lint -e522 suppress Warning -- Expected void type, assignment, increment or decrement */
+
+/*==== FUNCTIONS ==================================================*/
+
+#ifdef _TOOLS_
+/*
++------------------------------------------------------------------------------
+|  Function     :  pf_get_frameenv
++------------------------------------------------------------------------------
+|  Description  :  This function returns the current value of FrameEnv
+|
+|  Parameters   :  void
+|
+|  Return       :  FrameEnv
++------------------------------------------------------------------------------
+*/
+USHORT pf_get_frameenv (void)
+{
+  return (USHORT) FrameEnv;
+}
+
+#endif /* _TOOLS_ */
+
+#ifndef _TOOLS_
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : StartFrame          |
++--------------------------------------------------------------------+
+
+  PURPOSE : Start the frame 
+
+*/
+SHORT StartFrame ( void )
+{
+  prf_init();
+  pf_Init(NULL);
+  pf_CreateAllEntities();
+#ifdef _ESF_SUPPORT_
+  esf_init();
+  esf_init_func1(); 
+#endif
+  pf_StartAllTasks ();
+  return ( PF_OK );
+}
+#endif
+#endif /* ndef _TOOLS_ */
+
+#if defined (_LINUX_) || (defined _SOLARIS_)
+int main ()
+{
+  (void) StartFrame ();
+  for (;;)
+  {
+    os_SuspendTask (0, 1500);
+  }
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : is_entity_in_task   |
++--------------------------------------------------------------------+
+
+  PURPOSE : Initialize the frame 
+
+*/
+int is_entity_in_task ( T_HANDLE t_handle, char *name )
+{
+int i;
+
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == t_handle )
+    {
+      if ( !strncmp (pf_TaskTable[i].Name, name, RESOURCE_NAMELEN-1) )
+        return TRUE;
+    }
+  }
+  return FALSE;
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_Init             |
++--------------------------------------------------------------------+
+
+  PURPOSE : Initialize the frame 
+
+*/
+
+/*lint -esym(715,ConfigAddress) only needed for _TOOLS_*/
+GLOBAL void pf_Init ( T_CONFIGURATION_ADDRESS *ConfigAddress)
+{
+#ifndef _TOOLS_
+const T_FRM_PARTITION_POOL_CONFIG * pool_config;
+USHORT i = 1,j = 0;
+#endif
+
+#if defined _NUCLEUS_ && !defined _TARGET_ || defined (_LINUX_)
+  printf ("FRAME VERSION: %s, %s\n",frame_version_date, frame_version_time);
+  printf ("MISC VERSION:  %s, %s\n",misc_version_date,  misc_version_time);
+  printf ("TIF VERSION:   %s, %s\n\n",tif_version_date, tif_version_time);
+#endif
+  if ( os_Initialize() == OS_ERROR )
+  {
+    vsi_o_assert ( 0, OS_SYST_ERR, __FILE__, __LINE__, "OS initialization error" );
+  }
+  
+  time_is_tdma_frame = 0;
+  TestInterface = 0;
+  NextTimerEntry = 0;
+#ifdef _TOOLS_
+  ComponentTables[RCV_ADR] = ConfigAddress->RcvAdr; 
+  ComponentTables[TST_ADR] = ConfigAddress->TstAdr; 
+  ComponentTables[END_OF_COMP_TABLE] = NULL; 
+  DriverConfigList = ConfigAddress->DrvListAdr;
+  InitFunc = ConfigAddress->InitFuncAdr;
+  FrameEnv = *ConfigAddress->FrameEnvAdr;
+#else
+  DriverConfigList = &DrvList[0];
+#endif
+
+#ifndef _TOOLS_
+
+  
+  j = 0;
+  /*
+   * create memory pools
+   */
+  while ( memory_pool_config[j].Name != NULL )
+  {
+    if ( memory_pool_config[j].Size > 1 )
+      os_CreateMemoryPool ( NO_TASK, 
+                          memory_pool_config[j].Name, 
+                          memory_pool_config[j].PoolAddress, 
+                          memory_pool_config[j].Size, 
+                          (OS_HANDLE*)MemoryPoolHandle[j] );                    
+    j++;
+  }
+
+#ifdef _NUCLEUS_
+  os_SetPoolHandles (ext_data_pool_handle, int_data_pool_handle);
+#endif
+
+  /*
+   * create partition pools
+   */
+
+  for ( i = 0; partition_grp_config[i].name != NULL; i++ )
+  {
+#ifdef MEMORY_SUPERVISION      
+//    if ( strcmp ("TEST", partition_grp_config[i].name ) )
+//    {
+      /* currently all created groups are counted to ease offset calculation for
+         partition supervision */
+      NumOfPPMGroups++;
+//    }
+#endif
+    pool_config = partition_grp_config[i].grp_config;
+    while ( pool_config->part_size && pool_config->part_num )
+    {
+      os_CreatePartitionPool ( NO_TASK, 
+                               partition_grp_config[i].name, 
+                               pool_config->mem, 
+                               (USHORT)pool_config->part_num,
+                               pool_config->part_size, 
+                               (OS_HANDLE*)PoolGroupHandle[i] );   
+#ifdef MEMORY_SUPERVISION 
+	  /* TEST pool not under partition supervision */
+      if ( strcmp ("TEST", partition_grp_config[i].name ) )
+      {
+        NumOfPPMPools++;
+        NumberOfPPMPartitions += pool_config->part_num;
+      }
+#endif
+      if ( !strcmp ("PRIM", partition_grp_config[i].name ) )
+      {
+        if ( MaxPrimPartSize < pool_config->part_size )
+        {
+          MaxPrimPartSize = pool_config->part_size;
+        }
+#ifdef MEMORY_SUPERVISION
+        NumOfPrimPools++;
+#endif
+      }
+#ifdef MEMORY_SUPERVISION
+      if ( !strcmp ("DMEM", partition_grp_config[i].name ) )
+      {
+        NumOfDmemPools++;
+      }
+#endif
+      pool_config++;
+    }
+  }
+
+#endif
+  /* 
+   * To allow CCD (TaskHandle = 0) the usage of dynamic Memory to create a semaphore
+   * the MemPoolHandle for non-task users is initialized with the handle of the int_data_pool
+   * pool.
+   */
+  pf_TaskTable[0].MemPoolHandle = int_data_pool_handle;
+  strcpy ( pf_TaskTable[0].Name, "IRQ" );
+
+  rt_Init();
+#ifdef _TOOLS_
+  (InitFunc)();
+#else
+  InitializeApplication();
+#endif
+#ifdef MEMORY_SUPERVISION
+  InitializePPM();
+#endif /* MEMORY_SUPERVISION */
+
+  InitializeTimer();
+  InitializeDriverConfig();
+#if !defined _TARGET_ && !defined _TOOLS_
+  vsi_pcheck_init(); 
+#endif
+#ifndef _TOOLS_
+  fei_lemu_SendToQueue_init();
+#endif
+  /* 
+  not needed -> temporarily removed 
+  vsi_c_init_com_matrix (MaxEntities);
+  */
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_CreateAllEntities|
++--------------------------------------------------------------------+
+*/
+GLOBAL SHORT pf_CreateAllEntities (void)
+{
+int i = 0;
+
+  while ( ComponentTables[i] != NULL )
+  {
+    pf_CreateTask ( ComponentTables[i] );
+    i++;
+  }
+  InitializeTrace();
+  return PF_OK;
+}
+#endif
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_CreateEntity     |
++--------------------------------------------------------------------+
+*/
+LOCAL LONG pf_CreateTask ( const T_COMPONENT_ADDRESS *Comp )
+{
+T_PEI_INFO const *Info;
+T_HANDLE TaskHandle;
+T_HANDLE mem_pool_handle = ext_data_pool_handle;
+int Priority = 0;
+ULONG StackSize = 0;
+const T_PEI_FUNC *PeiTable;
+USHORT     QueueEntries = 0;
+USHORT   	 NumOfTimers = 0;
+U32      Flags;
+char *Name = NULL;
+static int e_handle = 1;
+int start_e_handle;
+int i;
+
+  start_e_handle = e_handle;
+  while ( Comp->PeiCreate || Comp->Name )
+  {
+    if ( e_handle > MaxEntities )
+    {
+      vsi_o_assert ( 0, OS_SYST_ERR, __FILE__, __LINE__, "More than MAX_ENTITIES" );
+    }
+    if (  Comp->PeiCreate && Comp->PeiCreate ( &Info ) == PEI_OK )
+    {
+      if ( Comp->Priority != ASSIGNED_BY_TI )
+      {
+        if ( Priority < Comp->Priority )
+          Priority = Comp->Priority;
+      }
+      else
+      {
+        if ( Priority < Info->Priority )
+          Priority = Info->Priority;
+      }
+      Flags = Info->Flags;
+      PeiTable = &Info->PeiTable;
+      Name = (char*)Info->Name;
+      if ( StackSize < Info->StackSize )
+        StackSize = Info->StackSize;
+      pf_TaskTable[e_handle].QueueEntries = Info->QueueEntries;
+      NumOfTimers = Info->NumOfTimers;
+    }
+    else if ( Comp->Name && strlen (Comp->Name) <= RESOURCE_NAMELEN )
+    {
+      Flags = DummyInfo.Flags;
+      PeiTable = &DummyInfo.PeiTable;
+      Name = Comp->Name;
+      if ( StackSize < DummyInfo.StackSize )
+        StackSize = DummyInfo.StackSize;
+      if ( Priority < DummyInfo.Priority )
+        Priority = DummyInfo.Priority;
+      pf_TaskTable[e_handle].QueueEntries = DummyInfo.QueueEntries;
+      NumOfTimers = DummyInfo.NumOfTimers;
+    }
+    else
+      return PF_ERROR;
+
+    if ( QueueEntries < pf_TaskTable[e_handle].QueueEntries )
+      QueueEntries = pf_TaskTable[e_handle].QueueEntries;
+
+    pf_TaskTable[e_handle].Flags = Flags;
+    pf_TaskTable[e_handle].PeiTable = PeiTable;
+    pf_TaskTable[e_handle].NumOfTimers = NumOfTimers;
+    strncpy (pf_TaskTable[e_handle].Name, Name, RESOURCE_NAMELEN);
+    pf_TaskTable[e_handle].Name[RESOURCE_NAMELEN-1] = 0;
+    if ( pf_TaskTable[e_handle].Flags & INT_DATA_TASK )
+    {
+      pf_TaskTable[e_handle].MemPoolHandle = int_data_pool_handle;
+      mem_pool_handle = int_data_pool_handle;
+    }
+    else
+    {
+      pf_TaskTable[e_handle].MemPoolHandle = ext_data_pool_handle;
+      mem_pool_handle = ext_data_pool_handle;
+    }
+    prf_log_entity_create ((void*)e_handle, Name);
+    e_handle++;
+    Comp++;
+  }
+  if ( e_handle > start_e_handle + 1 )
+    Name = (char*)Comp->Priority;
+
+#ifdef MEMORY_SUPERVISION
+  StackSize = StackSize + (StackSize>>3);
+#endif
+  if ( os_CreateTask (NO_TASK, Name, pf_TaskEntry, StackSize, (USHORT)Priority, &TaskHandle, 
+                      mem_pool_handle) == OS_OK )
+  {
+    for ( i = start_e_handle; i < e_handle; i++ )
+    {
+      pf_TaskTable[i].TaskHandle = TaskHandle;
+    }
+    return PF_OK;
+  }
+  else
+    vsi_o_assert ( NO_TASK, OS_SYST_ERR, __FILE__, __LINE__, "Error at creating %s Task", Name );  
+  /*lint +e771 */
+
+  return PF_ERROR;
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_StartAllTasks    |
++--------------------------------------------------------------------+
+*/
+GLOBAL SHORT pf_StartAllTasks ( void )
+{
+int e_handle;
+int t_handle;
+int started_t_handle = 0;
+
+  for ( e_handle = 1; e_handle <= MaxEntities; e_handle++ )
+  {
+    if ( pf_TaskTable[e_handle].Name[0] != 0 )
+    {
+      if ( (t_handle = pf_TaskTable[e_handle].TaskHandle) != started_t_handle )
+      {
+        if ( os_StartTask ( NO_TASK, t_handle, 0 ) == OS_ERROR)
+          return OS_ERROR;
+        NumberOfStartedTasks++;
+        started_t_handle = t_handle;
+      }
+    }
+  }
+  return OS_OK;
+}
+#endif
+
+
+#ifndef RUN_FLASH
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_TaskEntry        |
++--------------------------------------------------------------------+
+*/
+/*lint -esym(715,Value) suppress Info -- Symbol 'Value' not referenced */
+GLOBAL void pf_TaskEntry (T_HANDLE TaskHandle, ULONG Value )
+{
+OS_QDATA Msg;
+OS_HANDLE mem_pool_handle = ext_data_pool_handle;
+LONG sts;
+int i;
+int queue_entries;
+int queue_handle;
+int biggest_queue_size = 0;
+int sum_queue_size = 0;
+U32 entity_flags = 0;
+#ifndef _TOOLS_
+char queue_name [ RESOURCE_NAMELEN ];
+#endif
+static int entity_init_fail_cnt = 0;
+
+#ifdef _ESF_SUPPORT_
+  {
+    /* OS timer should not be started at this point, otherwise risk of
+       race condition.
+       Furthermore, ESF THIF socket interface can't be used by task tst 
+       before esf_init_func2() is completed. 
+     */
+
+    T_HANDLE esf_init_func2_sem;
+    T_HANDLE caller;
+
+    caller = e_running[os_MyHandle()];
+    esf_init_func2_sem = vsi_s_open (caller, "esf_init_func2_sem", 1);
+
+    vsi_s_get (caller, esf_init_func2_sem);      /* start of critical section */
+    if (firstTime)
+    {
+      firstTime = FALSE;
+      esf_init_func2();
+      esf_init_func2_ready = TRUE; 
+    }
+    vsi_s_release(caller, esf_init_func2_sem); /* end of critical section */
+
+    while (!esf_init_func2_ready)
+    {
+      os_SuspendTask(caller, 100);
+    }
+  }
+#endif
+
+  if ( is_entity_in_task ( TaskHandle, FRM_TST_NAME ) == FALSE
+    && is_entity_in_task ( TaskHandle, FRM_RCV_NAME ) == FALSE )
+  {
+    while ( !(TestInterface & RUNNING) )
+    {
+      os_SuspendTask (TaskHandle, 100);
+    }
+  }
+
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == TaskHandle )
+    {
+      if ( pf_TaskTable[i].Flags & ADD_QUEUE_SIZES )
+      {
+        entity_flags |= ADD_QUEUE_SIZES;
+      }
+      sum_queue_size += pf_TaskTable[i].QueueEntries;
+      if ( biggest_queue_size < pf_TaskTable[i].QueueEntries )
+      {
+        biggest_queue_size = pf_TaskTable[i].QueueEntries;
+      }
+      if ( pf_TaskTable[i].Flags & INT_DATA_TASK )
+        mem_pool_handle = int_data_pool_handle;
+    }
+  }
+
+  /* set queue size depending on the flag exported by the entities */
+  if ( entity_flags & ADD_QUEUE_SIZES )
+  {
+    queue_entries = sum_queue_size;
+  }
+  else
+  {
+    queue_entries = biggest_queue_size;
+  }
+
+#ifdef _TOOLS_
+  if ( os_CreateQueue ( TaskHandle, 0, pf_TaskTable[TaskHandle].Name, (USHORT)queue_entries, &queue_handle,
+                        pf_TaskTable[TaskHandle].MemPoolHandle) == OS_ERROR )
+  {
+    vsi_o_assert ( NO_TASK, OS_SYST_ERR_QUEUE_CREATE, __FILE__, __LINE__, 
+                   "Error at creating %s Queue", pf_TaskTable[TaskHandle].Name ); 
+  }
+#else
+  os_GetTaskName ( TaskHandle, TaskHandle, queue_name );
+  if ( os_CreateQueue ( TaskHandle, 0, queue_name, (USHORT)queue_entries, &queue_handle, mem_pool_handle) == OS_ERROR )
+  {
+    vsi_o_assert ( NO_TASK, OS_SYST_ERR_QUEUE_CREATE, __FILE__, __LINE__, "Error at creating %s Queue", queue_name ); 
+  }
+#endif
+
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == TaskHandle )
+    {
+      pf_TaskTable[i].QueueHandle = queue_handle;
+      pf_TaskTable[i].FirstTimerEntry = &TimerHandleField [ NextTimerEntry ];
+      if ( (NextTimerEntry += pf_TaskTable[i].NumOfTimers) >= MaxTimer )
+        vsi_o_assert ( NO_TASK, OS_SYST_ERR_MAX_TIMER, __FILE__, __LINE__, 
+                       "Number of Timers > MAX_TIMER" );  
+    }
+  }
+
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == TaskHandle )
+    {
+      if (pf_TaskTable[i].PeiTable->pei_init != NULL)
+      {
+        e_running[TaskHandle] = i;
+        while (pf_TaskTable[i].PeiTable->pei_init (i) == PEI_ERROR)
+        {
+          if ( entity_init_fail_cnt++ > (NumberOfStartedTasks * 5) )
+            vsi_o_ttrace(NO_TASK, TC_SYSTEM, "%s pei_init() failed",pf_TaskTable[i].Name );
+		      os_SuspendTask (TaskHandle, 100);
+        }
+        e_running[TaskHandle] = 0;
+      }
+    }
+  }
+
+  if ( is_entity_in_task ( TaskHandle, FRM_TST_NAME ) == TRUE ) 
+    TestInterface |= RUNNING;
+
+
+  if ( ++NumberOfRunningTasks == NumberOfStartedTasks )
+  {
+    if ( TooManyTasks )
+      vsi_o_assert (NO_TASK, OS_SYST_ERR_MAX_TASK, __FILE__, __LINE__, "Number of entities > MAX_ENTITIES" );  
+    vsi_o_ttrace(NO_TASK, TC_SYSTEM, "All tasks entered main loop" );
+#if defined _NUCLEUS_ && !defined _TARGET_
+    printf ("%s\n","All tasks entered main loop");
+#endif
+#ifdef _TARGET_
+    // TraceMask[0] = 0;	// removed in FreeCalypso - Space Falcon
+    os_dar_set_filter();
+#endif
+  }
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == TaskHandle )
+    {
+      if (pf_TaskTable[i].PeiTable->pei_run != NULL)
+      {
+        if ( !(pf_TaskTable[i].Flags & PASSIVE_BODY) )
+        {
+            /*
+             * in the active body variant call pei_run
+             */
+            e_running[TaskHandle] = i;
+            pf_TaskTable[i].PeiTable->pei_run (TaskHandle, pf_TaskTable[i].QueueHandle );
+#ifdef _TOOLS_
+            pf_TaskTable[i].PeiTable->pei_exit();
+            NextTimerEntry -= pf_TaskTable[i].NumOfTimers;
+            rt_RoutingModify ( TaskHandle, (char*)SYSPRIM_REDIRECT_TOKEN, (char*)SYSPRIM_CLEAR_TOKEN );
+            os_DestroyQueue ( TaskHandle, pf_TaskTable[i].QueueHandle );
+            e_running[TaskHandle] = 0;
+            os_DestroyTask ( TaskHandle, TaskHandle );
+#endif
+            e_running[TaskHandle] = 0;
+            for (;;)
+              os_SuspendTask(TaskHandle,10000);
+        }
+      }
+    }
+  }
+
+  /*
+   * in the passive body variant wait for a message and
+   * handle it
+   */
+  for ( i = MaxEntities; i > 0; i-- )
+  {
+    if ( pf_TaskTable[i].TaskHandle == TaskHandle )
+    {
+      break;
+    }
+  }
+  for (;;)
+  {
+    sts = os_ReceiveFromQueue ( TaskHandle, pf_TaskTable[i].QueueHandle,
+                                &Msg, OS_SUSPEND );
+    switch ( sts )
+    {
+      case OS_OK:
+#if defined (_TOOLS_) || defined (_LINUX_)
+           e_running[TaskHandle] = TaskHandle;
+           pf_HandleMessage (TaskHandle, &Msg);
+#else
+           e_running[TaskHandle] = Msg.e_id;
+           prf_log_entity_activate ((void*)Msg.e_id);
+           pf_HandleMessage (Msg.e_id, &Msg);
+#endif
+           e_running[TaskHandle] = 0;
+#ifdef _NUCLEUS_ 
+           if ( os_CheckTaskStack ( TaskHandle ) == OS_ERROR )
+           {
+             os_GetTaskName ( TaskHandle, TaskHandle, TaskName );
+             vsi_o_assert ( TaskHandle, OS_SYST_ERR_STACK_OVERFLOW, __FILE__, __LINE__, 
+                            "%s Stack overflow", TaskName );
+           }
+#endif
+      break;
+      case OS_TIMEOUT:
+      break;
+      case OS_ERROR:
+           for(;;)
+             os_SuspendTask(TaskHandle,10000);
+      /*lint -e527, suppress Warning -- Unreachable */
+      break;
+      default:
+           for(;;)
+             os_SuspendTask(TaskHandle,10000);
+      break;
+      /*lint +e527 */
+
+    }
+  }
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_Timeout          |
++--------------------------------------------------------------------+
+*/
+GLOBAL void pf_Timeout (T_HANDLE TaskHandle, T_HANDLE EntityHandle, USHORT TimerIndex )
+{
+OS_QDATA TimeoutMsg;
+
+  TimeoutMsg.data16 = MSG_TIMEOUT;
+  TimeoutMsg.data32 = (ULONG)TimerIndex;
+#ifdef _TOOLS_
+  TimeoutMsg.len = 0;
+#endif
+  TimeoutMsg.e_id = EntityHandle;
+  os_GetTime ( 0, &TimeoutMsg.time );
+    
+  *(pf_TaskTable[EntityHandle].FirstTimerEntry + TimerIndex) |= TIMEOUT_OCCURRED;
+
+#ifdef _TOOLS_
+  if ( rt_Route (TaskHandle, pf_TaskTable[EntityHandle].QueueHandle, OS_NORMAL, OS_SUSPEND, 
+    &TimeoutMsg ) == OS_TIMEOUT )
+#else
+  if ( rt_Route (TaskHandle, EntityHandle, OS_NORMAL, OS_SUSPEND, 
+    &TimeoutMsg ) == OS_TIMEOUT )
+#endif
+      vsi_o_assert ( 0, OS_SYST_ERR_QUEUE_FULL, __FILE__, __LINE__, 
+                     "Timeout write attempt to %s queue failed", pf_TaskTable[EntityHandle].Name );
+}
+#endif
+
+#ifndef RUN_FLASH
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_HandleMessage    |
++--------------------------------------------------------------------+
+*/
+LOCAL SHORT pf_HandleMessage (T_HANDLE TaskHandle, OS_QDATA *pMsg )
+{
+ULONG PrimId = 0; 
+
+  switch (pMsg->data16)
+  {
+    case MSG_PRIMITIVE:
+      if ( pMsg->ptr != NULL )
+      {
+        PrimId = ((T_PRIM_HEADER*)(pMsg->ptr))->opc;
+
+        if ( PrimId & SYS_MASK )
+        {
+          pf_ProcessSystemPrim ( TaskHandle, pMsg->ptr );
+        }
+        else
+        {
+          pf_ProcessProtocolPrim ( TaskHandle, pMsg->ptr );
+        }
+      }
+    break;
+    case MSG_SIGNAL:
+      if ( pf_TaskTable[TaskHandle].PeiTable->pei_signal != NULL )
+      {
+        pf_TaskTable[TaskHandle].PeiTable->pei_signal ( pMsg->data32, pMsg->ptr ); 
+      }
+    break;
+    case MSG_TIMEOUT:
+      if ( *(pf_TaskTable[TaskHandle].FirstTimerEntry + pMsg->data32) & TIMEOUT_OCCURRED )
+      {
+        if ( !(*(pf_TaskTable[TaskHandle].FirstTimerEntry + pMsg->data32) & PERIODIC_TIMER) )
+        {
+          os_DestroyTimer ( TaskHandle, (OS_HANDLE)(*(pf_TaskTable[TaskHandle].FirstTimerEntry + pMsg->data32) & TIMER_HANDLE_MASK) );
+          *(pf_TaskTable[TaskHandle].FirstTimerEntry + pMsg->data32) = 0;
+        }
+        else
+        {
+          *(pf_TaskTable[TaskHandle].FirstTimerEntry + pMsg->data32) &= ~TIMEOUT_OCCURRED;
+        }
+        vsi_o_ttrace ( TaskHandle, TC_TIMER, "Timeout   : Index %d",pMsg->data32) ;
+        if ( pf_TaskTable[TaskHandle].PeiTable->pei_timeout != NULL )
+          pf_TaskTable[TaskHandle].PeiTable->pei_timeout ( (USHORT)pMsg->data32 ); 
+      }
+    break;
+    default:
+      VSI_PPM_FREE(pMsg->ptr);
+      os_DeallocatePartition (TaskHandle, pMsg->ptr-PPM_OFFSET );
+      return PF_ERROR;
+    /*lint -e527, suppress Warning -- Unreachable */
+    break;
+    /*lint +e527 */
+  }
+  return PF_OK;
+}
+#endif
+
+#ifndef RUN_FLASH
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)           MODULE  : FRAME                 |
+| STATE   : code                     ROUTINE : pf_ProcessProtocolPrim|
++--------------------------------------------------------------------+
+*/
+LOCAL void pf_ProcessProtocolPrim ( T_HANDLE TaskHandle, T_VOID_STRUCT *pPrim)
+{
+
+  if ( TaskHandle != NO_TASK )
+  {
+    if (pf_TaskTable[TaskHandle].PeiTable->pei_primitive != NULL)
+    {
+#ifdef PRIM_AUTO_FREE
+      if ( pf_TaskTable[TaskHandle].Flags & PARTITION_AUTO_FREE )
+      {
+        /* 
+         * TST uses its own partition pool and is handled differently 
+         */
+        if ( TaskHandle != TST_Handle )
+        {
+          processed_prim[TaskHandle] = pPrim;
+          freed_prim[TaskHandle] = NULL;
+        }
+      }
+#endif /* PRIM_AUTO_FREE */
+#ifdef MEMORY_SUPERVISION
+      if ( TaskHandle != TST_Handle ) /* Trace pools are not monitored by PPM */ 
+        VSI_PPM_RCV(pPrim);
+#endif
+      pf_TaskTable[TaskHandle].PeiTable->pei_primitive (pPrim);
+
+#ifdef PRIM_AUTO_FREE
+      if ( pf_TaskTable[TaskHandle].Flags & PARTITION_AUTO_FREE )
+      {
+        /*
+         * if PSTORE was called during the primitive processing, PFREE was no longer
+         * blocked inside the entity and it could have happened that a primitive  
+         * was freed and then newly allocated either by the same or by a different
+         * entity (IRQ). To avoid auto free it is checked if an effective free was
+         * done with the pointer passed to pei_primitive(). In this case the 
+         * partition is not freed.
+         */
+        if ( freed_prim[TaskHandle] == pPrim )
+        {
+          freed_prim[TaskHandle] = NULL;
+          return;
+        }
+        else
+        {
+          processed_prim[TaskHandle] = NULL;
+
+          if ( pPrim != NULL ) 
+          {
+            FREE ( P2D(pPrim) );
+          }
+          return;
+        }
+      }
+      else
+#endif /* PRIM_AUTO_FREE */
+        return;
+    }
+  }
+  if ( pPrim != NULL)
+  {
+#ifndef _TARGET_
+    vsi_o_ttrace ( NO_TASK, TC_SYSTEM, "Primitive discarded in dummy entity %s, opc 0x%x",
+                   pf_TaskTable[TaskHandle].Name, ((T_PRIM_HEADER*)pPrim)->opc );
+#endif
+    VSI_PPM_RCV(pPrim);
+    FREE ( P2D(pPrim) );
+  }
+}
+#endif
+ 
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)           MODULE  : FRAME                 |
+| STATE   : code                     ROUTINE : pf_ProcessSystemPrim  |
++--------------------------------------------------------------------+
+*/ 
+GLOBAL void pf_ProcessSystemPrim ( T_HANDLE TaskHandle, T_VOID_STRUCT *pPrim)
+{
+char * data;
+/*lint -e813, suppress Info 813: auto variable 'token' has size '132' -> uncritical in this context */
+char token[TRACE_TEXT_SIZE];
+/*lint +e813 */
+BOOL Error = FALSE;
+LONG i;
+unsigned int Length;
+T_HANDLE min, max;
+char TraceMaskBuffer[9];
+ULONG trace_mask;
+LONG state;
+#ifdef _TOOLS_
+T_S_HEADER *s_hdr;
+#endif
+
+  VSI_PPM_RCV(pPrim);
+
+  data = (char *)P2D( pPrim );
+
+  Length = GetNextToken (data, token, " #");
+
+  if (!strcmp (token, SYSPRIM_REDIRECT_TOKEN)
+   OR !strcmp (token, SYSPRIM_DUPLICATE_TOKEN))
+  {
+
+    if (TaskHandle NEQ NO_TASK)
+    {
+      /*
+       * Redirect or Duplicate primitives
+       */
+      if ( (state = rt_RoutingModify (TaskHandle, token, data+strlen(token)+1)) != RT_OK )
+      {
+#ifdef NU_DEBUG
+        switch ( state )
+        {
+          case RT_NO_MEM:
+            vsi_o_ttrace(NO_TASK, TC_SYSTEM, "SYSTEM WARNING: Out of Memory - routing command rejected");
+            VSI_PPM_FREE(pPrim);
+            os_DeallocatePartition (TaskHandle, pPrim-PPM_OFFSET );
+            return;
+            /*lint -e527, suppress Warning -- Unreachable */
+            break;
+            /*lint +e527 */
+		      case RT_ERROR: Error = TRUE;
+            break;
+        }
+#else
+        Error = TRUE;
+#endif
+      }
+    }
+  }
+  else if ( !strcmp ( token, SYSPRIM_TRACECLASS_TOKEN) )
+  {
+    if ( Length < strlen(data)-1 )
+    {
+      GetNextToken (data+Length+1, token, " #");
+      trace_mask = ASCIIToHex(token, CHARS_FOR_32BIT);
+      if ( TaskHandle == TST_Handle )
+      {
+        min = 1;
+        max = MaxEntities;
+      }
+      else
+      {
+        min = TaskHandle;
+        max = TaskHandle;
+      }
+      for ( i = min; i <= max; i++ )
+      {
+        if ( vsi_settracemask ( TaskHandle, i, trace_mask) == VSI_ERROR )
+          break;
+      }
+    }
+    else
+    {
+      vsi_gettracemask ( TaskHandle, TaskHandle, &trace_mask);
+      HexToASCII ( trace_mask, TraceMaskBuffer, CHARS_FOR_32BIT );
+      TraceMaskBuffer[8] = 0;
+      sprintf ( data, "%s %s %s", pf_TaskTable[TaskHandle].Name, SYSPRIM_TRACECLASS_TOKEN, TraceMaskBuffer );
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, data );
+    }
+  }
+  else if (!strcmp (token, SYSPRIM_CONFIG_TOKEN))
+  {
+    /*
+     * Dynamic Configuration
+     */
+    if (TaskHandle != NO_TASK)
+    {
+      /*
+       * call the pei_config function of the entity
+       */
+      if (pf_TaskTable[TaskHandle].PeiTable->pei_config NEQ NULL)
+        if ( pf_TaskTable[TaskHandle].PeiTable->pei_config ( data+strlen (token)+1 ) == PEI_ERROR )
+          Error = TRUE;
+    }
+  }
+#if 0
+  /* not needed -> temporarily removed */
+  else if (!strcmp (token, SYSPRIM_ISOLATE_TOKEN))
+  {
+    if ( rt_isolate_entity (TaskHandle, data+strlen(token)+1) == RT_ERROR )
+      Error = TRUE;
+  }
+#endif
+  else if (!strcmp (token, SYSPRIM_REGISTER_ERR_IND))
+  {
+    strncpy ( error_ind_dst, data+strlen(token)+1, RESOURCE_NAMELEN );
+    error_ind_dst[RESOURCE_NAMELEN-1] = 0;
+    if ( frm_error_ind == NULL )
+    {
+      frm_error_ind = (T_FRM_ERROR_IND*)vsi_c_pnew (sizeof(T_FRM_ERROR_IND), FRM_ERROR_IND FILE_LINE_MACRO );
+    }
+  }
+  else if (!strcmp (token, SYSPRIM_WITHDRAW_ERR_IND))
+  {
+    if ( frm_error_ind != NULL )
+    {
+      error_ind_dst[0] = 0;
+      vsi_c_pfree( (T_VOID_STRUCT**)&frm_error_ind FILE_LINE_MACRO );
+      frm_error_ind = NULL;
+    }
+  }
+  else if (!strcmp (token, SYSPRIM_STATUS_TOKEN))
+  {
+    GetNextToken (data+strlen(token)+1, token, " #");
+    VSI_PPM_FREE(pPrim);
+    os_DeallocatePartition (TaskHandle, pPrim-PPM_OFFSET );
+    i = 0;
+    while ( Resource[i].Name && strcmp ( Resource[i].Name, token ) )
+      i++;
+    if ( vsi_object_info (TaskHandle, Resource[i].Id, FIRST_ENTRY, token, sizeof(token)) == VSI_OK )       
+    {
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      while ( vsi_object_info (TaskHandle, Resource[i].Id, NEXT_ENTRY, token, sizeof(token)) == VSI_OK )
+      {
+        vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      }
+    }
+    return;
+  }
+#if 0
+  else if (!strcmp (token, SYSPRIM_READ_COM_MATRIX))
+  {
+    state = vsi_c_get_com_matrix_entry ( FIRST_ENTRY, token );
+    if ( state == VSI_OK )
+    {
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      do
+      {
+        if ( (state = vsi_c_get_com_matrix_entry ( NEXT_ENTRY, token)) == VSI_OK )
+          vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      } while ( state == VSI_OK );
+    }
+  }
+#endif
+#ifdef _TARGET_
+  else if (!strcmp (token, SYSPRIM_READ_FFS_DAR))
+  {
+    state = os_read_dar_ffs_data ( FIRST_ENTRY, token, TextTracePartitionSize - sizeof(T_S_HEADER) - sizeof(T_PRIM_HEADER) - 1 );
+    if ( state == OS_OK )
+    {
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      do
+      {
+        if ( (state = os_read_dar_ffs_data ( NEXT_ENTRY, token, TextTracePartitionSize - sizeof(T_S_HEADER) - sizeof(T_PRIM_HEADER) - 1)) == OS_OK )
+          vsi_o_ttrace ( NO_TASK, TC_SYSTEM, token ); 
+      } while ( state == OS_OK );
+    }
+    else
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, "No DAR entry stored" ); 
+
+  }
+#endif
+#if !defined _TARGET_ && !defined _TOOLS_
+  else if (!strcmp (token, SYSPRIM_PCHECK))
+  {
+    pcheck_active[TaskHandle] = TRUE;
+  }
+#endif
+  else if (!strcmp (token, SYSPRIM_ROUTE_DESCLIST))
+  {
+    route_desclist[TaskHandle] = TRUE;
+  }
+  else if (!strcmp (token, SYSPRIM_CHECK_DESCLIST))
+  {
+    check_desclist = TRUE;
+  }
+#ifdef _NUCLEUS_
+  else if (!strcmp (token, SYSPRIM_VERSION_TOKEN))
+  {
+    vsi_o_ttrace (NO_TASK, TC_SYSTEM,"FRAME VERSION: %s, %s",frame_version_date, frame_version_time);
+    vsi_o_ttrace (NO_TASK, TC_SYSTEM,"MISC VERSION:  %s, %s",misc_version_date,  misc_version_time);
+    vsi_o_ttrace (NO_TASK, TC_SYSTEM,"TIF VERSION:   %s, %s",tif_version_date,   tif_version_time);
+  }
+#endif
+  else if (!strcmp (token, SYSPRIM_RESET_TOKEN))
+  {
+    /*
+     * Reset
+     */
+    pf_Reset (TaskHandle);
+  }
+#ifdef _TOOLS_
+  else if (!strcmp (token, SYSPRIM_EXIT_TOKEN))
+  {
+    /*
+     * Exit and delete
+     */
+    if (pf_TaskTable[TaskHandle].PeiTable->pei_exit != NULL)
+    {
+      pf_TaskTable[TaskHandle].PeiTable->pei_exit();
+    }
+    VSI_PPM_FREE(pPrim);
+    os_DeallocatePartition (TaskHandle, pPrim-PPM_OFFSET );
+    vsi_p_delete(0,TaskHandle);
+  }
+#endif /* _TOOLS_ */
+#ifdef MEMORY_SUPERVISION
+  else if (!strcmp (token, SYSPRIM_CHECK_OWNER))
+  {
+    ppm_check_partition_owner = 1;
+  }
+  else if (!strcmp (token, SYSPRIM_SHOW_MEMORY))
+  {
+    /*
+     * Show state of the partition pool monitor
+     */
+    VSI_PPM_FREE(pPrim);
+    os_DeallocatePartition (TaskHandle, pPrim-PPM_OFFSET );
+    TracePoolstatus (TaskHandle);
+    return;
+  }
+#endif /* MEMORY_SUPERVISION */    
+#ifndef _TOOLS_  
+  else if (!strcmp (token, SYSPRIM_SELECT_TIME_TDMA))
+  {
+    time_is_tdma_frame = 1;
+  }
+#endif
+#ifdef _TOOLS_
+  else if (!strcmp (token, SYSPRIM_IS_STACK_TIME))
+  {
+    s_hdr = P_SHDR(pPrim);
+    set_stack_time (s_hdr->time);
+  }
+  else if (!strcmp (token, SYSPRIM_REGISTER_TOKEN))
+  {
+    OS_HANDLE comhandle;
+    GetNextToken (data+strlen(token)+1, token, " #");
+    if (os_create_extq (token, &comhandle) == OS_OK)
+    {
+      if (!strcmp (token, FRM_PCO_NAME))
+      {
+        vsi_o_set_htrace (comhandle);
+      }
+    }
+    else
+      Error = TRUE;
+  }
+  else if (!strcmp (token, SYSPRIM_WITHDRAW_TOKEN))
+  {
+    GetNextToken (data+strlen(token)+1, token, " #");
+    if (os_destroy_extq (token) == OS_OK)
+    {
+      if (!strcmp (token, FRM_PCO_NAME))
+      {
+        vsi_o_set_htrace (0);
+      }
+    }
+    else
+      Error = TRUE;
+  }
+#endif /* _TOOLS_ */
+  else
+    Error = TRUE;
+
+  if ( Error )
+  {
+    vsi_o_ttrace ( NO_TASK, TC_SYSTEM, "SYSTEM WARNING:Invalid system primitive '%s'",data );
+  }
+  else
+  {
+    if ( !SuppressOK )
+    {
+      vsi_o_ttrace ( NO_TASK, TC_SYSTEM, "OK (%s %s)", pf_TaskTable[TaskHandle].Name, data );
+    }
+  }
+  VSI_PPM_FREE(pPrim);
+  os_DeallocatePartition (TaskHandle, pPrim-PPM_OFFSET );
+}
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-GPF (8415)             MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_Reset            |
++--------------------------------------------------------------------+
+*/
+LOCAL void pf_Reset (T_HANDLE TaskHandle)
+{
+  if (TaskHandle != NO_TASK)
+  {
+    if (pf_TaskTable[TaskHandle].PeiTable->pei_exit != NULL)
+      pf_TaskTable[TaskHandle].PeiTable->pei_exit();
+    /* 
+     * reset a single entity
+     */
+    if (pf_TaskTable[TaskHandle].PeiTable->pei_init != NULL)
+      while (pf_TaskTable[TaskHandle].PeiTable->pei_init(TaskHandle) == PEI_ERROR)
+        os_SuspendTask ( TaskHandle, 5);
+  }
+  else
+  {
+    USHORT Handle;
+    /*
+     * reset all entities
+     */
+    for (Handle = 1; Handle <= MaxEntities; Handle++)
+    {
+      if (pf_TaskTable[TaskHandle].PeiTable->pei_exit != NULL)
+        pf_TaskTable[TaskHandle].PeiTable->pei_exit();
+
+      if (pf_TaskTable[Handle].PeiTable->pei_init != NULL)
+        while (pf_TaskTable[TaskHandle].PeiTable->pei_init(TaskHandle) == PEI_ERROR)
+          os_SuspendTask ( TaskHandle, 5);
+    }
+  }
+}
+#endif
+
+#ifdef _TOOLS_
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-Frame (8415)           MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : set_stack_time      |
++--------------------------------------------------------------------+
+
+  PURPOSE : stores the local time of stack under test. Used to align 
+            timestamps while tracing.
+
+*/
+void set_stack_time ( ULONG time )
+{
+  init_stack_time = time;
+  os_GetTime ( NO_TASK, &init_local_time );
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-Frame (8415)           MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : get_stack_time      |
++--------------------------------------------------------------------+
+
+  PURPOSE : returns the local time of stack under test. Used to align 
+            timestamps while tracing.
+
+*/
+void get_local_time ( ULONG *time )
+{
+OS_TIME current_local_time;
+
+ os_GetTime ( NO_TASK, &current_local_time );
+ *time = init_stack_time + current_local_time - init_local_time;
+}
+
+#endif
+
+#ifndef RUN_INT_RAM
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-Frame (8415)           MODULE  : FRAME               |
+| STATE   : code                       ROUTINE : pf_handle_error     |
++--------------------------------------------------------------------+
+
+  PURPOSE : frame error and warning handling
+
+*/
+/*lint -e506, suppress Warning 506: Constant value Boolean */
+/*lint -e718, suppress nfo 718: Symbol '_va_argref' undeclared, assumed to return int */
+int pf_handle_warning ( USHORT cause, const char * const format,...)
+{
+T_HANDLE caller;
+va_list varpars;
+static int recursion_count = 0;
+USHORT free;
+USHORT alloc;
+
+  /* recursion counter is needed to avoid endless loop when generating warning during processing of warning */
+  if ( recursion_count == 0 )
+  {
+    recursion_count++;
+    caller = e_running[os_MyHandle()];
+    va_start (varpars, format);              
+    int_vsi_o_ttrace ( NO_TASK, TC_SYSTEM, format, varpars );
+
+    if ( error_ind_dst[0] != 0 )
+    {
+      /* drop the warning, if there are fewer than 3 partitions available to avoid deadlock */
+      vsi_m_status ( caller, sizeof(T_FRM_WARNING_IND)+sizeof(T_PRIM_HEADER), PrimGroupHandle, &free, &alloc );
+      if ( free >= 3 )
+      {
+        PALLOC(frm_warning_ind,FRM_WARNING_IND);
+        frm_warning_ind->warning_code = cause;
+#ifdef _TARGET_
+        /* We will destroy the partition guard pattern if the warning is longer than the warning string in FRM_WARNING_IND */
+        vsprintf ((char*)frm_warning_ind->warning_string, format, varpars);
+#else
+#if defined(_LINUX_) || defined(_SOLARIS_)
+        vsnprintf ((char*)frm_warning_ind->warning_string,
+                     sizeof(frm_warning_ind->warning_string), format, varpars);
+#else
+        _vsnprintf ((char*)frm_warning_ind->warning_string, sizeof(frm_warning_ind->warning_string), format, varpars);
+#endif
+#endif
+        vsi_o_primsend ( caller, TC_SYSTEM, 0, error_ind_dst, (unsigned int)FRM_WARNING_IND, frm_warning_ind, sizeof(T_FRM_WARNING_IND) FILE_LINE_MACRO );
+      }
+      else
+      {
+        vsi_o_ttrace ( NO_TASK, TC_SYSTEM, "FRM_WARNING_IND dropped" );
+      }
+    }
+#if defined _NUCLEUS_ && !defined _TARGET_
+    vsprintf (TraceBuffer, format, varpars);
+    printf ("%s\n",TraceBuffer);
+#endif
+#ifdef _NUCLEUS_
+    os_SystemError ( os_MyHandle(), cause, NULL );
+#endif
+    recursion_count--;
+  }
+  return VSI_OK;
+}
+/*lint +e718 */
+/*lint +e506 */
+
+#endif
+
+