diff gsm-fw/g23m-aci/uart/uart_dtxf.c @ 775:eedbf248bac0

gsm-fw/g23m-aci subtree: initial import from LoCosto source
author Michael Spacefalcon <msokolov@ivan.Harhan.ORG>
date Sun, 12 Oct 2014 01:45:14 +0000
parents
children f54080301c98
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/gsm-fw/g23m-aci/uart/uart_dtxf.c	Sun Oct 12 01:45:14 2014 +0000
@@ -0,0 +1,349 @@
+/*
++-----------------------------------------------------------------------------
+|  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 modul is part of the entity UART and implements all
+|             procedures and functions as described in the
+|             SDL-documentation (DTX-statemachine)
++-----------------------------------------------------------------------------
+*/
+
+#ifndef UART_DTXF_C
+#define UART_DTXF_C
+#endif /* !UART_DTXF_C */
+
+#define ENTITY_UART
+
+/*==== INCLUDES =============================================================*/
+
+#ifdef WIN32
+#include "nucleus.h"
+#endif /* WIN32 */
+#include "typedefs.h"   /* to get Condat data types */
+#include "vsi.h"        /* to get a lot of macros */
+#include "macdef.h"     /* to get a lot of macros */
+#include "custom.h"
+#include "gsm.h"        /* to get a lot of macros */
+#include "cnf_uart.h"   /* to get cnf-definitions */
+#include "mon_uart.h"   /* to get mon-definitions */
+#include "prim.h"       /* to get the definitions of used SAP and directions */
+#include "dti.h"        /* to get dti lib */
+#include "pei.h"        /* to get PEI interface */
+#ifdef FF_MULTI_PORT
+#include "gsi.h"        /* to get definitions of serial driver */
+#else /* FF_MULTI_PORT */
+#ifdef _TARGET_
+#include "uart/serialswitch.h"
+#include "uart/traceswitch.h"
+#else /* _TARGET_ */
+#include "serial_dat.h" /* to get definitions of serial driver */
+#endif /* _TARGET_ */
+#endif /* FF_MULTI_PORT */
+#include "uart.h"       /* to get the global entity definitions */
+
+/*==== CONST ================================================================*/
+
+/*
+ * names of escape sequence detection state machine
+ */
+#ifdef _SIMULATION_
+char * uart_esd_state_names[] =
+{
+  "UART_ESD_NULL",
+  "UART_ESD_CHAR_1",
+  "UART_ESD_CHAR_2",
+  "UART_ESD_CHAR_3",
+  "UART_ESD_DETECTED"
+};
+#endif /* _SIMULATION_ */
+
+/*==== LOCAL VARS ===========================================================*/
+
+/*==== PRIVATE FUNCTIONS ====================================================*/
+
+/*==== PUBLIC FUNCTIONS =====================================================*/
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_get_esd_state
++------------------------------------------------------------------------------
+| Description : This function returns the current state of the Escape Sequence
+|               Detection.
+|
+| Parameters  : none
+|
+| Return      : ESD State
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL T_ESD_STATE dtx_get_esd_state()
+{
+  TRACE_FUNCTION ("dtx_get_esd_state");
+
+#ifdef _SIMULATION_
+  TRACE_EVENT_P1 ("esd_state is [%s]",
+                  uart_esd_state_names[uart_data->dtx->esd_state]);
+#endif /* _SIMULATION_ */
+
+  return uart_data->dtx->esd_state;
+} /* dtx_get_esd_state() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_set_esd_state
++------------------------------------------------------------------------------
+| Description : This function sets the state of the Escape Sequence Detection.
+|
+| Parameters  : new ESD State
+|
+| Return      : none
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_set_esd_state( T_ESD_STATE new_esd_state )
+{
+  TRACE_FUNCTION ("dtx_set_esd_state");
+
+#ifdef _SIMULATION_
+  if(uart_data->dtx->esd_state != new_esd_state)
+  {
+    TRACE_EVENT_P2 ("esd_state [%s] -> [%s]",
+                    uart_esd_state_names[uart_data->dtx->esd_state],
+                    uart_esd_state_names[new_esd_state]);
+    uart_data->dtx->esd_state = new_esd_state;
+    uart_data->dtx->esd_state_name = uart_esd_state_names[new_esd_state];
+  }
+  else
+  {
+    TRACE_EVENT_P1 ("esd_state remains [%s]",
+                    uart_esd_state_names[uart_data->dtx->esd_state]);
+  }
+#else /* _SIMULATION_ */
+  if(uart_data->dtx->esd_state != new_esd_state)
+    uart_data->dtx->esd_state = new_esd_state;
+#endif /* _SIMULATION_ */
+} /* dtx_set_esd_state() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_init
++------------------------------------------------------------------------------
+| Description : The function dtx_init() initializes the service DTX
+|
+| Parameters  : none
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_init ()
+{
+  USHORT i;
+
+  TRACE_FUNCTION( "dtx_init" );
+
+  for( i = 0; i < UART_MAX_NUMBER_OF_CHANNELS; i++ )
+  {
+    /*
+     * select next instance of service DTX
+     */
+    uart_data->dtx = &( uart_data->dtx_base[i] );
+
+    /*
+     * initialize service specific variables
+     */
+    uart_data->dtx->to_send_data  = NULL;
+    uart_data->dtx->cur_desc_size = 0;
+    uart_data->dtx->write_pos     = 0;
+    uart_data->dtx->size_multiplier   = 3;
+    uart_data->dtx->st_flow           = DTI_FLOW_ON;
+    uart_data->dtx->st_line_sa        = DTI_SA_ON;
+    uart_data->dtx->st_line_sb        = DTI_SB_ON;
+    uart_data->dtx->st_break_len      = DTI_BREAK_OFF;
+    uart_data->dtx->detect_escape     = TRUE;
+    uart_data->dtx->lines_changed     = FALSE;
+    uart_data->dtx->receiving_state   = UART_DTX_NOT_RECEIVING;
+    uart_data->dtx->data_flow         = UART_FLOW_DISABLED;
+    dtx_set_esd_state( UART_ESD_NULL );
+    uart_data->dtx->esd_guard_time    = 0;
+    uart_data->dtx->esd_pos           = 0;
+    uart_data->dtx->dti_dtx_state = DTI_CLOSED;
+
+    INIT_STATE( UART_SERVICE_DTX , DTX_DEAD );
+  }
+} /* dtx_init() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_free_resources
++------------------------------------------------------------------------------
+| Description : The function dtx_free_resources() frees the currently allocated
+|               resources of the service DTX.
+|
+| Parameters  : none
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_free_resources ()
+{
+  TRACE_FUNCTION( "dtx_free_resources()" );
+
+  /*
+   * free all resources
+   */
+  if(uart_data->dtx->to_send_data)
+  {
+    MFREE_DESC2( uart_data->dtx->to_send_data );
+    uart_data->dtx->to_send_data  = NULL;
+  }
+  uart_data->dtx->cur_desc_size = 0;
+  uart_data->dtx->write_pos     = 0;
+
+} /* dtx_free_resources() */
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_exit
++------------------------------------------------------------------------------
+| Description : The function dtx_exit() frees the currently allocated
+|               resources of the service DTX.
+|
+| Parameters  : none
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_exit ()
+{
+  ULONG i;
+
+  TRACE_FUNCTION( "dtx_exit()" );
+
+  /*
+   * free all resources
+   */
+  if(uart_data->dtx->to_send_data)
+  {
+    MFREE_DESC2( uart_data->dtx->to_send_data );
+    uart_data->dtx->to_send_data  = NULL;
+  }
+  uart_data->dtx->cur_desc_size = 0;
+  uart_data->dtx->write_pos     = 0;
+
+  if(uart_data->ker.tx_data_waiting)
+  {
+    MFREE_DESC2(uart_data->ker.tx_data_waiting);
+    uart_data->ker.tx_data_waiting = NULL;
+  }
+  for(i = 0; i < UART_MAX_NUMBER_OF_CHANNELS; i++)
+  {
+    if(uart_data->dlc_table[i].transmit_data)
+    {
+      MFREE_DESC2(uart_data->dlc_table[i].transmit_data);
+      uart_data->dlc_table[i].transmit_data = NULL;
+    }
+
+    if(uart_data->dlc_table[i].receive_data)
+    {
+      MFREE_DESC2(uart_data->dlc_table[i].receive_data);
+      uart_data->dlc_table[i].receive_data = NULL;
+    }
+  }
+
+} /* dtx_exit() */
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_allocate_resources
++------------------------------------------------------------------------------
+| Description : The function dtx_allocate_resources() allocates a new set of
+|               resources for the service DTX.
+|
+| Parameters  : none
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_allocate_resources ()
+{
+  TRACE_FUNCTION( "dtx_allocate_resources()" );
+
+  /*
+   * allocate a new descriptor
+   * with a size of: size_multiplier * N1 (frame size)
+   */
+  uart_data->dtx->cur_desc_size = uart_data->n1 *
+                                  uart_data->dtx->size_multiplier;
+  MALLOC(uart_data->dtx->to_send_data,
+         (USHORT)(sizeof(T_desc2) - 1 + uart_data->dtx->cur_desc_size));
+  uart_data->dtx->to_send_data->len  = 0;
+  uart_data->dtx->to_send_data->size  = 0;
+  uart_data->dtx->to_send_data->offset  = 0;
+  uart_data->dtx->to_send_data->next = (ULONG) NULL;
+  uart_data->dtx->write_pos          = 0;
+} /* dtx_allocate_resources() */
+
+
+
+/*
++------------------------------------------------------------------------------
+| Function    : dtx_calculate_size_multiplier
++------------------------------------------------------------------------------
+| Description : The function dtx_calculate_size_multiplier() calculates the new
+|               size_multiplier value.
+|
+| Parameters  : desc_to_send - data descriptor that should be sent
+|               data_flow    - state of data flow befor we want to sent
+|
++------------------------------------------------------------------------------
+*/
+GLOBAL void dtx_calculate_size_multiplier (T_desc2* desc_to_send,
+                                           T_DATA_FLOW_STATE data_flow)
+{
+  TRACE_FUNCTION( "dtx_calculate_size_multiplier()" );
+
+  /*
+   * calculate new size multiplier according to fillrate of buffer
+   */
+  if((uart_data->dtx->size_multiplier < UART_DTX_MAX_SIZE_MULTIPLIER ) &&
+     (data_flow EQ UART_FLOW_DISABLED))
+  {
+    /*
+     * buffer is rather full, so increase the multiplier
+     */
+#ifdef _SIMULATION_
+    TRACE_EVENT( " sig_rx_dtx_data_received_ind(): buffer size_multiplier increased " );
+#endif /* _SIMULATION_ */
+    uart_data->dtx->size_multiplier++;
+  }
+  else if((uart_data->dtx->size_multiplier > 3) &&
+          (data_flow EQ UART_FLOW_ENABLED)  &&
+          ((uart_data->dtx->cur_desc_size - desc_to_send->len) >
+           ((USHORT)uart_data->n1 << 1)))
+  {
+    /*
+     * buffer is rather empty, so decrease the multiplier
+     */
+#ifdef _SIMULATION_
+    TRACE_EVENT( " sig_rx_dtx_data_received_ind(): buffer size_multiplier decreased " );
+#endif /* _SIMULATION_ */
+    uart_data->dtx->size_multiplier--;
+  }
+} /* dtx_calculate_size_multiplier() */