diff src/g23m-gprs/grr/grr_psip.c @ 1:d393cd9bb723

src/g23m-*: initial import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Sun, 15 Jul 2018 04:40:46 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/g23m-gprs/grr/grr_psip.c	Sun Jul 15 04:40:46 2018 +0000
@@ -0,0 +1,327 @@
+/* 
++----------------------------------------------------------------------------- 
+|  Project :  GPRS (8441)
+|  Modul   :  GRR
++----------------------------------------------------------------------------- 
+|  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 primitive handler functions for service
+|             PSI of entity GRR.
++----------------------------------------------------------------------------- 
+*/ 
+
+#ifndef GRR_PSIP_C
+#define GRR_PSIP_C
+#endif
+
+#define ENTITY_GRR
+
+/*==== INCLUDES =============================================================*/
+
+#include "typedefs.h"    /* to get Condat data types */
+#include <string.h>
+
+#include "vsi.h"        /* to get a lot of macros */
+#include "macdef.h"
+#include "gprs.h"
+#include "gsm.h"        /* to get a lot of macros */
+#include "ccdapi.h"     /* to get CCD API */
+#include "cnf_grr.h"    /* to get cnf-definitions */
+#include "mon_grr.h"    /* to get mon-definitions */
+#include "prim.h"       /* to get the definitions of used SAP and directions */
+#include "message.h"
+#include "grr.h"        /* to get the global entity definitions */
+
+#include "grr_f.h"      /* */
+
+#include "grr_psip.h"   /* header file of primitives*/
+
+#include "grr_psif.h"   /* header file of functions*/
+
+#include "grr_meass.h"   /* signals exchanged between PSI and MEAS*/
+#include "grr_ctrls.h"   /* header file of functions*/
+
+/*==== CONST ================================================================*/
+
+/*==== LOCAL VARS ===========================================================*/
+
+/*==== PRIVATE FUNCTIONS ====================================================*/
+
+/*==== PUBLIC FUNCTIONS =====================================================*/
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : psi_t_60_sec
++------------------------------------------------------------------------------
+| Description : Handles the primitive T_60_SEC
+|
+| Parameters  : void
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void psi_t_60_sec ( void )
+{
+  TRACE_FUNCTION( "t_60_sec" );
+
+#ifndef _TARGET_
+
+  /*
+   * No PSI1 or PSI13 or SI13 received within 60 sec
+   * This will result in a cell reselection
+   */
+  TRACE_EVENT( "No PSI1 or PSI13 or SI13 received within 60 sec" );
+  
+  sig_psi_ctrl_psi1or_psi13_receiption_failure();
+
+#else /* #ifndef _TARGET_ */
+  
+  TRACE_EVENT( "Processing timeout of T_60_SEC disabled on target" );
+
+#endif /* #ifndef _TARGET_ */
+
+} /* psi_t_60_sec() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : psi_t_30_sec
++------------------------------------------------------------------------------
+| Description : Handles the primitive T_30_SEC
+|
+| Parameters  : void
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void psi_t_30_sec ( void)
+{
+  TRACE_FUNCTION( "t_30_sec" );
+
+/*#ifndef _TARGET_*/
+  /*
+   * No PSI1 received within 30 sec
+   */
+
+  switch( GET_STATE( PSI ) )
+  {
+    case PSI_TRANSFER:
+      if(grr_data->test_mode NEQ CGRLC_NO_TEST_MODE) 
+      {
+        psi_start_30sec();
+        TRACE_EVENT( "T_30_SEC received during test mode" );
+        break;
+      }
+      /*lint -fallthrough*/
+    case PSI_IDLE:
+      /*
+        If the mobile station has not received the PSI1 message within the last 30 seconds,
+        it shall attempt to receive the PSI1 message each time it is scheduled on PBCCH.
+        Such attempts shall be made during both packet idle and packet transfer modes.
+      */
+      switch(psc_db->acq_type)
+      {
+        case NONE:
+          psc_db->acq_type = PERIODICAL_PSI1_READING;
+          psi_receive_psi(READ_PSI1_IN_PSI1_REPEAT_PERIODS);
+          break;
+        default:
+          /*
+           * Access to the network not allowed or complete PSI
+           * has not been read. Nothing to do. Acquisition is running
+           */
+          TRACE_EVENT("PSI not complete/ access not allowed");
+          break;
+      }
+      break;
+ case PSI_BCCH_TRANSFER:
+      if(grr_data->test_mode NEQ CGRLC_NO_TEST_MODE) 
+      {
+        psi_start_30sec();
+        TRACE_EVENT( "T_30_SEC received during test mode" );
+        break;
+      }
+      /*lint -fallthrough*/
+    case PSI_BCCH_IDLE:
+      /*
+        If the mobile station has received neither the SI13 nor the PSI13 message within
+        the last 30 seconds, it shall attempt to receive the SI13 message each time it is
+        scheduled on BCCH. Such attempts shall be made during both packet idle and packet
+        transfer modes.
+      */
+      switch(psc_db->acq_type)
+      {
+        case NONE:
+          psc_db->acq_type = PERIODICAL_SI13_READING;
+          sig_psi_ctrl_read_si( UPDATE_SI13 );
+          break;
+        default:
+          /*
+           * Access to the network not allowed or complete SI
+           * has not been read. Nothing to do. Acquisition is running
+           */
+          TRACE_EVENT("SI not complete/ access not allowed");
+          break;
+      }
+      break;
+    default:
+      TRACE_ERROR( "T_30_SEC unexpected" );
+      break;
+  }
+/*#endif*/
+} /* psi_t_30_sec() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : psi_t_10_sec
++------------------------------------------------------------------------------
+| Description : Handles the primitive T_10_SEC
+|
+| Parameters  : void
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void psi_t_10_sec ( void )
+{
+  TRACE_FUNCTION( "t_10_sec" );
+  /*
+   * partial or complete acq has not completed within 10 seconds
+   */
+/*#ifndef _TARGET_*/
+
+  if( grr_t_status( T3174 ) > 0 )
+  {
+	  TRACE_EVENT( "psi_t_10_sec expired when t3174 is running" );
+    return;
+  }
+
+  switch( GET_STATE( PSI ) )  
+  {            
+    case PSI_IDLE:
+    case PSI_TRANSFER:
+      psi_stop_10sec();
+      /*  If the mobile station has not received the required messages within 10 seconds
+       *  after the start of the acquisition procedure, an attempt to receive a missing message
+       *  shall be made each time the message is scheduled on the broadcast channel.
+       *  This case should not happen -except the network goes down. Reason:
+       *  in case of partial or complete acquisition we read all required (P)SI messages
+       *  each time the message is scheduled on the broadcast channel. Our reading process
+       *  continues until the 60 second   expires or we receive the required messages.
+       *  If the 60 second timer expires we should perform a cell selection
+       */
+      psi_update_data_to_request(INIT_NOT_NEEDED );
+      switch(psc_db->acq_type)
+        {
+          case COMPLETE:
+            psi_complete_acq(COMPLETE);
+            break;
+          case PARTIAL:
+            psi_partial_acq();
+            psc_db->send_psi_status = TRUE; /* this parameters has meaning if the network supports PSI STATUS */
+            break;
+          default:
+            TRACE_ERROR("Unknown acq_type in T_10_sec (PBCCH)");
+            break;
+        }
+        break;
+    case PSI_BCCH_IDLE:
+    case PSI_BCCH_TRANSFER:
+      psi_stop_10sec();
+      /*  Please see comment above */
+      switch(psc_db->acq_type)
+        {
+          case COMPLETE:
+            sig_psi_ctrl_read_si(COMPLETE_SI);
+            break;
+          case PARTIAL:
+            sig_psi_ctrl_read_si(psc_db->si_to_acquire);
+            break;
+          default:
+            TRACE_ERROR("Unknown acq_type in T_10_sec (BCCH)");
+            break;
+        }
+        break;
+      default:
+        TRACE_ERROR( "T_10_SEC unexpected" );
+        break;
+	
+  }
+/*#endif*/
+} /* psi_t_10_sec() */
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : psi_complete_psi_read_failed
++------------------------------------------------------------------------------
+| Description : Handles the primitive PSI_COMPLETE_PSI_READ_FAILED
+|
+| Parameters  : void
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void psi_complete_psi_read_failed ( void )
+{
+  TRACE_FUNCTION( "psi_complete_psi_read_failed" );
+  /*
+   * reading of complete PSI within 10 sec failed
+   * Stop PBCCH reading if running,
+   * Inform CTRL, cell reselection should be performed
+   */
+  TRACE_EVENT("reading of complete PSI within 10 sec failed");
+
+  if( grr_t_status( T3174 ) > 0 )
+  {
+	  TRACE_EVENT( "psi_complete_psi expired when t3174 is running" );
+    return;
+  }
+
+  SET_STATE( PSI, PSI_NULL );
+  if(psc_db->acq_type NEQ NONE) /* acquisition has been running, so we have to stop this acq.*/
+  {
+    TRACE_EVENT("psi_stop_psi_reading");
+    psi_stop_psi_reading(NONE);
+  }
+  
+  psi_stop_timer();
+  psi_reset_all();
+  /*
+   * Perform CR
+   */
+  sig_psi_ctrl_psi1or_psi13_receiption_failure();
+  
+} /* psi_complete_psi_read_failed() */