diff g23m/condat/ms/src/aci/ati_lcs.c @ 0:509db1a7b7b8

initial import: leo2moko-r1
author Space Falcon <falcon@ivan.Harhan.ORG>
date Mon, 01 Jun 2015 03:24:05 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/g23m/condat/ms/src/aci/ati_lcs.c	Mon Jun 01 03:24:05 2015 +0000
@@ -0,0 +1,471 @@
+/* 
++----------------------------------------------------------------------------- 
+|  Project :  GSM-F&D (8411)
+|  Modul   :  ATI
++----------------------------------------------------------------------------- 
+|  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 :  AT Command Interpreter: Location service related commands.
++----------------------------------------------------------------------------- 
+*/ 
+
+#ifndef ATI_LCS_C
+#define ATI_LCS_C
+
+#ifdef FF_EOTD
+
+#undef DUMMY_ATI_STRINGS
+
+#ifdef MFW
+#define ENTITY_MFW
+#else
+#ifdef SMI
+#define ENTITY_SMI
+#else
+#define ENTITY_ACI
+#endif
+#endif
+#define ACI_MEMBER
+
+
+#if 0
+#include <string.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <ctype.h>
+#include "typedefs.h"
+#include "pconst.cdg"
+#include "mconst.cdg"
+#include "message.h"
+#include "ccdapi.h"
+#include "vsi.h"
+#include "custom.h"
+#include "gsm.h"
+#include "prim.h"
+#include "cnf_aci.h"
+#include "mon_aci.h"
+#include "pei.h"
+#include "tok.h"
+#include "aci_cmh.h"
+#include "ati_cmd.h"
+#include "aci_io.h"
+#include "aci_cmd.h"
+#include "l4_tim.h"
+#include "psa_uart.h"
+#include "ati_io.h"
+#include "aci.h"
+#include "aci_mem.h"
+#endif
+
+#include "aci_all.h"
+/*==== INCLUDES ===================================================*/
+#include "aci_cmh.h"
+#include "ati_cmd.h"
+#include "aci_cmd.h"
+#include "dti.h"      /* functionality of the dti library */
+
+#include "aci_lst.h"
+#include "dti_conn_mng.h"
+#ifdef UART
+#include "psa_uart.h"
+#include "cmh_uart.h"
+#endif
+#include "aci_io.h"
+#include "aci_mem.h"
+#include "aci.h"
+#include "ati_io.h"
+#include "ati_int.h"
+
+EXTERN T_ACI_LIST *ati_src_list;
+
+/*==== EXPORT ==================================================*/
+EXTERN CHAR  *cmdCmsError ( T_ACI_CMS_ERR e );
+EXTERN CHAR  *cmdExtError (T_ACI_EXT_ERR e);
+EXTERN CHAR  *parse(CHAR *b,CHAR *f, ...);
+
+/*==============================================================*/
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : setatPlusCLSA      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLSA command
+            for test of location service
+            set source and destination addresses of
+            Mobile Location Center
+*/
+
+GLOBAL T_ATI_RSLT setatPlusCLSA   (char *cl, UBYTE srcId)
+{
+  T_ACI_RETURN  ret;
+  char          mlcs[MAX_SMS_ADDR_DIG]; /* MLC source address */
+  char          mlcd[MAX_SMS_ADDR_DIG]; /* MLC destination address */
+  memset (mlcs, 0, sizeof(mlcs));
+  memset (mlcd, 0, sizeof(mlcd));
+
+  TRACE_FUNCTION("setatPlusCLSA()");
+
+   /* parse source and destination address strings */
+   cl = parse(cl,"qq",(LONG)MAX_SMS_ADDR_DIG,mlcs,(LONG)MAX_SMS_ADDR_DIG,mlcd);
+   if (!cl OR (mlcs[0] EQ '\0') OR (mlcd[0] EQ '\0'))
+   {
+      cmdExtError(EXT_ERR_LCS_CmdNotRec);
+      return ATI_FAIL;
+   }
+   /* store source and destination MLC addresses */
+   ret=sAT_PlusCLSA(srcId,mlcs,mlcd);
+   if (ret EQ AT_FAIL)
+   {
+     cmdCmeError(CME_ERR_Unknown);
+     return ATI_FAIL;
+   }
+
+  return ATI_CMPL;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : queatPlusCLSA      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLSA command
+            for test of location service
+            query source and destination addresses of
+            Service Mobile Location Center
+*/
+
+GLOBAL T_ATI_RSLT queatPlusCLSA   (char *cl, UBYTE srcId)
+{
+  char          mlcs[MAX_SMS_ADDR_DIG]; /* MLC source address */
+  char          mlcd[MAX_SMS_ADDR_DIG]; /* MLC destination address */
+  memset (mlcs, 0, sizeof(mlcs));
+  memset (mlcd, 0, sizeof(mlcd));
+
+  TRACE_FUNCTION("queatPlusCLSA()");
+
+  if (qAT_PlusCLSA(srcId,mlcs,mlcd) EQ AT_CMPL)
+  {
+    sprintf(g_sa,"+CLSA:%s,%s",mlcs,mlcd);
+
+    io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+  }
+  else
+  {
+    cmdCmeError(CME_ERR_Unknown);
+    return ATI_FAIL;
+  }
+  return ATI_CMPL;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : setatPlusCLOM      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLOM command
+            set feature flag Location Service
+            handle list of LC clients
+            store list in FFS
+*/
+
+GLOBAL T_ATI_RSLT setatPlusCLOM   (char *cl, UBYTE srcId)
+{
+  T_ACI_RETURN  ret;
+  char          client_id[MAX_SMS_ADDR_DIG]; /* Client identifier */
+  char          clom_set;
+
+  TRACE_FUNCTION("setatPlusCLOM()");
+
+  memset (client_id, 0, sizeof(client_id));
+
+   /* parse CLOM setting and Client Id (optional) */
+   cl = parse(cl,"xq",&clom_set,(LONG)MAX_SMS_ADDR_DIG,client_id);
+   if (!cl)
+   {
+      cmdExtError(EXT_ERR_LCS_CmdNotRec);;
+      return ATI_FAIL;
+   }
+   /* handle settings and store in FFS */
+   ret=sAT_PlusCLOM(srcId,clom_set,client_id);
+   if (ret EQ AT_FAIL)
+   {
+     cmdCmeError(CME_ERR_Unknown);
+     return ATI_FAIL;
+   }
+
+  return ATI_CMPL;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : queatPlusCLOM      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLOM command
+            query current Operational Mode settings of
+            Location Service
+*/
+/**************************/
+EXTERN T_LOC_SERV_PARA   locServPrm;  /* list of LC clients */
+EXTERN BOOL location_service_flag;
+EXTERN BOOL eotd_periodic_update_flag;
+/**************************/
+GLOBAL T_ATI_RSLT queatPlusCLOM   (char *cl, UBYTE srcId)
+{
+  UBYTE num_clients;
+  T_LOC_SERV_PARA *lc_client_list = 0;
+  T_LOC_SERV_CLIENT *lc_client = 0;
+
+  TRACE_FUNCTION("queatPlusCLOM()");
+TRACE_EVENT_P4("num_client=%d location_service_flag=%d eotd_periodic_update_flag=%d clients=%08x",
+                locServPrm.numb_lc_clients,
+                location_service_flag,
+                eotd_periodic_update_flag,
+                locServPrm.clients);
+if (locServPrm.clients)
+{
+  lc_client = locServPrm.clients;
+  while (lc_client)
+  {
+    TRACE_EVENT_P4("client status=%d addr=%s ton=%d npi=%d", lc_client->client_status,
+                    lc_client->client_id.address,
+                    lc_client->client_id.toa.ton,
+                    lc_client->client_id.toa.npi);
+    lc_client = lc_client->next;
+  }
+  lc_client = 0;
+}
+TRACE_EVENT_P6("SC_sAddr=%s ton=%d npi=%d SC_dAddr=%s ton=%d npi=%d",
+                locServPrm.mlcsrc.address,  locServPrm.mlcsrc.toa.ton,  locServPrm.mlcsrc.toa.npi,
+                locServPrm.mlcdest.address, locServPrm.mlcdest.toa.ton, locServPrm.mlcdest.toa.npi);
+
+  if (qAT_PlusCLOM(srcId,&num_clients,&lc_client_list) EQ AT_CMPL)
+  {
+    if(lc_client_list EQ NULL)
+    {
+        cmdCmeError(CME_ERR_Unknown);
+        return ATI_FAIL;
+    }
+    if(!num_clients) /* list of clients is empty */
+    {
+        sprintf(g_sa,"+CLOM:%d",num_clients);
+        io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+    }
+    else
+    {
+        sprintf(g_sa,"+CLOM:%d",num_clients);
+        lc_client = lc_client_list->clients;
+        io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+        memset(g_sa,0,(KEY + 2*MAX_SMS_ADDR_DIG));
+        while(num_clients)
+        {
+          if(lc_client->client_id.toa.ton EQ TON_International)
+                sprintf(g_sa,"%d,+%s",lc_client->client_status,lc_client->client_id.address);
+          else
+               sprintf(g_sa,"%d,%s",lc_client->client_status,lc_client->client_id.address);
+          lc_client = lc_client->next;
+          io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+          memset(g_sa,0,(KEY + 2*MAX_SMS_ADDR_DIG));
+          num_clients--;
+      }
+    }
+  }
+  else
+  {
+    cmdCmeError(CME_ERR_Unknown);
+    return ATI_FAIL;
+  }
+  return ATI_CMPL;
+}
+
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD                                  |
+| STATE   : code                        ROUTINE : setatPlusCLPS                                     |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLPS command
+            set feature flag Periodic Update Timer
+            set timer for specific LC client
+            request position data
+*/
+
+GLOBAL T_ATI_RSLT setatPlusCLPS   (char *cl, UBYTE srcId)
+{
+  T_ACI_RETURN  ret;
+  char          client_id[MAX_SMS_ADDR_DIG]; /* Client identifier */
+  char          clps_set;
+  T_ATI_SRC_PARAMS *src_params = find_element (ati_src_list, srcId, search_ati_src_id);
+  USHORT         lc_timer = 0;
+
+  TRACE_FUNCTION("setatPlusCLPS()");
+
+  memset (client_id, 0, sizeof(client_id));
+
+   /* parse CLPS setting,Client Id (optional) and Client timer (optional) */
+   cl = parse(cl,"xqr",&clps_set,(LONG)MAX_SMS_ADDR_DIG,client_id,&lc_timer);
+   if (!cl)
+   {
+      cmdExtError(EXT_ERR_LCS_CmdNotRec);
+      return ATI_FAIL;
+   }
+   /* handle settings and store in FFS */
+   ret=sAT_PlusCLPS(srcId,clps_set,client_id,lc_timer);
+   if (ret EQ AT_FAIL)
+   {
+     cmdCmeError(CME_ERR_Unknown);
+     return ATI_FAIL;
+   }
+
+  return ATI_CMPL;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : queatPlusCLPS      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLPS command
+            query periodic update settings
+*/
+
+GLOBAL T_ATI_RSLT queatPlusCLPS   (char *cl, UBYTE srcId)
+{
+  UBYTE num_clients,num_clients_test,num_per_clients=0;
+  T_LOC_SERV_PARA *lc_client_list = 0;
+  T_LOC_SERV_CLIENT *lc_client = 0;
+
+  TRACE_FUNCTION("queatPlusCLPS()");
+
+  if (qAT_PlusCLPS(srcId,&num_clients,&lc_client_list) EQ AT_CMPL)
+  {
+      if(lc_client_list EQ NULL)
+      {
+          cmdCmeError(CME_ERR_Unknown);
+          return ATI_FAIL;
+      }
+      if(!num_clients) /* list of clients is empty */
+      {
+        sprintf(g_sa,"+CLPS:%d",num_clients);
+        io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+      }
+      else
+      {
+          lc_client = lc_client_list->clients;
+          num_clients_test = num_clients;
+          while(num_clients_test)
+          {
+              if(lc_client->period_upd_status EQ PERIODIC_UP_ACTIVE)
+                  num_per_clients++;
+              lc_client = lc_client->next;
+              num_clients_test--;
+          }
+
+        sprintf(g_sa,"+CLPS:%d",num_per_clients);
+        io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+        memset(g_sa,0,(KEY + 2*MAX_SMS_ADDR_DIG));
+        lc_client = lc_client_list->clients;
+        while(num_clients)
+        {
+          if(lc_client->client_id.toa.ton EQ TON_International)
+          {
+              if(lc_client->period_upd_status EQ PERIODIC_UP_ACTIVE)
+                 sprintf(g_sa,"+%s,%d",lc_client->client_id.address,lc_client->period_upd_value);
+          }
+          else
+          {
+              if(lc_client->period_upd_status EQ PERIODIC_UP_ACTIVE)
+                 sprintf(g_sa,"%s,%d",lc_client->client_id.address,lc_client->period_upd_value);
+          }
+          lc_client = lc_client->next;
+          io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT);
+          memset(g_sa,0,(KEY + 2*MAX_SMS_ADDR_DIG));
+          num_clients--;
+      }
+    }
+  }
+  else
+  {
+    cmdCmeError(CME_ERR_Unknown);
+    return ATI_FAIL;
+  }
+  return ATI_CMPL;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)                                    MODULE  : ACI_CMD            |
+| STATE   : code                                                       ROUTINE : setatPlusCLSR      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLSR command
+                  set user privacy data: notify, confirmation
+                  request position data: currently not supported (RM 10-25-02)
+                  set up call to client_id and/or to second address:
+                  currently not supported (RM 10-25-02)
+*/
+
+GLOBAL T_ATI_RSLT setatPlusCLSR   (char *cl, UBYTE srcId)
+{
+  T_ACI_RETURN  ret;
+  char          client_id[MAX_SMS_ADDR_DIG]; /* Client identifier */
+  char          clsr_notify;
+  char          clsr_confirmation;
+
+  TRACE_FUNCTION("setatPlusCLSR()");
+
+  memset (client_id, 0, sizeof(client_id));
+
+  /* parse CLSR settings: Client notify state, Client confirmation state, Client Id  */
+  cl = parse(cl,"xxq",&clsr_notify,&clsr_confirmation,(LONG)MAX_SMS_ADDR_DIG,client_id);
+  if (!cl)
+  {
+    cmdExtError(EXT_ERR_LCS_CmdNotRec);
+    return ATI_FAIL;
+  }
+  /* handle settings and store in FFS */
+  ret=sAT_PlusCLSR(srcId,clsr_notify,clsr_confirmation,client_id);
+  if (ret EQ AT_FAIL)
+  {
+    cmdCmeError(CME_ERR_Unknown);
+    return ATI_FAIL;
+  }
+  return ATI_CMPL;
+}
+
+/*
++--------------------------------------------------------------------+
+| PROJECT : GSM-F&D (8411)              MODULE  : ACI_CMD            |
+| STATE   : code                        ROUTINE : queatPlusCLSR      |
++--------------------------------------------------------------------+
+
+  PURPOSE : +CLSR command
+            query
+*/
+
+GLOBAL T_ATI_RSLT queatPlusCLSR   (char *cl, UBYTE srcId)
+{
+return ATI_CMPL;
+}
+
+#endif /* FF_EOTD */
+
+#endif /* ATI_LCS_C */